firefish/packages/client/src/pages/reset-password.vue

78 lines
1.6 KiB
Vue
Raw Normal View History

2023-07-20 04:17:05 +09:00
<template>
<MkStickyContainer>
<template #header
><MkPageHeader :actions="headerActions" :tabs="headerTabs"
/></template>
<MkSpacer
v-if="token"
:content-max="700"
:margin-min="16"
:margin-max="32"
>
<div class="_formRoot">
<FormInput
v-model="password"
type="password"
class="_formBlock"
>
<template #prefix
><i class="ph-lock ph-bold ph-lg"></i
></template>
<template #label>{{ i18n.ts.newPassword }}</template>
</FormInput>
<FormButton primary class="_formBlock" @click="save">{{
i18n.ts.save
}}</FormButton>
</div>
</MkSpacer>
</MkStickyContainer>
</template>
<script lang="ts" setup>
2023-09-04 17:47:24 +09:00
import { computed, defineAsyncComponent, onMounted, ref } from "vue";
2023-07-20 04:17:05 +09:00
import FormInput from "@/components/form/input.vue";
import FormButton from "@/components/MkButton.vue";
import * as os from "@/os";
import { i18n } from "@/i18n";
import { mainRouter } from "@/router";
import { definePageMetadata } from "@/scripts/page-metadata";
const props = defineProps<{
token?: string;
}>();
2023-09-04 17:47:24 +09:00
const password = ref("");
2023-07-20 04:17:05 +09:00
async function save() {
await os.apiWithDialog("reset-password", {
token: props.token,
2023-08-25 07:19:12 +09:00
password: password.value,
2023-07-20 04:17:05 +09:00
});
mainRouter.push("/");
}
onMounted(() => {
if (props.token == null) {
os.popup(
defineAsyncComponent(
() => import("@/components/MkForgotPassword.vue"),
),
{},
{},
"closed",
);
mainRouter.push("/");
}
});
2023-08-25 07:19:12 +09:00
const headerActions = computed(() => []);
2023-07-20 04:17:05 +09:00
2023-08-25 07:19:12 +09:00
const headerTabs = computed(() => []);
2023-07-20 04:17:05 +09:00
definePageMetadata({
title: i18n.ts.resetPassword,
icon: "ph-lock ph-bold ph-lg",
});
</script>