index.vue 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185
  1. <script setup lang="ts">
  2. import { useUserStoreWithOut } from "@/stores/modules/user";
  3. import { getAssetsURI, getStoreObject } from "@/utils/common";
  4. import { getAttendCount, createProcessByModalId } from "@/service/flow";
  5. import request 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 = reactive<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. path: "myDailyLogs",
  34. },
  35. {
  36. title: "我的周报",
  37. icon: "../assets/images/wdrz_icon.png",
  38. path: "myWeeklyLogs",
  39. },
  40. ]);
  41. interface ProcessMenuItem extends MenuItem {
  42. instanceId: string;
  43. }
  44. const processMenus: ProcessMenuItem[] = [
  45. {
  46. title: "请假申请",
  47. corner: 0,
  48. icon: "../assets/images/qjsq_icon.png",
  49. instanceId: "018c1f593f2c09477b1b8c1080b6000b",
  50. },
  51. {
  52. title: "出差申请",
  53. corner: 0,
  54. icon: "../assets/images/ccsq_icon.png",
  55. instanceId: "018c389986fb0947969a8c33d89b000a",
  56. },
  57. {
  58. title: "考情说明条",
  59. corner: 0,
  60. icon: "../assets/images/kqsmt_icon.png",
  61. instanceId: "018c24045d65094794178c23e986001e",
  62. },
  63. {
  64. title: "借款申请",
  65. corner: 0,
  66. icon: "../assets/images/jksq_icon.png",
  67. instanceId: "018e36519fd70a0796ba8dd062c80830",
  68. },
  69. ];
  70. const personMenus: MenuItem[] = [
  71. {
  72. title: "我的资产",
  73. path: "assetMy",
  74. icon: "../assets/images/wdzc_icon.png",
  75. },
  76. {
  77. title: "通知公告",
  78. path: 'notice',
  79. icon: "../assets/images/tzgg_icon.png",
  80. corner: 0
  81. },
  82. ];
  83. const router = useRouter();
  84. /***
  85. * 根据用户ID获取待办角标
  86. */
  87. const initAttendCount = async () => {
  88. const result = await getAttendCount({
  89. userId: getStoreObject("_userInfo", "id")
  90. })
  91. if (result) {
  92. navMenus[0]['corner'] = result?.data
  93. }
  94. }
  95. initAttendCount()
  96. /**
  97. * 获取通知公告角标
  98. */
  99. async function queryNoticeAndLearnCount() {
  100. const urlApi = `/admin-api/adm/noticeAndLearn/readNo/count`
  101. const result = await request.get(urlApi)
  102. personMenus[1]['corner'] = result?.data
  103. }
  104. queryNoticeAndLearnCount()
  105. const toPageHandle = (path: string) => {
  106. router.push({
  107. path
  108. })
  109. };
  110. const toProcessHandle = (item: ProcessMenuItem): void => {
  111. createProcessByModalId({
  112. templateId: item.instanceId,
  113. }).then((result: any) => {
  114. if (typeof result === "string") {
  115. //@ts-ignore
  116. const arr = result.split(window?.locationBaseUrl)
  117. if (arr.length > 1) {
  118. router.push(arr[1])
  119. }
  120. }
  121. });
  122. };
  123. </script>
  124. <template>
  125. <div class="home_box">
  126. <div class="header">
  127. <div class="nav">
  128. <div class="login_info">
  129. <img src="@/assets/images/user_log.jpg" />
  130. <span>{{ userStore.userInfo.nickname }}</span>
  131. </div>
  132. </div>
  133. <ul>
  134. <li
  135. v-for="(item, index) in navMenus"
  136. :key="index"
  137. @click="toPageHandle(item.path as string)"
  138. >
  139. <img :src="getAssetsURI(item['icon'])" />
  140. <p class="title">{{ item["title"] }}</p>
  141. <span class="corner" v-if="item['corner'] && item['corner'] > 0">{{ item["corner"] }}</span>
  142. </li>
  143. </ul>
  144. </div>
  145. <div class="content">
  146. <div class="card">
  147. <p class="card_title">常用流程</p>
  148. <ul>
  149. <li
  150. v-for="(item, index) in processMenus"
  151. :key="index"
  152. @click="toProcessHandle(item)"
  153. >
  154. <span class="title">{{ item["title"] }}</span>
  155. <img :src="getAssetsURI(item['icon'])" />
  156. </li>
  157. </ul>
  158. </div>
  159. <div class="item">
  160. <p class="card_title">个人中心</p>
  161. <ul>
  162. <li
  163. v-for="(item, index) in personMenus"
  164. :key="index"
  165. @click="toPageHandle(item.path as string)"
  166. >
  167. <img :src="getAssetsURI(item['icon'])" />
  168. <span class="title">{{ item["title"] }}</span>
  169. <span class="corner" v-if="item['corner']">{{
  170. item["corner"]
  171. }}</span>
  172. </li>
  173. </ul>
  174. </div>
  175. </div>
  176. </div>
  177. </template>
  178. <style scoped>
  179. @import "./index.scss";
  180. </style>