admin.vue 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146
  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. v-snackbar(
  71. :color='notification.style'
  72. bottom,
  73. right,
  74. multi-line,
  75. v-model='notificationState'
  76. )
  77. .text-xs-left
  78. v-icon.mr-3(dark) {{ notification.icon }}
  79. span {{ notification.message }}
  80. </template>
  81. <script>
  82. import VueRouter from 'vue-router'
  83. import { mapState } from 'vuex'
  84. const router = new VueRouter({
  85. mode: 'history',
  86. base: '/a',
  87. routes: [
  88. { path: '/', redirect: '/dashboard' },
  89. { path: '/dashboard', component: () => import(/* webpackChunkName: "admin" */ './admin-dashboard.vue') },
  90. { path: '/general', component: () => import(/* webpackChunkName: "admin" */ './admin-general.vue') },
  91. { path: '/locale', component: () => import(/* webpackChunkName: "admin" */ './admin-locale.vue') },
  92. { path: '/stats', component: () => import(/* webpackChunkName: "admin" */ './admin-stats.vue') },
  93. { path: '/theme', component: () => import(/* webpackChunkName: "admin" */ './admin-theme.vue') },
  94. { path: '/groups', component: () => import(/* webpackChunkName: "admin" */ './admin-groups.vue') },
  95. { path: '/users', component: () => import(/* webpackChunkName: "admin" */ './admin-users.vue') },
  96. { path: '/auth', component: () => import(/* webpackChunkName: "admin" */ './admin-auth.vue') },
  97. { path: '/rendering', component: () => import(/* webpackChunkName: "admin" */ './admin-rendering.vue') },
  98. { path: '/editor', component: () => import(/* webpackChunkName: "admin" */ './admin-editor.vue') },
  99. { path: '/logging', component: () => import(/* webpackChunkName: "admin" */ './admin-logging.vue') },
  100. { path: '/search', component: () => import(/* webpackChunkName: "admin" */ './admin-search.vue') },
  101. { path: '/storage', component: () => import(/* webpackChunkName: "admin" */ './admin-storage.vue') },
  102. { path: '/api', component: () => import(/* webpackChunkName: "admin" */ './admin-api.vue') },
  103. { path: '/system', component: () => import(/* webpackChunkName: "admin" */ './admin-system.vue') },
  104. { path: '/utilities', component: () => import(/* webpackChunkName: "admin" */ './admin-utilities.vue') },
  105. { path: '/dev', component: () => import(/* webpackChunkName: "admin-dev" */ './admin-dev.vue') }
  106. ]
  107. })
  108. export default {
  109. data() {
  110. return {
  111. adminDrawerShown: true
  112. }
  113. },
  114. computed: {
  115. ...mapState(['notification']),
  116. notificationState: {
  117. get() { return this.notification.isActive },
  118. set(newState) { this.$store.commit('updateNotificationState', newState) }
  119. }
  120. },
  121. router
  122. }
  123. </script>
  124. <style lang='scss'>
  125. .admin-router {
  126. &-enter-active, &-leave-active {
  127. transition: opacity .25s ease;
  128. opacity: 1;
  129. }
  130. &-enter-active {
  131. transition-delay: .25s;
  132. }
  133. &-enter, &-leave-to {
  134. opacity: 0;
  135. }
  136. }
  137. </style>