feat: main Testing unique dom id system
This commit is contained in:
parent
7ea2048719
commit
9e40e2c227
@ -1,7 +1,13 @@
|
|||||||
import React from 'react'
|
import React from 'react'
|
||||||
import { Box, Flex } from '@chakra-ui/react'
|
import { Box, Flex } from '@chakra-ui/react'
|
||||||
|
import { safe } from '~/functions/safe'
|
||||||
|
|
||||||
export const Thingtime = props => {
|
export const Thingtime = props => {
|
||||||
|
// const cuid = React.useMemo(() => {
|
||||||
|
// return Math.random().toString(36).substring(7)
|
||||||
|
// }, [])
|
||||||
|
const cuid = React.useRef(Math.random().toString(36).substring(7))
|
||||||
|
|
||||||
const thing = React.useMemo(() => {
|
const thing = React.useMemo(() => {
|
||||||
return props.thing
|
return props.thing
|
||||||
}, [props.thing])
|
}, [props.thing])
|
||||||
@ -90,20 +96,8 @@ export const Thingtime = props => {
|
|||||||
return ret
|
return ret
|
||||||
}, [thing])
|
}, [thing])
|
||||||
|
|
||||||
// do not render more than the limit of things to prevent infinite loops
|
let value = null
|
||||||
try {
|
let editableValue = null
|
||||||
if (
|
|
||||||
typeof window?.thingtime?.things?.count === 'number' &&
|
|
||||||
window?.thingtime?.things?.count > window?.thingtime?.things?.limit
|
|
||||||
) {
|
|
||||||
console.error('Maximum things reached')
|
|
||||||
return null
|
|
||||||
}
|
|
||||||
} catch (err) {
|
|
||||||
// console.error('Error in Thingtime.tsx checking maximum things', err)
|
|
||||||
}
|
|
||||||
|
|
||||||
let ret = null
|
|
||||||
|
|
||||||
const keysToUse = keys
|
const keysToUse = keys
|
||||||
// const keysToUse = flattenedKeys
|
// const keysToUse = flattenedKeys
|
||||||
@ -113,7 +107,7 @@ export const Thingtime = props => {
|
|||||||
if (template1Modes?.includes(mode)) {
|
if (template1Modes?.includes(mode)) {
|
||||||
console.log('nik keys', keys)
|
console.log('nik keys', keys)
|
||||||
if (keys?.length) {
|
if (keys?.length) {
|
||||||
ret = (
|
value = (
|
||||||
<Flex
|
<Flex
|
||||||
position='relative'
|
position='relative'
|
||||||
flexDir='column'
|
flexDir='column'
|
||||||
@ -144,40 +138,62 @@ export const Thingtime = props => {
|
|||||||
</Flex>
|
</Flex>
|
||||||
)
|
)
|
||||||
} else {
|
} else {
|
||||||
ret = (
|
editableValue = (
|
||||||
<Flex flexDir='column'>
|
<Box
|
||||||
<Box>{props?.key?.human}</Box>
|
contentEditable={mode === 'edit'}
|
||||||
<Box
|
border='none'
|
||||||
contentEditable={mode === 'edit'}
|
outline={'none'}
|
||||||
border='none'
|
py={2}
|
||||||
outline={'none'}
|
fontSize={'20px'}
|
||||||
py={2}
|
>
|
||||||
fontSize={'20px'}
|
{renderableValue}
|
||||||
>
|
</Box>
|
||||||
{renderableValue}
|
|
||||||
</Box>
|
|
||||||
</Flex>
|
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const contextMenu = (
|
const contextMenu = (
|
||||||
<Flex position='absolute' top={0} right={0}>
|
<Flex userSelect={'none'} position='absolute' top={0} right={0}>
|
||||||
Settings
|
Settings
|
||||||
</Flex>
|
</Flex>
|
||||||
)
|
)
|
||||||
|
|
||||||
const [showContextMenu, setShowContextMenu] = React.useState(false)
|
const [showContextMenu, setShowContextMenu] = React.useState(false)
|
||||||
|
|
||||||
return (
|
const path = React.useMemo(() => {
|
||||||
|
return <Flex fontSize='12px'>{props?.path?.human}</Flex>
|
||||||
|
}, [props?.path])
|
||||||
|
|
||||||
|
const handleMouseEvent = React.useCallback(
|
||||||
|
e => {
|
||||||
|
const target = e?.target
|
||||||
|
// extract cuid from className
|
||||||
|
console.log('nik eh', target?.className, cuid)
|
||||||
|
const className = target?.className
|
||||||
|
if (className?.includes(cuid?.current)) {
|
||||||
|
setShowContextMenu(e?.type === 'mouseenter')
|
||||||
|
}
|
||||||
|
},
|
||||||
|
[cuid]
|
||||||
|
)
|
||||||
|
|
||||||
|
console.log('nik cuid', cuid)
|
||||||
|
|
||||||
|
return safe(
|
||||||
<Flex
|
<Flex
|
||||||
onMouseEnter={() => setShowContextMenu(true)}
|
onMouseEnter={handleMouseEvent}
|
||||||
onMouseLeave={() => setShowContextMenu(false)}
|
onMouseLeave={handleMouseEvent}
|
||||||
position='relative'
|
position='relative'
|
||||||
|
flexDir='column'
|
||||||
|
py={3}
|
||||||
{...props}
|
{...props}
|
||||||
|
className={`thing-${cuid?.current}`}
|
||||||
>
|
>
|
||||||
|
{cuid?.current}
|
||||||
|
{path}
|
||||||
{showContextMenu && contextMenu}
|
{showContextMenu && contextMenu}
|
||||||
{ret}
|
{editableValue}
|
||||||
|
{value}
|
||||||
</Flex>
|
</Flex>
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
@ -1,8 +1,7 @@
|
|||||||
import React from "react"
|
import React from 'react'
|
||||||
import { Thingtime } from "./Thingtime"
|
import { Thingtime } from './Thingtime'
|
||||||
|
|
||||||
export const ThingtimeDemo = props => {
|
export const ThingtimeDemo = props => {
|
||||||
|
|
||||||
const thing = {
|
const thing = {
|
||||||
name: 'thing',
|
name: 'thing',
|
||||||
description: 'thing description',
|
description: 'thing description',
|
||||||
@ -20,8 +19,10 @@ export const ThingtimeDemo = props => {
|
|||||||
}
|
}
|
||||||
|
|
||||||
const [demoThing, setDemoThing] = React.useState(thing)
|
const [demoThing, setDemoThing] = React.useState(thing)
|
||||||
|
|
||||||
|
|
||||||
return <Thingtime thing={demoThing}></Thingtime>
|
|
||||||
|
|
||||||
}
|
const debug = {
|
||||||
|
test: 'hey'
|
||||||
|
}
|
||||||
|
|
||||||
|
return <Thingtime thing={debug}></Thingtime>
|
||||||
|
}
|
||||||
|
16
remix/app/functions/safe.tsx
Normal file
16
remix/app/functions/safe.tsx
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
export const safe = response => {
|
||||||
|
// do not render more than the limit of things to prevent infinite loops
|
||||||
|
try {
|
||||||
|
if (
|
||||||
|
typeof window?.thingtime?.things?.count === 'number' &&
|
||||||
|
window?.thingtime?.things?.count > window?.thingtime?.things?.limit
|
||||||
|
) {
|
||||||
|
console.error('Maximum things reached')
|
||||||
|
return null
|
||||||
|
}
|
||||||
|
} catch (err) {
|
||||||
|
// console.error('Error in Thingtime.tsx checking maximum things', err)
|
||||||
|
}
|
||||||
|
|
||||||
|
return response
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user