index.vue 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161
  1. <script setup lang="ts">
  2. import { useUserStoreWithOut } from "@/stores/modules/user";
  3. import { getAssetsURI } from "@/utils/common";
  4. import { createProcessByModalId } from "@/service/flow";
  5. import reqest from "@/utils/request";
  6. const userStore = useUserStoreWithOut();
  7. interface MenuItem {
  8. title: string;
  9. corner?: number;
  10. path?: string;
  11. icon: string;
  12. }
  13. const navMenus: MenuItem[] = [
  14. {
  15. title: "办件中心",
  16. corner: 1,
  17. path: "/handleCenter",
  18. icon: "../assets/images/bjzx_icon.png",
  19. },
  20. {
  21. title: "日志填写",
  22. icon: "../assets/images/rztx_icon.png",
  23. path: "daily",
  24. },
  25. {
  26. title: "周报填写",
  27. icon: "../assets/images/wdxx_icon.png",
  28. path: "weekly",
  29. },
  30. {
  31. title: "我的日志",
  32. icon: "../assets/images/wdrz_icon.png",
  33. },
  34. {
  35. title: "我的周报",
  36. icon: "../assets/images/wdrz_icon.png",
  37. },
  38. ];
  39. interface ProcessMenuItem extends MenuItem {
  40. instanceId: string;
  41. }
  42. const processMenus: ProcessMenuItem[] = [
  43. {
  44. title: "请假申请",
  45. corner: 0,
  46. icon: "../assets/images/qjsq_icon.png",
  47. instanceId: "018c1f593f2c09477b1b8c1080b6000b",
  48. },
  49. {
  50. title: "出差申请",
  51. corner: 0,
  52. icon: "../assets/images/ccsq_icon.png",
  53. instanceId: "018c389986fb0947969a8c33d89b000a",
  54. },
  55. {
  56. title: "考情说明条",
  57. corner: 0,
  58. icon: "../assets/images/kqsmt_icon.png",
  59. instanceId: "018c24045d65094794178c23e986001e",
  60. },
  61. {
  62. title: "借款申请",
  63. corner: 0,
  64. icon: "../assets/images/jksq_icon.png",
  65. instanceId: "018e36519fd70a0796ba8dd062c80830",
  66. },
  67. ];
  68. const personMenus: MenuItem[] = [
  69. {
  70. title: "我的考勤",
  71. icon: "../assets/images/wdkq_icon.png",
  72. },
  73. {
  74. title: "我的资产",
  75. path: "asset",
  76. icon: "../assets/images/wdzc_icon.png",
  77. },
  78. {
  79. title: "通知公告",
  80. corner: 1,
  81. icon: "../assets/images/tzgg_icon.png",
  82. },
  83. ];
  84. const router = useRouter();
  85. const toPageHandle = (path: string) => {
  86. router.push({
  87. path
  88. })
  89. };
  90. const toProcessHandle = (item: ProcessMenuItem): void => {
  91. createProcessByModalId({
  92. templateId: item.instanceId,
  93. }).then((result: any) => {
  94. if (typeof result === "string") {
  95. location.href=result
  96. }
  97. });
  98. };
  99. </script>
  100. <template>
  101. <div class="home_box">
  102. <div class="header">
  103. <div class="nav">
  104. <div class="login_info">
  105. <img src="@/assets/images/user_log.jpg" />
  106. <span>{{ userStore.userInfo.nickname }}</span>
  107. </div>
  108. </div>
  109. <ul>
  110. <li
  111. v-for="(item, index) in navMenus"
  112. :key="index"
  113. @click="toPageHandle(item.path as string)"
  114. >
  115. <img :src="getAssetsURI(item['icon'])" />
  116. <p class="title">{{ item["title"] }}</p>
  117. <span class="corner" v-if="item['corner']">{{ item["corner"] }}</span>
  118. </li>
  119. </ul>
  120. </div>
  121. <div class="content">
  122. <div class="card">
  123. <p class="card_title">常用流程</p>
  124. <ul>
  125. <li
  126. v-for="(item, index) in processMenus"
  127. :key="index"
  128. @click="toProcessHandle(item)"
  129. >
  130. <span class="title">{{ item["title"] }}</span>
  131. <img :src="getAssetsURI(item['icon'])" />
  132. </li>
  133. </ul>
  134. </div>
  135. <div class="item">
  136. <p class="card_title">个人中心</p>
  137. <ul>
  138. <li
  139. v-for="(item, index) in personMenus"
  140. :key="index"
  141. @click="toPageHandle(item.path as string)"
  142. >
  143. <img :src="getAssetsURI(item['icon'])" />
  144. <span class="title">{{ item["title"] }}</span>
  145. <span class="corner" v-if="item['corner']">{{
  146. item["corner"]
  147. }}</span>
  148. </li>
  149. </ul>
  150. </div>
  151. </div>
  152. </div>
  153. </template>
  154. <style scoped>
  155. @import "./index.scss";
  156. </style>