asterui 0.11.0 → 0.12.1

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 (303) hide show
  1. package/README.md +1 -103
  2. package/dist/components/Anchor.d.ts +45 -0
  3. package/dist/components/Diff.d.ts +12 -0
  4. package/dist/components/Form.d.ts +27 -2
  5. package/dist/components/Kbd.d.ts +8 -0
  6. package/dist/components/Radio.d.ts +7 -1
  7. package/dist/components/Status.d.ts +18 -0
  8. package/dist/components/TextRotate.d.ts +13 -0
  9. package/dist/index.d.ts +12 -2
  10. package/dist/index.js +210 -200
  11. package/dist/index.js.map +1 -1
  12. package/dist/index10.js +92 -30
  13. package/dist/index10.js.map +1 -1
  14. package/dist/index100.js +8 -5
  15. package/dist/index100.js.map +1 -1
  16. package/dist/index101.js +12 -41
  17. package/dist/index101.js.map +1 -1
  18. package/dist/index102.js +31 -2
  19. package/dist/index102.js.map +1 -1
  20. package/dist/index103.js +17 -6
  21. package/dist/index103.js.map +1 -1
  22. package/dist/index104.js +10788 -147
  23. package/dist/index104.js.map +1 -1
  24. package/dist/index105.js +5 -30
  25. package/dist/index105.js.map +1 -1
  26. package/dist/index106.js +39 -27
  27. package/dist/index106.js.map +1 -1
  28. package/dist/index108.js +6 -71
  29. package/dist/index108.js.map +1 -1
  30. package/dist/index109.js +147 -34
  31. package/dist/index109.js.map +1 -1
  32. package/dist/index11.js +28 -263
  33. package/dist/index11.js.map +1 -1
  34. package/dist/index110.js +28 -24
  35. package/dist/index110.js.map +1 -1
  36. package/dist/index111.js +28 -19
  37. package/dist/index111.js.map +1 -1
  38. package/dist/index112.js +2 -24
  39. package/dist/index112.js.map +1 -1
  40. package/dist/index113.js +71 -19
  41. package/dist/index113.js.map +1 -1
  42. package/dist/index114.js +33 -94
  43. package/dist/index114.js.map +1 -1
  44. package/dist/index115.js +24 -358
  45. package/dist/index115.js.map +1 -1
  46. package/dist/index116.js +19 -23
  47. package/dist/index116.js.map +1 -1
  48. package/dist/index117.js +22 -71
  49. package/dist/index117.js.map +1 -1
  50. package/dist/index118.js +17 -13
  51. package/dist/index118.js.map +1 -1
  52. package/dist/index119.js +91 -57
  53. package/dist/index119.js.map +1 -1
  54. package/dist/index12.js +259 -89
  55. package/dist/index12.js.map +1 -1
  56. package/dist/index120.js +357 -141
  57. package/dist/index120.js.map +1 -1
  58. package/dist/index121.js +25 -2
  59. package/dist/index121.js.map +1 -1
  60. package/dist/index122.js +70 -53
  61. package/dist/index122.js.map +1 -1
  62. package/dist/index123.js +16 -2
  63. package/dist/index123.js.map +1 -1
  64. package/dist/index124.js +66 -2
  65. package/dist/index124.js.map +1 -1
  66. package/dist/index125.js +144 -2
  67. package/dist/index125.js.map +1 -1
  68. package/dist/index126.js +2 -2
  69. package/dist/index127.js +56 -2
  70. package/dist/index127.js.map +1 -1
  71. package/dist/index13.js +90 -153
  72. package/dist/index13.js.map +1 -1
  73. package/dist/index130.js +2 -32
  74. package/dist/index130.js.map +1 -1
  75. package/dist/index132.js +2 -8
  76. package/dist/index132.js.map +1 -1
  77. package/dist/index133.js +2 -2
  78. package/dist/index134.js +2 -2
  79. package/dist/index135.js +2 -21
  80. package/dist/index135.js.map +1 -1
  81. package/dist/index136.js +32 -2
  82. package/dist/index136.js.map +1 -1
  83. package/dist/index137.js +2 -24
  84. package/dist/index137.js.map +1 -1
  85. package/dist/index138.js +7 -70
  86. package/dist/index138.js.map +1 -1
  87. package/dist/index139.js +2 -21
  88. package/dist/index139.js.map +1 -1
  89. package/dist/index14.js +154 -146
  90. package/dist/index14.js.map +1 -1
  91. package/dist/index140.js +2 -34
  92. package/dist/index140.js.map +1 -1
  93. package/dist/index141.js +20 -69
  94. package/dist/index141.js.map +1 -1
  95. package/dist/index142.js +2 -2
  96. package/dist/index143.js +24 -2
  97. package/dist/index143.js.map +1 -1
  98. package/dist/index144.js +70 -21
  99. package/dist/index144.js.map +1 -1
  100. package/dist/index145.js +21 -2
  101. package/dist/index145.js.map +1 -1
  102. package/dist/index146.js +34 -2
  103. package/dist/index146.js.map +1 -1
  104. package/dist/index147.js +70 -2
  105. package/dist/index147.js.map +1 -1
  106. package/dist/index148.js +2 -2
  107. package/dist/index149.js +21 -3
  108. package/dist/index149.js.map +1 -1
  109. package/dist/index15.js +150 -5
  110. package/dist/index15.js.map +1 -1
  111. package/dist/index150.js +5 -0
  112. package/dist/index150.js.map +1 -0
  113. package/dist/index151.js +5 -0
  114. package/dist/index151.js.map +1 -0
  115. package/dist/index152.js +5 -0
  116. package/dist/index152.js.map +1 -0
  117. package/dist/index153.js +5 -0
  118. package/dist/index153.js.map +1 -0
  119. package/dist/index154.js +7 -0
  120. package/dist/index154.js.map +1 -0
  121. package/dist/index16.js +5 -71
  122. package/dist/index16.js.map +1 -1
  123. package/dist/index17.js +71 -17
  124. package/dist/index17.js.map +1 -1
  125. package/dist/index18.js +15 -96
  126. package/dist/index18.js.map +1 -1
  127. package/dist/index19.js +89 -105
  128. package/dist/index19.js.map +1 -1
  129. package/dist/index20.js +107 -177
  130. package/dist/index20.js.map +1 -1
  131. package/dist/index21.js +181 -107
  132. package/dist/index21.js.map +1 -1
  133. package/dist/index22.js +107 -29
  134. package/dist/index22.js.map +1 -1
  135. package/dist/index23.js +19 -41
  136. package/dist/index23.js.map +1 -1
  137. package/dist/index24.js +31 -11
  138. package/dist/index24.js.map +1 -1
  139. package/dist/index25.js +41 -33
  140. package/dist/index25.js.map +1 -1
  141. package/dist/index26.js +12 -63
  142. package/dist/index26.js.map +1 -1
  143. package/dist/index27.js +33 -80
  144. package/dist/index27.js.map +1 -1
  145. package/dist/index28.js +63 -18
  146. package/dist/index28.js.map +1 -1
  147. package/dist/index29.js +78 -159
  148. package/dist/index29.js.map +1 -1
  149. package/dist/index3.js +96 -27
  150. package/dist/index3.js.map +1 -1
  151. package/dist/index30.js +16 -1080
  152. package/dist/index30.js.map +1 -1
  153. package/dist/index31.js +218 -16
  154. package/dist/index31.js.map +1 -1
  155. package/dist/index32.js +1081 -121
  156. package/dist/index32.js.map +1 -1
  157. package/dist/index33.js +17 -39
  158. package/dist/index33.js.map +1 -1
  159. package/dist/index34.js +121 -190
  160. package/dist/index34.js.map +1 -1
  161. package/dist/index35.js +37 -94
  162. package/dist/index35.js.map +1 -1
  163. package/dist/index36.js +186 -157
  164. package/dist/index36.js.map +1 -1
  165. package/dist/index37.js +89 -138
  166. package/dist/index37.js.map +1 -1
  167. package/dist/index38.js +161 -14
  168. package/dist/index38.js.map +1 -1
  169. package/dist/index39.js +146 -21
  170. package/dist/index39.js.map +1 -1
  171. package/dist/index4.js +26 -99
  172. package/dist/index4.js.map +1 -1
  173. package/dist/index40.js +12 -116
  174. package/dist/index40.js.map +1 -1
  175. package/dist/index41.js +18 -13
  176. package/dist/index41.js.map +1 -1
  177. package/dist/index42.js +21 -35
  178. package/dist/index42.js.map +1 -1
  179. package/dist/index43.js +117 -114
  180. package/dist/index43.js.map +1 -1
  181. package/dist/index44.js +13 -176
  182. package/dist/index44.js.map +1 -1
  183. package/dist/index45.js +34 -146
  184. package/dist/index45.js.map +1 -1
  185. package/dist/index46.js +116 -12
  186. package/dist/index46.js.map +1 -1
  187. package/dist/index47.js +176 -22
  188. package/dist/index47.js.map +1 -1
  189. package/dist/index48.js +147 -14
  190. package/dist/index48.js.map +1 -1
  191. package/dist/index49.js +10 -5
  192. package/dist/index49.js.map +1 -1
  193. package/dist/index5.js +100 -60
  194. package/dist/index5.js.map +1 -1
  195. package/dist/index50.js +21 -265
  196. package/dist/index50.js.map +1 -1
  197. package/dist/index51.js +10 -13
  198. package/dist/index51.js.map +1 -1
  199. package/dist/index52.js +7 -122
  200. package/dist/index52.js.map +1 -1
  201. package/dist/index53.js +262 -106
  202. package/dist/index53.js.map +1 -1
  203. package/dist/index54.js +14 -167
  204. package/dist/index54.js.map +1 -1
  205. package/dist/index55.js +121 -31
  206. package/dist/index55.js.map +1 -1
  207. package/dist/index56.js +107 -119
  208. package/dist/index56.js.map +1 -1
  209. package/dist/index57.js +161 -77
  210. package/dist/index57.js.map +1 -1
  211. package/dist/index58.js +31 -19
  212. package/dist/index58.js.map +1 -1
  213. package/dist/index59.js +117 -69
  214. package/dist/index59.js.map +1 -1
  215. package/dist/index6.js +61 -130
  216. package/dist/index6.js.map +1 -1
  217. package/dist/index60.js +82 -53
  218. package/dist/index60.js.map +1 -1
  219. package/dist/index61.js +19 -44
  220. package/dist/index61.js.map +1 -1
  221. package/dist/index62.js +70 -48
  222. package/dist/index62.js.map +1 -1
  223. package/dist/index63.js +55 -60
  224. package/dist/index63.js.map +1 -1
  225. package/dist/index64.js +39 -101
  226. package/dist/index64.js.map +1 -1
  227. package/dist/index65.js +52 -41
  228. package/dist/index65.js.map +1 -1
  229. package/dist/index66.js +58 -64
  230. package/dist/index66.js.map +1 -1
  231. package/dist/index67.js +105 -19
  232. package/dist/index67.js.map +1 -1
  233. package/dist/index68.js +41 -46
  234. package/dist/index68.js.map +1 -1
  235. package/dist/index69.js +63 -129
  236. package/dist/index69.js.map +1 -1
  237. package/dist/index7.js +130 -11
  238. package/dist/index7.js.map +1 -1
  239. package/dist/index70.js +19 -50
  240. package/dist/index70.js.map +1 -1
  241. package/dist/index71.js +46 -22
  242. package/dist/index71.js.map +1 -1
  243. package/dist/index72.js +134 -22
  244. package/dist/index72.js.map +1 -1
  245. package/dist/index73.js +51 -328
  246. package/dist/index73.js.map +1 -1
  247. package/dist/index74.js +19 -53
  248. package/dist/index74.js.map +1 -1
  249. package/dist/index75.js +31 -40
  250. package/dist/index75.js.map +1 -1
  251. package/dist/index76.js +22 -95
  252. package/dist/index76.js.map +1 -1
  253. package/dist/index77.js +311 -112
  254. package/dist/index77.js.map +1 -1
  255. package/dist/index78.js +52 -157
  256. package/dist/index78.js.map +1 -1
  257. package/dist/index79.js +40 -65
  258. package/dist/index79.js.map +1 -1
  259. package/dist/index8.js +11 -70
  260. package/dist/index8.js.map +1 -1
  261. package/dist/index80.js +23 -35
  262. package/dist/index80.js.map +1 -1
  263. package/dist/index81.js +88 -227
  264. package/dist/index81.js.map +1 -1
  265. package/dist/index82.js +130 -34
  266. package/dist/index82.js.map +1 -1
  267. package/dist/index83.js +153 -202
  268. package/dist/index83.js.map +1 -1
  269. package/dist/index84.js +61 -209
  270. package/dist/index84.js.map +1 -1
  271. package/dist/index85.js +34 -294
  272. package/dist/index85.js.map +1 -1
  273. package/dist/index86.js +228 -172
  274. package/dist/index86.js.map +1 -1
  275. package/dist/index87.js +32 -256
  276. package/dist/index87.js.map +1 -1
  277. package/dist/index88.js +208 -12
  278. package/dist/index88.js.map +1 -1
  279. package/dist/index89.js +209 -29
  280. package/dist/index89.js.map +1 -1
  281. package/dist/index9.js +69 -91
  282. package/dist/index9.js.map +1 -1
  283. package/dist/index90.js +294 -5
  284. package/dist/index90.js.map +1 -1
  285. package/dist/index91.js +176 -12
  286. package/dist/index91.js.map +1 -1
  287. package/dist/index92.js +256 -44
  288. package/dist/index92.js.map +1 -1
  289. package/dist/index93.js +13 -12
  290. package/dist/index93.js.map +1 -1
  291. package/dist/index94.js +32 -14
  292. package/dist/index94.js.map +1 -1
  293. package/dist/index95.js +5 -7
  294. package/dist/index95.js.map +1 -1
  295. package/dist/index96.js +13 -12
  296. package/dist/index96.js.map +1 -1
  297. package/dist/index97.js +42 -27
  298. package/dist/index97.js.map +1 -1
  299. package/dist/index98.js +11 -16
  300. package/dist/index98.js.map +1 -1
  301. package/dist/index99.js +12 -10790
  302. package/dist/index99.js.map +1 -1
  303. package/package.json +1 -1
@@ -1 +1 @@
1
- {"version":3,"file":"index71.js","sources":["../src/components/Stat.tsx"],"sourcesContent":["import React from 'react'\n\nexport interface StatsProps extends React.HTMLAttributes<HTMLDivElement> {\n children: React.ReactNode\n vertical?: boolean\n}\n\nexport interface StatProps extends Omit<React.HTMLAttributes<HTMLDivElement>, 'title'> {\n title?: React.ReactNode\n value?: React.ReactNode\n desc?: React.ReactNode\n figure?: React.ReactNode\n actions?: React.ReactNode\n}\n\nfunction StatsRoot({ children, className = '', vertical = false, ...rest }: StatsProps) {\n const classes = [\n 'stats',\n vertical ? 'stats-vertical' : 'stats-horizontal',\n className,\n ]\n .filter(Boolean)\n .join(' ')\n\n return <div className={classes} {...rest}>{children}</div>\n}\n\nfunction StatItem({ title, value, desc, figure, actions, className = '', ...rest }: StatProps) {\n return (\n <div className={`stat ${className}`} {...rest}>\n {figure && <div className=\"stat-figure\">{figure}</div>}\n {title && <div className=\"stat-title\">{title}</div>}\n {value && <div className=\"stat-value\">{value}</div>}\n {desc && <div className=\"stat-desc\">{desc}</div>}\n {actions && <div className=\"stat-actions\">{actions}</div>}\n </div>\n )\n}\n\nexport const Stats = Object.assign(StatsRoot, {\n Stat: StatItem,\n})\n"],"names":["StatsRoot","children","className","vertical","rest","classes","StatItem","title","value","desc","figure","actions","jsx","Stats"],"mappings":";AAeA,SAASA,EAAU,EAAE,UAAAC,GAAU,WAAAC,IAAY,IAAI,UAAAC,IAAW,IAAO,GAAGC,KAAoB;AACtF,QAAMC,IAAU;AAAA,IACd;AAAA,IACAF,IAAW,mBAAmB;AAAA,IAC9BD;AAAA,EAAA,EAEC,OAAO,OAAO,EACd,KAAK,GAAG;AAEX,2BAAQ,OAAA,EAAI,WAAWG,GAAU,GAAGD,GAAO,UAAAH,GAAS;AACtD;AAEA,SAASK,EAAS,EAAE,OAAAC,GAAO,OAAAC,GAAO,MAAAC,GAAM,QAAAC,GAAQ,SAAAC,GAAS,WAAAT,IAAY,IAAI,GAAGE,KAAmB;AAC7F,2BACG,OAAA,EAAI,WAAW,QAAQF,CAAS,IAAK,GAAGE,GACtC,UAAA;AAAA,IAAAM,KAAU,gBAAAE,EAAC,OAAA,EAAI,WAAU,eAAe,UAAAF,GAAO;AAAA,IAC/CH,KAAS,gBAAAK,EAAC,OAAA,EAAI,WAAU,cAAc,UAAAL,GAAM;AAAA,IAC5CC,KAAS,gBAAAI,EAAC,OAAA,EAAI,WAAU,cAAc,UAAAJ,GAAM;AAAA,IAC5CC,KAAQ,gBAAAG,EAAC,OAAA,EAAI,WAAU,aAAa,UAAAH,GAAK;AAAA,IACzCE,KAAW,gBAAAC,EAAC,OAAA,EAAI,WAAU,gBAAgB,UAAAD,EAAA,CAAQ;AAAA,EAAA,GACrD;AAEJ;AAEO,MAAME,IAAQ,OAAO,OAAOb,GAAW;AAAA,EAC5C,MAAMM;AACR,CAAC;"}
1
+ {"version":3,"file":"index71.js","sources":["../src/components/Space.tsx"],"sourcesContent":["import React from 'react'\n\nexport interface SpaceProps extends React.HTMLAttributes<HTMLDivElement> {\n direction?: 'horizontal' | 'vertical'\n size?: 'xs' | 'sm' | 'md' | 'lg' | 'xl' | number\n align?: 'start' | 'end' | 'center' | 'baseline' | 'stretch'\n justify?: 'start' | 'end' | 'center' | 'between' | 'around' | 'evenly'\n wrap?: boolean\n children: React.ReactNode\n}\n\nconst gapClasses = {\n xs: 'gap-1',\n sm: 'gap-2',\n md: 'gap-4',\n lg: 'gap-6',\n xl: 'gap-8',\n} as const\n\nconst alignClasses = {\n start: 'items-start',\n end: 'items-end',\n center: 'items-center',\n baseline: 'items-baseline',\n stretch: 'items-stretch',\n} as const\n\nconst justifyClasses = {\n start: 'justify-start',\n end: 'justify-end',\n center: 'justify-center',\n between: 'justify-between',\n around: 'justify-around',\n evenly: 'justify-evenly',\n} as const\n\nexport const Space: React.FC<SpaceProps> = ({\n direction = 'horizontal',\n size = 'md',\n align,\n justify,\n wrap = false,\n className = '',\n style,\n children,\n ...rest\n}) => {\n const isNumericSize = typeof size === 'number'\n const gapClass = isNumericSize ? '' : gapClasses[size]\n const alignClass = align ? alignClasses[align] : ''\n const justifyClass = justify ? justifyClasses[justify] : ''\n const wrapClass = wrap ? 'flex-wrap' : ''\n const directionClass = direction === 'horizontal' ? 'flex-row' : 'flex-col'\n\n const classes = [\n 'flex',\n directionClass,\n gapClass,\n alignClass,\n justifyClass,\n wrapClass,\n className\n ].filter(Boolean).join(' ')\n\n const combinedStyle: React.CSSProperties = {\n ...style,\n ...(isNumericSize ? { gap: `${size}px` } : {}),\n }\n\n return <div className={classes} style={combinedStyle} {...rest}>{children}</div>\n}\n"],"names":["gapClasses","alignClasses","justifyClasses","Space","direction","size","align","justify","wrap","className","style","children","rest","isNumericSize","gapClass","alignClass","justifyClass","classes","combinedStyle","jsx"],"mappings":";AAWA,MAAMA,IAAa;AAAA,EACjB,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AACN,GAEMC,IAAe;AAAA,EACnB,OAAO;AAAA,EACP,KAAK;AAAA,EACL,QAAQ;AAAA,EACR,UAAU;AAAA,EACV,SAAS;AACX,GAEMC,IAAiB;AAAA,EACrB,OAAO;AAAA,EACP,KAAK;AAAA,EACL,QAAQ;AAAA,EACR,SAAS;AAAA,EACT,QAAQ;AAAA,EACR,QAAQ;AACV,GAEaC,IAA8B,CAAC;AAAA,EAC1C,WAAAC,IAAY;AAAA,EACZ,MAAAC,IAAO;AAAA,EACP,OAAAC;AAAA,EACA,SAAAC;AAAA,EACA,MAAAC,IAAO;AAAA,EACP,WAAAC,IAAY;AAAA,EACZ,OAAAC;AAAA,EACA,UAAAC;AAAA,EACA,GAAGC;AACL,MAAM;AACJ,QAAMC,IAAgB,OAAOR,KAAS,UAChCS,IAAWD,IAAgB,KAAKb,EAAWK,CAAI,GAC/CU,IAAaT,IAAQL,EAAaK,CAAK,IAAI,IAC3CU,IAAeT,IAAUL,EAAeK,CAAO,IAAI,IAInDU,IAAU;AAAA,IACd;AAAA,IAHqBb,MAAc,eAAe,aAAa;AAAA,IAK/DU;AAAA,IACAC;AAAA,IACAC;AAAA,IARgBR,IAAO,cAAc;AAAA,IAUrCC;AAAA,EAAA,EACA,OAAO,OAAO,EAAE,KAAK,GAAG,GAEpBS,IAAqC;AAAA,IACzC,GAAGR;AAAA,IACH,GAAIG,IAAgB,EAAE,KAAK,GAAGR,CAAI,SAAS,CAAA;AAAA,EAAC;AAG9C,SAAO,gBAAAc,EAAC,SAAI,WAAWF,GAAS,OAAOC,GAAgB,GAAGN,GAAO,UAAAD,GAAS;AAC5E;"}
package/dist/index72.js CHANGED
@@ -1,25 +1,137 @@
1
- import { jsx as o } from "react/jsx-runtime";
2
- function c({ children: e, vertical: s = !1, className: t = "", ...n }) {
3
- const r = ["steps", s && "steps-vertical", t].filter(Boolean).join(" ");
4
- return /* @__PURE__ */ o("ul", { className: r, ...n, children: e });
5
- }
6
- function p({ children: e, color: s, dataContent: t, className: n = "", ...r }) {
7
- const a = ["step", s && {
8
- neutral: "step-neutral",
9
- primary: "step-primary",
10
- secondary: "step-secondary",
11
- accent: "step-accent",
12
- info: "step-info",
13
- success: "step-success",
14
- warning: "step-warning",
15
- error: "step-error"
16
- }[s], n].filter(Boolean).join(" ");
17
- return /* @__PURE__ */ o("li", { className: a, "data-content": t, ...r, children: e });
18
- }
19
- const u = Object.assign(c, {
20
- Step: p
21
- });
1
+ import { jsx as f, jsxs as B, Fragment as _ } from "react/jsx-runtime";
2
+ import C, { useRef as E, useCallback as x, useState as ee, useEffect as te } from "react";
3
+ const ne = ({ children: N }) => /* @__PURE__ */ f(_, { children: N }), oe = ({
4
+ children: N,
5
+ direction: c = "horizontal",
6
+ sizes: g,
7
+ defaultSizes: y,
8
+ onSizesChange: I,
9
+ gutterSize: z = 8,
10
+ minSize: R = 50,
11
+ className: G = ""
12
+ }) => {
13
+ const $ = E(null), H = E([]), b = E(null), h = C.Children.toArray(N).filter(
14
+ (n) => C.isValidElement(n)
15
+ ), l = h.length, k = x(() => {
16
+ if (y && y.length === l)
17
+ return y;
18
+ const n = 100 / l;
19
+ return Array(l).fill(n);
20
+ }, [y, l]), [D, j] = ee(k), p = g || D;
21
+ te(() => {
22
+ !g && D.length !== l && j(k());
23
+ }, [l, g, D.length, k]);
24
+ const S = x(
25
+ (n) => {
26
+ g || j(n), I?.(n);
27
+ },
28
+ [g, I]
29
+ ), V = x(
30
+ (n, e) => {
31
+ e.preventDefault();
32
+ const a = c === "horizontal" ? e.clientX : e.clientY;
33
+ b.current = {
34
+ index: n,
35
+ startPos: a,
36
+ startSizes: [...p]
37
+ };
38
+ const r = (w) => {
39
+ if (!b.current || !$.current) return;
40
+ const { index: t, startPos: P, startSizes: s } = b.current, K = $.current.getBoundingClientRect(), O = c === "horizontal" ? K.width : K.height, Q = c === "horizontal" ? w.clientX : w.clientY, T = (l - 1) * z, v = O - T, F = (Q - P) / v * 100, U = h[t]?.props || {}, X = h[t + 1]?.props || {}, W = U.minSize ?? R, Z = X.minSize ?? R, A = W / v * 100, L = Z / v * 100;
41
+ let i = s[t] + F, u = s[t + 1] - F;
42
+ i < A && (i = A, u = s[t] + s[t + 1] - A), u < L && (u = L, i = s[t] + s[t + 1] - L);
43
+ const Y = U.maxSize, q = X.maxSize;
44
+ if (Y) {
45
+ const m = Y / v * 100;
46
+ i > m && (i = m, u = s[t] + s[t + 1] - m);
47
+ }
48
+ if (q) {
49
+ const m = q / v * 100;
50
+ u > m && (u = m, i = s[t] + s[t + 1] - m);
51
+ }
52
+ const M = [...s];
53
+ M[t] = i, M[t + 1] = u, S(M);
54
+ }, o = () => {
55
+ b.current = null, document.removeEventListener("mousemove", r), document.removeEventListener("mouseup", o), document.body.style.cursor = "", document.body.style.userSelect = "";
56
+ };
57
+ document.addEventListener("mousemove", r), document.addEventListener("mouseup", o), document.body.style.cursor = c === "horizontal" ? "col-resize" : "row-resize", document.body.style.userSelect = "none";
58
+ },
59
+ [c, p, l, z, h, R, S]
60
+ ), J = x(
61
+ (n, e) => {
62
+ const a = e.shiftKey ? 10 : 1;
63
+ let r = 0;
64
+ if (c === "horizontal" ? e.key === "ArrowLeft" ? r = -a : e.key === "ArrowRight" && (r = a) : e.key === "ArrowUp" ? r = -a : e.key === "ArrowDown" && (r = a), r !== 0) {
65
+ e.preventDefault();
66
+ const o = [...p], w = 5;
67
+ let t = o[n] + r, P = o[n + 1] - r;
68
+ t >= w && P >= w && (o[n] = t, o[n + 1] = P, S(o));
69
+ }
70
+ },
71
+ [c, p, S]
72
+ ), d = c === "horizontal";
73
+ return /* @__PURE__ */ f(
74
+ "div",
75
+ {
76
+ ref: $,
77
+ className: `flex ${d ? "flex-row" : "flex-col"} h-full w-full ${G}`,
78
+ children: h.map((n, e) => {
79
+ const a = n.props, r = e === h.length - 1;
80
+ return /* @__PURE__ */ B(C.Fragment, { children: [
81
+ /* @__PURE__ */ f(
82
+ "div",
83
+ {
84
+ ref: (o) => {
85
+ H.current[e] = o;
86
+ },
87
+ className: `overflow-auto ${a.className || ""}`,
88
+ style: {
89
+ [d ? "width" : "height"]: `calc(${p[e]}% - ${(l - 1) * z / l}px)`,
90
+ flexShrink: 0
91
+ },
92
+ children: a.children
93
+ }
94
+ ),
95
+ !r && /* @__PURE__ */ f(
96
+ "div",
97
+ {
98
+ role: "separator",
99
+ "aria-orientation": d ? "vertical" : "horizontal",
100
+ "aria-valuenow": Math.round(p[e]),
101
+ tabIndex: 0,
102
+ className: `
103
+ flex-shrink-0 bg-base-300 hover:bg-primary/30 active:bg-primary/50
104
+ transition-colors duration-150 relative group
105
+ ${d ? "cursor-col-resize" : "cursor-row-resize"}
106
+ `,
107
+ style: {
108
+ [d ? "width" : "height"]: `${z}px`
109
+ },
110
+ onMouseDown: (o) => V(e, o),
111
+ onKeyDown: (o) => J(e, o),
112
+ children: /* @__PURE__ */ B(
113
+ "div",
114
+ {
115
+ className: `
116
+ absolute inset-0 flex items-center justify-center
117
+ ${d ? "flex-col gap-0.5" : "flex-row gap-0.5"}
118
+ `,
119
+ children: [
120
+ /* @__PURE__ */ f("div", { className: "w-1 h-1 rounded-full bg-base-content/30 group-hover:bg-primary/60" }),
121
+ /* @__PURE__ */ f("div", { className: "w-1 h-1 rounded-full bg-base-content/30 group-hover:bg-primary/60" }),
122
+ /* @__PURE__ */ f("div", { className: "w-1 h-1 rounded-full bg-base-content/30 group-hover:bg-primary/60" })
123
+ ]
124
+ }
125
+ )
126
+ }
127
+ )
128
+ ] }, e);
129
+ })
130
+ }
131
+ );
132
+ };
133
+ oe.Panel = ne;
22
134
  export {
23
- u as Steps
135
+ oe as Splitter
24
136
  };
25
137
  //# sourceMappingURL=index72.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index72.js","sources":["../src/components/Steps.tsx"],"sourcesContent":["import React from 'react'\n\nexport interface StepsProps extends React.HTMLAttributes<HTMLUListElement> {\n children: React.ReactNode\n vertical?: boolean\n}\n\nexport interface StepProps extends Omit<React.LiHTMLAttributes<HTMLLIElement>, 'color'> {\n children: React.ReactNode\n color?: 'neutral' | 'primary' | 'secondary' | 'accent' | 'info' | 'success' | 'warning' | 'error'\n dataContent?: string\n}\n\nfunction StepsRoot({ children, vertical = false, className = '', ...rest }: StepsProps) {\n const classes = ['steps', vertical && 'steps-vertical', className].filter(Boolean).join(' ')\n\n return <ul className={classes} {...rest}>{children}</ul>\n}\n\nfunction Step({ children, color, dataContent, className = '', ...rest }: StepProps) {\n const colorClasses = {\n neutral: 'step-neutral',\n primary: 'step-primary',\n secondary: 'step-secondary',\n accent: 'step-accent',\n info: 'step-info',\n success: 'step-success',\n warning: 'step-warning',\n error: 'step-error',\n }\n\n const classes = ['step', color && colorClasses[color], className].filter(Boolean).join(' ')\n\n return (\n <li className={classes} data-content={dataContent} {...rest}>\n {children}\n </li>\n )\n}\n\nexport const Steps = Object.assign(StepsRoot, {\n Step,\n})\n"],"names":["StepsRoot","children","vertical","className","rest","classes","Step","color","dataContent","jsx","Steps"],"mappings":";AAaA,SAASA,EAAU,EAAE,UAAAC,GAAU,UAAAC,IAAW,IAAO,WAAAC,IAAY,IAAI,GAAGC,KAAoB;AACtF,QAAMC,IAAU,CAAC,SAASH,KAAY,kBAAkBC,CAAS,EAAE,OAAO,OAAO,EAAE,KAAK,GAAG;AAE3F,2BAAQ,MAAA,EAAG,WAAWE,GAAU,GAAGD,GAAO,UAAAH,GAAS;AACrD;AAEA,SAASK,EAAK,EAAE,UAAAL,GAAU,OAAAM,GAAO,aAAAC,GAAa,WAAAL,IAAY,IAAI,GAAGC,KAAmB;AAYlF,QAAMC,IAAU,CAAC,QAAQE,KAXJ;AAAA,IACnB,SAAS;AAAA,IACT,SAAS;AAAA,IACT,WAAW;AAAA,IACX,QAAQ;AAAA,IACR,MAAM;AAAA,IACN,SAAS;AAAA,IACT,SAAS;AAAA,IACT,OAAO;AAAA,EAAA,EAGsCA,CAAK,GAAGJ,CAAS,EAAE,OAAO,OAAO,EAAE,KAAK,GAAG;AAE1F,SACE,gBAAAM,EAAC,QAAG,WAAWJ,GAAS,gBAAcG,GAAc,GAAGJ,GACpD,UAAAH,GACH;AAEJ;AAEO,MAAMS,IAAQ,OAAO,OAAOV,GAAW;AAAA,EAC5C,MAAAM;AACF,CAAC;"}
1
+ {"version":3,"file":"index72.js","sources":["../src/components/Splitter.tsx"],"sourcesContent":["import React, { useState, useRef, useCallback, useEffect } from 'react'\n\nexport interface SplitterPanelProps {\n children: React.ReactNode\n defaultSize?: number\n size?: number\n minSize?: number\n maxSize?: number\n collapsible?: boolean\n collapsed?: boolean\n onCollapse?: (collapsed: boolean) => void\n className?: string\n}\n\nexport interface SplitterProps {\n children: React.ReactNode\n direction?: 'horizontal' | 'vertical'\n sizes?: number[]\n defaultSizes?: number[]\n onSizesChange?: (sizes: number[]) => void\n gutterSize?: number\n minSize?: number\n className?: string\n}\n\nconst Panel: React.FC<SplitterPanelProps> = ({ children }) => {\n return <>{children}</>\n}\n\nexport const Splitter: React.FC<SplitterProps> & { Panel: typeof Panel } = ({\n children,\n direction = 'horizontal',\n sizes,\n defaultSizes,\n onSizesChange,\n gutterSize = 8,\n minSize = 50,\n className = '',\n}) => {\n const containerRef = useRef<HTMLDivElement>(null)\n const panelsRef = useRef<(HTMLDivElement | null)[]>([])\n const draggingRef = useRef<{ index: number; startPos: number; startSizes: number[] } | null>(null)\n\n // Extract panel props from children\n const panels = React.Children.toArray(children).filter(\n (child): child is React.ReactElement<SplitterPanelProps> =>\n React.isValidElement(child)\n )\n\n const panelCount = panels.length\n\n // Initialize sizes\n const getInitialSizes = useCallback(() => {\n if (defaultSizes && defaultSizes.length === panelCount) {\n return defaultSizes\n }\n // Equal distribution\n const equalSize = 100 / panelCount\n return Array(panelCount).fill(equalSize)\n }, [defaultSizes, panelCount])\n\n const [internalSizes, setInternalSizes] = useState<number[]>(getInitialSizes)\n const currentSizes = sizes || internalSizes\n\n // Update internal sizes when panel count changes\n useEffect(() => {\n if (!sizes && internalSizes.length !== panelCount) {\n setInternalSizes(getInitialSizes())\n }\n }, [panelCount, sizes, internalSizes.length, getInitialSizes])\n\n const updateSizes = useCallback(\n (newSizes: number[]) => {\n if (!sizes) {\n setInternalSizes(newSizes)\n }\n onSizesChange?.(newSizes)\n },\n [sizes, onSizesChange]\n )\n\n const handleMouseDown = useCallback(\n (index: number, e: React.MouseEvent) => {\n e.preventDefault()\n const startPos = direction === 'horizontal' ? e.clientX : e.clientY\n draggingRef.current = {\n index,\n startPos,\n startSizes: [...currentSizes],\n }\n\n const handleMouseMove = (moveEvent: MouseEvent) => {\n if (!draggingRef.current || !containerRef.current) return\n\n const { index: dragIndex, startPos: dragStartPos, startSizes } = draggingRef.current\n const containerRect = containerRef.current.getBoundingClientRect()\n const containerSize = direction === 'horizontal' ? containerRect.width : containerRect.height\n const currentPos = direction === 'horizontal' ? moveEvent.clientX : moveEvent.clientY\n\n // Calculate delta as percentage\n const gutterCount = panelCount - 1\n const totalGutterSize = gutterCount * gutterSize\n const availableSize = containerSize - totalGutterSize\n const deltaPixels = currentPos - dragStartPos\n const deltaPercent = (deltaPixels / availableSize) * 100\n\n // Get min sizes for panels\n const panel1Props = panels[dragIndex]?.props || {}\n const panel2Props = panels[dragIndex + 1]?.props || {}\n const minSize1 = panel1Props.minSize ?? minSize\n const minSize2 = panel2Props.minSize ?? minSize\n const minPercent1 = (minSize1 / availableSize) * 100\n const minPercent2 = (minSize2 / availableSize) * 100\n\n // Calculate new sizes\n let newSize1 = startSizes[dragIndex] + deltaPercent\n let newSize2 = startSizes[dragIndex + 1] - deltaPercent\n\n // Apply min constraints\n if (newSize1 < minPercent1) {\n newSize1 = minPercent1\n newSize2 = startSizes[dragIndex] + startSizes[dragIndex + 1] - minPercent1\n }\n if (newSize2 < minPercent2) {\n newSize2 = minPercent2\n newSize1 = startSizes[dragIndex] + startSizes[dragIndex + 1] - minPercent2\n }\n\n // Apply max constraints\n const maxSize1 = panel1Props.maxSize\n const maxSize2 = panel2Props.maxSize\n if (maxSize1) {\n const maxPercent1 = (maxSize1 / availableSize) * 100\n if (newSize1 > maxPercent1) {\n newSize1 = maxPercent1\n newSize2 = startSizes[dragIndex] + startSizes[dragIndex + 1] - maxPercent1\n }\n }\n if (maxSize2) {\n const maxPercent2 = (maxSize2 / availableSize) * 100\n if (newSize2 > maxPercent2) {\n newSize2 = maxPercent2\n newSize1 = startSizes[dragIndex] + startSizes[dragIndex + 1] - maxPercent2\n }\n }\n\n const newSizes = [...startSizes]\n newSizes[dragIndex] = newSize1\n newSizes[dragIndex + 1] = newSize2\n updateSizes(newSizes)\n }\n\n const handleMouseUp = () => {\n draggingRef.current = null\n document.removeEventListener('mousemove', handleMouseMove)\n document.removeEventListener('mouseup', handleMouseUp)\n document.body.style.cursor = ''\n document.body.style.userSelect = ''\n }\n\n document.addEventListener('mousemove', handleMouseMove)\n document.addEventListener('mouseup', handleMouseUp)\n document.body.style.cursor = direction === 'horizontal' ? 'col-resize' : 'row-resize'\n document.body.style.userSelect = 'none'\n },\n [direction, currentSizes, panelCount, gutterSize, panels, minSize, updateSizes]\n )\n\n const handleKeyDown = useCallback(\n (index: number, e: React.KeyboardEvent) => {\n const step = e.shiftKey ? 10 : 1\n let delta = 0\n\n if (direction === 'horizontal') {\n if (e.key === 'ArrowLeft') delta = -step\n else if (e.key === 'ArrowRight') delta = step\n } else {\n if (e.key === 'ArrowUp') delta = -step\n else if (e.key === 'ArrowDown') delta = step\n }\n\n if (delta !== 0) {\n e.preventDefault()\n const newSizes = [...currentSizes]\n const minPercent = 5 // Minimum 5% when using keyboard\n\n let newSize1 = newSizes[index] + delta\n let newSize2 = newSizes[index + 1] - delta\n\n if (newSize1 >= minPercent && newSize2 >= minPercent) {\n newSizes[index] = newSize1\n newSizes[index + 1] = newSize2\n updateSizes(newSizes)\n }\n }\n },\n [direction, currentSizes, updateSizes]\n )\n\n const isHorizontal = direction === 'horizontal'\n\n return (\n <div\n ref={containerRef}\n className={`flex ${isHorizontal ? 'flex-row' : 'flex-col'} h-full w-full ${className}`}\n >\n {panels.map((panel, index) => {\n const panelProps = panel.props\n const isLast = index === panels.length - 1\n\n return (\n <React.Fragment key={index}>\n <div\n ref={(el) => {\n panelsRef.current[index] = el\n }}\n className={`overflow-auto ${panelProps.className || ''}`}\n style={{\n [isHorizontal ? 'width' : 'height']: `calc(${currentSizes[index]}% - ${\n ((panelCount - 1) * gutterSize) / panelCount\n }px)`,\n flexShrink: 0,\n }}\n >\n {panelProps.children}\n </div>\n {!isLast && (\n <div\n role=\"separator\"\n aria-orientation={isHorizontal ? 'vertical' : 'horizontal'}\n aria-valuenow={Math.round(currentSizes[index])}\n tabIndex={0}\n className={`\n flex-shrink-0 bg-base-300 hover:bg-primary/30 active:bg-primary/50\n transition-colors duration-150 relative group\n ${isHorizontal ? 'cursor-col-resize' : 'cursor-row-resize'}\n `}\n style={{\n [isHorizontal ? 'width' : 'height']: `${gutterSize}px`,\n }}\n onMouseDown={(e) => handleMouseDown(index, e)}\n onKeyDown={(e) => handleKeyDown(index, e)}\n >\n {/* Grip indicator */}\n <div\n className={`\n absolute inset-0 flex items-center justify-center\n ${isHorizontal ? 'flex-col gap-0.5' : 'flex-row gap-0.5'}\n `}\n >\n <div className=\"w-1 h-1 rounded-full bg-base-content/30 group-hover:bg-primary/60\" />\n <div className=\"w-1 h-1 rounded-full bg-base-content/30 group-hover:bg-primary/60\" />\n <div className=\"w-1 h-1 rounded-full bg-base-content/30 group-hover:bg-primary/60\" />\n </div>\n </div>\n )}\n </React.Fragment>\n )\n })}\n </div>\n )\n}\n\nSplitter.Panel = Panel\n"],"names":["Panel","children","Splitter","direction","sizes","defaultSizes","onSizesChange","gutterSize","minSize","className","containerRef","useRef","panelsRef","draggingRef","panels","React","child","panelCount","getInitialSizes","useCallback","equalSize","internalSizes","setInternalSizes","useState","currentSizes","useEffect","updateSizes","newSizes","handleMouseDown","index","startPos","handleMouseMove","moveEvent","dragIndex","dragStartPos","startSizes","containerRect","containerSize","currentPos","totalGutterSize","availableSize","deltaPercent","panel1Props","panel2Props","minSize1","minSize2","minPercent1","minPercent2","newSize1","newSize2","maxSize1","maxSize2","maxPercent1","maxPercent2","handleMouseUp","handleKeyDown","step","delta","minPercent","isHorizontal","jsx","panel","panelProps","isLast","jsxs","el","e"],"mappings":"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"}
package/dist/index73.js CHANGED
@@ -1,332 +1,55 @@
1
- import { jsx as s, jsxs as f } from "react/jsx-runtime";
2
- import { useState as v } from "react";
3
- function te({
4
- filters: l,
5
- selectedValues: p,
6
- onChange: k
7
- }) {
8
- const [w, m] = v(!1), I = (c) => {
9
- const S = p.includes(c) ? p.filter(($) => $ !== c) : [...p, c];
10
- k(S);
11
- }, P = () => {
12
- k([]), m(!1);
13
- };
14
- return /* @__PURE__ */ f("div", { className: "dropdown dropdown-end", children: [
15
- /* @__PURE__ */ s(
16
- "button",
17
- {
18
- tabIndex: 0,
19
- className: `btn btn-ghost btn-xs ${p.length > 0 ? "text-primary" : ""}`,
20
- onClick: () => m(!w),
21
- children: /* @__PURE__ */ s("svg", { className: "w-4 h-4", fill: "none", stroke: "currentColor", viewBox: "0 0 24 24", children: /* @__PURE__ */ s("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "M3 4a1 1 0 011-1h16a1 1 0 011 1v2.586a1 1 0 01-.293.707l-6.414 6.414a1 1 0 00-.293.707V17l-4 4v-6.586a1 1 0 00-.293-.707L3.293 7.293A1 1 0 013 6.586V4z" }) })
22
- }
23
- ),
24
- w && /* @__PURE__ */ f(
25
- "div",
26
- {
27
- tabIndex: 0,
28
- className: "dropdown-content z-[1] menu p-2 shadow bg-base-100 rounded-box w-52 border border-base-content/10",
29
- children: [
30
- /* @__PURE__ */ s("div", { className: "space-y-2", children: l.map((c) => /* @__PURE__ */ f("label", { className: "flex items-center gap-2 cursor-pointer p-2 hover:bg-base-200 rounded", children: [
31
- /* @__PURE__ */ s(
32
- "input",
33
- {
34
- type: "checkbox",
35
- className: "checkbox checkbox-xs",
36
- checked: p.includes(c.value),
37
- onChange: () => I(c.value)
38
- }
39
- ),
40
- /* @__PURE__ */ s("span", { className: "text-sm", children: c.text })
41
- ] }, String(c.value))) }),
42
- /* @__PURE__ */ s("div", { className: "divider my-1" }),
43
- /* @__PURE__ */ s(
44
- "button",
45
- {
46
- className: "btn btn-ghost btn-xs w-full",
47
- onClick: P,
48
- children: "Clear"
49
- }
50
- )
51
- ]
52
- }
53
- )
54
- ] });
55
- }
56
- function ne({
57
- columns: l,
58
- dataSource: p,
59
- rowKey: k = "id",
60
- loading: w = !1,
61
- size: m = "md",
62
- bordered: I = !1,
63
- hoverable: P = !0,
64
- striped: c = !1,
65
- pinRows: S = !1,
66
- pinCols: $ = !1,
67
- pagination: h,
68
- rowSelection: o,
69
- className: E = "",
70
- onRow: W
71
- }) {
72
- const [N, K] = v(
73
- h !== !1 && h?.current ? h.current : 1
74
- ), j = h !== !1 && h?.pageSize ? h.pageSize : 10, [x, T] = v(() => {
75
- const e = l.find((t) => t.defaultSortOrder);
76
- return {
77
- columnKey: e?.key || null,
78
- order: e?.defaultSortOrder || null
79
- };
80
- }), [V, _] = v(() => {
81
- const e = {};
82
- return l.forEach((t) => {
83
- t.defaultFilteredValue && (e[t.key] = t.defaultFilteredValue);
84
- }), e;
85
- }), [z, O] = v(
86
- o?.selectedRowKeys || []
87
- ), R = h !== !1;
88
- let y = [...p];
89
- if (Object.entries(V).forEach(([e, t]) => {
90
- if (t.length > 0) {
91
- const n = l.find((r) => r.key === e);
92
- n?.onFilter && (y = y.filter(
93
- (r) => t.some((i) => n.onFilter(i, r))
94
- ));
95
- }
96
- }), x.columnKey && x.order) {
97
- const e = l.find((t) => t.key === x.columnKey);
98
- e?.sorter && y.sort((t, n) => {
99
- let r = 0;
100
- if (typeof e.sorter == "function")
101
- r = e.sorter(t, n);
102
- else if (e.dataIndex) {
103
- const i = t[e.dataIndex], d = n[e.dataIndex];
104
- i < d && (r = -1), i > d && (r = 1);
105
- }
106
- return x.order === "ascend" ? r : -r;
107
- });
108
- }
109
- const L = Math.ceil(y.length / j), A = (N - 1) * j, q = A + j, C = R ? y.slice(A, q) : y, B = (e) => {
110
- K(e), h !== !1 && h?.onChange && h.onChange(e, j);
111
- }, G = (e) => {
112
- T((t) => {
113
- if (t.columnKey === e) {
114
- if (t.order === "ascend") return { columnKey: e, order: "descend" };
115
- if (t.order === "descend") return { columnKey: null, order: null };
116
- }
117
- return { columnKey: e, order: "ascend" };
118
- }), K(1);
119
- }, J = (e, t) => {
120
- _((n) => ({
121
- ...n,
122
- [e]: t
123
- })), K(1);
124
- }, Q = (e) => {
125
- const t = e ? C.map((n, r) => F(n, r)) : [];
126
- if (O(t), o?.onChange) {
127
- const n = e ? C : [];
128
- o.onChange(t, n);
129
- }
130
- }, U = (e, t, n) => {
131
- const r = F(e, t), i = n ? [...z, r] : z.filter((d) => d !== r);
132
- if (O(i), o?.onChange) {
133
- const d = y.filter(
134
- (u, a) => i.includes(F(u, a))
135
- );
136
- o.onChange(i, d);
137
- }
138
- }, F = (e, t) => typeof k == "function" ? k(e) : e[k] ?? t.toString(), X = (e, t, n) => e.render ? e.render(
139
- e.dataIndex ? t[e.dataIndex] : void 0,
140
- t,
141
- n
142
- ) : e.dataIndex ? t[e.dataIndex] : "", M = (e) => e === "center" ? "text-center" : e === "right" ? "text-right" : "text-left", D = (e, t = !1) => {
143
- const n = l[e];
144
- if (!n.fixed) return { className: "" };
145
- const r = ["sticky", "bg-base-100"];
146
- let i = 0;
147
- const d = {
148
- boxSizing: "border-box"
149
- };
150
- if (n.fixed === "left") {
151
- for (let a = 0; a < e; a++)
152
- if (l[a].fixed === "left" && l[a].width) {
153
- const b = l[a].width, g = typeof b == "number" ? b : parseInt(String(b));
154
- isNaN(g) || (i += g);
155
- }
156
- i === 0 ? r.push("left-0") : d.left = `${i}px`, r.push(t ? "z-30" : "z-20");
157
- let u = -1;
158
- for (let a = l.length - 1; a >= 0; a--)
159
- if (l[a].fixed === "left") {
160
- u = a;
161
- break;
162
- }
163
- e === u && (d.boxShadow = "2px 0 4px rgba(0, 0, 0, 0.1)");
164
- }
165
- if (n.fixed === "right") {
166
- for (let a = e + 1; a < l.length; a++)
167
- if (l[a].fixed === "right" && l[a].width) {
168
- const b = l[a].width, g = typeof b == "number" ? b : parseInt(String(b));
169
- isNaN(g) || (i += g);
170
- }
171
- i === 0 ? r.push("right-0") : d.right = `${i}px`, r.push(t ? "z-30" : "z-20"), e === l.findIndex((a) => a.fixed === "right") && (d.boxShadow = "-2px 0 4px rgba(0, 0, 0, 0.1)");
172
- }
173
- return {
174
- className: r.filter(Boolean).join(" "),
175
- style: Object.keys(d).length > 0 ? d : void 0
176
- };
177
- }, Y = [
178
- "table",
179
- "bg-base-100",
180
- m === "xs" && "table-xs",
181
- m === "sm" && "table-sm",
182
- m === "lg" && "table-lg",
183
- c && "table-zebra",
184
- S && "table-pin-rows",
185
- $ && "table-pin-cols",
186
- E
187
- ].filter(Boolean).join(" "), Z = l.some((e) => e.fixed), H = [
188
- (!S || Z) && "overflow-x-auto",
189
- I && "rounded-box border border-base-content/5 bg-base-100"
1
+ import { jsx as u } from "react/jsx-runtime";
2
+ const j = ({
3
+ children: s,
4
+ direction: a = "vertical",
5
+ spacing: n = 4,
6
+ align: e,
7
+ justify: t,
8
+ wrap: r = !1,
9
+ className: c = "",
10
+ ...i
11
+ }) => {
12
+ const l = {
13
+ vertical: "flex-col",
14
+ horizontal: "flex-row"
15
+ }, o = {
16
+ 0: "gap-0",
17
+ 1: "gap-1",
18
+ 2: "gap-2",
19
+ 3: "gap-3",
20
+ 4: "gap-4",
21
+ 5: "gap-5",
22
+ 6: "gap-6",
23
+ 8: "gap-8",
24
+ 10: "gap-10",
25
+ 12: "gap-12",
26
+ 16: "gap-16",
27
+ 20: "gap-20",
28
+ 24: "gap-24"
29
+ }, p = e && {
30
+ start: "items-start",
31
+ center: "items-center",
32
+ end: "items-end",
33
+ stretch: "items-stretch"
34
+ }[e], g = t && {
35
+ start: "justify-start",
36
+ center: "justify-center",
37
+ end: "justify-end",
38
+ between: "justify-between",
39
+ around: "justify-around",
40
+ evenly: "justify-evenly"
41
+ }[t], f = [
42
+ "flex",
43
+ l[a],
44
+ o[n],
45
+ p,
46
+ g,
47
+ r && "flex-wrap",
48
+ c
190
49
  ].filter(Boolean).join(" ");
191
- if (w)
192
- return /* @__PURE__ */ s("div", { className: "flex justify-center items-center p-8", children: /* @__PURE__ */ s("span", { className: "loading loading-spinner loading-lg" }) });
193
- const ee = C.length > 0 && z.length === C.length;
194
- return /* @__PURE__ */ f("div", { className: "space-y-4", children: [
195
- /* @__PURE__ */ s("div", { className: H, children: /* @__PURE__ */ f("table", { className: Y, style: { borderCollapse: "separate", borderSpacing: 0, tableLayout: "fixed" }, children: [
196
- /* @__PURE__ */ s("thead", { children: /* @__PURE__ */ f("tr", { children: [
197
- o && /* @__PURE__ */ s("th", { style: { width: 50 }, className: "sticky left-0 z-20 bg-base-100", children: o.type !== "radio" && /* @__PURE__ */ s(
198
- "input",
199
- {
200
- type: "checkbox",
201
- className: "checkbox checkbox-sm",
202
- checked: ee,
203
- onChange: (e) => Q(e.target.checked)
204
- }
205
- ) }),
206
- l.map((e, t) => {
207
- const n = D(t, !0);
208
- return /* @__PURE__ */ s(
209
- "th",
210
- {
211
- className: `${M(e.align)} ${n.className}`,
212
- style: {
213
- ...e.width ? { width: e.width } : {},
214
- ...n.style
215
- },
216
- children: /* @__PURE__ */ f("div", { className: "flex items-center gap-2", children: [
217
- /* @__PURE__ */ s(
218
- "span",
219
- {
220
- className: e.sorter ? "cursor-pointer select-none" : "",
221
- onClick: () => e.sorter && G(e.key),
222
- children: e.title
223
- }
224
- ),
225
- e.sorter && /* @__PURE__ */ f("div", { className: "flex flex-col", children: [
226
- /* @__PURE__ */ s(
227
- "svg",
228
- {
229
- className: `w-3 h-3 ${x.columnKey === e.key && x.order === "ascend" ? "text-primary" : "text-base-content/30"}`,
230
- fill: "currentColor",
231
- viewBox: "0 0 20 20",
232
- children: /* @__PURE__ */ s("path", { d: "M5.293 9.707a1 1 0 010-1.414l4-4a1 1 0 011.414 0l4 4a1 1 0 01-1.414 1.414L11 7.414V15a1 1 0 11-2 0V7.414L6.707 9.707a1 1 0 01-1.414 0z" })
233
- }
234
- ),
235
- /* @__PURE__ */ s(
236
- "svg",
237
- {
238
- className: `w-3 h-3 -mt-1 ${x.columnKey === e.key && x.order === "descend" ? "text-primary" : "text-base-content/30"}`,
239
- fill: "currentColor",
240
- viewBox: "0 0 20 20",
241
- children: /* @__PURE__ */ s("path", { d: "M14.707 10.293a1 1 0 010 1.414l-4 4a1 1 0 01-1.414 0l-4-4a1 1 0 111.414-1.414L9 12.586V5a1 1 0 012 0v7.586l2.293-2.293a1 1 0 011.414 0z" })
242
- }
243
- )
244
- ] }),
245
- e.filters && /* @__PURE__ */ s(
246
- te,
247
- {
248
- filters: e.filters,
249
- selectedValues: V[e.key] || [],
250
- onChange: (r) => J(e.key, r)
251
- }
252
- )
253
- ] })
254
- },
255
- e.key
256
- );
257
- })
258
- ] }) }),
259
- /* @__PURE__ */ s("tbody", { children: C.map((e, t) => {
260
- const n = W?.(e, t) || {}, r = F(e, t), i = z.includes(r), d = [
261
- P && "hover:bg-base-300",
262
- i && "bg-primary/10"
263
- ].filter(Boolean).join(" "), u = o?.getCheckboxProps?.(e) || {};
264
- return /* @__PURE__ */ f(
265
- "tr",
266
- {
267
- className: d,
268
- ...n,
269
- children: [
270
- o && /* @__PURE__ */ s("td", { className: "sticky left-0 z-10 bg-base-100", children: /* @__PURE__ */ s(
271
- "input",
272
- {
273
- type: o.type === "radio" ? "radio" : "checkbox",
274
- className: o.type === "radio" ? "radio radio-sm" : "checkbox checkbox-sm",
275
- checked: i,
276
- onChange: (a) => U(e, t, a.target.checked),
277
- ...u
278
- }
279
- ) }),
280
- l.map((a, b) => {
281
- const g = D(b, !1);
282
- return /* @__PURE__ */ s(
283
- "td",
284
- {
285
- className: `${M(a.align)} ${g.className}`,
286
- style: g.style,
287
- children: X(a, e, t)
288
- },
289
- a.key
290
- );
291
- })
292
- ]
293
- },
294
- r
295
- );
296
- }) })
297
- ] }) }),
298
- R && L > 1 && /* @__PURE__ */ s("div", { className: "flex justify-end", children: /* @__PURE__ */ f("div", { className: "join", children: [
299
- /* @__PURE__ */ s(
300
- "button",
301
- {
302
- className: "join-item btn btn-sm",
303
- onClick: () => B(N - 1),
304
- disabled: N === 1,
305
- children: "«"
306
- }
307
- ),
308
- Array.from({ length: L }, (e, t) => t + 1).map((e) => /* @__PURE__ */ s(
309
- "button",
310
- {
311
- className: `join-item btn btn-sm ${N === e ? "btn-active" : ""}`,
312
- onClick: () => B(e),
313
- children: e
314
- },
315
- e
316
- )),
317
- /* @__PURE__ */ s(
318
- "button",
319
- {
320
- className: "join-item btn btn-sm",
321
- onClick: () => B(N + 1),
322
- disabled: N === L,
323
- children: "»"
324
- }
325
- )
326
- ] }) })
327
- ] });
328
- }
50
+ return /* @__PURE__ */ u("div", { className: f, ...i, children: s });
51
+ };
329
52
  export {
330
- ne as Table
53
+ j as Stack
331
54
  };
332
55
  //# sourceMappingURL=index73.js.map