asterui 0.12.72 → 0.12.74

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.
@@ -1 +1 @@
1
- {"version":3,"file":"Typography.js","sources":["../../src/components/Typography.tsx"],"sourcesContent":["import React, { useState } from 'react'\n\n// DaisyUI classes\nconst dBtn = 'btn'\nconst dBtnGhost = 'btn-ghost'\nconst dBtnXs = 'btn-xs'\nconst dLink = 'link'\nconst dLinkPrimary = 'link-primary'\n\nexport type TypographySize = 'sm' | 'base' | 'lg' | 'xl' | '2xl'\nexport type TitleLevel = 1 | 2 | 3 | 4 | 5\n\nexport interface TypographyProps extends React.HTMLAttributes<HTMLDivElement> {\n children: React.ReactNode\n size?: TypographySize\n 'data-testid'?: string\n}\n\nexport interface TitleProps extends Omit<React.HTMLAttributes<HTMLHeadingElement>, 'title'> {\n level?: TitleLevel\n children: React.ReactNode\n copyable?: boolean\n ellipsis?: boolean\n 'data-testid'?: string\n}\n\nexport interface ParagraphProps extends React.HTMLAttributes<HTMLDivElement> {\n children: React.ReactNode\n ellipsis?: boolean | { rows?: number; expandable?: boolean; onExpand?: () => void }\n copyable?: boolean\n size?: TypographySize\n align?: 'left' | 'center' | 'right'\n 'data-testid'?: string\n}\n\nexport interface TextProps extends React.HTMLAttributes<HTMLSpanElement> {\n children: React.ReactNode\n code?: boolean\n mark?: boolean\n strong?: boolean\n italic?: boolean\n underline?: boolean\n delete?: boolean\n type?: 'default' | 'secondary' | 'success' | 'warning' | 'error'\n copyable?: boolean\n 'data-testid'?: string\n}\n\nexport interface TypographyLinkProps extends React.AnchorHTMLAttributes<HTMLAnchorElement> {\n href?: string\n children: React.ReactNode\n external?: boolean\n size?: TypographySize\n 'data-testid'?: string\n}\n\nfunction CopyButton({ text, 'data-testid': testId }: { text: string; 'data-testid'?: string }) {\n const [copied, setCopied] = useState(false)\n\n const handleCopy = async () => {\n try {\n await navigator.clipboard.writeText(text)\n setCopied(true)\n setTimeout(() => setCopied(false), 2000)\n } catch (err) {\n console.error('Failed to copy:', err)\n }\n }\n\n return (\n <button\n onClick={handleCopy}\n className={`${dBtn} ${dBtnGhost} ${dBtnXs} ml-2 opacity-0 group-hover:opacity-100 transition-opacity`}\n title=\"Copy to clipboard\"\n data-testid={testId}\n >\n {copied ? (\n <svg className=\"w-4 h-4\" fill=\"currentColor\" viewBox=\"0 0 20 20\">\n <path\n fillRule=\"evenodd\"\n d=\"M16.707 5.293a1 1 0 010 1.414l-8 8a1 1 0 01-1.414 0l-4-4a1 1 0 011.414-1.414L8 12.586l7.293-7.293a1 1 0 011.414 0z\"\n clipRule=\"evenodd\"\n />\n </svg>\n ) : (\n <svg className=\"w-4 h-4\" fill=\"currentColor\" viewBox=\"0 0 20 20\">\n <path d=\"M8 3a1 1 0 011-1h2a1 1 0 110 2H9a1 1 0 01-1-1z\" />\n <path d=\"M6 3a2 2 0 00-2 2v11a2 2 0 002 2h8a2 2 0 002-2V5a2 2 0 00-2-2 3 3 0 01-3 3H9a3 3 0 01-3-3z\" />\n </svg>\n )}\n </button>\n )\n}\n\nfunction TypographyRoot({ children, size = 'base', className = '', 'data-testid': testId, ...rest }: TypographyProps) {\n const sizeClasses = {\n sm: 'prose-sm text-sm',\n base: 'prose-base text-base',\n lg: 'prose-lg text-lg',\n xl: 'prose-xl text-xl',\n '2xl': 'prose-2xl text-2xl',\n }\n\n const classes = [\n // Prose classes (only apply if @tailwindcss/typography is installed)\n 'prose dark:prose-invert max-w-none',\n // Fallback styles (always apply)\n 'text-base-content leading-relaxed',\n sizeClasses[size],\n className,\n ]\n .filter(Boolean)\n .join(' ')\n\n return <div className={classes} data-testid={testId} {...rest}>{children}</div>\n}\n\nfunction Title({ level = 1, children, copyable, ellipsis, className = '', id, 'data-testid': testId, ...rest }: TitleProps) {\n const textContent = typeof children === 'string' ? children : ''\n const generatedId = id || (textContent ? textContent.toLowerCase().replace(/\\s+/g, '-') : undefined)\n const getTestId = (suffix: string) => (testId ? `${testId}-${suffix}` : undefined)\n\n const levelClasses = {\n 1: 'text-4xl font-bold mb-4',\n 2: 'text-3xl font-bold mb-3',\n 3: 'text-2xl font-semibold mb-3',\n 4: 'text-xl font-semibold mb-2',\n 5: 'text-lg font-semibold mb-2',\n }\n\n const ellipsisClass = ellipsis ? 'truncate' : ''\n const classes = `group ${levelClasses[level]} ${ellipsisClass} ${className}`.trim()\n\n const content = (\n <>\n {children}\n {copyable && <CopyButton text={textContent} data-testid={getTestId('copy')} />}\n </>\n )\n\n switch (level) {\n case 1:\n return <h1 id={generatedId} className={classes} data-testid={testId} {...rest}>{content}</h1>\n case 2:\n return <h2 id={generatedId} className={classes} data-testid={testId} {...rest}>{content}</h2>\n case 3:\n return <h3 id={generatedId} className={classes} data-testid={testId} {...rest}>{content}</h3>\n case 4:\n return <h4 id={generatedId} className={classes} data-testid={testId} {...rest}>{content}</h4>\n case 5:\n return <h5 id={generatedId} className={classes} data-testid={testId} {...rest}>{content}</h5>\n default:\n return <h1 id={generatedId} className={classes} data-testid={testId} {...rest}>{content}</h1>\n }\n}\n\nconst lineClampClasses = {\n 1: 'line-clamp-1',\n 2: 'line-clamp-2',\n 3: 'line-clamp-3',\n 4: 'line-clamp-4',\n 5: 'line-clamp-5',\n 6: 'line-clamp-6',\n} as const\n\nfunction Paragraph({ children, ellipsis, copyable, size, align, className = '', 'data-testid': testId, ...rest }: ParagraphProps) {\n const [expanded, setExpanded] = useState(false)\n const textContent = typeof children === 'string' ? children : ''\n const getTestId = (suffix: string) => (testId ? `${testId}-${suffix}` : undefined)\n\n const isEllipsisObject = typeof ellipsis === 'object'\n const rows = isEllipsisObject ? ellipsis.rows || 3 : 3\n const expandable = isEllipsisObject ? ellipsis.expandable : false\n\n const clampedRows = Math.min(Math.max(rows, 1), 6) as 1 | 2 | 3 | 4 | 5 | 6\n const ellipsisClass =\n ellipsis && !expanded ? lineClampClasses[clampedRows] : ''\n\n const classes = [\n 'group',\n 'mb-4',\n ellipsisClass,\n size === 'sm' && 'text-sm',\n size === 'base' && 'text-base',\n size === 'lg' && 'text-lg',\n size === 'xl' && 'text-xl',\n size === '2xl' && 'text-2xl',\n align === 'left' && 'text-left',\n align === 'center' && 'text-center',\n align === 'right' && 'text-right',\n className,\n ].filter(Boolean).join(' ')\n\n return (\n <div data-testid={testId} {...rest}>\n <p className={classes} data-testid={getTestId('text')}>\n {children}\n {copyable && <CopyButton text={textContent} data-testid={getTestId('copy')} />}\n </p>\n {expandable && ellipsis && (\n <button\n onClick={() => {\n setExpanded(!expanded)\n if (isEllipsisObject && ellipsis.onExpand) {\n ellipsis.onExpand()\n }\n }}\n className=\"text-primary text-sm hover:underline\"\n >\n {expanded ? 'Show less' : 'Show more'}\n </button>\n )}\n </div>\n )\n}\n\nfunction Text({\n children,\n code,\n mark,\n strong,\n italic,\n underline,\n delete: del,\n type = 'default',\n copyable,\n className = '',\n 'data-testid': testId,\n ...rest\n}: TextProps) {\n const textContent = typeof children === 'string' ? children : ''\n const getTestId = (suffix: string) => (testId ? `${testId}-${suffix}` : undefined)\n\n const typeClasses = {\n default: '',\n secondary: 'text-base-content/70',\n success: 'text-success',\n warning: 'text-warning',\n error: 'text-error',\n }\n\n let content = children\n\n if (code) {\n content = (\n <code className=\"px-1.5 py-0.5 bg-base-200 rounded text-sm font-mono\">{content}</code>\n )\n }\n\n if (mark) {\n content = <mark className=\"bg-warning/30 px-1\">{content}</mark>\n }\n\n if (strong) {\n content = <strong className=\"font-bold\">{content}</strong>\n }\n\n if (italic) {\n content = <em className=\"italic\">{content}</em>\n }\n\n if (underline) {\n content = <u className=\"underline\">{content}</u>\n }\n\n if (del) {\n content = <del className=\"line-through opacity-70\">{content}</del>\n }\n\n const classes = `group inline ${typeClasses[type]} ${className}`.trim()\n\n return (\n <span className={classes} data-testid={testId} {...rest}>\n {content}\n {copyable && <CopyButton text={textContent} data-testid={getTestId('copy')} />}\n </span>\n )\n}\n\nfunction Link({ href = '#', children, target, external, size, className = '', 'data-testid': testId, ...rest }: TypographyLinkProps) {\n const isExternal = external || (href && href.startsWith('http'))\n const linkTarget = target || (isExternal ? '_blank' : undefined)\n const rel = isExternal ? 'noopener noreferrer' : undefined\n\n const classes = [\n dLink,\n dLinkPrimary,\n size === 'sm' && 'text-sm',\n size === 'base' && 'text-base',\n size === 'lg' && 'text-lg',\n size === 'xl' && 'text-xl',\n size === '2xl' && 'text-2xl',\n className,\n ].filter(Boolean).join(' ')\n\n return (\n <a\n href={href}\n target={linkTarget}\n rel={rel}\n className={classes}\n data-testid={testId}\n {...rest}\n >\n {children}\n {isExternal && (\n <svg className=\"w-3 h-3 inline-block ml-1\" fill=\"currentColor\" viewBox=\"0 0 20 20\">\n <path d=\"M11 3a1 1 0 100 2h2.586l-6.293 6.293a1 1 0 101.414 1.414L15 6.414V9a1 1 0 102 0V4a1 1 0 00-1-1h-5z\" />\n <path d=\"M5 5a2 2 0 00-2 2v8a2 2 0 002 2h8a2 2 0 002-2v-3a1 1 0 10-2 0v3H5V7h3a1 1 0 000-2H5z\" />\n </svg>\n )}\n </a>\n )\n}\n\nexport const Typography = Object.assign(TypographyRoot, {\n Title,\n Paragraph,\n Text,\n Link,\n})\n\nexport default Typography\n"],"names":["dBtn","dBtnGhost","dBtnXs","dLink","dLinkPrimary","CopyButton","text","testId","copied","setCopied","useState","jsx","err","jsxs","TypographyRoot","children","size","className","rest","classes","Title","level","copyable","ellipsis","id","textContent","generatedId","getTestId","suffix","levelClasses","ellipsisClass","content","Fragment","lineClampClasses","Paragraph","align","expanded","setExpanded","isEllipsisObject","rows","expandable","clampedRows","Text","code","mark","strong","italic","underline","del","type","typeClasses","Link","href","target","external","isExternal","linkTarget","rel","Typography"],"mappings":"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"}
1
+ {"version":3,"file":"Typography.js","sources":["../../src/components/Typography.tsx"],"sourcesContent":["import React, { useState } from 'react'\n\n// DaisyUI classes\nconst dBtn = 'btn'\nconst dBtnGhost = 'btn-ghost'\nconst dBtnXs = 'btn-xs'\nconst dLink = 'link'\nconst dLinkPrimary = 'link-primary'\n\nexport type TypographySize = 'xs' | 'sm' | 'base' | 'lg' | 'xl' | '2xl'\nexport type TitleLevel = 1 | 2 | 3 | 4 | 5\n\nexport interface TypographyProps extends React.HTMLAttributes<HTMLDivElement> {\n children: React.ReactNode\n size?: TypographySize\n 'data-testid'?: string\n}\n\nexport interface TitleProps extends Omit<React.HTMLAttributes<HTMLHeadingElement>, 'title'> {\n level?: TitleLevel\n children: React.ReactNode\n copyable?: boolean\n ellipsis?: boolean\n 'data-testid'?: string\n}\n\nexport interface ParagraphProps extends React.HTMLAttributes<HTMLDivElement> {\n children: React.ReactNode\n ellipsis?: boolean | { rows?: number; expandable?: boolean; onExpand?: () => void }\n copyable?: boolean\n size?: TypographySize\n align?: 'left' | 'center' | 'right'\n 'data-testid'?: string\n}\n\nexport interface TextProps extends React.HTMLAttributes<HTMLSpanElement> {\n children: React.ReactNode\n code?: boolean\n mark?: boolean\n strong?: boolean\n italic?: boolean\n underline?: boolean\n delete?: boolean\n type?: 'default' | 'secondary' | 'success' | 'warning' | 'error'\n size?: TypographySize\n copyable?: boolean\n 'data-testid'?: string\n}\n\nexport interface TypographyLinkProps extends React.AnchorHTMLAttributes<HTMLAnchorElement> {\n href?: string\n children: React.ReactNode\n external?: boolean\n size?: TypographySize\n 'data-testid'?: string\n}\n\nfunction CopyButton({ text, 'data-testid': testId }: { text: string; 'data-testid'?: string }) {\n const [copied, setCopied] = useState(false)\n\n const handleCopy = async () => {\n try {\n await navigator.clipboard.writeText(text)\n setCopied(true)\n setTimeout(() => setCopied(false), 2000)\n } catch (err) {\n console.error('Failed to copy:', err)\n }\n }\n\n return (\n <button\n onClick={handleCopy}\n className={`${dBtn} ${dBtnGhost} ${dBtnXs} ml-2 opacity-0 group-hover:opacity-100 transition-opacity`}\n title=\"Copy to clipboard\"\n data-testid={testId}\n >\n {copied ? (\n <svg className=\"w-4 h-4\" fill=\"currentColor\" viewBox=\"0 0 20 20\">\n <path\n fillRule=\"evenodd\"\n d=\"M16.707 5.293a1 1 0 010 1.414l-8 8a1 1 0 01-1.414 0l-4-4a1 1 0 011.414-1.414L8 12.586l7.293-7.293a1 1 0 011.414 0z\"\n clipRule=\"evenodd\"\n />\n </svg>\n ) : (\n <svg className=\"w-4 h-4\" fill=\"currentColor\" viewBox=\"0 0 20 20\">\n <path d=\"M8 3a1 1 0 011-1h2a1 1 0 110 2H9a1 1 0 01-1-1z\" />\n <path d=\"M6 3a2 2 0 00-2 2v11a2 2 0 002 2h8a2 2 0 002-2V5a2 2 0 00-2-2 3 3 0 01-3 3H9a3 3 0 01-3-3z\" />\n </svg>\n )}\n </button>\n )\n}\n\nfunction TypographyRoot({ children, size = 'base', className = '', 'data-testid': testId, ...rest }: TypographyProps) {\n const sizeClasses = {\n xs: 'prose-xs text-xs',\n sm: 'prose-sm text-sm',\n base: 'prose-base text-base',\n lg: 'prose-lg text-lg',\n xl: 'prose-xl text-xl',\n '2xl': 'prose-2xl text-2xl',\n }\n\n const classes = [\n // Prose classes (only apply if @tailwindcss/typography is installed)\n 'prose dark:prose-invert max-w-none',\n // Fallback styles (always apply)\n 'text-base-content leading-relaxed',\n sizeClasses[size],\n className,\n ]\n .filter(Boolean)\n .join(' ')\n\n return <div className={classes} data-testid={testId} {...rest}>{children}</div>\n}\n\nfunction Title({ level = 1, children, copyable, ellipsis, className = '', id, 'data-testid': testId, ...rest }: TitleProps) {\n const textContent = typeof children === 'string' ? children : ''\n const generatedId = id || (textContent ? textContent.toLowerCase().replace(/\\s+/g, '-') : undefined)\n const getTestId = (suffix: string) => (testId ? `${testId}-${suffix}` : undefined)\n\n const levelClasses = {\n 1: 'text-4xl font-bold mb-4',\n 2: 'text-3xl font-bold mb-3',\n 3: 'text-2xl font-semibold mb-3',\n 4: 'text-xl font-semibold mb-2',\n 5: 'text-lg font-semibold mb-2',\n }\n\n const ellipsisClass = ellipsis ? 'truncate' : ''\n const classes = `group ${levelClasses[level]} ${ellipsisClass} ${className}`.trim()\n\n const content = (\n <>\n {children}\n {copyable && <CopyButton text={textContent} data-testid={getTestId('copy')} />}\n </>\n )\n\n switch (level) {\n case 1:\n return <h1 id={generatedId} className={classes} data-testid={testId} {...rest}>{content}</h1>\n case 2:\n return <h2 id={generatedId} className={classes} data-testid={testId} {...rest}>{content}</h2>\n case 3:\n return <h3 id={generatedId} className={classes} data-testid={testId} {...rest}>{content}</h3>\n case 4:\n return <h4 id={generatedId} className={classes} data-testid={testId} {...rest}>{content}</h4>\n case 5:\n return <h5 id={generatedId} className={classes} data-testid={testId} {...rest}>{content}</h5>\n default:\n return <h1 id={generatedId} className={classes} data-testid={testId} {...rest}>{content}</h1>\n }\n}\n\nconst lineClampClasses = {\n 1: 'line-clamp-1',\n 2: 'line-clamp-2',\n 3: 'line-clamp-3',\n 4: 'line-clamp-4',\n 5: 'line-clamp-5',\n 6: 'line-clamp-6',\n} as const\n\nfunction Paragraph({ children, ellipsis, copyable, size, align, className = '', 'data-testid': testId, ...rest }: ParagraphProps) {\n const [expanded, setExpanded] = useState(false)\n const textContent = typeof children === 'string' ? children : ''\n const getTestId = (suffix: string) => (testId ? `${testId}-${suffix}` : undefined)\n\n const isEllipsisObject = typeof ellipsis === 'object'\n const rows = isEllipsisObject ? ellipsis.rows || 3 : 3\n const expandable = isEllipsisObject ? ellipsis.expandable : false\n\n const clampedRows = Math.min(Math.max(rows, 1), 6) as 1 | 2 | 3 | 4 | 5 | 6\n const ellipsisClass =\n ellipsis && !expanded ? lineClampClasses[clampedRows] : ''\n\n const classes = [\n 'group',\n 'mb-4',\n ellipsisClass,\n size === 'sm' && 'text-sm',\n size === 'base' && 'text-base',\n size === 'lg' && 'text-lg',\n size === 'xl' && 'text-xl',\n size === '2xl' && 'text-2xl',\n align === 'left' && 'text-left',\n align === 'center' && 'text-center',\n align === 'right' && 'text-right',\n className,\n ].filter(Boolean).join(' ')\n\n return (\n <div data-testid={testId} {...rest}>\n <p className={classes} data-testid={getTestId('text')}>\n {children}\n {copyable && <CopyButton text={textContent} data-testid={getTestId('copy')} />}\n </p>\n {expandable && ellipsis && (\n <button\n onClick={() => {\n setExpanded(!expanded)\n if (isEllipsisObject && ellipsis.onExpand) {\n ellipsis.onExpand()\n }\n }}\n className=\"text-primary text-sm hover:underline\"\n >\n {expanded ? 'Show less' : 'Show more'}\n </button>\n )}\n </div>\n )\n}\n\nfunction Text({\n children,\n code,\n mark,\n strong,\n italic,\n underline,\n delete: del,\n type = 'default',\n size,\n copyable,\n className = '',\n 'data-testid': testId,\n ...rest\n}: TextProps) {\n const textContent = typeof children === 'string' ? children : ''\n const getTestId = (suffix: string) => (testId ? `${testId}-${suffix}` : undefined)\n\n const typeClasses = {\n default: '',\n secondary: 'text-base-content/70',\n success: 'text-success',\n warning: 'text-warning',\n error: 'text-error',\n }\n\n let content = children\n\n if (code) {\n content = (\n <code className=\"px-1.5 py-0.5 bg-base-200 rounded text-sm font-mono\">{content}</code>\n )\n }\n\n if (mark) {\n content = <mark className=\"bg-warning/30 px-1\">{content}</mark>\n }\n\n if (strong) {\n content = <strong className=\"font-bold\">{content}</strong>\n }\n\n if (italic) {\n content = <em className=\"italic\">{content}</em>\n }\n\n if (underline) {\n content = <u className=\"underline\">{content}</u>\n }\n\n if (del) {\n content = <del className=\"line-through opacity-70\">{content}</del>\n }\n\n const classes = [\n 'group',\n 'inline',\n typeClasses[type],\n size === 'xs' && 'text-xs',\n size === 'sm' && 'text-sm',\n size === 'base' && 'text-base',\n size === 'lg' && 'text-lg',\n size === 'xl' && 'text-xl',\n size === '2xl' && 'text-2xl',\n className,\n ].filter(Boolean).join(' ')\n\n return (\n <span className={classes} data-testid={testId} {...rest}>\n {content}\n {copyable && <CopyButton text={textContent} data-testid={getTestId('copy')} />}\n </span>\n )\n}\n\nfunction Link({ href = '#', children, target, external, size, className = '', 'data-testid': testId, ...rest }: TypographyLinkProps) {\n const isExternal = external || (href && href.startsWith('http'))\n const linkTarget = target || (isExternal ? '_blank' : undefined)\n const rel = isExternal ? 'noopener noreferrer' : undefined\n\n const classes = [\n dLink,\n dLinkPrimary,\n size === 'sm' && 'text-sm',\n size === 'base' && 'text-base',\n size === 'lg' && 'text-lg',\n size === 'xl' && 'text-xl',\n size === '2xl' && 'text-2xl',\n className,\n ].filter(Boolean).join(' ')\n\n return (\n <a\n href={href}\n target={linkTarget}\n rel={rel}\n className={classes}\n data-testid={testId}\n {...rest}\n >\n {children}\n {isExternal && (\n <svg className=\"w-3 h-3 inline-block ml-1\" fill=\"currentColor\" viewBox=\"0 0 20 20\">\n <path d=\"M11 3a1 1 0 100 2h2.586l-6.293 6.293a1 1 0 101.414 1.414L15 6.414V9a1 1 0 102 0V4a1 1 0 00-1-1h-5z\" />\n <path d=\"M5 5a2 2 0 00-2 2v8a2 2 0 002 2h8a2 2 0 002-2v-3a1 1 0 10-2 0v3H5V7h3a1 1 0 000-2H5z\" />\n </svg>\n )}\n </a>\n )\n}\n\nexport const Typography = Object.assign(TypographyRoot, {\n Title,\n Paragraph,\n Text,\n Link,\n})\n\nexport default Typography\n"],"names":["dBtn","dBtnGhost","dBtnXs","dLink","dLinkPrimary","CopyButton","text","testId","copied","setCopied","useState","jsx","err","jsxs","TypographyRoot","children","size","className","rest","classes","Title","level","copyable","ellipsis","id","textContent","generatedId","getTestId","suffix","levelClasses","ellipsisClass","content","Fragment","lineClampClasses","Paragraph","align","expanded","setExpanded","isEllipsisObject","rows","expandable","clampedRows","Text","code","mark","strong","italic","underline","del","type","typeClasses","Link","href","target","external","isExternal","linkTarget","rel","Typography"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "asterui",
3
- "version": "0.12.72",
3
+ "version": "0.12.74",
4
4
  "description": "React UI component library with DaisyUI",
5
5
  "homepage": "https://asterui.com",
6
6
  "repository": {
@@ -82,7 +82,7 @@
82
82
  }
83
83
  },
84
84
  "devDependencies": {
85
- "@tailwindcss/vite": "^4.1.17",
85
+ "@tailwindcss/vite": "^4.1.18",
86
86
  "@tanstack/react-virtual": "^3.13.13",
87
87
  "@tiptap/extension-link": "^2.11.5",
88
88
  "@tiptap/extension-placeholder": "^2.11.5",
@@ -94,12 +94,12 @@
94
94
  "@types/react-dom": "^19.2.2",
95
95
  "@vitejs/plugin-react": "^5.1.1",
96
96
  "apexcharts": "^5.3.6",
97
- "daisyui": "^5.5.8",
97
+ "daisyui": "^5.5.14",
98
98
  "qrcode": "^1.5.4",
99
99
  "react": "^19.2.0",
100
100
  "react-dom": "^19.2.0",
101
101
  "react-hook-form": "^7.66.1",
102
- "tailwindcss": "^4.1.17",
102
+ "tailwindcss": "^4.1.18",
103
103
  "typescript": "^5.6.3",
104
104
  "vite": "^7.2.2",
105
105
  "vite-plugin-dts": "^4.5.4"