@saas-ui/forms 1.0.0-rc.2 → 1.0.0-rc.5

Sign up to get free protection for your applications and to get access to all the features.
@@ -3,8 +3,20 @@ import { FieldValues, UseFormReturn } from 'react-hook-form';
3
3
  import { FormProps } from './form';
4
4
  import { FieldResolver } from '.';
5
5
  interface AutoFormOptions {
6
- submitLabel?: false | string;
6
+ /**
7
+ * The submit button label.
8
+ * Pass `null` to render no submit button.
9
+ */
10
+ submitLabel?: React.ReactNode;
11
+ /**
12
+ * The schema.
13
+ * Supports object schema, Yup or Zod.
14
+ * @see https://www.saas-ui.dev/docs/forms/auto-form
15
+ */
7
16
  schema: any;
17
+ /**
18
+ * The field resolver.
19
+ */
8
20
  fieldResolver?: any;
9
21
  }
10
22
  export interface AutoFormProps<TFieldValues extends FieldValues> extends Omit<FormProps<TFieldValues>, 'schema'>, AutoFormOptions {
@@ -1 +1 @@
1
- {"version":3,"file":"auto-form.d.ts","sourceRoot":"","sources":["../src/auto-form.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAC9B,OAAO,EAAE,WAAW,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAA;AAI5D,OAAO,EAAQ,SAAS,EAAE,MAAM,QAAQ,CAAA;AAIxC,OAAO,EAAE,aAAa,EAAE,MAAM,GAAG,CAAA;AAEjC,UAAU,eAAe;IACvB,WAAW,CAAC,EAAE,KAAK,GAAG,MAAM,CAAA;IAC5B,MAAM,EAAE,GAAG,CAAA;IACX,aAAa,CAAC,EAAE,GAAG,CAAA;CACpB;AAED,MAAM,WAAW,aAAa,CAAC,YAAY,SAAS,WAAW,CAC7D,SAAQ,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,EAAE,QAAQ,CAAC,EAC7C,eAAe;CAAG;AAEtB,eAAO,MAAM,QAAQ;;MAoBhB,MAAM,YAAY;;iCAEO,GAAG,KAAK,aAAa;CAClD,CAAA"}
1
+ {"version":3,"file":"auto-form.d.ts","sourceRoot":"","sources":["../src/auto-form.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAC9B,OAAO,EAAE,WAAW,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAA;AAI5D,OAAO,EAAQ,SAAS,EAAE,MAAM,QAAQ,CAAA;AAIxC,OAAO,EAAE,aAAa,EAAE,MAAM,GAAG,CAAA;AAEjC,UAAU,eAAe;IACvB;;;OAGG;IACH,WAAW,CAAC,EAAE,KAAK,CAAC,SAAS,CAAA;IAC7B;;;;OAIG;IACH,MAAM,EAAE,GAAG,CAAA;IACX;;OAEG;IACH,aAAa,CAAC,EAAE,GAAG,CAAA;CACpB;AAED,MAAM,WAAW,aAAa,CAAC,YAAY,SAAS,WAAW,CAC7D,SAAQ,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,EAAE,QAAQ,CAAC,EAC7C,eAAe;CAAG;AAEtB,eAAO,MAAM,QAAQ;;MA2BhB,MAAM,YAAY;;iCAEO,GAAG,KAAK,aAAa;CAClD,CAAA"}
package/dist/field.d.ts CHANGED
@@ -76,7 +76,7 @@ export interface RegisterFieldTypeOptions {
76
76
  * @param component The React component
77
77
  * @param options
78
78
  * @param options.isControlled Set this to true if this is a controlled field.
79
- * @param options.hideLabel Hide the field label, for example for checkbox or switch field.
79
+ * @param options.hideLabel Hide the field label, for example for the checkbox field.
80
80
  */
81
81
  export declare const registerFieldType: (type: string, component: React.FC<any>, options?: RegisterFieldTypeOptions) => import("@chakra-ui/react").ComponentWithAs<import("@chakra-ui/react").ComponentWithAs<"div", FormControlProps>, FieldProps<FieldValues, string>>;
82
82
  export declare const InputField: import("@chakra-ui/react").ComponentWithAs<import("@chakra-ui/react").ComponentWithAs<"div", FormControlProps>, FieldProps<FieldValues, string>>;
@@ -1 +1 @@
1
- {"version":3,"file":"field.d.ts","sourceRoot":"","sources":["../src/field.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAC9B,OAAO,EAKL,eAAe,EACf,WAAW,EACX,SAAS,EACV,MAAM,iBAAiB,CAAA;AAExB,OAAO,EAIL,gBAAgB,EASjB,MAAM,kBAAkB,CAAA;AAQzB,OAAO,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAA;AAEnD,MAAM,WAAW,MAAM;IACrB,KAAK,EAAE,MAAM,CAAA;IACb,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAA;CACvB;AAED,oBAAY,UAAU,GAAG,IAAI,CAC3B,eAAe,EACf,UAAU,GAAG,KAAK,GAAG,KAAK,GAAG,WAAW,GAAG,WAAW,GAAG,SAAS,CACnE,CAAA;AAED,oBAAY,UAAU,GAClB,MAAM,GACN,QAAQ,GACR,UAAU,GACV,UAAU,GACV,QAAQ,GACR,eAAe,GACf,UAAU,GACV,OAAO,GACP,QAAQ,GACR,KAAK,GACL,MAAM,CAAA;AAEV,MAAM,WAAW,UAAU,CACzB,YAAY,SAAS,WAAW,GAAG,WAAW,EAC9C,KAAK,SAAS,SAAS,CAAC,YAAY,CAAC,GAAG,SAAS,CAAC,YAAY,CAAC,CAC/D,SAAQ,IAAI,CAAC,gBAAgB,EAAE,OAAO,GAAG,MAAM,CAAC;IAChD;;OAEG;IACH,IAAI,EAAE,KAAK,CAAA;IACX;;OAEG;IACH,KAAK,CAAC,EAAE,MAAM,CAAA;IACd;;OAEG;IACH,SAAS,CAAC,EAAE,OAAO,CAAA;IACnB;;OAEG;IACH,IAAI,CAAC,EAAE,MAAM,CAAA;IACb;;OAEG;IACH,KAAK,CAAC,EAAE,IAAI,CACV,eAAe,CAAC,YAAY,EAAE,KAAK,CAAC,EACpC,eAAe,GAAG,aAAa,GAAG,YAAY,GAAG,UAAU,CAC5D,CAAA;IACD;;OAEG;IACH,OAAO,CAAC,EAAE,MAAM,EAAE,CAAA;IAClB;;;;;;;;;;;;;;;;OAgBG;IACH,IAAI,CAAC,EAAE,UAAU,CAAA;IACjB;;OAEG;IACH,WAAW,CAAC,EAAE,MAAM,CAAA;CACrB;AAqBD,eAAO,MAAM,SAAS,EAAE,KAAK,CAAC,EAAE,CAAC,UAAU,CAwB1C,CAAA;AAMD,eAAO,MAAM,KAAK;;;;MAkBb,MAAM,YAAY,CAAA;AA6DvB,eAAO,MAAM,mBAAmB,mBAAoB,GAAG,qFAqBtD,CAAA;AAED,eAAO,MAAM,qBAAqB,mBAAoB,GAAG,qFAgBxD,CAAA;AAED,MAAM,WAAW,wBAAwB;IACvC,YAAY,CAAC,EAAE,OAAO,CAAA;IACtB,SAAS,CAAC,EAAE,OAAO,CAAA;IACnB,SAAS,CAAC,EAAE,KAAK,CAAC,EAAE,CAAC,GAAG,CAAC,CAAA;CAC1B;AAED;;;;;;;GAOG;AACH,eAAO,MAAM,iBAAiB,SACtB,MAAM,aACD,MAAM,EAAE,CAAC,GAAG,CAAC,YACd,wBAAwB,qJAqBnC,CAAA;AAID,eAAO,MAAM,UAAU,kJAAmC,CAAA;AAC1D,eAAO,MAAM,gBAAgB,kJAE3B,CAAA;AACF,eAAO,MAAM,kBAAkB,kJAA+C,CAAA;AAC9E,eAAO,MAAM,aAAa,kJAA0C,CAAA;AACpE,eAAO,MAAM,WAAW,kJAavB,CAAA;AACD,eAAO,MAAM,WAAW,kJAEtB,CAAA;AACF,eAAO,MAAM,aAAa,kJAYzB,CAAA;AACD,eAAO,MAAM,UAAU,kJAErB,CAAA;AACF,eAAO,MAAM,QAAQ,kJAEnB,CAAA;AACF,eAAO,MAAM,iBAAiB,kJAI7B,CAAA"}
1
+ {"version":3,"file":"field.d.ts","sourceRoot":"","sources":["../src/field.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAC9B,OAAO,EAKL,eAAe,EACf,WAAW,EACX,SAAS,EACV,MAAM,iBAAiB,CAAA;AAExB,OAAO,EAIL,gBAAgB,EASjB,MAAM,kBAAkB,CAAA;AAQzB,OAAO,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAA;AAEnD,MAAM,WAAW,MAAM;IACrB,KAAK,EAAE,MAAM,CAAA;IACb,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAA;CACvB;AAED,oBAAY,UAAU,GAAG,IAAI,CAC3B,eAAe,EACf,UAAU,GAAG,KAAK,GAAG,KAAK,GAAG,WAAW,GAAG,WAAW,GAAG,SAAS,CACnE,CAAA;AAED,oBAAY,UAAU,GAClB,MAAM,GACN,QAAQ,GACR,UAAU,GACV,UAAU,GACV,QAAQ,GACR,eAAe,GACf,UAAU,GACV,OAAO,GACP,QAAQ,GACR,KAAK,GACL,MAAM,CAAA;AAEV,MAAM,WAAW,UAAU,CACzB,YAAY,SAAS,WAAW,GAAG,WAAW,EAC9C,KAAK,SAAS,SAAS,CAAC,YAAY,CAAC,GAAG,SAAS,CAAC,YAAY,CAAC,CAC/D,SAAQ,IAAI,CAAC,gBAAgB,EAAE,OAAO,GAAG,MAAM,CAAC;IAChD;;OAEG;IACH,IAAI,EAAE,KAAK,CAAA;IACX;;OAEG;IACH,KAAK,CAAC,EAAE,MAAM,CAAA;IACd;;OAEG;IACH,SAAS,CAAC,EAAE,OAAO,CAAA;IACnB;;OAEG;IACH,IAAI,CAAC,EAAE,MAAM,CAAA;IACb;;OAEG;IACH,KAAK,CAAC,EAAE,IAAI,CACV,eAAe,CAAC,YAAY,EAAE,KAAK,CAAC,EACpC,eAAe,GAAG,aAAa,GAAG,YAAY,GAAG,UAAU,CAC5D,CAAA;IACD;;OAEG;IACH,OAAO,CAAC,EAAE,MAAM,EAAE,CAAA;IAClB;;;;;;;;;;;;;;;;OAgBG;IACH,IAAI,CAAC,EAAE,UAAU,CAAA;IACjB;;OAEG;IACH,WAAW,CAAC,EAAE,MAAM,CAAA;CACrB;AAqBD,eAAO,MAAM,SAAS,EAAE,KAAK,CAAC,EAAE,CAAC,UAAU,CAwB1C,CAAA;AAMD,eAAO,MAAM,KAAK;;;;MAkBb,MAAM,YAAY,CAAA;AA6DvB,eAAO,MAAM,mBAAmB,mBAAoB,GAAG,qFAqBtD,CAAA;AAED,eAAO,MAAM,qBAAqB,mBAAoB,GAAG,qFAgBxD,CAAA;AAED,MAAM,WAAW,wBAAwB;IACvC,YAAY,CAAC,EAAE,OAAO,CAAA;IACtB,SAAS,CAAC,EAAE,OAAO,CAAA;IACnB,SAAS,CAAC,EAAE,KAAK,CAAC,EAAE,CAAC,GAAG,CAAC,CAAA;CAC1B;AAED;;;;;;;GAOG;AACH,eAAO,MAAM,iBAAiB,SACtB,MAAM,aACD,MAAM,EAAE,CAAC,GAAG,CAAC,YACd,wBAAwB,qJAqBnC,CAAA;AAED,eAAO,MAAM,UAAU,kJAKtB,CAAA;AACD,eAAO,MAAM,gBAAgB,kJAE3B,CAAA;AACF,eAAO,MAAM,kBAAkB,kJAA+C,CAAA;AAC9E,eAAO,MAAM,aAAa,kJAA0C,CAAA;AACpE,eAAO,MAAM,WAAW,kJAQvB,CAAA;AACD,eAAO,MAAM,WAAW,kJAEtB,CAAA;AACF,eAAO,MAAM,aAAa,kJAczB,CAAA;AACD,eAAO,MAAM,UAAU,kJAErB,CAAA;AACF,eAAO,MAAM,QAAQ,kJAEnB,CAAA;AACF,eAAO,MAAM,iBAAiB,kJAI7B,CAAA"}
package/dist/index.js CHANGED
@@ -1,2 +1,2 @@
1
- var e=require("react"),r=require("@chakra-ui/utils"),t=require("react-hook-form"),n=require("@chakra-ui/react"),a=require("@saas-ui/number-input"),l=require("@saas-ui/password-input"),i=require("@saas-ui/radio"),o=require("@saas-ui/pin-input"),s=require("@saas-ui/select"),u=require("@chakra-ui/system"),d=require("@chakra-ui/icons"),m=require("@saas-ui/button"),c=require("@chakra-ui/react-utils"),p=require("@saas-ui/stepper"),f=require("@saas-ui/input-right-button");function v(e){if(e&&e.__esModule)return e;var r=Object.create(null);return e&&Object.keys(e).forEach(function(t){if("default"!==t){var n=Object.getOwnPropertyDescriptor(e,t);Object.defineProperty(r,t,n.get?n:{enumerable:!0,get:function(){return e[t]}})}}),r.default=e,r}var x=/*#__PURE__*/v(e);function h(){return h=Object.assign?Object.assign.bind():function(e){for(var r=1;r<arguments.length;r++){var t=arguments[r];for(var n in t)Object.prototype.hasOwnProperty.call(t,n)&&(e[n]=t[n])}return e},h.apply(this,arguments)}function F(e,r){if(null==e)return{};var t,n,a={},l=Object.keys(e);for(n=0;n<l.length;n++)r.indexOf(t=l[n])>=0||(a[t]=e[t]);return a}var b=["name","label","placeholder"],y=function(e){var r=e.name,t=e.label,a=F(e,b);/*#__PURE__*/return x.createElement(n.FormControl,a,t?/*#__PURE__*/x.createElement(n.FormLabel,{htmlFor:r},t):null,/*#__PURE__*/x.createElement(n.Text,{fontSize:"md"},/*#__PURE__*/x.createElement(E,{name:r})))};r.__DEV__&&(y.displayName="DisplayField");var E=function(e){var r=e.name;return(0,t.useFormContext().getValues)(r)||null};r.__DEV__&&(E.displayName="FormValue");var _=["name","label","help","variant","hideLabel","children"],g=["id","name","label","help","isDisabled","isInvalid","isReadOnly","isRequired","rules","variant"],C=["name","rules"],S=["ref"],N=["name","rules"],R=["ref"],V=["label"],w=["label"],D={},A=function(e){var r=e.name,a=e.label,l=e.help,i=e.variant,o=e.hideLabel,s=e.children,u=F(e,_),d=function(e,r){return t.get(r.errors,e)}(r,t.useFormContext().formState);/*#__PURE__*/return x.createElement(n.FormControl,h({variant:i},u,{isInvalid:!!d}),a&&!o?/*#__PURE__*/x.createElement(n.FormLabel,{variant:i},a):null,/*#__PURE__*/x.createElement(n.Box,null,s,!l||null!=d&&d.message?null:/*#__PURE__*/x.createElement(n.FormHelperText,null,l),(null==d?void 0:d.message)&&/*#__PURE__*/x.createElement(n.FormErrorMessage,null,null==d?void 0:d.message)))};r.__DEV__&&(A.displayName="BaseField");var k=n.forwardRef(function(e,r){var t=e.type;/*#__PURE__*/return x.createElement(D[void 0===t?"text":t]||D.text,h({ref:r},e))}),I=function(e){return n.forwardRef(function(r,a){var l=r.name,i=r.rules,o=F(r,C),s=t.useFormContext();/*#__PURE__*/return x.createElement(t.Controller,{name:l,control:s.control,rules:i,render:function(r){var t=r.field,l=t.ref,i=F(t,S);/*#__PURE__*/return x.createElement(e,h({},i,o,{ref:n.useMergeRefs(a,l)}))}})})},L=function(e){return n.forwardRef(function(r,a){var l=r.name,i=r.rules,o=F(r,N),s=(0,t.useFormContext().register)(l,i),u=s.ref,d=F(s,R);/*#__PURE__*/return x.createElement(e,h({},d,o,{ref:n.useMergeRefs(a,u)}))})},P=function(e,r,t){var a=function(e,r){var t=r.displayName,a=r.hideLabel,l=r.BaseField,i=n.forwardRef(function(r,t){var n=r.id,i=r.name,o=r.label,s=r.help,u=r.isDisabled,d=r.isInvalid,m=r.isReadOnly,c=r.isRequired,p=r.rules,f=r.variant,v=F(r,g),b=h({required:c},p);/*#__PURE__*/return x.createElement(l,{id:n,name:i,label:o,help:s,hideLabel:a,isDisabled:u,isInvalid:d,isReadOnly:m,isRequired:c,variant:f},/*#__PURE__*/x.createElement(e,h({ref:t,id:n,name:i,label:o,rules:b},v)))});return i.displayName=t,i}(null!=t&&t.isControlled?I(r):L(r),{displayName:e.split("-").map(function(e){return e.charAt(0).toUpperCase()+e.slice(1)}).join("")+"Field",hideLabel:null==t?void 0:t.hideLabel,BaseField:(null==t?void 0:t.BaseField)||A});return D[e]=a,a},B=P("text",n.Input),O=P("number",a.NumberInput,{isControlled:!0}),j=P("password",l.PasswordInput),q=P("textarea",n.Textarea),M=P("switch",n.forwardRef(function(e,r){var t=e.label,a=F(e,V);/*#__PURE__*/return x.createElement(n.Switch,h({ref:r},a),t)}),{isControlled:!0,hideLabel:!0}),U=P("select",s.Select,{isControlled:!0}),T=P("checkbox",n.forwardRef(function(e,r){var t=e.label,a=F(e,w);/*#__PURE__*/return x.createElement(n.Checkbox,h({ref:r},a),t)}),{hideLabel:!0}),H=P("radio",i.RadioInput,{isControlled:!0}),G=P("pin",o.PinInput,{isControlled:!0}),z=P("native-select",s.NativeSelect,{isControlled:!0}),W=function(e){return e&&Object.entries(e).map(function(e){return h({},e[1],{name:e[0]})})},J=function(e){return{getFields:function(){return W(e)},getNestedFields:function(t){var n,a=r.get(e,t);return a?"object"===(null==(n=a.items)?void 0:n.type)?W(a.items.properties):"object"===a.type?W(a.properties):[a.items]:[]}}},K=["mode","resolver","reValidateMode","shouldFocusError","shouldUnregister","shouldUseNativeValidation","criteriaMode","delayError","schema","defaultValues","onSubmit","onError","formRef","children"],Q=n.forwardRef(function(e,a){var l=e.mode,i=void 0===l?"all":l,o=e.resolver,s=e.reValidateMode,u=e.shouldFocusError,d=e.shouldUnregister,m=e.shouldUseNativeValidation,c=e.criteriaMode,p=e.delayError,f=e.schema,v=e.defaultValues,b=e.onSubmit,y=e.onError,E=e.formRef,_=e.children,g=F(e,K),C={mode:i,resolver:o,defaultValues:v,reValidateMode:s,shouldFocusError:u,shouldUnregister:d,shouldUseNativeValidation:m,criteriaMode:c,delayError:p};f&&!o&&(C.resolver=null==Q.getResolver?void 0:Q.getResolver(f));var S=t.useForm(C),N=S.handleSubmit;return x.useImperativeHandle(a,function(){return S},[a,S]),/*#__PURE__*/x.createElement(t.FormProvider,S,/*#__PURE__*/x.createElement(n.chakra.form,h({ref:E,onSubmit:N(b,y)},g,{className:r.cx("saas-form",e.className)}),_))});Q.getFieldResolver=J,r.__DEV__&&(Q.displayName="Form");var X=["children"],Y=function(e){/*#__PURE__*/return x.createElement(n.chakra.div,null,e.children)};r.__DEV__&&(Y.displayName="FormLayoutItem");var Z=function(e){var t,a,l,i=e.children,o=F(e,X),s=h({},null!=(t=null==(a=n.useTheme().components)||null==(l=a.FormLayout)?void 0:l.defaultProps)?t:{spacing:4},o);/*#__PURE__*/return x.createElement(n.SimpleGrid,h({},s,{className:r.cx("saas-form__layout",o.className)}),x.Children.map(i,function(e){return x.isValidElement(e)?/*#__PURE__*/x.createElement(Y,null,e):e}))};r.__DEV__&&(Z.displayName="FormLayout");var $=function(e,r){return x.Children.map(r,function(r){return x.isValidElement(r)&&r.props.name?x.cloneElement(r,h({},r.props,{name:e+"."+r.props.name})):r})},ee=c.createContext({name:"ArrayFieldContext"}),re=ee[0],te=ee[1],ne=c.createContext({name:"ArrayFieldRowContext"}),ae=ne[0],le=ne[1],ie=function(e){var r=e.name,n=e.defaultValue,a=void 0===n?{}:n,l=e.keyName,i=e.min,o=e.max,s=t.useFormContext();return h({},t.useFieldArray({control:s.control,name:r,keyName:l}),{name:r,defaultValue:a,min:i,max:o})},oe=function(e){var r=e.index,n=t.useFormContext().clearErrors,a=te(),l=a.name,i=a.remove,o=a.fields;return x.useEffect(function(){n(l)},[]),{index:r,isFirst:0===r,isLast:r===o.length-1,name:l+"."+r,remove:x.useCallback(function(){n(l),i(r)},[r])}},se=function(){var e=le(),r=e.isFirst,t=e.remove,n=te(),a=n.min;return{onClick:function(){return t()},isDisabled:r&&!!(a&&n.fields.length<=a)}},ue=function(){var e=te(),r=e.append,t=e.defaultValue,n=e.max;return{onClick:function(){return r(t,{shouldFocus:!1})},isDisabled:!!(n&&e.fields.length>=n)}},de=["children","columns","spacing"],me=["children"],ce=["name","defaultValue","keyName","min","max","children"],pe=function(e){/*#__PURE__*/return x.createElement(ve,{index:e.index},/*#__PURE__*/x.createElement(fe,{columns:e.columns,spacing:e.spacing},e.children),/*#__PURE__*/x.createElement(xe,null))};r.__DEV__&&(pe.displayName="ArrayFieldRow");var fe=function(e){var r=e.children,t=e.columns,n=e.spacing,a=F(e,de),l=le().name;/*#__PURE__*/return x.createElement(Z,h({flex:"1",columns:t,gridGap:n,mr:"2"},a),$(l,r))};r.__DEV__&&(fe.displayName="ArrayFieldRowFields");var ve=function(e){var r=e.children,t=oe({index:e.index});/*#__PURE__*/return x.createElement(ae,{value:t},/*#__PURE__*/x.createElement(u.chakra.div,{__css:{display:"flex",flexDirection:"row",alignItems:"flex-end",width:"100%",mb:4}},r))};r.__DEV__&&(ve.displayName="ArrayFieldRowContainer");var xe=function(e){/*#__PURE__*/return x.createElement(m.IconButton,h({icon:/*#__PURE__*/x.createElement(d.MinusIcon,null),"aria-label":"Remove row"},se(),e))};r.__DEV__&&(xe.displayName="ArrayFieldRemoveButton");var he=function(e){/*#__PURE__*/return x.createElement(m.IconButton,h({icon:/*#__PURE__*/x.createElement(d.AddIcon,null),"aria-label":"Add row",float:"right"},ue(),e))};r.__DEV__&&(he.displayName="ArrayFieldAddButton");var Fe=x.forwardRef(function(e,r){var t=e.children,n=F(e,me);/*#__PURE__*/return x.createElement(ye,h({ref:r},n),/*#__PURE__*/x.createElement(be,null,function(e){/*#__PURE__*/return x.createElement(x.Fragment,null,e.map(function(e,r){/*#__PURE__*/return x.createElement(pe,{key:e.id,index:r},t)}))}),/*#__PURE__*/x.createElement(he,null))});r.__DEV__&&(Fe.displayName="ArrayField");var be=function(e){return(0,e.children)(te().fields)};r.__DEV__&&(be.displayName="ArrayFieldRows");var ye=x.forwardRef(function(e,r){var t=e.name,n=e.defaultValue,a=e.keyName,l=e.min,i=e.max,o=e.children,s=F(e,ce),u=ie({name:t,defaultValue:n,keyName:a,min:l,max:i});return x.useImperativeHandle(r,function(){return u},[r,u]),/*#__PURE__*/x.createElement(re,{value:u},/*#__PURE__*/x.createElement(A,h({name:t},s),o))});r.__DEV__&&(ye.displayName="ArrayFieldContainer");var Ee=["name","label","hideLabel","children","columns","spacing"],_e=function(e){var r=n.useStyles();/*#__PURE__*/return x.createElement(n.FormLabel,h({as:"legend",sx:r.legend},e))},ge=function(e){var r=e.name,t=e.label,a=e.hideLabel,l=e.children,i=e.columns,o=e.spacing,s=F(e,Ee);/*#__PURE__*/return x.createElement(n.FormControl,h({name:r,as:"fieldset"},s),/*#__PURE__*/x.createElement(_e,{display:a?"none":"block"},t),/*#__PURE__*/x.createElement(Z,{columns:i,gridGap:o},$(r,l)))};r.__DEV__&&(ge.displayName="ObjectField");var Ce=["name","type"],Se=["schema","fieldResolver"],Ne=["name","type","defaultValue"],Re=function(e,r){var t;return null==(t=e.getNestedFields(r))?void 0:t.map(function(e,r){var t=e.name,n=e.type,a=F(e,Ce);/*#__PURE__*/return x.createElement(k,h({key:t||r,name:t,type:n},a))})},Ve=function(e){var r=e.schema,t=e.fieldResolver,n=F(e,Se),a=x.useMemo(function(){return t||Q.getFieldResolver(r)},[r,t]);/*#__PURE__*/return x.createElement(Z,n,a.getFields().map(function(e){var r=e.name,t=e.type,n=F(e,Ne);return"array"===t?/*#__PURE__*/x.createElement(Fe,h({key:r,name:r},n),Re(a,r)):"object"===t?/*#__PURE__*/x.createElement(ge,h({key:r,name:r},n),Re(a,r)):/*#__PURE__*/x.createElement(k,h({key:r,name:r,type:t},n))}))};r.__DEV__&&(Ve.displayName="Fields");var we=["children","disableIfUntouched","disableIfInvalid"],De=u.forwardRef(function(e,r){var n=e.children,a=e.disableIfUntouched,l=e.disableIfInvalid,i=F(e,we),o=t.useFormContext().formState;/*#__PURE__*/return x.createElement(m.Button,h({type:"submit",isLoading:o.isSubmitting,isPrimary:!0,ref:r,isDisabled:a&&!o.isDirty||l&&!o.isValid},i),n)});De.defaultProps={label:"Submit",disableIfUntouched:!1,disableIfInvalid:!1},r.__DEV__&&(De.displayName="SubmitButton");var Ae=["schema","submitLabel","fieldResolver"],ke=n.forwardRef(function(e,r){var t=e.schema,n=e.submitLabel,a=void 0===n?"Submit":n,l=e.fieldResolver,i=F(e,Ae);/*#__PURE__*/return x.createElement(Q,h({},i,{schema:t,ref:r}),/*#__PURE__*/x.createElement(Z,null,/*#__PURE__*/x.createElement(Ve,{schema:t,fieldResolver:l}),a&&/*#__PURE__*/x.createElement(De,{label:a})))});r.__DEV__&&(ke.displayName="AutoForm");var Ie=function(e){var r=e.children,n=e.condition;return(void 0===n?function(e){return!!e}:n)(t.useWatch({name:e.name,defaultValue:e.defaultValue,disabled:e.isDisabled,exact:e.isExact}),t.useFormContext())?r:null};r.__DEV__&&(Ie.displayName="DisplayIf");var Le=c.createContext({name:"StepFormContext",errorMessage:"useStepFormContext: `context` is undefined. Seems you forgot to wrap step form components in `<StepForm />`"}),Pe=Le[0],Be=Le[1];function Oe(e){var r=p.useStepper(e),t=r.activeStep,n=r.isLastStep,a=r.nextStep,l=x.useState({}),i=l[0],o=l[1],s=x.useCallback(function(r){try{return n?Promise.resolve(null==e.onSubmit?void 0:e.onSubmit(r).then(function(){d(h({},i[t],{isCompleted:!0}))}).then(a)):(a(),Promise.resolve())}catch(e){return Promise.reject(e)}},[t,n]),u=x.useCallback(function(){var e=i[t];return{onSubmit:s,schema:null==e?void 0:e.schema,resolver:null==e?void 0:e.resolver}},[i,s,t]),d=x.useCallback(function(e){o(function(r){var t;return h({},r,((t={})[e.name]=e,t))})},[i]);return h({getFormProps:u,updateStep:d,steps:i},r)}function je(e){var r=e.name,t=e.schema,n=e.resolver,a=p.useStep({name:r}),l=Be(),i=l.steps,o=l.updateStep;return x.useEffect(function(){o({name:r,schema:t,resolver:n})},[r,t]),h({},a,i[r]||{name:r,schema:t})}var qe=["children"],Me=["getFormProps"],Ue=["name","schema","resolver","children","className"],Te=["label","submitLabel"],He=x.forwardRef(function(e,t){var n=e.children,a=F(e,qe),l=Oe(e),i=l.getFormProps,o=F(l,Me),s=x.useMemo(function(){return o},[o]);/*#__PURE__*/return x.createElement(p.StepperProvider,{value:s},/*#__PURE__*/x.createElement(Pe,{value:s},/*#__PURE__*/x.createElement(Q,h({ref:t},a,i()),r.runIfFn(n,l))))}),Ge=function(e){var t=e.name,n=e.schema,a=e.resolver,l=e.children,i=e.className,o=F(e,Ue);return je({name:t,schema:n,resolver:a}).isActive?/*#__PURE__*/x.createElement(u.chakra.div,h({},o,{className:r.cx("saas-form__step",i)}),l):null};r.__DEV__&&(Ge.displayName="FormStep");var ze=function(e){var t=p.useStepperContext(),n=t.prevStep;/*#__PURE__*/return x.createElement(m.Button,h({isDisabled:t.isFirstStep||t.isCompleted,label:"Back"},e,{className:r.cx("saas-form__prev-button",e.className),onClick:r.callAllHandlers(e.onClick,n)}))};r.__DEV__&&(ze.displayName="PrevButton");var We=function(e){var t=e.label,n=void 0===t?"Next":t,a=e.submitLabel,l=void 0===a?"Complete":a,i=F(e,Te),o=p.useStepperContext(),s=o.isCompleted;/*#__PURE__*/return x.createElement(De,h({isDisabled:s,label:o.isLastStep||s?l:n},i,{className:r.cx("saas-form__next-button",e.className)}))};r.__DEV__&&(We.displayName="NextButton"),exports.ArrayField=Fe,exports.ArrayFieldAddButton=he,exports.ArrayFieldContainer=ye,exports.ArrayFieldProvider=re,exports.ArrayFieldRemoveButton=xe,exports.ArrayFieldRow=pe,exports.ArrayFieldRowContainer=ve,exports.ArrayFieldRowFields=fe,exports.ArrayFieldRowProvider=ae,exports.ArrayFieldRows=be,exports.AutoForm=ke,exports.BaseField=A,exports.CheckboxField=T,exports.DisplayField=y,exports.DisplayIf=Ie,exports.Field=k,exports.Fields=Ve,exports.Form=Q,exports.FormLayout=Z,exports.FormLegend=_e,exports.FormStep=Ge,exports.FormStepper=function(e){var r=u.useMultiStyleConfig("Stepper",e),t=x.Children.map(e.children,function(e){if(x.isValidElement(e)&&(null==e?void 0:e.type)===Ge){var r=je(e.props);/*#__PURE__*/return x.createElement(p.StepperStep,{name:e.props.name,title:e.props.title,isCompleted:r.isCompleted},e.props.children)}return e});/*#__PURE__*/return x.createElement(u.StylesProvider,{value:r},/*#__PURE__*/x.createElement(p.StepperSteps,h({mb:"4"},e),t))},exports.FormValue=E,exports.InputField=B,exports.NativeSelectField=z,exports.NextButton=We,exports.NumberInputField=O,exports.ObjectField=ge,exports.PasswordInputFIeld=j,exports.PinField=G,exports.PrevButton=ze,exports.RadioField=H,exports.SelectField=U,exports.StepForm=He,exports.StepFormProvider=Pe,exports.SubmitButton=De,exports.SwitchField=M,exports.TextareaField=q,exports.objectFieldResolver=J,exports.registerFieldType=P,exports.useArrayField=ie,exports.useArrayFieldAddButton=ue,exports.useArrayFieldContext=te,exports.useArrayFieldRemoveButton=se,exports.useArrayFieldRow=oe,exports.useArrayFieldRowContext=le,exports.useFormStep=je,exports.useStepForm=Oe,exports.useStepFormContext=Be,exports.withControlledInput=I,exports.withUncontrolledInput=L,Object.keys(f).forEach(function(e){"default"===e||exports.hasOwnProperty(e)||Object.defineProperty(exports,e,{enumerable:!0,get:function(){return f[e]}})});
1
+ var e=require("react"),r=require("@chakra-ui/utils"),t=require("react-hook-form"),n=require("@chakra-ui/react"),a=require("@saas-ui/number-input"),l=require("@saas-ui/password-input"),i=require("@saas-ui/radio"),o=require("@saas-ui/pin-input"),s=require("@saas-ui/select"),u=require("@chakra-ui/system"),d=require("@chakra-ui/icons"),m=require("@saas-ui/button"),c=require("@chakra-ui/react-utils"),p=require("@saas-ui/stepper"),f=require("@saas-ui/input-right-button");function v(e){if(e&&e.__esModule)return e;var r=Object.create(null);return e&&Object.keys(e).forEach(function(t){if("default"!==t){var n=Object.getOwnPropertyDescriptor(e,t);Object.defineProperty(r,t,n.get?n:{enumerable:!0,get:function(){return e[t]}})}}),r.default=e,r}var x=/*#__PURE__*/v(e);function h(){return h=Object.assign?Object.assign.bind():function(e){for(var r=1;r<arguments.length;r++){var t=arguments[r];for(var n in t)Object.prototype.hasOwnProperty.call(t,n)&&(e[n]=t[n])}return e},h.apply(this,arguments)}function F(e,r){if(null==e)return{};var t,n,a={},l=Object.keys(e);for(n=0;n<l.length;n++)r.indexOf(t=l[n])>=0||(a[t]=e[t]);return a}var y=["name","label","placeholder"],b=function(e){var r=e.name,t=e.label,a=F(e,y);/*#__PURE__*/return x.createElement(n.FormControl,a,t?/*#__PURE__*/x.createElement(n.FormLabel,{htmlFor:r},t):null,/*#__PURE__*/x.createElement(n.Text,{fontSize:"md"},/*#__PURE__*/x.createElement(E,{name:r})))};r.__DEV__&&(b.displayName="DisplayField");var E=function(e){var r=e.name;return(0,t.useFormContext().getValues)(r)||null};r.__DEV__&&(E.displayName="FormValue");var _=["name","label","help","variant","hideLabel","children"],C=["id","name","label","help","isDisabled","isInvalid","isReadOnly","isRequired","rules","variant"],g=["name","rules"],S=["ref"],N=["name","rules"],R=["ref"],V=["type"],w=["type"],D=["label","type"],k={},A=function(e){var r=e.name,a=e.label,l=e.help,i=e.variant,o=e.hideLabel,s=e.children,u=F(e,_),d=function(e,r){return t.get(r.errors,e)}(r,t.useFormContext().formState);/*#__PURE__*/return x.createElement(n.FormControl,h({variant:i},u,{isInvalid:!!d}),a&&!o?/*#__PURE__*/x.createElement(n.FormLabel,{variant:i},a):null,/*#__PURE__*/x.createElement(n.Box,null,s,!l||null!=d&&d.message?null:/*#__PURE__*/x.createElement(n.FormHelperText,null,l),(null==d?void 0:d.message)&&/*#__PURE__*/x.createElement(n.FormErrorMessage,null,null==d?void 0:d.message)))};r.__DEV__&&(A.displayName="BaseField");var I=n.forwardRef(function(e,r){var t=e.type;/*#__PURE__*/return x.createElement(k[void 0===t?"text":t]||k.text,h({ref:r},e))}),L=function(e){return n.forwardRef(function(r,a){var l=r.name,i=r.rules,o=F(r,g),s=t.useFormContext();/*#__PURE__*/return x.createElement(t.Controller,{name:l,control:s.control,rules:i,render:function(r){var t=r.field,l=t.ref,i=F(t,S);/*#__PURE__*/return x.createElement(e,h({},i,o,{ref:n.useMergeRefs(a,l)}))}})})},P=function(e){return n.forwardRef(function(r,a){var l=r.name,i=r.rules,o=F(r,N),s=(0,t.useFormContext().register)(l,i),u=s.ref,d=F(s,R);/*#__PURE__*/return x.createElement(e,h({},d,o,{ref:n.useMergeRefs(a,u)}))})},B=function(e,r,t){var a=function(e,r){var t=r.displayName,a=r.hideLabel,l=r.BaseField,i=n.forwardRef(function(r,t){var n=r.id,i=r.name,o=r.label,s=r.help,u=r.isDisabled,d=r.isInvalid,m=r.isReadOnly,c=r.isRequired,p=r.rules,f=r.variant,v=F(r,C),y=h({required:c},p);/*#__PURE__*/return x.createElement(l,{id:n,name:i,label:o,help:s,hideLabel:a,isDisabled:u,isInvalid:d,isReadOnly:m,isRequired:c,variant:f},/*#__PURE__*/x.createElement(e,h({ref:t,id:n,name:i,label:a?o:void 0,rules:y},v)))});return i.displayName=t,i}(null!=t&&t.isControlled?L(r):P(r),{displayName:e.split("-").map(function(e){return e.charAt(0).toUpperCase()+e.slice(1)}).join("")+"Field",hideLabel:null==t?void 0:t.hideLabel,BaseField:(null==t?void 0:t.BaseField)||A});return k[e]=a,a},O=B("text",n.forwardRef(function(e,r){var t=e.type,a=void 0===t?"text":t,l=F(e,V);/*#__PURE__*/return x.createElement(n.Input,h({type:a},l,{ref:r}))})),j=B("number",a.NumberInput,{isControlled:!0}),q=B("password",l.PasswordInput),M=B("textarea",n.Textarea),U=B("switch",n.forwardRef(function(e,r){var t=F(e,w);/*#__PURE__*/return x.createElement(n.Switch,h({},t,{ref:r}))}),{isControlled:!0}),T=B("select",s.Select,{isControlled:!0}),H=B("checkbox",n.forwardRef(function(e,r){var t=e.label,a=F(e,D);/*#__PURE__*/return x.createElement(n.Checkbox,h({ref:r},a),t)}),{hideLabel:!0}),G=B("radio",i.RadioInput,{isControlled:!0}),z=B("pin",o.PinInput,{isControlled:!0}),W=B("native-select",s.NativeSelect,{isControlled:!0}),J=["items"],K=function(e){return e&&Object.entries(e).map(function(e){var r=e[0];return h({},F(e[1],J),{name:r})})},Q=function(e){return{getFields:function(){return K(e)},getNestedFields:function(t){var n,a=r.get(e,t);return a?"object"===(null==(n=a.items)?void 0:n.type)?K(a.items.properties):"object"===a.type?K(a.properties):[a.items]:[]}}},X=["mode","resolver","reValidateMode","shouldFocusError","shouldUnregister","shouldUseNativeValidation","criteriaMode","delayError","schema","defaultValues","onSubmit","onError","formRef","children"],Y=n.forwardRef(function(e,a){var l=e.mode,i=void 0===l?"all":l,o=e.resolver,s=e.reValidateMode,u=e.shouldFocusError,d=e.shouldUnregister,m=e.shouldUseNativeValidation,c=e.criteriaMode,p=e.delayError,f=e.schema,v=e.defaultValues,y=e.onSubmit,b=e.onError,E=e.formRef,_=e.children,C=F(e,X),g={mode:i,resolver:o,defaultValues:v,reValidateMode:s,shouldFocusError:u,shouldUnregister:d,shouldUseNativeValidation:m,criteriaMode:c,delayError:p};f&&!o&&(g.resolver=null==Y.getResolver?void 0:Y.getResolver(f));var S=t.useForm(g),N=S.handleSubmit;return x.useImperativeHandle(a,function(){return S},[a,S]),/*#__PURE__*/x.createElement(t.FormProvider,S,/*#__PURE__*/x.createElement(n.chakra.form,h({ref:E,onSubmit:N(y,b)},C,{className:r.cx("saas-form",e.className)}),_))});Y.getFieldResolver=Q,r.__DEV__&&(Y.displayName="Form");var Z=["children"],$=function(e){/*#__PURE__*/return x.createElement(n.chakra.div,null,e.children)};r.__DEV__&&($.displayName="FormLayoutItem");var ee=function(e){var t,a,l,i=e.children,o=F(e,Z),s=h({},null!=(t=null==(a=n.useTheme().components)||null==(l=a.FormLayout)?void 0:l.defaultProps)?t:{spacing:4},o);/*#__PURE__*/return x.createElement(n.SimpleGrid,h({},s,{className:r.cx("saas-form__layout",o.className)}),x.Children.map(i,function(e){return x.isValidElement(e)?/*#__PURE__*/x.createElement($,null,e):e}))};r.__DEV__&&(ee.displayName="FormLayout");var re=function(e,r){return x.Children.map(r,function(r){return x.isValidElement(r)&&r.props.name?x.cloneElement(r,h({},r.props,{name:e+"."+r.props.name})):r})},te=c.createContext({name:"ArrayFieldContext"}),ne=te[0],ae=te[1],le=c.createContext({name:"ArrayFieldRowContext"}),ie=le[0],oe=le[1],se=function(e){var r=e.name,n=e.defaultValue,a=void 0===n?{}:n,l=e.keyName,i=e.min,o=e.max,s=t.useFormContext();return h({},t.useFieldArray({control:s.control,name:r,keyName:l}),{name:r,defaultValue:a,min:i,max:o})},ue=function(e){var r=e.index,n=t.useFormContext().clearErrors,a=ae(),l=a.name,i=a.remove,o=a.fields;return x.useEffect(function(){n(l)},[]),{index:r,isFirst:0===r,isLast:r===o.length-1,name:l+"."+r,remove:x.useCallback(function(){n(l),i(r)},[r])}},de=function(){var e=oe(),r=e.isFirst,t=e.remove,n=ae(),a=n.min;return{onClick:function(){return t()},isDisabled:r&&!!(a&&n.fields.length<=a)}},me=function(){var e=ae(),r=e.append,t=e.defaultValue,n=e.max;return{onClick:function(){return r(t,{shouldFocus:!1})},isDisabled:!!(n&&e.fields.length>=n)}},ce=["children","columns","spacing"],pe=["children"],fe=["name","defaultValue","keyName","min","max","children"],ve=function(e){/*#__PURE__*/return x.createElement(he,{index:e.index},/*#__PURE__*/x.createElement(xe,{columns:e.columns,spacing:e.spacing},e.children),/*#__PURE__*/x.createElement(Fe,null))};r.__DEV__&&(ve.displayName="ArrayFieldRow");var xe=function(e){var r=e.children,t=e.columns,n=e.spacing,a=F(e,ce),l=oe().name;/*#__PURE__*/return x.createElement(ee,h({flex:"1",columns:t,gridGap:n,mr:"2"},a),re(l,r))};r.__DEV__&&(xe.displayName="ArrayFieldRowFields");var he=function(e){var r=e.children,t=ue({index:e.index});/*#__PURE__*/return x.createElement(ie,{value:t},/*#__PURE__*/x.createElement(u.chakra.div,{__css:{display:"flex",flexDirection:"row",alignItems:"flex-end",width:"100%",mb:4}},r))};r.__DEV__&&(he.displayName="ArrayFieldRowContainer");var Fe=function(e){/*#__PURE__*/return x.createElement(m.IconButton,h({icon:/*#__PURE__*/x.createElement(d.MinusIcon,null),"aria-label":"Remove row"},de(),e))};r.__DEV__&&(Fe.displayName="ArrayFieldRemoveButton");var ye=function(e){/*#__PURE__*/return x.createElement(m.IconButton,h({icon:/*#__PURE__*/x.createElement(d.AddIcon,null),"aria-label":"Add row",float:"right"},me(),e))};r.__DEV__&&(ye.displayName="ArrayFieldAddButton");var be=x.forwardRef(function(e,r){var t=e.children,n=F(e,pe);/*#__PURE__*/return x.createElement(_e,h({ref:r},n),/*#__PURE__*/x.createElement(Ee,null,function(e){/*#__PURE__*/return x.createElement(x.Fragment,null,e.map(function(e,r){/*#__PURE__*/return x.createElement(ve,{key:e.id,index:r},t)}))}),/*#__PURE__*/x.createElement(ye,null))});r.__DEV__&&(be.displayName="ArrayField");var Ee=function(e){return(0,e.children)(ae().fields)};r.__DEV__&&(Ee.displayName="ArrayFieldRows");var _e=x.forwardRef(function(e,r){var t=e.name,n=e.defaultValue,a=e.keyName,l=e.min,i=e.max,o=e.children,s=F(e,fe),u=se({name:t,defaultValue:n,keyName:a,min:l,max:i});return x.useImperativeHandle(r,function(){return u},[r,u]),/*#__PURE__*/x.createElement(ne,{value:u},/*#__PURE__*/x.createElement(A,h({name:t},s),o))});r.__DEV__&&(_e.displayName="ArrayFieldContainer");var Ce=["name","label","hideLabel","children","columns","spacing"],ge=function(e){var r=n.useStyleConfig("FormLegend");/*#__PURE__*/return x.createElement(n.FormLabel,h({as:"legend",sx:r},e))},Se=function(e){var r=e.name,t=e.label,a=e.hideLabel,l=e.children,i=e.columns,o=e.spacing,s=F(e,Ce);/*#__PURE__*/return x.createElement(n.FormControl,h({name:r,as:"fieldset"},s),/*#__PURE__*/x.createElement(ge,{display:a?"none":"block"},t),/*#__PURE__*/x.createElement(ee,{columns:i,gridGap:o},re(r,l)))};r.__DEV__&&(Se.displayName="ObjectField");var Ne=["name","type"],Re=["schema","fieldResolver"],Ve=["name","type","defaultValue"],we=function(e,r){var t;return null==(t=e.getNestedFields(r))?void 0:t.map(function(e,r){var t=e.name,n=e.type,a=F(e,Ne);/*#__PURE__*/return x.createElement(I,h({key:t||r,name:t,type:n},a))})},De=function(e){var r=e.schema,t=e.fieldResolver,n=F(e,Re),a=x.useMemo(function(){return t||Y.getFieldResolver(r)},[r,t]);/*#__PURE__*/return x.createElement(ee,n,a.getFields().map(function(e){var r=e.name,t=e.type,n=F(e,Ve);return"array"===t?/*#__PURE__*/x.createElement(be,h({key:r,name:r},n),we(a,r)):"object"===t?/*#__PURE__*/x.createElement(Se,h({key:r,name:r},n),we(a,r)):/*#__PURE__*/x.createElement(I,h({key:r,name:r,type:t},n))}))};r.__DEV__&&(De.displayName="Fields");var ke=["children","disableIfUntouched","disableIfInvalid"],Ae=u.forwardRef(function(e,r){var n=e.children,a=e.disableIfUntouched,l=e.disableIfInvalid,i=F(e,ke),o=t.useFormContext().formState;/*#__PURE__*/return x.createElement(m.Button,h({type:"submit",isLoading:o.isSubmitting,isPrimary:!0,ref:r,isDisabled:a&&!o.isDirty||l&&!o.isValid},i),n)});Ae.defaultProps={label:"Submit",disableIfUntouched:!1,disableIfInvalid:!1},r.__DEV__&&(Ae.displayName="SubmitButton");var Ie=["schema","submitLabel","fieldResolver","children"],Le=n.forwardRef(function(e,r){var t=e.schema,n=e.submitLabel,a=void 0===n?"Submit":n,l=e.fieldResolver,i=e.children,o=F(e,Ie);/*#__PURE__*/return x.createElement(Y,h({},o,{schema:t,ref:r}),/*#__PURE__*/x.createElement(ee,null,/*#__PURE__*/x.createElement(De,{schema:t,fieldResolver:l}),a&&/*#__PURE__*/x.createElement(Ae,{label:a}),i))});r.__DEV__&&(Le.displayName="AutoForm");var Pe=function(e){var r=e.children,n=e.condition;return(void 0===n?function(e){return!!e}:n)(t.useWatch({name:e.name,defaultValue:e.defaultValue,disabled:e.isDisabled,exact:e.isExact}),t.useFormContext())?r:null};r.__DEV__&&(Pe.displayName="DisplayIf");var Be=["onChange"],Oe=c.createContext({name:"StepFormContext",errorMessage:"useStepFormContext: `context` is undefined. Seems you forgot to wrap step form components in `<StepForm />`"}),je=Oe[0],qe=Oe[1];function Me(e){var r=F(e,Be),t=p.useStepper(r),n=t.activeStep,a=t.isLastStep,l=t.nextStep,i=x.useState({}),o=i[0],s=i[1],u=x.useCallback(function(r){try{return a?Promise.resolve(null==e.onSubmit?void 0:e.onSubmit(r).then(function(){m(h({},o[n],{isCompleted:!0}))}).then(l)):(l(),Promise.resolve())}catch(e){return Promise.reject(e)}},[n,a]),d=x.useCallback(function(){var e=o[n];return{onSubmit:u,schema:null==e?void 0:e.schema,resolver:null==e?void 0:e.resolver}},[o,u,n]),m=x.useCallback(function(e){s(function(r){var t;return h({},r,((t={})[e.name]=e,t))})},[o]);return h({getFormProps:d,updateStep:m,steps:o},t)}function Ue(e){var r=e.name,t=e.schema,n=e.resolver,a=p.useStep({name:r}),l=qe(),i=l.steps,o=l.updateStep;return x.useEffect(function(){o({name:r,schema:t,resolver:n})},[r,t]),h({},a,i[r]||{name:r,schema:t})}var Te=["children"],He=["getFormProps"],Ge=["name","schema","resolver","children","className"],ze=["label","submitLabel"],We=x.forwardRef(function(e,t){var n=e.children,a=F(e,Te),l=Me(e),i=l.getFormProps,o=F(l,He),s=x.useMemo(function(){return o},[o]);/*#__PURE__*/return x.createElement(p.StepperProvider,{value:s},/*#__PURE__*/x.createElement(je,{value:s},/*#__PURE__*/x.createElement(Y,h({ref:t},a,i()),r.runIfFn(n,l))))}),Je=function(e){var t=e.name,n=e.schema,a=e.resolver,l=e.children,i=e.className,o=F(e,Ge);return Ue({name:t,schema:n,resolver:a}).isActive?/*#__PURE__*/x.createElement(u.chakra.div,h({},o,{className:r.cx("saas-form__step",i)}),l):null};r.__DEV__&&(Je.displayName="FormStep");var Ke=function(e){var t=p.useStepperContext(),n=t.prevStep;/*#__PURE__*/return x.createElement(m.Button,h({isDisabled:t.isFirstStep||t.isCompleted,label:"Back"},e,{className:r.cx("saas-form__prev-button",e.className),onClick:r.callAllHandlers(e.onClick,n)}))};r.__DEV__&&(Ke.displayName="PrevButton");var Qe=function(e){var t=e.label,n=void 0===t?"Next":t,a=e.submitLabel,l=void 0===a?"Complete":a,i=F(e,ze),o=p.useStepperContext(),s=o.isCompleted;/*#__PURE__*/return x.createElement(Ae,h({isDisabled:s,label:o.isLastStep||s?l:n},i,{className:r.cx("saas-form__next-button",e.className)}))};r.__DEV__&&(Qe.displayName="NextButton"),exports.ArrayField=be,exports.ArrayFieldAddButton=ye,exports.ArrayFieldContainer=_e,exports.ArrayFieldProvider=ne,exports.ArrayFieldRemoveButton=Fe,exports.ArrayFieldRow=ve,exports.ArrayFieldRowContainer=he,exports.ArrayFieldRowFields=xe,exports.ArrayFieldRowProvider=ie,exports.ArrayFieldRows=Ee,exports.AutoForm=Le,exports.BaseField=A,exports.CheckboxField=H,exports.DisplayField=b,exports.DisplayIf=Pe,exports.Field=I,exports.Fields=De,exports.Form=Y,exports.FormLayout=ee,exports.FormLegend=ge,exports.FormStep=Je,exports.FormStepper=function(e){var r=p.useStepperContext(),t=r.activeIndex,n=r.setIndex,a=x.Children.map(e.children,function(e){if(x.isValidElement(e)&&(null==e?void 0:e.type)===Je){var r=Ue(e.props);/*#__PURE__*/return x.createElement(p.StepperStep,{name:e.props.name,title:e.props.title,isCompleted:r.isCompleted},e.props.children)}return e}),l=x.useCallback(function(e){n(e)},[]);/*#__PURE__*/return x.createElement(p.StepperContainer,{step:t,onChange:l},/*#__PURE__*/x.createElement(p.StepperSteps,h({mb:"4"},e),a))},exports.FormValue=E,exports.InputField=O,exports.NativeSelectField=W,exports.NextButton=Qe,exports.NumberInputField=j,exports.ObjectField=Se,exports.PasswordInputFIeld=q,exports.PinField=z,exports.PrevButton=Ke,exports.RadioField=G,exports.SelectField=T,exports.StepForm=We,exports.StepFormProvider=je,exports.SubmitButton=Ae,exports.SwitchField=U,exports.TextareaField=M,exports.objectFieldResolver=Q,exports.registerFieldType=B,exports.useArrayField=se,exports.useArrayFieldAddButton=me,exports.useArrayFieldContext=ae,exports.useArrayFieldRemoveButton=de,exports.useArrayFieldRow=ue,exports.useArrayFieldRowContext=oe,exports.useFormStep=Ue,exports.useStepForm=Me,exports.useStepFormContext=qe,exports.withControlledInput=L,exports.withUncontrolledInput=P,Object.keys(f).forEach(function(e){"default"===e||exports.hasOwnProperty(e)||Object.defineProperty(exports,e,{enumerable:!0,get:function(){return f[e]}})});
2
2
  //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../src/display-field.tsx","../src/field.tsx","../src/field-resolver.ts","../src/form.tsx","../src/layout.tsx","../src/utils.ts","../src/use-array-field.tsx","../src/array-field.tsx","../src/object-field.tsx","../src/fields.tsx","../src/submit-button.tsx","../src/auto-form.tsx","../src/display-if.tsx","../src/use-step-form.tsx","../src/step-form.tsx"],"sourcesContent":["import * as React from 'react'\nimport { __DEV__ } from '@chakra-ui/utils'\nimport { useFormContext } from 'react-hook-form'\n\nimport {\n Text,\n FormControl,\n FormControlProps,\n FormLabel,\n} from '@chakra-ui/react'\n\nimport { FieldProps } from './field'\n\nexport interface DisplayFieldProps\n extends FormControlProps,\n Omit<FieldProps, 'type' | 'label'> {}\n\nexport const DisplayField: React.FC<DisplayFieldProps> = ({\n name,\n label,\n placeholder,\n ...props\n}) => {\n return (\n <FormControl {...props}>\n {label ? <FormLabel htmlFor={name}>{label}</FormLabel> : null}\n <Text fontSize=\"md\">\n <FormValue name={name} />\n </Text>\n </FormControl>\n )\n}\n\nif (__DEV__) {\n DisplayField.displayName = 'DisplayField'\n}\n\nexport const FormValue: React.FC<{ name: string }> = ({ name }) => {\n const { getValues } = useFormContext()\n return getValues(name) || null\n}\n\nif (__DEV__) {\n FormValue.displayName = 'FormValue'\n}\n","import * as React from 'react'\nimport {\n useFormContext,\n FormState,\n Controller,\n get,\n RegisterOptions,\n FieldValues,\n FieldPath,\n} from 'react-hook-form'\n\nimport {\n forwardRef,\n Box,\n FormControl,\n FormControlProps,\n FormLabel,\n FormHelperText,\n FormErrorMessage,\n Input,\n Textarea,\n Checkbox,\n Switch,\n useMergeRefs,\n} from '@chakra-ui/react'\nimport { __DEV__ } from '@chakra-ui/utils'\n\nimport { NumberInput } from '@saas-ui/number-input'\nimport { PasswordInput } from '@saas-ui/password-input'\nimport { RadioInput } from '@saas-ui/radio'\nimport { PinInput } from '@saas-ui/pin-input'\nimport { Select, NativeSelect } from '@saas-ui/select'\nimport { FocusableElement } from '@chakra-ui/utils'\n\nexport interface Option {\n value: string\n label?: string\n [key: string]: unknown\n}\n\nexport type FieldRules = Pick<\n RegisterOptions,\n 'required' | 'min' | 'max' | 'maxLength' | 'minLength' | 'pattern'\n>\n\nexport type FieldTypes =\n | 'text'\n | 'number'\n | 'password'\n | 'textarea'\n | 'select'\n | 'native-select'\n | 'checkbox'\n | 'radio'\n | 'switch'\n | 'pin'\n | string\n\nexport interface FieldProps<\n TFieldValues extends FieldValues = FieldValues,\n TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>\n> extends Omit<FormControlProps, 'label' | 'type'> {\n /**\n * The field name\n */\n name: TName\n /**\n * The field label\n */\n label?: string\n /**\n * Hide the field label\n */\n hideLabel?: boolean\n /**\n * Field help text\n */\n help?: string\n /**\n * React hook form rules\n */\n rules?: Omit<\n RegisterOptions<TFieldValues, TName>,\n 'valueAsNumber' | 'valueAsDate' | 'setValueAs' | 'disabled'\n >\n /**\n * Options used for selects and radio fields\n */\n options?: Option[]\n /**\n * The field type\n * Build-in types:\n * - text\n * - number\n * - password\n * - textarea\n * - select\n * - native-select\n * - checkbox\n * - radio\n * - switch\n * - pin\n *\n * Will default to a text field if there is no matching type.\n * @default 'text'\n */\n type?: FieldTypes\n /**\n * The input placeholder\n */\n placeholder?: string\n}\n\nconst inputTypes: Record<FieldTypes, any> = {}\n\nconst defaultInputType = 'text'\n\nconst getInput = (type: string) => {\n return inputTypes[type] || inputTypes[defaultInputType]\n}\n\nconst getError = (name: string, formState: FormState<{ [x: string]: any }>) => {\n return get(formState.errors, name)\n}\n\nconst isTouched = (\n name: string,\n formState: FormState<{ [x: string]: any }>\n) => {\n return get(formState.touchedFields, name)\n}\n\nexport const BaseField: React.FC<FieldProps> = (props) => {\n const { name, label, help, variant, hideLabel, children, ...controlProps } =\n props\n\n const { formState } = useFormContext()\n\n const error = getError(name, formState)\n\n return (\n <FormControl variant={variant} {...controlProps} isInvalid={!!error}>\n {label && !hideLabel ? (\n <FormLabel variant={variant}>{label}</FormLabel>\n ) : null}\n <Box>\n {children}\n {help && !error?.message ? (\n <FormHelperText>{help}</FormHelperText>\n ) : null}\n {error?.message && (\n <FormErrorMessage>{error?.message}</FormErrorMessage>\n )}\n </Box>\n </FormControl>\n )\n}\n\nif (__DEV__) {\n BaseField.displayName = 'BaseField'\n}\n\nexport const Field = forwardRef(\n <TFieldValues extends FieldValues = FieldValues>(\n props: FieldProps<TFieldValues> & {\n [key: string]: unknown // Make sure attributes of custom components work. Need to change this to a global typedef at some point.\n },\n ref: React.ForwardedRef<FocusableElement>\n ) => {\n const { type = defaultInputType } = props\n const InputComponent = getInput(type)\n\n return <InputComponent ref={ref} {...props} />\n }\n) as <TFieldValues extends FieldValues>(\n props: FieldProps<TFieldValues> & {\n [key: string]: unknown\n } & {\n ref?: React.ForwardedRef<FocusableElement>\n }\n) => React.ReactElement\n\ninterface CreateFieldProps {\n displayName: string\n hideLabel?: boolean\n BaseField: React.FC<any>\n}\n\nconst createField = (\n InputComponent: React.FC<any>,\n { displayName, hideLabel, BaseField }: CreateFieldProps\n) => {\n const Field = forwardRef<FieldProps, typeof FormControl>((props, ref) => {\n const {\n id,\n name,\n label,\n help,\n isDisabled,\n isInvalid,\n isReadOnly,\n isRequired,\n rules,\n variant,\n ...inputProps\n } = props\n\n const inputRules = {\n required: isRequired,\n ...rules,\n }\n\n return (\n <BaseField\n id={id}\n name={name}\n label={label}\n help={help}\n hideLabel={hideLabel}\n isDisabled={isDisabled}\n isInvalid={isInvalid}\n isReadOnly={isReadOnly}\n isRequired={isRequired}\n variant={variant}\n >\n <InputComponent\n ref={ref}\n id={id}\n name={name}\n label={label}\n rules={inputRules}\n {...inputProps}\n />\n </BaseField>\n )\n })\n Field.displayName = displayName\n\n return Field\n}\n\nexport const withControlledInput = (InputComponent: any) => {\n return forwardRef<FieldProps, typeof InputComponent>(\n ({ name, rules, ...inputProps }, ref) => {\n const { control } = useFormContext()\n\n return (\n <Controller\n name={name}\n control={control}\n rules={rules}\n render={({ field: { ref: _ref, ...field } }) => (\n <InputComponent\n {...field}\n {...inputProps}\n ref={useMergeRefs(ref, _ref)}\n />\n )}\n />\n )\n }\n )\n}\n\nexport const withUncontrolledInput = (InputComponent: any) => {\n return forwardRef<FieldProps, typeof InputComponent>(\n ({ name, rules, ...inputProps }, ref) => {\n const { register } = useFormContext()\n\n const { ref: _ref, ...field } = register(name, rules)\n\n return (\n <InputComponent\n {...field}\n {...inputProps}\n ref={useMergeRefs(ref, _ref)}\n />\n )\n }\n )\n}\n\nexport interface RegisterFieldTypeOptions {\n isControlled?: boolean\n hideLabel?: boolean\n BaseField?: React.FC<any>\n}\n\n/**\n * Register a new field type\n * @param type The name for this field in kebab-case, eg `email` or `array-field`\n * @param component The React component\n * @param options\n * @param options.isControlled Set this to true if this is a controlled field.\n * @param options.hideLabel Hide the field label, for example for checkbox or switch field.\n */\nexport const registerFieldType = (\n type: string,\n component: React.FC<any>,\n options?: RegisterFieldTypeOptions\n) => {\n let InputComponent\n if (options?.isControlled) {\n InputComponent = withControlledInput(component)\n } else {\n InputComponent = withUncontrolledInput(component)\n }\n\n const Field = createField(InputComponent, {\n displayName: `${type\n .split('-')\n .map((part) => part.charAt(0).toUpperCase() + part.slice(1))\n .join('')}Field`,\n hideLabel: options?.hideLabel,\n BaseField: options?.BaseField || BaseField,\n })\n\n inputTypes[type] = Field\n\n return Field\n}\n\n// @todo Consider not registering all fields by default to lower the package size and computations.\n// Not all types may be required in a project.\nexport const InputField = registerFieldType('text', Input)\nexport const NumberInputField = registerFieldType('number', NumberInput, {\n isControlled: true,\n})\nexport const PasswordInputFIeld = registerFieldType('password', PasswordInput)\nexport const TextareaField = registerFieldType('textarea', Textarea)\nexport const SwitchField = registerFieldType(\n 'switch',\n forwardRef(({ label, ...props }: { label?: string }, ref) => {\n return (\n <Switch ref={ref} {...props}>\n {label}\n </Switch>\n )\n }),\n {\n isControlled: true,\n hideLabel: true,\n }\n)\nexport const SelectField = registerFieldType('select', Select, {\n isControlled: true,\n})\nexport const CheckboxField = registerFieldType(\n 'checkbox',\n forwardRef(({ label, ...props }: { label?: string }, ref) => {\n return (\n <Checkbox ref={ref} {...props}>\n {label}\n </Checkbox>\n )\n }),\n {\n hideLabel: true,\n }\n)\nexport const RadioField = registerFieldType('radio', RadioInput, {\n isControlled: true,\n})\nexport const PinField = registerFieldType('pin', PinInput, {\n isControlled: true,\n})\nexport const NativeSelectField = registerFieldType(\n 'native-select',\n NativeSelect,\n { isControlled: true }\n)\n","import { FieldProps } from './field'\n\nimport { get } from '@chakra-ui/utils'\n\nexport type FieldResolver = {\n getFields(): FieldProps[]\n getNestedFields(name: string): FieldProps[]\n}\n\ninterface SchemaField extends FieldProps {\n items?: SchemaField[]\n properties?: Record<string, SchemaField>\n}\n\nexport type ObjectSchema = Record<string, SchemaField>\n\nconst mapFields = (schema: ObjectSchema) =>\n schema &&\n Object.entries(schema).map(([name, field]) => {\n return {\n ...field,\n name,\n }\n })\n\nexport const objectFieldResolver = (schema: ObjectSchema): FieldResolver => {\n const getFields = () => {\n return mapFields(schema)\n }\n const getNestedFields = (name: string) => {\n const field = get(schema, name)\n\n if (!field) return []\n\n if (field.items?.type === 'object') {\n return mapFields(field.items.properties)\n } else if (field.type === 'object') {\n return mapFields(field.properties)\n }\n return [field.items]\n }\n\n return { getFields, getNestedFields }\n}\n","import * as React from 'react'\n\nimport { chakra, HTMLChakraProps, forwardRef } from '@chakra-ui/react'\nimport { cx, __DEV__ } from '@chakra-ui/utils'\n\nimport {\n useForm,\n FormProvider,\n UseFormProps,\n UseFormReturn,\n FieldValues,\n SubmitHandler,\n SubmitErrorHandler,\n UnpackNestedValue,\n ResolverOptions,\n ResolverResult,\n} from 'react-hook-form'\nimport { objectFieldResolver, FieldResolver } from './field-resolver'\nimport { css } from '@emotion/react'\n\nexport type { UseFormReturn, FieldValues, SubmitHandler }\n\ninterface FormOptions<TFieldValues extends FieldValues = FieldValues> {\n /**\n * The form schema, currently supports Yup schema only.\n */\n schema?: any\n /**\n * The submit handler.\n */\n onSubmit: SubmitHandler<TFieldValues>\n /**\n * Triggers when there are validation errors.\n */\n onError?: SubmitErrorHandler<TFieldValues>\n /**\n * Ref on the HTMLFormElement.\n */\n formRef?: React.MutableRefObject<HTMLFormElement>\n}\n\n/**\n * @todo Figure out how to pass down FieldValues to all Field components,\n * if at all possible.\n */\nexport interface FormProps<TFieldValues extends FieldValues = FieldValues>\n extends UseFormProps<TFieldValues>,\n Omit<HTMLChakraProps<'form'>, 'onSubmit' | 'onError'>,\n FormOptions<TFieldValues> {}\n\nexport const Form = forwardRef(\n <TFieldValues extends FieldValues = FieldValues>(\n props: FormProps<TFieldValues>,\n ref: React.ForwardedRef<UseFormReturn<TFieldValues>>\n ) => {\n const {\n mode = 'all',\n resolver,\n reValidateMode,\n shouldFocusError,\n shouldUnregister,\n shouldUseNativeValidation,\n criteriaMode,\n delayError,\n schema,\n defaultValues,\n onSubmit,\n onError,\n formRef,\n children,\n ...rest\n } = props\n\n const form = {\n mode,\n resolver,\n defaultValues,\n reValidateMode,\n shouldFocusError,\n shouldUnregister,\n shouldUseNativeValidation,\n criteriaMode,\n delayError,\n }\n\n if (schema && !resolver) {\n form.resolver = Form.getResolver?.(schema)\n }\n\n const methods = useForm<TFieldValues>(form)\n const { handleSubmit } = methods\n\n // This exposes the useForm api through the forwarded ref\n React.useImperativeHandle(ref, () => methods, [ref, methods])\n\n return (\n <FormProvider {...methods}>\n <chakra.form\n ref={formRef}\n onSubmit={handleSubmit(onSubmit, onError)}\n {...rest}\n className={cx('saas-form', props.className)}\n >\n {children}\n </chakra.form>\n </FormProvider>\n )\n }\n) as (<TFieldValues extends FieldValues>(\n props: FormProps<TFieldValues> & {\n ref?: React.ForwardedRef<UseFormReturn<TFieldValues>>\n }\n) => React.ReactElement) & {\n displayName?: string\n getResolver?: GetResolver\n getFieldResolver: GetFieldResolver\n}\n\nForm.getFieldResolver = objectFieldResolver\n\nif (__DEV__) {\n Form.displayName = 'Form'\n}\n\nexport type GetResolver = (\n schema: any\n) => <TFieldValues extends FieldValues, TContext>(\n values: UnpackNestedValue<TFieldValues>,\n context: TContext | undefined,\n options: ResolverOptions<TFieldValues>\n) => Promise<ResolverResult<TFieldValues>>\n\nexport type GetFieldResolver = (schema: any) => FieldResolver\n","import * as React from 'react'\n\nimport { chakra, SimpleGrid, SimpleGridProps, useTheme } from '@chakra-ui/react'\nimport { cx, __DEV__ } from '@chakra-ui/utils'\n\nexport type FormLayoutProps = SimpleGridProps\n\ninterface FormLayoutItemProps {\n children: React.ReactNode\n}\n\nconst FormLayoutItem: React.FC<FormLayoutItemProps> = ({ children }) => {\n return <chakra.div>{children}</chakra.div>\n}\n\nif (__DEV__) {\n FormLayoutItem.displayName = 'FormLayoutItem'\n}\n\n/**\n * FormLayout\n *\n * Renders form items in a `SimpleGrid`\n * @see https://chakra-ui.com/docs/layout/simple-grid\n */\nexport const FormLayout = ({ children, ...props }: FormLayoutProps) => {\n const theme = useTheme()\n\n const defaultProps = theme.components?.FormLayout?.defaultProps ?? {\n spacing: 4,\n }\n\n const gridProps = {\n ...defaultProps,\n ...props,\n }\n\n return (\n <SimpleGrid\n {...gridProps}\n className={cx('saas-form__layout', props.className)}\n >\n {React.Children.map(children, (child) => {\n if (React.isValidElement(child)) {\n return <FormLayoutItem>{child}</FormLayoutItem>\n }\n return child\n })}\n </SimpleGrid>\n )\n}\n\nif (__DEV__) {\n FormLayout.displayName = 'FormLayout'\n}\n","import * as React from 'react'\n\nexport const mapNestedFields = (name: string, children: React.ReactNode) => {\n return React.Children.map(children, (child) => {\n if (React.isValidElement(child) && child.props.name) {\n return React.cloneElement(child, {\n ...child.props,\n name: `${name}.${child.props.name}`,\n })\n }\n return child\n })\n}\n","import * as React from 'react'\nimport {\n useFieldArray,\n useFormContext,\n UseFieldArrayReturn,\n} from 'react-hook-form'\n\nimport { createContext } from '@chakra-ui/react-utils'\n\nexport interface UseArrayFieldReturn extends UseFieldArrayReturn {\n /**\n * The array field name\n */\n name: string\n /**\n * The default value for new items\n */\n defaultValue: Record<string, any>\n /**\n * Min amount of items\n */\n min?: number\n /**\n * Max amount of items\n */\n max?: number\n}\n\nexport const [ArrayFieldProvider, useArrayFieldContext] =\n createContext<UseArrayFieldReturn>({\n name: 'ArrayFieldContext',\n })\n\nexport interface UseArrayFieldRowReturn {\n /**\n * Name of the array field including the index, eg 'field.0'\n */\n name: string\n /**\n * The field index\n */\n index: number\n /**\n * Remove this array item\n */\n remove: () => void\n /**\n * True if this is the first item\n */\n isFirst: boolean\n /**\n * True if this is the last item\n */\n isLast: boolean\n}\n\nexport const [ArrayFieldRowProvider, useArrayFieldRowContext] =\n createContext<UseArrayFieldRowReturn>({\n name: 'ArrayFieldRowContext',\n })\n\nexport interface ArrayFieldOptions {\n /**\n * The field name\n */\n name: string\n /**\n * Default value for new values in the array\n */\n defaultValue?: Record<string, any>\n /**\n * Default key name for rows, change this if your data uses a different 'id' field\n * @default \"id\"\n */\n keyName?: string\n min?: number\n max?: number\n}\n\nexport const useArrayField = ({\n name,\n defaultValue = {},\n keyName,\n min,\n max,\n}: ArrayFieldOptions) => {\n const { control } = useFormContext()\n const context = useFieldArray({\n control,\n name,\n keyName,\n })\n\n return {\n ...context,\n name,\n defaultValue,\n min,\n max,\n }\n}\n\nexport interface UseArrayFieldRowProps {\n index: number\n}\n\nexport const useArrayFieldRow = ({ index }: UseArrayFieldRowProps) => {\n const { clearErrors } = useFormContext()\n const { name, remove, fields } = useArrayFieldContext()\n\n React.useEffect(() => {\n // reset errors, to make sure min/max errors reset correctly\n clearErrors(name)\n }, [])\n\n return {\n index,\n isFirst: index === 0,\n isLast: index === fields.length - 1,\n name: `${name}.${index}`,\n remove: React.useCallback(() => {\n clearErrors(name)\n remove(index)\n }, [index]),\n }\n}\n\nexport const useArrayFieldRemoveButton = () => {\n const { isFirst, remove } = useArrayFieldRowContext()\n const { min, fields } = useArrayFieldContext()\n\n const isDisabled = isFirst && !!(min && fields.length <= min)\n\n return {\n onClick: () => remove(),\n isDisabled,\n }\n}\n\nexport const useArrayFieldAddButton = () => {\n const { append, defaultValue, max, fields } = useArrayFieldContext()\n\n const isDisabled = !!(max && fields.length >= max)\n\n return {\n onClick: () =>\n append(defaultValue, {\n shouldFocus: false,\n }),\n isDisabled,\n }\n}\n","import * as React from 'react'\n\nimport { chakra, ResponsiveValue } from '@chakra-ui/system'\nimport { __DEV__ } from '@chakra-ui/utils'\nimport { AddIcon, MinusIcon } from '@chakra-ui/icons'\nimport { IconButton, ButtonProps } from '@saas-ui/button'\n\nimport { FormLayout } from './layout'\nimport { BaseField, FieldProps } from './field'\n\nimport { mapNestedFields } from './utils'\n\nimport {\n useArrayField,\n useArrayFieldRow,\n useArrayFieldContext,\n ArrayFieldProvider,\n ArrayFieldOptions,\n ArrayFieldRowProvider,\n useArrayFieldRowContext,\n useArrayFieldRemoveButton,\n useArrayFieldAddButton,\n UseArrayFieldReturn,\n} from './use-array-field'\n\ninterface ArrayField {\n id: string\n [key: string]: unknown\n}\n\ninterface ArrayFieldRowProps {\n /**\n * Amount of field columns\n */\n columns?: ResponsiveValue<number>\n /**\n * Spacing between fields\n */\n spacing?: ResponsiveValue<string | number>\n /**\n * The array index\n */\n index: number\n\n children: React.ReactNode\n}\n\nexport const ArrayFieldRow: React.FC<ArrayFieldRowProps> = ({\n children,\n columns,\n spacing,\n index,\n}) => {\n return (\n <ArrayFieldRowContainer index={index}>\n <ArrayFieldRowFields columns={columns} spacing={spacing}>\n {children}\n </ArrayFieldRowFields>\n <ArrayFieldRemoveButton />\n </ArrayFieldRowContainer>\n )\n}\n\nif (__DEV__) {\n ArrayFieldRow.displayName = 'ArrayFieldRow'\n}\n\nexport interface ArrayFieldRowFieldsProps {\n /**\n * Amount of field columns\n */\n columns?: ResponsiveValue<number>\n /**\n * Spacing between fields\n */\n spacing?: ResponsiveValue<string | number>\n\n children: React.ReactNode\n}\n\nexport const ArrayFieldRowFields: React.FC<ArrayFieldRowFieldsProps> = ({\n children,\n columns,\n spacing,\n ...layoutProps\n}) => {\n const { name } = useArrayFieldRowContext()\n return (\n <FormLayout\n flex=\"1\"\n columns={columns}\n gridGap={spacing}\n mr=\"2\"\n {...layoutProps}\n >\n {mapNestedFields(name, children)}\n </FormLayout>\n )\n}\n\nif (__DEV__) {\n ArrayFieldRowFields.displayName = 'ArrayFieldRowFields'\n}\n\nexport const ArrayFieldRowContainer: React.FC<ArrayFieldRowProps> = ({\n children,\n index,\n}) => {\n const context = useArrayFieldRow({ index })\n\n const styles = {\n display: 'flex',\n flexDirection: 'row',\n alignItems: 'flex-end',\n width: '100%',\n mb: 4,\n }\n\n return (\n <ArrayFieldRowProvider value={context}>\n <chakra.div __css={styles}>{children}</chakra.div>\n </ArrayFieldRowProvider>\n )\n}\n\nif (__DEV__) {\n ArrayFieldRowContainer.displayName = 'ArrayFieldRowContainer'\n}\n\nexport const ArrayFieldRemoveButton: React.FC<ButtonProps> = (props) => {\n return (\n <IconButton\n icon={<MinusIcon />}\n aria-label=\"Remove row\"\n {...useArrayFieldRemoveButton()}\n {...props}\n />\n )\n}\n\nif (__DEV__) {\n ArrayFieldRemoveButton.displayName = 'ArrayFieldRemoveButton'\n}\n\nexport const ArrayFieldAddButton: React.FC<ButtonProps> = (props) => {\n return (\n <IconButton\n icon={<AddIcon />}\n aria-label=\"Add row\"\n float=\"right\"\n {...useArrayFieldAddButton()}\n {...props}\n />\n )\n}\n\nif (__DEV__) {\n ArrayFieldAddButton.displayName = 'ArrayFieldAddButton'\n}\n\nexport interface ArrayFieldProps\n extends ArrayFieldOptions,\n Omit<FieldProps, 'defaultValue'> {}\n\nexport const ArrayField = React.forwardRef(\n (props: ArrayFieldProps, ref: React.ForwardedRef<UseArrayFieldReturn>) => {\n const { children, ...containerProps } = props\n\n return (\n <ArrayFieldContainer ref={ref} {...containerProps}>\n <ArrayFieldRows>\n {(fields: ArrayField[]) => (\n <>\n {fields.map(({ id }, index: number) => (\n <ArrayFieldRow key={id} index={index}>\n {children}\n </ArrayFieldRow>\n ))}\n </>\n )}\n </ArrayFieldRows>\n <ArrayFieldAddButton />\n </ArrayFieldContainer>\n )\n }\n)\n\nif (__DEV__) {\n ArrayField.displayName = 'ArrayField'\n}\n\nexport interface ArrayFieldRowsProps {\n children: (fields: ArrayField[]) => React.ReactElement | null\n}\n\nexport const ArrayFieldRows = ({\n children,\n}: ArrayFieldRowsProps): React.ReactElement | null => {\n const { fields } = useArrayFieldContext()\n return children(fields)\n}\n\nif (__DEV__) {\n ArrayFieldRows.displayName = 'ArrayFieldRows'\n}\n\nexport const ArrayFieldContainer = React.forwardRef(\n (\n {\n name,\n defaultValue,\n keyName,\n min,\n max,\n children,\n ...fieldProps\n }: ArrayFieldProps,\n ref: React.ForwardedRef<UseArrayFieldReturn>\n ) => {\n const context = useArrayField({\n name,\n defaultValue,\n keyName,\n min,\n max,\n })\n\n // This exposes the useArrayField api through the forwarded ref\n React.useImperativeHandle(ref, () => context, [ref, context])\n\n return (\n <ArrayFieldProvider value={context}>\n <BaseField name={name} {...fieldProps}>\n {children}\n </BaseField>\n </ArrayFieldProvider>\n )\n }\n)\n\nif (__DEV__) {\n ArrayFieldContainer.displayName = 'ArrayFieldContainer'\n}\n","import * as React from 'react'\nimport {\n FormControl,\n FormLabel,\n FormLabelProps,\n ResponsiveValue,\n useStyles,\n} from '@chakra-ui/react'\nimport { __DEV__ } from '@chakra-ui/utils'\n\nimport { FormLayout } from './layout'\nimport { FieldProps } from './field'\n\nimport { mapNestedFields } from './utils'\n\nexport interface ObjectFieldProps extends FieldProps {\n name: string\n children: React.ReactNode\n columns?: ResponsiveValue<number>\n spacing?: ResponsiveValue<string | number>\n}\n\nexport const FormLegend = (props: FormLabelProps) => {\n const styles = useStyles()\n return <FormLabel as=\"legend\" sx={styles.legend} {...props} />\n}\n\nexport const ObjectField: React.FC<ObjectFieldProps> = (props) => {\n const { name, label, hideLabel, children, columns, spacing, ...fieldProps } =\n props\n\n return (\n <FormControl name={name} as=\"fieldset\" {...fieldProps}>\n <FormLegend display={hideLabel ? 'none' : 'block'}>{label}</FormLegend>\n <FormLayout columns={columns} gridGap={spacing}>\n {mapNestedFields(name, children)}\n </FormLayout>\n </FormControl>\n )\n}\n\nif (__DEV__) {\n ObjectField.displayName = 'ObjectField'\n}\n","import * as React from 'react'\nimport { __DEV__ } from '@chakra-ui/utils'\n\nimport { Form } from './form'\nimport { FormLayout } from './layout'\nimport { Field, FieldProps } from './field'\n\nimport { ArrayField } from './array-field'\nimport { ObjectField } from './object-field'\nimport { FieldResolver } from './field-resolver'\n\nexport interface FieldsProps {\n schema: any\n fieldResolver?: FieldResolver\n}\n\nconst mapNestedFields = (resolver: FieldResolver, name: string) => {\n return resolver\n .getNestedFields(name)\n ?.map(\n ({ name, type, ...nestedFieldProps }: FieldProps, i): React.ReactNode => (\n <Field key={name || i} name={name} type={type} {...nestedFieldProps} />\n )\n )\n}\n\nexport const Fields: React.FC<FieldsProps> = ({\n schema,\n fieldResolver,\n ...props\n}) => {\n const resolver = React.useMemo(\n () => fieldResolver || Form.getFieldResolver(schema),\n [schema, fieldResolver]\n )\n\n return (\n <FormLayout {...props}>\n {resolver\n .getFields()\n .map(\n ({\n name,\n type,\n defaultValue,\n ...fieldProps\n }: FieldProps): React.ReactNode => {\n if (type === 'array') {\n return (\n <ArrayField key={name} name={name} {...fieldProps}>\n {mapNestedFields(resolver, name)}\n </ArrayField>\n )\n } else if (type === 'object') {\n return (\n <ObjectField key={name} name={name} {...fieldProps}>\n {mapNestedFields(resolver, name)}\n </ObjectField>\n )\n }\n\n return <Field key={name} name={name} type={type} {...fieldProps} />\n }\n )}\n </FormLayout>\n )\n}\n\nif (__DEV__) {\n Fields.displayName = 'Fields'\n}\n","import * as React from 'react'\n\nimport { useFormContext } from 'react-hook-form'\n\nimport { Button, ButtonProps } from '@saas-ui/button'\n\nimport { forwardRef } from '@chakra-ui/system'\nimport { __DEV__ } from '@chakra-ui/utils'\n\nexport interface SubmitButtonProps extends ButtonProps {\n /**\n * Disable the submit button if the form is untouched.\n *\n * Change the default behavior by updating\n * `SubmitButton.defaultProps.disableIfUntouched`\n */\n disableIfUntouched?: boolean\n /**\n * Disable the submit button if the form is invalid.\n *\n * Change the default behavior by updating\n * `SubmitButton.defaultProps.disableIfInvalid`\n */\n disableIfInvalid?: boolean\n}\n\nexport const SubmitButton = forwardRef<SubmitButtonProps, 'button'>(\n (props, ref) => {\n const { children, disableIfUntouched, disableIfInvalid, ...rest } = props\n const { formState } = useFormContext()\n\n const isDisabled =\n (disableIfUntouched && !formState.isDirty) ||\n (disableIfInvalid && !formState.isValid)\n\n return (\n <Button\n type=\"submit\"\n isLoading={formState.isSubmitting}\n isPrimary\n ref={ref}\n isDisabled={isDisabled}\n {...rest}\n >\n {children}\n </Button>\n )\n }\n)\n\nSubmitButton.defaultProps = {\n label: 'Submit',\n disableIfUntouched: false,\n disableIfInvalid: false,\n}\n\nif (__DEV__) {\n SubmitButton.displayName = 'SubmitButton'\n}\n","import * as React from 'react'\nimport { FieldValues, UseFormReturn } from 'react-hook-form'\nimport { forwardRef } from '@chakra-ui/react'\nimport { __DEV__ } from '@chakra-ui/utils'\n\nimport { Form, FormProps } from './form'\nimport { FormLayout } from './layout'\nimport { Fields } from './fields'\nimport { SubmitButton } from './submit-button'\nimport { FieldResolver } from '.'\n\ninterface AutoFormOptions {\n submitLabel?: false | string\n schema: any\n fieldResolver?: any\n}\n\nexport interface AutoFormProps<TFieldValues extends FieldValues>\n extends Omit<FormProps<TFieldValues>, 'schema'>,\n AutoFormOptions {}\n\nexport const AutoForm = forwardRef(\n <TFieldValues extends FieldValues = FieldValues>(\n props: AutoFormProps<TFieldValues>,\n ref: React.ForwardedRef<UseFormReturn<TFieldValues>>\n ) => {\n const { schema, submitLabel = 'Submit', fieldResolver, ...rest } = props\n\n return (\n <Form {...rest} schema={schema} ref={ref}>\n <FormLayout>\n {<Fields schema={schema} fieldResolver={fieldResolver} />}\n {submitLabel && <SubmitButton label={submitLabel} />}\n </FormLayout>\n </Form>\n )\n }\n) as (<TFieldValues extends FieldValues>(\n props: AutoFormProps<TFieldValues> & {\n ref?: React.ForwardedRef<UseFormReturn<TFieldValues>>\n }\n) => React.ReactElement) & {\n displayName?: string\n getFieldResolver?: (schema: any) => FieldResolver\n}\n\nif (__DEV__) {\n AutoForm.displayName = 'AutoForm'\n}\n","import * as React from 'react'\nimport { __DEV__ } from '@chakra-ui/utils'\nimport {\n useFormContext,\n useWatch,\n FieldValues,\n UseFormReturn,\n} from 'react-hook-form'\n\nexport interface DisplayIfProps<TFieldValues> {\n children: React.ReactElement\n name: string\n defaultValue?: unknown\n isDisabled?: boolean\n isExact?: boolean\n condition?: (value: unknown, context: UseFormReturn<TFieldValues>) => boolean\n}\n\nexport const DisplayIf = <TFieldValues extends FieldValues = FieldValues>({\n children,\n name,\n defaultValue,\n isDisabled,\n isExact,\n condition = (value) => !!value,\n}: DisplayIfProps<TFieldValues>) => {\n const value = useWatch({\n name,\n defaultValue,\n disabled: isDisabled,\n exact: isExact,\n })\n const context = useFormContext<TFieldValues>()\n return condition(value, context) ? children : null\n}\n\nif (__DEV__) {\n DisplayIf.displayName = 'DisplayIf'\n}\n","import * as React from 'react'\nimport { FieldValues, SubmitHandler } from 'react-hook-form'\nimport { createContext } from '@chakra-ui/react-utils'\nimport {\n useStepper,\n useStep,\n UseStepperProps,\n UseStepperReturn,\n} from '@saas-ui/stepper'\n\nexport interface StepState {\n name: string\n schema?: any\n resolver?: any\n isActive?: boolean\n isCompleted?: boolean\n}\n\nexport interface StepFormContext extends UseStepperReturn {\n updateStep(state: StepState): void\n steps: Record<string, StepState>\n}\n\nexport const [StepFormProvider, useStepFormContext] =\n createContext<StepFormContext>({\n name: 'StepFormContext',\n errorMessage:\n 'useStepFormContext: `context` is undefined. Seems you forgot to wrap step form components in `<StepForm />`',\n })\n\nimport { FormProps } from './form'\n\nexport interface UseStepFormProps<\n TFieldValues extends FieldValues = FieldValues\n> extends UseStepperProps,\n Omit<FormProps<TFieldValues>, 'children'> {\n children:\n | React.ReactNode\n | ((stepper: UseStepFormReturn<TFieldValues>) => React.ReactElement)\n}\n\nexport interface UseStepFormReturn<\n TFieldValues extends FieldValues = FieldValues\n> extends UseStepperReturn {\n getFormProps(): {\n onSubmit: SubmitHandler<TFieldValues>\n schema?: any\n resolver?: any\n }\n updateStep(step: any): void\n steps: Record<string, any>\n}\n\nexport function useStepForm<TFieldValues extends FieldValues = FieldValues>(\n props: UseStepFormProps<TFieldValues>\n): UseStepFormReturn<TFieldValues> {\n const stepper = useStepper(props)\n\n const { activeStep, isLastStep, nextStep } = stepper\n\n const [steps, updateSteps] = React.useState<Record<string, StepState>>({})\n\n const onSubmitStep: SubmitHandler<TFieldValues> = React.useCallback(\n async (data) => {\n if (isLastStep) {\n return props\n .onSubmit?.(data)\n .then(() => {\n const step = steps[activeStep]\n updateStep({\n ...step,\n isCompleted: true,\n })\n })\n .then(nextStep) // Show completed step\n }\n\n nextStep()\n },\n [activeStep, isLastStep]\n )\n\n const getFormProps = React.useCallback(() => {\n const step = steps[activeStep]\n return {\n onSubmit: onSubmitStep,\n schema: step?.schema,\n resolver: step?.resolver,\n }\n }, [steps, onSubmitStep, activeStep])\n\n const updateStep = React.useCallback(\n (step: StepState) => {\n updateSteps((steps) => {\n return {\n ...steps,\n [step.name]: step,\n }\n })\n },\n [steps]\n )\n\n return {\n getFormProps,\n updateStep,\n steps,\n ...stepper,\n }\n}\n\nexport interface UseFormStepProps {\n name: string\n schema?: any\n resolver?: any\n}\n\nexport function useFormStep(props: UseFormStepProps): StepState {\n const { name, schema, resolver } = props\n const step = useStep({ name })\n\n const { steps, updateStep } = useStepFormContext()\n\n React.useEffect(() => {\n updateStep({ name, schema, resolver })\n }, [name, schema])\n\n return {\n ...step,\n ...(steps[name] || { name, schema }),\n }\n}\n","import * as React from 'react'\n\nimport { FieldValues, UseFormReturn } from 'react-hook-form'\n\nimport {\n chakra,\n HTMLChakraProps,\n useMultiStyleConfig,\n StylesProvider,\n SystemStyleObject,\n} from '@chakra-ui/system'\n\nimport { callAllHandlers, runIfFn, cx, __DEV__ } from '@chakra-ui/utils'\n\nimport {\n StepperProvider,\n StepperSteps,\n StepperStepsProps,\n StepperStep,\n useStepperContext,\n} from '@saas-ui/stepper'\nimport { Button, ButtonProps } from '@saas-ui/button'\n\nimport { Form, FormProps } from './form'\nimport { SubmitButton } from './submit-button'\n\nimport {\n useStepForm,\n useFormStep,\n StepFormProvider,\n UseStepFormProps,\n UseStepFormReturn,\n} from './use-step-form'\n\nexport interface StepFormProps<TFieldValues extends FieldValues = FieldValues>\n extends UseStepFormProps<TFieldValues> {}\n\nexport const StepForm = React.forwardRef(\n <TFieldValues extends FieldValues = FieldValues>(\n props: StepFormProps<TFieldValues>,\n ref: React.ForwardedRef<UseFormReturn<TFieldValues>>\n ) => {\n const { children, ...rest } = props\n\n const stepper = useStepForm<TFieldValues>(props)\n\n const { getFormProps, ...ctx } = stepper\n\n const context = React.useMemo(() => ctx, [ctx])\n\n return (\n <StepperProvider value={context}>\n <StepFormProvider value={context}>\n <Form ref={ref} {...rest} {...getFormProps()}>\n {runIfFn(children, stepper)}\n </Form>\n </StepFormProvider>\n </StepperProvider>\n )\n }\n) as <TFieldValues extends FieldValues>(\n props: FormProps<TFieldValues> & {\n ref?: React.ForwardedRef<UseFormReturn<TFieldValues>>\n }\n) => React.ReactElement\n\nexport interface FormStepOptions {\n /**\n * The step name\n */\n name: string\n /**\n * Schema\n */\n schema?: any\n /**\n * Hook Form Resolver\n */\n resolver?: any\n}\n\nexport const FormStepper: React.FC<StepperStepsProps> = (props) => {\n const styles = useMultiStyleConfig('Stepper', props)\n\n const { children } = props\n\n const elements = React.Children.map(children, (child) => {\n if (React.isValidElement(child) && child?.type === FormStep) {\n const { isCompleted } = useFormStep(child.props) // Register this step\n return (\n <StepperStep\n name={child.props.name}\n title={child.props.title}\n isCompleted={isCompleted}\n >\n {child.props.children}\n </StepperStep>\n )\n }\n return child\n })\n\n return (\n <StylesProvider value={styles}>\n <StepperSteps mb=\"4\" {...props}>\n {elements}\n </StepperSteps>\n </StylesProvider>\n )\n}\n\nexport interface FormStepProps\n extends FormStepOptions,\n HTMLChakraProps<'div'> {}\n\nexport const FormStep: React.FC<FormStepProps> = (props) => {\n const { name, schema, resolver, children, className, ...rest } = props\n const step = useFormStep({ name, schema, resolver })\n\n const { isActive } = step\n\n return isActive ? (\n <chakra.div {...rest} className={cx('saas-form__step', className)}>\n {children}\n </chakra.div>\n ) : null\n}\n\nif (__DEV__) {\n FormStep.displayName = 'FormStep'\n}\n\nexport const PrevButton: React.FC<ButtonProps> = (props) => {\n const { isFirstStep, isCompleted, prevStep } = useStepperContext()\n\n return (\n <Button\n isDisabled={isFirstStep || isCompleted}\n label=\"Back\"\n {...props}\n className={cx('saas-form__prev-button', props.className)}\n onClick={callAllHandlers(props.onClick, prevStep)}\n />\n )\n}\n\nif (__DEV__) {\n PrevButton.displayName = 'PrevButton'\n}\n\nexport interface NextButtonProps extends ButtonProps {\n submitLabel?: string\n}\n\nexport const NextButton: React.FC<NextButtonProps> = (props) => {\n const { label = 'Next', submitLabel = 'Complete', ...rest } = props\n const { isLastStep, isCompleted } = useStepperContext()\n\n return (\n <SubmitButton\n isDisabled={isCompleted}\n label={isLastStep || isCompleted ? submitLabel : label}\n {...rest}\n className={cx('saas-form__next-button', props.className)}\n />\n )\n}\n\nif (__DEV__) {\n NextButton.displayName = 'NextButton'\n}\n"],"names":["_excluded","DisplayField","_ref","name","label","props","React","createElement","FormControl","FormLabel","htmlFor","Text","fontSize","FormValue","__DEV__","displayName","_ref2","getValues","useFormContext","inputTypes","BaseField","help","variant","hideLabel","children","controlProps","_objectWithoutPropertiesLoose","error","formState","get","errors","getError","_extends","isInvalid","Box","message","FormHelperText","FormErrorMessage","Field","forwardRef","ref","type","_props$type","withControlledInput","InputComponent","_ref3","rules","inputProps","_excluded3","Controller","control","_useFormContext2","render","_ref4","_ref4$field","field","_excluded4","useMergeRefs","withUncontrolledInput","_ref5","_excluded5","register","_register","_excluded6","registerFieldType","component","options","id","isDisabled","isReadOnly","isRequired","_excluded2","inputRules","required","createField","isControlled","split","map","part","charAt","toUpperCase","slice","join","InputField","Input","NumberInputField","NumberInput","PasswordInputFIeld","PasswordInput","TextareaField","Textarea","SwitchField","_ref6","_excluded7","Switch","SelectField","Select","CheckboxField","_ref7","_excluded8","Checkbox","RadioField","RadioInput","PinField","PinInput","NativeSelectField","NativeSelect","mapFields","schema","Object","entries","getFields","getNestedFields","_field$items","items","properties","Form","mode","_props$mode","resolver","reValidateMode","shouldFocusError","shouldUnregister","shouldUseNativeValidation","criteriaMode","delayError","defaultValues","onSubmit","onError","formRef","rest","form","getResolver","methods","useForm","handleSubmit","useImperativeHandle","FormProvider","chakra","className","cx","getFieldResolver","objectFieldResolver","FormLayoutItem","div","FormLayout","_theme$components$For","_theme$components","_theme$components$For2","gridProps","theme","useTheme","components","defaultProps","spacing","SimpleGrid","Children","child","isValidElement","mapNestedFields","cloneElement","createContext","ArrayFieldProvider","useArrayFieldContext","_createContext","ArrayFieldRowProvider","useArrayFieldRowContext","useArrayField","_ref$defaultValue","defaultValue","keyName","min","max","context","useFieldArray","useArrayFieldRow","index","clearErrors","_useArrayFieldContext","remove","fields","useEffect","isFirst","isLast","length","useCallback","useArrayFieldRemoveButton","_useArrayFieldRowCont","_useArrayFieldContext2","onClick","append","_useArrayFieldContext3","shouldFocus","ArrayFieldRow","ArrayFieldRowContainer","ArrayFieldRowFields","columns","ArrayFieldRemoveButton","layoutProps","flex","gridGap","mr","value","__css","display","flexDirection","alignItems","width","mb","IconButton","icon","MinusIcon","ArrayFieldAddButton","AddIcon","float","useArrayFieldAddButton","ArrayField","containerProps","ArrayFieldContainer","ArrayFieldRows","key","fieldProps","FormLegend","styles","useStyles","as","sx","legend","ObjectField","_resolver$getNestedFi","i","nestedFieldProps","Fields","fieldResolver","useMemo","SubmitButton","disableIfUntouched","disableIfInvalid","Button","isLoading","isSubmitting","isPrimary","isDirty","isValid","AutoForm","submitLabel","_props$submitLabel","DisplayIf","condition","_ref$condition","useWatch","disabled","exact","isExact","errorMessage","StepFormProvider","useStepFormContext","stepper","useStepper","activeStep","isLastStep","nextStep","_React$useState","useState","steps","updateSteps","onSubmitStep","data","Promise","resolve","then","updateStep","step","isCompleted","e","reject","getFormProps","_extends2","useStep","_useStepFormContext","StepForm","useStepForm","ctx","StepperProvider","runIfFn","FormStep","useFormStep","isActive","PrevButton","useStepperContext","prevStep","_useStepperContext","isFirstStep","callAllHandlers","NextButton","_props$label","_useStepperContext2","useMultiStyleConfig","_useFormStep","StepperStep","title","StylesProvider","StepperSteps","elements"],"mappings":"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"}
1
+ {"version":3,"file":"index.js","sources":["../src/display-field.tsx","../src/field.tsx","../src/field-resolver.ts","../src/form.tsx","../src/layout.tsx","../src/utils.ts","../src/use-array-field.tsx","../src/array-field.tsx","../src/object-field.tsx","../src/fields.tsx","../src/submit-button.tsx","../src/auto-form.tsx","../src/display-if.tsx","../src/use-step-form.tsx","../src/step-form.tsx"],"sourcesContent":["import * as React from 'react'\nimport { __DEV__ } from '@chakra-ui/utils'\nimport { useFormContext } from 'react-hook-form'\n\nimport {\n Text,\n FormControl,\n FormControlProps,\n FormLabel,\n} from '@chakra-ui/react'\n\nimport { FieldProps } from './field'\n\nexport interface DisplayFieldProps\n extends FormControlProps,\n Omit<FieldProps, 'type' | 'label'> {}\n\nexport const DisplayField: React.FC<DisplayFieldProps> = ({\n name,\n label,\n placeholder,\n ...props\n}) => {\n return (\n <FormControl {...props}>\n {label ? <FormLabel htmlFor={name}>{label}</FormLabel> : null}\n <Text fontSize=\"md\">\n <FormValue name={name} />\n </Text>\n </FormControl>\n )\n}\n\nif (__DEV__) {\n DisplayField.displayName = 'DisplayField'\n}\n\nexport const FormValue: React.FC<{ name: string }> = ({ name }) => {\n const { getValues } = useFormContext()\n return getValues(name) || null\n}\n\nif (__DEV__) {\n FormValue.displayName = 'FormValue'\n}\n","import * as React from 'react'\nimport {\n useFormContext,\n FormState,\n Controller,\n get,\n RegisterOptions,\n FieldValues,\n FieldPath,\n} from 'react-hook-form'\n\nimport {\n forwardRef,\n Box,\n FormControl,\n FormControlProps,\n FormLabel,\n FormHelperText,\n FormErrorMessage,\n Input,\n Textarea,\n Checkbox,\n Switch,\n useMergeRefs,\n} from '@chakra-ui/react'\nimport { __DEV__ } from '@chakra-ui/utils'\n\nimport { NumberInput } from '@saas-ui/number-input'\nimport { PasswordInput } from '@saas-ui/password-input'\nimport { RadioInput } from '@saas-ui/radio'\nimport { PinInput } from '@saas-ui/pin-input'\nimport { Select, NativeSelect } from '@saas-ui/select'\nimport { FocusableElement } from '@chakra-ui/utils'\n\nexport interface Option {\n value: string\n label?: string\n [key: string]: unknown\n}\n\nexport type FieldRules = Pick<\n RegisterOptions,\n 'required' | 'min' | 'max' | 'maxLength' | 'minLength' | 'pattern'\n>\n\nexport type FieldTypes =\n | 'text'\n | 'number'\n | 'password'\n | 'textarea'\n | 'select'\n | 'native-select'\n | 'checkbox'\n | 'radio'\n | 'switch'\n | 'pin'\n | string\n\nexport interface FieldProps<\n TFieldValues extends FieldValues = FieldValues,\n TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>\n> extends Omit<FormControlProps, 'label' | 'type'> {\n /**\n * The field name\n */\n name: TName\n /**\n * The field label\n */\n label?: string\n /**\n * Hide the field label\n */\n hideLabel?: boolean\n /**\n * Field help text\n */\n help?: string\n /**\n * React hook form rules\n */\n rules?: Omit<\n RegisterOptions<TFieldValues, TName>,\n 'valueAsNumber' | 'valueAsDate' | 'setValueAs' | 'disabled'\n >\n /**\n * Options used for selects and radio fields\n */\n options?: Option[]\n /**\n * The field type\n * Build-in types:\n * - text\n * - number\n * - password\n * - textarea\n * - select\n * - native-select\n * - checkbox\n * - radio\n * - switch\n * - pin\n *\n * Will default to a text field if there is no matching type.\n * @default 'text'\n */\n type?: FieldTypes\n /**\n * The input placeholder\n */\n placeholder?: string\n}\n\nconst inputTypes: Record<FieldTypes, any> = {}\n\nconst defaultInputType = 'text'\n\nconst getInput = (type: string) => {\n return inputTypes[type] || inputTypes[defaultInputType]\n}\n\nconst getError = (name: string, formState: FormState<{ [x: string]: any }>) => {\n return get(formState.errors, name)\n}\n\nconst isTouched = (\n name: string,\n formState: FormState<{ [x: string]: any }>\n) => {\n return get(formState.touchedFields, name)\n}\n\nexport const BaseField: React.FC<FieldProps> = (props) => {\n const { name, label, help, variant, hideLabel, children, ...controlProps } =\n props\n\n const { formState } = useFormContext()\n\n const error = getError(name, formState)\n\n return (\n <FormControl variant={variant} {...controlProps} isInvalid={!!error}>\n {label && !hideLabel ? (\n <FormLabel variant={variant}>{label}</FormLabel>\n ) : null}\n <Box>\n {children}\n {help && !error?.message ? (\n <FormHelperText>{help}</FormHelperText>\n ) : null}\n {error?.message && (\n <FormErrorMessage>{error?.message}</FormErrorMessage>\n )}\n </Box>\n </FormControl>\n )\n}\n\nif (__DEV__) {\n BaseField.displayName = 'BaseField'\n}\n\nexport const Field = forwardRef(\n <TFieldValues extends FieldValues = FieldValues>(\n props: FieldProps<TFieldValues> & {\n [key: string]: unknown // Make sure attributes of custom components work. Need to change this to a global typedef at some point.\n },\n ref: React.ForwardedRef<FocusableElement>\n ) => {\n const { type = defaultInputType } = props\n const InputComponent = getInput(type)\n\n return <InputComponent ref={ref} {...props} />\n }\n) as <TFieldValues extends FieldValues>(\n props: FieldProps<TFieldValues> & {\n [key: string]: unknown\n } & {\n ref?: React.ForwardedRef<FocusableElement>\n }\n) => React.ReactElement\n\ninterface CreateFieldProps {\n displayName: string\n hideLabel?: boolean\n BaseField: React.FC<any>\n}\n\nconst createField = (\n InputComponent: React.FC<any>,\n { displayName, hideLabel, BaseField }: CreateFieldProps\n) => {\n const Field = forwardRef<FieldProps, typeof FormControl>((props, ref) => {\n const {\n id,\n name,\n label,\n help,\n isDisabled,\n isInvalid,\n isReadOnly,\n isRequired,\n rules,\n variant,\n ...inputProps\n } = props\n\n const inputRules = {\n required: isRequired,\n ...rules,\n }\n\n return (\n <BaseField\n id={id}\n name={name}\n label={label}\n help={help}\n hideLabel={hideLabel}\n isDisabled={isDisabled}\n isInvalid={isInvalid}\n isReadOnly={isReadOnly}\n isRequired={isRequired}\n variant={variant}\n >\n <InputComponent\n ref={ref}\n id={id}\n name={name}\n label={hideLabel ? label : undefined} // Only pass down the label when it should be inline.\n rules={inputRules}\n {...inputProps}\n />\n </BaseField>\n )\n })\n Field.displayName = displayName\n\n return Field\n}\n\nexport const withControlledInput = (InputComponent: any) => {\n return forwardRef<FieldProps, typeof InputComponent>(\n ({ name, rules, ...inputProps }, ref) => {\n const { control } = useFormContext()\n\n return (\n <Controller\n name={name}\n control={control}\n rules={rules}\n render={({ field: { ref: _ref, ...field } }) => (\n <InputComponent\n {...field}\n {...inputProps}\n ref={useMergeRefs(ref, _ref)}\n />\n )}\n />\n )\n }\n )\n}\n\nexport const withUncontrolledInput = (InputComponent: any) => {\n return forwardRef<FieldProps, typeof InputComponent>(\n ({ name, rules, ...inputProps }, ref) => {\n const { register } = useFormContext()\n\n const { ref: _ref, ...field } = register(name, rules)\n\n return (\n <InputComponent\n {...field}\n {...inputProps}\n ref={useMergeRefs(ref, _ref)}\n />\n )\n }\n )\n}\n\nexport interface RegisterFieldTypeOptions {\n isControlled?: boolean\n hideLabel?: boolean\n BaseField?: React.FC<any>\n}\n\n/**\n * Register a new field type\n * @param type The name for this field in kebab-case, eg `email` or `array-field`\n * @param component The React component\n * @param options\n * @param options.isControlled Set this to true if this is a controlled field.\n * @param options.hideLabel Hide the field label, for example for the checkbox field.\n */\nexport const registerFieldType = (\n type: string,\n component: React.FC<any>,\n options?: RegisterFieldTypeOptions\n) => {\n let InputComponent\n if (options?.isControlled) {\n InputComponent = withControlledInput(component)\n } else {\n InputComponent = withUncontrolledInput(component)\n }\n\n const Field = createField(InputComponent, {\n displayName: `${type\n .split('-')\n .map((part) => part.charAt(0).toUpperCase() + part.slice(1))\n .join('')}Field`,\n hideLabel: options?.hideLabel,\n BaseField: options?.BaseField || BaseField,\n })\n\n inputTypes[type] = Field\n\n return Field\n}\n\nexport const InputField = registerFieldType(\n 'text',\n forwardRef(({ type = 'text', ...rest }, ref) => {\n return <Input type={type} {...rest} ref={ref} />\n })\n)\nexport const NumberInputField = registerFieldType('number', NumberInput, {\n isControlled: true,\n})\nexport const PasswordInputFIeld = registerFieldType('password', PasswordInput)\nexport const TextareaField = registerFieldType('textarea', Textarea)\nexport const SwitchField = registerFieldType(\n 'switch',\n forwardRef(({ type, ...rest }, ref) => {\n return <Switch {...rest} ref={ref} />\n }),\n {\n isControlled: true,\n }\n)\nexport const SelectField = registerFieldType('select', Select, {\n isControlled: true,\n})\nexport const CheckboxField = registerFieldType(\n 'checkbox',\n forwardRef(\n ({ label, type, ...props }: { label?: string; type: string }, ref) => {\n return (\n <Checkbox ref={ref} {...props}>\n {label}\n </Checkbox>\n )\n }\n ),\n {\n hideLabel: true,\n }\n)\nexport const RadioField = registerFieldType('radio', RadioInput, {\n isControlled: true,\n})\nexport const PinField = registerFieldType('pin', PinInput, {\n isControlled: true,\n})\nexport const NativeSelectField = registerFieldType(\n 'native-select',\n NativeSelect,\n { isControlled: true }\n)\n","import { FieldProps } from './field'\n\nimport { get } from '@chakra-ui/utils'\n\nexport type FieldResolver = {\n getFields(): FieldProps[]\n getNestedFields(name: string): FieldProps[]\n}\n\ninterface SchemaField extends FieldProps {\n items?: SchemaField[]\n properties?: Record<string, SchemaField>\n}\n\nexport type ObjectSchema = Record<string, SchemaField>\n\nconst mapFields = (schema: ObjectSchema): FieldProps[] =>\n schema &&\n Object.entries(schema).map(([name, { items, ...field }]) => {\n return {\n ...field,\n name,\n }\n })\n\nexport const objectFieldResolver = (schema: ObjectSchema): FieldResolver => {\n const getFields = () => {\n return mapFields(schema)\n }\n const getNestedFields = (name: string) => {\n const field = get(schema, name)\n\n if (!field) return []\n\n if (field.items?.type === 'object') {\n return mapFields(field.items.properties)\n } else if (field.type === 'object') {\n return mapFields(field.properties)\n }\n return [field.items]\n }\n\n return { getFields, getNestedFields }\n}\n","import * as React from 'react'\n\nimport { chakra, HTMLChakraProps, forwardRef } from '@chakra-ui/react'\nimport { cx, __DEV__ } from '@chakra-ui/utils'\n\nimport {\n useForm,\n FormProvider,\n UseFormProps,\n UseFormReturn,\n FieldValues,\n SubmitHandler,\n SubmitErrorHandler,\n UnpackNestedValue,\n ResolverOptions,\n ResolverResult,\n} from 'react-hook-form'\nimport { objectFieldResolver, FieldResolver } from './field-resolver'\nimport { css } from '@emotion/react'\n\nexport type { UseFormReturn, FieldValues, SubmitHandler }\n\ninterface FormOptions<TFieldValues extends FieldValues = FieldValues> {\n /**\n * The form schema, currently supports Yup schema only.\n */\n schema?: any\n /**\n * The submit handler.\n */\n onSubmit: SubmitHandler<TFieldValues>\n /**\n * Triggers when there are validation errors.\n */\n onError?: SubmitErrorHandler<TFieldValues>\n /**\n * Ref on the HTMLFormElement.\n */\n formRef?: React.MutableRefObject<HTMLFormElement>\n}\n\n/**\n * @todo Figure out how to pass down FieldValues to all Field components,\n * if at all possible.\n */\nexport interface FormProps<TFieldValues extends FieldValues = FieldValues>\n extends UseFormProps<TFieldValues>,\n Omit<HTMLChakraProps<'form'>, 'onSubmit' | 'onError'>,\n FormOptions<TFieldValues> {}\n\nexport const Form = forwardRef(\n <TFieldValues extends FieldValues = FieldValues>(\n props: FormProps<TFieldValues>,\n ref: React.ForwardedRef<UseFormReturn<TFieldValues>>\n ) => {\n const {\n mode = 'all',\n resolver,\n reValidateMode,\n shouldFocusError,\n shouldUnregister,\n shouldUseNativeValidation,\n criteriaMode,\n delayError,\n schema,\n defaultValues,\n onSubmit,\n onError,\n formRef,\n children,\n ...rest\n } = props\n\n const form = {\n mode,\n resolver,\n defaultValues,\n reValidateMode,\n shouldFocusError,\n shouldUnregister,\n shouldUseNativeValidation,\n criteriaMode,\n delayError,\n }\n\n if (schema && !resolver) {\n form.resolver = Form.getResolver?.(schema)\n }\n\n const methods = useForm<TFieldValues>(form)\n const { handleSubmit } = methods\n\n // This exposes the useForm api through the forwarded ref\n React.useImperativeHandle(ref, () => methods, [ref, methods])\n\n return (\n <FormProvider {...methods}>\n <chakra.form\n ref={formRef}\n onSubmit={handleSubmit(onSubmit, onError)}\n {...rest}\n className={cx('saas-form', props.className)}\n >\n {children}\n </chakra.form>\n </FormProvider>\n )\n }\n) as (<TFieldValues extends FieldValues>(\n props: FormProps<TFieldValues> & {\n ref?: React.ForwardedRef<UseFormReturn<TFieldValues>>\n }\n) => React.ReactElement) & {\n displayName?: string\n getResolver?: GetResolver\n getFieldResolver: GetFieldResolver\n}\n\nForm.getFieldResolver = objectFieldResolver\n\nif (__DEV__) {\n Form.displayName = 'Form'\n}\n\nexport type GetResolver = (\n schema: any\n) => <TFieldValues extends FieldValues, TContext>(\n values: UnpackNestedValue<TFieldValues>,\n context: TContext | undefined,\n options: ResolverOptions<TFieldValues>\n) => Promise<ResolverResult<TFieldValues>>\n\nexport type GetFieldResolver = (schema: any) => FieldResolver\n","import * as React from 'react'\n\nimport { chakra, SimpleGrid, SimpleGridProps, useTheme } from '@chakra-ui/react'\nimport { cx, __DEV__ } from '@chakra-ui/utils'\n\nexport type FormLayoutProps = SimpleGridProps\n\ninterface FormLayoutItemProps {\n children: React.ReactNode\n}\n\nconst FormLayoutItem: React.FC<FormLayoutItemProps> = ({ children }) => {\n return <chakra.div>{children}</chakra.div>\n}\n\nif (__DEV__) {\n FormLayoutItem.displayName = 'FormLayoutItem'\n}\n\n/**\n * FormLayout\n *\n * Renders form items in a `SimpleGrid`\n * @see https://chakra-ui.com/docs/layout/simple-grid\n */\nexport const FormLayout = ({ children, ...props }: FormLayoutProps) => {\n const theme = useTheme()\n\n const defaultProps = theme.components?.FormLayout?.defaultProps ?? {\n spacing: 4,\n }\n\n const gridProps = {\n ...defaultProps,\n ...props,\n }\n\n return (\n <SimpleGrid\n {...gridProps}\n className={cx('saas-form__layout', props.className)}\n >\n {React.Children.map(children, (child) => {\n if (React.isValidElement(child)) {\n return <FormLayoutItem>{child}</FormLayoutItem>\n }\n return child\n })}\n </SimpleGrid>\n )\n}\n\nif (__DEV__) {\n FormLayout.displayName = 'FormLayout'\n}\n","import * as React from 'react'\n\nexport const mapNestedFields = (name: string, children: React.ReactNode) => {\n return React.Children.map(children, (child) => {\n if (React.isValidElement(child) && child.props.name) {\n return React.cloneElement(child, {\n ...child.props,\n name: `${name}.${child.props.name}`,\n })\n }\n return child\n })\n}\n","import * as React from 'react'\nimport {\n useFieldArray,\n useFormContext,\n UseFieldArrayReturn,\n} from 'react-hook-form'\n\nimport { createContext } from '@chakra-ui/react-utils'\n\nexport interface UseArrayFieldReturn extends UseFieldArrayReturn {\n /**\n * The array field name\n */\n name: string\n /**\n * The default value for new items\n */\n defaultValue: Record<string, any>\n /**\n * Min amount of items\n */\n min?: number\n /**\n * Max amount of items\n */\n max?: number\n}\n\nexport const [ArrayFieldProvider, useArrayFieldContext] =\n createContext<UseArrayFieldReturn>({\n name: 'ArrayFieldContext',\n })\n\nexport interface UseArrayFieldRowReturn {\n /**\n * Name of the array field including the index, eg 'field.0'\n */\n name: string\n /**\n * The field index\n */\n index: number\n /**\n * Remove this array item\n */\n remove: () => void\n /**\n * True if this is the first item\n */\n isFirst: boolean\n /**\n * True if this is the last item\n */\n isLast: boolean\n}\n\nexport const [ArrayFieldRowProvider, useArrayFieldRowContext] =\n createContext<UseArrayFieldRowReturn>({\n name: 'ArrayFieldRowContext',\n })\n\nexport interface ArrayFieldOptions {\n /**\n * The field name\n */\n name: string\n /**\n * Default value for new values in the array\n */\n defaultValue?: Record<string, any>\n /**\n * Default key name for rows, change this if your data uses a different 'id' field\n * @default \"id\"\n */\n keyName?: string\n min?: number\n max?: number\n}\n\nexport const useArrayField = ({\n name,\n defaultValue = {},\n keyName,\n min,\n max,\n}: ArrayFieldOptions) => {\n const { control } = useFormContext()\n const context = useFieldArray({\n control,\n name,\n keyName,\n })\n\n return {\n ...context,\n name,\n defaultValue,\n min,\n max,\n }\n}\n\nexport interface UseArrayFieldRowProps {\n index: number\n}\n\nexport const useArrayFieldRow = ({ index }: UseArrayFieldRowProps) => {\n const { clearErrors } = useFormContext()\n const { name, remove, fields } = useArrayFieldContext()\n\n React.useEffect(() => {\n // reset errors, to make sure min/max errors reset correctly\n clearErrors(name)\n }, [])\n\n return {\n index,\n isFirst: index === 0,\n isLast: index === fields.length - 1,\n name: `${name}.${index}`,\n remove: React.useCallback(() => {\n clearErrors(name)\n remove(index)\n }, [index]),\n }\n}\n\nexport const useArrayFieldRemoveButton = () => {\n const { isFirst, remove } = useArrayFieldRowContext()\n const { min, fields } = useArrayFieldContext()\n\n const isDisabled = isFirst && !!(min && fields.length <= min)\n\n return {\n onClick: () => remove(),\n isDisabled,\n }\n}\n\nexport const useArrayFieldAddButton = () => {\n const { append, defaultValue, max, fields } = useArrayFieldContext()\n\n const isDisabled = !!(max && fields.length >= max)\n\n return {\n onClick: () =>\n append(defaultValue, {\n shouldFocus: false,\n }),\n isDisabled,\n }\n}\n","import * as React from 'react'\n\nimport { chakra, ResponsiveValue } from '@chakra-ui/system'\nimport { __DEV__ } from '@chakra-ui/utils'\nimport { AddIcon, MinusIcon } from '@chakra-ui/icons'\nimport { IconButton, ButtonProps } from '@saas-ui/button'\n\nimport { FormLayout } from './layout'\nimport { BaseField, FieldProps } from './field'\n\nimport { mapNestedFields } from './utils'\n\nimport {\n useArrayField,\n useArrayFieldRow,\n useArrayFieldContext,\n ArrayFieldProvider,\n ArrayFieldOptions,\n ArrayFieldRowProvider,\n useArrayFieldRowContext,\n useArrayFieldRemoveButton,\n useArrayFieldAddButton,\n UseArrayFieldReturn,\n} from './use-array-field'\n\ninterface ArrayField {\n id: string\n [key: string]: unknown\n}\n\ninterface ArrayFieldRowProps {\n /**\n * Amount of field columns\n */\n columns?: ResponsiveValue<number>\n /**\n * Spacing between fields\n */\n spacing?: ResponsiveValue<string | number>\n /**\n * The array index\n */\n index: number\n\n children: React.ReactNode\n}\n\nexport const ArrayFieldRow: React.FC<ArrayFieldRowProps> = ({\n children,\n columns,\n spacing,\n index,\n}) => {\n return (\n <ArrayFieldRowContainer index={index}>\n <ArrayFieldRowFields columns={columns} spacing={spacing}>\n {children}\n </ArrayFieldRowFields>\n <ArrayFieldRemoveButton />\n </ArrayFieldRowContainer>\n )\n}\n\nif (__DEV__) {\n ArrayFieldRow.displayName = 'ArrayFieldRow'\n}\n\nexport interface ArrayFieldRowFieldsProps {\n /**\n * Amount of field columns\n */\n columns?: ResponsiveValue<number>\n /**\n * Spacing between fields\n */\n spacing?: ResponsiveValue<string | number>\n\n children: React.ReactNode\n}\n\nexport const ArrayFieldRowFields: React.FC<ArrayFieldRowFieldsProps> = ({\n children,\n columns,\n spacing,\n ...layoutProps\n}) => {\n const { name } = useArrayFieldRowContext()\n return (\n <FormLayout\n flex=\"1\"\n columns={columns}\n gridGap={spacing}\n mr=\"2\"\n {...layoutProps}\n >\n {mapNestedFields(name, children)}\n </FormLayout>\n )\n}\n\nif (__DEV__) {\n ArrayFieldRowFields.displayName = 'ArrayFieldRowFields'\n}\n\nexport const ArrayFieldRowContainer: React.FC<ArrayFieldRowProps> = ({\n children,\n index,\n}) => {\n const context = useArrayFieldRow({ index })\n\n const styles = {\n display: 'flex',\n flexDirection: 'row',\n alignItems: 'flex-end',\n width: '100%',\n mb: 4,\n }\n\n return (\n <ArrayFieldRowProvider value={context}>\n <chakra.div __css={styles}>{children}</chakra.div>\n </ArrayFieldRowProvider>\n )\n}\n\nif (__DEV__) {\n ArrayFieldRowContainer.displayName = 'ArrayFieldRowContainer'\n}\n\nexport const ArrayFieldRemoveButton: React.FC<ButtonProps> = (props) => {\n return (\n <IconButton\n icon={<MinusIcon />}\n aria-label=\"Remove row\"\n {...useArrayFieldRemoveButton()}\n {...props}\n />\n )\n}\n\nif (__DEV__) {\n ArrayFieldRemoveButton.displayName = 'ArrayFieldRemoveButton'\n}\n\nexport const ArrayFieldAddButton: React.FC<ButtonProps> = (props) => {\n return (\n <IconButton\n icon={<AddIcon />}\n aria-label=\"Add row\"\n float=\"right\"\n {...useArrayFieldAddButton()}\n {...props}\n />\n )\n}\n\nif (__DEV__) {\n ArrayFieldAddButton.displayName = 'ArrayFieldAddButton'\n}\n\nexport interface ArrayFieldProps\n extends ArrayFieldOptions,\n Omit<FieldProps, 'defaultValue'> {}\n\nexport const ArrayField = React.forwardRef(\n (props: ArrayFieldProps, ref: React.ForwardedRef<UseArrayFieldReturn>) => {\n const { children, ...containerProps } = props\n\n return (\n <ArrayFieldContainer ref={ref} {...containerProps}>\n <ArrayFieldRows>\n {(fields: ArrayField[]) => (\n <>\n {fields.map(({ id }, index: number) => (\n <ArrayFieldRow key={id} index={index}>\n {children}\n </ArrayFieldRow>\n ))}\n </>\n )}\n </ArrayFieldRows>\n <ArrayFieldAddButton />\n </ArrayFieldContainer>\n )\n }\n)\n\nif (__DEV__) {\n ArrayField.displayName = 'ArrayField'\n}\n\nexport interface ArrayFieldRowsProps {\n children: (fields: ArrayField[]) => React.ReactElement | null\n}\n\nexport const ArrayFieldRows = ({\n children,\n}: ArrayFieldRowsProps): React.ReactElement | null => {\n const { fields } = useArrayFieldContext()\n return children(fields)\n}\n\nif (__DEV__) {\n ArrayFieldRows.displayName = 'ArrayFieldRows'\n}\n\nexport const ArrayFieldContainer = React.forwardRef(\n (\n {\n name,\n defaultValue,\n keyName,\n min,\n max,\n children,\n ...fieldProps\n }: ArrayFieldProps,\n ref: React.ForwardedRef<UseArrayFieldReturn>\n ) => {\n const context = useArrayField({\n name,\n defaultValue,\n keyName,\n min,\n max,\n })\n\n // This exposes the useArrayField api through the forwarded ref\n React.useImperativeHandle(ref, () => context, [ref, context])\n\n return (\n <ArrayFieldProvider value={context}>\n <BaseField name={name} {...fieldProps}>\n {children}\n </BaseField>\n </ArrayFieldProvider>\n )\n }\n)\n\nif (__DEV__) {\n ArrayFieldContainer.displayName = 'ArrayFieldContainer'\n}\n","import * as React from 'react'\nimport {\n FormControl,\n FormLabel,\n FormLabelProps,\n ResponsiveValue,\n useStyleConfig,\n} from '@chakra-ui/react'\nimport { __DEV__ } from '@chakra-ui/utils'\n\nimport { FormLayout } from './layout'\nimport { FieldProps } from './field'\n\nimport { mapNestedFields } from './utils'\n\nexport interface ObjectFieldProps extends FieldProps {\n name: string\n children: React.ReactNode\n columns?: ResponsiveValue<number>\n spacing?: ResponsiveValue<string | number>\n}\n\nexport const FormLegend = (props: FormLabelProps) => {\n const styles = useStyleConfig('FormLegend')\n return <FormLabel as=\"legend\" sx={styles} {...props} />\n}\n\nexport const ObjectField: React.FC<ObjectFieldProps> = (props) => {\n const { name, label, hideLabel, children, columns, spacing, ...fieldProps } =\n props\n\n return (\n <FormControl name={name} as=\"fieldset\" {...fieldProps}>\n <FormLegend display={hideLabel ? 'none' : 'block'}>{label}</FormLegend>\n <FormLayout columns={columns} gridGap={spacing}>\n {mapNestedFields(name, children)}\n </FormLayout>\n </FormControl>\n )\n}\n\nif (__DEV__) {\n ObjectField.displayName = 'ObjectField'\n}\n","import * as React from 'react'\nimport { __DEV__ } from '@chakra-ui/utils'\n\nimport { Form } from './form'\nimport { FormLayout } from './layout'\nimport { Field, FieldProps } from './field'\n\nimport { ArrayField } from './array-field'\nimport { ObjectField } from './object-field'\nimport { FieldResolver } from './field-resolver'\n\nexport interface FieldsProps {\n schema: any\n fieldResolver?: FieldResolver\n}\n\nconst mapNestedFields = (resolver: FieldResolver, name: string) => {\n return resolver\n .getNestedFields(name)\n ?.map(\n ({ name, type, ...nestedFieldProps }: FieldProps, i): React.ReactNode => (\n <Field key={name || i} name={name} type={type} {...nestedFieldProps} />\n )\n )\n}\n\nexport const Fields: React.FC<FieldsProps> = ({\n schema,\n fieldResolver,\n ...props\n}) => {\n const resolver = React.useMemo(\n () => fieldResolver || Form.getFieldResolver(schema),\n [schema, fieldResolver]\n )\n\n return (\n <FormLayout {...props}>\n {resolver\n .getFields()\n .map(\n ({\n name,\n type,\n defaultValue,\n ...fieldProps\n }: FieldProps): React.ReactNode => {\n if (type === 'array') {\n return (\n <ArrayField key={name} name={name} {...fieldProps}>\n {mapNestedFields(resolver, name)}\n </ArrayField>\n )\n } else if (type === 'object') {\n return (\n <ObjectField key={name} name={name} {...fieldProps}>\n {mapNestedFields(resolver, name)}\n </ObjectField>\n )\n }\n\n return <Field key={name} name={name} type={type} {...fieldProps} />\n }\n )}\n </FormLayout>\n )\n}\n\nif (__DEV__) {\n Fields.displayName = 'Fields'\n}\n","import * as React from 'react'\n\nimport { useFormContext } from 'react-hook-form'\n\nimport { Button, ButtonProps } from '@saas-ui/button'\n\nimport { forwardRef } from '@chakra-ui/system'\nimport { __DEV__ } from '@chakra-ui/utils'\n\nexport interface SubmitButtonProps extends ButtonProps {\n /**\n * Disable the submit button if the form is untouched.\n *\n * Change the default behavior by updating\n * `SubmitButton.defaultProps.disableIfUntouched`\n */\n disableIfUntouched?: boolean\n /**\n * Disable the submit button if the form is invalid.\n *\n * Change the default behavior by updating\n * `SubmitButton.defaultProps.disableIfInvalid`\n */\n disableIfInvalid?: boolean\n}\n\nexport const SubmitButton = forwardRef<SubmitButtonProps, 'button'>(\n (props, ref) => {\n const { children, disableIfUntouched, disableIfInvalid, ...rest } = props\n const { formState } = useFormContext()\n\n const isDisabled =\n (disableIfUntouched && !formState.isDirty) ||\n (disableIfInvalid && !formState.isValid)\n\n return (\n <Button\n type=\"submit\"\n isLoading={formState.isSubmitting}\n isPrimary\n ref={ref}\n isDisabled={isDisabled}\n {...rest}\n >\n {children}\n </Button>\n )\n }\n)\n\nSubmitButton.defaultProps = {\n label: 'Submit',\n disableIfUntouched: false,\n disableIfInvalid: false,\n}\n\nif (__DEV__) {\n SubmitButton.displayName = 'SubmitButton'\n}\n","import * as React from 'react'\nimport { FieldValues, UseFormReturn } from 'react-hook-form'\nimport { forwardRef } from '@chakra-ui/react'\nimport { __DEV__ } from '@chakra-ui/utils'\n\nimport { Form, FormProps } from './form'\nimport { FormLayout } from './layout'\nimport { Fields } from './fields'\nimport { SubmitButton, SubmitButtonProps } from './submit-button'\nimport { FieldResolver } from '.'\n\ninterface AutoFormOptions {\n /**\n * The submit button label.\n * Pass `null` to render no submit button.\n */\n submitLabel?: React.ReactNode\n /**\n * The schema.\n * Supports object schema, Yup or Zod.\n * @see https://www.saas-ui.dev/docs/forms/auto-form\n */\n schema: any\n /**\n * The field resolver.\n */\n fieldResolver?: any\n}\n\nexport interface AutoFormProps<TFieldValues extends FieldValues>\n extends Omit<FormProps<TFieldValues>, 'schema'>,\n AutoFormOptions {}\n\nexport const AutoForm = forwardRef(\n <TFieldValues extends FieldValues = FieldValues>(\n props: AutoFormProps<TFieldValues>,\n ref: React.ForwardedRef<UseFormReturn<TFieldValues>>\n ) => {\n const {\n schema,\n submitLabel = 'Submit',\n fieldResolver,\n children,\n ...rest\n } = props\n\n return (\n <Form {...rest} schema={schema} ref={ref}>\n <FormLayout>\n {<Fields schema={schema} fieldResolver={fieldResolver} />}\n {submitLabel && <SubmitButton label={submitLabel} />}\n {children}\n </FormLayout>\n </Form>\n )\n }\n) as (<TFieldValues extends FieldValues>(\n props: AutoFormProps<TFieldValues> & {\n ref?: React.ForwardedRef<UseFormReturn<TFieldValues>>\n }\n) => React.ReactElement) & {\n displayName?: string\n getFieldResolver?: (schema: any) => FieldResolver\n}\n\nif (__DEV__) {\n AutoForm.displayName = 'AutoForm'\n}\n","import * as React from 'react'\nimport { __DEV__ } from '@chakra-ui/utils'\nimport {\n useFormContext,\n useWatch,\n FieldValues,\n UseFormReturn,\n} from 'react-hook-form'\n\nexport interface DisplayIfProps<TFieldValues> {\n children: React.ReactElement\n name: string\n defaultValue?: unknown\n isDisabled?: boolean\n isExact?: boolean\n condition?: (value: unknown, context: UseFormReturn<TFieldValues>) => boolean\n}\n\nexport const DisplayIf = <TFieldValues extends FieldValues = FieldValues>({\n children,\n name,\n defaultValue,\n isDisabled,\n isExact,\n condition = (value) => !!value,\n}: DisplayIfProps<TFieldValues>) => {\n const value = useWatch({\n name,\n defaultValue,\n disabled: isDisabled,\n exact: isExact,\n })\n const context = useFormContext<TFieldValues>()\n return condition(value, context) ? children : null\n}\n\nif (__DEV__) {\n DisplayIf.displayName = 'DisplayIf'\n}\n","import * as React from 'react'\nimport { FieldValues, SubmitHandler } from 'react-hook-form'\nimport { createContext } from '@chakra-ui/react-utils'\nimport {\n useStepper,\n useStep,\n UseStepperProps,\n UseStepperReturn,\n} from '@saas-ui/stepper'\n\nexport interface StepState {\n name: string\n schema?: any\n resolver?: any\n isActive?: boolean\n isCompleted?: boolean\n}\n\nexport interface StepFormContext extends UseStepperReturn {\n updateStep(state: StepState): void\n steps: Record<string, StepState>\n}\n\nexport const [StepFormProvider, useStepFormContext] =\n createContext<StepFormContext>({\n name: 'StepFormContext',\n errorMessage:\n 'useStepFormContext: `context` is undefined. Seems you forgot to wrap step form components in `<StepForm />`',\n })\n\nimport { FormProps } from './form'\n\nexport interface UseStepFormProps<\n TFieldValues extends FieldValues = FieldValues\n> extends Omit<UseStepperProps, 'onChange'>,\n Omit<FormProps<TFieldValues>, 'children'> {\n children:\n | React.ReactNode\n | ((stepper: UseStepFormReturn<TFieldValues>) => React.ReactElement)\n}\n\nexport interface UseStepFormReturn<\n TFieldValues extends FieldValues = FieldValues\n> extends UseStepperReturn {\n getFormProps(): {\n onSubmit: SubmitHandler<TFieldValues>\n schema?: any\n resolver?: any\n }\n updateStep(step: any): void\n steps: Record<string, any>\n}\n\nexport function useStepForm<TFieldValues extends FieldValues = FieldValues>(\n props: UseStepFormProps<TFieldValues>\n): UseStepFormReturn<TFieldValues> {\n const { onChange, ...rest } = props\n const stepper = useStepper(rest)\n\n const { activeStep, isLastStep, nextStep } = stepper\n\n const [steps, updateSteps] = React.useState<Record<string, StepState>>({})\n\n const onSubmitStep: SubmitHandler<TFieldValues> = React.useCallback(\n async (data) => {\n if (isLastStep) {\n return props\n .onSubmit?.(data)\n .then(() => {\n const step = steps[activeStep]\n updateStep({\n ...step,\n isCompleted: true,\n })\n })\n .then(nextStep) // Show completed step\n }\n\n nextStep()\n },\n [activeStep, isLastStep]\n )\n\n const getFormProps = React.useCallback(() => {\n const step = steps[activeStep]\n return {\n onSubmit: onSubmitStep,\n schema: step?.schema,\n resolver: step?.resolver,\n }\n }, [steps, onSubmitStep, activeStep])\n\n const updateStep = React.useCallback(\n (step: StepState) => {\n updateSteps((steps) => {\n return {\n ...steps,\n [step.name]: step,\n }\n })\n },\n [steps]\n )\n\n return {\n getFormProps,\n updateStep,\n steps,\n ...stepper,\n }\n}\n\nexport interface UseFormStepProps {\n name: string\n schema?: any\n resolver?: any\n}\n\nexport function useFormStep(props: UseFormStepProps): StepState {\n const { name, schema, resolver } = props\n const step = useStep({ name })\n\n const { steps, updateStep } = useStepFormContext()\n\n React.useEffect(() => {\n updateStep({ name, schema, resolver })\n }, [name, schema])\n\n return {\n ...step,\n ...(steps[name] || { name, schema }),\n }\n}\n","import * as React from 'react'\n\nimport { FieldValues, UseFormReturn } from 'react-hook-form'\n\nimport { chakra, HTMLChakraProps } from '@chakra-ui/system'\n\nimport { callAllHandlers, runIfFn, cx, __DEV__ } from '@chakra-ui/utils'\n\nimport {\n StepperProvider,\n StepperSteps,\n StepperStepsProps,\n StepperStep,\n useStepperContext,\n StepperContainer,\n} from '@saas-ui/stepper'\nimport { Button, ButtonProps } from '@saas-ui/button'\n\nimport { Form, FormProps } from './form'\nimport { SubmitButton } from './submit-button'\n\nimport {\n useStepForm,\n useFormStep,\n StepFormProvider,\n UseStepFormProps,\n} from './use-step-form'\n\nexport interface StepFormProps<TFieldValues extends FieldValues = FieldValues>\n extends UseStepFormProps<TFieldValues> {}\n\nexport const StepForm = React.forwardRef(\n <TFieldValues extends FieldValues = FieldValues>(\n props: StepFormProps<TFieldValues>,\n ref: React.ForwardedRef<UseFormReturn<TFieldValues>>\n ) => {\n const { children, ...rest } = props\n\n const stepper = useStepForm<TFieldValues>(props)\n\n const { getFormProps, ...ctx } = stepper\n\n const context = React.useMemo(() => ctx, [ctx])\n\n return (\n <StepperProvider value={context}>\n <StepFormProvider value={context}>\n <Form ref={ref} {...rest} {...getFormProps()}>\n {runIfFn(children, stepper)}\n </Form>\n </StepFormProvider>\n </StepperProvider>\n )\n }\n) as <TFieldValues extends FieldValues>(\n props: FormProps<TFieldValues> & {\n ref?: React.ForwardedRef<UseFormReturn<TFieldValues>>\n }\n) => React.ReactElement\n\nexport interface FormStepOptions {\n /**\n * The step name\n */\n name: string\n /**\n * Schema\n */\n schema?: any\n /**\n * Hook Form Resolver\n */\n resolver?: any\n}\n\nexport const FormStepper: React.FC<StepperStepsProps> = (props) => {\n const { activeIndex, setIndex } = useStepperContext()\n\n const { children } = props\n\n const elements = React.Children.map(children, (child) => {\n if (React.isValidElement(child) && child?.type === FormStep) {\n const { isCompleted } = useFormStep(child.props) // Register this step\n return (\n <StepperStep\n name={child.props.name}\n title={child.props.title}\n isCompleted={isCompleted}\n >\n {child.props.children}\n </StepperStep>\n )\n }\n return child\n })\n\n const onChange = React.useCallback((i: number) => {\n setIndex(i)\n }, [])\n\n return (\n <StepperContainer step={activeIndex} onChange={onChange}>\n <StepperSteps mb=\"4\" {...props}>\n {elements}\n </StepperSteps>\n </StepperContainer>\n )\n}\n\nexport interface FormStepProps\n extends FormStepOptions,\n HTMLChakraProps<'div'> {}\n\nexport const FormStep: React.FC<FormStepProps> = (props) => {\n const { name, schema, resolver, children, className, ...rest } = props\n const step = useFormStep({ name, schema, resolver })\n\n const { isActive } = step\n\n return isActive ? (\n <chakra.div {...rest} className={cx('saas-form__step', className)}>\n {children}\n </chakra.div>\n ) : null\n}\n\nif (__DEV__) {\n FormStep.displayName = 'FormStep'\n}\n\nexport const PrevButton: React.FC<ButtonProps> = (props) => {\n const { isFirstStep, isCompleted, prevStep } = useStepperContext()\n\n return (\n <Button\n isDisabled={isFirstStep || isCompleted}\n label=\"Back\"\n {...props}\n className={cx('saas-form__prev-button', props.className)}\n onClick={callAllHandlers(props.onClick, prevStep)}\n />\n )\n}\n\nif (__DEV__) {\n PrevButton.displayName = 'PrevButton'\n}\n\nexport interface NextButtonProps extends ButtonProps {\n submitLabel?: string\n}\n\nexport const NextButton: React.FC<NextButtonProps> = (props) => {\n const { label = 'Next', submitLabel = 'Complete', ...rest } = props\n const { isLastStep, isCompleted } = useStepperContext()\n\n return (\n <SubmitButton\n isDisabled={isCompleted}\n label={isLastStep || isCompleted ? submitLabel : label}\n {...rest}\n className={cx('saas-form__next-button', props.className)}\n />\n )\n}\n\nif (__DEV__) {\n NextButton.displayName = 'NextButton'\n}\n"],"names":["_excluded","DisplayField","_ref","name","label","props","React","createElement","FormControl","FormLabel","htmlFor","Text","fontSize","FormValue","__DEV__","displayName","_ref2","getValues","useFormContext","_excluded2","_excluded3","_excluded4","_excluded5","_excluded6","_excluded7","_excluded8","_excluded9","inputTypes","BaseField","help","variant","hideLabel","children","controlProps","_objectWithoutPropertiesLoose","error","formState","get","errors","getError","_extends","isInvalid","Box","message","FormHelperText","FormErrorMessage","Field","forwardRef","ref","_props$type","type","withControlledInput","InputComponent","_ref3","rules","inputProps","_useFormContext2","Controller","control","render","field","_ref4$field","useMergeRefs","withUncontrolledInput","_ref5","_register","register","registerFieldType","component","options","id","isDisabled","isReadOnly","isRequired","inputRules","required","undefined","createField","isControlled","split","map","part","charAt","toUpperCase","slice","join","InputField","_ref6$type","_ref6","rest","Input","NumberInputField","NumberInput","PasswordInputFIeld","PasswordInput","TextareaField","Textarea","SwitchField","_ref7","Switch","SelectField","Select","CheckboxField","_ref8","Checkbox","RadioField","RadioInput","PinField","PinInput","NativeSelectField","NativeSelect","mapFields","schema","Object","entries","objectFieldResolver","getFields","getNestedFields","_field$items","items","properties","Form","mode","_props$mode","resolver","reValidateMode","shouldFocusError","shouldUnregister","shouldUseNativeValidation","criteriaMode","delayError","defaultValues","onSubmit","onError","formRef","form","getResolver","methods","useForm","handleSubmit","useImperativeHandle","FormProvider","chakra","className","cx","getFieldResolver","FormLayoutItem","div","FormLayout","_theme$components$For","_theme$components","_theme$components$For2","gridProps","theme","useTheme","components","defaultProps","spacing","SimpleGrid","Children","child","isValidElement","mapNestedFields","cloneElement","createContext","ArrayFieldProvider","useArrayFieldContext","_createContext","ArrayFieldRowProvider","useArrayFieldRowContext","useArrayField","_ref$defaultValue","defaultValue","keyName","min","max","context","useFieldArray","useArrayFieldRow","index","clearErrors","_useArrayFieldContext","remove","fields","useEffect","isFirst","isLast","length","useCallback","useArrayFieldRemoveButton","_useArrayFieldRowCont","_useArrayFieldContext2","onClick","append","_useArrayFieldContext3","shouldFocus","ArrayFieldRow","ArrayFieldRowContainer","ArrayFieldRowFields","columns","ArrayFieldRemoveButton","layoutProps","flex","gridGap","mr","value","__css","display","flexDirection","alignItems","width","mb","IconButton","icon","MinusIcon","ArrayFieldAddButton","AddIcon","float","useArrayFieldAddButton","ArrayField","containerProps","ArrayFieldContainer","ArrayFieldRows","key","_ref4","fieldProps","FormLegend","styles","useStyleConfig","as","sx","ObjectField","_resolver$getNestedFi","i","nestedFieldProps","Fields","fieldResolver","useMemo","SubmitButton","disableIfUntouched","disableIfInvalid","Button","isLoading","isSubmitting","isPrimary","isDirty","isValid","AutoForm","_props$submitLabel","submitLabel","DisplayIf","condition","_ref$condition","useWatch","disabled","exact","isExact","errorMessage","StepFormProvider","useStepFormContext","useStepForm","onChange","stepper","useStepper","activeStep","isLastStep","nextStep","_React$useState","useState","steps","updateSteps","onSubmitStep","data","then","updateStep","step","isCompleted","Promise","resolve","e","reject","getFormProps","_extends2","useFormStep","useStep","_useStepFormContext","StepForm","ctx","StepperProvider","runIfFn","FormStep","isActive","PrevButton","_useStepperContext2","useStepperContext","prevStep","isFirstStep","callAllHandlers","NextButton","_props$label","_useStepperContext3","_useStepperContext","activeIndex","setIndex","elements","StepperStep","title","StepperContainer","StepperSteps"],"mappings":"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"}
@@ -1,2 +1,2 @@
1
- import*as e from"react";import{__DEV__ as t,get as a,cx as l,runIfFn as r,callAllHandlers as n}from"@chakra-ui/utils";import{useFormContext as s,get as i,Controller as o,useForm as m,FormProvider as c,useFieldArray as d,useWatch as u}from"react-hook-form";import{FormControl as p,FormLabel as f,Text as h,forwardRef as b,Switch as y,Checkbox as E,Box as v,FormHelperText as N,FormErrorMessage as F,useMergeRefs as g,Input as x,Textarea as C,chakra as k,useTheme as S,SimpleGrid as R,useStyles as V}from"@chakra-ui/react";import{NumberInput as L}from"@saas-ui/number-input";import{PasswordInput as w}from"@saas-ui/password-input";import{RadioInput as I}from"@saas-ui/radio";import{PinInput as A}from"@saas-ui/pin-input";import{Select as D,NativeSelect as O}from"@saas-ui/select";import{chakra as j,forwardRef as B,useMultiStyleConfig as U,StylesProvider as _}from"@chakra-ui/system";import{MinusIcon as M,AddIcon as P}from"@chakra-ui/icons";import{IconButton as $,Button as q}from"@saas-ui/button";import{createContext as G}from"@chakra-ui/react-utils";import{useStepper as H,useStep as z,StepperProvider as J,StepperStep as K,StepperSteps as Q,useStepperContext as T}from"@saas-ui/stepper";export*from"@saas-ui/input-right-button";function W(){return W=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var a=arguments[t];for(var l in a)Object.prototype.hasOwnProperty.call(a,l)&&(e[l]=a[l])}return e},W.apply(this,arguments)}function X(e,t){if(null==e)return{};var a,l,r={},n=Object.keys(e);for(l=0;l<n.length;l++)t.indexOf(a=n[l])>=0||(r[a]=e[a]);return r}const Y=["name","label","placeholder"],Z=t=>{let{name:a,label:l}=t,r=X(t,Y);/*#__PURE__*/return e.createElement(p,r,l?/*#__PURE__*/e.createElement(f,{htmlFor:a},l):null,/*#__PURE__*/e.createElement(h,{fontSize:"md"},/*#__PURE__*/e.createElement(ee,{name:a})))};t&&(Z.displayName="DisplayField");const ee=({name:e})=>{const{getValues:t}=s();return t(e)||null};t&&(ee.displayName="FormValue");const te=["name","label","help","variant","hideLabel","children"],ae=["id","name","label","help","isDisabled","isInvalid","isReadOnly","isRequired","rules","variant"],le=["name","rules"],re=["ref"],ne=["name","rules"],se=["ref"],ie=["label"],oe=["label"],me={},ce="text",de=t=>{const{name:a,label:l,help:r,variant:n,hideLabel:o,children:m}=t,c=X(t,te),{formState:d}=s(),u=((e,t)=>i(t.errors,e))(a,d);/*#__PURE__*/return e.createElement(p,W({variant:n},c,{isInvalid:!!u}),l&&!o?/*#__PURE__*/e.createElement(f,{variant:n},l):null,/*#__PURE__*/e.createElement(v,null,m,!r||null!=u&&u.message?null:/*#__PURE__*/e.createElement(N,null,r),(null==u?void 0:u.message)&&/*#__PURE__*/e.createElement(F,null,null==u?void 0:u.message)))};t&&(de.displayName="BaseField");const ue=b((t,a)=>{const{type:l=ce}=t,r=(e=>me[e]||me[ce])(l);/*#__PURE__*/return e.createElement(r,W({ref:a},t))}),pe=t=>b((a,l)=>{let{name:r,rules:n}=a,i=X(a,le);const{control:m}=s();/*#__PURE__*/return e.createElement(o,{name:r,control:m,rules:n,render:a=>{let{field:{ref:r}}=a,n=X(a.field,re);/*#__PURE__*/return e.createElement(t,W({},n,i,{ref:g(l,r)}))}})}),fe=t=>b((a,l)=>{let{name:r,rules:n}=a,i=X(a,ne);const{register:o}=s(),m=o(r,n),{ref:c}=m,d=X(m,se);/*#__PURE__*/return e.createElement(t,W({},d,i,{ref:g(l,c)}))}),he=(t,a,l)=>{let r;r=null!=l&&l.isControlled?pe(a):fe(a);const n=((t,{displayName:a,hideLabel:l,BaseField:r})=>{const n=b((a,n)=>{const{id:s,name:i,label:o,help:m,isDisabled:c,isInvalid:d,isReadOnly:u,isRequired:p,rules:f,variant:h}=a,b=X(a,ae),y=W({required:p},f);/*#__PURE__*/return e.createElement(r,{id:s,name:i,label:o,help:m,hideLabel:l,isDisabled:c,isInvalid:d,isReadOnly:u,isRequired:p,variant:h},/*#__PURE__*/e.createElement(t,W({ref:n,id:s,name:i,label:o,rules:y},b)))});return n.displayName=a,n})(r,{displayName:`${t.split("-").map(e=>e.charAt(0).toUpperCase()+e.slice(1)).join("")}Field`,hideLabel:null==l?void 0:l.hideLabel,BaseField:(null==l?void 0:l.BaseField)||de});return me[t]=n,n},be=he("text",x),ye=he("number",L,{isControlled:!0}),Ee=he("password",w),ve=he("textarea",C),Ne=he("switch",b((t,a)=>{let{label:l}=t,r=X(t,ie);/*#__PURE__*/return e.createElement(y,W({ref:a},r),l)}),{isControlled:!0,hideLabel:!0}),Fe=he("select",D,{isControlled:!0}),ge=he("checkbox",b((t,a)=>{let{label:l}=t,r=X(t,oe);/*#__PURE__*/return e.createElement(E,W({ref:a},r),l)}),{hideLabel:!0}),xe=he("radio",I,{isControlled:!0}),Ce=he("pin",A,{isControlled:!0}),ke=he("native-select",O,{isControlled:!0}),Se=e=>e&&Object.entries(e).map(([e,t])=>W({},t,{name:e})),Re=e=>({getFields:()=>Se(e),getNestedFields:t=>{var l;const r=a(e,t);return r?"object"===(null==(l=r.items)?void 0:l.type)?Se(r.items.properties):"object"===r.type?Se(r.properties):[r.items]:[]}}),Ve=["mode","resolver","reValidateMode","shouldFocusError","shouldUnregister","shouldUseNativeValidation","criteriaMode","delayError","schema","defaultValues","onSubmit","onError","formRef","children"],Le=b((t,a)=>{const{mode:r="all",resolver:n,reValidateMode:s,shouldFocusError:i,shouldUnregister:o,shouldUseNativeValidation:d,criteriaMode:u,delayError:p,schema:f,defaultValues:h,onSubmit:b,onError:y,formRef:E,children:v}=t,N=X(t,Ve),F={mode:r,resolver:n,defaultValues:h,reValidateMode:s,shouldFocusError:i,shouldUnregister:o,shouldUseNativeValidation:d,criteriaMode:u,delayError:p};f&&!n&&(F.resolver=null==Le.getResolver?void 0:Le.getResolver(f));const g=m(F),{handleSubmit:x}=g;return e.useImperativeHandle(a,()=>g,[a,g]),/*#__PURE__*/e.createElement(c,g,/*#__PURE__*/e.createElement(k.form,W({ref:E,onSubmit:x(b,y)},N,{className:l("saas-form",t.className)}),v))});Le.getFieldResolver=Re,t&&(Le.displayName="Form");const we=["children"],Ie=({children:t})=>/*#__PURE__*/e.createElement(k.div,null,t);t&&(Ie.displayName="FormLayoutItem");const Ae=t=>{var a,r,n;let{children:s}=t,i=X(t,we);const o=W({},null!=(a=null==(r=S().components)||null==(n=r.FormLayout)?void 0:n.defaultProps)?a:{spacing:4},i);/*#__PURE__*/return e.createElement(R,W({},o,{className:l("saas-form__layout",i.className)}),e.Children.map(s,t=>e.isValidElement(t)?/*#__PURE__*/e.createElement(Ie,null,t):t))};t&&(Ae.displayName="FormLayout");const De=(t,a)=>e.Children.map(a,a=>e.isValidElement(a)&&a.props.name?e.cloneElement(a,W({},a.props,{name:`${t}.${a.props.name}`})):a),[Oe,je]=G({name:"ArrayFieldContext"}),[Be,Ue]=G({name:"ArrayFieldRowContext"}),_e=({name:e,defaultValue:t={},keyName:a,min:l,max:r})=>{const{control:n}=s();return W({},d({control:n,name:e,keyName:a}),{name:e,defaultValue:t,min:l,max:r})},Me=({index:t})=>{const{clearErrors:a}=s(),{name:l,remove:r,fields:n}=je();return e.useEffect(()=>{a(l)},[]),{index:t,isFirst:0===t,isLast:t===n.length-1,name:`${l}.${t}`,remove:e.useCallback(()=>{a(l),r(t)},[t])}},Pe=()=>{const{isFirst:e,remove:t}=Ue(),{min:a,fields:l}=je();return{onClick:()=>t(),isDisabled:e&&!!(a&&l.length<=a)}},$e=()=>{const{append:e,defaultValue:t,max:a,fields:l}=je();return{onClick:()=>e(t,{shouldFocus:!1}),isDisabled:!!(a&&l.length>=a)}},qe=["children","columns","spacing"],Ge=["children"],He=["name","defaultValue","keyName","min","max","children"],ze=({children:t,columns:a,spacing:l,index:r})=>/*#__PURE__*/e.createElement(Ke,{index:r},/*#__PURE__*/e.createElement(Je,{columns:a,spacing:l},t),/*#__PURE__*/e.createElement(Qe,null));t&&(ze.displayName="ArrayFieldRow");const Je=t=>{let{children:a,columns:l,spacing:r}=t,n=X(t,qe);const{name:s}=Ue();/*#__PURE__*/return e.createElement(Ae,W({flex:"1",columns:l,gridGap:r,mr:"2"},n),De(s,a))};t&&(Je.displayName="ArrayFieldRowFields");const Ke=({children:t,index:a})=>{const l=Me({index:a});/*#__PURE__*/return e.createElement(Be,{value:l},/*#__PURE__*/e.createElement(j.div,{__css:{display:"flex",flexDirection:"row",alignItems:"flex-end",width:"100%",mb:4}},t))};t&&(Ke.displayName="ArrayFieldRowContainer");const Qe=t=>/*#__PURE__*/e.createElement($,W({icon:/*#__PURE__*/e.createElement(M,null),"aria-label":"Remove row"},Pe(),t));t&&(Qe.displayName="ArrayFieldRemoveButton");const Te=t=>/*#__PURE__*/e.createElement($,W({icon:/*#__PURE__*/e.createElement(P,null),"aria-label":"Add row",float:"right"},$e(),t));t&&(Te.displayName="ArrayFieldAddButton");const We=e.forwardRef((t,a)=>{const{children:l}=t,r=X(t,Ge);/*#__PURE__*/return e.createElement(Ye,W({ref:a},r),/*#__PURE__*/e.createElement(Xe,null,t=>/*#__PURE__*/e.createElement(e.Fragment,null,t.map(({id:t},a)=>/*#__PURE__*/e.createElement(ze,{key:t,index:a},l)))),/*#__PURE__*/e.createElement(Te,null))});t&&(We.displayName="ArrayField");const Xe=({children:e})=>{const{fields:t}=je();return e(t)};t&&(Xe.displayName="ArrayFieldRows");const Ye=e.forwardRef((t,a)=>{let{name:l,defaultValue:r,keyName:n,min:s,max:i,children:o}=t,m=X(t,He);const c=_e({name:l,defaultValue:r,keyName:n,min:s,max:i});return e.useImperativeHandle(a,()=>c,[a,c]),/*#__PURE__*/e.createElement(Oe,{value:c},/*#__PURE__*/e.createElement(de,W({name:l},m),o))});t&&(Ye.displayName="ArrayFieldContainer");const Ze=["name","label","hideLabel","children","columns","spacing"],et=t=>{const a=V();/*#__PURE__*/return e.createElement(f,W({as:"legend",sx:a.legend},t))},tt=t=>{const{name:a,label:l,hideLabel:r,children:n,columns:s,spacing:i}=t,o=X(t,Ze);/*#__PURE__*/return e.createElement(p,W({name:a,as:"fieldset"},o),/*#__PURE__*/e.createElement(et,{display:r?"none":"block"},l),/*#__PURE__*/e.createElement(Ae,{columns:s,gridGap:i},De(a,n)))};t&&(tt.displayName="ObjectField");const at=["name","type"],lt=["schema","fieldResolver"],rt=["name","type","defaultValue"],nt=(t,a)=>{var l;return null==(l=t.getNestedFields(a))?void 0:l.map((t,a)=>{let{name:l,type:r}=t,n=X(t,at);/*#__PURE__*/return e.createElement(ue,W({key:l||a,name:l,type:r},n))})},st=t=>{let{schema:a,fieldResolver:l}=t,r=X(t,lt);const n=e.useMemo(()=>l||Le.getFieldResolver(a),[a,l]);/*#__PURE__*/return e.createElement(Ae,r,n.getFields().map(t=>{let{name:a,type:l}=t,r=X(t,rt);return"array"===l?/*#__PURE__*/e.createElement(We,W({key:a,name:a},r),nt(n,a)):"object"===l?/*#__PURE__*/e.createElement(tt,W({key:a,name:a},r),nt(n,a)):/*#__PURE__*/e.createElement(ue,W({key:a,name:a,type:l},r))}))};t&&(st.displayName="Fields");const it=["children","disableIfUntouched","disableIfInvalid"],ot=B((t,a)=>{const{children:l,disableIfUntouched:r,disableIfInvalid:n}=t,i=X(t,it),{formState:o}=s();/*#__PURE__*/return e.createElement(q,W({type:"submit",isLoading:o.isSubmitting,isPrimary:!0,ref:a,isDisabled:r&&!o.isDirty||n&&!o.isValid},i),l)});ot.defaultProps={label:"Submit",disableIfUntouched:!1,disableIfInvalid:!1},t&&(ot.displayName="SubmitButton");const mt=["schema","submitLabel","fieldResolver"],ct=b((t,a)=>{const{schema:l,submitLabel:r="Submit",fieldResolver:n}=t,s=X(t,mt);/*#__PURE__*/return e.createElement(Le,W({},s,{schema:l,ref:a}),/*#__PURE__*/e.createElement(Ae,null,/*#__PURE__*/e.createElement(st,{schema:l,fieldResolver:n}),r&&/*#__PURE__*/e.createElement(ot,{label:r})))});t&&(ct.displayName="AutoForm");const dt=({children:e,name:t,defaultValue:a,isDisabled:l,isExact:r,condition:n=(e=>!!e)})=>n(u({name:t,defaultValue:a,disabled:l,exact:r}),s())?e:null;t&&(dt.displayName="DisplayIf");const[ut,pt]=G({name:"StepFormContext",errorMessage:"useStepFormContext: `context` is undefined. Seems you forgot to wrap step form components in `<StepForm />`"});function ft(t){const a=H(t),{activeStep:l,isLastStep:r,nextStep:n}=a,[s,i]=e.useState({}),o=e.useCallback(async e=>{if(r)return null==t.onSubmit?void 0:t.onSubmit(e).then(()=>{c(W({},s[l],{isCompleted:!0}))}).then(n);n()},[l,r]),m=e.useCallback(()=>{const e=s[l];return{onSubmit:o,schema:null==e?void 0:e.schema,resolver:null==e?void 0:e.resolver}},[s,o,l]),c=e.useCallback(e=>{i(t=>W({},t,{[e.name]:e}))},[s]);return W({getFormProps:m,updateStep:c,steps:s},a)}function ht(t){const{name:a,schema:l,resolver:r}=t,n=z({name:a}),{steps:s,updateStep:i}=pt();return e.useEffect(()=>{i({name:a,schema:l,resolver:r})},[a,l]),W({},n,s[a]||{name:a,schema:l})}const bt=["children"],yt=["getFormProps"],Et=["name","schema","resolver","children","className"],vt=["label","submitLabel"],Nt=e.forwardRef((t,a)=>{const{children:l}=t,n=X(t,bt),s=ft(t),{getFormProps:i}=s,o=X(s,yt),m=e.useMemo(()=>o,[o]);/*#__PURE__*/return e.createElement(J,{value:m},/*#__PURE__*/e.createElement(ut,{value:m},/*#__PURE__*/e.createElement(Le,W({ref:a},n,i()),r(l,s))))}),Ft=t=>{const a=U("Stepper",t),{children:l}=t,r=e.Children.map(l,t=>{if(e.isValidElement(t)&&(null==t?void 0:t.type)===gt){const{isCompleted:a}=ht(t.props);/*#__PURE__*/return e.createElement(K,{name:t.props.name,title:t.props.title,isCompleted:a},t.props.children)}return t});/*#__PURE__*/return e.createElement(_,{value:a},/*#__PURE__*/e.createElement(Q,W({mb:"4"},t),r))},gt=t=>{const{name:a,schema:r,resolver:n,children:s,className:i}=t,o=X(t,Et),m=ht({name:a,schema:r,resolver:n}),{isActive:c}=m;return c?/*#__PURE__*/e.createElement(j.div,W({},o,{className:l("saas-form__step",i)}),s):null};t&&(gt.displayName="FormStep");const xt=t=>{const{isFirstStep:a,isCompleted:r,prevStep:s}=T();/*#__PURE__*/return e.createElement(q,W({isDisabled:a||r,label:"Back"},t,{className:l("saas-form__prev-button",t.className),onClick:n(t.onClick,s)}))};t&&(xt.displayName="PrevButton");const Ct=t=>{const{label:a="Next",submitLabel:r="Complete"}=t,n=X(t,vt),{isLastStep:s,isCompleted:i}=T();/*#__PURE__*/return e.createElement(ot,W({isDisabled:i,label:s||i?r:a},n,{className:l("saas-form__next-button",t.className)}))};t&&(Ct.displayName="NextButton");export{We as ArrayField,Te as ArrayFieldAddButton,Ye as ArrayFieldContainer,Oe as ArrayFieldProvider,Qe as ArrayFieldRemoveButton,ze as ArrayFieldRow,Ke as ArrayFieldRowContainer,Je as ArrayFieldRowFields,Be as ArrayFieldRowProvider,Xe as ArrayFieldRows,ct as AutoForm,de as BaseField,ge as CheckboxField,Z as DisplayField,dt as DisplayIf,ue as Field,st as Fields,Le as Form,Ae as FormLayout,et as FormLegend,gt as FormStep,Ft as FormStepper,ee as FormValue,be as InputField,ke as NativeSelectField,Ct as NextButton,ye as NumberInputField,tt as ObjectField,Ee as PasswordInputFIeld,Ce as PinField,xt as PrevButton,xe as RadioField,Fe as SelectField,Nt as StepForm,ut as StepFormProvider,ot as SubmitButton,Ne as SwitchField,ve as TextareaField,Re as objectFieldResolver,he as registerFieldType,_e as useArrayField,$e as useArrayFieldAddButton,je as useArrayFieldContext,Pe as useArrayFieldRemoveButton,Me as useArrayFieldRow,Ue as useArrayFieldRowContext,ht as useFormStep,ft as useStepForm,pt as useStepFormContext,pe as withControlledInput,fe as withUncontrolledInput};
1
+ import*as e from"react";import{__DEV__ as t,get as a,cx as l,runIfFn as r,callAllHandlers as n}from"@chakra-ui/utils";import{useFormContext as s,get as i,Controller as o,useForm as m,FormProvider as c,useFieldArray as d,useWatch as u}from"react-hook-form";import{FormControl as p,FormLabel as f,Text as h,forwardRef as b,Input as y,Switch as E,Checkbox as v,Box as g,FormHelperText as F,FormErrorMessage as N,useMergeRefs as x,Textarea as C,chakra as k,useTheme as R,SimpleGrid as S,useStyleConfig as V}from"@chakra-ui/react";import{NumberInput as L}from"@saas-ui/number-input";import{PasswordInput as I}from"@saas-ui/password-input";import{RadioInput as w}from"@saas-ui/radio";import{PinInput as A}from"@saas-ui/pin-input";import{Select as D,NativeSelect as O}from"@saas-ui/select";import{chakra as j,forwardRef as B}from"@chakra-ui/system";import{MinusIcon as U,AddIcon as _}from"@chakra-ui/icons";import{IconButton as M,Button as P}from"@saas-ui/button";import{createContext as $}from"@chakra-ui/react-utils";import{useStepper as q,useStep as G,StepperProvider as H,useStepperContext as z,StepperStep as J,StepperContainer as K,StepperSteps as Q}from"@saas-ui/stepper";export*from"@saas-ui/input-right-button";function T(){return T=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var a=arguments[t];for(var l in a)Object.prototype.hasOwnProperty.call(a,l)&&(e[l]=a[l])}return e},T.apply(this,arguments)}function W(e,t){if(null==e)return{};var a,l,r={},n=Object.keys(e);for(l=0;l<n.length;l++)t.indexOf(a=n[l])>=0||(r[a]=e[a]);return r}const X=["name","label","placeholder"],Y=t=>{let{name:a,label:l}=t,r=W(t,X);/*#__PURE__*/return e.createElement(p,r,l?/*#__PURE__*/e.createElement(f,{htmlFor:a},l):null,/*#__PURE__*/e.createElement(h,{fontSize:"md"},/*#__PURE__*/e.createElement(Z,{name:a})))};t&&(Y.displayName="DisplayField");const Z=({name:e})=>{const{getValues:t}=s();return t(e)||null};t&&(Z.displayName="FormValue");const ee=["name","label","help","variant","hideLabel","children"],te=["id","name","label","help","isDisabled","isInvalid","isReadOnly","isRequired","rules","variant"],ae=["name","rules"],le=["ref"],re=["name","rules"],ne=["ref"],se=["type"],ie=["type"],oe=["label","type"],me={},ce="text",de=t=>{const{name:a,label:l,help:r,variant:n,hideLabel:o,children:m}=t,c=W(t,ee),{formState:d}=s(),u=((e,t)=>i(t.errors,e))(a,d);/*#__PURE__*/return e.createElement(p,T({variant:n},c,{isInvalid:!!u}),l&&!o?/*#__PURE__*/e.createElement(f,{variant:n},l):null,/*#__PURE__*/e.createElement(g,null,m,!r||null!=u&&u.message?null:/*#__PURE__*/e.createElement(F,null,r),(null==u?void 0:u.message)&&/*#__PURE__*/e.createElement(N,null,null==u?void 0:u.message)))};t&&(de.displayName="BaseField");const ue=b((t,a)=>{const{type:l=ce}=t,r=(e=>me[e]||me[ce])(l);/*#__PURE__*/return e.createElement(r,T({ref:a},t))}),pe=t=>b((a,l)=>{let{name:r,rules:n}=a,i=W(a,ae);const{control:m}=s();/*#__PURE__*/return e.createElement(o,{name:r,control:m,rules:n,render:a=>{let{field:{ref:r}}=a,n=W(a.field,le);/*#__PURE__*/return e.createElement(t,T({},n,i,{ref:x(l,r)}))}})}),fe=t=>b((a,l)=>{let{name:r,rules:n}=a,i=W(a,re);const{register:o}=s(),m=o(r,n),{ref:c}=m,d=W(m,ne);/*#__PURE__*/return e.createElement(t,T({},d,i,{ref:x(l,c)}))}),he=(t,a,l)=>{let r;r=null!=l&&l.isControlled?pe(a):fe(a);const n=((t,{displayName:a,hideLabel:l,BaseField:r})=>{const n=b((a,n)=>{const{id:s,name:i,label:o,help:m,isDisabled:c,isInvalid:d,isReadOnly:u,isRequired:p,rules:f,variant:h}=a,b=W(a,te),y=T({required:p},f);/*#__PURE__*/return e.createElement(r,{id:s,name:i,label:o,help:m,hideLabel:l,isDisabled:c,isInvalid:d,isReadOnly:u,isRequired:p,variant:h},/*#__PURE__*/e.createElement(t,T({ref:n,id:s,name:i,label:l?o:void 0,rules:y},b)))});return n.displayName=a,n})(r,{displayName:`${t.split("-").map(e=>e.charAt(0).toUpperCase()+e.slice(1)).join("")}Field`,hideLabel:null==l?void 0:l.hideLabel,BaseField:(null==l?void 0:l.BaseField)||de});return me[t]=n,n},be=he("text",b((t,a)=>{let{type:l="text"}=t,r=W(t,se);/*#__PURE__*/return e.createElement(y,T({type:l},r,{ref:a}))})),ye=he("number",L,{isControlled:!0}),Ee=he("password",I),ve=he("textarea",C),ge=he("switch",b((t,a)=>{let l=W(t,ie);/*#__PURE__*/return e.createElement(E,T({},l,{ref:a}))}),{isControlled:!0}),Fe=he("select",D,{isControlled:!0}),Ne=he("checkbox",b((t,a)=>{let{label:l}=t,r=W(t,oe);/*#__PURE__*/return e.createElement(v,T({ref:a},r),l)}),{hideLabel:!0}),xe=he("radio",w,{isControlled:!0}),Ce=he("pin",A,{isControlled:!0}),ke=he("native-select",O,{isControlled:!0}),Re=["items"],Se=e=>e&&Object.entries(e).map(([e,t])=>T({},W(t,Re),{name:e})),Ve=e=>({getFields:()=>Se(e),getNestedFields:t=>{var l;const r=a(e,t);return r?"object"===(null==(l=r.items)?void 0:l.type)?Se(r.items.properties):"object"===r.type?Se(r.properties):[r.items]:[]}}),Le=["mode","resolver","reValidateMode","shouldFocusError","shouldUnregister","shouldUseNativeValidation","criteriaMode","delayError","schema","defaultValues","onSubmit","onError","formRef","children"],Ie=b((t,a)=>{const{mode:r="all",resolver:n,reValidateMode:s,shouldFocusError:i,shouldUnregister:o,shouldUseNativeValidation:d,criteriaMode:u,delayError:p,schema:f,defaultValues:h,onSubmit:b,onError:y,formRef:E,children:v}=t,g=W(t,Le),F={mode:r,resolver:n,defaultValues:h,reValidateMode:s,shouldFocusError:i,shouldUnregister:o,shouldUseNativeValidation:d,criteriaMode:u,delayError:p};f&&!n&&(F.resolver=null==Ie.getResolver?void 0:Ie.getResolver(f));const N=m(F),{handleSubmit:x}=N;return e.useImperativeHandle(a,()=>N,[a,N]),/*#__PURE__*/e.createElement(c,N,/*#__PURE__*/e.createElement(k.form,T({ref:E,onSubmit:x(b,y)},g,{className:l("saas-form",t.className)}),v))});Ie.getFieldResolver=Ve,t&&(Ie.displayName="Form");const we=["children"],Ae=({children:t})=>/*#__PURE__*/e.createElement(k.div,null,t);t&&(Ae.displayName="FormLayoutItem");const De=t=>{var a,r,n;let{children:s}=t,i=W(t,we);const o=T({},null!=(a=null==(r=R().components)||null==(n=r.FormLayout)?void 0:n.defaultProps)?a:{spacing:4},i);/*#__PURE__*/return e.createElement(S,T({},o,{className:l("saas-form__layout",i.className)}),e.Children.map(s,t=>e.isValidElement(t)?/*#__PURE__*/e.createElement(Ae,null,t):t))};t&&(De.displayName="FormLayout");const Oe=(t,a)=>e.Children.map(a,a=>e.isValidElement(a)&&a.props.name?e.cloneElement(a,T({},a.props,{name:`${t}.${a.props.name}`})):a),[je,Be]=$({name:"ArrayFieldContext"}),[Ue,_e]=$({name:"ArrayFieldRowContext"}),Me=({name:e,defaultValue:t={},keyName:a,min:l,max:r})=>{const{control:n}=s();return T({},d({control:n,name:e,keyName:a}),{name:e,defaultValue:t,min:l,max:r})},Pe=({index:t})=>{const{clearErrors:a}=s(),{name:l,remove:r,fields:n}=Be();return e.useEffect(()=>{a(l)},[]),{index:t,isFirst:0===t,isLast:t===n.length-1,name:`${l}.${t}`,remove:e.useCallback(()=>{a(l),r(t)},[t])}},$e=()=>{const{isFirst:e,remove:t}=_e(),{min:a,fields:l}=Be();return{onClick:()=>t(),isDisabled:e&&!!(a&&l.length<=a)}},qe=()=>{const{append:e,defaultValue:t,max:a,fields:l}=Be();return{onClick:()=>e(t,{shouldFocus:!1}),isDisabled:!!(a&&l.length>=a)}},Ge=["children","columns","spacing"],He=["children"],ze=["name","defaultValue","keyName","min","max","children"],Je=({children:t,columns:a,spacing:l,index:r})=>/*#__PURE__*/e.createElement(Qe,{index:r},/*#__PURE__*/e.createElement(Ke,{columns:a,spacing:l},t),/*#__PURE__*/e.createElement(Te,null));t&&(Je.displayName="ArrayFieldRow");const Ke=t=>{let{children:a,columns:l,spacing:r}=t,n=W(t,Ge);const{name:s}=_e();/*#__PURE__*/return e.createElement(De,T({flex:"1",columns:l,gridGap:r,mr:"2"},n),Oe(s,a))};t&&(Ke.displayName="ArrayFieldRowFields");const Qe=({children:t,index:a})=>{const l=Pe({index:a});/*#__PURE__*/return e.createElement(Ue,{value:l},/*#__PURE__*/e.createElement(j.div,{__css:{display:"flex",flexDirection:"row",alignItems:"flex-end",width:"100%",mb:4}},t))};t&&(Qe.displayName="ArrayFieldRowContainer");const Te=t=>/*#__PURE__*/e.createElement(M,T({icon:/*#__PURE__*/e.createElement(U,null),"aria-label":"Remove row"},$e(),t));t&&(Te.displayName="ArrayFieldRemoveButton");const We=t=>/*#__PURE__*/e.createElement(M,T({icon:/*#__PURE__*/e.createElement(_,null),"aria-label":"Add row",float:"right"},qe(),t));t&&(We.displayName="ArrayFieldAddButton");const Xe=e.forwardRef((t,a)=>{const{children:l}=t,r=W(t,He);/*#__PURE__*/return e.createElement(Ze,T({ref:a},r),/*#__PURE__*/e.createElement(Ye,null,t=>/*#__PURE__*/e.createElement(e.Fragment,null,t.map(({id:t},a)=>/*#__PURE__*/e.createElement(Je,{key:t,index:a},l)))),/*#__PURE__*/e.createElement(We,null))});t&&(Xe.displayName="ArrayField");const Ye=({children:e})=>{const{fields:t}=Be();return e(t)};t&&(Ye.displayName="ArrayFieldRows");const Ze=e.forwardRef((t,a)=>{let{name:l,defaultValue:r,keyName:n,min:s,max:i,children:o}=t,m=W(t,ze);const c=Me({name:l,defaultValue:r,keyName:n,min:s,max:i});return e.useImperativeHandle(a,()=>c,[a,c]),/*#__PURE__*/e.createElement(je,{value:c},/*#__PURE__*/e.createElement(de,T({name:l},m),o))});t&&(Ze.displayName="ArrayFieldContainer");const et=["name","label","hideLabel","children","columns","spacing"],tt=t=>{const a=V("FormLegend");/*#__PURE__*/return e.createElement(f,T({as:"legend",sx:a},t))},at=t=>{const{name:a,label:l,hideLabel:r,children:n,columns:s,spacing:i}=t,o=W(t,et);/*#__PURE__*/return e.createElement(p,T({name:a,as:"fieldset"},o),/*#__PURE__*/e.createElement(tt,{display:r?"none":"block"},l),/*#__PURE__*/e.createElement(De,{columns:s,gridGap:i},Oe(a,n)))};t&&(at.displayName="ObjectField");const lt=["name","type"],rt=["schema","fieldResolver"],nt=["name","type","defaultValue"],st=(t,a)=>{var l;return null==(l=t.getNestedFields(a))?void 0:l.map((t,a)=>{let{name:l,type:r}=t,n=W(t,lt);/*#__PURE__*/return e.createElement(ue,T({key:l||a,name:l,type:r},n))})},it=t=>{let{schema:a,fieldResolver:l}=t,r=W(t,rt);const n=e.useMemo(()=>l||Ie.getFieldResolver(a),[a,l]);/*#__PURE__*/return e.createElement(De,r,n.getFields().map(t=>{let{name:a,type:l}=t,r=W(t,nt);return"array"===l?/*#__PURE__*/e.createElement(Xe,T({key:a,name:a},r),st(n,a)):"object"===l?/*#__PURE__*/e.createElement(at,T({key:a,name:a},r),st(n,a)):/*#__PURE__*/e.createElement(ue,T({key:a,name:a,type:l},r))}))};t&&(it.displayName="Fields");const ot=["children","disableIfUntouched","disableIfInvalid"],mt=B((t,a)=>{const{children:l,disableIfUntouched:r,disableIfInvalid:n}=t,i=W(t,ot),{formState:o}=s();/*#__PURE__*/return e.createElement(P,T({type:"submit",isLoading:o.isSubmitting,isPrimary:!0,ref:a,isDisabled:r&&!o.isDirty||n&&!o.isValid},i),l)});mt.defaultProps={label:"Submit",disableIfUntouched:!1,disableIfInvalid:!1},t&&(mt.displayName="SubmitButton");const ct=["schema","submitLabel","fieldResolver","children"],dt=b((t,a)=>{const{schema:l,submitLabel:r="Submit",fieldResolver:n,children:s}=t,i=W(t,ct);/*#__PURE__*/return e.createElement(Ie,T({},i,{schema:l,ref:a}),/*#__PURE__*/e.createElement(De,null,/*#__PURE__*/e.createElement(it,{schema:l,fieldResolver:n}),r&&/*#__PURE__*/e.createElement(mt,{label:r}),s))});t&&(dt.displayName="AutoForm");const ut=({children:e,name:t,defaultValue:a,isDisabled:l,isExact:r,condition:n=(e=>!!e)})=>n(u({name:t,defaultValue:a,disabled:l,exact:r}),s())?e:null;t&&(ut.displayName="DisplayIf");const pt=["onChange"],[ft,ht]=$({name:"StepFormContext",errorMessage:"useStepFormContext: `context` is undefined. Seems you forgot to wrap step form components in `<StepForm />`"});function bt(t){const a=W(t,pt),l=q(a),{activeStep:r,isLastStep:n,nextStep:s}=l,[i,o]=e.useState({}),m=e.useCallback(async e=>{if(n)return null==t.onSubmit?void 0:t.onSubmit(e).then(()=>{d(T({},i[r],{isCompleted:!0}))}).then(s);s()},[r,n]),c=e.useCallback(()=>{const e=i[r];return{onSubmit:m,schema:null==e?void 0:e.schema,resolver:null==e?void 0:e.resolver}},[i,m,r]),d=e.useCallback(e=>{o(t=>T({},t,{[e.name]:e}))},[i]);return T({getFormProps:c,updateStep:d,steps:i},l)}function yt(t){const{name:a,schema:l,resolver:r}=t,n=G({name:a}),{steps:s,updateStep:i}=ht();return e.useEffect(()=>{i({name:a,schema:l,resolver:r})},[a,l]),T({},n,s[a]||{name:a,schema:l})}const Et=["children"],vt=["getFormProps"],gt=["name","schema","resolver","children","className"],Ft=["label","submitLabel"],Nt=e.forwardRef((t,a)=>{const{children:l}=t,n=W(t,Et),s=bt(t),{getFormProps:i}=s,o=W(s,vt),m=e.useMemo(()=>o,[o]);/*#__PURE__*/return e.createElement(H,{value:m},/*#__PURE__*/e.createElement(ft,{value:m},/*#__PURE__*/e.createElement(Ie,T({ref:a},n,i()),r(l,s))))}),xt=t=>{const{activeIndex:a,setIndex:l}=z(),{children:r}=t,n=e.Children.map(r,t=>{if(e.isValidElement(t)&&(null==t?void 0:t.type)===Ct){const{isCompleted:a}=yt(t.props);/*#__PURE__*/return e.createElement(J,{name:t.props.name,title:t.props.title,isCompleted:a},t.props.children)}return t}),s=e.useCallback(e=>{l(e)},[]);/*#__PURE__*/return e.createElement(K,{step:a,onChange:s},/*#__PURE__*/e.createElement(Q,T({mb:"4"},t),n))},Ct=t=>{const{name:a,schema:r,resolver:n,children:s,className:i}=t,o=W(t,gt),m=yt({name:a,schema:r,resolver:n}),{isActive:c}=m;return c?/*#__PURE__*/e.createElement(j.div,T({},o,{className:l("saas-form__step",i)}),s):null};t&&(Ct.displayName="FormStep");const kt=t=>{const{isFirstStep:a,isCompleted:r,prevStep:s}=z();/*#__PURE__*/return e.createElement(P,T({isDisabled:a||r,label:"Back"},t,{className:l("saas-form__prev-button",t.className),onClick:n(t.onClick,s)}))};t&&(kt.displayName="PrevButton");const Rt=t=>{const{label:a="Next",submitLabel:r="Complete"}=t,n=W(t,Ft),{isLastStep:s,isCompleted:i}=z();/*#__PURE__*/return e.createElement(mt,T({isDisabled:i,label:s||i?r:a},n,{className:l("saas-form__next-button",t.className)}))};t&&(Rt.displayName="NextButton");export{Xe as ArrayField,We as ArrayFieldAddButton,Ze as ArrayFieldContainer,je as ArrayFieldProvider,Te as ArrayFieldRemoveButton,Je as ArrayFieldRow,Qe as ArrayFieldRowContainer,Ke as ArrayFieldRowFields,Ue as ArrayFieldRowProvider,Ye as ArrayFieldRows,dt as AutoForm,de as BaseField,Ne as CheckboxField,Y as DisplayField,ut as DisplayIf,ue as Field,it as Fields,Ie as Form,De as FormLayout,tt as FormLegend,Ct as FormStep,xt as FormStepper,Z as FormValue,be as InputField,ke as NativeSelectField,Rt as NextButton,ye as NumberInputField,at as ObjectField,Ee as PasswordInputFIeld,Ce as PinField,kt as PrevButton,xe as RadioField,Fe as SelectField,Nt as StepForm,ft as StepFormProvider,mt as SubmitButton,ge as SwitchField,ve as TextareaField,Ve as objectFieldResolver,he as registerFieldType,Me as useArrayField,qe as useArrayFieldAddButton,Be as useArrayFieldContext,$e as useArrayFieldRemoveButton,Pe as useArrayFieldRow,_e as useArrayFieldRowContext,yt as useFormStep,bt as useStepForm,ht as useStepFormContext,pe as withControlledInput,fe as withUncontrolledInput};
2
2
  //# sourceMappingURL=index.modern.mjs.map