d146e45e2f
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.
95 lines
2.5 KiB
TypeScript
Vendored
95 lines
2.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
|
|
*/
|
|
'use client'
|
|
|
|
import {
|
|
CheckmarkCircle02Icon,
|
|
InformationCircleIcon,
|
|
Alert02Icon,
|
|
MultiplicationSignCircleIcon,
|
|
Loading03Icon,
|
|
} from '@hugeicons/core-free-icons'
|
|
import { HugeiconsIcon } from '@hugeicons/react'
|
|
import { useTheme } from 'next-themes'
|
|
import { Toaster as Sonner, type ToasterProps } from 'sonner'
|
|
|
|
const Toaster = ({ ...props }: ToasterProps) => {
|
|
const { theme = 'system' } = useTheme()
|
|
|
|
return (
|
|
<Sonner
|
|
theme={theme as ToasterProps['theme']}
|
|
className='toaster group'
|
|
icons={{
|
|
success: (
|
|
<HugeiconsIcon
|
|
icon={CheckmarkCircle02Icon}
|
|
strokeWidth={2}
|
|
className='size-4'
|
|
/>
|
|
),
|
|
info: (
|
|
<HugeiconsIcon
|
|
icon={InformationCircleIcon}
|
|
strokeWidth={2}
|
|
className='size-4'
|
|
/>
|
|
),
|
|
warning: (
|
|
<HugeiconsIcon
|
|
icon={Alert02Icon}
|
|
strokeWidth={2}
|
|
className='size-4'
|
|
/>
|
|
),
|
|
error: (
|
|
<HugeiconsIcon
|
|
icon={MultiplicationSignCircleIcon}
|
|
strokeWidth={2}
|
|
className='size-4'
|
|
/>
|
|
),
|
|
loading: (
|
|
<HugeiconsIcon
|
|
icon={Loading03Icon}
|
|
strokeWidth={2}
|
|
className='size-4 animate-spin'
|
|
/>
|
|
),
|
|
}}
|
|
style={
|
|
{
|
|
'--normal-bg': 'var(--popover)',
|
|
'--normal-text': 'var(--popover-foreground)',
|
|
'--normal-border': 'var(--border)',
|
|
'--border-radius': 'var(--radius)',
|
|
} as React.CSSProperties
|
|
}
|
|
toastOptions={{
|
|
classNames: {
|
|
toast: 'cn-toast',
|
|
},
|
|
}}
|
|
{...props}
|
|
/>
|
|
)
|
|
}
|
|
|
|
export { Toaster }
|