@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.
- package/dist/CheckboxGrid.native.d.ts.map +1 -1
- package/dist/CheckboxGrid.native.js +2 -1
- package/dist/CheckboxGrid.native.js.map +1 -1
- package/dist/Combobox.native.d.ts.map +1 -1
- package/dist/Combobox.native.js +2 -1
- package/dist/Combobox.native.js.map +1 -1
- package/dist/DataTable/column-filter.d.ts +8 -0
- package/dist/DataTable/column-filter.d.ts.map +1 -0
- package/dist/DataTable/column-filter.js +67 -0
- package/dist/DataTable/column-filter.js.map +1 -0
- package/dist/DataTable/column-header.d.ts +16 -0
- package/dist/DataTable/column-header.d.ts.map +1 -0
- package/dist/DataTable/column-header.js +11 -0
- package/dist/DataTable/column-header.js.map +1 -0
- package/dist/DataTable/column-visibility.d.ts +7 -0
- package/dist/DataTable/column-visibility.d.ts.map +1 -0
- package/dist/DataTable/column-visibility.js +35 -0
- package/dist/DataTable/column-visibility.js.map +1 -0
- package/dist/DataTable/index.d.ts +5 -0
- package/dist/DataTable/index.d.ts.map +1 -0
- package/dist/DataTable/index.js +5 -0
- package/dist/DataTable/index.js.map +1 -0
- package/dist/DataTable/pinning.d.ts +13 -0
- package/dist/DataTable/pinning.d.ts.map +1 -0
- package/dist/DataTable/pinning.js +29 -0
- package/dist/DataTable/pinning.js.map +1 -0
- package/dist/DataTable.d.ts +3 -7
- package/dist/DataTable.d.ts.map +1 -1
- package/dist/DataTable.js +7 -126
- package/dist/DataTable.js.map +1 -1
- package/dist/Dialog.native.d.ts +3 -1
- package/dist/Dialog.native.d.ts.map +1 -1
- package/dist/Dialog.native.js +2 -2
- package/dist/Dialog.native.js.map +1 -1
- package/dist/Form/building-blocks.d.ts +26 -0
- package/dist/Form/building-blocks.d.ts.map +1 -0
- package/dist/Form/building-blocks.js +29 -0
- package/dist/Form/building-blocks.js.map +1 -0
- package/dist/Form/fields-choice.d.ts +72 -0
- package/dist/Form/fields-choice.d.ts.map +1 -0
- package/dist/Form/fields-choice.js +69 -0
- package/dist/Form/fields-choice.js.map +1 -0
- package/dist/Form/fields-complex.d.ts +28 -0
- package/dist/Form/fields-complex.d.ts.map +1 -0
- package/dist/Form/fields-complex.js +38 -0
- package/dist/Form/fields-complex.js.map +1 -0
- package/dist/Form/fields-date.d.ts +46 -0
- package/dist/Form/fields-date.d.ts.map +1 -0
- package/dist/Form/fields-date.js +41 -0
- package/dist/Form/fields-date.js.map +1 -0
- package/dist/Form/fields-text.d.ts +47 -0
- package/dist/Form/fields-text.d.ts.map +1 -0
- package/dist/Form/fields-text.js +46 -0
- package/dist/Form/fields-text.js.map +1 -0
- package/dist/Form/fields-toggle.d.ts +24 -0
- package/dist/Form/fields-toggle.d.ts.map +1 -0
- package/dist/Form/fields-toggle.js +32 -0
- package/dist/Form/fields-toggle.js.map +1 -0
- package/dist/Form/helpers.d.ts +66 -0
- package/dist/Form/helpers.d.ts.map +1 -0
- package/dist/Form/helpers.js +44 -0
- package/dist/Form/helpers.js.map +1 -0
- package/dist/Form/types.d.ts +25 -0
- package/dist/Form/types.d.ts.map +1 -0
- package/dist/Form/types.js +8 -0
- package/dist/Form/types.js.map +1 -0
- package/dist/Form.d.ts +24 -298
- package/dist/Form.d.ts.map +1 -1
- package/dist/Form.js +30 -246
- package/dist/Form.js.map +1 -1
- package/dist/IconSidebar.d.ts +6 -46
- package/dist/IconSidebar.d.ts.map +1 -1
- package/dist/IconSidebar.js +6 -116
- package/dist/IconSidebar.js.map +1 -1
- package/dist/MainSidebar/back-button.d.ts +14 -0
- package/dist/MainSidebar/back-button.d.ts.map +1 -0
- package/dist/MainSidebar/back-button.js +14 -0
- package/dist/MainSidebar/back-button.js.map +1 -0
- package/dist/MainSidebar/breadcrumb.d.ts +10 -0
- package/dist/MainSidebar/breadcrumb.d.ts.map +1 -0
- package/dist/MainSidebar/breadcrumb.js +24 -0
- package/dist/MainSidebar/breadcrumb.js.map +1 -0
- package/dist/MainSidebar/columns.d.ts +3 -0
- package/dist/MainSidebar/columns.d.ts.map +1 -0
- package/dist/MainSidebar/columns.js +198 -0
- package/dist/MainSidebar/columns.js.map +1 -0
- package/dist/MainSidebar/command.d.ts +3 -0
- package/dist/MainSidebar/command.d.ts.map +1 -0
- package/dist/MainSidebar/command.js +193 -0
- package/dist/MainSidebar/command.js.map +1 -0
- package/dist/MainSidebar/drilldown.d.ts +3 -0
- package/dist/MainSidebar/drilldown.d.ts.map +1 -0
- package/dist/MainSidebar/drilldown.js +154 -0
- package/dist/MainSidebar/drilldown.js.map +1 -0
- package/dist/MainSidebar/expanded.d.ts +7 -0
- package/dist/MainSidebar/expanded.d.ts.map +1 -0
- package/dist/MainSidebar/expanded.js +102 -0
- package/dist/MainSidebar/expanded.js.map +1 -0
- package/dist/MainSidebar/floating.d.ts +3 -0
- package/dist/MainSidebar/floating.d.ts.map +1 -0
- package/dist/MainSidebar/floating.js +116 -0
- package/dist/MainSidebar/floating.js.map +1 -0
- package/dist/MainSidebar/helpers.d.ts +50 -0
- package/dist/MainSidebar/helpers.d.ts.map +1 -0
- package/dist/MainSidebar/helpers.js +150 -0
- package/dist/MainSidebar/helpers.js.map +1 -0
- package/dist/MainSidebar/hover.d.ts +3 -0
- package/dist/MainSidebar/hover.d.ts.map +1 -0
- package/dist/MainSidebar/hover.js +177 -0
- package/dist/MainSidebar/hover.js.map +1 -0
- package/dist/MainSidebar/index.d.ts +6 -0
- package/dist/MainSidebar/index.d.ts.map +1 -0
- package/dist/MainSidebar/index.js +108 -0
- package/dist/MainSidebar/index.js.map +1 -0
- package/dist/MainSidebar/mobile.d.ts +29 -0
- package/dist/MainSidebar/mobile.d.ts.map +1 -0
- package/dist/MainSidebar/mobile.js +38 -0
- package/dist/MainSidebar/mobile.js.map +1 -0
- package/dist/MainSidebar/motion.d.ts +23 -0
- package/dist/MainSidebar/motion.d.ts.map +1 -0
- package/dist/MainSidebar/motion.js +40 -0
- package/dist/MainSidebar/motion.js.map +1 -0
- package/dist/MainSidebar/rail.d.ts +24 -0
- package/dist/MainSidebar/rail.d.ts.map +1 -0
- package/dist/MainSidebar/rail.js +29 -0
- package/dist/MainSidebar/rail.js.map +1 -0
- package/dist/MainSidebar/search.d.ts +19 -0
- package/dist/MainSidebar/search.d.ts.map +1 -0
- package/dist/MainSidebar/search.js +33 -0
- package/dist/MainSidebar/search.js.map +1 -0
- package/dist/MainSidebar/types.d.ts +161 -0
- package/dist/MainSidebar/types.d.ts.map +1 -0
- package/dist/MainSidebar/types.js +2 -0
- package/dist/MainSidebar/types.js.map +1 -0
- package/dist/MainSidebar.d.ts +6 -1
- package/dist/MainSidebar.d.ts.map +1 -1
- package/dist/MainSidebar.js +6 -1
- package/dist/MainSidebar.js.map +1 -1
- package/dist/NavigationMenu.js +1 -1
- package/dist/NavigationMenu.js.map +1 -1
- package/dist/RichTextEditor/theme.d.ts +44 -0
- package/dist/RichTextEditor/theme.d.ts.map +1 -0
- package/dist/RichTextEditor/theme.js +41 -0
- package/dist/RichTextEditor/theme.js.map +1 -0
- package/dist/RichTextEditor/toolbar-icons.d.ts +21 -0
- package/dist/RichTextEditor/toolbar-icons.d.ts.map +1 -0
- package/dist/RichTextEditor/toolbar-icons.js +21 -0
- package/dist/RichTextEditor/toolbar-icons.js.map +1 -0
- package/dist/RichTextEditor/toolbar.d.ts +5 -0
- package/dist/RichTextEditor/toolbar.d.ts.map +1 -0
- package/dist/RichTextEditor/toolbar.js +116 -0
- package/dist/RichTextEditor/toolbar.js.map +1 -0
- package/dist/RichTextEditor.d.ts +16 -9
- package/dist/RichTextEditor.d.ts.map +1 -1
- package/dist/RichTextEditor.js +18 -164
- package/dist/RichTextEditor.js.map +1 -1
- package/dist/Select/content.d.ts +9 -0
- package/dist/Select/content.d.ts.map +1 -0
- package/dist/Select/content.js +80 -0
- package/dist/Select/content.js.map +1 -0
- package/dist/Select/context.d.ts +27 -0
- package/dist/Select/context.d.ts.map +1 -0
- package/dist/Select/context.js +35 -0
- package/dist/Select/context.js.map +1 -0
- package/dist/Select/item.d.ts +13 -0
- package/dist/Select/item.d.ts.map +1 -0
- package/dist/Select/item.js +39 -0
- package/dist/Select/item.js.map +1 -0
- package/dist/Select/parts.d.ts +14 -0
- package/dist/Select/parts.d.ts.map +1 -0
- package/dist/Select/parts.js +17 -0
- package/dist/Select/parts.js.map +1 -0
- package/dist/Select/react-select.d.ts +25 -0
- package/dist/Select/react-select.d.ts.map +1 -0
- package/dist/Select/react-select.js +66 -0
- package/dist/Select/react-select.js.map +1 -0
- package/dist/Select/root.d.ts +15 -0
- package/dist/Select/root.d.ts.map +1 -0
- package/dist/Select/root.js +41 -0
- package/dist/Select/root.js.map +1 -0
- package/dist/Select/trigger.d.ts +15 -0
- package/dist/Select/trigger.d.ts.map +1 -0
- package/dist/Select/trigger.js +61 -0
- package/dist/Select/trigger.js.map +1 -0
- package/dist/Select.d.ts +14 -62
- package/dist/Select.d.ts.map +1 -1
- package/dist/Select.js +14 -293
- package/dist/Select.js.map +1 -1
- package/dist/Sidebar/context.d.ts +28 -0
- package/dist/Sidebar/context.d.ts.map +1 -0
- package/dist/Sidebar/context.js +37 -0
- package/dist/Sidebar/context.js.map +1 -0
- package/dist/Sidebar/group.d.ts +13 -0
- package/dist/Sidebar/group.d.ts.map +1 -0
- package/dist/Sidebar/group.js +20 -0
- package/dist/Sidebar/group.js.map +1 -0
- package/dist/Sidebar/icons.d.ts +7 -0
- package/dist/Sidebar/icons.d.ts.map +1 -0
- package/dist/Sidebar/icons.js +12 -0
- package/dist/Sidebar/icons.js.map +1 -0
- package/dist/Sidebar/layout.d.ts +9 -0
- package/dist/Sidebar/layout.d.ts.map +1 -0
- package/dist/Sidebar/layout.js +21 -0
- package/dist/Sidebar/layout.js.map +1 -0
- package/dist/Sidebar/menu.d.ts +29 -0
- package/dist/Sidebar/menu.d.ts.map +1 -0
- package/dist/Sidebar/menu.js +55 -0
- package/dist/Sidebar/menu.js.map +1 -0
- package/dist/Sidebar/provider.d.ts +33 -0
- package/dist/Sidebar/provider.d.ts.map +1 -0
- package/dist/Sidebar/provider.js +110 -0
- package/dist/Sidebar/provider.js.map +1 -0
- package/dist/Sidebar/sidebar.d.ts +17 -0
- package/dist/Sidebar/sidebar.d.ts.map +1 -0
- package/dist/Sidebar/sidebar.js +51 -0
- package/dist/Sidebar/sidebar.js.map +1 -0
- package/dist/Sidebar/submenu.d.ts +13 -0
- package/dist/Sidebar/submenu.d.ts.map +1 -0
- package/dist/Sidebar/submenu.js +17 -0
- package/dist/Sidebar/submenu.js.map +1 -0
- package/dist/Sidebar/trigger.d.ts +9 -0
- package/dist/Sidebar/trigger.d.ts.map +1 -0
- package/dist/Sidebar/trigger.js +33 -0
- package/dist/Sidebar/trigger.js.map +1 -0
- package/dist/Sidebar.d.ts +14 -104
- package/dist/Sidebar.d.ts.map +1 -1
- package/dist/Sidebar.js +14 -300
- package/dist/Sidebar.js.map +1 -1
- package/dist/StatCard.d.ts +67 -9
- package/dist/StatCard.d.ts.map +1 -1
- package/dist/StatCard.js +111 -9
- package/dist/StatCard.js.map +1 -1
- package/dist/TransferList.native.d.ts.map +1 -1
- package/dist/TransferList.native.js +2 -1
- package/dist/TransferList.native.js.map +1 -1
- package/package.json +2 -2
- package/src/CheckboxGrid.native.tsx +2 -1
- package/src/Combobox.native.tsx +2 -1
- package/src/DataTable/column-filter.tsx +134 -0
- package/src/DataTable/column-header.tsx +67 -0
- package/src/DataTable/column-visibility.tsx +87 -0
- package/src/DataTable/index.ts +4 -0
- package/src/DataTable/pinning.ts +40 -0
- package/src/DataTable.tsx +14 -297
- package/src/Dialog.native.tsx +4 -2
- package/src/Form/building-blocks.tsx +97 -0
- package/src/Form/fields-choice.tsx +312 -0
- package/src/Form/fields-complex.tsx +195 -0
- package/src/Form/fields-date.tsx +195 -0
- package/src/Form/fields-text.tsx +218 -0
- package/src/Form/fields-toggle.tsx +123 -0
- package/src/Form/helpers.tsx +189 -0
- package/src/Form/types.ts +26 -0
- package/src/Form.tsx +91 -1308
- package/src/IconSidebar.tsx +20 -442
- package/src/MainSidebar/back-button.tsx +58 -0
- package/src/MainSidebar/breadcrumb.tsx +53 -0
- package/src/MainSidebar/columns.tsx +350 -0
- package/src/MainSidebar/command.tsx +404 -0
- package/src/MainSidebar/drilldown.tsx +373 -0
- package/src/MainSidebar/expanded.tsx +414 -0
- package/src/MainSidebar/floating.tsx +268 -0
- package/src/MainSidebar/helpers.ts +166 -0
- package/src/MainSidebar/hover.tsx +334 -0
- package/src/MainSidebar/index.tsx +191 -0
- package/src/MainSidebar/mobile.tsx +117 -0
- package/src/MainSidebar/motion.ts +64 -0
- package/src/MainSidebar/rail.tsx +137 -0
- package/src/MainSidebar/search.tsx +99 -0
- package/src/MainSidebar/types.ts +208 -0
- package/src/MainSidebar.tsx +15 -4
- package/src/NavigationMenu.tsx +1 -1
- package/src/RichTextEditor/theme.ts +43 -0
- package/src/RichTextEditor/toolbar-icons.tsx +40 -0
- package/src/RichTextEditor/toolbar.tsx +271 -0
- package/src/RichTextEditor.tsx +23 -371
- package/src/Select/content.tsx +111 -0
- package/src/Select/context.tsx +66 -0
- package/src/Select/item.tsx +97 -0
- package/src/Select/parts.tsx +43 -0
- package/src/Select/react-select.tsx +216 -0
- package/src/Select/root.tsx +75 -0
- package/src/Select/trigger.tsx +122 -0
- package/src/Select.tsx +34 -692
- package/src/Sidebar/context.tsx +72 -0
- package/src/Sidebar/group.tsx +69 -0
- package/src/Sidebar/icons.tsx +42 -0
- package/src/Sidebar/layout.tsx +64 -0
- package/src/Sidebar/menu.tsx +171 -0
- package/src/Sidebar/provider.tsx +224 -0
- package/src/Sidebar/sidebar.tsx +178 -0
- package/src/Sidebar/submenu.tsx +58 -0
- package/src/Sidebar/trigger.tsx +104 -0
- package/src/Sidebar.tsx +44 -927
- package/src/StatCard.tsx +365 -20
- package/src/TransferList.native.tsx +2 -1
- package/dist/TiptapEditor.d.ts +0 -24
- package/dist/TiptapEditor.d.ts.map +0 -1
- package/dist/TiptapEditor.js +0 -84
- 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 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/Form/types.ts"],"names":[],"mappings":"AAAA;;;;;GAKG"}
|