From 9223138d12225f062a93ebf78cd9debe95829f2f Mon Sep 17 00:00:00 2001 From: Nikolaj Frey Date: Sun, 13 Aug 2023 00:06:33 +1000 Subject: [PATCH] feat: feature/mvp-sprint-1 Progress on commander changes --- remix/app/Providers/ThingtimeProvider.tsx | 18 +- remix/app/components/Commander/Commander.tsx | 171 ++++++++++++------- remix/app/components/Icon/Icon.tsx | 5 +- remix/app/components/Nav/Nav.tsx | 2 +- remix/app/components/Thingtime/Thingtime.tsx | 27 ++- remix/app/functions/safe.tsx | 22 +-- remix/app/root.tsx | 3 +- 7 files changed, 160 insertions(+), 88 deletions(-) diff --git a/remix/app/Providers/ThingtimeProvider.tsx b/remix/app/Providers/ThingtimeProvider.tsx index b7c9307..6dd10c7 100644 --- a/remix/app/Providers/ThingtimeProvider.tsx +++ b/remix/app/Providers/ThingtimeProvider.tsx @@ -27,14 +27,14 @@ try { const force = { settings: { - commanders: { - nav: { - // commanderActive: false, - // clearCommanderOnToggle: true, - // clearCommanderContextOnToggle: true, - // hideSuggestionsOnToggle: true, - }, - }, + // commander: { + // nav: { + // commanderActive: false, + // clearCommanderOnToggle: true, + // clearCommanderContextOnToggle: true, + // hideSuggestionsOnToggle: true, + // }, + // }, }, version: 23, } @@ -51,7 +51,7 @@ const newVersionData = { const initialValues = { settings: { - commanders: { + commander: { nav: { commanderActive: false, clearCommanderOnToggle: true, diff --git a/remix/app/components/Commander/Commander.tsx b/remix/app/components/Commander/Commander.tsx index 50b8407..276f93d 100644 --- a/remix/app/components/Commander/Commander.tsx +++ b/remix/app/components/Commander/Commander.tsx @@ -20,6 +20,16 @@ export const Commander = (props) => { const inputRef = React.useRef() + const global = props?.global + + const commanderSettings = React.useMemo(() => { + return thingtime?.settings?.commander?.[commanderId] || {} + }, [ + thingtime?.settings?.commander, + thingtime?.settings?.commander?.[commanderId], + commanderId, + ]) + const [inputValue, setInputValue] = React.useState("") const [virtualValue, setVirtualValue] = React.useState("") const [hoveredSuggestion, setHoveredSuggestion] = React.useState() @@ -53,8 +63,8 @@ export const Commander = (props) => { }, [contextPath, getThingtime]) const commanderActive = React.useMemo(() => { - return getThingtime("settings.commanderActive." + commanderId) - }, [commanderId, getThingtime]) + return thingtime?.settings?.commander?.[commanderId]?.commanderActive + }, [commanderSettings, commanderId]) // commanderActive useEffect React.useEffect(() => { @@ -63,11 +73,18 @@ export const Commander = (props) => { } else { document.activeElement.blur() - if (thingtimeRef?.current?.settings?.clearCommanderOnToggle) { + if ( + thingtimeRef?.current?.settings?.commander?.[commanderId] + ?.clearCommanderOnToggle + ) { setInputValue("") setHoveredSuggestion(null) } - if (thingtimeRef?.current?.settings?.clearCommanderContextOnToggle) { + if ( + thingtimeRef?.current?.settings?.commander?.[commanderId]?.commander?.[ + commanderId + ]?.clearCommanderContextOnToggle + ) { setShowContext(false, "commanderActive useEffect") } if (contextPath !== undefined && !inputValue) { @@ -81,6 +98,7 @@ export const Commander = (props) => { commanderActive, thingtimeRef, setShowContext, + commanderId, inputValue, contextPath, showContext, @@ -178,13 +196,15 @@ export const Commander = (props) => { inputValue?.length && suggestions?.length && commanderActive && - thingtime?.settings?.hideSuggestionsOnToggle + thingtime?.settings?.commander?.[commanderId]?.hideSuggestionsOnToggle ) }, [ inputValue, suggestions, commanderActive, - thingtime?.settings?.hideSuggestionsOnToggle, + commanderId, + thingtime?.settings?.commander, + commanderSettings, ]) const selectSuggestion = React.useCallback( @@ -208,27 +228,41 @@ export const Commander = (props) => { }, [commandPath, suggestions]) const openCommander = React.useCallback(() => { - setThingtime("settings.commanderActive", true) - }, [setThingtime]) + setThingtime(`settings.commander.${commanderId}.commanderActive`, true) + }, [setThingtime, commanderId]) const closeCommander = React.useCallback( (e?: any) => { if (!e?.defaultPrevented) { - if (thingtime?.settings?.commanderActive) { - setThingtime("settings.commanderActive", false) + if (thingtime?.settings?.commander?.[commanderId]?.commanderActive) { + setThingtime( + `settings.commander.${commanderId}.commanderActive`, + false + ) } } }, - [setThingtime, thingtime?.settings?.commanderActive] + [ + setThingtime, + commanderId, + commanderSettings, + thingtime?.settings?.commander, + ] ) const toggleCommander = React.useCallback(() => { - if (thingtime?.settings?.commanderActive) { + if (thingtime?.settings?.commander?.[commanderId]?.commanderActive) { closeCommander() } else { openCommander() } - }, [thingtime?.settings?.commanderActive, closeCommander, openCommander]) + }, [ + thingtime?.settings?.commander, + commanderSettings, + commanderId, + closeCommander, + openCommander, + ]) const executeCommand = React.useCallback(() => { // if selection is active then select it @@ -380,6 +414,58 @@ export const Commander = (props) => { setVirtualValue(inputValue) }, [inputValue]) + const InputJSX = React.useMemo(() => { + return ( + + ) + }, [inputRef, inputValue, onInputChange, openCommander]) + + const MainInput = React.useMemo(() => { + return ( +
+ {props?.rainbow && ( + + )} + {InputJSX} +
+ ) + }, [InputJSX, commanderActive, rainbowRepeats, props?.rainbow, mobileVW]) + return ( { maxWidth={[mobileVW, "100%"]} height="100%" > - -
- - -
-
+ {MainInput} + + )} + {!props?.rainbow && MainInput}
diff --git a/remix/app/components/Icon/Icon.tsx b/remix/app/components/Icon/Icon.tsx index b49d85f..23318ea 100644 --- a/remix/app/components/Icon/Icon.tsx +++ b/remix/app/components/Icon/Icon.tsx @@ -133,13 +133,16 @@ export const Icon = (props) => { if (["seedling", "seed"]?.includes(name)) { return "🌱" } - if (["undefined"]?.includes(name)) { + if (["undefined", "null", "question", "confused"]?.includes(name)) { return "❓" // return "🌫️" } if (["codex", "robot", "ai", "chatgpt"]?.includes(name)) { return "🤖" } + if (["trash", "bin", "delete", "remove"]?.includes(name)) { + return "🗑️" + } if (["thingtime"]?.includes(name)) { if (Math.random() > 0.5) { return "🌳" diff --git a/remix/app/components/Nav/Nav.tsx b/remix/app/components/Nav/Nav.tsx index 3266fae..19da4de 100644 --- a/remix/app/components/Nav/Nav.tsx +++ b/remix/app/components/Nav/Nav.tsx @@ -49,7 +49,7 @@ export const Nav = (props) => { - +
{ [pl] ) + const propsRef = React.useRef(props) + + React.useEffect(() => { + propsRef.current = props + }, [props]) + // will only run on the client React.useEffect(() => { setUuid(Math.random().toString(36).substring(7)) @@ -99,15 +105,24 @@ export const Thingtime = (props) => { return props.thing }, [props.thing, childrenRef.current]) + const fullPath = React.useMemo(() => { + const ret = props?.fullPath || props?.path + + // store this thing in the global db + try { + window.meta.things[ret] = props?.thing + } catch { + // nothing + } + + return ret + }, [props?.fullPath, props?.path, props?.thing]) + React.useEffect(() => { console.log("thingtime changed in path", props?.fullPath) createDependancies() }, [thingtime, props?.fullPath, childrenRef]) - const fullPath = React.useMemo(() => { - return props?.fullPath || props?.path - }, [props?.fullPath, props?.path]) - const seen = React.useMemo(() => { if (props?.seen instanceof Array) { if (props?.seen?.includes(thing)) { @@ -460,7 +475,7 @@ export const Thingtime = (props) => { return ( {/* TODO: Implement UI-less commander */} - {/* */} + ) } @@ -476,6 +491,8 @@ export const Thingtime = (props) => { renderableValue, pl, type, + fullPath, + uuid, AtomicWrapper, props?.edit, thing, diff --git a/remix/app/functions/safe.tsx b/remix/app/functions/safe.tsx index f3f6faa..c905f8c 100644 --- a/remix/app/functions/safe.tsx +++ b/remix/app/functions/safe.tsx @@ -1,18 +1,18 @@ export const safe = (props) => { // do not render more than the limit of things to prevent infinite loops - const thingtime = getThingtime() + const meta = getMeta() const uuid = props?.uuid try { if ( - typeof thingtime?.things?.count === "number" && - thingtime?.things?.count >= thingtime?.things?.limit + typeof meta?.stats?.count === "number" && + meta?.stats?.count >= meta?.stats?.limit ) { console.error( "[codex] Maximum things reached", - thingtime?.things?.count, - thingtime?.things?.limit + meta?.stats?.count, + meta?.stats?.limit ) return null } @@ -21,22 +21,22 @@ export const safe = (props) => { } try { - if (!thingtime?.things?.db?.[uuid]) { - thingtime.things.db[uuid] = { + if (!meta?.stats?.db?.[uuid]) { + meta.stats.db[uuid] = { count: 1, } - thingtime.things.count++ + meta.stats.count++ } } catch { // empty } try { - if (props?.depth >= thingtime?.things?.maxDepth) { + if (props?.depth >= meta?.stats?.maxDepth) { console.error( "[codex] Reached max depth", props?.depth, - thingtime?.things?.maxDepth + meta?.stats?.maxDepth ) return null } @@ -51,7 +51,7 @@ export const safe = (props) => { } } -export const getThingtime = () => { +export const getMeta = () => { try { return window?.meta || globalThis?.meta } catch { diff --git a/remix/app/root.tsx b/remix/app/root.tsx index 041cfd2..0491a20 100644 --- a/remix/app/root.tsx +++ b/remix/app/root.tsx @@ -65,12 +65,13 @@ const setThingtime = (glob) => { subscribers: {}, state: {}, db: {}, - things: { + stats: { db: {}, limit: 9999, maxDepth: 10, count: 0, }, + things: {}, } } catch (err) { // will error on server