2021-05-04 08:05:34 +02:00
|
|
|
<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
|
2023-10-17 03:57:20 +02:00
|
|
|
><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>
|
2021-05-04 08:05:34 +02:00
|
|
|
</template>
|
|
|
|
|
2022-01-16 03:02:27 +01:00
|
|
|
<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";
|
2023-10-17 03:57:20 +02:00
|
|
|
import icon from "@/scripts/icon";
|
2022-01-16 03:02:27 +01:00
|
|
|
|
|
|
|
const props = defineProps<{
|
|
|
|
token?: string;
|
|
|
|
}>();
|
|
|
|
|
2023-09-02 01:16:23 +02:00
|
|
|
const password = ref("");
|
2022-01-16 03:02:27 +01:00
|
|
|
|
|
|
|
async function save() {
|
2023-04-08 02:01:42 +02:00
|
|
|
await os.apiWithDialog("reset-password", {
|
2022-01-16 03:02:27 +01:00
|
|
|
token: props.token,
|
2023-08-12 02:44:46 +02:00
|
|
|
password: password.value,
|
2022-01-16 03:02:27 +01:00
|
|
|
});
|
2023-04-08 02:01:42 +02:00
|
|
|
mainRouter.push("/");
|
2022-01-16 03:02:27 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
onMounted(() => {
|
|
|
|
if (props.token == null) {
|
2023-04-08 02:01:42 +02:00
|
|
|
os.popup(
|
2024-03-28 17:26:52 +01:00
|
|
|
defineAsyncComponent(() => 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("/");
|
2022-01-16 03:02:27 +01:00
|
|
|
}
|
|
|
|
});
|
2021-05-04 08:05:34 +02:00
|
|
|
|
2023-08-12 02:44:46 +02:00
|
|
|
const headerActions = computed(() => []);
|
2022-06-20 10:38:49 +02:00
|
|
|
|
2023-08-12 02:44:46 +02:00
|
|
|
const headerTabs = computed(() => []);
|
2022-06-20 10:38:49 +02:00
|
|
|
|
|
|
|
definePageMetadata({
|
|
|
|
title: i18n.ts.resetPassword,
|
2023-10-17 03:57:20 +02:00
|
|
|
icon: `${icon("ph-lock")}`,
|
2021-05-04 08:05:34 +02:00
|
|
|
});
|
|
|
|
</script>
|