Add a Bun script to apply and normalize AGPL copyright headers across the default frontend source files. The script keeps headers idempotent, upgrades existing headers to the 2023-2026 QuantumNous range, and is exposed through `bun run copyright` for future maintenance.
118 lines
3.5 KiB
TypeScript
Vendored
118 lines
3.5 KiB
TypeScript
Vendored
/*
|
|
Copyright (C) 2023-2026 QuantumNous
|
|
|
|
This program is free software: you can redistribute it and/or modify
|
|
it under the terms of the GNU Affero General Public License as
|
|
published by the Free Software Foundation, either version 3 of the
|
|
License, or (at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU Affero General Public License for more details.
|
|
|
|
You should have received a copy of the GNU Affero General Public License
|
|
along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
For commercial licensing, please contact support@quantumnous.com
|
|
*/
|
|
import * as React from 'react'
|
|
import { Popover as PopoverPrimitive } from '@base-ui/react/popover'
|
|
import { cn } from '@/lib/utils'
|
|
|
|
function Popover({ ...props }: PopoverPrimitive.Root.Props) {
|
|
return <PopoverPrimitive.Root data-slot='popover' {...props} />
|
|
}
|
|
|
|
function PopoverTrigger({ ...props }: PopoverPrimitive.Trigger.Props) {
|
|
return <PopoverPrimitive.Trigger data-slot='popover-trigger' {...props} />
|
|
}
|
|
|
|
function PopoverContent({
|
|
className,
|
|
align = 'center',
|
|
alignOffset = 0,
|
|
side = 'bottom',
|
|
sideOffset = 4,
|
|
collisionPadding,
|
|
collisionBoundary,
|
|
collisionAvoidance,
|
|
...props
|
|
}: PopoverPrimitive.Popup.Props &
|
|
Pick<
|
|
PopoverPrimitive.Positioner.Props,
|
|
| 'align'
|
|
| 'alignOffset'
|
|
| 'side'
|
|
| 'sideOffset'
|
|
| 'collisionPadding'
|
|
| 'collisionBoundary'
|
|
| 'collisionAvoidance'
|
|
>) {
|
|
return (
|
|
<PopoverPrimitive.Portal>
|
|
<PopoverPrimitive.Positioner
|
|
align={align}
|
|
alignOffset={alignOffset}
|
|
side={side}
|
|
sideOffset={sideOffset}
|
|
collisionPadding={collisionPadding}
|
|
collisionBoundary={collisionBoundary}
|
|
collisionAvoidance={collisionAvoidance}
|
|
className='isolate z-50'
|
|
>
|
|
<PopoverPrimitive.Popup
|
|
data-slot='popover-content'
|
|
className={cn(
|
|
'bg-popover text-popover-foreground ring-foreground/10 data-[side=bottom]:slide-in-from-top-2 data-[side=inline-end]:slide-in-from-left-2 data-[side=inline-start]:slide-in-from-right-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 data-open:animate-in data-open:fade-in-0 data-open:zoom-in-95 data-closed:animate-out data-closed:fade-out-0 data-closed:zoom-out-95 z-50 flex w-72 origin-(--transform-origin) flex-col gap-2.5 rounded-lg p-2.5 text-sm shadow-md ring-1 outline-hidden duration-100',
|
|
className
|
|
)}
|
|
{...props}
|
|
/>
|
|
</PopoverPrimitive.Positioner>
|
|
</PopoverPrimitive.Portal>
|
|
)
|
|
}
|
|
|
|
function PopoverHeader({ className, ...props }: React.ComponentProps<'div'>) {
|
|
return (
|
|
<div
|
|
data-slot='popover-header'
|
|
className={cn('flex flex-col gap-0.5 text-sm', className)}
|
|
{...props}
|
|
/>
|
|
)
|
|
}
|
|
|
|
function PopoverTitle({ className, ...props }: PopoverPrimitive.Title.Props) {
|
|
return (
|
|
<PopoverPrimitive.Title
|
|
data-slot='popover-title'
|
|
className={cn('font-medium', className)}
|
|
{...props}
|
|
/>
|
|
)
|
|
}
|
|
|
|
function PopoverDescription({
|
|
className,
|
|
...props
|
|
}: PopoverPrimitive.Description.Props) {
|
|
return (
|
|
<PopoverPrimitive.Description
|
|
data-slot='popover-description'
|
|
className={cn('text-muted-foreground', className)}
|
|
{...props}
|
|
/>
|
|
)
|
|
}
|
|
|
|
export {
|
|
Popover,
|
|
PopoverContent,
|
|
PopoverDescription,
|
|
PopoverHeader,
|
|
PopoverTitle,
|
|
PopoverTrigger,
|
|
}
|