misskey/src/client/app/desktop/views/pages/admin/admin.vue

118 lines
2.2 KiB
Vue
Raw Normal View History

2018-08-14 01:05:58 +09:00
<template>
2018-08-14 04:30:42 +09:00
<div class="mk-admin">
2018-08-14 01:05:58 +09:00
<nav>
<ul>
2018-08-14 04:30:42 +09:00
<li @click="nav('dashboard')" :class="{ active: page == 'dashboard' }">%fa:chalkboard .fw%%i18n:@dashboard%</li>
2018-08-15 04:44:39 +09:00
<li @click="nav('users')" :class="{ active: page == 'users' }">%fa:users .fw%%i18n:@users%</li>
2018-08-14 04:39:37 +09:00
<!-- <li @click="nav('drive')" :class="{ active: page == 'drive' }">%fa:cloud .fw%%i18n:@drive%</li> -->
2018-08-14 04:30:42 +09:00
<!-- <li @click="nav('update')" :class="{ active: page == 'update' }">%i18n:@update%</li> -->
2018-08-14 01:05:58 +09:00
</ul>
</nav>
<main>
<div v-if="page == 'dashboard'">
<x-dashboard/>
2018-08-18 03:52:24 +09:00
<x-users-chart/>
<x-notes-chart/>
2018-08-14 01:05:58 +09:00
</div>
<div v-if="page == 'users'">
<x-suspend-user/>
2018-08-15 06:50:49 +09:00
<x-unsuspend-user/>
2018-08-17 21:40:08 +09:00
<x-verify-user/>
2018-08-14 01:05:58 +09:00
</div>
2018-08-14 04:30:42 +09:00
<div v-if="page == 'drive'"></div>
2018-08-14 01:05:58 +09:00
<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";
2018-08-15 06:50:49 +09:00
import XUnsuspendUser from "./admin.unsuspend-user.vue";
2018-08-17 21:40:08 +09:00
import XVerifyUser from "./admin.verify-user.vue";
2018-08-18 03:52:24 +09:00
import XUsersChart from "./admin.users-chart.vue";
import XNotesChart from "./admin.notes-chart.vue";
2018-08-14 01:05:58 +09:00
export default Vue.extend({
2018-08-14 01:24:46 +09:00
components: {
2018-08-14 01:05:58 +09:00
XDashboard,
2018-08-15 06:50:49 +09:00
XSuspendUser,
2018-08-17 21:40:08 +09:00
XUnsuspendUser,
2018-08-18 03:52:24 +09:00
XVerifyUser,
XUsersChart,
XNotesChart
2018-08-14 01:35:36 +09:00
},
data() {
return {
page: 'dashboard'
};
},
methods: {
nav(page: string) {
this.page = page;
}
2018-08-14 01:24:46 +09:00
}
2018-08-14 01:05:58 +09:00
});
</script>
2018-08-14 04:30:42 +09:00
2018-08-18 03:52:24 +09:00
<style lang="stylus">
2018-08-14 04:30:42 +09:00
@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
2018-08-17 23:06:58 +09:00
> div
> div
margin-bottom 16px
padding 32px
max-width 800px
background #fff
box-shadow 0 2px 8px rgba(#000, 0.1)
2018-08-18 03:52:24 +09:00
> header
margin 0 0 1em 0
padding 0 0 8px 0
font-size 1em
color #555
border-bottom solid 1px #eee
2018-08-15 04:44:39 +09:00
2018-08-14 04:30:42 +09:00
</style>