@a-type/ui 3.0.24 → 3.0.25
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/cjs/components/forms/CheckboxField.js +4 -5
- package/dist/cjs/components/forms/CheckboxField.js.map +1 -1
- package/dist/cjs/components/forms/FieldLabel.d.ts +1 -0
- package/dist/cjs/components/forms/FieldLabel.js +3 -2
- package/dist/cjs/components/forms/FieldLabel.js.map +1 -1
- package/dist/cjs/components/forms/FormikForm.d.ts +5 -0
- package/dist/cjs/components/forms/FormikForm.js +5 -1
- package/dist/cjs/components/forms/FormikForm.js.map +1 -1
- package/dist/cjs/components/forms/FormikForm.stories.d.ts +5 -0
- package/dist/cjs/components/forms/FormikForm.stories.js +10 -1
- package/dist/cjs/components/forms/FormikForm.stories.js.map +1 -1
- package/dist/cjs/components/forms/SubmitButton.js +1 -1
- package/dist/cjs/components/forms/SubmitButton.js.map +1 -1
- package/dist/cjs/components/forms/SwitchField.d.ts +8 -0
- package/dist/cjs/components/forms/SwitchField.js +30 -0
- package/dist/cjs/components/forms/SwitchField.js.map +1 -0
- package/dist/cjs/components/forms/ToggleGroupField.d.ts +13 -0
- package/dist/cjs/components/forms/ToggleGroupField.js +29 -0
- package/dist/cjs/components/forms/ToggleGroupField.js.map +1 -0
- package/dist/cjs/components/toggleGroup/toggleGroup.d.ts +1 -0
- package/dist/cjs/components/toggleGroup/toggleGroup.js.map +1 -1
- package/dist/css/main.css +3 -3
- package/dist/esm/components/forms/CheckboxField.js +4 -5
- package/dist/esm/components/forms/CheckboxField.js.map +1 -1
- package/dist/esm/components/forms/FieldLabel.d.ts +1 -0
- package/dist/esm/components/forms/FieldLabel.js +2 -1
- package/dist/esm/components/forms/FieldLabel.js.map +1 -1
- package/dist/esm/components/forms/FormikForm.d.ts +5 -0
- package/dist/esm/components/forms/FormikForm.js +5 -1
- package/dist/esm/components/forms/FormikForm.js.map +1 -1
- package/dist/esm/components/forms/FormikForm.stories.d.ts +5 -0
- package/dist/esm/components/forms/FormikForm.stories.js +10 -1
- package/dist/esm/components/forms/FormikForm.stories.js.map +1 -1
- package/dist/esm/components/forms/SubmitButton.js +1 -1
- package/dist/esm/components/forms/SubmitButton.js.map +1 -1
- package/dist/esm/components/forms/SwitchField.d.ts +8 -0
- package/dist/esm/components/forms/SwitchField.js +27 -0
- package/dist/esm/components/forms/SwitchField.js.map +1 -0
- package/dist/esm/components/forms/ToggleGroupField.d.ts +13 -0
- package/dist/esm/components/forms/ToggleGroupField.js +26 -0
- package/dist/esm/components/forms/ToggleGroupField.js.map +1 -0
- package/dist/esm/components/toggleGroup/toggleGroup.d.ts +1 -0
- package/dist/esm/components/toggleGroup/toggleGroup.js.map +1 -1
- package/package.json +1 -1
- package/src/components/forms/CheckboxField.tsx +8 -14
- package/src/components/forms/FieldLabel.tsx +6 -1
- package/src/components/forms/FormikForm.stories.tsx +22 -0
- package/src/components/forms/FormikForm.tsx +5 -1
- package/src/components/forms/SubmitButton.tsx +1 -0
- package/src/components/forms/SwitchField.tsx +41 -0
- package/src/components/forms/ToggleGroupField.tsx +40 -0
- package/src/components/toggleGroup/toggleGroup.tsx +3 -0
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
// @unocss-include
|
|
2
2
|
import { withClassName } from '../../hooks.js';
|
|
3
|
-
export const FieldLabel = withClassName('label', 'inline-flex flex-col gap-
|
|
3
|
+
export const FieldLabel = withClassName('label', 'inline-flex flex-col gap-xs text-sm font-bold color-gray-ink ml-md');
|
|
4
|
+
export const HorizontalFieldLabel = withClassName('label', 'inline-flex flex-row items-center gap-sm text-sm color-gray-ink');
|
|
4
5
|
//# sourceMappingURL=FieldLabel.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"FieldLabel.js","sourceRoot":"","sources":["../../../../src/components/forms/FieldLabel.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAC;AAE/C,MAAM,CAAC,MAAM,UAAU,GAAG,aAAa,CACtC,OAAO,EACP,
|
|
1
|
+
{"version":3,"file":"FieldLabel.js","sourceRoot":"","sources":["../../../../src/components/forms/FieldLabel.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAC;AAE/C,MAAM,CAAC,MAAM,UAAU,GAAG,aAAa,CACtC,OAAO,EACP,oEAAoE,CACpE,CAAC;AAEF,MAAM,CAAC,MAAM,oBAAoB,GAAG,aAAa,CAChD,OAAO,EACP,iEAAiE,CACjE,CAAC"}
|
|
@@ -2,6 +2,7 @@ import { FormikConfig, FormikValues } from 'formik';
|
|
|
2
2
|
import { CheckboxField } from './CheckboxField.js';
|
|
3
3
|
import { NumberStepperField } from './NumberStepperField.js';
|
|
4
4
|
import { SubmitButton } from './SubmitButton.js';
|
|
5
|
+
import { SwitchField } from './SwitchField.js';
|
|
5
6
|
import { TextAreaField } from './TextField.js';
|
|
6
7
|
export interface FormikFormProps<T extends FormikValues = FormikValues> extends FormikConfig<T> {
|
|
7
8
|
className?: string;
|
|
@@ -16,4 +17,8 @@ export declare const FormikForm: typeof FormikFormRoot & {
|
|
|
16
17
|
NumberStepperField: typeof NumberStepperField;
|
|
17
18
|
SubmitButton: typeof SubmitButton;
|
|
18
19
|
CheckboxField: typeof CheckboxField;
|
|
20
|
+
SwitchField: typeof SwitchField;
|
|
21
|
+
ToggleGroupField: (({ name, label, required, className, id, ...props }: import("./ToggleGroupField.js").ToggleGroupFieldProps) => import("react/jsx-runtime").JSX.Element) & {
|
|
22
|
+
Item: import("react").FunctionComponent<import("@radix-ui/react-toggle-group").ToggleGroupItemProps & import("react").RefAttributes<HTMLButtonElement>>;
|
|
23
|
+
};
|
|
19
24
|
};
|
|
@@ -17,14 +17,16 @@ import { CheckboxField } from './CheckboxField.js';
|
|
|
17
17
|
import { Form } from './Form.js';
|
|
18
18
|
import { NumberStepperField } from './NumberStepperField.js';
|
|
19
19
|
import { SubmitButton } from './SubmitButton.js';
|
|
20
|
+
import { SwitchField } from './SwitchField.js';
|
|
20
21
|
import { TextAreaField, TextField } from './TextField.js';
|
|
22
|
+
import { ToggleGroupField } from './ToggleGroupField.js';
|
|
21
23
|
export { FieldArray } from 'formik';
|
|
22
24
|
export function FormikFormRoot(_a) {
|
|
23
25
|
var { className, children, onSubmit } = _a, props = __rest(_a, ["className", "children", "onSubmit"]);
|
|
24
26
|
const wrappedOnSubmit = useCallback(async (values, bag) => {
|
|
25
27
|
try {
|
|
26
28
|
bag.setSubmitting(true);
|
|
27
|
-
return await onSubmit(values, bag);
|
|
29
|
+
return await (onSubmit === null || onSubmit === void 0 ? void 0 : onSubmit(values, bag));
|
|
28
30
|
}
|
|
29
31
|
finally {
|
|
30
32
|
bag.setSubmitting(false);
|
|
@@ -41,5 +43,7 @@ export const FormikForm = Object.assign(FormikFormRoot, {
|
|
|
41
43
|
NumberStepperField,
|
|
42
44
|
SubmitButton,
|
|
43
45
|
CheckboxField,
|
|
46
|
+
SwitchField,
|
|
47
|
+
ToggleGroupField,
|
|
44
48
|
});
|
|
45
49
|
//# sourceMappingURL=FormikForm.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"FormikForm.js","sourceRoot":"","sources":["../../../../src/components/forms/FormikForm.tsx"],"names":[],"mappings":";;;;;;;;;;;;AAAA,OAAO,EAAE,MAAM,EAA6C,MAAM,QAAQ,CAAC;AAC3E,OAAO,EAAE,WAAW,EAAE,MAAM,OAAO,CAAC;AACpC,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AACjC,OAAO,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAC7D,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,aAAa,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;
|
|
1
|
+
{"version":3,"file":"FormikForm.js","sourceRoot":"","sources":["../../../../src/components/forms/FormikForm.tsx"],"names":[],"mappings":";;;;;;;;;;;;AAAA,OAAO,EAAE,MAAM,EAA6C,MAAM,QAAQ,CAAC;AAC3E,OAAO,EAAE,WAAW,EAAE,MAAM,OAAO,CAAC;AACpC,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AACjC,OAAO,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAC7D,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAE,aAAa,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC1D,OAAO,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AAOzD,OAAO,EAAE,UAAU,EAAE,MAAM,QAAQ,CAAC;AAEpC,MAAM,UAAU,cAAc,CAA8B,EAKlC;QALkC,EAC3D,SAAS,EACT,QAAQ,EACR,QAAQ,OAEiB,EADtB,KAAK,cAJmD,qCAK3D,CADQ;IAER,MAAM,eAAe,GAAG,WAAW,CAClC,KAAK,EAAE,MAAc,EAAE,GAA0B,EAAE,EAAE;QACpD,IAAI,CAAC;YACJ,GAAG,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;YACxB,OAAO,MAAM,CAAA,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAG,MAAM,EAAE,GAAG,CAAC,CAAA,CAAC;QACtC,CAAC;gBAAS,CAAC;YACV,GAAG,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAC1B,CAAC;IACF,CAAC,EACD,CAAC,QAAQ,CAAC,CACV,CAAC;IAEF,IAAI,OAAO,QAAQ,KAAK,UAAU,EAAE,CAAC;QACpC,OAAO,CACN,KAAC,MAAM,kBAAS,QAAQ,EAAE,eAAe,IAAM,KAAK,cAClD,CAAC,MAAM,EAAE,EAAE,CAAC,KAAC,IAAI,IAAC,SAAS,EAAE,SAAS,YAAG,QAAQ,CAAC,MAAM,CAAC,GAAQ,IAC1D,CACT,CAAC;IACH,CAAC;IAED,OAAO,CACN,KAAC,MAAM,kBAAS,QAAQ,EAAE,eAAe,IAAM,KAAK,cACnD,KAAC,IAAI,IAAC,SAAS,EAAE,SAAS,YAAG,QAAQ,GAAQ,IACrC,CACT,CAAC;AACH,CAAC;AAED,MAAM,CAAC,MAAM,UAAU,GAAG,MAAM,CAAC,MAAM,CAAC,cAAc,EAAE;IACvD,SAAS;IACT,aAAa;IACb,kBAAkB;IAClB,YAAY;IACZ,aAAa;IACb,WAAW;IACX,gBAAgB;CAChB,CAAC,CAAC"}
|
|
@@ -3,6 +3,7 @@ import { CheckboxField } from './CheckboxField.js';
|
|
|
3
3
|
import { FormikForm } from './FormikForm.js';
|
|
4
4
|
import { NumberStepperField } from './NumberStepperField.js';
|
|
5
5
|
import { SubmitButton } from './SubmitButton.js';
|
|
6
|
+
import { SwitchField } from './SwitchField.js';
|
|
6
7
|
declare const meta: {
|
|
7
8
|
title: string;
|
|
8
9
|
component: typeof import("./FormikForm.js").FormikFormRoot & {
|
|
@@ -13,6 +14,10 @@ declare const meta: {
|
|
|
13
14
|
NumberStepperField: typeof NumberStepperField;
|
|
14
15
|
SubmitButton: typeof SubmitButton;
|
|
15
16
|
CheckboxField: typeof CheckboxField;
|
|
17
|
+
SwitchField: typeof SwitchField;
|
|
18
|
+
ToggleGroupField: (({ name, label, required, className, id, ...props }: import("./ToggleGroupField.js").ToggleGroupFieldProps) => import("react/jsx-runtime").JSX.Element) & {
|
|
19
|
+
Item: import("react").FunctionComponent<import("@radix-ui/react-toggle-group").ToggleGroupItemProps & import("react").RefAttributes<HTMLButtonElement>>;
|
|
20
|
+
};
|
|
16
21
|
};
|
|
17
22
|
argTypes: {};
|
|
18
23
|
parameters: {
|
|
@@ -15,7 +15,9 @@ import { CheckboxField } from './CheckboxField.js';
|
|
|
15
15
|
import { FormikForm } from './FormikForm.js';
|
|
16
16
|
import { NumberStepperField } from './NumberStepperField.js';
|
|
17
17
|
import { SubmitButton } from './SubmitButton.js';
|
|
18
|
+
import { SwitchField } from './SwitchField.js';
|
|
18
19
|
import { TextField } from './TextField.js';
|
|
20
|
+
import { ToggleGroupField } from './ToggleGroupField.js';
|
|
19
21
|
const meta = {
|
|
20
22
|
title: 'Components/Form',
|
|
21
23
|
component: FormikForm,
|
|
@@ -26,6 +28,11 @@ const meta = {
|
|
|
26
28
|
};
|
|
27
29
|
export default meta;
|
|
28
30
|
export const Default = {
|
|
31
|
+
args: {
|
|
32
|
+
onSubmit: (values) => {
|
|
33
|
+
alert(JSON.stringify(values, null, 2));
|
|
34
|
+
},
|
|
35
|
+
},
|
|
29
36
|
render(_a) {
|
|
30
37
|
var { initialValues } = _a, args = __rest(_a, ["initialValues"]);
|
|
31
38
|
return (_jsxs(FormikForm, Object.assign({ initialValues: {
|
|
@@ -33,7 +40,9 @@ export const Default = {
|
|
|
33
40
|
password: '',
|
|
34
41
|
age: 18,
|
|
35
42
|
tos: false,
|
|
36
|
-
|
|
43
|
+
newsletter: false,
|
|
44
|
+
plan: 'basic',
|
|
45
|
+
} }, args, { children: [_jsx(TextField, { name: "email", type: "email", label: "Email" }), _jsx(TextField, { name: "password", type: "password", label: "Password" }), _jsx(NumberStepperField, { name: "age", label: "Age", min: 13, max: 100 }), _jsx(CheckboxField, { name: "tos", label: "I agree" }), _jsx(SwitchField, { name: "newsletter", label: "Subscribe to newsletter" }), _jsxs(ToggleGroupField, { type: "single", name: "plan", label: "Select your plan", required: true, children: [_jsx(ToggleGroupField.Item, { value: "basic", children: "Basic" }), _jsx(ToggleGroupField.Item, { value: "pro", children: "Pro" }), _jsx(ToggleGroupField.Item, { value: "enterprise", children: "Enterprise" })] }), _jsx(SubmitButton, { children: "Sign up" })] })));
|
|
37
46
|
},
|
|
38
47
|
};
|
|
39
48
|
//# sourceMappingURL=FormikForm.stories.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"FormikForm.stories.js","sourceRoot":"","sources":["../../../../src/components/forms/FormikForm.stories.tsx"],"names":[],"mappings":";;;;;;;;;;;;AACA,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAC7C,OAAO,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAC7D,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;
|
|
1
|
+
{"version":3,"file":"FormikForm.stories.js","sourceRoot":"","sources":["../../../../src/components/forms/FormikForm.stories.tsx"],"names":[],"mappings":";;;;;;;;;;;;AACA,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAC7C,OAAO,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAC7D,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC3C,OAAO,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AAEzD,MAAM,IAAI,GAAG;IACZ,KAAK,EAAE,iBAAiB;IACxB,SAAS,EAAE,UAAU;IACrB,QAAQ,EAAE,EAAE;IACZ,UAAU,EAAE;QACX,QAAQ,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE;KAC5B;CACiC,CAAC;AAEpC,eAAe,IAAI,CAAC;AAIpB,MAAM,CAAC,MAAM,OAAO,GAAU;IAC7B,IAAI,EAAE;QACL,QAAQ,EAAE,CAAC,MAAM,EAAE,EAAE;YACpB,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;QACxC,CAAC;KACD;IACD,MAAM,CAAC,EAA0B;YAA1B,EAAE,aAAa,OAAW,EAAN,IAAI,cAAxB,iBAA0B,CAAF;QAC9B,OAAO,CACN,MAAC,UAAU,kBACV,aAAa,EAAE;gBACd,KAAK,EAAE,EAAE;gBACT,QAAQ,EAAE,EAAE;gBACZ,GAAG,EAAE,EAAE;gBACP,GAAG,EAAE,KAAK;gBACV,UAAU,EAAE,KAAK;gBACjB,IAAI,EAAE,OAAO;aACb,IACG,IAAI,eAER,KAAC,SAAS,IAAC,IAAI,EAAC,OAAO,EAAC,IAAI,EAAC,OAAO,EAAC,KAAK,EAAC,OAAO,GAAG,EACrD,KAAC,SAAS,IAAC,IAAI,EAAC,UAAU,EAAC,IAAI,EAAC,UAAU,EAAC,KAAK,EAAC,UAAU,GAAG,EAC9D,KAAC,kBAAkB,IAAC,IAAI,EAAC,KAAK,EAAC,KAAK,EAAC,KAAK,EAAC,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,GAAG,GAAI,EAChE,KAAC,aAAa,IAAC,IAAI,EAAC,KAAK,EAAC,KAAK,EAAC,SAAS,GAAG,EAC5C,KAAC,WAAW,IAAC,IAAI,EAAC,YAAY,EAAC,KAAK,EAAC,yBAAyB,GAAG,EACjE,MAAC,gBAAgB,IAChB,IAAI,EAAC,QAAQ,EACb,IAAI,EAAC,MAAM,EACX,KAAK,EAAC,kBAAkB,EACxB,QAAQ,mBAER,KAAC,gBAAgB,CAAC,IAAI,IAAC,KAAK,EAAC,OAAO,sBAA8B,EAClE,KAAC,gBAAgB,CAAC,IAAI,IAAC,KAAK,EAAC,KAAK,oBAA4B,EAC9D,KAAC,gBAAgB,CAAC,IAAI,IAAC,KAAK,EAAC,YAAY,2BAEjB,IACN,EACnB,KAAC,YAAY,0BAAuB,KACxB,CACb,CAAC;IACH,CAAC;CACD,CAAC"}
|
|
@@ -4,6 +4,6 @@ import { useFormikContext } from 'formik';
|
|
|
4
4
|
import { Button } from '../button/Button.js';
|
|
5
5
|
export function SubmitButton(props) {
|
|
6
6
|
const { isSubmitting, isValid } = useFormikContext();
|
|
7
|
-
return (_jsx(Button, Object.assign({ loading: isSubmitting, disabled: !isValid, color: "primary", type: "submit" }, props)));
|
|
7
|
+
return (_jsx(Button, Object.assign({ loading: isSubmitting, disabled: !isValid, color: "primary", emphasis: "primary", type: "submit" }, props)));
|
|
8
8
|
}
|
|
9
9
|
//# sourceMappingURL=SubmitButton.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SubmitButton.js","sourceRoot":"","sources":["../../../../src/components/forms/SubmitButton.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,QAAQ,CAAC;AAC1C,OAAO,EAAE,MAAM,EAAe,MAAM,qBAAqB,CAAC;AAE1D,MAAM,UAAU,YAAY,CAAC,KAAkB;IAC9C,MAAM,EAAE,YAAY,EAAE,OAAO,EAAE,GAAG,gBAAgB,EAAE,CAAC;IACrD,OAAO,CACN,KAAC,MAAM,kBACN,OAAO,EAAE,YAAY,EACrB,QAAQ,EAAE,CAAC,OAAO,EAClB,KAAK,EAAC,SAAS,EACf,IAAI,EAAC,QAAQ,IACT,KAAK,EACR,CACF,CAAC;AACH,CAAC"}
|
|
1
|
+
{"version":3,"file":"SubmitButton.js","sourceRoot":"","sources":["../../../../src/components/forms/SubmitButton.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,QAAQ,CAAC;AAC1C,OAAO,EAAE,MAAM,EAAe,MAAM,qBAAqB,CAAC;AAE1D,MAAM,UAAU,YAAY,CAAC,KAAkB;IAC9C,MAAM,EAAE,YAAY,EAAE,OAAO,EAAE,GAAG,gBAAgB,EAAE,CAAC;IACrD,OAAO,CACN,KAAC,MAAM,kBACN,OAAO,EAAE,YAAY,EACrB,QAAQ,EAAE,CAAC,OAAO,EAClB,KAAK,EAAC,SAAS,EACf,QAAQ,EAAC,SAAS,EAClB,IAAI,EAAC,QAAQ,IACT,KAAK,EACR,CACF,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export interface SwitchFieldProps {
|
|
2
|
+
name: string;
|
|
3
|
+
label?: string;
|
|
4
|
+
required?: boolean;
|
|
5
|
+
className?: string;
|
|
6
|
+
id?: string;
|
|
7
|
+
}
|
|
8
|
+
export declare function SwitchField({ name, label, className, required, id: providedId, ...rest }: SwitchFieldProps): import("react/jsx-runtime").JSX.Element;
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
// @unocss-include
|
|
2
|
+
var __rest = (this && this.__rest) || function (s, e) {
|
|
3
|
+
var t = {};
|
|
4
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
|
|
5
|
+
t[p] = s[p];
|
|
6
|
+
if (s != null && typeof Object.getOwnPropertySymbols === "function")
|
|
7
|
+
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
|
|
8
|
+
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
|
|
9
|
+
t[p[i]] = s[p[i]];
|
|
10
|
+
}
|
|
11
|
+
return t;
|
|
12
|
+
};
|
|
13
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
14
|
+
import { useField } from 'formik';
|
|
15
|
+
import { useIdOrGenerated } from '../../hooks/useIdOrGenerated.js';
|
|
16
|
+
import { Box } from '../box/Box.js';
|
|
17
|
+
import { Switch } from '../switch/Switch.js';
|
|
18
|
+
import { HorizontalFieldLabel } from './FieldLabel.js';
|
|
19
|
+
export function SwitchField(_a) {
|
|
20
|
+
var { name, label, className, required, id: providedId } = _a, rest = __rest(_a, ["name", "label", "className", "required", "id"]);
|
|
21
|
+
const [props, _, tools] = useField({ name, type: 'checkbox' });
|
|
22
|
+
const id = useIdOrGenerated(providedId);
|
|
23
|
+
return (_jsxs(Box, { gap: "sm", className: className, children: [_jsx(Switch, Object.assign({}, props, { checked: props.checked, onCheckedChange: (v) => {
|
|
24
|
+
tools.setValue(!!v);
|
|
25
|
+
}, id: id }, rest)), label && (_jsx(HorizontalFieldLabel, { htmlFor: id, children: label }))] }));
|
|
26
|
+
}
|
|
27
|
+
//# sourceMappingURL=SwitchField.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SwitchField.js","sourceRoot":"","sources":["../../../../src/components/forms/SwitchField.tsx"],"names":[],"mappings":";;;;;;;;;;;;AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAC;AAClC,OAAO,EAAE,gBAAgB,EAAE,MAAM,iCAAiC,CAAC;AACnE,OAAO,EAAE,GAAG,EAAE,MAAM,eAAe,CAAC;AACpC,OAAO,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AAC7C,OAAO,EAAE,oBAAoB,EAAE,MAAM,iBAAiB,CAAC;AAUvD,MAAM,UAAU,WAAW,CAAC,EAOT;QAPS,EAC3B,IAAI,EACJ,KAAK,EACL,SAAS,EACT,QAAQ,EACR,EAAE,EAAE,UAAU,OAEI,EADf,IAAI,cANoB,gDAO3B,CADO;IAEP,MAAM,CAAC,KAAK,EAAE,CAAC,EAAE,KAAK,CAAC,GAAG,QAAQ,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC,CAAC;IAC/D,MAAM,EAAE,GAAG,gBAAgB,CAAC,UAAU,CAAC,CAAC;IACxC,OAAO,CACN,MAAC,GAAG,IAAC,GAAG,EAAC,IAAI,EAAC,SAAS,EAAE,SAAS,aACjC,KAAC,MAAM,oBACF,KAAK,IACT,OAAO,EAAE,KAAK,CAAC,OAAO,EACtB,eAAe,EAAE,CAAC,CAAC,EAAE,EAAE;oBACtB,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;gBACrB,CAAC,EACD,EAAE,EAAE,EAAE,IACF,IAAI,EACP,EACD,KAAK,IAAI,CACT,KAAC,oBAAoB,IAAC,OAAO,EAAE,EAAE,YAAG,KAAK,GAAwB,CACjE,IACI,CACN,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { ToggleGroupProps } from '../toggleGroup/toggleGroup.js';
|
|
2
|
+
export type ToggleGroupFieldProps = ToggleGroupProps & {
|
|
3
|
+
name: string;
|
|
4
|
+
label?: string;
|
|
5
|
+
required?: boolean;
|
|
6
|
+
className?: string;
|
|
7
|
+
id?: string;
|
|
8
|
+
};
|
|
9
|
+
declare function ToggleGroupFieldDefault({ name, label, required, className, id, ...props }: ToggleGroupFieldProps): import("react/jsx-runtime").JSX.Element;
|
|
10
|
+
export declare const ToggleGroupField: typeof ToggleGroupFieldDefault & {
|
|
11
|
+
Item: import("react").FunctionComponent<import("@radix-ui/react-toggle-group").ToggleGroupItemProps & import("react").RefAttributes<HTMLButtonElement>>;
|
|
12
|
+
};
|
|
13
|
+
export {};
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
// @unocss-include
|
|
2
|
+
var __rest = (this && this.__rest) || function (s, e) {
|
|
3
|
+
var t = {};
|
|
4
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
|
|
5
|
+
t[p] = s[p];
|
|
6
|
+
if (s != null && typeof Object.getOwnPropertySymbols === "function")
|
|
7
|
+
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
|
|
8
|
+
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
|
|
9
|
+
t[p[i]] = s[p[i]];
|
|
10
|
+
}
|
|
11
|
+
return t;
|
|
12
|
+
};
|
|
13
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
14
|
+
import { useField } from 'formik';
|
|
15
|
+
import { ToggleGroup } from '../toggleGroup/toggleGroup.js';
|
|
16
|
+
import { FieldLabel } from './FieldLabel.js';
|
|
17
|
+
import { FieldRoot } from './TextField.js';
|
|
18
|
+
function ToggleGroupFieldDefault(_a) {
|
|
19
|
+
var { name, label, required, className, id } = _a, props = __rest(_a, ["name", "label", "required", "className", "id"]);
|
|
20
|
+
const [fieldProps, _, tools] = useField(Object.assign({ name }, props));
|
|
21
|
+
return (_jsxs(FieldRoot, { children: [label && _jsx(FieldLabel, { htmlFor: id, children: label }), _jsx(ToggleGroup, Object.assign({}, fieldProps, { onValueChange: (v) => tools.setValue(v) }, props, { id: id, className: className }))] }));
|
|
22
|
+
}
|
|
23
|
+
export const ToggleGroupField = Object.assign(ToggleGroupFieldDefault, {
|
|
24
|
+
Item: ToggleGroup.Item,
|
|
25
|
+
});
|
|
26
|
+
//# sourceMappingURL=ToggleGroupField.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ToggleGroupField.js","sourceRoot":"","sources":["../../../../src/components/forms/ToggleGroupField.tsx"],"names":[],"mappings":";;;;;;;;;;;;AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAC;AAClC,OAAO,EAAE,WAAW,EAAoB,MAAM,+BAA+B,CAAC;AAC9E,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAC7C,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAU3C,SAAS,uBAAuB,CAAC,EAOT;QAPS,EAChC,IAAI,EACJ,KAAK,EACL,QAAQ,EACR,SAAS,EACT,EAAE,OAEqB,EADpB,KAAK,cANwB,gDAOhC,CADQ;IAER,MAAM,CAAC,UAAU,EAAE,CAAC,EAAE,KAAK,CAAC,GAAG,QAAQ,iBAAG,IAAI,IAAK,KAAK,EAAG,CAAC;IAE5D,OAAO,CACN,MAAC,SAAS,eACR,KAAK,IAAI,KAAC,UAAU,IAAC,OAAO,EAAE,EAAE,YAAG,KAAK,GAAc,EACvD,KAAC,WAAW,oBACP,UAAU,IACd,aAAa,EAAE,CAAC,CAAM,EAAE,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,IACxC,KAAK,IACT,EAAE,EAAE,EAAE,EACN,SAAS,EAAE,SAAS,IACnB,IACS,CACZ,CAAC;AACH,CAAC;AAED,MAAM,CAAC,MAAM,gBAAgB,GAAG,MAAM,CAAC,MAAM,CAAC,uBAAuB,EAAE;IACtE,IAAI,EAAE,WAAW,CAAC,IAAI;CACtB,CAAC,CAAC"}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import * as ToggleGroupPrimitive from '@radix-ui/react-toggle-group';
|
|
2
2
|
export declare const ToggleGroupRoot: import("react").FunctionComponent<(ToggleGroupPrimitive.ToggleGroupSingleProps | ToggleGroupPrimitive.ToggleGroupMultipleProps) & import("react").RefAttributes<HTMLDivElement>>;
|
|
3
3
|
export declare const ToggleGroupItem: import("react").FunctionComponent<ToggleGroupPrimitive.ToggleGroupItemProps & import("react").RefAttributes<HTMLButtonElement>>;
|
|
4
|
+
export type ToggleGroupProps = ToggleGroupPrimitive.ToggleGroupMultipleProps | ToggleGroupPrimitive.ToggleGroupSingleProps;
|
|
4
5
|
export declare const ToggleGroup: import("react").FunctionComponent<(ToggleGroupPrimitive.ToggleGroupSingleProps | ToggleGroupPrimitive.ToggleGroupMultipleProps) & import("react").RefAttributes<HTMLDivElement>> & {
|
|
5
6
|
Item: import("react").FunctionComponent<ToggleGroupPrimitive.ToggleGroupItemProps & import("react").RefAttributes<HTMLButtonElement>>;
|
|
6
7
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"toggleGroup.js","sourceRoot":"","sources":["../../../../src/components/toggleGroup/toggleGroup.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,oBAAoB,MAAM,8BAA8B,CAAC;AACrE,OAAO,EAAE,aAAa,EAAE,MAAM,8BAA8B,CAAC;AAE7D,MAAM,CAAC,MAAM,eAAe,GAAG,aAAa,CAC3C,oBAAoB,CAAC,IAAI,EACzB,yEAAyE,CACzE,CAAC;AACF,MAAM,CAAC,MAAM,eAAe,GAAG,aAAa,CAC3C,oBAAoB,CAAC,IAAI,EACzB,wLAAwL,EACxL,yEAAyE,EACzE,iEAAiE,EACjE,iEAAiE,EACjE,6FAA6F,CAC7F,CAAC;
|
|
1
|
+
{"version":3,"file":"toggleGroup.js","sourceRoot":"","sources":["../../../../src/components/toggleGroup/toggleGroup.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,oBAAoB,MAAM,8BAA8B,CAAC;AACrE,OAAO,EAAE,aAAa,EAAE,MAAM,8BAA8B,CAAC;AAE7D,MAAM,CAAC,MAAM,eAAe,GAAG,aAAa,CAC3C,oBAAoB,CAAC,IAAI,EACzB,yEAAyE,CACzE,CAAC;AACF,MAAM,CAAC,MAAM,eAAe,GAAG,aAAa,CAC3C,oBAAoB,CAAC,IAAI,EACzB,wLAAwL,EACxL,yEAAyE,EACzE,iEAAiE,EACjE,iEAAiE,EACjE,6FAA6F,CAC7F,CAAC;AAKF,MAAM,CAAC,MAAM,WAAW,GAAG,MAAM,CAAC,MAAM,CAAC,eAAe,EAAE;IACzD,IAAI,EAAE,eAAe;CACrB,CAAC,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import { useField } from 'formik';
|
|
2
|
-
import { withClassName } from '../../hooks.js';
|
|
3
2
|
import { useIdOrGenerated } from '../../hooks/useIdOrGenerated.js';
|
|
3
|
+
import { Box } from '../box/Box.js';
|
|
4
4
|
import { Checkbox } from '../checkbox/index.js';
|
|
5
|
+
import { HorizontalFieldLabel } from './FieldLabel.js';
|
|
5
6
|
|
|
6
7
|
export interface CheckboxFieldProps {
|
|
7
8
|
name: string;
|
|
@@ -22,26 +23,19 @@ export function CheckboxField({
|
|
|
22
23
|
const [props, _, tools] = useField({ name, type: 'checkbox' });
|
|
23
24
|
const id = useIdOrGenerated(providedId);
|
|
24
25
|
return (
|
|
25
|
-
<
|
|
26
|
+
<Box gap="sm" className={className}>
|
|
26
27
|
<Checkbox
|
|
27
28
|
{...props}
|
|
28
29
|
checked={props.checked}
|
|
29
30
|
onCheckedChange={(v) => {
|
|
30
31
|
tools.setValue(!!v);
|
|
31
32
|
}}
|
|
33
|
+
id={id}
|
|
32
34
|
{...rest}
|
|
33
35
|
/>
|
|
34
|
-
{label &&
|
|
35
|
-
|
|
36
|
+
{label && (
|
|
37
|
+
<HorizontalFieldLabel htmlFor={id}>{label}</HorizontalFieldLabel>
|
|
38
|
+
)}
|
|
39
|
+
</Box>
|
|
36
40
|
);
|
|
37
41
|
}
|
|
38
|
-
|
|
39
|
-
const FieldRoot = withClassName(
|
|
40
|
-
'div',
|
|
41
|
-
'layer-components:(flex flex-row gap-2)',
|
|
42
|
-
);
|
|
43
|
-
|
|
44
|
-
const FieldLabel = withClassName(
|
|
45
|
-
'label',
|
|
46
|
-
'layer-components:(inline-flex flex-col gap-1 text-md font-normal color-dark/50 mt-2px)',
|
|
47
|
-
);
|
|
@@ -2,5 +2,10 @@ import { withClassName } from '../../hooks.js';
|
|
|
2
2
|
|
|
3
3
|
export const FieldLabel = withClassName(
|
|
4
4
|
'label',
|
|
5
|
-
'inline-flex flex-col gap-
|
|
5
|
+
'inline-flex flex-col gap-xs text-sm font-bold color-gray-ink ml-md',
|
|
6
|
+
);
|
|
7
|
+
|
|
8
|
+
export const HorizontalFieldLabel = withClassName(
|
|
9
|
+
'label',
|
|
10
|
+
'inline-flex flex-row items-center gap-sm text-sm color-gray-ink',
|
|
6
11
|
);
|
|
@@ -3,7 +3,9 @@ import { CheckboxField } from './CheckboxField.js';
|
|
|
3
3
|
import { FormikForm } from './FormikForm.js';
|
|
4
4
|
import { NumberStepperField } from './NumberStepperField.js';
|
|
5
5
|
import { SubmitButton } from './SubmitButton.js';
|
|
6
|
+
import { SwitchField } from './SwitchField.js';
|
|
6
7
|
import { TextField } from './TextField.js';
|
|
8
|
+
import { ToggleGroupField } from './ToggleGroupField.js';
|
|
7
9
|
|
|
8
10
|
const meta = {
|
|
9
11
|
title: 'Components/Form',
|
|
@@ -19,6 +21,11 @@ export default meta;
|
|
|
19
21
|
type Story = StoryObj<typeof FormikForm>;
|
|
20
22
|
|
|
21
23
|
export const Default: Story = {
|
|
24
|
+
args: {
|
|
25
|
+
onSubmit: (values) => {
|
|
26
|
+
alert(JSON.stringify(values, null, 2));
|
|
27
|
+
},
|
|
28
|
+
},
|
|
22
29
|
render({ initialValues, ...args }) {
|
|
23
30
|
return (
|
|
24
31
|
<FormikForm
|
|
@@ -27,6 +34,8 @@ export const Default: Story = {
|
|
|
27
34
|
password: '',
|
|
28
35
|
age: 18,
|
|
29
36
|
tos: false,
|
|
37
|
+
newsletter: false,
|
|
38
|
+
plan: 'basic',
|
|
30
39
|
}}
|
|
31
40
|
{...args}
|
|
32
41
|
>
|
|
@@ -34,6 +43,19 @@ export const Default: Story = {
|
|
|
34
43
|
<TextField name="password" type="password" label="Password" />
|
|
35
44
|
<NumberStepperField name="age" label="Age" min={13} max={100} />
|
|
36
45
|
<CheckboxField name="tos" label="I agree" />
|
|
46
|
+
<SwitchField name="newsletter" label="Subscribe to newsletter" />
|
|
47
|
+
<ToggleGroupField
|
|
48
|
+
type="single"
|
|
49
|
+
name="plan"
|
|
50
|
+
label="Select your plan"
|
|
51
|
+
required
|
|
52
|
+
>
|
|
53
|
+
<ToggleGroupField.Item value="basic">Basic</ToggleGroupField.Item>
|
|
54
|
+
<ToggleGroupField.Item value="pro">Pro</ToggleGroupField.Item>
|
|
55
|
+
<ToggleGroupField.Item value="enterprise">
|
|
56
|
+
Enterprise
|
|
57
|
+
</ToggleGroupField.Item>
|
|
58
|
+
</ToggleGroupField>
|
|
37
59
|
<SubmitButton>Sign up</SubmitButton>
|
|
38
60
|
</FormikForm>
|
|
39
61
|
);
|
|
@@ -4,7 +4,9 @@ import { CheckboxField } from './CheckboxField.js';
|
|
|
4
4
|
import { Form } from './Form.js';
|
|
5
5
|
import { NumberStepperField } from './NumberStepperField.js';
|
|
6
6
|
import { SubmitButton } from './SubmitButton.js';
|
|
7
|
+
import { SwitchField } from './SwitchField.js';
|
|
7
8
|
import { TextAreaField, TextField } from './TextField.js';
|
|
9
|
+
import { ToggleGroupField } from './ToggleGroupField.js';
|
|
8
10
|
|
|
9
11
|
export interface FormikFormProps<T extends FormikValues = FormikValues>
|
|
10
12
|
extends FormikConfig<T> {
|
|
@@ -23,7 +25,7 @@ export function FormikFormRoot<Values extends FormikValues>({
|
|
|
23
25
|
async (values: Values, bag: FormikHelpers<Values>) => {
|
|
24
26
|
try {
|
|
25
27
|
bag.setSubmitting(true);
|
|
26
|
-
return await onSubmit(values, bag);
|
|
28
|
+
return await onSubmit?.(values, bag);
|
|
27
29
|
} finally {
|
|
28
30
|
bag.setSubmitting(false);
|
|
29
31
|
}
|
|
@@ -52,4 +54,6 @@ export const FormikForm = Object.assign(FormikFormRoot, {
|
|
|
52
54
|
NumberStepperField,
|
|
53
55
|
SubmitButton,
|
|
54
56
|
CheckboxField,
|
|
57
|
+
SwitchField,
|
|
58
|
+
ToggleGroupField,
|
|
55
59
|
});
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { useField } from 'formik';
|
|
2
|
+
import { useIdOrGenerated } from '../../hooks/useIdOrGenerated.js';
|
|
3
|
+
import { Box } from '../box/Box.js';
|
|
4
|
+
import { Switch } from '../switch/Switch.js';
|
|
5
|
+
import { HorizontalFieldLabel } from './FieldLabel.js';
|
|
6
|
+
|
|
7
|
+
export interface SwitchFieldProps {
|
|
8
|
+
name: string;
|
|
9
|
+
label?: string;
|
|
10
|
+
required?: boolean;
|
|
11
|
+
className?: string;
|
|
12
|
+
id?: string;
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
export function SwitchField({
|
|
16
|
+
name,
|
|
17
|
+
label,
|
|
18
|
+
className,
|
|
19
|
+
required,
|
|
20
|
+
id: providedId,
|
|
21
|
+
...rest
|
|
22
|
+
}: SwitchFieldProps) {
|
|
23
|
+
const [props, _, tools] = useField({ name, type: 'checkbox' });
|
|
24
|
+
const id = useIdOrGenerated(providedId);
|
|
25
|
+
return (
|
|
26
|
+
<Box gap="sm" className={className}>
|
|
27
|
+
<Switch
|
|
28
|
+
{...props}
|
|
29
|
+
checked={props.checked}
|
|
30
|
+
onCheckedChange={(v) => {
|
|
31
|
+
tools.setValue(!!v);
|
|
32
|
+
}}
|
|
33
|
+
id={id}
|
|
34
|
+
{...rest}
|
|
35
|
+
/>
|
|
36
|
+
{label && (
|
|
37
|
+
<HorizontalFieldLabel htmlFor={id}>{label}</HorizontalFieldLabel>
|
|
38
|
+
)}
|
|
39
|
+
</Box>
|
|
40
|
+
);
|
|
41
|
+
}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { useField } from 'formik';
|
|
2
|
+
import { ToggleGroup, ToggleGroupProps } from '../toggleGroup/toggleGroup.js';
|
|
3
|
+
import { FieldLabel } from './FieldLabel.js';
|
|
4
|
+
import { FieldRoot } from './TextField.js';
|
|
5
|
+
|
|
6
|
+
export type ToggleGroupFieldProps = ToggleGroupProps & {
|
|
7
|
+
name: string;
|
|
8
|
+
label?: string;
|
|
9
|
+
required?: boolean;
|
|
10
|
+
className?: string;
|
|
11
|
+
id?: string;
|
|
12
|
+
};
|
|
13
|
+
|
|
14
|
+
function ToggleGroupFieldDefault({
|
|
15
|
+
name,
|
|
16
|
+
label,
|
|
17
|
+
required,
|
|
18
|
+
className,
|
|
19
|
+
id,
|
|
20
|
+
...props
|
|
21
|
+
}: ToggleGroupFieldProps) {
|
|
22
|
+
const [fieldProps, _, tools] = useField({ name, ...props });
|
|
23
|
+
|
|
24
|
+
return (
|
|
25
|
+
<FieldRoot>
|
|
26
|
+
{label && <FieldLabel htmlFor={id}>{label}</FieldLabel>}
|
|
27
|
+
<ToggleGroup
|
|
28
|
+
{...fieldProps}
|
|
29
|
+
onValueChange={(v: any) => tools.setValue(v)}
|
|
30
|
+
{...props}
|
|
31
|
+
id={id}
|
|
32
|
+
className={className}
|
|
33
|
+
/>
|
|
34
|
+
</FieldRoot>
|
|
35
|
+
);
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
export const ToggleGroupField = Object.assign(ToggleGroupFieldDefault, {
|
|
39
|
+
Item: ToggleGroup.Item,
|
|
40
|
+
});
|
|
@@ -14,6 +14,9 @@ export const ToggleGroupItem = withClassName(
|
|
|
14
14
|
'layer-components:[&[data-state=on]]:(bg-main border-default shadow-sm hover:border-default)',
|
|
15
15
|
);
|
|
16
16
|
|
|
17
|
+
export type ToggleGroupProps =
|
|
18
|
+
| ToggleGroupPrimitive.ToggleGroupMultipleProps
|
|
19
|
+
| ToggleGroupPrimitive.ToggleGroupSingleProps;
|
|
17
20
|
export const ToggleGroup = Object.assign(ToggleGroupRoot, {
|
|
18
21
|
Item: ToggleGroupItem,
|
|
19
22
|
});
|