From 2a7995c36307e54c581137ed982f80884c0f5532 Mon Sep 17 00:00:00 2001 From: Nikolaj Frey Date: Thu, 17 Aug 2023 20:41:40 +1000 Subject: [PATCH] feat: feature/999 --- remix/app/Providers/ThingtimeProvider.tsx | 56 --------------- remix/app/components/Thingtime/Thingtime.tsx | 72 +++++++++++-------- .../app/components/Thingtime/ThingtimeURL.tsx | 1 - 3 files changed, 44 insertions(+), 85 deletions(-) diff --git a/remix/app/Providers/ThingtimeProvider.tsx b/remix/app/Providers/ThingtimeProvider.tsx index f7d1f97..1c3aace 100644 --- a/remix/app/Providers/ThingtimeProvider.tsx +++ b/remix/app/Providers/ThingtimeProvider.tsx @@ -82,33 +82,6 @@ Content.Nested Content = New Nested Content! // const initialThingtime = createInitialThingtime() const initialThingtime = smarts.merge(initialValues, force) -// TODO: Make localStorage be loaded first before initialValues if local version exists -// and is valid -// Issue seems to be server id is different to client hydration - -// let thingtimeToUse = initialThingtime - -// try { -// const thingtimeFromLocalStorage = window.localStorage.getItem("thingtime") - -// if (thingtimeFromLocalStorage) { -// const parsed = parse(thingtimeFromLocalStorage) -// if (parsed) { -// const localIsValid = !parsed.version || parsed.version >= force.version -// if (localIsValid) { -// const newThingtime = smarts.merge(force, parsed) -// thingtimeToUse = newThingtime -// } else { -// const withVersionUpdates = smarts.merge(newVersionData, parsed) -// const newThingtime = smarts.merge(force, withVersionUpdates) -// thingtimeToUse = newThingtime -// } -// } -// } -// } catch (err) { -// console.error("Caught error restoring thingtime from localstorage", err) -// } - // initialise thingtime initialThingtime.thingtime = initialThingtime initialThingtime.tt = initialThingtime @@ -151,20 +124,8 @@ export const ThingtimeProvider = (props: any): JSX.Element => { // nothing } // if last undoHistory does not equal new undo history - // console.log( - // "ThingtimeProvider saving to undo history undoHistory[undoHistory.length - 1]?.value", - // undoHistory[undoHistory.length - 1]?.value - // ) - // console.log( - // "ThingtimeProvider saving to undo history stringified", - // stringified - // ) if (undoHistory[undoHistory.length - 1]?.value !== stringified) { try { - // console.log( - // "ThingtimeProvider saving to undo history undoHistory", - // undoHistory - // ) const limit = newThingtimeReference?.settings?.undoLimit || 999 if (undoHistory?.length > limit) { @@ -181,8 +142,6 @@ export const ThingtimeProvider = (props: any): JSX.Element => { // nothing } } - // window.localStorage.setItem("thingtime", stringified) - // }, 600) } catch (err) { console.error("There was an error saving thingtime to localStorage") } @@ -205,21 +164,8 @@ export const ThingtimeProvider = (props: any): JSX.Element => { } catch { // nothing } - // if last redoHistory does not equal new redo history - // console.log( - // "ThingtimeProvider saving to redo history redoHistory[redoHistory.length - 1]?.value", - // redoHistory[redoHistory.length - 1]?.value - // ) - // console.log( - // "ThingtimeProvider saving to redo history stringified", - // stringified - // ) if (redoHistory[redoHistory.length - 1]?.value !== stringified) { try { - // console.log( - // "ThingtimeProvider saving to redo history redoHistory", - // redoHistory - // ) const limit = newThingtimeReference?.settings?.redoLimit || 999 if (redoHistory?.length > limit) { @@ -236,8 +182,6 @@ export const ThingtimeProvider = (props: any): JSX.Element => { // nothing } } - // window.localStorage.setItem("thingtime", stringified) - // }, 600) } catch (err) { console.error("There was an error saving thingtime to localStorage") } diff --git a/remix/app/components/Thingtime/Thingtime.tsx b/remix/app/components/Thingtime/Thingtime.tsx index ebe5a44..f508305 100644 --- a/remix/app/components/Thingtime/Thingtime.tsx +++ b/remix/app/components/Thingtime/Thingtime.tsx @@ -287,13 +287,24 @@ export const Thingtime = (props) => { } }, [thing, thingDep, type, chakras, keys]) + const hasChakraChildren = React.useMemo(() => { + return !props?.edit && chakra && render && thing?.children + }, [chakra, props?.edit, render, thing?.children]) + + const renderChakra = React.useMemo(() => { + if (!props?.edit && chakra && render) { + return true + } + return false + }, [chakra, props?.edit, render]) + const keysToUse = React.useMemo(() => { - if (!props?.edit && chakra) { + if (renderChakra) { return ["children"] } return keys - }, [chakra, keys, props?.edit]) + }, [hasChakraChildren, keys]) // const keysToUse = flattenedKeys const template1Modes = React.useMemo(() => { @@ -357,7 +368,7 @@ export const Thingtime = (props) => { notRoot fullPath={fullPath + "." + key?.key} path={key} - chakra={chakra} + chakraChildren={chakra} thing={nextThing} // thing={{ infinite: { yes: true } }} valuePl={pl} @@ -383,11 +394,9 @@ export const Thingtime = (props) => { console.log("Thingtime found thing?.props", fullPath, thing?.props) const ret = ( - - - {inner} - - + + {inner} + ) return ret } @@ -396,22 +405,27 @@ export const Thingtime = (props) => { } } + // TODO: Is it safe to spread props + // because having props as a dependency will cause a re-render every time + + if (props?.chakraChildren) { + return inner + } + return ( - - - {inner} - - + + {inner} + ) } }, [ @@ -420,13 +434,15 @@ export const Thingtime = (props) => { circular, seen, type, + props?.chakraChildren, + props?.path, + props?.edit, chakra, fullPath, render, depth, thing, thingDep, - props, valuePl, pl, keys, @@ -697,9 +713,9 @@ export const Thingtime = (props) => { const [showContextIcon, setShowContextIcon] = React.useState(false) - // if (render && depth >= 1) { - // return thingtimeChildren - // } + if (props?.chakraChildren) { + return thingtimeChildren + } return ( @@ -720,7 +736,7 @@ export const Thingtime = (props) => { data-path={props?.path} > {/* {uuid?.current} */} - {!chakras && ( + {!chakras && !chakra && ( { path={path} thing={thing} render - chakra chakras={{ marginY: 200 }} width="600px" >