|
|
|
<template lang='pug'>
|
|
|
|
v-container(fluid, grid-list-lg)
|
|
|
|
v-layout(row, wrap)
|
|
|
|
v-flex(xs12)
|
|
|
|
.admin-header
|
|
|
|
img(src='/svg/icon-maintenance.svg', alt='Utilities', style='width: 80px;')
|
|
|
|
.admin-header-title
|
|
|
|
.headline.primary--text {{$t('admin:utilities.title')}}
|
|
|
|
.subtitle-1.grey--text {{$t('admin:utilities.subtitle')}}
|
|
|
|
|
|
|
|
v-flex(lg3, xs12)
|
|
|
|
v-card.animated.fadeInUp
|
|
|
|
v-toolbar(flat, color='primary', dark, dense)
|
|
|
|
.subtitle-1 {{$t('admin:utilities.tools')}}
|
|
|
|
v-list(two-line, dense).py-0
|
|
|
|
template(v-for='(tool, idx) in tools')
|
|
|
|
v-list-item(:key='tool.key', @click='selectedTool = tool.key', :disabled='!tool.isAvailable')
|
|
|
|
v-list-item-avatar
|
|
|
|
v-icon(:color='!tool.isAvailable ? `grey lighten-1` : (selectedTool === tool.key ? `blue ` : `grey darken-1`)') {{ tool.icon }}
|
|
|
|
v-list-item-content
|
|
|
|
v-list-item-title.body-2(:class='!tool.isAvailable ? `grey--text` : (selectedTool === tool.key ? `primary--text` : ``)') {{ $t('admin:utilities.' + tool.i18nKey + 'Title') }}
|
|
|
|
v-list-item-subtitle: .caption(:class='!tool.isAvailable ? `grey--text text--lighten-1` : (selectedTool === tool.key ? `blue--text ` : ``)') {{ $t('admin:utilities.' + tool.i18nKey + 'Subtitle') }}
|
|
|
|
v-list-item-avatar(v-if='selectedTool === tool.key')
|
|
|
|
v-icon.animated.fadeInLeft(color='primary', large) mdi-chevron-right
|
|
|
|
v-divider(v-if='idx < tools.length - 1')
|
|
|
|
|
|
|
|
v-flex.animated.fadeInUp.wait-p2s(xs12, lg9)
|
|
|
|
transition(name='admin-router')
|
|
|
|
component(:is='selectedTool')
|
|
|
|
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<script>
|
|
|
|
|
|
|
|
export default {
|
|
|
|
components: {
|
|
|
|
UtilityAuth: () => import(/* webpackChunkName: "admin" */ './admin-utilities-auth.vue'),
|
|
|
|
UtilityContent: () => import(/* webpackChunkName: "admin" */ './admin-utilities-content.vue'),
|
|
|
|
UtilityCache: () => import(/* webpackChunkName: "admin" */ './admin-utilities-cache.vue'),
|
|
|
|
UtilityImportv1: () => import(/* webpackChunkName: "admin" */ './admin-utilities-importv1.vue'),
|
|
|
|
UtilityTelemetry: () => import(/* webpackChunkName: "admin" */ './admin-utilities-telemetry.vue')
|
|
|
|
},
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
selectedTool: 'UtilityAuth',
|
|
|
|
tools: [
|
|
|
|
{
|
|
|
|
key: 'UtilityAuth',
|
|
|
|
icon: 'mdi-lock-open-outline',
|
|
|
|
i18nKey: 'auth',
|
|
|
|
isAvailable: true
|
|
|
|
},
|
|
|
|
{
|
|
|
|
key: 'UtilityContent',
|
|
|
|
icon: 'mdi-content-duplicate',
|
|
|
|
i18nKey: 'content',
|
|
|
|
isAvailable: true
|
|
|
|
},
|
|
|
|
{
|
|
|
|
key: 'UtilityCache',
|
|
|
|
icon: 'mdi-database-refresh',
|
|
|
|
i18nKey: 'cache',
|
|
|
|
isAvailable: true
|
|
|
|
},
|
|
|
|
{
|
|
|
|
key: 'UtilityGraphEndpoint',
|
|
|
|
icon: 'mdi-graphql',
|
|
|
|
i18nKey: 'graphEndpoint',
|
|
|
|
isAvailable: false
|
|
|
|
},
|
|
|
|
{
|
|
|
|
key: 'UtilityImportv1',
|
|
|
|
icon: 'mdi-database-import',
|
|
|
|
i18nKey: 'importv1',
|
|
|
|
isAvailable: true
|
|
|
|
},
|
|
|
|
{
|
|
|
|
key: 'UtilityTelemetry',
|
|
|
|
icon: 'mdi-math-compass',
|
|
|
|
i18nKey: 'telemetry',
|
|
|
|
isAvailable: true
|
|
|
|
}
|
|
|
|
]
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
</script>
|
|
|
|
|
|
|
|
<style lang='scss'>
|
|
|
|
|
|
|
|
</style>
|