@roy-ui/ui 0.0.6 → 0.0.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (69) hide show
  1. package/dist/Button-OZLAH5NO.css +179 -0
  2. package/dist/{Pagination-FUYIHYSD.css → Pagination-LLKV7XXI.css} +3 -1
  3. package/dist/Table-qVdGZkB4.d.ts +42 -0
  4. package/dist/TimePicker-BhRta4MK.d.ts +39 -0
  5. package/dist/chunk-4SGMAZBG.js +161 -0
  6. package/dist/chunk-4SGMAZBG.js.map +1 -0
  7. package/dist/chunk-5CIBIH7R.js +98 -0
  8. package/dist/chunk-5CIBIH7R.js.map +1 -0
  9. package/dist/chunk-75IGGPXL.js +518 -0
  10. package/dist/chunk-75IGGPXL.js.map +1 -0
  11. package/dist/chunk-C5X3TE5U.js +87 -0
  12. package/dist/chunk-C5X3TE5U.js.map +1 -0
  13. package/dist/chunk-HUCK7AM7.js +840 -0
  14. package/dist/chunk-HUCK7AM7.js.map +1 -0
  15. package/dist/chunk-KSHKVSNK.js +82 -0
  16. package/dist/chunk-KSHKVSNK.js.map +1 -0
  17. package/dist/chunk-M6HB6BMA.js +101 -0
  18. package/dist/chunk-M6HB6BMA.js.map +1 -0
  19. package/dist/chunk-MDPMEW4K.js +58 -0
  20. package/dist/chunk-MDPMEW4K.js.map +1 -0
  21. package/dist/chunk-PGV55XSZ.js +107 -0
  22. package/dist/chunk-PGV55XSZ.js.map +1 -0
  23. package/dist/chunk-RLBVY3DG.js +64 -0
  24. package/dist/chunk-RLBVY3DG.js.map +1 -0
  25. package/dist/chunk-SFENGB5N.js +410 -0
  26. package/dist/chunk-SFENGB5N.js.map +1 -0
  27. package/dist/chunk-XERZVDIT.js +194 -0
  28. package/dist/chunk-XERZVDIT.js.map +1 -0
  29. package/dist/components/button/index.d.ts +37 -0
  30. package/dist/components/button/index.js +4 -0
  31. package/dist/components/button/index.js.map +1 -0
  32. package/dist/components/data-table/index.d.ts +145 -0
  33. package/dist/components/data-table/index.js +9 -0
  34. package/dist/components/data-table/index.js.map +1 -0
  35. package/dist/components/date-range-picker/index.d.ts +30 -0
  36. package/dist/components/date-range-picker/index.js +4 -0
  37. package/dist/components/date-range-picker/index.js.map +1 -0
  38. package/dist/components/gradient-button/index.d.ts +12 -0
  39. package/dist/components/gradient-button/index.js +4 -0
  40. package/dist/components/gradient-button/index.js.map +1 -0
  41. package/dist/components/made-by/index.d.ts +23 -0
  42. package/dist/components/made-by/index.js +4 -0
  43. package/dist/components/made-by/index.js.map +1 -0
  44. package/dist/components/pagination/index.d.ts +23 -0
  45. package/dist/components/pagination/index.js +4 -0
  46. package/dist/components/pagination/index.js.map +1 -0
  47. package/dist/components/popover/index.d.ts +18 -0
  48. package/dist/components/popover/index.js +4 -0
  49. package/dist/components/popover/index.js.map +1 -0
  50. package/dist/components/table/index.d.ts +28 -0
  51. package/dist/components/table/index.js +4 -0
  52. package/dist/components/table/index.js.map +1 -0
  53. package/dist/components/table-search/index.d.ts +19 -0
  54. package/dist/components/table-search/index.js +4 -0
  55. package/dist/components/table-search/index.js.map +1 -0
  56. package/dist/components/text-morph/index.d.ts +28 -0
  57. package/dist/components/text-morph/index.js +4 -0
  58. package/dist/components/text-morph/index.js.map +1 -0
  59. package/dist/components/time-picker/index.d.ts +14 -0
  60. package/dist/components/time-picker/index.js +4 -0
  61. package/dist/components/time-picker/index.js.map +1 -0
  62. package/dist/components/tree-nav/index.d.ts +30 -0
  63. package/dist/components/tree-nav/index.js +4 -0
  64. package/dist/components/tree-nav/index.js.map +1 -0
  65. package/dist/dateUtils-B_m_EICl.d.ts +14 -0
  66. package/dist/index.d.ts +17 -408
  67. package/dist/index.js +12 -2462
  68. package/dist/index.js.map +1 -1
  69. package/package.json +51 -2
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/data-table/ColumnMenu.tsx","../src/components/data-table/useTableLayout.ts","../src/components/data-table/filters.ts","../src/components/data-table/io.ts","../src/components/data-table/DataTable.tsx"],"names":["useState","useEffect","useMemo","useRef","useCallback","jsxs","jsx"],"mappings":"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","file":"chunk-HUCK7AM7.js","sourcesContent":["'use client';\n\nimport { useEffect, useRef, useState } from 'react';\nimport type { Column, TableLayout } from './types';\n\nexport interface ColumnMenuProps<T> {\n columns: Column<T>[];\n layout: TableLayout;\n onToggle: (key: string) => void;\n onReset: () => void;\n}\n\nexport function ColumnMenu<T>({\n columns,\n layout,\n onToggle,\n onReset,\n}: ColumnMenuProps<T>) {\n const [open, setOpen] = useState(false);\n const wrap = useRef<HTMLDivElement>(null);\n\n useEffect(() => {\n if (!open) return;\n function onDown(e: MouseEvent) {\n if (wrap.current && !wrap.current.contains(e.target as Node)) {\n setOpen(false);\n }\n }\n function onKey(e: KeyboardEvent) {\n if (e.key === 'Escape') setOpen(false);\n }\n document.addEventListener('mousedown', onDown);\n document.addEventListener('keydown', onKey);\n return () => {\n document.removeEventListener('mousedown', onDown);\n document.removeEventListener('keydown', onKey);\n };\n }, [open]);\n\n const hiddenCount = layout.hidden.length;\n\n return (\n <div className=\"royui-dt-colmenu\" ref={wrap}>\n <button\n type=\"button\"\n className=\"royui-dt-colmenu__trigger\"\n onClick={() => setOpen((o) => !o)}\n aria-expanded={open}\n aria-haspopup=\"menu\"\n >\n Columns\n </button>\n {hiddenCount > 0 && (\n <button\n type=\"button\"\n className=\"royui-dt-colmenu__chip\"\n onClick={() => setOpen(true)}\n >\n {hiddenCount} hidden\n </button>\n )}\n\n {open && (\n <div className=\"royui-dt-colmenu__panel\" role=\"menu\">\n <div className=\"royui-dt-colmenu__head\">\n <span className=\"royui-dt-colmenu__title\">Columns</span>\n <button\n type=\"button\"\n className=\"royui-dt-colmenu__reset\"\n onClick={() => {\n onReset();\n }}\n >\n Reset\n </button>\n </div>\n <ul className=\"royui-dt-colmenu__list\">\n {columns.map((c) => {\n const isHidden = layout.hidden.includes(c.key);\n const disabled = c.hideable === false;\n return (\n <li key={c.key}>\n <button\n type=\"button\"\n role=\"menuitemcheckbox\"\n aria-checked={!isHidden}\n className={[\n 'royui-dt-colmenu__row',\n isHidden && 'royui-dt-colmenu__row--off',\n disabled && 'royui-dt-colmenu__row--locked',\n ]\n .filter(Boolean)\n .join(' ')}\n onClick={() => !disabled && onToggle(c.key)}\n disabled={disabled}\n >\n <span\n className={[\n 'royui-dt-colmenu__dot',\n !isHidden && 'royui-dt-colmenu__dot--on',\n ]\n .filter(Boolean)\n .join(' ')}\n aria-hidden\n />\n <span className=\"royui-dt-colmenu__label\">{c.header}</span>\n </button>\n </li>\n );\n })}\n </ul>\n </div>\n )}\n </div>\n );\n}\n","'use client';\n\nimport { useCallback, useEffect, useMemo, useState } from 'react';\nimport type { Column, TableLayout } from './types';\n\nfunction defaultLayout<T>(columns: Column<T>[]): TableLayout {\n return {\n order: columns.map((c) => c.key),\n sizes: columns.reduce<Record<string, number>>((acc, c) => {\n if (c.defaultWidth != null) acc[c.key] = c.defaultWidth;\n return acc;\n }, {}),\n hidden: columns.filter((c) => c.defaultHidden).map((c) => c.key),\n };\n}\n\nfunction loadLayout(key: string | undefined): TableLayout | null {\n if (!key || typeof window === 'undefined') return null;\n try {\n const raw = window.localStorage.getItem(key);\n if (!raw) return null;\n return JSON.parse(raw) as TableLayout;\n } catch {\n return null;\n }\n}\n\nfunction saveLayout(key: string | undefined, layout: TableLayout): void {\n if (!key || typeof window === 'undefined') return;\n try {\n window.localStorage.setItem(key, JSON.stringify(layout));\n } catch {\n // ignore\n }\n}\n\nexport function useTableLayout<T>(columns: Column<T>[], storageKey?: string) {\n const initial = useMemo<TableLayout>(() => {\n return loadLayout(storageKey) ?? defaultLayout(columns);\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n\n const [layout, setLayout] = useState<TableLayout>(initial);\n\n useEffect(() => {\n // reconcile if columns change: drop unknown keys, append new ones at the end\n setLayout((prev) => {\n const known = new Set(columns.map((c) => c.key));\n const order = prev.order.filter((k) => known.has(k));\n columns.forEach((c) => {\n if (!order.includes(c.key)) order.push(c.key);\n });\n const sizes: Record<string, number> = {};\n Object.entries(prev.sizes).forEach(([k, v]) => {\n if (known.has(k)) sizes[k] = v;\n });\n const hidden = prev.hidden.filter((k) => known.has(k));\n return { order, sizes, hidden };\n });\n }, [columns]);\n\n useEffect(() => {\n saveLayout(storageKey, layout);\n }, [layout, storageKey]);\n\n const orderedColumns = useMemo(() => {\n const pinnedLeft = columns.filter((c) => c.pinned === 'left');\n const pinnedRight = columns.filter((c) => c.pinned === 'right');\n const pinnedKeys = new Set(\n [...pinnedLeft, ...pinnedRight].map((c) => c.key),\n );\n const rest = layout.order\n .filter((k) => !pinnedKeys.has(k))\n .map((k) => columns.find((c) => c.key === k))\n .filter(Boolean) as Column<T>[];\n return [...pinnedLeft, ...rest, ...pinnedRight];\n }, [columns, layout.order]);\n\n const visibleColumns = useMemo(\n () => orderedColumns.filter((c) => !layout.hidden.includes(c.key)),\n [orderedColumns, layout.hidden],\n );\n\n const reorder = useCallback((key: string, toIndex: number) => {\n setLayout((prev) => {\n const order = [...prev.order];\n const from = order.indexOf(key);\n if (from === -1 || from === toIndex) return prev;\n const item = order.splice(from, 1)[0];\n if (item === undefined) return prev;\n const insertAt = toIndex > from ? toIndex - 1 : toIndex;\n order.splice(Math.max(0, Math.min(insertAt, order.length)), 0, item);\n return { ...prev, order };\n });\n }, []);\n\n const resize = useCallback((key: string, px: number | null) => {\n setLayout((prev) => {\n const sizes = { ...prev.sizes };\n if (px == null) delete sizes[key];\n else sizes[key] = Math.max(40, Math.round(px));\n return { ...prev, sizes };\n });\n }, []);\n\n const toggleHidden = useCallback((key: string) => {\n setLayout((prev) => {\n const hidden = prev.hidden.includes(key)\n ? prev.hidden.filter((k) => k !== key)\n : [...prev.hidden, key];\n return { ...prev, hidden };\n });\n }, []);\n\n const reset = useCallback(() => {\n setLayout(defaultLayout(columns));\n }, [columns]);\n\n return {\n layout,\n orderedColumns,\n visibleColumns,\n reorder,\n resize,\n toggleHidden,\n reset,\n };\n}\n","import type { Column, FilterState, SortDir } from './types';\nimport { isBetween, startOfDay } from '../date-range-picker';\n\nexport function defaultSearchPredicate<T>(\n row: T,\n query: string,\n columns: Column<T>[],\n): boolean {\n if (!query) return true;\n const q = query.toLowerCase();\n return columns.some((c) => {\n const v = c.accessor(row);\n if (v == null) return false;\n const s = v instanceof Date ? v.toLocaleString() : String(v);\n return s.toLowerCase().includes(q);\n });\n}\n\nexport function applyFilters<T>(\n rows: T[],\n columns: Column<T>[],\n filters: FilterState,\n cfg: {\n dateColumn?: string;\n timeColumn?: string;\n timeTolerance?: number;\n searchPredicate?: (row: T, q: string, cols: Column<T>[]) => boolean;\n },\n): T[] {\n const searchFn = cfg.searchPredicate ?? defaultSearchPredicate;\n\n return rows.filter((row) => {\n if (filters.search && !searchFn(row, filters.search, columns)) return false;\n\n if (cfg.dateColumn && (filters.dateRange.from || filters.dateRange.to)) {\n const col = columns.find((c) => c.key === cfg.dateColumn);\n if (col) {\n const raw = col.accessor(row);\n const d = raw instanceof Date ? raw : raw ? new Date(raw as string | number) : null;\n if (!d || isNaN(d.getTime())) return false;\n const day = startOfDay(d);\n const from = filters.dateRange.from ?? day;\n const to = filters.dateRange.to ?? filters.dateRange.from ?? day;\n if (!isBetween(day, startOfDay(from), startOfDay(to))) return false;\n }\n }\n\n if (cfg.timeColumn && filters.time) {\n const col = columns.find((c) => c.key === cfg.timeColumn);\n if (col) {\n const raw = col.accessor(row);\n const d = raw instanceof Date ? raw : raw ? new Date(raw as string | number) : null;\n if (!d || isNaN(d.getTime())) return false;\n const rowMin = d.getHours() * 60 + d.getMinutes();\n const filterMin = filters.time.hours * 60 + filters.time.minutes;\n const tol = cfg.timeTolerance ?? 0;\n if (Math.abs(rowMin - filterMin) > tol) return false;\n }\n }\n\n return true;\n });\n}\n\nexport function applySort<T>(\n rows: T[],\n columns: Column<T>[],\n sort: { key: string; dir: SortDir } | null,\n): T[] {\n if (!sort || !sort.dir) return rows;\n const col = columns.find((c) => c.key === sort.key);\n if (!col) return rows;\n const dirMul = sort.dir === 'asc' ? 1 : -1;\n const getter = col.sortBy ?? col.accessor;\n return [...rows].sort((a, b) => {\n const av = getter(a) as string | number | Date;\n const bv = getter(b) as string | number | Date;\n if (av == null && bv == null) return 0;\n if (av == null) return 1;\n if (bv == null) return -1;\n if (av instanceof Date && bv instanceof Date) {\n return (av.getTime() - bv.getTime()) * dirMul;\n }\n if (typeof av === 'number' && typeof bv === 'number') {\n return (av - bv) * dirMul;\n }\n return String(av).localeCompare(String(bv)) * dirMul;\n });\n}\n\nexport function paginate<T>(rows: T[], page: number, pageSize: number): T[] {\n const start = (page - 1) * pageSize;\n return rows.slice(start, start + pageSize);\n}\n","import type { Column } from './types';\n\n/* ────────────────────────────────────────────────────────────\n CSV (RFC 4180)\n ──────────────────────────────────────────────────────────── */\n\nfunction csvEscape(v: unknown): string {\n if (v == null) return '';\n const s = typeof v === 'string' ? v : v instanceof Date ? v.toISOString() : String(v);\n if (/[\",\\n\\r]/.test(s)) {\n return `\"${s.replace(/\"/g, '\"\"')}\"`;\n }\n return s;\n}\n\nexport function toCsv<T>(rows: T[], cols: Column<T>[]): string {\n const visible = cols.filter((c) => !c.defaultHidden);\n const header = visible.map((c) => csvEscape(c.header)).join(',');\n const body = rows\n .map((row) =>\n visible.map((c) => csvEscape(c.accessor(row))).join(','),\n )\n .join('\\n');\n return body ? `${header}\\n${body}` : header;\n}\n\nexport function fromCsv(text: string): Record<string, string>[] {\n const rows: string[][] = [];\n let cur: string[] = [];\n let field = '';\n let i = 0;\n let inQuotes = false;\n const len = text.length;\n\n while (i < len) {\n const ch = text[i];\n if (inQuotes) {\n if (ch === '\"') {\n if (text[i + 1] === '\"') {\n field += '\"';\n i += 2;\n continue;\n }\n inQuotes = false;\n i++;\n continue;\n }\n field += ch;\n i++;\n continue;\n }\n if (ch === '\"') {\n inQuotes = true;\n i++;\n continue;\n }\n if (ch === ',') {\n cur.push(field);\n field = '';\n i++;\n continue;\n }\n if (ch === '\\r') {\n i++;\n continue;\n }\n if (ch === '\\n') {\n cur.push(field);\n rows.push(cur);\n cur = [];\n field = '';\n i++;\n continue;\n }\n field += ch;\n i++;\n }\n if (field.length > 0 || cur.length > 0) {\n cur.push(field);\n rows.push(cur);\n }\n\n if (rows.length === 0) return [];\n const head = rows[0] ?? [];\n const body = rows.slice(1);\n return body.map((r) => {\n const obj: Record<string, string> = {};\n head.forEach((h, idx) => {\n obj[h] = r[idx] ?? '';\n });\n return obj;\n });\n}\n\n/* ────────────────────────────────────────────────────────────\n JSON\n ──────────────────────────────────────────────────────────── */\n\nexport function toJson<T>(rows: T[], cols: Column<T>[]): string {\n const visible = cols.filter((c) => !c.defaultHidden);\n const out = rows.map((row) => {\n const obj: Record<string, unknown> = {};\n visible.forEach((c) => {\n obj[c.key] = c.accessor(row);\n });\n return obj;\n });\n return JSON.stringify(out, null, 2);\n}\n\nexport function fromJson<T>(text: string): T[] {\n const parsed = JSON.parse(text);\n if (!Array.isArray(parsed)) {\n throw new Error('Expected a JSON array of rows');\n }\n return parsed as T[];\n}\n\n/* ────────────────────────────────────────────────────────────\n Download trigger\n ──────────────────────────────────────────────────────────── */\n\nexport function downloadString(text: string, filename: string, mime: string): void {\n if (typeof window === 'undefined') return;\n const blob = new Blob([text], { type: mime });\n const url = URL.createObjectURL(blob);\n const a = document.createElement('a');\n a.href = url;\n a.download = filename;\n document.body.appendChild(a);\n a.click();\n a.remove();\n setTimeout(() => URL.revokeObjectURL(url), 1000);\n}\n","'use client';\n\nimport {\n useCallback,\n useMemo,\n useRef,\n useState,\n type CSSProperties,\n type DragEvent,\n type PointerEvent as ReactPointerEvent,\n type ReactNode,\n} from 'react';\nimport {\n Table,\n TableBody,\n TableCell,\n TableHead,\n TableHeader,\n TableRow,\n type FontSpec,\n} from '../table';\nimport { TableSearch } from '../table-search';\nimport { Pagination } from '../pagination';\nimport { DateRangePicker } from '../date-range-picker';\nimport type { DateRange } from '../date-range-picker';\nimport { TimePicker, type TimeValue } from '../time-picker';\nimport { ColumnMenu } from './ColumnMenu';\nimport { useTableLayout } from './useTableLayout';\nimport { applyFilters, applySort, paginate } from './filters';\nimport { downloadString, toCsv, toJson, fromCsv, fromJson } from './io';\nimport type {\n Column,\n DataTableProps,\n FilterState,\n SortDir,\n} from './types';\nimport './DataTable.css';\n\nfunction fontStyleFor(spec: FontSpec | undefined): CSSProperties | undefined {\n if (!spec) return undefined;\n if (typeof spec === 'string') return { fontFamily: spec };\n const s: CSSProperties = {};\n if (spec.family) s.fontFamily = spec.family;\n if (spec.size != null)\n s.fontSize = typeof spec.size === 'number' ? `${spec.size}px` : spec.size;\n if (spec.weight != null) s.fontWeight = spec.weight as number;\n if (spec.letterSpacing) s.letterSpacing = spec.letterSpacing;\n if (spec.featureSettings) s.fontFeatureSettings = spec.featureSettings;\n return s;\n}\n\nfunction renderCellValue(value: unknown, type?: Column<unknown>['type']): string {\n if (value == null) return '';\n if (value instanceof Date) {\n if (type === 'time') {\n return value.toLocaleTimeString([], {\n hour: '2-digit',\n minute: '2-digit',\n });\n }\n if (type === 'date') {\n return value.toLocaleDateString();\n }\n return value.toLocaleString();\n }\n return String(value);\n}\n\nexport function DataTable<T>({\n data,\n columns,\n getRowId,\n visibleRows = 7,\n rowHeight = 44,\n stickyHeader = true,\n density = 'cozy',\n loading,\n empty,\n fitColumns = false,\n search,\n dateFilter,\n timeFilter,\n pagination,\n reorderable = true,\n resizable = true,\n columnMenu = true,\n dataIO,\n headerFont,\n rowHeaderFont,\n cellFont,\n storageKey,\n className = '',\n toolbarExtras,\n}: DataTableProps<T>) {\n const {\n layout,\n orderedColumns,\n visibleColumns,\n reorder,\n resize,\n toggleHidden,\n reset,\n } = useTableLayout(columns, storageKey);\n\n /* ── filter state ─────────────────────────────────────── */\n const [filters, setFilters] = useState<FilterState>({\n search: '',\n dateRange: { from: null, to: null },\n time: null,\n });\n const [sort, setSort] = useState<{ key: string; dir: SortDir } | null>(null);\n const pageSize = pagination === false ? Infinity : pagination?.pageSize ?? 25;\n const [page, setPage] = useState(1);\n\n /* ── pipeline ─────────────────────────────────────────── */\n const filtered = useMemo(\n () =>\n applyFilters(data, columns, filters, {\n dateColumn: dateFilter?.column,\n timeColumn: timeFilter?.column,\n timeTolerance: timeFilter?.toleranceMinutes,\n searchPredicate: search?.predicate,\n }),\n [data, columns, filters, dateFilter?.column, timeFilter?.column, timeFilter?.toleranceMinutes, search?.predicate],\n );\n\n const sorted = useMemo(() => applySort(filtered, columns, sort), [filtered, columns, sort]);\n\n const pageCount = pagination === false ? 1 : Math.max(1, Math.ceil(sorted.length / pageSize));\n const currentPage = Math.min(page, pageCount);\n\n const pageRows = useMemo(\n () => (pagination === false ? sorted : paginate(sorted, currentPage, pageSize)),\n [pagination, sorted, currentPage, pageSize],\n );\n\n /* ── column drag reorder ──────────────────────────────── */\n const [dragKey, setDragKey] = useState<string | null>(null);\n const [dropIndex, setDropIndex] = useState<number | null>(null);\n\n const onDragStart = (e: DragEvent<HTMLTableCellElement>, key: string) => {\n if (!reorderable) return;\n setDragKey(key);\n e.dataTransfer.effectAllowed = 'move';\n try {\n e.dataTransfer.setData('text/plain', key);\n } catch {\n /* IE/Safari quirks */\n }\n };\n\n const onDragOver = (e: DragEvent<HTMLTableCellElement>, idx: number) => {\n if (!reorderable || !dragKey) return;\n e.preventDefault();\n e.dataTransfer.dropEffect = 'move';\n const rect = e.currentTarget.getBoundingClientRect();\n const isRight = e.clientX - rect.left > rect.width / 2;\n setDropIndex(idx + (isRight ? 1 : 0));\n };\n\n const onDrop = (e: DragEvent<HTMLTableCellElement>) => {\n if (!reorderable || !dragKey || dropIndex == null) return;\n e.preventDefault();\n reorder(dragKey, dropIndex);\n setDragKey(null);\n setDropIndex(null);\n };\n\n const onDragEnd = () => {\n setDragKey(null);\n setDropIndex(null);\n };\n\n /* ── column resize ────────────────────────────────────── */\n const resizingKey = useRef<string | null>(null);\n const resizeStartX = useRef(0);\n const resizeStartW = useRef(0);\n\n const beginResize = (\n e: ReactPointerEvent<HTMLSpanElement>,\n key: string,\n ) => {\n if (!resizable) return;\n e.stopPropagation();\n e.preventDefault();\n const th = (e.currentTarget.parentElement as HTMLElement) ?? null;\n const startW = th ? th.getBoundingClientRect().width : 120;\n resizingKey.current = key;\n resizeStartX.current = e.clientX;\n resizeStartW.current = startW;\n window.addEventListener('pointermove', onResizeMove);\n window.addEventListener('pointerup', endResize);\n };\n\n const onResizeMove = (e: PointerEvent) => {\n if (!resizingKey.current) return;\n const dx = e.clientX - resizeStartX.current;\n const col = columns.find((c) => c.key === resizingKey.current);\n const min = col?.minWidth ?? 80;\n const max = col?.maxWidth ?? 2000;\n const next = Math.max(min, Math.min(max, resizeStartW.current + dx));\n resize(resizingKey.current, next);\n };\n\n const endResize = () => {\n resizingKey.current = null;\n window.removeEventListener('pointermove', onResizeMove);\n window.removeEventListener('pointerup', endResize);\n };\n\n const doubleClickReset = (key: string) => resize(key, null);\n\n /* ── sort handler ─────────────────────────────────────── */\n const cycleSort = useCallback((key: string) => {\n setSort((prev) => {\n if (!prev || prev.key !== key) return { key, dir: 'asc' };\n if (prev.dir === 'asc') return { key, dir: 'desc' };\n return null;\n });\n }, []);\n\n /* ── data IO ──────────────────────────────────────────── */\n const fileInput = useRef<HTMLInputElement>(null);\n const [ioFlash, setIoFlash] = useState<string | null>(null);\n const flashTimer = useRef<ReturnType<typeof setTimeout> | null>(null);\n const flash = (text: string, ms = 1400) => {\n if (flashTimer.current) clearTimeout(flashTimer.current);\n setIoFlash(text);\n flashTimer.current = setTimeout(() => setIoFlash(null), ms);\n };\n\n const exportRows = (format: 'csv' | 'json') => {\n if (!dataIO?.export) return;\n const scope = dataIO.export.scope ?? 'filtered';\n let rows: T[];\n if (scope === 'all') rows = data;\n else if (scope === 'page') rows = pageRows;\n else rows = sorted;\n\n const cols = visibleColumns;\n const text = dataIO.export.serialize\n ? dataIO.export.serialize(rows, cols, format)\n : format === 'csv'\n ? toCsv(rows, cols)\n : toJson(rows, cols);\n\n const baseName =\n typeof dataIO.export.filename === 'function'\n ? dataIO.export.filename()\n : dataIO.export.filename ?? 'table-export';\n const filename = `${baseName}.${format}`;\n const mime = format === 'csv' ? 'text/csv;charset=utf-8' : 'application/json';\n downloadString(text, filename, mime);\n flash('Exported');\n };\n\n const onPickFile = async (file: File) => {\n if (!dataIO?.import) return;\n const text = await file.text();\n try {\n const parsed = dataIO.import.parse\n ? await dataIO.import.parse(text, file)\n : file.name.endsWith('.json')\n ? (fromJson(text) as T[])\n : (fromCsv(text) as unknown as T[]);\n dataIO.import.onImport(parsed as T[], {\n mode: dataIO.import.mode ?? 'replace',\n file,\n });\n flash(`Imported ${parsed.length} ${parsed.length === 1 ? 'row' : 'rows'}`);\n } catch (err) {\n dataIO.import.onError?.(err, file);\n flash(\"Couldn't read file\", 2000);\n }\n };\n\n /* ── render ───────────────────────────────────────────── */\n\n const showToolbar =\n search?.enabled ||\n !!dateFilter ||\n !!timeFilter ||\n columnMenu ||\n !!dataIO?.export?.enabled ||\n !!dataIO?.import?.enabled ||\n !!toolbarExtras;\n\n const exportFormats = dataIO?.export?.formats ?? ['csv', 'json'];\n const [exportMenuOpen, setExportMenuOpen] = useState(false);\n\n return (\n <div className={['royui-dt', className].filter(Boolean).join(' ')}>\n {showToolbar && (\n <div className=\"royui-dt__toolbar\">\n <div className=\"royui-dt__toolbar-left\">\n {search?.enabled && (\n <TableSearch\n value={filters.search}\n onChange={(v) => {\n setFilters((f) => ({ ...f, search: v }));\n setPage(1);\n }}\n placeholder={search.placeholder}\n debounceMs={search.debounceMs}\n />\n )}\n {dateFilter && (\n <DateRangePicker\n value={filters.dateRange}\n onChange={(r) => {\n setFilters((f) => ({ ...f, dateRange: r }));\n setPage(1);\n }}\n monthsVisible={dateFilter.monthsVisible ?? 2}\n placeholder={dateFilter.placeholder ?? 'Date range'}\n />\n )}\n {timeFilter && (\n <TimePicker\n value={filters.time}\n onChange={(t: TimeValue) => {\n setFilters((f) => ({ ...f, time: t }));\n setPage(1);\n }}\n variant={timeFilter.variant ?? 'analog'}\n hourCycle={timeFilter.hourCycle ?? 24}\n placeholder={timeFilter.placeholder ?? 'Time'}\n />\n )}\n </div>\n\n <div className=\"royui-dt__toolbar-right\">\n {toolbarExtras}\n {columnMenu && (\n <ColumnMenu\n columns={orderedColumns}\n layout={layout}\n onToggle={toggleHidden}\n onReset={reset}\n />\n )}\n {(dataIO?.export?.enabled || dataIO?.import?.enabled) && (\n <span className=\"royui-dt__sep\" aria-hidden>·</span>\n )}\n {dataIO?.export?.enabled && (\n <div className=\"royui-dt-io\">\n <button\n type=\"button\"\n className=\"royui-dt-io__btn\"\n onClick={() => {\n const only = exportFormats[0];\n if (exportFormats.length === 1 && only) {\n exportRows(only);\n } else {\n setExportMenuOpen((o) => !o);\n }\n }}\n >\n {ioFlash && ioFlash.startsWith('Export') ? ioFlash : 'Export'}\n </button>\n {exportMenuOpen && exportFormats.length > 1 && (\n <div\n className=\"royui-dt-io__menu\"\n onMouseLeave={() => setExportMenuOpen(false)}\n >\n {exportFormats.map((f) => (\n <button\n key={f}\n type=\"button\"\n className=\"royui-dt-io__menu-item\"\n onClick={() => {\n exportRows(f);\n setExportMenuOpen(false);\n }}\n >\n {f.toUpperCase()}\n </button>\n ))}\n </div>\n )}\n </div>\n )}\n {dataIO?.import?.enabled && (\n <>\n <button\n type=\"button\"\n className=\"royui-dt-io__btn\"\n onClick={() => fileInput.current?.click()}\n >\n {ioFlash && (ioFlash.startsWith('Import') || ioFlash.startsWith(\"Couldn't\"))\n ? ioFlash\n : 'Import'}\n </button>\n <input\n ref={fileInput}\n type=\"file\"\n accept={dataIO.import.accept ?? '.csv,.json'}\n style={{ display: 'none' }}\n onChange={(e) => {\n const f = e.target.files?.[0];\n if (f) onPickFile(f);\n e.target.value = '';\n }}\n />\n </>\n )}\n </div>\n </div>\n )}\n\n <Table\n visibleRows={visibleRows}\n rowHeight={rowHeight}\n stickyHeader={stickyHeader}\n density={density}\n loading={loading}\n empty={empty}\n isEmpty={pageRows.length === 0}\n fitColumns={fitColumns}\n headerFont={headerFont}\n rowHeaderFont={rowHeaderFont}\n cellFont={cellFont}\n >\n <colgroup>\n {visibleColumns.map((c) => {\n const w = fitColumns ? undefined : layout.sizes[c.key];\n return (\n <col\n key={c.key}\n style={w ? { width: w } : undefined}\n className={dragKey === c.key ? 'royui-dt__col--dragging' : undefined}\n />\n );\n })}\n </colgroup>\n\n <TableHeader>\n <TableRow>\n {visibleColumns.map((c, idx) => {\n const isDragging = dragKey === c.key;\n const showDropBefore = dropIndex === idx;\n const sortDir =\n sort && sort.key === c.key && sort.dir ? sort.dir : null;\n const canReorder = reorderable && c.reorderable !== false && !c.pinned;\n const canResize = resizable && c.resizable !== false;\n\n return (\n <TableHead\n key={c.key}\n align={c.align ?? (c.type === 'number' ? 'right' : 'left')}\n className={[\n 'royui-dt__th',\n canReorder && 'royui-dt__th--reorderable',\n canResize && 'royui-dt__th--resizable',\n isDragging && 'royui-dt__th--dragging',\n showDropBefore && 'royui-dt__th--drop-before',\n ]\n .filter(Boolean)\n .join(' ')}\n draggable={canReorder}\n onDragStart={(e) => onDragStart(e, c.key)}\n onDragOver={(e) => onDragOver(e, idx)}\n onDrop={onDrop}\n onDragEnd={onDragEnd}\n title={\n canReorder && canResize\n ? 'Drag to reorder · drag the right edge to resize'\n : canReorder\n ? 'Drag to reorder'\n : canResize\n ? 'Drag the right edge to resize'\n : undefined\n }\n >\n <span\n className=\"royui-dt__th-inner\"\n onClick={() => cycleSort(c.key)}\n role=\"button\"\n tabIndex={0}\n onKeyDown={(e) => {\n if (e.key === 'Enter' || e.key === ' ') {\n e.preventDefault();\n cycleSort(c.key);\n }\n }}\n >\n <span className=\"royui-dt__th-label\">{c.header}</span>\n {sortDir && (\n <span\n className={`royui-dt__sort-indicator royui-dt__sort-indicator--${sortDir}`}\n aria-hidden\n />\n )}\n </span>\n {canResize && (\n <span\n className=\"royui-dt__resize\"\n onPointerDown={(e) => beginResize(e, c.key)}\n onDoubleClick={() => doubleClickReset(c.key)}\n aria-hidden\n >\n <span className=\"royui-dt__resize-bar\" aria-hidden />\n </span>\n )}\n </TableHead>\n );\n })}\n {dropIndex === visibleColumns.length && (\n <TableHead className=\"royui-dt__th--drop-end\" aria-hidden />\n )}\n </TableRow>\n </TableHeader>\n\n <TableBody>\n {pageRows.map((row, i) => {\n const id = getRowId\n ? getRowId(row, i)\n : (row as Record<string, unknown>)?.['id'] != null\n ? String((row as Record<string, unknown>)['id'])\n : i;\n return (\n <TableRow key={id as string | number}>\n {visibleColumns.map((c) => {\n const value = c.accessor(row);\n const display = c.cell ? c.cell(value, row) : renderCellValue(value, c.type);\n const cellStyle = fontStyleFor(c.font);\n const isNum = c.type === 'number';\n return (\n <TableCell\n key={c.key}\n isRowHeader={c.isRowHeader}\n align={c.align ?? (isNum ? 'right' : 'left')}\n className={isNum ? 'royui-table__td--num' : undefined}\n style={cellStyle}\n >\n {display}\n </TableCell>\n );\n })}\n </TableRow>\n );\n })}\n </TableBody>\n </Table>\n\n {pagination !== false && pageCount > 1 && (\n <div className=\"royui-dt__pagination\">\n <Pagination\n page={currentPage}\n pageCount={pageCount}\n onPageChange={setPage}\n siblingCount={pagination?.siblingCount ?? 1}\n showSummary={pagination?.showSummary ?? true}\n summaryRender={(p, pc) =>\n `${(p - 1) * pageSize + 1}–${Math.min(p * pageSize, sorted.length)} of ${sorted.length}`\n }\n />\n </div>\n )}\n </div>\n );\n}\n"]}
@@ -0,0 +1,82 @@
1
+ "use client";
2
+ import { forwardRef, useState, useRef, useEffect } from 'react';
3
+ import './TableSearch-UZO4ZJVE.css';
4
+ import { jsxs, jsx } from 'react/jsx-runtime';
5
+
6
+ // src/components/table-search/TableSearch.tsx
7
+ var TableSearch = forwardRef(
8
+ function TableSearch2({
9
+ value,
10
+ defaultValue,
11
+ onChange,
12
+ debounceMs = 0,
13
+ placeholder = "Search",
14
+ width = 260,
15
+ hideIndicator,
16
+ className = "",
17
+ style,
18
+ ...rest
19
+ }, ref) {
20
+ const controlled = value !== void 0;
21
+ const [internal, setInternal] = useState(defaultValue ?? "");
22
+ const current = controlled ? value : internal;
23
+ const timer = useRef(null);
24
+ useEffect(() => () => {
25
+ if (timer.current) clearTimeout(timer.current);
26
+ }, []);
27
+ const emit = (next) => {
28
+ if (!onChange) return;
29
+ if (debounceMs <= 0) {
30
+ onChange(next);
31
+ return;
32
+ }
33
+ if (timer.current) clearTimeout(timer.current);
34
+ timer.current = setTimeout(() => onChange(next), debounceMs);
35
+ };
36
+ const handle = (e) => {
37
+ const next = e.target.value;
38
+ if (!controlled) setInternal(next);
39
+ emit(next);
40
+ };
41
+ const clear = () => {
42
+ if (!controlled) setInternal("");
43
+ if (onChange) onChange("");
44
+ };
45
+ return /* @__PURE__ */ jsxs(
46
+ "div",
47
+ {
48
+ className: ["royui-tablesearch", className].filter(Boolean).join(" "),
49
+ style: { width, ...style },
50
+ children: [
51
+ !hideIndicator && /* @__PURE__ */ jsx("span", { className: "royui-tablesearch__dot", "aria-hidden": true }),
52
+ /* @__PURE__ */ jsx(
53
+ "input",
54
+ {
55
+ ref,
56
+ type: "text",
57
+ className: "royui-tablesearch__input",
58
+ placeholder,
59
+ value: current,
60
+ onChange: handle,
61
+ ...rest
62
+ }
63
+ ),
64
+ current.length > 0 && /* @__PURE__ */ jsx(
65
+ "button",
66
+ {
67
+ type: "button",
68
+ className: "royui-tablesearch__clear",
69
+ onClick: clear,
70
+ "aria-label": "Clear search",
71
+ children: "Clear"
72
+ }
73
+ )
74
+ ]
75
+ }
76
+ );
77
+ }
78
+ );
79
+
80
+ export { TableSearch };
81
+ //# sourceMappingURL=chunk-KSHKVSNK.js.map
82
+ //# sourceMappingURL=chunk-KSHKVSNK.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/table-search/TableSearch.tsx"],"names":["TableSearch"],"mappings":";;;;;AA4BO,IAAM,WAAA,GAAc,UAAA;AAAA,EACzB,SAASA,YAAAA,CACP;AAAA,IACE,KAAA;AAAA,IACA,YAAA;AAAA,IACA,QAAA;AAAA,IACA,UAAA,GAAa,CAAA;AAAA,IACb,WAAA,GAAc,QAAA;AAAA,IACd,KAAA,GAAQ,GAAA;AAAA,IACR,aAAA;AAAA,IACA,SAAA,GAAY,EAAA;AAAA,IACZ,KAAA;AAAA,IACA,GAAG;AAAA,KAEL,GAAA,EACA;AACA,IAAA,MAAM,aAAa,KAAA,KAAU,MAAA;AAC7B,IAAA,MAAM,CAAC,QAAA,EAAU,WAAW,CAAA,GAAI,QAAA,CAAS,gBAAgB,EAAE,CAAA;AAC3D,IAAA,MAAM,OAAA,GAAU,aAAa,KAAA,GAAS,QAAA;AACtC,IAAA,MAAM,KAAA,GAAQ,OAA6C,IAAI,CAAA;AAE/D,IAAA,SAAA,CAAU,MAAM,MAAM;AACpB,MAAA,IAAI,KAAA,CAAM,OAAA,EAAS,YAAA,CAAa,KAAA,CAAM,OAAO,CAAA;AAAA,IAC/C,CAAA,EAAG,EAAE,CAAA;AAEL,IAAA,MAAM,IAAA,GAAO,CAAC,IAAA,KAAiB;AAC7B,MAAA,IAAI,CAAC,QAAA,EAAU;AACf,MAAA,IAAI,cAAc,CAAA,EAAG;AACnB,QAAA,QAAA,CAAS,IAAI,CAAA;AACb,QAAA;AAAA,MACF;AACA,MAAA,IAAI,KAAA,CAAM,OAAA,EAAS,YAAA,CAAa,KAAA,CAAM,OAAO,CAAA;AAC7C,MAAA,KAAA,CAAM,UAAU,UAAA,CAAW,MAAM,QAAA,CAAS,IAAI,GAAG,UAAU,CAAA;AAAA,IAC7D,CAAA;AAEA,IAAA,MAAM,MAAA,GAAS,CAAC,CAAA,KAAqC;AACnD,MAAA,MAAM,IAAA,GAAO,EAAE,MAAA,CAAO,KAAA;AACtB,MAAA,IAAI,CAAC,UAAA,EAAY,WAAA,CAAY,IAAI,CAAA;AACjC,MAAA,IAAA,CAAK,IAAI,CAAA;AAAA,IACX,CAAA;AAEA,IAAA,MAAM,QAAQ,MAAM;AAClB,MAAA,IAAI,CAAC,UAAA,EAAY,WAAA,CAAY,EAAE,CAAA;AAC/B,MAAA,IAAI,QAAA,WAAmB,EAAE,CAAA;AAAA,IAC3B,CAAA;AAEA,IAAA,uBACE,IAAA;AAAA,MAAC,KAAA;AAAA,MAAA;AAAA,QACC,SAAA,EAAW,CAAC,mBAAA,EAAqB,SAAS,EAAE,MAAA,CAAO,OAAO,CAAA,CAAE,IAAA,CAAK,GAAG,CAAA;AAAA,QACpE,KAAA,EAAO,EAAE,KAAA,EAAO,GAAG,KAAA,EAAM;AAAA,QAExB,QAAA,EAAA;AAAA,UAAA,CAAC,iCAAiB,GAAA,CAAC,MAAA,EAAA,EAAK,SAAA,EAAU,wBAAA,EAAyB,eAAW,IAAA,EAAC,CAAA;AAAA,0BACxE,GAAA;AAAA,YAAC,OAAA;AAAA,YAAA;AAAA,cACC,GAAA;AAAA,cACA,IAAA,EAAK,MAAA;AAAA,cACL,SAAA,EAAU,0BAAA;AAAA,cACV,WAAA;AAAA,cACA,KAAA,EAAO,OAAA;AAAA,cACP,QAAA,EAAU,MAAA;AAAA,cACT,GAAG;AAAA;AAAA,WACN;AAAA,UACC,OAAA,CAAQ,SAAS,CAAA,oBAChB,GAAA;AAAA,YAAC,QAAA;AAAA,YAAA;AAAA,cACC,IAAA,EAAK,QAAA;AAAA,cACL,SAAA,EAAU,0BAAA;AAAA,cACV,OAAA,EAAS,KAAA;AAAA,cACT,YAAA,EAAW,cAAA;AAAA,cACZ,QAAA,EAAA;AAAA;AAAA;AAED;AAAA;AAAA,KAEJ;AAAA,EAEJ;AACF","file":"chunk-KSHKVSNK.js","sourcesContent":["'use client';\n\nimport {\n forwardRef,\n useEffect,\n useRef,\n useState,\n type ChangeEvent,\n type CSSProperties,\n type InputHTMLAttributes,\n} from 'react';\nimport './TableSearch.css';\n\nexport interface TableSearchProps\n extends Omit<InputHTMLAttributes<HTMLInputElement>, 'onChange' | 'value' | 'defaultValue'> {\n value?: string;\n defaultValue?: string;\n onChange?: (value: string) => void;\n /** Debounce in ms before onChange fires. Default 0 (synchronous). */\n debounceMs?: number;\n placeholder?: string;\n /** Width in px. Default 260. */\n width?: number | string;\n /** Hide the magnifier dot. */\n hideIndicator?: boolean;\n style?: CSSProperties;\n}\n\nexport const TableSearch = forwardRef<HTMLInputElement, TableSearchProps>(\n function TableSearch(\n {\n value,\n defaultValue,\n onChange,\n debounceMs = 0,\n placeholder = 'Search',\n width = 260,\n hideIndicator,\n className = '',\n style,\n ...rest\n },\n ref,\n ) {\n const controlled = value !== undefined;\n const [internal, setInternal] = useState(defaultValue ?? '');\n const current = controlled ? value! : internal;\n const timer = useRef<ReturnType<typeof setTimeout> | null>(null);\n\n useEffect(() => () => {\n if (timer.current) clearTimeout(timer.current);\n }, []);\n\n const emit = (next: string) => {\n if (!onChange) return;\n if (debounceMs <= 0) {\n onChange(next);\n return;\n }\n if (timer.current) clearTimeout(timer.current);\n timer.current = setTimeout(() => onChange(next), debounceMs);\n };\n\n const handle = (e: ChangeEvent<HTMLInputElement>) => {\n const next = e.target.value;\n if (!controlled) setInternal(next);\n emit(next);\n };\n\n const clear = () => {\n if (!controlled) setInternal('');\n if (onChange) onChange('');\n };\n\n return (\n <div\n className={['royui-tablesearch', className].filter(Boolean).join(' ')}\n style={{ width, ...style }}\n >\n {!hideIndicator && <span className=\"royui-tablesearch__dot\" aria-hidden />}\n <input\n ref={ref}\n type=\"text\"\n className=\"royui-tablesearch__input\"\n placeholder={placeholder}\n value={current}\n onChange={handle}\n {...rest}\n />\n {current.length > 0 && (\n <button\n type=\"button\"\n className=\"royui-tablesearch__clear\"\n onClick={clear}\n aria-label=\"Clear search\"\n >\n Clear\n </button>\n )}\n </div>\n );\n },\n);\n"]}
@@ -0,0 +1,101 @@
1
+ "use client";
2
+ import { forwardRef, Children, isValidElement, cloneElement } from 'react';
3
+ import './TreeNav-22DY7TP5.css';
4
+ import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
5
+
6
+ // src/components/tree-nav/TreeNav.tsx
7
+ var TreeNav = forwardRef(
8
+ ({ indent = 24, gap = 2, className = "", style, children, ...rest }, ref) => {
9
+ const mergedStyle = {
10
+ ...style,
11
+ ["--royui-treenav-indent"]: `${indent}px`,
12
+ ["--royui-treenav-gap"]: `${gap}px`
13
+ };
14
+ const classes = ["royui-treenav", className].filter(Boolean).join(" ");
15
+ return /* @__PURE__ */ jsx("ul", { ref, className: classes, style: mergedStyle, ...rest, children });
16
+ }
17
+ );
18
+ TreeNav.displayName = "TreeNav";
19
+ var TreeNavItem = forwardRef(
20
+ ({
21
+ href,
22
+ active = false,
23
+ asChild = false,
24
+ hideTip = false,
25
+ icon,
26
+ children,
27
+ linkProps,
28
+ className = "",
29
+ ...rest
30
+ }, ref) => {
31
+ const itemClasses = [
32
+ "royui-treenav__item",
33
+ hideTip && "royui-treenav__item--no-tip",
34
+ className
35
+ ].filter(Boolean).join(" ");
36
+ const linkContent = /* @__PURE__ */ jsxs(Fragment, { children: [
37
+ icon && /* @__PURE__ */ jsx("span", { className: "royui-treenav__icon", "aria-hidden": true, children: icon }),
38
+ /* @__PURE__ */ jsx("span", { className: "royui-treenav__label", children })
39
+ ] });
40
+ let renderedLink;
41
+ if (asChild) {
42
+ const onlyChild = Children.only(children);
43
+ if (!isValidElement(onlyChild)) {
44
+ throw new Error(
45
+ "TreeNavItem: asChild requires a single React element child."
46
+ );
47
+ }
48
+ const childClassName = [
49
+ "royui-treenav__link",
50
+ onlyChild.props.className
51
+ ].filter(Boolean).join(" ");
52
+ renderedLink = cloneElement(onlyChild, {
53
+ className: childClassName,
54
+ ...active ? { "aria-current": "page" } : {}
55
+ });
56
+ } else {
57
+ const { className: linkClassName, ...linkRest } = linkProps ?? {};
58
+ const mergedLinkClass = ["royui-treenav__link", linkClassName].filter(Boolean).join(" ");
59
+ renderedLink = /* @__PURE__ */ jsx(
60
+ "a",
61
+ {
62
+ href,
63
+ className: mergedLinkClass,
64
+ ...active ? { "aria-current": "page" } : {},
65
+ ...linkRest,
66
+ children: linkContent
67
+ }
68
+ );
69
+ }
70
+ return /* @__PURE__ */ jsxs("li", { ref, className: itemClasses, ...rest, children: [
71
+ /* @__PURE__ */ jsx(
72
+ "svg",
73
+ {
74
+ className: "royui-treenav__connector",
75
+ viewBox: "0 0 20 30",
76
+ preserveAspectRatio: "xMinYMid meet",
77
+ "aria-hidden": true,
78
+ children: hideTip ? /* @__PURE__ */ jsx(
79
+ "path",
80
+ {
81
+ d: "M1.25 0 L1.25 7 Q1.25 15.75 11 15.75 L11 14.25 Q2.75 14.25 2.75 7 L2.75 0 Z",
82
+ fill: "currentColor"
83
+ }
84
+ ) : /* @__PURE__ */ jsx(
85
+ "path",
86
+ {
87
+ d: "M1.25 0 L1.25 7 Q1.25 15.75 10.33 15.75 L10.33 16.94 L14.22 15 L10.33 13.06 L10.33 14.25 Q2.75 14.25 2.75 7 L2.75 0 Z",
88
+ fill: "currentColor"
89
+ }
90
+ )
91
+ }
92
+ ),
93
+ renderedLink
94
+ ] });
95
+ }
96
+ );
97
+ TreeNavItem.displayName = "TreeNavItem";
98
+
99
+ export { TreeNav, TreeNavItem };
100
+ //# sourceMappingURL=chunk-M6HB6BMA.js.map
101
+ //# sourceMappingURL=chunk-M6HB6BMA.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/tree-nav/TreeNav.tsx","../src/components/tree-nav/TreeNavItem.tsx"],"names":["forwardRef","jsx"],"mappings":"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","file":"chunk-M6HB6BMA.js","sourcesContent":["'use client';\n\nimport {\n forwardRef,\n type CSSProperties,\n type HTMLAttributes,\n} from 'react';\nimport './TreeNav.css';\n\nexport interface TreeNavProps extends HTMLAttributes<HTMLUListElement> {\n /** Left indent of the branched group, in pixels. Default 24. */\n indent?: number;\n /** Vertical gap between items, in pixels. Default 2. */\n gap?: number;\n}\n\nexport const TreeNav = forwardRef<HTMLUListElement, TreeNavProps>(\n ({ indent = 24, gap = 2, className = '', style, children, ...rest }, ref) => {\n const mergedStyle: CSSProperties = {\n ...style,\n ['--royui-treenav-indent' as string]: `${indent}px`,\n ['--royui-treenav-gap' as string]: `${gap}px`,\n };\n\n const classes = ['royui-treenav', className].filter(Boolean).join(' ');\n\n return (\n <ul ref={ref} className={classes} style={mergedStyle} {...rest}>\n {children}\n </ul>\n );\n },\n);\n\nTreeNav.displayName = 'TreeNav';\n","'use client';\n\nimport {\n Children,\n cloneElement,\n forwardRef,\n isValidElement,\n type AnchorHTMLAttributes,\n type LiHTMLAttributes,\n type ReactElement,\n type ReactNode,\n} from 'react';\n\nexport interface TreeNavItemProps\n extends Omit<LiHTMLAttributes<HTMLLIElement>, 'children'> {\n /** Link target. Used when asChild is false (default <a> render). */\n href?: string;\n /** Mark this item active. Adds aria-current=\"page\" to the rendered link. */\n active?: boolean;\n /** Render the consumer's element (e.g. next/link, TanStack Link) instead of an <a>. */\n asChild?: boolean;\n /** Hide the triangle tip at the end of the branch. Default false (tip shown). */\n hideTip?: boolean;\n /** Leading icon slot. */\n icon?: ReactNode;\n /** Anchor / link contents. */\n children?: ReactNode;\n /** Forwarded to the inner link element (className, onClick, etc.). */\n linkProps?: Omit<AnchorHTMLAttributes<HTMLAnchorElement>, 'href' | 'children'>;\n}\n\ntype ChildLinkElement = ReactElement<{\n className?: string;\n 'aria-current'?: AnchorHTMLAttributes<HTMLAnchorElement>['aria-current'];\n children?: ReactNode;\n}>;\n\nexport const TreeNavItem = forwardRef<HTMLLIElement, TreeNavItemProps>(\n (\n {\n href,\n active = false,\n asChild = false,\n hideTip = false,\n icon,\n children,\n linkProps,\n className = '',\n ...rest\n },\n ref,\n ) => {\n const itemClasses = [\n 'royui-treenav__item',\n hideTip && 'royui-treenav__item--no-tip',\n className,\n ]\n .filter(Boolean)\n .join(' ');\n\n const linkContent = (\n <>\n {icon && (\n <span className=\"royui-treenav__icon\" aria-hidden>\n {icon}\n </span>\n )}\n <span className=\"royui-treenav__label\">{children}</span>\n </>\n );\n\n let renderedLink: ReactNode;\n\n if (asChild) {\n const onlyChild = Children.only(children) as ChildLinkElement;\n if (!isValidElement(onlyChild)) {\n throw new Error(\n 'TreeNavItem: asChild requires a single React element child.',\n );\n }\n const childClassName = [\n 'royui-treenav__link',\n onlyChild.props.className,\n ]\n .filter(Boolean)\n .join(' ');\n\n renderedLink = cloneElement(onlyChild, {\n className: childClassName,\n ...(active ? { 'aria-current': 'page' as const } : {}),\n });\n } else {\n const { className: linkClassName, ...linkRest } = linkProps ?? {};\n const mergedLinkClass = ['royui-treenav__link', linkClassName]\n .filter(Boolean)\n .join(' ');\n\n renderedLink = (\n <a\n href={href}\n className={mergedLinkClass}\n {...(active ? { 'aria-current': 'page' as const } : {})}\n {...linkRest}\n >\n {linkContent}\n </a>\n );\n }\n\n return (\n <li ref={ref} className={itemClasses} {...rest}>\n <svg\n className=\"royui-treenav__connector\"\n viewBox=\"0 0 20 30\"\n preserveAspectRatio=\"xMinYMid meet\"\n aria-hidden\n >\n {hideTip ? (\n <path\n d=\"M1.25 0 L1.25 7 Q1.25 15.75 11 15.75 L11 14.25 Q2.75 14.25 2.75 7 L2.75 0 Z\"\n fill=\"currentColor\"\n />\n ) : (\n <path\n d=\"M1.25 0 L1.25 7 Q1.25 15.75 10.33 15.75 L10.33 16.94 L14.22 15 L10.33 13.06 L10.33 14.25 Q2.75 14.25 2.75 7 L2.75 0 Z\"\n fill=\"currentColor\"\n />\n )}\n </svg>\n {renderedLink}\n </li>\n );\n },\n);\n\nTreeNavItem.displayName = 'TreeNavItem';\n"]}
@@ -0,0 +1,58 @@
1
+ "use client";
2
+ import { forwardRef } from 'react';
3
+ import './MadeBy-JCYGHWSD.css';
4
+ import { jsxs, jsx } from 'react/jsx-runtime';
5
+
6
+ // src/components/made-by/MadeBy.tsx
7
+ var MadeBy = forwardRef(
8
+ ({
9
+ name,
10
+ href,
11
+ prefix = "Made by",
12
+ position = "bottom-right",
13
+ icon,
14
+ nameFont,
15
+ nameStyle,
16
+ className = "",
17
+ target = "_blank",
18
+ rel = "noopener noreferrer",
19
+ ...rest
20
+ }, ref) => {
21
+ const classes = [
22
+ "royui-madeby",
23
+ `royui-madeby--${position}`,
24
+ className
25
+ ].filter(Boolean).join(" ");
26
+ const nameStyles = {};
27
+ if (nameFont) nameStyles.fontFamily = nameFont;
28
+ if (nameStyle) nameStyles.fontStyle = nameStyle;
29
+ return /* @__PURE__ */ jsxs(
30
+ "a",
31
+ {
32
+ ref,
33
+ href,
34
+ target,
35
+ rel,
36
+ className: classes,
37
+ ...rest,
38
+ children: [
39
+ icon && /* @__PURE__ */ jsx("span", { className: "royui-madeby__icon", "aria-hidden": true, children: icon }),
40
+ /* @__PURE__ */ jsx("span", { className: "royui-madeby__prefix", children: prefix }),
41
+ /* @__PURE__ */ jsx(
42
+ "span",
43
+ {
44
+ className: "royui-madeby__name",
45
+ style: Object.keys(nameStyles).length ? nameStyles : void 0,
46
+ children: name
47
+ }
48
+ )
49
+ ]
50
+ }
51
+ );
52
+ }
53
+ );
54
+ MadeBy.displayName = "MadeBy";
55
+
56
+ export { MadeBy };
57
+ //# sourceMappingURL=chunk-MDPMEW4K.js.map
58
+ //# sourceMappingURL=chunk-MDPMEW4K.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/made-by/MadeBy.tsx"],"names":[],"mappings":";;;;;AAkCO,IAAM,MAAA,GAAS,UAAA;AAAA,EACpB,CACE;AAAA,IACE,IAAA;AAAA,IACA,IAAA;AAAA,IACA,MAAA,GAAS,SAAA;AAAA,IACT,QAAA,GAAW,cAAA;AAAA,IACX,IAAA;AAAA,IACA,QAAA;AAAA,IACA,SAAA;AAAA,IACA,SAAA,GAAY,EAAA;AAAA,IACZ,MAAA,GAAS,QAAA;AAAA,IACT,GAAA,GAAM,qBAAA;AAAA,IACN,GAAG;AAAA,KAEL,GAAA,KACG;AACH,IAAA,MAAM,OAAA,GAAU;AAAA,MACd,cAAA;AAAA,MACA,iBAAiB,QAAQ,CAAA,CAAA;AAAA,MACzB;AAAA,KACF,CACG,MAAA,CAAO,OAAO,CAAA,CACd,KAAK,GAAG,CAAA;AAEX,IAAA,MAAM,aAA4B,EAAC;AACnC,IAAA,IAAI,QAAA,aAAqB,UAAA,GAAa,QAAA;AACtC,IAAA,IAAI,SAAA,aAAsB,SAAA,GAAY,SAAA;AAEtC,IAAA,uBACE,IAAA;AAAA,MAAC,GAAA;AAAA,MAAA;AAAA,QACC,GAAA;AAAA,QACA,IAAA;AAAA,QACA,MAAA;AAAA,QACA,GAAA;AAAA,QACA,SAAA,EAAW,OAAA;AAAA,QACV,GAAG,IAAA;AAAA,QAEH,QAAA,EAAA;AAAA,UAAA,IAAA,wBACE,MAAA,EAAA,EAAK,SAAA,EAAU,oBAAA,EAAqB,aAAA,EAAW,MAC7C,QAAA,EAAA,IAAA,EACH,CAAA;AAAA,0BAEF,GAAA,CAAC,MAAA,EAAA,EAAK,SAAA,EAAU,sBAAA,EAAwB,QAAA,EAAA,MAAA,EAAO,CAAA;AAAA,0BAC/C,GAAA;AAAA,YAAC,MAAA;AAAA,YAAA;AAAA,cACC,SAAA,EAAU,oBAAA;AAAA,cACV,OAAO,MAAA,CAAO,IAAA,CAAK,UAAU,CAAA,CAAE,SAAS,UAAA,GAAa,MAAA;AAAA,cAEpD,QAAA,EAAA;AAAA;AAAA;AACH;AAAA;AAAA,KACF;AAAA,EAEJ;AACF;AAEA,MAAA,CAAO,WAAA,GAAc,QAAA","file":"chunk-MDPMEW4K.js","sourcesContent":["'use client';\n\nimport {\n forwardRef,\n type AnchorHTMLAttributes,\n type CSSProperties,\n type ReactNode,\n} from 'react';\nimport './MadeBy.css';\n\nexport type MadeByPosition =\n | 'bottom-right'\n | 'bottom-left'\n | 'top-right'\n | 'top-left';\n\nexport interface MadeByProps\n extends Omit<AnchorHTMLAttributes<HTMLAnchorElement>, 'href' | 'prefix'> {\n /** Display name shown after the prefix. */\n name: string;\n /** URL opened when the badge is clicked. */\n href: string;\n /** Prefix copy. Defaults to \"Made by\". */\n prefix?: ReactNode;\n /** Viewport anchor. Defaults to \"bottom-right\". */\n position?: MadeByPosition;\n /** Optional leading slot — avatar, mark, emoji, dot. */\n icon?: ReactNode;\n /** Custom font-family for the author name. */\n nameFont?: string;\n /** Font style for the author name. Defaults to \"italic\". */\n nameStyle?: CSSProperties['fontStyle'];\n}\n\nexport const MadeBy = forwardRef<HTMLAnchorElement, MadeByProps>(\n (\n {\n name,\n href,\n prefix = 'Made by',\n position = 'bottom-right',\n icon,\n nameFont,\n nameStyle,\n className = '',\n target = '_blank',\n rel = 'noopener noreferrer',\n ...rest\n },\n ref,\n ) => {\n const classes = [\n 'royui-madeby',\n `royui-madeby--${position}`,\n className,\n ]\n .filter(Boolean)\n .join(' ');\n\n const nameStyles: CSSProperties = {};\n if (nameFont) nameStyles.fontFamily = nameFont;\n if (nameStyle) nameStyles.fontStyle = nameStyle;\n\n return (\n <a\n ref={ref}\n href={href}\n target={target}\n rel={rel}\n className={classes}\n {...rest}\n >\n {icon && (\n <span className=\"royui-madeby__icon\" aria-hidden>\n {icon}\n </span>\n )}\n <span className=\"royui-madeby__prefix\">{prefix}</span>\n <span\n className=\"royui-madeby__name\"\n style={Object.keys(nameStyles).length ? nameStyles : undefined}\n >\n {name}\n </span>\n </a>\n );\n },\n);\n\nMadeBy.displayName = 'MadeBy';\n"]}
@@ -0,0 +1,107 @@
1
+ "use client";
2
+ import { forwardRef, useState, useRef, useEffect } from 'react';
3
+ import './TextMorph-RX2BX25F.css';
4
+ import { jsx } from 'react/jsx-runtime';
5
+
6
+ // src/components/text-morph/TextMorph.tsx
7
+ function sleep(ms) {
8
+ return new Promise((resolve) => setTimeout(resolve, ms));
9
+ }
10
+ function findDiff(from, to) {
11
+ let p = 0;
12
+ const maxP = Math.min(from.length, to.length);
13
+ while (p < maxP && from[p] === to[p]) p++;
14
+ let s = 0;
15
+ while (s < from.length - p && s < to.length - p && from[from.length - 1 - s] === to[to.length - 1 - s]) {
16
+ s++;
17
+ }
18
+ return {
19
+ prefix: from.slice(0, p),
20
+ suffix: from.slice(from.length - s),
21
+ oldMid: from.slice(p, from.length - s),
22
+ newMid: to.slice(p, to.length - s)
23
+ };
24
+ }
25
+ function rand(min, max) {
26
+ return min + Math.random() * (max - min);
27
+ }
28
+ var TextMorph = forwardRef(
29
+ function TextMorph2({
30
+ value,
31
+ renderText,
32
+ typeDelay = [30, 60],
33
+ backspaceDelay = [18, 30],
34
+ hardChars = /[\/{}\-_@]/,
35
+ hardCharExtraDelay = [30, 65],
36
+ pauseMs = 70,
37
+ disabled = false,
38
+ className = "",
39
+ ...rest
40
+ }, ref) {
41
+ const [displayed, setDisplayed] = useState(value);
42
+ const tokenRef = useRef(0);
43
+ const reducedRef = useRef(false);
44
+ const prevValueRef = useRef(value);
45
+ const displayedRef = useRef(value);
46
+ useEffect(() => {
47
+ if (typeof window !== "undefined") {
48
+ reducedRef.current = window.matchMedia(
49
+ "(prefers-reduced-motion: reduce)"
50
+ ).matches;
51
+ }
52
+ }, []);
53
+ useEffect(() => {
54
+ displayedRef.current = displayed;
55
+ }, [displayed]);
56
+ useEffect(() => {
57
+ if (value === prevValueRef.current) return;
58
+ const source = displayedRef.current;
59
+ prevValueRef.current = value;
60
+ if (disabled || reducedRef.current) {
61
+ setDisplayed(value);
62
+ return;
63
+ }
64
+ const myToken = ++tokenRef.current;
65
+ (async () => {
66
+ const { prefix, suffix, oldMid, newMid } = findDiff(source, value);
67
+ for (let i = oldMid.length - 1; i >= 0; i--) {
68
+ if (myToken !== tokenRef.current) return;
69
+ setDisplayed(prefix + oldMid.slice(0, i) + suffix);
70
+ await sleep(rand(backspaceDelay[0], backspaceDelay[1]));
71
+ }
72
+ if (myToken !== tokenRef.current) return;
73
+ await sleep(pauseMs);
74
+ for (let i = 1; i <= newMid.length; i++) {
75
+ if (myToken !== tokenRef.current) return;
76
+ setDisplayed(prefix + newMid.slice(0, i) + suffix);
77
+ const ch = newMid.charAt(i - 1);
78
+ const base = rand(typeDelay[0], typeDelay[1]);
79
+ const extra = hardChars.test(ch) ? rand(hardCharExtraDelay[0], hardCharExtraDelay[1]) : 0;
80
+ await sleep(base + extra);
81
+ }
82
+ })();
83
+ }, [
84
+ value,
85
+ disabled,
86
+ typeDelay,
87
+ backspaceDelay,
88
+ hardChars,
89
+ hardCharExtraDelay,
90
+ pauseMs
91
+ ]);
92
+ return /* @__PURE__ */ jsx(
93
+ "span",
94
+ {
95
+ ref,
96
+ className: `royui-textmorph ${className}`.trim(),
97
+ "aria-live": "polite",
98
+ ...rest,
99
+ children: renderText ? renderText(displayed) : displayed
100
+ }
101
+ );
102
+ }
103
+ );
104
+
105
+ export { TextMorph };
106
+ //# sourceMappingURL=chunk-PGV55XSZ.js.map
107
+ //# sourceMappingURL=chunk-PGV55XSZ.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/text-morph/TextMorph.tsx"],"names":["TextMorph"],"mappings":"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","file":"chunk-PGV55XSZ.js","sourcesContent":["'use client';\n\nimport {\n forwardRef,\n useEffect,\n useRef,\n useState,\n type HTMLAttributes,\n type ReactNode,\n} from 'react';\nimport './TextMorph.css';\n\nexport interface TextMorphProps\n extends Omit<HTMLAttributes<HTMLSpanElement>, 'children'> {\n /** The current text. When this prop changes, the component diff-types\n from the previously displayed text to the new value. */\n value: string;\n /** Optional renderer for the current intermediate text — handy for\n syntax highlighting, gradient spans, or wrapping each word. Receives\n the partial string at every keystroke during the animation. */\n renderText?: (current: string) => ReactNode;\n /** Per-character typing delay range in ms. Default [30, 60]. */\n typeDelay?: [min: number, max: number];\n /** Per-character backspace delay range in ms. Default [18, 30]. */\n backspaceDelay?: [min: number, max: number];\n /** Characters that get an additional delay (harder to type on a real\n keyboard — punctuation, brackets, symbols). Default /[\\/{}\\-_@]/. */\n hardChars?: RegExp;\n /** Extra delay range for hard chars in ms. Default [30, 65]. */\n hardCharExtraDelay?: [min: number, max: number];\n /** Pause between backspace phase and typing phase, in ms. Default 70. */\n pauseMs?: number;\n /** Skip animation entirely and just swap text. */\n disabled?: boolean;\n}\n\nfunction sleep(ms: number) {\n return new Promise<void>((resolve) => setTimeout(resolve, ms));\n}\n\nfunction findDiff(from: string, to: string) {\n let p = 0;\n const maxP = Math.min(from.length, to.length);\n while (p < maxP && from[p] === to[p]) p++;\n let s = 0;\n while (\n s < from.length - p &&\n s < to.length - p &&\n from[from.length - 1 - s] === to[to.length - 1 - s]\n ) {\n s++;\n }\n return {\n prefix: from.slice(0, p),\n suffix: from.slice(from.length - s),\n oldMid: from.slice(p, from.length - s),\n newMid: to.slice(p, to.length - s),\n };\n}\n\nfunction rand(min: number, max: number) {\n return min + Math.random() * (max - min);\n}\n\nexport const TextMorph = forwardRef<HTMLSpanElement, TextMorphProps>(\n function TextMorph(\n {\n value,\n renderText,\n typeDelay = [30, 60],\n backspaceDelay = [18, 30],\n hardChars = /[\\/{}\\-_@]/,\n hardCharExtraDelay = [30, 65],\n pauseMs = 70,\n disabled = false,\n className = '',\n ...rest\n },\n ref,\n ) {\n const [displayed, setDisplayed] = useState(value);\n const tokenRef = useRef(0);\n const reducedRef = useRef(false);\n const prevValueRef = useRef(value);\n const displayedRef = useRef(value);\n\n useEffect(() => {\n if (typeof window !== 'undefined') {\n reducedRef.current = window.matchMedia(\n '(prefers-reduced-motion: reduce)',\n ).matches;\n }\n }, []);\n\n // Keep a ref of the currently shown text so the animation always\n // starts from the latest frame (even if interrupted mid-typing).\n useEffect(() => {\n displayedRef.current = displayed;\n }, [displayed]);\n\n useEffect(() => {\n if (value === prevValueRef.current) return;\n const source = displayedRef.current;\n prevValueRef.current = value;\n\n if (disabled || reducedRef.current) {\n setDisplayed(value);\n return;\n }\n\n const myToken = ++tokenRef.current;\n\n (async () => {\n const { prefix, suffix, oldMid, newMid } = findDiff(source, value);\n\n for (let i = oldMid.length - 1; i >= 0; i--) {\n if (myToken !== tokenRef.current) return;\n setDisplayed(prefix + oldMid.slice(0, i) + suffix);\n await sleep(rand(backspaceDelay[0], backspaceDelay[1]));\n }\n\n if (myToken !== tokenRef.current) return;\n await sleep(pauseMs);\n\n for (let i = 1; i <= newMid.length; i++) {\n if (myToken !== tokenRef.current) return;\n setDisplayed(prefix + newMid.slice(0, i) + suffix);\n const ch = newMid.charAt(i - 1);\n const base = rand(typeDelay[0], typeDelay[1]);\n const extra = hardChars.test(ch)\n ? rand(hardCharExtraDelay[0], hardCharExtraDelay[1])\n : 0;\n await sleep(base + extra);\n }\n })();\n }, [\n value,\n disabled,\n typeDelay,\n backspaceDelay,\n hardChars,\n hardCharExtraDelay,\n pauseMs,\n ]);\n\n return (\n <span\n ref={ref}\n className={`royui-textmorph ${className}`.trim()}\n aria-live=\"polite\"\n {...rest}\n >\n {renderText ? renderText(displayed) : displayed}\n </span>\n );\n },\n);\n"]}
@@ -0,0 +1,64 @@
1
+ "use client";
2
+ import { forwardRef } from 'react';
3
+ import './GradientButton-TX2GJRIQ.css';
4
+ import { jsx, jsxs } from 'react/jsx-runtime';
5
+
6
+ // src/components/gradient-button/GradientButton.tsx
7
+ var DefaultSpinner = () => /* @__PURE__ */ jsx("span", { className: "gradient-btn__spinner", "aria-hidden": "true", children: /* @__PURE__ */ jsxs("svg", { viewBox: "0 0 24 24", width: "18", height: "18", fill: "none", children: [
8
+ /* @__PURE__ */ jsx(
9
+ "circle",
10
+ {
11
+ cx: "12",
12
+ cy: "12",
13
+ r: "9",
14
+ stroke: "currentColor",
15
+ strokeOpacity: "0.3",
16
+ strokeWidth: "2.5"
17
+ }
18
+ ),
19
+ /* @__PURE__ */ jsx(
20
+ "path",
21
+ {
22
+ d: "M21 12a9 9 0 0 0-9-9",
23
+ stroke: "currentColor",
24
+ strokeWidth: "2.5",
25
+ strokeLinecap: "round"
26
+ }
27
+ )
28
+ ] }) });
29
+ var GradientButton = forwardRef(
30
+ ({
31
+ loading = false,
32
+ loadingLabel,
33
+ fullWidth = true,
34
+ disabled,
35
+ className = "",
36
+ children,
37
+ type = "button",
38
+ ...rest
39
+ }, ref) => {
40
+ const classes = [
41
+ "gradient-btn",
42
+ fullWidth ? "gradient-btn--full" : "",
43
+ loading ? "gradient-btn--loading" : "",
44
+ className
45
+ ].filter(Boolean).join(" ");
46
+ return /* @__PURE__ */ jsx(
47
+ "button",
48
+ {
49
+ ref,
50
+ type,
51
+ disabled: disabled || loading,
52
+ className: classes,
53
+ "aria-busy": loading || void 0,
54
+ ...rest,
55
+ children: loading ? loadingLabel ?? /* @__PURE__ */ jsx(DefaultSpinner, {}) : children
56
+ }
57
+ );
58
+ }
59
+ );
60
+ GradientButton.displayName = "GradientButton";
61
+
62
+ export { GradientButton };
63
+ //# sourceMappingURL=chunk-RLBVY3DG.js.map
64
+ //# sourceMappingURL=chunk-RLBVY3DG.js.map