@expcat/tigercat-react 0.4.3 → 1.0.4

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 (480) hide show
  1. package/dist/chunk-24RUEJWB.js +293 -0
  2. package/dist/{chunk-WGRYO5HX.mjs → chunk-2UQC3WOI.mjs} +63 -49
  3. package/dist/{chunk-V5NIFF2F.mjs → chunk-2WBPUW75.mjs} +7 -7
  4. package/dist/{chunk-QL6UEG3U.js → chunk-2XOFRGY6.js} +16 -3
  5. package/dist/chunk-32PAZTVF.mjs +123 -0
  6. package/dist/{chunk-IGE44BIS.mjs → chunk-34DLDOGP.mjs} +105 -19
  7. package/dist/chunk-34VGG7AK.mjs +40 -0
  8. package/dist/chunk-3EB42WFR.mjs +35 -0
  9. package/dist/{chunk-Z7SXK2KO.js → chunk-3JGOTJZM.js} +10 -7
  10. package/dist/{chunk-ENSLMM3L.mjs → chunk-3KMKMAE3.mjs} +15 -10
  11. package/dist/{chunk-SFALTVPS.js → chunk-3USEV7EV.js} +2 -2
  12. package/dist/chunk-45H3JEI3.js +155 -0
  13. package/dist/chunk-4APNERYR.js +212 -0
  14. package/dist/chunk-4GV7UQJJ.js +96 -0
  15. package/dist/chunk-4MKMM2OI.js +112 -0
  16. package/dist/{chunk-XKDWDANG.js → chunk-4Q4GADHJ.js} +7 -7
  17. package/dist/{chunk-QM4GOQDT.js → chunk-4QJZT6QK.js} +44 -6
  18. package/dist/chunk-4QQZ5H4V.mjs +213 -0
  19. package/dist/chunk-5CGXFQND.mjs +100 -0
  20. package/dist/chunk-5EVHVZG5.js +119 -0
  21. package/dist/{chunk-LXX2ZDJN.js → chunk-5MALB34H.js} +9 -9
  22. package/dist/chunk-5ZYZQXEM.mjs +167 -0
  23. package/dist/{chunk-PEGJ2KHC.js → chunk-65VXCN5N.js} +50 -68
  24. package/dist/{chunk-6PXNWGR5.mjs → chunk-6744DTEB.mjs} +9 -4
  25. package/dist/chunk-6E7FPBRR.mjs +192 -0
  26. package/dist/{chunk-NQFHS4W2.mjs → chunk-6KKUJT6B.mjs} +1 -1
  27. package/dist/{chunk-OXT5RN55.mjs → chunk-6P3JIUSI.mjs} +3 -3
  28. package/dist/chunk-73BP3WQN.mjs +210 -0
  29. package/dist/{chunk-77PE7OFK.mjs → chunk-7MASYF4S.mjs} +1 -1
  30. package/dist/{chunk-VCNZEQEB.mjs → chunk-7QZ4XT2P.mjs} +6 -5
  31. package/dist/chunk-7YLVAZJQ.mjs +47 -0
  32. package/dist/{chunk-NV3JUZ3N.js → chunk-AGR3FM3V.js} +4 -4
  33. package/dist/{chunk-EHYSER2Z.js → chunk-AHF6JE43.js} +7 -7
  34. package/dist/{chunk-MWH6FCSE.js → chunk-AJQPGAYL.js} +8 -8
  35. package/dist/{chunk-3PV2MDST.mjs → chunk-AMOH5AMN.mjs} +8 -8
  36. package/dist/chunk-AOZLBASY.mjs +38 -0
  37. package/dist/chunk-ASALMHFI.js +34 -0
  38. package/dist/chunk-AUW7DCXL.js +61 -0
  39. package/dist/{chunk-QFYS5QIZ.mjs → chunk-AYDTXJOR.mjs} +4 -4
  40. package/dist/{chunk-LLHUBM6E.mjs → chunk-B3MNIAM5.mjs} +4 -4
  41. package/dist/chunk-B53R2U2R.mjs +86 -0
  42. package/dist/chunk-BALJCZ62.mjs +147 -0
  43. package/dist/{chunk-F24IF2QL.js → chunk-BCNKTT5C.js} +14 -9
  44. package/dist/{chunk-JNLX47UL.mjs → chunk-BJ2GUKPU.mjs} +74 -36
  45. package/dist/chunk-BKYE77F2.js +171 -0
  46. package/dist/chunk-BR5OSUZT.mjs +55 -0
  47. package/dist/chunk-BZ3AXFLG.js +149 -0
  48. package/dist/{chunk-SOC74QA2.js → chunk-C6WJ4GQW.js} +8 -8
  49. package/dist/{chunk-LXQOQJMU.js → chunk-CDT3P2ZN.js} +5 -12
  50. package/dist/chunk-CHH7DWIO.js +121 -0
  51. package/dist/{chunk-3T7L3MHX.js → chunk-CKFE2B36.js} +76 -38
  52. package/dist/{chunk-QNRAM3CM.js → chunk-CMGI5WHZ.js} +3 -2
  53. package/dist/chunk-CQGAZ5JQ.js +61 -0
  54. package/dist/chunk-CRSMECWE.mjs +33 -0
  55. package/dist/{chunk-KAWE5LQZ.js → chunk-D6BHFGTN.js} +29 -0
  56. package/dist/chunk-DAR2BMMV.js +150 -0
  57. package/dist/{chunk-OCVQ3LOT.mjs → chunk-DKT2EYVM.mjs} +3 -5
  58. package/dist/chunk-DZGDCRBH.mjs +30 -0
  59. package/dist/{chunk-S4GNTA7V.mjs → chunk-EBLAM3YP.mjs} +2 -2
  60. package/dist/chunk-EEF26RBA.mjs +48 -0
  61. package/dist/{chunk-PJCY45UP.mjs → chunk-EHU3J4B2.mjs} +1 -1
  62. package/dist/{chunk-RKB2VUQO.js → chunk-EOYJLBFD.js} +24 -21
  63. package/dist/{chunk-DTQZPZSJ.mjs → chunk-EPN7QWP6.mjs} +16 -2
  64. package/dist/{chunk-M46L73HR.js → chunk-ET5YJELZ.js} +14 -14
  65. package/dist/{chunk-NTODO3Q3.mjs → chunk-EV6KRX6F.mjs} +38 -8
  66. package/dist/{chunk-GB5G2CJY.js → chunk-F2OF6XZ6.js} +36 -6
  67. package/dist/chunk-F6KHZNRS.js +32 -0
  68. package/dist/{chunk-URM7QDHH.js → chunk-F7H4ALKN.js} +2 -2
  69. package/dist/chunk-FHE4D56E.js +188 -0
  70. package/dist/chunk-FNK4ZATV.js +94 -0
  71. package/dist/{chunk-RGFSY3S2.mjs → chunk-FPURO6QB.mjs} +16 -3
  72. package/dist/chunk-GBTKAKUD.mjs +300 -0
  73. package/dist/chunk-GOUMB34F.mjs +168 -0
  74. package/dist/chunk-H3NLKNR4.mjs +192 -0
  75. package/dist/{chunk-6W6CRBBG.mjs → chunk-HCZA4LV6.mjs} +8 -5
  76. package/dist/{chunk-5CLXOFRZ.mjs → chunk-HLJQZUIY.mjs} +11 -10
  77. package/dist/chunk-HLS4CHWX.mjs +29 -0
  78. package/dist/{chunk-MTL2QUM3.mjs → chunk-HSHVLIEL.mjs} +2 -2
  79. package/dist/{chunk-XWNVBCJA.js → chunk-HU3VDVH6.js} +14 -15
  80. package/dist/{chunk-SW4I4X6E.mjs → chunk-HUCBHFSL.mjs} +24 -21
  81. package/dist/{chunk-Q57BYUUW.js → chunk-HWWNBCFB.js} +39 -8
  82. package/dist/{chunk-MDZDPGRK.mjs → chunk-HZ5Z5Y2J.mjs} +29 -10
  83. package/dist/chunk-HZHFFVP7.mjs +63 -0
  84. package/dist/chunk-I3CDTF4U.js +45 -0
  85. package/dist/chunk-I4SKKEU3.js +151 -0
  86. package/dist/{chunk-RCNTRSUA.mjs → chunk-INBSKSZG.mjs} +51 -69
  87. package/dist/chunk-IOHPB4CF.js +148 -0
  88. package/dist/{chunk-QIJG42YQ.mjs → chunk-IPLK4AIE.mjs} +3 -3
  89. package/dist/{chunk-XWRJVNB6.js → chunk-IWP22YTF.js} +104 -18
  90. package/dist/chunk-J3N24I7A.mjs +58 -0
  91. package/dist/chunk-JB33A4S6.js +125 -0
  92. package/dist/{chunk-DQNA57CA.js → chunk-JLM4LBUS.js} +5 -12
  93. package/dist/{chunk-TJFS44SH.js → chunk-JLRRXRZO.js} +2 -4
  94. package/dist/{chunk-GNMOOYHG.js → chunk-KNBNE74O.js} +11 -10
  95. package/dist/chunk-LODDAS62.js +173 -0
  96. package/dist/{chunk-LL6B4BHF.mjs → chunk-LPNHBHS2.mjs} +4 -4
  97. package/dist/{chunk-KBTFBEPE.mjs → chunk-MB7CJ32C.mjs} +153 -16
  98. package/dist/{chunk-IP3MAJSH.mjs → chunk-MQ5ZP5RW.mjs} +5 -12
  99. package/dist/{chunk-KMTERPME.mjs → chunk-MSHCPJIJ.mjs} +1 -1
  100. package/dist/chunk-N66WEQ6M.js +240 -0
  101. package/dist/{chunk-TDRINUMH.js → chunk-NZNSUKPT.js} +29 -10
  102. package/dist/{chunk-EFLIFXZH.js → chunk-P3XVLJYD.js} +15 -1
  103. package/dist/chunk-P6E3DILH.mjs +51 -0
  104. package/dist/{chunk-HPXLUJFJ.mjs → chunk-PN33UCWB.mjs} +3 -5
  105. package/dist/chunk-PNAWOJ32.js +54 -0
  106. package/dist/{chunk-72MWKUBC.js → chunk-PUYT62KC.js} +17 -4
  107. package/dist/chunk-Q4JMAQXJ.js +41 -0
  108. package/dist/chunk-QBZODEIG.js +49 -0
  109. package/dist/chunk-QHG7KJH6.js +302 -0
  110. package/dist/chunk-QIXQYLH5.js +44 -0
  111. package/dist/chunk-QO3GGQAV.mjs +148 -0
  112. package/dist/{chunk-RGZYYVQF.mjs → chunk-QPGL4YEO.mjs} +39 -11
  113. package/dist/{chunk-6IH5QPTR.mjs → chunk-QPOH6SOO.mjs} +44 -6
  114. package/dist/chunk-QVZTZHCJ.mjs +148 -0
  115. package/dist/{chunk-C7UKFKVY.js → chunk-QYGBT4NL.js} +40 -12
  116. package/dist/chunk-QYLNPHKG.mjs +87 -0
  117. package/dist/chunk-R3QWJ7GT.mjs +186 -0
  118. package/dist/chunk-R5P72RIT.js +180 -0
  119. package/dist/chunk-R5XY4EQL.js +56 -0
  120. package/dist/chunk-RRJTIKU6.mjs +238 -0
  121. package/dist/{chunk-ZFHTSHXS.mjs → chunk-RUROWRB5.mjs} +30 -1
  122. package/dist/{chunk-SAZ6V6DX.js → chunk-RVCUNEBU.js} +2 -4
  123. package/dist/chunk-RWZIWKZR.js +188 -0
  124. package/dist/{chunk-HB2UYJBY.js → chunk-RYW4CV7U.js} +61 -47
  125. package/dist/chunk-S5Y6UHAK.mjs +116 -0
  126. package/dist/{chunk-YV6Y7C43.js → chunk-SDWJSALH.js} +8 -3
  127. package/dist/chunk-SQK2CPSV.mjs +59 -0
  128. package/dist/{chunk-NJCKTIWB.mjs → chunk-SWF7GJYT.mjs} +6 -7
  129. package/dist/chunk-T5FAKJ6C.mjs +49 -0
  130. package/dist/chunk-TFPIRBHL.js +103 -0
  131. package/dist/chunk-TKZO5UBH.js +65 -0
  132. package/dist/chunk-TMQA74FM.js +215 -0
  133. package/dist/chunk-TQEIMVJD.mjs +94 -0
  134. package/dist/chunk-TYCRDHE6.mjs +143 -0
  135. package/dist/chunk-TZNTHABR.js +58 -0
  136. package/dist/chunk-UBKOITHT.mjs +142 -0
  137. package/dist/{chunk-RDIEZKV2.js → chunk-UEJHVPE2.js} +2 -2
  138. package/dist/chunk-UF3DXKCI.js +35 -0
  139. package/dist/chunk-UIO6O4MI.js +57 -0
  140. package/dist/chunk-UKGQ7256.js +13 -0
  141. package/dist/chunk-UPQGB5NQ.mjs +38 -0
  142. package/dist/chunk-UQMPEMY7.mjs +11 -0
  143. package/dist/chunk-V3P4ZAGL.mjs +110 -0
  144. package/dist/{chunk-TGPQ4KET.mjs → chunk-VAQDUVBP.mjs} +29 -2
  145. package/dist/chunk-VHHEP5G7.js +123 -0
  146. package/dist/{chunk-J3HKED4B.js → chunk-VHWTMNQN.js} +8 -8
  147. package/dist/{chunk-56KTCMRE.mjs → chunk-VONFSF4S.mjs} +5 -12
  148. package/dist/{chunk-JWFEJ4XG.js → chunk-WGPUGPYE.js} +2 -2
  149. package/dist/chunk-WIWTY74F.mjs +44 -0
  150. package/dist/chunk-WNLUUD5N.mjs +179 -0
  151. package/dist/{chunk-VCOBBJLP.js → chunk-WVVXZKNI.js} +5 -4
  152. package/dist/chunk-XEYP62CR.js +194 -0
  153. package/dist/chunk-XFJ5Q5PF.mjs +30 -0
  154. package/dist/{chunk-ZBVFM3GJ.js → chunk-XO6NSGV3.js} +152 -15
  155. package/dist/{chunk-FMF2G6BJ.js → chunk-XR6B2URW.js} +3 -3
  156. package/dist/chunk-Y3NDP56G.mjs +174 -0
  157. package/dist/chunk-YHFBPSMF.js +198 -0
  158. package/dist/chunk-YID7J6ZK.js +37 -0
  159. package/dist/chunk-YJ4W6DMX.mjs +186 -0
  160. package/dist/chunk-YLZEOXFS.mjs +116 -0
  161. package/dist/chunk-YPHOVEVU.mjs +118 -0
  162. package/dist/chunk-YXWRSEP5.mjs +286 -0
  163. package/dist/chunk-Z6CRXABX.js +88 -0
  164. package/dist/{chunk-24U2DQRP.mjs → chunk-ZD4BVRYG.mjs} +2 -1
  165. package/dist/chunk-ZRHDNGWO.js +46 -0
  166. package/dist/chunk-ZYJTHGQW.js +181 -0
  167. package/dist/components/ActivityFeed.js +5 -5
  168. package/dist/components/ActivityFeed.mjs +3 -3
  169. package/dist/components/Affix.d.mts +11 -0
  170. package/dist/components/Affix.d.ts +11 -0
  171. package/dist/components/Affix.js +10 -0
  172. package/dist/components/Affix.mjs +1 -0
  173. package/dist/components/Alert.js +2 -2
  174. package/dist/components/Alert.mjs +1 -1
  175. package/dist/components/AreaChart.js +5 -5
  176. package/dist/components/AreaChart.mjs +3 -3
  177. package/dist/components/AutoComplete.d.mts +16 -0
  178. package/dist/components/AutoComplete.d.ts +16 -0
  179. package/dist/components/AutoComplete.js +10 -0
  180. package/dist/components/AutoComplete.mjs +1 -0
  181. package/dist/components/AvatarGroup.d.mts +14 -0
  182. package/dist/components/AvatarGroup.d.ts +14 -0
  183. package/dist/components/AvatarGroup.js +14 -0
  184. package/dist/components/AvatarGroup.mjs +1 -0
  185. package/dist/components/Badge.js +2 -2
  186. package/dist/components/Badge.mjs +1 -1
  187. package/dist/components/BarChart.js +5 -5
  188. package/dist/components/BarChart.mjs +3 -3
  189. package/dist/components/Button.d.mts +2 -1
  190. package/dist/components/Button.d.ts +2 -1
  191. package/dist/components/Button.js +2 -2
  192. package/dist/components/Button.mjs +1 -1
  193. package/dist/components/ButtonGroup.d.mts +15 -0
  194. package/dist/components/ButtonGroup.d.ts +15 -0
  195. package/dist/components/ButtonGroup.js +18 -0
  196. package/dist/components/ButtonGroup.mjs +1 -0
  197. package/dist/components/Calendar.d.mts +15 -0
  198. package/dist/components/Calendar.d.ts +15 -0
  199. package/dist/components/Calendar.js +16 -0
  200. package/dist/components/Calendar.mjs +1 -0
  201. package/dist/components/Card.js +2 -2
  202. package/dist/components/Card.mjs +1 -1
  203. package/dist/components/Cascader.d.mts +15 -0
  204. package/dist/components/Cascader.d.ts +15 -0
  205. package/dist/components/Cascader.js +10 -0
  206. package/dist/components/Cascader.mjs +1 -0
  207. package/dist/components/ChatWindow.js +7 -6
  208. package/dist/components/ChatWindow.mjs +5 -4
  209. package/dist/components/Checkbox.js +4 -3
  210. package/dist/components/Checkbox.mjs +3 -2
  211. package/dist/components/CheckboxGroup.js +4 -3
  212. package/dist/components/CheckboxGroup.mjs +2 -1
  213. package/dist/components/CodeEditor.d.mts +11 -0
  214. package/dist/components/CodeEditor.d.ts +11 -0
  215. package/dist/components/CodeEditor.js +16 -0
  216. package/dist/components/CodeEditor.mjs +1 -0
  217. package/dist/components/ColorPicker.d.mts +12 -0
  218. package/dist/components/ColorPicker.d.ts +12 -0
  219. package/dist/components/ColorPicker.js +10 -0
  220. package/dist/components/ColorPicker.mjs +1 -0
  221. package/dist/components/CommentThread.js +7 -6
  222. package/dist/components/CommentThread.mjs +5 -4
  223. package/dist/components/ConfigProvider.d.mts +5 -1
  224. package/dist/components/ConfigProvider.d.ts +5 -1
  225. package/dist/components/ConfigProvider.js +3 -3
  226. package/dist/components/ConfigProvider.mjs +1 -1
  227. package/dist/components/CropUpload.js +4 -4
  228. package/dist/components/CropUpload.mjs +3 -3
  229. package/dist/components/DataTableWithToolbar.js +7 -7
  230. package/dist/components/DataTableWithToolbar.mjs +5 -5
  231. package/dist/components/DatePicker.js +2 -2
  232. package/dist/components/DatePicker.mjs +1 -1
  233. package/dist/components/Descriptions.d.mts +3 -3
  234. package/dist/components/Descriptions.d.ts +3 -3
  235. package/dist/components/Descriptions.js +3 -3
  236. package/dist/components/Descriptions.mjs +1 -1
  237. package/dist/components/Divider.js +2 -2
  238. package/dist/components/Divider.mjs +1 -1
  239. package/dist/components/DonutChart.js +5 -5
  240. package/dist/components/DonutChart.mjs +3 -3
  241. package/dist/components/Drawer.js +2 -2
  242. package/dist/components/Drawer.mjs +1 -1
  243. package/dist/components/Dropdown.d.mts +1 -1
  244. package/dist/components/Dropdown.d.ts +1 -1
  245. package/dist/components/Dropdown.js +3 -3
  246. package/dist/components/Dropdown.mjs +1 -1
  247. package/dist/components/DropdownItem.js +3 -3
  248. package/dist/components/DropdownItem.mjs +2 -2
  249. package/dist/components/Empty.d.mts +14 -0
  250. package/dist/components/Empty.d.ts +14 -0
  251. package/dist/components/Empty.js +10 -0
  252. package/dist/components/Empty.mjs +1 -0
  253. package/dist/components/FileManager.d.mts +29 -0
  254. package/dist/components/FileManager.d.ts +29 -0
  255. package/dist/components/FileManager.js +16 -0
  256. package/dist/components/FileManager.mjs +1 -0
  257. package/dist/components/FloatButton.d.mts +21 -0
  258. package/dist/components/FloatButton.d.ts +21 -0
  259. package/dist/components/FloatButton.js +14 -0
  260. package/dist/components/FloatButton.mjs +1 -0
  261. package/dist/components/Form.d.mts +24 -0
  262. package/dist/components/Form.d.ts +24 -0
  263. package/dist/components/Form.js +3 -3
  264. package/dist/components/Form.mjs +1 -1
  265. package/dist/components/FormItem.js +3 -3
  266. package/dist/components/FormItem.mjs +2 -2
  267. package/dist/components/FormWizard.d.mts +1 -1
  268. package/dist/components/FormWizard.d.ts +1 -1
  269. package/dist/components/FormWizard.js +5 -5
  270. package/dist/components/FormWizard.mjs +3 -3
  271. package/dist/components/FunnelChart.d.mts +15 -0
  272. package/dist/components/FunnelChart.d.ts +15 -0
  273. package/dist/components/FunnelChart.js +14 -0
  274. package/dist/components/FunnelChart.mjs +5 -0
  275. package/dist/components/GaugeChart.d.mts +9 -0
  276. package/dist/components/GaugeChart.d.ts +9 -0
  277. package/dist/components/GaugeChart.js +11 -0
  278. package/dist/components/GaugeChart.mjs +2 -0
  279. package/dist/components/HeatmapChart.d.mts +13 -0
  280. package/dist/components/HeatmapChart.d.ts +13 -0
  281. package/dist/components/HeatmapChart.js +13 -0
  282. package/dist/components/HeatmapChart.mjs +4 -0
  283. package/dist/components/Image.d.mts +4 -0
  284. package/dist/components/Image.d.ts +4 -0
  285. package/dist/components/Image.js +4 -4
  286. package/dist/components/Image.mjs +3 -3
  287. package/dist/components/ImageGroup.js +4 -4
  288. package/dist/components/ImageGroup.mjs +2 -2
  289. package/dist/components/ImagePreview.d.mts +3 -2
  290. package/dist/components/ImagePreview.d.ts +3 -2
  291. package/dist/components/ImagePreview.js +2 -2
  292. package/dist/components/ImagePreview.mjs +1 -1
  293. package/dist/components/ImageViewer.d.mts +20 -0
  294. package/dist/components/ImageViewer.d.ts +20 -0
  295. package/dist/components/ImageViewer.js +10 -0
  296. package/dist/components/ImageViewer.mjs +1 -0
  297. package/dist/components/InfiniteScroll.d.mts +20 -0
  298. package/dist/components/InfiniteScroll.d.ts +20 -0
  299. package/dist/components/InfiniteScroll.js +16 -0
  300. package/dist/components/InfiniteScroll.mjs +1 -0
  301. package/dist/components/Input.d.mts +5 -0
  302. package/dist/components/Input.d.ts +5 -0
  303. package/dist/components/Input.js +2 -2
  304. package/dist/components/Input.mjs +1 -1
  305. package/dist/components/InputGroup.d.mts +20 -0
  306. package/dist/components/InputGroup.d.ts +20 -0
  307. package/dist/components/InputGroup.js +22 -0
  308. package/dist/components/InputGroup.mjs +1 -0
  309. package/dist/components/InputNumber.js +2 -2
  310. package/dist/components/InputNumber.mjs +1 -1
  311. package/dist/components/Kanban.d.mts +46 -0
  312. package/dist/components/Kanban.d.ts +46 -0
  313. package/dist/components/Kanban.js +17 -0
  314. package/dist/components/Kanban.mjs +2 -0
  315. package/dist/components/LineChart.js +5 -5
  316. package/dist/components/LineChart.mjs +3 -3
  317. package/dist/components/List.d.mts +9 -1
  318. package/dist/components/List.d.ts +9 -1
  319. package/dist/components/List.js +2 -2
  320. package/dist/components/List.mjs +1 -1
  321. package/dist/components/Mentions.d.mts +18 -0
  322. package/dist/components/Mentions.d.ts +18 -0
  323. package/dist/components/Mentions.js +16 -0
  324. package/dist/components/Mentions.mjs +1 -0
  325. package/dist/components/Modal.d.mts +2 -2
  326. package/dist/components/Modal.d.ts +2 -2
  327. package/dist/components/Modal.js +3 -3
  328. package/dist/components/Modal.mjs +2 -2
  329. package/dist/components/NotificationCenter.js +8 -8
  330. package/dist/components/NotificationCenter.mjs +6 -6
  331. package/dist/components/PieChart.js +4 -4
  332. package/dist/components/PieChart.mjs +2 -2
  333. package/dist/components/Popconfirm.d.mts +1 -1
  334. package/dist/components/Popconfirm.d.ts +1 -1
  335. package/dist/components/Popconfirm.js +3 -3
  336. package/dist/components/Popconfirm.mjs +2 -2
  337. package/dist/components/Popover.d.mts +1 -1
  338. package/dist/components/Popover.d.ts +1 -1
  339. package/dist/components/Popover.js +3 -3
  340. package/dist/components/Popover.mjs +2 -2
  341. package/dist/components/PrintLayout.d.mts +22 -0
  342. package/dist/components/PrintLayout.d.ts +22 -0
  343. package/dist/components/PrintLayout.js +14 -0
  344. package/dist/components/PrintLayout.mjs +1 -0
  345. package/dist/components/Progress.js +2 -2
  346. package/dist/components/Progress.mjs +1 -1
  347. package/dist/components/QRCode.d.mts +16 -0
  348. package/dist/components/QRCode.d.ts +16 -0
  349. package/dist/components/QRCode.js +16 -0
  350. package/dist/components/QRCode.mjs +1 -0
  351. package/dist/components/RadarChart.js +4 -4
  352. package/dist/components/RadarChart.mjs +2 -2
  353. package/dist/components/Radio.js +4 -3
  354. package/dist/components/Radio.mjs +3 -2
  355. package/dist/components/RadioGroup.js +4 -3
  356. package/dist/components/RadioGroup.mjs +2 -1
  357. package/dist/components/Rate.d.mts +14 -0
  358. package/dist/components/Rate.d.ts +14 -0
  359. package/dist/components/Rate.js +10 -0
  360. package/dist/components/Rate.mjs +1 -0
  361. package/dist/components/Resizable.d.mts +13 -0
  362. package/dist/components/Resizable.d.ts +13 -0
  363. package/dist/components/Resizable.js +16 -0
  364. package/dist/components/Resizable.mjs +1 -0
  365. package/dist/components/Result.d.mts +14 -0
  366. package/dist/components/Result.d.ts +14 -0
  367. package/dist/components/Result.js +11 -0
  368. package/dist/components/Result.mjs +2 -0
  369. package/dist/components/RichTextEditor.d.mts +26 -0
  370. package/dist/components/RichTextEditor.d.ts +26 -0
  371. package/dist/components/RichTextEditor.js +17 -0
  372. package/dist/components/RichTextEditor.mjs +2 -0
  373. package/dist/components/ScatterChart.js +5 -5
  374. package/dist/components/ScatterChart.mjs +3 -3
  375. package/dist/components/Segmented.d.mts +12 -0
  376. package/dist/components/Segmented.d.ts +12 -0
  377. package/dist/components/Segmented.js +10 -0
  378. package/dist/components/Segmented.mjs +1 -0
  379. package/dist/components/Select.js +2 -2
  380. package/dist/components/Select.mjs +1 -1
  381. package/dist/components/Splitter.d.mts +18 -0
  382. package/dist/components/Splitter.d.ts +18 -0
  383. package/dist/components/Splitter.js +16 -0
  384. package/dist/components/Splitter.mjs +1 -0
  385. package/dist/components/Statistic.d.mts +8 -0
  386. package/dist/components/Statistic.d.ts +8 -0
  387. package/dist/components/Statistic.js +10 -0
  388. package/dist/components/Statistic.mjs +1 -0
  389. package/dist/components/Stepper.d.mts +12 -0
  390. package/dist/components/Stepper.d.ts +12 -0
  391. package/dist/components/Stepper.js +10 -0
  392. package/dist/components/Stepper.mjs +1 -0
  393. package/dist/components/SunburstChart.d.mts +15 -0
  394. package/dist/components/SunburstChart.d.ts +15 -0
  395. package/dist/components/SunburstChart.js +14 -0
  396. package/dist/components/SunburstChart.mjs +5 -0
  397. package/dist/components/TabPane.js +2 -2
  398. package/dist/components/TabPane.mjs +1 -1
  399. package/dist/components/Table.d.mts +13 -1
  400. package/dist/components/Table.d.ts +13 -1
  401. package/dist/components/Table.js +2 -2
  402. package/dist/components/Table.mjs +1 -1
  403. package/dist/components/Tabs.d.mts +7 -0
  404. package/dist/components/Tabs.d.ts +7 -0
  405. package/dist/components/Tabs.js +3 -3
  406. package/dist/components/Tabs.mjs +1 -1
  407. package/dist/components/TaskBoard.js +4 -4
  408. package/dist/components/TaskBoard.mjs +2 -2
  409. package/dist/components/Text.js +2 -2
  410. package/dist/components/Text.mjs +1 -1
  411. package/dist/components/Textarea.js +3 -2
  412. package/dist/components/Textarea.mjs +2 -1
  413. package/dist/components/Tooltip.d.mts +1 -1
  414. package/dist/components/Tooltip.d.ts +1 -1
  415. package/dist/components/Tooltip.js +3 -3
  416. package/dist/components/Tooltip.mjs +2 -2
  417. package/dist/components/Tour.d.mts +14 -0
  418. package/dist/components/Tour.d.ts +14 -0
  419. package/dist/components/Tour.js +11 -0
  420. package/dist/components/Tour.mjs +2 -0
  421. package/dist/components/Transfer.d.mts +12 -0
  422. package/dist/components/Transfer.d.ts +12 -0
  423. package/dist/components/Transfer.js +10 -0
  424. package/dist/components/Transfer.mjs +1 -0
  425. package/dist/components/Tree.d.mts +18 -0
  426. package/dist/components/Tree.d.ts +18 -0
  427. package/dist/components/Tree.js +3 -3
  428. package/dist/components/Tree.mjs +1 -1
  429. package/dist/components/TreeMapChart.d.mts +15 -0
  430. package/dist/components/TreeMapChart.d.ts +15 -0
  431. package/dist/components/TreeMapChart.js +14 -0
  432. package/dist/components/TreeMapChart.mjs +5 -0
  433. package/dist/components/TreeSelect.d.mts +12 -0
  434. package/dist/components/TreeSelect.d.ts +12 -0
  435. package/dist/components/TreeSelect.js +10 -0
  436. package/dist/components/TreeSelect.mjs +1 -0
  437. package/dist/components/Upload.js +3 -3
  438. package/dist/components/Upload.mjs +2 -2
  439. package/dist/components/VirtualList.d.mts +14 -0
  440. package/dist/components/VirtualList.d.ts +14 -0
  441. package/dist/components/VirtualList.js +10 -0
  442. package/dist/components/VirtualList.mjs +1 -0
  443. package/dist/components/VirtualTable.d.mts +26 -0
  444. package/dist/components/VirtualTable.d.ts +26 -0
  445. package/dist/components/VirtualTable.js +16 -0
  446. package/dist/components/VirtualTable.mjs +1 -0
  447. package/dist/components/Watermark.d.mts +9 -0
  448. package/dist/components/Watermark.d.ts +9 -0
  449. package/dist/components/Watermark.js +10 -0
  450. package/dist/components/Watermark.mjs +1 -0
  451. package/dist/index.d.mts +85 -2
  452. package/dist/index.d.ts +85 -2
  453. package/dist/index.js +504 -181
  454. package/dist/index.mjs +223 -64
  455. package/package.json +2 -2
  456. package/dist/chunk-3M2IG6IN.mjs +0 -34
  457. package/dist/chunk-4Y7YH32A.mjs +0 -157
  458. package/dist/chunk-FPNT7FV5.mjs +0 -44
  459. package/dist/chunk-FSDZJD7M.js +0 -159
  460. package/dist/chunk-I5TCE5E7.js +0 -32
  461. package/dist/chunk-LIV33O73.mjs +0 -26
  462. package/dist/chunk-O3W3OZ6V.js +0 -37
  463. package/dist/chunk-OYCMGKQ7.js +0 -111
  464. package/dist/chunk-RPTLVIBF.mjs +0 -109
  465. package/dist/chunk-RYWGELJ7.js +0 -46
  466. package/dist/chunk-SSQOCZ6O.js +0 -36
  467. package/dist/chunk-UZ7SBFQV.mjs +0 -35
  468. package/dist/chunk-VEGBO77D.mjs +0 -20
  469. package/dist/{chunk-2DW3WFZI.mjs → chunk-2LUDQBVY.mjs} +2 -2
  470. package/dist/{chunk-JQNKI2ZZ.js → chunk-C443YA4U.js} +2 -2
  471. package/dist/{chunk-QGCQAJGL.mjs → chunk-DEQWHJLQ.mjs} +2 -2
  472. package/dist/{chunk-N4EMXCRQ.mjs → chunk-FXX3GD35.mjs} +1 -1
  473. package/dist/{chunk-GASFXURT.js → chunk-KQJYSG23.js} +2 -2
  474. package/dist/{chunk-NEP3CS6S.js → chunk-OE6WTZES.js} +2 -2
  475. package/dist/{chunk-SH6O6LDJ.mjs → chunk-QQDKQLHJ.mjs} +1 -1
  476. package/dist/{chunk-F4Q5QMX2.js → chunk-TVJZB7ZC.js} +1 -1
  477. package/dist/{chunk-SM7RDJFB.js → chunk-VILZFNR7.js} +2 -2
  478. package/dist/{chunk-W4TFISRK.js → chunk-WK5QJO57.js} +1 -1
  479. package/dist/{chunk-CYZLGYY4.mjs → chunk-XNMSECO4.mjs} +2 -2
  480. package/dist/{chunk-763M6U5U.mjs → chunk-ZDL3GE3Q.mjs} +2 -2
@@ -1,5 +1,5 @@
1
1
  import { useRef, useState, useCallback, useEffect, useMemo } from 'react';
2
- import { clampValue, formatPrecision, stepValue, isAtMin, isAtMax, classNames, getInputNumberWrapperClasses, getInputNumberStatusClasses, getInputNumberSizeClasses, getInputNumberFocusRingColor, getInputNumberInputClasses, getInputNumberSideButtonClasses, inputNumberMinusIconPathD, inputNumberPlusIconPathD, inputNumberControlsRightClasses, getInputNumberStepButtonClasses, inputNumberUpIconPathD, inputNumberDownIconPathD } from '@expcat/tigercat-core';
2
+ import { isAtMin, isAtMax, classNames, getInputNumberWrapperClasses, getInputNumberStatusClasses, getInputNumberSizeClasses, getInputNumberFocusRingColor, getInputNumberInputClasses, getInputNumberSideButtonClasses, inputNumberMinusIconPathD, inputNumberPlusIconPathD, inputNumberControlsRightClasses, getInputNumberStepButtonClasses, inputNumberUpIconPathD, inputNumberDownIconPathD, stepValue, clampValue, formatPrecision } from '@expcat/tigercat-core';
3
3
  import { jsxs, jsx } from 'react/jsx-runtime';
4
4
 
5
5
  // src/components/InputNumber.tsx
@@ -45,15 +45,12 @@ var InputNumber = ({
45
45
  },
46
46
  [formatter, precision]
47
47
  );
48
- const parseValue = useCallback(
49
- (str) => {
50
- if (str === "" || str === "-") return null;
51
- if (parser) return parser(str);
52
- const num = Number(str);
53
- return Number.isNaN(num) ? null : num;
54
- },
55
- [parser]
56
- );
48
+ const parseValue = (str) => {
49
+ if (str === "" || str === "-") return null;
50
+ if (parser) return parser(str);
51
+ const num = Number(str);
52
+ return Number.isNaN(num) ? null : num;
53
+ };
57
54
  useEffect(() => {
58
55
  if (!focused) {
59
56
  setDisplayValue(toDisplayValue(currentValue));
@@ -64,69 +61,54 @@ var InputNumber = ({
64
61
  inputRef.current.focus();
65
62
  }
66
63
  }, [autoFocus]);
67
- const commitValue = useCallback(
68
- (val) => {
69
- let finalVal = val;
70
- if (finalVal !== null) {
71
- finalVal = clampValue(finalVal, min, max);
72
- if (precision !== void 0) {
73
- finalVal = formatPrecision(finalVal, precision);
74
- }
75
- }
76
- if (!isControlled) {
77
- setInternalValue(finalVal);
64
+ const commitValue = (val) => {
65
+ let finalVal = val;
66
+ if (finalVal !== null) {
67
+ finalVal = clampValue(finalVal, min, max);
68
+ if (precision !== void 0) {
69
+ finalVal = formatPrecision(finalVal, precision);
78
70
  }
79
- onChange?.(finalVal);
80
- setDisplayValue(toDisplayValue(finalVal));
81
- },
82
- [min, max, precision, isControlled, onChange, toDisplayValue]
83
- );
84
- const handleStep = useCallback(
85
- (direction) => {
86
- if (disabled || readonly) return;
87
- const next = stepValue(currentValue, step, direction, min, max, precision);
88
- commitValue(next);
89
- },
90
- [currentValue, step, min, max, precision, disabled, readonly, commitValue]
91
- );
92
- const handleInput = useCallback((e) => {
71
+ }
72
+ if (!isControlled) {
73
+ setInternalValue(finalVal);
74
+ }
75
+ onChange?.(finalVal);
76
+ setDisplayValue(toDisplayValue(finalVal));
77
+ };
78
+ const handleStep = (direction) => {
79
+ if (disabled || readonly) return;
80
+ const next = stepValue(currentValue, step, direction, min, max, precision);
81
+ commitValue(next);
82
+ };
83
+ const handleInput = (e) => {
93
84
  setDisplayValue(e.target.value);
94
- }, []);
95
- const handleBlur = useCallback(
96
- (e) => {
97
- setFocused(false);
85
+ };
86
+ const handleBlur = (e) => {
87
+ setFocused(false);
88
+ const parsed = parseValue(displayValue);
89
+ commitValue(parsed);
90
+ onBlur?.(e);
91
+ };
92
+ const handleFocus = (e) => {
93
+ setFocused(true);
94
+ if (formatter && currentValue !== null) {
95
+ setDisplayValue(String(currentValue));
96
+ }
97
+ onFocus?.(e);
98
+ };
99
+ const handleKeyDown = (e) => {
100
+ if (!keyboard || disabled || readonly) return;
101
+ if (e.key === "ArrowUp") {
102
+ e.preventDefault();
103
+ handleStep("up");
104
+ } else if (e.key === "ArrowDown") {
105
+ e.preventDefault();
106
+ handleStep("down");
107
+ } else if (e.key === "Enter") {
98
108
  const parsed = parseValue(displayValue);
99
109
  commitValue(parsed);
100
- onBlur?.(e);
101
- },
102
- [displayValue, parseValue, commitValue, onBlur]
103
- );
104
- const handleFocus = useCallback(
105
- (e) => {
106
- setFocused(true);
107
- if (formatter && currentValue !== null) {
108
- setDisplayValue(String(currentValue));
109
- }
110
- onFocus?.(e);
111
- },
112
- [formatter, currentValue, onFocus]
113
- );
114
- const handleKeyDown = useCallback(
115
- (e) => {
116
- if (!keyboard || disabled || readonly) return;
117
- if (e.key === "ArrowUp") {
118
- e.preventDefault();
119
- handleStep("up");
120
- } else if (e.key === "ArrowDown") {
121
- e.preventDefault();
122
- handleStep("down");
123
- } else if (e.key === "Enter") {
124
- const parsed = parseValue(displayValue);
125
- commitValue(parsed);
126
- }
127
- },
128
- [keyboard, disabled, readonly, handleStep, parseValue, displayValue, commitValue]
129
- );
110
+ }
111
+ };
130
112
  const atMin = isAtMin(currentValue, min);
131
113
  const atMax = isAtMax(currentValue, max);
132
114
  const wrapperClasses = useMemo(
@@ -0,0 +1,148 @@
1
+ 'use strict';
2
+
3
+ var chunkDUWAV47E_js = require('./chunk-DUWAV47E.js');
4
+ var React = require('react');
5
+ var tigercatCore = require('@expcat/tigercat-core');
6
+ var jsxRuntime = require('react/jsx-runtime');
7
+
8
+ function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
9
+
10
+ var React__default = /*#__PURE__*/_interopDefault(React);
11
+
12
+ var GaugeChart = ({
13
+ width = 280,
14
+ height = 200,
15
+ padding = 24,
16
+ value,
17
+ min = 0,
18
+ max = 100,
19
+ startAngle = 135,
20
+ endAngle = 405,
21
+ arcWidth = 20,
22
+ showTicks = true,
23
+ tickCount = 5,
24
+ valueFormatter,
25
+ label,
26
+ segments,
27
+ trackColor = "var(--tiger-border,#e5e7eb)",
28
+ color = "var(--tiger-primary,#2563eb)",
29
+ title: chartTitle,
30
+ desc,
31
+ className
32
+ }) => {
33
+ const innerRect = React.useMemo(
34
+ () => tigercatCore.getChartInnerRect(width, height, padding),
35
+ [width, height, padding]
36
+ );
37
+ const radius = React.useMemo(
38
+ () => Math.min(innerRect.width, innerRect.height) / 2 - 4,
39
+ [innerRect.width, innerRect.height]
40
+ );
41
+ const cx = innerRect.width / 2;
42
+ const cy = innerRect.height / 2;
43
+ const needleAngle = React.useMemo(
44
+ () => tigercatCore.valueToGaugeAngle(value, min, max, startAngle, endAngle),
45
+ [value, min, max, startAngle, endAngle]
46
+ );
47
+ const ticks = React.useMemo(
48
+ () => showTicks ? tigercatCore.computeGaugeTicks(cx, cy, radius, min, max, startAngle, endAngle, tickCount) : [],
49
+ [showTicks, cx, cy, radius, min, max, startAngle, endAngle, tickCount]
50
+ );
51
+ const trackPath = tigercatCore.createGaugeArcPath(cx, cy, radius, startAngle, endAngle, arcWidth);
52
+ const valuePath = needleAngle > startAngle ? tigercatCore.createGaugeArcPath(cx, cy, radius, startAngle, needleAngle, arcWidth) : null;
53
+ const needlePath = tigercatCore.createGaugeNeedlePath(cx, cy, radius - arcWidth - 6, needleAngle);
54
+ const formattedValue = valueFormatter ? valueFormatter(value) : `${value}`;
55
+ return /* @__PURE__ */ jsxRuntime.jsxs(
56
+ chunkDUWAV47E_js.ChartCanvas,
57
+ {
58
+ width,
59
+ height,
60
+ padding,
61
+ title: chartTitle,
62
+ desc,
63
+ className: tigercatCore.classNames(className),
64
+ children: [
65
+ /* @__PURE__ */ jsxRuntime.jsx("path", { d: trackPath, fill: trackColor, strokeWidth: 0 }),
66
+ segments ? segments.map((seg, i) => {
67
+ const sStart = tigercatCore.valueToGaugeAngle(seg.range[0], min, max, startAngle, endAngle);
68
+ const sEnd = tigercatCore.valueToGaugeAngle(seg.range[1], min, max, startAngle, endAngle);
69
+ return /* @__PURE__ */ jsxRuntime.jsx(
70
+ "path",
71
+ {
72
+ d: tigercatCore.createGaugeArcPath(cx, cy, radius, sStart, sEnd, arcWidth),
73
+ fill: seg.color,
74
+ strokeWidth: 0
75
+ },
76
+ `seg-${i}`
77
+ );
78
+ }) : valuePath && /* @__PURE__ */ jsxRuntime.jsx(
79
+ "path",
80
+ {
81
+ d: valuePath,
82
+ fill: color,
83
+ strokeWidth: 0,
84
+ style: { transition: "all 0.3s ease-out" }
85
+ }
86
+ ),
87
+ ticks.map((tick, i) => /* @__PURE__ */ jsxRuntime.jsxs(React__default.default.Fragment, { children: [
88
+ /* @__PURE__ */ jsxRuntime.jsx(
89
+ "line",
90
+ {
91
+ x1: tick.x1,
92
+ y1: tick.y1,
93
+ x2: tick.x2,
94
+ y2: tick.y2,
95
+ stroke: "var(--tiger-text-secondary,#6b7280)",
96
+ strokeWidth: 1
97
+ }
98
+ ),
99
+ /* @__PURE__ */ jsxRuntime.jsx(
100
+ "text",
101
+ {
102
+ x: tick.x2 + (tick.x2 - tick.x1) * 1.5,
103
+ y: tick.y2 + (tick.y2 - tick.y1) * 1.5,
104
+ className: tigercatCore.chartAxisTickTextClasses,
105
+ textAnchor: "middle",
106
+ dominantBaseline: "middle",
107
+ style: { fontSize: "10px" },
108
+ children: tick.label
109
+ }
110
+ )
111
+ ] }, `tick-${i}`)),
112
+ /* @__PURE__ */ jsxRuntime.jsx(
113
+ "path",
114
+ {
115
+ d: needlePath,
116
+ fill: "var(--tiger-text,#374151)",
117
+ style: { transition: "all 0.3s ease-out" }
118
+ }
119
+ ),
120
+ /* @__PURE__ */ jsxRuntime.jsx("circle", { cx, cy, r: 5, fill: "var(--tiger-text,#374151)" }),
121
+ /* @__PURE__ */ jsxRuntime.jsx(
122
+ "text",
123
+ {
124
+ x: cx,
125
+ y: cy + radius * 0.35,
126
+ className: "fill-[color:var(--tiger-text,#374151)] text-lg font-semibold",
127
+ textAnchor: "middle",
128
+ dominantBaseline: "middle",
129
+ children: formattedValue
130
+ }
131
+ ),
132
+ label && /* @__PURE__ */ jsxRuntime.jsx(
133
+ "text",
134
+ {
135
+ x: cx,
136
+ y: cy + radius * 0.35 + 20,
137
+ className: tigercatCore.chartAxisTickTextClasses,
138
+ textAnchor: "middle",
139
+ dominantBaseline: "middle",
140
+ children: label
141
+ }
142
+ )
143
+ ]
144
+ }
145
+ );
146
+ };
147
+
148
+ exports.GaugeChart = GaugeChart;
@@ -1,4 +1,4 @@
1
- import { ImagePreview } from './chunk-5CLXOFRZ.mjs';
1
+ import { ImagePreview } from './chunk-HLJQZUIY.mjs';
2
2
  import { createContext, useState, useRef, useCallback, useMemo } from 'react';
3
3
  import { jsx, jsxs } from 'react/jsx-runtime';
4
4
 
@@ -38,10 +38,10 @@ var ImageGroup = ({
38
38
  preview && /* @__PURE__ */ jsx(
39
39
  ImagePreview,
40
40
  {
41
- visible: previewVisible,
41
+ open: previewVisible,
42
42
  images: imagesRef.current,
43
43
  currentIndex: previewIndex,
44
- onVisibleChange: (val) => {
44
+ onOpenChange: (val) => {
45
45
  setPreviewVisible(val);
46
46
  if (!val) onPreviewVisibleChange?.(false);
47
47
  },
@@ -25,17 +25,22 @@ var Form = React.forwardRef(
25
25
  inlineMessage = true,
26
26
  showRequiredAsterisk = true,
27
27
  disabled = false,
28
+ loading = false,
28
29
  children,
29
30
  onSubmit,
30
31
  onValidate,
31
32
  onChange,
32
33
  className,
34
+ fieldDependencies,
35
+ undoable = false,
36
+ maxHistorySize = 50,
33
37
  ...props
34
38
  }, ref) => {
35
39
  const [errors, setErrors] = React.useState([]);
36
40
  const [formValues, setFormValues] = React.useState(model);
37
41
  const fieldRulesRef = React__default.default.useRef({});
38
42
  const formValuesRef = React__default.default.useRef(model);
43
+ const [historyState, setHistoryState] = React.useState(() => tigercatCore.createFormHistory(model, maxHistorySize));
39
44
  React__default.default.useEffect(() => {
40
45
  setFormValues(model);
41
46
  }, [model]);
@@ -80,24 +85,29 @@ var Form = React.forwardRef(
80
85
  const validateField = React.useCallback(
81
86
  async (fieldName, rulesOverride, trigger) => {
82
87
  const fieldRules = resolveFieldRules(fieldName, rulesOverride);
83
- if (!fieldRules) {
84
- return;
88
+ if (fieldRules) {
89
+ const error = await runFieldValidation(fieldName, rulesOverride, trigger);
90
+ setErrors((prevErrors) => {
91
+ const existing = prevErrors.find((e) => e.field === fieldName);
92
+ const existingMessage = existing?.message ?? null;
93
+ if (!error && !existingMessage) return prevErrors;
94
+ if (error && error === existingMessage) return prevErrors;
95
+ const filtered = prevErrors.filter((e) => e.field !== fieldName);
96
+ if (error) {
97
+ return [...filtered, { field: fieldName, message: error }];
98
+ }
99
+ return filtered;
100
+ });
101
+ onValidate?.(fieldName, !error, error);
85
102
  }
86
- const error = await runFieldValidation(fieldName, rulesOverride, trigger);
87
- setErrors((prevErrors) => {
88
- const existing = prevErrors.find((e) => e.field === fieldName);
89
- const existingMessage = existing?.message ?? null;
90
- if (!error && !existingMessage) return prevErrors;
91
- if (error && error === existingMessage) return prevErrors;
92
- const filtered = prevErrors.filter((e) => e.field !== fieldName);
93
- if (error) {
94
- return [...filtered, { field: fieldName, message: error }];
103
+ if (fieldDependencies) {
104
+ const dependents = tigercatCore.getDependentFields(fieldName, fieldDependencies);
105
+ for (const dep of dependents) {
106
+ await validateField(dep);
95
107
  }
96
- return filtered;
97
- });
98
- onValidate?.(fieldName, !error, error);
108
+ }
99
109
  },
100
- [resolveFieldRules, runFieldValidation, onValidate]
110
+ [resolveFieldRules, runFieldValidation, onValidate, fieldDependencies]
101
111
  );
102
112
  const runValidation = React.useCallback(async () => {
103
113
  const effectiveRules = getEffectiveRules();
@@ -152,6 +162,29 @@ var Form = React.forwardRef(
152
162
  clearValidate();
153
163
  setFormValues(model);
154
164
  }, [model, clearValidate]);
165
+ const addField = React.useCallback(
166
+ (fieldName, defaultValue) => {
167
+ if (!fieldName) return;
168
+ setFormValues((prev) => {
169
+ const next = { ...prev, [fieldName]: defaultValue ?? null };
170
+ onChange?.(next);
171
+ return next;
172
+ });
173
+ },
174
+ [onChange]
175
+ );
176
+ const removeField = React.useCallback(
177
+ (fieldName) => {
178
+ if (!fieldName) return;
179
+ setFormValues((prev) => {
180
+ const { [fieldName]: _, ...next } = prev;
181
+ onChange?.(next);
182
+ return next;
183
+ });
184
+ clearValidate(fieldName);
185
+ },
186
+ [onChange, clearValidate]
187
+ );
155
188
  const updateValue = React.useCallback(
156
189
  (fieldName, value) => {
157
190
  const setValueByPath = (target, path, nextValue) => {
@@ -186,13 +219,44 @@ var Form = React.forwardRef(
186
219
  },
187
220
  [onChange]
188
221
  );
222
+ const snapshotHistory = React.useCallback(() => {
223
+ if (!undoable) return;
224
+ setHistoryState((prev) => tigercatCore.pushFormHistory(prev, formValuesRef.current));
225
+ }, [undoable]);
226
+ const undo = React.useCallback(() => {
227
+ if (!undoable) return;
228
+ setHistoryState((prev) => {
229
+ const result = tigercatCore.undoFormHistory(prev);
230
+ if (result) {
231
+ setFormValues(result.present);
232
+ formValuesRef.current = result.present;
233
+ onChange?.(result.present);
234
+ return result;
235
+ }
236
+ return prev;
237
+ });
238
+ }, [undoable, onChange]);
239
+ const redo = React.useCallback(() => {
240
+ if (!undoable) return;
241
+ setHistoryState((prev) => {
242
+ const result = tigercatCore.redoFormHistory(prev);
243
+ if (result) {
244
+ setFormValues(result.present);
245
+ formValuesRef.current = result.present;
246
+ onChange?.(result.present);
247
+ return result;
248
+ }
249
+ return prev;
250
+ });
251
+ }, [undoable, onChange]);
189
252
  const handleSubmit = React.useCallback(
190
253
  async (event) => {
191
254
  event.preventDefault();
255
+ if (loading) return;
192
256
  const result = await runValidation();
193
257
  onSubmit?.({ ...result, values: formValuesRef.current });
194
258
  },
195
- [runValidation, onSubmit]
259
+ [runValidation, onSubmit, loading]
196
260
  );
197
261
  React.useImperativeHandle(
198
262
  ref,
@@ -201,9 +265,28 @@ var Form = React.forwardRef(
201
265
  validateFields,
202
266
  validateField,
203
267
  clearValidate,
204
- resetFields
268
+ resetFields,
269
+ addField,
270
+ removeField,
271
+ undo,
272
+ redo,
273
+ snapshotHistory,
274
+ canUndo: tigercatCore.canUndo(historyState),
275
+ canRedo: tigercatCore.canRedo(historyState)
205
276
  }),
206
- [validate, validateFields, validateField, clearValidate, resetFields]
277
+ [
278
+ validate,
279
+ validateFields,
280
+ validateField,
281
+ clearValidate,
282
+ resetFields,
283
+ addField,
284
+ removeField,
285
+ undo,
286
+ redo,
287
+ snapshotHistory,
288
+ historyState
289
+ ]
207
290
  );
208
291
  const contextValue = React.useMemo(
209
292
  () => ({
@@ -216,6 +299,7 @@ var Form = React.forwardRef(
216
299
  inlineMessage,
217
300
  showRequiredAsterisk,
218
301
  disabled,
302
+ loading,
219
303
  errors,
220
304
  registerFieldRules,
221
305
  validateField,
@@ -232,6 +316,7 @@ var Form = React.forwardRef(
232
316
  inlineMessage,
233
317
  showRequiredAsterisk,
234
318
  disabled,
319
+ loading,
235
320
  errors,
236
321
  registerFieldRules,
237
322
  validateField,
@@ -243,6 +328,7 @@ var Form = React.forwardRef(
243
328
  "tiger-form",
244
329
  `tiger-form--label-${labelPosition}`,
245
330
  disabled && "tiger-form--disabled",
331
+ loading && "tiger-form--loading",
246
332
  className
247
333
  );
248
334
  return /* @__PURE__ */ jsxRuntime.jsx(FormContext.Provider, { value: contextValue, children: /* @__PURE__ */ jsxRuntime.jsx("form", { className: formClasses, onSubmit: handleSubmit, ...props, children }) });
@@ -0,0 +1,58 @@
1
+ import { useMemo } from 'react';
2
+ import { generateQRMatrix, classNames, qrcodeContainerClasses, qrcodeOverlayClasses, qrcodeExpiredTextClasses, qrcodeRefreshClasses } from '@expcat/tigercat-core';
3
+ import { jsxs, jsx } from 'react/jsx-runtime';
4
+
5
+ // src/components/QRCode.tsx
6
+ var QRCode = ({
7
+ value,
8
+ size = 128,
9
+ color = "#000000",
10
+ bgColor = "#ffffff",
11
+ level: _level = "M",
12
+ status = "active",
13
+ onRefresh,
14
+ className
15
+ }) => {
16
+ const matrix = useMemo(() => generateQRMatrix(value), [value]);
17
+ const moduleSize = useMemo(() => size / matrix.length, [size, matrix.length]);
18
+ const containerClass = classNames(qrcodeContainerClasses, className);
19
+ return /* @__PURE__ */ jsxs("div", { className: containerClass, style: { width: size, height: size }, children: [
20
+ /* @__PURE__ */ jsxs(
21
+ "svg",
22
+ {
23
+ width: size,
24
+ height: size,
25
+ viewBox: `0 0 ${size} ${size}`,
26
+ xmlns: "http://www.w3.org/2000/svg",
27
+ role: "img",
28
+ "aria-label": "QR Code",
29
+ children: [
30
+ /* @__PURE__ */ jsx("rect", { width: size, height: size, fill: bgColor }),
31
+ matrix.flatMap(
32
+ (row, r) => row.map(
33
+ (cell, c) => cell ? /* @__PURE__ */ jsx(
34
+ "rect",
35
+ {
36
+ x: c * moduleSize,
37
+ y: r * moduleSize,
38
+ width: moduleSize,
39
+ height: moduleSize,
40
+ fill: color
41
+ },
42
+ `${r}-${c}`
43
+ ) : null
44
+ )
45
+ )
46
+ ]
47
+ }
48
+ ),
49
+ status === "expired" && /* @__PURE__ */ jsxs("div", { className: qrcodeOverlayClasses, children: [
50
+ /* @__PURE__ */ jsx("span", { className: qrcodeExpiredTextClasses, children: "QR code expired" }),
51
+ /* @__PURE__ */ jsx("span", { className: qrcodeRefreshClasses, onClick: onRefresh, children: "Refresh" })
52
+ ] }),
53
+ status === "loading" && /* @__PURE__ */ jsx("div", { className: qrcodeOverlayClasses, children: /* @__PURE__ */ jsx("span", { className: "text-sm text-gray-500", children: "Loading..." }) })
54
+ ] });
55
+ };
56
+ var QRCode_default = QRCode;
57
+
58
+ export { QRCode, QRCode_default };
@@ -0,0 +1,125 @@
1
+ 'use strict';
2
+
3
+ var react = require('react');
4
+ var tigercatCore = require('@expcat/tigercat-core');
5
+ var jsxRuntime = require('react/jsx-runtime');
6
+
7
+ // src/components/ColorPicker.tsx
8
+ var ColorPicker = ({
9
+ value = "#2563eb",
10
+ disabled = false,
11
+ size = "md",
12
+ showAlpha: _showAlpha = false,
13
+ format: _format = "hex",
14
+ presets,
15
+ className,
16
+ onChange
17
+ }) => {
18
+ const [isOpen, setIsOpen] = react.useState(false);
19
+ const [inputValue, setInputValue] = react.useState(value);
20
+ const containerRef = react.useRef(null);
21
+ const hsv = react.useMemo(() => {
22
+ const rgb = tigercatCore.hexToRgb(value);
23
+ return tigercatCore.rgbToHsv(rgb.r, rgb.g, rgb.b);
24
+ }, [value]);
25
+ react.useEffect(() => {
26
+ setInputValue(value);
27
+ }, [value]);
28
+ function togglePanel() {
29
+ if (disabled) return;
30
+ setIsOpen((v) => !v);
31
+ }
32
+ function handleHueChange(e) {
33
+ const hue = Number(e.target.value);
34
+ const { r, g, b } = tigercatCore.hsvToRgb(hue, hsv.s, hsv.v);
35
+ const hex = tigercatCore.rgbToHex(r, g, b);
36
+ onChange?.(hex);
37
+ }
38
+ function handleInputChange(e) {
39
+ const val = e.target.value;
40
+ setInputValue(val);
41
+ if (tigercatCore.isValidHex(val)) {
42
+ const hex = val.startsWith("#") ? val : `#${val}`;
43
+ onChange?.(hex);
44
+ }
45
+ }
46
+ function handlePresetClick(color) {
47
+ onChange?.(color);
48
+ }
49
+ react.useEffect(() => {
50
+ if (!isOpen) return;
51
+ function handleClickOutside(e) {
52
+ if (containerRef.current && !containerRef.current.contains(e.target)) {
53
+ setIsOpen(false);
54
+ }
55
+ }
56
+ document.addEventListener("click", handleClickOutside);
57
+ return () => document.removeEventListener("click", handleClickOutside);
58
+ }, [isOpen]);
59
+ return /* @__PURE__ */ jsxRuntime.jsxs("div", { ref: containerRef, className: tigercatCore.classNames(tigercatCore.colorPickerBaseClasses, className), children: [
60
+ /* @__PURE__ */ jsxRuntime.jsx(
61
+ "div",
62
+ {
63
+ className: tigercatCore.getColorPickerTriggerClasses(size, disabled),
64
+ style: { backgroundColor: value },
65
+ role: "button",
66
+ "aria-label": "Pick color",
67
+ tabIndex: 0,
68
+ onClick: togglePanel
69
+ }
70
+ ),
71
+ isOpen && /* @__PURE__ */ jsxRuntime.jsxs("div", { className: tigercatCore.colorPickerPanelClasses, children: [
72
+ /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "mb-2", children: [
73
+ /* @__PURE__ */ jsxRuntime.jsx("label", { className: "block text-xs text-[var(--tiger-text-muted,#6b7280)] mb-1", children: "Hue" }),
74
+ /* @__PURE__ */ jsxRuntime.jsx(
75
+ "input",
76
+ {
77
+ type: "range",
78
+ min: 0,
79
+ max: 360,
80
+ value: hsv.h,
81
+ className: "w-full h-2 rounded-full cursor-pointer accent-[var(--tiger-primary,#2563eb)]",
82
+ "aria-label": "Hue",
83
+ onChange: handleHueChange
84
+ }
85
+ )
86
+ ] }),
87
+ /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "mb-2", children: [
88
+ /* @__PURE__ */ jsxRuntime.jsx("label", { className: "block text-xs text-[var(--tiger-text-muted,#6b7280)] mb-1", children: "Hex" }),
89
+ /* @__PURE__ */ jsxRuntime.jsx(
90
+ "input",
91
+ {
92
+ type: "text",
93
+ className: tigercatCore.colorPickerInputClasses,
94
+ value: inputValue,
95
+ "aria-label": "Color value",
96
+ onChange: handleInputChange
97
+ }
98
+ )
99
+ ] }),
100
+ /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "flex items-center gap-2 mb-2", children: [
101
+ /* @__PURE__ */ jsxRuntime.jsx(
102
+ "div",
103
+ {
104
+ className: "w-8 h-8 rounded border border-[var(--tiger-border,#d1d5db)]",
105
+ style: { backgroundColor: value },
106
+ "aria-label": "Color preview"
107
+ }
108
+ ),
109
+ /* @__PURE__ */ jsxRuntime.jsx("span", { className: "text-xs font-mono text-[var(--tiger-text,#111827)]", children: value })
110
+ ] }),
111
+ presets && presets.length > 0 && /* @__PURE__ */ jsxRuntime.jsx("div", { className: "flex flex-wrap gap-1", children: presets.map((color) => /* @__PURE__ */ jsxRuntime.jsx(
112
+ "div",
113
+ {
114
+ className: tigercatCore.colorPickerPresetClasses,
115
+ style: { backgroundColor: color },
116
+ "aria-label": `Select ${color}`,
117
+ onClick: () => handlePresetClick(color)
118
+ },
119
+ color
120
+ )) })
121
+ ] })
122
+ ] });
123
+ };
124
+
125
+ exports.ColorPicker = ColorPicker;