2023-09-02 01:27:33 +02:00
|
|
|
import type { Ref } from "vue";
|
|
|
|
import { inject, onUnmounted } from "vue";
|
2023-01-13 05:40:33 +01:00
|
|
|
import { i18n } from "@/i18n";
|
|
|
|
import * as os from "@/os";
|
2022-01-16 07:02:15 +01:00
|
|
|
|
|
|
|
export function useLeaveGuard(enabled: Ref<boolean>) {
|
2022-06-23 17:47:55 +02:00
|
|
|
/* TODO
|
2022-01-16 07:02:15 +01:00
|
|
|
const setLeaveGuard = inject('setLeaveGuard');
|
|
|
|
|
|
|
|
if (setLeaveGuard) {
|
|
|
|
setLeaveGuard(async () => {
|
|
|
|
if (!enabled.value) return false;
|
|
|
|
|
|
|
|
const { canceled } = await os.confirm({
|
|
|
|
type: 'warning',
|
2022-01-28 03:39:49 +01:00
|
|
|
text: i18n.ts.leaveConfirm,
|
2022-01-16 07:02:15 +01:00
|
|
|
});
|
|
|
|
|
|
|
|
return canceled;
|
|
|
|
});
|
2022-01-16 13:31:09 +01:00
|
|
|
} else {
|
|
|
|
onBeforeRouteLeave(async (to, from) => {
|
|
|
|
if (!enabled.value) return true;
|
|
|
|
|
|
|
|
const { canceled } = await os.confirm({
|
|
|
|
type: 'warning',
|
2022-01-28 03:39:49 +01:00
|
|
|
text: i18n.ts.leaveConfirm,
|
2022-01-16 13:31:09 +01:00
|
|
|
});
|
|
|
|
|
|
|
|
return !canceled;
|
|
|
|
});
|
2022-01-16 07:02:15 +01:00
|
|
|
}
|
2022-06-23 17:47:55 +02:00
|
|
|
*/
|
2022-01-16 07:02:15 +01:00
|
|
|
/*
|
|
|
|
function onBeforeLeave(ev: BeforeUnloadEvent) {
|
|
|
|
if (enabled.value) {
|
|
|
|
ev.preventDefault();
|
|
|
|
ev.returnValue = '';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
window.addEventListener('beforeunload', onBeforeLeave);
|
|
|
|
onUnmounted(() => {
|
|
|
|
window.removeEventListener('beforeunload', onBeforeLeave);
|
|
|
|
});
|
|
|
|
*/
|
|
|
|
}
|