ikoncomponents 1.5.8 → 1.5.10

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 (423) hide show
  1. package/dist/hooks/use-mobile.d.ts +1 -0
  2. package/dist/hooks/use-mobile.js +15 -0
  3. package/dist/ikoncomponents/action-menu/index.d.ts +5 -0
  4. package/dist/ikoncomponents/action-menu/index.js +42 -0
  5. package/dist/ikoncomponents/action-menu/type.d.ts +14 -0
  6. package/dist/ikoncomponents/action-menu/type.js +1 -0
  7. package/dist/ikoncomponents/activity-sheet/index.d.ts +11 -0
  8. package/dist/ikoncomponents/activity-sheet/index.js +23 -0
  9. package/dist/ikoncomponents/alert-dialog/dialog-context.d.ts +21 -0
  10. package/dist/ikoncomponents/alert-dialog/dialog-context.js +30 -0
  11. package/dist/ikoncomponents/alert-dialog/index.d.ts +14 -0
  12. package/dist/ikoncomponents/alert-dialog/index.js +20 -0
  13. package/dist/ikoncomponents/app-breadcrumb/BreadcrumbProvider.d.ts +18 -0
  14. package/dist/ikoncomponents/app-breadcrumb/BreadcrumbProvider.js +43 -0
  15. package/dist/ikoncomponents/app-breadcrumb/index.d.ts +5 -0
  16. package/dist/ikoncomponents/app-breadcrumb/index.js +57 -0
  17. package/dist/ikoncomponents/big-calendar/big-calender-event/index.d.ts +5 -0
  18. package/dist/ikoncomponents/big-calendar/big-calender-event/index.js +16 -0
  19. package/dist/ikoncomponents/big-calendar/big-calender-toolbar/index.d.ts +2 -0
  20. package/dist/ikoncomponents/big-calendar/big-calender-toolbar/index.js +39 -0
  21. package/dist/ikoncomponents/big-calendar/index.d.ts +3 -0
  22. package/dist/ikoncomponents/big-calendar/index.js +35 -0
  23. package/dist/ikoncomponents/big-calendar/type.d.ts +31 -0
  24. package/dist/ikoncomponents/big-calendar/type.js +1 -0
  25. package/dist/ikoncomponents/buttons/index.d.ts +18 -0
  26. package/dist/ikoncomponents/buttons/index.js +38 -0
  27. package/dist/ikoncomponents/combobox-input/index.d.ts +2 -0
  28. package/dist/ikoncomponents/combobox-input/index.js +18 -0
  29. package/dist/ikoncomponents/combobox-input/type.d.ts +13 -0
  30. package/dist/ikoncomponents/combobox-input/type.js +1 -0
  31. package/dist/ikoncomponents/custom-combo-dropdown/index.d.ts +21 -0
  32. package/dist/ikoncomponents/custom-combo-dropdown/index.js +85 -0
  33. package/dist/ikoncomponents/data-table/datatable-column-filter/index.d.ts +2 -0
  34. package/dist/ikoncomponents/data-table/datatable-column-filter/index.js +22 -0
  35. package/dist/ikoncomponents/data-table/datatable-faceted-filter/index.d.ts +2 -0
  36. package/dist/ikoncomponents/data-table/datatable-faceted-filter/index.js +35 -0
  37. package/dist/ikoncomponents/data-table/datatable-filter-menu/index.d.ts +2 -0
  38. package/dist/ikoncomponents/data-table/datatable-filter-menu/index.js +38 -0
  39. package/dist/ikoncomponents/data-table/datatable-pagination/index.d.ts +2 -0
  40. package/dist/ikoncomponents/data-table/datatable-pagination/index.js +13 -0
  41. package/dist/ikoncomponents/data-table/datatable-toolbar/index.d.ts +2 -0
  42. package/dist/ikoncomponents/data-table/datatable-toolbar/index.js +18 -0
  43. package/dist/ikoncomponents/data-table/function.d.ts +1 -0
  44. package/dist/ikoncomponents/data-table/function.js +6 -0
  45. package/dist/ikoncomponents/data-table/index.d.ts +2 -0
  46. package/dist/ikoncomponents/data-table/index.js +223 -0
  47. package/dist/ikoncomponents/data-table/type.d.ts +60 -0
  48. package/dist/ikoncomponents/data-table/type.js +1 -0
  49. package/dist/ikoncomponents/e-chart/index.d.ts +15 -0
  50. package/dist/ikoncomponents/e-chart/index.js +115 -0
  51. package/dist/ikoncomponents/file-input/index.d.ts +1 -0
  52. package/dist/ikoncomponents/file-input/index.js +21 -0
  53. package/dist/ikoncomponents/fileUpload/index.d.ts +15 -0
  54. package/dist/ikoncomponents/fileUpload/index.js +69 -0
  55. package/dist/ikoncomponents/form-fields/combobox-input/index.d.ts +2 -0
  56. package/dist/ikoncomponents/form-fields/combobox-input/index.js +21 -0
  57. package/dist/ikoncomponents/form-fields/combobox-input-value/index.d.ts +18 -0
  58. package/dist/ikoncomponents/form-fields/combobox-input-value/index.js +26 -0
  59. package/dist/ikoncomponents/form-fields/date-input/index.d.ts +2 -0
  60. package/dist/ikoncomponents/form-fields/date-input/index.js +15 -0
  61. package/dist/ikoncomponents/form-fields/file-input/index.d.ts +1 -0
  62. package/dist/ikoncomponents/form-fields/file-input/index.js +4 -0
  63. package/dist/ikoncomponents/form-fields/input/index.d.ts +2 -0
  64. package/dist/ikoncomponents/form-fields/input/index.js +18 -0
  65. package/dist/ikoncomponents/form-fields/multi-combobox-input/index.d.ts +6 -0
  66. package/{templates/default/ikoncomponents/form-fields/multi-combobox-input/index.tsx → dist/ikoncomponents/form-fields/multi-combobox-input/index.js} +381 -574
  67. package/dist/ikoncomponents/form-fields/otp-input/index.d.ts +2 -0
  68. package/dist/ikoncomponents/form-fields/otp-input/index.js +18 -0
  69. package/dist/ikoncomponents/form-fields/phone-input/index.d.ts +1 -0
  70. package/dist/ikoncomponents/form-fields/phone-input/index.js +4 -0
  71. package/dist/ikoncomponents/form-fields/textarea/index.d.ts +2 -0
  72. package/dist/ikoncomponents/form-fields/textarea/index.js +18 -0
  73. package/dist/ikoncomponents/form-fields/types/index.d.ts +36 -0
  74. package/dist/ikoncomponents/form-fields/types/index.js +1 -0
  75. package/dist/ikoncomponents/glowing-effect/index.d.ts +14 -0
  76. package/dist/ikoncomponents/glowing-effect/index.js +84 -0
  77. package/dist/ikoncomponents/icon/index.d.ts +8 -0
  78. package/dist/ikoncomponents/icon/index.js +23 -0
  79. package/dist/ikoncomponents/image-cropper-upload/components/newCropper.d.ts +15 -0
  80. package/{templates/default/ikoncomponents/image-cropper-upload/components/newCropper.tsx → dist/ikoncomponents/image-cropper-upload/components/newCropper.js} +85 -117
  81. package/dist/ikoncomponents/image-cropper-upload/components/newImageUploadForm.d.ts +7 -0
  82. package/dist/ikoncomponents/image-cropper-upload/components/newImageUploadForm.js +145 -0
  83. package/dist/ikoncomponents/image-cropper-upload/cropper-form/index.d.ts +6 -0
  84. package/dist/ikoncomponents/image-cropper-upload/cropper-form/index.js +92 -0
  85. package/dist/ikoncomponents/image-cropper-upload/cropper-form-with-modal/index.d.ts +6 -0
  86. package/dist/ikoncomponents/image-cropper-upload/cropper-form-with-modal/index.js +14 -0
  87. package/dist/ikoncomponents/image-cropper-upload/image-cropper/index.d.ts +14 -0
  88. package/{templates/default/ikoncomponents/image-cropper-upload/image-cropper/index.tsx → dist/ikoncomponents/image-cropper-upload/image-cropper/index.js} +87 -119
  89. package/dist/ikoncomponents/image-cropper-upload/index.d.ts +27 -0
  90. package/dist/ikoncomponents/image-cropper-upload/index.js +49 -0
  91. package/dist/ikoncomponents/image-cropper-upload/utils/index.d.ts +16 -0
  92. package/dist/ikoncomponents/image-cropper-upload/utils/index.js +73 -0
  93. package/dist/ikoncomponents/loading-spinner/index.d.ts +9 -0
  94. package/dist/ikoncomponents/loading-spinner/index.js +19 -0
  95. package/dist/ikoncomponents/main-layout/RefreshContext.d.ts +10 -0
  96. package/dist/ikoncomponents/main-layout/RefreshContext.js +18 -0
  97. package/dist/ikoncomponents/main-layout/SidebarNavContext.d.ts +33 -0
  98. package/dist/ikoncomponents/main-layout/SidebarNavContext.js +52 -0
  99. package/dist/ikoncomponents/main-layout/app-sidebar.d.ts +3 -0
  100. package/dist/ikoncomponents/main-layout/app-sidebar.js +24 -0
  101. package/dist/ikoncomponents/main-layout/footer.d.ts +1 -0
  102. package/dist/ikoncomponents/main-layout/footer.js +5 -0
  103. package/dist/ikoncomponents/main-layout/header.d.ts +3 -0
  104. package/dist/ikoncomponents/main-layout/header.js +15 -0
  105. package/dist/ikoncomponents/main-layout/index.d.ts +6 -0
  106. package/dist/ikoncomponents/main-layout/index.js +11 -0
  107. package/dist/ikoncomponents/main-layout/main-sidebar.d.ts +60 -0
  108. package/dist/ikoncomponents/main-layout/main-sidebar.js +119 -0
  109. package/dist/ikoncomponents/main-layout/nav-main.d.ts +11 -0
  110. package/dist/ikoncomponents/main-layout/nav-main.js +33 -0
  111. package/dist/ikoncomponents/multi-combobox/index.d.ts +13 -0
  112. package/dist/ikoncomponents/multi-combobox/index.js +202 -0
  113. package/dist/ikoncomponents/no-data/index.d.ts +3 -0
  114. package/dist/ikoncomponents/no-data/index.js +5 -0
  115. package/dist/ikoncomponents/page-wrapper/index.d.ts +9 -0
  116. package/dist/ikoncomponents/page-wrapper/index.js +7 -0
  117. package/dist/ikoncomponents/password-strength-meter/index.d.ts +3 -0
  118. package/dist/ikoncomponents/password-strength-meter/index.js +40 -0
  119. package/dist/ikoncomponents/phone-input/index.d.ts +1 -0
  120. package/dist/ikoncomponents/phone-input/index.js +41 -0
  121. package/dist/ikoncomponents/provider-wrapper/index.d.ts +6 -0
  122. package/dist/ikoncomponents/provider-wrapper/index.js +11 -0
  123. package/dist/ikoncomponents/search-input/index.d.ts +1 -0
  124. package/dist/ikoncomponents/search-input/index.js +19 -0
  125. package/dist/ikoncomponents/sheet/index.d.ts +10 -0
  126. package/dist/ikoncomponents/sheet/index.js +6 -0
  127. package/dist/ikoncomponents/simple-widget/index.d.ts +14 -0
  128. package/dist/ikoncomponents/simple-widget/index.js +14 -0
  129. package/dist/ikoncomponents/skeleton-loader/skeleton-table.d.ts +5 -0
  130. package/dist/ikoncomponents/skeleton-loader/skeleton-table.js +6 -0
  131. package/dist/ikoncomponents/skeleton-loader/skeleton-widget.d.ts +3 -0
  132. package/dist/ikoncomponents/skeleton-loader/skeleton-widget.js +5 -0
  133. package/dist/ikoncomponents/tabs/index.d.ts +2 -0
  134. package/dist/ikoncomponents/tabs/index.js +50 -0
  135. package/{templates/default/ikoncomponents/tabs/type.ts → dist/ikoncomponents/tabs/type.d.ts} +19 -20
  136. package/dist/ikoncomponents/tabs/type.js +2 -0
  137. package/dist/ikoncomponents/theme-toggle-btn/index.d.ts +1 -0
  138. package/{templates/default/ikoncomponents/theme-toggle-btn/index.tsx → dist/ikoncomponents/theme-toggle-btn/index.js} +118 -189
  139. package/dist/ikoncomponents/title-progress/index.d.ts +12 -0
  140. package/dist/ikoncomponents/title-progress/index.js +10 -0
  141. package/dist/ikoncomponents/tooltip/index.d.ts +5 -0
  142. package/dist/ikoncomponents/tooltip/index.js +5 -0
  143. package/dist/ikoncomponents/twolevel-dropdown/index.d.ts +31 -0
  144. package/dist/ikoncomponents/twolevel-dropdown/index.js +143 -0
  145. package/dist/ikoncomponents/upload-tab/index.d.ts +1 -0
  146. package/dist/ikoncomponents/upload-tab/index.js +92 -0
  147. package/dist/ikoncomponents/widgets/index.d.ts +2 -0
  148. package/dist/ikoncomponents/widgets/index.js +14 -0
  149. package/dist/ikoncomponents/widgets/type.d.ts +10 -0
  150. package/dist/ikoncomponents/widgets/type.js +2 -0
  151. package/dist/ikoncomponents/work-in-progress/index.d.ts +1 -0
  152. package/dist/ikoncomponents/work-in-progress/index.js +4 -0
  153. package/dist/index.d.ts +138 -0
  154. package/dist/index.js +116 -14
  155. package/dist/shadcn/accordion.d.ts +7 -0
  156. package/dist/shadcn/accordion.js +33 -0
  157. package/dist/shadcn/alert-dialog.d.ts +20 -0
  158. package/dist/shadcn/alert-dialog.js +83 -0
  159. package/dist/shadcn/alert.d.ts +9 -0
  160. package/dist/shadcn/alert.js +38 -0
  161. package/dist/shadcn/aspect-ratio.d.ts +3 -0
  162. package/dist/shadcn/aspect-ratio.js +19 -0
  163. package/dist/shadcn/avatar.d.ts +6 -0
  164. package/dist/shadcn/avatar.js +28 -0
  165. package/dist/shadcn/badge.d.ts +9 -0
  166. package/dist/shadcn/badge.js +35 -0
  167. package/dist/shadcn/breadcrumb.d.ts +11 -0
  168. package/dist/shadcn/breadcrumb.js +45 -0
  169. package/dist/shadcn/button.d.ts +10 -0
  170. package/dist/shadcn/button.js +47 -0
  171. package/dist/shadcn/calendar.d.ts +8 -0
  172. package/dist/shadcn/calendar.js +61 -0
  173. package/dist/shadcn/card.d.ts +9 -0
  174. package/dist/shadcn/card.js +42 -0
  175. package/dist/shadcn/checkbox.d.ts +4 -0
  176. package/dist/shadcn/checkbox.js +21 -0
  177. package/dist/shadcn/collapsible.d.ts +5 -0
  178. package/dist/shadcn/collapsible.js +27 -0
  179. package/dist/shadcn/command.d.ts +18 -0
  180. package/dist/shadcn/command.js +54 -0
  181. package/dist/shadcn/date-input.d.ts +7 -0
  182. package/dist/shadcn/date-input.js +179 -0
  183. package/dist/shadcn/date-range-picker.d.ts +24 -0
  184. package/dist/shadcn/date-range-picker.js +45 -0
  185. package/dist/shadcn/dialog.d.ts +15 -0
  186. package/dist/shadcn/dialog.js +57 -0
  187. package/dist/shadcn/drawer.d.ts +13 -0
  188. package/dist/shadcn/drawer.js +56 -0
  189. package/dist/shadcn/dropdown-menu.d.ts +25 -0
  190. package/dist/shadcn/dropdown-menu.js +77 -0
  191. package/dist/shadcn/form.d.ts +24 -0
  192. package/dist/shadcn/form.js +70 -0
  193. package/dist/shadcn/hover-card.d.ts +6 -0
  194. package/dist/shadcn/hover-card.js +28 -0
  195. package/dist/shadcn/input-otp.d.ts +34 -0
  196. package/dist/shadcn/input-otp.js +40 -0
  197. package/dist/shadcn/input.d.ts +3 -0
  198. package/dist/shadcn/input.js +18 -0
  199. package/dist/shadcn/label.d.ts +4 -0
  200. package/dist/shadcn/label.js +20 -0
  201. package/dist/shadcn/navigation-menu.d.ts +16 -0
  202. package/dist/shadcn/navigation-menu.js +74 -0
  203. package/dist/shadcn/popover.d.ts +7 -0
  204. package/dist/shadcn/popover.js +32 -0
  205. package/dist/shadcn/progress.d.ts +8 -0
  206. package/dist/shadcn/progress.js +23 -0
  207. package/dist/shadcn/radio-group.d.ts +5 -0
  208. package/dist/shadcn/radio-group.js +25 -0
  209. package/dist/shadcn/scroll-area.d.ts +5 -0
  210. package/dist/shadcn/scroll-area.js +26 -0
  211. package/dist/shadcn/select.d.ts +15 -0
  212. package/dist/shadcn/select.js +59 -0
  213. package/dist/shadcn/separator.d.ts +4 -0
  214. package/dist/shadcn/separator.js +20 -0
  215. package/dist/shadcn/sheet.d.ts +13 -0
  216. package/dist/shadcn/sheet.js +61 -0
  217. package/dist/shadcn/sidebar.d.ts +69 -0
  218. package/dist/shadcn/sidebar.js +242 -0
  219. package/dist/shadcn/skeleton.d.ts +3 -0
  220. package/dist/shadcn/skeleton.js +18 -0
  221. package/dist/shadcn/slider.d.ts +4 -0
  222. package/dist/shadcn/slider.js +26 -0
  223. package/dist/shadcn/sonner.d.ts +3 -0
  224. package/dist/shadcn/sonner.js +25 -0
  225. package/dist/shadcn/switch.d.ts +4 -0
  226. package/dist/shadcn/switch.js +20 -0
  227. package/dist/shadcn/table.d.ts +10 -0
  228. package/dist/shadcn/table.js +47 -0
  229. package/dist/shadcn/tabs.d.ts +7 -0
  230. package/dist/shadcn/tabs.js +32 -0
  231. package/dist/shadcn/textarea.d.ts +3 -0
  232. package/dist/shadcn/textarea.js +18 -0
  233. package/dist/shadcn/toggle-group.d.ts +9 -0
  234. package/dist/shadcn/toggle-group.js +35 -0
  235. package/dist/shadcn/toggle.d.ts +9 -0
  236. package/dist/shadcn/toggle.js +38 -0
  237. package/dist/shadcn/tooltip.d.ts +7 -0
  238. package/dist/shadcn/tooltip.js +32 -0
  239. package/dist/shadcn/workflow.d.ts +20 -0
  240. package/dist/shadcn/workflow.js +20 -0
  241. package/dist/styles.css +6163 -0
  242. package/dist/utils/actions/account/index.d.ts +5 -0
  243. package/dist/utils/actions/account/index.js +28 -0
  244. package/dist/utils/actions/account/type.d.ts +4 -0
  245. package/dist/utils/actions/account/type.js +1 -0
  246. package/dist/utils/actions/auth/index.d.ts +7 -0
  247. package/{templates/default/utils/actions/auth/index.ts → dist/utils/actions/auth/index.js} +58 -69
  248. package/dist/utils/actions/common/utils.d.ts +5 -0
  249. package/{templates/default/utils/actions/common/utils.ts → dist/utils/actions/common/utils.js} +25 -28
  250. package/dist/utils/actions/software/index.d.ts +11 -0
  251. package/dist/utils/actions/software/index.js +75 -0
  252. package/dist/utils/api/accountService/index.d.ts +23 -0
  253. package/dist/utils/api/accountService/index.js +64 -0
  254. package/dist/utils/api/accountService/type.d.ts +4 -0
  255. package/dist/utils/api/accountService/type.js +1 -0
  256. package/dist/utils/api/file-upload/index.d.ts +5 -0
  257. package/dist/utils/api/file-upload/index.js +80 -0
  258. package/dist/utils/api/file-upload/type.d.ts +6 -0
  259. package/dist/utils/api/file-upload/type.js +1 -0
  260. package/dist/utils/api/ikonBaseApi.d.ts +12 -0
  261. package/{templates/default/utils/api/ikonBaseApi.ts → dist/utils/api/ikonBaseApi.js} +104 -132
  262. package/dist/utils/api/loginService/index.d.ts +12 -0
  263. package/dist/utils/api/loginService/index.js +72 -0
  264. package/{templates/default/utils/api/loginService/type.ts → dist/utils/api/loginService/type.d.ts} +31 -35
  265. package/dist/utils/api/loginService/type.js +1 -0
  266. package/dist/utils/api/softwareService/index.d.ts +64 -0
  267. package/dist/utils/api/softwareService/index.js +212 -0
  268. package/dist/utils/api/softwareService/type.d.ts +54 -0
  269. package/dist/utils/api/softwareService/type.js +1 -0
  270. package/dist/utils/border-radius-provider.d.ts +11 -0
  271. package/{templates/default/utils/border-radius-provider.tsx → dist/utils/border-radius-provider.js} +35 -59
  272. package/dist/utils/cn.d.ts +2 -0
  273. package/dist/utils/cn.js +5 -0
  274. package/dist/utils/font-provider.d.ts +11 -0
  275. package/{templates/default/utils/font-provider.tsx → dist/utils/font-provider.js} +37 -61
  276. package/dist/utils/session/cookieSession.d.ts +8 -0
  277. package/dist/utils/session/cookieSession.js +33 -0
  278. package/dist/utils/theme-provider/index.d.ts +3 -0
  279. package/dist/utils/theme-provider/index.js +18 -0
  280. package/dist/utils/token-management/index.d.ts +10 -0
  281. package/dist/utils/token-management/index.js +69 -0
  282. package/dist/utils/token-management/types.d.ts +6 -0
  283. package/dist/utils/token-management/types.js +1 -0
  284. package/package.json +91 -17
  285. package/bin.js +0 -2
  286. package/dist/commands/init.js +0 -63
  287. package/dist/utlis/copyDir.js +0 -7
  288. package/templates/default/hooks/use-mobile.ts +0 -19
  289. package/templates/default/ikonS/accordion.tsx +0 -66
  290. package/templates/default/ikonS/alert-dialog.tsx +0 -179
  291. package/templates/default/ikonS/alert.tsx +0 -66
  292. package/templates/default/ikonS/aspect-ratio.tsx +0 -11
  293. package/templates/default/ikonS/avatar.tsx +0 -53
  294. package/templates/default/ikonS/badge.tsx +0 -49
  295. package/templates/default/ikonS/breadcrumb.tsx +0 -109
  296. package/templates/default/ikonS/button.tsx +0 -64
  297. package/templates/default/ikonS/calendar.tsx +0 -227
  298. package/templates/default/ikonS/card.tsx +0 -92
  299. package/templates/default/ikonS/checkbox.tsx +0 -33
  300. package/templates/default/ikonS/collapsible.tsx +0 -33
  301. package/templates/default/ikonS/command.tsx +0 -184
  302. package/templates/default/ikonS/date-input.tsx +0 -259
  303. package/templates/default/ikonS/date-range-picker.tsx +0 -103
  304. package/templates/default/ikonS/dialog.tsx +0 -143
  305. package/templates/default/ikonS/drawer.tsx +0 -134
  306. package/templates/default/ikonS/dropdown-menu.tsx +0 -259
  307. package/templates/default/ikonS/form.tsx +0 -166
  308. package/templates/default/ikonS/hover-card.tsx +0 -44
  309. package/templates/default/ikonS/input-otp.tsx +0 -71
  310. package/templates/default/ikonS/input.tsx +0 -22
  311. package/templates/default/ikonS/label.tsx +0 -24
  312. package/templates/default/ikonS/navigation-menu.tsx +0 -195
  313. package/templates/default/ikonS/popover.tsx +0 -48
  314. package/templates/default/ikonS/progress.tsx +0 -40
  315. package/templates/default/ikonS/radio-group.tsx +0 -45
  316. package/templates/default/ikonS/scroll-area.tsx +0 -58
  317. package/templates/default/ikonS/select.tsx +0 -184
  318. package/templates/default/ikonS/separator.tsx +0 -28
  319. package/templates/default/ikonS/sheet.tsx +0 -139
  320. package/templates/default/ikonS/sidebar.tsx +0 -726
  321. package/templates/default/ikonS/skeleton.tsx +0 -15
  322. package/templates/default/ikonS/slider.tsx +0 -64
  323. package/templates/default/ikonS/sonner.tsx +0 -25
  324. package/templates/default/ikonS/switch.tsx +0 -31
  325. package/templates/default/ikonS/table.tsx +0 -116
  326. package/templates/default/ikonS/tabs.tsx +0 -67
  327. package/templates/default/ikonS/textarea.tsx +0 -18
  328. package/templates/default/ikonS/toggle-group.tsx +0 -83
  329. package/templates/default/ikonS/toggle.tsx +0 -47
  330. package/templates/default/ikonS/tooltip.tsx +0 -65
  331. package/templates/default/ikonS/workflow.tsx +0 -119
  332. package/templates/default/ikoncomponents/action-menu/index.tsx +0 -108
  333. package/templates/default/ikoncomponents/action-menu/type.ts +0 -18
  334. package/templates/default/ikoncomponents/activity-sheet/index.tsx +0 -63
  335. package/templates/default/ikoncomponents/alert-dialog/dialog-context.tsx +0 -65
  336. package/templates/default/ikoncomponents/alert-dialog/index.tsx +0 -80
  337. package/templates/default/ikoncomponents/app-breadcrumb/BreadcrumbProvider.tsx +0 -68
  338. package/templates/default/ikoncomponents/app-breadcrumb/index.tsx +0 -222
  339. package/templates/default/ikoncomponents/big-calendar/big-calender-event/index.tsx +0 -38
  340. package/templates/default/ikoncomponents/big-calendar/big-calender-toolbar/index.tsx +0 -81
  341. package/templates/default/ikoncomponents/big-calendar/index.css +0 -879
  342. package/templates/default/ikoncomponents/big-calendar/index.tsx +0 -59
  343. package/templates/default/ikoncomponents/big-calendar/type.ts +0 -37
  344. package/templates/default/ikoncomponents/buttons/index.tsx +0 -127
  345. package/templates/default/ikoncomponents/combobox-input/index.tsx +0 -75
  346. package/templates/default/ikoncomponents/combobox-input/type.ts +0 -14
  347. package/templates/default/ikoncomponents/custom-combo-dropdown/index.tsx +0 -242
  348. package/templates/default/ikoncomponents/data-table/datatable-column-filter/index.tsx +0 -80
  349. package/templates/default/ikoncomponents/data-table/datatable-faceted-filter/index.tsx +0 -149
  350. package/templates/default/ikoncomponents/data-table/datatable-filter-menu/index.tsx +0 -98
  351. package/templates/default/ikoncomponents/data-table/datatable-pagination/index.tsx +0 -119
  352. package/templates/default/ikoncomponents/data-table/datatable-toolbar/index.tsx +0 -45
  353. package/templates/default/ikoncomponents/data-table/function.ts +0 -7
  354. package/templates/default/ikoncomponents/data-table/index.tsx +0 -549
  355. package/templates/default/ikoncomponents/data-table/type.ts +0 -75
  356. package/templates/default/ikoncomponents/e-chart/index.tsx +0 -183
  357. package/templates/default/ikoncomponents/file-input/index.tsx +0 -27
  358. package/templates/default/ikoncomponents/fileUpload/index.tsx +0 -121
  359. package/templates/default/ikoncomponents/form-fields/combobox-input/index.tsx +0 -111
  360. package/templates/default/ikoncomponents/form-fields/combobox-input-value/index.tsx +0 -121
  361. package/templates/default/ikoncomponents/form-fields/date-input/index.tsx +0 -80
  362. package/templates/default/ikoncomponents/form-fields/file-input/index.tsx +0 -9
  363. package/templates/default/ikoncomponents/form-fields/input/index.tsx +0 -27
  364. package/templates/default/ikoncomponents/form-fields/otp-input/index.tsx +0 -39
  365. package/templates/default/ikoncomponents/form-fields/password-input/index.tsx +0 -52
  366. package/templates/default/ikoncomponents/form-fields/phone-input/index.tsx +0 -7
  367. package/templates/default/ikoncomponents/form-fields/textarea/index.tsx +0 -28
  368. package/templates/default/ikoncomponents/form-fields/types/index.ts +0 -46
  369. package/templates/default/ikoncomponents/glowing-effect/index.tsx +0 -171
  370. package/templates/default/ikoncomponents/icon/index.tsx +0 -22
  371. package/templates/default/ikoncomponents/image-cropper-upload/components/cropperImg.css +0 -19
  372. package/templates/default/ikoncomponents/image-cropper-upload/components/newImageUploadForm.tsx +0 -352
  373. package/templates/default/ikoncomponents/image-cropper-upload/cropper-form/index.tsx +0 -250
  374. package/templates/default/ikoncomponents/image-cropper-upload/cropper-form-with-modal/index.tsx +0 -32
  375. package/templates/default/ikoncomponents/image-cropper-upload/index.tsx +0 -95
  376. package/templates/default/ikoncomponents/image-cropper-upload/utils/index.ts +0 -117
  377. package/templates/default/ikoncomponents/loading-spinner/index.tsx +0 -43
  378. package/templates/default/ikoncomponents/main-layout/RefreshContext.tsx +0 -30
  379. package/templates/default/ikoncomponents/main-layout/SidebarNavContext.tsx +0 -103
  380. package/templates/default/ikoncomponents/main-layout/app-sidebar.tsx +0 -36
  381. package/templates/default/ikoncomponents/main-layout/footer.tsx +0 -21
  382. package/templates/default/ikoncomponents/main-layout/header.tsx +0 -53
  383. package/templates/default/ikoncomponents/main-layout/index.tsx +0 -38
  384. package/templates/default/ikoncomponents/main-layout/main-sidebar.tsx +0 -389
  385. package/templates/default/ikoncomponents/main-layout/nav-main.tsx +0 -103
  386. package/templates/default/ikoncomponents/multi-combobox/index.tsx +0 -345
  387. package/templates/default/ikoncomponents/no-data/index.tsx +0 -11
  388. package/templates/default/ikoncomponents/page-wrapper/index.tsx +0 -30
  389. package/templates/default/ikoncomponents/password-strength-meter/index.tsx +0 -49
  390. package/templates/default/ikoncomponents/phone-input/index.tsx +0 -72
  391. package/templates/default/ikoncomponents/provider-wrapper/index.tsx +0 -32
  392. package/templates/default/ikoncomponents/search-input/index.tsx +0 -18
  393. package/templates/default/ikoncomponents/sheet/index.tsx +0 -34
  394. package/templates/default/ikoncomponents/simple-widget/index.tsx +0 -54
  395. package/templates/default/ikoncomponents/skeleton-loader/skeleton-table.tsx +0 -34
  396. package/templates/default/ikoncomponents/skeleton-loader/skeleton-widget.tsx +0 -13
  397. package/templates/default/ikoncomponents/tabs/index.tsx +0 -139
  398. package/templates/default/ikoncomponents/title-progress/index.tsx +0 -41
  399. package/templates/default/ikoncomponents/tooltip/index.tsx +0 -17
  400. package/templates/default/ikoncomponents/twolevel-dropdown/convertToDropdownNodes.tsx +0 -33
  401. package/templates/default/ikoncomponents/twolevel-dropdown/index.tsx +0 -279
  402. package/templates/default/ikoncomponents/upload-tab/index.tsx +0 -237
  403. package/templates/default/ikoncomponents/widgets/index.tsx +0 -81
  404. package/templates/default/ikoncomponents/widgets/type.ts +0 -11
  405. package/templates/default/ikoncomponents/work-in-progress/index.tsx +0 -16
  406. package/templates/default/styles.css +0 -1159
  407. package/templates/default/utils/actions/account/index.ts +0 -33
  408. package/templates/default/utils/actions/account/type.ts +0 -4
  409. package/templates/default/utils/actions/common/revalidate.ts +0 -18
  410. package/templates/default/utils/actions/common/type.ts +0 -4
  411. package/templates/default/utils/actions/software/index.ts +0 -106
  412. package/templates/default/utils/api/accountService/index.ts +0 -103
  413. package/templates/default/utils/api/accountService/type.ts +0 -4
  414. package/templates/default/utils/api/file-upload/index.ts +0 -103
  415. package/templates/default/utils/api/file-upload/type.ts +0 -8
  416. package/templates/default/utils/api/loginService/index.ts +0 -106
  417. package/templates/default/utils/api/softwareService/index.ts +0 -356
  418. package/templates/default/utils/api/softwareService/type.ts +0 -62
  419. package/templates/default/utils/cn.ts +0 -6
  420. package/templates/default/utils/session/cookieSession.ts +0 -49
  421. package/templates/default/utils/theme-provider/index.tsx +0 -11
  422. package/templates/default/utils/token-management/index.ts +0 -115
  423. package/templates/default/utils/token-management/types.ts +0 -6
@@ -1,183 +0,0 @@
1
- 'use client';
2
-
3
- import React, { ForwardedRef, forwardRef, JSX, useEffect, useImperativeHandle, useRef } from 'react';
4
- import { EChartsType, getInstanceByDom, init, ResizeOpts } from 'echarts';
5
-
6
- interface Props {
7
- parentDivProps?: any;
8
- option?: Record<string | number, any>;
9
- style?: Record<string, string>;
10
- settings?: Record<string, any>;
11
- loading?: boolean;
12
- theme?: string | object | null;
13
- isConfigurable?: boolean;
14
- resizeKey?: null | boolean | number | string;
15
- onClick?: (...args: any) => void;
16
- onConfigure?: (...args: any) => void;
17
- }
18
-
19
- function validateOption(option?: null | Record<string, any>): Record<string, any> {
20
- if (option === undefined || option === null || typeof option !== 'object') {
21
- option = {};
22
- }
23
-
24
- const validatedOption = { ...option };
25
-
26
- if (
27
- validatedOption.toolbox === undefined ||
28
- validatedOption.toolbox === null ||
29
- typeof validatedOption.toolbox !== 'object'
30
- ) {
31
- validatedOption.toolbox = {};
32
- }
33
-
34
- if (
35
- validatedOption.toolbox.feature === undefined ||
36
- validatedOption.toolbox.feature === null ||
37
- typeof validatedOption.toolbox.feature !== 'object'
38
- ) {
39
- validatedOption.toolbox.feature = {};
40
- }
41
-
42
- return validatedOption;
43
- }
44
-
45
- export const EChart = forwardRef<HTMLElement, Props>((
46
- {
47
- parentDivProps = {},
48
- option = {},
49
- style = {},
50
- settings = {},
51
- loading = true,
52
- theme,
53
- isConfigurable = false,
54
- resizeKey,
55
- onClick = () => { },
56
- onConfigure = () => { }
57
- },
58
- ref
59
- ) => {
60
- const chartRef = useRef<HTMLDivElement | null>(null);
61
- const chartInstanceRef = useRef<EChartsType | null>(null);
62
-
63
- const validatedOption = validateOption(option);
64
-
65
- if (isConfigurable) {
66
- validatedOption.toolbox.feature = {
67
- ...validatedOption.toolbox.feature,
68
- myConfigureChartTool: {
69
- show: true,
70
- title: 'Configure Chart',
71
- icon: 'image://data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgaGVpZ2h0PSIxNiIgdmlld0JveD0iMCAwIDI0IDI0IiBmaWxsPSJub25lIiBzdHJva2U9ImN1cnJlbnRDb2xvciIgc3Ryb2tlLXdpZHRoPSIxIiBzdHJva2UtbGluZWNhcD0icm91bmQiIHN0cm9rZS1saW5lam9pbj0icm91bmQiIGNsYXNzPSJsdWNpZGUgbHVjaWRlLXNldHRpbmdzLTIiPjxwYXRoIGQ9Ik0yMCA3aC05Ii8+PHBhdGggZD0iTTE0IDE3SDUiLz48Y2lyY2xlIGN4PSIxNyIgY3k9IjE3IiByPSIzIi8+PGNpcmNsZSBjeD0iNyIgY3k9IjciIHI9IjMiLz48L3N2Zz4=',
72
- onclick: () => onConfigure?.()
73
- }
74
- };
75
- }
76
-
77
- useImperativeHandle<HTMLElement, any>(ref, () => {
78
- return {
79
- getChartObject: () => {
80
- return chartRef.current ? getInstanceByDom(chartRef.current) : null;
81
- },
82
-
83
- setOption: (validatedOption: any, settings: any) => {
84
- if (!chartRef.current) {
85
- return;
86
- }
87
-
88
- const chart = getInstanceByDom(chartRef.current);
89
- chart?.setOption(validatedOption, settings);
90
- },
91
-
92
- resize: (secondResizeDelay = 0) => {
93
- if (!chartRef.current) {
94
- return;
95
- }
96
-
97
- const chart = getInstanceByDom(chartRef.current);
98
- chart?.resize();
99
-
100
- if (secondResizeDelay) {
101
- setTimeout(() => chart?.resize(), secondResizeDelay);
102
- }
103
- },
104
-
105
- loadingVisible: (visibility?: boolean) => {
106
- if (!chartRef.current) {
107
- return;
108
- }
109
-
110
- const chart = getInstanceByDom(chartRef.current);
111
- visibility ? chart?.showLoading() : chart?.hideLoading();
112
- },
113
-
114
- dispose: () => {
115
- if (!chartRef.current) {
116
- return;
117
- }
118
-
119
- const chart = getInstanceByDom(chartRef.current);
120
- chart?.dispose();
121
- },
122
-
123
- on: (eventName: string, callback: (...args: any) => void) => {
124
- if (!chartRef.current) {
125
- return;
126
- }
127
-
128
- const chart = getInstanceByDom(chartRef.current);
129
- chart?.on(eventName, callback);
130
- }
131
- };
132
- });
133
-
134
- useEffect(() => {
135
- if (chartRef.current) {
136
- chartInstanceRef.current = init(chartRef.current, theme);
137
- }
138
-
139
- const resizeCallback = () => chartInstanceRef.current?.resize?.();
140
- window.addEventListener('resize', resizeCallback);
141
-
142
- return () => {
143
- if (chartInstanceRef.current) {
144
- chartInstanceRef.current.dispose();
145
- chartInstanceRef.current = null;
146
- }
147
-
148
- window.removeEventListener('resize', resizeCallback);
149
- };
150
- }, [theme]);
151
-
152
- useEffect(() => {
153
- if (chartInstanceRef.current) {
154
- chartInstanceRef.current.setOption(validatedOption, settings);
155
- }
156
- if (chartInstanceRef.current) {
157
- chartInstanceRef.current.on('click', onClick);
158
- }
159
- }, [option, settings, theme]);
160
-
161
- useEffect(() => {
162
- if (chartInstanceRef.current) {
163
- chartInstanceRef.current.resize();
164
- }
165
- }, [resizeKey]);
166
-
167
- useEffect(() => {
168
- if (chartInstanceRef.current) {
169
- setTimeout(() => {
170
- chartInstanceRef.current?.resize();
171
- }, 500);
172
- }
173
- }, []);
174
-
175
- return (
176
- <div
177
- ref={chartRef}
178
- {...parentDivProps}
179
- style={{ width: '100%', height: '100%', ...style }}
180
- />
181
- );
182
- });
183
-
@@ -1,27 +0,0 @@
1
- import React, { useRef } from 'react'
2
- import { Upload } from 'lucide-react'
3
- import { Input } from '../../shadcn/input'
4
- import { IconButtonWithTooltip } from '../buttons';
5
-
6
- export function FileInput({ tooltipContent, fileNamePlaceholder, fileName, onFileNameChange, ...props }: any) {
7
- const inputRef = useRef<HTMLInputElement>(null);
8
- return (
9
- <>
10
- <div className='flex'>
11
- <Input
12
- ref={inputRef}
13
- type="file"
14
- className="hidden"
15
- {...props}
16
- />
17
- <div className='mx-1'></div>
18
- <Input className='rounded-e-none' placeholder={fileNamePlaceholder} onChange={(...args: any) => onFileNameChange?.(...args)} value={fileName} />
19
- <IconButtonWithTooltip tooltipContent={tooltipContent || "Browse File"} onClick={() => inputRef?.current?.click()} className='border-s-0 rounded-s-none'>
20
- <Upload />
21
- </IconButtonWithTooltip>
22
- </div>
23
- </>
24
- )
25
- }
26
-
27
-
@@ -1,121 +0,0 @@
1
- "use client";
2
-
3
- import React, { useState, DragEvent } from "react";
4
- import { UploadCloud, FileUp } from "lucide-react";
5
-
6
- export interface FileUploaderProps {
7
- label?: string;
8
- isDrag?: boolean; // enable or disable drag & drop
9
- onFileSelect: (fileObj: any) => Promise<any> | void; // now returns object with base64
10
- }
11
-
12
- // --- Helper: Convert File to Object with Base64 ---
13
- export const convertFileToObject = async (file: File) => {
14
- const arrayBuffer = await file.arrayBuffer();
15
- const base64 = btoa(String.fromCharCode(...new Uint8Array(arrayBuffer)));
16
-
17
- return {
18
- message: "File processed successfully",
19
- fileName: file.name,
20
- size: file.size,
21
- type: file.type,
22
- lastModified: file.lastModified,
23
- base64: base64,
24
- };
25
- };
26
-
27
- export function FileUploader({
28
- label = "Upload File",
29
- isDrag = false,
30
- onFileSelect,
31
- }: FileUploaderProps) {
32
- const [isDragging, setIsDragging] = useState(false);
33
-
34
- const handleFile = async (file: File) => {
35
- if (!file) return;
36
- const fileObj = await convertFileToObject(file); // convert to object
37
- await onFileSelect(fileObj); // pass object to parent
38
- };
39
-
40
- // ---- DRAG HANDLERS ----
41
- const handleDrop = (e: DragEvent<HTMLDivElement>) => {
42
- if (!isDrag) return;
43
- e.preventDefault();
44
- setIsDragging(false);
45
-
46
- const file = e.dataTransfer.files?.[0];
47
- if (file) handleFile(file);
48
- };
49
-
50
- const handleDragOver = (e: DragEvent<HTMLDivElement>) => {
51
- if (!isDrag) return;
52
- e.preventDefault();
53
- setIsDragging(true);
54
- };
55
-
56
- const handleDragLeave = () => {
57
- if (!isDrag) return;
58
- setIsDragging(false);
59
- };
60
-
61
- const handleInputChange = (e: React.ChangeEvent<HTMLInputElement>) => {
62
- const file = e.target.files?.[0];
63
- if (file) handleFile(file);
64
- };
65
-
66
- return (
67
- <div className="flex flex-col gap-2 w-full">
68
- <label className="text-sm font-medium">{label}</label>
69
-
70
- <input
71
- type="file"
72
- id="fileInput"
73
- className="hidden"
74
- onChange={handleInputChange}
75
- />
76
-
77
- {/* ----- DRAG & DROP VERSION ----- */}
78
- {isDrag ? (
79
- <div
80
- className={`border-2 border-dashed rounded-lg p-6 text-center cursor-pointer transition
81
- ${isDragging ? "border-blue-600 bg-blue-50" : "border-gray-300"}
82
- `}
83
- onDragOver={handleDragOver}
84
- onDragLeave={handleDragLeave}
85
- onDrop={handleDrop}
86
- onClick={() => document.getElementById("fileInput")?.click()}
87
- >
88
- <div className="flex flex-col items-center gap-3">
89
- <UploadCloud className="w-10 h-10 text-blue-600" />
90
- <p className="text-gray-600">
91
- Drag & drop your file here or{" "}
92
- <span className="text-blue-600 underline">browse</span>
93
- </p>
94
- </div>
95
- </div>
96
- ) : (
97
- // ----- SIMPLE UPLOAD BOX -----
98
- <div
99
- className="border rounded-lg p-4 flex flex-col items-center gap-2 cursor-pointer text-center"
100
- onClick={() => document.getElementById("fileInput")?.click()}
101
- >
102
- <FileUp className="w-8 h-8 text-blue-600" />
103
- <span className="text-blue-600 underline">Browse File</span>
104
- </div>
105
- )}
106
- </div>
107
- );
108
- }
109
-
110
- // --- Helper Function: Recreate Image from File Object ---
111
- export function getImageFromObject(obj: any) {
112
- const byteCharacters = atob(obj.base64);
113
- const byteNumbers = new Array(byteCharacters.length)
114
- .fill(0)
115
- .map((_, i) => byteCharacters.charCodeAt(i));
116
- const byteArray = new Uint8Array(byteNumbers);
117
-
118
- const blob = new Blob([byteArray], { type: obj.type });
119
-
120
- return URL.createObjectURL(blob); // usable in <img src="..." />
121
- }
@@ -1,111 +0,0 @@
1
- import {
2
- FormControl,
3
- FormDescription,
4
- FormField,
5
- FormItem,
6
- FormLabel,
7
- FormMessage,
8
- } from "../../../shadcn/form";
9
- import React from "react";
10
- import { FormComboboxInputProps } from "../types";
11
- import { Popover, PopoverContent, PopoverTrigger } from "../../../shadcn/popover";
12
- import { Button } from "../../../shadcn/button";
13
- import { cn } from "../../../utils/cn";
14
- import { Check, ChevronsUpDown } from "lucide-react";
15
- import {
16
- Command,
17
- CommandEmpty,
18
- CommandGroup,
19
- CommandInput,
20
- CommandItem,
21
- CommandList,
22
- } from "../../../shadcn/command";
23
-
24
- export function FormComboboxInput({
25
- formControl,
26
- name,
27
- label,
28
- placeholder,
29
- formDescription,
30
- items,
31
- disabled,
32
- onSelect,
33
- }: FormComboboxInputProps) {
34
- return (
35
- <>
36
- <FormField
37
- control={formControl}
38
- name={name}
39
- render={({ field }) => (
40
- <FormItem className="">
41
- {label && (
42
- <>
43
- <FormLabel>{label}</FormLabel>
44
-
45
- </>
46
- )}
47
- <Popover>
48
- <PopoverTrigger asChild className="w-full">
49
- <FormControl>
50
- <Button
51
- variant="outline"
52
- role="combobox"
53
- className={cn(
54
- "justify-between",
55
- !field.value && "text-muted-foreground"
56
- )}
57
- disabled={
58
- disabled == true ||
59
- (disabled && disabled(...arguments))
60
- }
61
- >
62
- {field.value
63
- ? items.find((item) => item.value === field.value)
64
- ?.label || field.value
65
- : placeholder}
66
- <ChevronsUpDown className="opacity-50" />
67
- </Button>
68
- </FormControl>
69
- </PopoverTrigger>
70
- <PopoverContent className="p-0" align="start">
71
- <Command>
72
- <CommandInput placeholder="Search..." />
73
- <CommandList>
74
- <CommandEmpty>No items found.</CommandEmpty>
75
- <CommandGroup>
76
- {items.map((item) => (
77
- <CommandItem
78
- value={item.value}
79
- key={item.value}
80
- disabled={(item.disabled == true || (item.disabled && item.disabled(item)))}
81
- onSelect={(value) => {
82
- field.onChange(value);
83
- onSelect && onSelect(value);
84
- }}
85
- >
86
- {item?.label || item.value}
87
- <Check
88
- className={cn(
89
- "ml-auto",
90
- item.value === field.value
91
- ? "opacity-100"
92
- : "opacity-0"
93
- )}
94
- />
95
- </CommandItem>
96
- ))}
97
- </CommandGroup>
98
- </CommandList>
99
- </Command>
100
- </PopoverContent>
101
- </Popover>
102
- {formDescription && (
103
- <FormDescription>{formDescription}</FormDescription>
104
- )}
105
- <FormMessage />
106
- </FormItem>
107
- )}
108
- />
109
- </>
110
- );
111
- }
@@ -1,121 +0,0 @@
1
- 'use client'
2
-
3
- import React from "react";
4
- import { useController, Control } from "react-hook-form";
5
- import {
6
- FormControl,
7
- FormDescription,
8
- FormField,
9
- FormItem,
10
- FormLabel,
11
- FormMessage,
12
- } from "../../../shadcn/form";
13
- import { Popover, PopoverContent, PopoverTrigger } from "../../../shadcn/popover";
14
- import { Button } from "../../../shadcn/button";
15
- import { cn } from "../../../utils/cn";
16
- import { Check, ChevronsUpDown } from "lucide-react";
17
- import {
18
- Command,
19
- CommandEmpty,
20
- CommandGroup,
21
- CommandInput,
22
- CommandItem,
23
- CommandList,
24
- } from "../../../shadcn/command";
25
-
26
- // Updated type definition to include 'value' and 'onChange'
27
- export interface FormComboboxInputProps {
28
- formControl: Control<any>;
29
- name: string;
30
- label?: string;
31
- placeholder?: string;
32
- formDescription?: string;
33
- items: { value: string; label: string; disabled?: boolean | ((item: any) => boolean) }[];
34
- disabled?: boolean | ((...args: any[]) => boolean);
35
- onSelect?: (value: any) => void;
36
- value?: string; // added for controlled component
37
- onChange?: (value: any) => void; // added for controlled component
38
- }
39
-
40
- export function FormComboboxInputWithValue(props: FormComboboxInputProps) {
41
- const { field } = useController({ name: props.name, control: props.formControl });
42
- // Use the external value if provided, otherwise use the field's value.
43
- const currentValue = props.value !== undefined ? props.value : field.value;
44
- return (
45
- <FormField
46
- control={props.formControl}
47
- name={props.name}
48
- render={({ field }) => (
49
- <FormItem className="">
50
- {props.label && (
51
- <>
52
- <FormLabel>{props.label}</FormLabel>
53
- <br />
54
- </>
55
- )}
56
- <Popover>
57
- <PopoverTrigger asChild className="w-full">
58
- <FormControl>
59
- <Button
60
- variant="outline"
61
- role="combobox"
62
- className={cn(
63
- "justify-between",
64
- !currentValue && "text-muted-foreground"
65
- )}
66
- disabled={
67
- typeof props.disabled === "function" ? props.disabled() : props.disabled
68
- }
69
- >
70
- {currentValue
71
- ? props.items.find((item) => item.value === currentValue)
72
- ?.label || currentValue
73
- : props.placeholder}
74
- <ChevronsUpDown className="opacity-50" />
75
- </Button>
76
- </FormControl>
77
- </PopoverTrigger>
78
- <PopoverContent className="p-0" align="start">
79
- <Command>
80
- <CommandInput placeholder="Search..." />
81
- <CommandList>
82
- <CommandEmpty>No items found.</CommandEmpty>
83
- <CommandGroup>
84
- {props.items.map((item) => (
85
- <CommandItem
86
- value={item.value}
87
- key={item.value}
88
- disabled={
89
- typeof item.disabled === "function"
90
- ? item.disabled(item)
91
- : item.disabled
92
- }
93
- onSelect={(value) => {
94
- field.onChange(value);
95
- props.onSelect && props.onSelect(value);
96
- props.onChange && props.onChange(value);
97
- }}
98
- >
99
- {item?.label || item.value}
100
- <Check
101
- className={cn(
102
- "ml-auto",
103
- item.value === currentValue ? "opacity-100" : "opacity-0"
104
- )}
105
- />
106
- </CommandItem>
107
- ))}
108
- </CommandGroup>
109
- </CommandList>
110
- </Command>
111
- </PopoverContent>
112
- </Popover>
113
- {props.formDescription && (
114
- <FormDescription>{props.formDescription}</FormDescription>
115
- )}
116
- <FormMessage />
117
- </FormItem>
118
- )}
119
- />
120
- );
121
- }
@@ -1,80 +0,0 @@
1
- import {
2
- FormControl,
3
- FormDescription,
4
- FormField,
5
- FormItem,
6
- FormLabel,
7
- FormMessage,
8
- } from "../../../shadcn/form";
9
- import React from "react";
10
- import { FormDateInputProps } from "../types";
11
- import { Popover, PopoverContent, PopoverTrigger } from "../../../shadcn/popover";
12
- import { Button } from "../../../shadcn/button";
13
- import { cn } from "../../../utils/cn";
14
- import { format } from "date-fns";
15
- import { CalendarIcon } from "lucide-react";
16
- import { Calendar } from "../../../shadcn/calendar";
17
-
18
- export function FormDateInput({
19
- formControl,
20
- name,
21
- label,
22
- placeholder,
23
- dateFormat,
24
- calendarDateDisabled,
25
- formDescription,
26
- disabled,
27
- }: FormDateInputProps) {
28
- return (
29
- <>
30
- <FormField
31
- control={formControl}
32
- name={name}
33
- render={({ field }) => (
34
- <FormItem>
35
- {label && (
36
- <>
37
- <FormLabel>{label}</FormLabel>
38
- </>
39
- )}
40
- <Popover>
41
- <PopoverTrigger asChild className="w-full">
42
- <FormControl>
43
- <Button
44
- variant={"outline"}
45
- className={cn(!field.value && "text-foreground/50")}
46
- disabled={disabled}
47
- >
48
- {field.value ? (
49
- format(field.value, dateFormat || "PPP")
50
- ) : (
51
- <span>{placeholder || "Pick a date"}</span>
52
- )}
53
- <CalendarIcon className="ml-auto h-4 w-4 opacity-50" />
54
- </Button>
55
- </FormControl>
56
- </PopoverTrigger>
57
- <PopoverContent className="w-auto p-0" align="start">
58
- <Calendar
59
- mode="single"
60
- selected={field.value}
61
- onSelect={field.onChange}
62
- disabled={calendarDateDisabled}
63
- captionLayout="dropdown"
64
- // disabled={(date) =>
65
- // date > new Date() || date < new Date("1900-01-01")
66
- // }
67
- autoFocus
68
- />
69
- </PopoverContent>
70
- </Popover>
71
- {formDescription && (
72
- <FormDescription>{formDescription}</FormDescription>
73
- )}
74
- <FormMessage />
75
- </FormItem>
76
- )}
77
- />
78
- </>
79
- );
80
- }
@@ -1,9 +0,0 @@
1
- import React from 'react'
2
-
3
- export function FormFileInput() {
4
- return (
5
- <>
6
-
7
- </>
8
- )
9
- }
@@ -1,27 +0,0 @@
1
- import { FormControl, FormDescription, FormField, FormItem, FormLabel, FormMessage } from '../../../shadcn/form'
2
- import { Input } from '../../../shadcn/input'
3
- import React from 'react'
4
- import { FormInputProps } from '../types'
5
-
6
-
7
- export function FormInput({ formControl, label, formDescription, extraFormComponent, name, ...inputProps }: FormInputProps) {
8
- return (
9
- <>
10
- <FormField
11
- control={formControl}
12
- name={name}
13
- render={({ field }) => (
14
- <FormItem>
15
- {label && <FormLabel>{label}</FormLabel>}
16
- <FormControl>
17
- <Input {...field} {...inputProps} />
18
- </FormControl>
19
- {extraFormComponent && extraFormComponent(field.value)}
20
- {formDescription && <FormDescription>{formDescription}</FormDescription>}
21
- <FormMessage />
22
- </FormItem>
23
- )}
24
- />
25
- </>
26
- )
27
- }