@mihcm/ui 0.14.1 → 0.15.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (300) hide show
  1. package/dist/CheckboxGrid.native.d.ts.map +1 -1
  2. package/dist/CheckboxGrid.native.js +2 -1
  3. package/dist/CheckboxGrid.native.js.map +1 -1
  4. package/dist/Combobox.native.d.ts.map +1 -1
  5. package/dist/Combobox.native.js +2 -1
  6. package/dist/Combobox.native.js.map +1 -1
  7. package/dist/DataTable/column-filter.d.ts +8 -0
  8. package/dist/DataTable/column-filter.d.ts.map +1 -0
  9. package/dist/DataTable/column-filter.js +67 -0
  10. package/dist/DataTable/column-filter.js.map +1 -0
  11. package/dist/DataTable/column-header.d.ts +16 -0
  12. package/dist/DataTable/column-header.d.ts.map +1 -0
  13. package/dist/DataTable/column-header.js +11 -0
  14. package/dist/DataTable/column-header.js.map +1 -0
  15. package/dist/DataTable/column-visibility.d.ts +7 -0
  16. package/dist/DataTable/column-visibility.d.ts.map +1 -0
  17. package/dist/DataTable/column-visibility.js +35 -0
  18. package/dist/DataTable/column-visibility.js.map +1 -0
  19. package/dist/DataTable/index.d.ts +5 -0
  20. package/dist/DataTable/index.d.ts.map +1 -0
  21. package/dist/DataTable/index.js +5 -0
  22. package/dist/DataTable/index.js.map +1 -0
  23. package/dist/DataTable/pinning.d.ts +13 -0
  24. package/dist/DataTable/pinning.d.ts.map +1 -0
  25. package/dist/DataTable/pinning.js +29 -0
  26. package/dist/DataTable/pinning.js.map +1 -0
  27. package/dist/DataTable.d.ts +3 -7
  28. package/dist/DataTable.d.ts.map +1 -1
  29. package/dist/DataTable.js +7 -126
  30. package/dist/DataTable.js.map +1 -1
  31. package/dist/Dialog.native.d.ts +3 -1
  32. package/dist/Dialog.native.d.ts.map +1 -1
  33. package/dist/Dialog.native.js +2 -2
  34. package/dist/Dialog.native.js.map +1 -1
  35. package/dist/Form/building-blocks.d.ts +26 -0
  36. package/dist/Form/building-blocks.d.ts.map +1 -0
  37. package/dist/Form/building-blocks.js +29 -0
  38. package/dist/Form/building-blocks.js.map +1 -0
  39. package/dist/Form/fields-choice.d.ts +72 -0
  40. package/dist/Form/fields-choice.d.ts.map +1 -0
  41. package/dist/Form/fields-choice.js +69 -0
  42. package/dist/Form/fields-choice.js.map +1 -0
  43. package/dist/Form/fields-complex.d.ts +28 -0
  44. package/dist/Form/fields-complex.d.ts.map +1 -0
  45. package/dist/Form/fields-complex.js +38 -0
  46. package/dist/Form/fields-complex.js.map +1 -0
  47. package/dist/Form/fields-date.d.ts +46 -0
  48. package/dist/Form/fields-date.d.ts.map +1 -0
  49. package/dist/Form/fields-date.js +41 -0
  50. package/dist/Form/fields-date.js.map +1 -0
  51. package/dist/Form/fields-text.d.ts +47 -0
  52. package/dist/Form/fields-text.d.ts.map +1 -0
  53. package/dist/Form/fields-text.js +46 -0
  54. package/dist/Form/fields-text.js.map +1 -0
  55. package/dist/Form/fields-toggle.d.ts +24 -0
  56. package/dist/Form/fields-toggle.d.ts.map +1 -0
  57. package/dist/Form/fields-toggle.js +32 -0
  58. package/dist/Form/fields-toggle.js.map +1 -0
  59. package/dist/Form/helpers.d.ts +66 -0
  60. package/dist/Form/helpers.d.ts.map +1 -0
  61. package/dist/Form/helpers.js +44 -0
  62. package/dist/Form/helpers.js.map +1 -0
  63. package/dist/Form/types.d.ts +25 -0
  64. package/dist/Form/types.d.ts.map +1 -0
  65. package/dist/Form/types.js +8 -0
  66. package/dist/Form/types.js.map +1 -0
  67. package/dist/Form.d.ts +24 -298
  68. package/dist/Form.d.ts.map +1 -1
  69. package/dist/Form.js +30 -246
  70. package/dist/Form.js.map +1 -1
  71. package/dist/IconSidebar.d.ts +6 -46
  72. package/dist/IconSidebar.d.ts.map +1 -1
  73. package/dist/IconSidebar.js +6 -116
  74. package/dist/IconSidebar.js.map +1 -1
  75. package/dist/MainSidebar/back-button.d.ts +14 -0
  76. package/dist/MainSidebar/back-button.d.ts.map +1 -0
  77. package/dist/MainSidebar/back-button.js +14 -0
  78. package/dist/MainSidebar/back-button.js.map +1 -0
  79. package/dist/MainSidebar/breadcrumb.d.ts +10 -0
  80. package/dist/MainSidebar/breadcrumb.d.ts.map +1 -0
  81. package/dist/MainSidebar/breadcrumb.js +24 -0
  82. package/dist/MainSidebar/breadcrumb.js.map +1 -0
  83. package/dist/MainSidebar/columns.d.ts +3 -0
  84. package/dist/MainSidebar/columns.d.ts.map +1 -0
  85. package/dist/MainSidebar/columns.js +198 -0
  86. package/dist/MainSidebar/columns.js.map +1 -0
  87. package/dist/MainSidebar/command.d.ts +3 -0
  88. package/dist/MainSidebar/command.d.ts.map +1 -0
  89. package/dist/MainSidebar/command.js +193 -0
  90. package/dist/MainSidebar/command.js.map +1 -0
  91. package/dist/MainSidebar/drilldown.d.ts +3 -0
  92. package/dist/MainSidebar/drilldown.d.ts.map +1 -0
  93. package/dist/MainSidebar/drilldown.js +154 -0
  94. package/dist/MainSidebar/drilldown.js.map +1 -0
  95. package/dist/MainSidebar/expanded.d.ts +7 -0
  96. package/dist/MainSidebar/expanded.d.ts.map +1 -0
  97. package/dist/MainSidebar/expanded.js +102 -0
  98. package/dist/MainSidebar/expanded.js.map +1 -0
  99. package/dist/MainSidebar/floating.d.ts +3 -0
  100. package/dist/MainSidebar/floating.d.ts.map +1 -0
  101. package/dist/MainSidebar/floating.js +116 -0
  102. package/dist/MainSidebar/floating.js.map +1 -0
  103. package/dist/MainSidebar/helpers.d.ts +50 -0
  104. package/dist/MainSidebar/helpers.d.ts.map +1 -0
  105. package/dist/MainSidebar/helpers.js +150 -0
  106. package/dist/MainSidebar/helpers.js.map +1 -0
  107. package/dist/MainSidebar/hover.d.ts +3 -0
  108. package/dist/MainSidebar/hover.d.ts.map +1 -0
  109. package/dist/MainSidebar/hover.js +177 -0
  110. package/dist/MainSidebar/hover.js.map +1 -0
  111. package/dist/MainSidebar/index.d.ts +6 -0
  112. package/dist/MainSidebar/index.d.ts.map +1 -0
  113. package/dist/MainSidebar/index.js +108 -0
  114. package/dist/MainSidebar/index.js.map +1 -0
  115. package/dist/MainSidebar/mobile.d.ts +29 -0
  116. package/dist/MainSidebar/mobile.d.ts.map +1 -0
  117. package/dist/MainSidebar/mobile.js +38 -0
  118. package/dist/MainSidebar/mobile.js.map +1 -0
  119. package/dist/MainSidebar/motion.d.ts +23 -0
  120. package/dist/MainSidebar/motion.d.ts.map +1 -0
  121. package/dist/MainSidebar/motion.js +40 -0
  122. package/dist/MainSidebar/motion.js.map +1 -0
  123. package/dist/MainSidebar/rail.d.ts +24 -0
  124. package/dist/MainSidebar/rail.d.ts.map +1 -0
  125. package/dist/MainSidebar/rail.js +29 -0
  126. package/dist/MainSidebar/rail.js.map +1 -0
  127. package/dist/MainSidebar/search.d.ts +19 -0
  128. package/dist/MainSidebar/search.d.ts.map +1 -0
  129. package/dist/MainSidebar/search.js +33 -0
  130. package/dist/MainSidebar/search.js.map +1 -0
  131. package/dist/MainSidebar/types.d.ts +161 -0
  132. package/dist/MainSidebar/types.d.ts.map +1 -0
  133. package/dist/MainSidebar/types.js +2 -0
  134. package/dist/MainSidebar/types.js.map +1 -0
  135. package/dist/MainSidebar.d.ts +6 -1
  136. package/dist/MainSidebar.d.ts.map +1 -1
  137. package/dist/MainSidebar.js +6 -1
  138. package/dist/MainSidebar.js.map +1 -1
  139. package/dist/NavigationMenu.js +1 -1
  140. package/dist/NavigationMenu.js.map +1 -1
  141. package/dist/RichTextEditor/theme.d.ts +44 -0
  142. package/dist/RichTextEditor/theme.d.ts.map +1 -0
  143. package/dist/RichTextEditor/theme.js +41 -0
  144. package/dist/RichTextEditor/theme.js.map +1 -0
  145. package/dist/RichTextEditor/toolbar-icons.d.ts +21 -0
  146. package/dist/RichTextEditor/toolbar-icons.d.ts.map +1 -0
  147. package/dist/RichTextEditor/toolbar-icons.js +21 -0
  148. package/dist/RichTextEditor/toolbar-icons.js.map +1 -0
  149. package/dist/RichTextEditor/toolbar.d.ts +5 -0
  150. package/dist/RichTextEditor/toolbar.d.ts.map +1 -0
  151. package/dist/RichTextEditor/toolbar.js +116 -0
  152. package/dist/RichTextEditor/toolbar.js.map +1 -0
  153. package/dist/RichTextEditor.d.ts +16 -9
  154. package/dist/RichTextEditor.d.ts.map +1 -1
  155. package/dist/RichTextEditor.js +18 -164
  156. package/dist/RichTextEditor.js.map +1 -1
  157. package/dist/Select/content.d.ts +9 -0
  158. package/dist/Select/content.d.ts.map +1 -0
  159. package/dist/Select/content.js +80 -0
  160. package/dist/Select/content.js.map +1 -0
  161. package/dist/Select/context.d.ts +27 -0
  162. package/dist/Select/context.d.ts.map +1 -0
  163. package/dist/Select/context.js +35 -0
  164. package/dist/Select/context.js.map +1 -0
  165. package/dist/Select/item.d.ts +13 -0
  166. package/dist/Select/item.d.ts.map +1 -0
  167. package/dist/Select/item.js +39 -0
  168. package/dist/Select/item.js.map +1 -0
  169. package/dist/Select/parts.d.ts +14 -0
  170. package/dist/Select/parts.d.ts.map +1 -0
  171. package/dist/Select/parts.js +17 -0
  172. package/dist/Select/parts.js.map +1 -0
  173. package/dist/Select/react-select.d.ts +25 -0
  174. package/dist/Select/react-select.d.ts.map +1 -0
  175. package/dist/Select/react-select.js +66 -0
  176. package/dist/Select/react-select.js.map +1 -0
  177. package/dist/Select/root.d.ts +15 -0
  178. package/dist/Select/root.d.ts.map +1 -0
  179. package/dist/Select/root.js +41 -0
  180. package/dist/Select/root.js.map +1 -0
  181. package/dist/Select/trigger.d.ts +15 -0
  182. package/dist/Select/trigger.d.ts.map +1 -0
  183. package/dist/Select/trigger.js +61 -0
  184. package/dist/Select/trigger.js.map +1 -0
  185. package/dist/Select.d.ts +14 -62
  186. package/dist/Select.d.ts.map +1 -1
  187. package/dist/Select.js +14 -293
  188. package/dist/Select.js.map +1 -1
  189. package/dist/Sidebar/context.d.ts +28 -0
  190. package/dist/Sidebar/context.d.ts.map +1 -0
  191. package/dist/Sidebar/context.js +37 -0
  192. package/dist/Sidebar/context.js.map +1 -0
  193. package/dist/Sidebar/group.d.ts +13 -0
  194. package/dist/Sidebar/group.d.ts.map +1 -0
  195. package/dist/Sidebar/group.js +20 -0
  196. package/dist/Sidebar/group.js.map +1 -0
  197. package/dist/Sidebar/icons.d.ts +7 -0
  198. package/dist/Sidebar/icons.d.ts.map +1 -0
  199. package/dist/Sidebar/icons.js +12 -0
  200. package/dist/Sidebar/icons.js.map +1 -0
  201. package/dist/Sidebar/layout.d.ts +9 -0
  202. package/dist/Sidebar/layout.d.ts.map +1 -0
  203. package/dist/Sidebar/layout.js +21 -0
  204. package/dist/Sidebar/layout.js.map +1 -0
  205. package/dist/Sidebar/menu.d.ts +29 -0
  206. package/dist/Sidebar/menu.d.ts.map +1 -0
  207. package/dist/Sidebar/menu.js +55 -0
  208. package/dist/Sidebar/menu.js.map +1 -0
  209. package/dist/Sidebar/provider.d.ts +33 -0
  210. package/dist/Sidebar/provider.d.ts.map +1 -0
  211. package/dist/Sidebar/provider.js +110 -0
  212. package/dist/Sidebar/provider.js.map +1 -0
  213. package/dist/Sidebar/sidebar.d.ts +17 -0
  214. package/dist/Sidebar/sidebar.d.ts.map +1 -0
  215. package/dist/Sidebar/sidebar.js +51 -0
  216. package/dist/Sidebar/sidebar.js.map +1 -0
  217. package/dist/Sidebar/submenu.d.ts +13 -0
  218. package/dist/Sidebar/submenu.d.ts.map +1 -0
  219. package/dist/Sidebar/submenu.js +17 -0
  220. package/dist/Sidebar/submenu.js.map +1 -0
  221. package/dist/Sidebar/trigger.d.ts +9 -0
  222. package/dist/Sidebar/trigger.d.ts.map +1 -0
  223. package/dist/Sidebar/trigger.js +33 -0
  224. package/dist/Sidebar/trigger.js.map +1 -0
  225. package/dist/Sidebar.d.ts +14 -104
  226. package/dist/Sidebar.d.ts.map +1 -1
  227. package/dist/Sidebar.js +14 -300
  228. package/dist/Sidebar.js.map +1 -1
  229. package/dist/StatCard.d.ts +67 -9
  230. package/dist/StatCard.d.ts.map +1 -1
  231. package/dist/StatCard.js +111 -9
  232. package/dist/StatCard.js.map +1 -1
  233. package/dist/TransferList.native.d.ts.map +1 -1
  234. package/dist/TransferList.native.js +2 -1
  235. package/dist/TransferList.native.js.map +1 -1
  236. package/package.json +2 -2
  237. package/src/CheckboxGrid.native.tsx +2 -1
  238. package/src/Combobox.native.tsx +2 -1
  239. package/src/DataTable/column-filter.tsx +134 -0
  240. package/src/DataTable/column-header.tsx +67 -0
  241. package/src/DataTable/column-visibility.tsx +87 -0
  242. package/src/DataTable/index.ts +4 -0
  243. package/src/DataTable/pinning.ts +40 -0
  244. package/src/DataTable.tsx +14 -297
  245. package/src/Dialog.native.tsx +4 -2
  246. package/src/Form/building-blocks.tsx +97 -0
  247. package/src/Form/fields-choice.tsx +312 -0
  248. package/src/Form/fields-complex.tsx +195 -0
  249. package/src/Form/fields-date.tsx +195 -0
  250. package/src/Form/fields-text.tsx +218 -0
  251. package/src/Form/fields-toggle.tsx +123 -0
  252. package/src/Form/helpers.tsx +189 -0
  253. package/src/Form/types.ts +26 -0
  254. package/src/Form.tsx +91 -1308
  255. package/src/IconSidebar.tsx +20 -442
  256. package/src/MainSidebar/back-button.tsx +58 -0
  257. package/src/MainSidebar/breadcrumb.tsx +53 -0
  258. package/src/MainSidebar/columns.tsx +350 -0
  259. package/src/MainSidebar/command.tsx +404 -0
  260. package/src/MainSidebar/drilldown.tsx +373 -0
  261. package/src/MainSidebar/expanded.tsx +414 -0
  262. package/src/MainSidebar/floating.tsx +268 -0
  263. package/src/MainSidebar/helpers.ts +166 -0
  264. package/src/MainSidebar/hover.tsx +334 -0
  265. package/src/MainSidebar/index.tsx +191 -0
  266. package/src/MainSidebar/mobile.tsx +117 -0
  267. package/src/MainSidebar/motion.ts +64 -0
  268. package/src/MainSidebar/rail.tsx +137 -0
  269. package/src/MainSidebar/search.tsx +99 -0
  270. package/src/MainSidebar/types.ts +208 -0
  271. package/src/MainSidebar.tsx +15 -4
  272. package/src/NavigationMenu.tsx +1 -1
  273. package/src/RichTextEditor/theme.ts +43 -0
  274. package/src/RichTextEditor/toolbar-icons.tsx +40 -0
  275. package/src/RichTextEditor/toolbar.tsx +271 -0
  276. package/src/RichTextEditor.tsx +23 -371
  277. package/src/Select/content.tsx +111 -0
  278. package/src/Select/context.tsx +66 -0
  279. package/src/Select/item.tsx +97 -0
  280. package/src/Select/parts.tsx +43 -0
  281. package/src/Select/react-select.tsx +216 -0
  282. package/src/Select/root.tsx +75 -0
  283. package/src/Select/trigger.tsx +122 -0
  284. package/src/Select.tsx +34 -692
  285. package/src/Sidebar/context.tsx +72 -0
  286. package/src/Sidebar/group.tsx +69 -0
  287. package/src/Sidebar/icons.tsx +42 -0
  288. package/src/Sidebar/layout.tsx +64 -0
  289. package/src/Sidebar/menu.tsx +171 -0
  290. package/src/Sidebar/provider.tsx +224 -0
  291. package/src/Sidebar/sidebar.tsx +178 -0
  292. package/src/Sidebar/submenu.tsx +58 -0
  293. package/src/Sidebar/trigger.tsx +104 -0
  294. package/src/Sidebar.tsx +44 -927
  295. package/src/StatCard.tsx +365 -20
  296. package/src/TransferList.native.tsx +2 -1
  297. package/dist/TiptapEditor.d.ts +0 -24
  298. package/dist/TiptapEditor.d.ts.map +0 -1
  299. package/dist/TiptapEditor.js +0 -84
  300. package/dist/TiptapEditor.js.map +0 -1
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fields-complex.d.ts","sourceRoot":"","sources":["../../src/Form/fields-complex.tsx"],"names":[],"mappings":"AAOA,OAAO,EAEL,KAAK,iBAAiB,EAEvB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAY,KAAK,aAAa,EAAE,MAAM,gBAAgB,CAAC;AAO9D,OAAO,KAAK,EAAE,UAAU,EAAoB,mBAAmB,EAAE,MAAM,YAAY,CAAC;AAIpF,MAAM,WAAW,qBAAsB,SAAQ,IAAI,CACjD,iBAAiB,EACf,OAAO,GACP,SAAS,GACT,QAAQ,GACR,SAAS,GACT,aAAa,GACb,mBAAmB,GACnB,WAAW,GACX,YAAY,GACZ,kBAAkB,CACrB;IACC,IAAI,EAAE,UAAU,CAAC;IACjB,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,UAAU,CAAC,EAAE,mBAAmB,CAAC;CAClC;AAED,+DAA+D;AAC/D,wBAAgB,gBAAgB,CAAC,EAC/B,IAAI,EACJ,IAAI,EACJ,KAAK,EACL,WAAW,EACX,QAAQ,EACR,QAAQ,EACR,SAAS,EACT,UAAU,EACV,KAAK,EACL,OAAO,EACP,MAAM,EACN,OAAO,EACP,WAAW,EACX,iBAAiB,EACjB,SAAS,EACT,UAAU,EACV,gBAAgB,GACjB,EAAE,qBAAqB,2CAwCvB;AAID,MAAM,WAAW,iBAAkB,SAAQ,IAAI,CAC7C,aAAa,EACX,QAAQ,GACR,UAAU,GACV,SAAS,GACT,SAAS,GACT,UAAU,GACV,WAAW,GACX,SAAS,GACT,aAAa,GACb,aAAa,GACb,UAAU,CACb;IACC,IAAI,EAAE,UAAU,CAAC;IACjB,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;IACd,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,UAAU,CAAC,EAAE,mBAAmB,CAAC;CAClC;AAED,iFAAiF;AACjF,wBAAgB,YAAY,CAAC,EAC3B,IAAI,EACJ,IAAI,EACJ,KAAK,EACL,gBAAgB,EAChB,QAAQ,EACR,QAAQ,EACR,SAAS,EACT,UAAU,EACV,MAAM,EACN,QAAQ,EACR,OAAO,EACP,OAAO,EACP,QAAQ,EACR,SAAS,EACT,OAAO,EACP,WAAW,EACX,WAAW,EACX,QAAQ,GACT,EAAE,iBAAiB,2CA2CnB"}
@@ -0,0 +1,38 @@
1
+ 'use client';
2
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
+ /**
4
+ * Complex multi-value fields integrated with TanStack Form: FormCheckboxGrid,
5
+ * FormDropzone.
6
+ */
7
+ import { useId } from 'react';
8
+ import { CheckboxGrid, } from '../CheckboxGrid.js';
9
+ import { Dropzone } from '../Dropzone.js';
10
+ import { FormDescription, FormItem, FormLabel, FormMessage, } from './building-blocks.js';
11
+ /** Multi-select CheckboxGrid integrated with TanStack Form. */
12
+ export function FormCheckboxGrid({ form, name, label, description, required, disabled, className, validators, items, columns, layout, density, showToolbar, searchPlaceholder, maxHeight, emptyState, getItemClassName, }) {
13
+ const descId = useId();
14
+ const msgId = `${descId}-msg`;
15
+ return (_jsx(form.Field, { name: name, ...(validators !== undefined && { validators }), children: (field) => {
16
+ const errors = field.state.meta.isTouched ? field.state.meta.errors : [];
17
+ const hasError = errors.length > 0;
18
+ return (_jsxs(FormItem, { ...(className !== undefined && { className }), children: [_jsx(FormLabel, { ...(required !== undefined && { required }), children: label }), _jsx(CheckboxGrid, { items: items, selected: field.state.value ?? {}, onSelectedChange: (next) => {
19
+ if (!disabled)
20
+ field.handleChange(next);
21
+ field.handleBlur();
22
+ }, ...(columns !== undefined && { columns }), ...(layout !== undefined && { layout }), ...(density !== undefined && { density }), ...(showToolbar !== undefined && { showToolbar }), ...(searchPlaceholder !== undefined && { searchPlaceholder }), ...(maxHeight !== undefined && { maxHeight }), ...(emptyState !== undefined && { emptyState }), ...(getItemClassName !== undefined && { getItemClassName }), "aria-disabled": disabled, "aria-describedby": hasError ? msgId : description !== undefined ? descId : undefined, "aria-invalid": hasError }), description !== undefined ? (_jsx(FormDescription, { id: descId, children: description })) : null, hasError ? _jsx(FormMessage, { id: msgId, errors: errors }) : null] }));
23
+ } }));
24
+ }
25
+ /** File-list Dropzone integrated with TanStack Form. Field value is `File[]`. */
26
+ export function FormDropzone({ form, name, label, fieldDescription, required, disabled, className, validators, accept, maxFiles, maxSize, minSize, multiple, validator, heading, description, browseLabel, children, }) {
27
+ const descId = useId();
28
+ const msgId = `${descId}-msg`;
29
+ return (_jsx(form.Field, { name: name, ...(validators !== undefined && { validators }), children: (field) => {
30
+ const errors = field.state.meta.isTouched ? field.state.meta.errors : [];
31
+ const hasError = errors.length > 0;
32
+ return (_jsxs(FormItem, { ...(className !== undefined && { className }), children: [_jsx(FormLabel, { ...(required !== undefined && { required }), children: label }), _jsx(Dropzone, { ...(accept !== undefined && { accept }), ...(maxFiles !== undefined && { maxFiles }), ...(maxSize !== undefined && { maxSize }), ...(minSize !== undefined && { minSize }), ...(multiple !== undefined && { multiple }), ...(validator !== undefined && { validator }), ...(heading !== undefined && { heading }), ...(description !== undefined && { description }), ...(browseLabel !== undefined && { browseLabel }), ...(children !== undefined && { children }), ...(disabled !== undefined && { disabled }), onFilesAccepted: (files) => {
33
+ field.handleChange(files);
34
+ field.handleBlur();
35
+ }, onFilesRejected: () => field.handleBlur(), "aria-describedby": hasError ? msgId : fieldDescription !== undefined ? descId : undefined, "aria-invalid": hasError }), fieldDescription !== undefined ? (_jsx(FormDescription, { id: descId, children: fieldDescription })) : null, hasError ? _jsx(FormMessage, { id: msgId, errors: errors }) : null] }));
36
+ } }));
37
+ }
38
+ //# sourceMappingURL=fields-complex.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fields-complex.js","sourceRoot":"","sources":["../../src/Form/fields-complex.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,46 @@
1
+ import { type DatePickerProps } from '../DatePicker.js';
2
+ import type { AnyFormApi, FormFieldValidators } from './types.js';
3
+ export interface FormDatePickerProps {
4
+ form: AnyFormApi;
5
+ name: string;
6
+ label: string;
7
+ description?: string;
8
+ required?: boolean;
9
+ placeholder?: string;
10
+ disabled?: boolean;
11
+ /** Show time selection alongside date. */
12
+ showTimeSelect?: boolean;
13
+ /** Date format string (default: "MM/dd/yyyy"). */
14
+ dateFormat?: string;
15
+ className?: string;
16
+ validators?: FormFieldValidators;
17
+ }
18
+ /** DatePicker field integrated with TanStack Form. Uses the mihcm DatePicker primitive. */
19
+ export declare function FormDatePicker({ form, name, label, description, required, placeholder, disabled, showTimeSelect, dateFormat, className, validators, }: FormDatePickerProps): import("react/jsx-runtime").JSX.Element;
20
+ export interface FormDateRangePickerProps {
21
+ form: AnyFormApi;
22
+ name: string;
23
+ label: string;
24
+ description?: string;
25
+ required?: boolean;
26
+ placeholder?: string;
27
+ disabled?: boolean;
28
+ isClearable?: boolean;
29
+ align?: DatePickerProps['align'];
30
+ showTimeSelect?: boolean;
31
+ showWeekNumbers?: boolean;
32
+ monthsShown?: number;
33
+ minDate?: Date;
34
+ maxDate?: Date;
35
+ disabledDays?: DatePickerProps['disabledDays'];
36
+ dateFormat?: string;
37
+ calendarProps?: DatePickerProps['calendarProps'];
38
+ triggerWidth?: 'auto' | 'full';
39
+ triggerClassName?: string;
40
+ closeOnRangeComplete?: boolean;
41
+ className?: string;
42
+ validators?: FormFieldValidators;
43
+ }
44
+ /** Date range picker integrated with TanStack Form. Field value is `[start, end]`. */
45
+ export declare function FormDateRangePicker({ form, name, label, description, required, placeholder, disabled, isClearable, align, showTimeSelect, showWeekNumbers, monthsShown, minDate, maxDate, disabledDays, dateFormat, calendarProps, triggerWidth, triggerClassName, closeOnRangeComplete, className, validators, }: FormDateRangePickerProps): import("react/jsx-runtime").JSX.Element;
46
+ //# sourceMappingURL=fields-date.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fields-date.d.ts","sourceRoot":"","sources":["../../src/Form/fields-date.tsx"],"names":[],"mappings":"AAOA,OAAO,EAAc,KAAK,eAAe,EAAE,MAAM,kBAAkB,CAAC;AAOpE,OAAO,KAAK,EAAE,UAAU,EAAoB,mBAAmB,EAAE,MAAM,YAAY,CAAC;AAIpF,MAAM,WAAW,mBAAmB;IAClC,IAAI,EAAE,UAAU,CAAC;IACjB,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,0CAA0C;IAC1C,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,kDAAkD;IAClD,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,UAAU,CAAC,EAAE,mBAAmB,CAAC;CAClC;AAED,2FAA2F;AAC3F,wBAAgB,cAAc,CAAC,EAC7B,IAAI,EACJ,IAAI,EACJ,KAAK,EACL,WAAW,EACX,QAAQ,EACR,WAAW,EACX,QAAQ,EACR,cAAc,EACd,UAAU,EACV,SAAS,EACT,UAAU,GACX,EAAE,mBAAmB,2CAwCrB;AAID,MAAM,WAAW,wBAAwB;IACvC,IAAI,EAAE,UAAU,CAAC;IACjB,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,KAAK,CAAC,EAAE,eAAe,CAAC,OAAO,CAAC,CAAC;IACjC,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,OAAO,CAAC,EAAE,IAAI,CAAC;IACf,OAAO,CAAC,EAAE,IAAI,CAAC;IACf,YAAY,CAAC,EAAE,eAAe,CAAC,cAAc,CAAC,CAAC;IAC/C,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,aAAa,CAAC,EAAE,eAAe,CAAC,eAAe,CAAC,CAAC;IACjD,YAAY,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IAC/B,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,oBAAoB,CAAC,EAAE,OAAO,CAAC;IAC/B,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,UAAU,CAAC,EAAE,mBAAmB,CAAC;CAClC;AAED,sFAAsF;AACtF,wBAAgB,mBAAmB,CAAC,EAClC,IAAI,EACJ,IAAI,EACJ,KAAK,EACL,WAAW,EACX,QAAQ,EACR,WAAW,EACX,QAAQ,EACR,WAAW,EACX,KAAK,EACL,cAAc,EACd,eAAe,EACf,WAAW,EACX,OAAO,EACP,OAAO,EACP,YAAY,EACZ,UAAU,EACV,aAAa,EACb,YAAY,EACZ,gBAAgB,EAChB,oBAAoB,EACpB,SAAS,EACT,UAAU,GACX,EAAE,wBAAwB,2CAsD1B"}
@@ -0,0 +1,41 @@
1
+ 'use client';
2
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
+ /**
4
+ * Date fields integrated with TanStack Form: FormDatePicker, FormDateRangePicker.
5
+ */
6
+ import { useId } from 'react';
7
+ import { cn } from '../internal/cn.js';
8
+ import { DatePicker } from '../DatePicker.js';
9
+ import { FormDescription, FormItem, FormLabel, FormMessage, } from './building-blocks.js';
10
+ /** DatePicker field integrated with TanStack Form. Uses the mihcm DatePicker primitive. */
11
+ export function FormDatePicker({ form, name, label, description, required, placeholder, disabled, showTimeSelect, dateFormat, className, validators, }) {
12
+ const id = useId();
13
+ const descId = `${id}-desc`;
14
+ const msgId = `${id}-msg`;
15
+ return (_jsx(form.Field, { name: name, ...(validators !== undefined && { validators }), children: (field) => {
16
+ const errors = field.state.meta.isTouched ? field.state.meta.errors : [];
17
+ const hasError = errors.length > 0;
18
+ return (_jsxs(FormItem, { ...(className !== undefined && { className }), children: [_jsx(FormLabel, { htmlFor: id, ...(required !== undefined && { required }), children: label }), _jsx(DatePicker, { id: id, selected: field.state.value, onChange: (date) => field.handleChange(date), onBlur: field.handleBlur, ...(placeholder !== undefined && { placeholderText: placeholder }), ...(disabled !== undefined && { disabled }), ...(showTimeSelect !== undefined && { showTimeSelect }), ...(dateFormat !== undefined && { dateFormat }), className: cn(hasError && 'border-destructive focus:ring-destructive'), ...(hasError
19
+ ? { 'aria-describedby': msgId }
20
+ : description !== undefined
21
+ ? { 'aria-describedby': descId }
22
+ : {}) }), description !== undefined ? (_jsx(FormDescription, { id: descId, children: description })) : null, hasError ? _jsx(FormMessage, { id: msgId, errors: errors }) : null] }));
23
+ } }));
24
+ }
25
+ /** Date range picker integrated with TanStack Form. Field value is `[start, end]`. */
26
+ export function FormDateRangePicker({ form, name, label, description, required, placeholder, disabled, isClearable, align, showTimeSelect, showWeekNumbers, monthsShown, minDate, maxDate, disabledDays, dateFormat, calendarProps, triggerWidth, triggerClassName, closeOnRangeComplete, className, validators, }) {
27
+ const id = useId();
28
+ const descId = `${id}-desc`;
29
+ const msgId = `${id}-msg`;
30
+ return (_jsx(form.Field, { name: name, ...(validators !== undefined && { validators }), children: (field) => {
31
+ const errors = field.state.meta.isTouched ? field.state.meta.errors : [];
32
+ const hasError = errors.length > 0;
33
+ const [startDate, endDate] = field.state.value ?? [null, null];
34
+ return (_jsxs(FormItem, { ...(className !== undefined && { className }), children: [_jsx(FormLabel, { htmlFor: id, ...(required !== undefined && { required }), children: label }), _jsx(DatePicker, { id: id, selectsRange: true, startDate: startDate, endDate: endDate, onChange: (range) => field.handleChange(range), onBlur: field.handleBlur, ...(placeholder !== undefined && { placeholderText: placeholder }), ...(disabled !== undefined && { disabled }), ...(isClearable !== undefined && { isClearable }), ...(align !== undefined && { align }), ...(showTimeSelect !== undefined && { showTimeSelect }), ...(showWeekNumbers !== undefined && { showWeekNumbers }), ...(monthsShown !== undefined && { monthsShown }), ...(minDate !== undefined && { minDate }), ...(maxDate !== undefined && { maxDate }), ...(disabledDays !== undefined && { disabledDays }), ...(dateFormat !== undefined && { dateFormat }), ...(calendarProps !== undefined && { calendarProps }), ...(triggerWidth !== undefined && { triggerWidth }), ...(triggerClassName !== undefined && { triggerClassName }), ...(closeOnRangeComplete !== undefined && { closeOnRangeComplete }), className: cn(hasError && 'border-destructive focus:ring-destructive'), ...(hasError
35
+ ? { 'aria-describedby': msgId }
36
+ : description !== undefined
37
+ ? { 'aria-describedby': descId }
38
+ : {}) }), description !== undefined ? (_jsx(FormDescription, { id: descId, children: description })) : null, hasError ? _jsx(FormMessage, { id: msgId, errors: errors }) : null] }));
39
+ } }));
40
+ }
41
+ //# sourceMappingURL=fields-date.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fields-date.js","sourceRoot":"","sources":["../../src/Form/fields-date.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,47 @@
1
+ import { type SearchFieldProps } from '../SearchField.js';
2
+ import type { AnyFormApi, FormFieldValidators } from './types.js';
3
+ export interface FormInputProps {
4
+ form: AnyFormApi;
5
+ name: string;
6
+ label: string;
7
+ description?: string;
8
+ required?: boolean;
9
+ placeholder?: string;
10
+ type?: string;
11
+ disabled?: boolean;
12
+ className?: string;
13
+ validators?: FormFieldValidators;
14
+ }
15
+ /** Input field integrated with TanStack Form. */
16
+ export declare function FormInput({ form, name, label, description, required, placeholder, type, disabled, className, validators, }: FormInputProps): import("react/jsx-runtime").JSX.Element;
17
+ export interface FormSearchFieldProps {
18
+ form: AnyFormApi;
19
+ name: string;
20
+ label: string;
21
+ description?: string;
22
+ required?: boolean;
23
+ placeholder?: string;
24
+ disabled?: boolean;
25
+ size?: SearchFieldProps['size'];
26
+ noClear?: boolean;
27
+ className?: string;
28
+ inputClassName?: string;
29
+ validators?: FormFieldValidators;
30
+ }
31
+ /** Search field integrated with TanStack Form. */
32
+ export declare function FormSearchField({ form, name, label, description, required, placeholder, disabled, size, noClear, className, inputClassName, validators, }: FormSearchFieldProps): import("react/jsx-runtime").JSX.Element;
33
+ export interface FormTextareaProps {
34
+ form: AnyFormApi;
35
+ name: string;
36
+ label: string;
37
+ description?: string;
38
+ required?: boolean;
39
+ placeholder?: string;
40
+ rows?: number;
41
+ disabled?: boolean;
42
+ className?: string;
43
+ validators?: FormFieldValidators;
44
+ }
45
+ /** Textarea field integrated with TanStack Form. */
46
+ export declare function FormTextarea({ form, name, label, description, required, placeholder, rows, disabled, className, validators, }: FormTextareaProps): import("react/jsx-runtime").JSX.Element;
47
+ //# sourceMappingURL=fields-text.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fields-text.d.ts","sourceRoot":"","sources":["../../src/Form/fields-text.tsx"],"names":[],"mappings":"AASA,OAAO,EAAe,KAAK,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AAQvE,OAAO,KAAK,EAAE,UAAU,EAAoB,mBAAmB,EAAE,MAAM,YAAY,CAAC;AAIpF,MAAM,WAAW,cAAc;IAC7B,IAAI,EAAE,UAAU,CAAC;IACjB,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,UAAU,CAAC,EAAE,mBAAmB,CAAC;CAClC;AAED,iDAAiD;AACjD,wBAAgB,SAAS,CAAC,EACxB,IAAI,EACJ,IAAI,EACJ,KAAK,EACL,WAAW,EACX,QAAQ,EACR,WAAW,EACX,IAAI,EACJ,QAAQ,EACR,SAAS,EACT,UAAU,GACX,EAAE,cAAc,2CAoChB;AAID,MAAM,WAAW,oBAAoB;IACnC,IAAI,EAAE,UAAU,CAAC;IACjB,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,IAAI,CAAC,EAAE,gBAAgB,CAAC,MAAM,CAAC,CAAC;IAChC,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,UAAU,CAAC,EAAE,mBAAmB,CAAC;CAClC;AAED,kDAAkD;AAClD,wBAAgB,eAAe,CAAC,EAC9B,IAAI,EACJ,IAAI,EACJ,KAAK,EACL,WAAW,EACX,QAAQ,EACR,WAAW,EACX,QAAQ,EACR,IAAI,EACJ,OAAO,EACP,SAAS,EACT,cAAc,EACd,UAAU,GACX,EAAE,oBAAoB,2CAqCtB;AAID,MAAM,WAAW,iBAAiB;IAChC,IAAI,EAAE,UAAU,CAAC;IACjB,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,UAAU,CAAC,EAAE,mBAAmB,CAAC;CAClC;AAED,oDAAoD;AACpD,wBAAgB,YAAY,CAAC,EAC3B,IAAI,EACJ,IAAI,EACJ,KAAK,EACL,WAAW,EACX,QAAQ,EACR,WAAW,EACX,IAAI,EACJ,QAAQ,EACR,SAAS,EACT,UAAU,GACX,EAAE,iBAAiB,2CAoCnB"}
@@ -0,0 +1,46 @@
1
+ 'use client';
2
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
+ /**
4
+ * Text-style fields integrated with TanStack Form: FormInput, FormSearchField,
5
+ * FormTextarea. Each wires `form.Field` to the matching UI primitive with
6
+ * label, description, and error display included.
7
+ */
8
+ import { useId } from 'react';
9
+ import { Input } from '../Input.js';
10
+ import { SearchField } from '../SearchField.js';
11
+ import { Textarea } from '../Textarea.js';
12
+ import { FormDescription, FormItem, FormLabel, FormMessage, } from './building-blocks.js';
13
+ /** Input field integrated with TanStack Form. */
14
+ export function FormInput({ form, name, label, description, required, placeholder, type, disabled, className, validators, }) {
15
+ const id = useId();
16
+ const descId = `${id}-desc`;
17
+ const msgId = `${id}-msg`;
18
+ return (_jsx(form.Field, { name: name, ...(validators !== undefined && { validators }), children: (field) => {
19
+ const errors = field.state.meta.isTouched ? field.state.meta.errors : [];
20
+ const hasError = errors.length > 0;
21
+ return (_jsxs(FormItem, { ...(className !== undefined && { className }), children: [_jsx(FormLabel, { htmlFor: id, ...(required !== undefined && { required }), children: label }), _jsx(Input, { id: id, ...(type !== undefined && { type }), ...(placeholder !== undefined && { placeholder }), ...(disabled !== undefined && { disabled }), ...(required !== undefined && { required }), invalid: hasError, value: field.state.value ?? '', onChange: (e) => field.handleChange(e.target.value), onBlur: field.handleBlur, "aria-describedby": hasError ? msgId : description !== undefined ? descId : undefined }), description !== undefined ? (_jsx(FormDescription, { id: descId, children: description })) : null, hasError ? _jsx(FormMessage, { id: msgId, errors: errors }) : null] }));
22
+ } }));
23
+ }
24
+ /** Search field integrated with TanStack Form. */
25
+ export function FormSearchField({ form, name, label, description, required, placeholder, disabled, size, noClear, className, inputClassName, validators, }) {
26
+ const id = useId();
27
+ const descId = `${id}-desc`;
28
+ const msgId = `${id}-msg`;
29
+ return (_jsx(form.Field, { name: name, ...(validators !== undefined && { validators }), children: (field) => {
30
+ const errors = field.state.meta.isTouched ? field.state.meta.errors : [];
31
+ const hasError = errors.length > 0;
32
+ return (_jsxs(FormItem, { ...(className !== undefined && { className }), children: [_jsx(FormLabel, { htmlFor: id, ...(required !== undefined && { required }), children: label }), _jsx(SearchField, { id: id, value: field.state.value ?? '', onValueChange: field.handleChange, onBlur: field.handleBlur, ...(placeholder !== undefined && { placeholder }), ...(disabled !== undefined && { disabled }), ...(size !== undefined && { size }), ...(noClear !== undefined && { noClear }), ...(inputClassName !== undefined && { inputClassName }), "aria-describedby": hasError ? msgId : description !== undefined ? descId : undefined, "aria-invalid": hasError }), description !== undefined ? (_jsx(FormDescription, { id: descId, children: description })) : null, hasError ? _jsx(FormMessage, { id: msgId, errors: errors }) : null] }));
33
+ } }));
34
+ }
35
+ /** Textarea field integrated with TanStack Form. */
36
+ export function FormTextarea({ form, name, label, description, required, placeholder, rows, disabled, className, validators, }) {
37
+ const id = useId();
38
+ const descId = `${id}-desc`;
39
+ const msgId = `${id}-msg`;
40
+ return (_jsx(form.Field, { name: name, ...(validators !== undefined && { validators }), children: (field) => {
41
+ const errors = field.state.meta.isTouched ? field.state.meta.errors : [];
42
+ const hasError = errors.length > 0;
43
+ return (_jsxs(FormItem, { ...(className !== undefined && { className }), children: [_jsx(FormLabel, { htmlFor: id, ...(required !== undefined && { required }), children: label }), _jsx(Textarea, { id: id, ...(placeholder !== undefined && { placeholder }), ...(disabled !== undefined && { disabled }), ...(required !== undefined && { required }), ...(rows !== undefined && { rows }), invalid: hasError, value: field.state.value ?? '', onChange: (e) => field.handleChange(e.target.value), onBlur: field.handleBlur, "aria-describedby": hasError ? msgId : description !== undefined ? descId : undefined }), description !== undefined ? (_jsx(FormDescription, { id: descId, children: description })) : null, hasError ? _jsx(FormMessage, { id: msgId, errors: errors }) : null] }));
44
+ } }));
45
+ }
46
+ //# sourceMappingURL=fields-text.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fields-text.js","sourceRoot":"","sources":["../../src/Form/fields-text.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,24 @@
1
+ import type { AnyFormApi, FormFieldValidators } from './types.js';
2
+ export interface FormCheckboxProps {
3
+ form: AnyFormApi;
4
+ name: string;
5
+ label: string;
6
+ description?: string;
7
+ disabled?: boolean;
8
+ className?: string;
9
+ validators?: FormFieldValidators;
10
+ }
11
+ /** Checkbox field integrated with TanStack Form. */
12
+ export declare function FormCheckbox({ form, name, label, description, disabled, className, validators, }: FormCheckboxProps): import("react/jsx-runtime").JSX.Element;
13
+ export interface FormSwitchProps {
14
+ form: AnyFormApi;
15
+ name: string;
16
+ label: string;
17
+ description?: string;
18
+ disabled?: boolean;
19
+ className?: string;
20
+ validators?: FormFieldValidators;
21
+ }
22
+ /** Switch field integrated with TanStack Form. */
23
+ export declare function FormSwitch({ form, name, label, description, disabled, className, validators, }: FormSwitchProps): import("react/jsx-runtime").JSX.Element;
24
+ //# sourceMappingURL=fields-toggle.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fields-toggle.d.ts","sourceRoot":"","sources":["../../src/Form/fields-toggle.tsx"],"names":[],"mappings":"AAcA,OAAO,KAAK,EAAE,UAAU,EAAoB,mBAAmB,EAAE,MAAM,YAAY,CAAC;AAIpF,MAAM,WAAW,iBAAiB;IAChC,IAAI,EAAE,UAAU,CAAC;IACjB,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,UAAU,CAAC,EAAE,mBAAmB,CAAC;CAClC;AAED,oDAAoD;AACpD,wBAAgB,YAAY,CAAC,EAC3B,IAAI,EACJ,IAAI,EACJ,KAAK,EACL,WAAW,EACX,QAAQ,EACR,SAAS,EACT,UAAU,GACX,EAAE,iBAAiB,2CA+BnB;AAID,MAAM,WAAW,eAAe;IAC9B,IAAI,EAAE,UAAU,CAAC;IACjB,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,UAAU,CAAC,EAAE,mBAAmB,CAAC;CAClC;AAED,kDAAkD;AAClD,wBAAgB,UAAU,CAAC,EACzB,IAAI,EACJ,IAAI,EACJ,KAAK,EACL,WAAW,EACX,QAAQ,EACR,SAAS,EACT,UAAU,GACX,EAAE,eAAe,2CA+BjB"}
@@ -0,0 +1,32 @@
1
+ 'use client';
2
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
+ /**
4
+ * Boolean / toggle fields integrated with TanStack Form: FormCheckbox, FormSwitch.
5
+ */
6
+ import { useId } from 'react';
7
+ import { Checkbox } from '../Checkbox.js';
8
+ import { Switch } from '../Switch.js';
9
+ import { FormDescription, FormItem, FormLabel, FormMessage, } from './building-blocks.js';
10
+ /** Checkbox field integrated with TanStack Form. */
11
+ export function FormCheckbox({ form, name, label, description, disabled, className, validators, }) {
12
+ const id = useId();
13
+ const descId = `${id}-desc`;
14
+ const msgId = `${id}-msg`;
15
+ return (_jsx(form.Field, { name: name, ...(validators !== undefined && { validators }), children: (field) => {
16
+ const errors = field.state.meta.isTouched ? field.state.meta.errors : [];
17
+ const hasError = errors.length > 0;
18
+ return (_jsxs(FormItem, { ...(className !== undefined && { className }), children: [_jsxs("div", { className: "flex items-center gap-2", children: [_jsx(Checkbox, { id: id, checked: !!field.state.value, onCheckedChange: (checked) => field.handleChange(checked === true), ...(disabled !== undefined && { disabled }), "aria-describedby": hasError ? msgId : description !== undefined ? descId : undefined }), _jsx(FormLabel, { htmlFor: id, children: label })] }), description !== undefined ? (_jsx(FormDescription, { id: descId, children: description })) : null, hasError ? _jsx(FormMessage, { id: msgId, errors: errors }) : null] }));
19
+ } }));
20
+ }
21
+ /** Switch field integrated with TanStack Form. */
22
+ export function FormSwitch({ form, name, label, description, disabled, className, validators, }) {
23
+ const id = useId();
24
+ const descId = `${id}-desc`;
25
+ const msgId = `${id}-msg`;
26
+ return (_jsx(form.Field, { name: name, ...(validators !== undefined && { validators }), children: (field) => {
27
+ const errors = field.state.meta.isTouched ? field.state.meta.errors : [];
28
+ const hasError = errors.length > 0;
29
+ return (_jsxs(FormItem, { ...(className !== undefined && { className }), children: [_jsxs("div", { className: "flex items-center gap-3", children: [_jsx(Switch, { id: id, checked: !!field.state.value, onCheckedChange: (checked) => field.handleChange(checked), ...(disabled !== undefined && { disabled }), "aria-describedby": hasError ? msgId : description !== undefined ? descId : undefined }), _jsx(FormLabel, { htmlFor: id, children: label })] }), description !== undefined ? (_jsx(FormDescription, { id: descId, children: description })) : null, hasError ? _jsx(FormMessage, { id: msgId, errors: errors }) : null] }));
30
+ } }));
31
+ }
32
+ //# sourceMappingURL=fields-toggle.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fields-toggle.js","sourceRoot":"","sources":["../../src/Form/fields-toggle.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,66 @@
1
+ /**
2
+ * Form composition helpers: FormFieldArray, FormSubscribe, FormListenEffect,
3
+ * FormActions. These wire common TanStack Form patterns to MiHCM primitives.
4
+ */
5
+ import { type ReactNode } from 'react';
6
+ import type { AnyFormApi, FormFieldValidators } from './types.js';
7
+ /** Render props supplied to each array item's `renderField` callback. */
8
+ export interface FieldArrayItemApi {
9
+ /** Index of this item within the array. */
10
+ index: number;
11
+ /** Total number of items currently in the array. */
12
+ total: number;
13
+ /** Remove this item from the array. */
14
+ remove: () => void;
15
+ }
16
+ export interface FormFieldArrayProps {
17
+ form: AnyFormApi;
18
+ name: string;
19
+ label: string;
20
+ description?: string;
21
+ /** Render function called for each array item. */
22
+ renderField: (item: FieldArrayItemApi) => ReactNode;
23
+ /** Label text for the add button. Default: "Add item". */
24
+ addLabel?: string;
25
+ className?: string;
26
+ validators?: FormFieldValidators;
27
+ }
28
+ /** Field array integrated with TanStack Form. Provides add/remove buttons. */
29
+ export declare function FormFieldArray({ form, name, label, description, renderField, addLabel, className, validators, }: FormFieldArrayProps): import("react/jsx-runtime").JSX.Element;
30
+ export interface FormSubscribeProps<TSelected> {
31
+ form: AnyFormApi;
32
+ /** Selector function that picks values from form state. */
33
+ selector: (state: any) => TSelected;
34
+ /** Render function receiving the selected state. */
35
+ children: (selected: TSelected) => ReactNode;
36
+ }
37
+ /** Convenience wrapper around `form.Subscribe` for reactive state display. */
38
+ export declare function FormSubscribe<TSelected>({ form, selector, children, }: FormSubscribeProps<TSelected>): import("react/jsx-runtime").JSX.Element;
39
+ export interface FormListenEffectProps {
40
+ form: AnyFormApi;
41
+ /** Field name to listen to. */
42
+ name: string;
43
+ /** Listener callbacks (onChange, onBlur, etc.) for side effects. */
44
+ listeners: Record<string, any>;
45
+ }
46
+ /**
47
+ * Invisible field that fires side effects when another field changes.
48
+ * Useful for dependent field updates (e.g. country changes → reset city).
49
+ * Renders nothing visually.
50
+ */
51
+ export declare function FormListenEffect({ form, name, listeners }: FormListenEffectProps): import("react/jsx-runtime").JSX.Element;
52
+ export interface FormActionsProps {
53
+ form: AnyFormApi;
54
+ /** Label for the submit button. Default: "Submit". */
55
+ submitLabel?: string;
56
+ /** Label for the reset button. Default: "Reset". */
57
+ resetLabel?: string;
58
+ /** Whether to show the reset button. Default: true. */
59
+ showReset?: boolean;
60
+ /** Disable both buttons externally. */
61
+ disabled?: boolean;
62
+ className?: string;
63
+ }
64
+ /** Footer with submit and reset buttons. Reacts to form submitting state. */
65
+ export declare function FormActions({ form, submitLabel, resetLabel, showReset, disabled, className, }: FormActionsProps): import("react/jsx-runtime").JSX.Element;
66
+ //# sourceMappingURL=helpers.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"helpers.d.ts","sourceRoot":"","sources":["../../src/Form/helpers.tsx"],"names":[],"mappings":"AAEA;;;GAGG;AACH,OAAO,EAAS,KAAK,SAAS,EAAE,MAAM,OAAO,CAAC;AAQ9C,OAAO,KAAK,EAAE,UAAU,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAC;AAIlE,yEAAyE;AACzE,MAAM,WAAW,iBAAiB;IAChC,2CAA2C;IAC3C,KAAK,EAAE,MAAM,CAAC;IACd,oDAAoD;IACpD,KAAK,EAAE,MAAM,CAAC;IACd,uCAAuC;IACvC,MAAM,EAAE,MAAM,IAAI,CAAC;CACpB;AAED,MAAM,WAAW,mBAAmB;IAClC,IAAI,EAAE,UAAU,CAAC;IACjB,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,kDAAkD;IAClD,WAAW,EAAE,CAAC,IAAI,EAAE,iBAAiB,KAAK,SAAS,CAAC;IACpD,0DAA0D;IAC1D,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,UAAU,CAAC,EAAE,mBAAmB,CAAC;CAClC;AAED,8EAA8E;AAC9E,wBAAgB,cAAc,CAAC,EAC7B,IAAI,EACJ,IAAI,EACJ,KAAK,EACL,WAAW,EACX,WAAW,EACX,QAAqB,EACrB,SAAS,EACT,UAAU,GACX,EAAE,mBAAmB,2CAwCrB;AAID,MAAM,WAAW,kBAAkB,CAAC,SAAS;IAC3C,IAAI,EAAE,UAAU,CAAC;IACjB,2DAA2D;IAE3D,QAAQ,EAAE,CAAC,KAAK,EAAE,GAAG,KAAK,SAAS,CAAC;IACpC,oDAAoD;IACpD,QAAQ,EAAE,CAAC,QAAQ,EAAE,SAAS,KAAK,SAAS,CAAC;CAC9C;AAED,8EAA8E;AAC9E,wBAAgB,aAAa,CAAC,SAAS,EAAE,EACvC,IAAI,EACJ,QAAQ,EACR,QAAQ,GACT,EAAE,kBAAkB,CAAC,SAAS,CAAC,2CAE/B;AAID,MAAM,WAAW,qBAAqB;IACpC,IAAI,EAAE,UAAU,CAAC;IACjB,+BAA+B;IAC/B,IAAI,EAAE,MAAM,CAAC;IACb,oEAAoE;IAEpE,SAAS,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;CAChC;AAED;;;;GAIG;AACH,wBAAgB,gBAAgB,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,SAAS,EAAE,EAAE,qBAAqB,2CAMhF;AAID,MAAM,WAAW,gBAAgB;IAC/B,IAAI,EAAE,UAAU,CAAC;IACjB,sDAAsD;IACtD,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,oDAAoD;IACpD,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,uDAAuD;IACvD,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,uCAAuC;IACvC,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,6EAA6E;AAC7E,wBAAgB,WAAW,CAAC,EAC1B,IAAI,EACJ,WAAsB,EACtB,UAAoB,EACpB,SAAgB,EAChB,QAAQ,EACR,SAAS,GACV,EAAE,gBAAgB,2CA4BlB"}
@@ -0,0 +1,44 @@
1
+ 'use client';
2
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
+ /**
4
+ * Form composition helpers: FormFieldArray, FormSubscribe, FormListenEffect,
5
+ * FormActions. These wire common TanStack Form patterns to MiHCM primitives.
6
+ */
7
+ import { useId } from 'react';
8
+ import { cn } from '../internal/cn.js';
9
+ import { Button } from '../Button.js';
10
+ import { FormDescription, FormItem, FormLabel, } from './building-blocks.js';
11
+ /** Field array integrated with TanStack Form. Provides add/remove buttons. */
12
+ export function FormFieldArray({ form, name, label, description, renderField, addLabel = 'Add item', className, validators, }) {
13
+ const id = useId();
14
+ const descId = `${id}-desc`;
15
+ return (_jsx(form.Field, { name: name, mode: "array", ...(validators !== undefined && { validators }), children: (field) => {
16
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
17
+ const items = (field.state.value ?? []);
18
+ return (_jsxs(FormItem, { ...(className !== undefined && { className }), children: [_jsxs("div", { className: "flex items-center justify-between", children: [_jsx(FormLabel, { children: label }), _jsxs(Button, { type: "button", variant: "outline", size: "sm", onClick: () => field.pushValue({}), children: ["+ ", addLabel] })] }), description !== undefined ? (_jsx(FormDescription, { id: descId, children: description })) : null, _jsx("div", { className: "space-y-3", children: items.map((_, i) => (_jsx("div", { className: "rounded-lg border border-border p-3 transition-all duration-150", children: renderField({
19
+ index: i,
20
+ total: items.length,
21
+ remove: () => field.removeValue(i),
22
+ }) }, i))) })] }));
23
+ } }));
24
+ }
25
+ /** Convenience wrapper around `form.Subscribe` for reactive state display. */
26
+ export function FormSubscribe({ form, selector, children, }) {
27
+ return _jsx(form.Subscribe, { selector: selector, children: children });
28
+ }
29
+ /**
30
+ * Invisible field that fires side effects when another field changes.
31
+ * Useful for dependent field updates (e.g. country changes → reset city).
32
+ * Renders nothing visually.
33
+ */
34
+ export function FormListenEffect({ form, name, listeners }) {
35
+ return (_jsx(form.Field, { name: name, listeners: listeners, children: () => null }));
36
+ }
37
+ /** Footer with submit and reset buttons. Reacts to form submitting state. */
38
+ export function FormActions({ form, submitLabel = 'Submit', resetLabel = 'Reset', showReset = true, disabled, className, }) {
39
+ return (_jsx(form.Subscribe, { selector: (s) => ({
40
+ canSubmit: s.canSubmit,
41
+ isSubmitting: s.isSubmitting,
42
+ }), children: (state) => (_jsxs("div", { className: cn('flex items-center gap-3 pt-2', className), children: [_jsx(Button, { type: "submit", disabled: disabled || !state.canSubmit, children: state.isSubmitting ? 'Submitting...' : submitLabel }), showReset ? (_jsx(Button, { type: "button", variant: "outline", disabled: disabled || state.isSubmitting, onClick: () => form.reset(), children: resetLabel })) : null] })) }));
43
+ }
44
+ //# sourceMappingURL=helpers.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"helpers.js","sourceRoot":"","sources":["../../src/Form/helpers.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,25 @@
1
+ /**
2
+ * Shared Form types.
3
+ *
4
+ * Wraps TanStack React Form's internals at the boundary so the rest of the
5
+ * field components can stay strongly typed without leaking 12-param generics.
6
+ */
7
+ /** Validator config passed through to TanStack Form's `form.Field`. */
8
+ export type FormFieldValidators = Record<string, any>;
9
+ export type AnyFormApi = any;
10
+ /**
11
+ * Field render-prop shape — kept minimal to avoid coupling to TanStack
12
+ * internals that change across minor versions.
13
+ */
14
+ export interface FieldRenderProps<T> {
15
+ state: {
16
+ value: T;
17
+ meta: {
18
+ errors: string[];
19
+ isTouched: boolean;
20
+ };
21
+ };
22
+ handleChange: (v: T) => void;
23
+ handleBlur: () => void;
24
+ }
25
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/Form/types.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,uEAAuE;AAEvE,MAAM,MAAM,mBAAmB,GAAG,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;AAGtD,MAAM,MAAM,UAAU,GAAG,GAAG,CAAC;AAE7B;;;GAGG;AACH,MAAM,WAAW,gBAAgB,CAAC,CAAC;IACjC,KAAK,EAAE;QACL,KAAK,EAAE,CAAC,CAAC;QACT,IAAI,EAAE;YAAE,MAAM,EAAE,MAAM,EAAE,CAAC;YAAC,SAAS,EAAE,OAAO,CAAA;SAAE,CAAC;KAChD,CAAC;IACF,YAAY,EAAE,CAAC,CAAC,EAAE,CAAC,KAAK,IAAI,CAAC;IAC7B,UAAU,EAAE,MAAM,IAAI,CAAC;CACxB"}
@@ -0,0 +1,8 @@
1
+ /**
2
+ * Shared Form types.
3
+ *
4
+ * Wraps TanStack React Form's internals at the boundary so the rest of the
5
+ * field components can stay strongly typed without leaking 12-param generics.
6
+ */
7
+ export {};
8
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/Form/types.ts"],"names":[],"mappings":"AAAA;;;;;GAKG"}