@maif/react-forms 1.6.10 → 1.6.12

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/lib/index.d.ts CHANGED
@@ -170,6 +170,7 @@ declare const SelectInput: <T extends {
170
170
  placeholder?: React$1.ReactNode;
171
171
  className: string;
172
172
  isClearable?: boolean | undefined;
173
+ schema: Schema;
173
174
  }) => JSX.Element;
174
175
 
175
176
  declare type InternalState = {
@@ -319,6 +320,7 @@ interface SchemaEntry {
319
320
  value: any;
320
321
  informations?: Informations;
321
322
  }) => React.ReactNode);
323
+ name?: string;
322
324
  placeholder?: string;
323
325
  defaultValue?: any;
324
326
  help?: string;
package/lib/index.js CHANGED
@@ -1 +1 @@
1
- import*as e from"yup";import*as t from"react";import r,{useRef as n,useEffect as a,useCallback as o,forwardRef as l,useState as i,useMemo as s,useImperativeHandle as c}from"react";import{yupResolver as m}from"@hookform/resolvers/yup";import{useWatch as u,useFormContext as p,useController as d,useFieldArray as f,Controller as b,useForm as v,FormProvider as y}from"react-hook-form";import h from"object-hash";import g from"lodash.debounce";import O from"fast-deep-equal";import{AdapterDateFns as j}from"@mui/x-date-pickers/AdapterDateFns";import{LocalizationProvider as E}from"@mui/x-date-pickers/LocalizationProvider";import{DatePicker as w}from"@mui/x-date-pickers/DatePicker";import{TimePicker as k}from"@mui/x-date-pickers/TimePicker";import{DateTimePicker as x}from"@mui/x-date-pickers/DateTimePicker";import _ from"@mui/material/TextField";import C from"prop-types";import V from"classnames";import N from"react-select/creatable";import S from"react-select";import{EditorState as F}from"@codemirror/state";import{javascript as P}from"@codemirror/lang-javascript";import{html as T}from"@codemirror/lang-html";import{json as M}from"@codemirror/lang-json";import{css as z}from"@codemirror/lang-css";import{markdown as W}from"@codemirror/lang-markdown";import{EditorView as L,highlightSpecialChars as A,drawSelection as D,dropCursor as $,highlightActiveLine as R,keymap as I}from"@codemirror/view";import{history as q,historyKeymap as B}from"@codemirror/history";import{foldGutter as H,foldKeymap as J}from"@codemirror/fold";import{defaultKeymap as U,indentWithTab as K}from"@codemirror/commands";import{indentUnit as Y}from"@codemirror/language";import{lineNumbers as G,highlightActiveLineGutter as Q}from"@codemirror/gutter";import{bracketMatching as X}from"@codemirror/matchbrackets";import{closeBrackets as Z,closeBracketsKeymap as ee}from"@codemirror/closebrackets";import{highlightSelectionMatches as te,searchKeymap as re}from"@codemirror/search";import{autocompletion as ne,completionKeymap as ae}from"@codemirror/autocomplete";import{commentKeymap as oe}from"@codemirror/comment";import{rectangularSelection as le}from"@codemirror/rectangular-selection";import{defaultHighlightStyle as ie}from"@codemirror/highlight";import{lintKeymap as se}from"@codemirror/lint";import{oneDark as ce}from"@codemirror/theme-one-dark";import me from"showdown";import"@fortawesome/fontawesome-free/css/all.css";import"highlight.js/styles/monokai.css";import ue from"highlight.js/lib/core";import pe from"react-tooltip";import{v4 as de}from"uuid";const fe={string:"string",number:"number",bool:"bool",date:"date",object:"object",file:"file",json:"json"};Object.values(fe);const be={array:"array",select:"select",code:"code",markdown:"markdown",text:"textarea",textarea:"textarea",email:"email",password:"password",hidden:"hidden",form:"form",buttonsSelect:"buttons",singleLineCode:"singleLineCode",datetime:"datetime-local",time:"time"};Object.values(be);const ve=(e="Value required")=>t=>t.required(e),ye=(e="That is not a valid url")=>t=>t.url(e),he=(e="That is not a valid email")=>t=>t.email(e),ge=(e="That is not a valid uuid")=>t=>t.uuid(e),Oe=(e=/.*/,t="This field does not match the pattern")=>r=>r.matches(e,{message:t,excludeEmptyString:!0}),je=(e,t="Min value is required")=>r=>r.min(Le(e),t),Ee=(e,t="Max value is required")=>r=>r.max(Le(e),t),we=(e="Positive value is required")=>t=>t.positive(e),ke=(e="Negative value is required")=>t=>t.negative(e),xe=(e="an integer please")=>t=>t.integer(e),_e=(e,t=`This field must be less than ${e}`)=>(r,n,a)=>("number"!=typeof e&&a.push([n,e]),r.lessThan(Le(e),t)),Ce=(e,t=`This field must be more than ${e}`)=>(r,n,a)=>("number"!=typeof e&&a.push([n,e]),r.moreThan(Le(e),t)),Ve=(e,t=`The size of this collection must be ${e}`)=>r=>r.length(Le(e),t),Ne=(e,t="Unsupported File Format")=>r=>{const n=e.map((e=>e.toLowerCase()));return r.test("supportedFormat",t,(e=>!e.length||n.some((t=>e[0].type.toLowerCase().includes(t)))))},Se=(e,t="Unsupported File Format")=>r=>{const n=e.map((e=>e.toLowerCase()));return r.test("unsupportedFormat",t,(e=>!e.length||n.some((t=>e[0].type.toLowerCase().includes(t)))))},Fe=(e,t=`size is excedeed ${e}`)=>r=>r.test("fileSize",t,(t=>!t.length||t[0].size<=Le(e))),Pe=(e,t="Test failed",r)=>n=>n.test(e,t,r),Te=(e,t,r=[],n=[])=>(a,o,l)=>{const i=r.reduce(((e,t)=>t(e,o,l)),a),s=n.reduce(((e,t)=>t(e,o,l)),a);return a.when(e,{is:t,then:i,otherwise:s})},Me=(e,t=`This value must be one of ${e.join(", ")}`)=>r=>r.oneOf(e.map(Le),t),ze=(e,t=`This value can't include the following values ${e.join(", ")}`)=>r=>r.test("blacklist",t,(t=>!e.some((e=>(t||"").includes(e))))),We=t=>e.ref(t),Le=e=>(null==e?void 0:e.ref)?We(e.ref):e,Ae={required:({message:e="Value required"})=>ve(e),url:({message:e="That is not a valid url"})=>ye(e),email:({message:e="That is not a valid email"})=>he(e),uuid:({message:e="That is not a valid uuid"})=>ge(e),matches:({regexp:e=/.*/,message:t="This field does not match the pattern"})=>Oe(e,t),min:({ref:e,message:t="Min value is required"})=>je(e,t),max:({ref:e,message:t="Max value is required"})=>Ee(e,t),positive:({message:e="Positive value is required"})=>we(e),negative:({message:e="Negative value is required"})=>ke(e),integer:({message:e="an integer please"})=>xe(e),lessThan:({ref:e,message:t=`This field must be less than ${e}`})=>_e(e,t),moreThan:({ref:e,message:t=`This field must be more than ${e}`})=>Ce(e,t),length:({ref:e,message:t=`The size of this collection must be ${e}`})=>Ve(e,t),supportedFormat:({arrayOfValues:e,message:t="Unsupported File Format"})=>Ne(e,t),unsupportedFormat:({arrayOfValues:e,message:t="Unsupported File Format"})=>Se(e,t),maxSize:({ref:e,message:t=`size is excedeed ${e}`})=>Fe(e,t),test:e=>Pe(e.name,e.message,e.test),when:({ref:e,test:t,then:r=[],otherwise:n=[]})=>Te(e,t,r,n),oneOf:({arrayOfValues:e,message:t=`This value must be one of ${e.join(", ")}`})=>Me(e,t),blacklist:({arrayOfValues:e,message:t=`This value can't include the following values ${e.join(", ")}`})=>ze(e,t),ref:e=>We(e.ref)};var De=Object.freeze({__proto__:null,required:ve,url:ye,email:he,uuid:ge,matches:Oe,min:je,max:Ee,positive:we,negative:ke,integer:xe,lessThan:_e,moreThan:Ce,length:Ve,supportedFormat:Ne,unsupportedFormat:Se,maxSize:Fe,test:Pe,when:Te,oneOf:Me,blacklist:ze,ref:We,jsonConstraints:Ae});function $e(e){return null==e?Ie:Re(e)}const Re=e=>({map:t=>$e(t(e)),flatMap:t=>$e(t(e)).getOrElse(Ie),fold:(t,r)=>r(e),orElse:()=>$e(e),getOrElse:()=>e,getOrNull:()=>e,isDefined:()=>!0,exists:t=>$e(t(e)).isDefined()}),Ie={map:()=>Ie,flatMap:()=>Ie,fold:e=>e(),orElse:e=>$e(e),getOrElse:e=>e,getOrNull:()=>{},isDefined:()=>!1,exists:()=>!1},qe={[fe.string]:t=>e.string().nullable().optional().typeError(t||"Value must be a string"),[fe.number]:t=>e.number().nullable().optional().transform((e=>isNaN(e)?null:e)).typeError(t||"Value must be a number"),[fe.bool]:()=>e.bool().nullable().optional(),[fe.object]:()=>e.object().nullable().optional(),[fe.date]:t=>e.date().nullable().optional().typeError(t||"Value must be a date"),[fe.file]:()=>e.mixed(),[fe.json]:()=>e.mixed()},Be=(t,r,n,a)=>{var o,l;const{constraints:i=[]}=t;if(t.array||t.isMulti){let i,s=e.array().nullable().optional();if(t.schema){const r=[];i=e.object().shape(Je(t.flow||Object.keys(t.schema),t.schema,r,a).shape,r),s=s.of(e.object().shape({value:i}))}else(null===(o=t.constraints)||void 0===o?void 0:o.length)&&(i=t.constraints.reduce(((e,t)=>He(t,e,r,n)),qe[t.type]()),s=s.of(e.object().shape({value:i})));return(null===(l=t.arrayConstraints)||void 0===l?void 0:l.length)&&(s=t.arrayConstraints.reduce(((e,t)=>He(t,e,r,n)),s)),s}if(t.type===fe.object&&t.schema){if(!Object.keys(t.schema).length)return e.object().nullable().optional();const o=Je(t.flow||Object.keys(t.schema),t.schema,n,a);return i.reduce(((e,t)=>He(t,e,r,n)),e.object().nullable().optional().shape(o.shape,n))}if(t.type===fe.object&&t.conditionalSchema){const{schema:o,flow:l}=$e(t.conditionalSchema).map((e=>{const t=$e(e.ref).map((e=>a[e])).getOrNull();return $e(e.switch.find((e=>"function"==typeof e.condition?e.condition({rawValues:a,ref:t}):e.condition===t))).orElse(e.switch.find((e=>e.default))).getOrElse({schema:{},flow:[]})})).getOrElse({schema:{},flow:[]}),s=Je(l||Object.keys(o),o,n,a);return i.reduce(((e,t)=>He(t,e,r,n)),e.object().nullable().optional().shape(s.shape,n))}return i.reduce(((e,t)=>He(t,e,r,n)),qe[t.type]())},He=(e,t,r,n)=>"function"==typeof e?e(t,r,n):Ae[e.type](e)(t,r,n),Je=(e,t,r=[],n={})=>{if(!Object.keys(t).length)return{shape:{},dependencies:r};const a=(e||Object.keys(t)).reduce(((e,a)=>{if("object"==typeof a)return Object.assign(Object.assign({},e),Je(a.flow,t,r,n).shape);if(!t[a])return e;const o=Be(t[a],a,r,n);return Object.assign(Object.assign({},e),{[a]:o})}),{});return{shape:a,dependencies:r}},Ue=e=>Boolean(e&&"function"==typeof e.then),Ke=e=>e.some(Array.isArray)?Ke(e.flat()):e;function Ye(e){return null!=e}const Ge=e=>e&&Array.isArray(e)?e.map(Ge):e&&"object"==typeof e?Object.fromEntries(Object.entries(e).map((([e,t])=>Ue(t)?[e,`promise-${e}`]:"object"==typeof t?[e,Ge(t)]:[e,t]))):e,Qe=e=>h(Ge(e)),Xe=(e,t)=>{const r=n(!0),o=n(t);a((()=>{if(r.current)return e(),void(r.current=!1);Qe(t)!==Qe(o.current)&&(o.current=Object.assign({},t),e())}),t)},Ze=(e,t,r,n)=>Ye(r)?r:t?[]:e;function et(e,t,r){return t?(e||Object.keys(t)).reduce(((e,n)=>{if("object"==typeof n)return Object.assign(Object.assign({},e),et(n.flow,t,r));const a=t[n];return a?a.schema&&!a.array?Object.assign(Object.assign({},e),{[n]:a.defaultValue||et(a.flow,a.schema)}):Object.assign(Object.assign({},e),{[n]:Ze(r?r[n]:null,a.array||a.isMulti||!1,a.defaultValue)}):e}),{}):{}}const tt=(e,t={},r,n)=>{const a=$e(r).map((e=>e.map((e=>"object"==typeof e?e.flow:e)))).map(Ke).getOrElse(Object.keys(n||{}));return Object.entries(n||{}).filter((([e])=>a.includes(e))).reduce(((r,[a,o])=>{var l,i;let s=null;e&&(s=e[a]);const c=t[a];return!s&&Ye(c)&&(s=c),o.array&&!o.render?Object.assign(Object.assign({},r),{[a]:(s||[]).map((e=>{var r,o;return{value:"object"!=typeof e||e instanceof Date||Array.isArray(e)?e:tt(e,t,null===(r=null==n?void 0:n[a])||void 0===r?void 0:r.flow,(null===(o=null==n?void 0:n[a])||void 0===o?void 0:o.schema)||{})}}))}):null===s||"object"!=typeof s||s instanceof Date||Array.isArray(s)?Object.assign(Object.assign({},r),{[a]:void 0===s?Array.isArray(s)?[]:null:s}):Object.assign(Object.assign({},r),{[a]:tt(null==e?void 0:e[a],null==t?void 0:t[a],null===(l=null==n?void 0:n[a])||void 0===l?void 0:l.flow,(null===(i=null==n?void 0:n[a])||void 0===i?void 0:i.schema)||{})})}),e||{})},rt=(e,t)=>!e||"object"!=typeof e||e instanceof Date||Array.isArray(e)?e:Object.entries(e).reduce(((e,r)=>{var n,a;const[o,l]=r;if(Array.isArray(l)){return $e(t).map((e=>e[o])).map((e=>!!e.array&&!e.render)).getOrElse(!1)?Object.assign(Object.assign({},e),{[o]:l.map((e=>{var r;return!e.value||"object"!=typeof e.value||e.value instanceof Date&&!Array.isArray(e.value)?e.value:rt(e.value,(null===(r=t[o])||void 0===r?void 0:r.schema)||{})}))}):Object.assign(Object.assign({},e),{[o]:l})}if(!(!l||"object"!=typeof l||l instanceof Date&&!Array.isArray(l)))return Object.assign(Object.assign({},e),{[o]:rt(l,(null===(n=t[o])||void 0===n?void 0:n.schema)||{})});if("json"!==(null===(a=t[o])||void 0===a?void 0:a.type))return Object.assign(Object.assign({},e),{[o]:l});try{return Object.assign(Object.assign({},e),{[o]:JSON.parse(l)})}catch(t){return Object.assign(Object.assign({},e),{[o]:l})}}),{});function nt(e){return e.flow.map((e=>"string"==typeof e?e:nt(e))).flat()}const at=r.memo((({options:e,control:t,schema:r,onSubmit:n,handleSubmit:a,onError:l})=>{const i=u({control:t}),s=o(g((e=>a((()=>n(rt(e,r))),l)()),250,{leading:!0}),[]);return Xe((()=>{(null==e?void 0:e.autosubmit)&&s(i)}),[i]),(null==e?void 0:e.watch)&&("function"==typeof e.watch?e.watch(rt(i,r)):(console.group("react-form watch"),console.log(rt(i,r)),console.groupEnd())),null}),(()=>!0));function ot(){return ot=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e},ot.apply(this,arguments)}function lt(e,t){if(null==e)return{};var r,n,a=function(e,t){if(null==e)return{};var r,n,a={},o=Object.keys(e);for(n=0;n<o.length;n++)r=o[n],t.indexOf(r)>=0||(a[r]=e[r]);return a}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n<o.length;n++)r=o[n],t.indexOf(r)>=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(a[r]=e[r])}return a}var it=l((function(e,t){var n=e.color,a=void 0===n?"currentColor":n,o=e.size,l=void 0===o?24:o,i=lt(e,["color","size"]);return r.createElement("svg",ot({ref:t,xmlns:"http://www.w3.org/2000/svg",width:l,height:l,viewBox:"0 0 24 24",fill:"none",stroke:a,strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"},i),r.createElement("line",{x1:"12",y1:"2",x2:"12",y2:"6"}),r.createElement("line",{x1:"12",y1:"18",x2:"12",y2:"22"}),r.createElement("line",{x1:"4.93",y1:"4.93",x2:"7.76",y2:"7.76"}),r.createElement("line",{x1:"16.24",y1:"16.24",x2:"19.07",y2:"19.07"}),r.createElement("line",{x1:"2",y1:"12",x2:"6",y2:"12"}),r.createElement("line",{x1:"18",y1:"12",x2:"22",y2:"12"}),r.createElement("line",{x1:"4.93",y1:"19.07",x2:"7.76",y2:"16.24"}),r.createElement("line",{x1:"16.24",y1:"7.76",x2:"19.07",y2:"4.93"}))}));function st(){return st=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e},st.apply(this,arguments)}function ct(e,t){if(null==e)return{};var r,n,a=function(e,t){if(null==e)return{};var r,n,a={},o=Object.keys(e);for(n=0;n<o.length;n++)r=o[n],t.indexOf(r)>=0||(a[r]=e[r]);return a}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n<o.length;n++)r=o[n],t.indexOf(r)>=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(a[r]=e[r])}return a}it.propTypes={color:C.string,size:C.oneOfType([C.string,C.number])},it.displayName="Loader";var mt=l((function(e,t){var n=e.color,a=void 0===n?"currentColor":n,o=e.size,l=void 0===o?24:o,i=ct(e,["color","size"]);return r.createElement("svg",st({ref:t,xmlns:"http://www.w3.org/2000/svg",width:l,height:l,viewBox:"0 0 24 24",fill:"none",stroke:a,strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"},i),r.createElement("path",{d:"M21 15v4a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2v-4"}),r.createElement("polyline",{points:"17 8 12 3 7 8"}),r.createElement("line",{x1:"12",y1:"3",x2:"12",y2:"15"}))}));function ut(){return ut=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e},ut.apply(this,arguments)}function pt(e,t){if(null==e)return{};var r,n,a=function(e,t){if(null==e)return{};var r,n,a={},o=Object.keys(e);for(n=0;n<o.length;n++)r=o[n],t.indexOf(r)>=0||(a[r]=e[r]);return a}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n<o.length;n++)r=o[n],t.indexOf(r)>=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(a[r]=e[r])}return a}mt.propTypes={color:C.string,size:C.oneOfType([C.string,C.number])},mt.displayName="Upload";var dt=l((function(e,t){var n=e.color,a=void 0===n?"currentColor":n,o=e.size,l=void 0===o?24:o,i=pt(e,["color","size"]);return r.createElement("svg",ut({ref:t,xmlns:"http://www.w3.org/2000/svg",width:l,height:l,viewBox:"0 0 24 24",fill:"none",stroke:a,strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"},i),r.createElement("polyline",{points:"6 9 12 15 18 9"}))}));function ft(){return ft=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e},ft.apply(this,arguments)}function bt(e,t){if(null==e)return{};var r,n,a=function(e,t){if(null==e)return{};var r,n,a={},o=Object.keys(e);for(n=0;n<o.length;n++)r=o[n],t.indexOf(r)>=0||(a[r]=e[r]);return a}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n<o.length;n++)r=o[n],t.indexOf(r)>=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(a[r]=e[r])}return a}dt.propTypes={color:C.string,size:C.oneOfType([C.string,C.number])},dt.displayName="ChevronDown";var vt=l((function(e,t){var n=e.color,a=void 0===n?"currentColor":n,o=e.size,l=void 0===o?24:o,i=bt(e,["color","size"]);return r.createElement("svg",ft({ref:t,xmlns:"http://www.w3.org/2000/svg",width:l,height:l,viewBox:"0 0 24 24",fill:"none",stroke:a,strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"},i),r.createElement("polyline",{points:"18 15 12 9 6 15"}))}));function yt(){return yt=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e},yt.apply(this,arguments)}function ht(e,t){if(null==e)return{};var r,n,a=function(e,t){if(null==e)return{};var r,n,a={},o=Object.keys(e);for(n=0;n<o.length;n++)r=o[n],t.indexOf(r)>=0||(a[r]=e[r]);return a}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n<o.length;n++)r=o[n],t.indexOf(r)>=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(a[r]=e[r])}return a}vt.propTypes={color:C.string,size:C.oneOfType([C.string,C.number])},vt.displayName="ChevronUp";var gt=l((function(e,t){var n=e.color,a=void 0===n?"currentColor":n,o=e.size,l=void 0===o?24:o,i=ht(e,["color","size"]);return r.createElement("svg",yt({ref:t,xmlns:"http://www.w3.org/2000/svg",width:l,height:l,viewBox:"0 0 24 24",fill:"none",stroke:a,strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"},i),r.createElement("polyline",{points:"3 6 5 6 21 6"}),r.createElement("path",{d:"M19 6v14a2 2 0 0 1-2 2H7a2 2 0 0 1-2-2V6m3 0V4a2 2 0 0 1 2-2h4a2 2 0 0 1 2 2v2"}),r.createElement("line",{x1:"10",y1:"11",x2:"10",y2:"17"}),r.createElement("line",{x1:"14",y1:"11",x2:"14",y2:"17"}))}));gt.propTypes={color:C.string,size:C.oneOfType([C.string,C.number])},gt.displayName="Trash2";const Ot=({onChange:e,value:t,readOnly:n,className:a,errorDisplayed:o,buttons:l,trueLabel:i,falseLabel:s})=>{const c=t=>{n||null==e||e(t)};let m=V("mrf-content_switch",a,{"mrf-content_switch_button_on":!!t,"mrf-content_switch_button_off":!t&&null!==t,"mrf-content_switch_button_null":null===t,"mrf-cursor_pointer":!n,"mrf-cursor_not_allowed":n,"mrf-input__invalid":!!o}),u=()=>c(!0);return t&&(u=()=>c(!1)),l?r.createElement("div",{className:"d-flex"},r.createElement("button",{type:"button",className:V("mrf-flex_grow_1 mrf-btn mrf-btn_grey mrf-ml_5",{active:!!t}),onClick:()=>e(!0)},i||"true"),r.createElement("button",{type:"button",className:V("mrf-flex_grow_1 mrf-btn mrf-btn_grey mrf-ml_5",{active:!t}),onClick:()=>e(!1)},s||"false")):r.createElement("input",{type:"checkbox",className:m,onChange:u})};function jt(){return jt=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e},jt.apply(this,arguments)}function Et(e,t){if(null==e)return{};var r,n,a=function(e,t){if(null==e)return{};var r,n,a={},o=Object.keys(e);for(n=0;n<o.length;n++)r=o[n],t.indexOf(r)>=0||(a[r]=e[r]);return a}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n<o.length;n++)r=o[n],t.indexOf(r)>=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(a[r]=e[r])}return a}var wt=l((function(e,t){var n=e.color,a=void 0===n?"currentColor":n,o=e.size,l=void 0===o?24:o,i=Et(e,["color","size"]);return r.createElement("svg",jt({ref:t,xmlns:"http://www.w3.org/2000/svg",width:l,height:l,viewBox:"0 0 24 24",fill:"none",stroke:a,strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"},i),r.createElement("path",{d:"M17.94 17.94A10.07 10.07 0 0 1 12 20c-7 0-11-8-11-8a18.45 18.45 0 0 1 5.06-5.94M9.9 4.24A9.12 9.12 0 0 1 12 4c7 0 11 8 11 8a18.5 18.5 0 0 1-2.16 3.19m-6.72-1.07a3 3 0 1 1-4.24-4.24"}),r.createElement("line",{x1:"1",y1:"1",x2:"23",y2:"23"}))}));function kt(){return kt=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e},kt.apply(this,arguments)}function xt(e,t){if(null==e)return{};var r,n,a=function(e,t){if(null==e)return{};var r,n,a={},o=Object.keys(e);for(n=0;n<o.length;n++)r=o[n],t.indexOf(r)>=0||(a[r]=e[r]);return a}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n<o.length;n++)r=o[n],t.indexOf(r)>=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(a[r]=e[r])}return a}wt.propTypes={color:C.string,size:C.oneOfType([C.string,C.number])},wt.displayName="EyeOff";var _t=l((function(e,t){var n=e.color,a=void 0===n?"currentColor":n,o=e.size,l=void 0===o?24:o,i=xt(e,["color","size"]);return r.createElement("svg",kt({ref:t,xmlns:"http://www.w3.org/2000/svg",width:l,height:l,viewBox:"0 0 24 24",fill:"none",stroke:a,strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"},i),r.createElement("path",{d:"M1 12s4-8 11-8 11 8 11 8-4 8-11 8-11-8-11-8z"}),r.createElement("circle",{cx:"12",cy:"12",r:"3"}))}));_t.propTypes={color:C.string,size:C.oneOfType([C.string,C.number])},_t.displayName="Eye";const Ct=e=>{const[t,n]=i(e.initCollapsed||e.collapsed),a=e=>{e&&e.stopPropagation(),n(!t)};return r.createElement("div",null,r.createElement("hr",{className:V({"mrf-collapse_error":e.errored})}),r.createElement("div",{className:"mrf-cursor_pointer mrf-flex mrf-jc_between",onClick:a},r.createElement("span",{className:V("mrf-collapse_label",{"mrf-collapse_error":e.errored})},e.label),r.createElement("button",{type:"button",className:V("mrf-btn","mrf-btn_sm","mrf-ml_5",{"mrf-collapse_error":e.errored}),onClick:a},!!t&&r.createElement(_t,{size:16}),!t&&r.createElement(wt,{size:16}))),r.createElement("div",{className:V("mrf-ml_10",{"mrf-display__none":!!t,"mrf-flex":!!e.inline,"mrf-collapse__inline":!!e.inline})},e.children),e.lineEnd&&r.createElement("hr",null))},Vt=(e,t=[],r=!1)=>{if(null===e||!e)return null;if(r)return $e(e).map((e=>(Array.isArray(e)?e||[]:"object"==typeof e?Object.values(e):e).map((e=>Vt(e,t,!1))))).getOrElse([]);const n=$e(t.find((t=>O(t.value,e))));return n.getOrElse({label:n.map((e=>e.label)).getOrElse((null==e?void 0:e.label)||("object"==typeof e?JSON.stringify(e):e)),value:n.map((e=>e.value)).getOrElse((null==e?void 0:e.value)||e)})},Nt=e=>{const{getValues:t}=p();function n(t){const r=e.transformer?"function"==typeof e.transformer?e.transformer(t):{label:t[e.transformer.label],value:t[e.transformer.value]}:t;return{label:(null==r?void 0:r.label)||("object"==typeof r?JSON.stringify(r):r),value:(null==r?void 0:r.value)||t}}const o=(e.possibleValues||[]).map((e=>n(e))),[l,s]=i(!0),[c,m]=i(o),[u,d]=i();a((()=>{!l&&c.length&&d(Vt(e.value||e.defaultValue,c,e.isMulti))}),[e.value,c,e.defaultValue,l]),a((()=>{if(e.optionsFrom){if($e(e.fetchCondition).map((e=>e())).getOrElse(!0)){let r;if(s(!0),Ue(e.optionsFrom))r=e.optionsFrom;else if("function"==typeof e.optionsFrom){const n=e.optionsFrom({rawValues:t(),value:t(e.id),getValue:e=>t(e)});r=Ue(n)?n:e.httpClient(n,"GET").then((e=>e.json()))}else r=e.httpClient(e.optionsFrom,"GET").then((e=>e.json()));r.then((e=>e.map((e=>n(e))))).then((e=>{m(e),d(e.find((e=>Array.isArray(u)?u.find((t=>t.value===e.value)):e.value===(u?u.value:u)))||null),s(!1)}))}}else m((e.possibleValues||[]).map((e=>n(e)))),setTimeout((()=>s(!1)),250)}),[e.optionsFrom,e.possibleValues,e.onChange]);const f=t=>{var r,n;d(t),e.isMulti?null===(r=null==e?void 0:e.onChange)||void 0===r||r.call(e,t.map((e=>e.value))):null===(n=null==e?void 0:e.onChange)||void 0===n||n.call(e,null==t?void 0:t.value)},b=(t,r)=>{const n=$e(r).map((e=>e(t))).flatMap((t=>{return r=t,e.transformer?"function"==typeof e.transformer?$e(e.transformer(r)):Re({label:r[e.transformer.label],value:r[e.transformer.value]}):Ie;var r})).getOrElse(Vt(t,c));m([...c||[],n]),e.isMulti?f([...u||[],n]):f(n)};return e.buttons?r.createElement("div",{style:{display:"flex"}},c.map(((t,n)=>{const a=!!u&&(e.isMulti?u.includes(t):t.value===u.value);return r.createElement("button",{key:n,type:"button",disabled:e.disabled,className:V(e.className,"mrf-btn mrf-btn_grey mrf-ml_5",{active:a}),onClick:()=>(t=>{if(e.isMulti){const e=u;return e.includes(t)?f(e.filter((e=>e.value!==t.value))):f([...e,t])}return!e.isMulti&&e.isClearable&&u&&t.value===u.value?f(null):f(t)})(t)},t.label)}))):e.createOption?r.createElement(N,Object.assign({},e,{name:`${e.label}-search`,isLoading:l,value:u,isDisabled:l||e.disabled,placeholder:e.placeholder,onChange:f,options:c,onCreateOption:t=>b(t,e.onCreateOption),classNamePrefix:"react-form-select",className:e.className})):r.createElement(S,Object.assign({},e,{name:`${e.label}-search`,isLoading:l,value:u,defaultValue:u,isDisabled:l||e.disabled,placeholder:e.placeholder,options:c,onChange:f,classNamePrefix:"react-form-select",className:e.className}))};function St(){return St=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e},St.apply(this,arguments)}function Ft(e,t){if(null==e)return{};var r,n,a=function(e,t){if(null==e)return{};var r,n,a={},o=Object.keys(e);for(n=0;n<o.length;n++)r=o[n],t.indexOf(r)>=0||(a[r]=e[r]);return a}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n<o.length;n++)r=o[n],t.indexOf(r)>=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(a[r]=e[r])}return a}var Pt=l((function(e,t){var n=e.color,a=void 0===n?"currentColor":n,o=e.size,l=void 0===o?24:o,i=Ft(e,["color","size"]);return r.createElement("svg",St({ref:t,xmlns:"http://www.w3.org/2000/svg",width:l,height:l,viewBox:"0 0 24 24",fill:"none",stroke:a,strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"},i),r.createElement("circle",{cx:"12",cy:"12",r:"10"}),r.createElement("line",{x1:"12",y1:"8",x2:"12",y2:"16"}),r.createElement("line",{x1:"8",y1:"12",x2:"16",y2:"12"}))}));function Tt(){return Tt=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e},Tt.apply(this,arguments)}function Mt(e,t){if(null==e)return{};var r,n,a=function(e,t){if(null==e)return{};var r,n,a={},o=Object.keys(e);for(n=0;n<o.length;n++)r=o[n],t.indexOf(r)>=0||(a[r]=e[r]);return a}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n<o.length;n++)r=o[n],t.indexOf(r)>=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(a[r]=e[r])}return a}Pt.propTypes={color:C.string,size:C.oneOfType([C.string,C.number])},Pt.displayName="PlusCircle";var zt=l((function(e,t){var n=e.color,a=void 0===n?"currentColor":n,o=e.size,l=void 0===o?24:o,i=Mt(e,["color","size"]);return r.createElement("svg",Tt({ref:t,xmlns:"http://www.w3.org/2000/svg",width:l,height:l,viewBox:"0 0 24 24",fill:"none",stroke:a,strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"},i),r.createElement("circle",{cx:"12",cy:"12",r:"10"}),r.createElement("line",{x1:"8",y1:"12",x2:"16",y2:"12"}))}));zt.propTypes={color:C.string,size:C.oneOfType([C.string,C.number])},zt.displayName="MinusCircle";const Wt=e=>{const[r,n]=i({});a((()=>{n(Object.fromEntries(Object.entries(e.value||{}).map((([e,t],r)=>[Date.now()+r,{key:e,value:t}]))))}),[]),a((()=>{if(e.value){const t=e.value||{},a=Object.entries(r||{}).reduce(((e,[t,r])=>r.key?Object.assign(Object.assign({},e),{[r.key]:r.value}):e),{});O(t,a)||n(Object.fromEntries(Object.entries(e.value||{}).map((([e,t],r)=>[Date.now()+r,{key:e,value:t}]))))}}),[e.value]);const o=t=>{var r;null===(r=null==e?void 0:e.onChange)||void 0===r||r.call(e,Object.values(t).reduce(((e,t)=>Object.assign(Object.assign({},e),{[t.key]:t.value})),{}))},l=()=>{const t=e.defaultKeyValue||{key:"",value:""},a=Object.assign(Object.assign({},r),{[Date.now()]:t});n(a),o(a)};return t.createElement("div",{className:e.className},0===Object.keys(r||{}).length&&t.createElement("button",{disabled:e.disabled,type:"button",className:"mrf-flex mrf-btn mrf-btn_blue mrf-btn_sm",onClick:()=>{if(!r||0===Object.keys(r).length){const t=Object.assign(Object.assign({},r),{[Date.now()]:e.defaultKeyValue||{key:"",value:""}});n(t),o(t)}}},t.createElement(Pt,null)),Object.entries(r||{}).map((([a,{key:i,value:s}],c)=>t.createElement("div",{className:"mrf-flex mrf-mt_5",key:c},t.createElement("input",{disabled:e.disabled,type:"text",className:"mrf-w_50 mrf-input",placeholder:e.placeholderKey,value:i,onChange:e=>((e,t)=>{const a=Object.assign(Object.assign({},r),{[e]:{key:t,value:r[e].value}});n(a),o(a)})(a,e.target.value)}),t.createElement("input",{disabled:e.disabled,type:"text",className:"mrf-w_50 mrf-input",placeholder:e.placeholderValue,value:s,onChange:e=>((e,t)=>{const a=Object.assign(Object.assign({},r),{[e]:{key:r[e].key,value:t}});n(a),o(a)})(a,e.target.value)}),t.createElement("button",{disabled:e.disabled,type:"button",className:"mrf-flex mrf-ai_center mrf-btn mrf-btn_red mrf-btn_sm mrf-ml_10",onClick:()=>(e=>{const t=Object.fromEntries(Object.entries(r).filter((([t,r])=>t!==e)));n(t),o(t)})(a)},t.createElement(zt,null)),c===Object.keys(r).length-1&&t.createElement("button",{disabled:e.disabled,type:"button",className:"mrf-flex mrf-ai_center mrf-btn mrf-btn_blue mrf-btn_sm mrf-ml_5",onClick:l},t.createElement(Pt,null))))))},Lt={javascript:P,css:z,json:M,html:T,markdown:W};function At(e,t,r=1,n=!1,a=!0,o=!1,l={height:"-1",minHeight:"300px",maxHeight:"-1",width:"-1",minWidth:"-1",maxWidth:"-1"},i,s){const c=L.theme({"&":Object.assign({},l)}),m=[a?G():G({formatNumber:()=>""}),Q(),A(),q(),Lt[t](),H(),D(),$(),F.allowMultipleSelections.of(!0),ie.fallback,X(),Z(),ne(),le(),o?R():void 0,te(),I.of([...ee,...U,...re,...B,...J,...oe,...ae,...se,K]),ce,c,F.tabSize.of(r),Y.of(" ".repeat(r))].filter((e=>!!e)),u=F.create({extensions:[...m,L.updateListener.of((e=>{try{if(e.docChanged){const t=e.state.doc.toString();null==i||i(t)}}catch(e){}})),L.editable.of(!n)],doc:null==s?"":"object"==typeof s?s.value:s});return new L({state:u,parent:e})}function Dt({onChange:e,value:t,mode:o="javascript",tabSize:l=2,readOnly:s=!1,showLinesNumber:c=!0,highlightLine:m=!1,themeStyle:u={height:"-1",minHeight:"300px",maxHeight:"-1",width:"-1",minWidth:"-1",maxWidth:"-1"},className:p,setRef:d}){const f=n(),[b,v]=i();return a((()=>{const r=At(f.current,o,l,s,c,m,u,e,t);f.current.addEventListener("keydown",(e=>{e.stopImmediatePropagation()})),d&&d(r),r.dispatch({changes:{from:0,to:r.state.doc.length,insert:null==t?"":"object"==typeof t?JSON.stringify(t,null,2):t}}),v(r)}),[]),a((()=>{b&&("object"==typeof t?JSON.stringify(t,null,2):t)!==b.state.doc.toString()&&b.dispatch({changes:{from:0,to:b.state.doc.length,insert:null==t?"":"object"==typeof t?JSON.stringify(t,null,2):t}})}),[t]),r.createElement("div",{className:p,ref:f})}const $t=new me.Converter({omitExtraWLInCodeBlocks:!0,ghCompatibleHeaderId:!0,parseImgDimensions:!0,simplifiedAutoLink:!0,tables:!0,tasklists:!0,requireSpaceBeforeHeadingText:!0,ghMentions:!0,emoji:!0,ghMentionsLink:"/{u}"}),Rt=e=>{const[t,o]=i(e.preview||!1),l=n();a((()=>{t&&c()}),[t,e.value]);const s=[{name:"Add header",icon:"heading",inject:e=>[{from:e.from,insert:"# "}]},{name:"Add bold text",icon:"bold",inject:e=>[{from:e.from,insert:"**"},{from:e.to,insert:"**"}]},{name:"Add italic text",icon:"italic",inject:e=>[{from:e.from,insert:"*"},{from:e.to,insert:"*"}]},{name:"Add strikethrough text",icon:"strikethrough",inject:e=>[{from:e.from,insert:"~~"},{from:e.to,insert:"~~"}]},{name:"Add link",icon:"link",inject:e=>[{from:e.from,insert:"["},{from:e.to,insert:"](url)"}]},{name:"Add code",icon:"code",inject:e=>[{from:e.from,insert:"```\n"},{from:e.to,insert:"\n```\n"}]},{name:"Add quotes",icon:"quote-right",inject:e=>[{from:e.from,insert:"> "}]},{name:"Add image",icon:"image",inject:e=>[{from:e.from,insert:"!["},{from:e.to,insert:"](image-url)"}]},{name:"Add unordered list",icon:"list-ul",inject:e=>[{from:e.from,insert:"* "}]},{name:"Add ordered list",icon:"list-ol",inject:e=>[{from:e.from,insert:"1. "}]},{name:"Add check list",icon:"tasks",inject:e=>[{from:e.from,insert:"* [ ] "}]}],c=()=>{const e=[...document.getElementsByClassName("mrf-preview")];e.length>0&&[...e[0].querySelectorAll("pre code")].forEach((e=>ue.highlightElement(e)))};return r.createElement("div",{className:V(e.className)},!e.readOnly&&r.createElement("div",{style:{marginBottom:10}},r.createElement("div",null,r.createElement("div",null,r.createElement("button",{type:"button",className:"mrf-btn mrf-btn_sm",style:{color:t?"white":"#7f96af",backgroundColor:t?"#7f96af":"white"},onClick:()=>o(!1)},"Write"),r.createElement("button",{type:"button",className:"mrf-btn mrf-btn_sm mrf-ml_5",style:{color:t?"#7f96af":"white",backgroundColor:t?"white":"#7f96af"},onClick:()=>o(!0)},"Preview"))),r.createElement("div",{className:"mrf-flex mrf-flexWrap"},r.createElement(r.Fragment,null,s.map(((e,t)=>r.createElement("button",{type:"button",className:V("mrf-btn_for_descriptionToolbar"),"aria-label":e.name,title:e.name,key:`toolbar-btn-${t}`,onClick:()=>{const t=l.current;t.dispatch(t.state.changeByRange((t=>({changes:e.inject(t),range:t})))),t.focus()}},r.createElement("i",{className:`fas fa-${e.icon}`})))),e.actions&&e.actions((e=>{const t=l.current;t.dispatch(t.state.changeByRange((t=>({changes:[{from:t.from,insert:e}],range:t})))),t.focus()}))))),!t&&r.createElement(Dt,Object.assign({},e,{mode:"markdown",setRef:e=>l.current=e})),t&&r.createElement("div",{className:"mrf-preview",dangerouslySetInnerHTML:{__html:$t.makeHtml(e.value||"")}}))};function It({onChange:e,value:t,mode:o="javascript",tabSize:l=2,readOnly:i=!1,showLinesNumber:s=!0,highlightLine:c=!1,themeStyle:m={height:"-1",minHeight:"-1",maxHeight:"-1",width:"-1",minWidth:"-1",maxWidth:"-1"}}){const u=n();return a((()=>{At(u.current,o,l,i,s,c,m,(t=>{null==e||e(t.replace(/\n/g,""))}),t),u.current.addEventListener("keydown",(e=>{e.stopImmediatePropagation()}))}),[]),r.createElement("div",{ref:u,style:{flex:1,overflow:"hidden"}})}function qt(){return qt=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e},qt.apply(this,arguments)}function Bt(e,t){if(null==e)return{};var r,n,a=function(e,t){if(null==e)return{};var r,n,a={},o=Object.keys(e);for(n=0;n<o.length;n++)r=o[n],t.indexOf(r)>=0||(a[r]=e[r]);return a}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n<o.length;n++)r=o[n],t.indexOf(r)>=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(a[r]=e[r])}return a}var Ht=l((function(e,t){var n=e.color,a=void 0===n?"currentColor":n,o=e.size,l=void 0===o?24:o,i=Bt(e,["color","size"]);return r.createElement("svg",qt({ref:t,xmlns:"http://www.w3.org/2000/svg",width:l,height:l,viewBox:"0 0 24 24",fill:"none",stroke:a,strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"},i),r.createElement("circle",{cx:"12",cy:"12",r:"10"}),r.createElement("path",{d:"M9.09 9a3 3 0 0 1 5.83 1c0 2-3 3-3 3"}),r.createElement("line",{x1:"12",y1:"17",x2:"12.01",y2:"17"}))}));Ht.propTypes={color:C.string,size:C.oneOfType([C.string,C.number])},Ht.displayName="HelpCircle";const Jt=({entry:e,realEntry:t,children:n,render:a,functionalProperty:o,step:l,informations:i,className:s})=>{const{formState:c}=p();if("object"==typeof e)return n;const m=e.split(".").reduce(((e,t)=>e&&e[t]),c.errors),u=e.split(".").reduce(((e,t)=>e&&e[t]),c.dirtyFields),d=e.split(".").reduce(((e,t)=>e&&e[t]),c.touchedFields),f=c.isSubmitted||u||d;if(!o(e,void 0===(null==l?void 0:l.visible)||l.visible,i,m))return null;const b=o(e,null===(null==l?void 0:l.label)?null:(null==l?void 0:l.label)||t||e,i),v=de();return a?a({entry:e,label:b,error:m,help:null==l?void 0:l.help,children:n}):r.createElement("div",{className:`mrf-mt_10 ${s||""}`,style:{position:"relative"}},b&&r.createElement("label",{className:"mrf-flex mrf-ai_center mrf-mb_5",htmlFor:e},r.createElement("span",null,b),(null==l?void 0:l.help)&&r.createElement(r.Fragment,null,r.createElement(pe,{html:!0,place:"bottom",id:v}),r.createElement("span",{className:"mrf-flex mrf-ai_center","data-html":!0,"data-tip":null==l?void 0:l.help,"data-for":v},r.createElement(Ht,{style:{color:"gray",width:17,marginLeft:".5rem",cursor:"help"}})))),n,m&&r.createElement("div",{className:V("mrf-feedback",{"mrf-txt_red":!!f})},m.message))},Ut=t.memo((e=>e.render?e.render(Object.assign(Object.assign({},e.field),{error:e.error,informations:e.informations,defaultValue:e.step.defaultValue})):e.children),((e,t)=>!t.deactivateReactMemo&&(e.field.value===t.field.value&&t.errorDisplayed===e.errorDisplayed&&Qe(t.step)===Qe(e.step)))),Kt=e=>{const{step:r,entry:n,realEntry:a,children:o,component:l,errorDisplayed:i=!1,informations:s,deactivateReactMemo:c,inputWrapper:m,defaultFormValue:u}=e,{field:f}=d({defaultValue:Ye(r.defaultValue)?r.defaultValue:null,name:n}),{getValues:b,setValue:v,formState:{errors:y}}=p(),[h,g]=t.useState(!!f.value),O=n.split(".").reduce(((e,t)=>e&&e[t]),y),j=(e,t)=>"function"==typeof t?t({rawValues:b(),value:b(e),defaultFormValue:u,informations:s,error:O,getValue:e=>b(e)}):t,E=Object.assign(Object.assign({name:f.name},r.props),{id:n,readOnly:j(n,r.disabled)?"readOnly":null,placeholder:r.placeholder,onChange:e=>{const t=e?e.target?e.target.value||null:e:r.type===fe.bool||r.type===fe.number&&0===f.value?e:null;f.onChange(t),$e(r.onChange).map((e=>e({rawValues:b(),value:t,setValue:v})))},value:f.value});return r.optional&&h?t.createElement("div",{className:"mrf-ai_center mrf-mt_5",style:{position:"relative"}},t.createElement("div",{style:{width:"95%"}},t.createElement(Jt,{key:`collapse-${n}`,entry:n,realEntry:a,functionalProperty:j,step:r,render:m,informations:s},t.createElement(Ut,{render:r.render,step:r,field:Object.assign({setValue:(e,t)=>v(e,t),rawValues:b(),getValue:e=>b(e)},f),error:O,errorDisplayed:i,informations:s,deactivateReactMemo:c},l?l(f,E):t.cloneElement(o,Object.assign({},E))))),t.createElement("button",{type:"button",style:{position:"absolute",top:"2px",right:0},className:"mrf-btn mrf-btn_red mrf-btn_sm mrf-ml_5",onClick:()=>{g(!1),v(n,null)}},t.createElement(gt,{size:16}))):r.optional?t.createElement(Jt,{key:`collapse-${n}`,entry:n,realEntry:a,functionalProperty:j,step:r,render:m,informations:s},t.createElement("div",{className:"mrf-flex mrf-jc_flex_end"},t.createElement("button",{type:"button",className:V("mrf-btn","mrf-btn_blue","mrf-btn_sm","mrf-mt_5"),onClick:()=>{g(!0)}},"Add"))):t.createElement(Jt,{key:`collapse-${n}`,entry:n,realEntry:a,functionalProperty:j,step:r,render:m,informations:s},t.createElement(Ut,{render:r.render,step:r,field:Object.assign({setValue:(e,t)=>v(e,t),rawValues:b(),getValue:e=>b(e)},f),error:O,errorDisplayed:i,informations:s,deactivateReactMemo:c},l?l(f,E):t.cloneElement(o,Object.assign({},E))))},Yt=({entry:e,step:t,component:n,disabled:a,addLabel:o})=>{const{getValues:l,setValue:i,control:s,trigger:c,formState:m}=p(),u=l(e),d=e.split(".").reduce(((e,t)=>e&&e[t]),m.errors),b=e.split(".").reduce(((e,t)=>e&&e[t]),m.dirtyFields),v=e.split(".").reduce(((e,t)=>e&&e[t]),m.touchedFields),y=!!d&&(m.isSubmitted||b||v),{fields:h,append:g,remove:O}=f({control:s,name:e});return r.createElement(r.Fragment,null,h.map(((o,s)=>r.createElement("div",{key:o.id},r.createElement("div",{className:"mrf-ai_center mrf-mt_5",style:{position:"relative"}},r.createElement("div",{style:{width:"95%"}},n(Object.assign(Object.assign({key:o.id},o),{defaultValue:u[s]}),s)),r.createElement("button",{type:"button",style:{position:"absolute",top:"2px",right:0},className:"mrf-btn mrf-btn_red mrf-btn_sm mrf-ml_5",disabled:a,onClick:()=>{O(s),$e(t.onChange).map((t=>t({rawValues:l(),value:l(e),setValue:i}))),c(e)}},r.createElement(gt,{size:16})))))),r.createElement("div",{className:"mrf-flex mrf-jc_flex_end"},r.createElement("button",{type:"button",className:V("mrf-btn","mrf-btn_blue","mrf-btn_sm","mrf-mt_5",{"mrf-input__invalid":!!y}),onClick:()=>{const r=t.type===fe.object?et(t.flow,t.schema):Ze();g({value:t.addableDefaultValue||r}),$e(t.onChange).map((t=>t({rawValues:l(),value:l(e),setValue:i})))},disabled:a},o||"Add")))},Gt=e=>e.render?e.render(Object.assign(Object.assign({},e),{error:e.error})):e.children,Qt=e=>{let{entry:t,schema:n,inputWrapper:a,httpClient:o,functionalProperty:l}=e;const{formState:{errors:i,dirtyFields:s,touchedFields:c}}=p(),m=nt(t).some((e=>!!i[e]&&(s[e]||c[e])));return r.createElement(Ct,Object.assign({},t,{errored:m}),t.flow.map(((t,i)=>{if("object"==typeof t)return r.createElement(Qt,Object.assign({key:i},e,{entry:t}));const s=n[t];if(!s&&"string"==typeof t)return console.error(`no step found for the entry "${t}" in the given schema. Your form might not work properly. Please fix it`),null;const c={path:t,key:t};return r.createElement(Xt,{entry:t,step:s,schema:n,inputWrapper:a,httpClient:o,defaultValue:null==s?void 0:s.defaultValue,functionalProperty:l,informations:c,options:e.stepsOptions,defaultFormValue:e.defaultFormValue})})))},Xt=e=>{var t;let{entry:o,realEntry:l,step:c,schema:m,inputWrapper:u,httpClient:d,functionalProperty:f,informations:v,defaultFormValue:y}=e;const h=p(),{formState:{errors:g,dirtyFields:C,touchedFields:N,isSubmitted:S},control:F,getValues:P,setValue:T,reset:M}=h,{watch:z}=h,[W,L]=i(Qe(P())),A=o.split(".").reduce(((e,t)=>e&&e[t]),g),D=o.split(".").reduce(((e,t)=>e&&e[t]),C),$=o.split(".").reduce(((e,t)=>e&&e[t]),N),R=!!A&&(S||D||$);if(c=c,c.onAfterChange){const e=z(),t=o.replace("[",".").replace("]","").split(".").reduce(((e,t)=>e&&e[t]),e)||{},r=(e=>{const t=n();return a((()=>{t.current=e}),[e]),t.current})(rt(t,m)),l=rt(t,m);(!O(l,r)||void 0!==l&&void 0===r)&&c.onAfterChange({entry:o,value:P(o),rawValues:P(),previousValue:r,getValue:e=>P(e),setValue:T,onChange:e=>T(o,e),reset:M,informations:v})}const I=s((()=>{const e="function"==typeof c.visible,t="function"==typeof c.disabled,r="function"==typeof c.label;return!!("function"==typeof c.deps?c.deps(v):c.deps)||e||t||r||!!c.render||!!c.conditionalSchema}),[Qe(m)]);if(I){const e="function"==typeof c.deps?c.deps(v):c.deps,t=e?z(e):z(),r=Qe(t);r!==W&&L(r)}if(c.array)return r.createElement(Kt,{step:c,entry:o,realEntry:l,errorDisplayed:R,informations:v,deactivateReactMemo:I,inputWrapper:u,defaultFormValue:y},r.createElement(Yt,{entry:o,step:c,disabled:f(o,c.disabled||!1,v,A),component:(t,n)=>{var a,i,s,p,b,h,g,O,j;return r.createElement(Xt,{entry:`${o}.${n}.value`,step:Object.assign(Object.assign({},m[l||o]),{label:(null===(a=c.item)||void 0===a?void 0:a.label)||null,render:null===(i=c.item)||void 0===i?void 0:i.render,onChange:null===(s=c.item)||void 0===s?void 0:s.onChange,array:(null===(p=c.item)||void 0===p?void 0:p.array)||!1,onAfterChange:null===(b=c.item)||void 0===b?void 0:b.onAfterChange,visible:null===(h=c.item)||void 0===h?void 0:h.visible,disabled:null===(g=c.item)||void 0===g?void 0:g.disabled,deps:null===(O=c.item)||void 0===O?void 0:O.deps}),schema:m,inputWrapper:u,httpClient:d,defaultValue:null===(j=t.defaultValue)||void 0===j?void 0:j.value,index:n,functionalProperty:f,informations:{path:`${null==v?void 0:v.path}.${n}.value`,parent:v,index:n},options:e.options,defaultFormValue:y})},addLabel:null===(t=e.options)||void 0===t?void 0:t.addLabel}));switch(c.type){case fe.string:switch(c.format){case be.text:return r.createElement(Kt,{step:c,entry:o,realEntry:l,errorDisplayed:R,informations:v,deactivateReactMemo:I,inputWrapper:u,defaultFormValue:y},r.createElement("textarea",{className:V("mrf-input",c.className,{"mrf-mrf-input__invalid":!!R})}));case be.code:case be.singleLineCode:const e=c.format===be.code?Dt:It;return r.createElement(Kt,{step:c,entry:o,realEntry:l,errorDisplayed:R,informations:v,deactivateReactMemo:I,inputWrapper:u,defaultFormValue:y},r.createElement(e,{className:V(null==c?void 0:c.className,{"mrf-input__invalid":!!A})}));case be.markdown:return r.createElement(Kt,{step:c,entry:o,realEntry:l,errorDisplayed:R,informations:v,deactivateReactMemo:I,inputWrapper:u,defaultFormValue:y},r.createElement(Rt,{className:V(c.className,{"mrf-input__invalid":!!R})}));case be.buttonsSelect:case be.select:return r.createElement(Kt,{step:c,entry:o,realEntry:l,errorDisplayed:R,informations:v,deactivateReactMemo:I,inputWrapper:u,defaultFormValue:y},r.createElement(Nt,Object.assign({className:V("mrf-flex_grow_1",c.className,{"mrf-input__invalid":!!R}),disabled:f(o,c.disabled||!1,v,A)},c.props,{possibleValues:c.options,httpClient:d,isMulti:c.isMulti,createOption:c.createOption,onCreateOption:c.onCreateOption,transformer:c.transformer,buttons:c.format===be.buttonsSelect,optionsFrom:c.optionsFrom})));default:return r.createElement(Kt,{step:c,entry:o,realEntry:l,errorDisplayed:R,informations:v,deactivateReactMemo:I,inputWrapper:u,defaultFormValue:y},r.createElement("input",{type:c.format||"text",className:V("mrf-input",c.className,{"mrf-input__invalid":!!R})}))}case fe.number:switch(c.format){case be.buttonsSelect:case be.select:return r.createElement(Kt,{step:c,entry:o,realEntry:l,errorDisplayed:R,informations:v,deactivateReactMemo:I,inputWrapper:u,defaultFormValue:y},r.createElement(Nt,Object.assign({className:V("mrf-content",c.className,{"mrf-input__invalid":!!R})},c.props,{possibleValues:c.options,httpClient:d,isMulti:c.isMulti,createOption:c.createOption,onCreateOption:c.onCreateOption,transformer:c.transformer,buttons:c.format===be.buttonsSelect,optionsFrom:c.optionsFrom})));default:return r.createElement(Kt,{step:c,entry:o,realEntry:l,errorDisplayed:R,informations:v,deactivateReactMemo:I,inputWrapper:u,defaultFormValue:y},r.createElement("input",{type:c.format||"number",className:V("mrf-input",c.className,{"mrf-input__invalid":!!R})}))}case fe.bool:return r.createElement(Kt,{step:c,defaultFormValue:y,entry:o,realEntry:l,errorDisplayed:R,informations:v,deactivateReactMemo:I,inputWrapper:u},r.createElement(Ot,{className:c.className,errorDisplayed:R,buttons:c.format===be.buttonsSelect}));case fe.object:const t=P(o),n=Ye(c.defaultValue)?c.defaultValue:et(c.flow,c.schema);switch(c.format){case be.buttonsSelect:case be.select:return r.createElement(Kt,{step:Object.assign(Object.assign({},c),{defaultValue:t||n}),entry:o,realEntry:l,errorDisplayed:R,informations:v,deactivateReactMemo:I,inputWrapper:u,defaultFormValue:y},r.createElement(Nt,Object.assign({className:V("mrf-flex_grow_1",c.className,{"mrf-input__invalid":!!R})},c.props,{possibleValues:c.options,httpClient:d,isMulti:c.isMulti,createOption:c.createOption,onCreateOption:c.onCreateOption,transformer:c.transformer,buttons:c.format===be.buttonsSelect,optionsFrom:c.optionsFrom})));case be.form:const a=$e(c.flow).getOrElse($e(c.schema).map((e=>Object.keys(e))).getOrElse([]));return r.createElement(Kt,{step:Object.assign(Object.assign({},c),{defaultValue:t||n}),entry:o,realEntry:l,errorDisplayed:R,informations:v,deactivateReactMemo:I,inputWrapper:u,defaultFormValue:y},r.createElement(Gt,{render:c.render,rawValues:P(),value:P(o),onChange:e=>T(o,e,{shouldValidate:!0}),setValue:(e,t)=>T(e,t),getValue:e=>P(e),informations:v,defaultValue:t||n},r.createElement(Zt,{schema:c.schema,flow:a,step:c,parent:o,inputWrapper:u,maybeCustomHttpClient:d,value:P(o)||n,functionalProperty:f,errorDisplayed:R,informations:v,stepsOptions:e.options,defaultFormValue:y})));case be.code:return r.createElement(Kt,{step:Object.assign(Object.assign({},c),{defaultValue:t||n}),entry:o,realEntry:l,errorDisplayed:R,informations:v,deactivateReactMemo:I,inputWrapper:u,defaultFormValue:y,component:(e,t)=>r.createElement(Dt,Object.assign({},t,{className:V(null==c?void 0:c.className,{"mrf-input__invalid":!!A}),onChange:t=>{let r;try{r=JSON.parse(t)}catch(e){r=t}e.onChange(r),$e(null==c?void 0:c.onChange).map((e=>e({rawValues:P(),value:r,setValue:T})))},value:null===e.value?null:"object"==typeof e.value?JSON.stringify(e.value,null,2):e.value}))});default:return r.createElement(Kt,{step:Object.assign(Object.assign({},c),{defaultValue:t||n}),entry:o,realEntry:l,errorDisplayed:R,informations:v,deactivateReactMemo:I,inputWrapper:u,defaultFormValue:y},r.createElement(Wt,{className:V(c.className,{"mrf-input__invalid":!!R})}))}case fe.date:switch(c.format){case be.datetime:return r.createElement(Kt,{step:c,entry:o,realEntry:l,informations:v,deactivateReactMemo:I,inputWrapper:u,defaultFormValue:y,component:e=>r.createElement(E,{dateAdapter:j},r.createElement(x,{value:e.value,onChange:t=>{e.onChange(t),$e(c.onChange).map((e=>e({rawValues:P(),value:t,setValue:T})))},renderInput:e=>r.createElement(_,Object.assign({},e))}))});case be.time:return r.createElement(Kt,{step:c,entry:o,realEntry:l,informations:v,deactivateReactMemo:I,inputWrapper:u,defaultFormValue:y,component:e=>r.createElement(E,{dateAdapter:j},r.createElement(k,{value:e.value,onChange:t=>{e.onChange(t),$e(c.onChange).map((e=>e({rawValues:P(),value:t,setValue:T})))},renderInput:e=>r.createElement(_,Object.assign({},e))}))});default:return r.createElement(Kt,{step:c,entry:o,realEntry:l,informations:v,deactivateReactMemo:I,inputWrapper:u,defaultFormValue:y,component:e=>r.createElement(E,{dateAdapter:j},r.createElement(w,{value:e.value,onChange:t=>{e.onChange(t),$e(c.onChange).map((e=>e({rawValues:P(),value:t,setValue:T})))},renderInput:e=>r.createElement(_,Object.assign({},e))}))})}case fe.file:return r.createElement(b,{name:o,control:F,render:({field:e})=>r.createElement(Kt,{step:c,entry:o,realEntry:l,errorDisplayed:R,informations:v,deactivateReactMemo:I,inputWrapper:u,defaultFormValue:y},r.createElement((({onChange:t})=>{const[n,a]=i(!1),[l,s]=i(void 0),m=e.value||[];return r.createElement("div",{className:V("mrf-flex","mrf-ai_center",null==c?void 0:c.className,{"mrf-input__invalid":!!A})},r.createElement("input",{ref:e=>s(e),type:"file",multiple:!0,className:"mrf-d_none",onChange:e=>{const r=e.target.files;a(!0),t&&t(r?[...r]:[]),a(!1)}}),r.createElement("button",{type:"button",className:"mrf-btn mrf-btn_sm mrf-flex mrf-ai_center",disabled:n||f(o,(null==c?void 0:c.disabled)||!1,v,A),onClick:()=>{null==l||l.click()}},n&&r.createElement(it,null),!n&&r.createElement(mt,null),r.createElement("span",{className:"mrf-ml_5"},"Select file(s)")),r.createElement("span",{className:"mrf-ml_5"},m.length<=0?"No files selected":m.map((e=>e.name)).join(" , ")))}),null))});case fe.json:return r.createElement(Kt,{step:c,entry:o,realEntry:l,informations:v,deactivateReactMemo:I,inputWrapper:u,defaultFormValue:y,component:(e,t)=>r.createElement(Dt,Object.assign({},t,{className:V(null==c?void 0:c.className,{"mrf-input__invalid":!!A}),onChange:t=>{e.onChange(t),$e(null==c?void 0:c.onChange).map((e=>e({rawValues:P(),value:t,setValue:T})))},value:e.value}))});default:return null}},Zt=({schema:e,flow:t,parent:n,inputWrapper:a,maybeCustomHttpClient:o,errorDisplayed:l,value:s,step:c,functionalProperty:m,informations:d,stepsOptions:f,defaultFormValue:b})=>{var v;const{getValues:y,control:h}=p(),[g,O]=i(!!c.collapsed);u({name:(null===(v=null==c?void 0:c.conditionalSchema)||void 0===v?void 0:v.ref)||"",control:h});const j=$e(c.conditionalSchema).map((e=>{const t=$e(e.ref).map((e=>y(e))).getOrNull(),r=y(),n=$e(e.switch.find((e=>"function"==typeof e.condition?e.condition({rawValues:r,ref:t}):e.condition===t))).orElse(e.switch.find((e=>e.default))).getOrElse({schema:{},flow:[]});return{schema:n.schema,flow:n.flow||Object.keys(n.schema)}})).getOrElse({schema:e,flow:t}),E=j.flow.reduce(((e,t)=>[...e,{step:"string"==typeof t?j.schema[t]:j.schema[t.label],entry:t}]),[]),w=E.length>=1&&null!==c.label;return r.createElement("div",{className:V(c.className,{"mrf-nestedform__border":w,"mrf-border__error":!!l}),style:{position:"relative"}},!!c.collapsable&&j.flow.length>1&&g&&r.createElement(dt,{size:30,className:"mrf-cursor_pointer",style:{position:"absolute",top:-35,right:0,zIndex:100},strokeWidth:"2",onClick:()=>O(!g)}),!!c.collapsable&&j.flow.length>1&&!g&&r.createElement(vt,{size:30,className:"mrf-cursor_pointer",style:{position:"absolute",top:-35,right:0,zIndex:100},strokeWidth:"2",onClick:()=>O(!g)}),g&&!!c.collapsable&&"function"==typeof c.collapsable&&c.collapsable({rawValues:y(),getValue:e=>y(e),value:s}),("function"!=typeof c.collapsable||!g)&&E.map((({step:t,entry:l},i)=>g&&!t.visibleOnCollapse?null:"object"==typeof l?r.createElement(Qt,{key:i,entry:l,schema:e,inputWrapper:a,httpClient:o,functionalProperty:m,stepsOptions:f,defaultFormValue:b}):t||"string"!=typeof l?r.createElement(Xt,{key:`step.${l}.${i}`,entry:`${n}.${l}`,realEntry:l,step:j.schema[l],schema:j.schema,inputWrapper:a,httpClient:o,defaultValue:s&&s[l],functionalProperty:m,informations:{path:`${null==d?void 0:d.path}.${l}`,key:l,parent:d},options:f,defaultFormValue:b}):(console.error(`no step found for the entry "${l}" in the given schema. Your form might not work properly. Please fix it`),null))))},er=e=>{var t,n,a,o,l,i,s,c,m,u,p,d,f,b;if(e.render)return e.render({reset:e.reset,valid:e.valid});const v=void 0===(null===(n=null===(t=e.actions)||void 0===t?void 0:t.submit)||void 0===n?void 0:n.display)||!!(null===(o=null===(a=e.actions)||void 0===a?void 0:a.submit)||void 0===o?void 0:o.display);return r.createElement("div",{className:"mrf-flex mrf-jc_end mrf-mt_5"},(null===(i=null===(l=e.actions)||void 0===l?void 0:l.cancel)||void 0===i?void 0:i.display)&&r.createElement("button",{className:"mrf-btn mrf-btn_red",type:"button",onClick:()=>{var t,r;return null===(r=null===(t=e.actions)||void 0===t?void 0:t.cancel)||void 0===r?void 0:r.action()}},(null===(c=null===(s=e.actions)||void 0===s?void 0:s.cancel)||void 0===c?void 0:c.label)||"Cancel"),(null===(u=null===(m=e.actions)||void 0===m?void 0:m.reset)||void 0===u?void 0:u.display)&&r.createElement("button",{className:"mrf-btn mrf-btn_red",type:"button",onClick:e.reset},(null===(d=null===(p=e.actions)||void 0===p?void 0:p.reset)||void 0===d?void 0:d.label)||"Reset"),v&&r.createElement("button",{className:"mrf-btn mrf-btn_green mrf-ml_10",type:"submit"},(null===(b=null===(f=e.actions)||void 0===f?void 0:f.submit)||void 0===b?void 0:b.label)||"Save"))},tr=r.forwardRef(((t,n)=>{const{schema:o,flow:l,value:s,inputWrapper:u,onSubmit:p,onError:d=(()=>{}),footer:f,className:b,options:h={}}=t,g=l||Object.keys(o),O=(e,t)=>h.httpClient?h.httpClient(e,t):fetch(e,{method:t,headers:{Accept:"application/json","Content-Type":"application/json"}}),j=et(g,o,s),E=v({resolver:(t,r,n)=>m((t=>{const{shape:r,dependencies:n}=Je(g,o,[],t);return e.object().shape(r,n)})(t))(t,r,n),shouldFocusError:!1,mode:"onChange",defaultValues:tt(s,j,l,o)}),[w,k]=i(!1),{handleSubmit:x,reset:_,trigger:C}=E,{getValues:V}=E;a((()=>{h.showErrorsOnStart&&C()}),[C,w]),Xe((()=>{_(Object.assign({},tt(s,j,l,o)))}),[s,o,l]);const N=(e,t,r,n)=>"function"==typeof t?t({rawValues:V(),value:V(e),defaultFormValue:s,informations:r,getValue:e=>V(e),error:n}):t;return c(n,(()=>({handleSubmit:()=>x((e=>{const t=rt(e,o);p(t)}),d)(),trigger:C,methods:Object.assign(Object.assign({},E),{data:()=>rt(V(),o)})}))),r.createElement(y,Object.assign({},E),(!!h.watch||!!h.autosubmit)&&r.createElement(at,{options:h,control:E.control,schema:o,onSubmit:p,handleSubmit:x,onError:d}),r.createElement("form",{className:b||"mrf-pr_15 mrf-w_100",onSubmit:x((e=>{const t=rt(e,o);p(t)}),d)},g.map(((e,n)=>{var a,l,i,c,m,p;if("object"==typeof e)return r.createElement(Qt,{key:n,entry:e,schema:o,inputWrapper:u,httpClient:O,functionalProperty:N,stepsOptions:{addLabel:null===(i=null===(l=null===(a=t.options)||void 0===a?void 0:a.actions)||void 0===l?void 0:l.add)||void 0===i?void 0:i.label},defaultFormValue:s});const d=o[e];if(!d&&"string"==typeof e)return console.error(`no step found for the entry "${e}" in the given schema. Your form might not work properly. Please fix it`),null;const f={path:e,key:e};return r.createElement(Xt,{defaultFormValue:s,key:n,entry:e,step:d,schema:o,inputWrapper:u,httpClient:O,functionalProperty:N,informations:f,options:{addLabel:null===(p=null===(m=null===(c=t.options)||void 0===c?void 0:c.actions)||void 0===m?void 0:m.add)||void 0===p?void 0:p.label}})})),r.createElement(er,{render:f,reset:()=>_(j),valid:x((e=>p(rt(e,o))),d),actions:h.actions})))}));export{Ot as BooleanInput,Dt as CodeInput,Ct as Collapse,tr as Form,Rt as MarkdownInput,Wt as ObjectInput,Nt as SelectInput,It as SingleLineCode,De as constraints,be as format,fe as type};
1
+ import*as e from"yup";import*as t from"react";import r,{useRef as n,useEffect as a,useCallback as o,forwardRef as l,useState as i,useMemo as s,useImperativeHandle as c}from"react";import{yupResolver as m}from"@hookform/resolvers/yup";import{useWatch as u,useFormContext as p,useController as d,useFieldArray as f,Controller as h,useForm as b,FormProvider as v}from"react-hook-form";import y from"object-hash";import g from"lodash.debounce";import O from"fast-deep-equal";import{AdapterDateFns as j}from"@mui/x-date-pickers/AdapterDateFns";import{LocalizationProvider as E}from"@mui/x-date-pickers/LocalizationProvider";import{DatePicker as w}from"@mui/x-date-pickers/DatePicker";import{TimePicker as k}from"@mui/x-date-pickers/TimePicker";import{DateTimePicker as x}from"@mui/x-date-pickers/DateTimePicker";import _ from"@mui/material/TextField";import C from"prop-types";import V from"classnames";import N from"react-select/creatable";import S from"react-select";import{EditorState as F}from"@codemirror/state";import{javascript as P}from"@codemirror/lang-javascript";import{html as T}from"@codemirror/lang-html";import{json as M}from"@codemirror/lang-json";import{css as z}from"@codemirror/lang-css";import{markdown as W}from"@codemirror/lang-markdown";import{EditorView as L,highlightSpecialChars as A,drawSelection as D,dropCursor as $,highlightActiveLine as R,keymap as I}from"@codemirror/view";import{history as q,historyKeymap as B}from"@codemirror/history";import{foldGutter as H,foldKeymap as J}from"@codemirror/fold";import{defaultKeymap as U,indentWithTab as K}from"@codemirror/commands";import{indentUnit as Y}from"@codemirror/language";import{lineNumbers as G,highlightActiveLineGutter as Q}from"@codemirror/gutter";import{bracketMatching as X}from"@codemirror/matchbrackets";import{closeBrackets as Z,closeBracketsKeymap as ee}from"@codemirror/closebrackets";import{highlightSelectionMatches as te,searchKeymap as re}from"@codemirror/search";import{autocompletion as ne,completionKeymap as ae}from"@codemirror/autocomplete";import{commentKeymap as oe}from"@codemirror/comment";import{rectangularSelection as le}from"@codemirror/rectangular-selection";import{defaultHighlightStyle as ie}from"@codemirror/highlight";import{lintKeymap as se}from"@codemirror/lint";import{oneDark as ce}from"@codemirror/theme-one-dark";import me from"showdown";import"@fortawesome/fontawesome-free/css/all.css";import"highlight.js/styles/monokai.css";import ue from"highlight.js/lib/core";import pe from"react-tooltip";import{v4 as de}from"uuid";const fe={string:"string",number:"number",bool:"bool",date:"date",object:"object",file:"file",json:"json"};Object.values(fe);const he={array:"array",select:"select",code:"code",markdown:"markdown",text:"textarea",textarea:"textarea",email:"email",password:"password",hidden:"hidden",form:"form",buttonsSelect:"buttons",singleLineCode:"singleLineCode",datetime:"datetime-local",time:"time"};Object.values(he);const be=(e="Value required")=>t=>t.required(e),ve=(e="That is not a valid url")=>t=>t.url(e),ye=(e="That is not a valid email")=>t=>t.email(e),ge=(e="That is not a valid uuid")=>t=>t.uuid(e),Oe=(e=/.*/,t="This field does not match the pattern")=>r=>r.matches(e,{message:t,excludeEmptyString:!0}),je=(e,t="Min value is required")=>r=>r.min(Le(e),t),Ee=(e,t="Max value is required")=>r=>r.max(Le(e),t),we=(e="Positive value is required")=>t=>t.positive(e),ke=(e="Negative value is required")=>t=>t.negative(e),xe=(e="an integer please")=>t=>t.integer(e),_e=(e,t=`This field must be less than ${e}`)=>(r,n,a)=>("number"!=typeof e&&a.push([n,e]),r.lessThan(Le(e),t)),Ce=(e,t=`This field must be more than ${e}`)=>(r,n,a)=>("number"!=typeof e&&a.push([n,e]),r.moreThan(Le(e),t)),Ve=(e,t=`The size of this collection must be ${e}`)=>r=>r.length(Le(e),t),Ne=(e,t="Unsupported File Format")=>r=>{const n=e.map((e=>e.toLowerCase()));return r.test("supportedFormat",t,(e=>!e.length||n.some((t=>e[0].type.toLowerCase().includes(t)))))},Se=(e,t="Unsupported File Format")=>r=>{const n=e.map((e=>e.toLowerCase()));return r.test("unsupportedFormat",t,(e=>!e.length||n.some((t=>e[0].type.toLowerCase().includes(t)))))},Fe=(e,t=`size is excedeed ${e}`)=>r=>r.test("fileSize",t,(t=>!t.length||t[0].size<=Le(e))),Pe=(e,t="Test failed",r)=>n=>n.test(e,t,r),Te=(e,t,r=[],n=[])=>(a,o,l)=>{const i=r.reduce(((e,t)=>t(e,o,l)),a),s=n.reduce(((e,t)=>t(e,o,l)),a);return a.when(e,{is:t,then:i,otherwise:s})},Me=(e,t=`This value must be one of ${e.join(", ")}`)=>r=>r.oneOf(e.map(Le),t),ze=(e,t=`This value can't include the following values ${e.join(", ")}`)=>r=>r.test("blacklist",t,(t=>!e.some((e=>(t||"").includes(e))))),We=t=>e.ref(t),Le=e=>(null==e?void 0:e.ref)?We(e.ref):e,Ae={required:({message:e="Value required"})=>be(e),url:({message:e="That is not a valid url"})=>ve(e),email:({message:e="That is not a valid email"})=>ye(e),uuid:({message:e="That is not a valid uuid"})=>ge(e),matches:({regexp:e=/.*/,message:t="This field does not match the pattern"})=>Oe(e,t),min:({ref:e,message:t="Min value is required"})=>je(e,t),max:({ref:e,message:t="Max value is required"})=>Ee(e,t),positive:({message:e="Positive value is required"})=>we(e),negative:({message:e="Negative value is required"})=>ke(e),integer:({message:e="an integer please"})=>xe(e),lessThan:({ref:e,message:t=`This field must be less than ${e}`})=>_e(e,t),moreThan:({ref:e,message:t=`This field must be more than ${e}`})=>Ce(e,t),length:({ref:e,message:t=`The size of this collection must be ${e}`})=>Ve(e,t),supportedFormat:({arrayOfValues:e,message:t="Unsupported File Format"})=>Ne(e,t),unsupportedFormat:({arrayOfValues:e,message:t="Unsupported File Format"})=>Se(e,t),maxSize:({ref:e,message:t=`size is excedeed ${e}`})=>Fe(e,t),test:e=>Pe(e.name,e.message,e.test),when:({ref:e,test:t,then:r=[],otherwise:n=[]})=>Te(e,t,r,n),oneOf:({arrayOfValues:e,message:t=`This value must be one of ${e.join(", ")}`})=>Me(e,t),blacklist:({arrayOfValues:e,message:t=`This value can't include the following values ${e.join(", ")}`})=>ze(e,t),ref:e=>We(e.ref)};var De=Object.freeze({__proto__:null,required:be,url:ve,email:ye,uuid:ge,matches:Oe,min:je,max:Ee,positive:we,negative:ke,integer:xe,lessThan:_e,moreThan:Ce,length:Ve,supportedFormat:Ne,unsupportedFormat:Se,maxSize:Fe,test:Pe,when:Te,oneOf:Me,blacklist:ze,ref:We,jsonConstraints:Ae});function $e(e){return null==e?Ie:Re(e)}const Re=e=>({map:t=>$e(t(e)),flatMap:t=>$e(t(e)).getOrElse(Ie),fold:(t,r)=>r(e),orElse:()=>$e(e),getOrElse:()=>e,getOrNull:()=>e,isDefined:()=>!0,exists:t=>$e(t(e)).isDefined()}),Ie={map:()=>Ie,flatMap:()=>Ie,fold:e=>e(),orElse:e=>$e(e),getOrElse:e=>e,getOrNull:()=>{},isDefined:()=>!1,exists:()=>!1},qe={[fe.string]:t=>e.string().nullable().optional().typeError(t||"Value must be a string"),[fe.number]:t=>e.number().nullable().optional().transform((e=>isNaN(e)?null:e)).typeError(t||"Value must be a number"),[fe.bool]:()=>e.bool().nullable().optional(),[fe.object]:()=>e.object().nullable().optional(),[fe.date]:t=>e.date().nullable().optional().typeError(t||"Value must be a date"),[fe.file]:()=>e.mixed(),[fe.json]:()=>e.mixed()},Be=(t,r,n,a)=>{var o,l;const{constraints:i=[]}=t;if(t.array||t.isMulti){let i,s=e.array().nullable().optional();if(t.schema){const r=[];i=e.object().shape(Je(t.flow||Object.keys(t.schema),t.schema,r,a).shape,r),s=s.of(e.object().shape({value:i}))}else(null===(o=t.constraints)||void 0===o?void 0:o.length)&&(i=t.constraints.reduce(((e,t)=>He(t,e,r,n)),qe[t.type]()),s=s.of(e.object().shape({value:i})));return(null===(l=t.arrayConstraints)||void 0===l?void 0:l.length)&&(s=t.arrayConstraints.reduce(((e,t)=>He(t,e,r,n)),s)),s}if(t.type===fe.object&&t.schema){if(!Object.keys(t.schema).length)return e.object().nullable().optional();const o=Je(t.flow||Object.keys(t.schema),t.schema,n,a);return i.reduce(((e,t)=>He(t,e,r,n)),e.object().nullable().optional().shape(o.shape,n))}if(t.type===fe.object&&t.conditionalSchema){const{schema:o,flow:l}=$e(t.conditionalSchema).map((e=>{const t=$e(e.ref).map((e=>a[e])).getOrNull();return $e(e.switch.find((e=>"function"==typeof e.condition?e.condition({rawValues:a,ref:t}):e.condition===t))).orElse(e.switch.find((e=>e.default))).getOrElse({schema:{},flow:[]})})).getOrElse({schema:{},flow:[]}),s=Je(l||Object.keys(o),o,n,a);return i.reduce(((e,t)=>He(t,e,r,n)),e.object().nullable().optional().shape(s.shape,n))}return i.reduce(((e,t)=>He(t,e,r,n)),qe[t.type]())},He=(e,t,r,n)=>"function"==typeof e?e(t,r,n):Ae[e.type](e)(t,r,n),Je=(e,t,r=[],n={})=>{if(!Object.keys(t).length)return{shape:{},dependencies:r};const a=(e||Object.keys(t)).reduce(((e,a)=>{if("object"==typeof a)return Object.assign(Object.assign({},e),Je(a.flow,t,r,n).shape);if(!t[a])return e;const o=Be(t[a],a,r,n);return Object.assign(Object.assign({},e),{[a]:o})}),{});return{shape:a,dependencies:r}},Ue=e=>Boolean(e&&"function"==typeof e.then),Ke=e=>e.some(Array.isArray)?Ke(e.flat()):e;function Ye(e){return null!=e}const Ge=e=>e&&Array.isArray(e)?e.map(Ge):e&&"object"==typeof e?Object.fromEntries(Object.entries(e).map((([e,t])=>Ue(t)?[e,`promise-${e}`]:"object"==typeof t?[e,Ge(t)]:[e,t]))):e,Qe=e=>y(Ge(e)),Xe=(e,t)=>{const r=n(!0),o=n(t);a((()=>{if(r.current)return e(),void(r.current=!1);Qe(t)!==Qe(o.current)&&(o.current=Object.assign({},t),e())}),t)},Ze=(e,t,r,n)=>Ye(r)?r:t?[]:e;function et(e,t,r){return t?(e||Object.keys(t)).reduce(((e,n)=>{if("object"==typeof n)return Object.assign(Object.assign({},e),et(n.flow,t,r));const a=t[n];return a?a.schema&&!a.array?Object.assign(Object.assign({},e),{[n]:a.defaultValue||et(a.flow,a.schema)}):Object.assign(Object.assign({},e),{[n]:Ze(r?r[n]:null,a.array||a.isMulti||!1,a.defaultValue)}):e}),{}):{}}const tt=(e,t={},r,n)=>{const a=$e(r).map((e=>e.map((e=>"object"==typeof e?e.flow:e)))).map(Ke).getOrElse(Object.keys(n||{}));return Object.entries(n||{}).filter((([e])=>a.includes(e))).reduce(((r,[a,o])=>{var l,i;let s=null;e&&(s=e[a]);const c=t[a];return!s&&Ye(c)&&(s=c),o.array&&!o.render?Object.assign(Object.assign({},r),{[a]:(s||[]).map((e=>{var r,o;return{value:"object"!=typeof e||e instanceof Date||Array.isArray(e)?e:tt(e,t,null===(r=null==n?void 0:n[a])||void 0===r?void 0:r.flow,(null===(o=null==n?void 0:n[a])||void 0===o?void 0:o.schema)||{})}}))}):null===s||"object"!=typeof s||s instanceof Date||Array.isArray(s)?Object.assign(Object.assign({},r),{[a]:void 0===s?Array.isArray(s)?[]:null:s}):Object.assign(Object.assign({},r),{[a]:tt(null==e?void 0:e[a],null==t?void 0:t[a],null===(l=null==n?void 0:n[a])||void 0===l?void 0:l.flow,(null===(i=null==n?void 0:n[a])||void 0===i?void 0:i.schema)||{})})}),e||{})},rt=(e,t)=>!e||"object"!=typeof e||e instanceof Date||Array.isArray(e)?e:Object.entries(e).reduce(((e,r)=>{var n,a;const[o,l]=r;if(Array.isArray(l)){return $e(t).map((e=>e[o])).map((e=>!!e.array&&!e.render)).getOrElse(!1)?Object.assign(Object.assign({},e),{[o]:l.map((e=>{var r;return!e.value||"object"!=typeof e.value||e.value instanceof Date&&!Array.isArray(e.value)?e.value:rt(e.value,(null===(r=t[o])||void 0===r?void 0:r.schema)||{})}))}):Object.assign(Object.assign({},e),{[o]:l})}if(!(!l||"object"!=typeof l||l instanceof Date&&!Array.isArray(l)))return Object.assign(Object.assign({},e),{[o]:rt(l,(null===(n=t[o])||void 0===n?void 0:n.schema)||{})});if("json"!==(null===(a=t[o])||void 0===a?void 0:a.type))return Object.assign(Object.assign({},e),{[o]:l});try{return Object.assign(Object.assign({},e),{[o]:JSON.parse(l)})}catch(t){return Object.assign(Object.assign({},e),{[o]:l})}}),{});function nt(e){return e.flow.map((e=>"string"==typeof e?e:nt(e))).flat()}const at=r.memo((({options:e,control:t,schema:r,onSubmit:n,handleSubmit:a,onError:l})=>{const i=u({control:t}),s=o(g((e=>a((()=>n(rt(e,r))),l)()),250,{leading:!0}),[]);return Xe((()=>{(null==e?void 0:e.autosubmit)&&s(i)}),[i]),(null==e?void 0:e.watch)&&("function"==typeof e.watch?e.watch(rt(i,r)):(console.group("react-form watch"),console.log(rt(i,r)),console.groupEnd())),null}),(()=>!0));function ot(){return ot=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e},ot.apply(this,arguments)}function lt(e,t){if(null==e)return{};var r,n,a=function(e,t){if(null==e)return{};var r,n,a={},o=Object.keys(e);for(n=0;n<o.length;n++)r=o[n],t.indexOf(r)>=0||(a[r]=e[r]);return a}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n<o.length;n++)r=o[n],t.indexOf(r)>=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(a[r]=e[r])}return a}var it=l((function(e,t){var n=e.color,a=void 0===n?"currentColor":n,o=e.size,l=void 0===o?24:o,i=lt(e,["color","size"]);return r.createElement("svg",ot({ref:t,xmlns:"http://www.w3.org/2000/svg",width:l,height:l,viewBox:"0 0 24 24",fill:"none",stroke:a,strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"},i),r.createElement("line",{x1:"12",y1:"2",x2:"12",y2:"6"}),r.createElement("line",{x1:"12",y1:"18",x2:"12",y2:"22"}),r.createElement("line",{x1:"4.93",y1:"4.93",x2:"7.76",y2:"7.76"}),r.createElement("line",{x1:"16.24",y1:"16.24",x2:"19.07",y2:"19.07"}),r.createElement("line",{x1:"2",y1:"12",x2:"6",y2:"12"}),r.createElement("line",{x1:"18",y1:"12",x2:"22",y2:"12"}),r.createElement("line",{x1:"4.93",y1:"19.07",x2:"7.76",y2:"16.24"}),r.createElement("line",{x1:"16.24",y1:"7.76",x2:"19.07",y2:"4.93"}))}));function st(){return st=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e},st.apply(this,arguments)}function ct(e,t){if(null==e)return{};var r,n,a=function(e,t){if(null==e)return{};var r,n,a={},o=Object.keys(e);for(n=0;n<o.length;n++)r=o[n],t.indexOf(r)>=0||(a[r]=e[r]);return a}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n<o.length;n++)r=o[n],t.indexOf(r)>=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(a[r]=e[r])}return a}it.propTypes={color:C.string,size:C.oneOfType([C.string,C.number])},it.displayName="Loader";var mt=l((function(e,t){var n=e.color,a=void 0===n?"currentColor":n,o=e.size,l=void 0===o?24:o,i=ct(e,["color","size"]);return r.createElement("svg",st({ref:t,xmlns:"http://www.w3.org/2000/svg",width:l,height:l,viewBox:"0 0 24 24",fill:"none",stroke:a,strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"},i),r.createElement("path",{d:"M21 15v4a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2v-4"}),r.createElement("polyline",{points:"17 8 12 3 7 8"}),r.createElement("line",{x1:"12",y1:"3",x2:"12",y2:"15"}))}));function ut(){return ut=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e},ut.apply(this,arguments)}function pt(e,t){if(null==e)return{};var r,n,a=function(e,t){if(null==e)return{};var r,n,a={},o=Object.keys(e);for(n=0;n<o.length;n++)r=o[n],t.indexOf(r)>=0||(a[r]=e[r]);return a}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n<o.length;n++)r=o[n],t.indexOf(r)>=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(a[r]=e[r])}return a}mt.propTypes={color:C.string,size:C.oneOfType([C.string,C.number])},mt.displayName="Upload";var dt=l((function(e,t){var n=e.color,a=void 0===n?"currentColor":n,o=e.size,l=void 0===o?24:o,i=pt(e,["color","size"]);return r.createElement("svg",ut({ref:t,xmlns:"http://www.w3.org/2000/svg",width:l,height:l,viewBox:"0 0 24 24",fill:"none",stroke:a,strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"},i),r.createElement("polyline",{points:"6 9 12 15 18 9"}))}));function ft(){return ft=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e},ft.apply(this,arguments)}function ht(e,t){if(null==e)return{};var r,n,a=function(e,t){if(null==e)return{};var r,n,a={},o=Object.keys(e);for(n=0;n<o.length;n++)r=o[n],t.indexOf(r)>=0||(a[r]=e[r]);return a}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n<o.length;n++)r=o[n],t.indexOf(r)>=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(a[r]=e[r])}return a}dt.propTypes={color:C.string,size:C.oneOfType([C.string,C.number])},dt.displayName="ChevronDown";var bt=l((function(e,t){var n=e.color,a=void 0===n?"currentColor":n,o=e.size,l=void 0===o?24:o,i=ht(e,["color","size"]);return r.createElement("svg",ft({ref:t,xmlns:"http://www.w3.org/2000/svg",width:l,height:l,viewBox:"0 0 24 24",fill:"none",stroke:a,strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"},i),r.createElement("polyline",{points:"18 15 12 9 6 15"}))}));function vt(){return vt=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e},vt.apply(this,arguments)}function yt(e,t){if(null==e)return{};var r,n,a=function(e,t){if(null==e)return{};var r,n,a={},o=Object.keys(e);for(n=0;n<o.length;n++)r=o[n],t.indexOf(r)>=0||(a[r]=e[r]);return a}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n<o.length;n++)r=o[n],t.indexOf(r)>=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(a[r]=e[r])}return a}bt.propTypes={color:C.string,size:C.oneOfType([C.string,C.number])},bt.displayName="ChevronUp";var gt=l((function(e,t){var n=e.color,a=void 0===n?"currentColor":n,o=e.size,l=void 0===o?24:o,i=yt(e,["color","size"]);return r.createElement("svg",vt({ref:t,xmlns:"http://www.w3.org/2000/svg",width:l,height:l,viewBox:"0 0 24 24",fill:"none",stroke:a,strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"},i),r.createElement("polyline",{points:"3 6 5 6 21 6"}),r.createElement("path",{d:"M19 6v14a2 2 0 0 1-2 2H7a2 2 0 0 1-2-2V6m3 0V4a2 2 0 0 1 2-2h4a2 2 0 0 1 2 2v2"}),r.createElement("line",{x1:"10",y1:"11",x2:"10",y2:"17"}),r.createElement("line",{x1:"14",y1:"11",x2:"14",y2:"17"}))}));gt.propTypes={color:C.string,size:C.oneOfType([C.string,C.number])},gt.displayName="Trash2";const Ot=({onChange:e,value:t,readOnly:n,className:a,errorDisplayed:o,buttons:l,trueLabel:i,falseLabel:s})=>{const c=t=>{n||null==e||e(t)};let m=V("mrf-content_switch",a,{"mrf-content_switch_button_on":!!t,"mrf-content_switch_button_off":!t&&null!==t,"mrf-content_switch_button_null":null===t,"mrf-cursor_pointer":!n,"mrf-cursor_not_allowed":n,"mrf-input__invalid":!!o}),u=()=>c(!0);return t&&(u=()=>c(!1)),l?r.createElement("div",{className:"d-flex"},r.createElement("button",{type:"button",className:V("mrf-flex_grow_1 mrf-btn mrf-btn_grey mrf-ml_5",{active:!!t}),onClick:()=>e(!0)},i||"true"),r.createElement("button",{type:"button",className:V("mrf-flex_grow_1 mrf-btn mrf-btn_grey mrf-ml_5",{active:!t}),onClick:()=>e(!1)},s||"false")):r.createElement("input",{type:"checkbox",className:m,onChange:u})};function jt(){return jt=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e},jt.apply(this,arguments)}function Et(e,t){if(null==e)return{};var r,n,a=function(e,t){if(null==e)return{};var r,n,a={},o=Object.keys(e);for(n=0;n<o.length;n++)r=o[n],t.indexOf(r)>=0||(a[r]=e[r]);return a}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n<o.length;n++)r=o[n],t.indexOf(r)>=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(a[r]=e[r])}return a}var wt=l((function(e,t){var n=e.color,a=void 0===n?"currentColor":n,o=e.size,l=void 0===o?24:o,i=Et(e,["color","size"]);return r.createElement("svg",jt({ref:t,xmlns:"http://www.w3.org/2000/svg",width:l,height:l,viewBox:"0 0 24 24",fill:"none",stroke:a,strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"},i),r.createElement("path",{d:"M17.94 17.94A10.07 10.07 0 0 1 12 20c-7 0-11-8-11-8a18.45 18.45 0 0 1 5.06-5.94M9.9 4.24A9.12 9.12 0 0 1 12 4c7 0 11 8 11 8a18.5 18.5 0 0 1-2.16 3.19m-6.72-1.07a3 3 0 1 1-4.24-4.24"}),r.createElement("line",{x1:"1",y1:"1",x2:"23",y2:"23"}))}));function kt(){return kt=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e},kt.apply(this,arguments)}function xt(e,t){if(null==e)return{};var r,n,a=function(e,t){if(null==e)return{};var r,n,a={},o=Object.keys(e);for(n=0;n<o.length;n++)r=o[n],t.indexOf(r)>=0||(a[r]=e[r]);return a}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n<o.length;n++)r=o[n],t.indexOf(r)>=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(a[r]=e[r])}return a}wt.propTypes={color:C.string,size:C.oneOfType([C.string,C.number])},wt.displayName="EyeOff";var _t=l((function(e,t){var n=e.color,a=void 0===n?"currentColor":n,o=e.size,l=void 0===o?24:o,i=xt(e,["color","size"]);return r.createElement("svg",kt({ref:t,xmlns:"http://www.w3.org/2000/svg",width:l,height:l,viewBox:"0 0 24 24",fill:"none",stroke:a,strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"},i),r.createElement("path",{d:"M1 12s4-8 11-8 11 8 11 8-4 8-11 8-11-8-11-8z"}),r.createElement("circle",{cx:"12",cy:"12",r:"3"}))}));_t.propTypes={color:C.string,size:C.oneOfType([C.string,C.number])},_t.displayName="Eye";const Ct=e=>{const[t,n]=i(e.initCollapsed||e.collapsed),a=e=>{e&&e.stopPropagation(),n(!t)};return r.createElement("div",null,r.createElement("hr",{className:V({"mrf-collapse_error":e.errored})}),r.createElement("div",{className:"mrf-cursor_pointer mrf-flex mrf-jc_between",onClick:a},r.createElement("span",{className:V("mrf-collapse_label",{"mrf-collapse_error":e.errored})},e.label),r.createElement("button",{type:"button",className:V("mrf-btn","mrf-btn_sm","mrf-ml_5",{"mrf-collapse_error":e.errored}),onClick:a},!!t&&r.createElement(_t,{size:16}),!t&&r.createElement(wt,{size:16}))),r.createElement("div",{className:V("mrf-ml_10",{"mrf-display__none":!!t,"mrf-flex":!!e.inline,"mrf-collapse__inline":!!e.inline})},e.children),e.lineEnd&&r.createElement("hr",null))},Vt=(e,t=[],r=!1)=>{if(null===e||!e)return null;if(r)return $e(e).map((e=>(Array.isArray(e)?e||[]:"object"==typeof e?Object.values(e):e).map((e=>Vt(e,t,!1))))).getOrElse([]);const n=$e(t.find((t=>O(t.value,e))));return n.getOrElse({label:n.map((e=>e.label)).getOrElse((null==e?void 0:e.label)||("object"==typeof e?JSON.stringify(e):e)),value:n.map((e=>e.value)).getOrElse((null==e?void 0:e.value)||e)})},Nt=e=>{const{getValues:t}=p();function n(t){const r=e.transformer?"function"==typeof e.transformer?e.transformer(t):{label:t[e.transformer.label],value:t[e.transformer.value]}:t;return{label:(null==r?void 0:r.label)||("object"==typeof r?JSON.stringify(r):r),value:(null==r?void 0:r.value)||t}}const o=(e.possibleValues||[]).map((e=>n(e))),[l,s]=i(!0),[c,m]=i(o),[u,d]=i();a((()=>{!l&&c.length&&d(Vt(e.value||e.defaultValue,c,e.isMulti))}),[e.value,c,e.defaultValue,l]),a((()=>{if(e.optionsFrom){if($e(e.fetchCondition).map((e=>e())).getOrElse(!0)){let r;if(s(!0),Ue(e.optionsFrom))r=e.optionsFrom;else if("function"==typeof e.optionsFrom){const n=e.optionsFrom({rawValues:rt(t(),e.schema),value:t(e.id),getValue:e=>t(e)});r=Ue(n)?n:e.httpClient(n,"GET").then((e=>e.json()))}else r=e.httpClient(e.optionsFrom,"GET").then((e=>e.json()));r.then((e=>e.map((e=>n(e))))).then((e=>{m(e),d(e.find((e=>Array.isArray(u)?u.find((t=>t.value===e.value)):e.value===(u?u.value:u)))||null),s(!1)}))}}else m((e.possibleValues||[]).map((e=>n(e)))),setTimeout((()=>s(!1)),250)}),[e.optionsFrom,e.possibleValues,e.onChange]);const f=t=>{var r,n;d(t),e.isMulti?null===(r=null==e?void 0:e.onChange)||void 0===r||r.call(e,t.map((e=>e.value))):null===(n=null==e?void 0:e.onChange)||void 0===n||n.call(e,null==t?void 0:t.value)},h=(t,r)=>{const n=$e(r).map((e=>e(t))).flatMap((t=>{return r=t,e.transformer?"function"==typeof e.transformer?$e(e.transformer(r)):Re({label:r[e.transformer.label],value:r[e.transformer.value]}):Ie;var r})).getOrElse(Vt(t,c));m([...c||[],n]),e.isMulti?f([...u||[],n]):f(n)};return e.buttons?r.createElement("div",{style:{display:"flex"}},c.map(((t,n)=>{const a=!!u&&(e.isMulti?u.includes(t):t.value===u.value);return r.createElement("button",{key:n,type:"button",disabled:e.disabled,className:V(e.className,"mrf-btn mrf-btn_grey mrf-ml_5",{active:a}),onClick:()=>(t=>{if(e.isMulti){const e=u;return e.includes(t)?f(e.filter((e=>e.value!==t.value))):f([...e,t])}return!e.isMulti&&e.isClearable&&u&&t.value===u.value?f(null):f(t)})(t)},t.label)}))):e.createOption?r.createElement(N,Object.assign({},e,{name:`${e.label}-search`,isLoading:l,value:u,isDisabled:l||e.disabled,placeholder:e.placeholder,onChange:f,options:c,onCreateOption:t=>h(t,e.onCreateOption),classNamePrefix:"react-form-select",className:e.className})):r.createElement(S,Object.assign({},e,{name:`${e.label}-search`,isLoading:l,value:u,defaultValue:u,isDisabled:l||e.disabled,placeholder:e.placeholder,options:c,onChange:f,classNamePrefix:"react-form-select",className:e.className}))};function St(){return St=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e},St.apply(this,arguments)}function Ft(e,t){if(null==e)return{};var r,n,a=function(e,t){if(null==e)return{};var r,n,a={},o=Object.keys(e);for(n=0;n<o.length;n++)r=o[n],t.indexOf(r)>=0||(a[r]=e[r]);return a}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n<o.length;n++)r=o[n],t.indexOf(r)>=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(a[r]=e[r])}return a}var Pt=l((function(e,t){var n=e.color,a=void 0===n?"currentColor":n,o=e.size,l=void 0===o?24:o,i=Ft(e,["color","size"]);return r.createElement("svg",St({ref:t,xmlns:"http://www.w3.org/2000/svg",width:l,height:l,viewBox:"0 0 24 24",fill:"none",stroke:a,strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"},i),r.createElement("circle",{cx:"12",cy:"12",r:"10"}),r.createElement("line",{x1:"12",y1:"8",x2:"12",y2:"16"}),r.createElement("line",{x1:"8",y1:"12",x2:"16",y2:"12"}))}));function Tt(){return Tt=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e},Tt.apply(this,arguments)}function Mt(e,t){if(null==e)return{};var r,n,a=function(e,t){if(null==e)return{};var r,n,a={},o=Object.keys(e);for(n=0;n<o.length;n++)r=o[n],t.indexOf(r)>=0||(a[r]=e[r]);return a}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n<o.length;n++)r=o[n],t.indexOf(r)>=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(a[r]=e[r])}return a}Pt.propTypes={color:C.string,size:C.oneOfType([C.string,C.number])},Pt.displayName="PlusCircle";var zt=l((function(e,t){var n=e.color,a=void 0===n?"currentColor":n,o=e.size,l=void 0===o?24:o,i=Mt(e,["color","size"]);return r.createElement("svg",Tt({ref:t,xmlns:"http://www.w3.org/2000/svg",width:l,height:l,viewBox:"0 0 24 24",fill:"none",stroke:a,strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"},i),r.createElement("circle",{cx:"12",cy:"12",r:"10"}),r.createElement("line",{x1:"8",y1:"12",x2:"16",y2:"12"}))}));zt.propTypes={color:C.string,size:C.oneOfType([C.string,C.number])},zt.displayName="MinusCircle";const Wt=e=>{const[r,n]=i({});a((()=>{n(Object.fromEntries(Object.entries(e.value||{}).map((([e,t],r)=>[Date.now()+r,{key:e,value:t}]))))}),[]),a((()=>{if(e.value){const t=e.value||{},a=Object.entries(r||{}).reduce(((e,[t,r])=>r.key?Object.assign(Object.assign({},e),{[r.key]:r.value}):e),{});O(t,a)||n(Object.fromEntries(Object.entries(e.value||{}).map((([e,t],r)=>[Date.now()+r,{key:e,value:t}]))))}}),[e.value]);const o=t=>{var r;null===(r=null==e?void 0:e.onChange)||void 0===r||r.call(e,Object.values(t).reduce(((e,t)=>Object.assign(Object.assign({},e),{[t.key]:t.value})),{}))},l=()=>{const t=e.defaultKeyValue||{key:"",value:""},a=Object.assign(Object.assign({},r),{[Date.now()]:t});n(a),o(a)};return t.createElement("div",{className:e.className},0===Object.keys(r||{}).length&&t.createElement("button",{disabled:e.disabled,type:"button",className:"mrf-flex mrf-btn mrf-btn_blue mrf-btn_sm",onClick:()=>{if(!r||0===Object.keys(r).length){const t=Object.assign(Object.assign({},r),{[Date.now()]:e.defaultKeyValue||{key:"",value:""}});n(t),o(t)}}},t.createElement(Pt,null)),Object.entries(r||{}).map((([a,{key:i,value:s}],c)=>t.createElement("div",{className:"mrf-flex mrf-mt_5",key:c},t.createElement("input",{disabled:e.disabled,type:"text",className:"mrf-w_50 mrf-input",placeholder:e.placeholderKey,value:i,onChange:e=>((e,t)=>{const a=Object.assign(Object.assign({},r),{[e]:{key:t,value:r[e].value}});n(a),o(a)})(a,e.target.value)}),t.createElement("input",{disabled:e.disabled,type:"text",className:"mrf-w_50 mrf-input",placeholder:e.placeholderValue,value:s,onChange:e=>((e,t)=>{const a=Object.assign(Object.assign({},r),{[e]:{key:r[e].key,value:t}});n(a),o(a)})(a,e.target.value)}),t.createElement("button",{disabled:e.disabled,type:"button",className:"mrf-flex mrf-ai_center mrf-btn mrf-btn_red mrf-btn_sm mrf-ml_10",onClick:()=>(e=>{const t=Object.fromEntries(Object.entries(r).filter((([t,r])=>t!==e)));n(t),o(t)})(a)},t.createElement(zt,null)),c===Object.keys(r).length-1&&t.createElement("button",{disabled:e.disabled,type:"button",className:"mrf-flex mrf-ai_center mrf-btn mrf-btn_blue mrf-btn_sm mrf-ml_5",onClick:l},t.createElement(Pt,null))))))},Lt={javascript:P,css:z,json:M,html:T,markdown:W};function At(e,t,r=1,n=!1,a=!0,o=!1,l={height:"-1",minHeight:"300px",maxHeight:"-1",width:"-1",minWidth:"-1",maxWidth:"-1"},i,s){const c=L.theme({"&":Object.assign({},l)}),m=[a?G():G({formatNumber:()=>""}),Q(),A(),q(),Lt[t](),H(),D(),$(),F.allowMultipleSelections.of(!0),ie.fallback,X(),Z(),ne(),le(),o?R():void 0,te(),I.of([...ee,...U,...re,...B,...J,...oe,...ae,...se,K]),ce,c,F.tabSize.of(r),Y.of(" ".repeat(r))].filter((e=>!!e)),u=F.create({extensions:[...m,L.updateListener.of((e=>{try{if(e.docChanged){const t=e.state.doc.toString();null==i||i(t)}}catch(e){}})),L.editable.of(!n)],doc:null==s?"":"object"==typeof s?s.value:s});return new L({state:u,parent:e})}function Dt({onChange:e,value:t,mode:o="javascript",tabSize:l=2,readOnly:s=!1,showLinesNumber:c=!0,highlightLine:m=!1,themeStyle:u={height:"-1",minHeight:"300px",maxHeight:"-1",width:"-1",minWidth:"-1",maxWidth:"-1"},className:p,setRef:d}){const f=n(),[h,b]=i();return a((()=>{const r=At(f.current,o,l,s,c,m,u,e,t);f.current.addEventListener("keydown",(e=>{e.stopImmediatePropagation()})),d&&d(r),r.dispatch({changes:{from:0,to:r.state.doc.length,insert:null==t?"":"object"==typeof t?JSON.stringify(t,null,2):t}}),b(r)}),[]),a((()=>{h&&("object"==typeof t?JSON.stringify(t,null,2):t)!==h.state.doc.toString()&&h.dispatch({changes:{from:0,to:h.state.doc.length,insert:null==t?"":"object"==typeof t?JSON.stringify(t,null,2):t}})}),[t]),r.createElement("div",{className:p,ref:f})}const $t=new me.Converter({omitExtraWLInCodeBlocks:!0,ghCompatibleHeaderId:!0,parseImgDimensions:!0,simplifiedAutoLink:!0,tables:!0,tasklists:!0,requireSpaceBeforeHeadingText:!0,ghMentions:!0,emoji:!0,ghMentionsLink:"/{u}"}),Rt=e=>{const[t,o]=i(e.preview||!1),l=n();a((()=>{t&&c()}),[t,e.value]);const s=[{name:"Add header",icon:"heading",inject:e=>[{from:e.from,insert:"# "}]},{name:"Add bold text",icon:"bold",inject:e=>[{from:e.from,insert:"**"},{from:e.to,insert:"**"}]},{name:"Add italic text",icon:"italic",inject:e=>[{from:e.from,insert:"*"},{from:e.to,insert:"*"}]},{name:"Add strikethrough text",icon:"strikethrough",inject:e=>[{from:e.from,insert:"~~"},{from:e.to,insert:"~~"}]},{name:"Add link",icon:"link",inject:e=>[{from:e.from,insert:"["},{from:e.to,insert:"](url)"}]},{name:"Add code",icon:"code",inject:e=>[{from:e.from,insert:"```\n"},{from:e.to,insert:"\n```\n"}]},{name:"Add quotes",icon:"quote-right",inject:e=>[{from:e.from,insert:"> "}]},{name:"Add image",icon:"image",inject:e=>[{from:e.from,insert:"!["},{from:e.to,insert:"](image-url)"}]},{name:"Add unordered list",icon:"list-ul",inject:e=>[{from:e.from,insert:"* "}]},{name:"Add ordered list",icon:"list-ol",inject:e=>[{from:e.from,insert:"1. "}]},{name:"Add check list",icon:"tasks",inject:e=>[{from:e.from,insert:"* [ ] "}]}],c=()=>{const e=[...document.getElementsByClassName("mrf-preview")];e.length>0&&[...e[0].querySelectorAll("pre code")].forEach((e=>ue.highlightElement(e)))};return r.createElement("div",{className:V(e.className)},!e.readOnly&&r.createElement("div",{style:{marginBottom:10}},r.createElement("div",null,r.createElement("div",null,r.createElement("button",{type:"button",className:"mrf-btn mrf-btn_sm",style:{color:t?"white":"#7f96af",backgroundColor:t?"#7f96af":"white"},onClick:()=>o(!1)},"Write"),r.createElement("button",{type:"button",className:"mrf-btn mrf-btn_sm mrf-ml_5",style:{color:t?"#7f96af":"white",backgroundColor:t?"white":"#7f96af"},onClick:()=>o(!0)},"Preview"))),r.createElement("div",{className:"mrf-flex mrf-flexWrap"},r.createElement(r.Fragment,null,s.map(((e,t)=>r.createElement("button",{type:"button",className:V("mrf-btn_for_descriptionToolbar"),"aria-label":e.name,title:e.name,key:`toolbar-btn-${t}`,onClick:()=>{const t=l.current;t.dispatch(t.state.changeByRange((t=>({changes:e.inject(t),range:t})))),t.focus()}},r.createElement("i",{className:`fas fa-${e.icon}`})))),e.actions&&e.actions((e=>{const t=l.current;t.dispatch(t.state.changeByRange((t=>({changes:[{from:t.from,insert:e}],range:t})))),t.focus()}))))),!t&&r.createElement(Dt,Object.assign({},e,{mode:"markdown",setRef:e=>l.current=e})),t&&r.createElement("div",{className:"mrf-preview",dangerouslySetInnerHTML:{__html:$t.makeHtml(e.value||"")}}))};function It({onChange:e,value:t,mode:o="javascript",tabSize:l=2,readOnly:i=!1,showLinesNumber:s=!0,highlightLine:c=!1,themeStyle:m={height:"-1",minHeight:"-1",maxHeight:"-1",width:"-1",minWidth:"-1",maxWidth:"-1"}}){const u=n();return a((()=>{At(u.current,o,l,i,s,c,m,(t=>{null==e||e(t.replace(/\n/g,""))}),t),u.current.addEventListener("keydown",(e=>{e.stopImmediatePropagation()}))}),[]),r.createElement("div",{ref:u,style:{flex:1,overflow:"hidden"}})}function qt(){return qt=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e},qt.apply(this,arguments)}function Bt(e,t){if(null==e)return{};var r,n,a=function(e,t){if(null==e)return{};var r,n,a={},o=Object.keys(e);for(n=0;n<o.length;n++)r=o[n],t.indexOf(r)>=0||(a[r]=e[r]);return a}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n<o.length;n++)r=o[n],t.indexOf(r)>=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(a[r]=e[r])}return a}var Ht=l((function(e,t){var n=e.color,a=void 0===n?"currentColor":n,o=e.size,l=void 0===o?24:o,i=Bt(e,["color","size"]);return r.createElement("svg",qt({ref:t,xmlns:"http://www.w3.org/2000/svg",width:l,height:l,viewBox:"0 0 24 24",fill:"none",stroke:a,strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"},i),r.createElement("circle",{cx:"12",cy:"12",r:"10"}),r.createElement("path",{d:"M9.09 9a3 3 0 0 1 5.83 1c0 2-3 3-3 3"}),r.createElement("line",{x1:"12",y1:"17",x2:"12.01",y2:"17"}))}));Ht.propTypes={color:C.string,size:C.oneOfType([C.string,C.number])},Ht.displayName="HelpCircle";const Jt=({entry:e,realEntry:t,children:n,render:a,functionalProperty:o,step:l,informations:i,className:s})=>{var c;const{formState:m}=p();if("object"==typeof e)return n;const u=e.split(".").reduce(((e,t)=>e&&e[t]),m.errors),d=e.split(".").reduce(((e,t)=>e&&e[t]),m.dirtyFields),f=e.split(".").reduce(((e,t)=>e&&e[t]),m.touchedFields),h=m.isSubmitted||d||f;if(!o(e,void 0===(null==l?void 0:l.visible)||l.visible,i,u))return null;const b=o(e,null===(null==l?void 0:l.label)?null:(null==l?void 0:l.label)||t||e,i),v=de();return a?a({entry:e,label:b,error:u,help:null==l?void 0:l.help,children:n}):r.createElement("div",{className:`mrf-mt_10 ${s||""}`,style:{position:"relative"}},b&&r.createElement("label",{className:"mrf-flex mrf-ai_center mrf-mb_5",htmlFor:null!==(c=null==l?void 0:l.name)&&void 0!==c?c:e},r.createElement("span",null,b),(null==l?void 0:l.help)&&r.createElement(r.Fragment,null,r.createElement(pe,{html:!0,place:"bottom",id:v}),r.createElement("span",{className:"mrf-flex mrf-ai_center","data-html":!0,"data-tip":null==l?void 0:l.help,"data-for":v},r.createElement(Ht,{style:{color:"gray",width:17,marginLeft:".5rem",cursor:"help"}})))),n,u&&r.createElement("div",{className:V("mrf-feedback",{"mrf-txt_red":!!h})},u.message))},Ut=t.memo((e=>e.render?e.render(Object.assign(Object.assign({},e.field),{error:e.error,informations:e.informations,defaultValue:e.step.defaultValue})):e.children),((e,t)=>!t.deactivateReactMemo&&(e.field.value===t.field.value&&t.errorDisplayed===e.errorDisplayed&&Qe(t.step)===Qe(e.step)))),Kt=e=>{var r,n;const{step:a,entry:o,realEntry:l,children:i,component:s,errorDisplayed:c=!1,informations:m,deactivateReactMemo:u,inputWrapper:f,defaultFormValue:h}=e,{field:b}=d({defaultValue:Ye(a.defaultValue)?a.defaultValue:null,name:o}),{getValues:v,setValue:y,formState:{errors:g}}=p(),[O,j]=t.useState(!!b.value),E=o.split(".").reduce(((e,t)=>e&&e[t]),g),w=(t,r)=>"function"==typeof r?r({rawValues:rt(v(),e.schema),value:v(t),defaultFormValue:h,informations:m,error:E,getValue:e=>v(e)}):r,k=Object.assign(Object.assign({name:null!==(r=a.name)&&void 0!==r?r:b.name},a.props),{id:null!==(n=a.name)&&void 0!==n?n:o,readOnly:w(o,a.disabled)?"readOnly":null,placeholder:a.placeholder,onChange:t=>{const r=t?t.target?t.target.value||null:t:a.type===fe.bool||a.type===fe.number&&0===b.value?t:null;b.onChange(r),$e(a.onChange).map((t=>t({rawValues:rt(v(),e.schema),value:r,setValue:y})))},value:b.value});return a.optional&&O?t.createElement("div",{className:"mrf-ai_center mrf-mt_5",style:{position:"relative"}},t.createElement("div",{style:{width:"95%"}},t.createElement(Jt,{key:`collapse-${o}`,entry:o,realEntry:l,functionalProperty:w,step:a,render:f,informations:m},t.createElement(Ut,{render:a.render,step:a,field:Object.assign({setValue:(e,t)=>y(e,t),rawValues:v(),getValue:e=>v(e)},b),error:E,errorDisplayed:c,informations:m,deactivateReactMemo:u},s?s(b,k):t.cloneElement(i,Object.assign({},k))))),t.createElement("button",{type:"button",style:{position:"absolute",top:"2px",right:0},className:"mrf-btn mrf-btn_red mrf-btn_sm mrf-ml_5",onClick:()=>{j(!1),y(o,null)}},t.createElement(gt,{size:16}))):a.optional?t.createElement(Jt,{key:`collapse-${o}`,entry:o,realEntry:l,functionalProperty:w,step:a,render:f,informations:m},t.createElement("div",{className:"mrf-flex mrf-jc_flex_end"},t.createElement("button",{type:"button",className:V("mrf-btn","mrf-btn_blue","mrf-btn_sm","mrf-mt_5"),onClick:()=>{j(!0)}},"Add"))):t.createElement(Jt,{key:`collapse-${o}`,entry:o,realEntry:l,functionalProperty:w,step:a,render:f,informations:m},t.createElement(Ut,{render:a.render,step:a,field:Object.assign({setValue:(e,t)=>y(e,t),rawValues:rt(v(),e.schema),getValue:e=>v(e)},b),error:E,errorDisplayed:c,informations:m,deactivateReactMemo:u},s?s(b,k):t.cloneElement(i,Object.assign({},k))))},Yt=({entry:e,step:t,component:n,disabled:a,addLabel:o,schema:l})=>{const{getValues:i,setValue:s,control:c,trigger:m,formState:u}=p(),d=i(e),h=e.split(".").reduce(((e,t)=>e&&e[t]),u.errors),b=e.split(".").reduce(((e,t)=>e&&e[t]),u.dirtyFields),v=e.split(".").reduce(((e,t)=>e&&e[t]),u.touchedFields),y=!!h&&(u.isSubmitted||b||v),{fields:g,append:O,remove:j}=f({control:c,name:e});return r.createElement(r.Fragment,null,g.map(((o,c)=>r.createElement("div",{key:o.id},r.createElement("div",{className:"mrf-ai_center mrf-mt_5",style:{position:"relative"}},r.createElement("div",{style:{width:"95%"}},n(Object.assign(Object.assign({key:o.id},o),{defaultValue:d[c]}),c)),r.createElement("button",{type:"button",style:{position:"absolute",top:"2px",right:0},className:"mrf-btn mrf-btn_red mrf-btn_sm mrf-ml_5",disabled:a,onClick:()=>{j(c),$e(t.onChange).map((t=>t({rawValues:rt(i(),l),value:i(e),setValue:s}))),m(e)}},r.createElement(gt,{size:16})))))),r.createElement("div",{className:"mrf-flex mrf-jc_flex_end"},r.createElement("button",{type:"button",className:V("mrf-btn","mrf-btn_blue","mrf-btn_sm","mrf-mt_5",{"mrf-input__invalid":!!y}),onClick:()=>{const r=t.type===fe.object?et(t.flow,t.schema):Ze();O({value:t.addableDefaultValue||r}),$e(t.onChange).map((t=>t({rawValues:rt(i(),l),value:i(e),setValue:s})))},disabled:a},o||"Add")))},Gt=e=>e.render?e.render(Object.assign(Object.assign({},e),{error:e.error})):e.children,Qt=e=>{let{entry:t,schema:n,inputWrapper:a,httpClient:o,functionalProperty:l}=e;const{formState:{errors:i,dirtyFields:s,touchedFields:c}}=p(),m=nt(t).some((e=>!!i[e]&&(s[e]||c[e])));return r.createElement(Ct,Object.assign({},t,{errored:m}),t.flow.map(((t,i)=>{if("object"==typeof t)return r.createElement(Qt,Object.assign({key:i},e,{entry:t}));const s=n[t];if(!s&&"string"==typeof t)return console.error(`no step found for the entry "${t}" in the given schema. Your form might not work properly. Please fix it`),null;const c={path:t,key:t};return r.createElement(Xt,{entry:t,step:s,schema:n,inputWrapper:a,httpClient:o,defaultValue:null==s?void 0:s.defaultValue,functionalProperty:l,informations:c,options:e.stepsOptions,defaultFormValue:e.defaultFormValue})})))},Xt=e=>{var t;let{entry:o,realEntry:l,step:c,schema:m,inputWrapper:u,httpClient:d,functionalProperty:f,informations:b,defaultFormValue:v}=e;const y=p(),{formState:{errors:g,dirtyFields:C,touchedFields:N,isSubmitted:S},control:F,getValues:P,setValue:T,reset:M}=y,{watch:z}=y,[W,L]=i(Qe(P())),A=o.split(".").reduce(((e,t)=>e&&e[t]),g),D=o.split(".").reduce(((e,t)=>e&&e[t]),C),$=o.split(".").reduce(((e,t)=>e&&e[t]),N),R=!!A&&(S||D||$);if(c=c,c.onAfterChange){const e=z(),t=o.replace("[",".").replace("]","").split(".").reduce(((e,t)=>e&&e[t]),e)||{},r=(e=>{const t=n();return a((()=>{t.current=e}),[e]),t.current})(rt(t,m)),l=rt(t,m);(!O(l,r)||void 0!==l&&void 0===r)&&c.onAfterChange({entry:o,value:P(o),rawValues:rt(P(),m),previousValue:r,getValue:e=>P(e),setValue:T,onChange:e=>T(o,e),reset:M,informations:b})}const I=s((()=>{const e="function"==typeof c.visible,t="function"==typeof c.disabled,r="function"==typeof c.label;return!!("function"==typeof c.deps?c.deps(b):c.deps)||e||t||r||!!c.render||!!c.conditionalSchema}),[Qe(m)]);if(I){const e="function"==typeof c.deps?c.deps(b):c.deps,t=e?z(e):z(),r=Qe(t);r!==W&&L(r)}if(c.array)return r.createElement(Kt,{schema:e.schema,step:c,entry:o,realEntry:l,errorDisplayed:R,informations:b,deactivateReactMemo:I,inputWrapper:u,defaultFormValue:v},r.createElement(Yt,{entry:o,step:c,schema:m,disabled:f(o,c.disabled||!1,b,A),component:(t,n)=>{var a,i,s,p,h,y,g,O,j;return r.createElement(Xt,{entry:`${o}.${n}.value`,step:Object.assign(Object.assign({},m[l||o]),{label:(null===(a=c.item)||void 0===a?void 0:a.label)||null,render:null===(i=c.item)||void 0===i?void 0:i.render,onChange:null===(s=c.item)||void 0===s?void 0:s.onChange,array:(null===(p=c.item)||void 0===p?void 0:p.array)||!1,onAfterChange:null===(h=c.item)||void 0===h?void 0:h.onAfterChange,visible:null===(y=c.item)||void 0===y?void 0:y.visible,disabled:null===(g=c.item)||void 0===g?void 0:g.disabled,deps:null===(O=c.item)||void 0===O?void 0:O.deps}),schema:m,inputWrapper:u,httpClient:d,defaultValue:null===(j=t.defaultValue)||void 0===j?void 0:j.value,index:n,functionalProperty:f,informations:{path:`${null==b?void 0:b.path}.${n}.value`,parent:b,index:n},options:e.options,defaultFormValue:v})},addLabel:null===(t=e.options)||void 0===t?void 0:t.addLabel}));switch(c.type){case fe.string:switch(c.format){case he.text:return r.createElement(Kt,{schema:e.schema,step:c,entry:o,realEntry:l,errorDisplayed:R,informations:b,deactivateReactMemo:I,inputWrapper:u,defaultFormValue:v},r.createElement("textarea",{className:V("mrf-input",c.className,{"mrf-mrf-input__invalid":!!R})}));case he.code:case he.singleLineCode:const t=c.format===he.code?Dt:It;return r.createElement(Kt,{schema:e.schema,step:c,entry:o,realEntry:l,errorDisplayed:R,informations:b,deactivateReactMemo:I,inputWrapper:u,defaultFormValue:v},r.createElement(t,{className:V(null==c?void 0:c.className,{"mrf-input__invalid":!!A})}));case he.markdown:return r.createElement(Kt,{schema:e.schema,step:c,entry:o,realEntry:l,errorDisplayed:R,informations:b,deactivateReactMemo:I,inputWrapper:u,defaultFormValue:v},r.createElement(Rt,{className:V(c.className,{"mrf-input__invalid":!!R})}));case he.buttonsSelect:case he.select:return r.createElement(Kt,{schema:e.schema,step:c,entry:o,realEntry:l,errorDisplayed:R,informations:b,deactivateReactMemo:I,inputWrapper:u,defaultFormValue:v},r.createElement(Nt,Object.assign({className:V("mrf-flex_grow_1",c.className,{"mrf-input__invalid":!!R}),disabled:f(o,c.disabled||!1,b,A)},c.props,{possibleValues:c.options,httpClient:d,isMulti:c.isMulti,createOption:c.createOption,onCreateOption:c.onCreateOption,transformer:c.transformer,buttons:c.format===he.buttonsSelect,optionsFrom:c.optionsFrom,schema:m})));default:return r.createElement(Kt,{schema:e.schema,step:c,entry:o,realEntry:l,errorDisplayed:R,informations:b,deactivateReactMemo:I,inputWrapper:u,defaultFormValue:v},r.createElement("input",{type:c.format||"text",className:V("mrf-input",c.className,{"mrf-input__invalid":!!R})}))}case fe.number:switch(c.format){case he.buttonsSelect:case he.select:return r.createElement(Kt,{schema:e.schema,step:c,entry:o,realEntry:l,errorDisplayed:R,informations:b,deactivateReactMemo:I,inputWrapper:u,defaultFormValue:v},r.createElement(Nt,Object.assign({className:V("mrf-content",c.className,{"mrf-input__invalid":!!R})},c.props,{possibleValues:c.options,httpClient:d,isMulti:c.isMulti,createOption:c.createOption,onCreateOption:c.onCreateOption,transformer:c.transformer,buttons:c.format===he.buttonsSelect,optionsFrom:c.optionsFrom,schema:m})));default:return r.createElement(Kt,{schema:e.schema,step:c,entry:o,realEntry:l,errorDisplayed:R,informations:b,deactivateReactMemo:I,inputWrapper:u,defaultFormValue:v},r.createElement("input",{type:c.format||"number",className:V("mrf-input",c.className,{"mrf-input__invalid":!!R})}))}case fe.bool:return r.createElement(Kt,{schema:e.schema,step:c,defaultFormValue:v,entry:o,realEntry:l,errorDisplayed:R,informations:b,deactivateReactMemo:I,inputWrapper:u},r.createElement(Ot,{className:c.className,errorDisplayed:R,buttons:c.format===he.buttonsSelect}));case fe.object:const t=P(o),n=Ye(c.defaultValue)?c.defaultValue:et(c.flow,c.schema);switch(c.format){case he.buttonsSelect:case he.select:return r.createElement(Kt,{schema:e.schema,step:Object.assign(Object.assign({},c),{defaultValue:t||n}),entry:o,realEntry:l,errorDisplayed:R,informations:b,deactivateReactMemo:I,inputWrapper:u,defaultFormValue:v},r.createElement(Nt,Object.assign({className:V("mrf-flex_grow_1",c.className,{"mrf-input__invalid":!!R})},c.props,{possibleValues:c.options,httpClient:d,isMulti:c.isMulti,createOption:c.createOption,onCreateOption:c.onCreateOption,transformer:c.transformer,buttons:c.format===he.buttonsSelect,optionsFrom:c.optionsFrom,schema:m})));case he.form:const a=$e(c.flow).getOrElse($e(c.schema).map((e=>Object.keys(e))).getOrElse([]));return r.createElement(Kt,{schema:e.schema,step:Object.assign(Object.assign({},c),{defaultValue:t||n}),entry:o,realEntry:l,errorDisplayed:R,informations:b,deactivateReactMemo:I,inputWrapper:u,defaultFormValue:v},r.createElement(Gt,{render:c.render,rawValues:P(),value:P(o),onChange:e=>T(o,e,{shouldValidate:!0}),setValue:(e,t)=>T(e,t),getValue:e=>P(e),informations:b,defaultValue:t||n},r.createElement(Zt,{schema:c.schema,flow:a,step:c,parent:o,inputWrapper:u,maybeCustomHttpClient:d,value:P(o)||n,functionalProperty:f,errorDisplayed:R,informations:b,stepsOptions:e.options,defaultFormValue:v})));case he.code:return r.createElement(Kt,{schema:e.schema,step:Object.assign(Object.assign({},c),{defaultValue:t||n}),entry:o,realEntry:l,errorDisplayed:R,informations:b,deactivateReactMemo:I,inputWrapper:u,defaultFormValue:v,component:(e,t)=>r.createElement(Dt,Object.assign({},t,{className:V(null==c?void 0:c.className,{"mrf-input__invalid":!!A}),onChange:t=>{let r;try{r=JSON.parse(t)}catch(e){r=t}e.onChange(r),$e(null==c?void 0:c.onChange).map((e=>e({rawValues:rt(P(),m),value:r,setValue:T})))},value:null===e.value?null:"object"==typeof e.value?JSON.stringify(e.value,null,2):e.value}))});default:return r.createElement(Kt,{schema:e.schema,step:Object.assign(Object.assign({},c),{defaultValue:t||n}),entry:o,realEntry:l,errorDisplayed:R,informations:b,deactivateReactMemo:I,inputWrapper:u,defaultFormValue:v},r.createElement(Wt,{className:V(c.className,{"mrf-input__invalid":!!R})}))}case fe.date:switch(c.format){case he.datetime:return r.createElement(Kt,{schema:e.schema,step:c,entry:o,realEntry:l,informations:b,deactivateReactMemo:I,inputWrapper:u,defaultFormValue:v,component:e=>r.createElement(E,{dateAdapter:j},r.createElement(x,{value:e.value,onChange:t=>{e.onChange(t),$e(c.onChange).map((e=>e({rawValues:rt(P(),m),value:t,setValue:T})))},renderInput:e=>r.createElement(_,Object.assign({},e))}))});case he.time:return r.createElement(Kt,{schema:e.schema,step:c,entry:o,realEntry:l,informations:b,deactivateReactMemo:I,inputWrapper:u,defaultFormValue:v,component:e=>r.createElement(E,{dateAdapter:j},r.createElement(k,{value:e.value,onChange:t=>{e.onChange(t),$e(c.onChange).map((e=>e({rawValues:rt(P(),m),value:t,setValue:T})))},renderInput:e=>r.createElement(_,Object.assign({},e))}))});default:return r.createElement(Kt,{schema:e.schema,step:c,entry:o,realEntry:l,informations:b,deactivateReactMemo:I,inputWrapper:u,defaultFormValue:v,component:e=>r.createElement(E,{dateAdapter:j},r.createElement(w,{value:e.value,onChange:t=>{e.onChange(t),$e(c.onChange).map((e=>e({rawValues:rt(P(),m),value:t,setValue:T})))},renderInput:e=>r.createElement(_,Object.assign({},e))}))})}case fe.file:return r.createElement(h,{name:o,control:F,render:({field:t})=>r.createElement(Kt,{schema:e.schema,step:c,entry:o,realEntry:l,errorDisplayed:R,informations:b,deactivateReactMemo:I,inputWrapper:u,defaultFormValue:v},r.createElement((({onChange:e})=>{const[n,a]=i(!1),[l,s]=i(void 0),m=t.value||[];return r.createElement("div",{className:V("mrf-flex","mrf-ai_center",null==c?void 0:c.className,{"mrf-input__invalid":!!A})},r.createElement("input",{ref:e=>s(e),type:"file",multiple:!0,className:"mrf-d_none",onChange:t=>{const r=t.target.files;a(!0),e&&e(r?[...r]:[]),a(!1)}}),r.createElement("button",{type:"button",className:"mrf-btn mrf-btn_sm mrf-flex mrf-ai_center",disabled:n||f(o,(null==c?void 0:c.disabled)||!1,b,A),onClick:()=>{null==l||l.click()}},n&&r.createElement(it,null),!n&&r.createElement(mt,null),r.createElement("span",{className:"mrf-ml_5"},"Select file(s)")),r.createElement("span",{className:"mrf-ml_5"},m.length<=0?"No files selected":m.map((e=>e.name)).join(" , ")))}),null))});case fe.json:return r.createElement(Kt,{schema:e.schema,step:c,entry:o,realEntry:l,informations:b,deactivateReactMemo:I,inputWrapper:u,defaultFormValue:v,component:(e,t)=>r.createElement(Dt,Object.assign({},t,{className:V(null==c?void 0:c.className,{"mrf-input__invalid":!!A}),onChange:t=>{e.onChange(t),$e(null==c?void 0:c.onChange).map((e=>e({rawValues:rt(P(),m),value:t,setValue:T})))},value:e.value}))});default:return null}},Zt=({schema:e,flow:t,parent:n,inputWrapper:a,maybeCustomHttpClient:o,errorDisplayed:l,value:s,step:c,functionalProperty:m,informations:d,stepsOptions:f,defaultFormValue:h})=>{var b;const{getValues:v,control:y}=p(),[g,O]=i(!!c.collapsed);u({name:(null===(b=null==c?void 0:c.conditionalSchema)||void 0===b?void 0:b.ref)||"",control:y});const j=$e(c.conditionalSchema).map((e=>{const t=$e(e.ref).map((e=>v(e))).getOrNull(),r=v(),n=$e(e.switch.find((e=>"function"==typeof e.condition?e.condition({rawValues:r,ref:t}):e.condition===t))).orElse(e.switch.find((e=>e.default))).getOrElse({schema:{},flow:[]});return{schema:n.schema,flow:n.flow||Object.keys(n.schema)}})).getOrElse({schema:e,flow:t}),E=j.flow.reduce(((e,t)=>[...e,{step:"string"==typeof t?j.schema[t]:j.schema[t.label],entry:t}]),[]),w=E.length>=1&&null!==c.label;return r.createElement("div",{className:V(c.className,{"mrf-nestedform__border":w,"mrf-border__error":!!l}),style:{position:"relative"}},!!c.collapsable&&j.flow.length>1&&g&&r.createElement(dt,{size:30,className:"mrf-cursor_pointer",style:{position:"absolute",top:-35,right:0,zIndex:100},strokeWidth:"2",onClick:()=>O(!g)}),!!c.collapsable&&j.flow.length>1&&!g&&r.createElement(bt,{size:30,className:"mrf-cursor_pointer",style:{position:"absolute",top:-35,right:0,zIndex:100},strokeWidth:"2",onClick:()=>O(!g)}),g&&!!c.collapsable&&"function"==typeof c.collapsable&&c.collapsable({rawValues:rt(v(),e),getValue:e=>v(e),value:s}),("function"!=typeof c.collapsable||!g)&&E.map((({step:t,entry:l},i)=>g&&!t.visibleOnCollapse?null:"object"==typeof l?r.createElement(Qt,{key:i,entry:l,schema:e,inputWrapper:a,httpClient:o,functionalProperty:m,stepsOptions:f,defaultFormValue:h}):t||"string"!=typeof l?r.createElement(Xt,{key:`step.${l}.${i}`,entry:`${n}.${l}`,realEntry:l,step:j.schema[l],schema:j.schema,inputWrapper:a,httpClient:o,defaultValue:s&&s[l],functionalProperty:m,informations:{path:`${null==d?void 0:d.path}.${l}`,key:l,parent:d},options:f,defaultFormValue:h}):(console.error(`no step found for the entry "${l}" in the given schema. Your form might not work properly. Please fix it`),null))))},er=e=>{var t,n,a,o,l,i,s,c,m,u,p,d,f,h;if(e.render)return e.render({reset:e.reset,valid:e.valid});const b=void 0===(null===(n=null===(t=e.actions)||void 0===t?void 0:t.submit)||void 0===n?void 0:n.display)||!!(null===(o=null===(a=e.actions)||void 0===a?void 0:a.submit)||void 0===o?void 0:o.display);return r.createElement("div",{className:"mrf-flex mrf-jc_end mrf-mt_5"},(null===(i=null===(l=e.actions)||void 0===l?void 0:l.cancel)||void 0===i?void 0:i.display)&&r.createElement("button",{className:"mrf-btn mrf-btn_red",type:"button",onClick:()=>{var t,r;return null===(r=null===(t=e.actions)||void 0===t?void 0:t.cancel)||void 0===r?void 0:r.action()}},(null===(c=null===(s=e.actions)||void 0===s?void 0:s.cancel)||void 0===c?void 0:c.label)||"Cancel"),(null===(u=null===(m=e.actions)||void 0===m?void 0:m.reset)||void 0===u?void 0:u.display)&&r.createElement("button",{className:"mrf-btn mrf-btn_red",type:"button",onClick:e.reset},(null===(d=null===(p=e.actions)||void 0===p?void 0:p.reset)||void 0===d?void 0:d.label)||"Reset"),b&&r.createElement("button",{className:"mrf-btn mrf-btn_green mrf-ml_10",type:"submit"},(null===(h=null===(f=e.actions)||void 0===f?void 0:f.submit)||void 0===h?void 0:h.label)||"Save"))},tr=r.forwardRef(((t,n)=>{const{schema:o,flow:l,value:s,inputWrapper:u,onSubmit:p,onError:d=(()=>{}),footer:f,className:h,options:y={}}=t,g=l||Object.keys(o),O=(e,t)=>y.httpClient?y.httpClient(e,t):fetch(e,{method:t,headers:{Accept:"application/json","Content-Type":"application/json"}}),j=et(g,o,s),E=b({resolver:(t,r,n)=>m((t=>{const{shape:r,dependencies:n}=Je(g,o,[],t);return e.object().shape(r,n)})(t))(t,r,n),shouldFocusError:!1,mode:"onChange",defaultValues:tt(s,j,l,o)}),[w,k]=i(!1),{handleSubmit:x,reset:_,trigger:C}=E,{getValues:V}=E;a((()=>{y.showErrorsOnStart&&C()}),[C,w]),Xe((()=>{_(Object.assign({},tt(s,j,l,o)))}),[s,o,l]);const N=(e,t,r,n)=>"function"==typeof t?t({rawValues:rt(V(),o),value:V(e),defaultFormValue:s,informations:r,getValue:e=>V(e),error:n}):t;return c(n,(()=>({handleSubmit:()=>x((e=>{const t=rt(e,o);p(t)}),d)(),trigger:C,methods:Object.assign(Object.assign({},E),{data:()=>rt(V(),o)})}))),r.createElement(v,Object.assign({},E),(!!y.watch||!!y.autosubmit)&&r.createElement(at,{options:y,control:E.control,schema:o,onSubmit:p,handleSubmit:x,onError:d}),r.createElement("form",{className:h||"mrf-pr_15 mrf-w_100",onSubmit:x((e=>{const t=rt(e,o);p(t)}),d)},g.map(((e,n)=>{var a,l,i,c,m,p;if("object"==typeof e)return r.createElement(Qt,{key:n,entry:e,schema:o,inputWrapper:u,httpClient:O,functionalProperty:N,stepsOptions:{addLabel:null===(i=null===(l=null===(a=t.options)||void 0===a?void 0:a.actions)||void 0===l?void 0:l.add)||void 0===i?void 0:i.label},defaultFormValue:s});const d=o[e];if(!d&&"string"==typeof e)return console.error(`no step found for the entry "${e}" in the given schema. Your form might not work properly. Please fix it`),null;const f={path:e,key:e};return r.createElement(Xt,{defaultFormValue:s,key:n,entry:e,step:d,schema:o,inputWrapper:u,httpClient:O,functionalProperty:N,informations:f,options:{addLabel:null===(p=null===(m=null===(c=t.options)||void 0===c?void 0:c.actions)||void 0===m?void 0:m.add)||void 0===p?void 0:p.label}})})),r.createElement(er,{render:f,reset:()=>_(j),valid:x((e=>p(rt(e,o))),d),actions:y.actions})))}));export{Ot as BooleanInput,Dt as CodeInput,Ct as Collapse,tr as Form,Rt as MarkdownInput,Wt as ObjectInput,Nt as SelectInput,It as SingleLineCode,De as constraints,he as format,fe as type};
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@maif/react-forms",
3
3
  "description": "Build react safe forms as fast as possible",
4
- "version": "1.6.10",
4
+ "version": "1.6.12",
5
5
  "main": "lib/index.js",
6
6
  "types": "lib/index.d.ts",
7
7
  "source": "src/index.ts",