konobangu/apps/webui/src/components/ui/popover.tsx

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 };