asterui 0.12.1 → 0.12.3

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 (273) hide show
  1. package/dist/components/Checkbox.d.ts +10 -0
  2. package/dist/components/Dock.d.ts +38 -0
  3. package/dist/components/Mask.d.ts +14 -0
  4. package/dist/index.d.ts +5 -1
  5. package/dist/index.js +173 -169
  6. package/dist/index.js.map +1 -1
  7. package/dist/index10.js +85 -59
  8. package/dist/index10.js.map +1 -1
  9. package/dist/index100.js +12 -7
  10. package/dist/index100.js.map +1 -1
  11. package/dist/index101.js +13 -11
  12. package/dist/index101.js.map +1 -1
  13. package/dist/index102.js +7 -30
  14. package/dist/index102.js.map +1 -1
  15. package/dist/index103.js +11 -16
  16. package/dist/index103.js.map +1 -1
  17. package/dist/index104.js +30 -10792
  18. package/dist/index104.js.map +1 -1
  19. package/dist/index105.js +18 -5
  20. package/dist/index105.js.map +1 -1
  21. package/dist/index15.js +3 -3
  22. package/dist/index21.js +1 -1
  23. package/dist/index24.js +43 -32
  24. package/dist/index24.js.map +1 -1
  25. package/dist/index25.js +32 -41
  26. package/dist/index25.js.map +1 -1
  27. package/dist/index26.js +41 -12
  28. package/dist/index26.js.map +1 -1
  29. package/dist/index27.js +12 -33
  30. package/dist/index27.js.map +1 -1
  31. package/dist/index28.js +33 -63
  32. package/dist/index28.js.map +1 -1
  33. package/dist/index29.js +60 -77
  34. package/dist/index29.js.map +1 -1
  35. package/dist/index30.js +80 -18
  36. package/dist/index30.js.map +1 -1
  37. package/dist/index31.js +15 -217
  38. package/dist/index31.js.map +1 -1
  39. package/dist/index32.js +216 -1078
  40. package/dist/index32.js.map +1 -1
  41. package/dist/index33.js +1081 -17
  42. package/dist/index33.js.map +1 -1
  43. package/dist/index34.js +17 -121
  44. package/dist/index34.js.map +1 -1
  45. package/dist/index35.js +119 -37
  46. package/dist/index35.js.map +1 -1
  47. package/dist/index36.js +31 -182
  48. package/dist/index36.js.map +1 -1
  49. package/dist/index37.js +191 -97
  50. package/dist/index37.js.map +1 -1
  51. package/dist/index38.js +93 -158
  52. package/dist/index38.js.map +1 -1
  53. package/dist/index39.js +155 -139
  54. package/dist/index39.js.map +1 -1
  55. package/dist/index40.js +146 -15
  56. package/dist/index40.js.map +1 -1
  57. package/dist/index41.js +14 -17
  58. package/dist/index41.js.map +1 -1
  59. package/dist/index42.js +18 -21
  60. package/dist/index42.js.map +1 -1
  61. package/dist/index43.js +18 -116
  62. package/dist/index43.js.map +1 -1
  63. package/dist/index44.js +116 -10
  64. package/dist/index44.js.map +1 -1
  65. package/dist/index45.js +13 -35
  66. package/dist/index45.js.map +1 -1
  67. package/dist/index46.js +33 -114
  68. package/dist/index46.js.map +1 -1
  69. package/dist/index47.js +10 -176
  70. package/dist/index47.js.map +1 -1
  71. package/dist/index48.js +114 -145
  72. package/dist/index48.js.map +1 -1
  73. package/dist/index49.js +176 -12
  74. package/dist/index49.js.map +1 -1
  75. package/dist/index50.js +146 -21
  76. package/dist/index50.js.map +1 -1
  77. package/dist/index51.js +12 -14
  78. package/dist/index51.js.map +1 -1
  79. package/dist/index52.js +20 -5
  80. package/dist/index52.js.map +1 -1
  81. package/dist/index53.js +14 -266
  82. package/dist/index53.js.map +1 -1
  83. package/dist/index54.js +7 -17
  84. package/dist/index54.js.map +1 -1
  85. package/dist/index55.js +257 -113
  86. package/dist/index55.js.map +1 -1
  87. package/dist/index56.js +17 -110
  88. package/dist/index56.js.map +1 -1
  89. package/dist/index57.js +121 -169
  90. package/dist/index57.js.map +1 -1
  91. package/dist/index58.js +110 -32
  92. package/dist/index58.js.map +1 -1
  93. package/dist/index59.js +163 -115
  94. package/dist/index59.js.map +1 -1
  95. package/dist/index60.js +30 -84
  96. package/dist/index60.js.map +1 -1
  97. package/dist/index61.js +121 -19
  98. package/dist/index61.js.map +1 -1
  99. package/dist/index62.js +81 -69
  100. package/dist/index62.js.map +1 -1
  101. package/dist/index63.js +19 -56
  102. package/dist/index63.js.map +1 -1
  103. package/dist/index64.js +72 -43
  104. package/dist/index64.js.map +1 -1
  105. package/dist/index65.js +54 -49
  106. package/dist/index65.js.map +1 -1
  107. package/dist/index66.js +41 -58
  108. package/dist/index66.js.map +1 -1
  109. package/dist/index67.js +50 -105
  110. package/dist/index67.js.map +1 -1
  111. package/dist/index68.js +62 -41
  112. package/dist/index68.js.map +1 -1
  113. package/dist/index69.js +99 -60
  114. package/dist/index69.js.map +1 -1
  115. package/dist/index70.js +41 -21
  116. package/dist/index70.js.map +1 -1
  117. package/dist/index71.js +66 -44
  118. package/dist/index71.js.map +1 -1
  119. package/dist/index72.js +19 -132
  120. package/dist/index72.js.map +1 -1
  121. package/dist/index73.js +40 -46
  122. package/dist/index73.js.map +1 -1
  123. package/dist/index74.js +134 -22
  124. package/dist/index74.js.map +1 -1
  125. package/dist/index75.js +50 -29
  126. package/dist/index75.js.map +1 -1
  127. package/dist/index76.js +19 -19
  128. package/dist/index76.js.map +1 -1
  129. package/dist/index77.js +31 -329
  130. package/dist/index77.js.map +1 -1
  131. package/dist/index78.js +19 -53
  132. package/dist/index78.js.map +1 -1
  133. package/dist/index79.js +328 -39
  134. package/dist/index79.js.map +1 -1
  135. package/dist/index80.js +56 -23
  136. package/dist/index80.js.map +1 -1
  137. package/dist/index81.js +40 -95
  138. package/dist/index81.js.map +1 -1
  139. package/dist/index82.js +22 -129
  140. package/dist/index82.js.map +1 -1
  141. package/dist/index83.js +86 -152
  142. package/dist/index83.js.map +1 -1
  143. package/dist/index84.js +125 -60
  144. package/dist/index84.js.map +1 -1
  145. package/dist/index85.js +160 -34
  146. package/dist/index85.js.map +1 -1
  147. package/dist/index86.js +65 -234
  148. package/dist/index86.js.map +1 -1
  149. package/dist/index87.js +35 -34
  150. package/dist/index87.js.map +1 -1
  151. package/dist/index88.js +222 -198
  152. package/dist/index88.js.map +1 -1
  153. package/dist/index89.js +34 -213
  154. package/dist/index89.js.map +1 -1
  155. package/dist/index90.js +190 -275
  156. package/dist/index90.js.map +1 -1
  157. package/dist/index91.js +202 -167
  158. package/dist/index91.js.map +1 -1
  159. package/dist/index92.js +263 -226
  160. package/dist/index92.js.map +1 -1
  161. package/dist/index93.js +176 -12
  162. package/dist/index93.js.map +1 -1
  163. package/dist/index94.js +257 -32
  164. package/dist/index94.js.map +1 -1
  165. package/dist/index95.js +13 -5
  166. package/dist/index95.js.map +1 -1
  167. package/dist/index96.js +31 -12
  168. package/dist/index96.js.map +1 -1
  169. package/dist/index97.js +5 -45
  170. package/dist/index97.js.map +1 -1
  171. package/dist/index98.js +13 -12
  172. package/dist/index98.js.map +1 -1
  173. package/dist/index99.js +44 -13
  174. package/dist/index99.js.map +1 -1
  175. package/package.json +11 -4
  176. package/dist/index106.js +0 -45
  177. package/dist/index106.js.map +0 -1
  178. package/dist/index107.js +0 -5
  179. package/dist/index107.js.map +0 -1
  180. package/dist/index108.js +0 -10
  181. package/dist/index108.js.map +0 -1
  182. package/dist/index109.js +0 -155
  183. package/dist/index109.js.map +0 -1
  184. package/dist/index110.js +0 -33
  185. package/dist/index110.js.map +0 -1
  186. package/dist/index111.js +0 -33
  187. package/dist/index111.js.map +0 -1
  188. package/dist/index112.js +0 -5
  189. package/dist/index112.js.map +0 -1
  190. package/dist/index113.js +0 -75
  191. package/dist/index113.js.map +0 -1
  192. package/dist/index114.js +0 -42
  193. package/dist/index114.js.map +0 -1
  194. package/dist/index115.js +0 -29
  195. package/dist/index115.js.map +0 -1
  196. package/dist/index116.js +0 -24
  197. package/dist/index116.js.map +0 -1
  198. package/dist/index117.js +0 -27
  199. package/dist/index117.js.map +0 -1
  200. package/dist/index118.js +0 -23
  201. package/dist/index118.js.map +0 -1
  202. package/dist/index119.js +0 -103
  203. package/dist/index119.js.map +0 -1
  204. package/dist/index120.js +0 -363
  205. package/dist/index120.js.map +0 -1
  206. package/dist/index121.js +0 -28
  207. package/dist/index121.js.map +0 -1
  208. package/dist/index122.js +0 -76
  209. package/dist/index122.js.map +0 -1
  210. package/dist/index123.js +0 -19
  211. package/dist/index123.js.map +0 -1
  212. package/dist/index124.js +0 -69
  213. package/dist/index124.js.map +0 -1
  214. package/dist/index125.js +0 -147
  215. package/dist/index125.js.map +0 -1
  216. package/dist/index126.js +0 -5
  217. package/dist/index126.js.map +0 -1
  218. package/dist/index127.js +0 -59
  219. package/dist/index127.js.map +0 -1
  220. package/dist/index128.js +0 -5
  221. package/dist/index128.js.map +0 -1
  222. package/dist/index129.js +0 -5
  223. package/dist/index129.js.map +0 -1
  224. package/dist/index130.js +0 -5
  225. package/dist/index130.js.map +0 -1
  226. package/dist/index131.js +0 -5
  227. package/dist/index131.js.map +0 -1
  228. package/dist/index132.js +0 -5
  229. package/dist/index132.js.map +0 -1
  230. package/dist/index133.js +0 -5
  231. package/dist/index133.js.map +0 -1
  232. package/dist/index134.js +0 -5
  233. package/dist/index134.js.map +0 -1
  234. package/dist/index135.js +0 -5
  235. package/dist/index135.js.map +0 -1
  236. package/dist/index136.js +0 -35
  237. package/dist/index136.js.map +0 -1
  238. package/dist/index137.js +0 -5
  239. package/dist/index137.js.map +0 -1
  240. package/dist/index138.js +0 -11
  241. package/dist/index138.js.map +0 -1
  242. package/dist/index139.js +0 -5
  243. package/dist/index139.js.map +0 -1
  244. package/dist/index140.js +0 -5
  245. package/dist/index140.js.map +0 -1
  246. package/dist/index141.js +0 -24
  247. package/dist/index141.js.map +0 -1
  248. package/dist/index142.js +0 -5
  249. package/dist/index142.js.map +0 -1
  250. package/dist/index143.js +0 -27
  251. package/dist/index143.js.map +0 -1
  252. package/dist/index144.js +0 -74
  253. package/dist/index144.js.map +0 -1
  254. package/dist/index145.js +0 -24
  255. package/dist/index145.js.map +0 -1
  256. package/dist/index146.js +0 -37
  257. package/dist/index146.js.map +0 -1
  258. package/dist/index147.js +0 -73
  259. package/dist/index147.js.map +0 -1
  260. package/dist/index148.js +0 -5
  261. package/dist/index148.js.map +0 -1
  262. package/dist/index149.js +0 -25
  263. package/dist/index149.js.map +0 -1
  264. package/dist/index150.js +0 -5
  265. package/dist/index150.js.map +0 -1
  266. package/dist/index151.js +0 -5
  267. package/dist/index151.js.map +0 -1
  268. package/dist/index152.js +0 -5
  269. package/dist/index152.js.map +0 -1
  270. package/dist/index153.js +0 -5
  271. package/dist/index153.js.map +0 -1
  272. package/dist/index154.js +0 -7
  273. package/dist/index154.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"index39.js","sources":["../src/components/InputNumber.tsx"],"sourcesContent":["import React, { useState, useRef, forwardRef, useImperativeHandle } from 'react'\n\nexport interface InputNumberProps extends Omit<React.InputHTMLAttributes<HTMLInputElement>, 'size' | 'onChange' | 'value' | 'defaultValue'> {\n value?: number\n defaultValue?: number\n min?: number\n max?: number\n step?: number\n precision?: number\n size?: 'xs' | 'sm' | 'md' | 'lg' | 'xl'\n disabled?: boolean\n onChange?: (value: number | null) => void\n formatter?: (value: number | undefined) => string\n parser?: (displayValue: string) => number\n className?: string\n controls?: boolean\n block?: boolean\n}\n\nexport const InputNumber = forwardRef<HTMLInputElement, InputNumberProps>(\n (\n {\n value: controlledValue,\n defaultValue,\n min = -Infinity,\n max = Infinity,\n step = 1,\n precision,\n size,\n disabled = false,\n onChange,\n formatter,\n parser,\n className = '',\n controls = true,\n block = true,\n ...props\n },\n ref\n ) => {\n const [internalValue, setInternalValue] = useState<number | null>(defaultValue ?? null)\n const inputRef = useRef<HTMLInputElement>(null)\n\n useImperativeHandle(ref, () => inputRef.current!)\n\n const value = controlledValue !== undefined ? controlledValue : internalValue\n\n const formatValue = (num: number | null): string => {\n if (num === null) return ''\n let formatted = num\n if (precision !== undefined) {\n formatted = Number(num.toFixed(precision))\n }\n return formatter ? formatter(formatted) : String(formatted)\n }\n\n const parseValue = (str: string): number | null => {\n if (!str) return null\n const parsed = parser ? parser(str) : parseFloat(str)\n if (isNaN(parsed)) return null\n return parsed\n }\n\n const clampValue = (num: number): number => {\n let clamped = Math.max(min, Math.min(max, num))\n if (precision !== undefined) {\n clamped = Number(clamped.toFixed(precision))\n }\n return clamped\n }\n\n const updateValue = (newValue: number | null) => {\n if (newValue === null) {\n if (controlledValue === undefined) {\n setInternalValue(null)\n }\n onChange?.(null)\n return\n }\n\n const clamped = clampValue(newValue)\n if (controlledValue === undefined) {\n setInternalValue(clamped)\n }\n onChange?.(clamped)\n }\n\n const handleIncrement = () => {\n if (disabled) return\n const currentValue = value ?? 0\n updateValue(currentValue + step)\n }\n\n const handleDecrement = () => {\n if (disabled) return\n const currentValue = value ?? 0\n updateValue(currentValue - step)\n }\n\n const handleInputChange = (e: React.ChangeEvent<HTMLInputElement>) => {\n const parsed = parseValue(e.target.value)\n if (parsed !== null) {\n updateValue(parsed)\n } else if (e.target.value === '') {\n updateValue(null)\n }\n }\n\n const handleKeyDown = (e: React.KeyboardEvent<HTMLInputElement>) => {\n if (disabled) return\n\n if (e.key === 'ArrowUp') {\n e.preventDefault()\n handleIncrement()\n } else if (e.key === 'ArrowDown') {\n e.preventDefault()\n handleDecrement()\n }\n }\n\n const handleBlur = () => {\n // Ensure value is within bounds on blur\n if (value !== null && (value < min || value > max)) {\n updateValue(clampValue(value))\n }\n }\n\n const sizeClasses = {\n xs: 'input-xs',\n sm: 'input-sm',\n md: 'input-md',\n lg: 'input-lg',\n xl: 'input-xl',\n }\n\n const inputClasses = [\n 'input',\n 'input-bordered',\n 'w-full',\n size && sizeClasses[size],\n disabled && 'input-disabled',\n controls && 'pr-8',\n ]\n .filter(Boolean)\n .join(' ')\n\n const buttonSize = size === 'xs' || size === 'sm' ? 'btn-xs' : 'btn-sm'\n\n return (\n <div className={`relative ${block ? 'w-full' : 'inline-block'} group ${className}`}>\n <input\n ref={inputRef}\n type=\"text\"\n className={inputClasses}\n value={formatValue(value)}\n onChange={handleInputChange}\n onKeyDown={handleKeyDown}\n onBlur={handleBlur}\n disabled={disabled}\n {...props}\n />\n {controls && (\n <div className=\"absolute right-1 top-1/2 -translate-y-1/2 flex flex-col gap-0.5 opacity-0 group-hover:opacity-100 transition-opacity\">\n <button\n type=\"button\"\n className={`btn ${buttonSize} btn-ghost px-1 min-h-0 h-3.5`}\n onClick={handleIncrement}\n disabled={disabled || (value !== null && value >= max)}\n tabIndex={-1}\n >\n <svg\n className=\"w-3 h-3\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n stroke=\"currentColor\"\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n strokeWidth={2}\n d=\"M5 15l7-7 7 7\"\n />\n </svg>\n </button>\n <button\n type=\"button\"\n className={`btn ${buttonSize} btn-ghost px-1 min-h-0 h-3.5`}\n onClick={handleDecrement}\n disabled={disabled || (value !== null && value <= min)}\n tabIndex={-1}\n >\n <svg\n className=\"w-3 h-3\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n stroke=\"currentColor\"\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n strokeWidth={2}\n d=\"M19 9l-7 7-7-7\"\n />\n </svg>\n </button>\n </div>\n )}\n </div>\n )\n }\n)\n\nInputNumber.displayName = 'InputNumber'\n\nexport default InputNumber\n"],"names":["InputNumber","forwardRef","controlledValue","defaultValue","min","max","step","precision","size","disabled","onChange","formatter","parser","className","controls","block","props","ref","internalValue","setInternalValue","useState","inputRef","useRef","useImperativeHandle","value","formatValue","num","formatted","parseValue","str","parsed","clampValue","clamped","updateValue","newValue","handleIncrement","handleDecrement","handleInputChange","e","handleKeyDown","handleBlur","inputClasses","buttonSize","jsxs","jsx"],"mappings":"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"}
1
+ {"version":3,"file":"index39.js","sources":["../src/components/Input.tsx"],"sourcesContent":["import React, { forwardRef, useState, useCallback, useRef, useEffect } from 'react'\n\nexport interface InputProps extends Omit<React.InputHTMLAttributes<HTMLInputElement>, 'size'> {\n type?: 'text' | 'password' | 'email' | 'number' | 'date' | 'datetime-local' | 'week' | 'month' | 'tel' | 'url' | 'search' | 'time'\n size?: 'xs' | 'sm' | 'md' | 'lg' | 'xl'\n color?: 'neutral' | 'primary' | 'secondary' | 'accent' | 'info' | 'success' | 'warning' | 'error'\n ghost?: boolean\n bordered?: boolean\n className?: string\n /** Input mask pattern. Use # for digits, A for letters, * for alphanumeric */\n mask?: string\n /** Placeholder character shown in mask (default: _) */\n maskPlaceholder?: string\n}\n\n// Helper to apply mask to raw value\nfunction applyMask(raw: string, mask: string, placeholder: string): string {\n let result = ''\n let rawIndex = 0\n\n for (let i = 0; i < mask.length && rawIndex <= raw.length; i++) {\n const maskChar = mask[i]\n if (maskChar === '#' || maskChar === 'A' || maskChar === '*') {\n if (rawIndex < raw.length) {\n result += raw[rawIndex]\n rawIndex++\n } else {\n result += placeholder\n }\n } else {\n result += maskChar\n }\n }\n\n return result\n}\n\n// Extract raw value from masked input\nfunction extractRaw(value: string, mask: string): string {\n let raw = ''\n for (let i = 0; i < value.length && i < mask.length; i++) {\n const maskChar = mask[i]\n if ((maskChar === '#' || maskChar === 'A' || maskChar === '*') && value[i] !== '_') {\n raw += value[i]\n }\n }\n return raw\n}\n\n// Check if character is valid for mask position\nfunction isValidChar(char: string, maskChar: string): boolean {\n if (maskChar === '#') return /\\d/.test(char)\n if (maskChar === 'A') return /[a-zA-Z]/.test(char)\n if (maskChar === '*') return /[a-zA-Z0-9]/.test(char)\n return false\n}\n\n// Find next input position in mask\nfunction findNextInputPosition(mask: string, fromIndex: number): number {\n for (let i = fromIndex; i < mask.length; i++) {\n if (mask[i] === '#' || mask[i] === 'A' || mask[i] === '*') {\n return i\n }\n }\n return mask.length\n}\n\nexport const Input = forwardRef<HTMLInputElement, InputProps>(\n (\n {\n type = 'text',\n size,\n color,\n ghost = false,\n bordered = true,\n className = '',\n mask,\n maskPlaceholder = '_',\n value,\n defaultValue,\n onChange,\n onKeyDown,\n ...props\n },\n ref\n ) => {\n const sizeClasses = {\n xs: 'input-xs',\n sm: 'input-sm',\n md: 'input-md',\n lg: 'input-lg',\n xl: 'input-xl',\n }\n\n const colorClasses = {\n neutral: 'input-neutral',\n primary: 'input-primary',\n secondary: 'input-secondary',\n accent: 'input-accent',\n info: 'input-info',\n success: 'input-success',\n warning: 'input-warning',\n error: 'input-error',\n }\n\n const inputClasses = [\n 'input',\n !bordered && 'border-0',\n ghost && 'input-ghost',\n size && sizeClasses[size],\n color && colorClasses[color],\n className,\n ]\n .filter(Boolean)\n .join(' ')\n\n // Mask handling\n const innerRef = useRef<HTMLInputElement>(null)\n const inputRef = (ref as React.RefObject<HTMLInputElement>) || innerRef\n\n const getInitialRaw = useCallback(() => {\n if (!mask) return ''\n const initial = (value ?? defaultValue ?? '') as string\n return extractRaw(initial, mask)\n }, [mask, value, defaultValue])\n\n const [rawValue, setRawValue] = useState(getInitialRaw)\n const [cursorPos, setCursorPos] = useState<number | null>(null)\n\n // Sync with controlled value\n useEffect(() => {\n if (mask && value !== undefined) {\n setRawValue(extractRaw(value as string, mask))\n }\n }, [mask, value])\n\n // Set cursor position after render\n useEffect(() => {\n if (cursorPos !== null && inputRef.current) {\n inputRef.current.setSelectionRange(cursorPos, cursorPos)\n setCursorPos(null)\n }\n }, [cursorPos, inputRef])\n\n const handleMaskedChange = useCallback(\n (e: React.ChangeEvent<HTMLInputElement>) => {\n if (!mask) {\n onChange?.(e)\n return\n }\n\n const input = e.target\n const inputValue = input.value\n\n // Extract what the user is trying to type\n const newRaw = extractRaw(inputValue, mask)\n\n // Filter to only valid characters\n let filteredRaw = ''\n let rawIdx = 0\n for (let i = 0; i < mask.length && rawIdx < newRaw.length; i++) {\n const maskChar = mask[i]\n if (maskChar === '#' || maskChar === 'A' || maskChar === '*') {\n if (isValidChar(newRaw[rawIdx], maskChar)) {\n filteredRaw += newRaw[rawIdx]\n }\n rawIdx++\n }\n }\n\n setRawValue(filteredRaw)\n\n // Calculate new cursor position\n const maskedValue = applyMask(filteredRaw, mask, maskPlaceholder)\n let newCursor = findNextInputPosition(mask, 0)\n let charsPlaced = 0\n for (let i = 0; i < mask.length; i++) {\n const maskChar = mask[i]\n if (maskChar === '#' || maskChar === 'A' || maskChar === '*') {\n if (charsPlaced < filteredRaw.length) {\n charsPlaced++\n newCursor = i + 1\n }\n }\n }\n // Skip to next input position if we're on a literal\n newCursor = findNextInputPosition(mask, newCursor)\n if (newCursor > mask.length) newCursor = mask.length\n\n setCursorPos(newCursor)\n\n // Create synthetic event with masked value\n const syntheticEvent = {\n ...e,\n target: { ...input, value: maskedValue },\n currentTarget: { ...input, value: maskedValue },\n } as React.ChangeEvent<HTMLInputElement>\n\n onChange?.(syntheticEvent)\n },\n [mask, maskPlaceholder, onChange]\n )\n\n const handleMaskedKeyDown = useCallback(\n (e: React.KeyboardEvent<HTMLInputElement>) => {\n if (!mask) {\n onKeyDown?.(e)\n return\n }\n\n if (e.key === 'Backspace') {\n e.preventDefault()\n const newRaw = rawValue.slice(0, -1)\n setRawValue(newRaw)\n\n // Calculate cursor position\n let newCursor = 0\n let charsPlaced = 0\n for (let i = 0; i < mask.length; i++) {\n const maskChar = mask[i]\n if (maskChar === '#' || maskChar === 'A' || maskChar === '*') {\n if (charsPlaced < newRaw.length) {\n charsPlaced++\n newCursor = i + 1\n } else {\n newCursor = i\n break\n }\n }\n }\n setCursorPos(newCursor)\n\n const maskedValue = applyMask(newRaw, mask, maskPlaceholder)\n const input = e.currentTarget\n const syntheticEvent = {\n target: { ...input, value: maskedValue },\n currentTarget: { ...input, value: maskedValue },\n } as unknown as React.ChangeEvent<HTMLInputElement>\n\n onChange?.(syntheticEvent)\n }\n\n onKeyDown?.(e)\n },\n [mask, maskPlaceholder, rawValue, onChange, onKeyDown]\n )\n\n // If no mask, render simple input\n if (!mask) {\n return (\n <input\n ref={ref}\n type={type}\n className={inputClasses}\n value={value}\n defaultValue={defaultValue}\n onChange={onChange}\n onKeyDown={onKeyDown}\n {...props}\n />\n )\n }\n\n // Render masked input\n const maskedValue = applyMask(rawValue, mask, maskPlaceholder)\n\n return (\n <input\n ref={inputRef}\n type=\"text\"\n className={inputClasses}\n value={maskedValue}\n onChange={handleMaskedChange}\n onKeyDown={handleMaskedKeyDown}\n {...props}\n />\n )\n }\n)\n\nInput.displayName = 'Input'\n"],"names":["applyMask","raw","mask","placeholder","result","rawIndex","i","maskChar","extractRaw","value","isValidChar","char","findNextInputPosition","fromIndex","Input","forwardRef","type","size","color","ghost","bordered","className","maskPlaceholder","defaultValue","onChange","onKeyDown","props","ref","sizeClasses","colorClasses","inputClasses","innerRef","useRef","inputRef","getInitialRaw","useCallback","rawValue","setRawValue","useState","cursorPos","setCursorPos","useEffect","handleMaskedChange","e","input","inputValue","newRaw","filteredRaw","rawIdx","maskedValue","newCursor","charsPlaced","syntheticEvent","handleMaskedKeyDown","jsx"],"mappings":"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"}
package/dist/index40.js CHANGED
@@ -1,18 +1,149 @@
1
- import { jsx as c } from "react/jsx-runtime";
2
- import n from "react";
3
- function p({ children: i, vertical: o = !1, className: t = "", ...a }) {
4
- const r = ["join", o && "join-vertical", t].filter(Boolean).join(" "), m = n.Children.map(i, (e) => {
5
- if (n.isValidElement(e)) {
6
- const s = e.props.className || "", l = s ? `join-item ${s}` : "join-item";
7
- return n.cloneElement(e, {
8
- className: l
9
- });
10
- }
11
- return e;
12
- });
13
- return /* @__PURE__ */ c("div", { className: r, ...a, children: m });
14
- }
1
+ import { jsxs as k, jsx as r } from "react/jsx-runtime";
2
+ import { forwardRef as S, useState as A, useRef as K, useImperativeHandle as W } from "react";
3
+ const H = S(
4
+ ({
5
+ value: o,
6
+ defaultValue: w,
7
+ min: i = -1 / 0,
8
+ max: c = 1 / 0,
9
+ step: p = 1,
10
+ precision: a,
11
+ size: s,
12
+ disabled: l = !1,
13
+ onChange: f,
14
+ formatter: d,
15
+ parser: h,
16
+ className: I = "",
17
+ controls: m = !0,
18
+ block: C = !0,
19
+ ...D
20
+ }, V) => {
21
+ const [j, v] = A(w ?? null), x = K(null);
22
+ W(V, () => x.current);
23
+ const n = o !== void 0 ? o : j, B = (t) => {
24
+ if (t === null) return "";
25
+ let e = t;
26
+ return a !== void 0 && (e = Number(t.toFixed(a))), d ? d(e) : String(e);
27
+ }, L = (t) => {
28
+ if (!t) return null;
29
+ const e = h ? h(t) : parseFloat(t);
30
+ return isNaN(e) ? null : e;
31
+ }, b = (t) => {
32
+ let e = Math.max(i, Math.min(c, t));
33
+ return a !== void 0 && (e = Number(e.toFixed(a))), e;
34
+ }, u = (t) => {
35
+ if (t === null) {
36
+ o === void 0 && v(null), f?.(null);
37
+ return;
38
+ }
39
+ const e = b(t);
40
+ o === void 0 && v(e), f?.(e);
41
+ }, g = () => {
42
+ if (l) return;
43
+ u((n ?? 0) + p);
44
+ }, y = () => {
45
+ if (l) return;
46
+ u((n ?? 0) - p);
47
+ }, M = (t) => {
48
+ const e = L(t.target.value);
49
+ e !== null ? u(e) : t.target.value === "" && u(null);
50
+ }, $ = (t) => {
51
+ l || (t.key === "ArrowUp" ? (t.preventDefault(), g()) : t.key === "ArrowDown" && (t.preventDefault(), y()));
52
+ }, F = () => {
53
+ n !== null && (n < i || n > c) && u(b(n));
54
+ }, R = [
55
+ "input",
56
+ "input-bordered",
57
+ "w-full",
58
+ s && {
59
+ xs: "input-xs",
60
+ sm: "input-sm",
61
+ md: "input-md",
62
+ lg: "input-lg",
63
+ xl: "input-xl"
64
+ }[s],
65
+ l && "input-disabled",
66
+ m && "pr-8"
67
+ ].filter(Boolean).join(" "), N = s === "xs" || s === "sm" ? "btn-xs" : "btn-sm";
68
+ return /* @__PURE__ */ k("div", { className: `relative ${C ? "w-full" : "inline-block"} group ${I}`, children: [
69
+ /* @__PURE__ */ r(
70
+ "input",
71
+ {
72
+ ref: x,
73
+ type: "text",
74
+ className: R,
75
+ value: B(n),
76
+ onChange: M,
77
+ onKeyDown: $,
78
+ onBlur: F,
79
+ disabled: l,
80
+ ...D
81
+ }
82
+ ),
83
+ m && /* @__PURE__ */ k("div", { className: "absolute right-1 top-1/2 -translate-y-1/2 flex flex-col gap-0.5 opacity-0 group-hover:opacity-100 transition-opacity", children: [
84
+ /* @__PURE__ */ r(
85
+ "button",
86
+ {
87
+ type: "button",
88
+ className: `btn ${N} btn-ghost px-1 min-h-0 h-3.5`,
89
+ onClick: g,
90
+ disabled: l || n !== null && n >= c,
91
+ tabIndex: -1,
92
+ children: /* @__PURE__ */ r(
93
+ "svg",
94
+ {
95
+ className: "w-3 h-3",
96
+ fill: "none",
97
+ viewBox: "0 0 24 24",
98
+ stroke: "currentColor",
99
+ children: /* @__PURE__ */ r(
100
+ "path",
101
+ {
102
+ strokeLinecap: "round",
103
+ strokeLinejoin: "round",
104
+ strokeWidth: 2,
105
+ d: "M5 15l7-7 7 7"
106
+ }
107
+ )
108
+ }
109
+ )
110
+ }
111
+ ),
112
+ /* @__PURE__ */ r(
113
+ "button",
114
+ {
115
+ type: "button",
116
+ className: `btn ${N} btn-ghost px-1 min-h-0 h-3.5`,
117
+ onClick: y,
118
+ disabled: l || n !== null && n <= i,
119
+ tabIndex: -1,
120
+ children: /* @__PURE__ */ r(
121
+ "svg",
122
+ {
123
+ className: "w-3 h-3",
124
+ fill: "none",
125
+ viewBox: "0 0 24 24",
126
+ stroke: "currentColor",
127
+ children: /* @__PURE__ */ r(
128
+ "path",
129
+ {
130
+ strokeLinecap: "round",
131
+ strokeLinejoin: "round",
132
+ strokeWidth: 2,
133
+ d: "M19 9l-7 7-7-7"
134
+ }
135
+ )
136
+ }
137
+ )
138
+ }
139
+ )
140
+ ] })
141
+ ] });
142
+ }
143
+ );
144
+ H.displayName = "InputNumber";
15
145
  export {
16
- p as Join
146
+ H as InputNumber,
147
+ H as default
17
148
  };
18
149
  //# sourceMappingURL=index40.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index40.js","sources":["../src/components/Join.tsx"],"sourcesContent":["import React from 'react'\n\nexport interface JoinProps extends React.HTMLAttributes<HTMLDivElement> {\n children: React.ReactNode\n vertical?: boolean\n}\n\nexport function Join({ children, vertical = false, className = '', ...rest }: JoinProps) {\n const classes = ['join', vertical && 'join-vertical', className].filter(Boolean).join(' ')\n\n // Automatically add join-item class to all children\n const childrenWithJoinItem = React.Children.map(children, (child) => {\n if (React.isValidElement(child)) {\n const existingClassName = (child.props as any).className || ''\n const newClassName = existingClassName ? `join-item ${existingClassName}` : 'join-item'\n\n return React.cloneElement(child as React.ReactElement<any>, {\n className: newClassName,\n })\n }\n return child\n })\n\n return <div className={classes} {...rest}>{childrenWithJoinItem}</div>\n}\n"],"names":["Join","children","vertical","className","rest","classes","childrenWithJoinItem","React","child","existingClassName","newClassName"],"mappings":";;AAOO,SAASA,EAAK,EAAE,UAAAC,GAAU,UAAAC,IAAW,IAAO,WAAAC,IAAY,IAAI,GAAGC,KAAmB;AACvF,QAAMC,IAAU,CAAC,QAAQH,KAAY,iBAAiBC,CAAS,EAAE,OAAO,OAAO,EAAE,KAAK,GAAG,GAGnFG,IAAuBC,EAAM,SAAS,IAAIN,GAAU,CAACO,MAAU;AACnE,QAAID,EAAM,eAAeC,CAAK,GAAG;AAC/B,YAAMC,IAAqBD,EAAM,MAAc,aAAa,IACtDE,IAAeD,IAAoB,aAAaA,CAAiB,KAAK;AAE5E,aAAOF,EAAM,aAAaC,GAAkC;AAAA,QAC1D,WAAWE;AAAA,MAAA,CACZ;AAAA,IACH;AACA,WAAOF;AAAA,EACT,CAAC;AAED,2BAAQ,OAAA,EAAI,WAAWH,GAAU,GAAGD,GAAO,UAAAE,GAAqB;AAClE;"}
1
+ {"version":3,"file":"index40.js","sources":["../src/components/InputNumber.tsx"],"sourcesContent":["import React, { useState, useRef, forwardRef, useImperativeHandle } from 'react'\n\nexport interface InputNumberProps extends Omit<React.InputHTMLAttributes<HTMLInputElement>, 'size' | 'onChange' | 'value' | 'defaultValue'> {\n value?: number\n defaultValue?: number\n min?: number\n max?: number\n step?: number\n precision?: number\n size?: 'xs' | 'sm' | 'md' | 'lg' | 'xl'\n disabled?: boolean\n onChange?: (value: number | null) => void\n formatter?: (value: number | undefined) => string\n parser?: (displayValue: string) => number\n className?: string\n controls?: boolean\n block?: boolean\n}\n\nexport const InputNumber = forwardRef<HTMLInputElement, InputNumberProps>(\n (\n {\n value: controlledValue,\n defaultValue,\n min = -Infinity,\n max = Infinity,\n step = 1,\n precision,\n size,\n disabled = false,\n onChange,\n formatter,\n parser,\n className = '',\n controls = true,\n block = true,\n ...props\n },\n ref\n ) => {\n const [internalValue, setInternalValue] = useState<number | null>(defaultValue ?? null)\n const inputRef = useRef<HTMLInputElement>(null)\n\n useImperativeHandle(ref, () => inputRef.current!)\n\n const value = controlledValue !== undefined ? controlledValue : internalValue\n\n const formatValue = (num: number | null): string => {\n if (num === null) return ''\n let formatted = num\n if (precision !== undefined) {\n formatted = Number(num.toFixed(precision))\n }\n return formatter ? formatter(formatted) : String(formatted)\n }\n\n const parseValue = (str: string): number | null => {\n if (!str) return null\n const parsed = parser ? parser(str) : parseFloat(str)\n if (isNaN(parsed)) return null\n return parsed\n }\n\n const clampValue = (num: number): number => {\n let clamped = Math.max(min, Math.min(max, num))\n if (precision !== undefined) {\n clamped = Number(clamped.toFixed(precision))\n }\n return clamped\n }\n\n const updateValue = (newValue: number | null) => {\n if (newValue === null) {\n if (controlledValue === undefined) {\n setInternalValue(null)\n }\n onChange?.(null)\n return\n }\n\n const clamped = clampValue(newValue)\n if (controlledValue === undefined) {\n setInternalValue(clamped)\n }\n onChange?.(clamped)\n }\n\n const handleIncrement = () => {\n if (disabled) return\n const currentValue = value ?? 0\n updateValue(currentValue + step)\n }\n\n const handleDecrement = () => {\n if (disabled) return\n const currentValue = value ?? 0\n updateValue(currentValue - step)\n }\n\n const handleInputChange = (e: React.ChangeEvent<HTMLInputElement>) => {\n const parsed = parseValue(e.target.value)\n if (parsed !== null) {\n updateValue(parsed)\n } else if (e.target.value === '') {\n updateValue(null)\n }\n }\n\n const handleKeyDown = (e: React.KeyboardEvent<HTMLInputElement>) => {\n if (disabled) return\n\n if (e.key === 'ArrowUp') {\n e.preventDefault()\n handleIncrement()\n } else if (e.key === 'ArrowDown') {\n e.preventDefault()\n handleDecrement()\n }\n }\n\n const handleBlur = () => {\n // Ensure value is within bounds on blur\n if (value !== null && (value < min || value > max)) {\n updateValue(clampValue(value))\n }\n }\n\n const sizeClasses = {\n xs: 'input-xs',\n sm: 'input-sm',\n md: 'input-md',\n lg: 'input-lg',\n xl: 'input-xl',\n }\n\n const inputClasses = [\n 'input',\n 'input-bordered',\n 'w-full',\n size && sizeClasses[size],\n disabled && 'input-disabled',\n controls && 'pr-8',\n ]\n .filter(Boolean)\n .join(' ')\n\n const buttonSize = size === 'xs' || size === 'sm' ? 'btn-xs' : 'btn-sm'\n\n return (\n <div className={`relative ${block ? 'w-full' : 'inline-block'} group ${className}`}>\n <input\n ref={inputRef}\n type=\"text\"\n className={inputClasses}\n value={formatValue(value)}\n onChange={handleInputChange}\n onKeyDown={handleKeyDown}\n onBlur={handleBlur}\n disabled={disabled}\n {...props}\n />\n {controls && (\n <div className=\"absolute right-1 top-1/2 -translate-y-1/2 flex flex-col gap-0.5 opacity-0 group-hover:opacity-100 transition-opacity\">\n <button\n type=\"button\"\n className={`btn ${buttonSize} btn-ghost px-1 min-h-0 h-3.5`}\n onClick={handleIncrement}\n disabled={disabled || (value !== null && value >= max)}\n tabIndex={-1}\n >\n <svg\n className=\"w-3 h-3\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n stroke=\"currentColor\"\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n strokeWidth={2}\n d=\"M5 15l7-7 7 7\"\n />\n </svg>\n </button>\n <button\n type=\"button\"\n className={`btn ${buttonSize} btn-ghost px-1 min-h-0 h-3.5`}\n onClick={handleDecrement}\n disabled={disabled || (value !== null && value <= min)}\n tabIndex={-1}\n >\n <svg\n className=\"w-3 h-3\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n stroke=\"currentColor\"\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n strokeWidth={2}\n d=\"M19 9l-7 7-7-7\"\n />\n </svg>\n </button>\n </div>\n )}\n </div>\n )\n }\n)\n\nInputNumber.displayName = 'InputNumber'\n\nexport default InputNumber\n"],"names":["InputNumber","forwardRef","controlledValue","defaultValue","min","max","step","precision","size","disabled","onChange","formatter","parser","className","controls","block","props","ref","internalValue","setInternalValue","useState","inputRef","useRef","useImperativeHandle","value","formatValue","num","formatted","parseValue","str","parsed","clampValue","clamped","updateValue","newValue","handleIncrement","handleDecrement","handleInputChange","e","handleKeyDown","handleBlur","inputClasses","buttonSize","jsxs","jsx"],"mappings":"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"}
package/dist/index41.js CHANGED
@@ -1,21 +1,18 @@
1
- import { jsx as d } from "react/jsx-runtime";
2
- const a = ({
3
- size: s,
4
- children: r,
5
- className: t = "",
6
- ...o
7
- }) => {
8
- const b = s ? `kbd-${s}` : "";
9
- return /* @__PURE__ */ d(
10
- "kbd",
11
- {
12
- className: `kbd ${b} ${t}`.trim(),
13
- ...o,
14
- children: r
1
+ import { jsx as c } from "react/jsx-runtime";
2
+ import n from "react";
3
+ function p({ children: i, vertical: o = !1, className: t = "", ...a }) {
4
+ const r = ["join", o && "join-vertical", t].filter(Boolean).join(" "), m = n.Children.map(i, (e) => {
5
+ if (n.isValidElement(e)) {
6
+ const s = e.props.className || "", l = s ? `join-item ${s}` : "join-item";
7
+ return n.cloneElement(e, {
8
+ className: l
9
+ });
15
10
  }
16
- );
17
- };
11
+ return e;
12
+ });
13
+ return /* @__PURE__ */ c("div", { className: r, ...a, children: m });
14
+ }
18
15
  export {
19
- a as Kbd
16
+ p as Join
20
17
  };
21
18
  //# sourceMappingURL=index41.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index41.js","sources":["../src/components/Kbd.tsx"],"sourcesContent":["import React from 'react'\n\nexport interface KbdProps extends React.HTMLAttributes<HTMLElement> {\n /** Size of the kbd */\n size?: 'xs' | 'sm' | 'md' | 'lg' | 'xl'\n /** Key content */\n children?: React.ReactNode\n}\n\nexport const Kbd: React.FC<KbdProps> = ({\n size,\n children,\n className = '',\n ...rest\n}) => {\n const sizeClass = size ? `kbd-${size}` : ''\n\n return (\n <kbd\n className={`kbd ${sizeClass} ${className}`.trim()}\n {...rest}\n >\n {children}\n </kbd>\n )\n}\n"],"names":["Kbd","size","children","className","rest","sizeClass","jsx"],"mappings":";AASO,MAAMA,IAA0B,CAAC;AAAA,EACtC,MAAAC;AAAA,EACA,UAAAC;AAAA,EACA,WAAAC,IAAY;AAAA,EACZ,GAAGC;AACL,MAAM;AACJ,QAAMC,IAAYJ,IAAO,OAAOA,CAAI,KAAK;AAEzC,SACE,gBAAAK;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,WAAW,OAAOD,CAAS,IAAIF,CAAS,GAAG,KAAA;AAAA,MAC1C,GAAGC;AAAA,MAEH,UAAAF;AAAA,IAAA;AAAA,EAAA;AAGP;"}
1
+ {"version":3,"file":"index41.js","sources":["../src/components/Join.tsx"],"sourcesContent":["import React from 'react'\n\nexport interface JoinProps extends React.HTMLAttributes<HTMLDivElement> {\n children: React.ReactNode\n vertical?: boolean\n}\n\nexport function Join({ children, vertical = false, className = '', ...rest }: JoinProps) {\n const classes = ['join', vertical && 'join-vertical', className].filter(Boolean).join(' ')\n\n // Automatically add join-item class to all children\n const childrenWithJoinItem = React.Children.map(children, (child) => {\n if (React.isValidElement(child)) {\n const existingClassName = (child.props as any).className || ''\n const newClassName = existingClassName ? `join-item ${existingClassName}` : 'join-item'\n\n return React.cloneElement(child as React.ReactElement<any>, {\n className: newClassName,\n })\n }\n return child\n })\n\n return <div className={classes} {...rest}>{childrenWithJoinItem}</div>\n}\n"],"names":["Join","children","vertical","className","rest","classes","childrenWithJoinItem","React","child","existingClassName","newClassName"],"mappings":";;AAOO,SAASA,EAAK,EAAE,UAAAC,GAAU,UAAAC,IAAW,IAAO,WAAAC,IAAY,IAAI,GAAGC,KAAmB;AACvF,QAAMC,IAAU,CAAC,QAAQH,KAAY,iBAAiBC,CAAS,EAAE,OAAO,OAAO,EAAE,KAAK,GAAG,GAGnFG,IAAuBC,EAAM,SAAS,IAAIN,GAAU,CAACO,MAAU;AACnE,QAAID,EAAM,eAAeC,CAAK,GAAG;AAC/B,YAAMC,IAAqBD,EAAM,MAAc,aAAa,IACtDE,IAAeD,IAAoB,aAAaA,CAAiB,KAAK;AAE5E,aAAOF,EAAM,aAAaC,GAAkC;AAAA,QAC1D,WAAWE;AAAA,MAAA,CACZ;AAAA,IACH;AACA,WAAOF;AAAA,EACT,CAAC;AAED,2BAAQ,OAAA,EAAI,WAAWH,GAAU,GAAGD,GAAO,UAAAE,GAAqB;AAClE;"}
package/dist/index42.js CHANGED
@@ -1,24 +1,21 @@
1
- import { jsx as a, jsxs as o } from "react/jsx-runtime";
2
- function c({ children: l, className: n = "", ...s }) {
3
- return /* @__PURE__ */ a("span", { className: `label ${n}`, ...s, children: l });
4
- }
5
- function r({ children: l, label: n, size: s, className: e = "", ...t }) {
6
- const i = ["floating-label", s && {
7
- xs: "input-xs",
8
- sm: "input-sm",
9
- md: "input-md",
10
- lg: "input-lg",
11
- xl: "input-xl"
12
- }[s], e].filter(Boolean).join(" ");
13
- return /* @__PURE__ */ o("label", { className: i, ...t, children: [
14
- l,
15
- /* @__PURE__ */ a("span", { children: n })
16
- ] });
17
- }
18
- const m = Object.assign(c, {
19
- Floating: r
20
- });
1
+ import { jsx as d } from "react/jsx-runtime";
2
+ const a = ({
3
+ size: s,
4
+ children: r,
5
+ className: t = "",
6
+ ...o
7
+ }) => {
8
+ const b = s ? `kbd-${s}` : "";
9
+ return /* @__PURE__ */ d(
10
+ "kbd",
11
+ {
12
+ className: `kbd ${b} ${t}`.trim(),
13
+ ...o,
14
+ children: r
15
+ }
16
+ );
17
+ };
21
18
  export {
22
- m as Label
19
+ a as Kbd
23
20
  };
24
21
  //# sourceMappingURL=index42.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index42.js","sources":["../src/components/Label.tsx"],"sourcesContent":["import React from 'react'\n\nexport interface LabelProps extends React.HTMLAttributes<HTMLSpanElement> {\n children: React.ReactNode\n}\n\nexport interface FloatingLabelProps extends React.LabelHTMLAttributes<HTMLLabelElement> {\n children: React.ReactNode\n label: string\n size?: 'xs' | 'sm' | 'md' | 'lg' | 'xl'\n}\n\nfunction LabelRoot({ children, className = '', ...rest }: LabelProps) {\n return <span className={`label ${className}`} {...rest}>{children}</span>\n}\n\nfunction FloatingLabel({ children, label, size, className = '', ...rest }: FloatingLabelProps) {\n const sizeClasses = {\n xs: 'input-xs',\n sm: 'input-sm',\n md: 'input-md',\n lg: 'input-lg',\n xl: 'input-xl',\n }\n\n const classes = ['floating-label', size && sizeClasses[size], className].filter(Boolean).join(' ')\n\n return (\n <label className={classes} {...rest}>\n {children}\n <span>{label}</span>\n </label>\n )\n}\n\nexport const Label = Object.assign(LabelRoot, {\n Floating: FloatingLabel,\n})\n"],"names":["LabelRoot","children","className","rest","jsx","FloatingLabel","label","size","classes","jsxs","Label"],"mappings":";AAYA,SAASA,EAAU,EAAE,UAAAC,GAAU,WAAAC,IAAY,IAAI,GAAGC,KAAoB;AACpE,SAAO,gBAAAC,EAAC,UAAK,WAAW,SAASF,CAAS,IAAK,GAAGC,GAAO,UAAAF,GAAS;AACpE;AAEA,SAASI,EAAc,EAAE,UAAAJ,GAAU,OAAAK,GAAO,MAAAC,GAAM,WAAAL,IAAY,IAAI,GAAGC,KAA4B;AAS7F,QAAMK,IAAU,CAAC,kBAAkBD,KARf;AAAA,IAClB,IAAI;AAAA,IACJ,IAAI;AAAA,IACJ,IAAI;AAAA,IACJ,IAAI;AAAA,IACJ,IAAI;AAAA,EAAA,EAGiDA,CAAI,GAAGL,CAAS,EAAE,OAAO,OAAO,EAAE,KAAK,GAAG;AAEjG,SACE,gBAAAO,EAAC,SAAA,EAAM,WAAWD,GAAU,GAAGL,GAC5B,UAAA;AAAA,IAAAF;AAAA,IACD,gBAAAG,EAAC,UAAM,UAAAE,EAAA,CAAM;AAAA,EAAA,GACf;AAEJ;AAEO,MAAMI,IAAQ,OAAO,OAAOV,GAAW;AAAA,EAC5C,UAAUK;AACZ,CAAC;"}
1
+ {"version":3,"file":"index42.js","sources":["../src/components/Kbd.tsx"],"sourcesContent":["import React from 'react'\n\nexport interface KbdProps extends React.HTMLAttributes<HTMLElement> {\n /** Size of the kbd */\n size?: 'xs' | 'sm' | 'md' | 'lg' | 'xl'\n /** Key content */\n children?: React.ReactNode\n}\n\nexport const Kbd: React.FC<KbdProps> = ({\n size,\n children,\n className = '',\n ...rest\n}) => {\n const sizeClass = size ? `kbd-${size}` : ''\n\n return (\n <kbd\n className={`kbd ${sizeClass} ${className}`.trim()}\n {...rest}\n >\n {children}\n </kbd>\n )\n}\n"],"names":["Kbd","size","children","className","rest","sizeClass","jsx"],"mappings":";AASO,MAAMA,IAA0B,CAAC;AAAA,EACtC,MAAAC;AAAA,EACA,UAAAC;AAAA,EACA,WAAAC,IAAY;AAAA,EACZ,GAAGC;AACL,MAAM;AACJ,QAAMC,IAAYJ,IAAO,OAAOA,CAAI,KAAK;AAEzC,SACE,gBAAAK;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,WAAW,OAAOD,CAAS,IAAIF,CAAS,GAAG,KAAA;AAAA,MAC1C,GAAGC;AAAA,MAEH,UAAAF;AAAA,IAAA;AAAA,EAAA;AAGP;"}
package/dist/index43.js CHANGED
@@ -1,122 +1,24 @@
1
- import { jsx as a, jsxs as v } from "react/jsx-runtime";
2
- import u, { useContext as k, createContext as S, useState as w, useCallback as g } from "react";
3
- const p = S(null);
4
- function F() {
5
- return k(p);
1
+ import { jsx as a, jsxs as o } from "react/jsx-runtime";
2
+ function c({ children: l, className: n = "", ...s }) {
3
+ return /* @__PURE__ */ a("span", { className: `label ${n}`, ...s, children: l });
6
4
  }
7
- function m({ children: o, className: n = "", style: s }) {
8
- const t = u.Children.toArray(o), l = t.some(
9
- (e) => u.isValidElement(e) && e.type.displayName === "LayoutSider"
10
- ), f = [
11
- "flex",
12
- "min-h-0",
13
- l ? "flex-row" : "flex-col",
14
- n
15
- ].filter(Boolean).join(" "), i = l ? t.map((e) => {
16
- if (u.isValidElement(e) && (e.type === m || e.type.displayName === "LayoutRoot") && e.type.displayName !== "LayoutSider") {
17
- const c = e.props.className || "";
18
- if (!c.includes("flex-1"))
19
- return u.cloneElement(e, {
20
- className: `flex-1 ${c}`.trim()
21
- });
22
- }
23
- return e;
24
- }) : o;
25
- return /* @__PURE__ */ a("div", { className: f, style: s, children: i });
5
+ function r({ children: l, label: n, size: s, className: e = "", ...t }) {
6
+ const i = ["floating-label", s && {
7
+ xs: "input-xs",
8
+ sm: "input-sm",
9
+ md: "input-md",
10
+ lg: "input-lg",
11
+ xl: "input-xl"
12
+ }[s], e].filter(Boolean).join(" ");
13
+ return /* @__PURE__ */ o("label", { className: i, ...t, children: [
14
+ l,
15
+ /* @__PURE__ */ a("span", { children: n })
16
+ ] });
26
17
  }
27
- m.displayName = "LayoutRoot";
28
- function B({ children: o, className: n = "", style: s }) {
29
- const t = [
30
- "flex",
31
- "items-center",
32
- "px-6",
33
- "h-16",
34
- "bg-base-300",
35
- "flex-shrink-0",
36
- n
37
- ].filter(Boolean).join(" ");
38
- return /* @__PURE__ */ a("header", { className: t, style: s, children: o });
39
- }
40
- function E({ children: o, className: n = "", style: s }) {
41
- const t = [
42
- "px-6",
43
- "py-4",
44
- "text-center",
45
- "bg-base-300",
46
- "flex-shrink-0",
47
- n
48
- ].filter(Boolean).join(" ");
49
- return /* @__PURE__ */ a("footer", { className: t, style: s, children: o });
50
- }
51
- function R({ children: o, className: n = "", style: s }) {
52
- const t = ["flex-1", "min-h-0", "overflow-auto", n].filter(Boolean).join(" ");
53
- return /* @__PURE__ */ a("main", { className: t, style: s, children: o });
54
- }
55
- function y({
56
- children: o,
57
- width: n = 200,
58
- collapsedWidth: s = 80,
59
- collapsed: t,
60
- defaultCollapsed: l = !1,
61
- collapsible: f = !1,
62
- onCollapse: i,
63
- trigger: e,
64
- className: c = "",
65
- style: C
66
- }) {
67
- const [b, N] = w(l), r = t ?? b, h = g(() => {
68
- const x = !r;
69
- t === void 0 && N(x), i?.(x);
70
- }, [r, t, i]), d = r ? s : n, L = [
71
- "flex",
72
- "flex-col",
73
- "bg-base-200",
74
- "flex-shrink-0",
75
- "transition-all",
76
- "duration-200",
77
- c
78
- ].filter(Boolean).join(" "), j = f && e !== null && /* @__PURE__ */ a(
79
- "button",
80
- {
81
- onClick: h,
82
- className: "flex items-center justify-center h-10 w-full bg-base-300 hover:bg-base-content/10 transition-colors",
83
- "aria-label": r ? "Expand sidebar" : "Collapse sidebar",
84
- children: /* @__PURE__ */ a(
85
- "svg",
86
- {
87
- className: `w-4 h-4 transition-transform ${r ? "rotate-180" : ""}`,
88
- fill: "none",
89
- viewBox: "0 0 24 24",
90
- stroke: "currentColor",
91
- children: /* @__PURE__ */ a("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "M15 19l-7-7 7-7" })
92
- }
93
- )
94
- }
95
- );
96
- return /* @__PURE__ */ a(p.Provider, { value: { collapsed: r, collapsedWidth: s, width: n }, children: /* @__PURE__ */ v(
97
- "aside",
98
- {
99
- className: L,
100
- style: {
101
- width: typeof d == "number" ? `${d}px` : d,
102
- ...C
103
- },
104
- children: [
105
- /* @__PURE__ */ a("div", { className: "flex-1 overflow-auto", children: o }),
106
- e !== null && (e ?? j)
107
- ]
108
- }
109
- ) });
110
- }
111
- y.displayName = "LayoutSider";
112
- const H = Object.assign(m, {
113
- Header: B,
114
- Footer: E,
115
- Content: R,
116
- Sider: y
18
+ const m = Object.assign(c, {
19
+ Floating: r
117
20
  });
118
21
  export {
119
- H as Layout,
120
- F as useSiderContext
22
+ m as Label
121
23
  };
122
24
  //# sourceMappingURL=index43.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index43.js","sources":["../src/components/Layout.tsx"],"sourcesContent":["import React, { createContext, useContext, useState, useCallback } from 'react'\n\nexport interface LayoutProps {\n children: React.ReactNode\n className?: string\n style?: React.CSSProperties\n}\n\nexport interface LayoutHeaderProps {\n children: React.ReactNode\n className?: string\n style?: React.CSSProperties\n}\n\nexport interface LayoutFooterProps {\n children: React.ReactNode\n className?: string\n style?: React.CSSProperties\n}\n\nexport interface LayoutContentProps {\n children: React.ReactNode\n className?: string\n style?: React.CSSProperties\n}\n\nexport interface LayoutSiderProps {\n children: React.ReactNode\n width?: number | string\n collapsedWidth?: number | string\n collapsed?: boolean\n defaultCollapsed?: boolean\n collapsible?: boolean\n onCollapse?: (collapsed: boolean) => void\n trigger?: React.ReactNode | null\n breakpoint?: 'sm' | 'md' | 'lg' | 'xl' | '2xl'\n onBreakpoint?: (broken: boolean) => void\n className?: string\n style?: React.CSSProperties\n}\n\ninterface SiderContextValue {\n collapsed: boolean\n collapsedWidth: number | string\n width: number | string\n}\n\nconst SiderContext = createContext<SiderContextValue | null>(null)\n\nexport function useSiderContext() {\n return useContext(SiderContext)\n}\n\nfunction LayoutRoot({ children, className = '', style }: LayoutProps) {\n // Check if any child is a Sider to determine flex direction\n const childArray = React.Children.toArray(children)\n const hasSider = childArray.some(\n (child) => React.isValidElement(child) && (child.type as any).displayName === 'LayoutSider'\n )\n\n const layoutClasses = [\n 'flex',\n 'min-h-0',\n hasSider ? 'flex-row' : 'flex-col',\n className,\n ]\n .filter(Boolean)\n .join(' ')\n\n // If we have a Sider, auto-add flex-1 to non-Sider Layout children\n const processedChildren = hasSider\n ? childArray.map((child) => {\n if (\n React.isValidElement(child) &&\n (child.type === LayoutRoot || (child.type as any).displayName === 'LayoutRoot') &&\n (child.type as any).displayName !== 'LayoutSider'\n ) {\n // Clone the Layout child and add flex-1 if not already present\n const existingClassName = (child.props as any).className || ''\n if (!existingClassName.includes('flex-1')) {\n return React.cloneElement(child as React.ReactElement<any>, {\n className: `flex-1 ${existingClassName}`.trim(),\n })\n }\n }\n return child\n })\n : children\n\n return (\n <div className={layoutClasses} style={style}>\n {processedChildren}\n </div>\n )\n}\n\nLayoutRoot.displayName = 'LayoutRoot'\n\nfunction LayoutHeader({ children, className = '', style }: LayoutHeaderProps) {\n const headerClasses = [\n 'flex',\n 'items-center',\n 'px-6',\n 'h-16',\n 'bg-base-300',\n 'flex-shrink-0',\n className,\n ]\n .filter(Boolean)\n .join(' ')\n\n return (\n <header className={headerClasses} style={style}>\n {children}\n </header>\n )\n}\n\nfunction LayoutFooter({ children, className = '', style }: LayoutFooterProps) {\n const footerClasses = [\n 'px-6',\n 'py-4',\n 'text-center',\n 'bg-base-300',\n 'flex-shrink-0',\n className,\n ]\n .filter(Boolean)\n .join(' ')\n\n return (\n <footer className={footerClasses} style={style}>\n {children}\n </footer>\n )\n}\n\nfunction LayoutContent({ children, className = '', style }: LayoutContentProps) {\n // flex-1 by default so Content fills available space\n const contentClasses = ['flex-1', 'min-h-0', 'overflow-auto', className].filter(Boolean).join(' ')\n\n return (\n <main className={contentClasses} style={style}>\n {children}\n </main>\n )\n}\n\nfunction LayoutSider({\n children,\n width = 200,\n collapsedWidth = 80,\n collapsed: controlledCollapsed,\n defaultCollapsed = false,\n collapsible = false,\n onCollapse,\n trigger,\n className = '',\n style,\n}: LayoutSiderProps) {\n const [internalCollapsed, setInternalCollapsed] = useState(defaultCollapsed)\n\n const collapsed = controlledCollapsed ?? internalCollapsed\n\n const handleCollapse = useCallback(() => {\n const newCollapsed = !collapsed\n if (controlledCollapsed === undefined) {\n setInternalCollapsed(newCollapsed)\n }\n onCollapse?.(newCollapsed)\n }, [collapsed, controlledCollapsed, onCollapse])\n\n const currentWidth = collapsed ? collapsedWidth : width\n\n const siderClasses = [\n 'flex',\n 'flex-col',\n 'bg-base-200',\n 'flex-shrink-0',\n 'transition-all',\n 'duration-200',\n className,\n ]\n .filter(Boolean)\n .join(' ')\n\n const defaultTrigger = collapsible && trigger !== null && (\n <button\n onClick={handleCollapse}\n className=\"flex items-center justify-center h-10 w-full bg-base-300 hover:bg-base-content/10 transition-colors\"\n aria-label={collapsed ? 'Expand sidebar' : 'Collapse sidebar'}\n >\n <svg\n className={`w-4 h-4 transition-transform ${collapsed ? 'rotate-180' : ''}`}\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n stroke=\"currentColor\"\n >\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M15 19l-7-7 7-7\" />\n </svg>\n </button>\n )\n\n return (\n <SiderContext.Provider value={{ collapsed, collapsedWidth, width }}>\n <aside\n className={siderClasses}\n style={{\n width: typeof currentWidth === 'number' ? `${currentWidth}px` : currentWidth,\n ...style,\n }}\n >\n <div className=\"flex-1 overflow-auto\">{children}</div>\n {trigger !== null && (trigger ?? defaultTrigger)}\n </aside>\n </SiderContext.Provider>\n )\n}\n\nLayoutSider.displayName = 'LayoutSider'\n\nexport const Layout = Object.assign(LayoutRoot, {\n Header: LayoutHeader,\n Footer: LayoutFooter,\n Content: LayoutContent,\n Sider: LayoutSider,\n})\n"],"names":["SiderContext","createContext","useSiderContext","useContext","LayoutRoot","children","className","style","childArray","React","hasSider","child","layoutClasses","processedChildren","existingClassName","jsx","LayoutHeader","headerClasses","LayoutFooter","footerClasses","LayoutContent","contentClasses","LayoutSider","width","collapsedWidth","controlledCollapsed","defaultCollapsed","collapsible","onCollapse","trigger","internalCollapsed","setInternalCollapsed","useState","collapsed","handleCollapse","useCallback","newCollapsed","currentWidth","siderClasses","defaultTrigger","jsxs","Layout"],"mappings":"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"}
1
+ {"version":3,"file":"index43.js","sources":["../src/components/Label.tsx"],"sourcesContent":["import React from 'react'\n\nexport interface LabelProps extends React.HTMLAttributes<HTMLSpanElement> {\n children: React.ReactNode\n}\n\nexport interface FloatingLabelProps extends React.LabelHTMLAttributes<HTMLLabelElement> {\n children: React.ReactNode\n label: string\n size?: 'xs' | 'sm' | 'md' | 'lg' | 'xl'\n}\n\nfunction LabelRoot({ children, className = '', ...rest }: LabelProps) {\n return <span className={`label ${className}`} {...rest}>{children}</span>\n}\n\nfunction FloatingLabel({ children, label, size, className = '', ...rest }: FloatingLabelProps) {\n const sizeClasses = {\n xs: 'input-xs',\n sm: 'input-sm',\n md: 'input-md',\n lg: 'input-lg',\n xl: 'input-xl',\n }\n\n const classes = ['floating-label', size && sizeClasses[size], className].filter(Boolean).join(' ')\n\n return (\n <label className={classes} {...rest}>\n {children}\n <span>{label}</span>\n </label>\n )\n}\n\nexport const Label = Object.assign(LabelRoot, {\n Floating: FloatingLabel,\n})\n"],"names":["LabelRoot","children","className","rest","jsx","FloatingLabel","label","size","classes","jsxs","Label"],"mappings":";AAYA,SAASA,EAAU,EAAE,UAAAC,GAAU,WAAAC,IAAY,IAAI,GAAGC,KAAoB;AACpE,SAAO,gBAAAC,EAAC,UAAK,WAAW,SAASF,CAAS,IAAK,GAAGC,GAAO,UAAAF,GAAS;AACpE;AAEA,SAASI,EAAc,EAAE,UAAAJ,GAAU,OAAAK,GAAO,MAAAC,GAAM,WAAAL,IAAY,IAAI,GAAGC,KAA4B;AAS7F,QAAMK,IAAU,CAAC,kBAAkBD,KARf;AAAA,IAClB,IAAI;AAAA,IACJ,IAAI;AAAA,IACJ,IAAI;AAAA,IACJ,IAAI;AAAA,IACJ,IAAI;AAAA,EAAA,EAGiDA,CAAI,GAAGL,CAAS,EAAE,OAAO,OAAO,EAAE,KAAK,GAAG;AAEjG,SACE,gBAAAO,EAAC,SAAA,EAAM,WAAWD,GAAU,GAAGL,GAC5B,UAAA;AAAA,IAAAF;AAAA,IACD,gBAAAG,EAAC,UAAM,UAAAE,EAAA,CAAM;AAAA,EAAA,GACf;AAEJ;AAEO,MAAMI,IAAQ,OAAO,OAAOV,GAAW;AAAA,EAC5C,UAAUK;AACZ,CAAC;"}