36 lines
1.3 KiB
TypeScript
36 lines
1.3 KiB
TypeScript
import type { Component, ValidComponent } from 'solid-js';
|
|
import { splitProps } from 'solid-js';
|
|
|
|
import type { PolymorphicProps } from '@kobalte/core/polymorphic';
|
|
import * as PopoverPrimitive from '@kobalte/core/popover';
|
|
|
|
import { cn } from '~/utils/styles';
|
|
|
|
const PopoverTrigger = PopoverPrimitive.Trigger;
|
|
|
|
const Popover: Component<PopoverPrimitive.PopoverRootProps> = (props) => {
|
|
return <PopoverPrimitive.Root gutter={4} {...props} />;
|
|
};
|
|
|
|
type PopoverContentProps<T extends ValidComponent = 'div'> =
|
|
PopoverPrimitive.PopoverContentProps<T> & { class?: string | undefined };
|
|
|
|
const PopoverContent = <T extends ValidComponent = 'div'>(
|
|
props: PolymorphicProps<T, PopoverContentProps<T>>
|
|
) => {
|
|
const [local, others] = splitProps(props as PopoverContentProps, ['class']);
|
|
return (
|
|
<PopoverPrimitive.Portal>
|
|
<PopoverPrimitive.Content
|
|
class={cn(
|
|
'data-[closed]:fade-out-0 data-[expanded]:fade-in-0 data-[closed]:zoom-out-95 data-[expanded]:zoom-in-95 z-50 w-72 origin-[var(--kb-popover-content-transform-origin)] rounded-md border bg-popover p-4 text-popover-foreground shadow-md outline-none data-[closed]:animate-out data-[expanded]:animate-in',
|
|
local.class
|
|
)}
|
|
{...others}
|
|
/>
|
|
</PopoverPrimitive.Portal>
|
|
);
|
|
};
|
|
|
|
export { Popover, PopoverTrigger, PopoverContent };
|