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

79 lines
1.6 KiB
Vue
Raw Normal View History

<template>
2023-04-08 02:01:42 +02:00
<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="icon('ph-lock')"></i
2023-04-08 02:01:42 +02:00
></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-02 01:27:33 +02:00
import { computed, defineAsyncComponent, onMounted, ref } from "vue";
2023-04-08 02:01:42 +02: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";
import icon from "@/scripts/icon";
const props = defineProps<{
token?: string;
}>();
const password = ref("");
async function save() {
2023-04-08 02:01:42 +02:00
await os.apiWithDialog("reset-password", {
token: props.token,
password: password.value,
});
2023-04-08 02:01:42 +02:00
mainRouter.push("/");
}
onMounted(() => {
if (props.token == null) {
2023-04-08 02:01:42 +02:00
os.popup(
defineAsyncComponent(
2023-07-06 03:28:27 +02:00
() => import("@/components/MkForgotPassword.vue"),
2023-04-08 02:01:42 +02:00
),
{},
{},
2023-07-06 03:28:27 +02:00
"closed",
2023-04-08 02:01:42 +02:00
);
mainRouter.push("/");
}
});
const headerActions = computed(() => []);
const headerTabs = computed(() => []);
definePageMetadata({
title: i18n.ts.resetPassword,
icon: `${icon("ph-lock")}`,
});
</script>