From a0706fd52f8f4d1a9ee834b22d65512fe94c45be Mon Sep 17 00:00:00 2001 From: DrMint <29893320+DrMint@users.noreply.github.com> Date: Wed, 22 Feb 2023 06:12:17 +0100 Subject: [PATCH] Dev Editor now save state in localstorage --- src/pages/dev/editor.tsx | 22 ++++++++++++++-------- 1 file changed, 14 insertions(+), 8 deletions(-) diff --git a/src/pages/dev/editor.tsx b/src/pages/dev/editor.tsx index aed49c3..f471cae 100644 --- a/src/pages/dev/editor.tsx +++ b/src/pages/dev/editor.tsx @@ -1,6 +1,7 @@ import { GetStaticProps } from "next"; import { useCallback, useRef, useState } from "react"; import TurndownService from "turndown"; +import { atomWithStorage } from "jotai/utils"; import { AppLayout, AppLayoutRequired } from "components/AppLayout"; import { Button } from "components/Inputs/Button"; import { getTocFromMarkdawn, Markdawn, TableOfContents } from "components/Markdown/Markdawn"; @@ -10,6 +11,14 @@ import { ToolTip } from "components/ToolTip"; import { getOpenGraph } from "helpers/openGraph"; import { getFormat } from "helpers/i18n"; import { isDefined } from "helpers/asserts"; +import { atomPairing, useAtomPair } from "helpers/atoms"; + +/* + * ╭─────────────╮ + * ────────────────────────────────────────╯ CONSTANTS ╰────────────────────────────────────────── + */ + +const markdownAtom = atomPairing(atomWithStorage("editorState", "")); /* * ╭────────╮ @@ -19,14 +28,11 @@ import { isDefined } from "helpers/asserts"; interface Props extends AppLayoutRequired {} const Editor = (props: Props): JSX.Element => { - const handleInput = useCallback((text: string) => { - setMarkdown(text); - }, []); - - const [markdown, setMarkdown] = useState(""); const [converterOpened, setConverterOpened] = useState(false); const textAreaRef = useRef(null); + const [markdown, setMarkdown] = useAtomPair(markdownAtom); + const transformationWrapper = useCallback( ( transformation: ( @@ -45,14 +51,14 @@ const Editor = (props: Props): JSX.Element => { ); textAreaRef.current.value = transformedValue; - handleInput(textAreaRef.current.value); + setMarkdown(textAreaRef.current.value); textAreaRef.current.focus(); textAreaRef.current.selectionStart = selectionStart + prependLength; textAreaRef.current.selectionEnd = selectionEnd + prependLength; } }, - [handleInput] + [setMarkdown] ); const wrap = useCallback( @@ -375,7 +381,7 @@ const Editor = (props: Props): JSX.Element => { ref={textAreaRef} onInput={(event) => { const textarea = event.target as HTMLTextAreaElement; - handleInput(textarea.value); + setMarkdown(textarea.value); }} className="h-[70vh] w-full rounded-xl bg-mid/40 p-8 font-mono text-black outline-none"