demos.ts 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347
  1. import type { RouteRecordRaw } from 'vue-router';
  2. import { BasicLayout, IFrameView } from '#/layouts';
  3. import { $t } from '#/locales';
  4. const routes: RouteRecordRaw[] = [
  5. {
  6. component: BasicLayout,
  7. meta: {
  8. icon: 'ic:baseline-view-in-ar',
  9. keepAlive: true,
  10. order: 1000,
  11. title: $t('page.demos.title'),
  12. },
  13. name: 'Demos',
  14. path: '/demos',
  15. redirect: '/demos/access',
  16. children: [
  17. {
  18. meta: {
  19. icon: 'mdi:shield-key-outline',
  20. title: $t('page.demos.access.frontendPermissions'),
  21. },
  22. name: 'Access',
  23. path: 'access',
  24. redirect: '/demos/access',
  25. children: [
  26. {
  27. name: 'AccessPageControl',
  28. path: 'page-control',
  29. component: () => import('#/views/demos/access/index.vue'),
  30. meta: {
  31. icon: 'mdi:page-previous-outline',
  32. title: $t('page.demos.access.pageAccess'),
  33. },
  34. },
  35. {
  36. name: 'AccessButtonControl',
  37. path: 'button-control',
  38. component: () => import('#/views/demos/access/button-control.vue'),
  39. meta: {
  40. icon: 'mdi:button-cursor',
  41. title: $t('page.demos.access.buttonControl'),
  42. },
  43. },
  44. {
  45. name: 'AccessMenuVisible403',
  46. path: 'menu-visible-403',
  47. component: () =>
  48. import('#/views/demos/access/menu-visible-403.vue'),
  49. meta: {
  50. authority: ['no-body'],
  51. icon: 'mdi:button-cursor',
  52. menuVisibleWithForbidden: true,
  53. title: $t('page.demos.access.menuVisible403'),
  54. },
  55. },
  56. {
  57. name: 'AccessSuperVisible',
  58. path: 'super-visible',
  59. component: () => import('#/views/demos/access/super-visible.vue'),
  60. meta: {
  61. authority: ['super'],
  62. icon: 'mdi:button-cursor',
  63. title: $t('page.demos.access.superVisible'),
  64. },
  65. },
  66. {
  67. name: 'AccessAdminVisible',
  68. path: 'admin-visible',
  69. component: () => import('#/views/demos/access/admin-visible.vue'),
  70. meta: {
  71. authority: ['admin'],
  72. icon: 'mdi:button-cursor',
  73. title: $t('page.demos.access.adminVisible'),
  74. },
  75. },
  76. {
  77. name: 'AccessUserVisible',
  78. path: 'user-visible',
  79. component: () => import('#/views/demos/access/user-visible.vue'),
  80. meta: {
  81. authority: ['user'],
  82. icon: 'mdi:button-cursor',
  83. title: $t('page.demos.access.userVisible'),
  84. },
  85. },
  86. ],
  87. },
  88. {
  89. meta: {
  90. icon: 'mdi:feature-highlight',
  91. title: $t('page.demos.features.title'),
  92. },
  93. name: 'Features',
  94. path: '/features',
  95. redirect: '/features/hide-menu-children',
  96. children: [
  97. {
  98. name: 'HideChildrenInMenuParent',
  99. path: 'hide-children-in-menu',
  100. component: () =>
  101. import('#/views/demos/features/hide-menu-children/parent.vue'),
  102. meta: {
  103. hideChildrenInMenu: true,
  104. icon: 'ic:round-menu',
  105. title: 'page.demos.features.hideChildrenInMenu',
  106. },
  107. children: [
  108. {
  109. name: 'HideChildrenInMenuChildren',
  110. path: 'hide-children-in-menu',
  111. component: () =>
  112. import(
  113. '#/views/demos/features/hide-menu-children/children.vue'
  114. ),
  115. },
  116. ],
  117. },
  118. {
  119. name: 'LoginExpired',
  120. path: 'login-expired',
  121. component: () =>
  122. import('#/views/demos/features/login-expired/index.vue'),
  123. meta: {
  124. icon: 'mdi:encryption-expiration',
  125. title: $t('page.demos.features.loginExpired'),
  126. },
  127. },
  128. ],
  129. },
  130. {
  131. meta: {
  132. icon: 'mdi:lightbulb-error-outline',
  133. title: $t('page.demos.fallback.title'),
  134. },
  135. name: 'Fallback',
  136. path: '/fallback',
  137. redirect: '/fallback/403',
  138. children: [
  139. {
  140. name: 'Fallback403',
  141. path: '403',
  142. component: () =>
  143. import('#/views/_essential/fallback/forbidden.vue'),
  144. meta: {
  145. icon: 'mdi:do-not-disturb-alt',
  146. title: '403',
  147. },
  148. },
  149. {
  150. name: 'Fallback404',
  151. path: '404',
  152. component: () =>
  153. import('#/views/_essential/fallback/not-found.vue'),
  154. meta: {
  155. icon: 'mdi:table-off',
  156. title: '404',
  157. },
  158. },
  159. {
  160. name: 'Fallback500',
  161. path: '500',
  162. component: () =>
  163. import('#/views/_essential/fallback/internal-error.vue'),
  164. meta: {
  165. icon: 'mdi:server-network-off',
  166. title: '500',
  167. },
  168. },
  169. {
  170. name: 'FallbackOffline',
  171. path: 'offline',
  172. component: () => import('#/views/_essential/fallback/offline.vue'),
  173. meta: {
  174. icon: 'mdi:offline',
  175. title: $t('fallback.offline'),
  176. },
  177. },
  178. ],
  179. },
  180. {
  181. meta: {
  182. icon: 'ic:round-settings-input-composite',
  183. title: $t('page.demos.outside.title'),
  184. },
  185. name: 'Outside',
  186. path: '/outside',
  187. redirect: '/outside/iframe',
  188. children: [
  189. {
  190. name: 'iframe',
  191. path: 'iframe',
  192. meta: {
  193. icon: 'mdi:newspaper-variant-outline',
  194. title: $t('page.demos.outside.embedded'),
  195. },
  196. redirect: '/outside/iframe/vue-document',
  197. children: [
  198. {
  199. name: 'VueDocument',
  200. path: 'vue-document',
  201. component: IFrameView,
  202. meta: {
  203. icon: 'logos:vue',
  204. iframeSrc: 'https://cn.vuejs.org/',
  205. keepAlive: true,
  206. title: 'Vue',
  207. },
  208. },
  209. {
  210. name: 'Tailwindcss',
  211. path: 'tailwindcss',
  212. component: IFrameView,
  213. meta: {
  214. icon: 'devicon:tailwindcss',
  215. iframeSrc: 'https://tailwindcss.com/',
  216. // keepAlive: true,
  217. title: 'Tailwindcss',
  218. },
  219. },
  220. ],
  221. },
  222. {
  223. name: 'ExternalLink',
  224. path: 'external-link',
  225. meta: {
  226. icon: 'mdi:newspaper-variant-multiple-outline',
  227. title: $t('page.demos.outside.externalLink'),
  228. },
  229. redirect: '/outside/external-link/vite',
  230. children: [
  231. {
  232. name: 'Vite',
  233. path: 'vite',
  234. component: IFrameView,
  235. meta: {
  236. icon: 'logos:vitejs',
  237. link: 'https://vitejs.dev/',
  238. title: 'Vite',
  239. },
  240. },
  241. {
  242. name: 'VueUse',
  243. path: 'vue-use',
  244. component: IFrameView,
  245. meta: {
  246. icon: 'logos:vueuse',
  247. link: 'https://vueuse.org',
  248. title: 'VueUse',
  249. },
  250. },
  251. ],
  252. },
  253. ],
  254. },
  255. {
  256. meta: {
  257. icon: 'ic:round-menu',
  258. title: $t('page.demos.nested.title'),
  259. },
  260. name: 'Nested',
  261. path: 'nested',
  262. redirect: '/demos/nested/menu1',
  263. children: [
  264. {
  265. name: 'Menu1',
  266. path: 'menu1',
  267. component: () => import('#/views/demos/nested/menu-1.vue'),
  268. meta: {
  269. icon: 'ic:round-menu',
  270. keepAlive: true,
  271. title: $t('page.demos.nested.menu1'),
  272. },
  273. },
  274. {
  275. name: 'Menu2',
  276. path: 'menu2',
  277. meta: {
  278. icon: 'ic:round-menu',
  279. keepAlive: true,
  280. title: $t('page.demos.nested.menu2'),
  281. },
  282. redirect: '/nested/menu2/menu2-1',
  283. children: [
  284. {
  285. name: 'Menu21',
  286. path: 'menu2-1',
  287. component: () => import('#/views/demos/nested/menu-2-1.vue'),
  288. meta: {
  289. icon: 'ic:round-menu',
  290. keepAlive: true,
  291. title: $t('page.demos.nested.menu2_1'),
  292. },
  293. },
  294. ],
  295. },
  296. {
  297. name: 'Menu3',
  298. path: 'menu3',
  299. meta: {
  300. icon: 'ic:round-menu',
  301. title: $t('page.demos.nested.menu3'),
  302. },
  303. redirect: '/nested/menu3/menu3-1',
  304. children: [
  305. {
  306. name: 'Menu31',
  307. path: 'menu3-1',
  308. component: () => import('#/views/demos/nested/menu-3-1.vue'),
  309. meta: {
  310. icon: 'ic:round-menu',
  311. keepAlive: true,
  312. title: $t('page.demos.nested.menu3_1'),
  313. },
  314. },
  315. {
  316. name: 'Menu32',
  317. path: 'menu3-2',
  318. meta: {
  319. icon: 'ic:round-menu',
  320. title: $t('page.demos.nested.menu3_2'),
  321. },
  322. redirect: '/nested/menu3/menu3-2/menu3-2-1',
  323. children: [
  324. {
  325. name: 'Menu321',
  326. path: 'menu3-2-1',
  327. component: () =>
  328. import('#/views/demos/nested/menu-3-2-1.vue'),
  329. meta: {
  330. icon: 'ic:round-menu',
  331. keepAlive: true,
  332. title: $t('page.demos.nested.menu3_2_1'),
  333. },
  334. },
  335. ],
  336. },
  337. ],
  338. },
  339. ],
  340. },
  341. ],
  342. },
  343. ];
  344. export default routes;