mirror of
https://github.com/ilyakooo0/urbit.git
synced 2024-12-14 08:34:25 +03:00
parent
e279b08049
commit
61442c4c2e
@ -1,3 +1,4 @@
|
|||||||
|
import React from 'react';
|
||||||
import _ from 'lodash';
|
import _ from 'lodash';
|
||||||
import f from 'lodash/fp';
|
import f from 'lodash/fp';
|
||||||
import bigInt from 'big-integer';
|
import bigInt from 'big-integer';
|
||||||
@ -325,3 +326,12 @@ export function numToUd(num) {
|
|||||||
f.join('.')
|
f.join('.')
|
||||||
)(num.toString())
|
)(num.toString())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export function usePreventWindowUnload(shouldPreventDefault) {
|
||||||
|
React.useEffect(() => {
|
||||||
|
if (!shouldPreventDefault) return;
|
||||||
|
const handleBeforeUnload = event => event.preventDefault();
|
||||||
|
window.addEventListener("beforeunload", handleBeforeUnload);
|
||||||
|
return () => window.removeEventListener("beforeunload", handleBeforeUnload);
|
||||||
|
}, [shouldPreventDefault]);
|
||||||
|
}
|
@ -1,7 +1,9 @@
|
|||||||
import React, { useCallback } from "react";
|
import React, { useCallback } from "react";
|
||||||
|
|
||||||
import { UnControlled as CodeEditor } from "react-codemirror2";
|
import { UnControlled as CodeEditor } from "react-codemirror2";
|
||||||
import { MOBILE_BROWSER_REGEX } from "~/logic/lib/util";
|
import { useFormikContext } from 'formik';
|
||||||
|
import { Prompt } from 'react-router-dom';
|
||||||
|
|
||||||
|
import { MOBILE_BROWSER_REGEX, usePreventWindowUnload } from "~/logic/lib/util";
|
||||||
import { PropFunc } from "~/types/util";
|
import { PropFunc } from "~/types/util";
|
||||||
import CodeMirror from "codemirror";
|
import CodeMirror from "codemirror";
|
||||||
|
|
||||||
@ -22,6 +24,17 @@ interface MarkdownEditorProps {
|
|||||||
onBlur?: (e: any) => void;
|
onBlur?: (e: any) => void;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const PromptIfDirty = () => {
|
||||||
|
const formik = useFormikContext();
|
||||||
|
usePreventWindowUnload(formik.dirty);
|
||||||
|
return (
|
||||||
|
<Prompt
|
||||||
|
when={formik.dirty}
|
||||||
|
message="Are you sure you want to leave? You have with unsaved changes."
|
||||||
|
/>
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
export function MarkdownEditor(
|
export function MarkdownEditor(
|
||||||
props: MarkdownEditorProps & PropFunc<typeof Box>
|
props: MarkdownEditorProps & PropFunc<typeof Box>
|
||||||
) {
|
) {
|
||||||
@ -63,6 +76,7 @@ export function MarkdownEditor(
|
|||||||
height={['calc(100% - 22vh)', '100%']}
|
height={['calc(100% - 22vh)', '100%']}
|
||||||
{...boxProps}
|
{...boxProps}
|
||||||
>
|
>
|
||||||
|
<PromptIfDirty />
|
||||||
<CodeEditor
|
<CodeEditor
|
||||||
autoCursor={false}
|
autoCursor={false}
|
||||||
onBlur={onBlur}
|
onBlur={onBlur}
|
||||||
|
Loading…
Reference in New Issue
Block a user