shad-m 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 (912) hide show
  1. package/README.md +260 -0
  2. package/dist/assets/Animation/index.d.ts +25655 -0
  3. package/dist/assets/Animation/index.d.ts.map +1 -0
  4. package/dist/assets/Animation/index.js +180 -0
  5. package/dist/assets/Animation/index.js.map +1 -0
  6. package/dist/assets/Animation/index.mjs +79 -0
  7. package/dist/assets/Animation/index.mjs.map +1 -0
  8. package/dist/assets/Icon/index.d.ts +420 -0
  9. package/dist/assets/Icon/index.d.ts.map +1 -0
  10. package/dist/assets/Icon/index.js +2102 -0
  11. package/dist/assets/Icon/index.js.map +1 -0
  12. package/dist/assets/Icon/index.mjs +421 -0
  13. package/dist/assets/Icon/index.mjs.map +1 -0
  14. package/dist/assets/Image/index.d.ts +151 -0
  15. package/dist/assets/Image/index.d.ts.map +1 -0
  16. package/dist/assets/Image/index.js +755 -0
  17. package/dist/assets/Image/index.js.map +1 -0
  18. package/dist/assets/Image/index.mjs +150 -0
  19. package/dist/assets/Image/index.mjs.map +1 -0
  20. package/dist/common/display/countdown.d.ts +26 -0
  21. package/dist/common/display/countdown.d.ts.map +1 -0
  22. package/dist/common/display/countdown.js +68 -0
  23. package/dist/common/display/countdown.js.map +1 -0
  24. package/dist/common/display/countdown.mjs +46 -0
  25. package/dist/common/display/countdown.mjs.map +1 -0
  26. package/dist/common/display/display-field-group.d.ts +59 -0
  27. package/dist/common/display/display-field-group.d.ts.map +1 -0
  28. package/dist/common/display/display-field-group.js +91 -0
  29. package/dist/common/display/display-field-group.js.map +1 -0
  30. package/dist/common/display/display-field-group.mjs +89 -0
  31. package/dist/common/display/display-field-group.mjs.map +1 -0
  32. package/dist/common/display/display-field.d.ts +45 -0
  33. package/dist/common/display/display-field.d.ts.map +1 -0
  34. package/dist/common/display/display-field.js +46 -0
  35. package/dist/common/display/display-field.js.map +1 -0
  36. package/dist/common/display/display-field.mjs +40 -0
  37. package/dist/common/display/display-field.mjs.map +1 -0
  38. package/dist/common/display/display-html-string.d.ts +7 -0
  39. package/dist/common/display/display-html-string.d.ts.map +1 -0
  40. package/dist/common/display/display-html-string.js +52 -0
  41. package/dist/common/display/display-html-string.js.map +1 -0
  42. package/dist/common/display/display-html-string.mjs +30 -0
  43. package/dist/common/display/display-html-string.mjs.map +1 -0
  44. package/dist/common/display/index.d.ts +16 -0
  45. package/dist/common/display/index.d.ts.map +1 -0
  46. package/dist/common/display/index.js +59 -0
  47. package/dist/common/display/index.js.map +1 -0
  48. package/dist/common/display/index.mjs +10 -0
  49. package/dist/common/display/index.mjs.map +1 -0
  50. package/dist/common/display/page-breadcrumb.d.ts +19 -0
  51. package/dist/common/display/page-breadcrumb.d.ts.map +1 -0
  52. package/dist/common/display/page-breadcrumb.js +43 -0
  53. package/dist/common/display/page-breadcrumb.js.map +1 -0
  54. package/dist/common/display/page-breadcrumb.mjs +37 -0
  55. package/dist/common/display/page-breadcrumb.mjs.map +1 -0
  56. package/dist/common/display/page-v2.d.ts +15 -0
  57. package/dist/common/display/page-v2.d.ts.map +1 -0
  58. package/dist/common/display/page-v2.js +58 -0
  59. package/dist/common/display/page-v2.js.map +1 -0
  60. package/dist/common/display/page-v2.mjs +20 -0
  61. package/dist/common/display/page-v2.mjs.map +1 -0
  62. package/dist/common/display/page.d.ts +53 -0
  63. package/dist/common/display/page.d.ts.map +1 -0
  64. package/dist/common/display/page.js +155 -0
  65. package/dist/common/display/page.js.map +1 -0
  66. package/dist/common/display/page.mjs +138 -0
  67. package/dist/common/display/page.mjs.map +1 -0
  68. package/dist/common/display/score-meter.d.ts +22 -0
  69. package/dist/common/display/score-meter.d.ts.map +1 -0
  70. package/dist/common/display/score-meter.js +161 -0
  71. package/dist/common/display/score-meter.js.map +1 -0
  72. package/dist/common/display/score-meter.mjs +140 -0
  73. package/dist/common/display/score-meter.mjs.map +1 -0
  74. package/dist/common/display/sidebar/app-sidebar.d.ts +28 -0
  75. package/dist/common/display/sidebar/app-sidebar.d.ts.map +1 -0
  76. package/dist/common/display/sidebar/app-sidebar.js +114 -0
  77. package/dist/common/display/sidebar/app-sidebar.js.map +1 -0
  78. package/dist/common/display/sidebar/app-sidebar.mjs +92 -0
  79. package/dist/common/display/sidebar/app-sidebar.mjs.map +1 -0
  80. package/dist/common/display/sidebar/index.d.ts +30 -0
  81. package/dist/common/display/sidebar/index.d.ts.map +1 -0
  82. package/dist/common/display/sidebar/index.js +89 -0
  83. package/dist/common/display/sidebar/index.js.map +1 -0
  84. package/dist/common/display/sidebar/index.mjs +81 -0
  85. package/dist/common/display/sidebar/index.mjs.map +1 -0
  86. package/dist/common/display/sidebar/nav-main.d.ts +17 -0
  87. package/dist/common/display/sidebar/nav-main.d.ts.map +1 -0
  88. package/dist/common/display/sidebar/nav-main.js +406 -0
  89. package/dist/common/display/sidebar/nav-main.js.map +1 -0
  90. package/dist/common/display/sidebar/nav-main.mjs +400 -0
  91. package/dist/common/display/sidebar/nav-main.mjs.map +1 -0
  92. package/dist/common/display/sidebar/sidebar-sheet.d.ts +46 -0
  93. package/dist/common/display/sidebar/sidebar-sheet.d.ts.map +1 -0
  94. package/dist/common/display/sidebar/sidebar-sheet.js +140 -0
  95. package/dist/common/display/sidebar/sidebar-sheet.js.map +1 -0
  96. package/dist/common/display/sidebar/sidebar-sheet.mjs +118 -0
  97. package/dist/common/display/sidebar/sidebar-sheet.mjs.map +1 -0
  98. package/dist/common/display/sidebar/types.d.ts +18 -0
  99. package/dist/common/display/sidebar/types.d.ts.map +1 -0
  100. package/dist/common/display/sidebar/types.js +4 -0
  101. package/dist/common/display/sidebar/types.js.map +1 -0
  102. package/dist/common/display/sidebar/types.mjs +3 -0
  103. package/dist/common/display/sidebar/types.mjs.map +1 -0
  104. package/dist/common/display/status-state.d.ts +16 -0
  105. package/dist/common/display/status-state.d.ts.map +1 -0
  106. package/dist/common/display/status-state.js +97 -0
  107. package/dist/common/display/status-state.js.map +1 -0
  108. package/dist/common/display/status-state.mjs +88 -0
  109. package/dist/common/display/status-state.mjs.map +1 -0
  110. package/dist/common/forms/auto-form.d.ts +17 -0
  111. package/dist/common/forms/auto-form.d.ts.map +1 -0
  112. package/dist/common/forms/auto-form.js +101 -0
  113. package/dist/common/forms/auto-form.js.map +1 -0
  114. package/dist/common/forms/auto-form.mjs +78 -0
  115. package/dist/common/forms/auto-form.mjs.map +1 -0
  116. package/dist/common/forms/form-field.d.ts +16 -0
  117. package/dist/common/forms/form-field.d.ts.map +1 -0
  118. package/dist/common/forms/form-field.js +58 -0
  119. package/dist/common/forms/form-field.js.map +1 -0
  120. package/dist/common/forms/form-field.mjs +56 -0
  121. package/dist/common/forms/form-field.mjs.map +1 -0
  122. package/dist/common/forms/form-input-field.d.ts +16 -0
  123. package/dist/common/forms/form-input-field.d.ts.map +1 -0
  124. package/dist/common/forms/form-input-field.js +64 -0
  125. package/dist/common/forms/form-input-field.js.map +1 -0
  126. package/dist/common/forms/form-input-field.mjs +62 -0
  127. package/dist/common/forms/form-input-field.mjs.map +1 -0
  128. package/dist/common/forms/index.d.ts +7 -0
  129. package/dist/common/forms/index.d.ts.map +1 -0
  130. package/dist/common/forms/index.js +22 -0
  131. package/dist/common/forms/index.js.map +1 -0
  132. package/dist/common/forms/index.mjs +5 -0
  133. package/dist/common/forms/index.mjs.map +1 -0
  134. package/dist/common/forms/switch-field.d.ts +19 -0
  135. package/dist/common/forms/switch-field.d.ts.map +1 -0
  136. package/dist/common/forms/switch-field.js +106 -0
  137. package/dist/common/forms/switch-field.js.map +1 -0
  138. package/dist/common/forms/switch-field.mjs +104 -0
  139. package/dist/common/forms/switch-field.mjs.map +1 -0
  140. package/dist/common/interactive/alert-dialog-wrapper.d.ts +41 -0
  141. package/dist/common/interactive/alert-dialog-wrapper.d.ts.map +1 -0
  142. package/dist/common/interactive/alert-dialog-wrapper.js +141 -0
  143. package/dist/common/interactive/alert-dialog-wrapper.js.map +1 -0
  144. package/dist/common/interactive/alert-dialog-wrapper.mjs +119 -0
  145. package/dist/common/interactive/alert-dialog-wrapper.mjs.map +1 -0
  146. package/dist/common/interactive/autocomplete.d.ts +21 -0
  147. package/dist/common/interactive/autocomplete.d.ts.map +1 -0
  148. package/dist/common/interactive/autocomplete.js +178 -0
  149. package/dist/common/interactive/autocomplete.js.map +1 -0
  150. package/dist/common/interactive/autocomplete.mjs +157 -0
  151. package/dist/common/interactive/autocomplete.mjs.map +1 -0
  152. package/dist/common/interactive/copy-tooltip.d.ts +27 -0
  153. package/dist/common/interactive/copy-tooltip.d.ts.map +1 -0
  154. package/dist/common/interactive/copy-tooltip.js +152 -0
  155. package/dist/common/interactive/copy-tooltip.js.map +1 -0
  156. package/dist/common/interactive/copy-tooltip.mjs +143 -0
  157. package/dist/common/interactive/copy-tooltip.mjs.map +1 -0
  158. package/dist/common/interactive/date-field.d.ts +98 -0
  159. package/dist/common/interactive/date-field.d.ts.map +1 -0
  160. package/dist/common/interactive/date-field.js +303 -0
  161. package/dist/common/interactive/date-field.js.map +1 -0
  162. package/dist/common/interactive/date-field.mjs +281 -0
  163. package/dist/common/interactive/date-field.mjs.map +1 -0
  164. package/dist/common/interactive/date-input/date-input.d.ts +12 -0
  165. package/dist/common/interactive/date-input/date-input.d.ts.map +1 -0
  166. package/dist/common/interactive/date-input/date-input.js +68 -0
  167. package/dist/common/interactive/date-input/date-input.js.map +1 -0
  168. package/dist/common/interactive/date-input/date-input.mjs +62 -0
  169. package/dist/common/interactive/date-input/date-input.mjs.map +1 -0
  170. package/dist/common/interactive/date-input/index.d.ts +4 -0
  171. package/dist/common/interactive/date-input/index.d.ts.map +1 -0
  172. package/dist/common/interactive/date-input/index.js +17 -0
  173. package/dist/common/interactive/date-input/index.js.map +1 -0
  174. package/dist/common/interactive/date-input/index.mjs +4 -0
  175. package/dist/common/interactive/date-input/index.mjs.map +1 -0
  176. package/dist/common/interactive/date-input/types.d.ts +17 -0
  177. package/dist/common/interactive/date-input/types.d.ts.map +1 -0
  178. package/dist/common/interactive/date-input/types.js +4 -0
  179. package/dist/common/interactive/date-input/types.js.map +1 -0
  180. package/dist/common/interactive/date-input/types.mjs +3 -0
  181. package/dist/common/interactive/date-input/types.mjs.map +1 -0
  182. package/dist/common/interactive/date-input/use-typed-date.d.ts +17 -0
  183. package/dist/common/interactive/date-input/use-typed-date.d.ts.map +1 -0
  184. package/dist/common/interactive/date-input/use-typed-date.js +478 -0
  185. package/dist/common/interactive/date-input/use-typed-date.js.map +1 -0
  186. package/dist/common/interactive/date-input/use-typed-date.mjs +476 -0
  187. package/dist/common/interactive/date-input/use-typed-date.mjs.map +1 -0
  188. package/dist/common/interactive/date-input/utils.d.ts +5 -0
  189. package/dist/common/interactive/date-input/utils.d.ts.map +1 -0
  190. package/dist/common/interactive/date-input/utils.js +34 -0
  191. package/dist/common/interactive/date-input/utils.js.map +1 -0
  192. package/dist/common/interactive/date-input/utils.mjs +29 -0
  193. package/dist/common/interactive/date-input/utils.mjs.map +1 -0
  194. package/dist/common/interactive/date-picker.d.ts +114 -0
  195. package/dist/common/interactive/date-picker.d.ts.map +1 -0
  196. package/dist/common/interactive/date-picker.js +616 -0
  197. package/dist/common/interactive/date-picker.js.map +1 -0
  198. package/dist/common/interactive/date-picker.mjs +594 -0
  199. package/dist/common/interactive/date-picker.mjs.map +1 -0
  200. package/dist/common/interactive/date-range-input/date-range-input.d.ts +23 -0
  201. package/dist/common/interactive/date-range-input/date-range-input.d.ts.map +1 -0
  202. package/dist/common/interactive/date-range-input/date-range-input.js +82 -0
  203. package/dist/common/interactive/date-range-input/date-range-input.js.map +1 -0
  204. package/dist/common/interactive/date-range-input/date-range-input.mjs +76 -0
  205. package/dist/common/interactive/date-range-input/date-range-input.mjs.map +1 -0
  206. package/dist/common/interactive/date-range-input/index.d.ts +4 -0
  207. package/dist/common/interactive/date-range-input/index.d.ts.map +1 -0
  208. package/dist/common/interactive/date-range-input/index.js +12 -0
  209. package/dist/common/interactive/date-range-input/index.js.map +1 -0
  210. package/dist/common/interactive/date-range-input/index.mjs +3 -0
  211. package/dist/common/interactive/date-range-input/index.mjs.map +1 -0
  212. package/dist/common/interactive/date-range-input/types.d.ts +35 -0
  213. package/dist/common/interactive/date-range-input/types.d.ts.map +1 -0
  214. package/dist/common/interactive/date-range-input/types.js +4 -0
  215. package/dist/common/interactive/date-range-input/types.js.map +1 -0
  216. package/dist/common/interactive/date-range-input/types.mjs +3 -0
  217. package/dist/common/interactive/date-range-input/types.mjs.map +1 -0
  218. package/dist/common/interactive/date-range-input/use-typed-date-range.d.ts +17 -0
  219. package/dist/common/interactive/date-range-input/use-typed-date-range.d.ts.map +1 -0
  220. package/dist/common/interactive/date-range-input/use-typed-date-range.js +602 -0
  221. package/dist/common/interactive/date-range-input/use-typed-date-range.js.map +1 -0
  222. package/dist/common/interactive/date-range-input/use-typed-date-range.mjs +600 -0
  223. package/dist/common/interactive/date-range-input/use-typed-date-range.mjs.map +1 -0
  224. package/dist/common/interactive/date-time-picker.d.ts +86 -0
  225. package/dist/common/interactive/date-time-picker.d.ts.map +1 -0
  226. package/dist/common/interactive/date-time-picker.js +215 -0
  227. package/dist/common/interactive/date-time-picker.js.map +1 -0
  228. package/dist/common/interactive/date-time-picker.mjs +213 -0
  229. package/dist/common/interactive/date-time-picker.mjs.map +1 -0
  230. package/dist/common/interactive/dialog-wrapper.d.ts +34 -0
  231. package/dist/common/interactive/dialog-wrapper.d.ts.map +1 -0
  232. package/dist/common/interactive/dialog-wrapper.js +124 -0
  233. package/dist/common/interactive/dialog-wrapper.js.map +1 -0
  234. package/dist/common/interactive/dialog-wrapper.mjs +102 -0
  235. package/dist/common/interactive/dialog-wrapper.mjs.map +1 -0
  236. package/dist/common/interactive/filter.d.ts +51 -0
  237. package/dist/common/interactive/filter.d.ts.map +1 -0
  238. package/dist/common/interactive/filter.js +287 -0
  239. package/dist/common/interactive/filter.js.map +1 -0
  240. package/dist/common/interactive/filter.mjs +280 -0
  241. package/dist/common/interactive/filter.mjs.map +1 -0
  242. package/dist/common/interactive/index.d.ts +41 -0
  243. package/dist/common/interactive/index.d.ts.map +1 -0
  244. package/dist/common/interactive/index.js +235 -0
  245. package/dist/common/interactive/index.js.map +1 -0
  246. package/dist/common/interactive/index.mjs +24 -0
  247. package/dist/common/interactive/index.mjs.map +1 -0
  248. package/dist/common/interactive/list.d.ts +36 -0
  249. package/dist/common/interactive/list.d.ts.map +1 -0
  250. package/dist/common/interactive/list.js +160 -0
  251. package/dist/common/interactive/list.js.map +1 -0
  252. package/dist/common/interactive/list.mjs +134 -0
  253. package/dist/common/interactive/list.mjs.map +1 -0
  254. package/dist/common/interactive/otp-dialog/index.d.ts +7 -0
  255. package/dist/common/interactive/otp-dialog/index.d.ts.map +1 -0
  256. package/dist/common/interactive/otp-dialog/index.js +35 -0
  257. package/dist/common/interactive/otp-dialog/index.js.map +1 -0
  258. package/dist/common/interactive/otp-dialog/index.mjs +6 -0
  259. package/dist/common/interactive/otp-dialog/index.mjs.map +1 -0
  260. package/dist/common/interactive/otp-dialog/otp-dialog.d.ts +34 -0
  261. package/dist/common/interactive/otp-dialog/otp-dialog.d.ts.map +1 -0
  262. package/dist/common/interactive/otp-dialog/otp-dialog.js +325 -0
  263. package/dist/common/interactive/otp-dialog/otp-dialog.js.map +1 -0
  264. package/dist/common/interactive/otp-dialog/otp-dialog.mjs +303 -0
  265. package/dist/common/interactive/otp-dialog/otp-dialog.mjs.map +1 -0
  266. package/dist/common/interactive/otp-dialog/reducer.d.ts +11 -0
  267. package/dist/common/interactive/otp-dialog/reducer.d.ts.map +1 -0
  268. package/dist/common/interactive/otp-dialog/reducer.js +40 -0
  269. package/dist/common/interactive/otp-dialog/reducer.js.map +1 -0
  270. package/dist/common/interactive/otp-dialog/reducer.mjs +37 -0
  271. package/dist/common/interactive/otp-dialog/reducer.mjs.map +1 -0
  272. package/dist/common/interactive/otp-dialog/types.d.ts +82 -0
  273. package/dist/common/interactive/otp-dialog/types.d.ts.map +1 -0
  274. package/dist/common/interactive/otp-dialog/types.js +15 -0
  275. package/dist/common/interactive/otp-dialog/types.js.map +1 -0
  276. package/dist/common/interactive/otp-dialog/types.mjs +13 -0
  277. package/dist/common/interactive/otp-dialog/types.mjs.map +1 -0
  278. package/dist/common/interactive/otp-dialog/utils.d.ts +17 -0
  279. package/dist/common/interactive/otp-dialog/utils.d.ts.map +1 -0
  280. package/dist/common/interactive/otp-dialog/utils.js +24 -0
  281. package/dist/common/interactive/otp-dialog/utils.js.map +1 -0
  282. package/dist/common/interactive/otp-dialog/utils.mjs +21 -0
  283. package/dist/common/interactive/otp-dialog/utils.mjs.map +1 -0
  284. package/dist/common/interactive/pagination/PaginationSkeleton.d.ts +6 -0
  285. package/dist/common/interactive/pagination/PaginationSkeleton.d.ts.map +1 -0
  286. package/dist/common/interactive/pagination/PaginationSkeleton.js +51 -0
  287. package/dist/common/interactive/pagination/PaginationSkeleton.js.map +1 -0
  288. package/dist/common/interactive/pagination/PaginationSkeleton.mjs +49 -0
  289. package/dist/common/interactive/pagination/PaginationSkeleton.mjs.map +1 -0
  290. package/dist/common/interactive/pagination/index.d.ts +14 -0
  291. package/dist/common/interactive/pagination/index.d.ts.map +1 -0
  292. package/dist/common/interactive/pagination/index.js +235 -0
  293. package/dist/common/interactive/pagination/index.js.map +1 -0
  294. package/dist/common/interactive/pagination/index.mjs +223 -0
  295. package/dist/common/interactive/pagination/index.mjs.map +1 -0
  296. package/dist/common/interactive/pagination/usePagination.d.ts +3 -0
  297. package/dist/common/interactive/pagination/usePagination.d.ts.map +1 -0
  298. package/dist/common/interactive/pagination/usePagination.js +28 -0
  299. package/dist/common/interactive/pagination/usePagination.js.map +1 -0
  300. package/dist/common/interactive/pagination/usePagination.mjs +25 -0
  301. package/dist/common/interactive/pagination/usePagination.mjs.map +1 -0
  302. package/dist/common/interactive/popover-wrapper.d.ts +38 -0
  303. package/dist/common/interactive/popover-wrapper.d.ts.map +1 -0
  304. package/dist/common/interactive/popover-wrapper.js +138 -0
  305. package/dist/common/interactive/popover-wrapper.js.map +1 -0
  306. package/dist/common/interactive/popover-wrapper.mjs +116 -0
  307. package/dist/common/interactive/popover-wrapper.mjs.map +1 -0
  308. package/dist/common/interactive/pressable.d.ts +11 -0
  309. package/dist/common/interactive/pressable.d.ts.map +1 -0
  310. package/dist/common/interactive/pressable.js +84 -0
  311. package/dist/common/interactive/pressable.js.map +1 -0
  312. package/dist/common/interactive/pressable.mjs +62 -0
  313. package/dist/common/interactive/pressable.mjs.map +1 -0
  314. package/dist/common/interactive/select/context.d.ts +6 -0
  315. package/dist/common/interactive/select/context.d.ts.map +1 -0
  316. package/dist/common/interactive/select/context.js +38 -0
  317. package/dist/common/interactive/select/context.js.map +1 -0
  318. package/dist/common/interactive/select/context.mjs +14 -0
  319. package/dist/common/interactive/select/context.mjs.map +1 -0
  320. package/dist/common/interactive/select/index.d.ts +18 -0
  321. package/dist/common/interactive/select/index.d.ts.map +1 -0
  322. package/dist/common/interactive/select/index.js +123 -0
  323. package/dist/common/interactive/select/index.js.map +1 -0
  324. package/dist/common/interactive/select/index.mjs +18 -0
  325. package/dist/common/interactive/select/index.mjs.map +1 -0
  326. package/dist/common/interactive/select/select-body.d.ts +5 -0
  327. package/dist/common/interactive/select/select-body.d.ts.map +1 -0
  328. package/dist/common/interactive/select/select-body.js +89 -0
  329. package/dist/common/interactive/select/select-body.js.map +1 -0
  330. package/dist/common/interactive/select/select-body.mjs +67 -0
  331. package/dist/common/interactive/select/select-body.mjs.map +1 -0
  332. package/dist/common/interactive/select/select-close.d.ts +3 -0
  333. package/dist/common/interactive/select/select-close.d.ts.map +1 -0
  334. package/dist/common/interactive/select/select-close.js +38 -0
  335. package/dist/common/interactive/select/select-close.js.map +1 -0
  336. package/dist/common/interactive/select/select-close.mjs +16 -0
  337. package/dist/common/interactive/select/select-close.mjs.map +1 -0
  338. package/dist/common/interactive/select/select-content-auto-layout.d.ts +5 -0
  339. package/dist/common/interactive/select/select-content-auto-layout.d.ts.map +1 -0
  340. package/dist/common/interactive/select/select-content-auto-layout.js +221 -0
  341. package/dist/common/interactive/select/select-content-auto-layout.js.map +1 -0
  342. package/dist/common/interactive/select/select-content-auto-layout.mjs +199 -0
  343. package/dist/common/interactive/select/select-content-auto-layout.mjs.map +1 -0
  344. package/dist/common/interactive/select/select-content-group-auto-layout.d.ts +5 -0
  345. package/dist/common/interactive/select/select-content-group-auto-layout.d.ts.map +1 -0
  346. package/dist/common/interactive/select/select-content-group-auto-layout.js +411 -0
  347. package/dist/common/interactive/select/select-content-group-auto-layout.js.map +1 -0
  348. package/dist/common/interactive/select/select-content-group-auto-layout.mjs +389 -0
  349. package/dist/common/interactive/select/select-content-group-auto-layout.mjs.map +1 -0
  350. package/dist/common/interactive/select/select-content.d.ts +5 -0
  351. package/dist/common/interactive/select/select-content.d.ts.map +1 -0
  352. package/dist/common/interactive/select/select-content.js +187 -0
  353. package/dist/common/interactive/select/select-content.js.map +1 -0
  354. package/dist/common/interactive/select/select-content.mjs +165 -0
  355. package/dist/common/interactive/select/select-content.mjs.map +1 -0
  356. package/dist/common/interactive/select/select-footer.d.ts +5 -0
  357. package/dist/common/interactive/select/select-footer.d.ts.map +1 -0
  358. package/dist/common/interactive/select/select-footer.js +82 -0
  359. package/dist/common/interactive/select/select-footer.js.map +1 -0
  360. package/dist/common/interactive/select/select-footer.mjs +60 -0
  361. package/dist/common/interactive/select/select-footer.mjs.map +1 -0
  362. package/dist/common/interactive/select/select-item.d.ts +6 -0
  363. package/dist/common/interactive/select/select-item.d.ts.map +1 -0
  364. package/dist/common/interactive/select/select-item.js +214 -0
  365. package/dist/common/interactive/select/select-item.js.map +1 -0
  366. package/dist/common/interactive/select/select-item.mjs +191 -0
  367. package/dist/common/interactive/select/select-item.mjs.map +1 -0
  368. package/dist/common/interactive/select/select-layout.d.ts +8 -0
  369. package/dist/common/interactive/select/select-layout.d.ts.map +1 -0
  370. package/dist/common/interactive/select/select-layout.js +66 -0
  371. package/dist/common/interactive/select/select-layout.js.map +1 -0
  372. package/dist/common/interactive/select/select-layout.mjs +41 -0
  373. package/dist/common/interactive/select/select-layout.mjs.map +1 -0
  374. package/dist/common/interactive/select/select-search.d.ts +8 -0
  375. package/dist/common/interactive/select/select-search.d.ts.map +1 -0
  376. package/dist/common/interactive/select/select-search.js +55 -0
  377. package/dist/common/interactive/select/select-search.js.map +1 -0
  378. package/dist/common/interactive/select/select-search.mjs +33 -0
  379. package/dist/common/interactive/select/select-search.mjs.map +1 -0
  380. package/dist/common/interactive/select/select-states.d.ts +6 -0
  381. package/dist/common/interactive/select/select-states.d.ts.map +1 -0
  382. package/dist/common/interactive/select/select-states.js +57 -0
  383. package/dist/common/interactive/select/select-states.js.map +1 -0
  384. package/dist/common/interactive/select/select-states.mjs +34 -0
  385. package/dist/common/interactive/select/select-states.mjs.map +1 -0
  386. package/dist/common/interactive/select/select-trigger.d.ts +7 -0
  387. package/dist/common/interactive/select/select-trigger.d.ts.map +1 -0
  388. package/dist/common/interactive/select/select-trigger.js +310 -0
  389. package/dist/common/interactive/select/select-trigger.js.map +1 -0
  390. package/dist/common/interactive/select/select-trigger.mjs +286 -0
  391. package/dist/common/interactive/select/select-trigger.mjs.map +1 -0
  392. package/dist/common/interactive/select/select-value.d.ts +5 -0
  393. package/dist/common/interactive/select/select-value.d.ts.map +1 -0
  394. package/dist/common/interactive/select/select-value.js +52 -0
  395. package/dist/common/interactive/select/select-value.js.map +1 -0
  396. package/dist/common/interactive/select/select-value.mjs +30 -0
  397. package/dist/common/interactive/select/select-value.mjs.map +1 -0
  398. package/dist/common/interactive/select/select.css +62 -0
  399. package/dist/common/interactive/select/select.d.ts +4 -0
  400. package/dist/common/interactive/select/select.d.ts.map +1 -0
  401. package/dist/common/interactive/select/select.js +184 -0
  402. package/dist/common/interactive/select/select.js.map +1 -0
  403. package/dist/common/interactive/select/select.mjs +162 -0
  404. package/dist/common/interactive/select/select.mjs.map +1 -0
  405. package/dist/common/interactive/select/types.d.ts +213 -0
  406. package/dist/common/interactive/select/types.d.ts.map +1 -0
  407. package/dist/common/interactive/select/types.js +4 -0
  408. package/dist/common/interactive/select/types.js.map +1 -0
  409. package/dist/common/interactive/select/types.mjs +3 -0
  410. package/dist/common/interactive/select/types.mjs.map +1 -0
  411. package/dist/common/interactive/select/utils.d.ts +8 -0
  412. package/dist/common/interactive/select/utils.d.ts.map +1 -0
  413. package/dist/common/interactive/select/utils.js +31 -0
  414. package/dist/common/interactive/select/utils.js.map +1 -0
  415. package/dist/common/interactive/select/utils.mjs +28 -0
  416. package/dist/common/interactive/select/utils.mjs.map +1 -0
  417. package/dist/common/interactive/select/variants.d.ts +4 -0
  418. package/dist/common/interactive/select/variants.d.ts.map +1 -0
  419. package/dist/common/interactive/select/variants.js +27 -0
  420. package/dist/common/interactive/select/variants.js.map +1 -0
  421. package/dist/common/interactive/select/variants.mjs +25 -0
  422. package/dist/common/interactive/select/variants.mjs.map +1 -0
  423. package/dist/common/interactive/select-chip.d.ts +20 -0
  424. package/dist/common/interactive/select-chip.d.ts.map +1 -0
  425. package/dist/common/interactive/select-chip.js +76 -0
  426. package/dist/common/interactive/select-chip.js.map +1 -0
  427. package/dist/common/interactive/select-chip.mjs +74 -0
  428. package/dist/common/interactive/select-chip.mjs.map +1 -0
  429. package/dist/common/interactive/select-level.d.ts +19 -0
  430. package/dist/common/interactive/select-level.d.ts.map +1 -0
  431. package/dist/common/interactive/select-level.js +236 -0
  432. package/dist/common/interactive/select-level.js.map +1 -0
  433. package/dist/common/interactive/select-level.mjs +230 -0
  434. package/dist/common/interactive/select-level.mjs.map +1 -0
  435. package/dist/common/interactive/select-range.d.ts +30 -0
  436. package/dist/common/interactive/select-range.d.ts.map +1 -0
  437. package/dist/common/interactive/select-range.js +211 -0
  438. package/dist/common/interactive/select-range.js.map +1 -0
  439. package/dist/common/interactive/select-range.mjs +209 -0
  440. package/dist/common/interactive/select-range.mjs.map +1 -0
  441. package/dist/common/interactive/select-with-api.d.ts +97 -0
  442. package/dist/common/interactive/select-with-api.d.ts.map +1 -0
  443. package/dist/common/interactive/select-with-api.js +767 -0
  444. package/dist/common/interactive/select-with-api.js.map +1 -0
  445. package/dist/common/interactive/select-with-api.mjs +758 -0
  446. package/dist/common/interactive/select-with-api.mjs.map +1 -0
  447. package/dist/common/interactive/select.d.ts +3 -0
  448. package/dist/common/interactive/select.d.ts.map +1 -0
  449. package/dist/common/interactive/select.js +15 -0
  450. package/dist/common/interactive/select.js.map +1 -0
  451. package/dist/common/interactive/select.mjs +4 -0
  452. package/dist/common/interactive/select.mjs.map +1 -0
  453. package/dist/common/interactive/sheet-wrapper.d.ts +34 -0
  454. package/dist/common/interactive/sheet-wrapper.d.ts.map +1 -0
  455. package/dist/common/interactive/sheet-wrapper.js +105 -0
  456. package/dist/common/interactive/sheet-wrapper.js.map +1 -0
  457. package/dist/common/interactive/sheet-wrapper.mjs +83 -0
  458. package/dist/common/interactive/sheet-wrapper.mjs.map +1 -0
  459. package/dist/common/interactive/table/enhanced-table.d.ts +5 -0
  460. package/dist/common/interactive/table/enhanced-table.d.ts.map +1 -0
  461. package/dist/common/interactive/table/enhanced-table.js +390 -0
  462. package/dist/common/interactive/table/enhanced-table.js.map +1 -0
  463. package/dist/common/interactive/table/enhanced-table.mjs +388 -0
  464. package/dist/common/interactive/table/enhanced-table.mjs.map +1 -0
  465. package/dist/common/interactive/table/index.d.ts +10 -0
  466. package/dist/common/interactive/table/index.d.ts.map +1 -0
  467. package/dist/common/interactive/table/index.js +83 -0
  468. package/dist/common/interactive/table/index.js.map +1 -0
  469. package/dist/common/interactive/table/index.mjs +68 -0
  470. package/dist/common/interactive/table/index.mjs.map +1 -0
  471. package/dist/common/interactive/table/table-pagination.d.ts +5 -0
  472. package/dist/common/interactive/table/table-pagination.d.ts.map +1 -0
  473. package/dist/common/interactive/table/table-pagination.js +12 -0
  474. package/dist/common/interactive/table/table-pagination.js.map +1 -0
  475. package/dist/common/interactive/table/table-pagination.mjs +10 -0
  476. package/dist/common/interactive/table/table-pagination.mjs.map +1 -0
  477. package/dist/common/interactive/table/types.d.ts +54 -0
  478. package/dist/common/interactive/table/types.d.ts.map +1 -0
  479. package/dist/common/interactive/table/types.js +4 -0
  480. package/dist/common/interactive/table/types.js.map +1 -0
  481. package/dist/common/interactive/table/types.mjs +3 -0
  482. package/dist/common/interactive/table/types.mjs.map +1 -0
  483. package/dist/common/interactive/time-picker.d.ts +74 -0
  484. package/dist/common/interactive/time-picker.d.ts.map +1 -0
  485. package/dist/common/interactive/time-picker.js +313 -0
  486. package/dist/common/interactive/time-picker.js.map +1 -0
  487. package/dist/common/interactive/time-picker.mjs +307 -0
  488. package/dist/common/interactive/time-picker.mjs.map +1 -0
  489. package/dist/common/interactive/types.d.ts +2 -0
  490. package/dist/common/interactive/types.d.ts.map +1 -0
  491. package/dist/common/interactive/types.js +4 -0
  492. package/dist/common/interactive/types.js.map +1 -0
  493. package/dist/common/interactive/types.mjs +3 -0
  494. package/dist/common/interactive/types.mjs.map +1 -0
  495. package/dist/common/pages/page-404.d.ts +3 -0
  496. package/dist/common/pages/page-404.d.ts.map +1 -0
  497. package/dist/common/pages/page-404.js +16 -0
  498. package/dist/common/pages/page-404.js.map +1 -0
  499. package/dist/common/pages/page-404.mjs +11 -0
  500. package/dist/common/pages/page-404.mjs.map +1 -0
  501. package/dist/common/pages/page-500.d.ts +9 -0
  502. package/dist/common/pages/page-500.d.ts.map +1 -0
  503. package/dist/common/pages/page-500.js +30 -0
  504. package/dist/common/pages/page-500.js.map +1 -0
  505. package/dist/common/pages/page-500.mjs +25 -0
  506. package/dist/common/pages/page-500.mjs.map +1 -0
  507. package/dist/components/accordion.d.ts +8 -0
  508. package/dist/components/accordion.d.ts.map +1 -0
  509. package/dist/components/accordion.js +65 -0
  510. package/dist/components/accordion.js.map +1 -0
  511. package/dist/components/accordion.mjs +39 -0
  512. package/dist/components/accordion.mjs.map +1 -0
  513. package/dist/components/alert-dialog.d.ts +33 -0
  514. package/dist/components/alert-dialog.d.ts.map +1 -0
  515. package/dist/components/alert-dialog.js +231 -0
  516. package/dist/components/alert-dialog.js.map +1 -0
  517. package/dist/components/alert-dialog.mjs +197 -0
  518. package/dist/components/alert-dialog.mjs.map +1 -0
  519. package/dist/components/alert.d.ts +13 -0
  520. package/dist/components/alert.d.ts.map +1 -0
  521. package/dist/components/alert.js +97 -0
  522. package/dist/components/alert.js.map +1 -0
  523. package/dist/components/alert.mjs +72 -0
  524. package/dist/components/alert.mjs.map +1 -0
  525. package/dist/components/aspect-ratio.d.ts +4 -0
  526. package/dist/components/aspect-ratio.d.ts.map +1 -0
  527. package/dist/components/aspect-ratio.js +29 -0
  528. package/dist/components/aspect-ratio.js.map +1 -0
  529. package/dist/components/aspect-ratio.mjs +7 -0
  530. package/dist/components/aspect-ratio.mjs.map +1 -0
  531. package/dist/components/avatar.d.ts +7 -0
  532. package/dist/components/avatar.d.ts.map +1 -0
  533. package/dist/components/avatar.js +64 -0
  534. package/dist/components/avatar.js.map +1 -0
  535. package/dist/components/avatar.mjs +39 -0
  536. package/dist/components/avatar.mjs.map +1 -0
  537. package/dist/components/badge.d.ts +12 -0
  538. package/dist/components/badge.d.ts.map +1 -0
  539. package/dist/components/badge.js +72 -0
  540. package/dist/components/badge.js.map +1 -0
  541. package/dist/components/badge.mjs +69 -0
  542. package/dist/components/badge.mjs.map +1 -0
  543. package/dist/components/breadcrumb.d.ts +20 -0
  544. package/dist/components/breadcrumb.d.ts.map +1 -0
  545. package/dist/components/breadcrumb.js +109 -0
  546. package/dist/components/breadcrumb.js.map +1 -0
  547. package/dist/components/breadcrumb.mjs +81 -0
  548. package/dist/components/breadcrumb.mjs.map +1 -0
  549. package/dist/components/button.d.ts +28 -0
  550. package/dist/components/button.d.ts.map +1 -0
  551. package/dist/components/button.js +250 -0
  552. package/dist/components/button.js.map +1 -0
  553. package/dist/components/button.mjs +226 -0
  554. package/dist/components/button.mjs.map +1 -0
  555. package/dist/components/calendar.d.ts +57 -0
  556. package/dist/components/calendar.d.ts.map +1 -0
  557. package/dist/components/calendar.js +681 -0
  558. package/dist/components/calendar.js.map +1 -0
  559. package/dist/components/calendar.mjs +659 -0
  560. package/dist/components/calendar.mjs.map +1 -0
  561. package/dist/components/card.d.ts +12 -0
  562. package/dist/components/card.d.ts.map +1 -0
  563. package/dist/components/card.js +98 -0
  564. package/dist/components/card.js.map +1 -0
  565. package/dist/components/card.mjs +71 -0
  566. package/dist/components/card.mjs.map +1 -0
  567. package/dist/components/carousel.d.ts +23 -0
  568. package/dist/components/carousel.d.ts.map +1 -0
  569. package/dist/components/carousel.js +237 -0
  570. package/dist/components/carousel.js.map +1 -0
  571. package/dist/components/carousel.mjs +208 -0
  572. package/dist/components/carousel.mjs.map +1 -0
  573. package/dist/components/chart.d.ts +63 -0
  574. package/dist/components/chart.d.ts.map +1 -0
  575. package/dist/components/chart.js +252 -0
  576. package/dist/components/chart.js.map +1 -0
  577. package/dist/components/chart.mjs +224 -0
  578. package/dist/components/chart.mjs.map +1 -0
  579. package/dist/components/checkbox.d.ts +18 -0
  580. package/dist/components/checkbox.d.ts.map +1 -0
  581. package/dist/components/checkbox.js +97 -0
  582. package/dist/components/checkbox.js.map +1 -0
  583. package/dist/components/checkbox.mjs +74 -0
  584. package/dist/components/checkbox.mjs.map +1 -0
  585. package/dist/components/chip.d.ts +30 -0
  586. package/dist/components/chip.d.ts.map +1 -0
  587. package/dist/components/chip.js +88 -0
  588. package/dist/components/chip.js.map +1 -0
  589. package/dist/components/chip.mjs +82 -0
  590. package/dist/components/chip.mjs.map +1 -0
  591. package/dist/components/collapsible.d.ts +6 -0
  592. package/dist/components/collapsible.d.ts.map +1 -0
  593. package/dist/components/collapsible.js +33 -0
  594. package/dist/components/collapsible.js.map +1 -0
  595. package/dist/components/collapsible.mjs +9 -0
  596. package/dist/components/collapsible.mjs.map +1 -0
  597. package/dist/components/command.d.ts +81 -0
  598. package/dist/components/command.d.ts.map +1 -0
  599. package/dist/components/command.js +125 -0
  600. package/dist/components/command.js.map +1 -0
  601. package/dist/components/command.mjs +95 -0
  602. package/dist/components/command.mjs.map +1 -0
  603. package/dist/components/context-menu.d.ts +28 -0
  604. package/dist/components/context-menu.d.ts.map +1 -0
  605. package/dist/components/context-menu.js +168 -0
  606. package/dist/components/context-menu.js.map +1 -0
  607. package/dist/components/context-menu.mjs +131 -0
  608. package/dist/components/context-menu.mjs.map +1 -0
  609. package/dist/components/dialog.d.ts +32 -0
  610. package/dist/components/dialog.d.ts.map +1 -0
  611. package/dist/components/dialog.js +192 -0
  612. package/dist/components/dialog.js.map +1 -0
  613. package/dist/components/dialog.mjs +159 -0
  614. package/dist/components/dialog.mjs.map +1 -0
  615. package/dist/components/drawer.d.ts +23 -0
  616. package/dist/components/drawer.d.ts.map +1 -0
  617. package/dist/components/drawer.js +98 -0
  618. package/dist/components/drawer.js.map +1 -0
  619. package/dist/components/drawer.mjs +67 -0
  620. package/dist/components/drawer.mjs.map +1 -0
  621. package/dist/components/dropdown-menu.d.ts +28 -0
  622. package/dist/components/dropdown-menu.d.ts.map +1 -0
  623. package/dist/components/dropdown-menu.js +163 -0
  624. package/dist/components/dropdown-menu.js.map +1 -0
  625. package/dist/components/dropdown-menu.mjs +126 -0
  626. package/dist/components/dropdown-menu.mjs.map +1 -0
  627. package/dist/components/form.d.ts +24 -0
  628. package/dist/components/form.d.ts.map +1 -0
  629. package/dist/components/form.js +123 -0
  630. package/dist/components/form.js.map +1 -0
  631. package/dist/components/form.mjs +94 -0
  632. package/dist/components/form.mjs.map +1 -0
  633. package/dist/components/hover-card.d.ts +7 -0
  634. package/dist/components/hover-card.d.ts.map +1 -0
  635. package/dist/components/hover-card.js +50 -0
  636. package/dist/components/hover-card.js.map +1 -0
  637. package/dist/components/hover-card.mjs +25 -0
  638. package/dist/components/hover-card.mjs.map +1 -0
  639. package/dist/components/input-otp.d.ts +39 -0
  640. package/dist/components/input-otp.d.ts.map +1 -0
  641. package/dist/components/input-otp.js +84 -0
  642. package/dist/components/input-otp.js.map +1 -0
  643. package/dist/components/input-otp.mjs +59 -0
  644. package/dist/components/input-otp.mjs.map +1 -0
  645. package/dist/components/input.d.ts +150 -0
  646. package/dist/components/input.d.ts.map +1 -0
  647. package/dist/components/input.js +858 -0
  648. package/dist/components/input.js.map +1 -0
  649. package/dist/components/input.mjs +831 -0
  650. package/dist/components/input.mjs.map +1 -0
  651. package/dist/components/label.d.ts +6 -0
  652. package/dist/components/label.d.ts.map +1 -0
  653. package/dist/components/label.js +38 -0
  654. package/dist/components/label.js.map +1 -0
  655. package/dist/components/label.mjs +15 -0
  656. package/dist/components/label.mjs.map +1 -0
  657. package/dist/components/lottie.d.ts +63 -0
  658. package/dist/components/lottie.d.ts.map +1 -0
  659. package/dist/components/lottie.js +59 -0
  660. package/dist/components/lottie.js.map +1 -0
  661. package/dist/components/lottie.mjs +49 -0
  662. package/dist/components/lottie.mjs.map +1 -0
  663. package/dist/components/menubar.d.ts +29 -0
  664. package/dist/components/menubar.d.ts.map +1 -0
  665. package/dist/components/menubar.js +195 -0
  666. package/dist/components/menubar.js.map +1 -0
  667. package/dist/components/menubar.mjs +157 -0
  668. package/dist/components/menubar.mjs.map +1 -0
  669. package/dist/components/navigation-menu.d.ts +13 -0
  670. package/dist/components/navigation-menu.d.ts.map +1 -0
  671. package/dist/components/navigation-menu.js +126 -0
  672. package/dist/components/navigation-menu.js.map +1 -0
  673. package/dist/components/navigation-menu.mjs +95 -0
  674. package/dist/components/navigation-menu.mjs.map +1 -0
  675. package/dist/components/pagination.d.ts +29 -0
  676. package/dist/components/pagination.d.ts.map +1 -0
  677. package/dist/components/pagination.js +112 -0
  678. package/dist/components/pagination.js.map +1 -0
  679. package/dist/components/pagination.mjs +84 -0
  680. package/dist/components/pagination.mjs.map +1 -0
  681. package/dist/components/popover.d.ts +7 -0
  682. package/dist/components/popover.d.ts.map +1 -0
  683. package/dist/components/popover.js +63 -0
  684. package/dist/components/popover.js.map +1 -0
  685. package/dist/components/popover.mjs +38 -0
  686. package/dist/components/popover.mjs.map +1 -0
  687. package/dist/components/progress.d.ts +7 -0
  688. package/dist/components/progress.d.ts.map +1 -0
  689. package/dist/components/progress.js +50 -0
  690. package/dist/components/progress.js.map +1 -0
  691. package/dist/components/progress.mjs +27 -0
  692. package/dist/components/progress.mjs.map +1 -0
  693. package/dist/components/radio-group.d.ts +17 -0
  694. package/dist/components/radio-group.d.ts.map +1 -0
  695. package/dist/components/radio-group.js +91 -0
  696. package/dist/components/radio-group.js.map +1 -0
  697. package/dist/components/radio-group.mjs +67 -0
  698. package/dist/components/radio-group.mjs.map +1 -0
  699. package/dist/components/resizable.d.ts +24 -0
  700. package/dist/components/resizable.d.ts.map +1 -0
  701. package/dist/components/resizable.js +59 -0
  702. package/dist/components/resizable.js.map +1 -0
  703. package/dist/components/resizable.mjs +35 -0
  704. package/dist/components/resizable.mjs.map +1 -0
  705. package/dist/components/responsive-popover.d.ts +25 -0
  706. package/dist/components/responsive-popover.d.ts.map +1 -0
  707. package/dist/components/responsive-popover.js +74 -0
  708. package/dist/components/responsive-popover.js.map +1 -0
  709. package/dist/components/responsive-popover.mjs +50 -0
  710. package/dist/components/responsive-popover.mjs.map +1 -0
  711. package/dist/components/scroll-area.d.ts +6 -0
  712. package/dist/components/scroll-area.d.ts.map +1 -0
  713. package/dist/components/scroll-area.js +63 -0
  714. package/dist/components/scroll-area.js.map +1 -0
  715. package/dist/components/scroll-area.mjs +39 -0
  716. package/dist/components/scroll-area.mjs.map +1 -0
  717. package/dist/components/separator.d.ts +5 -0
  718. package/dist/components/separator.d.ts.map +1 -0
  719. package/dist/components/separator.js +47 -0
  720. package/dist/components/separator.js.map +1 -0
  721. package/dist/components/separator.mjs +24 -0
  722. package/dist/components/separator.mjs.map +1 -0
  723. package/dist/components/sheet.d.ts +29 -0
  724. package/dist/components/sheet.d.ts.map +1 -0
  725. package/dist/components/sheet.js +239 -0
  726. package/dist/components/sheet.js.map +1 -0
  727. package/dist/components/sheet.mjs +206 -0
  728. package/dist/components/sheet.mjs.map +1 -0
  729. package/dist/components/sidebar.d.ts +87 -0
  730. package/dist/components/sidebar.d.ts.map +1 -0
  731. package/dist/components/sidebar.js +888 -0
  732. package/dist/components/sidebar.js.map +1 -0
  733. package/dist/components/sidebar.mjs +842 -0
  734. package/dist/components/sidebar.mjs.map +1 -0
  735. package/dist/components/skeleton.d.ts +36 -0
  736. package/dist/components/skeleton.d.ts.map +1 -0
  737. package/dist/components/skeleton.js +153 -0
  738. package/dist/components/skeleton.js.map +1 -0
  739. package/dist/components/skeleton.mjs +127 -0
  740. package/dist/components/skeleton.mjs.map +1 -0
  741. package/dist/components/slider.d.ts +5 -0
  742. package/dist/components/slider.d.ts.map +1 -0
  743. package/dist/components/slider.js +45 -0
  744. package/dist/components/slider.js.map +1 -0
  745. package/dist/components/slider.mjs +22 -0
  746. package/dist/components/slider.mjs.map +1 -0
  747. package/dist/components/sonner.d.ts +4 -0
  748. package/dist/components/sonner.d.ts.map +1 -0
  749. package/dist/components/sonner.js +76 -0
  750. package/dist/components/sonner.js.map +1 -0
  751. package/dist/components/sonner.mjs +71 -0
  752. package/dist/components/sonner.mjs.map +1 -0
  753. package/dist/components/spinner.d.ts +11 -0
  754. package/dist/components/spinner.d.ts.map +1 -0
  755. package/dist/components/spinner.js +59 -0
  756. package/dist/components/spinner.js.map +1 -0
  757. package/dist/components/spinner.mjs +36 -0
  758. package/dist/components/spinner.mjs.map +1 -0
  759. package/dist/components/stepper.d.ts +114 -0
  760. package/dist/components/stepper.d.ts.map +1 -0
  761. package/dist/components/stepper.js +726 -0
  762. package/dist/components/stepper.js.map +1 -0
  763. package/dist/components/stepper.mjs +702 -0
  764. package/dist/components/stepper.mjs.map +1 -0
  765. package/dist/components/switch.d.ts +16 -0
  766. package/dist/components/switch.d.ts.map +1 -0
  767. package/dist/components/switch.js +85 -0
  768. package/dist/components/switch.js.map +1 -0
  769. package/dist/components/switch.mjs +62 -0
  770. package/dist/components/switch.mjs.map +1 -0
  771. package/dist/components/table.d.ts +11 -0
  772. package/dist/components/table.d.ts.map +1 -0
  773. package/dist/components/table.js +91 -0
  774. package/dist/components/table.js.map +1 -0
  775. package/dist/components/table.mjs +62 -0
  776. package/dist/components/table.mjs.map +1 -0
  777. package/dist/components/tabs.d.ts +32 -0
  778. package/dist/components/tabs.d.ts.map +1 -0
  779. package/dist/components/tabs.js +287 -0
  780. package/dist/components/tabs.js.map +1 -0
  781. package/dist/components/tabs.mjs +261 -0
  782. package/dist/components/tabs.mjs.map +1 -0
  783. package/dist/components/textarea.d.ts +21 -0
  784. package/dist/components/textarea.d.ts.map +1 -0
  785. package/dist/components/textarea.js +200 -0
  786. package/dist/components/textarea.js.map +1 -0
  787. package/dist/components/textarea.mjs +174 -0
  788. package/dist/components/textarea.mjs.map +1 -0
  789. package/dist/components/toggle-group.d.ts +13 -0
  790. package/dist/components/toggle-group.d.ts.map +1 -0
  791. package/dist/components/toggle-group.js +67 -0
  792. package/dist/components/toggle-group.js.map +1 -0
  793. package/dist/components/toggle-group.mjs +43 -0
  794. package/dist/components/toggle-group.mjs.map +1 -0
  795. package/dist/components/toggle.d.ts +13 -0
  796. package/dist/components/toggle.d.ts.map +1 -0
  797. package/dist/components/toggle.js +63 -0
  798. package/dist/components/toggle.js.map +1 -0
  799. package/dist/components/toggle.mjs +39 -0
  800. package/dist/components/toggle.mjs.map +1 -0
  801. package/dist/components/tooltip.d.ts +31 -0
  802. package/dist/components/tooltip.d.ts.map +1 -0
  803. package/dist/components/tooltip.js +172 -0
  804. package/dist/components/tooltip.js.map +1 -0
  805. package/dist/components/tooltip.mjs +145 -0
  806. package/dist/components/tooltip.mjs.map +1 -0
  807. package/dist/globals.css +1179 -0
  808. package/dist/hooks/index.d.ts +6 -0
  809. package/dist/hooks/index.d.ts.map +1 -0
  810. package/dist/hooks/index.js +27 -0
  811. package/dist/hooks/index.js.map +1 -0
  812. package/dist/hooks/index.mjs +6 -0
  813. package/dist/hooks/index.mjs.map +1 -0
  814. package/dist/hooks/useCopyToClipboard.d.ts +26 -0
  815. package/dist/hooks/useCopyToClipboard.d.ts.map +1 -0
  816. package/dist/hooks/useCopyToClipboard.js +59 -0
  817. package/dist/hooks/useCopyToClipboard.js.map +1 -0
  818. package/dist/hooks/useCopyToClipboard.mjs +57 -0
  819. package/dist/hooks/useCopyToClipboard.mjs.map +1 -0
  820. package/dist/hooks/useDevice.d.ts +7 -0
  821. package/dist/hooks/useDevice.d.ts.map +1 -0
  822. package/dist/hooks/useDevice.js +20 -0
  823. package/dist/hooks/useDevice.js.map +1 -0
  824. package/dist/hooks/useDevice.mjs +14 -0
  825. package/dist/hooks/useDevice.mjs.map +1 -0
  826. package/dist/hooks/useDialogTracking.d.ts +17 -0
  827. package/dist/hooks/useDialogTracking.d.ts.map +1 -0
  828. package/dist/hooks/useDialogTracking.js +113 -0
  829. package/dist/hooks/useDialogTracking.js.map +1 -0
  830. package/dist/hooks/useDialogTracking.mjs +91 -0
  831. package/dist/hooks/useDialogTracking.mjs.map +1 -0
  832. package/dist/hooks/useIsMounted.d.ts +8 -0
  833. package/dist/hooks/useIsMounted.d.ts.map +1 -0
  834. package/dist/hooks/useIsMounted.js +15 -0
  835. package/dist/hooks/useIsMounted.js.map +1 -0
  836. package/dist/hooks/useIsMounted.mjs +13 -0
  837. package/dist/hooks/useIsMounted.mjs.map +1 -0
  838. package/dist/hooks/usePathname.d.ts +20 -0
  839. package/dist/hooks/usePathname.d.ts.map +1 -0
  840. package/dist/hooks/usePathname.js +85 -0
  841. package/dist/hooks/usePathname.js.map +1 -0
  842. package/dist/hooks/usePathname.mjs +83 -0
  843. package/dist/hooks/usePathname.mjs.map +1 -0
  844. package/dist/icons.d.ts +2 -0
  845. package/dist/icons.d.ts.map +1 -0
  846. package/dist/icons.js +14 -0
  847. package/dist/icons.js.map +1 -0
  848. package/dist/icons.mjs +3 -0
  849. package/dist/icons.mjs.map +1 -0
  850. package/dist/lib/formatCurrency.d.ts +106 -0
  851. package/dist/lib/formatCurrency.d.ts.map +1 -0
  852. package/dist/lib/formatCurrency.js +187 -0
  853. package/dist/lib/formatCurrency.js.map +1 -0
  854. package/dist/lib/formatCurrency.mjs +185 -0
  855. package/dist/lib/formatCurrency.mjs.map +1 -0
  856. package/dist/lib/helpers.d.ts +64 -0
  857. package/dist/lib/helpers.d.ts.map +1 -0
  858. package/dist/lib/helpers.js +171 -0
  859. package/dist/lib/helpers.js.map +1 -0
  860. package/dist/lib/helpers.mjs +157 -0
  861. package/dist/lib/helpers.mjs.map +1 -0
  862. package/dist/lib/index.d.ts +6 -0
  863. package/dist/lib/index.d.ts.map +1 -0
  864. package/dist/lib/index.js +33 -0
  865. package/dist/lib/index.js.map +1 -0
  866. package/dist/lib/index.mjs +6 -0
  867. package/dist/lib/index.mjs.map +1 -0
  868. package/dist/lib/types.d.ts +37 -0
  869. package/dist/lib/types.d.ts.map +1 -0
  870. package/dist/lib/types.js +11 -0
  871. package/dist/lib/types.js.map +1 -0
  872. package/dist/lib/types.mjs +9 -0
  873. package/dist/lib/types.mjs.map +1 -0
  874. package/dist/lib/utils.d.ts +4 -0
  875. package/dist/lib/utils.d.ts.map +1 -0
  876. package/dist/lib/utils.js +24 -0
  877. package/dist/lib/utils.js.map +1 -0
  878. package/dist/lib/utils.mjs +19 -0
  879. package/dist/lib/utils.mjs.map +1 -0
  880. package/dist/providers/DeviceSizeWatcher/index.d.ts +3 -0
  881. package/dist/providers/DeviceSizeWatcher/index.d.ts.map +1 -0
  882. package/dist/providers/DeviceSizeWatcher/index.js +72 -0
  883. package/dist/providers/DeviceSizeWatcher/index.js.map +1 -0
  884. package/dist/providers/DeviceSizeWatcher/index.mjs +47 -0
  885. package/dist/providers/DeviceSizeWatcher/index.mjs.map +1 -0
  886. package/dist/providers/DeviceSizeWatcher/useDeviceSizeStore.d.ts +13 -0
  887. package/dist/providers/DeviceSizeWatcher/useDeviceSizeStore.d.ts.map +1 -0
  888. package/dist/providers/DeviceSizeWatcher/useDeviceSizeStore.js +22 -0
  889. package/dist/providers/DeviceSizeWatcher/useDeviceSizeStore.js.map +1 -0
  890. package/dist/providers/DeviceSizeWatcher/useDeviceSizeStore.mjs +20 -0
  891. package/dist/providers/DeviceSizeWatcher/useDeviceSizeStore.mjs.map +1 -0
  892. package/dist/providers/UISystemProvider.d.ts +68 -0
  893. package/dist/providers/UISystemProvider.d.ts.map +1 -0
  894. package/dist/providers/UISystemProvider.js +197 -0
  895. package/dist/providers/UISystemProvider.js.map +1 -0
  896. package/dist/providers/UISystemProvider.mjs +188 -0
  897. package/dist/providers/UISystemProvider.mjs.map +1 -0
  898. package/dist/providers/index.d.ts +3 -0
  899. package/dist/providers/index.d.ts.map +1 -0
  900. package/dist/providers/index.js +24 -0
  901. package/dist/providers/index.js.map +1 -0
  902. package/dist/providers/index.mjs +3 -0
  903. package/dist/providers/index.mjs.map +1 -0
  904. package/dist/theme.d.ts +10 -0
  905. package/dist/theme.d.ts.map +1 -0
  906. package/dist/theme.js +333 -0
  907. package/dist/theme.js.map +1 -0
  908. package/dist/theme.mjs +327 -0
  909. package/dist/theme.mjs.map +1 -0
  910. package/package.json +252 -0
  911. package/postcss.config.mjs +6 -0
  912. package/tailwind.config.ts +350 -0
@@ -0,0 +1,178 @@
1
+ 'use strict';
2
+
3
+ var jsxRuntime = require('react/jsx-runtime');
4
+ var cmdk = require('cmdk');
5
+ var React = require('react');
6
+ var command = require('@/components/command');
7
+ var input = require('@/components/input');
8
+ var popover = require('@/components/popover');
9
+ var skeleton = require('@/components/skeleton');
10
+ var utils = require('@/lib/utils');
11
+
12
+ function _interopNamespace(e) {
13
+ if (e && e.__esModule) return e;
14
+ var n = Object.create(null);
15
+ if (e) {
16
+ Object.keys(e).forEach(function (k) {
17
+ if (k !== 'default') {
18
+ var d = Object.getOwnPropertyDescriptor(e, k);
19
+ Object.defineProperty(n, k, d.get ? d : {
20
+ enumerable: true,
21
+ get: function () { return e[k]; }
22
+ });
23
+ }
24
+ });
25
+ }
26
+ n.default = e;
27
+ return Object.freeze(n);
28
+ }
29
+
30
+ var React__namespace = /*#__PURE__*/_interopNamespace(React);
31
+
32
+ function AutoComplete({
33
+ label = "",
34
+ placeholder = "",
35
+ options,
36
+ searchApi,
37
+ value,
38
+ onInputChange,
39
+ onSelectChange,
40
+ children,
41
+ enableAddNewItem,
42
+ newItemOption,
43
+ renderOption,
44
+ className,
45
+ renderEmpty,
46
+ ...props
47
+ }) {
48
+ const triggerRef = React__namespace.useRef(null);
49
+ const [triggerWidth, setTriggerWidth] = React.useState();
50
+ const [open, setOpen] = React.useState(false);
51
+ const [isLoading, setIsLoading] = React.useState(false);
52
+ const [searchedOptions, setSearchedOptions] = React.useState([]);
53
+ const newItem = React.useMemo(() => newItemOption?.(value ?? ""), [newItemOption, value]);
54
+ React.useEffect(() => {
55
+ if (open) handleSearch(value);
56
+ if (triggerRef.current) {
57
+ setTriggerWidth(triggerRef.current.offsetWidth);
58
+ }
59
+ }, [open, value]);
60
+ const isPaginatedApi = (api) => {
61
+ return typeof api === "function" && api.length >= 2;
62
+ };
63
+ const handleSearch = async (searchValue) => {
64
+ if (!searchValue) {
65
+ setSearchedOptions([]);
66
+ } else if (searchApi) {
67
+ handleSearchApi(value, 1, 10);
68
+ } else if (options) {
69
+ handleSearchLocal(searchValue);
70
+ }
71
+ };
72
+ const handleSearchLocal = (searchValue) => {
73
+ if (searchValue && options && options?.length > 0) {
74
+ const resultOptions = [...options ?? []].filter(
75
+ // (option) => (option.name?.toLowerCase().search(searchValue.toLowerCase()) ?? -1) > -1,
76
+ (option) => option.name?.toLowerCase().normalize("NFD").replace(/[\u0300-\u036f]/g, "").includes(
77
+ searchValue.toLowerCase().normalize("NFD").replace(/[\u0300-\u036f]/g, "")
78
+ ) ?? false
79
+ );
80
+ setSearchedOptions(resultOptions);
81
+ } else if (options && options?.length > 0) {
82
+ setSearchedOptions([...options ?? []]);
83
+ }
84
+ };
85
+ const handleSearchApi = async (searchValue = "", page = 1, size = 10) => {
86
+ try {
87
+ setIsLoading(true);
88
+ if (isPaginatedApi(searchApi)) {
89
+ const res = await searchApi?.(searchValue, page, size);
90
+ const resultOptions = res?.data ?? [];
91
+ setSearchedOptions(resultOptions);
92
+ } else {
93
+ const resultOptions = await searchApi(searchValue);
94
+ setSearchedOptions(resultOptions);
95
+ }
96
+ } catch (error) {
97
+ } finally {
98
+ setIsLoading(false);
99
+ }
100
+ };
101
+ const handleSelectItem = (option) => {
102
+ onSelectChange?.(option);
103
+ setOpen(false);
104
+ };
105
+ return /* @__PURE__ */ jsxRuntime.jsx(popover.Popover, { open, onOpenChange: setOpen, children: /* @__PURE__ */ jsxRuntime.jsxs(command.Command, { shouldFilter: false, children: [
106
+ /* @__PURE__ */ jsxRuntime.jsx(popover.PopoverTrigger, { asChild: true, children: /* @__PURE__ */ jsxRuntime.jsx("div", { ref: triggerRef, children: /* @__PURE__ */ jsxRuntime.jsx(
107
+ cmdk.Command.Input,
108
+ {
109
+ ...props,
110
+ asChild: true,
111
+ value,
112
+ onValueChange: onInputChange,
113
+ placeholder,
114
+ onKeyDown: (e) => setOpen(e.key !== "Escape"),
115
+ children: children ?? /* @__PURE__ */ jsxRuntime.jsx(input.Input, { label })
116
+ }
117
+ ) }) }),
118
+ /* @__PURE__ */ jsxRuntime.jsx(
119
+ popover.PopoverContent,
120
+ {
121
+ asChild: true,
122
+ onOpenAutoFocus: (e) => e.preventDefault(),
123
+ onInteractOutside: (e) => {
124
+ if (e.target instanceof Element && e.target.hasAttribute("cmdk-input")) {
125
+ e.preventDefault();
126
+ }
127
+ },
128
+ className: "w-full min-w-[300px] p-0",
129
+ hidden: !value,
130
+ align: "start",
131
+ style: { width: triggerWidth },
132
+ children: /* @__PURE__ */ jsxRuntime.jsxs(command.CommandList, { children: [
133
+ isLoading && /* @__PURE__ */ jsxRuntime.jsx(cmdk.Command.Loading, { children: /* @__PURE__ */ jsxRuntime.jsx("div", { className: "space-y-2 p-3", children: new Array(5).fill(1).map((_item, index) => /* @__PURE__ */ jsxRuntime.jsx(skeleton.Skeleton, { className: "h-10 w-full" }, index)) }) }),
134
+ searchedOptions?.length > 0 && !isLoading && /* @__PURE__ */ jsxRuntime.jsx(command.CommandGroup, { className: "px-0 py-2", children: searchedOptions.map((option, index) => /* @__PURE__ */ jsxRuntime.jsx(
135
+ command.CommandItem,
136
+ {
137
+ value: option.value,
138
+ onMouseDown: (e) => e.preventDefault(),
139
+ onSelect: () => handleSelectItem(option),
140
+ className: utils.cn(
141
+ "text-t16m hover:!bg-accent data-[selected='true']:bg-accent rounded-none p-3",
142
+ index > 0 && "border-border border-t"
143
+ ),
144
+ children: renderOption ? renderOption(option) : option.name ?? option.value
145
+ },
146
+ option.value
147
+ )) }),
148
+ searchedOptions?.length === 0 && !isLoading && enableAddNewItem && newItem && /* @__PURE__ */ jsxRuntime.jsx(command.CommandGroup, { className: "px-0 py-2", children: [newItem].filter((o) => !!o).map((option, index) => /* @__PURE__ */ jsxRuntime.jsx(
149
+ command.CommandItem,
150
+ {
151
+ value: option.value,
152
+ onMouseDown: (e) => e.preventDefault(),
153
+ onSelect: () => handleSelectItem(option),
154
+ className: utils.cn(
155
+ "text-t16m hover:!bg-accent data-[selected='true']:bg-accent rounded-none px-3 py-4",
156
+ index > 0 && "border-border border-t"
157
+ ),
158
+ children: renderOption ? renderOption(option, true) : option.name ?? option.value
159
+ },
160
+ option.value
161
+ )) }),
162
+ searchedOptions?.length === 0 && !isLoading && !enableAddNewItem && /* @__PURE__ */ jsxRuntime.jsx(command.CommandGroup, { className: "px-0 py-2", children: /* @__PURE__ */ jsxRuntime.jsx(
163
+ command.CommandItem,
164
+ {
165
+ onMouseDown: (e) => e.preventDefault(),
166
+ className: utils.cn("!text-t16 !text-muted-foreground !bg-transparent px-3 py-4"),
167
+ children: renderEmpty ? renderEmpty() : /* @__PURE__ */ jsxRuntime.jsx("p", { children: "Kh\xF4ng c\xF3 th\xF4ng tin hi\u1EC3n th\u1ECB" })
168
+ }
169
+ ) })
170
+ ] })
171
+ }
172
+ )
173
+ ] }) });
174
+ }
175
+
176
+ exports.AutoComplete = AutoComplete;
177
+ //# sourceMappingURL=autocomplete.js.map
178
+ //# sourceMappingURL=autocomplete.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/common/interactive/autocomplete.tsx"],"names":["React","useState","useMemo","useEffect","jsx","Popover","jsxs","Command","PopoverTrigger","CommandPrimitive","Input","PopoverContent","CommandList","Skeleton","CommandGroup","CommandItem","cn"],"mappings":"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","file":"autocomplete.js","sourcesContent":["import { Command as CommandPrimitive } from 'cmdk';\nimport { useEffect, useMemo, useState } from 'react';\nimport { Command, CommandGroup, CommandItem, CommandList } from '@/components/command';\nimport { Input } from '@/components/input';\nimport { Popover, PopoverTrigger, PopoverContent } from '@/components/popover';\nimport { Skeleton } from '@/components/skeleton';\nimport { Option } from '@/common/interactive/select';\nimport {\n ApiSearchFunction,\n ApiSearchPaginatedFunction,\n} from '@/common/interactive/select-with-api';\nimport * as React from 'react';\nimport { cn } from '@/lib/utils';\n\ntype Props<T extends string> = {\n label?: string;\n placeholder?: string;\n options?: Option[];\n searchApi?: ApiSearchFunction<Option> | ApiSearchPaginatedFunction<Option>;\n value?: string;\n onInputChange?: (value?: string) => void;\n onSelectChange?: (value?: Option) => void;\n children?: React.ReactNode;\n enableAddNewItem?: boolean;\n newItemOption?: (value: string) => Option | null;\n renderOption?: (option: Option, isNewItem?: boolean) => React.ReactNode;\n renderEmpty?: () => React.ReactNode;\n className?: string;\n};\n\nexport function AutoComplete<T extends string>({\n label = '',\n placeholder = '',\n options,\n searchApi,\n value,\n onInputChange,\n onSelectChange,\n children,\n enableAddNewItem,\n newItemOption,\n renderOption,\n className,\n renderEmpty,\n ...props\n}: Props<T>) {\n const triggerRef = React.useRef<HTMLDivElement>(null);\n const [triggerWidth, setTriggerWidth] = useState<number>();\n const [open, setOpen] = useState(false);\n const [isLoading, setIsLoading] = useState(false);\n const [searchedOptions, setSearchedOptions] = useState<Option[]>([]);\n\n const newItem = useMemo(() => newItemOption?.(value ?? ''), [newItemOption, value]);\n\n useEffect(() => {\n if (open) handleSearch(value);\n\n if (triggerRef.current) {\n setTriggerWidth(triggerRef.current.offsetWidth);\n }\n }, [open, value]);\n\n const isPaginatedApi = (api: any): api is ApiSearchPaginatedFunction<Option> => {\n return typeof api === 'function' && api.length >= 2;\n };\n\n const handleSearch = async (searchValue?: string) => {\n if (!searchValue) {\n setSearchedOptions([]);\n } else if (searchApi) {\n handleSearchApi(value, 1, 10);\n } else if (options) {\n handleSearchLocal(searchValue);\n }\n };\n\n const handleSearchLocal = (searchValue?: string) => {\n if (searchValue && options && options?.length > 0) {\n const resultOptions = [...(options ?? [])].filter(\n // (option) => (option.name?.toLowerCase().search(searchValue.toLowerCase()) ?? -1) > -1,\n (option) =>\n option.name\n ?.toLowerCase()\n .normalize('NFD')\n .replace(/[\\u0300-\\u036f]/g, '')\n .includes(\n searchValue\n .toLowerCase()\n .normalize('NFD')\n .replace(/[\\u0300-\\u036f]/g, ''),\n ) ?? false,\n );\n\n setSearchedOptions(resultOptions);\n } else if (options && options?.length > 0) {\n setSearchedOptions([...(options ?? [])]);\n }\n };\n\n const handleSearchApi = async (searchValue: string = '', page: number = 1, size: number = 10) => {\n try {\n setIsLoading(true);\n if (isPaginatedApi(searchApi)) {\n const res = await searchApi?.(searchValue, page, size);\n const resultOptions = res?.data ?? [];\n setSearchedOptions(resultOptions);\n } else {\n const resultOptions = await (searchApi as ApiSearchFunction<Option>)(searchValue);\n setSearchedOptions(resultOptions);\n }\n } catch (error) {\n } finally {\n setIsLoading(false);\n }\n };\n\n const handleSelectItem = (option: Option) => {\n onSelectChange?.(option);\n setOpen(false);\n };\n\n return (\n <Popover open={open} onOpenChange={setOpen}>\n <Command shouldFilter={false}>\n <PopoverTrigger asChild>\n <div ref={triggerRef}>\n <CommandPrimitive.Input\n {...props}\n asChild\n value={value}\n onValueChange={onInputChange}\n placeholder={placeholder}\n onKeyDown={(e) => setOpen(e.key !== 'Escape')}\n >\n {children ?? <Input label={label} />}\n </CommandPrimitive.Input>\n </div>\n </PopoverTrigger>\n\n <PopoverContent\n asChild\n onOpenAutoFocus={(e) => e.preventDefault()}\n onInteractOutside={(e) => {\n if (e.target instanceof Element && e.target.hasAttribute('cmdk-input')) {\n e.preventDefault();\n }\n }}\n className=\"w-full min-w-[300px] p-0\"\n // hidden={\n // // (!searchedOptions || searchedOptions?.length == 0) &&\n // // (!enableAddNewItem || !value || !newItem) &&\n // // !isLoading\n // }\n hidden={!value}\n align=\"start\"\n style={{ width: triggerWidth }}\n >\n <CommandList>\n {isLoading && (\n <CommandPrimitive.Loading>\n <div className=\"space-y-2 p-3\">\n {new Array(5).fill(1).map((_item, index) => (\n <Skeleton className=\"h-10 w-full\" key={index} />\n ))}\n </div>\n </CommandPrimitive.Loading>\n )}\n\n {searchedOptions?.length > 0 && !isLoading && (\n <CommandGroup className=\"px-0 py-2\">\n {searchedOptions.map((option, index: number) => (\n <CommandItem\n key={option.value}\n value={option.value}\n onMouseDown={(e) => e.preventDefault()}\n onSelect={() => handleSelectItem(option)}\n className={cn(\n \"text-t16m hover:!bg-accent data-[selected='true']:bg-accent rounded-none p-3\",\n index > 0 && 'border-border border-t',\n )}\n >\n {renderOption ? renderOption(option) : (option.name ?? option.value)}\n </CommandItem>\n ))}\n </CommandGroup>\n )}\n\n {searchedOptions?.length === 0 && !isLoading && enableAddNewItem && newItem && (\n <CommandGroup className=\"px-0 py-2\">\n {[newItem]\n .filter((o) => !!o)\n .map((option, index: number) => (\n <CommandItem\n key={option.value}\n value={option.value}\n onMouseDown={(e) => e.preventDefault()}\n onSelect={() => handleSelectItem(option)}\n className={cn(\n \"text-t16m hover:!bg-accent data-[selected='true']:bg-accent rounded-none px-3 py-4\",\n index > 0 && 'border-border border-t',\n )}\n >\n {renderOption ? renderOption(option, true) : (option.name ?? option.value)}\n </CommandItem>\n ))}\n </CommandGroup>\n )}\n\n {searchedOptions?.length === 0 && !isLoading && !enableAddNewItem && (\n <CommandGroup className=\"px-0 py-2\">\n <CommandItem\n onMouseDown={(e) => e.preventDefault()}\n className={cn('!text-t16 !text-muted-foreground !bg-transparent px-3 py-4')}\n >\n {renderEmpty ? renderEmpty() : <p>Không có thông tin hiển thị</p>}\n </CommandItem>\n </CommandGroup>\n )}\n </CommandList>\n </PopoverContent>\n </Command>\n </Popover>\n );\n}\n"]}
@@ -0,0 +1,157 @@
1
+ import { jsx, jsxs } from 'react/jsx-runtime';
2
+ import { Command as Command$1 } from 'cmdk';
3
+ import * as React from 'react';
4
+ import { useState, useMemo, useEffect } from 'react';
5
+ import { Command, CommandList, CommandGroup, CommandItem } from '@/components/command';
6
+ import { Input } from '@/components/input';
7
+ import { Popover, PopoverTrigger, PopoverContent } from '@/components/popover';
8
+ import { Skeleton } from '@/components/skeleton';
9
+ import { cn } from '@/lib/utils';
10
+
11
+ function AutoComplete({
12
+ label = "",
13
+ placeholder = "",
14
+ options,
15
+ searchApi,
16
+ value,
17
+ onInputChange,
18
+ onSelectChange,
19
+ children,
20
+ enableAddNewItem,
21
+ newItemOption,
22
+ renderOption,
23
+ className,
24
+ renderEmpty,
25
+ ...props
26
+ }) {
27
+ const triggerRef = React.useRef(null);
28
+ const [triggerWidth, setTriggerWidth] = useState();
29
+ const [open, setOpen] = useState(false);
30
+ const [isLoading, setIsLoading] = useState(false);
31
+ const [searchedOptions, setSearchedOptions] = useState([]);
32
+ const newItem = useMemo(() => newItemOption?.(value ?? ""), [newItemOption, value]);
33
+ useEffect(() => {
34
+ if (open) handleSearch(value);
35
+ if (triggerRef.current) {
36
+ setTriggerWidth(triggerRef.current.offsetWidth);
37
+ }
38
+ }, [open, value]);
39
+ const isPaginatedApi = (api) => {
40
+ return typeof api === "function" && api.length >= 2;
41
+ };
42
+ const handleSearch = async (searchValue) => {
43
+ if (!searchValue) {
44
+ setSearchedOptions([]);
45
+ } else if (searchApi) {
46
+ handleSearchApi(value, 1, 10);
47
+ } else if (options) {
48
+ handleSearchLocal(searchValue);
49
+ }
50
+ };
51
+ const handleSearchLocal = (searchValue) => {
52
+ if (searchValue && options && options?.length > 0) {
53
+ const resultOptions = [...options ?? []].filter(
54
+ // (option) => (option.name?.toLowerCase().search(searchValue.toLowerCase()) ?? -1) > -1,
55
+ (option) => option.name?.toLowerCase().normalize("NFD").replace(/[\u0300-\u036f]/g, "").includes(
56
+ searchValue.toLowerCase().normalize("NFD").replace(/[\u0300-\u036f]/g, "")
57
+ ) ?? false
58
+ );
59
+ setSearchedOptions(resultOptions);
60
+ } else if (options && options?.length > 0) {
61
+ setSearchedOptions([...options ?? []]);
62
+ }
63
+ };
64
+ const handleSearchApi = async (searchValue = "", page = 1, size = 10) => {
65
+ try {
66
+ setIsLoading(true);
67
+ if (isPaginatedApi(searchApi)) {
68
+ const res = await searchApi?.(searchValue, page, size);
69
+ const resultOptions = res?.data ?? [];
70
+ setSearchedOptions(resultOptions);
71
+ } else {
72
+ const resultOptions = await searchApi(searchValue);
73
+ setSearchedOptions(resultOptions);
74
+ }
75
+ } catch (error) {
76
+ } finally {
77
+ setIsLoading(false);
78
+ }
79
+ };
80
+ const handleSelectItem = (option) => {
81
+ onSelectChange?.(option);
82
+ setOpen(false);
83
+ };
84
+ return /* @__PURE__ */ jsx(Popover, { open, onOpenChange: setOpen, children: /* @__PURE__ */ jsxs(Command, { shouldFilter: false, children: [
85
+ /* @__PURE__ */ jsx(PopoverTrigger, { asChild: true, children: /* @__PURE__ */ jsx("div", { ref: triggerRef, children: /* @__PURE__ */ jsx(
86
+ Command$1.Input,
87
+ {
88
+ ...props,
89
+ asChild: true,
90
+ value,
91
+ onValueChange: onInputChange,
92
+ placeholder,
93
+ onKeyDown: (e) => setOpen(e.key !== "Escape"),
94
+ children: children ?? /* @__PURE__ */ jsx(Input, { label })
95
+ }
96
+ ) }) }),
97
+ /* @__PURE__ */ jsx(
98
+ PopoverContent,
99
+ {
100
+ asChild: true,
101
+ onOpenAutoFocus: (e) => e.preventDefault(),
102
+ onInteractOutside: (e) => {
103
+ if (e.target instanceof Element && e.target.hasAttribute("cmdk-input")) {
104
+ e.preventDefault();
105
+ }
106
+ },
107
+ className: "w-full min-w-[300px] p-0",
108
+ hidden: !value,
109
+ align: "start",
110
+ style: { width: triggerWidth },
111
+ children: /* @__PURE__ */ jsxs(CommandList, { children: [
112
+ isLoading && /* @__PURE__ */ jsx(Command$1.Loading, { children: /* @__PURE__ */ jsx("div", { className: "space-y-2 p-3", children: new Array(5).fill(1).map((_item, index) => /* @__PURE__ */ jsx(Skeleton, { className: "h-10 w-full" }, index)) }) }),
113
+ searchedOptions?.length > 0 && !isLoading && /* @__PURE__ */ jsx(CommandGroup, { className: "px-0 py-2", children: searchedOptions.map((option, index) => /* @__PURE__ */ jsx(
114
+ CommandItem,
115
+ {
116
+ value: option.value,
117
+ onMouseDown: (e) => e.preventDefault(),
118
+ onSelect: () => handleSelectItem(option),
119
+ className: cn(
120
+ "text-t16m hover:!bg-accent data-[selected='true']:bg-accent rounded-none p-3",
121
+ index > 0 && "border-border border-t"
122
+ ),
123
+ children: renderOption ? renderOption(option) : option.name ?? option.value
124
+ },
125
+ option.value
126
+ )) }),
127
+ searchedOptions?.length === 0 && !isLoading && enableAddNewItem && newItem && /* @__PURE__ */ jsx(CommandGroup, { className: "px-0 py-2", children: [newItem].filter((o) => !!o).map((option, index) => /* @__PURE__ */ jsx(
128
+ CommandItem,
129
+ {
130
+ value: option.value,
131
+ onMouseDown: (e) => e.preventDefault(),
132
+ onSelect: () => handleSelectItem(option),
133
+ className: cn(
134
+ "text-t16m hover:!bg-accent data-[selected='true']:bg-accent rounded-none px-3 py-4",
135
+ index > 0 && "border-border border-t"
136
+ ),
137
+ children: renderOption ? renderOption(option, true) : option.name ?? option.value
138
+ },
139
+ option.value
140
+ )) }),
141
+ searchedOptions?.length === 0 && !isLoading && !enableAddNewItem && /* @__PURE__ */ jsx(CommandGroup, { className: "px-0 py-2", children: /* @__PURE__ */ jsx(
142
+ CommandItem,
143
+ {
144
+ onMouseDown: (e) => e.preventDefault(),
145
+ className: cn("!text-t16 !text-muted-foreground !bg-transparent px-3 py-4"),
146
+ children: renderEmpty ? renderEmpty() : /* @__PURE__ */ jsx("p", { children: "Kh\xF4ng c\xF3 th\xF4ng tin hi\u1EC3n th\u1ECB" })
147
+ }
148
+ ) })
149
+ ] })
150
+ }
151
+ )
152
+ ] }) });
153
+ }
154
+
155
+ export { AutoComplete };
156
+ //# sourceMappingURL=autocomplete.mjs.map
157
+ //# sourceMappingURL=autocomplete.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/common/interactive/autocomplete.tsx"],"names":["CommandPrimitive"],"mappings":"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","file":"autocomplete.mjs","sourcesContent":["import { Command as CommandPrimitive } from 'cmdk';\nimport { useEffect, useMemo, useState } from 'react';\nimport { Command, CommandGroup, CommandItem, CommandList } from '@/components/command';\nimport { Input } from '@/components/input';\nimport { Popover, PopoverTrigger, PopoverContent } from '@/components/popover';\nimport { Skeleton } from '@/components/skeleton';\nimport { Option } from '@/common/interactive/select';\nimport {\n ApiSearchFunction,\n ApiSearchPaginatedFunction,\n} from '@/common/interactive/select-with-api';\nimport * as React from 'react';\nimport { cn } from '@/lib/utils';\n\ntype Props<T extends string> = {\n label?: string;\n placeholder?: string;\n options?: Option[];\n searchApi?: ApiSearchFunction<Option> | ApiSearchPaginatedFunction<Option>;\n value?: string;\n onInputChange?: (value?: string) => void;\n onSelectChange?: (value?: Option) => void;\n children?: React.ReactNode;\n enableAddNewItem?: boolean;\n newItemOption?: (value: string) => Option | null;\n renderOption?: (option: Option, isNewItem?: boolean) => React.ReactNode;\n renderEmpty?: () => React.ReactNode;\n className?: string;\n};\n\nexport function AutoComplete<T extends string>({\n label = '',\n placeholder = '',\n options,\n searchApi,\n value,\n onInputChange,\n onSelectChange,\n children,\n enableAddNewItem,\n newItemOption,\n renderOption,\n className,\n renderEmpty,\n ...props\n}: Props<T>) {\n const triggerRef = React.useRef<HTMLDivElement>(null);\n const [triggerWidth, setTriggerWidth] = useState<number>();\n const [open, setOpen] = useState(false);\n const [isLoading, setIsLoading] = useState(false);\n const [searchedOptions, setSearchedOptions] = useState<Option[]>([]);\n\n const newItem = useMemo(() => newItemOption?.(value ?? ''), [newItemOption, value]);\n\n useEffect(() => {\n if (open) handleSearch(value);\n\n if (triggerRef.current) {\n setTriggerWidth(triggerRef.current.offsetWidth);\n }\n }, [open, value]);\n\n const isPaginatedApi = (api: any): api is ApiSearchPaginatedFunction<Option> => {\n return typeof api === 'function' && api.length >= 2;\n };\n\n const handleSearch = async (searchValue?: string) => {\n if (!searchValue) {\n setSearchedOptions([]);\n } else if (searchApi) {\n handleSearchApi(value, 1, 10);\n } else if (options) {\n handleSearchLocal(searchValue);\n }\n };\n\n const handleSearchLocal = (searchValue?: string) => {\n if (searchValue && options && options?.length > 0) {\n const resultOptions = [...(options ?? [])].filter(\n // (option) => (option.name?.toLowerCase().search(searchValue.toLowerCase()) ?? -1) > -1,\n (option) =>\n option.name\n ?.toLowerCase()\n .normalize('NFD')\n .replace(/[\\u0300-\\u036f]/g, '')\n .includes(\n searchValue\n .toLowerCase()\n .normalize('NFD')\n .replace(/[\\u0300-\\u036f]/g, ''),\n ) ?? false,\n );\n\n setSearchedOptions(resultOptions);\n } else if (options && options?.length > 0) {\n setSearchedOptions([...(options ?? [])]);\n }\n };\n\n const handleSearchApi = async (searchValue: string = '', page: number = 1, size: number = 10) => {\n try {\n setIsLoading(true);\n if (isPaginatedApi(searchApi)) {\n const res = await searchApi?.(searchValue, page, size);\n const resultOptions = res?.data ?? [];\n setSearchedOptions(resultOptions);\n } else {\n const resultOptions = await (searchApi as ApiSearchFunction<Option>)(searchValue);\n setSearchedOptions(resultOptions);\n }\n } catch (error) {\n } finally {\n setIsLoading(false);\n }\n };\n\n const handleSelectItem = (option: Option) => {\n onSelectChange?.(option);\n setOpen(false);\n };\n\n return (\n <Popover open={open} onOpenChange={setOpen}>\n <Command shouldFilter={false}>\n <PopoverTrigger asChild>\n <div ref={triggerRef}>\n <CommandPrimitive.Input\n {...props}\n asChild\n value={value}\n onValueChange={onInputChange}\n placeholder={placeholder}\n onKeyDown={(e) => setOpen(e.key !== 'Escape')}\n >\n {children ?? <Input label={label} />}\n </CommandPrimitive.Input>\n </div>\n </PopoverTrigger>\n\n <PopoverContent\n asChild\n onOpenAutoFocus={(e) => e.preventDefault()}\n onInteractOutside={(e) => {\n if (e.target instanceof Element && e.target.hasAttribute('cmdk-input')) {\n e.preventDefault();\n }\n }}\n className=\"w-full min-w-[300px] p-0\"\n // hidden={\n // // (!searchedOptions || searchedOptions?.length == 0) &&\n // // (!enableAddNewItem || !value || !newItem) &&\n // // !isLoading\n // }\n hidden={!value}\n align=\"start\"\n style={{ width: triggerWidth }}\n >\n <CommandList>\n {isLoading && (\n <CommandPrimitive.Loading>\n <div className=\"space-y-2 p-3\">\n {new Array(5).fill(1).map((_item, index) => (\n <Skeleton className=\"h-10 w-full\" key={index} />\n ))}\n </div>\n </CommandPrimitive.Loading>\n )}\n\n {searchedOptions?.length > 0 && !isLoading && (\n <CommandGroup className=\"px-0 py-2\">\n {searchedOptions.map((option, index: number) => (\n <CommandItem\n key={option.value}\n value={option.value}\n onMouseDown={(e) => e.preventDefault()}\n onSelect={() => handleSelectItem(option)}\n className={cn(\n \"text-t16m hover:!bg-accent data-[selected='true']:bg-accent rounded-none p-3\",\n index > 0 && 'border-border border-t',\n )}\n >\n {renderOption ? renderOption(option) : (option.name ?? option.value)}\n </CommandItem>\n ))}\n </CommandGroup>\n )}\n\n {searchedOptions?.length === 0 && !isLoading && enableAddNewItem && newItem && (\n <CommandGroup className=\"px-0 py-2\">\n {[newItem]\n .filter((o) => !!o)\n .map((option, index: number) => (\n <CommandItem\n key={option.value}\n value={option.value}\n onMouseDown={(e) => e.preventDefault()}\n onSelect={() => handleSelectItem(option)}\n className={cn(\n \"text-t16m hover:!bg-accent data-[selected='true']:bg-accent rounded-none px-3 py-4\",\n index > 0 && 'border-border border-t',\n )}\n >\n {renderOption ? renderOption(option, true) : (option.name ?? option.value)}\n </CommandItem>\n ))}\n </CommandGroup>\n )}\n\n {searchedOptions?.length === 0 && !isLoading && !enableAddNewItem && (\n <CommandGroup className=\"px-0 py-2\">\n <CommandItem\n onMouseDown={(e) => e.preventDefault()}\n className={cn('!text-t16 !text-muted-foreground !bg-transparent px-3 py-4')}\n >\n {renderEmpty ? renderEmpty() : <p>Không có thông tin hiển thị</p>}\n </CommandItem>\n </CommandGroup>\n )}\n </CommandList>\n </PopoverContent>\n </Command>\n </Popover>\n );\n}\n"]}
@@ -0,0 +1,27 @@
1
+ import React, { ComponentPropsWithoutRef } from 'react';
2
+ import { TooltipContent } from '../../components/tooltip';
3
+ export interface CopyTooltipProps extends ComponentPropsWithoutRef<typeof TooltipContent> {
4
+ trigger?: React.ReactNode;
5
+ triggerAsChild?: boolean;
6
+ triggerClassName?: string;
7
+ children?: React.ReactNode;
8
+ text?: string;
9
+ responseContent?: string;
10
+ contentClassName?: string;
11
+ childrenClassName?: string;
12
+ delayDuration?: number;
13
+ open?: boolean;
14
+ onOpenChange?: (open: boolean) => void;
15
+ defaultOpen?: boolean;
16
+ disableHoverableContent?: boolean;
17
+ showArrow?: boolean;
18
+ arrowClassName?: string;
19
+ onCopySuccess?: (text: string) => void;
20
+ onCopyError?: (error: Error) => void;
21
+ resetDelay?: number;
22
+ skipDelayDuration?: number;
23
+ }
24
+ declare const CopyTooltip: React.ForwardRefExoticComponent<CopyTooltipProps & React.RefAttributes<HTMLDivElement>>;
25
+ export { CopyTooltip };
26
+ export default CopyTooltip;
27
+ //# sourceMappingURL=copy-tooltip.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"copy-tooltip.d.ts","sourceRoot":"","sources":["../../../src/common/interactive/copy-tooltip.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,wBAAwB,EAAoC,MAAM,OAAO,CAAC;AAC1F,OAAO,EAGL,cAAc,EAGf,MAAM,0BAA0B,CAAC;AAIlC,MAAM,WAAW,gBAAiB,SAAQ,wBAAwB,CAAC,OAAO,cAAc,CAAC;IAEvF,OAAO,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAG1B,QAAQ,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC3B,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAG3B,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,YAAY,CAAC,EAAE,CAAC,IAAI,EAAE,OAAO,KAAK,IAAI,CAAC;IACvC,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,uBAAuB,CAAC,EAAE,OAAO,CAAC;IAGlC,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,cAAc,CAAC,EAAE,MAAM,CAAC;IAGxB,aAAa,CAAC,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,CAAC;IACvC,WAAW,CAAC,EAAE,CAAC,KAAK,EAAE,KAAK,KAAK,IAAI,CAAC;IACrC,UAAU,CAAC,EAAE,MAAM,CAAC;IAGpB,iBAAiB,CAAC,EAAE,MAAM,CAAC;CAC5B;AAED,QAAA,MAAM,WAAW,yFA+IhB,CAAC;AAIF,OAAO,EAAE,WAAW,EAAE,CAAC;AACvB,eAAe,WAAW,CAAC"}
@@ -0,0 +1,152 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var jsxRuntime = require('react/jsx-runtime');
6
+ var React = require('react');
7
+ var tooltip = require('../../components/tooltip');
8
+ var utils = require('../../lib/utils');
9
+
10
+ function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
11
+
12
+ var React__default = /*#__PURE__*/_interopDefault(React);
13
+
14
+ const CopyTooltip = React__default.default.forwardRef(
15
+ ({
16
+ // Trigger props
17
+ trigger,
18
+ triggerAsChild = false,
19
+ triggerClassName,
20
+ // Tooltip behavior props
21
+ delayDuration = 700,
22
+ open: controlledOpen,
23
+ onOpenChange: controlledOnOpenChange,
24
+ defaultOpen = false,
25
+ disableHoverableContent = true,
26
+ // Arrow props
27
+ showArrow = true,
28
+ arrowClassName,
29
+ // Content props
30
+ children,
31
+ text,
32
+ responseContent = "\u0110\xE3 sao ch\xE9p",
33
+ contentClassName,
34
+ childrenClassName,
35
+ // Copy behavior props
36
+ onCopySuccess,
37
+ onCopyError,
38
+ resetDelay = 2e3,
39
+ // Tooltip provider props
40
+ skipDelayDuration = 300,
41
+ // Other props
42
+ className,
43
+ ...props
44
+ }, ref) => {
45
+ const [internalOpen, setInternalOpen] = React.useState(defaultOpen);
46
+ const [status, setStatus] = React.useState("idle");
47
+ const isControlled = controlledOpen !== void 0;
48
+ const open = isControlled ? controlledOpen : internalOpen && status !== "idle";
49
+ const setOpen = isControlled ? controlledOnOpenChange : setInternalOpen;
50
+ const handleOpenChange = React.useCallback(
51
+ (newOpen) => {
52
+ setOpen?.(newOpen);
53
+ },
54
+ [setOpen]
55
+ );
56
+ const copyToClipboard = React.useCallback(
57
+ async (textToCopy) => {
58
+ try {
59
+ await navigator.clipboard.writeText(textToCopy);
60
+ setStatus("copied");
61
+ setInternalOpen(true);
62
+ onCopySuccess?.(textToCopy);
63
+ return true;
64
+ } catch (error) {
65
+ const err = error;
66
+ setStatus("failed");
67
+ setInternalOpen(true);
68
+ onCopyError?.(err);
69
+ console.error("Failed to copy text to clipboard:", err);
70
+ return false;
71
+ }
72
+ },
73
+ [onCopySuccess, onCopyError]
74
+ );
75
+ const handleTriggerClick = React.useCallback(
76
+ (event) => {
77
+ event.preventDefault();
78
+ if (text) {
79
+ copyToClipboard(text);
80
+ }
81
+ },
82
+ [text, copyToClipboard]
83
+ );
84
+ React.useEffect(() => {
85
+ if (status === "copied" || status === "failed") {
86
+ const timeout = setTimeout(() => {
87
+ setStatus("idle");
88
+ setInternalOpen(false);
89
+ }, resetDelay);
90
+ return () => clearTimeout(timeout);
91
+ }
92
+ }, [status, resetDelay]);
93
+ return /* @__PURE__ */ jsxRuntime.jsx(
94
+ tooltip.TooltipProvider,
95
+ {
96
+ delayDuration,
97
+ skipDelayDuration,
98
+ disableHoverableContent,
99
+ children: /* @__PURE__ */ jsxRuntime.jsxs(
100
+ tooltip.Tooltip,
101
+ {
102
+ open,
103
+ onOpenChange: handleOpenChange,
104
+ defaultOpen: false,
105
+ delayDuration,
106
+ disableHoverableContent,
107
+ children: [
108
+ trigger && /* @__PURE__ */ jsxRuntime.jsx(
109
+ tooltip.TooltipTrigger,
110
+ {
111
+ asChild: triggerAsChild,
112
+ className: utils.cn("cursor-pointer", triggerClassName),
113
+ onClick: handleTriggerClick,
114
+ children: trigger
115
+ }
116
+ ),
117
+ children && /* @__PURE__ */ jsxRuntime.jsx(
118
+ tooltip.TooltipTrigger,
119
+ {
120
+ asChild: triggerAsChild,
121
+ className: utils.cn("cursor-pointer", triggerClassName),
122
+ onClick: handleTriggerClick,
123
+ children
124
+ }
125
+ ),
126
+ /* @__PURE__ */ jsxRuntime.jsxs(
127
+ tooltip.TooltipContent,
128
+ {
129
+ ref,
130
+ showArrow,
131
+ className: utils.cn("flex flex-col px-3 py-1", className, contentClassName),
132
+ ...props,
133
+ children: [
134
+ /* @__PURE__ */ jsxRuntime.jsx("div", { className: utils.cn(childrenClassName), children: responseContent }),
135
+ showArrow && /* @__PURE__ */ jsxRuntime.jsx(tooltip.TooltipArrow, { className: utils.cn("fill-foreground !h-[5px] !w-[8px]", arrowClassName) })
136
+ ]
137
+ }
138
+ )
139
+ ]
140
+ }
141
+ )
142
+ }
143
+ );
144
+ }
145
+ );
146
+ CopyTooltip.displayName = "CopyTooltip";
147
+ var copy_tooltip_default = CopyTooltip;
148
+
149
+ exports.CopyTooltip = CopyTooltip;
150
+ exports.default = copy_tooltip_default;
151
+ //# sourceMappingURL=copy-tooltip.js.map
152
+ //# sourceMappingURL=copy-tooltip.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/common/interactive/copy-tooltip.tsx"],"names":["React","useState","useCallback","useEffect","jsx","TooltipProvider","jsxs","Tooltip","TooltipTrigger","cn","TooltipContent","TooltipArrow"],"mappings":"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","file":"copy-tooltip.js","sourcesContent":["import React, { ComponentPropsWithoutRef, useCallback, useEffect, useState } from 'react';\nimport {\n Tooltip,\n TooltipArrow,\n TooltipContent,\n TooltipProvider,\n TooltipTrigger,\n} from '../../components/tooltip';\nimport { type CopyStatus } from '../../hooks/useCopyToClipboard';\nimport { cn } from '../../lib/utils';\n\nexport interface CopyTooltipProps extends ComponentPropsWithoutRef<typeof TooltipContent> {\n // Trigger props\n trigger?: React.ReactNode;\n triggerAsChild?: boolean;\n triggerClassName?: string;\n\n // Content props\n children?: React.ReactNode;\n text?: string;\n responseContent?: string;\n contentClassName?: string;\n childrenClassName?: string;\n\n // Tooltip behavior props\n delayDuration?: number;\n open?: boolean;\n onOpenChange?: (open: boolean) => void;\n defaultOpen?: boolean;\n disableHoverableContent?: boolean;\n\n // Arrow props\n showArrow?: boolean;\n arrowClassName?: string;\n\n // Copy behavior props\n onCopySuccess?: (text: string) => void;\n onCopyError?: (error: Error) => void;\n resetDelay?: number;\n\n // Tooltip provider props\n skipDelayDuration?: number;\n}\n\nconst CopyTooltip = React.forwardRef<React.ElementRef<typeof TooltipContent>, CopyTooltipProps>(\n (\n {\n // Trigger props\n trigger,\n triggerAsChild = false,\n triggerClassName,\n\n // Tooltip behavior props\n delayDuration = 700,\n open: controlledOpen,\n onOpenChange: controlledOnOpenChange,\n defaultOpen = false,\n disableHoverableContent = true,\n\n // Arrow props\n showArrow = true,\n arrowClassName,\n\n // Content props\n children,\n text,\n responseContent = 'Đã sao chép',\n contentClassName,\n childrenClassName,\n\n // Copy behavior props\n onCopySuccess,\n onCopyError,\n resetDelay = 2000,\n\n // Tooltip provider props\n skipDelayDuration = 300,\n\n // Other props\n className,\n ...props\n },\n ref,\n ) => {\n const [internalOpen, setInternalOpen] = useState(defaultOpen);\n const [status, setStatus] = useState<CopyStatus>('idle');\n\n // Use controlled or uncontrolled state\n const isControlled = controlledOpen !== undefined;\n const open = isControlled ? controlledOpen : internalOpen && status !== 'idle';\n const setOpen = isControlled ? controlledOnOpenChange : setInternalOpen;\n\n const handleOpenChange = useCallback(\n (newOpen: boolean) => {\n setOpen?.(newOpen);\n },\n [setOpen],\n );\n\n const copyToClipboard = useCallback(\n async (textToCopy: string): Promise<boolean> => {\n try {\n await navigator.clipboard.writeText(textToCopy);\n setStatus('copied');\n setInternalOpen(true);\n onCopySuccess?.(textToCopy);\n return true;\n } catch (error) {\n const err = error as Error;\n setStatus('failed');\n setInternalOpen(true);\n onCopyError?.(err);\n console.error('Failed to copy text to clipboard:', err);\n return false;\n }\n },\n [onCopySuccess, onCopyError],\n );\n\n const handleTriggerClick = useCallback(\n (event: React.MouseEvent) => {\n event.preventDefault();\n if (text) {\n copyToClipboard(text);\n }\n },\n [text, copyToClipboard],\n );\n\n // Reset status after specified delay\n useEffect(() => {\n if (status === 'copied' || status === 'failed') {\n const timeout = setTimeout(() => {\n setStatus('idle');\n setInternalOpen(false);\n }, resetDelay);\n\n return () => clearTimeout(timeout);\n }\n }, [status, resetDelay]);\n\n return (\n <TooltipProvider\n delayDuration={delayDuration}\n skipDelayDuration={skipDelayDuration}\n disableHoverableContent={disableHoverableContent}\n >\n <Tooltip\n open={open}\n onOpenChange={handleOpenChange}\n defaultOpen={false}\n delayDuration={delayDuration}\n disableHoverableContent={disableHoverableContent}\n >\n {trigger && (\n <TooltipTrigger\n asChild={triggerAsChild}\n className={cn('cursor-pointer', triggerClassName)}\n onClick={handleTriggerClick}\n >\n {trigger}\n </TooltipTrigger>\n )}\n {children && (\n <TooltipTrigger\n asChild={triggerAsChild}\n className={cn('cursor-pointer', triggerClassName)}\n onClick={handleTriggerClick}\n >\n {children}\n </TooltipTrigger>\n )}\n <TooltipContent\n ref={ref}\n showArrow={showArrow}\n className={cn('flex flex-col px-3 py-1', className, contentClassName)}\n {...props}\n >\n <div className={cn(childrenClassName)}>{responseContent}</div>\n {showArrow && (\n <TooltipArrow className={cn('fill-foreground !h-[5px] !w-[8px]', arrowClassName)} />\n )}\n </TooltipContent>\n </Tooltip>\n </TooltipProvider>\n );\n },\n);\n\nCopyTooltip.displayName = 'CopyTooltip';\n\nexport { CopyTooltip };\nexport default CopyTooltip;\n"]}