134 lines
2.6 KiB
Vue
134 lines
2.6 KiB
Vue
<template>
|
|
<div class="mk-admin">
|
|
<nav>
|
|
<ul>
|
|
<li @click="nav('dashboard')" :class="{ active: page == 'dashboard' }">%fa:chalkboard .fw%%i18n:@dashboard%</li>
|
|
<li @click="nav('users')" :class="{ active: page == 'users' }">%fa:users .fw%%i18n:@users%</li>
|
|
<!-- <li @click="nav('drive')" :class="{ active: page == 'drive' }">%fa:cloud .fw%%i18n:@drive%</li> -->
|
|
<!-- <li @click="nav('update')" :class="{ active: page == 'update' }">%i18n:@update%</li> -->
|
|
</ul>
|
|
</nav>
|
|
<main>
|
|
<div v-show="page == 'dashboard'">
|
|
<x-dashboard/>
|
|
<x-users-chart :chart="chart"/>
|
|
<x-notes-chart :chart="chart"/>
|
|
<x-drive-chart :chart="chart"/>
|
|
</div>
|
|
<div v-if="page == 'users'">
|
|
<x-suspend-user/>
|
|
<x-unsuspend-user/>
|
|
<x-verify-user/>
|
|
<x-unverify-user/>
|
|
</div>
|
|
<div v-if="page == 'drive'"></div>
|
|
<div v-if="page == 'update'"></div>
|
|
</main>
|
|
</div>
|
|
</template>
|
|
|
|
<script lang="ts">
|
|
import Vue from "vue";
|
|
import XDashboard from "./admin.dashboard.vue";
|
|
import XSuspendUser from "./admin.suspend-user.vue";
|
|
import XUnsuspendUser from "./admin.unsuspend-user.vue";
|
|
import XVerifyUser from "./admin.verify-user.vue";
|
|
import XUnverifyUser from "./admin.unverify-user.vue";
|
|
import XUsersChart from "./admin.users-chart.vue";
|
|
import XNotesChart from "./admin.notes-chart.vue";
|
|
import XDriveChart from "./admin.drive-chart.vue";
|
|
|
|
export default Vue.extend({
|
|
components: {
|
|
XDashboard,
|
|
XSuspendUser,
|
|
XUnsuspendUser,
|
|
XVerifyUser,
|
|
XUnverifyUser,
|
|
XUsersChart,
|
|
XNotesChart,
|
|
XDriveChart
|
|
},
|
|
data() {
|
|
return {
|
|
page: 'dashboard',
|
|
chart: null
|
|
};
|
|
},
|
|
created() {
|
|
(this as any).api('admin/chart').then(chart => {
|
|
this.chart = chart;
|
|
});
|
|
},
|
|
methods: {
|
|
nav(page: string) {
|
|
this.page = page;
|
|
}
|
|
}
|
|
});
|
|
</script>
|
|
|
|
<style lang="stylus">
|
|
@import '~const.styl'
|
|
|
|
.mk-admin
|
|
display flex
|
|
height 100%
|
|
margin 32px
|
|
|
|
> nav
|
|
flex 0 0 250px
|
|
width 100%
|
|
height 100%
|
|
padding 16px 0 0 0
|
|
overflow auto
|
|
border-right solid 1px #ddd
|
|
|
|
> ul
|
|
list-style none
|
|
|
|
> li
|
|
display block
|
|
padding 10px 16px
|
|
margin 0
|
|
color #666
|
|
cursor pointer
|
|
user-select none
|
|
transition margin-left 0.2s ease
|
|
|
|
> [data-fa]
|
|
margin-right 4px
|
|
|
|
|
|
&:hover
|
|
color #555
|
|
|
|
&.active
|
|
margin-left 8px
|
|
color $theme-color !important
|
|
|
|
> main
|
|
width 100%
|
|
padding 16px 32px
|
|
|
|
> div
|
|
> div
|
|
max-width 800px
|
|
|
|
.card
|
|
padding 32px
|
|
background #fff
|
|
box-shadow 0 2px 8px rgba(#000, 0.1)
|
|
|
|
&:not(:last-child)
|
|
margin-bottom 16px
|
|
|
|
> header
|
|
margin 0 0 1em 0
|
|
padding 0 0 8px 0
|
|
font-size 1em
|
|
color #555
|
|
border-bottom solid 1px #eee
|
|
|
|
</style>
|