@expcat/tigercat-react 0.4.3 → 1.0.0

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-S4GNTA7V.mjs → chunk-2H43QM4B.mjs} +1 -1
  3. package/dist/{chunk-WGRYO5HX.mjs → chunk-2UQC3WOI.mjs} +63 -49
  4. package/dist/{chunk-V5NIFF2F.mjs → chunk-2WBPUW75.mjs} +7 -7
  5. package/dist/{chunk-QL6UEG3U.js → chunk-2XOFRGY6.js} +16 -3
  6. package/dist/chunk-333325LH.mjs +87 -0
  7. package/dist/{chunk-IGE44BIS.mjs → chunk-34DLDOGP.mjs} +105 -19
  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-QM4GOQDT.js → chunk-4QJZT6QK.js} +44 -6
  17. package/dist/chunk-4QQZ5H4V.mjs +213 -0
  18. package/dist/{chunk-QFYS5QIZ.mjs → chunk-5BBZBI2V.mjs} +3 -3
  19. package/dist/chunk-5CGXFQND.mjs +100 -0
  20. package/dist/{chunk-LXX2ZDJN.js → chunk-5CQEXJF2.js} +9 -9
  21. package/dist/chunk-5EVHVZG5.js +119 -0
  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-LLHUBM6E.mjs → chunk-6SDLSIAO.mjs} +4 -4
  29. package/dist/chunk-73BP3WQN.mjs +210 -0
  30. package/dist/{chunk-77PE7OFK.mjs → chunk-7MASYF4S.mjs} +1 -1
  31. package/dist/{chunk-VCNZEQEB.mjs → chunk-7QZ4XT2P.mjs} +6 -5
  32. package/dist/chunk-7YLVAZJQ.mjs +47 -0
  33. package/dist/{chunk-NV3JUZ3N.js → chunk-AGR3FM3V.js} +4 -4
  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-AYDPWKSW.mjs +186 -0
  39. package/dist/chunk-B53R2U2R.mjs +86 -0
  40. package/dist/chunk-BALJCZ62.mjs +147 -0
  41. package/dist/{chunk-F24IF2QL.js → chunk-BCNKTT5C.js} +14 -9
  42. package/dist/{chunk-JNLX47UL.mjs → chunk-BJ2GUKPU.mjs} +74 -36
  43. package/dist/chunk-BKYE77F2.js +171 -0
  44. package/dist/chunk-BR5OSUZT.mjs +55 -0
  45. package/dist/chunk-BZ3AXFLG.js +149 -0
  46. package/dist/{chunk-SOC74QA2.js → chunk-C6WJ4GQW.js} +8 -8
  47. package/dist/{chunk-LXQOQJMU.js → chunk-CDT3P2ZN.js} +5 -12
  48. package/dist/chunk-CHH7DWIO.js +121 -0
  49. package/dist/{chunk-3T7L3MHX.js → chunk-CKFE2B36.js} +76 -38
  50. package/dist/{chunk-QNRAM3CM.js → chunk-CMGI5WHZ.js} +3 -2
  51. package/dist/chunk-CQGAZ5JQ.js +61 -0
  52. package/dist/chunk-CRSMECWE.mjs +33 -0
  53. package/dist/{chunk-KAWE5LQZ.js → chunk-D6BHFGTN.js} +29 -0
  54. package/dist/chunk-DAR2BMMV.js +150 -0
  55. package/dist/{chunk-OCVQ3LOT.mjs → chunk-DKT2EYVM.mjs} +3 -5
  56. package/dist/{chunk-EHYSER2Z.js → chunk-DR2DFFNQ.js} +6 -6
  57. package/dist/chunk-DZGDCRBH.mjs +30 -0
  58. package/dist/chunk-EEF26RBA.mjs +48 -0
  59. package/dist/{chunk-PJCY45UP.mjs → chunk-EHU3J4B2.mjs} +1 -1
  60. package/dist/{chunk-RKB2VUQO.js → chunk-EOYJLBFD.js} +24 -21
  61. package/dist/{chunk-DTQZPZSJ.mjs → chunk-EPN7QWP6.mjs} +16 -2
  62. package/dist/{chunk-M46L73HR.js → chunk-ET5YJELZ.js} +14 -14
  63. package/dist/{chunk-NTODO3Q3.mjs → chunk-EV6KRX6F.mjs} +38 -8
  64. package/dist/{chunk-GB5G2CJY.js → chunk-F2OF6XZ6.js} +36 -6
  65. package/dist/chunk-F6KHZNRS.js +32 -0
  66. package/dist/{chunk-URM7QDHH.js → chunk-F7H4ALKN.js} +2 -2
  67. package/dist/{chunk-RGFSY3S2.mjs → chunk-FPURO6QB.mjs} +16 -3
  68. package/dist/{chunk-FMF2G6BJ.js → chunk-FRHGRKKT.js} +2 -2
  69. package/dist/{chunk-LL6B4BHF.mjs → chunk-FT6TEMUF.mjs} +3 -3
  70. package/dist/chunk-GBTKAKUD.mjs +300 -0
  71. package/dist/chunk-GOUMB34F.mjs +168 -0
  72. package/dist/chunk-H5CAIMVL.js +45 -0
  73. package/dist/chunk-HADBETZG.js +94 -0
  74. package/dist/{chunk-6W6CRBBG.mjs → chunk-HCZA4LV6.mjs} +8 -5
  75. package/dist/{chunk-5CLXOFRZ.mjs → chunk-HLJQZUIY.mjs} +11 -10
  76. package/dist/chunk-HLS4CHWX.mjs +29 -0
  77. package/dist/{chunk-MTL2QUM3.mjs → chunk-HSHVLIEL.mjs} +2 -2
  78. package/dist/{chunk-SW4I4X6E.mjs → chunk-HUCBHFSL.mjs} +24 -21
  79. package/dist/{chunk-Q57BYUUW.js → chunk-HWWNBCFB.js} +39 -8
  80. package/dist/{chunk-MDZDPGRK.mjs → chunk-HZ5Z5Y2J.mjs} +29 -10
  81. package/dist/chunk-HZHFFVP7.mjs +63 -0
  82. package/dist/chunk-I4SKKEU3.js +151 -0
  83. package/dist/{chunk-RCNTRSUA.mjs → chunk-INBSKSZG.mjs} +51 -69
  84. package/dist/chunk-IOHPB4CF.js +148 -0
  85. package/dist/{chunk-QIJG42YQ.mjs → chunk-IPLK4AIE.mjs} +3 -3
  86. package/dist/{chunk-XWRJVNB6.js → chunk-IWP22YTF.js} +104 -18
  87. package/dist/{chunk-NJCKTIWB.mjs → chunk-IWTY32AW.mjs} +5 -5
  88. package/dist/{chunk-ZBVFM3GJ.js → chunk-J23B66DJ.js} +152 -15
  89. package/dist/{chunk-DQNA57CA.js → chunk-JLM4LBUS.js} +5 -12
  90. package/dist/{chunk-TJFS44SH.js → chunk-JLRRXRZO.js} +2 -4
  91. package/dist/chunk-JR7L67Q3.mjs +186 -0
  92. package/dist/{chunk-GNMOOYHG.js → chunk-KNBNE74O.js} +11 -10
  93. package/dist/chunk-L6WOLPV7.mjs +123 -0
  94. package/dist/chunk-LODDAS62.js +173 -0
  95. package/dist/{chunk-IP3MAJSH.mjs → chunk-MQ5ZP5RW.mjs} +5 -12
  96. package/dist/{chunk-KMTERPME.mjs → chunk-MSHCPJIJ.mjs} +1 -1
  97. package/dist/chunk-N66WEQ6M.js +240 -0
  98. package/dist/{chunk-TDRINUMH.js → chunk-NZNSUKPT.js} +29 -10
  99. package/dist/{chunk-EFLIFXZH.js → chunk-P3XVLJYD.js} +15 -1
  100. package/dist/chunk-P6E3DILH.mjs +51 -0
  101. package/dist/{chunk-HPXLUJFJ.mjs → chunk-PN33UCWB.mjs} +3 -5
  102. package/dist/chunk-PNAWOJ32.js +54 -0
  103. package/dist/{chunk-72MWKUBC.js → chunk-PUYT62KC.js} +17 -4
  104. package/dist/chunk-Q4JMAQXJ.js +41 -0
  105. package/dist/chunk-QBZODEIG.js +49 -0
  106. package/dist/chunk-QHG7KJH6.js +302 -0
  107. package/dist/chunk-QIXQYLH5.js +44 -0
  108. package/dist/chunk-QNFSZYTZ.js +188 -0
  109. package/dist/chunk-QO3GGQAV.mjs +148 -0
  110. package/dist/{chunk-RGZYYVQF.mjs → chunk-QPGL4YEO.mjs} +39 -11
  111. package/dist/{chunk-6IH5QPTR.mjs → chunk-QPOH6SOO.mjs} +44 -6
  112. package/dist/chunk-QVZTZHCJ.mjs +148 -0
  113. package/dist/{chunk-C7UKFKVY.js → chunk-QYGBT4NL.js} +40 -12
  114. package/dist/chunk-R5P72RIT.js +180 -0
  115. package/dist/chunk-R5XY4EQL.js +56 -0
  116. package/dist/chunk-RRJTIKU6.mjs +238 -0
  117. package/dist/{chunk-KBTFBEPE.mjs → chunk-RU6YS4LZ.mjs} +153 -16
  118. package/dist/{chunk-ZFHTSHXS.mjs → chunk-RUROWRB5.mjs} +30 -1
  119. package/dist/{chunk-SAZ6V6DX.js → chunk-RVCUNEBU.js} +2 -4
  120. package/dist/{chunk-HB2UYJBY.js → chunk-RYW4CV7U.js} +61 -47
  121. package/dist/chunk-S5Y6UHAK.mjs +116 -0
  122. package/dist/{chunk-YV6Y7C43.js → chunk-SDWJSALH.js} +8 -3
  123. package/dist/chunk-SJ5GT7Y4.mjs +58 -0
  124. package/dist/chunk-SKJXVYYF.js +188 -0
  125. package/dist/chunk-SQK2CPSV.mjs +59 -0
  126. package/dist/{chunk-XKDWDANG.js → chunk-SULHTYSV.js} +6 -6
  127. package/dist/chunk-SVASEF6K.js +125 -0
  128. package/dist/chunk-T5FAKJ6C.mjs +49 -0
  129. package/dist/chunk-T6KZ73VM.js +198 -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-VUD4BU4K.mjs +192 -0
  149. package/dist/{chunk-XWNVBCJA.js → chunk-VWMVWZMD.js} +13 -13
  150. package/dist/{chunk-JWFEJ4XG.js → chunk-WGPUGPYE.js} +2 -2
  151. package/dist/chunk-WIWTY74F.mjs +44 -0
  152. package/dist/chunk-WNLUUD5N.mjs +179 -0
  153. package/dist/{chunk-VCOBBJLP.js → chunk-WVVXZKNI.js} +5 -4
  154. package/dist/chunk-XEYP62CR.js +194 -0
  155. package/dist/chunk-XFJ5Q5PF.mjs +30 -0
  156. package/dist/chunk-XODGTE2Y.js +61 -0
  157. package/dist/chunk-Y3NDP56G.mjs +174 -0
  158. package/dist/chunk-YID7J6ZK.js +37 -0
  159. package/dist/chunk-YLZEOXFS.mjs +116 -0
  160. package/dist/chunk-YPHOVEVU.mjs +118 -0
  161. package/dist/chunk-YXWRSEP5.mjs +286 -0
  162. package/dist/chunk-Z6CRXABX.js +88 -0
  163. package/dist/chunk-ZCBKAOAX.mjs +40 -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
@@ -0,0 +1,37 @@
1
+ 'use strict';
2
+
3
+ var chunkHQ3QOT7H_js = require('./chunk-HQ3QOT7H.js');
4
+ var react = require('react');
5
+ var tigercatCore = require('@expcat/tigercat-core');
6
+ var jsxRuntime = require('react/jsx-runtime');
7
+
8
+ var Result = ({
9
+ status = "info",
10
+ title,
11
+ subTitle,
12
+ icon,
13
+ extra,
14
+ className,
15
+ children,
16
+ ...props
17
+ }) => {
18
+ const colors = react.useMemo(() => tigercatCore.getResultColorScheme(status), [status]);
19
+ const iconPath = react.useMemo(() => tigercatCore.getResultIconPath(status), [status]);
20
+ const httpLabel = react.useMemo(() => tigercatCore.getResultHttpLabel(status), [status]);
21
+ const wrapperClasses = react.useMemo(() => tigercatCore.classNames(tigercatCore.resultBaseClasses, className), [className]);
22
+ const iconContainerCls = react.useMemo(
23
+ () => tigercatCore.classNames(tigercatCore.resultIconContainerBaseClasses, colors.iconBg),
24
+ [colors]
25
+ );
26
+ const iconSvgCls = react.useMemo(() => tigercatCore.classNames(tigercatCore.resultIconClasses, colors.iconColor), [colors]);
27
+ const titleCls = react.useMemo(() => tigercatCore.classNames(tigercatCore.resultTitleClasses, colors.titleColor), [colors]);
28
+ return /* @__PURE__ */ jsxRuntime.jsxs("div", { className: wrapperClasses, role: "status", ...props, children: [
29
+ /* @__PURE__ */ jsxRuntime.jsx("div", { className: iconContainerCls, children: icon !== void 0 ? icon : httpLabel ? /* @__PURE__ */ jsxRuntime.jsx("span", { className: tigercatCore.classNames("text-5xl font-bold", colors.iconColor), children: httpLabel }) : /* @__PURE__ */ jsxRuntime.jsx(chunkHQ3QOT7H_js.StatusIcon, { path: iconPath, className: iconSvgCls }) }),
30
+ title && /* @__PURE__ */ jsxRuntime.jsx("div", { className: titleCls, children: title }),
31
+ subTitle && /* @__PURE__ */ jsxRuntime.jsx("div", { className: tigercatCore.resultSubTitleClasses, children: subTitle }),
32
+ extra && /* @__PURE__ */ jsxRuntime.jsx("div", { className: tigercatCore.resultExtraClasses, children: extra }),
33
+ children && /* @__PURE__ */ jsxRuntime.jsx("div", { className: "mt-6 w-full", children })
34
+ ] });
35
+ };
36
+
37
+ exports.Result = Result;
@@ -0,0 +1,116 @@
1
+ import React, { useState, useRef, useMemo, useCallback } from 'react';
2
+ import { countLines, generateLineNumbers, getCodeEditorContainerClasses, handleTabKey, getLineNumberClasses, classNames, codeEditorHighlightClasses, codeEditorTextareaClasses, tokenizeLine, getTokenClasses } from '@expcat/tigercat-core';
3
+ import { jsx, jsxs } from 'react/jsx-runtime';
4
+
5
+ // src/components/CodeEditor.tsx
6
+ var CodeEditor = ({
7
+ value: controlledValue,
8
+ defaultValue = "",
9
+ language = "plain",
10
+ theme = "light",
11
+ readOnly = false,
12
+ lineNumbers = true,
13
+ tabSize = 2,
14
+ placeholder,
15
+ wordWrap = false,
16
+ minLines = 3,
17
+ maxLines = 0,
18
+ disabled = false,
19
+ className,
20
+ style,
21
+ onChange
22
+ }) => {
23
+ const [internalValue, setInternalValue] = useState(defaultValue);
24
+ const textareaRef = useRef(null);
25
+ const code = controlledValue !== void 0 ? controlledValue : internalValue;
26
+ const lines = useMemo(() => code.split("\n"), [code]);
27
+ const lineCount = useMemo(() => countLines(code), [code]);
28
+ const lineNums = useMemo(() => generateLineNumbers(lineCount), [lineCount]);
29
+ const containerClasses = useMemo(
30
+ () => getCodeEditorContainerClasses(theme, disabled, className),
31
+ [theme, disabled, className]
32
+ );
33
+ const containerStyle = useMemo(() => {
34
+ const lineHeight = 1.625;
35
+ const s = { ...style };
36
+ if (minLines > 0) s.minHeight = `${minLines * lineHeight + 1.5}rem`;
37
+ if (maxLines > 0) s.maxHeight = `${maxLines * lineHeight + 1.5}rem`;
38
+ return s;
39
+ }, [minLines, maxLines, style]);
40
+ const handleInput = useCallback(
41
+ (e) => {
42
+ const val = e.target.value;
43
+ setInternalValue(val);
44
+ onChange?.(val);
45
+ },
46
+ [onChange]
47
+ );
48
+ const handleKeyDown = useCallback(
49
+ (e) => {
50
+ if (e.key === "Tab") {
51
+ e.preventDefault();
52
+ const ta = textareaRef.current;
53
+ if (!ta) return;
54
+ const result = handleTabKey(ta.value, ta.selectionStart, ta.selectionEnd, tabSize);
55
+ setInternalValue(result.value);
56
+ onChange?.(result.value);
57
+ requestAnimationFrame(() => {
58
+ ta.selectionStart = result.selectionStart;
59
+ ta.selectionEnd = result.selectionStart;
60
+ });
61
+ }
62
+ },
63
+ [tabSize, onChange]
64
+ );
65
+ const wrapClass = wordWrap ? "whitespace-pre-wrap break-all" : "";
66
+ const renderToken = (token, idx) => {
67
+ const cls = getTokenClasses(token.type, theme);
68
+ return cls ? /* @__PURE__ */ jsx("span", { className: cls, children: token.value }, idx) : /* @__PURE__ */ jsx(React.Fragment, { children: token.value }, idx);
69
+ };
70
+ const renderLine = (line, lineIndex) => {
71
+ const tokens = tokenizeLine(line, language);
72
+ return /* @__PURE__ */ jsxs("div", { className: "min-h-[1.625rem]", children: [
73
+ tokens.map(renderToken),
74
+ line === "" ? "\n" : null
75
+ ] }, lineIndex);
76
+ };
77
+ return /* @__PURE__ */ jsx(
78
+ "div",
79
+ {
80
+ className: containerClasses,
81
+ style: containerStyle,
82
+ "data-language": language,
83
+ "data-theme": theme,
84
+ children: /* @__PURE__ */ jsxs("div", { className: "flex h-full", children: [
85
+ lineNumbers && /* @__PURE__ */ jsx("div", { className: getLineNumberClasses(theme), "aria-hidden": "true", children: lineNums.map((n) => /* @__PURE__ */ jsx("div", { className: "min-h-[1.625rem]", children: n }, n)) }),
86
+ /* @__PURE__ */ jsxs("div", { className: "relative flex-1 overflow-auto", children: [
87
+ /* @__PURE__ */ jsx("div", { className: classNames(codeEditorHighlightClasses, wrapClass), "aria-hidden": "true", children: lines.map(renderLine) }),
88
+ /* @__PURE__ */ jsx(
89
+ "textarea",
90
+ {
91
+ ref: textareaRef,
92
+ className: classNames(codeEditorTextareaClasses, wrapClass),
93
+ value: code,
94
+ onChange: handleInput,
95
+ onKeyDown: handleKeyDown,
96
+ readOnly: readOnly || disabled,
97
+ disabled,
98
+ placeholder,
99
+ spellCheck: false,
100
+ autoCapitalize: "off",
101
+ autoComplete: "off",
102
+ autoCorrect: "off",
103
+ "data-gramm": "false",
104
+ "aria-label": "Code editor",
105
+ role: "textbox",
106
+ "aria-multiline": true
107
+ }
108
+ )
109
+ ] })
110
+ ] })
111
+ }
112
+ );
113
+ };
114
+ var CodeEditor_default = CodeEditor;
115
+
116
+ export { CodeEditor, CodeEditor_default };
@@ -0,0 +1,118 @@
1
+ import { useState, useRef, useMemo, useCallback, useEffect } from 'react';
2
+ import { extractMentionQuery, classNames, getMentionsInputClasses, mentionsDropdownClasses, getMentionsOptionClasses } from '@expcat/tigercat-core';
3
+ import { jsxs, jsx } from 'react/jsx-runtime';
4
+
5
+ // src/components/Mentions.tsx
6
+ var Mentions = ({
7
+ value = "",
8
+ prefix: triggerPrefix = "@",
9
+ options = [],
10
+ placeholder,
11
+ disabled = false,
12
+ size = "md",
13
+ rows = 3,
14
+ onChange,
15
+ onSelect,
16
+ className
17
+ }) => {
18
+ const [isOpen, setIsOpen] = useState(false);
19
+ const [activeIndex, setActiveIndex] = useState(0);
20
+ const [query, setQuery] = useState("");
21
+ const mentionStartRef = useRef(-1);
22
+ const textareaRef = useRef(null);
23
+ const containerRef = useRef(null);
24
+ const filteredOptions = useMemo(() => {
25
+ if (!query) return options;
26
+ const q = query.toLowerCase();
27
+ return options.filter((o) => !o.disabled && o.label.toLowerCase().includes(q));
28
+ }, [options, query]);
29
+ const handleInput = useCallback(
30
+ (e) => {
31
+ const newValue = e.target.value;
32
+ onChange?.(newValue);
33
+ const cursorPos = e.target.selectionStart ?? newValue.length;
34
+ const result = extractMentionQuery(newValue, cursorPos, triggerPrefix);
35
+ if (result && options.length > 0) {
36
+ setQuery(result.query);
37
+ mentionStartRef.current = result.startPos;
38
+ setIsOpen(true);
39
+ setActiveIndex(0);
40
+ } else {
41
+ setIsOpen(false);
42
+ }
43
+ },
44
+ [onChange, triggerPrefix, options.length]
45
+ );
46
+ const selectOption = useCallback(
47
+ (option) => {
48
+ if (option.disabled) return;
49
+ const before = value.slice(0, mentionStartRef.current);
50
+ const cursorPos = textareaRef.current?.selectionStart ?? value.length;
51
+ const after = value.slice(cursorPos);
52
+ const newValue = `${before}${triggerPrefix}${option.value} ${after}`;
53
+ onChange?.(newValue);
54
+ onSelect?.(option);
55
+ setIsOpen(false);
56
+ },
57
+ [value, triggerPrefix, onChange, onSelect]
58
+ );
59
+ const handleKeydown = useCallback(
60
+ (e) => {
61
+ if (!isOpen) return;
62
+ if (e.key === "ArrowDown") {
63
+ e.preventDefault();
64
+ setActiveIndex((prev) => (prev + 1) % filteredOptions.length);
65
+ } else if (e.key === "ArrowUp") {
66
+ e.preventDefault();
67
+ setActiveIndex((prev) => (prev - 1 + filteredOptions.length) % filteredOptions.length);
68
+ } else if (e.key === "Enter") {
69
+ e.preventDefault();
70
+ const opt = filteredOptions[activeIndex];
71
+ if (opt) selectOption(opt);
72
+ } else if (e.key === "Escape") {
73
+ setIsOpen(false);
74
+ }
75
+ },
76
+ [isOpen, filteredOptions, activeIndex, selectOption]
77
+ );
78
+ useEffect(() => {
79
+ if (!isOpen) return;
80
+ const handler = (e) => {
81
+ if (containerRef.current && !containerRef.current.contains(e.target)) {
82
+ setIsOpen(false);
83
+ }
84
+ };
85
+ document.addEventListener("mousedown", handler);
86
+ return () => document.removeEventListener("mousedown", handler);
87
+ }, [isOpen]);
88
+ const wrapperClass = classNames("relative", className);
89
+ return /* @__PURE__ */ jsxs("div", { ref: containerRef, className: wrapperClass, children: [
90
+ /* @__PURE__ */ jsx(
91
+ "textarea",
92
+ {
93
+ ref: textareaRef,
94
+ value,
95
+ className: getMentionsInputClasses(size, disabled),
96
+ placeholder,
97
+ disabled,
98
+ rows,
99
+ onChange: handleInput,
100
+ onKeyDown: handleKeydown
101
+ }
102
+ ),
103
+ isOpen && filteredOptions.length > 0 && /* @__PURE__ */ jsx("div", { className: mentionsDropdownClasses, role: "listbox", children: filteredOptions.map((opt, i) => /* @__PURE__ */ jsx(
104
+ "div",
105
+ {
106
+ className: getMentionsOptionClasses(i === activeIndex, !!opt.disabled),
107
+ role: "option",
108
+ "aria-selected": i === activeIndex,
109
+ onClick: () => selectOption(opt),
110
+ children: opt.label
111
+ },
112
+ opt.value
113
+ )) })
114
+ ] });
115
+ };
116
+ var Mentions_default = Mentions;
117
+
118
+ export { Mentions, Mentions_default };
@@ -0,0 +1,286 @@
1
+ import { useControlledState } from './chunk-UQMPEMY7.mjs';
2
+ import React, { useRef, useMemo, useState, useCallback } from 'react';
3
+ import { filterColumns, setDragData, createCardDragData, createColumnDragData, getDropIndex, getColumnDropIndex, parseDragData, moveCard, reorderColumns, classNames, getKanbanContainerClasses, isWipExceeded, getColumnCardCount, kanbanCardCountClasses, taskBoardWipExceededClasses, taskBoardColumnHeaderClasses, taskBoardColumnBodyClasses, taskBoardEmptyClasses, taskBoardDropIndicatorClasses, taskBoardCardClasses, taskBoardCardDraggingClasses, kanbanAddCardClasses, taskBoardColumnClasses, taskBoardColumnDropTargetClasses, taskBoardColumnDraggingClasses, kanbanAddColumnClasses } from '@expcat/tigercat-core';
4
+ import { jsxs, jsx, Fragment } from 'react/jsx-runtime';
5
+
6
+ var Kanban = ({
7
+ columns: controlledColumns,
8
+ defaultColumns = [],
9
+ draggable = true,
10
+ columnDraggable = true,
11
+ enforceWipLimit = false,
12
+ beforeCardMove,
13
+ beforeColumnMove,
14
+ filterText = "",
15
+ hiddenColumns,
16
+ showCardCount = true,
17
+ allowAddCard = true,
18
+ allowAddColumn = false,
19
+ onCardMove,
20
+ onColumnMove,
21
+ onColumnsChange,
22
+ onCardAdd,
23
+ onColumnAdd,
24
+ renderCard,
25
+ renderColumnHeader,
26
+ className,
27
+ ...restProps
28
+ }) => {
29
+ const boardRef = useRef(null);
30
+ const [rawColumns, setInternalColumns, isControlled] = useControlledState(
31
+ controlledColumns,
32
+ defaultColumns
33
+ );
34
+ const visibleColumns = useMemo(
35
+ () => filterColumns(rawColumns, filterText, hiddenColumns),
36
+ [rawColumns, filterText, hiddenColumns]
37
+ );
38
+ const [dragState, setDragState] = useState(null);
39
+ const [dropTargetCol, setDropTargetCol] = useState(null);
40
+ const [dropTargetIdx, setDropTargetIdx] = useState(-1);
41
+ function updateColumns(cols) {
42
+ if (!isControlled) setInternalColumns(cols);
43
+ onColumnsChange?.(cols);
44
+ }
45
+ function resetDrag() {
46
+ setDragState(null);
47
+ setDropTargetCol(null);
48
+ setDropTargetIdx(-1);
49
+ }
50
+ const handleCardDragStart = useCallback(
51
+ (e, card, colId, idx) => {
52
+ if (!draggable) return;
53
+ setDragData(e.nativeEvent.dataTransfer, createCardDragData(card.id, colId, idx));
54
+ setDragState({ type: "card", id: card.id, fromColumnId: colId, fromIndex: idx });
55
+ },
56
+ [draggable]
57
+ );
58
+ const handleColumnDragStart = useCallback(
59
+ (e, colId, idx) => {
60
+ if (!columnDraggable) return;
61
+ setDragData(e.nativeEvent.dataTransfer, createColumnDragData(colId, idx));
62
+ setDragState({ type: "column", id: colId, fromIndex: idx });
63
+ },
64
+ [columnDraggable]
65
+ );
66
+ const handleDragOver = useCallback(
67
+ (e, colId) => {
68
+ e.preventDefault();
69
+ if (!dragState) return;
70
+ setDropTargetCol(colId);
71
+ if (dragState.type === "card") {
72
+ const colEl = e.currentTarget.querySelector("[data-kanban-body]");
73
+ if (colEl) {
74
+ const cards = Array.from(colEl.querySelectorAll("[data-kanban-card]"));
75
+ const rects = cards.map((c) => c.getBoundingClientRect());
76
+ setDropTargetIdx(getDropIndex(e.clientY, rects));
77
+ }
78
+ }
79
+ },
80
+ [dragState]
81
+ );
82
+ const handleColumnDragOver = useCallback(
83
+ (e) => {
84
+ e.preventDefault();
85
+ if (!dragState || dragState.type !== "column") return;
86
+ const boardEl = boardRef.current;
87
+ if (!boardEl) return;
88
+ const cols = Array.from(boardEl.querySelectorAll("[data-kanban-column]"));
89
+ const rects = cols.map((c) => c.getBoundingClientRect());
90
+ setDropTargetIdx(getColumnDropIndex(e.clientX, rects));
91
+ },
92
+ [dragState]
93
+ );
94
+ const handleDrop = useCallback(
95
+ async (e) => {
96
+ e.preventDefault();
97
+ const data = parseDragData(e.nativeEvent.dataTransfer);
98
+ if (!data || !dragState) {
99
+ resetDrag();
100
+ return;
101
+ }
102
+ if (data.type === "card" && dropTargetCol != null) {
103
+ if (beforeCardMove) {
104
+ const evt = {
105
+ cardId: data.cardId,
106
+ fromColumnId: data.columnId,
107
+ toColumnId: dropTargetCol,
108
+ fromIndex: data.index,
109
+ toIndex: dropTargetIdx
110
+ };
111
+ const ok = await beforeCardMove(evt);
112
+ if (!ok) {
113
+ resetDrag();
114
+ return;
115
+ }
116
+ }
117
+ const result = moveCard(
118
+ rawColumns,
119
+ data.cardId,
120
+ data.columnId,
121
+ dropTargetCol,
122
+ dropTargetIdx,
123
+ { enforceWipLimit }
124
+ );
125
+ if (result) {
126
+ updateColumns(result.columns);
127
+ onCardMove?.(result.event);
128
+ }
129
+ } else if (data.type === "column") {
130
+ if (beforeColumnMove) {
131
+ const evt = {
132
+ columnId: data.columnId,
133
+ fromIndex: data.index,
134
+ toIndex: dropTargetIdx
135
+ };
136
+ const ok = await beforeColumnMove(evt);
137
+ if (!ok) {
138
+ resetDrag();
139
+ return;
140
+ }
141
+ }
142
+ const result = reorderColumns(rawColumns, data.index, dropTargetIdx);
143
+ if (result) {
144
+ updateColumns(result.columns);
145
+ onColumnMove?.(result.event);
146
+ }
147
+ }
148
+ resetDrag();
149
+ },
150
+ [
151
+ dragState,
152
+ dropTargetCol,
153
+ dropTargetIdx,
154
+ rawColumns,
155
+ enforceWipLimit,
156
+ beforeCardMove,
157
+ beforeColumnMove,
158
+ onCardMove,
159
+ onColumnMove
160
+ ]
161
+ );
162
+ const containerClasses = useMemo(
163
+ () => classNames(getKanbanContainerClasses(className)),
164
+ [className]
165
+ );
166
+ return /* @__PURE__ */ jsxs(
167
+ "div",
168
+ {
169
+ ref: boardRef,
170
+ className: containerClasses,
171
+ role: "region",
172
+ "aria-label": "Kanban board",
173
+ onDragOver: handleColumnDragOver,
174
+ ...restProps,
175
+ children: [
176
+ visibleColumns.map((col, colIdx) => {
177
+ const wipExceeded = isWipExceeded(col);
178
+ const cardCount = getColumnCardCount(col);
179
+ const isDragOverCol = dropTargetCol === col.id;
180
+ const isColDragging = dragState?.type === "column" && dragState.id === col.id;
181
+ return /* @__PURE__ */ jsxs(
182
+ "div",
183
+ {
184
+ className: classNames(
185
+ taskBoardColumnClasses,
186
+ isDragOverCol && dragState?.type === "card" && taskBoardColumnDropTargetClasses,
187
+ isColDragging && taskBoardColumnDraggingClasses
188
+ ),
189
+ "data-kanban-column": "",
190
+ draggable: columnDraggable,
191
+ onDragStart: (e) => handleColumnDragStart(e, col.id, colIdx),
192
+ onDragOver: (e) => handleDragOver(e, col.id),
193
+ onDrop: handleDrop,
194
+ onDragEnd: resetDrag,
195
+ children: [
196
+ /* @__PURE__ */ jsxs(
197
+ "div",
198
+ {
199
+ className: classNames(
200
+ taskBoardColumnHeaderClasses,
201
+ wipExceeded && taskBoardWipExceededClasses
202
+ ),
203
+ children: [
204
+ renderColumnHeader ? renderColumnHeader(col) : /* @__PURE__ */ jsx("span", { children: col.title }),
205
+ showCardCount && /* @__PURE__ */ jsx(
206
+ "span",
207
+ {
208
+ className: classNames(
209
+ kanbanCardCountClasses,
210
+ wipExceeded && taskBoardWipExceededClasses
211
+ ),
212
+ children: cardCount.limit ? `${cardCount.count}/${cardCount.limit}` : `${cardCount.count}`
213
+ }
214
+ )
215
+ ]
216
+ }
217
+ ),
218
+ /* @__PURE__ */ jsxs("div", { className: taskBoardColumnBodyClasses, "data-kanban-body": "", children: [
219
+ col.cards.length === 0 ? /* @__PURE__ */ jsx("div", { className: taskBoardEmptyClasses, children: "No cards" }) : col.cards.map((card, cardIdx) => {
220
+ const isCardDragging = dragState?.type === "card" && dragState.id === card.id;
221
+ return /* @__PURE__ */ jsxs(React.Fragment, { children: [
222
+ isDragOverCol && dragState?.type === "card" && dropTargetIdx === cardIdx && /* @__PURE__ */ jsx("div", { className: taskBoardDropIndicatorClasses }),
223
+ /* @__PURE__ */ jsx(
224
+ "div",
225
+ {
226
+ className: classNames(
227
+ taskBoardCardClasses,
228
+ isCardDragging && taskBoardCardDraggingClasses
229
+ ),
230
+ draggable,
231
+ "data-kanban-card": "",
232
+ onDragStart: (e) => handleCardDragStart(e, card, col.id, cardIdx),
233
+ children: renderCard ? renderCard(card, col.id) : /* @__PURE__ */ jsxs(Fragment, { children: [
234
+ /* @__PURE__ */ jsx("div", { className: "font-medium text-sm", children: card.title }),
235
+ card.description && /* @__PURE__ */ jsx("div", { className: "text-xs text-[var(--tiger-text-muted,#6b7280)] mt-1", children: card.description })
236
+ ] })
237
+ }
238
+ )
239
+ ] }, card.id);
240
+ }),
241
+ isDragOverCol && dragState?.type === "card" && dropTargetIdx >= col.cards.length && /* @__PURE__ */ jsx("div", { className: taskBoardDropIndicatorClasses })
242
+ ] }),
243
+ allowAddCard && /* @__PURE__ */ jsx(
244
+ "div",
245
+ {
246
+ className: kanbanAddCardClasses,
247
+ role: "button",
248
+ tabIndex: 0,
249
+ onClick: () => onCardAdd?.(col.id),
250
+ onKeyDown: (e) => {
251
+ if (e.key === "Enter" || e.key === " ") {
252
+ e.preventDefault();
253
+ onCardAdd?.(col.id);
254
+ }
255
+ },
256
+ children: "+ Add card"
257
+ }
258
+ )
259
+ ]
260
+ },
261
+ col.id
262
+ );
263
+ }),
264
+ allowAddColumn && /* @__PURE__ */ jsx(
265
+ "div",
266
+ {
267
+ className: kanbanAddColumnClasses,
268
+ role: "button",
269
+ tabIndex: 0,
270
+ onClick: () => onColumnAdd?.(),
271
+ onKeyDown: (e) => {
272
+ if (e.key === "Enter" || e.key === " ") {
273
+ e.preventDefault();
274
+ onColumnAdd?.();
275
+ }
276
+ },
277
+ children: "+ Add column"
278
+ }
279
+ )
280
+ ]
281
+ }
282
+ );
283
+ };
284
+ var Kanban_default = Kanban;
285
+
286
+ export { Kanban, Kanban_default };
@@ -0,0 +1,88 @@
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/Affix.tsx
8
+ var Affix = ({
9
+ offsetTop = 0,
10
+ offsetBottom,
11
+ target,
12
+ zIndex = 10,
13
+ className,
14
+ children,
15
+ onChange,
16
+ ...props
17
+ }) => {
18
+ const wrapperRef = react.useRef(null);
19
+ const placeholderRef = react.useRef(null);
20
+ const originalRectRef = react.useRef(null);
21
+ const [state, setState] = react.useState({ affixed: false, style: {} });
22
+ const prevAffixed = react.useRef(false);
23
+ const update = react.useCallback(() => {
24
+ const el = prevAffixed.current && placeholderRef.current ? placeholderRef.current : wrapperRef.current;
25
+ if (!el) return;
26
+ const rect = el.getBoundingClientRect();
27
+ if (!originalRectRef.current || !prevAffixed.current) {
28
+ originalRectRef.current = {
29
+ top: rect.top,
30
+ left: rect.left,
31
+ width: rect.width,
32
+ height: rect.height
33
+ };
34
+ }
35
+ const resolved = tigercatCore.resolveAffixTarget(target);
36
+ const containerRect = resolved.getRect();
37
+ const newState = tigercatCore.calculateAffixState(
38
+ originalRectRef.current,
39
+ containerRect,
40
+ offsetBottom !== void 0 ? void 0 : offsetTop,
41
+ offsetBottom,
42
+ zIndex
43
+ );
44
+ if (newState.affixed !== prevAffixed.current) {
45
+ prevAffixed.current = newState.affixed;
46
+ onChange?.(newState.affixed);
47
+ }
48
+ setState(newState);
49
+ }, [offsetTop, offsetBottom, target, zIndex, onChange]);
50
+ react.useEffect(() => {
51
+ const resolved = tigercatCore.resolveAffixTarget(target);
52
+ const scrollEl = resolved.element;
53
+ scrollEl.addEventListener("scroll", update, { passive: true });
54
+ window.addEventListener("resize", update, { passive: true });
55
+ update();
56
+ return () => {
57
+ scrollEl.removeEventListener("scroll", update);
58
+ window.removeEventListener("resize", update);
59
+ };
60
+ }, [target, update]);
61
+ const wrapperClasses = react.useMemo(() => tigercatCore.classNames(className), [className]);
62
+ if (state.affixed) {
63
+ return /* @__PURE__ */ jsxRuntime.jsxs("div", { ref: placeholderRef, children: [
64
+ /* @__PURE__ */ jsxRuntime.jsx(
65
+ "div",
66
+ {
67
+ style: {
68
+ width: originalRectRef.current?.width ?? 0,
69
+ height: originalRectRef.current?.height ?? 0
70
+ }
71
+ }
72
+ ),
73
+ /* @__PURE__ */ jsxRuntime.jsx(
74
+ "div",
75
+ {
76
+ ref: wrapperRef,
77
+ className: wrapperClasses,
78
+ style: state.style,
79
+ ...props,
80
+ children
81
+ }
82
+ )
83
+ ] });
84
+ }
85
+ return /* @__PURE__ */ jsxRuntime.jsx("div", { ref: wrapperRef, className: wrapperClasses, ...props, children });
86
+ };
87
+
88
+ exports.Affix = Affix;
@@ -0,0 +1,40 @@
1
+ import { createContext, useContext, useMemo } from 'react';
2
+ import { classNames, getInputGroupClasses, getInputGroupAddonClasses } from '@expcat/tigercat-core';
3
+ import { jsx } from 'react/jsx-runtime';
4
+
5
+ // src/components/InputGroup.tsx
6
+ var InputGroupContext = createContext(null);
7
+ function useInputGroupContext() {
8
+ return useContext(InputGroupContext);
9
+ }
10
+ var InputGroup = ({
11
+ size = "md",
12
+ compact = false,
13
+ className,
14
+ children,
15
+ ...rest
16
+ }) => {
17
+ const contextValue = useMemo(() => ({ size, compact }), [size, compact]);
18
+ const groupClasses = useMemo(
19
+ () => classNames(getInputGroupClasses(compact, className)),
20
+ [compact, className]
21
+ );
22
+ return /* @__PURE__ */ jsx(InputGroupContext.Provider, { value: contextValue, children: /* @__PURE__ */ jsx("div", { ...rest, className: groupClasses, role: "group", children }) });
23
+ };
24
+ var InputGroupAddon = ({
25
+ addonType = "text",
26
+ className,
27
+ children,
28
+ ...rest
29
+ }) => {
30
+ const ctx = useInputGroupContext();
31
+ const size = ctx?.size ?? "md";
32
+ const compact = ctx?.compact ?? true;
33
+ const addonClasses = useMemo(
34
+ () => classNames(getInputGroupAddonClasses(size, compact, className)),
35
+ [size, compact, className]
36
+ );
37
+ return /* @__PURE__ */ jsx("span", { ...rest, className: addonClasses, children });
38
+ };
39
+
40
+ export { InputGroup, InputGroupAddon, InputGroupContext, useInputGroupContext };