admin-utilities.vue 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. <template lang='pug'>
  2. v-container(fluid, grid-list-lg)
  3. v-layout(row, wrap)
  4. v-flex(xs12)
  5. .admin-header
  6. img(src='/svg/icon-maintenance.svg', alt='Utilities', style='width: 80px;')
  7. .admin-header-title
  8. .headline.primary--text {{$t('admin:utilities.title')}}
  9. .subheading.grey--text {{$t('admin:utilities.subtitle')}}
  10. v-flex(lg3, xs12)
  11. v-card.animated.fadeInUp
  12. v-toolbar(flat, color='primary', dark, dense)
  13. .subheading {{$t('admin:utilities.tools')}}
  14. v-list(two-line, dense).py-0
  15. template(v-for='(tool, idx) in tools')
  16. v-list-tile(:key='tool.key', @click='selectedTool = tool.key', :disabled='!tool.isAvailable')
  17. v-list-tile-avatar
  18. v-icon(:color='!tool.isAvailable ? `grey lighten-1` : (selectedTool === tool.key ? `blue ` : `grey darken-1`)') {{ tool.icon }}
  19. v-list-tile-content
  20. v-list-tile-title.body-2(:class='!tool.isAvailable ? `grey--text` : (selectedTool === tool.key ? `primary--text` : ``)') {{ $t('admin:utilities.' + tool.i18nKey + 'Title') }}
  21. v-list-tile-sub-title.caption(:class='!tool.isAvailable ? `grey--text text--lighten-1` : (selectedTool === tool.key ? `blue--text ` : ``)') {{ $t('admin:utilities.' + tool.i18nKey + 'Subtitle') }}
  22. v-list-tile-avatar(v-if='selectedTool === tool.key')
  23. v-icon.animated.fadeInLeft(color='primary') arrow_forward_ios
  24. v-divider(v-if='idx < tools.length - 1')
  25. v-flex.animated.fadeInUp.wait-p2s(xs12, lg9)
  26. transition(name='admin-router')
  27. component(:is='selectedTool')
  28. </template>
  29. <script>
  30. export default {
  31. components: {
  32. UtilityAuth: () => import(/* webpackChunkName: "admin" */ './admin-utilities-auth.vue'),
  33. UtilityCache: () => import(/* webpackChunkName: "admin" */ './admin-utilities-cache.vue'),
  34. UtilityImportv1: () => import(/* webpackChunkName: "admin" */ './admin-utilities-importv1.vue'),
  35. UtilityTelemetry: () => import(/* webpackChunkName: "admin" */ './admin-utilities-telemetry.vue')
  36. },
  37. data() {
  38. return {
  39. selectedTool: 'UtilityAuth',
  40. tools: [
  41. {
  42. key: 'UtilityAuth',
  43. icon: 'lock_outline',
  44. i18nKey: 'auth',
  45. isAvailable: true
  46. },
  47. {
  48. key: 'UtilityCache',
  49. icon: 'invert_colors',
  50. i18nKey: 'cache',
  51. isAvailable: true
  52. },
  53. {
  54. key: 'UtilityGraphEndpoint',
  55. icon: 'settings_ethernet',
  56. i18nKey: 'graphEndpoint',
  57. isAvailable: false
  58. },
  59. {
  60. key: 'UtilityImportv1',
  61. icon: 'present_to_all',
  62. i18nKey: 'importv1',
  63. isAvailable: true
  64. },
  65. {
  66. key: 'UtilityTelemetry',
  67. icon: 'wifi_tethering',
  68. i18nKey: 'telemetry',
  69. isAvailable: true
  70. }
  71. ]
  72. }
  73. }
  74. }
  75. </script>
  76. <style lang='scss'>
  77. </style>