Commit e7ecdb01 authored by StyleZhang's avatar StyleZhang

block-selector

parent 383bfd75
import type { FC } from 'react' import type {
FC,
MouseEventHandler,
} from 'react'
import { import {
memo, memo,
useCallback,
useState, useState,
} from 'react' } from 'react'
import type { import type {
...@@ -25,6 +29,7 @@ type NodeSelectorProps = { ...@@ -25,6 +29,7 @@ type NodeSelectorProps = {
placement?: Placement placement?: Placement
offset?: OffsetOptions offset?: OffsetOptions
triggerStyle?: React.CSSProperties triggerStyle?: React.CSSProperties
triggerClassName?: string
popupClassName?: string popupClassName?: string
asChild?: boolean asChild?: boolean
} }
...@@ -33,11 +38,17 @@ const NodeSelector: FC<NodeSelectorProps> = ({ ...@@ -33,11 +38,17 @@ const NodeSelector: FC<NodeSelectorProps> = ({
trigger, trigger,
placement = 'right', placement = 'right',
offset = 6, offset = 6,
triggerClassName,
triggerStyle, triggerStyle,
popupClassName, popupClassName,
asChild, asChild,
}) => { }) => {
const [open, setOpen] = useState(false) const [open, setOpen] = useState(false)
const handleTrigger = useCallback<MouseEventHandler<HTMLDivElement>>((e) => {
e.stopPropagation()
setOpen(v => !v)
}, [])
return ( return (
<PortalToFollowElem <PortalToFollowElem
placement={placement} placement={placement}
...@@ -45,7 +56,10 @@ const NodeSelector: FC<NodeSelectorProps> = ({ ...@@ -45,7 +56,10 @@ const NodeSelector: FC<NodeSelectorProps> = ({
open={open} open={open}
onOpenChange={setOpen} onOpenChange={setOpen}
> >
<PortalToFollowElemTrigger asChild={asChild} onClick={() => setOpen(v => !v)}> <PortalToFollowElemTrigger
asChild={asChild}
onClick={handleTrigger}
>
{ {
trigger trigger
? trigger(open) ? trigger(open)
...@@ -54,6 +68,7 @@ const NodeSelector: FC<NodeSelectorProps> = ({ ...@@ -54,6 +68,7 @@ const NodeSelector: FC<NodeSelectorProps> = ({
className={` className={`
flex items-center justify-center flex items-center justify-center
w-4 h-4 rounded-full bg-primary-600 cursor-pointer z-10 group-hover:flex w-4 h-4 rounded-full bg-primary-600 cursor-pointer z-10 group-hover:flex
${triggerClassName}
`} `}
style={triggerStyle} style={triggerStyle}
> >
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment