iceshrimp/packages/client/src/components/MkTokenGenerateWindow.vue
2023-04-07 17:01:42 -07:00

109 lines
2.5 KiB
Vue

<template>
<XModalWindow
ref="dialog"
:width="400"
:height="600"
:with-ok-button="true"
:ok-button-disabled="false"
:can-close="false"
@close="dialog.close()"
@closed="$emit('closed')"
@ok="ok()"
style="padding: 12px"
>
<template #header>{{ title || i18n.ts.generateAccessToken }}</template>
<div v-if="information" class="_section">
<MkInfo warn>{{ information }}</MkInfo>
</div>
<div class="_section">
<div style="margin-bottom: 16px">
<b>{{ i18n.ts.name }}</b>
</div>
<MkInput style="margin-bottom: 16px" v-model="name" />
</div>
<div class="_section">
<div style="margin-bottom: 16px">
<b>{{ i18n.ts.permission }}</b>
</div>
<MkButton inline @click="disableAll">{{
i18n.ts.disableAll
}}</MkButton>
<MkButton style="margin-bottom: 12px" inline @click="enableAll">{{
i18n.ts.enableAll
}}</MkButton>
<MkSwitch
style="margin-bottom: 6px"
v-for="kind in initialPermissions || kinds"
:key="kind"
v-model="permissions[kind]"
>{{ i18n.t(`_permissions.${kind}`) }}</MkSwitch
>
</div>
</XModalWindow>
</template>
<script lang="ts" setup>
import {} from "vue";
import { permissions as kinds } from "calckey-js";
import MkInput from "./form/input.vue";
import MkSwitch from "./form/switch.vue";
import MkButton from "./MkButton.vue";
import MkInfo from "./MkInfo.vue";
import XModalWindow from "@/components/MkModalWindow.vue";
import { i18n } from "@/i18n";
const props = withDefaults(
defineProps<{
title?: string | null;
information?: string | null;
initialName?: string | null;
initialPermissions?: string[] | null;
}>(),
{
title: null,
information: null,
initialName: null,
initialPermissions: null,
}
);
const emit = defineEmits<{
(ev: "closed"): void;
(ev: "done", result: { name: string | null; permissions: string[] }): void;
}>();
const dialog = $ref<InstanceType<typeof XModalWindow>>();
let name = $ref(props.initialName);
let permissions = $ref({});
if (props.initialPermissions) {
for (const kind of props.initialPermissions) {
permissions[kind] = true;
}
} else {
for (const kind of kinds) {
permissions[kind] = false;
}
}
function ok(): void {
emit("done", {
name: name,
permissions: Object.keys(permissions).filter((p) => permissions[p]),
});
dialog.close();
}
function disableAll(): void {
for (const p in permissions) {
permissions[p] = false;
}
}
function enableAll(): void {
for (const p in permissions) {
permissions[p] = true;
}
}
</script>