29 lines
744 B
TypeScript
29 lines
744 B
TypeScript
![]() |
import { OutputData } from "@editorjs/editorjs";
|
||
|
import { RichTextEditorChange } from "@saleor/components/RichTextEditor";
|
||
|
import { MutableRefObject, useEffect, useRef } from "react";
|
||
|
|
||
|
function useRichText(opts: {
|
||
|
initial?: string | null;
|
||
|
triggerChange: () => void;
|
||
|
}): [MutableRefObject<OutputData>, RichTextEditorChange] {
|
||
|
const data = useRef<OutputData>(
|
||
|
opts.initial === null ? { blocks: [] } : undefined
|
||
|
);
|
||
|
useEffect(() => {
|
||
|
try {
|
||
|
data.current = JSON.parse(opts.initial);
|
||
|
} catch {
|
||
|
data.current = undefined;
|
||
|
}
|
||
|
}, [opts.initial]);
|
||
|
|
||
|
const change: RichTextEditorChange = newData => {
|
||
|
opts.triggerChange();
|
||
|
data.current = newData;
|
||
|
};
|
||
|
|
||
|
return [data, change];
|
||
|
}
|
||
|
|
||
|
export default useRichText;
|