hippofish/packages/client/src/components/MkTokenGenerateWindow.vue
ThatOneCalculator 5d06aa5f13
chore: 🚨 lint
2023-09-01 16:27:33 -07:00

111 lines
2.5 KiB
Vue

<template>
<XModalWindow
ref="dialog"
:width="400"
:height="600"
:with-ok-button="true"
:ok-button-disabled="false"
:can-close="false"
style="padding: 12px"
@close="dialog.close()"
@closed="$emit('closed')"
@ok="ok()"
>
<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 v-model="name" style="margin-bottom: 16px" />
</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
v-for="kind in initialPermissions || kinds"
:key="kind"
v-model="permissions[kind]"
style="margin-bottom: 6px"
>{{ i18n.t(`_permissions.${kind}`) }}</MkSwitch
>
</div>
</XModalWindow>
</template>
<script lang="ts" setup>
import { ref } from "vue";
import { permissions as kinds } from "firefish-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>>();
const name = ref(props.initialName);
const permissions = ref({});
if (props.initialPermissions) {
for (const kind of props.initialPermissions) {
permissions.value[kind] = true;
}
} else {
for (const kind of kinds) {
permissions.value[kind] = false;
}
}
function ok(): void {
emit("done", {
name: name.value,
permissions: Object.keys(permissions.value).filter(
(p) => permissions.value[p],
),
});
dialog.value.close();
}
function disableAll(): void {
for (const p in permissions.value) {
permissions.value[p] = false;
}
}
function enableAll(): void {
for (const p in permissions.value) {
permissions.value[p] = true;
}
}
</script>