admin.vue 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127
  1. <template lang='pug'>
  2. v-app.admin
  3. nav-header
  4. v-navigation-drawer.pb-0(v-model='adminDrawerShown', app, fixed, clipped, left, permanent)
  5. v-list(dense)
  6. v-list-tile.pt-2(to='/dashboard')
  7. v-list-tile-action: v-icon dashboard
  8. v-list-tile-title Dashboard
  9. v-divider.my-2
  10. v-subheader Site
  11. v-list-tile(to='/general')
  12. v-list-tile-action: v-icon widgets
  13. v-list-tile-title General
  14. v-list-tile(to='/locale')
  15. v-list-tile-action: v-icon language
  16. v-list-tile-title Locale
  17. v-list-tile(to='/stats')
  18. v-list-tile-action: v-icon show_chart
  19. v-list-tile-title Statistics
  20. v-list-tile(to='/theme')
  21. v-list-tile-action: v-icon palette
  22. v-list-tile-title Theme
  23. v-divider.my-2
  24. v-subheader Users
  25. v-list-tile(to='/groups')
  26. v-list-tile-action: v-icon people
  27. v-list-tile-title Groups
  28. v-list-tile(to='/users')
  29. v-list-tile-action: v-icon perm_identity
  30. v-list-tile-title Users
  31. v-divider.my-2
  32. v-subheader Modules
  33. v-list-tile(to='/auth')
  34. v-list-tile-action: v-icon lock_outline
  35. v-list-tile-title Authentication
  36. v-list-tile(to='/rendering')
  37. v-list-tile-action: v-icon system_update_alt
  38. v-list-tile-title Content Rendering
  39. v-list-tile(to='/editor')
  40. v-list-tile-action: v-icon transform
  41. v-list-tile-title Editor
  42. v-list-tile(to='/logging')
  43. v-list-tile-action: v-icon graphic_eq
  44. v-list-tile-title Logging
  45. v-list-tile(to='/search')
  46. v-list-tile-action: v-icon search
  47. v-list-tile-title Search Engine
  48. v-list-tile(to='/storage')
  49. v-list-tile-action: v-icon storage
  50. v-list-tile-title Storage
  51. v-divider.my-2
  52. v-subheader System
  53. v-list-tile(to='/api')
  54. v-list-tile-action: v-icon call_split
  55. v-list-tile-title API Access
  56. v-list-tile(to='/system')
  57. v-list-tile-action: v-icon tune
  58. v-list-tile-title System Info
  59. v-list-tile(to='/utilities')
  60. v-list-tile-action: v-icon build
  61. v-list-tile-title Utilities
  62. v-list-tile(to='/dev')
  63. v-list-tile-action: v-icon weekend
  64. v-list-tile-title Developer Tools
  65. v-content
  66. transition(name='admin-router')
  67. router-view
  68. v-footer.py-2.justify-center(app, absolute, color='grey lighten-3', inset, height='auto')
  69. .caption.grey--text.text--darken-1 Powered by Wiki.js
  70. </template>
  71. <script>
  72. import VueRouter from 'vue-router'
  73. const router = new VueRouter({
  74. mode: 'history',
  75. base: '/a',
  76. routes: [
  77. { path: '/', redirect: '/dashboard' },
  78. { path: '/dashboard', component: () => import(/* webpackChunkName: "admin" */ './admin-dashboard.vue') },
  79. { path: '/general', component: () => import(/* webpackChunkName: "admin" */ './admin-general.vue') },
  80. { path: '/locale', component: () => import(/* webpackChunkName: "admin" */ './admin-locale.vue') },
  81. { path: '/stats', component: () => import(/* webpackChunkName: "admin" */ './admin-stats.vue') },
  82. { path: '/theme', component: () => import(/* webpackChunkName: "admin" */ './admin-theme.vue') },
  83. { path: '/groups', component: () => import(/* webpackChunkName: "admin" */ './admin-groups.vue') },
  84. { path: '/users', component: () => import(/* webpackChunkName: "admin" */ './admin-users.vue') },
  85. { path: '/auth', component: () => import(/* webpackChunkName: "admin" */ './admin-auth.vue') },
  86. { path: '/rendering', component: () => import(/* webpackChunkName: "admin" */ './admin-rendering.vue') },
  87. { path: '/editor', component: () => import(/* webpackChunkName: "admin" */ './admin-editor.vue') },
  88. { path: '/logging', component: () => import(/* webpackChunkName: "admin" */ './admin-logging.vue') },
  89. { path: '/search', component: () => import(/* webpackChunkName: "admin" */ './admin-search.vue') },
  90. { path: '/storage', component: () => import(/* webpackChunkName: "admin" */ './admin-storage.vue') },
  91. { path: '/api', component: () => import(/* webpackChunkName: "admin" */ './admin-api.vue') },
  92. { path: '/system', component: () => import(/* webpackChunkName: "admin" */ './admin-system.vue') },
  93. { path: '/utilities', component: () => import(/* webpackChunkName: "admin" */ './admin-utilities.vue') },
  94. { path: '/dev', component: () => import(/* webpackChunkName: "admin-dev" */ './admin-dev.vue') }
  95. ]
  96. })
  97. export default {
  98. data() {
  99. return {
  100. adminDrawerShown: true
  101. }
  102. },
  103. router
  104. }
  105. </script>
  106. <style lang='scss'>
  107. .admin-router {
  108. &-enter-active, &-leave-active {
  109. transition: opacity .25s ease;
  110. opacity: 1;
  111. }
  112. &-enter-active {
  113. transition-delay: .25s;
  114. }
  115. &-enter, &-leave-to {
  116. opacity: 0;
  117. }
  118. }
  119. </style>