@react-typed-forms/schemas-html 1.1.4 → 1.2.0
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/components/DefaultAccordion.d.ts +5 -2
- package/lib/createDefaultRenderers.d.ts +1 -0
- package/lib/index.cjs +1 -1
- package/lib/index.cjs.map +1 -1
- package/lib/index.d.ts +1 -0
- package/lib/index.js +1 -1
- package/lib/index.js.map +1 -1
- package/package.json +2 -2
|
@@ -1,11 +1,14 @@
|
|
|
1
1
|
import React, { CSSProperties, ReactElement } from "react";
|
|
2
|
+
import { Control } from "@react-typed-forms/core";
|
|
2
3
|
import { DefaultAccordionRendererOptions } from "../createDefaultRenderers";
|
|
3
|
-
import { AccordionAdornment, FormRenderer } from "@react-typed-forms/schemas";
|
|
4
|
-
export declare function DefaultAccordion({ children, accordion, contentStyle, contentClassName, designMode, iconOpenClass, iconClosedClass, className, renderTitle, renderToggler, renderers, titleClass, }: {
|
|
4
|
+
import { AccordionAdornment, ControlDataContext, FormRenderer } from "@react-typed-forms/schemas";
|
|
5
|
+
export declare function DefaultAccordion({ children, accordion, contentStyle, contentClassName, designMode, iconOpenClass, iconClosedClass, className, renderTitle, renderToggler, renderers, titleClass, useCss, dataContext, }: {
|
|
5
6
|
children: ReactElement;
|
|
6
7
|
accordion: Partial<AccordionAdornment>;
|
|
7
8
|
contentStyle?: CSSProperties;
|
|
8
9
|
contentClassName?: string;
|
|
9
10
|
designMode?: boolean;
|
|
10
11
|
renderers: FormRenderer;
|
|
12
|
+
dataContext: ControlDataContext;
|
|
11
13
|
} & DefaultAccordionRendererOptions): React.JSX.Element;
|
|
14
|
+
export declare function getAccordionState(c: Control<unknown>): Control<boolean> | undefined;
|
|
@@ -59,6 +59,7 @@ export interface DefaultAccordionRendererOptions {
|
|
|
59
59
|
iconClosedClass?: string;
|
|
60
60
|
renderTitle?: (title: string | undefined, current: Control<boolean>) => ReactNode;
|
|
61
61
|
renderToggler?: (current: Control<boolean>, title: ReactNode) => ReactNode;
|
|
62
|
+
useCss?: boolean;
|
|
62
63
|
}
|
|
63
64
|
export interface DefaultAdornmentRendererOptions {
|
|
64
65
|
accordion?: DefaultAccordionRendererOptions;
|
package/lib/index.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
var e=require("react"),t=require("clsx"),r=require("@react-typed-forms/schemas"),n=require("@react-typed-forms/core");function a(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var l=/*#__PURE__*/a(e),o=/*#__PURE__*/a(t);function u(){return u=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var n in r)({}).hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e},u.apply(null,arguments)}function i(e,t){if(null==e)return{};var r={};for(var n in e)if({}.hasOwnProperty.call(e,n)){if(t.includes(n))continue;r[n]=e[n]}return r}var s=["data","display","className","style"];function d(e){return void 0===e&&(e={}),{render:function(t){/*#__PURE__*/return l.default.createElement(c,u({},e,t))},type:"display"}}function c(e){var t=n.useComponentTracking();try{var a=e.data,u=e.display,d=e.className,c=e.style,f=i(e,s);switch(a.type){case r.DisplayDataType.Icon:/*#__PURE__*/return l.default.createElement("i",{style:c,className:o.default(r.getOverrideClass(d),u?u.value:a.iconClass)});case r.DisplayDataType.Text:/*#__PURE__*/return l.default.createElement("div",{style:c,className:r.rendererClass(d,f.textClassName)},u?r.coerceToString(u.value):a.text);case r.DisplayDataType.Html:/*#__PURE__*/return l.default.createElement("div",{style:c,className:r.rendererClass(d,f.htmlClassName),dangerouslySetInnerHTML:{__html:u?r.coerceToString(u.value):a.html}});case r.DisplayDataType.Custom:/*#__PURE__*/return l.default.createElement("div",null,"Custom display placeholder: ",a.customId);default:/*#__PURE__*/return l.default.createElement("h1",null,"Unknown display type: ",a.type)}}finally{t()}}var f=["control","convert"],m=["errorText","value","onChange"];function p(e){var t=n.useComponentTracking();try{var r=function(e){return null==e?"":o[2](e)},a=e.control,o=e.convert,s=i(e,f),d=n.formControlProps(a),c=d.value,p=i(d,m),y=n.useControl(function(){return r(c)});return n.useControlEffect(function(){return a.value},function(e){return y.value=r(e)}),/*#__PURE__*/l.default.createElement("input",u({},p,{type:o[0],value:y.value,onChange:function(e){y.value=e.target.value;var t=o[1](e.target.value);void 0!==t&&(a.value=t)}},s))}finally{t()}}function y(e){switch(e){case r.FieldType.String:return["text",function(e){return e},function(e){return e}];case r.FieldType.Bool:return["text",function(e){return"true"===e||"false"!==e&&void 0},function(e){var t;return null!=(t=null==e?void 0:e.toString())?t:""}];case r.FieldType.Int:return["number",function(e){return""!==e?parseInt(e):null},function(e){return null==e?"":e}];case r.FieldType.DateTime:return["datetime-local",function(e){return e||null},function(e){return e}];case r.FieldType.Date:return["date",function(e){return e||null},function(e){return e}];case r.FieldType.Time:return["time",function(e){var t=e.length;return 5===t?e+":00":8===t?e:void 0},function(e){return e?e.substring(0,5):""}];case r.FieldType.Double:return["number",function(e){return""!==e?parseFloat(e):null},function(e){return null==e?"":e}];default:return["text",function(e){return e},function(e){return e}]}}var v=["state","options","className","convert","required","emptyText","requiredText","readonly"];function C(e){return void 0===e&&(e={}),r.createDataRenderer(function(t,n){var a;/*#__PURE__*/return l.default.createElement(x,{className:r.rendererClass(t.className,e.className),state:t.control,id:t.id,readonly:t.readonly,options:null!=(a=t.options)?a:[],required:t.required,emptyText:e.emptyText,requiredText:e.requiredText,convert:N(t.field.type)})},{options:!0})}function x(t){var r=n.useComponentTracking();try{var a=function(e,t){/*#__PURE__*/return l.default.createElement("option",{key:t,value:c(e.value),disabled:!!e.disabled},e.name)},o=t.state,s=t.options,d=t.className,c=t.convert,f=t.required,m=t.emptyText,p=void 0===m?"N/A":m,y=t.requiredText,C=void 0===y?"<please select>":y,x=t.readonly,N=i(t,v),g=o.value,h=o.disabled,T=e.useState(!f||null==g)[0],E=e.useMemo(function(){return Object.fromEntries(s.map(function(e){return[c(e.value),e.value]}))},[s]),b=e.useMemo(function(){return new Set(s.filter(function(e){return e.group}).map(function(e){return e.group}))},[s]);/*#__PURE__*/return l.default.createElement("select",u({},N,{className:d,onChange:function(e){return o.value=E[e.target.value]},value:c(g),disabled:h||x}),T&&/*#__PURE__*/l.default.createElement("option",{value:""},f?C:p),[].concat(b.keys()).map(function(e){/*#__PURE__*/return l.default.createElement("optgroup",{key:e,label:e},s.filter(function(t){return t.group===e}).map(a))}),s.filter(function(e){return!e.group}).map(a))}finally{r()}}function N(e){switch(e){case r.FieldType.String:case r.FieldType.Int:case r.FieldType.Double:return function(e){return e};default:return function(e){var t;return null!=(t=null==e?void 0:e.toString())?t:""}}}function g(e){return void 0===e&&(e={}),r.createDataRenderer(function(t){/*#__PURE__*/return l.default.createElement(T,u({},e,t,{className:r.rendererClass(t.className,e.className),isChecked:function(e,t){return e.value==t.value},setChecked:function(e,t){return e.value=t.value},control:t.control,type:"radio",entryAdornment:r.fieldOptionAdornment(t)}))},{renderType:r.DataRenderType.Radio})}function h(e){return void 0===e&&(e={}),r.createDataRenderer(function(t){/*#__PURE__*/return l.default.createElement(T,u({},e,t,{className:r.rendererClass(t.className,e.className),isChecked:function(e,t){var r=e.value;return!!Array.isArray(r)&&r.includes(t.value)},setChecked:function(e,t,r){e.setValue(function(e){return E(null!=e?e:[],t.value,r)})},control:t.control,type:"checkbox",entryAdornment:r.fieldOptionAdornment(t)}))},{collection:!0,renderType:r.DataRenderType.CheckList})}function T(e){var t=n.useComponentTracking();try{var r=e.control,a=e.options,o=e.labelClass,u=e.checkClass,i=e.readonly,s=e.entryClass,d=e.type,c=e.isChecked,f=e.setChecked,m=e.entryAdornment,p=r.disabled,y="r"+r.uniqueId;/*#__PURE__*/return l.default.createElement("div",{className:e.className,id:e.id},/*#__PURE__*/l.default.createElement(n.RenderArrayElements,{array:null==a?void 0:a.filter(function(e){return null!=e.value})},function(e,t){var a=n.useComputed(function(){return c(r,e)}).value;/*#__PURE__*/return l.default.createElement(l.default.Fragment,null,/*#__PURE__*/l.default.createElement("div",{key:t,className:s},/*#__PURE__*/l.default.createElement("input",{id:y+"_"+t,className:u,type:d,name:y,readOnly:i,disabled:p,checked:a,onChange:function(t){!i&&f(r,e,t.target.checked)}}),/*#__PURE__*/l.default.createElement("label",{className:o,htmlFor:y+"_"+t},e.name)),null==m?void 0:m(e,t,a))}))}finally{t()}}function E(e,t,r){return r===e.includes(t)?e:r?[].concat(e,[t]):e.filter(function(e){return e!==t})}function b(e){return void 0===e&&(e={}),r.createDataRenderer(function(t,a){return function(o){return u({},o,{label:void 0,children:/*#__PURE__*/l.default.createElement("div",{className:r.rendererClass(t.className,e.entryClass)},/*#__PURE__*/l.default.createElement(n.Fcheckbox,{id:t.id,control:t.control,style:t.style,className:e.checkClass}),o.label&&a.renderLabel(o.label,void 0,void 0))})}},{renderType:r.DataRenderType.Checkbox})}function D(e){var t=n.useComponentTracking();try{var r=e.errorClass,a=e.renderError,o=e.layout,u=o.controlEnd,i=o.errorControl;/*#__PURE__*/return l.default.createElement(l.default.Fragment,null,o.label,o.controlStart,o.children,(void 0===a?function(e){return e&&/*#__PURE__*/l.default.createElement("div",{className:r},e)}:a)(i&&i.touched?i.error:void 0),u)}finally{t()}}function R(e){var t=n.useComponentTracking();try{var a,o=e.className,u=e.emptyText,i=e.schemaInterface,s=e.field,d=e.style,c=e.control.value,f=null!=(a=i.isEmptyValue(s,c)?u:i.textValue(s,c))?a:"";/*#__PURE__*/return l.default.createElement("div",{style:d,className:r.rendererClass(o)},f)}finally{t()}}function k(){return r.createVisibilityRenderer(function(e){/*#__PURE__*/return l.default.createElement(O,e)})}function O(t){var r=n.useComponentTracking();try{var a=t.visibility,u=t.children,i=t.className,s=t.style,d=t.divRef,c=a.value;return e.useEffect(function(){c&&a.setValue(function(e){return{visible:c.visible,showing:c.visible}})},[null==c?void 0:c.visible]),null!=c&&c.visible?/*#__PURE__*/l.default.createElement("div",{className:o.default(i),style:s,ref:d},u):/*#__PURE__*/l.default.createElement(l.default.Fragment,null)}finally{r()}}function A(e){return r.createDataRenderer(function(t){/*#__PURE__*/return l.default.createElement(F,{renderOptions:t.renderOptions,className:r.rendererClass(t.className,e),dataNode:t.dataNode,dataContext:t.dataContext,control:t.control,readonly:t.readonly})},{renderType:r.DataRenderType.Jsonata})}function F(e){var t=n.useComponentTracking();try{var a=e.control,o=e.renderOptions,u=e.readonly,i=e.className,s=e.dataContext,d=e.dataNode,c=null!=d.elementIndex?d:s.parentNode,f=n.useComputed(function(){return{value:a.value,readonly:u,disabled:a.disabled,formData:s.formData,dataPath:r.getJsonPath(d)}}),m=r.useJsonataExpression(o.expression,r.getRootDataNode(c).control,r.getJsonPath(c),f,r.coerceToString);/*#__PURE__*/return l.default.createElement("div",{className:i,dangerouslySetInnerHTML:{__html:m.value}})}finally{t()}}var S=["control","field","renderOptions"];function L(){return r.createDataRenderer(function(e,t){var a,o,s=e.control,d=e.field,c=i(e,S),f=null!=(o=(a=s.meta).nullControl)?o:a.nullControl=n.newControl(null!=s.current.value);return function(e){var n=t.renderData(u({},c,{control:f,field:u({},d,{type:r.FieldType.Bool}),renderOptions:{type:r.DataRenderType.Checkbox}}))(e);return u({},n,{children:/*#__PURE__*/l.default.createElement(w,{control:s,nullControl:f,children:n.children,readonly:c.readonly,defaultValue:c.definition.defaultValue})})}})}function w(e){var t=e.children,r=e.nullControl,a=e.control,l=e.defaultValue,o=e.readonly;return n.useControlEffect(function(){return o},function(e){return r.disabled=e},!0),n.useControlEffect(function(){return r.value},function(e){var t;e?a.value=null!=(t=r.meta.nonNullValue)?t:l:(r.meta.nonNullValue=a.value,a.value=null)}),t}function I(e){return r.createDataRenderer(function(t,r){/*#__PURE__*/return l.default.createElement(q,{dataProps:t,renderers:r,defaultActions:e})},{renderType:r.DataRenderType.Array,collection:!0})}function q(e){var t,a=e.dataProps,o=e.renderers,i=e.defaultActions,s=a.renderOptions,d=a.control,c=a.field,f=a.readonly,m=a.designMode,p=a.required,y=a.renderChild,v=a.definition,C=a.className,x=a.style,N=a.useChildVisibility,g=a.dataContext,h=r.mergeObjects(r.isArrayRenderer(s)?s:{},i),T=h.addText,E=h.noAdd,b=h.noRemove,D=h.removeText,R=r.isArrayRenderer(s)?s.childOptions:void 0,k=!r.isCompoundField(c),O=k?{type:r.ControlDefinitionType.Data,field:v.field,children:v.children,renderOptions:null!=R?R:{type:r.DataRenderType.Standard},hideTitle:!0}:{type:r.ControlDefinitionType.Group,children:v.children,groupOptions:{type:r.GroupRenderType.Standard,hideTitle:!0}},A=(null!=(t=v.children)?t:[]).map(function(e){return[N(e,void 0,!0),e]}),F=r.makeHookDepString(A,function(e){return e[0].deps}),S=n.useTrackedComponent(V,[F]),L=u({},r.createArrayActions(d,c,{addText:T,removeText:D,noAdd:E,noRemove:b,readonly:f,disabled:d.disabled,designMode:m}),{required:p,renderElement:function(e,t){/*#__PURE__*/return l.default.createElement(S,{index:e,renderChildElement:w,dataContext:g,visibilities:A,wrap:t})},className:C||void 0,style:x},r.getLengthRestrictions(v));return o.renderArray(L);function w(e,t){var r,n;return y(null!=(r=null==(n=d.elements)?void 0:n[e].uniqueId)?r:e,O,k?{elementIndex:e}:{parentDataNode:t})}}function V(e){var t=e.index,n=e.renderChildElement,a=e.visibilities,l=e.wrap,o=e.dataContext,i=o.dataNode.getChildElement(t),s=a.map(function(e){var t=e[0];return t.runHook(u({},o,{parentNode:i,dataNode:r.lookupDataNode(e[1],i)}),t.state).value});if(0==s.length||s.some(function(e){return!0===e}))return l(n(t,i))}function M(e){return{render:function(t,r){/*#__PURE__*/return l.default.createElement(P,u({},t,e,{renderAction:r.renderAction}))},type:"array"}}function P(e){var t=n.useComponentTracking();try{var a=e.renderElement,u=e.className,i=e.removableClass,s=e.childClass,d=e.removableChildClass,c=e.removeActionClass,f=e.addActionClass,m=e.arrayControl,p=e.renderAction,y=e.style,v=r.applyArrayLengthRestrictions(e),C=v.addAction,x=v.removeAction;/*#__PURE__*/return l.default.createElement("div",{style:y},/*#__PURE__*/l.default.createElement("div",{className:o.default(u,x&&i)},/*#__PURE__*/l.default.createElement(n.RenderElements,{control:m},function(e,t){return a(t,function(e){return x?/*#__PURE__*/l.default.createElement(l.default.Fragment,null,/*#__PURE__*/l.default.createElement("div",{className:o.default(s,d)},e),/*#__PURE__*/l.default.createElement("div",{className:c},p(x(t)))):/*#__PURE__*/l.default.createElement("div",{className:s},e)})})),C&&/*#__PURE__*/l.default.createElement("div",{className:f},p(C)))}finally{t()}}function G(e){var t=n.useComponentTracking();try{var r=e.children,a=e.accordion,i=e.contentStyle,s=e.contentClassName,d=e.designMode,c=e.iconOpenClass,f=e.iconClosedClass,m=e.className,p=e.renderTitle,y=void 0===p?function(e){return e}:p,v=e.renderToggler,C=e.renderers,x=e.titleClass,N=n.useControl(!!a.defaultExpanded),g=N.value,h=g||d?i:u({},i,{display:"none"}),T=C.renderLabelText(y(a.title,N)),E=v?v(N,T):/*#__PURE__*/l.default.createElement("button",{className:m,onClick:function(){return N.setValue(function(e){return!e})}},/*#__PURE__*/l.default.createElement("label",{className:x},T),/*#__PURE__*/l.default.createElement("i",{className:o.default(g?c:f)}));/*#__PURE__*/return l.default.createElement(l.default.Fragment,null,E,/*#__PURE__*/l.default.createElement("div",{style:h,className:s},r))}finally{t()}}function J(t){var r=n.useComponentTracking();try{var a=t.control,o=t.className,u=e.useRef(null);return n.useControlEffect(function(){return a.value},function(e){var t=u.current;t&&t.textContent!==e&&(t.textContent=e)},!0),/*#__PURE__*/l.default.createElement("code",{contentEditable:!a.disabled,className:o,onInput:function(e){return a.value=e.currentTarget.textContent},ref:u})}finally{r()}}function _(e,t){return void 0===t&&(t={}),r.createActionRenderer(e,function(e){var n,a=e.onClick,o=e.actionText,u=e.style,i=e.actionId,s=e.actionData,d=e.disabled;/*#__PURE__*/return l.default.createElement("button",{className:r.rendererClass(e.className,t.className),disabled:d,style:u,onClick:a},null!=(n=null==t.renderContent?void 0:t.renderContent(o,i,s))?n:o)})}function j(e){var t=null!=e?e:{},n=t.className,a=t.gridStyles,i=void 0===a?function(e){var t=e.columns;return{className:c,style:{display:"grid",gridTemplateColumns:"repeat("+(void 0===t?d:t)+", 1fr)"}}}:a,s=t.defaultGridColumns,d=void 0===s?2:s,c=t.gridClassName,f=t.standardClassName,m=t.flexClassName,p=t.defaultFlexGap;return{type:"group",render:function(e){var t=e.renderChild,a=e.renderOptions,s=e.childDefinitions,d=r.isGridRenderer(a)?i(a):r.isFlexRenderer(a)?function(e){return{className:m,style:{display:"flex",gap:e.gap?e.gap:p,flexDirection:e.direction?e.direction:void 0}}}(a):{className:f},c=d.style,y=d.className;return function(a){return u({},a,{children:/*#__PURE__*/l.default.createElement("div",{className:r.rendererClass(e.className,o.default(n,y)),style:c},null==s?void 0:s.map(function(e,r){return t(r,e)}))})}}}}var B=[{name:"Yes",value:!0},{name:"No",value:!1}];function H(e){var t,n,a;void 0===e&&(e={});var o,i=A(e.jsonataClass),s=L(),d=(o=e.multilineClass,r.createDataRenderer(function(e){/*#__PURE__*/return l.default.createElement(J,u({},e,{className:r.rendererClass(e.className,o)}))})),c=b(null!=(t=e.checkOptions)?t:e.checkboxOptions),f=C(e.selectOptions),m=g(null!=(n=e.radioOptions)?n:e.checkOptions),v=h(null!=(a=e.checkListOptions)?a:e.checkOptions),x=u({optionRenderer:f,booleanOptions:B},e),N=x.inputClass,T=x.booleanOptions,E=x.optionRenderer,D=x.displayOnlyClass,k=I(e.arrayOptions);return r.createDataRenderer(function(e,t){var n=e.field,a=n.type,o=e.renderOptions,C=o.type;if(n.collection&&null==e.elementIndex&&(C==r.DataRenderType.Standard||C==r.DataRenderType.Array))return k.render(e,t);if(a===r.FieldType.Compound){var x,g=null!=(x=r.isDataGroupRenderer(o)?o.groupOptions:void 0)?x:{type:"Standard",hideTitle:!0};return t.renderGroup(u({},e,{renderOptions:g}))}if(a==r.FieldType.Any)/*#__PURE__*/return l.default.createElement(l.default.Fragment,null,"No control for Any");if(r.isDisplayOnlyRenderer(o))return function(t){return u({},t,{className:D,children:/*#__PURE__*/l.default.createElement(R,{field:e.field,schemaInterface:e.dataContext.schemaInterface,control:e.control,className:e.className,style:e.style,emptyText:o.emptyText})})};if(null!=T&&a===r.FieldType.Bool&&null==e.options)return t.renderData(u({},e,{options:T}));if(C===r.DataRenderType.Standard&&r.hasOptions(e))return E.render(e,t);switch(C){case r.DataRenderType.NullToggle:return s.render(e,t);case r.DataRenderType.CheckList:return v.render(e,t);case r.DataRenderType.Dropdown:return f.render(e,t);case r.DataRenderType.Radio:return m.render(e,t);case r.DataRenderType.Checkbox:return c.render(e,t);case r.DataRenderType.Jsonata:return i.render(e,t)}if(r.isTextfieldRenderer(o)&&o.multiline)return d.render(e,t);var h=r.isTextfieldRenderer(o)?o.placeholder:void 0;/*#__PURE__*/return l.default.createElement(p,{className:r.rendererClass(e.className,N),style:e.style,id:e.id,readOnly:e.readonly,control:e.control,placeholder:null!=h?h:void 0,convert:y(e.field.type)})})}function U(t){return void 0===t&&(t={}),{type:"adornment",render:function(a,o){var i=a.adornment,s=a.designMode,d=a.dataContext,c=a.useExpr;return{apply:function(a){if(r.isSetFieldAdornment(i)&&c){var f=c(i.expression,function(e){return e}),m=r.useDynamicHooks({value:f}),p=e.useCallback(function(e){var t=e.children,a=e.adornment,l=e.parentContext,o=m(l).value,u=r.schemaDataForFieldRef(a.field,l.parentNode).control,i=!a.defaultOnly;return n.useControlEffect(function(){return[null==o?void 0:o.value,null==(null==u?void 0:u.value)]},function(e){var t=e[0];null==u||u.setValue(function(e){return i||null==e?t:e})},!0),t},[m]);return r.wrapLayout(function(e){/*#__PURE__*/return l.default.createElement(p,{children:e,parentContext:d,adornment:i})})(a)}var y;return r.isIconAdornment(i)?r.appendMarkupAt(null!=(y=i.placement)?y:r.AdornmentPlacement.ControlStart,/*#__PURE__*/l.default.createElement("i",{className:i.iconClass}))(a):r.isAccordionAdornment(i)?r.wrapLayout(function(e){/*#__PURE__*/return l.default.createElement(G,u({renderers:o,children:e,accordion:i,contentStyle:a.style,contentClassName:a.className,designMode:s},t.accordion))})(a):void 0},priority:0,adornment:i}}}}function Y(e){return void 0===e&&(e={}),r.createLayoutRenderer(function(t,n){var a=r.renderLayoutParts(u({},t,{className:r.rendererClass(t.className,e.className)}),n);return{children:a.wrapLayout(/*#__PURE__*/l.default.createElement(D,u({layout:a},e))),className:a.className,style:a.style,divRef:function(e){return e&&t.errorControl?t.errorControl.meta.scrollElement=e:void 0}}})}function z(e){var t=u({requiredElement:/*#__PURE__*/l.default.createElement("span",null," *"),labelContainer:function(e){return e}},e),n=t.className,a=t.groupLabelClass,i=t.controlLabelClass,s=t.requiredElement,d=t.labelContainer;return{render:function(e,t,u,c){return e.type==r.LabelType.Text?e.label:d(/*#__PURE__*/l.default.createElement(l.default.Fragment,null,/*#__PURE__*/l.default.createElement("label",{htmlFor:e.forId,className:r.rendererClass(e.className,o.default(n,e.type===r.LabelType.Group&&a,e.type===r.LabelType.Control&&i))},t,c.renderLabelText(e.label),e.required&&s),u))},type:"label"}}function K(e){return void 0===e&&(e={}),{data:H(e.data),display:d(e.display),action:_(void 0,e.action),array:M(e.array),group:j(e.group),label:z(e.label),adornment:U(e.adornment),renderLayout:Y(e.layout),visibility:k()}}var Q={label:{groupLabelClass:"font-bold",requiredElement:/*#__PURE__*/l.default.createElement("span",{className:"text-red-500"}," *")},array:{removableClass:"grid grid-cols-[1fr_auto] items-center gap-x-2",childClass:"grow my-2",addActionClass:"my-2"},group:{standardClassName:"flex flex-col gap-4",gridClassName:"gap-x-2 gap-y-4",flexClassName:"gap-2"},action:{className:"bg-primary-500 rounded-lg p-3 text-white"},layout:{className:"flex flex-col",errorClass:"text-sm text-danger-500"},data:{displayOnlyClass:"flex flex-row items-center gap-2",checkOptions:{className:"flex items-center gap-4",entryClass:"flex gap-1 items-center"},selectOptions:{emptyText:"<select>"},multilineClass:"border p-2 outline-0 whitespace-pre"},adornment:{accordion:{className:"flex items-center gap-2 my-2",titleClass:"cursor-pointer",iconOpenClass:"fa fa-chevron-up",iconClosedClass:"fa fa-chevron-down"}}};exports.CheckButtons=T,exports.ControlInput=p,exports.DataArrayRenderer=q,exports.DefaultArrayRenderer=P,exports.DefaultBoolOptions=B,exports.DefaultDisplay=c,exports.DefaultDisplayOnly=R,exports.DefaultLayout=D,exports.DefaultVisibility=O,exports.JsonataRenderer=F,exports.SelectDataRenderer=x,exports.createButtonActionRenderer=_,exports.createCheckListRenderer=h,exports.createCheckboxRenderer=b,exports.createClassStyledRenderers=function(){return K({layout:{className:"control"},group:{className:"group"},array:{className:"control-array"},action:{className:"action"},data:{inputClass:"data"},display:{htmlClassName:"html",textClassName:"text"}})},exports.createDefaultAdornmentRenderer=U,exports.createDefaultArrayDataRenderer=I,exports.createDefaultArrayRenderer=M,exports.createDefaultDataRenderer=H,exports.createDefaultDisplayRenderer=d,exports.createDefaultGroupRenderer=j,exports.createDefaultLabelRenderer=z,exports.createDefaultRenderers=K,exports.createDefaultVisibilityRenderer=k,exports.createInputConversion=y,exports.createJsonataRenderer=A,exports.createNullToggleRenderer=L,exports.createRadioRenderer=g,exports.createSelectConversion=N,exports.createSelectRenderer=C,exports.defaultTailwindTheme=Q,exports.setIncluded=E;
|
|
1
|
+
var e=require("react"),t=require("clsx"),r=require("@react-typed-forms/schemas"),n=require("@react-typed-forms/core");function a(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var l=/*#__PURE__*/a(e),o=/*#__PURE__*/a(t);function u(){return u=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var n in r)({}).hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e},u.apply(null,arguments)}function i(e,t){if(null==e)return{};var r={};for(var n in e)if({}.hasOwnProperty.call(e,n)){if(t.includes(n))continue;r[n]=e[n]}return r}var s=["data","display","className","style"];function d(e){return void 0===e&&(e={}),{render:function(t){/*#__PURE__*/return l.default.createElement(c,u({},e,t))},type:"display"}}function c(e){var t=n.useComponentTracking();try{var a=e.data,u=e.display,d=e.className,c=e.style,f=i(e,s);switch(a.type){case r.DisplayDataType.Icon:/*#__PURE__*/return l.default.createElement("i",{style:c,className:o.default(r.getOverrideClass(d),u?u.value:a.iconClass)});case r.DisplayDataType.Text:/*#__PURE__*/return l.default.createElement("div",{style:c,className:r.rendererClass(d,f.textClassName)},u?r.coerceToString(u.value):a.text);case r.DisplayDataType.Html:/*#__PURE__*/return l.default.createElement("div",{style:c,className:r.rendererClass(d,f.htmlClassName),dangerouslySetInnerHTML:{__html:u?r.coerceToString(u.value):a.html}});case r.DisplayDataType.Custom:/*#__PURE__*/return l.default.createElement("div",null,"Custom display placeholder: ",a.customId);default:/*#__PURE__*/return l.default.createElement("h1",null,"Unknown display type: ",a.type)}}finally{t()}}var f=["control","convert"],m=["errorText","value","onChange"];function p(e){var t=n.useComponentTracking();try{var r=function(e){return null==e?"":o[2](e)},a=e.control,o=e.convert,s=i(e,f),d=n.formControlProps(a),c=d.value,p=i(d,m),y=n.useControl(function(){return r(c)});return n.useControlEffect(function(){return a.value},function(e){return y.value=r(e)}),/*#__PURE__*/l.default.createElement("input",u({},p,{type:o[0],value:y.value,onChange:function(e){y.value=e.target.value;var t=o[1](e.target.value);void 0!==t&&(a.value=t)}},s))}finally{t()}}function y(e){switch(e){case r.FieldType.String:return["text",function(e){return e},function(e){return e}];case r.FieldType.Bool:return["text",function(e){return"true"===e||"false"!==e&&void 0},function(e){var t;return null!=(t=null==e?void 0:e.toString())?t:""}];case r.FieldType.Int:return["number",function(e){return""!==e?parseInt(e):null},function(e){return null==e?"":e}];case r.FieldType.DateTime:return["datetime-local",function(e){return e||null},function(e){return e}];case r.FieldType.Date:return["date",function(e){return e||null},function(e){return e}];case r.FieldType.Time:return["time",function(e){var t=e.length;return 5===t?e+":00":8===t?e:void 0},function(e){return e?e.substring(0,5):""}];case r.FieldType.Double:return["number",function(e){return""!==e?parseFloat(e):null},function(e){return null==e?"":e}];default:return["text",function(e){return e},function(e){return e}]}}var v=["state","options","className","convert","required","emptyText","requiredText","readonly"];function C(e){return void 0===e&&(e={}),r.createDataRenderer(function(t,n){var a;/*#__PURE__*/return l.default.createElement(x,{className:r.rendererClass(t.className,e.className),state:t.control,id:t.id,readonly:t.readonly,options:null!=(a=t.options)?a:[],required:t.required,emptyText:e.emptyText,requiredText:e.requiredText,convert:N(t.field.type)})},{options:!0})}function x(t){var r=n.useComponentTracking();try{var a=function(e,t){/*#__PURE__*/return l.default.createElement("option",{key:t,value:c(e.value),disabled:!!e.disabled},e.name)},o=t.state,s=t.options,d=t.className,c=t.convert,f=t.required,m=t.emptyText,p=void 0===m?"N/A":m,y=t.requiredText,C=void 0===y?"<please select>":y,x=t.readonly,N=i(t,v),g=o.value,h=o.disabled,T=e.useState(!f||null==g)[0],E=e.useMemo(function(){return Object.fromEntries(s.map(function(e){return[c(e.value),e.value]}))},[s]),b=e.useMemo(function(){return new Set(s.filter(function(e){return e.group}).map(function(e){return e.group}))},[s]);/*#__PURE__*/return l.default.createElement("select",u({},N,{className:d,onChange:function(e){return o.value=E[e.target.value]},value:c(g),disabled:h||x}),T&&/*#__PURE__*/l.default.createElement("option",{value:""},f?C:p),[].concat(b.keys()).map(function(e){/*#__PURE__*/return l.default.createElement("optgroup",{key:e,label:e},s.filter(function(t){return t.group===e}).map(a))}),s.filter(function(e){return!e.group}).map(a))}finally{r()}}function N(e){switch(e){case r.FieldType.String:case r.FieldType.Int:case r.FieldType.Double:return function(e){return e};default:return function(e){var t;return null!=(t=null==e?void 0:e.toString())?t:""}}}function g(e){return void 0===e&&(e={}),r.createDataRenderer(function(t){/*#__PURE__*/return l.default.createElement(T,u({},e,t,{className:r.rendererClass(t.className,e.className),isChecked:function(e,t){return e.value==t.value},setChecked:function(e,t){return e.value=t.value},control:t.control,type:"radio",entryAdornment:r.fieldOptionAdornment(t)}))},{renderType:r.DataRenderType.Radio})}function h(e){return void 0===e&&(e={}),r.createDataRenderer(function(t){/*#__PURE__*/return l.default.createElement(T,u({},e,t,{className:r.rendererClass(t.className,e.className),isChecked:function(e,t){var r=e.value;return!!Array.isArray(r)&&r.includes(t.value)},setChecked:function(e,t,r){e.setValue(function(e){return E(null!=e?e:[],t.value,r)})},control:t.control,type:"checkbox",entryAdornment:r.fieldOptionAdornment(t)}))},{collection:!0,renderType:r.DataRenderType.CheckList})}function T(e){var t=n.useComponentTracking();try{var r=e.control,a=e.options,o=e.labelClass,u=e.checkClass,i=e.readonly,s=e.entryClass,d=e.type,c=e.isChecked,f=e.setChecked,m=e.entryAdornment,p=r.disabled,y="r"+r.uniqueId;/*#__PURE__*/return l.default.createElement("div",{className:e.className,id:e.id},/*#__PURE__*/l.default.createElement(n.RenderArrayElements,{array:null==a?void 0:a.filter(function(e){return null!=e.value})},function(e,t){var a=n.useComputed(function(){return c(r,e)}).value;/*#__PURE__*/return l.default.createElement(l.default.Fragment,null,/*#__PURE__*/l.default.createElement("div",{key:t,className:s},/*#__PURE__*/l.default.createElement("input",{id:y+"_"+t,className:u,type:d,name:y,readOnly:i,disabled:p,checked:a,onChange:function(t){!i&&f(r,e,t.target.checked)}}),/*#__PURE__*/l.default.createElement("label",{className:o,htmlFor:y+"_"+t},e.name)),null==m?void 0:m(e,t,a))}))}finally{t()}}function E(e,t,r){return r===e.includes(t)?e:r?[].concat(e,[t]):e.filter(function(e){return e!==t})}function b(e){return void 0===e&&(e={}),r.createDataRenderer(function(t,a){return function(o){return u({},o,{label:void 0,children:/*#__PURE__*/l.default.createElement("div",{className:r.rendererClass(t.className,e.entryClass)},/*#__PURE__*/l.default.createElement(n.Fcheckbox,{id:t.id,control:t.control,style:t.style,className:e.checkClass}),o.label&&a.renderLabel(o.label,void 0,void 0))})}},{renderType:r.DataRenderType.Checkbox})}function D(e){var t=n.useComponentTracking();try{var r=e.errorClass,a=e.renderError,o=e.layout,u=o.controlEnd,i=o.errorControl;/*#__PURE__*/return l.default.createElement(l.default.Fragment,null,o.label,o.controlStart,o.children,(void 0===a?function(e){return e&&/*#__PURE__*/l.default.createElement("div",{className:r},e)}:a)(i&&i.touched?i.error:void 0),u)}finally{t()}}function R(e){var t=n.useComponentTracking();try{var a,o=e.className,u=e.emptyText,i=e.schemaInterface,s=e.field,d=e.style,c=e.control.value,f=null!=(a=i.isEmptyValue(s,c)?u:i.textValue(s,c))?a:"";/*#__PURE__*/return l.default.createElement("div",{style:d,className:r.rendererClass(o)},f)}finally{t()}}function k(e){var t=n.useComponentTracking();try{var r,a=e.children,i=e.accordion,s=e.contentStyle,d=e.contentClassName,c=e.designMode,f=e.iconOpenClass,m=e.iconClosedClass,p=e.className,y=e.renderTitle,v=void 0===y?function(e){return e}:y,C=e.renderToggler,x=e.renderers,N=e.titleClass,g=e.useCss,h=e.dataContext,T=(null!=(r=h.dataNode)?r:h.parentNode).control,E=n.useControl(!!i.defaultExpanded);T&&!T.meta.accordionState&&(T.meta.accordionState=E);var b=E.value,D=b||c?s:u({},s,{display:"none"}),R=x.renderLabelText(v(i.title,E)),k=C?C(E,R):/*#__PURE__*/l.default.createElement("button",{className:p,onClick:function(){return E.setValue(function(e){return!e})}},/*#__PURE__*/l.default.createElement("label",{className:N},R),/*#__PURE__*/l.default.createElement("i",{className:o.default(b?f:m)}));/*#__PURE__*/return l.default.createElement(l.default.Fragment,null,k,(g||b||c)&&/*#__PURE__*/l.default.createElement("div",{style:D,className:d},a))}finally{t()}}function A(){return r.createVisibilityRenderer(function(e){/*#__PURE__*/return l.default.createElement(O,e)})}function O(t){var r=n.useComponentTracking();try{var a=t.visibility,u=t.children,i=t.className,s=t.style,d=t.divRef,c=a.value;return e.useEffect(function(){c&&a.setValue(function(e){return{visible:c.visible,showing:c.visible}})},[null==c?void 0:c.visible]),null!=c&&c.visible?/*#__PURE__*/l.default.createElement("div",{className:o.default(i),style:s,ref:d},u):/*#__PURE__*/l.default.createElement(l.default.Fragment,null)}finally{r()}}function F(e){return r.createDataRenderer(function(t){/*#__PURE__*/return l.default.createElement(S,{renderOptions:t.renderOptions,className:r.rendererClass(t.className,e),dataNode:t.dataNode,dataContext:t.dataContext,control:t.control,readonly:t.readonly})},{renderType:r.DataRenderType.Jsonata})}function S(e){var t=n.useComponentTracking();try{var a=e.control,o=e.renderOptions,u=e.readonly,i=e.className,s=e.dataContext,d=e.dataNode,c=null!=d.elementIndex?d:s.parentNode,f=n.useComputed(function(){return{value:a.value,readonly:u,disabled:a.disabled,formData:s.formData,dataPath:r.getJsonPath(d)}}),m=r.useJsonataExpression(o.expression,r.getRootDataNode(c).control,r.getJsonPath(c),f,r.coerceToString);/*#__PURE__*/return l.default.createElement("div",{className:i,dangerouslySetInnerHTML:{__html:m.value}})}finally{t()}}var L=["control","field","renderOptions"];function w(){return r.createDataRenderer(function(e,t){var a,o,s=e.control,d=e.field,c=i(e,L),f=null!=(o=(a=s.meta).nullControl)?o:a.nullControl=n.newControl(null!=s.current.value);return function(e){var n=t.renderData(u({},c,{control:f,field:u({},d,{type:r.FieldType.Bool}),renderOptions:{type:r.DataRenderType.Checkbox}}))(e);return u({},n,{children:/*#__PURE__*/l.default.createElement(I,{control:s,nullControl:f,children:n.children,readonly:c.readonly,defaultValue:c.definition.defaultValue})})}})}function I(e){var t=e.children,r=e.nullControl,a=e.control,l=e.defaultValue,o=e.readonly;return n.useControlEffect(function(){return o},function(e){return r.disabled=e},!0),n.useControlEffect(function(){return r.value},function(e){var t;e?a.value=null!=(t=r.meta.nonNullValue)?t:l:(r.meta.nonNullValue=a.value,a.value=null)}),t}function q(e){return r.createDataRenderer(function(t,r){/*#__PURE__*/return l.default.createElement(V,{dataProps:t,renderers:r,defaultActions:e})},{renderType:r.DataRenderType.Array,collection:!0})}function V(e){var t,a=e.dataProps,o=e.renderers,i=e.defaultActions,s=a.renderOptions,d=a.control,c=a.field,f=a.readonly,m=a.designMode,p=a.required,y=a.renderChild,v=a.definition,C=a.className,x=a.style,N=a.useChildVisibility,g=a.dataContext,h=r.mergeObjects(r.isArrayRenderer(s)?s:{},i),T=h.addText,E=h.noAdd,b=h.noRemove,D=h.removeText,R=r.isArrayRenderer(s)?s.childOptions:void 0,k=!r.isCompoundField(c),A=k?{type:r.ControlDefinitionType.Data,field:v.field,children:v.children,renderOptions:null!=R?R:{type:r.DataRenderType.Standard},hideTitle:!0}:{type:r.ControlDefinitionType.Group,children:v.children,groupOptions:{type:r.GroupRenderType.Standard,hideTitle:!0}},O=(null!=(t=v.children)?t:[]).map(function(e){return[N(e,void 0,!0),e]}),F=r.makeHookDepString(O,function(e){return e[0].deps}),S=n.useTrackedComponent(M,[F]),L=u({},r.createArrayActions(d,c,{addText:T,removeText:D,noAdd:E,noRemove:b,readonly:f,disabled:d.disabled,designMode:m}),{required:p,renderElement:function(e,t){/*#__PURE__*/return l.default.createElement(S,{index:e,renderChildElement:w,dataContext:g,visibilities:O,wrap:t})},className:C||void 0,style:x},r.getLengthRestrictions(v));return o.renderArray(L);function w(e,t){var r,n;return y(null!=(r=null==(n=d.elements)?void 0:n[e].uniqueId)?r:e,A,k?{elementIndex:e}:{parentDataNode:t})}}function M(e){var t=e.index,n=e.renderChildElement,a=e.visibilities,l=e.wrap,o=e.dataContext,i=o.dataNode.getChildElement(t),s=a.map(function(e){var t=e[0];return t.runHook(u({},o,{parentNode:i,dataNode:r.lookupDataNode(e[1],i)}),t.state).value});if(0==s.length||s.some(function(e){return!0===e}))return l(n(t,i))}function P(e){return{render:function(t,r){/*#__PURE__*/return l.default.createElement(G,u({},t,e,{renderAction:r.renderAction}))},type:"array"}}function G(e){var t=n.useComponentTracking();try{var a=e.renderElement,u=e.className,i=e.removableClass,s=e.childClass,d=e.removableChildClass,c=e.removeActionClass,f=e.addActionClass,m=e.arrayControl,p=e.renderAction,y=e.style,v=r.applyArrayLengthRestrictions(e),C=v.addAction,x=v.removeAction;/*#__PURE__*/return l.default.createElement("div",{style:y},/*#__PURE__*/l.default.createElement("div",{className:o.default(u,x&&i)},/*#__PURE__*/l.default.createElement(n.RenderElements,{control:m},function(e,t){return a(t,function(e){return x?/*#__PURE__*/l.default.createElement(l.default.Fragment,null,/*#__PURE__*/l.default.createElement("div",{className:o.default(s,d)},e),/*#__PURE__*/l.default.createElement("div",{className:c},p(x(t)))):/*#__PURE__*/l.default.createElement("div",{className:s},e)})})),C&&/*#__PURE__*/l.default.createElement("div",{className:f},p(C)))}finally{t()}}function J(t){var r=n.useComponentTracking();try{var a=t.control,o=t.className,u=e.useRef(null);return n.useControlEffect(function(){return a.value},function(e){var t=u.current;t&&t.textContent!==e&&(t.textContent=e)},!0),/*#__PURE__*/l.default.createElement("code",{contentEditable:!a.disabled,className:o,onInput:function(e){return a.value=e.currentTarget.textContent},ref:u})}finally{r()}}function _(e,t){return void 0===t&&(t={}),r.createActionRenderer(e,function(e){var n,a=e.onClick,o=e.actionText,u=e.style,i=e.actionId,s=e.actionData,d=e.disabled;/*#__PURE__*/return l.default.createElement("button",{className:r.rendererClass(e.className,t.className),disabled:d,style:u,onClick:a},null!=(n=null==t.renderContent?void 0:t.renderContent(o,i,s))?n:o)})}function j(e){var t=null!=e?e:{},n=t.className,a=t.gridStyles,i=void 0===a?function(e){var t=e.columns;return{className:c,style:{display:"grid",gridTemplateColumns:"repeat("+(void 0===t?d:t)+", 1fr)"}}}:a,s=t.defaultGridColumns,d=void 0===s?2:s,c=t.gridClassName,f=t.standardClassName,m=t.flexClassName,p=t.defaultFlexGap;return{type:"group",render:function(e){var t=e.renderChild,a=e.renderOptions,s=e.childDefinitions,d=r.isGridRenderer(a)?i(a):r.isFlexRenderer(a)?function(e){return{className:m,style:{display:"flex",gap:e.gap?e.gap:p,flexDirection:e.direction?e.direction:void 0}}}(a):{className:f},c=d.style,y=d.className;return function(a){return u({},a,{children:/*#__PURE__*/l.default.createElement("div",{className:r.rendererClass(e.className,o.default(n,y)),style:c},null==s?void 0:s.map(function(e,r){return t(r,e)}))})}}}}var B=[{name:"Yes",value:!0},{name:"No",value:!1}];function H(e){var t,n,a;void 0===e&&(e={});var o,i=F(e.jsonataClass),s=w(),d=(o=e.multilineClass,r.createDataRenderer(function(e){/*#__PURE__*/return l.default.createElement(J,u({},e,{className:r.rendererClass(e.className,o)}))})),c=b(null!=(t=e.checkOptions)?t:e.checkboxOptions),f=C(e.selectOptions),m=g(null!=(n=e.radioOptions)?n:e.checkOptions),v=h(null!=(a=e.checkListOptions)?a:e.checkOptions),x=u({optionRenderer:f,booleanOptions:B},e),N=x.inputClass,T=x.booleanOptions,E=x.optionRenderer,D=x.displayOnlyClass,k=q(e.arrayOptions);return r.createDataRenderer(function(e,t){var n=e.field,a=n.type,o=e.renderOptions,C=o.type;if(n.collection&&null==e.elementIndex&&(C==r.DataRenderType.Standard||C==r.DataRenderType.Array))return k.render(e,t);if(a===r.FieldType.Compound){var x,g=null!=(x=r.isDataGroupRenderer(o)?o.groupOptions:void 0)?x:{type:"Standard",hideTitle:!0};return t.renderGroup(u({},e,{renderOptions:g}))}if(a==r.FieldType.Any)/*#__PURE__*/return l.default.createElement(l.default.Fragment,null,"No control for Any");if(r.isDisplayOnlyRenderer(o))return function(t){return u({},t,{className:D,children:/*#__PURE__*/l.default.createElement(R,{field:e.field,schemaInterface:e.dataContext.schemaInterface,control:e.control,className:e.className,style:e.style,emptyText:o.emptyText})})};if(null!=T&&a===r.FieldType.Bool&&null==e.options)return t.renderData(u({},e,{options:T}));if(C===r.DataRenderType.Standard&&r.hasOptions(e))return E.render(e,t);switch(C){case r.DataRenderType.NullToggle:return s.render(e,t);case r.DataRenderType.CheckList:return v.render(e,t);case r.DataRenderType.Dropdown:return f.render(e,t);case r.DataRenderType.Radio:return m.render(e,t);case r.DataRenderType.Checkbox:return c.render(e,t);case r.DataRenderType.Jsonata:return i.render(e,t)}if(r.isTextfieldRenderer(o)&&o.multiline)return d.render(e,t);var h=r.isTextfieldRenderer(o)?o.placeholder:void 0;/*#__PURE__*/return l.default.createElement(p,{className:r.rendererClass(e.className,N),style:e.style,id:e.id,readOnly:e.readonly,control:e.control,placeholder:null!=h?h:void 0,convert:y(e.field.type)})})}function U(t){return void 0===t&&(t={}),{type:"adornment",render:function(a,o){var i=a.adornment,s=a.designMode,d=a.dataContext,c=a.useExpr;return{apply:function(a){if(r.isSetFieldAdornment(i)&&c){var f=c(i.expression,function(e){return e}),m=r.useDynamicHooks({value:f}),p=e.useCallback(function(e){var t=e.children,a=e.adornment,l=e.parentContext,o=m(l).value,u=r.schemaDataForFieldRef(a.field,l.parentNode).control,i=!a.defaultOnly;return n.useControlEffect(function(){return[null==o?void 0:o.value,null==(null==u?void 0:u.value)]},function(e){var t=e[0];null==u||u.setValue(function(e){return i||null==e?t:e})},!0),t},[m]);return r.wrapLayout(function(e){/*#__PURE__*/return l.default.createElement(p,{children:e,parentContext:d,adornment:i})})(a)}var y;return r.isIconAdornment(i)?r.appendMarkupAt(null!=(y=i.placement)?y:r.AdornmentPlacement.ControlStart,/*#__PURE__*/l.default.createElement("i",{className:i.iconClass}))(a):r.isAccordionAdornment(i)?r.wrapLayout(function(e){/*#__PURE__*/return l.default.createElement(k,u({renderers:o,children:e,accordion:i,contentStyle:a.style,contentClassName:a.className,designMode:s,dataContext:d},t.accordion))})(a):void 0},priority:0,adornment:i}}}}function Y(e){return void 0===e&&(e={}),r.createLayoutRenderer(function(t,n){var a=r.renderLayoutParts(u({},t,{className:r.rendererClass(t.className,e.className)}),n);return{children:a.wrapLayout(/*#__PURE__*/l.default.createElement(D,u({layout:a},e))),className:a.className,style:a.style,divRef:function(e){return e&&t.errorControl?t.errorControl.meta.scrollElement=e:void 0}}})}function z(e){var t=u({requiredElement:/*#__PURE__*/l.default.createElement("span",null," *"),labelContainer:function(e){return e}},e),n=t.className,a=t.groupLabelClass,i=t.controlLabelClass,s=t.requiredElement,d=t.labelContainer;return{render:function(e,t,u,c){return e.type==r.LabelType.Text?e.label:d(/*#__PURE__*/l.default.createElement(l.default.Fragment,null,/*#__PURE__*/l.default.createElement("label",{htmlFor:e.forId,className:r.rendererClass(e.className,o.default(n,e.type===r.LabelType.Group&&a,e.type===r.LabelType.Control&&i))},t,c.renderLabelText(e.label),e.required&&s),u))},type:"label"}}function K(e){return void 0===e&&(e={}),{data:H(e.data),display:d(e.display),action:_(void 0,e.action),array:P(e.array),group:j(e.group),label:z(e.label),adornment:U(e.adornment),renderLayout:Y(e.layout),visibility:A()}}var Q={label:{groupLabelClass:"font-bold",requiredElement:/*#__PURE__*/l.default.createElement("span",{className:"text-red-500"}," *")},array:{removableClass:"grid grid-cols-[1fr_auto] items-center gap-x-2",childClass:"grow my-2",addActionClass:"my-2"},group:{standardClassName:"flex flex-col gap-4",gridClassName:"gap-x-2 gap-y-4",flexClassName:"gap-2"},action:{className:"bg-primary-500 rounded-lg p-3 text-white"},layout:{className:"flex flex-col",errorClass:"text-sm text-danger-500"},data:{displayOnlyClass:"flex flex-row items-center gap-2",checkOptions:{className:"flex items-center gap-4",entryClass:"flex gap-1 items-center"},selectOptions:{emptyText:"<select>"},multilineClass:"border p-2 outline-0 whitespace-pre"},adornment:{accordion:{className:"flex items-center gap-2 my-2",titleClass:"cursor-pointer",iconOpenClass:"fa fa-chevron-up",iconClosedClass:"fa fa-chevron-down"}}};exports.CheckButtons=T,exports.ControlInput=p,exports.DataArrayRenderer=V,exports.DefaultAccordion=k,exports.DefaultArrayRenderer=G,exports.DefaultBoolOptions=B,exports.DefaultDisplay=c,exports.DefaultDisplayOnly=R,exports.DefaultLayout=D,exports.DefaultVisibility=O,exports.JsonataRenderer=S,exports.SelectDataRenderer=x,exports.createButtonActionRenderer=_,exports.createCheckListRenderer=h,exports.createCheckboxRenderer=b,exports.createClassStyledRenderers=function(){return K({layout:{className:"control"},group:{className:"group"},array:{className:"control-array"},action:{className:"action"},data:{inputClass:"data"},display:{htmlClassName:"html",textClassName:"text"}})},exports.createDefaultAdornmentRenderer=U,exports.createDefaultArrayDataRenderer=q,exports.createDefaultArrayRenderer=P,exports.createDefaultDataRenderer=H,exports.createDefaultDisplayRenderer=d,exports.createDefaultGroupRenderer=j,exports.createDefaultLabelRenderer=z,exports.createDefaultRenderers=K,exports.createDefaultVisibilityRenderer=A,exports.createInputConversion=y,exports.createJsonataRenderer=F,exports.createNullToggleRenderer=w,exports.createRadioRenderer=g,exports.createSelectConversion=N,exports.createSelectRenderer=C,exports.defaultTailwindTheme=Q,exports.getAccordionState=function(e){return e.meta.accordionState},exports.setIncluded=E;
|
|
2
2
|
//# sourceMappingURL=index.cjs.map
|
package/lib/index.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.cjs","sources":["../src/components/DefaultDisplay.tsx","../src/components/ControlInput.tsx","../src/components/SelectDataRenderer.tsx","../src/components/CheckRenderer.tsx","../src/components/DefaultLayout.tsx","../src/components/DefaultDisplayOnly.tsx","../src/components/DefaultVisibility.tsx","../src/components/JsonataRenderer.tsx","../src/components/NullToggle.tsx","../src/components/DefaultArrayRenderer.tsx","../src/components/DefaultAccordion.tsx","../src/components/MultilineTextfield.tsx","../src/createDefaultRenderers.tsx","../src/tailwind.tsx"],"sourcesContent":["import React from \"react\";\nimport clsx from \"clsx\";\nimport {\n coerceToString,\n CustomDisplay,\n DisplayDataType,\n DisplayRendererProps,\n DisplayRendererRegistration,\n getOverrideClass,\n HtmlDisplay,\n IconDisplay,\n rendererClass,\n TextDisplay,\n} from \"@react-typed-forms/schemas\";\n\nexport interface DefaultDisplayRendererOptions {\n textClassName?: string;\n htmlClassName?: string;\n}\n\nexport function createDefaultDisplayRenderer(\n options: DefaultDisplayRendererOptions = {},\n): DisplayRendererRegistration {\n return {\n render: (props) => <DefaultDisplay {...options} {...props} />,\n type: \"display\",\n };\n}\n\nexport function DefaultDisplay({\n data,\n display,\n className,\n style,\n ...options\n}: DefaultDisplayRendererOptions & DisplayRendererProps) {\n switch (data.type) {\n case DisplayDataType.Icon:\n return (\n <i\n style={style}\n className={clsx(\n getOverrideClass(className),\n display ? display.value : (data as IconDisplay).iconClass,\n )}\n />\n );\n case DisplayDataType.Text:\n return (\n <div\n style={style}\n className={rendererClass(className, options.textClassName)}\n >\n {display ? coerceToString(display.value) : (data as TextDisplay).text}\n </div>\n );\n case DisplayDataType.Html:\n return (\n <div\n style={style}\n className={rendererClass(className, options.htmlClassName)}\n dangerouslySetInnerHTML={{\n __html: display\n ? coerceToString(display.value)\n : (data as HtmlDisplay).html,\n }}\n />\n );\n case DisplayDataType.Custom:\n return (\n <div>\n Custom display placeholder: {(data as CustomDisplay).customId}\n </div>\n );\n default:\n return <h1>Unknown display type: {data.type}</h1>;\n }\n}\n","import React from \"react\";\nimport {\n Control,\n formControlProps,\n useControl,\n useControlEffect,\n} from \"@react-typed-forms/core\";\nimport {FieldType} from \"@react-typed-forms/schemas\";\n\nexport function ControlInput({\n control,\n convert,\n ...props\n}: React.InputHTMLAttributes<HTMLInputElement> & {\n control: Control<any>;\n convert: InputConversion;\n}) {\n const { errorText, value, onChange, ...inputProps } =\n formControlProps(control);\n const textValue = useControl(() => toText(value));\n useControlEffect(\n () => control.value,\n (v) => (textValue.value = toText(v)),\n );\n return (\n <input\n {...inputProps}\n type={convert[0]}\n value={textValue.value}\n onChange={(e) => {\n textValue.value = e.target.value;\n const converted = convert[1](e.target.value);\n if (converted !== undefined) control.value = converted;\n }}\n {...props}\n />\n );\n\n function toText(value: any) {\n return value == null ? \"\" : convert[2](value);\n }\n}\n\ntype InputConversion = [\n string,\n (s: string) => any,\n (a: any) => string | number,\n];\n\nexport function createInputConversion(ft: string): InputConversion {\n switch (ft) {\n case FieldType.String:\n return [\"text\", (a) => a, (a) => a];\n case FieldType.Bool:\n return [\n \"text\",\n (a) => (a === \"true\" ? true : a === \"false\" ? false : undefined),\n (a) => a?.toString() ?? \"\",\n ];\n case FieldType.Int:\n return [\n \"number\",\n (a) => (a !== \"\" ? parseInt(a) : null),\n (a) => (a == null ? \"\" : a),\n ];\n case FieldType.DateTime:\n return [\"datetime-local\", (a) => (!a ? null : a), (a) => a];\n case FieldType.Date:\n return [\"date\", (a) => (!a ? null : a), (a) => a];\n case FieldType.Time:\n return [\n \"time\",\n (a) => {\n const l = a.length;\n if (l === 5) return a + \":00\";\n if (l === 8) return a;\n return undefined;\n },\n (a) => (a ? a.substring(0, 5) : \"\"),\n ];\n case FieldType.Double:\n return [\n \"number\",\n (a) => (a !== \"\" ? parseFloat(a) : null),\n (a) => (a == null ? \"\" : a),\n ];\n default:\n return [\"text\", (a) => a, (a) => a];\n }\n}\n","import { Control } from \"@react-typed-forms/core\";\nimport React, { useMemo, useState } from \"react\";\nimport {\n createDataRenderer,\n FieldOption,\n FieldType,\n rendererClass,\n} from \"@react-typed-forms/schemas\";\n\nexport interface SelectRendererOptions {\n className?: string;\n emptyText?: string;\n requiredText?: string;\n}\n\nexport function createSelectRenderer(options: SelectRendererOptions = {}) {\n return createDataRenderer(\n (props, asArray) => (\n <SelectDataRenderer\n className={rendererClass(props.className, options.className)}\n state={props.control}\n id={props.id}\n readonly={props.readonly}\n options={props.options ?? []}\n required={props.required}\n emptyText={options.emptyText}\n requiredText={options.requiredText}\n convert={createSelectConversion(props.field.type)}\n />\n ),\n {\n options: true,\n },\n );\n}\n\ntype SelectConversion = (a: any) => string | number;\n\nexport interface SelectDataRendererProps {\n id?: string;\n className?: string;\n options: FieldOption[];\n emptyText?: string;\n requiredText?: string;\n readonly: boolean;\n required: boolean;\n state: Control<any>;\n convert: SelectConversion;\n}\n\nexport function SelectDataRenderer({\n state,\n options,\n className,\n convert,\n required,\n emptyText = \"N/A\",\n requiredText = \"<please select>\",\n readonly,\n ...props\n}: SelectDataRendererProps) {\n const { value, disabled } = state;\n const [showEmpty] = useState(!required || value == null);\n const optionStringMap = useMemo(\n () => Object.fromEntries(options.map((x) => [convert(x.value), x.value])),\n [options],\n );\n const optionGroups = useMemo(\n () => new Set(options.filter((x) => x.group).map((x) => x.group!)),\n [options],\n );\n return (\n <select\n {...props}\n className={className}\n onChange={(v) => (state.value = optionStringMap[v.target.value])}\n value={convert(value)}\n disabled={disabled || readonly}\n >\n {showEmpty && (\n <option value=\"\">{required ? requiredText : emptyText}</option>\n )}\n {[...optionGroups.keys()].map((x) => (\n <optgroup key={x} label={x}>\n {options.filter((o) => o.group === x).map(renderOption)}\n </optgroup>\n ))}\n {options.filter((x) => !x.group).map(renderOption)}\n </select>\n );\n\n function renderOption(x: FieldOption, i: number) {\n return (\n <option key={i} value={convert(x.value)} disabled={!!x.disabled}>\n {x.name}\n </option>\n );\n }\n}\n\nexport function createSelectConversion(ft: string): SelectConversion {\n switch (ft) {\n case FieldType.String:\n case FieldType.Int:\n case FieldType.Double:\n return (a) => a;\n default:\n return (a) => a?.toString() ?? \"\";\n }\n}\n","import {\n Control,\n Fcheckbox,\n RenderArrayElements,\n useComputed,\n} from \"@react-typed-forms/core\";\nimport React, { ReactNode } from \"react\";\nimport {\n createDataRenderer,\n DataRenderType,\n FieldOption,\n fieldOptionAdornment,\n rendererClass\n} from \"@react-typed-forms/schemas\";\n\nexport interface CheckRendererOptions {\n className?: string;\n entryClass?: string;\n checkClass?: string;\n labelClass?: string;\n}\nexport function createRadioRenderer(options: CheckRendererOptions = {}) {\n return createDataRenderer(\n (p) => (\n <CheckButtons\n {...options}\n {...p}\n className={rendererClass(p.className, options.className)}\n isChecked={(control, o) => control.value == o.value}\n setChecked={(c, o) => (c.value = o.value)}\n control={p.control}\n type=\"radio\"\n entryAdornment={fieldOptionAdornment(p)}\n />\n ),\n {\n renderType: DataRenderType.Radio,\n },\n );\n}\n\nexport function createCheckListRenderer(options: CheckRendererOptions = {}) {\n return createDataRenderer(\n (p) => (\n <CheckButtons\n {...options}\n {...p}\n className={rendererClass(p.className, options.className)}\n isChecked={(control, o) => {\n const v = control.value;\n return Array.isArray(v) ? v.includes(o.value) : false;\n }}\n setChecked={(c, o, checked) => {\n c.setValue((x) => setIncluded(x ?? [], o.value, checked));\n }}\n control={p.control}\n type=\"checkbox\"\n entryAdornment={fieldOptionAdornment(p)}\n />\n ),\n {\n collection: true,\n renderType: DataRenderType.CheckList,\n },\n );\n}\n\nexport interface CheckButtonsProps {\n id?: string;\n className?: string;\n options?: FieldOption[] | null;\n control: Control<any>;\n entryClass?: string;\n checkClass?: string;\n labelClass?: string;\n readonly?: boolean;\n type: \"checkbox\" | \"radio\";\n isChecked: (c: Control<any>, o: FieldOption) => boolean;\n setChecked: (c: Control<any>, o: FieldOption, checked: boolean) => void;\n entryAdornment?: (c: FieldOption, i: number, selected: boolean) => ReactNode;\n}\n\nexport function CheckButtons({\n control,\n options,\n labelClass,\n checkClass,\n readonly,\n entryClass,\n className,\n id,\n type,\n isChecked,\n setChecked,\n entryAdornment,\n}: CheckButtonsProps) {\n const { disabled } = control;\n const name = \"r\" + control.uniqueId;\n return (\n <div className={className} id={id}>\n <RenderArrayElements array={options?.filter((x) => x.value != null)}>\n {(o, i) => {\n const checked = useComputed(() => isChecked(control, o)).value;\n return (\n <>\n <div key={i} className={entryClass}>\n <input\n id={name + \"_\" + i}\n className={checkClass}\n type={type}\n name={name}\n readOnly={readonly}\n disabled={disabled}\n checked={checked}\n onChange={(x) => {\n !readonly && setChecked(control, o, x.target.checked);\n }}\n />\n <label className={labelClass} htmlFor={name + \"_\" + i}>\n {o.name}\n </label>\n </div>\n {entryAdornment?.(o, i, checked)}\n </>\n );\n }}\n </RenderArrayElements>\n </div>\n );\n}\n\nexport function setIncluded<A>(array: A[], elem: A, included: boolean): A[] {\n const already = array.includes(elem);\n if (included === already) {\n return array;\n }\n if (included) {\n return [...array, elem];\n }\n return array.filter((e) => e !== elem);\n}\n\nexport function createCheckboxRenderer(options: CheckRendererOptions = {}) {\n return createDataRenderer(\n (props, renderer) => (p) => ({\n ...p,\n label: undefined,\n children: (\n <div className={rendererClass(props.className, options.entryClass)}>\n <Fcheckbox\n id={props.id}\n control={props.control}\n style={props.style}\n className={options.checkClass}\n />\n {p.label && renderer.renderLabel(p.label, undefined, undefined)}\n </div>\n ),\n }),\n { renderType: DataRenderType.Checkbox },\n );\n}\n","import React, { ReactNode } from \"react\";\nimport {RenderedLayout} from \"@react-typed-forms/schemas\";\n\nexport interface DefaultLayoutRendererOptions {\n className?: string;\n errorClass?: string;\n renderError?: (errorText: string | null | undefined) => ReactNode;\n}\n\nexport function DefaultLayout({\n errorClass,\n renderError = (e) => e && <div className={errorClass}>{e}</div>,\n layout: { controlEnd, controlStart, label, children, errorControl },\n}: DefaultLayoutRendererOptions & {\n layout: RenderedLayout;\n}) {\n const ec = errorControl;\n const errorText = ec && ec.touched ? ec.error : undefined;\n return (\n <>\n {label}\n {controlStart}\n {children}\n {renderError(errorText)}\n {controlEnd}\n </>\n );\n}\n","import { Control } from \"@react-typed-forms/core\";\nimport React from \"react\";\nimport {\n rendererClass,\n SchemaField,\n SchemaInterface,\n} from \"@react-typed-forms/schemas\";\n\nexport function DefaultDisplayOnly({\n control,\n className,\n emptyText,\n schemaInterface,\n field,\n style,\n}: {\n control: Control<any>;\n field: SchemaField;\n schemaInterface: SchemaInterface;\n className?: string | null;\n style?: React.CSSProperties;\n emptyText?: string | null;\n}) {\n const v = control.value;\n const text =\n (schemaInterface.isEmptyValue(field, v)\n ? emptyText\n : schemaInterface.textValue(field, v)) ?? \"\";\n return (\n <div style={style} className={rendererClass(className)}>\n {text}\n </div>\n );\n}\n","import React, { useEffect } from \"react\";\nimport clsx from \"clsx\";\nimport {\n createVisibilityRenderer,\n VisibilityRendererProps,\n} from \"@react-typed-forms/schemas\";\n\nexport function createDefaultVisibilityRenderer() {\n return createVisibilityRenderer((props) => <DefaultVisibility {...props} />);\n}\n\nexport function DefaultVisibility({\n visibility,\n children,\n className,\n style,\n divRef,\n}: VisibilityRendererProps) {\n const v = visibility.value;\n useEffect(() => {\n if (v) {\n visibility.setValue((ex) => ({ visible: v.visible, showing: v.visible }));\n }\n }, [v?.visible]);\n return v?.visible ? (\n <div className={clsx(className)} style={style} ref={divRef}>\n {children}\n </div>\n ) : (\n <></>\n );\n}\n","import { Control, useComputed } from \"@react-typed-forms/core\";\nimport React from \"react\";\nimport {\n coerceToString,\n ControlDataContext,\n createDataRenderer,\n DataRenderType,\n getJsonPath,\n getRootDataNode,\n JsonataRenderOptions,\n rendererClass,\n SchemaDataNode,\n useJsonataExpression,\n} from \"@react-typed-forms/schemas\";\n\nexport function createJsonataRenderer(className?: string) {\n return createDataRenderer(\n (p) => (\n <JsonataRenderer\n renderOptions={p.renderOptions as JsonataRenderOptions}\n className={rendererClass(p.className, className)}\n dataNode={p.dataNode}\n dataContext={p.dataContext}\n control={p.control}\n readonly={p.readonly}\n />\n ),\n { renderType: DataRenderType.Jsonata },\n );\n}\n\nexport function JsonataRenderer({\n control,\n renderOptions,\n readonly,\n className,\n dataContext,\n dataNode,\n}: {\n control: Control<any>;\n renderOptions: JsonataRenderOptions;\n className?: string;\n dataContext: ControlDataContext;\n dataNode: SchemaDataNode;\n readonly: boolean;\n}) {\n const sdn = dataNode.elementIndex != null ? dataNode : dataContext.parentNode;\n const bindings = useComputed(() => ({\n value: control.value,\n readonly,\n disabled: control.disabled,\n formData: dataContext.formData,\n dataPath: getJsonPath(dataNode),\n }));\n const rendered = useJsonataExpression(\n renderOptions.expression,\n getRootDataNode(sdn).control!,\n getJsonPath(sdn),\n bindings,\n coerceToString,\n );\n return (\n <div\n className={className}\n dangerouslySetInnerHTML={{ __html: rendered.value }}\n />\n );\n}\n","import { Control, newControl, useControlEffect } from \"@react-typed-forms/core\";\nimport React, { ReactNode } from \"react\";\nimport {\n createDataRenderer,\n DataRenderType,\n FieldType,\n} from \"@react-typed-forms/schemas\";\n\nexport function createNullToggleRenderer() {\n return createDataRenderer(\n ({ control, field, renderOptions, ...props }, renderers) => {\n const nullControl = (control.meta[\"nullControl\"] ??= newControl(\n control.current.value != null,\n ));\n return (layout) => {\n const newLayout = renderers.renderData({\n ...props,\n control: nullControl,\n field: { ...field, type: FieldType.Bool },\n renderOptions: { type: DataRenderType.Checkbox },\n })(layout);\n return {\n ...newLayout,\n children: (\n <NullWrapper\n control={control}\n nullControl={nullControl}\n children={newLayout.children}\n readonly={props.readonly}\n defaultValue={props.definition.defaultValue}\n />\n ),\n };\n };\n },\n );\n}\n\nfunction NullWrapper({\n children,\n nullControl,\n control,\n defaultValue,\n readonly,\n}: {\n control: Control<any>;\n nullControl: Control<boolean>;\n children: ReactNode;\n readonly: boolean;\n defaultValue: any;\n}) {\n useControlEffect(\n () => readonly,\n (r) => (nullControl.disabled = r),\n true,\n );\n useControlEffect(\n () => nullControl.value,\n (e) => {\n if (e) {\n control.value = nullControl.meta[\"nonNullValue\"] ?? defaultValue;\n } else {\n nullControl.meta[\"nonNullValue\"] = control.value;\n control.value = null;\n }\n },\n );\n return children;\n}\n","import clsx from \"clsx\";\nimport React, { Fragment, ReactNode } from \"react\";\nimport { RenderElements, useTrackedComponent } from \"@react-typed-forms/core\";\nimport {\n ActionRendererProps,\n applyArrayLengthRestrictions,\n ArrayActionOptions,\n ArrayRendererProps,\n ArrayRendererRegistration,\n ArrayRenderOptions,\n ControlDataContext,\n ControlDefinition,\n ControlDefinitionType,\n createArrayActions,\n createDataRenderer,\n DataControlDefinition,\n DataRendererProps,\n DataRendererRegistration,\n DataRenderType,\n EvalExpressionHook,\n FormRenderer,\n getLengthRestrictions,\n GroupedControlsDefinition,\n GroupRenderType,\n isArrayRenderer,\n isCompoundField,\n lookupDataNode,\n makeHookDepString,\n mergeObjects,\n SchemaDataNode,\n} from \"@react-typed-forms/schemas\";\n\nexport function createDefaultArrayDataRenderer(\n defaultActions?: ArrayActionOptions,\n): DataRendererRegistration {\n return createDataRenderer(\n (props, renderers) => {\n return (\n <DataArrayRenderer\n dataProps={props}\n renderers={renderers}\n defaultActions={defaultActions}\n />\n );\n },\n { renderType: DataRenderType.Array, collection: true },\n );\n}\n\nexport function DataArrayRenderer({\n dataProps,\n renderers,\n defaultActions,\n}: {\n renderers: FormRenderer;\n dataProps: DataRendererProps;\n defaultActions?: ArrayActionOptions;\n}) {\n const {\n renderOptions,\n control,\n field,\n readonly,\n designMode,\n required,\n renderChild,\n definition,\n className,\n style,\n useChildVisibility,\n dataContext,\n } = dataProps;\n const { addText, noAdd, noRemove, noReorder, removeText } = mergeObjects(\n isArrayRenderer(renderOptions) ? renderOptions : ({} as ArrayRenderOptions),\n defaultActions as ArrayRenderOptions,\n );\n const childOptions = isArrayRenderer(renderOptions)\n ? renderOptions.childOptions\n : undefined;\n\n const renderAsElement = !isCompoundField(field);\n const childDefinition: ControlDefinition = !renderAsElement\n ? ({\n type: ControlDefinitionType.Group,\n children: definition.children,\n groupOptions: { type: GroupRenderType.Standard, hideTitle: true },\n } as GroupedControlsDefinition)\n : ({\n type: ControlDefinitionType.Data,\n field: definition.field,\n children: definition.children,\n renderOptions: childOptions ?? { type: DataRenderType.Standard },\n hideTitle: true,\n } as DataControlDefinition);\n\n const visibilities = (definition.children ?? []).map(\n (x) => [useChildVisibility(x, undefined, true), x] as const,\n );\n const deps = makeHookDepString(visibilities, (x) => x[0].deps);\n const Entry = useTrackedComponent(RenderEntry, [deps]);\n\n const arrayProps = {\n ...createArrayActions(control, field, {\n addText,\n removeText,\n noAdd,\n noRemove,\n readonly,\n disabled: control.disabled,\n designMode,\n }),\n required,\n renderElement: (i, wrap) => (\n <Entry\n index={i}\n renderChildElement={renderChildElement}\n dataContext={dataContext}\n visibilities={visibilities}\n wrap={wrap}\n />\n ),\n className: className ? className : undefined,\n style,\n ...getLengthRestrictions(definition),\n } satisfies ArrayRendererProps;\n\n return renderers.renderArray(arrayProps);\n\n function renderChildElement(i: number, elementNode: SchemaDataNode) {\n return renderChild(\n control.elements?.[i].uniqueId ?? i,\n childDefinition,\n renderAsElement\n ? {\n elementIndex: i,\n }\n : { parentDataNode: elementNode },\n );\n }\n}\n\nfunction RenderEntry({\n index: i,\n renderChildElement,\n visibilities,\n wrap,\n dataContext,\n}: {\n index: number;\n renderChildElement: (i: number, element: SchemaDataNode) => ReactNode;\n visibilities: (readonly [EvalExpressionHook<boolean>, ControlDefinition])[];\n dataContext: ControlDataContext;\n wrap: (n: ReactNode) => ReactNode;\n}) {\n const elementNode = dataContext.dataNode!.getChildElement(i);\n const childVis = visibilities.map(\n ([hook, def]) =>\n hook.runHook(\n {\n ...dataContext,\n parentNode: elementNode,\n dataNode: lookupDataNode(def, elementNode),\n },\n hook.state,\n ).value,\n );\n const anyVisible = childVis.length == 0 || childVis.some((x) => x === true);\n if (!anyVisible) return undefined;\n return wrap(renderChildElement(i, elementNode));\n}\n\nexport interface DefaultArrayRendererOptions extends ArrayActionOptions {\n className?: string;\n removableClass?: string;\n childClass?: string;\n removableChildClass?: string;\n removeActionClass?: string;\n addActionClass?: string;\n}\n\nexport function createDefaultArrayRenderer(\n options?: DefaultArrayRendererOptions,\n): ArrayRendererRegistration {\n return {\n render: (props, { renderAction }) => (\n <DefaultArrayRenderer\n {...props}\n {...options}\n renderAction={renderAction}\n />\n ),\n type: \"array\",\n };\n}\n\nexport interface DefaultArrayRendererProps\n extends DefaultArrayRendererOptions,\n ArrayRendererProps {\n renderAction: (props: ActionRendererProps) => ReactNode;\n}\n\nexport function DefaultArrayRenderer(props: DefaultArrayRendererProps) {\n const {\n renderElement,\n className,\n removableClass,\n childClass,\n removableChildClass,\n removeActionClass,\n addActionClass,\n arrayControl,\n renderAction,\n style,\n } = props;\n const { addAction, removeAction } = applyArrayLengthRestrictions(props);\n return (\n <div style={style}>\n <div className={clsx(className, removeAction && removableClass)}>\n <RenderElements control={arrayControl}>\n {(_, x) =>\n renderElement(x, (children) =>\n removeAction ? (\n <>\n <div className={clsx(childClass, removableChildClass)}>\n {children}\n </div>\n <div className={removeActionClass}>\n {renderAction(removeAction(x))}\n </div>\n </>\n ) : (\n <div className={childClass}>{children}</div>\n ),\n )\n }\n </RenderElements>\n </div>\n {addAction && (\n <div className={addActionClass}>{renderAction(addAction)}</div>\n )}\n </div>\n );\n}\n","import React, { CSSProperties, Fragment, ReactElement } from \"react\";\nimport { useControl } from \"@react-typed-forms/core\";\nimport clsx from \"clsx\";\nimport { DefaultAccordionRendererOptions } from \"../createDefaultRenderers\";\nimport { AccordionAdornment, FormRenderer } from \"@react-typed-forms/schemas\";\n\nexport function DefaultAccordion({\n children,\n accordion,\n contentStyle,\n contentClassName,\n designMode,\n iconOpenClass,\n iconClosedClass,\n className,\n renderTitle = (t) => t,\n renderToggler,\n renderers,\n titleClass,\n}: {\n children: ReactElement;\n accordion: Partial<AccordionAdornment>;\n contentStyle?: CSSProperties;\n contentClassName?: string;\n designMode?: boolean;\n renderers: FormRenderer;\n} & DefaultAccordionRendererOptions) {\n const open = useControl(!!accordion.defaultExpanded);\n const isOpen = open.value;\n const fullContentStyle =\n isOpen || designMode ? contentStyle : { ...contentStyle, display: \"none\" };\n const title = renderers.renderLabelText(renderTitle(accordion.title, open));\n const toggler = renderToggler ? (\n renderToggler(open, title)\n ) : (\n <button className={className} onClick={() => open.setValue((x) => !x)}>\n <label className={titleClass}>{title}</label>\n <i className={clsx(isOpen ? iconOpenClass : iconClosedClass)} />\n </button>\n );\n\n return (\n <>\n {toggler}\n <div style={fullContentStyle} className={contentClassName}>\n {children}\n </div>\n </>\n );\n}\n","import React, { useRef } from \"react\";\nimport { useControlEffect } from \"@react-typed-forms/core\";\nimport {\n createDataRenderer,\n DataRendererProps,\n rendererClass,\n} from \"@react-typed-forms/schemas\";\n\nexport function createMultilineFieldRenderer(className?: string) {\n return createDataRenderer((p) => (\n <MultilineTextfield\n {...p}\n className={rendererClass(p.className, className)}\n />\n ));\n}\n\nexport function MultilineTextfield({ control, className }: DataRendererProps) {\n const codeRef = useRef<HTMLElement | null>(null);\n useControlEffect(\n () => control.value,\n (v) => {\n const c = codeRef.current;\n if (c && c.textContent !== v) {\n c.textContent = v;\n }\n },\n true,\n );\n return (\n <code\n contentEditable={!control.disabled}\n className={className}\n onInput={(t) => (control.value = t.currentTarget.textContent)}\n ref={codeRef}\n />\n );\n}\n","import {\n createDefaultDisplayRenderer,\n DefaultDisplayRendererOptions,\n} from \"./components/DefaultDisplay\";\nimport {\n DefaultLayout,\n DefaultLayoutRendererOptions,\n} from \"./components/DefaultLayout\";\nimport { createDefaultVisibilityRenderer } from \"./components/DefaultVisibility\";\nimport React, {\n CSSProperties,\n Fragment,\n ReactElement,\n ReactNode,\n useCallback,\n} from \"react\";\nimport clsx from \"clsx\";\nimport {\n createSelectRenderer,\n SelectRendererOptions,\n} from \"./components/SelectDataRenderer\";\nimport { DefaultDisplayOnly } from \"./components/DefaultDisplayOnly\";\nimport { Control, useControlEffect } from \"@react-typed-forms/core\";\nimport { ControlInput, createInputConversion } from \"./components/ControlInput\";\nimport {\n createDefaultArrayDataRenderer,\n createDefaultArrayRenderer,\n DefaultArrayRendererOptions,\n} from \"./components/DefaultArrayRenderer\";\nimport {\n CheckRendererOptions,\n createCheckboxRenderer,\n createCheckListRenderer,\n createRadioRenderer,\n} from \"./components/CheckRenderer\";\nimport { DefaultAccordion } from \"./components/DefaultAccordion\";\nimport { createNullToggleRenderer } from \"./components/NullToggle\";\nimport { createMultilineFieldRenderer } from \"./components/MultilineTextfield\";\nimport { createJsonataRenderer } from \"./components/JsonataRenderer\";\nimport {\n ActionRendererProps,\n ActionRendererRegistration,\n AdornmentPlacement,\n AdornmentRendererRegistration,\n appendMarkupAt,\n ArrayActionOptions,\n ControlDataContext,\n ControlLayoutProps,\n createActionRenderer,\n createDataRenderer,\n createLayoutRenderer,\n DataRendererRegistration,\n DataRenderType,\n DefaultRenderers,\n FieldOption,\n FieldType,\n FlexRenderer,\n GridRenderer,\n GroupRendererProps,\n GroupRendererRegistration,\n hasOptions,\n isAccordionAdornment,\n isDataGroupRenderer,\n isDisplayOnlyRenderer,\n isFlexRenderer,\n isGridRenderer,\n isIconAdornment,\n isSetFieldAdornment,\n isTextfieldRenderer,\n LabelRendererRegistration,\n LabelType,\n rendererClass,\n renderLayoutParts,\n schemaDataForFieldRef,\n SetFieldAdornment,\n useDynamicHooks,\n wrapLayout,\n} from \"@react-typed-forms/schemas\";\n\nexport interface DefaultRendererOptions {\n data?: DefaultDataRendererOptions;\n display?: DefaultDisplayRendererOptions;\n action?: DefaultActionRendererOptions;\n array?: DefaultArrayRendererOptions;\n group?: DefaultGroupRendererOptions;\n label?: DefaultLabelRendererOptions;\n adornment?: DefaultAdornmentRendererOptions;\n layout?: DefaultLayoutRendererOptions;\n}\n\ninterface StyleProps {\n className?: string;\n style?: CSSProperties;\n}\n\nexport interface DefaultActionRendererOptions {\n className?: string;\n renderContent?: (\n actionText: string,\n actionId: string,\n actionData: any,\n ) => ReactNode;\n}\n\nexport function createButtonActionRenderer(\n actionId: string | string[] | undefined,\n options: DefaultActionRendererOptions = {},\n): ActionRendererRegistration {\n return createActionRenderer(\n actionId,\n ({\n onClick,\n actionText,\n className,\n style,\n actionId,\n actionData,\n disabled,\n }: ActionRendererProps) => {\n return (\n <button\n className={rendererClass(className, options.className)}\n disabled={disabled}\n style={style}\n onClick={onClick}\n >\n {options.renderContent?.(actionText, actionId, actionData) ??\n actionText}\n </button>\n );\n },\n );\n}\n\nexport interface DefaultGroupRendererOptions {\n className?: string;\n standardClassName?: string;\n gridStyles?: (columns: GridRenderer) => StyleProps;\n gridClassName?: string;\n defaultGridColumns?: number;\n flexClassName?: string;\n defaultFlexGap?: string;\n}\n\nexport function createDefaultGroupRenderer(\n options?: DefaultGroupRendererOptions,\n): GroupRendererRegistration {\n const {\n className,\n gridStyles = defaultGridStyles,\n defaultGridColumns = 2,\n gridClassName,\n standardClassName,\n flexClassName,\n defaultFlexGap,\n } = options ?? {};\n\n function defaultGridStyles({\n columns = defaultGridColumns,\n }: GridRenderer): StyleProps {\n return {\n className: gridClassName,\n style: {\n display: \"grid\",\n gridTemplateColumns: `repeat(${columns}, 1fr)`,\n },\n };\n }\n\n function flexStyles(options: FlexRenderer): StyleProps {\n return {\n className: flexClassName,\n style: {\n display: \"flex\",\n gap: options.gap ? options.gap : defaultFlexGap,\n flexDirection: options.direction\n ? (options.direction as any)\n : undefined,\n },\n };\n }\n\n function render(props: GroupRendererProps) {\n const { renderChild, renderOptions, childDefinitions } = props;\n\n const { style, className: gcn } = isGridRenderer(renderOptions)\n ? gridStyles(renderOptions)\n : isFlexRenderer(renderOptions)\n ? flexStyles(renderOptions)\n : ({ className: standardClassName } as StyleProps);\n\n return (cp: ControlLayoutProps) => {\n return {\n ...cp,\n children: (\n <div\n className={rendererClass(props.className, clsx(className, gcn))}\n style={style}\n >\n {childDefinitions?.map((c, i) => renderChild(i, c))}\n </div>\n ),\n };\n };\n }\n\n return { type: \"group\", render };\n}\n\nexport const DefaultBoolOptions: FieldOption[] = [\n { name: \"Yes\", value: true },\n { name: \"No\", value: false },\n];\n\nexport interface DefaultDataRendererOptions {\n inputClass?: string;\n displayOnlyClass?: string;\n selectOptions?: SelectRendererOptions;\n checkboxOptions?: CheckRendererOptions;\n checkOptions?: CheckRendererOptions;\n radioOptions?: CheckRendererOptions;\n checkListOptions?: CheckRendererOptions;\n booleanOptions?: FieldOption[];\n optionRenderer?: DataRendererRegistration;\n multilineClass?: string;\n jsonataClass?: string;\n arrayOptions?: ArrayActionOptions;\n}\n\nexport function createDefaultDataRenderer(\n options: DefaultDataRendererOptions = {},\n): DataRendererRegistration {\n const jsonataRenderer = createJsonataRenderer(options.jsonataClass);\n const nullToggler = createNullToggleRenderer();\n const multilineRenderer = createMultilineFieldRenderer(\n options.multilineClass,\n );\n const checkboxRenderer = createCheckboxRenderer(\n options.checkOptions ?? options.checkboxOptions,\n );\n const selectRenderer = createSelectRenderer(options.selectOptions);\n const radioRenderer = createRadioRenderer(\n options.radioOptions ?? options.checkOptions,\n );\n const checkListRenderer = createCheckListRenderer(\n options.checkListOptions ?? options.checkOptions,\n );\n const { inputClass, booleanOptions, optionRenderer, displayOnlyClass } = {\n optionRenderer: selectRenderer,\n booleanOptions: DefaultBoolOptions,\n ...options,\n };\n const arrayRenderer = createDefaultArrayDataRenderer(options.arrayOptions);\n\n return createDataRenderer((props, renderers) => {\n const { field } = props;\n const fieldType = field.type;\n const renderOptions = props.renderOptions;\n let renderType = renderOptions.type;\n if (\n field.collection &&\n props.elementIndex == null &&\n (renderType == DataRenderType.Standard ||\n renderType == DataRenderType.Array)\n ) {\n return arrayRenderer.render(props, renderers);\n }\n if (fieldType === FieldType.Compound) {\n const groupOptions = (isDataGroupRenderer(renderOptions)\n ? renderOptions.groupOptions\n : undefined) ?? { type: \"Standard\", hideTitle: true };\n return renderers.renderGroup({ ...props, renderOptions: groupOptions });\n }\n if (fieldType == FieldType.Any) return <>No control for Any</>;\n if (isDisplayOnlyRenderer(renderOptions))\n return (p) => ({\n ...p,\n className: displayOnlyClass,\n children: (\n <DefaultDisplayOnly\n field={props.field}\n schemaInterface={props.dataContext.schemaInterface}\n control={props.control}\n className={props.className}\n style={props.style}\n emptyText={renderOptions.emptyText}\n />\n ),\n });\n const isBool = fieldType === FieldType.Bool;\n if (booleanOptions != null && isBool && props.options == null) {\n return renderers.renderData({ ...props, options: booleanOptions });\n }\n if (renderType === DataRenderType.Standard && hasOptions(props)) {\n return optionRenderer.render(props, renderers);\n }\n switch (renderType) {\n case DataRenderType.NullToggle:\n return nullToggler.render(props, renderers);\n case DataRenderType.CheckList:\n return checkListRenderer.render(props, renderers);\n case DataRenderType.Dropdown:\n return selectRenderer.render(props, renderers);\n case DataRenderType.Radio:\n return radioRenderer.render(props, renderers);\n case DataRenderType.Checkbox:\n return checkboxRenderer.render(props, renderers);\n case DataRenderType.Jsonata:\n return jsonataRenderer.render(props, renderers);\n }\n if (isTextfieldRenderer(renderOptions) && renderOptions.multiline)\n return multilineRenderer.render(props, renderers);\n const placeholder = isTextfieldRenderer(renderOptions)\n ? renderOptions.placeholder\n : undefined;\n return (\n <ControlInput\n className={rendererClass(props.className, inputClass)}\n style={props.style}\n id={props.id}\n readOnly={props.readonly}\n control={props.control}\n placeholder={placeholder ?? undefined}\n convert={createInputConversion(props.field.type)}\n />\n );\n });\n}\n\nexport interface DefaultAccordionRendererOptions {\n className?: string;\n titleClass?: string;\n togglerClass?: string;\n iconOpenClass?: string;\n iconClosedClass?: string;\n renderTitle?: (\n title: string | undefined,\n current: Control<boolean>,\n ) => ReactNode;\n renderToggler?: (current: Control<boolean>, title: ReactNode) => ReactNode;\n}\n\nexport interface DefaultAdornmentRendererOptions {\n accordion?: DefaultAccordionRendererOptions;\n}\n\nexport function createDefaultAdornmentRenderer(\n options: DefaultAdornmentRendererOptions = {},\n): AdornmentRendererRegistration {\n return {\n type: \"adornment\",\n render: ({ adornment, designMode, dataContext, useExpr }, renderers) => ({\n apply: (rl) => {\n if (isSetFieldAdornment(adornment) && useExpr) {\n const hook = useExpr(adornment.expression, (x) => x);\n const dynamicHooks = useDynamicHooks({ value: hook });\n const SetFieldWrapper = useCallback(setFieldWrapper, [dynamicHooks]);\n return wrapLayout((x) => (\n <SetFieldWrapper\n children={x}\n parentContext={dataContext}\n adornment={adornment}\n />\n ))(rl);\n\n function setFieldWrapper({\n children,\n adornment,\n parentContext,\n }: {\n children: ReactNode;\n adornment: SetFieldAdornment;\n parentContext: ControlDataContext;\n }) {\n const { value } = dynamicHooks(parentContext);\n const fieldNode = schemaDataForFieldRef(\n adornment.field,\n parentContext.parentNode,\n );\n const otherField = fieldNode.control;\n const always = !adornment.defaultOnly;\n useControlEffect(\n () => [value?.value, otherField?.value == null],\n ([v]) => {\n otherField?.setValue((x) => (always || x == null ? v : x));\n },\n true,\n );\n return children;\n }\n }\n if (isIconAdornment(adornment)) {\n return appendMarkupAt(\n adornment.placement ?? AdornmentPlacement.ControlStart,\n <i className={adornment.iconClass} />,\n )(rl);\n }\n if (isAccordionAdornment(adornment)) {\n return wrapLayout((x) => (\n <DefaultAccordion\n renderers={renderers}\n children={x}\n accordion={adornment}\n contentStyle={rl.style}\n contentClassName={rl.className}\n designMode={designMode}\n {...options.accordion}\n />\n ))(rl);\n }\n },\n priority: 0,\n adornment,\n }),\n };\n}\n\nfunction createDefaultLayoutRenderer(\n options: DefaultLayoutRendererOptions = {},\n) {\n return createLayoutRenderer((props, renderers) => {\n const layout = renderLayoutParts(\n {\n ...props,\n className: rendererClass(props.className, options.className),\n },\n renderers,\n );\n return {\n children: layout.wrapLayout(\n <DefaultLayout layout={layout} {...options} />,\n ),\n className: layout.className,\n style: layout.style,\n divRef: (e) =>\n e && props.errorControl\n ? (props.errorControl.meta.scrollElement = e)\n : undefined,\n };\n });\n}\n\ninterface DefaultLabelRendererOptions {\n className?: string;\n groupLabelClass?: string;\n controlLabelClass?: string;\n requiredElement?: ReactNode;\n labelContainer?: (children: ReactElement) => ReactElement;\n}\n\nexport function createDefaultLabelRenderer(\n options?: DefaultLabelRendererOptions,\n): LabelRendererRegistration {\n const {\n className,\n groupLabelClass,\n controlLabelClass,\n requiredElement,\n labelContainer,\n } = {\n requiredElement: <span> *</span>,\n labelContainer: (c: ReactElement) => c,\n ...options,\n };\n return {\n render: (props, labelStart, labelEnd, renderers) => {\n if (props.type == LabelType.Text) return props.label;\n return labelContainer(\n <>\n <label\n htmlFor={props.forId}\n className={rendererClass(\n props.className,\n clsx(\n className,\n props.type === LabelType.Group && groupLabelClass,\n props.type === LabelType.Control && controlLabelClass,\n ),\n )}\n >\n {labelStart}\n {renderers.renderLabelText(props.label)}\n {props.required && requiredElement}\n </label>\n {labelEnd}\n </>,\n );\n },\n type: \"label\",\n };\n}\n\nexport function createDefaultRenderers(\n options: DefaultRendererOptions = {},\n): DefaultRenderers {\n return {\n data: createDefaultDataRenderer(options.data),\n display: createDefaultDisplayRenderer(options.display),\n action: createButtonActionRenderer(undefined, options.action),\n array: createDefaultArrayRenderer(options.array),\n group: createDefaultGroupRenderer(options.group),\n label: createDefaultLabelRenderer(options.label),\n adornment: createDefaultAdornmentRenderer(options.adornment),\n renderLayout: createDefaultLayoutRenderer(options.layout),\n visibility: createDefaultVisibilityRenderer(),\n };\n}\n\nexport function createClassStyledRenderers() {\n return createDefaultRenderers({\n layout: { className: \"control\" },\n group: { className: \"group\" },\n array: { className: \"control-array\" },\n action: { className: \"action\" },\n data: { inputClass: \"data\" },\n display: { htmlClassName: \"html\", textClassName: \"text\" },\n });\n}\n","import React from \"react\";\n\nimport { DefaultRendererOptions } from \"./createDefaultRenderers\";\n\nexport const defaultTailwindTheme = {\n label: {\n groupLabelClass: \"font-bold\",\n requiredElement: <span className=\"text-red-500\"> *</span>,\n },\n array: {\n removableClass: \"grid grid-cols-[1fr_auto] items-center gap-x-2\",\n childClass: \"grow my-2\",\n addActionClass: \"my-2\",\n },\n group: {\n standardClassName: \"flex flex-col gap-4\",\n gridClassName: \"gap-x-2 gap-y-4\",\n flexClassName: \"gap-2\",\n },\n action: {\n className: \"bg-primary-500 rounded-lg p-3 text-white\",\n },\n layout: {\n className: \"flex flex-col\",\n errorClass: \"text-sm text-danger-500\",\n },\n data: {\n displayOnlyClass: \"flex flex-row items-center gap-2\",\n checkOptions: {\n className: \"flex items-center gap-4\",\n entryClass: \"flex gap-1 items-center\",\n },\n selectOptions: { emptyText: \"<select>\" },\n multilineClass: \"border p-2 outline-0 whitespace-pre\",\n },\n adornment: {\n accordion: {\n className: \"flex items-center gap-2 my-2\",\n titleClass: \"cursor-pointer\",\n iconOpenClass: \"fa fa-chevron-up\",\n iconClosedClass: \"fa fa-chevron-down\",\n },\n },\n} satisfies DefaultRendererOptions;\n"],"names":["_excluded","createDefaultDisplayRenderer","options","render","props","React","createElement","DefaultDisplay","_extends","type","_ref","_effect","_useComponentTracking","useComponentTracking","data","display","className","style","_objectWithoutPropertiesLoose","DisplayDataType","Icon","clsx","getOverrideClass","value","iconClass","Text","rendererClass","textClassName","coerceToString","text","Html","htmlClassName","dangerouslySetInnerHTML","__html","html","Custom","customId","_excluded2","ControlInput","toText","convert","control","_formControlProps","formControlProps","inputProps","textValue","useControl","useControlEffect","v","onChange","e","target","converted","undefined","createInputConversion","ft","FieldType","String","a","Bool","_a$toString","toString","Int","parseInt","DateTime","Date","Time","l","length","substring","Double","parseFloat","createSelectRenderer","createDataRenderer","asArray","_props$options","SelectDataRenderer","state","id","readonly","required","emptyText","requiredText","createSelectConversion","field","renderOption","x","i","key","disabled","name","_ref$emptyText","_ref$requiredText","showEmpty","useState","optionStringMap","useMemo","Object","fromEntries","map","optionGroups","Set","filter","group","concat","keys","label","o","createRadioRenderer","p","CheckButtons","isChecked","setChecked","c","entryAdornment","fieldOptionAdornment","renderType","DataRenderType","Radio","createCheckListRenderer","Array","isArray","includes","checked","setValue","setIncluded","collection","CheckList","labelClass","checkClass","entryClass","uniqueId","RenderArrayElements","array","useComputed","Fragment","readOnly","htmlFor","elem","included","createCheckboxRenderer","renderer","children","Fcheckbox","renderLabel","Checkbox","DefaultLayout","errorClass","_ref$renderError","renderError","_ref$layout","layout","controlEnd","errorControl","controlStart","touched","error","DefaultDisplayOnly","_ref2","schemaInterface","isEmptyValue","createDefaultVisibilityRenderer","createVisibilityRenderer","DefaultVisibility","visibility","divRef","useEffect","ex","visible","showing","ref","createJsonataRenderer","JsonataRenderer","renderOptions","dataNode","dataContext","Jsonata","sdn","elementIndex","parentNode","bindings","formData","dataPath","getJsonPath","rendered","useJsonataExpression","expression","getRootDataNode","createNullToggleRenderer","renderers","_control$meta","_control$meta$_nullCo","nullControl","meta","newControl","current","newLayout","renderData","NullWrapper","defaultValue","definition","r","_nullControl$meta$non","createDefaultArrayDataRenderer","defaultActions","DataArrayRenderer","dataProps","_definition$children","designMode","renderChild","useChildVisibility","_mergeObjects","mergeObjects","isArrayRenderer","addText","noAdd","noRemove","removeText","childOptions","renderAsElement","isCompoundField","childDefinition","ControlDefinitionType","Data","Standard","hideTitle","Group","groupOptions","GroupRenderType","visibilities","deps","makeHookDepString","Entry","useTrackedComponent","RenderEntry","arrayProps","createArrayActions","renderElement","wrap","index","renderChildElement","getLengthRestrictions","renderArray","elementNode","_control$elements$i$u","_control$elements","elements","parentDataNode","getChildElement","childVis","_ref3","hook","def","runHook","lookupDataNode","some","createDefaultArrayRenderer","_ref4","DefaultArrayRenderer","renderAction","removableClass","childClass","removableChildClass","removeActionClass","addActionClass","arrayControl","_applyArrayLengthRest","applyArrayLengthRestrictions","addAction","removeAction","RenderElements","_","DefaultAccordion","accordion","contentStyle","contentClassName","iconOpenClass","iconClosedClass","_ref$renderTitle","renderTitle","t","renderToggler","titleClass","open","defaultExpanded","isOpen","fullContentStyle","title","renderLabelText","toggler","onClick","MultilineTextfield","codeRef","useRef","textContent","contentEditable","onInput","currentTarget","createButtonActionRenderer","actionId","createActionRenderer","_options$renderConten","actionText","actionData","renderContent","createDefaultGroupRenderer","_ref2$gridStyles","gridStyles","_ref3$columns","columns","gridClassName","gridTemplateColumns","defaultGridColumns","_ref2$defaultGridColu","standardClassName","flexClassName","defaultFlexGap","childDefinitions","isGridRenderer","isFlexRenderer","gap","flexDirection","direction","flexStyles","gcn","cp","DefaultBoolOptions","createDefaultDataRenderer","_options$checkOptions","_options$radioOptions","_options$checkListOpt","jsonataRenderer","jsonataClass","nullToggler","multilineRenderer","multilineClass","checkboxRenderer","checkOptions","checkboxOptions","selectRenderer","selectOptions","radioRenderer","radioOptions","checkListRenderer","checkListOptions","_optionRenderer$boole","optionRenderer","booleanOptions","inputClass","displayOnlyClass","arrayRenderer","arrayOptions","fieldType","Compound","_ref5","isDataGroupRenderer","renderGroup","Any","isDisplayOnlyRenderer","hasOptions","NullToggle","Dropdown","isTextfieldRenderer","multiline","placeholder","createDefaultAdornmentRenderer","_ref6","adornment","useExpr","apply","rl","isSetFieldAdornment","dynamicHooks","useDynamicHooks","SetFieldWrapper","useCallback","_ref7","parentContext","otherField","schemaDataForFieldRef","always","defaultOnly","_ref8","wrapLayout","_adornment$placement","isIconAdornment","appendMarkupAt","placement","AdornmentPlacement","ControlStart","isAccordionAdornment","priority","createDefaultLayoutRenderer","createLayoutRenderer","renderLayoutParts","scrollElement","createDefaultLabelRenderer","_requiredElement$labe","requiredElement","labelContainer","groupLabelClass","controlLabelClass","labelStart","labelEnd","LabelType","forId","Control","createDefaultRenderers","action","renderLayout","defaultTailwindTheme"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.cjs","sources":["../src/components/DefaultDisplay.tsx","../src/components/ControlInput.tsx","../src/components/SelectDataRenderer.tsx","../src/components/CheckRenderer.tsx","../src/components/DefaultLayout.tsx","../src/components/DefaultDisplayOnly.tsx","../src/components/DefaultAccordion.tsx","../src/components/DefaultVisibility.tsx","../src/components/JsonataRenderer.tsx","../src/components/NullToggle.tsx","../src/components/DefaultArrayRenderer.tsx","../src/components/MultilineTextfield.tsx","../src/createDefaultRenderers.tsx","../src/tailwind.tsx"],"sourcesContent":["import React from \"react\";\nimport clsx from \"clsx\";\nimport {\n coerceToString,\n CustomDisplay,\n DisplayDataType,\n DisplayRendererProps,\n DisplayRendererRegistration,\n getOverrideClass,\n HtmlDisplay,\n IconDisplay,\n rendererClass,\n TextDisplay,\n} from \"@react-typed-forms/schemas\";\n\nexport interface DefaultDisplayRendererOptions {\n textClassName?: string;\n htmlClassName?: string;\n}\n\nexport function createDefaultDisplayRenderer(\n options: DefaultDisplayRendererOptions = {},\n): DisplayRendererRegistration {\n return {\n render: (props) => <DefaultDisplay {...options} {...props} />,\n type: \"display\",\n };\n}\n\nexport function DefaultDisplay({\n data,\n display,\n className,\n style,\n ...options\n}: DefaultDisplayRendererOptions & DisplayRendererProps) {\n switch (data.type) {\n case DisplayDataType.Icon:\n return (\n <i\n style={style}\n className={clsx(\n getOverrideClass(className),\n display ? display.value : (data as IconDisplay).iconClass,\n )}\n />\n );\n case DisplayDataType.Text:\n return (\n <div\n style={style}\n className={rendererClass(className, options.textClassName)}\n >\n {display ? coerceToString(display.value) : (data as TextDisplay).text}\n </div>\n );\n case DisplayDataType.Html:\n return (\n <div\n style={style}\n className={rendererClass(className, options.htmlClassName)}\n dangerouslySetInnerHTML={{\n __html: display\n ? coerceToString(display.value)\n : (data as HtmlDisplay).html,\n }}\n />\n );\n case DisplayDataType.Custom:\n return (\n <div>\n Custom display placeholder: {(data as CustomDisplay).customId}\n </div>\n );\n default:\n return <h1>Unknown display type: {data.type}</h1>;\n }\n}\n","import React from \"react\";\nimport {\n Control,\n formControlProps,\n useControl,\n useControlEffect,\n} from \"@react-typed-forms/core\";\nimport {FieldType} from \"@react-typed-forms/schemas\";\n\nexport function ControlInput({\n control,\n convert,\n ...props\n}: React.InputHTMLAttributes<HTMLInputElement> & {\n control: Control<any>;\n convert: InputConversion;\n}) {\n const { errorText, value, onChange, ...inputProps } =\n formControlProps(control);\n const textValue = useControl(() => toText(value));\n useControlEffect(\n () => control.value,\n (v) => (textValue.value = toText(v)),\n );\n return (\n <input\n {...inputProps}\n type={convert[0]}\n value={textValue.value}\n onChange={(e) => {\n textValue.value = e.target.value;\n const converted = convert[1](e.target.value);\n if (converted !== undefined) control.value = converted;\n }}\n {...props}\n />\n );\n\n function toText(value: any) {\n return value == null ? \"\" : convert[2](value);\n }\n}\n\ntype InputConversion = [\n string,\n (s: string) => any,\n (a: any) => string | number,\n];\n\nexport function createInputConversion(ft: string): InputConversion {\n switch (ft) {\n case FieldType.String:\n return [\"text\", (a) => a, (a) => a];\n case FieldType.Bool:\n return [\n \"text\",\n (a) => (a === \"true\" ? true : a === \"false\" ? false : undefined),\n (a) => a?.toString() ?? \"\",\n ];\n case FieldType.Int:\n return [\n \"number\",\n (a) => (a !== \"\" ? parseInt(a) : null),\n (a) => (a == null ? \"\" : a),\n ];\n case FieldType.DateTime:\n return [\"datetime-local\", (a) => (!a ? null : a), (a) => a];\n case FieldType.Date:\n return [\"date\", (a) => (!a ? null : a), (a) => a];\n case FieldType.Time:\n return [\n \"time\",\n (a) => {\n const l = a.length;\n if (l === 5) return a + \":00\";\n if (l === 8) return a;\n return undefined;\n },\n (a) => (a ? a.substring(0, 5) : \"\"),\n ];\n case FieldType.Double:\n return [\n \"number\",\n (a) => (a !== \"\" ? parseFloat(a) : null),\n (a) => (a == null ? \"\" : a),\n ];\n default:\n return [\"text\", (a) => a, (a) => a];\n }\n}\n","import { Control } from \"@react-typed-forms/core\";\nimport React, { useMemo, useState } from \"react\";\nimport {\n createDataRenderer,\n FieldOption,\n FieldType,\n rendererClass,\n} from \"@react-typed-forms/schemas\";\n\nexport interface SelectRendererOptions {\n className?: string;\n emptyText?: string;\n requiredText?: string;\n}\n\nexport function createSelectRenderer(options: SelectRendererOptions = {}) {\n return createDataRenderer(\n (props, asArray) => (\n <SelectDataRenderer\n className={rendererClass(props.className, options.className)}\n state={props.control}\n id={props.id}\n readonly={props.readonly}\n options={props.options ?? []}\n required={props.required}\n emptyText={options.emptyText}\n requiredText={options.requiredText}\n convert={createSelectConversion(props.field.type)}\n />\n ),\n {\n options: true,\n },\n );\n}\n\ntype SelectConversion = (a: any) => string | number;\n\nexport interface SelectDataRendererProps {\n id?: string;\n className?: string;\n options: FieldOption[];\n emptyText?: string;\n requiredText?: string;\n readonly: boolean;\n required: boolean;\n state: Control<any>;\n convert: SelectConversion;\n}\n\nexport function SelectDataRenderer({\n state,\n options,\n className,\n convert,\n required,\n emptyText = \"N/A\",\n requiredText = \"<please select>\",\n readonly,\n ...props\n}: SelectDataRendererProps) {\n const { value, disabled } = state;\n const [showEmpty] = useState(!required || value == null);\n const optionStringMap = useMemo(\n () => Object.fromEntries(options.map((x) => [convert(x.value), x.value])),\n [options],\n );\n const optionGroups = useMemo(\n () => new Set(options.filter((x) => x.group).map((x) => x.group!)),\n [options],\n );\n return (\n <select\n {...props}\n className={className}\n onChange={(v) => (state.value = optionStringMap[v.target.value])}\n value={convert(value)}\n disabled={disabled || readonly}\n >\n {showEmpty && (\n <option value=\"\">{required ? requiredText : emptyText}</option>\n )}\n {[...optionGroups.keys()].map((x) => (\n <optgroup key={x} label={x}>\n {options.filter((o) => o.group === x).map(renderOption)}\n </optgroup>\n ))}\n {options.filter((x) => !x.group).map(renderOption)}\n </select>\n );\n\n function renderOption(x: FieldOption, i: number) {\n return (\n <option key={i} value={convert(x.value)} disabled={!!x.disabled}>\n {x.name}\n </option>\n );\n }\n}\n\nexport function createSelectConversion(ft: string): SelectConversion {\n switch (ft) {\n case FieldType.String:\n case FieldType.Int:\n case FieldType.Double:\n return (a) => a;\n default:\n return (a) => a?.toString() ?? \"\";\n }\n}\n","import {\n Control,\n Fcheckbox,\n RenderArrayElements,\n useComputed,\n} from \"@react-typed-forms/core\";\nimport React, { ReactNode } from \"react\";\nimport {\n createDataRenderer,\n DataRenderType,\n FieldOption,\n fieldOptionAdornment,\n rendererClass\n} from \"@react-typed-forms/schemas\";\n\nexport interface CheckRendererOptions {\n className?: string;\n entryClass?: string;\n checkClass?: string;\n labelClass?: string;\n}\nexport function createRadioRenderer(options: CheckRendererOptions = {}) {\n return createDataRenderer(\n (p) => (\n <CheckButtons\n {...options}\n {...p}\n className={rendererClass(p.className, options.className)}\n isChecked={(control, o) => control.value == o.value}\n setChecked={(c, o) => (c.value = o.value)}\n control={p.control}\n type=\"radio\"\n entryAdornment={fieldOptionAdornment(p)}\n />\n ),\n {\n renderType: DataRenderType.Radio,\n },\n );\n}\n\nexport function createCheckListRenderer(options: CheckRendererOptions = {}) {\n return createDataRenderer(\n (p) => (\n <CheckButtons\n {...options}\n {...p}\n className={rendererClass(p.className, options.className)}\n isChecked={(control, o) => {\n const v = control.value;\n return Array.isArray(v) ? v.includes(o.value) : false;\n }}\n setChecked={(c, o, checked) => {\n c.setValue((x) => setIncluded(x ?? [], o.value, checked));\n }}\n control={p.control}\n type=\"checkbox\"\n entryAdornment={fieldOptionAdornment(p)}\n />\n ),\n {\n collection: true,\n renderType: DataRenderType.CheckList,\n },\n );\n}\n\nexport interface CheckButtonsProps {\n id?: string;\n className?: string;\n options?: FieldOption[] | null;\n control: Control<any>;\n entryClass?: string;\n checkClass?: string;\n labelClass?: string;\n readonly?: boolean;\n type: \"checkbox\" | \"radio\";\n isChecked: (c: Control<any>, o: FieldOption) => boolean;\n setChecked: (c: Control<any>, o: FieldOption, checked: boolean) => void;\n entryAdornment?: (c: FieldOption, i: number, selected: boolean) => ReactNode;\n}\n\nexport function CheckButtons({\n control,\n options,\n labelClass,\n checkClass,\n readonly,\n entryClass,\n className,\n id,\n type,\n isChecked,\n setChecked,\n entryAdornment,\n}: CheckButtonsProps) {\n const { disabled } = control;\n const name = \"r\" + control.uniqueId;\n return (\n <div className={className} id={id}>\n <RenderArrayElements array={options?.filter((x) => x.value != null)}>\n {(o, i) => {\n const checked = useComputed(() => isChecked(control, o)).value;\n return (\n <>\n <div key={i} className={entryClass}>\n <input\n id={name + \"_\" + i}\n className={checkClass}\n type={type}\n name={name}\n readOnly={readonly}\n disabled={disabled}\n checked={checked}\n onChange={(x) => {\n !readonly && setChecked(control, o, x.target.checked);\n }}\n />\n <label className={labelClass} htmlFor={name + \"_\" + i}>\n {o.name}\n </label>\n </div>\n {entryAdornment?.(o, i, checked)}\n </>\n );\n }}\n </RenderArrayElements>\n </div>\n );\n}\n\nexport function setIncluded<A>(array: A[], elem: A, included: boolean): A[] {\n const already = array.includes(elem);\n if (included === already) {\n return array;\n }\n if (included) {\n return [...array, elem];\n }\n return array.filter((e) => e !== elem);\n}\n\nexport function createCheckboxRenderer(options: CheckRendererOptions = {}) {\n return createDataRenderer(\n (props, renderer) => (p) => ({\n ...p,\n label: undefined,\n children: (\n <div className={rendererClass(props.className, options.entryClass)}>\n <Fcheckbox\n id={props.id}\n control={props.control}\n style={props.style}\n className={options.checkClass}\n />\n {p.label && renderer.renderLabel(p.label, undefined, undefined)}\n </div>\n ),\n }),\n { renderType: DataRenderType.Checkbox },\n );\n}\n","import React, { ReactNode } from \"react\";\nimport {RenderedLayout} from \"@react-typed-forms/schemas\";\n\nexport interface DefaultLayoutRendererOptions {\n className?: string;\n errorClass?: string;\n renderError?: (errorText: string | null | undefined) => ReactNode;\n}\n\nexport function DefaultLayout({\n errorClass,\n renderError = (e) => e && <div className={errorClass}>{e}</div>,\n layout: { controlEnd, controlStart, label, children, errorControl },\n}: DefaultLayoutRendererOptions & {\n layout: RenderedLayout;\n}) {\n const ec = errorControl;\n const errorText = ec && ec.touched ? ec.error : undefined;\n return (\n <>\n {label}\n {controlStart}\n {children}\n {renderError(errorText)}\n {controlEnd}\n </>\n );\n}\n","import { Control } from \"@react-typed-forms/core\";\nimport React from \"react\";\nimport {\n rendererClass,\n SchemaField,\n SchemaInterface,\n} from \"@react-typed-forms/schemas\";\n\nexport function DefaultDisplayOnly({\n control,\n className,\n emptyText,\n schemaInterface,\n field,\n style,\n}: {\n control: Control<any>;\n field: SchemaField;\n schemaInterface: SchemaInterface;\n className?: string | null;\n style?: React.CSSProperties;\n emptyText?: string | null;\n}) {\n const v = control.value;\n const text =\n (schemaInterface.isEmptyValue(field, v)\n ? emptyText\n : schemaInterface.textValue(field, v)) ?? \"\";\n return (\n <div style={style} className={rendererClass(className)}>\n {text}\n </div>\n );\n}\n","import React, { CSSProperties, Fragment, ReactElement } from \"react\";\nimport { Control, useControl } from \"@react-typed-forms/core\";\nimport clsx from \"clsx\";\nimport { DefaultAccordionRendererOptions } from \"../createDefaultRenderers\";\nimport {\n AccordionAdornment,\n ControlDataContext,\n FormRenderer,\n} from \"@react-typed-forms/schemas\";\n\nexport function DefaultAccordion({\n children,\n accordion,\n contentStyle,\n contentClassName,\n designMode,\n iconOpenClass,\n iconClosedClass,\n className,\n renderTitle = (t) => t,\n renderToggler,\n renderers,\n titleClass,\n useCss,\n dataContext,\n}: {\n children: ReactElement;\n accordion: Partial<AccordionAdornment>;\n contentStyle?: CSSProperties;\n contentClassName?: string;\n designMode?: boolean;\n renderers: FormRenderer;\n dataContext: ControlDataContext;\n} & DefaultAccordionRendererOptions) {\n const dataControl = (dataContext.dataNode ?? dataContext.parentNode).control;\n const open = useControl(!!accordion.defaultExpanded);\n if (dataControl && !dataControl.meta.accordionState) {\n dataControl.meta.accordionState = open;\n }\n const isOpen = open.value;\n const fullContentStyle =\n isOpen || designMode ? contentStyle : { ...contentStyle, display: \"none\" };\n const title = renderers.renderLabelText(renderTitle(accordion.title, open));\n const toggler = renderToggler ? (\n renderToggler(open, title)\n ) : (\n <button className={className} onClick={() => open.setValue((x) => !x)}>\n <label className={titleClass}>{title}</label>\n <i className={clsx(isOpen ? iconOpenClass : iconClosedClass)} />\n </button>\n );\n\n return (\n <>\n {toggler}\n {(useCss || isOpen || designMode) && (\n <div style={fullContentStyle} className={contentClassName}>\n {children}\n </div>\n )}\n </>\n );\n}\n\nexport function getAccordionState(\n c: Control<unknown>,\n): Control<boolean> | undefined {\n return c.meta.accordionState;\n}\n","import React, { useEffect } from \"react\";\nimport clsx from \"clsx\";\nimport {\n createVisibilityRenderer,\n VisibilityRendererProps,\n} from \"@react-typed-forms/schemas\";\n\nexport function createDefaultVisibilityRenderer() {\n return createVisibilityRenderer((props) => <DefaultVisibility {...props} />);\n}\n\nexport function DefaultVisibility({\n visibility,\n children,\n className,\n style,\n divRef,\n}: VisibilityRendererProps) {\n const v = visibility.value;\n useEffect(() => {\n if (v) {\n visibility.setValue((ex) => ({ visible: v.visible, showing: v.visible }));\n }\n }, [v?.visible]);\n return v?.visible ? (\n <div className={clsx(className)} style={style} ref={divRef}>\n {children}\n </div>\n ) : (\n <></>\n );\n}\n","import { Control, useComputed } from \"@react-typed-forms/core\";\nimport React from \"react\";\nimport {\n coerceToString,\n ControlDataContext,\n createDataRenderer,\n DataRenderType,\n getJsonPath,\n getRootDataNode,\n JsonataRenderOptions,\n rendererClass,\n SchemaDataNode,\n useJsonataExpression,\n} from \"@react-typed-forms/schemas\";\n\nexport function createJsonataRenderer(className?: string) {\n return createDataRenderer(\n (p) => (\n <JsonataRenderer\n renderOptions={p.renderOptions as JsonataRenderOptions}\n className={rendererClass(p.className, className)}\n dataNode={p.dataNode}\n dataContext={p.dataContext}\n control={p.control}\n readonly={p.readonly}\n />\n ),\n { renderType: DataRenderType.Jsonata },\n );\n}\n\nexport function JsonataRenderer({\n control,\n renderOptions,\n readonly,\n className,\n dataContext,\n dataNode,\n}: {\n control: Control<any>;\n renderOptions: JsonataRenderOptions;\n className?: string;\n dataContext: ControlDataContext;\n dataNode: SchemaDataNode;\n readonly: boolean;\n}) {\n const sdn = dataNode.elementIndex != null ? dataNode : dataContext.parentNode;\n const bindings = useComputed(() => ({\n value: control.value,\n readonly,\n disabled: control.disabled,\n formData: dataContext.formData,\n dataPath: getJsonPath(dataNode),\n }));\n const rendered = useJsonataExpression(\n renderOptions.expression,\n getRootDataNode(sdn).control!,\n getJsonPath(sdn),\n bindings,\n coerceToString,\n );\n return (\n <div\n className={className}\n dangerouslySetInnerHTML={{ __html: rendered.value }}\n />\n );\n}\n","import { Control, newControl, useControlEffect } from \"@react-typed-forms/core\";\nimport React, { ReactNode } from \"react\";\nimport {\n createDataRenderer,\n DataRenderType,\n FieldType,\n} from \"@react-typed-forms/schemas\";\n\nexport function createNullToggleRenderer() {\n return createDataRenderer(\n ({ control, field, renderOptions, ...props }, renderers) => {\n const nullControl = (control.meta[\"nullControl\"] ??= newControl(\n control.current.value != null,\n ));\n return (layout) => {\n const newLayout = renderers.renderData({\n ...props,\n control: nullControl,\n field: { ...field, type: FieldType.Bool },\n renderOptions: { type: DataRenderType.Checkbox },\n })(layout);\n return {\n ...newLayout,\n children: (\n <NullWrapper\n control={control}\n nullControl={nullControl}\n children={newLayout.children}\n readonly={props.readonly}\n defaultValue={props.definition.defaultValue}\n />\n ),\n };\n };\n },\n );\n}\n\nfunction NullWrapper({\n children,\n nullControl,\n control,\n defaultValue,\n readonly,\n}: {\n control: Control<any>;\n nullControl: Control<boolean>;\n children: ReactNode;\n readonly: boolean;\n defaultValue: any;\n}) {\n useControlEffect(\n () => readonly,\n (r) => (nullControl.disabled = r),\n true,\n );\n useControlEffect(\n () => nullControl.value,\n (e) => {\n if (e) {\n control.value = nullControl.meta[\"nonNullValue\"] ?? defaultValue;\n } else {\n nullControl.meta[\"nonNullValue\"] = control.value;\n control.value = null;\n }\n },\n );\n return children;\n}\n","import clsx from \"clsx\";\nimport React, { Fragment, ReactNode } from \"react\";\nimport { RenderElements, useTrackedComponent } from \"@react-typed-forms/core\";\nimport {\n ActionRendererProps,\n applyArrayLengthRestrictions,\n ArrayActionOptions,\n ArrayRendererProps,\n ArrayRendererRegistration,\n ArrayRenderOptions,\n ControlDataContext,\n ControlDefinition,\n ControlDefinitionType,\n createArrayActions,\n createDataRenderer,\n DataControlDefinition,\n DataRendererProps,\n DataRendererRegistration,\n DataRenderType,\n EvalExpressionHook,\n FormRenderer,\n getLengthRestrictions,\n GroupedControlsDefinition,\n GroupRenderType,\n isArrayRenderer,\n isCompoundField,\n lookupDataNode,\n makeHookDepString,\n mergeObjects,\n SchemaDataNode,\n} from \"@react-typed-forms/schemas\";\n\nexport function createDefaultArrayDataRenderer(\n defaultActions?: ArrayActionOptions,\n): DataRendererRegistration {\n return createDataRenderer(\n (props, renderers) => {\n return (\n <DataArrayRenderer\n dataProps={props}\n renderers={renderers}\n defaultActions={defaultActions}\n />\n );\n },\n { renderType: DataRenderType.Array, collection: true },\n );\n}\n\nexport function DataArrayRenderer({\n dataProps,\n renderers,\n defaultActions,\n}: {\n renderers: FormRenderer;\n dataProps: DataRendererProps;\n defaultActions?: ArrayActionOptions;\n}) {\n const {\n renderOptions,\n control,\n field,\n readonly,\n designMode,\n required,\n renderChild,\n definition,\n className,\n style,\n useChildVisibility,\n dataContext,\n } = dataProps;\n const { addText, noAdd, noRemove, noReorder, removeText } = mergeObjects(\n isArrayRenderer(renderOptions) ? renderOptions : ({} as ArrayRenderOptions),\n defaultActions as ArrayRenderOptions,\n );\n const childOptions = isArrayRenderer(renderOptions)\n ? renderOptions.childOptions\n : undefined;\n\n const renderAsElement = !isCompoundField(field);\n const childDefinition: ControlDefinition = !renderAsElement\n ? ({\n type: ControlDefinitionType.Group,\n children: definition.children,\n groupOptions: { type: GroupRenderType.Standard, hideTitle: true },\n } as GroupedControlsDefinition)\n : ({\n type: ControlDefinitionType.Data,\n field: definition.field,\n children: definition.children,\n renderOptions: childOptions ?? { type: DataRenderType.Standard },\n hideTitle: true,\n } as DataControlDefinition);\n\n const visibilities = (definition.children ?? []).map(\n (x) => [useChildVisibility(x, undefined, true), x] as const,\n );\n const deps = makeHookDepString(visibilities, (x) => x[0].deps);\n const Entry = useTrackedComponent(RenderEntry, [deps]);\n\n const arrayProps = {\n ...createArrayActions(control, field, {\n addText,\n removeText,\n noAdd,\n noRemove,\n readonly,\n disabled: control.disabled,\n designMode,\n }),\n required,\n renderElement: (i, wrap) => (\n <Entry\n index={i}\n renderChildElement={renderChildElement}\n dataContext={dataContext}\n visibilities={visibilities}\n wrap={wrap}\n />\n ),\n className: className ? className : undefined,\n style,\n ...getLengthRestrictions(definition),\n } satisfies ArrayRendererProps;\n\n return renderers.renderArray(arrayProps);\n\n function renderChildElement(i: number, elementNode: SchemaDataNode) {\n return renderChild(\n control.elements?.[i].uniqueId ?? i,\n childDefinition,\n renderAsElement\n ? {\n elementIndex: i,\n }\n : { parentDataNode: elementNode },\n );\n }\n}\n\nfunction RenderEntry({\n index: i,\n renderChildElement,\n visibilities,\n wrap,\n dataContext,\n}: {\n index: number;\n renderChildElement: (i: number, element: SchemaDataNode) => ReactNode;\n visibilities: (readonly [EvalExpressionHook<boolean>, ControlDefinition])[];\n dataContext: ControlDataContext;\n wrap: (n: ReactNode) => ReactNode;\n}) {\n const elementNode = dataContext.dataNode!.getChildElement(i);\n const childVis = visibilities.map(\n ([hook, def]) =>\n hook.runHook(\n {\n ...dataContext,\n parentNode: elementNode,\n dataNode: lookupDataNode(def, elementNode),\n },\n hook.state,\n ).value,\n );\n const anyVisible = childVis.length == 0 || childVis.some((x) => x === true);\n if (!anyVisible) return undefined;\n return wrap(renderChildElement(i, elementNode));\n}\n\nexport interface DefaultArrayRendererOptions extends ArrayActionOptions {\n className?: string;\n removableClass?: string;\n childClass?: string;\n removableChildClass?: string;\n removeActionClass?: string;\n addActionClass?: string;\n}\n\nexport function createDefaultArrayRenderer(\n options?: DefaultArrayRendererOptions,\n): ArrayRendererRegistration {\n return {\n render: (props, { renderAction }) => (\n <DefaultArrayRenderer\n {...props}\n {...options}\n renderAction={renderAction}\n />\n ),\n type: \"array\",\n };\n}\n\nexport interface DefaultArrayRendererProps\n extends DefaultArrayRendererOptions,\n ArrayRendererProps {\n renderAction: (props: ActionRendererProps) => ReactNode;\n}\n\nexport function DefaultArrayRenderer(props: DefaultArrayRendererProps) {\n const {\n renderElement,\n className,\n removableClass,\n childClass,\n removableChildClass,\n removeActionClass,\n addActionClass,\n arrayControl,\n renderAction,\n style,\n } = props;\n const { addAction, removeAction } = applyArrayLengthRestrictions(props);\n return (\n <div style={style}>\n <div className={clsx(className, removeAction && removableClass)}>\n <RenderElements control={arrayControl}>\n {(_, x) =>\n renderElement(x, (children) =>\n removeAction ? (\n <>\n <div className={clsx(childClass, removableChildClass)}>\n {children}\n </div>\n <div className={removeActionClass}>\n {renderAction(removeAction(x))}\n </div>\n </>\n ) : (\n <div className={childClass}>{children}</div>\n ),\n )\n }\n </RenderElements>\n </div>\n {addAction && (\n <div className={addActionClass}>{renderAction(addAction)}</div>\n )}\n </div>\n );\n}\n","import React, { useRef } from \"react\";\nimport { useControlEffect } from \"@react-typed-forms/core\";\nimport {\n createDataRenderer,\n DataRendererProps,\n rendererClass,\n} from \"@react-typed-forms/schemas\";\n\nexport function createMultilineFieldRenderer(className?: string) {\n return createDataRenderer((p) => (\n <MultilineTextfield\n {...p}\n className={rendererClass(p.className, className)}\n />\n ));\n}\n\nexport function MultilineTextfield({ control, className }: DataRendererProps) {\n const codeRef = useRef<HTMLElement | null>(null);\n useControlEffect(\n () => control.value,\n (v) => {\n const c = codeRef.current;\n if (c && c.textContent !== v) {\n c.textContent = v;\n }\n },\n true,\n );\n return (\n <code\n contentEditable={!control.disabled}\n className={className}\n onInput={(t) => (control.value = t.currentTarget.textContent)}\n ref={codeRef}\n />\n );\n}\n","import {\n createDefaultDisplayRenderer,\n DefaultDisplayRendererOptions,\n} from \"./components/DefaultDisplay\";\nimport {\n DefaultLayout,\n DefaultLayoutRendererOptions,\n} from \"./components/DefaultLayout\";\nimport { createDefaultVisibilityRenderer } from \"./components/DefaultVisibility\";\nimport React, {\n CSSProperties,\n Fragment,\n ReactElement,\n ReactNode,\n useCallback,\n} from \"react\";\nimport clsx from \"clsx\";\nimport {\n createSelectRenderer,\n SelectRendererOptions,\n} from \"./components/SelectDataRenderer\";\nimport { DefaultDisplayOnly } from \"./components/DefaultDisplayOnly\";\nimport { Control, useControlEffect } from \"@react-typed-forms/core\";\nimport { ControlInput, createInputConversion } from \"./components/ControlInput\";\nimport {\n createDefaultArrayDataRenderer,\n createDefaultArrayRenderer,\n DefaultArrayRendererOptions,\n} from \"./components/DefaultArrayRenderer\";\nimport {\n CheckRendererOptions,\n createCheckboxRenderer,\n createCheckListRenderer,\n createRadioRenderer,\n} from \"./components/CheckRenderer\";\nimport { DefaultAccordion } from \"./components/DefaultAccordion\";\nimport { createNullToggleRenderer } from \"./components/NullToggle\";\nimport { createMultilineFieldRenderer } from \"./components/MultilineTextfield\";\nimport { createJsonataRenderer } from \"./components/JsonataRenderer\";\nimport {\n ActionRendererProps,\n ActionRendererRegistration,\n AdornmentPlacement,\n AdornmentRendererRegistration,\n appendMarkupAt,\n ArrayActionOptions,\n ControlDataContext,\n ControlLayoutProps,\n createActionRenderer,\n createDataRenderer,\n createLayoutRenderer,\n DataRendererRegistration,\n DataRenderType,\n DefaultRenderers,\n FieldOption,\n FieldType,\n FlexRenderer,\n GridRenderer,\n GroupRendererProps,\n GroupRendererRegistration,\n hasOptions,\n isAccordionAdornment,\n isDataGroupRenderer,\n isDisplayOnlyRenderer,\n isFlexRenderer,\n isGridRenderer,\n isIconAdornment,\n isSetFieldAdornment,\n isTextfieldRenderer,\n LabelRendererRegistration,\n LabelType,\n rendererClass,\n renderLayoutParts,\n schemaDataForFieldRef,\n SetFieldAdornment,\n useDynamicHooks,\n wrapLayout,\n} from \"@react-typed-forms/schemas\";\n\nexport interface DefaultRendererOptions {\n data?: DefaultDataRendererOptions;\n display?: DefaultDisplayRendererOptions;\n action?: DefaultActionRendererOptions;\n array?: DefaultArrayRendererOptions;\n group?: DefaultGroupRendererOptions;\n label?: DefaultLabelRendererOptions;\n adornment?: DefaultAdornmentRendererOptions;\n layout?: DefaultLayoutRendererOptions;\n}\n\ninterface StyleProps {\n className?: string;\n style?: CSSProperties;\n}\n\nexport interface DefaultActionRendererOptions {\n className?: string;\n renderContent?: (\n actionText: string,\n actionId: string,\n actionData: any,\n ) => ReactNode;\n}\n\nexport function createButtonActionRenderer(\n actionId: string | string[] | undefined,\n options: DefaultActionRendererOptions = {},\n): ActionRendererRegistration {\n return createActionRenderer(\n actionId,\n ({\n onClick,\n actionText,\n className,\n style,\n actionId,\n actionData,\n disabled,\n }: ActionRendererProps) => {\n return (\n <button\n className={rendererClass(className, options.className)}\n disabled={disabled}\n style={style}\n onClick={onClick}\n >\n {options.renderContent?.(actionText, actionId, actionData) ??\n actionText}\n </button>\n );\n },\n );\n}\n\nexport interface DefaultGroupRendererOptions {\n className?: string;\n standardClassName?: string;\n gridStyles?: (columns: GridRenderer) => StyleProps;\n gridClassName?: string;\n defaultGridColumns?: number;\n flexClassName?: string;\n defaultFlexGap?: string;\n}\n\nexport function createDefaultGroupRenderer(\n options?: DefaultGroupRendererOptions,\n): GroupRendererRegistration {\n const {\n className,\n gridStyles = defaultGridStyles,\n defaultGridColumns = 2,\n gridClassName,\n standardClassName,\n flexClassName,\n defaultFlexGap,\n } = options ?? {};\n\n function defaultGridStyles({\n columns = defaultGridColumns,\n }: GridRenderer): StyleProps {\n return {\n className: gridClassName,\n style: {\n display: \"grid\",\n gridTemplateColumns: `repeat(${columns}, 1fr)`,\n },\n };\n }\n\n function flexStyles(options: FlexRenderer): StyleProps {\n return {\n className: flexClassName,\n style: {\n display: \"flex\",\n gap: options.gap ? options.gap : defaultFlexGap,\n flexDirection: options.direction\n ? (options.direction as any)\n : undefined,\n },\n };\n }\n\n function render(props: GroupRendererProps) {\n const { renderChild, renderOptions, childDefinitions } = props;\n\n const { style, className: gcn } = isGridRenderer(renderOptions)\n ? gridStyles(renderOptions)\n : isFlexRenderer(renderOptions)\n ? flexStyles(renderOptions)\n : ({ className: standardClassName } as StyleProps);\n\n return (cp: ControlLayoutProps) => {\n return {\n ...cp,\n children: (\n <div\n className={rendererClass(props.className, clsx(className, gcn))}\n style={style}\n >\n {childDefinitions?.map((c, i) => renderChild(i, c))}\n </div>\n ),\n };\n };\n }\n\n return { type: \"group\", render };\n}\n\nexport const DefaultBoolOptions: FieldOption[] = [\n { name: \"Yes\", value: true },\n { name: \"No\", value: false },\n];\n\nexport interface DefaultDataRendererOptions {\n inputClass?: string;\n displayOnlyClass?: string;\n selectOptions?: SelectRendererOptions;\n checkboxOptions?: CheckRendererOptions;\n checkOptions?: CheckRendererOptions;\n radioOptions?: CheckRendererOptions;\n checkListOptions?: CheckRendererOptions;\n booleanOptions?: FieldOption[];\n optionRenderer?: DataRendererRegistration;\n multilineClass?: string;\n jsonataClass?: string;\n arrayOptions?: ArrayActionOptions;\n}\n\nexport function createDefaultDataRenderer(\n options: DefaultDataRendererOptions = {},\n): DataRendererRegistration {\n const jsonataRenderer = createJsonataRenderer(options.jsonataClass);\n const nullToggler = createNullToggleRenderer();\n const multilineRenderer = createMultilineFieldRenderer(\n options.multilineClass,\n );\n const checkboxRenderer = createCheckboxRenderer(\n options.checkOptions ?? options.checkboxOptions,\n );\n const selectRenderer = createSelectRenderer(options.selectOptions);\n const radioRenderer = createRadioRenderer(\n options.radioOptions ?? options.checkOptions,\n );\n const checkListRenderer = createCheckListRenderer(\n options.checkListOptions ?? options.checkOptions,\n );\n const { inputClass, booleanOptions, optionRenderer, displayOnlyClass } = {\n optionRenderer: selectRenderer,\n booleanOptions: DefaultBoolOptions,\n ...options,\n };\n const arrayRenderer = createDefaultArrayDataRenderer(options.arrayOptions);\n\n return createDataRenderer((props, renderers) => {\n const { field } = props;\n const fieldType = field.type;\n const renderOptions = props.renderOptions;\n let renderType = renderOptions.type;\n if (\n field.collection &&\n props.elementIndex == null &&\n (renderType == DataRenderType.Standard ||\n renderType == DataRenderType.Array)\n ) {\n return arrayRenderer.render(props, renderers);\n }\n if (fieldType === FieldType.Compound) {\n const groupOptions = (isDataGroupRenderer(renderOptions)\n ? renderOptions.groupOptions\n : undefined) ?? { type: \"Standard\", hideTitle: true };\n return renderers.renderGroup({ ...props, renderOptions: groupOptions });\n }\n if (fieldType == FieldType.Any) return <>No control for Any</>;\n if (isDisplayOnlyRenderer(renderOptions))\n return (p) => ({\n ...p,\n className: displayOnlyClass,\n children: (\n <DefaultDisplayOnly\n field={props.field}\n schemaInterface={props.dataContext.schemaInterface}\n control={props.control}\n className={props.className}\n style={props.style}\n emptyText={renderOptions.emptyText}\n />\n ),\n });\n const isBool = fieldType === FieldType.Bool;\n if (booleanOptions != null && isBool && props.options == null) {\n return renderers.renderData({ ...props, options: booleanOptions });\n }\n if (renderType === DataRenderType.Standard && hasOptions(props)) {\n return optionRenderer.render(props, renderers);\n }\n switch (renderType) {\n case DataRenderType.NullToggle:\n return nullToggler.render(props, renderers);\n case DataRenderType.CheckList:\n return checkListRenderer.render(props, renderers);\n case DataRenderType.Dropdown:\n return selectRenderer.render(props, renderers);\n case DataRenderType.Radio:\n return radioRenderer.render(props, renderers);\n case DataRenderType.Checkbox:\n return checkboxRenderer.render(props, renderers);\n case DataRenderType.Jsonata:\n return jsonataRenderer.render(props, renderers);\n }\n if (isTextfieldRenderer(renderOptions) && renderOptions.multiline)\n return multilineRenderer.render(props, renderers);\n const placeholder = isTextfieldRenderer(renderOptions)\n ? renderOptions.placeholder\n : undefined;\n return (\n <ControlInput\n className={rendererClass(props.className, inputClass)}\n style={props.style}\n id={props.id}\n readOnly={props.readonly}\n control={props.control}\n placeholder={placeholder ?? undefined}\n convert={createInputConversion(props.field.type)}\n />\n );\n });\n}\n\nexport interface DefaultAccordionRendererOptions {\n className?: string;\n titleClass?: string;\n togglerClass?: string;\n iconOpenClass?: string;\n iconClosedClass?: string;\n renderTitle?: (\n title: string | undefined,\n current: Control<boolean>,\n ) => ReactNode;\n renderToggler?: (current: Control<boolean>, title: ReactNode) => ReactNode;\n useCss?: boolean;\n}\n\nexport interface DefaultAdornmentRendererOptions {\n accordion?: DefaultAccordionRendererOptions;\n}\n\nexport function createDefaultAdornmentRenderer(\n options: DefaultAdornmentRendererOptions = {},\n): AdornmentRendererRegistration {\n return {\n type: \"adornment\",\n render: ({ adornment, designMode, dataContext, useExpr }, renderers) => ({\n apply: (rl) => {\n if (isSetFieldAdornment(adornment) && useExpr) {\n const hook = useExpr(adornment.expression, (x) => x);\n const dynamicHooks = useDynamicHooks({ value: hook });\n const SetFieldWrapper = useCallback(setFieldWrapper, [dynamicHooks]);\n return wrapLayout((x) => (\n <SetFieldWrapper\n children={x}\n parentContext={dataContext}\n adornment={adornment}\n />\n ))(rl);\n\n function setFieldWrapper({\n children,\n adornment,\n parentContext,\n }: {\n children: ReactNode;\n adornment: SetFieldAdornment;\n parentContext: ControlDataContext;\n }) {\n const { value } = dynamicHooks(parentContext);\n const fieldNode = schemaDataForFieldRef(\n adornment.field,\n parentContext.parentNode,\n );\n const otherField = fieldNode.control;\n const always = !adornment.defaultOnly;\n useControlEffect(\n () => [value?.value, otherField?.value == null],\n ([v]) => {\n otherField?.setValue((x) => (always || x == null ? v : x));\n },\n true,\n );\n return children;\n }\n }\n if (isIconAdornment(adornment)) {\n return appendMarkupAt(\n adornment.placement ?? AdornmentPlacement.ControlStart,\n <i className={adornment.iconClass} />,\n )(rl);\n }\n if (isAccordionAdornment(adornment)) {\n return wrapLayout((x) => (\n <DefaultAccordion\n renderers={renderers}\n children={x}\n accordion={adornment}\n contentStyle={rl.style}\n contentClassName={rl.className}\n designMode={designMode}\n dataContext={dataContext}\n {...options.accordion}\n />\n ))(rl);\n }\n },\n priority: 0,\n adornment,\n }),\n };\n}\n\nfunction createDefaultLayoutRenderer(\n options: DefaultLayoutRendererOptions = {},\n) {\n return createLayoutRenderer((props, renderers) => {\n const layout = renderLayoutParts(\n {\n ...props,\n className: rendererClass(props.className, options.className),\n },\n renderers,\n );\n return {\n children: layout.wrapLayout(\n <DefaultLayout layout={layout} {...options} />,\n ),\n className: layout.className,\n style: layout.style,\n divRef: (e) =>\n e && props.errorControl\n ? (props.errorControl.meta.scrollElement = e)\n : undefined,\n };\n });\n}\n\ninterface DefaultLabelRendererOptions {\n className?: string;\n groupLabelClass?: string;\n controlLabelClass?: string;\n requiredElement?: ReactNode;\n labelContainer?: (children: ReactElement) => ReactElement;\n}\n\nexport function createDefaultLabelRenderer(\n options?: DefaultLabelRendererOptions,\n): LabelRendererRegistration {\n const {\n className,\n groupLabelClass,\n controlLabelClass,\n requiredElement,\n labelContainer,\n } = {\n requiredElement: <span> *</span>,\n labelContainer: (c: ReactElement) => c,\n ...options,\n };\n return {\n render: (props, labelStart, labelEnd, renderers) => {\n if (props.type == LabelType.Text) return props.label;\n return labelContainer(\n <>\n <label\n htmlFor={props.forId}\n className={rendererClass(\n props.className,\n clsx(\n className,\n props.type === LabelType.Group && groupLabelClass,\n props.type === LabelType.Control && controlLabelClass,\n ),\n )}\n >\n {labelStart}\n {renderers.renderLabelText(props.label)}\n {props.required && requiredElement}\n </label>\n {labelEnd}\n </>,\n );\n },\n type: \"label\",\n };\n}\n\nexport function createDefaultRenderers(\n options: DefaultRendererOptions = {},\n): DefaultRenderers {\n return {\n data: createDefaultDataRenderer(options.data),\n display: createDefaultDisplayRenderer(options.display),\n action: createButtonActionRenderer(undefined, options.action),\n array: createDefaultArrayRenderer(options.array),\n group: createDefaultGroupRenderer(options.group),\n label: createDefaultLabelRenderer(options.label),\n adornment: createDefaultAdornmentRenderer(options.adornment),\n renderLayout: createDefaultLayoutRenderer(options.layout),\n visibility: createDefaultVisibilityRenderer(),\n };\n}\n\nexport function createClassStyledRenderers() {\n return createDefaultRenderers({\n layout: { className: \"control\" },\n group: { className: \"group\" },\n array: { className: \"control-array\" },\n action: { className: \"action\" },\n data: { inputClass: \"data\" },\n display: { htmlClassName: \"html\", textClassName: \"text\" },\n });\n}\n","import React from \"react\";\n\nimport { DefaultRendererOptions } from \"./createDefaultRenderers\";\n\nexport const defaultTailwindTheme = {\n label: {\n groupLabelClass: \"font-bold\",\n requiredElement: <span className=\"text-red-500\"> *</span>,\n },\n array: {\n removableClass: \"grid grid-cols-[1fr_auto] items-center gap-x-2\",\n childClass: \"grow my-2\",\n addActionClass: \"my-2\",\n },\n group: {\n standardClassName: \"flex flex-col gap-4\",\n gridClassName: \"gap-x-2 gap-y-4\",\n flexClassName: \"gap-2\",\n },\n action: {\n className: \"bg-primary-500 rounded-lg p-3 text-white\",\n },\n layout: {\n className: \"flex flex-col\",\n errorClass: \"text-sm text-danger-500\",\n },\n data: {\n displayOnlyClass: \"flex flex-row items-center gap-2\",\n checkOptions: {\n className: \"flex items-center gap-4\",\n entryClass: \"flex gap-1 items-center\",\n },\n selectOptions: { emptyText: \"<select>\" },\n multilineClass: \"border p-2 outline-0 whitespace-pre\",\n },\n adornment: {\n accordion: {\n className: \"flex items-center gap-2 my-2\",\n titleClass: \"cursor-pointer\",\n iconOpenClass: \"fa fa-chevron-up\",\n iconClosedClass: \"fa fa-chevron-down\",\n },\n },\n} satisfies DefaultRendererOptions;\n"],"names":["_excluded","createDefaultDisplayRenderer","options","render","props","React","createElement","DefaultDisplay","_extends","type","_ref","_effect","_useComponentTracking","useComponentTracking","data","display","className","style","_objectWithoutPropertiesLoose","DisplayDataType","Icon","clsx","getOverrideClass","value","iconClass","Text","rendererClass","textClassName","coerceToString","text","Html","htmlClassName","dangerouslySetInnerHTML","__html","html","Custom","customId","_excluded2","ControlInput","toText","convert","control","_formControlProps","formControlProps","inputProps","textValue","useControl","useControlEffect","v","onChange","e","target","converted","undefined","createInputConversion","ft","FieldType","String","a","Bool","_a$toString","toString","Int","parseInt","DateTime","Date","Time","l","length","substring","Double","parseFloat","createSelectRenderer","createDataRenderer","asArray","_props$options","SelectDataRenderer","state","id","readonly","required","emptyText","requiredText","createSelectConversion","field","renderOption","x","i","key","disabled","name","_ref$emptyText","_ref$requiredText","showEmpty","useState","optionStringMap","useMemo","Object","fromEntries","map","optionGroups","Set","filter","group","concat","keys","label","o","createRadioRenderer","p","CheckButtons","isChecked","setChecked","c","entryAdornment","fieldOptionAdornment","renderType","DataRenderType","Radio","createCheckListRenderer","Array","isArray","includes","checked","setValue","setIncluded","collection","CheckList","labelClass","checkClass","entryClass","uniqueId","RenderArrayElements","array","useComputed","Fragment","readOnly","htmlFor","elem","included","createCheckboxRenderer","renderer","children","Fcheckbox","renderLabel","Checkbox","DefaultLayout","errorClass","_ref$renderError","renderError","_ref$layout","layout","controlEnd","errorControl","controlStart","touched","error","DefaultDisplayOnly","_ref2","schemaInterface","isEmptyValue","DefaultAccordion","_dataContext$dataNode","accordion","contentStyle","contentClassName","designMode","iconOpenClass","iconClosedClass","_ref$renderTitle","renderTitle","t","renderToggler","renderers","titleClass","useCss","dataContext","dataControl","dataNode","parentNode","open","defaultExpanded","meta","accordionState","isOpen","fullContentStyle","title","renderLabelText","toggler","onClick","createDefaultVisibilityRenderer","createVisibilityRenderer","DefaultVisibility","visibility","divRef","useEffect","ex","visible","showing","ref","createJsonataRenderer","JsonataRenderer","renderOptions","Jsonata","sdn","elementIndex","bindings","formData","dataPath","getJsonPath","rendered","useJsonataExpression","expression","getRootDataNode","createNullToggleRenderer","_control$meta","_control$meta$_nullCo","nullControl","newControl","current","newLayout","renderData","NullWrapper","defaultValue","definition","r","_nullControl$meta$non","createDefaultArrayDataRenderer","defaultActions","DataArrayRenderer","dataProps","_definition$children","renderChild","useChildVisibility","_mergeObjects","mergeObjects","isArrayRenderer","addText","noAdd","noRemove","removeText","childOptions","renderAsElement","isCompoundField","childDefinition","ControlDefinitionType","Data","Standard","hideTitle","Group","groupOptions","GroupRenderType","visibilities","deps","makeHookDepString","Entry","useTrackedComponent","RenderEntry","arrayProps","createArrayActions","renderElement","wrap","index","renderChildElement","getLengthRestrictions","renderArray","elementNode","_control$elements$i$u","_control$elements","elements","parentDataNode","getChildElement","childVis","_ref3","hook","def","runHook","lookupDataNode","some","createDefaultArrayRenderer","_ref4","DefaultArrayRenderer","renderAction","removableClass","childClass","removableChildClass","removeActionClass","addActionClass","arrayControl","_applyArrayLengthRest","applyArrayLengthRestrictions","addAction","removeAction","RenderElements","_","MultilineTextfield","codeRef","useRef","textContent","contentEditable","onInput","currentTarget","createButtonActionRenderer","actionId","createActionRenderer","_options$renderConten","actionText","actionData","renderContent","createDefaultGroupRenderer","_ref2$gridStyles","gridStyles","defaultGridStyles","_ref3$columns","columns","gridClassName","gridTemplateColumns","defaultGridColumns","_ref2$defaultGridColu","standardClassName","flexClassName","defaultFlexGap","childDefinitions","isGridRenderer","isFlexRenderer","gap","flexDirection","direction","flexStyles","gcn","cp","DefaultBoolOptions","createDefaultDataRenderer","_options$checkOptions","_options$radioOptions","_options$checkListOpt","jsonataRenderer","jsonataClass","nullToggler","multilineRenderer","multilineClass","checkboxRenderer","checkOptions","checkboxOptions","selectRenderer","selectOptions","radioRenderer","radioOptions","checkListRenderer","checkListOptions","_optionRenderer$boole","optionRenderer","booleanOptions","inputClass","displayOnlyClass","arrayRenderer","arrayOptions","fieldType","Compound","_ref5","isDataGroupRenderer","renderGroup","Any","isDisplayOnlyRenderer","hasOptions","NullToggle","Dropdown","isTextfieldRenderer","multiline","placeholder","createDefaultAdornmentRenderer","_ref6","adornment","useExpr","apply","rl","isSetFieldAdornment","dynamicHooks","useDynamicHooks","SetFieldWrapper","useCallback","_ref7","parentContext","otherField","schemaDataForFieldRef","always","defaultOnly","_ref8","wrapLayout","_adornment$placement","isIconAdornment","appendMarkupAt","placement","AdornmentPlacement","ControlStart","isAccordionAdornment","priority","createDefaultLayoutRenderer","createLayoutRenderer","renderLayoutParts","scrollElement","createDefaultLabelRenderer","_requiredElement$labe","requiredElement","labelContainer","groupLabelClass","controlLabelClass","labelStart","labelEnd","LabelType","forId","Control","createDefaultRenderers","action","renderLayout","defaultTailwindTheme"],"mappings":"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"}
|
package/lib/index.d.ts
CHANGED
|
@@ -4,6 +4,7 @@ export * from "./components/SelectDataRenderer";
|
|
|
4
4
|
export * from "./components/CheckRenderer";
|
|
5
5
|
export * from "./components/DefaultLayout";
|
|
6
6
|
export * from "./components/DefaultDisplayOnly";
|
|
7
|
+
export * from "./components/DefaultAccordion";
|
|
7
8
|
export * from "./components/DefaultVisibility";
|
|
8
9
|
export * from "./components/JsonataRenderer";
|
|
9
10
|
export * from "./components/NullToggle";
|
package/lib/index.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import e,{useState as t,useMemo as n,useEffect as l,useRef as a,useCallback as r}from"react";import s from"clsx";import{DisplayDataType as o,rendererClass as c,coerceToString as i,getOverrideClass as d,FieldType as u,createDataRenderer as m,fieldOptionAdornment as p,DataRenderType as y,createVisibilityRenderer as v,getJsonPath as f,useJsonataExpression as N,getRootDataNode as C,mergeObjects as h,isArrayRenderer as x,isCompoundField as E,makeHookDepString as g,createArrayActions as b,getLengthRestrictions as T,lookupDataNode as O,applyArrayLengthRestrictions as k,ControlDefinitionType as A,GroupRenderType as w,createActionRenderer as I,isDataGroupRenderer as S,isDisplayOnlyRenderer as q,hasOptions as D,isTextfieldRenderer as L,isSetFieldAdornment as V,useDynamicHooks as F,wrapLayout as R,schemaDataForFieldRef as M,isIconAdornment as _,appendMarkupAt as G,AdornmentPlacement as P,isAccordionAdornment as j,LabelType as H,isGridRenderer as B,isFlexRenderer as J,createLayoutRenderer as U,renderLayoutParts as Y}from"@react-typed-forms/schemas";import{useComponentTracking as $,formControlProps as z,useControl as K,useControlEffect as Q,RenderArrayElements as W,useComputed as X,Fcheckbox as Z,newControl as ee,useTrackedComponent as te,RenderElements as ne}from"@react-typed-forms/core";function le(){return le=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var l in n)({}).hasOwnProperty.call(n,l)&&(e[l]=n[l])}return e},le.apply(null,arguments)}function ae(e,t){if(null==e)return{};var n={};for(var l in e)if({}.hasOwnProperty.call(e,l)){if(t.includes(l))continue;n[l]=e[l]}return n}const re=["data","display","className","style"];function se(t={}){return{render:n=>/*#__PURE__*/e.createElement(oe,le({},t,n)),type:"display"}}function oe(t){var n=$();try{let{data:n,display:l,className:a,style:r}=t,u=ae(t,re);switch(n.type){case o.Icon:/*#__PURE__*/return e.createElement("i",{style:r,className:s(d(a),l?l.value:n.iconClass)});case o.Text:/*#__PURE__*/return e.createElement("div",{style:r,className:c(a,u.textClassName)},l?i(l.value):n.text);case o.Html:/*#__PURE__*/return e.createElement("div",{style:r,className:c(a,u.htmlClassName),dangerouslySetInnerHTML:{__html:l?i(l.value):n.html}});case o.Custom:/*#__PURE__*/return e.createElement("div",null,"Custom display placeholder: ",n.customId);default:/*#__PURE__*/return e.createElement("h1",null,"Unknown display type: ",n.type)}}finally{n()}}const ce=["control","convert"],ie=["errorText","value","onChange"];function de(t){var n=$();try{let{control:l,convert:a}=t,r=ae(t,ce);const s=z(l),{value:o}=s,c=ae(s,ie),i=K(()=>d(o));return Q(()=>l.value,e=>i.value=d(e)),/*#__PURE__*/e.createElement("input",le({},c,{type:a[0],value:i.value,onChange:e=>{i.value=e.target.value;const t=a[1](e.target.value);void 0!==t&&(l.value=t)}},r));function d(e){return null==e?"":a[2](e)}}finally{n()}}function ue(e){switch(e){case u.String:return["text",e=>e,e=>e];case u.Bool:return["text",e=>"true"===e||"false"!==e&&void 0,e=>{var t;return null!=(t=null==e?void 0:e.toString())?t:""}];case u.Int:return["number",e=>""!==e?parseInt(e):null,e=>null==e?"":e];case u.DateTime:return["datetime-local",e=>e||null,e=>e];case u.Date:return["date",e=>e||null,e=>e];case u.Time:return["time",e=>{const t=e.length;return 5===t?e+":00":8===t?e:void 0},e=>e?e.substring(0,5):""];case u.Double:return["number",e=>""!==e?parseFloat(e):null,e=>null==e?"":e];default:return["text",e=>e,e=>e]}}const me=["state","options","className","convert","required","emptyText","requiredText","readonly"];function pe(t={}){return m((n,l)=>{var a;/*#__PURE__*/return e.createElement(ye,{className:c(n.className,t.className),state:n.control,id:n.id,readonly:n.readonly,options:null!=(a=n.options)?a:[],required:n.required,emptyText:t.emptyText,requiredText:t.requiredText,convert:ve(n.field.type)})},{options:!0})}function ye(l){var a=$();try{let{state:r,options:s,className:o,convert:c,required:i,emptyText:d="N/A",requiredText:u="<please select>",readonly:m}=l,p=ae(l,me);const{value:y,disabled:v}=r,[f]=t(!i||null==y),N=n(()=>Object.fromEntries(s.map(e=>[c(e.value),e.value])),[s]),C=n(()=>new Set(s.filter(e=>e.group).map(e=>e.group)),[s]);/*#__PURE__*/return e.createElement("select",le({},p,{className:o,onChange:e=>r.value=N[e.target.value],value:c(y),disabled:v||m}),f&&/*#__PURE__*/e.createElement("option",{value:""},i?u:d),[...C.keys()].map(t=>/*#__PURE__*/e.createElement("optgroup",{key:t,label:t},s.filter(e=>e.group===t).map(h))),s.filter(e=>!e.group).map(h));function h(t,n){/*#__PURE__*/return e.createElement("option",{key:n,value:c(t.value),disabled:!!t.disabled},t.name)}}finally{a()}}function ve(e){switch(e){case u.String:case u.Int:case u.Double:return e=>e;default:return e=>{var t;return null!=(t=null==e?void 0:e.toString())?t:""}}}function fe(t={}){return m(n=>/*#__PURE__*/e.createElement(Ce,le({},t,n,{className:c(n.className,t.className),isChecked:(e,t)=>e.value==t.value,setChecked:(e,t)=>e.value=t.value,control:n.control,type:"radio",entryAdornment:p(n)})),{renderType:y.Radio})}function Ne(t={}){return m(n=>/*#__PURE__*/e.createElement(Ce,le({},t,n,{className:c(n.className,t.className),isChecked:(e,t)=>{const n=e.value;return!!Array.isArray(n)&&n.includes(t.value)},setChecked:(e,t,n)=>{e.setValue(e=>he(null!=e?e:[],t.value,n))},control:n.control,type:"checkbox",entryAdornment:p(n)})),{collection:!0,renderType:y.CheckList})}function Ce({control:t,options:n,labelClass:l,checkClass:a,readonly:r,entryClass:s,className:o,id:c,type:i,isChecked:d,setChecked:u,entryAdornment:m}){var p=$();try{const{disabled:p}=t,y="r"+t.uniqueId;/*#__PURE__*/return e.createElement("div",{className:o,id:c},/*#__PURE__*/e.createElement(W,{array:null==n?void 0:n.filter(e=>null!=e.value)},(n,o)=>{const c=X(()=>d(t,n)).value;/*#__PURE__*/return e.createElement(e.Fragment,null,/*#__PURE__*/e.createElement("div",{key:o,className:s},/*#__PURE__*/e.createElement("input",{id:y+"_"+o,className:a,type:i,name:y,readOnly:r,disabled:p,checked:c,onChange:e=>{!r&&u(t,n,e.target.checked)}}),/*#__PURE__*/e.createElement("label",{className:l,htmlFor:y+"_"+o},n.name)),null==m?void 0:m(n,o,c))}))}finally{p()}}function he(e,t,n){return n===e.includes(t)?e:n?[...e,t]:e.filter(e=>e!==t)}function xe(t={}){return m((n,l)=>a=>le({},a,{label:void 0,children:/*#__PURE__*/e.createElement("div",{className:c(n.className,t.entryClass)},/*#__PURE__*/e.createElement(Z,{id:n.id,control:n.control,style:n.style,className:t.checkClass}),a.label&&l.renderLabel(a.label,void 0,void 0))}),{renderType:y.Checkbox})}function Ee({errorClass:t,renderError:n=n=>n&&/*#__PURE__*/e.createElement("div",{className:t},n),layout:{controlEnd:l,controlStart:a,label:r,children:s,errorControl:o}}){var c=$();try{/*#__PURE__*/return e.createElement(e.Fragment,null,r,a,s,n(o&&o.touched?o.error:void 0),l)}finally{c()}}function ge({control:t,className:n,emptyText:l,schemaInterface:a,field:r,style:s}){var o=$();try{var i;const o=t.value,d=null!=(i=a.isEmptyValue(r,o)?l:a.textValue(r,o))?i:"";/*#__PURE__*/return e.createElement("div",{style:s,className:c(n)},d)}finally{o()}}function be(){return v(t=>/*#__PURE__*/e.createElement(Te,t))}function Te({visibility:t,children:n,className:a,style:r,divRef:o}){var c=$();try{const c=t.value;return l(()=>{c&&t.setValue(e=>({visible:c.visible,showing:c.visible}))},[null==c?void 0:c.visible]),null!=c&&c.visible?/*#__PURE__*/e.createElement("div",{className:s(a),style:r,ref:o},n):/*#__PURE__*/e.createElement(e.Fragment,null)}finally{c()}}function Oe(t){return m(n=>/*#__PURE__*/e.createElement(ke,{renderOptions:n.renderOptions,className:c(n.className,t),dataNode:n.dataNode,dataContext:n.dataContext,control:n.control,readonly:n.readonly}),{renderType:y.Jsonata})}function ke({control:t,renderOptions:n,readonly:l,className:a,dataContext:r,dataNode:s}){var o=$();try{const o=null!=s.elementIndex?s:r.parentNode,c=X(()=>({value:t.value,readonly:l,disabled:t.disabled,formData:r.formData,dataPath:f(s)})),d=N(n.expression,C(o).control,f(o),c,i);/*#__PURE__*/return e.createElement("div",{className:a,dangerouslySetInnerHTML:{__html:d.value}})}finally{o()}}const Ae=["control","field","renderOptions"];function we(){return m((t,n)=>{var l,a;let{control:r,field:s}=t,o=ae(t,Ae);const c=null!=(a=(l=r.meta).nullControl)?a:l.nullControl=ee(null!=r.current.value);return t=>{const l=n.renderData(le({},o,{control:c,field:le({},s,{type:u.Bool}),renderOptions:{type:y.Checkbox}}))(t);return le({},l,{children:/*#__PURE__*/e.createElement(Ie,{control:r,nullControl:c,children:l.children,readonly:o.readonly,defaultValue:o.definition.defaultValue})})}})}function Ie({children:e,nullControl:t,control:n,defaultValue:l,readonly:a}){return Q(()=>a,e=>t.disabled=e,!0),Q(()=>t.value,e=>{var a;e?n.value=null!=(a=t.meta.nonNullValue)?a:l:(t.meta.nonNullValue=n.value,n.value=null)}),e}function Se(t){return m((n,l)=>/*#__PURE__*/e.createElement(qe,{dataProps:n,renderers:l,defaultActions:t}),{renderType:y.Array,collection:!0})}function qe({dataProps:t,renderers:n,defaultActions:l}){var a;const{renderOptions:r,control:s,field:o,readonly:c,designMode:i,required:d,renderChild:u,definition:m,className:p,style:v,useChildVisibility:f,dataContext:N}=t,{addText:C,noAdd:O,noRemove:k,removeText:I}=h(x(r)?r:{},l),S=x(r)?r.childOptions:void 0,q=!E(o),D=q?{type:A.Data,field:m.field,children:m.children,renderOptions:null!=S?S:{type:y.Standard},hideTitle:!0}:{type:A.Group,children:m.children,groupOptions:{type:w.Standard,hideTitle:!0}},L=(null!=(a=m.children)?a:[]).map(e=>[f(e,void 0,!0),e]),V=g(L,e=>e[0].deps),F=te(De,[V]),R=le({},b(s,o,{addText:C,removeText:I,noAdd:O,noRemove:k,readonly:c,disabled:s.disabled,designMode:i}),{required:d,renderElement:(t,n)=>/*#__PURE__*/e.createElement(F,{index:t,renderChildElement:M,dataContext:N,visibilities:L,wrap:n}),className:p||void 0,style:v},T(m));return n.renderArray(R);function M(e,t){var n,l;return u(null!=(n=null==(l=s.elements)?void 0:l[e].uniqueId)?n:e,D,q?{elementIndex:e}:{parentDataNode:t})}}function De({index:e,renderChildElement:t,visibilities:n,wrap:l,dataContext:a}){const r=a.dataNode.getChildElement(e),s=n.map(([e,t])=>e.runHook(le({},a,{parentNode:r,dataNode:O(t,r)}),e.state).value);if(0==s.length||s.some(e=>!0===e))return l(t(e,r))}function Le(t){return{render:(n,{renderAction:l})=>/*#__PURE__*/e.createElement(Ve,le({},n,t,{renderAction:l})),type:"array"}}function Ve(t){var n=$();try{const{renderElement:n,className:l,removableClass:a,childClass:r,removableChildClass:o,removeActionClass:c,addActionClass:i,arrayControl:d,renderAction:u,style:m}=t,{addAction:p,removeAction:y}=k(t);/*#__PURE__*/return e.createElement("div",{style:m},/*#__PURE__*/e.createElement("div",{className:s(l,y&&a)},/*#__PURE__*/e.createElement(ne,{control:d},(t,l)=>n(l,t=>y?/*#__PURE__*/e.createElement(e.Fragment,null,/*#__PURE__*/e.createElement("div",{className:s(r,o)},t),/*#__PURE__*/e.createElement("div",{className:c},u(y(l)))):/*#__PURE__*/e.createElement("div",{className:r},t)))),p&&/*#__PURE__*/e.createElement("div",{className:i},u(p)))}finally{n()}}function Fe({children:t,accordion:n,contentStyle:l,contentClassName:a,designMode:r,iconOpenClass:o,iconClosedClass:c,className:i,renderTitle:d=e=>e,renderToggler:u,renderers:m,titleClass:p}){var y=$();try{const y=K(!!n.defaultExpanded),v=y.value,f=v||r?l:le({},l,{display:"none"}),N=m.renderLabelText(d(n.title,y)),C=u?u(y,N):/*#__PURE__*/e.createElement("button",{className:i,onClick:()=>y.setValue(e=>!e)},/*#__PURE__*/e.createElement("label",{className:p},N),/*#__PURE__*/e.createElement("i",{className:s(v?o:c)}));/*#__PURE__*/return e.createElement(e.Fragment,null,C,/*#__PURE__*/e.createElement("div",{style:f,className:a},t))}finally{y()}}function Re({control:t,className:n}){var l=$();try{const l=a(null);return Q(()=>t.value,e=>{const t=l.current;t&&t.textContent!==e&&(t.textContent=e)},!0),/*#__PURE__*/e.createElement("code",{contentEditable:!t.disabled,className:n,onInput:e=>t.value=e.currentTarget.textContent,ref:l})}finally{l()}}function Me(t,n={}){return I(t,({onClick:t,actionText:l,className:a,style:r,actionId:s,actionData:o,disabled:i})=>{var d;/*#__PURE__*/return e.createElement("button",{className:c(a,n.className),disabled:i,style:r,onClick:t},null!=(d=null==n.renderContent?void 0:n.renderContent(l,s,o))?d:l)})}function _e(t){const{className:n,gridStyles:l=u,defaultGridColumns:a=2,gridClassName:r,standardClassName:o,flexClassName:i,defaultFlexGap:d}=null!=t?t:{};function u({columns:e=a}){return{className:r,style:{display:"grid",gridTemplateColumns:`repeat(${e}, 1fr)`}}}return{type:"group",render:function(t){const{renderChild:a,renderOptions:r,childDefinitions:u}=t,{style:m,className:p}=B(r)?l(r):J(r)?function(e){return{className:i,style:{display:"flex",gap:e.gap?e.gap:d,flexDirection:e.direction?e.direction:void 0}}}(r):{className:o};return l=>le({},l,{children:/*#__PURE__*/e.createElement("div",{className:c(t.className,s(n,p)),style:m},null==u?void 0:u.map((e,t)=>a(t,e)))})}}}const Ge=[{name:"Yes",value:!0},{name:"No",value:!1}];function Pe(t={}){var n,l,a;const r=Oe(t.jsonataClass),s=we(),o=(i=t.multilineClass,m(t=>/*#__PURE__*/e.createElement(Re,le({},t,{className:c(t.className,i)}))));var i;const d=xe(null!=(n=t.checkOptions)?n:t.checkboxOptions),p=pe(t.selectOptions),v=fe(null!=(l=t.radioOptions)?l:t.checkOptions),f=Ne(null!=(a=t.checkListOptions)?a:t.checkOptions),{inputClass:N,booleanOptions:C,optionRenderer:h,displayOnlyClass:x}=le({optionRenderer:p,booleanOptions:Ge},t),E=Se(t.arrayOptions);return m((t,n)=>{const{field:l}=t,a=l.type,i=t.renderOptions;let m=i.type;if(l.collection&&null==t.elementIndex&&(m==y.Standard||m==y.Array))return E.render(t,n);if(a===u.Compound){var g;const e=null!=(g=S(i)?i.groupOptions:void 0)?g:{type:"Standard",hideTitle:!0};return n.renderGroup(le({},t,{renderOptions:e}))}if(a==u.Any)/*#__PURE__*/return e.createElement(e.Fragment,null,"No control for Any");if(q(i))return n=>le({},n,{className:x,children:/*#__PURE__*/e.createElement(ge,{field:t.field,schemaInterface:t.dataContext.schemaInterface,control:t.control,className:t.className,style:t.style,emptyText:i.emptyText})});if(null!=C&&a===u.Bool&&null==t.options)return n.renderData(le({},t,{options:C}));if(m===y.Standard&&D(t))return h.render(t,n);switch(m){case y.NullToggle:return s.render(t,n);case y.CheckList:return f.render(t,n);case y.Dropdown:return p.render(t,n);case y.Radio:return v.render(t,n);case y.Checkbox:return d.render(t,n);case y.Jsonata:return r.render(t,n)}if(L(i)&&i.multiline)return o.render(t,n);const b=L(i)?i.placeholder:void 0;/*#__PURE__*/return e.createElement(de,{className:c(t.className,N),style:t.style,id:t.id,readOnly:t.readonly,control:t.control,placeholder:null!=b?b:void 0,convert:ue(t.field.type)})})}function je(t={}){return{type:"adornment",render:({adornment:n,designMode:l,dataContext:a,useExpr:s},o)=>({apply:c=>{if(V(n)&&s){const d=s(n.expression,e=>e),u=F({value:d}),m=r(p,[u]);return R(t=>/*#__PURE__*/e.createElement(m,{children:t,parentContext:a,adornment:n}))(c);function p({children:e,adornment:t,parentContext:n}){const{value:l}=u(n),a=M(t.field,n.parentNode).control,r=!t.defaultOnly;return Q(()=>[null==l?void 0:l.value,null==(null==a?void 0:a.value)],([e])=>{null==a||a.setValue(t=>r||null==t?e:t)},!0),e}}var i;return _(n)?G(null!=(i=n.placement)?i:P.ControlStart,/*#__PURE__*/e.createElement("i",{className:n.iconClass}))(c):j(n)?R(a=>/*#__PURE__*/e.createElement(Fe,le({renderers:o,children:a,accordion:n,contentStyle:c.style,contentClassName:c.className,designMode:l},t.accordion)))(c):void 0},priority:0,adornment:n})}}function He(t={}){return U((n,l)=>{const a=Y(le({},n,{className:c(n.className,t.className)}),l);return{children:a.wrapLayout(/*#__PURE__*/e.createElement(Ee,le({layout:a},t))),className:a.className,style:a.style,divRef:e=>e&&n.errorControl?n.errorControl.meta.scrollElement=e:void 0}})}function Be(t){const{className:n,groupLabelClass:l,controlLabelClass:a,requiredElement:r,labelContainer:o}=le({requiredElement:/*#__PURE__*/e.createElement("span",null," *"),labelContainer:e=>e},t);return{render:(t,i,d,u)=>t.type==H.Text?t.label:o(/*#__PURE__*/e.createElement(e.Fragment,null,/*#__PURE__*/e.createElement("label",{htmlFor:t.forId,className:c(t.className,s(n,t.type===H.Group&&l,t.type===H.Control&&a))},i,u.renderLabelText(t.label),t.required&&r),d)),type:"label"}}function Je(e={}){return{data:Pe(e.data),display:se(e.display),action:Me(void 0,e.action),array:Le(e.array),group:_e(e.group),label:Be(e.label),adornment:je(e.adornment),renderLayout:He(e.layout),visibility:be()}}function Ue(){return Je({layout:{className:"control"},group:{className:"group"},array:{className:"control-array"},action:{className:"action"},data:{inputClass:"data"},display:{htmlClassName:"html",textClassName:"text"}})}const Ye={label:{groupLabelClass:"font-bold",requiredElement:/*#__PURE__*/e.createElement("span",{className:"text-red-500"}," *")},array:{removableClass:"grid grid-cols-[1fr_auto] items-center gap-x-2",childClass:"grow my-2",addActionClass:"my-2"},group:{standardClassName:"flex flex-col gap-4",gridClassName:"gap-x-2 gap-y-4",flexClassName:"gap-2"},action:{className:"bg-primary-500 rounded-lg p-3 text-white"},layout:{className:"flex flex-col",errorClass:"text-sm text-danger-500"},data:{displayOnlyClass:"flex flex-row items-center gap-2",checkOptions:{className:"flex items-center gap-4",entryClass:"flex gap-1 items-center"},selectOptions:{emptyText:"<select>"},multilineClass:"border p-2 outline-0 whitespace-pre"},adornment:{accordion:{className:"flex items-center gap-2 my-2",titleClass:"cursor-pointer",iconOpenClass:"fa fa-chevron-up",iconClosedClass:"fa fa-chevron-down"}}};export{Ce as CheckButtons,de as ControlInput,qe as DataArrayRenderer,Ve as DefaultArrayRenderer,Ge as DefaultBoolOptions,oe as DefaultDisplay,ge as DefaultDisplayOnly,Ee as DefaultLayout,Te as DefaultVisibility,ke as JsonataRenderer,ye as SelectDataRenderer,Me as createButtonActionRenderer,Ne as createCheckListRenderer,xe as createCheckboxRenderer,Ue as createClassStyledRenderers,je as createDefaultAdornmentRenderer,Se as createDefaultArrayDataRenderer,Le as createDefaultArrayRenderer,Pe as createDefaultDataRenderer,se as createDefaultDisplayRenderer,_e as createDefaultGroupRenderer,Be as createDefaultLabelRenderer,Je as createDefaultRenderers,be as createDefaultVisibilityRenderer,ue as createInputConversion,Oe as createJsonataRenderer,we as createNullToggleRenderer,fe as createRadioRenderer,ve as createSelectConversion,pe as createSelectRenderer,Ye as defaultTailwindTheme,he as setIncluded};
|
|
1
|
+
import e,{useState as t,useMemo as n,useEffect as l,useRef as a,useCallback as r}from"react";import o from"clsx";import{DisplayDataType as s,rendererClass as c,coerceToString as i,getOverrideClass as d,FieldType as u,createDataRenderer as m,fieldOptionAdornment as p,DataRenderType as y,createVisibilityRenderer as v,getJsonPath as f,useJsonataExpression as N,getRootDataNode as C,mergeObjects as h,isArrayRenderer as x,isCompoundField as E,makeHookDepString as g,createArrayActions as b,getLengthRestrictions as T,lookupDataNode as O,applyArrayLengthRestrictions as k,ControlDefinitionType as A,GroupRenderType as S,createActionRenderer as w,isDataGroupRenderer as I,isDisplayOnlyRenderer as q,hasOptions as D,isTextfieldRenderer as L,isSetFieldAdornment as V,useDynamicHooks as F,wrapLayout as R,schemaDataForFieldRef as M,isIconAdornment as _,appendMarkupAt as G,AdornmentPlacement as P,isAccordionAdornment as j,LabelType as H,isGridRenderer as B,isFlexRenderer as J,createLayoutRenderer as U,renderLayoutParts as Y}from"@react-typed-forms/schemas";import{useComponentTracking as $,formControlProps as z,useControl as K,useControlEffect as Q,RenderArrayElements as W,useComputed as X,Fcheckbox as Z,newControl as ee,useTrackedComponent as te,RenderElements as ne}from"@react-typed-forms/core";function le(){return le=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var l in n)({}).hasOwnProperty.call(n,l)&&(e[l]=n[l])}return e},le.apply(null,arguments)}function ae(e,t){if(null==e)return{};var n={};for(var l in e)if({}.hasOwnProperty.call(e,l)){if(t.includes(l))continue;n[l]=e[l]}return n}const re=["data","display","className","style"];function oe(t={}){return{render:n=>/*#__PURE__*/e.createElement(se,le({},t,n)),type:"display"}}function se(t){var n=$();try{let{data:n,display:l,className:a,style:r}=t,u=ae(t,re);switch(n.type){case s.Icon:/*#__PURE__*/return e.createElement("i",{style:r,className:o(d(a),l?l.value:n.iconClass)});case s.Text:/*#__PURE__*/return e.createElement("div",{style:r,className:c(a,u.textClassName)},l?i(l.value):n.text);case s.Html:/*#__PURE__*/return e.createElement("div",{style:r,className:c(a,u.htmlClassName),dangerouslySetInnerHTML:{__html:l?i(l.value):n.html}});case s.Custom:/*#__PURE__*/return e.createElement("div",null,"Custom display placeholder: ",n.customId);default:/*#__PURE__*/return e.createElement("h1",null,"Unknown display type: ",n.type)}}finally{n()}}const ce=["control","convert"],ie=["errorText","value","onChange"];function de(t){var n=$();try{let{control:l,convert:a}=t,r=ae(t,ce);const o=z(l),{value:s}=o,c=ae(o,ie),i=K(()=>d(s));return Q(()=>l.value,e=>i.value=d(e)),/*#__PURE__*/e.createElement("input",le({},c,{type:a[0],value:i.value,onChange:e=>{i.value=e.target.value;const t=a[1](e.target.value);void 0!==t&&(l.value=t)}},r));function d(e){return null==e?"":a[2](e)}}finally{n()}}function ue(e){switch(e){case u.String:return["text",e=>e,e=>e];case u.Bool:return["text",e=>"true"===e||"false"!==e&&void 0,e=>{var t;return null!=(t=null==e?void 0:e.toString())?t:""}];case u.Int:return["number",e=>""!==e?parseInt(e):null,e=>null==e?"":e];case u.DateTime:return["datetime-local",e=>e||null,e=>e];case u.Date:return["date",e=>e||null,e=>e];case u.Time:return["time",e=>{const t=e.length;return 5===t?e+":00":8===t?e:void 0},e=>e?e.substring(0,5):""];case u.Double:return["number",e=>""!==e?parseFloat(e):null,e=>null==e?"":e];default:return["text",e=>e,e=>e]}}const me=["state","options","className","convert","required","emptyText","requiredText","readonly"];function pe(t={}){return m((n,l)=>{var a;/*#__PURE__*/return e.createElement(ye,{className:c(n.className,t.className),state:n.control,id:n.id,readonly:n.readonly,options:null!=(a=n.options)?a:[],required:n.required,emptyText:t.emptyText,requiredText:t.requiredText,convert:ve(n.field.type)})},{options:!0})}function ye(l){var a=$();try{let{state:r,options:o,className:s,convert:c,required:i,emptyText:d="N/A",requiredText:u="<please select>",readonly:m}=l,p=ae(l,me);const{value:y,disabled:v}=r,[f]=t(!i||null==y),N=n(()=>Object.fromEntries(o.map(e=>[c(e.value),e.value])),[o]),C=n(()=>new Set(o.filter(e=>e.group).map(e=>e.group)),[o]);/*#__PURE__*/return e.createElement("select",le({},p,{className:s,onChange:e=>r.value=N[e.target.value],value:c(y),disabled:v||m}),f&&/*#__PURE__*/e.createElement("option",{value:""},i?u:d),[...C.keys()].map(t=>/*#__PURE__*/e.createElement("optgroup",{key:t,label:t},o.filter(e=>e.group===t).map(h))),o.filter(e=>!e.group).map(h));function h(t,n){/*#__PURE__*/return e.createElement("option",{key:n,value:c(t.value),disabled:!!t.disabled},t.name)}}finally{a()}}function ve(e){switch(e){case u.String:case u.Int:case u.Double:return e=>e;default:return e=>{var t;return null!=(t=null==e?void 0:e.toString())?t:""}}}function fe(t={}){return m(n=>/*#__PURE__*/e.createElement(Ce,le({},t,n,{className:c(n.className,t.className),isChecked:(e,t)=>e.value==t.value,setChecked:(e,t)=>e.value=t.value,control:n.control,type:"radio",entryAdornment:p(n)})),{renderType:y.Radio})}function Ne(t={}){return m(n=>/*#__PURE__*/e.createElement(Ce,le({},t,n,{className:c(n.className,t.className),isChecked:(e,t)=>{const n=e.value;return!!Array.isArray(n)&&n.includes(t.value)},setChecked:(e,t,n)=>{e.setValue(e=>he(null!=e?e:[],t.value,n))},control:n.control,type:"checkbox",entryAdornment:p(n)})),{collection:!0,renderType:y.CheckList})}function Ce({control:t,options:n,labelClass:l,checkClass:a,readonly:r,entryClass:o,className:s,id:c,type:i,isChecked:d,setChecked:u,entryAdornment:m}){var p=$();try{const{disabled:p}=t,y="r"+t.uniqueId;/*#__PURE__*/return e.createElement("div",{className:s,id:c},/*#__PURE__*/e.createElement(W,{array:null==n?void 0:n.filter(e=>null!=e.value)},(n,s)=>{const c=X(()=>d(t,n)).value;/*#__PURE__*/return e.createElement(e.Fragment,null,/*#__PURE__*/e.createElement("div",{key:s,className:o},/*#__PURE__*/e.createElement("input",{id:y+"_"+s,className:a,type:i,name:y,readOnly:r,disabled:p,checked:c,onChange:e=>{!r&&u(t,n,e.target.checked)}}),/*#__PURE__*/e.createElement("label",{className:l,htmlFor:y+"_"+s},n.name)),null==m?void 0:m(n,s,c))}))}finally{p()}}function he(e,t,n){return n===e.includes(t)?e:n?[...e,t]:e.filter(e=>e!==t)}function xe(t={}){return m((n,l)=>a=>le({},a,{label:void 0,children:/*#__PURE__*/e.createElement("div",{className:c(n.className,t.entryClass)},/*#__PURE__*/e.createElement(Z,{id:n.id,control:n.control,style:n.style,className:t.checkClass}),a.label&&l.renderLabel(a.label,void 0,void 0))}),{renderType:y.Checkbox})}function Ee({errorClass:t,renderError:n=n=>n&&/*#__PURE__*/e.createElement("div",{className:t},n),layout:{controlEnd:l,controlStart:a,label:r,children:o,errorControl:s}}){var c=$();try{/*#__PURE__*/return e.createElement(e.Fragment,null,r,a,o,n(s&&s.touched?s.error:void 0),l)}finally{c()}}function ge({control:t,className:n,emptyText:l,schemaInterface:a,field:r,style:o}){var s=$();try{var i;const s=t.value,d=null!=(i=a.isEmptyValue(r,s)?l:a.textValue(r,s))?i:"";/*#__PURE__*/return e.createElement("div",{style:o,className:c(n)},d)}finally{s()}}function be({children:t,accordion:n,contentStyle:l,contentClassName:a,designMode:r,iconOpenClass:s,iconClosedClass:c,className:i,renderTitle:d=e=>e,renderToggler:u,renderers:m,titleClass:p,useCss:y,dataContext:v}){var f=$();try{var N;const f=(null!=(N=v.dataNode)?N:v.parentNode).control,C=K(!!n.defaultExpanded);f&&!f.meta.accordionState&&(f.meta.accordionState=C);const h=C.value,x=h||r?l:le({},l,{display:"none"}),E=m.renderLabelText(d(n.title,C)),g=u?u(C,E):/*#__PURE__*/e.createElement("button",{className:i,onClick:()=>C.setValue(e=>!e)},/*#__PURE__*/e.createElement("label",{className:p},E),/*#__PURE__*/e.createElement("i",{className:o(h?s:c)}));/*#__PURE__*/return e.createElement(e.Fragment,null,g,(y||h||r)&&/*#__PURE__*/e.createElement("div",{style:x,className:a},t))}finally{f()}}function Te(e){return e.meta.accordionState}function Oe(){return v(t=>/*#__PURE__*/e.createElement(ke,t))}function ke({visibility:t,children:n,className:a,style:r,divRef:s}){var c=$();try{const c=t.value;return l(()=>{c&&t.setValue(e=>({visible:c.visible,showing:c.visible}))},[null==c?void 0:c.visible]),null!=c&&c.visible?/*#__PURE__*/e.createElement("div",{className:o(a),style:r,ref:s},n):/*#__PURE__*/e.createElement(e.Fragment,null)}finally{c()}}function Ae(t){return m(n=>/*#__PURE__*/e.createElement(Se,{renderOptions:n.renderOptions,className:c(n.className,t),dataNode:n.dataNode,dataContext:n.dataContext,control:n.control,readonly:n.readonly}),{renderType:y.Jsonata})}function Se({control:t,renderOptions:n,readonly:l,className:a,dataContext:r,dataNode:o}){var s=$();try{const s=null!=o.elementIndex?o:r.parentNode,c=X(()=>({value:t.value,readonly:l,disabled:t.disabled,formData:r.formData,dataPath:f(o)})),d=N(n.expression,C(s).control,f(s),c,i);/*#__PURE__*/return e.createElement("div",{className:a,dangerouslySetInnerHTML:{__html:d.value}})}finally{s()}}const we=["control","field","renderOptions"];function Ie(){return m((t,n)=>{var l,a;let{control:r,field:o}=t,s=ae(t,we);const c=null!=(a=(l=r.meta).nullControl)?a:l.nullControl=ee(null!=r.current.value);return t=>{const l=n.renderData(le({},s,{control:c,field:le({},o,{type:u.Bool}),renderOptions:{type:y.Checkbox}}))(t);return le({},l,{children:/*#__PURE__*/e.createElement(qe,{control:r,nullControl:c,children:l.children,readonly:s.readonly,defaultValue:s.definition.defaultValue})})}})}function qe({children:e,nullControl:t,control:n,defaultValue:l,readonly:a}){return Q(()=>a,e=>t.disabled=e,!0),Q(()=>t.value,e=>{var a;e?n.value=null!=(a=t.meta.nonNullValue)?a:l:(t.meta.nonNullValue=n.value,n.value=null)}),e}function De(t){return m((n,l)=>/*#__PURE__*/e.createElement(Le,{dataProps:n,renderers:l,defaultActions:t}),{renderType:y.Array,collection:!0})}function Le({dataProps:t,renderers:n,defaultActions:l}){var a;const{renderOptions:r,control:o,field:s,readonly:c,designMode:i,required:d,renderChild:u,definition:m,className:p,style:v,useChildVisibility:f,dataContext:N}=t,{addText:C,noAdd:O,noRemove:k,removeText:w}=h(x(r)?r:{},l),I=x(r)?r.childOptions:void 0,q=!E(s),D=q?{type:A.Data,field:m.field,children:m.children,renderOptions:null!=I?I:{type:y.Standard},hideTitle:!0}:{type:A.Group,children:m.children,groupOptions:{type:S.Standard,hideTitle:!0}},L=(null!=(a=m.children)?a:[]).map(e=>[f(e,void 0,!0),e]),V=g(L,e=>e[0].deps),F=te(Ve,[V]),R=le({},b(o,s,{addText:C,removeText:w,noAdd:O,noRemove:k,readonly:c,disabled:o.disabled,designMode:i}),{required:d,renderElement:(t,n)=>/*#__PURE__*/e.createElement(F,{index:t,renderChildElement:M,dataContext:N,visibilities:L,wrap:n}),className:p||void 0,style:v},T(m));return n.renderArray(R);function M(e,t){var n,l;return u(null!=(n=null==(l=o.elements)?void 0:l[e].uniqueId)?n:e,D,q?{elementIndex:e}:{parentDataNode:t})}}function Ve({index:e,renderChildElement:t,visibilities:n,wrap:l,dataContext:a}){const r=a.dataNode.getChildElement(e),o=n.map(([e,t])=>e.runHook(le({},a,{parentNode:r,dataNode:O(t,r)}),e.state).value);if(0==o.length||o.some(e=>!0===e))return l(t(e,r))}function Fe(t){return{render:(n,{renderAction:l})=>/*#__PURE__*/e.createElement(Re,le({},n,t,{renderAction:l})),type:"array"}}function Re(t){var n=$();try{const{renderElement:n,className:l,removableClass:a,childClass:r,removableChildClass:s,removeActionClass:c,addActionClass:i,arrayControl:d,renderAction:u,style:m}=t,{addAction:p,removeAction:y}=k(t);/*#__PURE__*/return e.createElement("div",{style:m},/*#__PURE__*/e.createElement("div",{className:o(l,y&&a)},/*#__PURE__*/e.createElement(ne,{control:d},(t,l)=>n(l,t=>y?/*#__PURE__*/e.createElement(e.Fragment,null,/*#__PURE__*/e.createElement("div",{className:o(r,s)},t),/*#__PURE__*/e.createElement("div",{className:c},u(y(l)))):/*#__PURE__*/e.createElement("div",{className:r},t)))),p&&/*#__PURE__*/e.createElement("div",{className:i},u(p)))}finally{n()}}function Me({control:t,className:n}){var l=$();try{const l=a(null);return Q(()=>t.value,e=>{const t=l.current;t&&t.textContent!==e&&(t.textContent=e)},!0),/*#__PURE__*/e.createElement("code",{contentEditable:!t.disabled,className:n,onInput:e=>t.value=e.currentTarget.textContent,ref:l})}finally{l()}}function _e(t,n={}){return w(t,({onClick:t,actionText:l,className:a,style:r,actionId:o,actionData:s,disabled:i})=>{var d;/*#__PURE__*/return e.createElement("button",{className:c(a,n.className),disabled:i,style:r,onClick:t},null!=(d=null==n.renderContent?void 0:n.renderContent(l,o,s))?d:l)})}function Ge(t){const{className:n,gridStyles:l=u,defaultGridColumns:a=2,gridClassName:r,standardClassName:s,flexClassName:i,defaultFlexGap:d}=null!=t?t:{};function u({columns:e=a}){return{className:r,style:{display:"grid",gridTemplateColumns:`repeat(${e}, 1fr)`}}}return{type:"group",render:function(t){const{renderChild:a,renderOptions:r,childDefinitions:u}=t,{style:m,className:p}=B(r)?l(r):J(r)?function(e){return{className:i,style:{display:"flex",gap:e.gap?e.gap:d,flexDirection:e.direction?e.direction:void 0}}}(r):{className:s};return l=>le({},l,{children:/*#__PURE__*/e.createElement("div",{className:c(t.className,o(n,p)),style:m},null==u?void 0:u.map((e,t)=>a(t,e)))})}}}const Pe=[{name:"Yes",value:!0},{name:"No",value:!1}];function je(t={}){var n,l,a;const r=Ae(t.jsonataClass),o=Ie(),s=(i=t.multilineClass,m(t=>/*#__PURE__*/e.createElement(Me,le({},t,{className:c(t.className,i)}))));var i;const d=xe(null!=(n=t.checkOptions)?n:t.checkboxOptions),p=pe(t.selectOptions),v=fe(null!=(l=t.radioOptions)?l:t.checkOptions),f=Ne(null!=(a=t.checkListOptions)?a:t.checkOptions),{inputClass:N,booleanOptions:C,optionRenderer:h,displayOnlyClass:x}=le({optionRenderer:p,booleanOptions:Pe},t),E=De(t.arrayOptions);return m((t,n)=>{const{field:l}=t,a=l.type,i=t.renderOptions;let m=i.type;if(l.collection&&null==t.elementIndex&&(m==y.Standard||m==y.Array))return E.render(t,n);if(a===u.Compound){var g;const e=null!=(g=I(i)?i.groupOptions:void 0)?g:{type:"Standard",hideTitle:!0};return n.renderGroup(le({},t,{renderOptions:e}))}if(a==u.Any)/*#__PURE__*/return e.createElement(e.Fragment,null,"No control for Any");if(q(i))return n=>le({},n,{className:x,children:/*#__PURE__*/e.createElement(ge,{field:t.field,schemaInterface:t.dataContext.schemaInterface,control:t.control,className:t.className,style:t.style,emptyText:i.emptyText})});if(null!=C&&a===u.Bool&&null==t.options)return n.renderData(le({},t,{options:C}));if(m===y.Standard&&D(t))return h.render(t,n);switch(m){case y.NullToggle:return o.render(t,n);case y.CheckList:return f.render(t,n);case y.Dropdown:return p.render(t,n);case y.Radio:return v.render(t,n);case y.Checkbox:return d.render(t,n);case y.Jsonata:return r.render(t,n)}if(L(i)&&i.multiline)return s.render(t,n);const b=L(i)?i.placeholder:void 0;/*#__PURE__*/return e.createElement(de,{className:c(t.className,N),style:t.style,id:t.id,readOnly:t.readonly,control:t.control,placeholder:null!=b?b:void 0,convert:ue(t.field.type)})})}function He(t={}){return{type:"adornment",render:({adornment:n,designMode:l,dataContext:a,useExpr:o},s)=>({apply:c=>{if(V(n)&&o){const d=o(n.expression,e=>e),u=F({value:d}),m=r(p,[u]);return R(t=>/*#__PURE__*/e.createElement(m,{children:t,parentContext:a,adornment:n}))(c);function p({children:e,adornment:t,parentContext:n}){const{value:l}=u(n),a=M(t.field,n.parentNode).control,r=!t.defaultOnly;return Q(()=>[null==l?void 0:l.value,null==(null==a?void 0:a.value)],([e])=>{null==a||a.setValue(t=>r||null==t?e:t)},!0),e}}var i;return _(n)?G(null!=(i=n.placement)?i:P.ControlStart,/*#__PURE__*/e.createElement("i",{className:n.iconClass}))(c):j(n)?R(r=>/*#__PURE__*/e.createElement(be,le({renderers:s,children:r,accordion:n,contentStyle:c.style,contentClassName:c.className,designMode:l,dataContext:a},t.accordion)))(c):void 0},priority:0,adornment:n})}}function Be(t={}){return U((n,l)=>{const a=Y(le({},n,{className:c(n.className,t.className)}),l);return{children:a.wrapLayout(/*#__PURE__*/e.createElement(Ee,le({layout:a},t))),className:a.className,style:a.style,divRef:e=>e&&n.errorControl?n.errorControl.meta.scrollElement=e:void 0}})}function Je(t){const{className:n,groupLabelClass:l,controlLabelClass:a,requiredElement:r,labelContainer:s}=le({requiredElement:/*#__PURE__*/e.createElement("span",null," *"),labelContainer:e=>e},t);return{render:(t,i,d,u)=>t.type==H.Text?t.label:s(/*#__PURE__*/e.createElement(e.Fragment,null,/*#__PURE__*/e.createElement("label",{htmlFor:t.forId,className:c(t.className,o(n,t.type===H.Group&&l,t.type===H.Control&&a))},i,u.renderLabelText(t.label),t.required&&r),d)),type:"label"}}function Ue(e={}){return{data:je(e.data),display:oe(e.display),action:_e(void 0,e.action),array:Fe(e.array),group:Ge(e.group),label:Je(e.label),adornment:He(e.adornment),renderLayout:Be(e.layout),visibility:Oe()}}function Ye(){return Ue({layout:{className:"control"},group:{className:"group"},array:{className:"control-array"},action:{className:"action"},data:{inputClass:"data"},display:{htmlClassName:"html",textClassName:"text"}})}const $e={label:{groupLabelClass:"font-bold",requiredElement:/*#__PURE__*/e.createElement("span",{className:"text-red-500"}," *")},array:{removableClass:"grid grid-cols-[1fr_auto] items-center gap-x-2",childClass:"grow my-2",addActionClass:"my-2"},group:{standardClassName:"flex flex-col gap-4",gridClassName:"gap-x-2 gap-y-4",flexClassName:"gap-2"},action:{className:"bg-primary-500 rounded-lg p-3 text-white"},layout:{className:"flex flex-col",errorClass:"text-sm text-danger-500"},data:{displayOnlyClass:"flex flex-row items-center gap-2",checkOptions:{className:"flex items-center gap-4",entryClass:"flex gap-1 items-center"},selectOptions:{emptyText:"<select>"},multilineClass:"border p-2 outline-0 whitespace-pre"},adornment:{accordion:{className:"flex items-center gap-2 my-2",titleClass:"cursor-pointer",iconOpenClass:"fa fa-chevron-up",iconClosedClass:"fa fa-chevron-down"}}};export{Ce as CheckButtons,de as ControlInput,Le as DataArrayRenderer,be as DefaultAccordion,Re as DefaultArrayRenderer,Pe as DefaultBoolOptions,se as DefaultDisplay,ge as DefaultDisplayOnly,Ee as DefaultLayout,ke as DefaultVisibility,Se as JsonataRenderer,ye as SelectDataRenderer,_e as createButtonActionRenderer,Ne as createCheckListRenderer,xe as createCheckboxRenderer,Ye as createClassStyledRenderers,He as createDefaultAdornmentRenderer,De as createDefaultArrayDataRenderer,Fe as createDefaultArrayRenderer,je as createDefaultDataRenderer,oe as createDefaultDisplayRenderer,Ge as createDefaultGroupRenderer,Je as createDefaultLabelRenderer,Ue as createDefaultRenderers,Oe as createDefaultVisibilityRenderer,ue as createInputConversion,Ae as createJsonataRenderer,Ie as createNullToggleRenderer,fe as createRadioRenderer,ve as createSelectConversion,pe as createSelectRenderer,$e as defaultTailwindTheme,Te as getAccordionState,he as setIncluded};
|
|
2
2
|
//# sourceMappingURL=index.js.map
|
package/lib/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":["../src/components/DefaultDisplay.tsx","../src/components/ControlInput.tsx","../src/components/SelectDataRenderer.tsx","../src/components/CheckRenderer.tsx","../src/components/DefaultLayout.tsx","../src/components/DefaultDisplayOnly.tsx","../src/components/DefaultVisibility.tsx","../src/components/JsonataRenderer.tsx","../src/components/NullToggle.tsx","../src/components/DefaultArrayRenderer.tsx","../src/components/DefaultAccordion.tsx","../src/components/MultilineTextfield.tsx","../src/createDefaultRenderers.tsx","../src/tailwind.tsx"],"sourcesContent":["import React from \"react\";\nimport clsx from \"clsx\";\nimport {\n coerceToString,\n CustomDisplay,\n DisplayDataType,\n DisplayRendererProps,\n DisplayRendererRegistration,\n getOverrideClass,\n HtmlDisplay,\n IconDisplay,\n rendererClass,\n TextDisplay,\n} from \"@react-typed-forms/schemas\";\n\nexport interface DefaultDisplayRendererOptions {\n textClassName?: string;\n htmlClassName?: string;\n}\n\nexport function createDefaultDisplayRenderer(\n options: DefaultDisplayRendererOptions = {},\n): DisplayRendererRegistration {\n return {\n render: (props) => <DefaultDisplay {...options} {...props} />,\n type: \"display\",\n };\n}\n\nexport function DefaultDisplay({\n data,\n display,\n className,\n style,\n ...options\n}: DefaultDisplayRendererOptions & DisplayRendererProps) {\n switch (data.type) {\n case DisplayDataType.Icon:\n return (\n <i\n style={style}\n className={clsx(\n getOverrideClass(className),\n display ? display.value : (data as IconDisplay).iconClass,\n )}\n />\n );\n case DisplayDataType.Text:\n return (\n <div\n style={style}\n className={rendererClass(className, options.textClassName)}\n >\n {display ? coerceToString(display.value) : (data as TextDisplay).text}\n </div>\n );\n case DisplayDataType.Html:\n return (\n <div\n style={style}\n className={rendererClass(className, options.htmlClassName)}\n dangerouslySetInnerHTML={{\n __html: display\n ? coerceToString(display.value)\n : (data as HtmlDisplay).html,\n }}\n />\n );\n case DisplayDataType.Custom:\n return (\n <div>\n Custom display placeholder: {(data as CustomDisplay).customId}\n </div>\n );\n default:\n return <h1>Unknown display type: {data.type}</h1>;\n }\n}\n","import React from \"react\";\nimport {\n Control,\n formControlProps,\n useControl,\n useControlEffect,\n} from \"@react-typed-forms/core\";\nimport {FieldType} from \"@react-typed-forms/schemas\";\n\nexport function ControlInput({\n control,\n convert,\n ...props\n}: React.InputHTMLAttributes<HTMLInputElement> & {\n control: Control<any>;\n convert: InputConversion;\n}) {\n const { errorText, value, onChange, ...inputProps } =\n formControlProps(control);\n const textValue = useControl(() => toText(value));\n useControlEffect(\n () => control.value,\n (v) => (textValue.value = toText(v)),\n );\n return (\n <input\n {...inputProps}\n type={convert[0]}\n value={textValue.value}\n onChange={(e) => {\n textValue.value = e.target.value;\n const converted = convert[1](e.target.value);\n if (converted !== undefined) control.value = converted;\n }}\n {...props}\n />\n );\n\n function toText(value: any) {\n return value == null ? \"\" : convert[2](value);\n }\n}\n\ntype InputConversion = [\n string,\n (s: string) => any,\n (a: any) => string | number,\n];\n\nexport function createInputConversion(ft: string): InputConversion {\n switch (ft) {\n case FieldType.String:\n return [\"text\", (a) => a, (a) => a];\n case FieldType.Bool:\n return [\n \"text\",\n (a) => (a === \"true\" ? true : a === \"false\" ? false : undefined),\n (a) => a?.toString() ?? \"\",\n ];\n case FieldType.Int:\n return [\n \"number\",\n (a) => (a !== \"\" ? parseInt(a) : null),\n (a) => (a == null ? \"\" : a),\n ];\n case FieldType.DateTime:\n return [\"datetime-local\", (a) => (!a ? null : a), (a) => a];\n case FieldType.Date:\n return [\"date\", (a) => (!a ? null : a), (a) => a];\n case FieldType.Time:\n return [\n \"time\",\n (a) => {\n const l = a.length;\n if (l === 5) return a + \":00\";\n if (l === 8) return a;\n return undefined;\n },\n (a) => (a ? a.substring(0, 5) : \"\"),\n ];\n case FieldType.Double:\n return [\n \"number\",\n (a) => (a !== \"\" ? parseFloat(a) : null),\n (a) => (a == null ? \"\" : a),\n ];\n default:\n return [\"text\", (a) => a, (a) => a];\n }\n}\n","import { Control } from \"@react-typed-forms/core\";\nimport React, { useMemo, useState } from \"react\";\nimport {\n createDataRenderer,\n FieldOption,\n FieldType,\n rendererClass,\n} from \"@react-typed-forms/schemas\";\n\nexport interface SelectRendererOptions {\n className?: string;\n emptyText?: string;\n requiredText?: string;\n}\n\nexport function createSelectRenderer(options: SelectRendererOptions = {}) {\n return createDataRenderer(\n (props, asArray) => (\n <SelectDataRenderer\n className={rendererClass(props.className, options.className)}\n state={props.control}\n id={props.id}\n readonly={props.readonly}\n options={props.options ?? []}\n required={props.required}\n emptyText={options.emptyText}\n requiredText={options.requiredText}\n convert={createSelectConversion(props.field.type)}\n />\n ),\n {\n options: true,\n },\n );\n}\n\ntype SelectConversion = (a: any) => string | number;\n\nexport interface SelectDataRendererProps {\n id?: string;\n className?: string;\n options: FieldOption[];\n emptyText?: string;\n requiredText?: string;\n readonly: boolean;\n required: boolean;\n state: Control<any>;\n convert: SelectConversion;\n}\n\nexport function SelectDataRenderer({\n state,\n options,\n className,\n convert,\n required,\n emptyText = \"N/A\",\n requiredText = \"<please select>\",\n readonly,\n ...props\n}: SelectDataRendererProps) {\n const { value, disabled } = state;\n const [showEmpty] = useState(!required || value == null);\n const optionStringMap = useMemo(\n () => Object.fromEntries(options.map((x) => [convert(x.value), x.value])),\n [options],\n );\n const optionGroups = useMemo(\n () => new Set(options.filter((x) => x.group).map((x) => x.group!)),\n [options],\n );\n return (\n <select\n {...props}\n className={className}\n onChange={(v) => (state.value = optionStringMap[v.target.value])}\n value={convert(value)}\n disabled={disabled || readonly}\n >\n {showEmpty && (\n <option value=\"\">{required ? requiredText : emptyText}</option>\n )}\n {[...optionGroups.keys()].map((x) => (\n <optgroup key={x} label={x}>\n {options.filter((o) => o.group === x).map(renderOption)}\n </optgroup>\n ))}\n {options.filter((x) => !x.group).map(renderOption)}\n </select>\n );\n\n function renderOption(x: FieldOption, i: number) {\n return (\n <option key={i} value={convert(x.value)} disabled={!!x.disabled}>\n {x.name}\n </option>\n );\n }\n}\n\nexport function createSelectConversion(ft: string): SelectConversion {\n switch (ft) {\n case FieldType.String:\n case FieldType.Int:\n case FieldType.Double:\n return (a) => a;\n default:\n return (a) => a?.toString() ?? \"\";\n }\n}\n","import {\n Control,\n Fcheckbox,\n RenderArrayElements,\n useComputed,\n} from \"@react-typed-forms/core\";\nimport React, { ReactNode } from \"react\";\nimport {\n createDataRenderer,\n DataRenderType,\n FieldOption,\n fieldOptionAdornment,\n rendererClass\n} from \"@react-typed-forms/schemas\";\n\nexport interface CheckRendererOptions {\n className?: string;\n entryClass?: string;\n checkClass?: string;\n labelClass?: string;\n}\nexport function createRadioRenderer(options: CheckRendererOptions = {}) {\n return createDataRenderer(\n (p) => (\n <CheckButtons\n {...options}\n {...p}\n className={rendererClass(p.className, options.className)}\n isChecked={(control, o) => control.value == o.value}\n setChecked={(c, o) => (c.value = o.value)}\n control={p.control}\n type=\"radio\"\n entryAdornment={fieldOptionAdornment(p)}\n />\n ),\n {\n renderType: DataRenderType.Radio,\n },\n );\n}\n\nexport function createCheckListRenderer(options: CheckRendererOptions = {}) {\n return createDataRenderer(\n (p) => (\n <CheckButtons\n {...options}\n {...p}\n className={rendererClass(p.className, options.className)}\n isChecked={(control, o) => {\n const v = control.value;\n return Array.isArray(v) ? v.includes(o.value) : false;\n }}\n setChecked={(c, o, checked) => {\n c.setValue((x) => setIncluded(x ?? [], o.value, checked));\n }}\n control={p.control}\n type=\"checkbox\"\n entryAdornment={fieldOptionAdornment(p)}\n />\n ),\n {\n collection: true,\n renderType: DataRenderType.CheckList,\n },\n );\n}\n\nexport interface CheckButtonsProps {\n id?: string;\n className?: string;\n options?: FieldOption[] | null;\n control: Control<any>;\n entryClass?: string;\n checkClass?: string;\n labelClass?: string;\n readonly?: boolean;\n type: \"checkbox\" | \"radio\";\n isChecked: (c: Control<any>, o: FieldOption) => boolean;\n setChecked: (c: Control<any>, o: FieldOption, checked: boolean) => void;\n entryAdornment?: (c: FieldOption, i: number, selected: boolean) => ReactNode;\n}\n\nexport function CheckButtons({\n control,\n options,\n labelClass,\n checkClass,\n readonly,\n entryClass,\n className,\n id,\n type,\n isChecked,\n setChecked,\n entryAdornment,\n}: CheckButtonsProps) {\n const { disabled } = control;\n const name = \"r\" + control.uniqueId;\n return (\n <div className={className} id={id}>\n <RenderArrayElements array={options?.filter((x) => x.value != null)}>\n {(o, i) => {\n const checked = useComputed(() => isChecked(control, o)).value;\n return (\n <>\n <div key={i} className={entryClass}>\n <input\n id={name + \"_\" + i}\n className={checkClass}\n type={type}\n name={name}\n readOnly={readonly}\n disabled={disabled}\n checked={checked}\n onChange={(x) => {\n !readonly && setChecked(control, o, x.target.checked);\n }}\n />\n <label className={labelClass} htmlFor={name + \"_\" + i}>\n {o.name}\n </label>\n </div>\n {entryAdornment?.(o, i, checked)}\n </>\n );\n }}\n </RenderArrayElements>\n </div>\n );\n}\n\nexport function setIncluded<A>(array: A[], elem: A, included: boolean): A[] {\n const already = array.includes(elem);\n if (included === already) {\n return array;\n }\n if (included) {\n return [...array, elem];\n }\n return array.filter((e) => e !== elem);\n}\n\nexport function createCheckboxRenderer(options: CheckRendererOptions = {}) {\n return createDataRenderer(\n (props, renderer) => (p) => ({\n ...p,\n label: undefined,\n children: (\n <div className={rendererClass(props.className, options.entryClass)}>\n <Fcheckbox\n id={props.id}\n control={props.control}\n style={props.style}\n className={options.checkClass}\n />\n {p.label && renderer.renderLabel(p.label, undefined, undefined)}\n </div>\n ),\n }),\n { renderType: DataRenderType.Checkbox },\n );\n}\n","import React, { ReactNode } from \"react\";\nimport {RenderedLayout} from \"@react-typed-forms/schemas\";\n\nexport interface DefaultLayoutRendererOptions {\n className?: string;\n errorClass?: string;\n renderError?: (errorText: string | null | undefined) => ReactNode;\n}\n\nexport function DefaultLayout({\n errorClass,\n renderError = (e) => e && <div className={errorClass}>{e}</div>,\n layout: { controlEnd, controlStart, label, children, errorControl },\n}: DefaultLayoutRendererOptions & {\n layout: RenderedLayout;\n}) {\n const ec = errorControl;\n const errorText = ec && ec.touched ? ec.error : undefined;\n return (\n <>\n {label}\n {controlStart}\n {children}\n {renderError(errorText)}\n {controlEnd}\n </>\n );\n}\n","import { Control } from \"@react-typed-forms/core\";\nimport React from \"react\";\nimport {\n rendererClass,\n SchemaField,\n SchemaInterface,\n} from \"@react-typed-forms/schemas\";\n\nexport function DefaultDisplayOnly({\n control,\n className,\n emptyText,\n schemaInterface,\n field,\n style,\n}: {\n control: Control<any>;\n field: SchemaField;\n schemaInterface: SchemaInterface;\n className?: string | null;\n style?: React.CSSProperties;\n emptyText?: string | null;\n}) {\n const v = control.value;\n const text =\n (schemaInterface.isEmptyValue(field, v)\n ? emptyText\n : schemaInterface.textValue(field, v)) ?? \"\";\n return (\n <div style={style} className={rendererClass(className)}>\n {text}\n </div>\n );\n}\n","import React, { useEffect } from \"react\";\nimport clsx from \"clsx\";\nimport {\n createVisibilityRenderer,\n VisibilityRendererProps,\n} from \"@react-typed-forms/schemas\";\n\nexport function createDefaultVisibilityRenderer() {\n return createVisibilityRenderer((props) => <DefaultVisibility {...props} />);\n}\n\nexport function DefaultVisibility({\n visibility,\n children,\n className,\n style,\n divRef,\n}: VisibilityRendererProps) {\n const v = visibility.value;\n useEffect(() => {\n if (v) {\n visibility.setValue((ex) => ({ visible: v.visible, showing: v.visible }));\n }\n }, [v?.visible]);\n return v?.visible ? (\n <div className={clsx(className)} style={style} ref={divRef}>\n {children}\n </div>\n ) : (\n <></>\n );\n}\n","import { Control, useComputed } from \"@react-typed-forms/core\";\nimport React from \"react\";\nimport {\n coerceToString,\n ControlDataContext,\n createDataRenderer,\n DataRenderType,\n getJsonPath,\n getRootDataNode,\n JsonataRenderOptions,\n rendererClass,\n SchemaDataNode,\n useJsonataExpression,\n} from \"@react-typed-forms/schemas\";\n\nexport function createJsonataRenderer(className?: string) {\n return createDataRenderer(\n (p) => (\n <JsonataRenderer\n renderOptions={p.renderOptions as JsonataRenderOptions}\n className={rendererClass(p.className, className)}\n dataNode={p.dataNode}\n dataContext={p.dataContext}\n control={p.control}\n readonly={p.readonly}\n />\n ),\n { renderType: DataRenderType.Jsonata },\n );\n}\n\nexport function JsonataRenderer({\n control,\n renderOptions,\n readonly,\n className,\n dataContext,\n dataNode,\n}: {\n control: Control<any>;\n renderOptions: JsonataRenderOptions;\n className?: string;\n dataContext: ControlDataContext;\n dataNode: SchemaDataNode;\n readonly: boolean;\n}) {\n const sdn = dataNode.elementIndex != null ? dataNode : dataContext.parentNode;\n const bindings = useComputed(() => ({\n value: control.value,\n readonly,\n disabled: control.disabled,\n formData: dataContext.formData,\n dataPath: getJsonPath(dataNode),\n }));\n const rendered = useJsonataExpression(\n renderOptions.expression,\n getRootDataNode(sdn).control!,\n getJsonPath(sdn),\n bindings,\n coerceToString,\n );\n return (\n <div\n className={className}\n dangerouslySetInnerHTML={{ __html: rendered.value }}\n />\n );\n}\n","import { Control, newControl, useControlEffect } from \"@react-typed-forms/core\";\nimport React, { ReactNode } from \"react\";\nimport {\n createDataRenderer,\n DataRenderType,\n FieldType,\n} from \"@react-typed-forms/schemas\";\n\nexport function createNullToggleRenderer() {\n return createDataRenderer(\n ({ control, field, renderOptions, ...props }, renderers) => {\n const nullControl = (control.meta[\"nullControl\"] ??= newControl(\n control.current.value != null,\n ));\n return (layout) => {\n const newLayout = renderers.renderData({\n ...props,\n control: nullControl,\n field: { ...field, type: FieldType.Bool },\n renderOptions: { type: DataRenderType.Checkbox },\n })(layout);\n return {\n ...newLayout,\n children: (\n <NullWrapper\n control={control}\n nullControl={nullControl}\n children={newLayout.children}\n readonly={props.readonly}\n defaultValue={props.definition.defaultValue}\n />\n ),\n };\n };\n },\n );\n}\n\nfunction NullWrapper({\n children,\n nullControl,\n control,\n defaultValue,\n readonly,\n}: {\n control: Control<any>;\n nullControl: Control<boolean>;\n children: ReactNode;\n readonly: boolean;\n defaultValue: any;\n}) {\n useControlEffect(\n () => readonly,\n (r) => (nullControl.disabled = r),\n true,\n );\n useControlEffect(\n () => nullControl.value,\n (e) => {\n if (e) {\n control.value = nullControl.meta[\"nonNullValue\"] ?? defaultValue;\n } else {\n nullControl.meta[\"nonNullValue\"] = control.value;\n control.value = null;\n }\n },\n );\n return children;\n}\n","import clsx from \"clsx\";\nimport React, { Fragment, ReactNode } from \"react\";\nimport { RenderElements, useTrackedComponent } from \"@react-typed-forms/core\";\nimport {\n ActionRendererProps,\n applyArrayLengthRestrictions,\n ArrayActionOptions,\n ArrayRendererProps,\n ArrayRendererRegistration,\n ArrayRenderOptions,\n ControlDataContext,\n ControlDefinition,\n ControlDefinitionType,\n createArrayActions,\n createDataRenderer,\n DataControlDefinition,\n DataRendererProps,\n DataRendererRegistration,\n DataRenderType,\n EvalExpressionHook,\n FormRenderer,\n getLengthRestrictions,\n GroupedControlsDefinition,\n GroupRenderType,\n isArrayRenderer,\n isCompoundField,\n lookupDataNode,\n makeHookDepString,\n mergeObjects,\n SchemaDataNode,\n} from \"@react-typed-forms/schemas\";\n\nexport function createDefaultArrayDataRenderer(\n defaultActions?: ArrayActionOptions,\n): DataRendererRegistration {\n return createDataRenderer(\n (props, renderers) => {\n return (\n <DataArrayRenderer\n dataProps={props}\n renderers={renderers}\n defaultActions={defaultActions}\n />\n );\n },\n { renderType: DataRenderType.Array, collection: true },\n );\n}\n\nexport function DataArrayRenderer({\n dataProps,\n renderers,\n defaultActions,\n}: {\n renderers: FormRenderer;\n dataProps: DataRendererProps;\n defaultActions?: ArrayActionOptions;\n}) {\n const {\n renderOptions,\n control,\n field,\n readonly,\n designMode,\n required,\n renderChild,\n definition,\n className,\n style,\n useChildVisibility,\n dataContext,\n } = dataProps;\n const { addText, noAdd, noRemove, noReorder, removeText } = mergeObjects(\n isArrayRenderer(renderOptions) ? renderOptions : ({} as ArrayRenderOptions),\n defaultActions as ArrayRenderOptions,\n );\n const childOptions = isArrayRenderer(renderOptions)\n ? renderOptions.childOptions\n : undefined;\n\n const renderAsElement = !isCompoundField(field);\n const childDefinition: ControlDefinition = !renderAsElement\n ? ({\n type: ControlDefinitionType.Group,\n children: definition.children,\n groupOptions: { type: GroupRenderType.Standard, hideTitle: true },\n } as GroupedControlsDefinition)\n : ({\n type: ControlDefinitionType.Data,\n field: definition.field,\n children: definition.children,\n renderOptions: childOptions ?? { type: DataRenderType.Standard },\n hideTitle: true,\n } as DataControlDefinition);\n\n const visibilities = (definition.children ?? []).map(\n (x) => [useChildVisibility(x, undefined, true), x] as const,\n );\n const deps = makeHookDepString(visibilities, (x) => x[0].deps);\n const Entry = useTrackedComponent(RenderEntry, [deps]);\n\n const arrayProps = {\n ...createArrayActions(control, field, {\n addText,\n removeText,\n noAdd,\n noRemove,\n readonly,\n disabled: control.disabled,\n designMode,\n }),\n required,\n renderElement: (i, wrap) => (\n <Entry\n index={i}\n renderChildElement={renderChildElement}\n dataContext={dataContext}\n visibilities={visibilities}\n wrap={wrap}\n />\n ),\n className: className ? className : undefined,\n style,\n ...getLengthRestrictions(definition),\n } satisfies ArrayRendererProps;\n\n return renderers.renderArray(arrayProps);\n\n function renderChildElement(i: number, elementNode: SchemaDataNode) {\n return renderChild(\n control.elements?.[i].uniqueId ?? i,\n childDefinition,\n renderAsElement\n ? {\n elementIndex: i,\n }\n : { parentDataNode: elementNode },\n );\n }\n}\n\nfunction RenderEntry({\n index: i,\n renderChildElement,\n visibilities,\n wrap,\n dataContext,\n}: {\n index: number;\n renderChildElement: (i: number, element: SchemaDataNode) => ReactNode;\n visibilities: (readonly [EvalExpressionHook<boolean>, ControlDefinition])[];\n dataContext: ControlDataContext;\n wrap: (n: ReactNode) => ReactNode;\n}) {\n const elementNode = dataContext.dataNode!.getChildElement(i);\n const childVis = visibilities.map(\n ([hook, def]) =>\n hook.runHook(\n {\n ...dataContext,\n parentNode: elementNode,\n dataNode: lookupDataNode(def, elementNode),\n },\n hook.state,\n ).value,\n );\n const anyVisible = childVis.length == 0 || childVis.some((x) => x === true);\n if (!anyVisible) return undefined;\n return wrap(renderChildElement(i, elementNode));\n}\n\nexport interface DefaultArrayRendererOptions extends ArrayActionOptions {\n className?: string;\n removableClass?: string;\n childClass?: string;\n removableChildClass?: string;\n removeActionClass?: string;\n addActionClass?: string;\n}\n\nexport function createDefaultArrayRenderer(\n options?: DefaultArrayRendererOptions,\n): ArrayRendererRegistration {\n return {\n render: (props, { renderAction }) => (\n <DefaultArrayRenderer\n {...props}\n {...options}\n renderAction={renderAction}\n />\n ),\n type: \"array\",\n };\n}\n\nexport interface DefaultArrayRendererProps\n extends DefaultArrayRendererOptions,\n ArrayRendererProps {\n renderAction: (props: ActionRendererProps) => ReactNode;\n}\n\nexport function DefaultArrayRenderer(props: DefaultArrayRendererProps) {\n const {\n renderElement,\n className,\n removableClass,\n childClass,\n removableChildClass,\n removeActionClass,\n addActionClass,\n arrayControl,\n renderAction,\n style,\n } = props;\n const { addAction, removeAction } = applyArrayLengthRestrictions(props);\n return (\n <div style={style}>\n <div className={clsx(className, removeAction && removableClass)}>\n <RenderElements control={arrayControl}>\n {(_, x) =>\n renderElement(x, (children) =>\n removeAction ? (\n <>\n <div className={clsx(childClass, removableChildClass)}>\n {children}\n </div>\n <div className={removeActionClass}>\n {renderAction(removeAction(x))}\n </div>\n </>\n ) : (\n <div className={childClass}>{children}</div>\n ),\n )\n }\n </RenderElements>\n </div>\n {addAction && (\n <div className={addActionClass}>{renderAction(addAction)}</div>\n )}\n </div>\n );\n}\n","import React, { CSSProperties, Fragment, ReactElement } from \"react\";\nimport { useControl } from \"@react-typed-forms/core\";\nimport clsx from \"clsx\";\nimport { DefaultAccordionRendererOptions } from \"../createDefaultRenderers\";\nimport { AccordionAdornment, FormRenderer } from \"@react-typed-forms/schemas\";\n\nexport function DefaultAccordion({\n children,\n accordion,\n contentStyle,\n contentClassName,\n designMode,\n iconOpenClass,\n iconClosedClass,\n className,\n renderTitle = (t) => t,\n renderToggler,\n renderers,\n titleClass,\n}: {\n children: ReactElement;\n accordion: Partial<AccordionAdornment>;\n contentStyle?: CSSProperties;\n contentClassName?: string;\n designMode?: boolean;\n renderers: FormRenderer;\n} & DefaultAccordionRendererOptions) {\n const open = useControl(!!accordion.defaultExpanded);\n const isOpen = open.value;\n const fullContentStyle =\n isOpen || designMode ? contentStyle : { ...contentStyle, display: \"none\" };\n const title = renderers.renderLabelText(renderTitle(accordion.title, open));\n const toggler = renderToggler ? (\n renderToggler(open, title)\n ) : (\n <button className={className} onClick={() => open.setValue((x) => !x)}>\n <label className={titleClass}>{title}</label>\n <i className={clsx(isOpen ? iconOpenClass : iconClosedClass)} />\n </button>\n );\n\n return (\n <>\n {toggler}\n <div style={fullContentStyle} className={contentClassName}>\n {children}\n </div>\n </>\n );\n}\n","import React, { useRef } from \"react\";\nimport { useControlEffect } from \"@react-typed-forms/core\";\nimport {\n createDataRenderer,\n DataRendererProps,\n rendererClass,\n} from \"@react-typed-forms/schemas\";\n\nexport function createMultilineFieldRenderer(className?: string) {\n return createDataRenderer((p) => (\n <MultilineTextfield\n {...p}\n className={rendererClass(p.className, className)}\n />\n ));\n}\n\nexport function MultilineTextfield({ control, className }: DataRendererProps) {\n const codeRef = useRef<HTMLElement | null>(null);\n useControlEffect(\n () => control.value,\n (v) => {\n const c = codeRef.current;\n if (c && c.textContent !== v) {\n c.textContent = v;\n }\n },\n true,\n );\n return (\n <code\n contentEditable={!control.disabled}\n className={className}\n onInput={(t) => (control.value = t.currentTarget.textContent)}\n ref={codeRef}\n />\n );\n}\n","import {\n createDefaultDisplayRenderer,\n DefaultDisplayRendererOptions,\n} from \"./components/DefaultDisplay\";\nimport {\n DefaultLayout,\n DefaultLayoutRendererOptions,\n} from \"./components/DefaultLayout\";\nimport { createDefaultVisibilityRenderer } from \"./components/DefaultVisibility\";\nimport React, {\n CSSProperties,\n Fragment,\n ReactElement,\n ReactNode,\n useCallback,\n} from \"react\";\nimport clsx from \"clsx\";\nimport {\n createSelectRenderer,\n SelectRendererOptions,\n} from \"./components/SelectDataRenderer\";\nimport { DefaultDisplayOnly } from \"./components/DefaultDisplayOnly\";\nimport { Control, useControlEffect } from \"@react-typed-forms/core\";\nimport { ControlInput, createInputConversion } from \"./components/ControlInput\";\nimport {\n createDefaultArrayDataRenderer,\n createDefaultArrayRenderer,\n DefaultArrayRendererOptions,\n} from \"./components/DefaultArrayRenderer\";\nimport {\n CheckRendererOptions,\n createCheckboxRenderer,\n createCheckListRenderer,\n createRadioRenderer,\n} from \"./components/CheckRenderer\";\nimport { DefaultAccordion } from \"./components/DefaultAccordion\";\nimport { createNullToggleRenderer } from \"./components/NullToggle\";\nimport { createMultilineFieldRenderer } from \"./components/MultilineTextfield\";\nimport { createJsonataRenderer } from \"./components/JsonataRenderer\";\nimport {\n ActionRendererProps,\n ActionRendererRegistration,\n AdornmentPlacement,\n AdornmentRendererRegistration,\n appendMarkupAt,\n ArrayActionOptions,\n ControlDataContext,\n ControlLayoutProps,\n createActionRenderer,\n createDataRenderer,\n createLayoutRenderer,\n DataRendererRegistration,\n DataRenderType,\n DefaultRenderers,\n FieldOption,\n FieldType,\n FlexRenderer,\n GridRenderer,\n GroupRendererProps,\n GroupRendererRegistration,\n hasOptions,\n isAccordionAdornment,\n isDataGroupRenderer,\n isDisplayOnlyRenderer,\n isFlexRenderer,\n isGridRenderer,\n isIconAdornment,\n isSetFieldAdornment,\n isTextfieldRenderer,\n LabelRendererRegistration,\n LabelType,\n rendererClass,\n renderLayoutParts,\n schemaDataForFieldRef,\n SetFieldAdornment,\n useDynamicHooks,\n wrapLayout,\n} from \"@react-typed-forms/schemas\";\n\nexport interface DefaultRendererOptions {\n data?: DefaultDataRendererOptions;\n display?: DefaultDisplayRendererOptions;\n action?: DefaultActionRendererOptions;\n array?: DefaultArrayRendererOptions;\n group?: DefaultGroupRendererOptions;\n label?: DefaultLabelRendererOptions;\n adornment?: DefaultAdornmentRendererOptions;\n layout?: DefaultLayoutRendererOptions;\n}\n\ninterface StyleProps {\n className?: string;\n style?: CSSProperties;\n}\n\nexport interface DefaultActionRendererOptions {\n className?: string;\n renderContent?: (\n actionText: string,\n actionId: string,\n actionData: any,\n ) => ReactNode;\n}\n\nexport function createButtonActionRenderer(\n actionId: string | string[] | undefined,\n options: DefaultActionRendererOptions = {},\n): ActionRendererRegistration {\n return createActionRenderer(\n actionId,\n ({\n onClick,\n actionText,\n className,\n style,\n actionId,\n actionData,\n disabled,\n }: ActionRendererProps) => {\n return (\n <button\n className={rendererClass(className, options.className)}\n disabled={disabled}\n style={style}\n onClick={onClick}\n >\n {options.renderContent?.(actionText, actionId, actionData) ??\n actionText}\n </button>\n );\n },\n );\n}\n\nexport interface DefaultGroupRendererOptions {\n className?: string;\n standardClassName?: string;\n gridStyles?: (columns: GridRenderer) => StyleProps;\n gridClassName?: string;\n defaultGridColumns?: number;\n flexClassName?: string;\n defaultFlexGap?: string;\n}\n\nexport function createDefaultGroupRenderer(\n options?: DefaultGroupRendererOptions,\n): GroupRendererRegistration {\n const {\n className,\n gridStyles = defaultGridStyles,\n defaultGridColumns = 2,\n gridClassName,\n standardClassName,\n flexClassName,\n defaultFlexGap,\n } = options ?? {};\n\n function defaultGridStyles({\n columns = defaultGridColumns,\n }: GridRenderer): StyleProps {\n return {\n className: gridClassName,\n style: {\n display: \"grid\",\n gridTemplateColumns: `repeat(${columns}, 1fr)`,\n },\n };\n }\n\n function flexStyles(options: FlexRenderer): StyleProps {\n return {\n className: flexClassName,\n style: {\n display: \"flex\",\n gap: options.gap ? options.gap : defaultFlexGap,\n flexDirection: options.direction\n ? (options.direction as any)\n : undefined,\n },\n };\n }\n\n function render(props: GroupRendererProps) {\n const { renderChild, renderOptions, childDefinitions } = props;\n\n const { style, className: gcn } = isGridRenderer(renderOptions)\n ? gridStyles(renderOptions)\n : isFlexRenderer(renderOptions)\n ? flexStyles(renderOptions)\n : ({ className: standardClassName } as StyleProps);\n\n return (cp: ControlLayoutProps) => {\n return {\n ...cp,\n children: (\n <div\n className={rendererClass(props.className, clsx(className, gcn))}\n style={style}\n >\n {childDefinitions?.map((c, i) => renderChild(i, c))}\n </div>\n ),\n };\n };\n }\n\n return { type: \"group\", render };\n}\n\nexport const DefaultBoolOptions: FieldOption[] = [\n { name: \"Yes\", value: true },\n { name: \"No\", value: false },\n];\n\nexport interface DefaultDataRendererOptions {\n inputClass?: string;\n displayOnlyClass?: string;\n selectOptions?: SelectRendererOptions;\n checkboxOptions?: CheckRendererOptions;\n checkOptions?: CheckRendererOptions;\n radioOptions?: CheckRendererOptions;\n checkListOptions?: CheckRendererOptions;\n booleanOptions?: FieldOption[];\n optionRenderer?: DataRendererRegistration;\n multilineClass?: string;\n jsonataClass?: string;\n arrayOptions?: ArrayActionOptions;\n}\n\nexport function createDefaultDataRenderer(\n options: DefaultDataRendererOptions = {},\n): DataRendererRegistration {\n const jsonataRenderer = createJsonataRenderer(options.jsonataClass);\n const nullToggler = createNullToggleRenderer();\n const multilineRenderer = createMultilineFieldRenderer(\n options.multilineClass,\n );\n const checkboxRenderer = createCheckboxRenderer(\n options.checkOptions ?? options.checkboxOptions,\n );\n const selectRenderer = createSelectRenderer(options.selectOptions);\n const radioRenderer = createRadioRenderer(\n options.radioOptions ?? options.checkOptions,\n );\n const checkListRenderer = createCheckListRenderer(\n options.checkListOptions ?? options.checkOptions,\n );\n const { inputClass, booleanOptions, optionRenderer, displayOnlyClass } = {\n optionRenderer: selectRenderer,\n booleanOptions: DefaultBoolOptions,\n ...options,\n };\n const arrayRenderer = createDefaultArrayDataRenderer(options.arrayOptions);\n\n return createDataRenderer((props, renderers) => {\n const { field } = props;\n const fieldType = field.type;\n const renderOptions = props.renderOptions;\n let renderType = renderOptions.type;\n if (\n field.collection &&\n props.elementIndex == null &&\n (renderType == DataRenderType.Standard ||\n renderType == DataRenderType.Array)\n ) {\n return arrayRenderer.render(props, renderers);\n }\n if (fieldType === FieldType.Compound) {\n const groupOptions = (isDataGroupRenderer(renderOptions)\n ? renderOptions.groupOptions\n : undefined) ?? { type: \"Standard\", hideTitle: true };\n return renderers.renderGroup({ ...props, renderOptions: groupOptions });\n }\n if (fieldType == FieldType.Any) return <>No control for Any</>;\n if (isDisplayOnlyRenderer(renderOptions))\n return (p) => ({\n ...p,\n className: displayOnlyClass,\n children: (\n <DefaultDisplayOnly\n field={props.field}\n schemaInterface={props.dataContext.schemaInterface}\n control={props.control}\n className={props.className}\n style={props.style}\n emptyText={renderOptions.emptyText}\n />\n ),\n });\n const isBool = fieldType === FieldType.Bool;\n if (booleanOptions != null && isBool && props.options == null) {\n return renderers.renderData({ ...props, options: booleanOptions });\n }\n if (renderType === DataRenderType.Standard && hasOptions(props)) {\n return optionRenderer.render(props, renderers);\n }\n switch (renderType) {\n case DataRenderType.NullToggle:\n return nullToggler.render(props, renderers);\n case DataRenderType.CheckList:\n return checkListRenderer.render(props, renderers);\n case DataRenderType.Dropdown:\n return selectRenderer.render(props, renderers);\n case DataRenderType.Radio:\n return radioRenderer.render(props, renderers);\n case DataRenderType.Checkbox:\n return checkboxRenderer.render(props, renderers);\n case DataRenderType.Jsonata:\n return jsonataRenderer.render(props, renderers);\n }\n if (isTextfieldRenderer(renderOptions) && renderOptions.multiline)\n return multilineRenderer.render(props, renderers);\n const placeholder = isTextfieldRenderer(renderOptions)\n ? renderOptions.placeholder\n : undefined;\n return (\n <ControlInput\n className={rendererClass(props.className, inputClass)}\n style={props.style}\n id={props.id}\n readOnly={props.readonly}\n control={props.control}\n placeholder={placeholder ?? undefined}\n convert={createInputConversion(props.field.type)}\n />\n );\n });\n}\n\nexport interface DefaultAccordionRendererOptions {\n className?: string;\n titleClass?: string;\n togglerClass?: string;\n iconOpenClass?: string;\n iconClosedClass?: string;\n renderTitle?: (\n title: string | undefined,\n current: Control<boolean>,\n ) => ReactNode;\n renderToggler?: (current: Control<boolean>, title: ReactNode) => ReactNode;\n}\n\nexport interface DefaultAdornmentRendererOptions {\n accordion?: DefaultAccordionRendererOptions;\n}\n\nexport function createDefaultAdornmentRenderer(\n options: DefaultAdornmentRendererOptions = {},\n): AdornmentRendererRegistration {\n return {\n type: \"adornment\",\n render: ({ adornment, designMode, dataContext, useExpr }, renderers) => ({\n apply: (rl) => {\n if (isSetFieldAdornment(adornment) && useExpr) {\n const hook = useExpr(adornment.expression, (x) => x);\n const dynamicHooks = useDynamicHooks({ value: hook });\n const SetFieldWrapper = useCallback(setFieldWrapper, [dynamicHooks]);\n return wrapLayout((x) => (\n <SetFieldWrapper\n children={x}\n parentContext={dataContext}\n adornment={adornment}\n />\n ))(rl);\n\n function setFieldWrapper({\n children,\n adornment,\n parentContext,\n }: {\n children: ReactNode;\n adornment: SetFieldAdornment;\n parentContext: ControlDataContext;\n }) {\n const { value } = dynamicHooks(parentContext);\n const fieldNode = schemaDataForFieldRef(\n adornment.field,\n parentContext.parentNode,\n );\n const otherField = fieldNode.control;\n const always = !adornment.defaultOnly;\n useControlEffect(\n () => [value?.value, otherField?.value == null],\n ([v]) => {\n otherField?.setValue((x) => (always || x == null ? v : x));\n },\n true,\n );\n return children;\n }\n }\n if (isIconAdornment(adornment)) {\n return appendMarkupAt(\n adornment.placement ?? AdornmentPlacement.ControlStart,\n <i className={adornment.iconClass} />,\n )(rl);\n }\n if (isAccordionAdornment(adornment)) {\n return wrapLayout((x) => (\n <DefaultAccordion\n renderers={renderers}\n children={x}\n accordion={adornment}\n contentStyle={rl.style}\n contentClassName={rl.className}\n designMode={designMode}\n {...options.accordion}\n />\n ))(rl);\n }\n },\n priority: 0,\n adornment,\n }),\n };\n}\n\nfunction createDefaultLayoutRenderer(\n options: DefaultLayoutRendererOptions = {},\n) {\n return createLayoutRenderer((props, renderers) => {\n const layout = renderLayoutParts(\n {\n ...props,\n className: rendererClass(props.className, options.className),\n },\n renderers,\n );\n return {\n children: layout.wrapLayout(\n <DefaultLayout layout={layout} {...options} />,\n ),\n className: layout.className,\n style: layout.style,\n divRef: (e) =>\n e && props.errorControl\n ? (props.errorControl.meta.scrollElement = e)\n : undefined,\n };\n });\n}\n\ninterface DefaultLabelRendererOptions {\n className?: string;\n groupLabelClass?: string;\n controlLabelClass?: string;\n requiredElement?: ReactNode;\n labelContainer?: (children: ReactElement) => ReactElement;\n}\n\nexport function createDefaultLabelRenderer(\n options?: DefaultLabelRendererOptions,\n): LabelRendererRegistration {\n const {\n className,\n groupLabelClass,\n controlLabelClass,\n requiredElement,\n labelContainer,\n } = {\n requiredElement: <span> *</span>,\n labelContainer: (c: ReactElement) => c,\n ...options,\n };\n return {\n render: (props, labelStart, labelEnd, renderers) => {\n if (props.type == LabelType.Text) return props.label;\n return labelContainer(\n <>\n <label\n htmlFor={props.forId}\n className={rendererClass(\n props.className,\n clsx(\n className,\n props.type === LabelType.Group && groupLabelClass,\n props.type === LabelType.Control && controlLabelClass,\n ),\n )}\n >\n {labelStart}\n {renderers.renderLabelText(props.label)}\n {props.required && requiredElement}\n </label>\n {labelEnd}\n </>,\n );\n },\n type: \"label\",\n };\n}\n\nexport function createDefaultRenderers(\n options: DefaultRendererOptions = {},\n): DefaultRenderers {\n return {\n data: createDefaultDataRenderer(options.data),\n display: createDefaultDisplayRenderer(options.display),\n action: createButtonActionRenderer(undefined, options.action),\n array: createDefaultArrayRenderer(options.array),\n group: createDefaultGroupRenderer(options.group),\n label: createDefaultLabelRenderer(options.label),\n adornment: createDefaultAdornmentRenderer(options.adornment),\n renderLayout: createDefaultLayoutRenderer(options.layout),\n visibility: createDefaultVisibilityRenderer(),\n };\n}\n\nexport function createClassStyledRenderers() {\n return createDefaultRenderers({\n layout: { className: \"control\" },\n group: { className: \"group\" },\n array: { className: \"control-array\" },\n action: { className: \"action\" },\n data: { inputClass: \"data\" },\n display: { htmlClassName: \"html\", textClassName: \"text\" },\n });\n}\n","import React from \"react\";\n\nimport { DefaultRendererOptions } from \"./createDefaultRenderers\";\n\nexport const defaultTailwindTheme = {\n label: {\n groupLabelClass: \"font-bold\",\n requiredElement: <span className=\"text-red-500\"> *</span>,\n },\n array: {\n removableClass: \"grid grid-cols-[1fr_auto] items-center gap-x-2\",\n childClass: \"grow my-2\",\n addActionClass: \"my-2\",\n },\n group: {\n standardClassName: \"flex flex-col gap-4\",\n gridClassName: \"gap-x-2 gap-y-4\",\n flexClassName: \"gap-2\",\n },\n action: {\n className: \"bg-primary-500 rounded-lg p-3 text-white\",\n },\n layout: {\n className: \"flex flex-col\",\n errorClass: \"text-sm text-danger-500\",\n },\n data: {\n displayOnlyClass: \"flex flex-row items-center gap-2\",\n checkOptions: {\n className: \"flex items-center gap-4\",\n entryClass: \"flex gap-1 items-center\",\n },\n selectOptions: { emptyText: \"<select>\" },\n multilineClass: \"border p-2 outline-0 whitespace-pre\",\n },\n adornment: {\n accordion: {\n className: \"flex items-center gap-2 my-2\",\n titleClass: \"cursor-pointer\",\n iconOpenClass: \"fa fa-chevron-up\",\n iconClosedClass: \"fa fa-chevron-down\",\n },\n },\n} satisfies DefaultRendererOptions;\n"],"names":["_excluded","createDefaultDisplayRenderer","options","render","props","React","createElement","DefaultDisplay","_extends","type","_ref","_effect","_useComponentTracking","data","display","className","style","_objectWithoutPropertiesLoose","DisplayDataType","Icon","clsx","getOverrideClass","value","iconClass","Text","rendererClass","textClassName","coerceToString","text","Html","htmlClassName","dangerouslySetInnerHTML","__html","html","Custom","customId","ControlInput","control","convert","_formControlProps","formControlProps","inputProps","_excluded2","textValue","useControl","toText","useControlEffect","v","onChange","e","target","converted","undefined","createInputConversion","ft","FieldType","String","a","Bool","_a$toString","toString","Int","parseInt","DateTime","Date","Time","l","length","substring","Double","parseFloat","createSelectRenderer","createDataRenderer","asArray","_props$options","SelectDataRenderer","state","id","readonly","required","emptyText","requiredText","createSelectConversion","field","disabled","showEmpty","useState","optionStringMap","useMemo","Object","fromEntries","map","x","optionGroups","Set","filter","group","keys","key","label","o","renderOption","i","name","createRadioRenderer","p","CheckButtons","isChecked","setChecked","c","entryAdornment","fieldOptionAdornment","renderType","DataRenderType","Radio","createCheckListRenderer","Array","isArray","includes","checked","setValue","setIncluded","collection","CheckList","labelClass","checkClass","entryClass","uniqueId","RenderArrayElements","array","useComputed","Fragment","readOnly","htmlFor","elem","included","createCheckboxRenderer","renderer","children","Fcheckbox","renderLabel","Checkbox","DefaultLayout","errorClass","renderError","layout","controlEnd","controlStart","errorControl","touched","error","DefaultDisplayOnly","schemaInterface","isEmptyValue","createDefaultVisibilityRenderer","createVisibilityRenderer","DefaultVisibility","visibility","divRef","useEffect","ex","visible","showing","ref","createJsonataRenderer","JsonataRenderer","renderOptions","dataNode","dataContext","Jsonata","sdn","elementIndex","parentNode","bindings","formData","dataPath","getJsonPath","rendered","useJsonataExpression","expression","getRootDataNode","createNullToggleRenderer","renderers","_control$meta","_control$meta$_nullCo","nullControl","meta","newControl","current","newLayout","renderData","NullWrapper","defaultValue","definition","r","_nullControl$meta$non","createDefaultArrayDataRenderer","defaultActions","DataArrayRenderer","dataProps","_definition$children","designMode","renderChild","useChildVisibility","addText","noAdd","noRemove","removeText","mergeObjects","isArrayRenderer","childOptions","renderAsElement","isCompoundField","childDefinition","ControlDefinitionType","Data","Standard","hideTitle","Group","groupOptions","GroupRenderType","visibilities","deps","makeHookDepString","Entry","useTrackedComponent","RenderEntry","arrayProps","createArrayActions","renderElement","wrap","index","renderChildElement","getLengthRestrictions","renderArray","elementNode","_control$elements$i$u","_control$elements","elements","parentDataNode","getChildElement","childVis","hook","def","runHook","lookupDataNode","some","createDefaultArrayRenderer","renderAction","DefaultArrayRenderer","removableClass","childClass","removableChildClass","removeActionClass","addActionClass","arrayControl","addAction","removeAction","applyArrayLengthRestrictions","RenderElements","_","DefaultAccordion","accordion","contentStyle","contentClassName","iconOpenClass","iconClosedClass","renderTitle","t","renderToggler","titleClass","open","defaultExpanded","isOpen","fullContentStyle","title","renderLabelText","toggler","onClick","MultilineTextfield","codeRef","useRef","textContent","contentEditable","onInput","currentTarget","createButtonActionRenderer","actionId","createActionRenderer","actionText","actionData","_options$renderConten","renderContent","createDefaultGroupRenderer","gridStyles","defaultGridStyles","defaultGridColumns","gridClassName","standardClassName","flexClassName","defaultFlexGap","columns","gridTemplateColumns","childDefinitions","gcn","isGridRenderer","isFlexRenderer","gap","flexDirection","direction","flexStyles","cp","DefaultBoolOptions","createDefaultDataRenderer","_options$checkOptions","_options$radioOptions","_options$checkListOpt","jsonataRenderer","jsonataClass","nullToggler","multilineRenderer","multilineClass","checkboxRenderer","checkOptions","checkboxOptions","selectRenderer","selectOptions","radioRenderer","radioOptions","checkListRenderer","checkListOptions","inputClass","booleanOptions","optionRenderer","displayOnlyClass","arrayRenderer","arrayOptions","fieldType","Compound","isDataGroupRenderer","renderGroup","Any","isDisplayOnlyRenderer","hasOptions","NullToggle","Dropdown","isTextfieldRenderer","multiline","placeholder","createDefaultAdornmentRenderer","adornment","useExpr","apply","rl","isSetFieldAdornment","dynamicHooks","useDynamicHooks","SetFieldWrapper","useCallback","setFieldWrapper","wrapLayout","parentContext","otherField","schemaDataForFieldRef","always","defaultOnly","_adornment$placement","isIconAdornment","appendMarkupAt","placement","AdornmentPlacement","ControlStart","isAccordionAdornment","priority","createDefaultLayoutRenderer","createLayoutRenderer","renderLayoutParts","scrollElement","createDefaultLabelRenderer","groupLabelClass","controlLabelClass","requiredElement","labelContainer","labelStart","labelEnd","LabelType","forId","Control","createDefaultRenderers","action","renderLayout","createClassStyledRenderers","defaultTailwindTheme"],"mappings":"snDAAA,MAAAA,GAAA,CAAA,OAAA,UAAA,YAAA,SAoBgB,SAAAC,GACdC,EAAyC,CAAA,GAEzC,MAAO,CACLC,OAASC,gBAAUC,EAAAC,cAACC,GAAcC,GAAA,CAAA,EAAKN,EAAaE,IACpDK,KAAM,UAEV,CAEgB,SAAAF,GAAcG,GAAA,IAAAC,EAAAC,IAAA,IAAA,IAACC,KAC7BA,EAAIC,QACJA,EAAOC,UACPA,EAASC,MACTA,GAEqDN,EADlDR,EAAOe,GAAAP,EAAAV,IAEV,OAAQa,EAAKJ,MACX,KAAKS,EAAgBC,kBACnB,OACEd,EAAAC,cAAA,IAAA,CACEU,MAAOA,EACPD,UAAWK,EACTC,EAAiBN,GACjBD,EAAUA,EAAQQ,MAAST,EAAqBU,aAIxD,KAAKL,EAAgBM,kBACnB,OACEnB,EAAAC,cAAA,MAAA,CACEU,MAAOA,EACPD,UAAWU,EAAcV,EAAWb,EAAQwB,gBAE3CZ,EAAUa,EAAeb,EAAQQ,OAAUT,EAAqBe,MAGvE,KAAKV,EAAgBW,kBACnB,OACExB,EAAAC,cAAA,MAAA,CACEU,MAAOA,EACPD,UAAWU,EAAcV,EAAWb,EAAQ4B,eAC5CC,wBAAyB,CACvBC,OAAQlB,EACJa,EAAeb,EAAQQ,OACtBT,EAAqBoB,QAIlC,KAAKf,EAAgBgB,oBACnB,OACE7B,EAAAC,cAAA,MAAA,KACE,+BAA8BO,EAAuBsB,UAG3D,qBACE,OAAO9B,EAAAC,cAAI,KAAA,KAAA,yBAAuBO,EAAKJ,MAC1C,SAAAE,GAAA,CAAA,oECnEG,SAAUyB,GAAY1B,GAAA,IAAAC,EAAAC,IAAA,IAAA,IAACyB,QAC3BA,EAAOC,QACPA,GAKD5B,EAJIN,EAAKa,GAAAP,EAAAV,IAKR,MAAAuC,EACEC,EAAiBH,IADbf,MAAaA,GAAgCiB,EAAZE,EAAUxB,GAAAsB,EAAAG,IAE3CC,EAAYC,EAAW,IAAMC,EAAOvB,IAK1C,OAJAwB,EACE,IAAMT,EAAQf,MACbyB,GAAOJ,EAAUrB,MAAQuB,EAAOE,iBAGjC1C,EAAAC,cAAA,QAAAE,GAAA,CAAA,EACMiC,EAAU,CACdhC,KAAM6B,EAAQ,GACdhB,MAAOqB,EAAUrB,MACjB0B,SAAWC,IACTN,EAAUrB,MAAQ2B,EAAEC,OAAO5B,MAC3B,MAAM6B,EAAYb,EAAQ,GAAGW,EAAEC,OAAO5B,YACpB8B,IAAdD,IAAyBd,EAAQf,MAAQ6B,EAAAA,GAE3C/C,IAIR,SAASyC,EAAOvB,GACd,OAAgB,MAATA,EAAgB,GAAKgB,EAAQ,GAAGhB,EACzC,CAAC,CAAAX,QAAAA,GASH,CAAA,CAAgB,SAAA0C,GAAsBC,GACpC,OAAQA,GACN,KAAKC,EAAUC,OACb,MAAO,CAAC,OAASC,GAAMA,EAAIA,GAAMA,GACnC,KAAKF,EAAUG,KACb,MAAO,CACL,OACCD,GAAa,SAANA,GAA4B,UAANA,QAAwBL,EACrDK,IAAC,IAAAE,EAAA,cAAAA,EAAKF,MAAAA,OAAAA,EAAAA,EAAGG,YAAUD,EAAI,KAE5B,KAAKJ,EAAUM,IACb,MAAO,CACL,SACCJ,GAAa,KAANA,EAAWK,SAASL,GAAK,KAChCA,GAAY,MAALA,EAAY,GAAKA,GAE7B,KAAKF,EAAUQ,SACb,MAAO,CAAC,iBAAmBN,GAAQA,GAAI,KAAYA,GAAMA,GAC3D,KAAKF,EAAUS,KACb,MAAO,CAAC,OAASP,GAAQA,GAAI,KAAYA,GAAMA,GACjD,KAAKF,EAAUU,KACb,MAAO,CACL,OACCR,IACC,MAAMS,EAAIT,EAAEU,OACZ,OAAU,IAAND,EAAgBT,EAAI,MACd,IAANS,EAAgBT,OAApB,CACOL,EAERK,GAAOA,EAAIA,EAAEW,UAAU,EAAG,GAAK,IAEpC,KAAKb,EAAUc,OACb,MAAO,CACL,SACCZ,GAAa,KAANA,EAAWa,WAAWb,GAAK,KAClCA,GAAY,MAALA,EAAY,GAAKA,GAE7B,QACE,MAAO,CAAC,OAASA,GAAMA,EAAIA,GAAMA,GAEvC,qGC1EgB,SAAAc,GAAqBrE,EAAiC,CAAA,GACpE,OAAOsE,EACL,CAACpE,EAAOqE,KAAOC,IAAAA,eACbrE,OAAAA,EAAAC,cAACqE,GACC5D,CAAAA,UAAWU,EAAcrB,EAAMW,UAAWb,EAAQa,WAClD6D,MAAOxE,EAAMiC,QACbwC,GAAIzE,EAAMyE,GACVC,SAAU1E,EAAM0E,SAChB5E,QAAsBwE,OAAfA,EAAEtE,EAAMF,SAAOwE,EAAI,GAC1BK,SAAU3E,EAAM2E,SAChBC,UAAW9E,EAAQ8E,UACnBC,aAAc/E,EAAQ+E,aACtB3C,QAAS4C,GAAuB9E,EAAM+E,MAAM1E,OAC5C,EAEJ,CACEP,SAAS,GAGf,CAgBgB,SAAAyE,GAAkBjE,GAAA,IAAAC,EAAAC,IAAA,IAAA,IAACgE,MACjCA,EAAK1E,QACLA,EAAOa,UACPA,EAASuB,QACTA,EAAOyC,SACPA,EAAQC,UACRA,EAAY,MAAKC,aACjBA,EAAe,kBAAiBH,SAChCA,GAEwBpE,EADrBN,EAAKa,GAAAP,EAAAV,IAER,MAAMsB,MAAEA,EAAK8D,SAAEA,GAAaR,GACrBS,GAAaC,GAAUP,GAAqB,MAATzD,GACpCiE,EAAkBC,EACtB,IAAMC,OAAOC,YAAYxF,EAAQyF,IAAKC,GAAM,CAACtD,EAAQsD,EAAEtE,OAAQsE,EAAEtE,SACjE,CAACpB,IAEG2F,EAAeL,EACnB,IAAM,IAAIM,IAAI5F,EAAQ6F,OAAQH,GAAMA,EAAEI,OAAOL,IAAKC,GAAMA,EAAEI,QAC1D,CAAC9F,iBAEH,OACEG,EAAAC,cAAA,SAAAE,GACMJ,CAAAA,EAAAA,EACJW,CAAAA,UAAWA,EACXiC,SAAWD,GAAO6B,EAAMtD,MAAQiE,EAAgBxC,EAAEG,OAAO5B,OACzDA,MAAOgB,EAAQhB,GACf8D,SAAUA,GAAYN,IAErBO,gBACChF,EAAAC,cAAA,SAAA,CAAQgB,MAAM,IAAIyD,EAAWE,EAAeD,GAE7C,IAAIa,EAAaI,QAAQN,IAAKC,gBAC7BvF,EAAAC,cAAA,WAAA,CAAU4F,IAAKN,EAAGO,MAAOP,GACtB1F,EAAQ6F,OAAQK,GAAMA,EAAEJ,QAAUJ,GAAGD,IAAIU,KAG7CnG,EAAQ6F,OAAQH,IAAOA,EAAEI,OAAOL,IAAIU,IAIzC,SAASA,EAAaT,EAAgBU,gBACpC,OACEjG,EAAAC,cAAA,SAAA,CAAQ4F,IAAKI,EAAGhF,MAAOgB,EAAQsD,EAAEtE,OAAQ8D,WAAYQ,EAAER,UACpDQ,EAAEW,KAGT,CAAC,CAAA,QAAA5F,GAAA,CAAA,CAGG,SAAUuE,GAAuB5B,GACrC,OAAQA,GACN,KAAKC,EAAUC,OACf,KAAKD,EAAUM,IACf,KAAKN,EAAUc,OACb,OAAQZ,GAAMA,EAChB,QACE,OAAQA,IAAC,IAAAE,EAAA,OAAkB,OAAlBA,EAAM,MAADF,OAAC,EAADA,EAAGG,YAAUD,EAAI,IAErC,CCxFgB,SAAA6C,GAAoBtG,EAAgC,CAAA,GAClE,OAAOsE,EACJiC,gBACCpG,EAAAC,cAACoG,GAAYlG,GACPN,CAAAA,EAAAA,EACAuG,EAAC,CACL1F,UAAWU,EAAcgF,EAAE1F,UAAWb,EAAQa,WAC9C4F,UAAWA,CAACtE,EAAS+D,IAAM/D,EAAQf,OAAS8E,EAAE9E,MAC9CsF,WAAYA,CAACC,EAAGT,IAAOS,EAAEvF,MAAQ8E,EAAE9E,MACnCe,QAASoE,EAAEpE,QACX5B,KAAK,QACLqG,eAAgBC,EAAqBN,MAGzC,CACEO,WAAYC,EAAeC,OAGjC,CAEgB,SAAAC,GAAwBjH,EAAgC,CAAA,GACtE,OAAOsE,EACJiC,gBACCpG,EAAAC,cAACoG,GAAYlG,GACPN,CAAAA,EAAAA,EACAuG,GACJ1F,UAAWU,EAAcgF,EAAE1F,UAAWb,EAAQa,WAC9C4F,UAAWA,CAACtE,EAAS+D,KACnB,MAAMrD,EAAIV,EAAQf,MAClB,QAAO8F,MAAMC,QAAQtE,IAAKA,EAAEuE,SAASlB,EAAE9E,MAAS,EAElDsF,WAAYA,CAACC,EAAGT,EAAGmB,KACjBV,EAAEW,SAAU5B,GAAM6B,GAAY7B,MAAAA,EAAAA,EAAK,GAAIQ,EAAE9E,MAAOiG,GAClD,EACAlF,QAASoE,EAAEpE,QACX5B,KAAK,WACLqG,eAAgBC,EAAqBN,MAGzC,CACEiB,YAAY,EACZV,WAAYC,EAAeU,WAGjC,CAiBgB,SAAAjB,IAAarE,QAC3BA,EAAOnC,QACPA,EAAO0H,WACPA,EAAUC,WACVA,EAAU/C,SACVA,EAAQgD,WACRA,EAAU/G,UACVA,EAAS8D,GACTA,EAAEpE,KACFA,EAAIkG,UACJA,EAASC,WACTA,EAAUE,eACVA,IACkB,IAAAnG,EAAAC,QAClB,MAAMwE,SAAEA,GAAa/C,EACfkE,EAAO,IAAMlE,EAAQ0F,sBAC3B,OACE1H,EAAAC,cAAKS,MAAAA,CAAAA,UAAWA,EAAW8D,GAAIA,gBAC7BxE,EAAAC,cAAC0H,EAAmB,CAACC,MAAO/H,MAAAA,OAAAA,EAAAA,EAAS6F,OAAQH,GAAiB,MAAXA,EAAEtE,QAClD,CAAC8E,EAAGE,KACH,MAAMiB,EAAUW,EAAY,IAAMvB,EAAUtE,EAAS+D,IAAI9E,mBACzD,OACEjB,EAAAC,cAAAD,EAAA8H,SACE9H,kBAAAA,EAAAC,cAAA,MAAA,CAAK4F,IAAKI,EAAGvF,UAAW+G,gBACtBzH,EAAAC,cAAA,QAAA,CACEuE,GAAI0B,EAAO,IAAMD,EACjBvF,UAAW8G,EACXpH,KAAMA,EACN8F,KAAMA,EACN6B,SAAUtD,EACVM,SAAUA,EACVmC,QAASA,EACTvE,SAAW4C,KACRd,GAAY8B,EAAWvE,EAAS+D,EAAGR,EAAE1C,OAAOqE,QAC/C,iBAEFlH,EAAAC,cAAOS,QAAAA,CAAAA,UAAW6G,EAAYS,QAAS9B,EAAO,IAAMD,GACjDF,EAAEG,aAGNO,SAAAA,EAAiBV,EAAGE,EAAGiB,GAC1B,GAKR,CAAA,QAAA5G,GAAA,CAAA,CAGY,SAAA8G,GAAeQ,EAAYK,EAASC,GAElD,OAAIA,IADYN,EAAMX,SAASgB,GAEtBL,EAELM,EACK,IAAIN,EAAOK,GAEbL,EAAMlC,OAAQ9C,GAAMA,IAAMqF,EACnC,CAEgB,SAAAE,GAAuBtI,EAAgC,CAAE,GACvE,OAAOsE,EACL,CAACpE,EAAOqI,IAAchC,GAACjG,GAAA,GAClBiG,EAAC,CACJN,WAAO/C,EACPsF,sBACErI,EAAAC,cAAA,MAAA,CAAKS,UAAWU,EAAcrB,EAAMW,UAAWb,EAAQ4H,0BACrDzH,EAAAC,cAACqI,EAAS,CACR9D,GAAIzE,EAAMyE,GACVxC,QAASjC,EAAMiC,QACfrB,MAAOZ,EAAMY,MACbD,UAAWb,EAAQ2H,aAEpBpB,EAAEN,OAASsC,EAASG,YAAYnC,EAAEN,WAAO/C,OAAWA,MAI3D,CAAE4D,WAAYC,EAAe4B,UAEjC,CCxJgB,SAAAC,IAAcC,WAC5BA,EAAUC,YACVA,EAAe/F,GAAMA,gBAAK5C,EAAAC,cAAKS,MAAAA,CAAAA,UAAWgI,GAAa9F,GACvDgG,QAAQC,WAAEA,EAAUC,aAAEA,EAAYhD,MAAEA,EAAKuC,SAAEA,EAAQU,aAAEA,SAGtDzI,EAAAC,IACC,iBAEA,OACEP,EAAAC,cAAAD,EAAA8H,SACGhC,KAAAA,EACAgD,EACAT,EACAM,EAPMI,KACgBC,QADhBD,EAC6BE,WAAQlG,GAO3C8F,EAEH,CAAA,QAAAvI,GAAA,CAAA,UClBY4I,IAAmBlH,QACjCA,EAAOtB,UACPA,EAASiE,UACTA,EAASwE,gBACTA,EAAerE,MACfA,EAAKnE,MACLA,IAQDL,IAAAA,EAAAC,IAAA,IAAA,IAAAF,EACC,MAAMqC,EAAIV,EAAQf,MACZM,SAAIlB,EACP8I,EAAgBC,aAAatE,EAAOpC,GACjCiC,EACAwE,EAAgB7G,UAAUwC,EAAOpC,IAAErC,EAAK,gBAC9C,OACEL,EAAAC,cAAKU,MAAAA,CAAAA,MAAOA,EAAOD,UAAWU,EAAcV,IACzCa,EAEH,CAAA,QAAAjB,GAAA,CAAA,UCzBY+I,KACd,OAAOC,EAA0BvJ,gBAAUC,EAAAC,cAACsJ,GAAsBxJ,GACpE,CAEgB,SAAAwJ,IAAkBC,WAChCA,EAAUnB,SACVA,EAAQ3H,UACRA,EAASC,MACTA,EAAK8I,OACLA,IACwB,IAAAnJ,EAAAC,IACxB,IAAA,MAAMmC,EAAI8G,EAAWvI,MAMrB,OALAyI,EAAU,KACJhH,GACF8G,EAAWrC,SAAUwC,IAAQ,CAAEC,QAASlH,EAAEkH,QAASC,QAASnH,EAAEkH,UAChE,EACC,CAAE,MAADlH,OAAC,EAADA,EAAGkH,UACC,MAADlH,GAAAA,EAAGkH,qBACR5J,EAAAC,cAAA,MAAA,CAAKS,UAAWK,EAAKL,GAAYC,MAAOA,EAAOmJ,IAAKL,GACjDpB,gBAGHrI,EAAAC,cAAAD,EAAA8H,SAAK,KACL,SAAAxH,GAAA,CAAA,CCfY,SAAAyJ,GAAsBrJ,GACpC,OAAOyD,EACJiC,gBACCpG,EAAAC,cAAC+J,GACCC,CAAAA,cAAe7D,EAAE6D,cACjBvJ,UAAWU,EAAcgF,EAAE1F,UAAWA,GACtCwJ,SAAU9D,EAAE8D,SACZC,YAAa/D,EAAE+D,YACfnI,QAASoE,EAAEpE,QACXyC,SAAU2B,EAAE3B,WAGhB,CAAEkC,WAAYC,EAAewD,SAEjC,CAEgB,SAAAJ,IAAgBhI,QAC9BA,EAAOiI,cACPA,EAAaxF,SACbA,EAAQ/D,UACRA,EAASyJ,YACTA,EAAWD,SACXA,QAQD5J,EAAAC,IAAA,IACC,MAAM8J,EAA+B,MAAzBH,EAASI,aAAuBJ,EAAWC,EAAYI,WAC7DC,EAAW3C,EAAY,MAC3B5G,MAAOe,EAAQf,MACfwD,WACAM,SAAU/C,EAAQ+C,SAClB0F,SAAUN,EAAYM,SACtBC,SAAUC,EAAYT,MAElBU,EAAWC,EACfZ,EAAca,WACdC,EAAgBV,GAAKrI,QACrB2I,EAAYN,GACZG,EACAlJ,gBAEF,OACEtB,EAAAC,cACES,MAAAA,CAAAA,UAAWA,EACXgB,wBAAyB,CAAEC,OAAQiJ,EAAS3J,QAE9C,CAAA,QAAAX,GAAA,CAAA,CClEJ,MAAAX,GAAA,CAAA,UAAA,QAAA,iBAQgB,SAAAqL,KACd,OAAO7G,EACL,CAAA9D,EAA8C4K,KAAaC,IAAAA,EAAAC,EAAA,IAA1DnJ,QAAEA,EAAO8C,MAAEA,GAAgCzE,EAAPN,EAAKa,GAAAP,EAAAV,IACxC,MAAMyL,EAA0C,OAA/BD,GAAID,EAAAlJ,EAAQqJ,MAAkB,aAACF,EAA3BD,EAAA,YAAgCI,GAC1B,MAAzBtJ,EAAQuJ,QAAQtK,OAElB,OAAQ2H,IACN,MAAM4C,EAAYP,EAAUQ,WAAUtL,GAAA,CAAA,EACjCJ,EACHiC,CAAAA,QAASoJ,EACTtG,MAAK3E,MAAO2E,EAAK,CAAE1E,KAAM8C,EAAUG,OACnC4G,cAAe,CAAE7J,KAAMwG,EAAe4B,YAJtByC,CAKfrC,GACH,OAAAzI,GACKqL,CAAAA,EAAAA,EACHnD,CAAAA,sBACErI,EAAAC,cAACyL,GAAW,CACV1J,QAASA,EACToJ,YAAaA,EACb/C,SAAUmD,EAAUnD,SACpB5D,SAAU1E,EAAM0E,SAChBkH,aAAc5L,EAAM6L,WAAWD,gBAIvC,CAAA,EAGN,CAEA,SAASD,IAAYrD,SACnBA,EAAQ+C,YACRA,EAAWpJ,QACXA,EAAO2J,aACPA,EAAYlH,SACZA,IAwBA,OAhBAhC,EACE,IAAMgC,EACLoH,GAAOT,EAAYrG,SAAW8G,GAC/B,GAEFpJ,EACE,IAAM2I,EAAYnK,MACjB2B,IACQ,IAAAkJ,EAAHlJ,EACFZ,EAAQf,MAAwC,OAAnC6K,EAAGV,EAAYC,KAAmB,cAACS,EAAIH,GAEpDP,EAAYC,KAAmB,aAAIrJ,EAAQf,MAC3Ce,EAAQf,MAAQ,KAClB,GAGGoH,CACT,CCpCgB,SAAA0D,GACdC,GAEA,OAAO7H,EACL,CAACpE,EAAOkL,iBAEJjL,EAAAC,cAACgM,GAAiB,CAChBC,UAAWnM,EACXkL,UAAWA,EACXe,eAAgBA,IAItB,CAAErF,WAAYC,EAAeG,MAAOM,YAAY,GAEpD,UAEgB4E,IAAkBC,UAChCA,EAASjB,UACTA,EAASe,eACTA,QAKDG,EACC,MAAMlC,cACJA,EAAajI,QACbA,EAAO8C,MACPA,EAAKL,SACLA,EAAQ2H,WACRA,EAAU1H,SACVA,EAAQ2H,YACRA,EAAWT,WACXA,EAAUlL,UACVA,EAASC,MACTA,EAAK2L,mBACLA,EAAkBnC,YAClBA,GACE+B,GACEK,QAAEA,EAAOC,MAAEA,EAAKC,SAAEA,EAAmBC,WAAEA,GAAeC,EAC1DC,EAAgB3C,GAAiBA,EAAiB,CAAA,EAClD+B,GAEIa,EAAeD,EAAgB3C,GACjCA,EAAc4C,kBACd9J,EAEE+J,GAAmBC,EAAgBjI,GACnCkI,EAAsCF,EAMvC,CACC1M,KAAM6M,EAAsBC,KAC5BpI,MAAO8G,EAAW9G,MAClBuD,SAAUuD,EAAWvD,SACrB4B,cAAe4C,MAAAA,EAAAA,EAAgB,CAAEzM,KAAMwG,EAAeuG,UACtDC,WAAW,GAVZ,CACChN,KAAM6M,EAAsBI,MAC5BhF,SAAUuD,EAAWvD,SACrBiF,aAAc,CAAElN,KAAMmN,EAAgBJ,SAAUC,WAAW,IAU3DI,GAAmC,OAApBrB,EAACP,EAAWvD,UAAQ8D,EAAI,IAAI7G,IAC9CC,GAAM,CAAC+G,EAAmB/G,OAAGxC,GAAW,GAAOwC,IAE5CkI,EAAOC,EAAkBF,EAAejI,GAAMA,EAAE,GAAGkI,MACnDE,EAAQC,GAAoBC,GAAa,CAACJ,IAE1CK,EAAU3N,MACX4N,EAAmB/L,EAAS8C,EAAO,CACpCyH,UACAG,aACAF,QACAC,WACAhI,WACAM,SAAU/C,EAAQ+C,SAClBqH,eACA,CACF1H,WACAsJ,cAAeA,CAAC/H,EAAGgI,iBACjBjO,EAAAC,cAAC0N,EACCO,CAAAA,MAAOjI,EACPkI,mBAAoBA,EACpBhE,YAAaA,EACbqD,aAAcA,EACdS,KAAMA,IAGVvN,UAAWA,QAAwBqC,EACnCpC,SACGyN,EAAsBxC,IAG3B,OAAOX,EAAUoD,YAAYP,GAE7B,SAASK,EAAmBlI,EAAWqI,GAA2BC,IAAAA,EAAAC,EAChE,OAAOnC,SAAWkC,EACA,OADAC,EAChBxM,EAAQyM,eAAQ,EAAhBD,EAAmBvI,GAAGyB,UAAQ6G,EAAItI,EAClC+G,EACAF,EACI,CACExC,aAAcrE,GAEhB,CAAEyI,eAAgBJ,GAE1B,CACF,CAEA,SAAST,IACPK,MAAOjI,EAACkI,mBACRA,EAAkBX,aAClBA,EAAYS,KACZA,EAAI9D,YACJA,IAQA,MAAMmE,EAAcnE,EAAYD,SAAUyE,gBAAgB1I,GACpD2I,EAAWpB,EAAalI,IAC5B,EAAEuJ,EAAMC,KACND,EAAKE,QAAO5O,GAAA,CAAA,EAELgK,EACHI,CAAAA,WAAY+D,EACZpE,SAAU8E,EAAeF,EAAKR,KAEhCO,EAAKtK,OACLtD,OAGN,GADsC,GAAnB2N,EAAS9K,QAAe8K,EAASK,KAAM1J,IAAY,IAANA,GAEhE,OAAO0I,EAAKE,EAAmBlI,EAAGqI,GACpC,CAWgB,SAAAY,GACdrP,GAEA,MAAO,CACLC,OAAQA,CAACC,GAASoP,+BAChBnP,EAAAC,cAACmP,GAAoBjP,GACfJ,CAAAA,EAAAA,EACAF,EACJsP,CAAAA,aAAcA,KAGlB/O,KAAM,QAEV,CAQgB,SAAAgP,GAAqBrP,OAAgCO,EAAAC,IACnE,IAAA,MAAMyN,cACJA,EAAatN,UACbA,EAAS2O,eACTA,EAAcC,WACdA,EAAUC,oBACVA,EAAmBC,kBACnBA,EAAiBC,eACjBA,EAAcC,aACdA,EAAYP,aACZA,EAAYxO,MACZA,GACEZ,GACE4P,UAAEA,EAASC,aAAEA,GAAiBC,EAA6B9P,gBACjE,OACEC,EAAAC,cAAKU,MAAAA,CAAAA,MAAOA,gBACVX,EAAAC,qBAAKS,UAAWK,EAAKL,EAAWkP,GAAgBP,iBAC9CrP,EAAAC,cAAC6P,GAAe9N,CAAAA,QAAS0N,GACtB,CAACK,EAAGxK,IACHyI,EAAczI,EAAI8C,GAChBuH,eACE5P,EAAAC,cAAAD,EAAA8H,SAAA,kBACE9H,EAAAC,cAAKS,MAAAA,CAAAA,UAAWK,EAAKuO,EAAYC,IAC9BlH,gBAEHrI,EAAAC,cAAKS,MAAAA,CAAAA,UAAW8O,GACbL,EAAaS,EAAarK,mBAI/BvF,EAAAC,cAAKS,MAAAA,CAAAA,UAAW4O,GAAajH,MAMtCsH,gBACC3P,EAAAC,cAAA,MAAA,CAAKS,UAAW+O,GAAiBN,EAAaQ,IAGlD,CAAA,QAAArP,GAAA,CAAA,CC3OY,SAAA0P,IAAiB3H,SAC/BA,EAAQ4H,UACRA,EAASC,aACTA,EAAYC,iBACZA,EAAgB/D,WAChBA,EAAUgE,cACVA,EAAaC,gBACbA,EAAe3P,UACfA,EAAS4P,YACTA,EAAeC,GAAMA,EAACC,cACtBA,EAAavF,UACbA,EAASwF,WACTA,QAQiCnQ,EAAAC,IACjC,IAAA,MAAMmQ,EAAOnO,IAAa0N,EAAUU,iBAC9BC,EAASF,EAAKzP,MACd4P,EACJD,GAAUxE,EAAa8D,EAAY/P,GAAQ+P,CAAAA,EAAAA,EAAczP,CAAAA,QAAS,SAC9DqQ,EAAQ7F,EAAU8F,gBAAgBT,EAAYL,EAAUa,MAAOJ,IAC/DM,EAAUR,EACdA,EAAcE,EAAMI,gBAEpB9Q,EAAAC,wBAAQS,UAAWA,EAAWuQ,QAASA,IAAMP,EAAKvJ,SAAU5B,IAAOA,iBACjEvF,EAAAC,cAAOS,QAAAA,CAAAA,UAAW+P,GAAaK,gBAC/B9Q,EAAAC,cAAGS,IAAAA,CAAAA,UAAWK,EAAK6P,EAASR,EAAgBC,mBAIhD,OACErQ,EAAAC,cAAAD,EAAA8H,cACGkJ,eACDhR,EAAAC,cAAA,MAAA,CAAKU,MAAOkQ,EAAkBnQ,UAAWyP,GACtC9H,GAGL,CAAA,QAAA/H,GAAA,CAAA,CC/BY,SAAA4Q,IAAmBlP,QAAEA,EAAOtB,UAAEA,QAA8BJ,EAAAC,IAC1E,IAAA,MAAM4Q,EAAUC,EAA2B,MAW3C,OAVA3O,EACE,IAAMT,EAAQf,MACbyB,IACC,MAAM8D,EAAI2K,EAAQ5F,QACd/E,GAAKA,EAAE6K,cAAgB3O,IACzB8D,EAAE6K,YAAc3O,EAClB,GAEF,gBAGA1C,EAAAC,sBACEqR,iBAAkBtP,EAAQ+C,SAC1BrE,UAAWA,EACX6Q,QAAUhB,GAAOvO,EAAQf,MAAQsP,EAAEiB,cAAcH,YACjDvH,IAAKqH,GAEP,SAAA7Q,GAAA,CAAA,CCoEY,SAAAmR,GACdC,EACA7R,EAAwC,CAAA,GAExC,OAAO8R,EACLD,EACA,EACET,UACAW,aACAlR,YACAC,QACA+Q,WACAG,aACA9M,eACwB,IAAA+M,eACxB,OACE9R,EAAAC,cAAA,SAAA,CACES,UAAWU,EAAcV,EAAWb,EAAQa,WAC5CqE,SAAUA,EACVpE,MAAOA,EACPsQ,QAASA,GAEiDa,OAFzCA,EAEK,MAArBjS,EAAQkS,mBAAa,EAArBlS,EAAQkS,cAAgBH,EAAYF,EAAUG,IAAWC,EACxDF,EACI,EAIhB,CAYgB,SAAAI,GACdnS,GAEA,MAAMa,UACJA,EAASuR,WACTA,EAAaC,EAAiBC,mBAC9BA,EAAqB,EAACC,cACtBA,EAAaC,kBACbA,EAAiBC,cACjBA,EAAaC,eACbA,GACE1S,MAAAA,EAAAA,EAAW,CAAE,EAEjB,SAASqS,GAAkBM,QACzBA,EAAUL,IAEV,MAAO,CACLzR,UAAW0R,EACXzR,MAAO,CACLF,QAAS,OACTgS,oBAAqB,UAAUD,WAGrC,CAuCA,MAAO,CAAEpS,KAAM,QAASN,OAxBxB,SAAgBC,GACd,MAAMsM,YAAEA,EAAWpC,cAAEA,EAAayI,iBAAEA,GAAqB3S,GAEnDY,MAAEA,EAAOD,UAAWiS,GAAQC,EAAe3I,GAC7CgI,EAAWhI,GACX4I,EAAe5I,GAlBrB,SAAoBpK,GAClB,MAAO,CACLa,UAAW4R,EACX3R,MAAO,CACLF,QAAS,OACTqS,IAAKjT,EAAQiT,IAAMjT,EAAQiT,IAAMP,EACjCQ,cAAelT,EAAQmT,UAClBnT,EAAQmT,eACTjQ,GAGV,CAQQkQ,CAAWhJ,GACV,CAAEvJ,UAAW2R,GAEpB,OAAQa,GACN/S,GACK+S,CAAAA,EAAAA,EACH7K,CAAAA,sBACErI,EAAAC,cACES,MAAAA,CAAAA,UAAWU,EAAcrB,EAAMW,UAAWK,EAAKL,EAAWiS,IAC1DhS,MAAOA,GAEU,MAAhB+R,OAAgB,EAAhBA,EAAkBpN,IAAI,CAACkB,EAAGP,IAAMoG,EAAYpG,EAAGO,MAK1D,EAGF,CAEa,MAAA2M,GAAoC,CAC/C,CAAEjN,KAAM,MAAOjF,OAAO,GACtB,CAAEiF,KAAM,KAAMjF,OAAO,IAkBP,SAAAmS,GACdvT,EAAsC,CAAA,GAAE,IAAAwT,EAAAC,EAAAC,EAExC,MAAMC,EAAkBzJ,GAAsBlK,EAAQ4T,cAChDC,EAAc1I,KACd2I,GDlOqCjT,ECmOzCb,EAAQ+T,eDlOHzP,EAAoBiC,gBACzBpG,EAAAC,cAACiR,GAAkB/Q,GACbiG,CAAAA,EAAAA,GACJ1F,UAAWU,EAAcgF,EAAE1F,UAAWA,QAJtC,IAAuCA,ECqO3C,MAAMmT,EAAmB1L,GACH,OADyBkL,EAC7CxT,EAAQiU,cAAYT,EAAIxT,EAAQkU,iBAE5BC,EAAiB9P,GAAqBrE,EAAQoU,eAC9CC,EAAgB/N,GACA,OADmBmN,EACvCzT,EAAQsU,cAAYb,EAAIzT,EAAQiU,cAE5BM,EAAoBtN,GACA,OADuByM,EAC/C1T,EAAQwU,kBAAgBd,EAAI1T,EAAQiU,eAEhCQ,WAAEA,EAAUC,eAAEA,EAAcC,eAAEA,EAAcC,iBAAEA,GAAkBtU,GAAA,CACpEqU,eAAgBR,EAChBO,eAAgBpB,IACbtT,GAEC6U,EAAgB3I,GAA+BlM,EAAQ8U,cAE7D,OAAOxQ,EAAmB,CAACpE,EAAOkL,KAChC,MAAMnG,MAAEA,GAAU/E,EACZ6U,EAAY9P,EAAM1E,KAClB6J,EAAgBlK,EAAMkK,cAC5B,IAAItD,EAAasD,EAAc7J,KAC/B,GACE0E,EAAMuC,YACgB,MAAtBtH,EAAMuK,eACL3D,GAAcC,EAAeuG,UAC5BxG,GAAcC,EAAeG,OAE/B,OAAO2N,EAAc5U,OAAOC,EAAOkL,GAErC,GAAI2J,IAAc1R,EAAU2R,SAAU,CAAAxU,IAAAA,EACpC,MAAMiN,EAEOjN,OAFKA,EAAIyU,EAAoB7K,GACtCA,EAAcqD,kBACdvK,GAAS1C,EAAK,CAAED,KAAM,WAAYgN,WAAW,GACjD,OAAOnC,EAAU8J,YAAW5U,GAAA,CAAA,EAAMJ,EAAK,CAAEkK,cAAeqD,IAC1D,CACA,GAAIsH,GAAa1R,EAAU8R,iBAAK,OAAOhV,EAAAC,cAAAD,EAAA8H,SAAE,KAAA,sBACzC,GAAImN,EAAsBhL,GACxB,OAAQ7D,GAACjG,GACJiG,GAAAA,EACH1F,CAAAA,UAAW+T,EACXpM,sBACErI,EAAAC,cAACiJ,GAAkB,CACjBpE,MAAO/E,EAAM+E,MACbqE,gBAAiBpJ,EAAMoK,YAAYhB,gBACnCnH,QAASjC,EAAMiC,QACftB,UAAWX,EAAMW,UACjBC,MAAOZ,EAAMY,MACbgE,UAAWsF,EAActF,cAKjC,GAAsB,MAAlB4P,GADWK,IAAc1R,EAAUG,MACkB,MAAjBtD,EAAMF,QAC5C,OAAOoL,EAAUQ,WAAUtL,GAAMJ,CAAAA,EAAAA,EAAOF,CAAAA,QAAS0U,KAEnD,GAAI5N,IAAeC,EAAeuG,UAAY+H,EAAWnV,GACvD,OAAOyU,EAAe1U,OAAOC,EAAOkL,GAEtC,OAAQtE,GACN,KAAKC,EAAeuO,WAClB,OAAOzB,EAAY5T,OAAOC,EAAOkL,GACnC,KAAKrE,EAAeU,UAClB,OAAO8M,EAAkBtU,OAAOC,EAAOkL,GACzC,KAAKrE,EAAewO,SAClB,OAAOpB,EAAelU,OAAOC,EAAOkL,GACtC,KAAKrE,EAAeC,MAClB,OAAOqN,EAAcpU,OAAOC,EAAOkL,GACrC,KAAKrE,EAAe4B,SAClB,OAAOqL,EAAiB/T,OAAOC,EAAOkL,GACxC,KAAKrE,EAAewD,QAClB,OAAOoJ,EAAgB1T,OAAOC,EAAOkL,GAEzC,GAAIoK,EAAoBpL,IAAkBA,EAAcqL,UACtD,OAAO3B,EAAkB7T,OAAOC,EAAOkL,GACzC,MAAMsK,EAAcF,EAAoBpL,GACpCA,EAAcsL,iBACdxS,eACJ,OACE/C,EAAAC,cAAC8B,IACCrB,UAAWU,EAAcrB,EAAMW,UAAW4T,GAC1C3T,MAAOZ,EAAMY,MACb6D,GAAIzE,EAAMyE,GACVuD,SAAUhI,EAAM0E,SAChBzC,QAASjC,EAAMiC,QACfuT,YAAwB,MAAXA,EAAAA,OAAexS,EAC5Bd,QAASe,GAAsBjD,EAAM+E,MAAM1E,OAAM,EAIzD,CAmBgB,SAAAoV,GACd3V,EAA2C,CAAA,GAE3C,MAAO,CACLO,KAAM,YACNN,OAAQA,EAAG2V,YAAWrJ,aAAYjC,cAAauL,WAAWzK,KAAe,CACvE0K,MAAQC,IACN,GAAIC,EAAoBJ,IAAcC,EAAS,CAC7C,MAAM7G,EAAO6G,EAAQD,EAAU3K,WAAavF,GAAMA,GAC5CuQ,EAAeC,EAAgB,CAAE9U,MAAO4N,IACxCmH,EAAkBC,EAAYC,EAAiB,CAACJ,IACtD,OAAOK,EAAY5Q,gBACjBvF,EAAAC,cAAC+V,EACC3N,CAAAA,SAAU9C,EACV6Q,cAAejM,EACfsL,UAAWA,IAJRU,CAMJP,GAEH,SAASM,GAAgB7N,SACvBA,EAAQoN,UACRA,EAASW,cACTA,IAMA,MAAMnV,MAAEA,GAAU6U,EAAaM,GAKzBC,EAJYC,EAChBb,EAAU3Q,MACVsR,EAAc7L,YAEavI,QACvBuU,GAAUd,EAAUe,YAQ1B,OAPA/T,EACE,IAAM,CAACxB,MAAAA,OAAAA,EAAAA,EAAOA,MAA4B,OAArBoV,MAAAA,OAAAA,EAAAA,EAAYpV,QACjC,EAAEyB,MACA2T,MAAAA,GAAAA,EAAYlP,SAAU5B,GAAOgR,GAAe,MAALhR,EAAY7C,EAAI6C,KAEzD,GAEK8C,CACT,CACF,CACgC,IAAAoO,EAAhC,OAAIC,EAAgBjB,GACXkB,EACc,OADAF,EACnBhB,EAAUmB,WAASH,EAAII,EAAmBC,0BAC1C9W,EAAAC,cAAA,IAAA,CAAGS,UAAW+U,EAAUvU,YAFnByV,CAGLf,GAEAmB,EAAqBtB,GAChBU,EAAY5Q,gBACjBvF,EAAAC,cAAC+P,GAAgB7P,IACf8K,UAAWA,EACX5C,SAAU9C,EACV0K,UAAWwF,EACXvF,aAAc0F,EAAGjV,MACjBwP,iBAAkByF,EAAGlV,UACrB0L,WAAYA,GACRvM,EAAQoQ,YARTkG,CAUJP,QAXL,CAYA,EAEFoB,SAAU,EACVvB,cAGN,CAEA,SAASwB,GACPpX,EAAwC,CAAE,GAE1C,OAAOqX,EAAqB,CAACnX,EAAOkL,KAClC,MAAMrC,EAASuO,EAAiBhX,GAAA,CAAA,EAEzBJ,EAAK,CACRW,UAAWU,EAAcrB,EAAMW,UAAWb,EAAQa,aAEpDuK,GAEF,MAAO,CACL5C,SAAUO,EAAOuN,wBACfnW,EAAAC,cAACwI,GAAatI,GAAA,CAACyI,OAAQA,GAAY/I,KAErCa,UAAWkI,EAAOlI,UAClBC,MAAOiI,EAAOjI,MACd8I,OAAS7G,GACPA,GAAK7C,EAAMgJ,aACNhJ,EAAMgJ,aAAasC,KAAK+L,cAAgBxU,OACzCG,IAGZ,CAUM,SAAUsU,GACdxX,GAEA,MAAMa,UACJA,EAAS4W,gBACTA,EAAeC,kBACfA,EAAiBC,gBACjBA,EAAeC,eACfA,GACDtX,GACCqX,CAAAA,6BAAiBxX,EAAAC,cAAA,OAAA,KAAO,MACxBwX,eAAiBjR,GAAoBA,GAClC3G,GAEL,MAAO,CACLC,OAAQA,CAACC,EAAO2X,EAAYC,EAAU1M,IAChClL,EAAMK,MAAQwX,EAAUzW,KAAapB,EAAM+F,MACxC2R,eACLzX,EAAAC,cAAAD,EAAA8H,SACE9H,kBAAAA,EAAAC,uBACE+H,QAASjI,EAAM8X,MACfnX,UAAWU,EACTrB,EAAMW,UACNK,EACEL,EACAX,EAAMK,OAASwX,EAAUvK,OAASiK,EAClCvX,EAAMK,OAASwX,EAAUE,SAAWP,KAIvCG,EACAzM,EAAU8F,gBAAgBhR,EAAM+F,OAChC/F,EAAM2E,UAAY8S,GAEpBG,IAIPvX,KAAM,QAEV,CAEgB,SAAA2X,GACdlY,EAAkC,IAElC,MAAO,CACLW,KAAM4S,GAA0BvT,EAAQW,MACxCC,QAASb,GAA6BC,EAAQY,SAC9CuX,OAAQvG,QAA2B1O,EAAWlD,EAAQmY,QACtDpQ,MAAOsH,GAA2BrP,EAAQ+H,OAC1CjC,MAAOqM,GAA2BnS,EAAQ8F,OAC1CG,MAAOuR,GAA2BxX,EAAQiG,OAC1C2P,UAAWD,GAA+B3V,EAAQ4V,WAClDwC,aAAchB,GAA4BpX,EAAQ+I,QAClDY,WAAYH,KAEhB,CAEgB,SAAA6O,KACd,OAAOH,GAAuB,CAC5BnP,OAAQ,CAAElI,UAAW,WACrBiF,MAAO,CAAEjF,UAAW,SACpBkH,MAAO,CAAElH,UAAW,iBACpBsX,OAAQ,CAAEtX,UAAW,UACrBF,KAAM,CAAE8T,WAAY,QACpB7T,QAAS,CAAEgB,cAAe,OAAQJ,cAAe,SAErD,CCjgBa,MAAA8W,GAAuB,CAClCrS,MAAO,CACLwR,gBAAiB,YACjBE,6BAAiBxX,EAAAC,cAAA,OAAA,CAAMS,UAAU,gBAAgB,OAEnDkH,MAAO,CACLyH,eAAgB,iDAChBC,WAAY,YACZG,eAAgB,QAElB9J,MAAO,CACL0M,kBAAmB,sBACnBD,cAAe,kBACfE,cAAe,SAEjB0F,OAAQ,CACNtX,UAAW,4CAEbkI,OAAQ,CACNlI,UAAW,gBACXgI,WAAY,2BAEdlI,KAAM,CACJiU,iBAAkB,mCAClBX,aAAc,CACZpT,UAAW,0BACX+G,WAAY,2BAEdwM,cAAe,CAAEtP,UAAW,YAC5BiP,eAAgB,uCAElB6B,UAAW,CACTxF,UAAW,CACTvP,UAAW,+BACX+P,WAAY,iBACZL,cAAe,mBACfC,gBAAiB"}
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../src/components/DefaultDisplay.tsx","../src/components/ControlInput.tsx","../src/components/SelectDataRenderer.tsx","../src/components/CheckRenderer.tsx","../src/components/DefaultLayout.tsx","../src/components/DefaultDisplayOnly.tsx","../src/components/DefaultAccordion.tsx","../src/components/DefaultVisibility.tsx","../src/components/JsonataRenderer.tsx","../src/components/NullToggle.tsx","../src/components/DefaultArrayRenderer.tsx","../src/components/MultilineTextfield.tsx","../src/createDefaultRenderers.tsx","../src/tailwind.tsx"],"sourcesContent":["import React from \"react\";\nimport clsx from \"clsx\";\nimport {\n coerceToString,\n CustomDisplay,\n DisplayDataType,\n DisplayRendererProps,\n DisplayRendererRegistration,\n getOverrideClass,\n HtmlDisplay,\n IconDisplay,\n rendererClass,\n TextDisplay,\n} from \"@react-typed-forms/schemas\";\n\nexport interface DefaultDisplayRendererOptions {\n textClassName?: string;\n htmlClassName?: string;\n}\n\nexport function createDefaultDisplayRenderer(\n options: DefaultDisplayRendererOptions = {},\n): DisplayRendererRegistration {\n return {\n render: (props) => <DefaultDisplay {...options} {...props} />,\n type: \"display\",\n };\n}\n\nexport function DefaultDisplay({\n data,\n display,\n className,\n style,\n ...options\n}: DefaultDisplayRendererOptions & DisplayRendererProps) {\n switch (data.type) {\n case DisplayDataType.Icon:\n return (\n <i\n style={style}\n className={clsx(\n getOverrideClass(className),\n display ? display.value : (data as IconDisplay).iconClass,\n )}\n />\n );\n case DisplayDataType.Text:\n return (\n <div\n style={style}\n className={rendererClass(className, options.textClassName)}\n >\n {display ? coerceToString(display.value) : (data as TextDisplay).text}\n </div>\n );\n case DisplayDataType.Html:\n return (\n <div\n style={style}\n className={rendererClass(className, options.htmlClassName)}\n dangerouslySetInnerHTML={{\n __html: display\n ? coerceToString(display.value)\n : (data as HtmlDisplay).html,\n }}\n />\n );\n case DisplayDataType.Custom:\n return (\n <div>\n Custom display placeholder: {(data as CustomDisplay).customId}\n </div>\n );\n default:\n return <h1>Unknown display type: {data.type}</h1>;\n }\n}\n","import React from \"react\";\nimport {\n Control,\n formControlProps,\n useControl,\n useControlEffect,\n} from \"@react-typed-forms/core\";\nimport {FieldType} from \"@react-typed-forms/schemas\";\n\nexport function ControlInput({\n control,\n convert,\n ...props\n}: React.InputHTMLAttributes<HTMLInputElement> & {\n control: Control<any>;\n convert: InputConversion;\n}) {\n const { errorText, value, onChange, ...inputProps } =\n formControlProps(control);\n const textValue = useControl(() => toText(value));\n useControlEffect(\n () => control.value,\n (v) => (textValue.value = toText(v)),\n );\n return (\n <input\n {...inputProps}\n type={convert[0]}\n value={textValue.value}\n onChange={(e) => {\n textValue.value = e.target.value;\n const converted = convert[1](e.target.value);\n if (converted !== undefined) control.value = converted;\n }}\n {...props}\n />\n );\n\n function toText(value: any) {\n return value == null ? \"\" : convert[2](value);\n }\n}\n\ntype InputConversion = [\n string,\n (s: string) => any,\n (a: any) => string | number,\n];\n\nexport function createInputConversion(ft: string): InputConversion {\n switch (ft) {\n case FieldType.String:\n return [\"text\", (a) => a, (a) => a];\n case FieldType.Bool:\n return [\n \"text\",\n (a) => (a === \"true\" ? true : a === \"false\" ? false : undefined),\n (a) => a?.toString() ?? \"\",\n ];\n case FieldType.Int:\n return [\n \"number\",\n (a) => (a !== \"\" ? parseInt(a) : null),\n (a) => (a == null ? \"\" : a),\n ];\n case FieldType.DateTime:\n return [\"datetime-local\", (a) => (!a ? null : a), (a) => a];\n case FieldType.Date:\n return [\"date\", (a) => (!a ? null : a), (a) => a];\n case FieldType.Time:\n return [\n \"time\",\n (a) => {\n const l = a.length;\n if (l === 5) return a + \":00\";\n if (l === 8) return a;\n return undefined;\n },\n (a) => (a ? a.substring(0, 5) : \"\"),\n ];\n case FieldType.Double:\n return [\n \"number\",\n (a) => (a !== \"\" ? parseFloat(a) : null),\n (a) => (a == null ? \"\" : a),\n ];\n default:\n return [\"text\", (a) => a, (a) => a];\n }\n}\n","import { Control } from \"@react-typed-forms/core\";\nimport React, { useMemo, useState } from \"react\";\nimport {\n createDataRenderer,\n FieldOption,\n FieldType,\n rendererClass,\n} from \"@react-typed-forms/schemas\";\n\nexport interface SelectRendererOptions {\n className?: string;\n emptyText?: string;\n requiredText?: string;\n}\n\nexport function createSelectRenderer(options: SelectRendererOptions = {}) {\n return createDataRenderer(\n (props, asArray) => (\n <SelectDataRenderer\n className={rendererClass(props.className, options.className)}\n state={props.control}\n id={props.id}\n readonly={props.readonly}\n options={props.options ?? []}\n required={props.required}\n emptyText={options.emptyText}\n requiredText={options.requiredText}\n convert={createSelectConversion(props.field.type)}\n />\n ),\n {\n options: true,\n },\n );\n}\n\ntype SelectConversion = (a: any) => string | number;\n\nexport interface SelectDataRendererProps {\n id?: string;\n className?: string;\n options: FieldOption[];\n emptyText?: string;\n requiredText?: string;\n readonly: boolean;\n required: boolean;\n state: Control<any>;\n convert: SelectConversion;\n}\n\nexport function SelectDataRenderer({\n state,\n options,\n className,\n convert,\n required,\n emptyText = \"N/A\",\n requiredText = \"<please select>\",\n readonly,\n ...props\n}: SelectDataRendererProps) {\n const { value, disabled } = state;\n const [showEmpty] = useState(!required || value == null);\n const optionStringMap = useMemo(\n () => Object.fromEntries(options.map((x) => [convert(x.value), x.value])),\n [options],\n );\n const optionGroups = useMemo(\n () => new Set(options.filter((x) => x.group).map((x) => x.group!)),\n [options],\n );\n return (\n <select\n {...props}\n className={className}\n onChange={(v) => (state.value = optionStringMap[v.target.value])}\n value={convert(value)}\n disabled={disabled || readonly}\n >\n {showEmpty && (\n <option value=\"\">{required ? requiredText : emptyText}</option>\n )}\n {[...optionGroups.keys()].map((x) => (\n <optgroup key={x} label={x}>\n {options.filter((o) => o.group === x).map(renderOption)}\n </optgroup>\n ))}\n {options.filter((x) => !x.group).map(renderOption)}\n </select>\n );\n\n function renderOption(x: FieldOption, i: number) {\n return (\n <option key={i} value={convert(x.value)} disabled={!!x.disabled}>\n {x.name}\n </option>\n );\n }\n}\n\nexport function createSelectConversion(ft: string): SelectConversion {\n switch (ft) {\n case FieldType.String:\n case FieldType.Int:\n case FieldType.Double:\n return (a) => a;\n default:\n return (a) => a?.toString() ?? \"\";\n }\n}\n","import {\n Control,\n Fcheckbox,\n RenderArrayElements,\n useComputed,\n} from \"@react-typed-forms/core\";\nimport React, { ReactNode } from \"react\";\nimport {\n createDataRenderer,\n DataRenderType,\n FieldOption,\n fieldOptionAdornment,\n rendererClass\n} from \"@react-typed-forms/schemas\";\n\nexport interface CheckRendererOptions {\n className?: string;\n entryClass?: string;\n checkClass?: string;\n labelClass?: string;\n}\nexport function createRadioRenderer(options: CheckRendererOptions = {}) {\n return createDataRenderer(\n (p) => (\n <CheckButtons\n {...options}\n {...p}\n className={rendererClass(p.className, options.className)}\n isChecked={(control, o) => control.value == o.value}\n setChecked={(c, o) => (c.value = o.value)}\n control={p.control}\n type=\"radio\"\n entryAdornment={fieldOptionAdornment(p)}\n />\n ),\n {\n renderType: DataRenderType.Radio,\n },\n );\n}\n\nexport function createCheckListRenderer(options: CheckRendererOptions = {}) {\n return createDataRenderer(\n (p) => (\n <CheckButtons\n {...options}\n {...p}\n className={rendererClass(p.className, options.className)}\n isChecked={(control, o) => {\n const v = control.value;\n return Array.isArray(v) ? v.includes(o.value) : false;\n }}\n setChecked={(c, o, checked) => {\n c.setValue((x) => setIncluded(x ?? [], o.value, checked));\n }}\n control={p.control}\n type=\"checkbox\"\n entryAdornment={fieldOptionAdornment(p)}\n />\n ),\n {\n collection: true,\n renderType: DataRenderType.CheckList,\n },\n );\n}\n\nexport interface CheckButtonsProps {\n id?: string;\n className?: string;\n options?: FieldOption[] | null;\n control: Control<any>;\n entryClass?: string;\n checkClass?: string;\n labelClass?: string;\n readonly?: boolean;\n type: \"checkbox\" | \"radio\";\n isChecked: (c: Control<any>, o: FieldOption) => boolean;\n setChecked: (c: Control<any>, o: FieldOption, checked: boolean) => void;\n entryAdornment?: (c: FieldOption, i: number, selected: boolean) => ReactNode;\n}\n\nexport function CheckButtons({\n control,\n options,\n labelClass,\n checkClass,\n readonly,\n entryClass,\n className,\n id,\n type,\n isChecked,\n setChecked,\n entryAdornment,\n}: CheckButtonsProps) {\n const { disabled } = control;\n const name = \"r\" + control.uniqueId;\n return (\n <div className={className} id={id}>\n <RenderArrayElements array={options?.filter((x) => x.value != null)}>\n {(o, i) => {\n const checked = useComputed(() => isChecked(control, o)).value;\n return (\n <>\n <div key={i} className={entryClass}>\n <input\n id={name + \"_\" + i}\n className={checkClass}\n type={type}\n name={name}\n readOnly={readonly}\n disabled={disabled}\n checked={checked}\n onChange={(x) => {\n !readonly && setChecked(control, o, x.target.checked);\n }}\n />\n <label className={labelClass} htmlFor={name + \"_\" + i}>\n {o.name}\n </label>\n </div>\n {entryAdornment?.(o, i, checked)}\n </>\n );\n }}\n </RenderArrayElements>\n </div>\n );\n}\n\nexport function setIncluded<A>(array: A[], elem: A, included: boolean): A[] {\n const already = array.includes(elem);\n if (included === already) {\n return array;\n }\n if (included) {\n return [...array, elem];\n }\n return array.filter((e) => e !== elem);\n}\n\nexport function createCheckboxRenderer(options: CheckRendererOptions = {}) {\n return createDataRenderer(\n (props, renderer) => (p) => ({\n ...p,\n label: undefined,\n children: (\n <div className={rendererClass(props.className, options.entryClass)}>\n <Fcheckbox\n id={props.id}\n control={props.control}\n style={props.style}\n className={options.checkClass}\n />\n {p.label && renderer.renderLabel(p.label, undefined, undefined)}\n </div>\n ),\n }),\n { renderType: DataRenderType.Checkbox },\n );\n}\n","import React, { ReactNode } from \"react\";\nimport {RenderedLayout} from \"@react-typed-forms/schemas\";\n\nexport interface DefaultLayoutRendererOptions {\n className?: string;\n errorClass?: string;\n renderError?: (errorText: string | null | undefined) => ReactNode;\n}\n\nexport function DefaultLayout({\n errorClass,\n renderError = (e) => e && <div className={errorClass}>{e}</div>,\n layout: { controlEnd, controlStart, label, children, errorControl },\n}: DefaultLayoutRendererOptions & {\n layout: RenderedLayout;\n}) {\n const ec = errorControl;\n const errorText = ec && ec.touched ? ec.error : undefined;\n return (\n <>\n {label}\n {controlStart}\n {children}\n {renderError(errorText)}\n {controlEnd}\n </>\n );\n}\n","import { Control } from \"@react-typed-forms/core\";\nimport React from \"react\";\nimport {\n rendererClass,\n SchemaField,\n SchemaInterface,\n} from \"@react-typed-forms/schemas\";\n\nexport function DefaultDisplayOnly({\n control,\n className,\n emptyText,\n schemaInterface,\n field,\n style,\n}: {\n control: Control<any>;\n field: SchemaField;\n schemaInterface: SchemaInterface;\n className?: string | null;\n style?: React.CSSProperties;\n emptyText?: string | null;\n}) {\n const v = control.value;\n const text =\n (schemaInterface.isEmptyValue(field, v)\n ? emptyText\n : schemaInterface.textValue(field, v)) ?? \"\";\n return (\n <div style={style} className={rendererClass(className)}>\n {text}\n </div>\n );\n}\n","import React, { CSSProperties, Fragment, ReactElement } from \"react\";\nimport { Control, useControl } from \"@react-typed-forms/core\";\nimport clsx from \"clsx\";\nimport { DefaultAccordionRendererOptions } from \"../createDefaultRenderers\";\nimport {\n AccordionAdornment,\n ControlDataContext,\n FormRenderer,\n} from \"@react-typed-forms/schemas\";\n\nexport function DefaultAccordion({\n children,\n accordion,\n contentStyle,\n contentClassName,\n designMode,\n iconOpenClass,\n iconClosedClass,\n className,\n renderTitle = (t) => t,\n renderToggler,\n renderers,\n titleClass,\n useCss,\n dataContext,\n}: {\n children: ReactElement;\n accordion: Partial<AccordionAdornment>;\n contentStyle?: CSSProperties;\n contentClassName?: string;\n designMode?: boolean;\n renderers: FormRenderer;\n dataContext: ControlDataContext;\n} & DefaultAccordionRendererOptions) {\n const dataControl = (dataContext.dataNode ?? dataContext.parentNode).control;\n const open = useControl(!!accordion.defaultExpanded);\n if (dataControl && !dataControl.meta.accordionState) {\n dataControl.meta.accordionState = open;\n }\n const isOpen = open.value;\n const fullContentStyle =\n isOpen || designMode ? contentStyle : { ...contentStyle, display: \"none\" };\n const title = renderers.renderLabelText(renderTitle(accordion.title, open));\n const toggler = renderToggler ? (\n renderToggler(open, title)\n ) : (\n <button className={className} onClick={() => open.setValue((x) => !x)}>\n <label className={titleClass}>{title}</label>\n <i className={clsx(isOpen ? iconOpenClass : iconClosedClass)} />\n </button>\n );\n\n return (\n <>\n {toggler}\n {(useCss || isOpen || designMode) && (\n <div style={fullContentStyle} className={contentClassName}>\n {children}\n </div>\n )}\n </>\n );\n}\n\nexport function getAccordionState(\n c: Control<unknown>,\n): Control<boolean> | undefined {\n return c.meta.accordionState;\n}\n","import React, { useEffect } from \"react\";\nimport clsx from \"clsx\";\nimport {\n createVisibilityRenderer,\n VisibilityRendererProps,\n} from \"@react-typed-forms/schemas\";\n\nexport function createDefaultVisibilityRenderer() {\n return createVisibilityRenderer((props) => <DefaultVisibility {...props} />);\n}\n\nexport function DefaultVisibility({\n visibility,\n children,\n className,\n style,\n divRef,\n}: VisibilityRendererProps) {\n const v = visibility.value;\n useEffect(() => {\n if (v) {\n visibility.setValue((ex) => ({ visible: v.visible, showing: v.visible }));\n }\n }, [v?.visible]);\n return v?.visible ? (\n <div className={clsx(className)} style={style} ref={divRef}>\n {children}\n </div>\n ) : (\n <></>\n );\n}\n","import { Control, useComputed } from \"@react-typed-forms/core\";\nimport React from \"react\";\nimport {\n coerceToString,\n ControlDataContext,\n createDataRenderer,\n DataRenderType,\n getJsonPath,\n getRootDataNode,\n JsonataRenderOptions,\n rendererClass,\n SchemaDataNode,\n useJsonataExpression,\n} from \"@react-typed-forms/schemas\";\n\nexport function createJsonataRenderer(className?: string) {\n return createDataRenderer(\n (p) => (\n <JsonataRenderer\n renderOptions={p.renderOptions as JsonataRenderOptions}\n className={rendererClass(p.className, className)}\n dataNode={p.dataNode}\n dataContext={p.dataContext}\n control={p.control}\n readonly={p.readonly}\n />\n ),\n { renderType: DataRenderType.Jsonata },\n );\n}\n\nexport function JsonataRenderer({\n control,\n renderOptions,\n readonly,\n className,\n dataContext,\n dataNode,\n}: {\n control: Control<any>;\n renderOptions: JsonataRenderOptions;\n className?: string;\n dataContext: ControlDataContext;\n dataNode: SchemaDataNode;\n readonly: boolean;\n}) {\n const sdn = dataNode.elementIndex != null ? dataNode : dataContext.parentNode;\n const bindings = useComputed(() => ({\n value: control.value,\n readonly,\n disabled: control.disabled,\n formData: dataContext.formData,\n dataPath: getJsonPath(dataNode),\n }));\n const rendered = useJsonataExpression(\n renderOptions.expression,\n getRootDataNode(sdn).control!,\n getJsonPath(sdn),\n bindings,\n coerceToString,\n );\n return (\n <div\n className={className}\n dangerouslySetInnerHTML={{ __html: rendered.value }}\n />\n );\n}\n","import { Control, newControl, useControlEffect } from \"@react-typed-forms/core\";\nimport React, { ReactNode } from \"react\";\nimport {\n createDataRenderer,\n DataRenderType,\n FieldType,\n} from \"@react-typed-forms/schemas\";\n\nexport function createNullToggleRenderer() {\n return createDataRenderer(\n ({ control, field, renderOptions, ...props }, renderers) => {\n const nullControl = (control.meta[\"nullControl\"] ??= newControl(\n control.current.value != null,\n ));\n return (layout) => {\n const newLayout = renderers.renderData({\n ...props,\n control: nullControl,\n field: { ...field, type: FieldType.Bool },\n renderOptions: { type: DataRenderType.Checkbox },\n })(layout);\n return {\n ...newLayout,\n children: (\n <NullWrapper\n control={control}\n nullControl={nullControl}\n children={newLayout.children}\n readonly={props.readonly}\n defaultValue={props.definition.defaultValue}\n />\n ),\n };\n };\n },\n );\n}\n\nfunction NullWrapper({\n children,\n nullControl,\n control,\n defaultValue,\n readonly,\n}: {\n control: Control<any>;\n nullControl: Control<boolean>;\n children: ReactNode;\n readonly: boolean;\n defaultValue: any;\n}) {\n useControlEffect(\n () => readonly,\n (r) => (nullControl.disabled = r),\n true,\n );\n useControlEffect(\n () => nullControl.value,\n (e) => {\n if (e) {\n control.value = nullControl.meta[\"nonNullValue\"] ?? defaultValue;\n } else {\n nullControl.meta[\"nonNullValue\"] = control.value;\n control.value = null;\n }\n },\n );\n return children;\n}\n","import clsx from \"clsx\";\nimport React, { Fragment, ReactNode } from \"react\";\nimport { RenderElements, useTrackedComponent } from \"@react-typed-forms/core\";\nimport {\n ActionRendererProps,\n applyArrayLengthRestrictions,\n ArrayActionOptions,\n ArrayRendererProps,\n ArrayRendererRegistration,\n ArrayRenderOptions,\n ControlDataContext,\n ControlDefinition,\n ControlDefinitionType,\n createArrayActions,\n createDataRenderer,\n DataControlDefinition,\n DataRendererProps,\n DataRendererRegistration,\n DataRenderType,\n EvalExpressionHook,\n FormRenderer,\n getLengthRestrictions,\n GroupedControlsDefinition,\n GroupRenderType,\n isArrayRenderer,\n isCompoundField,\n lookupDataNode,\n makeHookDepString,\n mergeObjects,\n SchemaDataNode,\n} from \"@react-typed-forms/schemas\";\n\nexport function createDefaultArrayDataRenderer(\n defaultActions?: ArrayActionOptions,\n): DataRendererRegistration {\n return createDataRenderer(\n (props, renderers) => {\n return (\n <DataArrayRenderer\n dataProps={props}\n renderers={renderers}\n defaultActions={defaultActions}\n />\n );\n },\n { renderType: DataRenderType.Array, collection: true },\n );\n}\n\nexport function DataArrayRenderer({\n dataProps,\n renderers,\n defaultActions,\n}: {\n renderers: FormRenderer;\n dataProps: DataRendererProps;\n defaultActions?: ArrayActionOptions;\n}) {\n const {\n renderOptions,\n control,\n field,\n readonly,\n designMode,\n required,\n renderChild,\n definition,\n className,\n style,\n useChildVisibility,\n dataContext,\n } = dataProps;\n const { addText, noAdd, noRemove, noReorder, removeText } = mergeObjects(\n isArrayRenderer(renderOptions) ? renderOptions : ({} as ArrayRenderOptions),\n defaultActions as ArrayRenderOptions,\n );\n const childOptions = isArrayRenderer(renderOptions)\n ? renderOptions.childOptions\n : undefined;\n\n const renderAsElement = !isCompoundField(field);\n const childDefinition: ControlDefinition = !renderAsElement\n ? ({\n type: ControlDefinitionType.Group,\n children: definition.children,\n groupOptions: { type: GroupRenderType.Standard, hideTitle: true },\n } as GroupedControlsDefinition)\n : ({\n type: ControlDefinitionType.Data,\n field: definition.field,\n children: definition.children,\n renderOptions: childOptions ?? { type: DataRenderType.Standard },\n hideTitle: true,\n } as DataControlDefinition);\n\n const visibilities = (definition.children ?? []).map(\n (x) => [useChildVisibility(x, undefined, true), x] as const,\n );\n const deps = makeHookDepString(visibilities, (x) => x[0].deps);\n const Entry = useTrackedComponent(RenderEntry, [deps]);\n\n const arrayProps = {\n ...createArrayActions(control, field, {\n addText,\n removeText,\n noAdd,\n noRemove,\n readonly,\n disabled: control.disabled,\n designMode,\n }),\n required,\n renderElement: (i, wrap) => (\n <Entry\n index={i}\n renderChildElement={renderChildElement}\n dataContext={dataContext}\n visibilities={visibilities}\n wrap={wrap}\n />\n ),\n className: className ? className : undefined,\n style,\n ...getLengthRestrictions(definition),\n } satisfies ArrayRendererProps;\n\n return renderers.renderArray(arrayProps);\n\n function renderChildElement(i: number, elementNode: SchemaDataNode) {\n return renderChild(\n control.elements?.[i].uniqueId ?? i,\n childDefinition,\n renderAsElement\n ? {\n elementIndex: i,\n }\n : { parentDataNode: elementNode },\n );\n }\n}\n\nfunction RenderEntry({\n index: i,\n renderChildElement,\n visibilities,\n wrap,\n dataContext,\n}: {\n index: number;\n renderChildElement: (i: number, element: SchemaDataNode) => ReactNode;\n visibilities: (readonly [EvalExpressionHook<boolean>, ControlDefinition])[];\n dataContext: ControlDataContext;\n wrap: (n: ReactNode) => ReactNode;\n}) {\n const elementNode = dataContext.dataNode!.getChildElement(i);\n const childVis = visibilities.map(\n ([hook, def]) =>\n hook.runHook(\n {\n ...dataContext,\n parentNode: elementNode,\n dataNode: lookupDataNode(def, elementNode),\n },\n hook.state,\n ).value,\n );\n const anyVisible = childVis.length == 0 || childVis.some((x) => x === true);\n if (!anyVisible) return undefined;\n return wrap(renderChildElement(i, elementNode));\n}\n\nexport interface DefaultArrayRendererOptions extends ArrayActionOptions {\n className?: string;\n removableClass?: string;\n childClass?: string;\n removableChildClass?: string;\n removeActionClass?: string;\n addActionClass?: string;\n}\n\nexport function createDefaultArrayRenderer(\n options?: DefaultArrayRendererOptions,\n): ArrayRendererRegistration {\n return {\n render: (props, { renderAction }) => (\n <DefaultArrayRenderer\n {...props}\n {...options}\n renderAction={renderAction}\n />\n ),\n type: \"array\",\n };\n}\n\nexport interface DefaultArrayRendererProps\n extends DefaultArrayRendererOptions,\n ArrayRendererProps {\n renderAction: (props: ActionRendererProps) => ReactNode;\n}\n\nexport function DefaultArrayRenderer(props: DefaultArrayRendererProps) {\n const {\n renderElement,\n className,\n removableClass,\n childClass,\n removableChildClass,\n removeActionClass,\n addActionClass,\n arrayControl,\n renderAction,\n style,\n } = props;\n const { addAction, removeAction } = applyArrayLengthRestrictions(props);\n return (\n <div style={style}>\n <div className={clsx(className, removeAction && removableClass)}>\n <RenderElements control={arrayControl}>\n {(_, x) =>\n renderElement(x, (children) =>\n removeAction ? (\n <>\n <div className={clsx(childClass, removableChildClass)}>\n {children}\n </div>\n <div className={removeActionClass}>\n {renderAction(removeAction(x))}\n </div>\n </>\n ) : (\n <div className={childClass}>{children}</div>\n ),\n )\n }\n </RenderElements>\n </div>\n {addAction && (\n <div className={addActionClass}>{renderAction(addAction)}</div>\n )}\n </div>\n );\n}\n","import React, { useRef } from \"react\";\nimport { useControlEffect } from \"@react-typed-forms/core\";\nimport {\n createDataRenderer,\n DataRendererProps,\n rendererClass,\n} from \"@react-typed-forms/schemas\";\n\nexport function createMultilineFieldRenderer(className?: string) {\n return createDataRenderer((p) => (\n <MultilineTextfield\n {...p}\n className={rendererClass(p.className, className)}\n />\n ));\n}\n\nexport function MultilineTextfield({ control, className }: DataRendererProps) {\n const codeRef = useRef<HTMLElement | null>(null);\n useControlEffect(\n () => control.value,\n (v) => {\n const c = codeRef.current;\n if (c && c.textContent !== v) {\n c.textContent = v;\n }\n },\n true,\n );\n return (\n <code\n contentEditable={!control.disabled}\n className={className}\n onInput={(t) => (control.value = t.currentTarget.textContent)}\n ref={codeRef}\n />\n );\n}\n","import {\n createDefaultDisplayRenderer,\n DefaultDisplayRendererOptions,\n} from \"./components/DefaultDisplay\";\nimport {\n DefaultLayout,\n DefaultLayoutRendererOptions,\n} from \"./components/DefaultLayout\";\nimport { createDefaultVisibilityRenderer } from \"./components/DefaultVisibility\";\nimport React, {\n CSSProperties,\n Fragment,\n ReactElement,\n ReactNode,\n useCallback,\n} from \"react\";\nimport clsx from \"clsx\";\nimport {\n createSelectRenderer,\n SelectRendererOptions,\n} from \"./components/SelectDataRenderer\";\nimport { DefaultDisplayOnly } from \"./components/DefaultDisplayOnly\";\nimport { Control, useControlEffect } from \"@react-typed-forms/core\";\nimport { ControlInput, createInputConversion } from \"./components/ControlInput\";\nimport {\n createDefaultArrayDataRenderer,\n createDefaultArrayRenderer,\n DefaultArrayRendererOptions,\n} from \"./components/DefaultArrayRenderer\";\nimport {\n CheckRendererOptions,\n createCheckboxRenderer,\n createCheckListRenderer,\n createRadioRenderer,\n} from \"./components/CheckRenderer\";\nimport { DefaultAccordion } from \"./components/DefaultAccordion\";\nimport { createNullToggleRenderer } from \"./components/NullToggle\";\nimport { createMultilineFieldRenderer } from \"./components/MultilineTextfield\";\nimport { createJsonataRenderer } from \"./components/JsonataRenderer\";\nimport {\n ActionRendererProps,\n ActionRendererRegistration,\n AdornmentPlacement,\n AdornmentRendererRegistration,\n appendMarkupAt,\n ArrayActionOptions,\n ControlDataContext,\n ControlLayoutProps,\n createActionRenderer,\n createDataRenderer,\n createLayoutRenderer,\n DataRendererRegistration,\n DataRenderType,\n DefaultRenderers,\n FieldOption,\n FieldType,\n FlexRenderer,\n GridRenderer,\n GroupRendererProps,\n GroupRendererRegistration,\n hasOptions,\n isAccordionAdornment,\n isDataGroupRenderer,\n isDisplayOnlyRenderer,\n isFlexRenderer,\n isGridRenderer,\n isIconAdornment,\n isSetFieldAdornment,\n isTextfieldRenderer,\n LabelRendererRegistration,\n LabelType,\n rendererClass,\n renderLayoutParts,\n schemaDataForFieldRef,\n SetFieldAdornment,\n useDynamicHooks,\n wrapLayout,\n} from \"@react-typed-forms/schemas\";\n\nexport interface DefaultRendererOptions {\n data?: DefaultDataRendererOptions;\n display?: DefaultDisplayRendererOptions;\n action?: DefaultActionRendererOptions;\n array?: DefaultArrayRendererOptions;\n group?: DefaultGroupRendererOptions;\n label?: DefaultLabelRendererOptions;\n adornment?: DefaultAdornmentRendererOptions;\n layout?: DefaultLayoutRendererOptions;\n}\n\ninterface StyleProps {\n className?: string;\n style?: CSSProperties;\n}\n\nexport interface DefaultActionRendererOptions {\n className?: string;\n renderContent?: (\n actionText: string,\n actionId: string,\n actionData: any,\n ) => ReactNode;\n}\n\nexport function createButtonActionRenderer(\n actionId: string | string[] | undefined,\n options: DefaultActionRendererOptions = {},\n): ActionRendererRegistration {\n return createActionRenderer(\n actionId,\n ({\n onClick,\n actionText,\n className,\n style,\n actionId,\n actionData,\n disabled,\n }: ActionRendererProps) => {\n return (\n <button\n className={rendererClass(className, options.className)}\n disabled={disabled}\n style={style}\n onClick={onClick}\n >\n {options.renderContent?.(actionText, actionId, actionData) ??\n actionText}\n </button>\n );\n },\n );\n}\n\nexport interface DefaultGroupRendererOptions {\n className?: string;\n standardClassName?: string;\n gridStyles?: (columns: GridRenderer) => StyleProps;\n gridClassName?: string;\n defaultGridColumns?: number;\n flexClassName?: string;\n defaultFlexGap?: string;\n}\n\nexport function createDefaultGroupRenderer(\n options?: DefaultGroupRendererOptions,\n): GroupRendererRegistration {\n const {\n className,\n gridStyles = defaultGridStyles,\n defaultGridColumns = 2,\n gridClassName,\n standardClassName,\n flexClassName,\n defaultFlexGap,\n } = options ?? {};\n\n function defaultGridStyles({\n columns = defaultGridColumns,\n }: GridRenderer): StyleProps {\n return {\n className: gridClassName,\n style: {\n display: \"grid\",\n gridTemplateColumns: `repeat(${columns}, 1fr)`,\n },\n };\n }\n\n function flexStyles(options: FlexRenderer): StyleProps {\n return {\n className: flexClassName,\n style: {\n display: \"flex\",\n gap: options.gap ? options.gap : defaultFlexGap,\n flexDirection: options.direction\n ? (options.direction as any)\n : undefined,\n },\n };\n }\n\n function render(props: GroupRendererProps) {\n const { renderChild, renderOptions, childDefinitions } = props;\n\n const { style, className: gcn } = isGridRenderer(renderOptions)\n ? gridStyles(renderOptions)\n : isFlexRenderer(renderOptions)\n ? flexStyles(renderOptions)\n : ({ className: standardClassName } as StyleProps);\n\n return (cp: ControlLayoutProps) => {\n return {\n ...cp,\n children: (\n <div\n className={rendererClass(props.className, clsx(className, gcn))}\n style={style}\n >\n {childDefinitions?.map((c, i) => renderChild(i, c))}\n </div>\n ),\n };\n };\n }\n\n return { type: \"group\", render };\n}\n\nexport const DefaultBoolOptions: FieldOption[] = [\n { name: \"Yes\", value: true },\n { name: \"No\", value: false },\n];\n\nexport interface DefaultDataRendererOptions {\n inputClass?: string;\n displayOnlyClass?: string;\n selectOptions?: SelectRendererOptions;\n checkboxOptions?: CheckRendererOptions;\n checkOptions?: CheckRendererOptions;\n radioOptions?: CheckRendererOptions;\n checkListOptions?: CheckRendererOptions;\n booleanOptions?: FieldOption[];\n optionRenderer?: DataRendererRegistration;\n multilineClass?: string;\n jsonataClass?: string;\n arrayOptions?: ArrayActionOptions;\n}\n\nexport function createDefaultDataRenderer(\n options: DefaultDataRendererOptions = {},\n): DataRendererRegistration {\n const jsonataRenderer = createJsonataRenderer(options.jsonataClass);\n const nullToggler = createNullToggleRenderer();\n const multilineRenderer = createMultilineFieldRenderer(\n options.multilineClass,\n );\n const checkboxRenderer = createCheckboxRenderer(\n options.checkOptions ?? options.checkboxOptions,\n );\n const selectRenderer = createSelectRenderer(options.selectOptions);\n const radioRenderer = createRadioRenderer(\n options.radioOptions ?? options.checkOptions,\n );\n const checkListRenderer = createCheckListRenderer(\n options.checkListOptions ?? options.checkOptions,\n );\n const { inputClass, booleanOptions, optionRenderer, displayOnlyClass } = {\n optionRenderer: selectRenderer,\n booleanOptions: DefaultBoolOptions,\n ...options,\n };\n const arrayRenderer = createDefaultArrayDataRenderer(options.arrayOptions);\n\n return createDataRenderer((props, renderers) => {\n const { field } = props;\n const fieldType = field.type;\n const renderOptions = props.renderOptions;\n let renderType = renderOptions.type;\n if (\n field.collection &&\n props.elementIndex == null &&\n (renderType == DataRenderType.Standard ||\n renderType == DataRenderType.Array)\n ) {\n return arrayRenderer.render(props, renderers);\n }\n if (fieldType === FieldType.Compound) {\n const groupOptions = (isDataGroupRenderer(renderOptions)\n ? renderOptions.groupOptions\n : undefined) ?? { type: \"Standard\", hideTitle: true };\n return renderers.renderGroup({ ...props, renderOptions: groupOptions });\n }\n if (fieldType == FieldType.Any) return <>No control for Any</>;\n if (isDisplayOnlyRenderer(renderOptions))\n return (p) => ({\n ...p,\n className: displayOnlyClass,\n children: (\n <DefaultDisplayOnly\n field={props.field}\n schemaInterface={props.dataContext.schemaInterface}\n control={props.control}\n className={props.className}\n style={props.style}\n emptyText={renderOptions.emptyText}\n />\n ),\n });\n const isBool = fieldType === FieldType.Bool;\n if (booleanOptions != null && isBool && props.options == null) {\n return renderers.renderData({ ...props, options: booleanOptions });\n }\n if (renderType === DataRenderType.Standard && hasOptions(props)) {\n return optionRenderer.render(props, renderers);\n }\n switch (renderType) {\n case DataRenderType.NullToggle:\n return nullToggler.render(props, renderers);\n case DataRenderType.CheckList:\n return checkListRenderer.render(props, renderers);\n case DataRenderType.Dropdown:\n return selectRenderer.render(props, renderers);\n case DataRenderType.Radio:\n return radioRenderer.render(props, renderers);\n case DataRenderType.Checkbox:\n return checkboxRenderer.render(props, renderers);\n case DataRenderType.Jsonata:\n return jsonataRenderer.render(props, renderers);\n }\n if (isTextfieldRenderer(renderOptions) && renderOptions.multiline)\n return multilineRenderer.render(props, renderers);\n const placeholder = isTextfieldRenderer(renderOptions)\n ? renderOptions.placeholder\n : undefined;\n return (\n <ControlInput\n className={rendererClass(props.className, inputClass)}\n style={props.style}\n id={props.id}\n readOnly={props.readonly}\n control={props.control}\n placeholder={placeholder ?? undefined}\n convert={createInputConversion(props.field.type)}\n />\n );\n });\n}\n\nexport interface DefaultAccordionRendererOptions {\n className?: string;\n titleClass?: string;\n togglerClass?: string;\n iconOpenClass?: string;\n iconClosedClass?: string;\n renderTitle?: (\n title: string | undefined,\n current: Control<boolean>,\n ) => ReactNode;\n renderToggler?: (current: Control<boolean>, title: ReactNode) => ReactNode;\n useCss?: boolean;\n}\n\nexport interface DefaultAdornmentRendererOptions {\n accordion?: DefaultAccordionRendererOptions;\n}\n\nexport function createDefaultAdornmentRenderer(\n options: DefaultAdornmentRendererOptions = {},\n): AdornmentRendererRegistration {\n return {\n type: \"adornment\",\n render: ({ adornment, designMode, dataContext, useExpr }, renderers) => ({\n apply: (rl) => {\n if (isSetFieldAdornment(adornment) && useExpr) {\n const hook = useExpr(adornment.expression, (x) => x);\n const dynamicHooks = useDynamicHooks({ value: hook });\n const SetFieldWrapper = useCallback(setFieldWrapper, [dynamicHooks]);\n return wrapLayout((x) => (\n <SetFieldWrapper\n children={x}\n parentContext={dataContext}\n adornment={adornment}\n />\n ))(rl);\n\n function setFieldWrapper({\n children,\n adornment,\n parentContext,\n }: {\n children: ReactNode;\n adornment: SetFieldAdornment;\n parentContext: ControlDataContext;\n }) {\n const { value } = dynamicHooks(parentContext);\n const fieldNode = schemaDataForFieldRef(\n adornment.field,\n parentContext.parentNode,\n );\n const otherField = fieldNode.control;\n const always = !adornment.defaultOnly;\n useControlEffect(\n () => [value?.value, otherField?.value == null],\n ([v]) => {\n otherField?.setValue((x) => (always || x == null ? v : x));\n },\n true,\n );\n return children;\n }\n }\n if (isIconAdornment(adornment)) {\n return appendMarkupAt(\n adornment.placement ?? AdornmentPlacement.ControlStart,\n <i className={adornment.iconClass} />,\n )(rl);\n }\n if (isAccordionAdornment(adornment)) {\n return wrapLayout((x) => (\n <DefaultAccordion\n renderers={renderers}\n children={x}\n accordion={adornment}\n contentStyle={rl.style}\n contentClassName={rl.className}\n designMode={designMode}\n dataContext={dataContext}\n {...options.accordion}\n />\n ))(rl);\n }\n },\n priority: 0,\n adornment,\n }),\n };\n}\n\nfunction createDefaultLayoutRenderer(\n options: DefaultLayoutRendererOptions = {},\n) {\n return createLayoutRenderer((props, renderers) => {\n const layout = renderLayoutParts(\n {\n ...props,\n className: rendererClass(props.className, options.className),\n },\n renderers,\n );\n return {\n children: layout.wrapLayout(\n <DefaultLayout layout={layout} {...options} />,\n ),\n className: layout.className,\n style: layout.style,\n divRef: (e) =>\n e && props.errorControl\n ? (props.errorControl.meta.scrollElement = e)\n : undefined,\n };\n });\n}\n\ninterface DefaultLabelRendererOptions {\n className?: string;\n groupLabelClass?: string;\n controlLabelClass?: string;\n requiredElement?: ReactNode;\n labelContainer?: (children: ReactElement) => ReactElement;\n}\n\nexport function createDefaultLabelRenderer(\n options?: DefaultLabelRendererOptions,\n): LabelRendererRegistration {\n const {\n className,\n groupLabelClass,\n controlLabelClass,\n requiredElement,\n labelContainer,\n } = {\n requiredElement: <span> *</span>,\n labelContainer: (c: ReactElement) => c,\n ...options,\n };\n return {\n render: (props, labelStart, labelEnd, renderers) => {\n if (props.type == LabelType.Text) return props.label;\n return labelContainer(\n <>\n <label\n htmlFor={props.forId}\n className={rendererClass(\n props.className,\n clsx(\n className,\n props.type === LabelType.Group && groupLabelClass,\n props.type === LabelType.Control && controlLabelClass,\n ),\n )}\n >\n {labelStart}\n {renderers.renderLabelText(props.label)}\n {props.required && requiredElement}\n </label>\n {labelEnd}\n </>,\n );\n },\n type: \"label\",\n };\n}\n\nexport function createDefaultRenderers(\n options: DefaultRendererOptions = {},\n): DefaultRenderers {\n return {\n data: createDefaultDataRenderer(options.data),\n display: createDefaultDisplayRenderer(options.display),\n action: createButtonActionRenderer(undefined, options.action),\n array: createDefaultArrayRenderer(options.array),\n group: createDefaultGroupRenderer(options.group),\n label: createDefaultLabelRenderer(options.label),\n adornment: createDefaultAdornmentRenderer(options.adornment),\n renderLayout: createDefaultLayoutRenderer(options.layout),\n visibility: createDefaultVisibilityRenderer(),\n };\n}\n\nexport function createClassStyledRenderers() {\n return createDefaultRenderers({\n layout: { className: \"control\" },\n group: { className: \"group\" },\n array: { className: \"control-array\" },\n action: { className: \"action\" },\n data: { inputClass: \"data\" },\n display: { htmlClassName: \"html\", textClassName: \"text\" },\n });\n}\n","import React from \"react\";\n\nimport { DefaultRendererOptions } from \"./createDefaultRenderers\";\n\nexport const defaultTailwindTheme = {\n label: {\n groupLabelClass: \"font-bold\",\n requiredElement: <span className=\"text-red-500\"> *</span>,\n },\n array: {\n removableClass: \"grid grid-cols-[1fr_auto] items-center gap-x-2\",\n childClass: \"grow my-2\",\n addActionClass: \"my-2\",\n },\n group: {\n standardClassName: \"flex flex-col gap-4\",\n gridClassName: \"gap-x-2 gap-y-4\",\n flexClassName: \"gap-2\",\n },\n action: {\n className: \"bg-primary-500 rounded-lg p-3 text-white\",\n },\n layout: {\n className: \"flex flex-col\",\n errorClass: \"text-sm text-danger-500\",\n },\n data: {\n displayOnlyClass: \"flex flex-row items-center gap-2\",\n checkOptions: {\n className: \"flex items-center gap-4\",\n entryClass: \"flex gap-1 items-center\",\n },\n selectOptions: { emptyText: \"<select>\" },\n multilineClass: \"border p-2 outline-0 whitespace-pre\",\n },\n adornment: {\n accordion: {\n className: \"flex items-center gap-2 my-2\",\n titleClass: \"cursor-pointer\",\n iconOpenClass: \"fa fa-chevron-up\",\n iconClosedClass: \"fa fa-chevron-down\",\n },\n },\n} satisfies DefaultRendererOptions;\n"],"names":["_excluded","createDefaultDisplayRenderer","options","render","props","React","createElement","DefaultDisplay","_extends","type","_ref","_effect","_useComponentTracking","data","display","className","style","_objectWithoutPropertiesLoose","DisplayDataType","Icon","clsx","getOverrideClass","value","iconClass","Text","rendererClass","textClassName","coerceToString","text","Html","htmlClassName","dangerouslySetInnerHTML","__html","html","Custom","customId","ControlInput","control","convert","_formControlProps","formControlProps","inputProps","_excluded2","textValue","useControl","toText","useControlEffect","v","onChange","e","target","converted","undefined","createInputConversion","ft","FieldType","String","a","Bool","_a$toString","toString","Int","parseInt","DateTime","Date","Time","l","length","substring","Double","parseFloat","createSelectRenderer","createDataRenderer","asArray","_props$options","SelectDataRenderer","state","id","readonly","required","emptyText","requiredText","createSelectConversion","field","disabled","showEmpty","useState","optionStringMap","useMemo","Object","fromEntries","map","x","optionGroups","Set","filter","group","keys","key","label","o","renderOption","i","name","createRadioRenderer","p","CheckButtons","isChecked","setChecked","c","entryAdornment","fieldOptionAdornment","renderType","DataRenderType","Radio","createCheckListRenderer","Array","isArray","includes","checked","setValue","setIncluded","collection","CheckList","labelClass","checkClass","entryClass","uniqueId","RenderArrayElements","array","useComputed","Fragment","readOnly","htmlFor","elem","included","createCheckboxRenderer","renderer","children","Fcheckbox","renderLabel","Checkbox","DefaultLayout","errorClass","renderError","layout","controlEnd","controlStart","errorControl","touched","error","DefaultDisplayOnly","schemaInterface","isEmptyValue","DefaultAccordion","accordion","contentStyle","contentClassName","designMode","iconOpenClass","iconClosedClass","renderTitle","t","renderToggler","renderers","titleClass","useCss","dataContext","_dataContext$dataNode","dataControl","dataNode","parentNode","open","defaultExpanded","meta","accordionState","isOpen","fullContentStyle","title","renderLabelText","toggler","onClick","getAccordionState","createDefaultVisibilityRenderer","createVisibilityRenderer","DefaultVisibility","visibility","divRef","useEffect","ex","visible","showing","ref","createJsonataRenderer","JsonataRenderer","renderOptions","Jsonata","sdn","elementIndex","bindings","formData","dataPath","getJsonPath","rendered","useJsonataExpression","expression","getRootDataNode","createNullToggleRenderer","_control$meta","_control$meta$_nullCo","nullControl","newControl","current","newLayout","renderData","NullWrapper","defaultValue","definition","r","_nullControl$meta$non","createDefaultArrayDataRenderer","defaultActions","DataArrayRenderer","dataProps","_definition$children","renderChild","useChildVisibility","addText","noAdd","noRemove","removeText","mergeObjects","isArrayRenderer","childOptions","renderAsElement","isCompoundField","childDefinition","ControlDefinitionType","Data","Standard","hideTitle","Group","groupOptions","GroupRenderType","visibilities","deps","makeHookDepString","Entry","useTrackedComponent","RenderEntry","arrayProps","createArrayActions","renderElement","wrap","index","renderChildElement","getLengthRestrictions","renderArray","elementNode","_control$elements$i$u","_control$elements","elements","parentDataNode","getChildElement","childVis","hook","def","runHook","lookupDataNode","some","createDefaultArrayRenderer","renderAction","DefaultArrayRenderer","removableClass","childClass","removableChildClass","removeActionClass","addActionClass","arrayControl","addAction","removeAction","applyArrayLengthRestrictions","RenderElements","_","MultilineTextfield","codeRef","useRef","textContent","contentEditable","onInput","currentTarget","createButtonActionRenderer","actionId","createActionRenderer","actionText","actionData","_options$renderConten","renderContent","createDefaultGroupRenderer","gridStyles","defaultGridStyles","defaultGridColumns","gridClassName","standardClassName","flexClassName","defaultFlexGap","columns","gridTemplateColumns","childDefinitions","gcn","isGridRenderer","isFlexRenderer","gap","flexDirection","direction","flexStyles","cp","DefaultBoolOptions","createDefaultDataRenderer","_options$checkOptions","_options$radioOptions","_options$checkListOpt","jsonataRenderer","jsonataClass","nullToggler","multilineRenderer","multilineClass","checkboxRenderer","checkOptions","checkboxOptions","selectRenderer","selectOptions","radioRenderer","radioOptions","checkListRenderer","checkListOptions","inputClass","booleanOptions","optionRenderer","displayOnlyClass","arrayRenderer","arrayOptions","fieldType","Compound","isDataGroupRenderer","renderGroup","Any","isDisplayOnlyRenderer","hasOptions","NullToggle","Dropdown","isTextfieldRenderer","multiline","placeholder","createDefaultAdornmentRenderer","adornment","useExpr","apply","rl","isSetFieldAdornment","dynamicHooks","useDynamicHooks","SetFieldWrapper","useCallback","setFieldWrapper","wrapLayout","parentContext","otherField","schemaDataForFieldRef","always","defaultOnly","_adornment$placement","isIconAdornment","appendMarkupAt","placement","AdornmentPlacement","ControlStart","isAccordionAdornment","priority","createDefaultLayoutRenderer","createLayoutRenderer","renderLayoutParts","scrollElement","createDefaultLabelRenderer","groupLabelClass","controlLabelClass","requiredElement","labelContainer","labelStart","labelEnd","LabelType","forId","Control","createDefaultRenderers","action","renderLayout","createClassStyledRenderers","defaultTailwindTheme"],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@react-typed-forms/schemas-html",
|
|
3
|
-
"version": "1.
|
|
3
|
+
"version": "1.2.0",
|
|
4
4
|
"description": "",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"main": "lib/index.cjs",
|
|
@@ -35,7 +35,7 @@
|
|
|
35
35
|
"clsx": "^1 || ^2",
|
|
36
36
|
"jsonata": "^2.0.4",
|
|
37
37
|
"react": "^18.2.0",
|
|
38
|
-
"@react-typed-forms/schemas": "13.1.
|
|
38
|
+
"@react-typed-forms/schemas": "13.1.4"
|
|
39
39
|
},
|
|
40
40
|
"devDependencies": {
|
|
41
41
|
"@react-typed-forms/transform": "^0.2.0",
|