index.vue 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266
  1. <script lang="ts" setup>
  2. import type {
  3. WorkbenchProjectItem,
  4. WorkbenchQuickNavItem,
  5. WorkbenchTodoItem,
  6. WorkbenchTrendItem,
  7. } from '@vben/common-ui';
  8. import { ref } from 'vue';
  9. import { useRouter } from 'vue-router';
  10. import {
  11. AnalysisChartCard,
  12. WorkbenchHeader,
  13. WorkbenchProject,
  14. WorkbenchQuickNav,
  15. WorkbenchTodo,
  16. WorkbenchTrends,
  17. } from '@vben/common-ui';
  18. import { preferences } from '@vben/preferences';
  19. import { useUserStore } from '@vben/stores';
  20. import { openWindow } from '@vben/utils';
  21. import AnalyticsVisitsSource from '../analytics/analytics-visits-source.vue';
  22. const userStore = useUserStore();
  23. // 这是一个示例数据,实际项目中需要根据实际情况进行调整
  24. // url 也可以是内部路由,在 navTo 方法中识别处理,进行内部跳转
  25. // 例如:url: /dashboard/workspace
  26. const projectItems: WorkbenchProjectItem[] = [
  27. {
  28. color: '',
  29. content: '不要等待机会,而要创造机会。',
  30. date: '2021-04-01',
  31. group: '开源组',
  32. icon: 'carbon:logo-github',
  33. title: 'Github',
  34. url: 'https://github.com',
  35. },
  36. {
  37. color: '#3fb27f',
  38. content: '现在的你决定将来的你。',
  39. date: '2021-04-01',
  40. group: '算法组',
  41. icon: 'ion:logo-vue',
  42. title: 'Vue',
  43. url: 'https://vuejs.org',
  44. },
  45. {
  46. color: '#e18525',
  47. content: '没有什么才能比努力更重要。',
  48. date: '2021-04-01',
  49. group: '上班摸鱼',
  50. icon: 'ion:logo-html5',
  51. title: 'Html5',
  52. url: 'https://developer.mozilla.org/zh-CN/docs/Web/HTML',
  53. },
  54. {
  55. color: '#bf0c2c',
  56. content: '热情和欲望可以突破一切难关。',
  57. date: '2021-04-01',
  58. group: 'UI',
  59. icon: 'ion:logo-angular',
  60. title: 'Angular',
  61. url: 'https://angular.io',
  62. },
  63. {
  64. color: '#00d8ff',
  65. content: '健康的身体是实现目标的基石。',
  66. date: '2021-04-01',
  67. group: '技术牛',
  68. icon: 'bx:bxl-react',
  69. title: 'React',
  70. url: 'https://reactjs.org',
  71. },
  72. {
  73. color: '#EBD94E',
  74. content: '路是走出来的,而不是空想出来的。',
  75. date: '2021-04-01',
  76. group: '架构组',
  77. icon: 'ion:logo-javascript',
  78. title: 'Js',
  79. url: 'https://developer.mozilla.org/zh-CN/docs/Web/JavaScript',
  80. },
  81. ];
  82. // 同样,这里的 url 也可以使用以 http 开头的外部链接
  83. const quickNavItems: WorkbenchQuickNavItem[] = [
  84. {
  85. color: '#1fdaca',
  86. icon: 'ion:home-outline',
  87. title: '首页',
  88. url: '/',
  89. },
  90. {
  91. color: '#bf0c2c',
  92. icon: 'ion:grid-outline',
  93. title: '仪表盘',
  94. url: '/dashboard',
  95. },
  96. {
  97. color: '#e18525',
  98. icon: 'ion:layers-outline',
  99. title: '组件',
  100. url: '/demos/features/icons',
  101. },
  102. {
  103. color: '#3fb27f',
  104. icon: 'ion:settings-outline',
  105. title: '系统管理',
  106. url: '/demos/features/login-expired', // 这里的 URL 是示例,实际项目中需要根据实际情况进行调整
  107. },
  108. {
  109. color: '#4daf1bc9',
  110. icon: 'ion:key-outline',
  111. title: '权限管理',
  112. url: '/demos/access/page-control',
  113. },
  114. {
  115. color: '#00d8ff',
  116. icon: 'ion:bar-chart-outline',
  117. title: '图表',
  118. url: '/analytics',
  119. },
  120. ];
  121. const todoItems = ref<WorkbenchTodoItem[]>([
  122. {
  123. completed: false,
  124. content: `审查最近提交到Git仓库的前端代码,确保代码质量和规范。`,
  125. date: '2024-07-30 11:00:00',
  126. title: '审查前端代码提交',
  127. },
  128. {
  129. completed: true,
  130. content: `检查并优化系统性能,降低CPU使用率。`,
  131. date: '2024-07-30 11:00:00',
  132. title: '系统性能优化',
  133. },
  134. {
  135. completed: false,
  136. content: `进行系统安全检查,确保没有安全漏洞或未授权的访问。 `,
  137. date: '2024-07-30 11:00:00',
  138. title: '安全检查',
  139. },
  140. {
  141. completed: false,
  142. content: `更新项目中的所有npm依赖包,确保使用最新版本。`,
  143. date: '2024-07-30 11:00:00',
  144. title: '更新项目依赖',
  145. },
  146. {
  147. completed: false,
  148. content: `修复用户报告的页面UI显示问题,确保在不同浏览器中显示一致。 `,
  149. date: '2024-07-30 11:00:00',
  150. title: '修复UI显示问题',
  151. },
  152. ]);
  153. const trendItems: WorkbenchTrendItem[] = [
  154. {
  155. avatar: 'svg:avatar-1',
  156. content: `在 <a>开源组</a> 创建了项目 <a>Vue</a>`,
  157. date: '刚刚',
  158. title: '威廉',
  159. },
  160. {
  161. avatar: 'svg:avatar-2',
  162. content: `关注了 <a>威廉</a> `,
  163. date: '1个小时前',
  164. title: '艾文',
  165. },
  166. {
  167. avatar: 'svg:avatar-3',
  168. content: `发布了 <a>个人动态</a> `,
  169. date: '1天前',
  170. title: '克里斯',
  171. },
  172. {
  173. avatar: 'svg:avatar-4',
  174. content: `发表文章 <a>如何编写一个Vite插件</a> `,
  175. date: '2天前',
  176. title: 'Vben',
  177. },
  178. {
  179. avatar: 'svg:avatar-1',
  180. content: `回复了 <a>杰克</a> 的问题 <a>如何进行项目优化?</a>`,
  181. date: '3天前',
  182. title: '皮特',
  183. },
  184. {
  185. avatar: 'svg:avatar-2',
  186. content: `关闭了问题 <a>如何运行项目</a> `,
  187. date: '1周前',
  188. title: '杰克',
  189. },
  190. {
  191. avatar: 'svg:avatar-3',
  192. content: `发布了 <a>个人动态</a> `,
  193. date: '1周前',
  194. title: '威廉',
  195. },
  196. {
  197. avatar: 'svg:avatar-4',
  198. content: `推送了代码到 <a>Github</a>`,
  199. date: '2021-04-01 20:00',
  200. title: '威廉',
  201. },
  202. {
  203. avatar: 'svg:avatar-4',
  204. content: `发表文章 <a>如何编写使用 Admin Vben</a> `,
  205. date: '2021-03-01 20:00',
  206. title: 'Vben',
  207. },
  208. ];
  209. const router = useRouter();
  210. // 这是一个示例方法,实际项目中需要根据实际情况进行调整
  211. // This is a sample method, adjust according to the actual project requirements
  212. function navTo(nav: WorkbenchProjectItem | WorkbenchQuickNavItem) {
  213. if (nav.url?.startsWith('http')) {
  214. openWindow(nav.url);
  215. return;
  216. }
  217. if (nav.url?.startsWith('/')) {
  218. router.push(nav.url).catch((error) => {
  219. console.error('Navigation failed:', error);
  220. });
  221. } else {
  222. console.warn(`Unknown URL for navigation item: ${nav.title} -> ${nav.url}`);
  223. }
  224. }
  225. </script>
  226. <template>
  227. <div class="p-5">
  228. <WorkbenchHeader
  229. :avatar="userStore.userInfo?.avatar || preferences.app.defaultAvatar"
  230. >
  231. <template #title>
  232. 早安, {{ userStore.userInfo?.realName }}, 开始您一天的工作吧!
  233. </template>
  234. <template #description> 今日晴,20℃ - 32℃! </template>
  235. </WorkbenchHeader>
  236. <div class="mt-5 flex flex-col lg:flex-row">
  237. <div class="mr-4 w-full lg:w-3/5">
  238. <WorkbenchProject :items="projectItems" title="项目" @click="navTo" />
  239. <WorkbenchTrends :items="trendItems" class="mt-5" title="最新动态" />
  240. </div>
  241. <div class="w-full lg:w-2/5">
  242. <WorkbenchQuickNav
  243. :items="quickNavItems"
  244. class="mt-5 lg:mt-0"
  245. title="快捷导航"
  246. @click="navTo"
  247. />
  248. <WorkbenchTodo :items="todoItems" class="mt-5" title="待办事项" />
  249. <AnalysisChartCard class="mt-5" title="访问来源">
  250. <AnalyticsVisitsSource />
  251. </AnalysisChartCard>
  252. </div>
  253. </div>
  254. </div>
  255. </template>