fix(Popover): apply asChild effect on PopoverContent
This commit is contained in:
parent
80c7542803
commit
2e441ff1e5
@ -200,7 +200,7 @@ const PopoverContent = React.forwardRef<HTMLDivElement, PopoverContentProps>(
|
|||||||
(props, ref) => {
|
(props, ref) => {
|
||||||
const [variantProps, otherPropsCompressed] =
|
const [variantProps, otherPropsCompressed] =
|
||||||
resolvePopoverContentVariantProps(props);
|
resolvePopoverContentVariantProps(props);
|
||||||
const { children, ...otherPropsExtracted } = otherPropsCompressed;
|
const { children, asChild, ...otherPropsExtracted } = otherPropsCompressed;
|
||||||
const [state, setState] = useContext(PopoverContext);
|
const [state, setState] = useContext(PopoverContext);
|
||||||
|
|
||||||
const internalRef = useRef<HTMLDivElement | null>(null);
|
const internalRef = useRef<HTMLDivElement | null>(null);
|
||||||
@ -221,8 +221,10 @@ const PopoverContent = React.forwardRef<HTMLDivElement, PopoverContentProps>(
|
|||||||
};
|
};
|
||||||
}, [state.controlled, setState]);
|
}, [state.controlled, setState]);
|
||||||
|
|
||||||
|
const Comp = asChild ? Slot : "div";
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div
|
<Comp
|
||||||
{...otherPropsExtracted}
|
{...otherPropsExtracted}
|
||||||
className={popoverContentVariant({
|
className={popoverContentVariant({
|
||||||
...variantProps,
|
...variantProps,
|
||||||
@ -238,7 +240,7 @@ const PopoverContent = React.forwardRef<HTMLDivElement, PopoverContentProps>(
|
|||||||
}}
|
}}
|
||||||
>
|
>
|
||||||
{children}
|
{children}
|
||||||
</div>
|
</Comp>
|
||||||
);
|
);
|
||||||
},
|
},
|
||||||
);
|
);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user