import React from 'react' import { Box, Flex } from '@chakra-ui/react' import { Safe } from '../Safety/Safe' import { useState } from './useState' export const Thingtime = props => { // const uuid = React.useMemo(() => { // return Math.random().toString(36).substring(7) // }, []) const uuid = React.useRef(Math.random().toString(36).substring(7)) const { state } = useState() React.useEffect(() => { console.log('nik state?.test changed', state?.test) }, [state?.test]) React.useEffect(() => { console.log('nik state changed', state) }, [state]) const depth = React.useMemo(() => { return props?.depth || 1 }, [props?.depth]) const thing = React.useMemo(() => { return props.thing }, [props.thing]) const mode = React.useMemo(() => { return 'view' }, []) const validKeyTypes = React.useMemo(() => { return ['object', 'array'] }, []) const keys = React.useMemo(() => { if (validKeyTypes?.includes(typeof thing)) { return Object.keys(thing) } else { return [] } }, [thing, validKeyTypes]) const type = React.useMemo(() => { return typeof thing }, [thing]) const renderableValue = React.useMemo(() => { if (type === 'string') { return thing } else if (type === 'number') { return thing } else if (type === 'boolean') { return thing ? 'true' : 'false' } else if (type === 'object') { return JSON.stringify(thing, null, 2) } else { return null } }, [thing, type]) const flattenedKeys = React.useMemo(() => { // create an array of all keys on object so that if object is // { my: { child: {} } } // the array looks like // ['my', 'my.child'] const ret = [] try { const randId = Math.random().toString(36).substring(7) window.thingtime.tmp[randId] = 0 const recurse = (obj, prefix) => { Object.keys(obj).forEach(key => { if (typeof obj[key] === 'object') { if (window?.thingtime?.tmp[randId] < 1000) { window.thingtime.tmp[randId]++ recurse(obj[key], `${prefix}${prefix && '.'}${key}`) } else { console.error('Recursion limit reached in Thingtime.tsx') } } else { ret.push({ key: `${prefix}${prefix && '.'}${key}`, human: `${prefix}${prefix && ' '}${key}` }) } }) } recurse(thing, '') } catch (err) { // console.error('Error in Thingtime.tsx creating flattenedKeys', err) } return ret }, [thing]) let value = null let editableValue = null const keysToUse = keys // const keysToUse = flattenedKeys const template1Modes = ['view', 'edit'] if (template1Modes?.includes(mode)) { if (keys?.length) { value = ( {keysToUse?.length && keysToUse.map((key, idx) => { if (!key?.human) { key = { human: key, key: key } } const nextThing = thing[key?.key] return ( ) })} ) } else { editableValue = ( {renderableValue} ) } } const contextMenu = ( Settings ) const [showContextMenu, setShowContextMenu] = React.useState(false) const path = React.useMemo(() => { return ( {props?.path?.human} ) }, [props?.path]) const handleMouseEvent = React.useCallback( e => { const target = e?.target // extract uuid from className const className = target?.className if (className?.includes(uuid?.current)) { setShowContextMenu(e?.type === 'mouseenter') } }, [uuid] ) return ( {/* {uuid?.current} */} {path} {showContextMenu && contextMenu} {editableValue} {value} ) }