diff options
Diffstat (limited to 'src/client/app/desktop/views/pages/admin/admin.unsuspend-user.vue')
| -rw-r--r-- | src/client/app/desktop/views/pages/admin/admin.unsuspend-user.vue | 51 |
1 files changed, 51 insertions, 0 deletions
diff --git a/src/client/app/desktop/views/pages/admin/admin.unsuspend-user.vue b/src/client/app/desktop/views/pages/admin/admin.unsuspend-user.vue new file mode 100644 index 0000000000..8c6f63ce88 --- /dev/null +++ b/src/client/app/desktop/views/pages/admin/admin.unsuspend-user.vue @@ -0,0 +1,51 @@ +<template> +<div> + <header>%i18n:@unsuspend-user%</header> + <input v-model="username" type="text" class="ui"/> + <button class="ui" @click="unsuspendUser" :disabled="unsuspending">%i18n:@unsuspend%</button> +</div> +</template> + +<script lang="ts"> +import Vue from "vue"; +import parseAcct from "../../../../../../misc/acct/parse"; + +export default Vue.extend({ + data() { + return { + username: null, + unsuspending: false + }; + }, + methods: { + async unsuspendUser() { + this.unsuspending = true; + + const user = await (this as any).os.api( + "users/show", + parseAcct(this.username) + ); + + await (this as any).os.api("admin/unsuspend-user", { + userId: user.id + }); + + this.unsuspending = false; + + (this as any).os.apis.dialog({ text: "%i18n:@unsuspended%" }); + } + } +}); +</script> + +<style lang="stylus" scoped> +@import '~const.styl' + +header + margin 10px 0 + + +button + margin 16px 0 + +</style> |