@dmitryvim/form-builder 0.2.23 → 0.2.24
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/browser/formbuilder.min.js +103 -103
- package/dist/browser/{formbuilder.v0.2.23.min.js → formbuilder.v0.2.24.min.js} +103 -103
- package/dist/cjs/index.cjs +92 -24
- package/dist/cjs/index.cjs.map +1 -1
- package/dist/esm/index.js +85 -24
- package/dist/esm/index.js.map +1 -1
- package/dist/form-builder.js +103 -103
- package/dist/types/types/schema.d.ts +8 -1
- package/dist/types/types/state.d.ts +1 -0
- package/dist/types/utils/helpers.d.ts +14 -0
- package/package.json +1 -1
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
var FormBuilder=(function(
|
|
1
|
+
var FormBuilder=(function(ye){"use strict";function k(e,t,n){const r=t.config.locale||"en",l=t.config.translations[r],a=t.config.translations.en;let o=(l==null?void 0:l[e])||(a==null?void 0:a[e])||e;if(n)for(const[s,i]of Object.entries(n))o=o.replace(new RegExp(`\\{${s}\\}`,"g"),String(i));return o}function pn(e,t,n){(e.minLength!=null||e.maxLength!=null)&&(e.minLength!=null&&e.maxLength!=null?t.push(k("hintLengthRange",n,{min:e.minLength,max:e.maxLength})):e.maxLength!=null?t.push(k("hintMaxLength",n,{max:e.maxLength})):e.minLength!=null&&t.push(k("hintMinLength",n,{min:e.minLength})))}function fn(e,t,n){(e.min!=null||e.max!=null)&&(e.min!=null&&e.max!=null?t.push(k("hintValueRange",n,{min:e.min,max:e.max})):e.max!=null?t.push(k("hintMaxValue",n,{max:e.max})):e.min!=null&&t.push(k("hintMinValue",n,{min:e.min})))}function mn(e,t,n){e.maxSizeMB&&t.push(k("hintMaxSize",n,{size:e.maxSizeMB}))}function hn(e,t,n){var r;(r=e.accept)!=null&&r.extensions&&t.push(k("hintFormats",n,{formats:e.accept.extensions.map(l=>l.toUpperCase()).join(",")}))}function vn(e,t,n){e.pattern&&t.push(k("hintPattern",n,{pattern:e.pattern}))}function ve(e,t){const n=[];return pn(e,n,t),e.type!=="slider"&&fn(e,n,t),mn(e,n,t),hn(e,n,t),vn(e,n,t),n.join(" \u2022 ")}function et(e){const t=[];if(!e||typeof e!="object")return t.push("Schema must be an object"),t;if(!Array.isArray(e.elements))return t.push("Schema missing elements array"),t;if("columns"in e&&e.columns!==void 0){const l=e.columns,a=[1,2,3,4];(!Number.isInteger(l)||!a.includes(l))&&t.push(`schema.columns must be 1, 2, 3, or 4 (got ${l})`)}if("prefillHints"in e&&e.prefillHints){const l=e.prefillHints;Array.isArray(l)&&l.forEach((a,o)=>{if((!a.label||typeof a.label!="string")&&t.push(`schema.prefillHints[${o}] must have a 'label' property of type string`),!a.values||typeof a.values!="object")t.push(`schema.prefillHints[${o}] must have a 'values' property of type object`);else for(const s in a.values)e.elements.some(i=>i.key===s)||t.push(`schema.prefillHints[${o}] references non-existent field "${s}"`)})}function n(l,a){var o,s;const i=new Set;for(const u of l)if(u.type==="richinput"&&u.flatOutput){const f=u,c=(o=f.textKey)!=null?o:"text",m=(s=f.filesKey)!=null?s:"files";for(const p of l)p!==u&&(p.key===c&&t.push(`${a}: RichInput "${u.key}" flatOutput textKey "${c}" collides with element key "${p.key}"`),p.key===m&&t.push(`${a}: RichInput "${u.key}" flatOutput filesKey "${m}" collides with element key "${p.key}"`));i.has(c)&&t.push(`${a}: RichInput "${u.key}" flatOutput textKey "${c}" collides with another flatOutput key`),i.has(m)&&t.push(`${a}: RichInput "${u.key}" flatOutput filesKey "${m}" collides with another flatOutput key`),i.add(c),i.add(m)}else i.has(u.key)&&t.push(`${a}: Element key "${u.key}" collides with a flatOutput richinput key`),i.add(u.key)}function r(l,a){l.forEach((o,s)=>{const i=`${a}[${s}]`;if(o.type||t.push(`${i}: missing type`),o.key||t.push(`${i}: missing key`),o.enableIf){const u=o.enableIf;(!u.key||typeof u.key!="string")&&t.push(`${i}: enableIf must have a 'key' property of type string`),"equals"in u||t.push(`${i}: enableIf must have at least one operator (equals, etc.)`)}if(o.type==="group"&&"elements"in o&&o.elements&&r(o.elements,`${i}.elements`),o.type==="container"&&o.elements){if("columns"in o&&o.columns!==void 0){const u=o.columns,f=[1,2,3,4];(!Number.isInteger(u)||!f.includes(u))&&t.push(`${i}: columns must be 1, 2, 3, or 4 (got ${u})`)}if("prefillHints"in o&&o.prefillHints){const u=o.prefillHints;Array.isArray(u)&&u.forEach((f,c)=>{if((!f.label||typeof f.label!="string")&&t.push(`${i}: prefillHints[${c}] must have a 'label' property of type string`),!f.values||typeof f.values!="object")t.push(`${i}: prefillHints[${c}] must have a 'values' property of type object`);else for(const m in f.values)o.elements.some(p=>p.key===m)||t.push(`container "${o.key}": prefillHints[${c}] references non-existent field "${m}"`)})}r(o.elements,`${i}.elements`),n(o.elements,`${i}.elements`)}if(o.type==="select"&&o.options){const u=o.default;u!=null&&u!==""&&(o.options.some(f=>f.value===u)||t.push(`${i}: default "${u}" not in options`))}})}return Array.isArray(e.elements)&&(r(e.elements,"elements"),n(e.elements,"elements")),t}function je(e){return e&&typeof e=="object"&&e.constructor===Object}function J(e){const t=document.createElement("div");return t.textContent=e,t.innerHTML}function ge(e,t){return e?`${e}.${t}`:t}function pe(e){for(;e.firstChild;)e.removeChild(e.firstChild)}function gn(e){return e<1024?`${e} B`:e<1048576?`${(e/1024).toFixed(1)} KB`:`${(e/1048576).toFixed(1)} MB`}function yt(e){return e==null?"":typeof e=="object"?JSON.stringify(e):String(e)}function xt(e){if(e==="")return null;try{return JSON.parse(e)}catch(t){return e}}function qe(e,t){const n=document.createElement("input");return n.type="hidden",n.name=e,n.setAttribute("data-hidden-field","true"),n.value=yt(t),n}function tt(e,t){if(!e||typeof e!="object")return;const n=t.match(/[^.[\]]+|\[\d+\]/g);if(!n||n.length===0)return;let r=e;for(const l of n){if(r==null)return;if(l.startsWith("[")&&l.endsWith("]")){const a=parseInt(l.slice(1,-1),10);if(!Array.isArray(r)||isNaN(a))return;r=r[a]}else r=r[l]}return r}function $e(e,t,n){var r;if(!e||!e.key)throw new Error("Invalid enableIf condition: must have a 'key' property");const l=(r=e.scope)!=null?r:"relative";let a;if(l==="relative")a=n!=null?n:t;else if(l==="absolute")a=t;else throw new Error(`Invalid enableIf scope: must be "relative" or "absolute" (got "${l}")`);const o=tt(a,e.key);if("equals"in e)return bn(o,e.equals);throw new Error("Invalid enableIf condition: no recognized operator (equals, etc.)")}function bn(e,t){if(e===t)return!0;if(e==null||t==null)return e===t;if(typeof e!=typeof t)return!1;if(typeof e=="object"&&typeof t=="object")try{return JSON.stringify(e)===JSON.stringify(t)}catch(n){if(n instanceof TypeError&&(n.message.includes("circular")||n.message.includes("cyclic")))return console.warn("deepEqual: Circular reference detected in enableIf comparison, using reference equality"),e===t;throw n}return e===t}function ze(e,t,n=!1){const r=document.createElement("span");r.className="char-counter",r.style.cssText=`
|
|
2
2
|
position: absolute;
|
|
3
3
|
${n?"bottom: 8px":"top: 50%; transform: translateY(-50%)"};
|
|
4
4
|
right: 10px;
|
|
@@ -7,7 +7,7 @@ var FormBuilder=(function(be){"use strict";function k(e,t,n){const r=t.config.lo
|
|
|
7
7
|
pointer-events: none;
|
|
8
8
|
background: var(--fb-background-color);
|
|
9
9
|
padding: 0 4px;
|
|
10
|
-
`;const l=()=>{const a=t.value.length,o=e.minLength,
|
|
10
|
+
`;const l=()=>{const a=t.value.length,o=e.minLength,s=e.maxLength;if(o==null&&s==null){r.textContent="";return}a===0||o!=null&&a<o?(o!=null&&s!=null?r.textContent=`${o}-${s}`:s!=null?r.textContent=`\u2264${s}`:o!=null&&(r.textContent=`\u2265${o}`),r.style.color="var(--fb-text-secondary-color)"):s!=null&&a>s?(r.textContent=`${a}/${s}`,r.style.color="var(--fb-error-color)"):(s!=null?r.textContent=`${a}/${s}`:r.textContent=`${a}`,r.style.color="var(--fb-text-secondary-color)")};return t.addEventListener("input",l),l(),r}function yn(e,t,n,r){const l=t.state,a=document.createElement("div");a.style.cssText="position: relative;";const o=document.createElement("input");if(o.type="text",o.className="w-full rounded-lg",o.style.cssText=`
|
|
11
11
|
padding: var(--fb-input-padding-y) var(--fb-input-padding-x);
|
|
12
12
|
padding-right: 60px;
|
|
13
13
|
border: var(--fb-border-width) solid var(--fb-border-color);
|
|
@@ -19,7 +19,7 @@ var FormBuilder=(function(be){"use strict";function k(e,t,n){const r=t.config.lo
|
|
|
19
19
|
transition: all var(--fb-transition-duration) ease-in-out;
|
|
20
20
|
width: 100%;
|
|
21
21
|
box-sizing: border-box;
|
|
22
|
-
`,o.name=r,o.placeholder=e.placeholder||"\u0412\u0432\u0435\u0434\u0438\u0442\u0435 \u0442\u0435\u043A\u0441\u0442",o.value=t.prefill[e.key]||e.default||"",o.readOnly=l.config.readonly,l.config.readonly||(o.addEventListener("focus",()=>{o.style.borderColor="var(--fb-border-focus-color)",o.style.outline="var(--fb-focus-ring-width) solid var(--fb-focus-ring-color)",o.style.outlineOffset="0"}),o.addEventListener("blur",()=>{o.style.borderColor="var(--fb-border-color)",o.style.outline="none"}),o.addEventListener("mouseenter",()=>{document.activeElement!==o&&(o.style.borderColor="var(--fb-border-hover-color)")}),o.addEventListener("mouseleave",()=>{document.activeElement!==o&&(o.style.borderColor="var(--fb-border-color)")})),!l.config.readonly&&t.instance){const
|
|
22
|
+
`,o.name=r,o.placeholder=e.placeholder||"\u0412\u0432\u0435\u0434\u0438\u0442\u0435 \u0442\u0435\u043A\u0441\u0442",o.value=t.prefill[e.key]||e.default||"",o.readOnly=l.config.readonly,l.config.readonly||(o.addEventListener("focus",()=>{o.style.borderColor="var(--fb-border-focus-color)",o.style.outline="var(--fb-focus-ring-width) solid var(--fb-focus-ring-color)",o.style.outlineOffset="0"}),o.addEventListener("blur",()=>{o.style.borderColor="var(--fb-border-color)",o.style.outline="none"}),o.addEventListener("mouseenter",()=>{document.activeElement!==o&&(o.style.borderColor="var(--fb-border-hover-color)")}),o.addEventListener("mouseleave",()=>{document.activeElement!==o&&(o.style.borderColor="var(--fb-border-color)")})),!l.config.readonly&&t.instance){const s=()=>{const i=o.value===""?null:o.value;t.instance.triggerOnChange(r,i)};o.addEventListener("blur",s),o.addEventListener("input",s)}if(a.appendChild(o),!l.config.readonly&&(e.minLength!=null||e.maxLength!=null)){const s=ze(e,o,!1);a.appendChild(s)}n.appendChild(a)}function xn(e,t,n,r){var l,a;const o=t.state,s=t.prefill[e.key]||[],i=Array.isArray(s)?[...s]:[],u=(l=e.minCount)!=null?l:1,f=(a=e.maxCount)!=null?a:1/0;for(;i.length<u;)i.push(e.default||"");const c=document.createElement("div");c.className="space-y-2",n.appendChild(c);function m(){c.querySelectorAll(".multiple-text-item").forEach((d,y)=>{const g=d.querySelector("input");g&&(g.name=`${r}[${y}]`)})}function p(d="",y=-1){const g=document.createElement("div");g.className="multiple-text-item flex items-center gap-2";const E=document.createElement("div");E.style.cssText="position: relative; flex: 1;";const C=document.createElement("input");if(C.type="text",C.style.cssText=`
|
|
23
23
|
padding: var(--fb-input-padding-y) var(--fb-input-padding-x);
|
|
24
24
|
padding-right: 60px;
|
|
25
25
|
border: var(--fb-border-width) solid var(--fb-border-color);
|
|
@@ -31,27 +31,27 @@ var FormBuilder=(function(be){"use strict";function k(e,t,n){const r=t.config.lo
|
|
|
31
31
|
transition: all var(--fb-transition-duration) ease-in-out;
|
|
32
32
|
width: 100%;
|
|
33
33
|
box-sizing: border-box;
|
|
34
|
-
`,C.placeholder=e.placeholder||k("placeholderText",o),C.value=d,C.readOnly=o.config.readonly,o.config.readonly||(C.addEventListener("focus",()=>{C.style.borderColor="var(--fb-border-focus-color)",C.style.outline="var(--fb-focus-ring-width) solid var(--fb-focus-ring-color)",C.style.outlineOffset="0"}),C.addEventListener("blur",()=>{C.style.borderColor="var(--fb-border-color)",C.style.outline="none"}),C.addEventListener("mouseenter",()=>{document.activeElement!==C&&(C.style.borderColor="var(--fb-border-hover-color)")}),C.addEventListener("mouseleave",()=>{document.activeElement!==C&&(C.style.borderColor="var(--fb-border-color)")})),!o.config.readonly&&t.instance){const w=()=>{const S=C.value===""?null:C.value;t.instance.triggerOnChange(C.name,S)};C.addEventListener("blur",w),C.addEventListener("input",w)}if(E.appendChild(C),!o.config.readonly&&(e.minLength!=null||e.maxLength!=null)){const w=
|
|
34
|
+
`,C.placeholder=e.placeholder||k("placeholderText",o),C.value=d,C.readOnly=o.config.readonly,o.config.readonly||(C.addEventListener("focus",()=>{C.style.borderColor="var(--fb-border-focus-color)",C.style.outline="var(--fb-focus-ring-width) solid var(--fb-focus-ring-color)",C.style.outlineOffset="0"}),C.addEventListener("blur",()=>{C.style.borderColor="var(--fb-border-color)",C.style.outline="none"}),C.addEventListener("mouseenter",()=>{document.activeElement!==C&&(C.style.borderColor="var(--fb-border-hover-color)")}),C.addEventListener("mouseleave",()=>{document.activeElement!==C&&(C.style.borderColor="var(--fb-border-color)")})),!o.config.readonly&&t.instance){const w=()=>{const S=C.value===""?null:C.value;t.instance.triggerOnChange(C.name,S)};C.addEventListener("blur",w),C.addEventListener("input",w)}if(E.appendChild(C),!o.config.readonly&&(e.minLength!=null||e.maxLength!=null)){const w=ze(e,C,!1);E.appendChild(w)}return g.appendChild(E),y===-1?c.appendChild(g):c.insertBefore(g,c.children[y]),m(),g}function h(){if(o.config.readonly)return;const d=c.querySelectorAll(".multiple-text-item"),y=d.length;d.forEach(g=>{let E=g.querySelector(".remove-item-btn");E||(E=document.createElement("button"),E.type="button",E.className="remove-item-btn px-2 py-1 rounded",E.style.cssText=`
|
|
35
35
|
color: var(--fb-error-color);
|
|
36
36
|
background-color: transparent;
|
|
37
37
|
transition: background-color var(--fb-transition-duration);
|
|
38
|
-
`,E.innerHTML="\u2715",E.addEventListener("mouseenter",()=>{E.style.backgroundColor="var(--fb-background-hover-color)"}),E.addEventListener("mouseleave",()=>{E.style.backgroundColor="transparent"}),E.onclick=()=>{const w=Array.from(
|
|
38
|
+
`,E.innerHTML="\u2715",E.addEventListener("mouseenter",()=>{E.style.backgroundColor="var(--fb-background-hover-color)"}),E.addEventListener("mouseleave",()=>{E.style.backgroundColor="transparent"}),E.onclick=()=>{const w=Array.from(c.children).indexOf(g);c.children.length>u&&(i.splice(w,1),g.remove(),m(),x(),h())},g.appendChild(E));const C=y<=u;E.disabled=C,E.style.opacity=C?"0.5":"1",E.style.pointerEvents=C?"none":"auto"})}let v=null,b=null;if(!o.config.readonly){v=document.createElement("div"),v.className="flex items-center gap-3 mt-2";const d=document.createElement("button");d.type="button",d.className="add-text-btn px-3 py-1 rounded",d.style.cssText=`
|
|
39
39
|
color: var(--fb-primary-color);
|
|
40
40
|
border: var(--fb-border-width) solid var(--fb-primary-color);
|
|
41
41
|
background-color: transparent;
|
|
42
42
|
font-size: var(--fb-font-size);
|
|
43
43
|
transition: all var(--fb-transition-duration);
|
|
44
|
-
`,d.textContent="+",d.addEventListener("mouseenter",()=>{d.style.backgroundColor="var(--fb-background-hover-color)"}),d.addEventListener("mouseleave",()=>{d.style.backgroundColor="transparent"}),d.onclick=()=>{i.push(e.default||""),p(e.default||""),x(),h()},b=document.createElement("span"),b.className="text-sm text-gray-500",v.appendChild(d),v.appendChild(b),n.appendChild(v)}function x(){if(!v||!b)return;const d=v.querySelector(".add-text-btn");if(d){const y=i.length>=f;d.disabled=y,d.style.opacity=y?"0.5":"1",d.style.pointerEvents=y?"none":"auto"}b.textContent=`${i.length}/${f===1/0?"\u221E":f}`}i.forEach(d=>p(d)),x(),h()}function
|
|
44
|
+
`,d.textContent="+",d.addEventListener("mouseenter",()=>{d.style.backgroundColor="var(--fb-background-hover-color)"}),d.addEventListener("mouseleave",()=>{d.style.backgroundColor="transparent"}),d.onclick=()=>{i.push(e.default||""),p(e.default||""),x(),h()},b=document.createElement("span"),b.className="text-sm text-gray-500",v.appendChild(d),v.appendChild(b),n.appendChild(v)}function x(){if(!v||!b)return;const d=v.querySelector(".add-text-btn");if(d){const y=i.length>=f;d.disabled=y,d.style.opacity=y?"0.5":"1",d.style.pointerEvents=y?"none":"auto"}b.textContent=`${i.length}/${f===1/0?"\u221E":f}`}i.forEach(d=>p(d)),x(),h()}function Et(e,t,n){var r,l,a;const o=[],{scopeRoot:s,skipValidation:i}=n,u=(c,m)=>{var p,h;if(!c)return;const v=`error-${c.getAttribute("name")||Math.random().toString(36).substring(7)}`;let b=document.getElementById(v);m?(c.classList.add("invalid"),c.title=m,b||(b=document.createElement("div"),b.id=v,b.className="error-message",b.style.cssText=`
|
|
45
45
|
color: var(--fb-error-color);
|
|
46
46
|
font-size: var(--fb-font-size-small);
|
|
47
47
|
margin-top: 0.25rem;
|
|
48
|
-
`,
|
|
48
|
+
`,c.nextSibling?(p=c.parentNode)==null||p.insertBefore(b,c.nextSibling):(h=c.parentNode)==null||h.appendChild(b)),b.textContent=m,b.style.display="block"):(c.classList.remove("invalid"),c.title="",b&&b.remove())},f=(c,m,p)=>{let h=!1;const{state:v}=n;if(!i&&m){if(e.minLength!==void 0&&e.minLength!==null&&m.length<e.minLength){const b=k("minLength",v,{min:e.minLength});o.push(`${p}: ${b}`),u(c,b),h=!0}else if(e.maxLength!==void 0&&e.maxLength!==null&&m.length>e.maxLength){const b=k("maxLength",v,{max:e.maxLength});o.push(`${p}: ${b}`),u(c,b),h=!0}else if(e.pattern)try{if(!new RegExp(e.pattern).test(m)){const b=k("patternMismatch",v);o.push(`${p}: ${b}`),u(c,b),h=!0}}catch(b){const x=k("invalidPattern",v);o.push(`${p}: ${x}`),u(c,x),h=!0}}h||u(c,null)};if(e.multiple){const c=s.querySelectorAll(`[name^="${t}["]`),m=[],p=[];if(c.forEach((h,v)=>{var b;const x=(b=h==null?void 0:h.value)!=null?b:"";p.push(x),m.push(x===""?null:x),f(h,x,`${t}[${v}]`)}),!i){const{state:h}=n,v=(r=e.minCount)!=null?r:1,b=(l=e.maxCount)!=null?l:1/0,x=p.filter(d=>d.trim()!=="");e.required&&x.length===0&&o.push(`${t}: ${k("required",h)}`),x.length<v&&o.push(`${t}: ${k("minItems",h,{min:v})}`),x.length>b&&o.push(`${t}: ${k("maxItems",h,{max:b})}`)}return{value:m,errors:o}}else{const c=s.querySelector(`[name$="${t}"]`),m=(a=c==null?void 0:c.value)!=null?a:"";if(!i&&e.required&&m===""){const p=k("required",n.state);return o.push(`${t}: ${p}`),u(c,p),{value:null,errors:o}}return c&&f(c,m,t),{value:m===""?null:m,errors:o}}}function Ct(e,t,n,r){const{scopeRoot:l}=r;if(e.multiple){if(!Array.isArray(n)){console.warn(`updateTextField: Expected array for multiple field "${t}", got ${typeof n}`);return}const a=l.querySelectorAll(`[name^="${t}["]`);a.forEach((o,s)=>{s<n.length&&(o.value=n[s]!=null?String(n[s]):"",o.classList.remove("invalid"),o.title="")}),n.length!==a.length&&console.warn(`updateTextField: Multiple field "${t}" has ${a.length} inputs but received ${n.length} values. Consider re-rendering for add/remove.`)}else{const a=l.querySelector(`[name="${t}"]`);a&&(a.value=n!=null?String(n):"",a.classList.remove("invalid"),a.title="")}}function wt(e){e.style.overflow="hidden",e.style.resize="none";const t=(e.value.match(/\n/g)||[]).length+1;e.rows=Math.max(1,t);const n=()=>{e.isConnected&&(e.style.height="0",e.style.height=`${e.scrollHeight}px`)};e.addEventListener("input",n),setTimeout(()=>{e.isConnected&&n()},0)}function En(e,t,n,r){const l=t.state,a=document.createElement("div");a.style.cssText="position: relative;";const o=document.createElement("textarea");if(o.className="w-full px-3 py-2 border border-gray-300 rounded-lg focus:ring-2 focus:ring-blue-500 focus:border-blue-500 resize-none",o.style.cssText="padding-bottom: 24px;",o.name=r,o.placeholder=e.placeholder||"\u0412\u0432\u0435\u0434\u0438\u0442\u0435 \u0442\u0435\u043A\u0441\u0442",o.rows=e.rows||4,o.value=t.prefill[e.key]||e.default||"",o.readOnly=l.config.readonly,!l.config.readonly&&t.instance){const s=()=>{const i=o.value===""?null:o.value;t.instance.triggerOnChange(r,i)};o.addEventListener("blur",s),o.addEventListener("input",s)}if((e.autoExpand||l.config.readonly)&&wt(o),a.appendChild(o),!l.config.readonly&&(e.minLength!=null||e.maxLength!=null)){const s=ze(e,o,!0);a.appendChild(s)}n.appendChild(a)}function Cn(e,t,n,r){var l,a;const o=t.state,s=t.prefill[e.key]||[],i=Array.isArray(s)?[...s]:[],u=(l=e.minCount)!=null?l:1,f=(a=e.maxCount)!=null?a:1/0;for(;i.length<u;)i.push(e.default||"");const c=document.createElement("div");c.className="space-y-2",n.appendChild(c);function m(){c.querySelectorAll(".multiple-textarea-item").forEach((d,y)=>{const g=d.querySelector("textarea");g&&(g.name=`${r}[${y}]`)})}function p(d="",y=-1){const g=document.createElement("div");g.className="multiple-textarea-item";const E=document.createElement("div");E.style.cssText="position: relative;";const C=document.createElement("textarea");if(C.className="w-full px-3 py-2 border border-gray-300 rounded-lg focus:ring-2 focus:ring-blue-500 focus:border-blue-500 resize-none",C.style.cssText="padding-bottom: 24px;",C.placeholder=e.placeholder||k("placeholderText",o),C.rows=e.rows||4,C.value=d,C.readOnly=o.config.readonly,!o.config.readonly&&t.instance){const w=()=>{const S=C.value===""?null:C.value;t.instance.triggerOnChange(C.name,S)};C.addEventListener("blur",w),C.addEventListener("input",w)}if((e.autoExpand||o.config.readonly)&&wt(C),E.appendChild(C),!o.config.readonly&&(e.minLength!=null||e.maxLength!=null)){const w=ze(e,C,!0);E.appendChild(w)}return g.appendChild(E),y===-1?c.appendChild(g):c.insertBefore(g,c.children[y]),m(),g}function h(){if(o.config.readonly)return;const d=c.querySelectorAll(".multiple-textarea-item"),y=d.length;d.forEach(g=>{let E=g.querySelector(".remove-item-btn");E||(E=document.createElement("button"),E.type="button",E.className="remove-item-btn mt-1 px-2 py-1 text-red-600 hover:bg-red-50 rounded text-sm",E.innerHTML="\u2715",E.onclick=()=>{const w=Array.from(c.children).indexOf(g);c.children.length>u&&(i.splice(w,1),g.remove(),m(),x(),h())},g.appendChild(E));const C=y<=u;E.disabled=C,E.style.opacity=C?"0.5":"1",E.style.pointerEvents=C?"none":"auto"})}let v=null,b=null;if(!o.config.readonly){v=document.createElement("div"),v.className="flex items-center gap-3 mt-2";const d=document.createElement("button");d.type="button",d.className="add-textarea-btn px-3 py-1 rounded",d.style.cssText=`
|
|
49
49
|
color: var(--fb-primary-color);
|
|
50
50
|
border: var(--fb-border-width) solid var(--fb-primary-color);
|
|
51
51
|
background-color: transparent;
|
|
52
52
|
font-size: var(--fb-font-size);
|
|
53
53
|
transition: all var(--fb-transition-duration);
|
|
54
|
-
`,d.textContent="+",d.addEventListener("mouseenter",()=>{d.style.backgroundColor="var(--fb-background-hover-color)"}),d.addEventListener("mouseleave",()=>{d.style.backgroundColor="transparent"}),d.onclick=()=>{i.push(e.default||""),p(e.default||""),x(),h()},b=document.createElement("span"),b.className="text-sm text-gray-500",v.appendChild(d),v.appendChild(b),n.appendChild(v)}function x(){if(!v||!b)return;const d=v.querySelector(".add-textarea-btn");if(d){const y=i.length>=f;d.disabled=y,d.style.opacity=y?"0.5":"1",d.style.pointerEvents=y?"none":"auto"}b.textContent=`${i.length}/${f===1/0?"\u221E":f}`}i.forEach(d=>p(d)),x(),h()}function
|
|
54
|
+
`,d.textContent="+",d.addEventListener("mouseenter",()=>{d.style.backgroundColor="var(--fb-background-hover-color)"}),d.addEventListener("mouseleave",()=>{d.style.backgroundColor="transparent"}),d.onclick=()=>{i.push(e.default||""),p(e.default||""),x(),h()},b=document.createElement("span"),b.className="text-sm text-gray-500",v.appendChild(d),v.appendChild(b),n.appendChild(v)}function x(){if(!v||!b)return;const d=v.querySelector(".add-textarea-btn");if(d){const y=i.length>=f;d.disabled=y,d.style.opacity=y?"0.5":"1",d.style.pointerEvents=y?"none":"auto"}b.textContent=`${i.length}/${f===1/0?"\u221E":f}`}i.forEach(d=>p(d)),x(),h()}function wn(e,t,n){return Et(e,t,n)}function kn(e,t,n,r){Ct(e,t,n,r);const{scopeRoot:l,state:a}=r;if(e.autoExpand||a.config.readonly)if(e.multiple)l.querySelectorAll(`textarea[name^="${t}["]`).forEach(o=>{o.dispatchEvent(new Event("input"))});else{const o=l.querySelector(`textarea[name="${t}"]`);o&&o.dispatchEvent(new Event("input"))}}function kt(e,t){const n=document.createElement("span");n.className="number-range-hint",n.style.cssText=`
|
|
55
55
|
position: absolute;
|
|
56
56
|
top: 50%;
|
|
57
57
|
transform: translateY(-50%);
|
|
@@ -61,31 +61,31 @@ var FormBuilder=(function(be){"use strict";function k(e,t,n){const r=t.config.lo
|
|
|
61
61
|
pointer-events: none;
|
|
62
62
|
background: var(--fb-background-color);
|
|
63
63
|
padding: 0 4px;
|
|
64
|
-
`;const r=e.min,l=e.max;let a="";r!=null&&l!=null?a=`${r} \u2013 ${l}`:l!=null?a=`\u2264${l}`:r!=null&&(a=`\u2265${r}`),n.textContent=a;const o=()=>{const
|
|
64
|
+
`;const r=e.min,l=e.max;let a="";r!=null&&l!=null?a=`${r} \u2013 ${l}`:l!=null?a=`\u2264${l}`:r!=null&&(a=`\u2265${r}`),n.textContent=a;const o=()=>{const s=t.value?parseFloat(t.value):null;if(s!=null){const i=r!=null&&s<r,u=l!=null&&s>l;n.style.color=i||u?"var(--fb-error-color)":"var(--fb-text-secondary-color)"}else n.style.color="var(--fb-text-secondary-color)"};return t.addEventListener("input",o),o(),n}function $n(e,t,n,r){const l=t.state,a=document.createElement("div");a.style.cssText="position: relative;";const o=document.createElement("input");if(o.type="number",o.className="w-full px-3 py-2 border border-gray-300 rounded-lg focus:ring-2 focus:ring-blue-500 focus:border-blue-500",o.style.cssText="padding-right: 60px; width: 100%; box-sizing: border-box;",o.name=r,o.placeholder=e.placeholder||"0",e.min!==void 0&&(o.min=e.min.toString()),e.max!==void 0&&(o.max=e.max.toString()),e.step!==void 0&&(o.step=e.step.toString()),o.value=t.prefill[e.key]||e.default||"",o.readOnly=l.config.readonly,!l.config.readonly&&t.instance){const s=()=>{const i=o.value?parseFloat(o.value):null;t.instance.triggerOnChange(r,i)};o.addEventListener("blur",s),o.addEventListener("input",s)}if(a.appendChild(o),!l.config.readonly&&(e.min!=null||e.max!=null)){const s=kt(e,o);a.appendChild(s)}n.appendChild(a)}function Ln(e,t,n,r){var l,a;const o=t.state,s=t.prefill[e.key]||[],i=Array.isArray(s)?[...s]:[],u=(l=e.minCount)!=null?l:1,f=(a=e.maxCount)!=null?a:1/0;for(;i.length<u;)i.push(e.default||"");const c=document.createElement("div");c.className="space-y-2",n.appendChild(c);function m(){c.querySelectorAll(".multiple-number-item").forEach((d,y)=>{const g=d.querySelector("input");g&&(g.name=`${r}[${y}]`)})}function p(d="",y=-1){const g=document.createElement("div");g.className="multiple-number-item flex items-center gap-2";const E=document.createElement("div");E.style.cssText="position: relative; flex: 1;";const C=document.createElement("input");if(C.type="number",C.className="w-full px-3 py-2 border border-gray-300 rounded-lg focus:ring-2 focus:ring-blue-500 focus:border-blue-500",C.style.cssText="padding-right: 60px; width: 100%; box-sizing: border-box;",C.placeholder=e.placeholder||"0",e.min!==void 0&&(C.min=e.min.toString()),e.max!==void 0&&(C.max=e.max.toString()),e.step!==void 0&&(C.step=e.step.toString()),C.value=d.toString(),C.readOnly=o.config.readonly,!o.config.readonly&&t.instance){const w=()=>{const S=C.value?parseFloat(C.value):null;t.instance.triggerOnChange(C.name,S)};C.addEventListener("blur",w),C.addEventListener("input",w)}if(E.appendChild(C),!o.config.readonly&&(e.min!=null||e.max!=null)){const w=kt(e,C);E.appendChild(w)}return g.appendChild(E),y===-1?c.appendChild(g):c.insertBefore(g,c.children[y]),m(),g}function h(){if(o.config.readonly)return;const d=c.querySelectorAll(".multiple-number-item"),y=d.length;d.forEach(g=>{let E=g.querySelector(".remove-item-btn");E||(E=document.createElement("button"),E.type="button",E.className="remove-item-btn px-2 py-1 text-red-600 hover:bg-red-50 rounded",E.innerHTML="\u2715",E.onclick=()=>{const w=Array.from(c.children).indexOf(g);c.children.length>u&&(i.splice(w,1),g.remove(),m(),x(),h())},g.appendChild(E));const C=y<=u;E.disabled=C,E.style.opacity=C?"0.5":"1",E.style.pointerEvents=C?"none":"auto"})}let v=null,b=null;if(!o.config.readonly){v=document.createElement("div"),v.className="flex items-center gap-3 mt-2";const d=document.createElement("button");d.type="button",d.className="add-number-btn px-3 py-1 rounded",d.style.cssText=`
|
|
65
65
|
color: var(--fb-primary-color);
|
|
66
66
|
border: var(--fb-border-width) solid var(--fb-primary-color);
|
|
67
67
|
background-color: transparent;
|
|
68
68
|
font-size: var(--fb-font-size);
|
|
69
69
|
transition: all var(--fb-transition-duration);
|
|
70
|
-
`,d.textContent="+",d.addEventListener("mouseenter",()=>{d.style.backgroundColor="var(--fb-background-hover-color)"}),d.addEventListener("mouseleave",()=>{d.style.backgroundColor="transparent"}),d.onclick=()=>{i.push(e.default||""),p(e.default||""),x(),h()},b=document.createElement("span"),b.className="text-sm text-gray-500",v.appendChild(d),v.appendChild(b),n.appendChild(v)}function x(){if(!v||!b)return;const d=v.querySelector(".add-number-btn");if(d){const y=i.length>=f;d.disabled=y,d.style.opacity=y?"0.5":"1",d.style.pointerEvents=y?"none":"auto"}b.textContent=`${i.length}/${f===1/0?"\u221E":f}`}i.forEach(d=>p(d)),x(),h()}function
|
|
70
|
+
`,d.textContent="+",d.addEventListener("mouseenter",()=>{d.style.backgroundColor="var(--fb-background-hover-color)"}),d.addEventListener("mouseleave",()=>{d.style.backgroundColor="transparent"}),d.onclick=()=>{i.push(e.default||""),p(e.default||""),x(),h()},b=document.createElement("span"),b.className="text-sm text-gray-500",v.appendChild(d),v.appendChild(b),n.appendChild(v)}function x(){if(!v||!b)return;const d=v.querySelector(".add-number-btn");if(d){const y=i.length>=f;d.disabled=y,d.style.opacity=y?"0.5":"1",d.style.pointerEvents=y?"none":"auto"}b.textContent=`${i.length}/${f===1/0?"\u221E":f}`}i.forEach(d=>p(d)),x(),h()}function Sn(e,t,n){var r,l,a,o,s;const i=[],{scopeRoot:u,skipValidation:f}=n,c=(p,h)=>{var v,b;if(!p)return;const x=`error-${p.getAttribute("name")||Math.random().toString(36).substring(7)}`;let d=document.getElementById(x);h?(p.classList.add("invalid"),p.title=h,d||(d=document.createElement("div"),d.id=x,d.className="error-message",d.style.cssText=`
|
|
71
71
|
color: var(--fb-error-color);
|
|
72
72
|
font-size: var(--fb-font-size-small);
|
|
73
73
|
margin-top: 0.25rem;
|
|
74
|
-
`,p.nextSibling?(v=p.parentNode)==null||v.insertBefore(d,p.nextSibling):(b=p.parentNode)==null||b.appendChild(d)),d.textContent=h,d.style.display="block"):(p.classList.remove("invalid"),p.title="",d&&d.remove())},m=(p,h,v)=>{let b=!1;const{state:x}=n;if(!f&&e.min!==void 0&&e.min!==null&&h<e.min){const d=k("minValue",x,{min:e.min});i.push(`${v}: ${d}`),
|
|
74
|
+
`,p.nextSibling?(v=p.parentNode)==null||v.insertBefore(d,p.nextSibling):(b=p.parentNode)==null||b.appendChild(d)),d.textContent=h,d.style.display="block"):(p.classList.remove("invalid"),p.title="",d&&d.remove())},m=(p,h,v)=>{let b=!1;const{state:x}=n;if(!f&&e.min!==void 0&&e.min!==null&&h<e.min){const d=k("minValue",x,{min:e.min});i.push(`${v}: ${d}`),c(p,d),b=!0}else if(!f&&e.max!==void 0&&e.max!==null&&h>e.max){const d=k("maxValue",x,{max:e.max});i.push(`${v}: ${d}`),c(p,d),b=!0}b||c(p,null)};if(e.multiple){const p=u.querySelectorAll(`[name^="${t}["]`),h=[];if(p.forEach((v,b)=>{var x,d,y;const g=(x=v==null?void 0:v.value)!=null?x:"";if(g===""){h.push(null),c(v,null);return}const E=parseFloat(g);if(!f&&!Number.isFinite(E)){const w=k("notANumber",n.state);i.push(`${t}[${b}]: ${w}`),c(v,w),h.push(null);return}m(v,E,`${t}[${b}]`);const C=Number.isInteger((d=e.decimals)!=null?d:0)&&(y=e.decimals)!=null?y:0;h.push(Number(E.toFixed(C)))}),!f){const{state:v}=n,b=(r=e.minCount)!=null?r:1,x=(l=e.maxCount)!=null?l:1/0,d=h.filter(y=>y!==null);e.required&&d.length===0&&i.push(`${t}: ${k("required",v)}`),d.length<b&&i.push(`${t}: ${k("minItems",v,{min:b})}`),d.length>x&&i.push(`${t}: ${k("maxItems",v,{max:x})}`)}return{value:h,errors:i}}else{const p=u.querySelector(`[name$="${t}"]`),h=(a=p==null?void 0:p.value)!=null?a:"",{state:v}=n;if(!f&&e.required&&h===""){const d=k("required",v);return i.push(`${t}: ${d}`),c(p,d),{value:null,errors:i}}if(h==="")return c(p,null),{value:null,errors:i};const b=parseFloat(h);if(!f&&!Number.isFinite(b)){const d=k("notANumber",v);return i.push(`${t}: ${d}`),c(p,d),{value:null,errors:i}}m(p,b,t);const x=Number.isInteger((o=e.decimals)!=null?o:0)&&(s=e.decimals)!=null?s:0;return{value:Number(b.toFixed(x)),errors:i}}}function Tn(e,t,n,r){const{scopeRoot:l}=r;if(e.multiple){if(!Array.isArray(n)){console.warn(`updateNumberField: Expected array for multiple field "${t}", got ${typeof n}`);return}const a=l.querySelectorAll(`[name^="${t}["]`);a.forEach((o,s)=>{s<n.length&&(o.value=n[s]!=null?String(n[s]):"",o.classList.remove("invalid"),o.title="")}),n.length!==a.length&&console.warn(`updateNumberField: Multiple field "${t}" has ${a.length} inputs but received ${n.length} values. Consider re-rendering for add/remove.`)}else{const a=l.querySelector(`[name="${t}"]`);a&&(a.value=n!=null?String(n):"",a.classList.remove("invalid"),a.title="")}}function An(e,t,n,r){const l=t.state,a=document.createElement("select");if(a.className="w-full px-3 py-2 border border-gray-300 rounded-lg focus:ring-2 focus:ring-blue-500 focus:border-blue-500",a.name=r,a.disabled=l.config.readonly,(e.options||[]).forEach(o=>{const s=document.createElement("option");s.value=o.value,s.textContent=o.label,(t.prefill[e.key]||e.default)===o.value&&(s.selected=!0),a.appendChild(s)}),!l.config.readonly&&t.instance){const o=()=>{t.instance.triggerOnChange(r,a.value)};a.addEventListener("change",o)}if(n.appendChild(a),!l.config.readonly){const o=document.createElement("p");o.className="text-xs text-gray-500 mt-1",o.textContent=ve(e,l),n.appendChild(o)}}function Fn(e,t,n,r){var l,a,o,s;const i=t.state,u=t.prefill[e.key]||[],f=Array.isArray(u)?[...u]:[],c=(l=e.minCount)!=null?l:1,m=(a=e.maxCount)!=null?a:1/0;for(;f.length<c;)f.push(e.default||((s=(o=e.options)==null?void 0:o[0])==null?void 0:s.value)||"");const p=document.createElement("div");p.className="space-y-2",n.appendChild(p);function h(){p.querySelectorAll(".multiple-select-item").forEach((g,E)=>{const C=g.querySelector("select");C&&(C.name=`${r}[${E}]`)})}function v(g="",E=-1){const C=document.createElement("div");C.className="multiple-select-item flex items-center gap-2";const w=document.createElement("select");if(w.className="flex-1 px-3 py-2 border border-gray-300 rounded-lg focus:ring-2 focus:ring-blue-500 focus:border-blue-500",w.disabled=i.config.readonly,(e.options||[]).forEach(S=>{const z=document.createElement("option");z.value=S.value,z.textContent=S.label,g===S.value&&(z.selected=!0),w.appendChild(z)}),!i.config.readonly&&t.instance){const S=()=>{t.instance.triggerOnChange(w.name,w.value)};w.addEventListener("change",S)}return C.appendChild(w),E===-1?p.appendChild(C):p.insertBefore(C,p.children[E]),h(),C}function b(){if(i.config.readonly)return;const g=p.querySelectorAll(".multiple-select-item"),E=g.length;g.forEach(C=>{let w=C.querySelector(".remove-item-btn");w||(w=document.createElement("button"),w.type="button",w.className="remove-item-btn px-2 py-1 text-red-600 hover:bg-red-50 rounded",w.innerHTML="\u2715",w.onclick=()=>{const z=Array.from(p.children).indexOf(C);p.children.length>c&&(f.splice(z,1),C.remove(),h(),y(),b())},C.appendChild(w));const S=E<=c;w.disabled=S,w.style.opacity=S?"0.5":"1",w.style.pointerEvents=S?"none":"auto"})}let x=null,d=null;if(!i.config.readonly){x=document.createElement("div"),x.className="flex items-center gap-3 mt-2";const g=document.createElement("button");g.type="button",g.className="add-select-btn px-3 py-1 rounded",g.style.cssText=`
|
|
75
75
|
color: var(--fb-primary-color);
|
|
76
76
|
border: var(--fb-border-width) solid var(--fb-primary-color);
|
|
77
77
|
background-color: transparent;
|
|
78
78
|
font-size: var(--fb-font-size);
|
|
79
79
|
transition: all var(--fb-transition-duration);
|
|
80
|
-
`,g.textContent="+",g.addEventListener("mouseenter",()=>{g.style.backgroundColor="var(--fb-background-hover-color)"}),g.addEventListener("mouseleave",()=>{g.style.backgroundColor="transparent"}),g.onclick=()=>{var E,C;const w=e.default||((C=(E=e.options)==null?void 0:E[0])==null?void 0:C.value)||"";f.push(w),v(w),y(),b()},d=document.createElement("span"),d.className="text-sm text-gray-500",x.appendChild(g),x.appendChild(d),n.appendChild(x)}function y(){if(!x||!d)return;const g=x.querySelector(".add-select-btn");if(g){const E=f.length>=m;g.disabled=E,g.style.opacity=E?"0.5":"1",g.style.pointerEvents=E?"none":"auto"}d.textContent=`${f.length}/${m===1/0?"\u221E":m}`}if(f.forEach(g=>v(g)),y(),b(),!i.config.readonly){const g=document.createElement("p");g.className="text-xs text-gray-500 mt-1",g.textContent=
|
|
80
|
+
`,g.textContent="+",g.addEventListener("mouseenter",()=>{g.style.backgroundColor="var(--fb-background-hover-color)"}),g.addEventListener("mouseleave",()=>{g.style.backgroundColor="transparent"}),g.onclick=()=>{var E,C;const w=e.default||((C=(E=e.options)==null?void 0:E[0])==null?void 0:C.value)||"";f.push(w),v(w),y(),b()},d=document.createElement("span"),d.className="text-sm text-gray-500",x.appendChild(g),x.appendChild(d),n.appendChild(x)}function y(){if(!x||!d)return;const g=x.querySelector(".add-select-btn");if(g){const E=f.length>=m;g.disabled=E,g.style.opacity=E?"0.5":"1",g.style.pointerEvents=E?"none":"auto"}d.textContent=`${f.length}/${m===1/0?"\u221E":m}`}if(f.forEach(g=>v(g)),y(),b(),!i.config.readonly){const g=document.createElement("p");g.className="text-xs text-gray-500 mt-1",g.textContent=ve(e,i),n.appendChild(g)}}function Nn(e,t,n){var r;const l=[],{scopeRoot:a,skipValidation:o}=n,s=(u,f)=>{var c,m;if(!u)return;const p=`error-${u.getAttribute("name")||Math.random().toString(36).substring(7)}`;let h=document.getElementById(p);f?(u.classList.add("invalid"),u.title=f,h||(h=document.createElement("div"),h.id=p,h.className="error-message",h.style.cssText=`
|
|
81
81
|
color: var(--fb-error-color);
|
|
82
82
|
font-size: var(--fb-font-size-small);
|
|
83
83
|
margin-top: 0.25rem;
|
|
84
|
-
`,u.nextSibling?(
|
|
84
|
+
`,u.nextSibling?(c=u.parentNode)==null||c.insertBefore(h,u.nextSibling):(m=u.parentNode)==null||m.appendChild(h)),h.textContent=f,h.style.display="block"):(u.classList.remove("invalid"),u.title="",h&&h.remove())},i=(u,f,c,m)=>{var p,h;if(o)return;const{state:v}=n,b=f.filter(m),x="minCount"in c&&(p=c.minCount)!=null?p:1,d="maxCount"in c&&(h=c.maxCount)!=null?h:1/0;c.required&&b.length===0&&l.push(`${u}: ${k("required",v)}`),b.length<x&&l.push(`${u}: ${k("minItems",v,{min:x})}`),b.length>d&&l.push(`${u}: ${k("maxItems",v,{max:d})}`)};if("multiple"in e&&e.multiple){const u=a.querySelectorAll(`[name^="${t}["]`),f=[];return u.forEach(c=>{var m;const p=(m=c==null?void 0:c.value)!=null?m:"";f.push(p),s(c,null)}),i(t,f,e,c=>c!==""),{value:f,errors:l}}else{const u=a.querySelector(`[name$="${t}"]`),f=(r=u==null?void 0:u.value)!=null?r:"";if(!o&&e.required&&f===""){const c=k("required",n.state);return l.push(`${t}: ${c}`),s(u,c),{value:null,errors:l}}else s(u,null);return{value:f===""?null:f,errors:l}}}function Mn(e,t,n,r){const{scopeRoot:l}=r;if("multiple"in e&&e.multiple){if(!Array.isArray(n)){console.warn(`updateSelectField: Expected array for multiple field "${t}", got ${typeof n}`);return}const a=l.querySelectorAll(`[name^="${t}["]`);a.forEach((o,s)=>{s<n.length&&(o.value=n[s]!=null?String(n[s]):"",o.querySelectorAll("option").forEach(i=>{i.selected=i.value===String(n[s])}),o.classList.remove("invalid"),o.title="")}),n.length!==a.length&&console.warn(`updateSelectField: Multiple field "${t}" has ${a.length} selects but received ${n.length} values. Consider re-rendering for add/remove.`)}else{const a=l.querySelector(`[name="${t}"]`);a&&(a.value=n!=null?String(n):"",a.querySelectorAll("option").forEach(o=>{o.selected=o.value===String(n)}),a.classList.remove("invalid"),a.title="")}}function Oe(e){e.style.backgroundColor="var(--fb-primary-color)",e.style.color="#ffffff",e.style.borderColor="var(--fb-primary-color)"}function Ue(e){e.style.backgroundColor="transparent",e.style.color="var(--fb-text-color)",e.style.borderColor="var(--fb-border-color)"}function $t(e,t,n,r,l){const a=e.options||[],o=document.createElement("div");o.className="fb-switcher-group",o.style.cssText=`
|
|
85
85
|
display: inline-flex;
|
|
86
86
|
flex-direction: row;
|
|
87
87
|
flex-wrap: nowrap;
|
|
88
|
-
`;const
|
|
88
|
+
`;const s=[];return a.forEach((i,u)=>{const f=document.createElement("button");f.type="button",f.className="fb-switcher-btn",f.dataset.value=i.value,f.textContent=i.label,f.style.cssText=`
|
|
89
89
|
padding: var(--fb-input-padding-y) var(--fb-input-padding-x);
|
|
90
90
|
font-size: var(--fb-font-size);
|
|
91
91
|
border-width: var(--fb-border-width);
|
|
@@ -95,59 +95,59 @@ var FormBuilder=(function(be){"use strict";function k(e,t,n){const r=t.config.lo
|
|
|
95
95
|
white-space: nowrap;
|
|
96
96
|
line-height: 1.25;
|
|
97
97
|
outline: none;
|
|
98
|
-
`,a.length===1?f.style.borderRadius="var(--fb-border-radius)":u===0?(f.style.borderRadius="var(--fb-border-radius) 0 0 var(--fb-border-radius)",f.style.borderRightWidth="0"):u===a.length-1?f.style.borderRadius="0 var(--fb-border-radius) var(--fb-border-radius) 0":(f.style.borderRadius="0",f.style.borderRightWidth="0"),i.value===t?
|
|
98
|
+
`,a.length===1?f.style.borderRadius="var(--fb-border-radius)":u===0?(f.style.borderRadius="var(--fb-border-radius) 0 0 var(--fb-border-radius)",f.style.borderRightWidth="0"):u===a.length-1?f.style.borderRadius="0 var(--fb-border-radius) var(--fb-border-radius) 0":(f.style.borderRadius="0",f.style.borderRightWidth="0"),i.value===t?Oe(f):Ue(f),r||(f.addEventListener("click",()=>{n.value=i.value,s.forEach(c=>{c.dataset.value===i.value?Oe(c):Ue(c)}),l&&l(i.value)}),f.addEventListener("mouseenter",()=>{n.value!==i.value&&(f.style.backgroundColor="var(--fb-background-hover-color)")}),f.addEventListener("mouseleave",()=>{n.value!==i.value&&(f.style.backgroundColor="transparent")})),s.push(f),o.appendChild(f)}),o}function qn(e,t,n,r){var l,a;const o=t.state,s=String((a=(l=t.prefill[e.key])!=null?l:e.default)!=null?a:""),i=document.createElement("input");i.type="hidden",i.name=r,i.value=s;const u=o.config.readonly,f=!u&&t.instance?m=>{t.instance.triggerOnChange(r,m)}:null,c=$t(e,s,i,u,f);if(n.appendChild(i),n.appendChild(c),!u){const m=document.createElement("p");m.className="text-xs text-gray-500 mt-1",m.textContent=ve(e,o),n.appendChild(m)}}function zn(e,t,n,r){var l,a,o,s;const i=t.state,u=t.prefill[e.key]||[],f=Array.isArray(u)?[...u]:[],c=(l=e.minCount)!=null?l:1,m=(a=e.maxCount)!=null?a:1/0;for(;f.length<c;)f.push(e.default||((s=(o=e.options)==null?void 0:o[0])==null?void 0:s.value)||"");const p=i.config.readonly,h=document.createElement("div");h.className="space-y-2",n.appendChild(h);function v(){h.querySelectorAll(".multiple-switcher-item").forEach((E,C)=>{const w=E.querySelector("input[type=hidden]");w&&(w.name=`${r}[${C}]`)})}function b(E="",C=-1){const w=C===-1?h.children.length:C,S=`${r}[${w}]`,z=document.createElement("div");z.className="multiple-switcher-item flex items-center gap-2";const Z=document.createElement("input");Z.type="hidden",Z.name=S,Z.value=E,z.appendChild(Z);const R=!p&&t.instance?fe=>{t.instance.triggerOnChange(Z.name,fe)}:null,_=$t(e,E,Z,p,R);return z.appendChild(_),C===-1?h.appendChild(z):h.insertBefore(z,h.children[C]),v(),z}function x(){if(p)return;const E=h.querySelectorAll(".multiple-switcher-item"),C=E.length;E.forEach(w=>{let S=w.querySelector(".remove-item-btn");S||(S=document.createElement("button"),S.type="button",S.className="remove-item-btn px-2 py-1 rounded",S.style.cssText=`
|
|
99
99
|
color: var(--fb-error-color);
|
|
100
100
|
background-color: transparent;
|
|
101
101
|
transition: background-color var(--fb-transition-duration);
|
|
102
|
-
`,S.innerHTML="\u2715",S.addEventListener("mouseenter",()=>{S.style.backgroundColor="var(--fb-background-hover-color)"}),S.addEventListener("mouseleave",()=>{S.style.backgroundColor="transparent"}),S.onclick=()=>{const
|
|
102
|
+
`,S.innerHTML="\u2715",S.addEventListener("mouseenter",()=>{S.style.backgroundColor="var(--fb-background-hover-color)"}),S.addEventListener("mouseleave",()=>{S.style.backgroundColor="transparent"}),S.onclick=()=>{const Z=Array.from(h.children).indexOf(w);h.children.length>c&&(f.splice(Z,1),w.remove(),v(),g(),x())},w.appendChild(S));const z=C<=c;S.disabled=z,S.style.opacity=z?"0.5":"1",S.style.pointerEvents=z?"none":"auto"})}let d=null,y=null;if(!p){d=document.createElement("div"),d.className="flex items-center gap-3 mt-2";const E=document.createElement("button");E.type="button",E.className="add-switcher-btn px-3 py-1 rounded",E.style.cssText=`
|
|
103
103
|
color: var(--fb-primary-color);
|
|
104
104
|
border: var(--fb-border-width) solid var(--fb-primary-color);
|
|
105
105
|
background-color: transparent;
|
|
106
106
|
font-size: var(--fb-font-size);
|
|
107
107
|
transition: all var(--fb-transition-duration);
|
|
108
|
-
`,E.textContent="+",E.addEventListener("mouseenter",()=>{E.style.backgroundColor="var(--fb-background-hover-color)"}),E.addEventListener("mouseleave",()=>{E.style.backgroundColor="transparent"}),E.onclick=()=>{var C,w;const S=e.default||((w=(C=e.options)==null?void 0:C[0])==null?void 0:w.value)||"";f.push(S),b(S),g(),x()},y=document.createElement("span"),y.className="text-sm text-gray-500",d.appendChild(E),d.appendChild(y),n.appendChild(d)}function g(){if(!d||!y)return;const E=d.querySelector(".add-switcher-btn");if(E){const C=f.length>=m;E.disabled=C,E.style.opacity=C?"0.5":"1",E.style.pointerEvents=C?"none":"auto"}y.textContent=`${f.length}/${m===1/0?"\u221E":m}`}if(f.forEach(E=>b(E)),g(),x(),!p){const E=document.createElement("p");E.className="text-xs text-gray-500 mt-1",E.textContent=
|
|
108
|
+
`,E.textContent="+",E.addEventListener("mouseenter",()=>{E.style.backgroundColor="var(--fb-background-hover-color)"}),E.addEventListener("mouseleave",()=>{E.style.backgroundColor="transparent"}),E.onclick=()=>{var C,w;const S=e.default||((w=(C=e.options)==null?void 0:C[0])==null?void 0:w.value)||"";f.push(S),b(S),g(),x()},y=document.createElement("span"),y.className="text-sm text-gray-500",d.appendChild(E),d.appendChild(y),n.appendChild(d)}function g(){if(!d||!y)return;const E=d.querySelector(".add-switcher-btn");if(E){const C=f.length>=m;E.disabled=C,E.style.opacity=C?"0.5":"1",E.style.pointerEvents=C?"none":"auto"}y.textContent=`${f.length}/${m===1/0?"\u221E":m}`}if(f.forEach(E=>b(E)),g(),x(),!p){const E=document.createElement("p");E.className="text-xs text-gray-500 mt-1",E.textContent=ve(e,i),n.appendChild(E)}}function Hn(e,t,n){var r;const l=[],{scopeRoot:a,skipValidation:o}=n,s=(f,c)=>{var m,p;if(!f)return;const h=`error-${f.getAttribute("name")||Math.random().toString(36).substring(7)}`;let v=document.getElementById(h);c?(f.classList.add("invalid"),f.title=c,v||(v=document.createElement("div"),v.id=h,v.className="error-message",v.style.cssText=`
|
|
109
109
|
color: var(--fb-error-color);
|
|
110
110
|
font-size: var(--fb-font-size-small);
|
|
111
111
|
margin-top: 0.25rem;
|
|
112
|
-
`,f.nextSibling?(m=f.parentNode)==null||m.insertBefore(v,f.nextSibling):(p=f.parentNode)==null||p.appendChild(v)),v.textContent=
|
|
112
|
+
`,f.nextSibling?(m=f.parentNode)==null||m.insertBefore(v,f.nextSibling):(p=f.parentNode)==null||p.appendChild(v)),v.textContent=c,v.style.display="block"):(f.classList.remove("invalid"),f.title="",v&&v.remove())},i=(f,c,m,p)=>{var h,v;if(o)return;const{state:b}=n,x=c.filter(p),d="minCount"in m&&(h=m.minCount)!=null?h:1,y="maxCount"in m&&(v=m.maxCount)!=null?v:1/0;m.required&&x.length===0&&l.push(`${f}: ${k("required",b)}`),x.length<d&&l.push(`${f}: ${k("minItems",b,{min:d})}`),x.length>y&&l.push(`${f}: ${k("maxItems",b,{max:y})}`)},u=new Set("options"in e?e.options.map(f=>f.value):[]);if("multiple"in e&&e.multiple){const f=a.querySelectorAll(`input[type="hidden"][name^="${t}["]`),c=[];return f.forEach(m=>{var p;const h=(p=m==null?void 0:m.value)!=null?p:"";if(c.push(h),!o&&h!==""&&!u.has(h)){const v=k("invalidOption",n.state);s(m,v),l.push(`${t}: ${v}`)}else s(m,null)}),i(t,c,e,m=>m!==""),{value:c,errors:l}}else{const f=a.querySelector(`input[type="hidden"][name$="${t}"]`),c=(r=f==null?void 0:f.value)!=null?r:"";if(!o&&e.required&&c===""){const m=k("required",n.state);return l.push(`${t}: ${m}`),s(f,m),{value:null,errors:l}}if(!o&&c!==""&&!u.has(c)){const m=k("invalidOption",n.state);return l.push(`${t}: ${m}`),s(f,m),{value:null,errors:l}}return s(f,null),{value:c===""?null:c,errors:l}}}function In(e,t,n,r){var l;const{scopeRoot:a}=r;if("multiple"in e&&e.multiple){if(!Array.isArray(n)){console.warn(`updateSwitcherField: Expected array for multiple field "${t}", got ${typeof n}`);return}const o=a.querySelectorAll(`input[type="hidden"][name^="${t}["]`);o.forEach((s,i)=>{var u;if(i<n.length){const f=n[i]!=null?String(n[i]):"";s.value=f;const c=(u=s.parentElement)==null?void 0:u.querySelector(".fb-switcher-group");c&&c.querySelectorAll(".fb-switcher-btn").forEach(m=>{m.dataset.value===f?Oe(m):Ue(m)}),s.classList.remove("invalid"),s.title=""}}),n.length!==o.length&&console.warn(`updateSwitcherField: Multiple field "${t}" has ${o.length} inputs but received ${n.length} values. Consider re-rendering for add/remove.`)}else{const o=a.querySelector(`input[type="hidden"][name="${t}"]`);if(o){const s=n!=null?String(n):"";o.value=s;const i=(l=o.parentElement)==null?void 0:l.querySelector(".fb-switcher-group");i&&i.querySelectorAll(".fb-switcher-btn").forEach(u=>{u.dataset.value===s?Oe(u):Ue(u)}),o.classList.remove("invalid"),o.title=""}}}function He(e){return e?typeof e=="object"&&Array.isArray(e.extensions)?e.extensions.map(t=>t.toLowerCase()):typeof e=="string"?e.split(",").map(t=>t.trim()).filter(t=>t.startsWith(".")).map(t=>t.substring(1).toLowerCase()):[]:[]}function we(e,t){var n;if(t.length===0)return!0;const r=((n=e.split(".").pop())==null?void 0:n.toLowerCase())||"";return t.includes(r)}function Le(e,t){return t===1/0?!0:e.size<=t*1024*1024}function Bn(e,t,n,r){const l=document.createElement("img");l.className="w-full h-full object-contain",l.alt=n||k("previewAlt",r);const a=new FileReader;a.onload=o=>{var s;l.src=((s=o.target)==null?void 0:s.result)||""},a.readAsDataURL(t),e.appendChild(l)}function Rn(e,t,n,r,l,a){const o=URL.createObjectURL(t);e.onclick=null;const s=e.cloneNode(!1);return e.parentNode&&e.parentNode.replaceChild(s,e),s.innerHTML=`
|
|
113
113
|
<div class="relative group h-full">
|
|
114
114
|
<video class="w-full h-full object-contain" controls preload="auto" muted src="${o}">
|
|
115
|
-
${
|
|
115
|
+
${J(k("videoNotSupported",l))}
|
|
116
116
|
</video>
|
|
117
117
|
<div class="absolute top-2 right-2 opacity-0 group-hover:opacity-100 transition-opacity z-10 flex gap-1">
|
|
118
118
|
<button class="bg-red-600 bg-opacity-75 hover:bg-opacity-90 text-white p-1 rounded text-xs delete-file-btn">
|
|
119
|
-
${
|
|
119
|
+
${J(k("removeElement",l))}
|
|
120
120
|
</button>
|
|
121
121
|
<button class="bg-gray-800 bg-opacity-75 hover:bg-opacity-90 text-white p-1 rounded text-xs change-file-btn">
|
|
122
|
-
${
|
|
122
|
+
${J(k("changeButton",l))}
|
|
123
123
|
</button>
|
|
124
124
|
</div>
|
|
125
125
|
</div>
|
|
126
|
-
`,
|
|
126
|
+
`,Dn(s,r,l,a),s}function Dn(e,t,n,r){const l=e.querySelector(".change-file-btn");l&&(l.onclick=o=>{o.stopPropagation(),r!=null&&r.picker&&r.picker.click()});const a=e.querySelector(".delete-file-btn");a&&(a.onclick=o=>{o.stopPropagation(),jn(e,t,n,r)})}function jn(e,t,n,r){var l;n.resourceIndex.delete(t);const a=(l=e.parentElement)==null?void 0:l.querySelector('input[type="hidden"]');a&&(a.value=""),r!=null&&r.fileUploadHandler&&(e.onclick=r.fileUploadHandler),r!=null&&r.dragHandler&<(e,r.dragHandler),e.innerHTML=`
|
|
127
127
|
<div class="flex flex-col items-center justify-center h-full text-gray-400">
|
|
128
128
|
<svg class="w-6 h-6 mb-2" fill="currentColor" viewBox="0 0 24 24">
|
|
129
129
|
<path d="M21 19V5c0-1.1-.9-2-2-2H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2zM8.5 13.5l2.5 3.01L14.5 12l4.5 6H5l3.5-4.5z"/>
|
|
130
130
|
</svg>
|
|
131
|
-
<div class="text-sm text-center">${
|
|
131
|
+
<div class="text-sm text-center">${J(k("clickDragText",n))}</div>
|
|
132
132
|
</div>
|
|
133
|
-
`}function
|
|
133
|
+
`}function On(e,t,n,r){const l=document.createElement("video");l.className="w-full h-full object-contain",l.controls=!0,l.preload="metadata",l.muted=!0,l.src=t,l.appendChild(document.createTextNode(k("videoNotSupported",r))),e.appendChild(l)}function Un(e,t,n){_n(e,n,()=>{var r;n.resourceIndex.delete(t);const l=(r=e.parentElement)==null?void 0:r.querySelector('input[type="hidden"]');l&&(l.value=""),e.innerHTML=`
|
|
134
134
|
<div class="flex flex-col items-center justify-center h-full text-gray-400">
|
|
135
135
|
<svg class="w-6 h-6 mb-2" fill="currentColor" viewBox="0 0 24 24">
|
|
136
136
|
<path d="M21 19V5c0-1.1-.9-2-2-2H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2zM8.5 13.5l2.5 3.01L14.5 12l4.5 6H5l3.5-4.5z"/>
|
|
137
137
|
</svg>
|
|
138
|
-
<div class="text-sm text-center">${
|
|
138
|
+
<div class="text-sm text-center">${J(k("clickDragText",n))}</div>
|
|
139
139
|
</div>
|
|
140
|
-
`})}async function
|
|
140
|
+
`})}async function Pn(e,t,n,r,l,a,o){!t.file||!(t.file instanceof File)||(t.type&&t.type.startsWith("image/")?Bn(e,t.file,n,a):t.type&&t.type.startsWith("video/")?e=Rn(e,t.file,t.type,r,a,o):e.innerHTML=`<div class="flex flex-col items-center justify-center h-full text-gray-400"><div class="text-2xl mb-2">\u{1F4C1}</div><div class="text-sm">${J(n)}</div></div>`,!l&&!(t.type&&t.type.startsWith("video/"))&&Un(e,r,a))}async function Vn(e,t,n,r,l){if(!l.config.getThumbnail){ot(e,l);return}try{const a=await l.config.getThumbnail(t);if(a)if(pe(e),r&&r.type&&r.type.startsWith("video/"))On(e,a,r.type,l);else{const o=document.createElement("img");o.className="w-full h-full object-contain",o.alt=n||k("previewAlt",l),o.src=a,e.appendChild(o)}else ot(e,l)}catch(a){console.error("Failed to get thumbnail:",a),e.innerHTML=`
|
|
141
141
|
<div class="flex flex-col items-center justify-center h-full text-gray-400">
|
|
142
142
|
<svg class="w-6 h-6 mb-2" fill="currentColor" viewBox="0 0 24 24">
|
|
143
143
|
<path d="M21 19V5c0-1.1-.9-2-2-2H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2zM8.5 13.5l2.5 3.01L14.5 12l4.5 6H5l3.5-4.5z"/>
|
|
144
144
|
</svg>
|
|
145
|
-
<div class="text-sm text-center">${
|
|
145
|
+
<div class="text-sm text-center">${J(n||k("previewUnavailable",l))}</div>
|
|
146
146
|
</div>
|
|
147
|
-
`}}async function
|
|
147
|
+
`}}async function Lt(e,t,n,r={}){const{fileName:l="",isReadonly:a=!1,deps:o=null}=r;if(!a&&o&&(!o.picker||!o.fileUploadHandler||!o.dragHandler))throw new Error("renderFilePreview: missing deps {picker, fileUploadHandler, dragHandler}");pe(e),a&&e.classList.add("cursor-pointer");const s=n.resourceIndex.get(t);s&&s.file&&s.file instanceof File?await Pn(e,s,l,t,a,n,o):await Vn(e,t,l,s,n)}async function nt(e,t,n){var r,l;const a=t.resourceIndex.get(e),o=(a==null?void 0:a.name)||e.split("/").pop()||"file",s=o.toLowerCase().match(/\.psd$/),i=document.createElement("div");i.className=s?"space-y-2":"space-y-3";const u=document.createElement("div");s?u.className="bg-gray-100 rounded-lg overflow-hidden cursor-pointer hover:opacity-90 transition-opacity flex items-center p-3 max-w-sm":u.className="bg-gray-100 rounded-lg overflow-hidden cursor-pointer hover:opacity-90 transition-opacity";const f=!s&&(((r=a==null?void 0:a.type)==null?void 0:r.startsWith("image/"))||o.toLowerCase().match(/\.(jpg|jpeg|png|gif|webp)$/)),c=((l=a==null?void 0:a.type)==null?void 0:l.startsWith("video/"))||o.toLowerCase().match(/\.(mp4|webm|avi|mov)$/);if(f)if(t.config.getThumbnail)try{const h=await t.config.getThumbnail(e);h?u.innerHTML=`<img src="${h}" alt="${J(o)}" class="w-full h-auto">`:u.innerHTML=`<div class="aspect-video flex items-center justify-center text-gray-400"><div class="text-center"><div class="text-4xl mb-2">\u{1F5BC}\uFE0F</div><div class="text-sm">${J(o)}</div></div></div>`}catch(h){console.warn("getThumbnail failed for",e,h),u.innerHTML=`<div class="aspect-video flex items-center justify-center text-gray-400"><div class="text-center"><div class="text-4xl mb-2">\u{1F5BC}\uFE0F</div><div class="text-sm">${J(o)}</div></div></div>`}else u.innerHTML=`<div class="aspect-video flex items-center justify-center text-gray-400"><div class="text-center"><div class="text-4xl mb-2">\u{1F5BC}\uFE0F</div><div class="text-sm">${J(o)}</div></div></div>`;else if(c)if(t.config.getThumbnail)try{const h=await t.config.getThumbnail(e);h?u.innerHTML=`
|
|
148
148
|
<div class="relative group">
|
|
149
149
|
<video class="w-full h-auto" controls preload="auto" muted src="${h}">
|
|
150
|
-
${
|
|
150
|
+
${J(k("videoNotSupported",t))}
|
|
151
151
|
</video>
|
|
152
152
|
<div class="absolute inset-0 bg-black bg-opacity-20 opacity-0 group-hover:opacity-100 transition-opacity flex items-center justify-center pointer-events-none">
|
|
153
153
|
<div class="bg-white bg-opacity-90 rounded-full p-3">
|
|
@@ -157,27 +157,27 @@ var FormBuilder=(function(be){"use strict";function k(e,t,n){const r=t.config.lo
|
|
|
157
157
|
</div>
|
|
158
158
|
</div>
|
|
159
159
|
</div>
|
|
160
|
-
`:u.innerHTML=`<div class="aspect-video flex items-center justify-center text-gray-400"><div class="text-center"><div class="text-4xl mb-2">\u{1F3A5}</div><div class="text-sm">${
|
|
160
|
+
`:u.innerHTML=`<div class="aspect-video flex items-center justify-center text-gray-400"><div class="text-center"><div class="text-4xl mb-2">\u{1F3A5}</div><div class="text-sm">${J(o)}</div></div></div>`}catch(h){console.warn("getThumbnail failed for video",e,h),u.innerHTML=`<div class="aspect-video flex items-center justify-center text-gray-400"><div class="text-center"><div class="text-4xl mb-2">\u{1F3A5}</div><div class="text-sm">${J(o)}</div></div></div>`}else u.innerHTML=`<div class="aspect-video flex items-center justify-center text-gray-400"><div class="text-center"><div class="text-4xl mb-2">\u{1F3A5}</div><div class="text-sm">${J(o)}</div></div></div>`;else{const h=s?"\u{1F3A8}":"\u{1F4C1}",v=s?"PSD File":"Document";s?u.innerHTML=`
|
|
161
161
|
<div class="flex items-center space-x-3">
|
|
162
162
|
<div class="text-3xl text-gray-400">${h}</div>
|
|
163
163
|
<div class="flex-1 min-w-0">
|
|
164
|
-
<div class="text-sm font-medium text-gray-900 truncate">${
|
|
164
|
+
<div class="text-sm font-medium text-gray-900 truncate">${J(o)}</div>
|
|
165
165
|
<div class="text-xs text-gray-500">${v}</div>
|
|
166
166
|
</div>
|
|
167
167
|
</div>
|
|
168
|
-
`:u.innerHTML=`<div class="aspect-video flex items-center justify-center text-gray-400"><div class="text-center"><div class="text-4xl mb-2">${h}</div><div class="text-sm">${
|
|
168
|
+
`:u.innerHTML=`<div class="aspect-video flex items-center justify-center text-gray-400"><div class="text-center"><div class="text-4xl mb-2">${h}</div><div class="text-sm">${J(o)}</div><div class="text-xs text-gray-500 mt-1">${v}</div></div></div>`}const m=document.createElement("p");m.className=s?"hidden":"text-sm font-medium text-gray-900 text-center",m.textContent=o;const p=document.createElement("button");return p.className="w-full px-3 py-2 text-sm bg-blue-600 text-white rounded-lg hover:bg-blue-700 transition-colors",p.textContent=k("downloadButton",t),p.onclick=h=>{h.preventDefault(),h.stopPropagation(),t.config.downloadFile?t.config.downloadFile(e,o):Wn(e,o,t)},i.appendChild(u),i.appendChild(m),i.appendChild(p),i}function St(e,t,n,r,l,a){pe(e);const o=()=>{const m=[k("clickDragTextMultiple",n)];return l&&m.push(l),a&&m.push(a),m.join(" \u2022 ")},s=!e.classList.contains("grid");if((!t||t.length===0)&&s){const m=document.createElement("div");m.className="grid grid-cols-4 gap-3 mb-3";for(let h=0;h<4;h++){const v=document.createElement("div");v.className="aspect-square bg-gray-100 border-2 border-dashed border-gray-300 rounded flex items-center justify-center cursor-pointer hover:border-gray-400 transition-colors";const b=document.createElementNS("http://www.w3.org/2000/svg","svg");b.setAttribute("class","w-12 h-12 text-gray-400"),b.setAttribute("fill","currentColor"),b.setAttribute("viewBox","0 0 24 24");const x=document.createElementNS("http://www.w3.org/2000/svg","path");x.setAttribute("d","M21 19V5c0-1.1-.9-2-2-2H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2zM8.5 13.5l2.5 3.01L14.5 12l4.5 6H5l3.5-4.5z"),b.appendChild(x),v.appendChild(b),v.onclick=()=>{let d=e.parentElement;for(;d&&!d.classList.contains("space-y-2");)d=d.parentElement;!d&&e.classList.contains("space-y-2")&&(d=e);const y=d==null?void 0:d.querySelector('input[type="file"]');y&&y.click()},m.appendChild(v)}const p=document.createElement("div");p.className="text-center text-xs text-gray-500 mt-2",p.textContent=o(),e.appendChild(m),e.appendChild(p);return}const i=document.createElement("div");i.className="files-list grid grid-cols-4 gap-3";const u=t?t.length:0,f=(Math.floor(u/4)+1)*4;for(let m=0;m<f;m++){const p=document.createElement("div");if(t&&m<t.length){const h=t[m],v=n.resourceIndex.get(h);if(p.className="resource-pill aspect-square bg-gray-100 rounded-lg overflow-hidden relative group border border-gray-300",p.dataset.resourceId=h,Kn(p,h,v,n).catch(b=>{console.error("Failed to render thumbnail:",b),p.innerHTML=`<div class="flex flex-col items-center justify-center h-full text-gray-400">
|
|
169
169
|
<div class="text-2xl mb-1">\u{1F4C1}</div>
|
|
170
|
-
<div class="text-xs">${
|
|
171
|
-
</div>`}),r){const b=document.createElement("div");b.className="absolute inset-0 bg-black bg-opacity-50 opacity-0 group-hover:opacity-100 transition-opacity flex items-center justify-center";const x=document.createElement("button");x.className="bg-red-600 text-white px-2 py-1 rounded text-xs",x.textContent=k("removeElement",n),x.onclick=d=>{d.stopPropagation(),r(h)},b.appendChild(x),p.appendChild(b)}}else p.className="aspect-square bg-gray-100 border-2 border-dashed border-gray-300 rounded-lg flex items-center justify-center cursor-pointer hover:border-gray-400 transition-colors",p.innerHTML='<svg class="w-12 h-12 text-gray-400" fill="currentColor" viewBox="0 0 24 24"><path d="M21 19V5c0-1.1-.9-2-2-2H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2zM8.5 13.5l2.5 3.01L14.5 12l4.5 6H5l3.5-4.5z"/></svg>',p.onclick=()=>{let h=e.parentElement;for(;h&&!h.classList.contains("space-y-2");)h=h.parentElement;!h&&e.classList.contains("space-y-2")&&(h=e);const v=h==null?void 0:h.querySelector('input[type="file"]');v&&v.click()};i.appendChild(p)}e.appendChild(i);const
|
|
172
|
-
<svg class="${
|
|
170
|
+
<div class="text-xs">${J(k("previewError",n))}</div>
|
|
171
|
+
</div>`}),r){const b=document.createElement("div");b.className="absolute inset-0 bg-black bg-opacity-50 opacity-0 group-hover:opacity-100 transition-opacity flex items-center justify-center";const x=document.createElement("button");x.className="bg-red-600 text-white px-2 py-1 rounded text-xs",x.textContent=k("removeElement",n),x.onclick=d=>{d.stopPropagation(),r(h)},b.appendChild(x),p.appendChild(b)}}else p.className="aspect-square bg-gray-100 border-2 border-dashed border-gray-300 rounded-lg flex items-center justify-center cursor-pointer hover:border-gray-400 transition-colors",p.innerHTML='<svg class="w-12 h-12 text-gray-400" fill="currentColor" viewBox="0 0 24 24"><path d="M21 19V5c0-1.1-.9-2-2-2H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2zM8.5 13.5l2.5 3.01L14.5 12l4.5 6H5l3.5-4.5z"/></svg>',p.onclick=()=>{let h=e.parentElement;for(;h&&!h.classList.contains("space-y-2");)h=h.parentElement;!h&&e.classList.contains("space-y-2")&&(h=e);const v=h==null?void 0:h.querySelector('input[type="file"]');v&&v.click()};i.appendChild(p)}e.appendChild(i);const c=document.createElement("div");c.className="text-center text-xs text-gray-500 mt-2",c.textContent=o(),e.appendChild(c)}function Tt(e,t,n="w-12 h-12"){e.innerHTML=`<div class="flex flex-col items-center justify-center h-full text-gray-400">
|
|
172
|
+
<svg class="${J(n)} text-red-400" fill="currentColor" viewBox="0 0 24 24">
|
|
173
173
|
<path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm1 15h-2v-2h2v2zm0-4h-2V7h2v6z"/>
|
|
174
174
|
</svg>
|
|
175
|
-
<div class="text-xs mt-1 text-red-600">${
|
|
176
|
-
</div>`}async function
|
|
175
|
+
<div class="text-xs mt-1 text-red-600">${J(k("previewError",t))}</div>
|
|
176
|
+
</div>`}async function Kn(e,t,n,r){var l,a;if(n&&(l=n.type)!=null&&l.startsWith("image/"))if(n.file&&n.file instanceof File){const o=document.createElement("img");o.className="w-full h-full object-contain",o.alt=n.name;const s=new FileReader;s.onload=i=>{var u;o.src=((u=i.target)==null?void 0:u.result)||""},s.readAsDataURL(n.file),e.appendChild(o)}else if(r.config.getThumbnail)try{const o=await r.config.getThumbnail(t);if(o){const s=document.createElement("img");s.className="w-full h-full object-contain",s.alt=n.name,s.src=o,e.appendChild(s)}else e.innerHTML=`<div class="flex flex-col items-center justify-center h-full text-gray-400">
|
|
177
177
|
<svg class="w-12 h-12" fill="currentColor" viewBox="0 0 24 24">
|
|
178
178
|
<path d="M21 19V5c0-1.1-.9-2-2-2H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2zM8.5 13.5l2.5 3.01L14.5 12l4.5 6H5l3.5-4.5z"/>
|
|
179
179
|
</svg>
|
|
180
|
-
</div>`}catch(o){const
|
|
180
|
+
</div>`}catch(o){const s=o instanceof Error?o:new Error(String(o));r.config.onThumbnailError&&r.config.onThumbnailError(s,t),Tt(e,r)}else e.innerHTML=`<div class="flex flex-col items-center justify-center h-full text-gray-400">
|
|
181
181
|
<svg class="w-12 h-12" fill="currentColor" viewBox="0 0 24 24">
|
|
182
182
|
<path d="M21 19V5c0-1.1-.9-2-2-2H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2zM8.5 13.5l2.5 3.01L14.5 12l4.5 6H5l3.5-4.5z"/>
|
|
183
183
|
</svg>
|
|
@@ -209,28 +209,28 @@ var FormBuilder=(function(be){"use strict";function k(e,t,n){const r=t.config.lo
|
|
|
209
209
|
<svg class="w-8 h-8" fill="currentColor" viewBox="0 0 24 24">
|
|
210
210
|
<path d="M8 5v14l11-7z"/>
|
|
211
211
|
</svg>
|
|
212
|
-
<div class="text-xs mt-1">${
|
|
213
|
-
</div>`}catch(o){const
|
|
212
|
+
<div class="text-xs mt-1">${J((n==null?void 0:n.name)||"Video")}</div>
|
|
213
|
+
</div>`}catch(o){const s=o instanceof Error?o:new Error(String(o));r.config.onThumbnailError&&r.config.onThumbnailError(s,t),Tt(e,r,"w-8 h-8")}else e.innerHTML=`<div class="flex flex-col items-center justify-center h-full text-gray-400">
|
|
214
214
|
<svg class="w-8 h-8" fill="currentColor" viewBox="0 0 24 24">
|
|
215
215
|
<path d="M8 5v14l11-7z"/>
|
|
216
216
|
</svg>
|
|
217
|
-
<div class="text-xs mt-1">${
|
|
217
|
+
<div class="text-xs mt-1">${J((n==null?void 0:n.name)||"Video")}</div>
|
|
218
218
|
</div>`;else e.innerHTML=`<div class="flex flex-col items-center justify-center h-full text-gray-400">
|
|
219
219
|
<div class="text-2xl mb-1">\u{1F4C1}</div>
|
|
220
|
-
<div class="text-xs">${
|
|
221
|
-
</div>`}function
|
|
220
|
+
<div class="text-xs">${J((n==null?void 0:n.name)||"File")}</div>
|
|
221
|
+
</div>`}function ot(e,t,n){const r=n?`<div class="text-xs text-gray-500 mt-1">${J(n)}</div>`:"";e.innerHTML=`
|
|
222
222
|
<div class="flex flex-col items-center justify-center h-full text-gray-400">
|
|
223
223
|
<svg class="w-6 h-6 mb-2" fill="currentColor" viewBox="0 0 24 24">
|
|
224
224
|
<path d="M21 19V5c0-1.1-.9-2-2-2H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2zM8.5 13.5l2.5 3.01L14.5 12l4.5 6H5l3.5-4.5z"/>
|
|
225
225
|
</svg>
|
|
226
|
-
<div class="text-sm text-center">${
|
|
226
|
+
<div class="text-sm text-center">${J(k("clickDragText",t))}</div>
|
|
227
227
|
${r}
|
|
228
228
|
</div>
|
|
229
|
-
`}function
|
|
229
|
+
`}function Pe(e,t){var n,r;const l=(n=e.closest(".space-y-2"))==null?void 0:n.querySelector(".file-error-message");l&&l.remove();const a=document.createElement("div");a.className="file-error-message error-message",a.style.cssText=`
|
|
230
230
|
color: var(--fb-error-color);
|
|
231
231
|
font-size: var(--fb-font-size-small);
|
|
232
232
|
margin-top: 0.25rem;
|
|
233
|
-
`,a.textContent=t,(r=e.closest(".space-y-2"))==null||r.appendChild(a)}function ot(e){var t;const n=(t=e.closest(".space-y-2"))==null?void 0:t.querySelector(".file-error-message");n&&n.remove()}async function Lt(e,t,n,r,l=null,a,o=[],c=1/0){var i,u;if(!Ee(e.name,o)){const m=o.join(", ");Oe(t,k("invalidFileExtension",r,{name:e.name,formats:m}));return}if(!$e(e,c)){Oe(t,k("fileTooLarge",r,{name:e.name,maxSize:c}));return}ot(t);let f;if(r.config.uploadFile)try{if(f=await r.config.uploadFile(e),typeof f!="string")throw new Error("Upload handler must return a string resource ID")}catch(m){const p=m instanceof Error?m:new Error(String(m));throw r.config.onUploadError&&r.config.onUploadError(p,e),new Error(`File upload failed: ${p.message}`)}else throw new Error("No upload handler configured. Set uploadHandler via FormBuilder.setUploadHandler()");r.resourceIndex.set(f,{name:e.name,type:e.type,size:e.size,uploadedAt:new Date,file:e});let s=(i=t.parentElement)==null?void 0:i.querySelector('input[type="hidden"]');s||(s=document.createElement("input"),s.type="hidden",s.name=n,(u=t.parentElement)==null||u.appendChild(s)),s.value=f,wt(t,f,r,{fileName:e.name,isReadonly:!1,deps:l}).catch(console.error),a&&!r.config.readonly&&a.triggerOnChange(n,f)}function rt(e,t){e.addEventListener("dragover",n=>{n.preventDefault(),e.classList.add("border-blue-500","bg-blue-50")}),e.addEventListener("dragleave",n=>{n.preventDefault(),e.classList.remove("border-blue-500","bg-blue-50")}),e.addEventListener("drop",n=>{var r;n.preventDefault(),e.classList.remove("border-blue-500","bg-blue-50"),(r=n.dataTransfer)!=null&&r.files&&t(n.dataTransfer.files)})}function Pn(e,t,n){const r=e.querySelector(".delete-overlay");r&&r.remove();const l=document.createElement("div");l.className="delete-overlay absolute inset-0 bg-black bg-opacity-50 opacity-0 group-hover:opacity-100 transition-opacity flex items-center justify-center";const a=document.createElement("button");a.className="bg-red-600 text-white px-3 py-1 rounded text-sm hover:bg-red-700 transition-colors",a.textContent=k("removeElement",t),a.onclick=o=>{o.stopPropagation(),n()},l.appendChild(a),e.appendChild(l)}async function St(e,t){if(t.config.uploadFile)try{const n=await t.config.uploadFile(e);if(typeof n!="string")throw new Error("Upload handler must return a string resource ID");return n}catch(n){const r=n instanceof Error?n:new Error(String(n));throw t.config.onUploadError&&t.config.onUploadError(r,e),new Error(`File upload failed: ${r.message}`)}else throw new Error("No upload handler configured. Set uploadHandler via FormBuilder.setUploadHandler()")}async function Vn(e,t,n){try{let r=null;if(n.config.getDownloadUrl?r=n.config.getDownloadUrl(e):n.config.getThumbnail&&(r=await n.config.getThumbnail(e)),r){const l=r.startsWith("http")?r:new URL(r,window.location.href).href,a=await fetch(l);if(!a.ok)throw new Error(`HTTP error! status: ${a.status}`);const o=await a.blob();Kn(o,t)}else throw new Error("No download URL available for resource")}catch(r){const l=r instanceof Error?r:new Error(String(r));throw n.config.onDownloadError&&n.config.onDownloadError(l,e,t),console.error(`File download failed for ${t}:`,l),l}}function Kn(e,t){try{const n=URL.createObjectURL(e),r=document.createElement("a");r.href=n,r.download=t,r.style.display="none",document.body.appendChild(r),r.click(),document.body.removeChild(r),setTimeout(()=>{URL.revokeObjectURL(n)},100)}catch(n){throw new Error(`Blob download failed: ${n.message}`)}}function Tt(e,t){e.length>0&&e.forEach(n=>{var r;if(!t.resourceIndex.has(n)){const l=n.split("/").pop()||"file",a=(r=l.split(".").pop())==null?void 0:r.toLowerCase();let o="application/octet-stream";a&&(["jpg","jpeg","png","gif","webp"].includes(a)?o=`image/${a==="jpg"?"jpeg":a}`:["mp4","webm","mov","avi"].includes(a)&&(o=`video/${a==="mov"?"quicktime":a}`)),t.resourceIndex.set(n,{name:l,type:o,size:0,uploadedAt:new Date,file:void 0})}})}function _n(e,t,n,r,l,a){var o;if(!l.resourceIndex.has(e)){const i=e.split("/").pop()||"file",u=(o=i.split(".").pop())==null?void 0:o.toLowerCase();let f="application/octet-stream";u&&(["jpg","jpeg","png","gif","webp"].includes(u)?f=`image/${u==="jpg"?"jpeg":u}`:["mp4","webm","mov","avi"].includes(u)&&(f=`video/${u==="mov"?"quicktime":u}`)),l.resourceIndex.set(e,{name:i,type:f,size:0,uploadedAt:new Date,file:void 0})}wt(t,e,l,{fileName:e,isReadonly:!1,deps:a}).catch(console.error);const c=document.createElement("input");c.type="hidden",c.name=n,c.value=e,r.appendChild(c)}function At(e,t,n,r,l,a,o){rt(e,async c=>{const i=Array.from(c),u=i.filter(x=>!Ee(x.name,l.allowedExtensions)),f=i.filter(x=>Ee(x.name,l.allowedExtensions)),s=f.filter(x=>!$e(x,l.maxSize)),m=f.filter(x=>$e(x,l.maxSize)),p=l.maxCount===1/0?m.length:Math.max(0,l.maxCount-t.length),h=m.slice(0,p),v=m.length-h.length,b=[];if(u.length>0){const x=l.allowedExtensions.join(", "),d=u.map(y=>y.name).join(", ");b.push(k("invalidFileExtension",n,{name:d,formats:x}))}if(s.length>0){const x=s.map(d=>d.name).join(", ");b.push(k("fileTooLarge",n,{name:x,maxSize:l.maxSize}))}v>0&&b.push(k("filesLimitExceeded",n,{skipped:v,max:l.maxCount})),b.length>0?Oe(e,b.join(" \u2022 ")):ot(e);for(const x of h){const d=await St(x,n);n.resourceIndex.set(d,{name:x.name,type:x.type,size:x.size,uploadedAt:new Date,file:void 0}),t.push(d)}r(),o&&a&&!n.config.readonly&&o.triggerOnChange(a,t)})}function Ft(e,t,n,r,l,a,o){e.onchange=async()=>{if(e.files){const c=Array.from(e.files),i=c.filter(x=>!Ee(x.name,l.allowedExtensions)),u=c.filter(x=>Ee(x.name,l.allowedExtensions)),f=u.filter(x=>!$e(x,l.maxSize)),s=u.filter(x=>$e(x,l.maxSize)),m=l.maxCount===1/0?s.length:Math.max(0,l.maxCount-t.length),p=s.slice(0,m),h=s.length-p.length,v=[];if(i.length>0){const x=l.allowedExtensions.join(", "),d=i.map(y=>y.name).join(", ");v.push(k("invalidFileExtension",n,{name:d,formats:x}))}if(f.length>0){const x=f.map(d=>d.name).join(", ");v.push(k("fileTooLarge",n,{name:x,maxSize:l.maxSize}))}h>0&&v.push(k("filesLimitExceeded",n,{skipped:h,max:l.maxCount}));const b=e.closest(".space-y-2")||e.parentElement;v.length>0&&b?Oe(b,v.join(" \u2022 ")):b&&ot(b);for(const x of p){const d=await St(x,n);n.resourceIndex.set(d,{name:x.name,type:x.type,size:x.size,uploadedAt:new Date,file:void 0}),t.push(d)}}r(),e.value="",o&&a&&!n.config.readonly&&o.triggerOnChange(a,t)}}function Wn(e,t,n,r){var l,a;const o=t.state;if(o.config.readonly){const c=t.prefill[e.key];if(c)tt(c,o).then(i=>{n.appendChild(i)}).catch(i=>{console.error("Failed to render file preview:",i);const u=document.createElement("div");u.className="aspect-video bg-gray-100 rounded-lg flex items-center justify-center text-gray-500",u.innerHTML=`<div class="text-center">${W(k("previewUnavailable",o))}</div>`,n.appendChild(u)});else{const i=document.createElement("div");i.className="aspect-video bg-gray-100 rounded-lg flex items-center justify-center text-gray-500",i.innerHTML=`<div class="text-center">${W(k("noFileSelected",o))}</div>`,n.appendChild(i)}}else{const c=document.createElement("div");c.className="space-y-2";const i=document.createElement("input");i.type="file",i.name=r,i.style.display="none",e.accept&&(i.accept=typeof e.accept=="string"?e.accept:((l=e.accept.extensions)==null?void 0:l.map(v=>`.${v}`).join(","))||"");const u=document.createElement("div");u.className="file-preview-container w-full aspect-square max-w-xs bg-gray-100 rounded-lg overflow-hidden relative group cursor-pointer";const f=t.prefill[e.key],s=Me(e.accept),m=(a=e.maxSize)!=null?a:1/0,p=()=>i.click(),h=v=>{if(v.length>0){const b={picker:i,fileUploadHandler:p,dragHandler:h};Lt(v[0],u,r,o,b,t.instance,s,m)}};if(f)_n(f,u,r,c,o,{picker:i,fileUploadHandler:p,dragHandler:h});else{const v=he(e,o);nt(u,o,v)}u.onclick=p,rt(u,h),i.onchange=()=>{if(i.files&&i.files.length>0){const v={picker:i,fileUploadHandler:p,dragHandler:h};Lt(i.files[0],u,r,o,v,t.instance,s,m)}},c.appendChild(u),c.appendChild(i),n.appendChild(c)}}function Jn(e,t,n,r){var l,a;const o=t.state;if(o.config.readonly){const c=document.createElement("div");c.className="space-y-4";const i=t.prefill[e.key]||[];i.length>0?i.forEach(u=>{tt(u,o).then(f=>{c.appendChild(f)}).catch(f=>{console.error("Failed to render file preview:",f)})}):c.innerHTML=`<div class="aspect-video bg-gray-100 rounded-lg flex items-center justify-center text-gray-500"><div class="text-center">${W(k("noFilesSelected",o))}</div></div>`,n.appendChild(c)}else{let c=function(){kt(s,m,o,v=>{const b=m.indexOf(v);b>-1&&m.splice(b,1),c()},p)};const i=document.createElement("div");i.className="space-y-2";const u=document.createElement("input");u.type="file",u.name=r,u.multiple=!0,u.style.display="none",e.accept&&(u.accept=typeof e.accept=="string"?e.accept:((l=e.accept.extensions)==null?void 0:l.map(v=>`.${v}`).join(","))||"");const f=document.createElement("div");f.className="border-2 border-dashed border-gray-300 rounded-lg p-3 hover:border-gray-400 transition-colors";const s=document.createElement("div");s.className="files-list";const m=t.prefill[e.key]||[];Tt(m,o);const p=he(e,o),h={maxCount:1/0,allowedExtensions:Me(e.accept),maxSize:(a=e.maxSize)!=null?a:1/0};c(),At(f,m,o,c,h,r,t.instance),Ft(u,m,o,c,h,r,t.instance),f.appendChild(s),i.appendChild(f),i.appendChild(u),n.appendChild(i)}}function Yn(e,t,n,r){var l,a,o,c;const i=t.state,u=(l=e.minCount)!=null?l:0,f=(a=e.maxCount)!=null?a:1/0;if(i.config.readonly){const s=document.createElement("div");s.className="space-y-4";const m=t.prefill[e.key]||[];m.length>0?m.forEach(p=>{tt(p,i).then(h=>{s.appendChild(h)}).catch(h=>{console.error("Failed to render file preview:",h)})}):s.innerHTML=`<div class="aspect-video bg-gray-100 rounded-lg flex items-center justify-center text-gray-500"><div class="text-center">${W(k("noFilesSelected",i))}</div></div>`,n.appendChild(s)}else{const s=document.createElement("div");s.className="space-y-2";const m=document.createElement("input");m.type="file",m.name=r,m.multiple=!0,m.style.display="none",e.accept&&(m.accept=typeof e.accept=="string"?e.accept:((o=e.accept.extensions)==null?void 0:o.map(y=>`.${y}`).join(","))||"");const p=document.createElement("div");p.className="files-list space-y-2",s.appendChild(m),s.appendChild(p);const h=Array.isArray(t.prefill[e.key])?[...t.prefill[e.key]]:[];Tt(h,i);const v=he(e,i),b={maxCount:f,allowedExtensions:Me(e.accept),maxSize:(c=e.maxSize)!=null?c:1/0},x=()=>{const y=h.length===1?k("fileCountSingle",i,{count:h.length}):k("fileCountPlural",i,{count:h.length}),g=u>0||f<1/0?` ${k("fileCountRange",i,{min:u,max:f})}`:"";return y+g},d=()=>{kt(p,h,i,y=>{h.splice(h.indexOf(y),1),d()},v,x())};At(p,h,i,d,b,r,t.instance),Ft(m,h,i,d,b,r,t.instance),d(),n.appendChild(s)}}function Nt(e,t,n){var r;const l=[],{scopeRoot:a,skipValidation:o,path:c}=n,i=e.type==="files"||"multiple"in e&&!!e.multiple,u=(m,p,h)=>{var v,b;if(o)return;const{state:x}=n,d="minCount"in h&&(v=h.minCount)!=null?v:0,y="maxCount"in h&&(b=h.maxCount)!=null?b:1/0;h.required&&p.length===0&&l.push(`${m}: ${k("required",x)}`),p.length<d&&l.push(`${m}: ${k("minFiles",x,{min:d})}`),p.length>y&&l.push(`${m}: ${k("maxFiles",x,{max:y})}`)},f=(m,p,h)=>{var v;if(o)return;const{state:b}=n,x="accept"in h?h.accept:void 0,d=Me(x);if(d.length===0)return;const y=d.join(", ");for(const g of p){const E=b.resourceIndex.get(g),C=(v=E==null?void 0:E.name)!=null?v:g;Ee(C,d)||l.push(`${m}: ${k("invalidFileExtension",b,{name:C,formats:y})}`)}},s=(m,p,h)=>{var v;if(o)return;const{state:b}=n,x="maxSize"in h&&(v=h.maxSize)!=null?v:1/0;if(x!==1/0)for(const d of p){const y=b.resourceIndex.get(d);y&&y.size>x*1024*1024&&l.push(`${m}: ${k("fileTooLarge",b,{name:y.name,maxSize:x})}`)}};if(i){const m=we(c,t),p=a.querySelector(`input[type="file"][name="${m}"]`),h=p==null?void 0:p.closest(".space-y-2"),v=(h==null?void 0:h.querySelector(".files-list"))||null,b=[];return v&&v.querySelectorAll(".resource-pill").forEach(x=>{const d=x.dataset.resourceId;d&&b.push(d)}),u(t,b,e),f(t,b,e),s(t,b,e),{value:b,errors:l}}else{const m=a.querySelector(`input[name$="${t}"][type="hidden"]`),p=(r=m==null?void 0:m.value)!=null?r:"";return!o&&e.required&&p===""?(l.push(`${t}: ${k("required",n.state)}`),{value:null,errors:l}):(!o&&p!==""&&(f(t,[p],e),s(t,[p],e)),{value:p||null,errors:l})}}function Mt(e,t,n,r){var l;const{scopeRoot:a,state:o}=r;if("multiple"in e&&e.multiple){if(!Array.isArray(n)){console.warn(`updateFileField: Expected array for multiple file field "${t}", got ${typeof n}`);return}n.forEach(c=>{var i;if(c&&typeof c=="string"&&!o.resourceIndex.has(c)){const u=c.split("/").pop()||"file",f=(i=u.split(".").pop())==null?void 0:i.toLowerCase();let s="application/octet-stream";f&&(["jpg","jpeg","png","gif","webp"].includes(f)?s=`image/${f==="jpg"?"jpeg":f}`:["mp4","webm","mov","avi"].includes(f)&&(s=`video/${f==="mov"?"quicktime":f}`)),o.resourceIndex.set(c,{name:u,type:s,size:0,uploadedAt:new Date,file:void 0})}}),console.info(`updateFileField: Multiple file field "${t}" updated. Preview update requires re-render.`)}else{const c=a.querySelector(`input[name="${t}"][type="hidden"]`);if(!c){console.warn(`updateFileField: Hidden input not found for file field "${t}"`);return}if(c.value=n!=null?String(n):"",n&&typeof n=="string"){if(!o.resourceIndex.has(n)){const i=n.split("/").pop()||"file",u=(l=i.split(".").pop())==null?void 0:l.toLowerCase();let f="application/octet-stream";u&&(["jpg","jpeg","png","gif","webp"].includes(u)?f=`image/${u==="jpg"?"jpeg":u}`:["mp4","webm","mov","avi"].includes(u)&&(f=`video/${u==="mov"?"quicktime":u}`)),o.resourceIndex.set(n,{name:i,type:f,size:0,uploadedAt:new Date,file:void 0})}console.info(`updateFileField: File field "${t}" updated. Preview update requires re-render.`)}}}function Le(e){return e?e.toUpperCase():"#000000"}function lt(e){return/^#[0-9A-F]{6}$/i.test(e)||/^#[0-9A-F]{3}$/i.test(e)}function qt(e){if(/^#[0-9A-F]{3}$/i.test(e)){const t=e[1],n=e[2],r=e[3];return`#${t}${t}${n}${n}${r}${r}`.toUpperCase()}return e.toUpperCase()}function zt(e){const t=document.createElement("div");t.className="flex items-center gap-2";const n=Le(e),r=document.createElement("div");r.style.cssText=`
|
|
233
|
+
`,a.textContent=t,(r=e.closest(".space-y-2"))==null||r.appendChild(a)}function rt(e){var t;const n=(t=e.closest(".space-y-2"))==null?void 0:t.querySelector(".file-error-message");n&&n.remove()}async function At(e,t,n,r,l=null,a,o=[],s=1/0){var i,u;if(!we(e.name,o)){const m=o.join(", ");Pe(t,k("invalidFileExtension",r,{name:e.name,formats:m}));return}if(!Le(e,s)){Pe(t,k("fileTooLarge",r,{name:e.name,maxSize:s}));return}rt(t);let f;if(r.config.uploadFile)try{if(f=await r.config.uploadFile(e),typeof f!="string")throw new Error("Upload handler must return a string resource ID")}catch(m){const p=m instanceof Error?m:new Error(String(m));throw r.config.onUploadError&&r.config.onUploadError(p,e),new Error(`File upload failed: ${p.message}`)}else throw new Error("No upload handler configured. Set uploadHandler via FormBuilder.setUploadHandler()");r.resourceIndex.set(f,{name:e.name,type:e.type,size:e.size,uploadedAt:new Date,file:e});let c=(i=t.parentElement)==null?void 0:i.querySelector('input[type="hidden"]');c||(c=document.createElement("input"),c.type="hidden",c.name=n,(u=t.parentElement)==null||u.appendChild(c)),c.value=f,Lt(t,f,r,{fileName:e.name,isReadonly:!1,deps:l}).catch(console.error),a&&!r.config.readonly&&a.triggerOnChange(n,f)}function lt(e,t){e.addEventListener("dragover",n=>{n.preventDefault(),e.classList.add("border-blue-500","bg-blue-50")}),e.addEventListener("dragleave",n=>{n.preventDefault(),e.classList.remove("border-blue-500","bg-blue-50")}),e.addEventListener("drop",n=>{var r;n.preventDefault(),e.classList.remove("border-blue-500","bg-blue-50"),(r=n.dataTransfer)!=null&&r.files&&t(n.dataTransfer.files)})}function _n(e,t,n){const r=e.querySelector(".delete-overlay");r&&r.remove();const l=document.createElement("div");l.className="delete-overlay absolute inset-0 bg-black bg-opacity-50 opacity-0 group-hover:opacity-100 transition-opacity flex items-center justify-center";const a=document.createElement("button");a.className="bg-red-600 text-white px-3 py-1 rounded text-sm hover:bg-red-700 transition-colors",a.textContent=k("removeElement",t),a.onclick=o=>{o.stopPropagation(),n()},l.appendChild(a),e.appendChild(l)}async function Ft(e,t){if(t.config.uploadFile)try{const n=await t.config.uploadFile(e);if(typeof n!="string")throw new Error("Upload handler must return a string resource ID");return n}catch(n){const r=n instanceof Error?n:new Error(String(n));throw t.config.onUploadError&&t.config.onUploadError(r,e),new Error(`File upload failed: ${r.message}`)}else throw new Error("No upload handler configured. Set uploadHandler via FormBuilder.setUploadHandler()")}async function Wn(e,t,n){try{let r=null;if(n.config.getDownloadUrl?r=n.config.getDownloadUrl(e):n.config.getThumbnail&&(r=await n.config.getThumbnail(e)),r){const l=r.startsWith("http")?r:new URL(r,window.location.href).href,a=await fetch(l);if(!a.ok)throw new Error(`HTTP error! status: ${a.status}`);const o=await a.blob();Jn(o,t)}else throw new Error("No download URL available for resource")}catch(r){const l=r instanceof Error?r:new Error(String(r));throw n.config.onDownloadError&&n.config.onDownloadError(l,e,t),console.error(`File download failed for ${t}:`,l),l}}function Jn(e,t){try{const n=URL.createObjectURL(e),r=document.createElement("a");r.href=n,r.download=t,r.style.display="none",document.body.appendChild(r),r.click(),document.body.removeChild(r),setTimeout(()=>{URL.revokeObjectURL(n)},100)}catch(n){throw new Error(`Blob download failed: ${n.message}`)}}function Nt(e,t){e.length>0&&e.forEach(n=>{var r;if(!t.resourceIndex.has(n)){const l=n.split("/").pop()||"file",a=(r=l.split(".").pop())==null?void 0:r.toLowerCase();let o="application/octet-stream";a&&(["jpg","jpeg","png","gif","webp"].includes(a)?o=`image/${a==="jpg"?"jpeg":a}`:["mp4","webm","mov","avi"].includes(a)&&(o=`video/${a==="mov"?"quicktime":a}`)),t.resourceIndex.set(n,{name:l,type:o,size:0,uploadedAt:new Date,file:void 0})}})}function Yn(e,t,n,r,l,a){var o;if(!l.resourceIndex.has(e)){const i=e.split("/").pop()||"file",u=(o=i.split(".").pop())==null?void 0:o.toLowerCase();let f="application/octet-stream";u&&(["jpg","jpeg","png","gif","webp"].includes(u)?f=`image/${u==="jpg"?"jpeg":u}`:["mp4","webm","mov","avi"].includes(u)&&(f=`video/${u==="mov"?"quicktime":u}`)),l.resourceIndex.set(e,{name:i,type:f,size:0,uploadedAt:new Date,file:void 0})}Lt(t,e,l,{fileName:e,isReadonly:!1,deps:a}).catch(console.error);const s=document.createElement("input");s.type="hidden",s.name=n,s.value=e,r.appendChild(s)}function Mt(e,t,n,r,l,a,o){lt(e,async s=>{const i=Array.from(s),u=i.filter(x=>!we(x.name,l.allowedExtensions)),f=i.filter(x=>we(x.name,l.allowedExtensions)),c=f.filter(x=>!Le(x,l.maxSize)),m=f.filter(x=>Le(x,l.maxSize)),p=l.maxCount===1/0?m.length:Math.max(0,l.maxCount-t.length),h=m.slice(0,p),v=m.length-h.length,b=[];if(u.length>0){const x=l.allowedExtensions.join(", "),d=u.map(y=>y.name).join(", ");b.push(k("invalidFileExtension",n,{name:d,formats:x}))}if(c.length>0){const x=c.map(d=>d.name).join(", ");b.push(k("fileTooLarge",n,{name:x,maxSize:l.maxSize}))}v>0&&b.push(k("filesLimitExceeded",n,{skipped:v,max:l.maxCount})),b.length>0?Pe(e,b.join(" \u2022 ")):rt(e);for(const x of h){const d=await Ft(x,n);n.resourceIndex.set(d,{name:x.name,type:x.type,size:x.size,uploadedAt:new Date,file:void 0}),t.push(d)}r(),o&&a&&!n.config.readonly&&o.triggerOnChange(a,t)})}function qt(e,t,n,r,l,a,o){e.onchange=async()=>{if(e.files){const s=Array.from(e.files),i=s.filter(x=>!we(x.name,l.allowedExtensions)),u=s.filter(x=>we(x.name,l.allowedExtensions)),f=u.filter(x=>!Le(x,l.maxSize)),c=u.filter(x=>Le(x,l.maxSize)),m=l.maxCount===1/0?c.length:Math.max(0,l.maxCount-t.length),p=c.slice(0,m),h=c.length-p.length,v=[];if(i.length>0){const x=l.allowedExtensions.join(", "),d=i.map(y=>y.name).join(", ");v.push(k("invalidFileExtension",n,{name:d,formats:x}))}if(f.length>0){const x=f.map(d=>d.name).join(", ");v.push(k("fileTooLarge",n,{name:x,maxSize:l.maxSize}))}h>0&&v.push(k("filesLimitExceeded",n,{skipped:h,max:l.maxCount}));const b=e.closest(".space-y-2")||e.parentElement;v.length>0&&b?Pe(b,v.join(" \u2022 ")):b&&rt(b);for(const x of p){const d=await Ft(x,n);n.resourceIndex.set(d,{name:x.name,type:x.type,size:x.size,uploadedAt:new Date,file:void 0}),t.push(d)}}r(),e.value="",o&&a&&!n.config.readonly&&o.triggerOnChange(a,t)}}function Xn(e,t,n,r){var l,a;const o=t.state;if(o.config.readonly){const s=t.prefill[e.key];if(s)nt(s,o).then(i=>{n.appendChild(i)}).catch(i=>{console.error("Failed to render file preview:",i);const u=document.createElement("div");u.className="aspect-video bg-gray-100 rounded-lg flex items-center justify-center text-gray-500",u.innerHTML=`<div class="text-center">${J(k("previewUnavailable",o))}</div>`,n.appendChild(u)});else{const i=document.createElement("div");i.className="aspect-video bg-gray-100 rounded-lg flex items-center justify-center text-gray-500",i.innerHTML=`<div class="text-center">${J(k("noFileSelected",o))}</div>`,n.appendChild(i)}}else{const s=document.createElement("div");s.className="space-y-2";const i=document.createElement("input");i.type="file",i.name=r,i.style.display="none",e.accept&&(i.accept=typeof e.accept=="string"?e.accept:((l=e.accept.extensions)==null?void 0:l.map(v=>`.${v}`).join(","))||"");const u=document.createElement("div");u.className="file-preview-container w-full aspect-square max-w-xs bg-gray-100 rounded-lg overflow-hidden relative group cursor-pointer";const f=t.prefill[e.key],c=He(e.accept),m=(a=e.maxSize)!=null?a:1/0,p=()=>i.click(),h=v=>{if(v.length>0){const b={picker:i,fileUploadHandler:p,dragHandler:h};At(v[0],u,r,o,b,t.instance,c,m)}};if(f)Yn(f,u,r,s,o,{picker:i,fileUploadHandler:p,dragHandler:h});else{const v=ve(e,o);ot(u,o,v)}u.onclick=p,lt(u,h),i.onchange=()=>{if(i.files&&i.files.length>0){const v={picker:i,fileUploadHandler:p,dragHandler:h};At(i.files[0],u,r,o,v,t.instance,c,m)}},s.appendChild(u),s.appendChild(i),n.appendChild(s)}}function Gn(e,t,n,r){var l,a;const o=t.state;if(o.config.readonly){const s=document.createElement("div");s.className="space-y-4";const i=t.prefill[e.key]||[];i.length>0?i.forEach(u=>{nt(u,o).then(f=>{s.appendChild(f)}).catch(f=>{console.error("Failed to render file preview:",f)})}):s.innerHTML=`<div class="aspect-video bg-gray-100 rounded-lg flex items-center justify-center text-gray-500"><div class="text-center">${J(k("noFilesSelected",o))}</div></div>`,n.appendChild(s)}else{let s=function(){St(c,m,o,v=>{const b=m.indexOf(v);b>-1&&m.splice(b,1),s()},p)};const i=document.createElement("div");i.className="space-y-2";const u=document.createElement("input");u.type="file",u.name=r,u.multiple=!0,u.style.display="none",e.accept&&(u.accept=typeof e.accept=="string"?e.accept:((l=e.accept.extensions)==null?void 0:l.map(v=>`.${v}`).join(","))||"");const f=document.createElement("div");f.className="border-2 border-dashed border-gray-300 rounded-lg p-3 hover:border-gray-400 transition-colors";const c=document.createElement("div");c.className="files-list";const m=t.prefill[e.key]||[];Nt(m,o);const p=ve(e,o),h={maxCount:1/0,allowedExtensions:He(e.accept),maxSize:(a=e.maxSize)!=null?a:1/0};s(),Mt(f,m,o,s,h,r,t.instance),qt(u,m,o,s,h,r,t.instance),f.appendChild(c),i.appendChild(f),i.appendChild(u),n.appendChild(i)}}function Zn(e,t,n,r){var l,a,o,s;const i=t.state,u=(l=e.minCount)!=null?l:0,f=(a=e.maxCount)!=null?a:1/0;if(i.config.readonly){const c=document.createElement("div");c.className="space-y-4";const m=t.prefill[e.key]||[];m.length>0?m.forEach(p=>{nt(p,i).then(h=>{c.appendChild(h)}).catch(h=>{console.error("Failed to render file preview:",h)})}):c.innerHTML=`<div class="aspect-video bg-gray-100 rounded-lg flex items-center justify-center text-gray-500"><div class="text-center">${J(k("noFilesSelected",i))}</div></div>`,n.appendChild(c)}else{const c=document.createElement("div");c.className="space-y-2";const m=document.createElement("input");m.type="file",m.name=r,m.multiple=!0,m.style.display="none",e.accept&&(m.accept=typeof e.accept=="string"?e.accept:((o=e.accept.extensions)==null?void 0:o.map(y=>`.${y}`).join(","))||"");const p=document.createElement("div");p.className="files-list space-y-2",c.appendChild(m),c.appendChild(p);const h=Array.isArray(t.prefill[e.key])?[...t.prefill[e.key]]:[];Nt(h,i);const v=ve(e,i),b={maxCount:f,allowedExtensions:He(e.accept),maxSize:(s=e.maxSize)!=null?s:1/0},x=()=>{const y=h.length===1?k("fileCountSingle",i,{count:h.length}):k("fileCountPlural",i,{count:h.length}),g=u>0||f<1/0?` ${k("fileCountRange",i,{min:u,max:f})}`:"";return y+g},d=()=>{St(p,h,i,y=>{h.splice(h.indexOf(y),1),d()},v,x())};Mt(p,h,i,d,b,r,t.instance),qt(m,h,i,d,b,r,t.instance),d(),n.appendChild(c)}}function zt(e,t,n){var r;const l=[],{scopeRoot:a,skipValidation:o,path:s}=n,i=e.type==="files"||"multiple"in e&&!!e.multiple,u=(m,p,h)=>{var v,b;if(o)return;const{state:x}=n,d="minCount"in h&&(v=h.minCount)!=null?v:0,y="maxCount"in h&&(b=h.maxCount)!=null?b:1/0;h.required&&p.length===0&&l.push(`${m}: ${k("required",x)}`),p.length<d&&l.push(`${m}: ${k("minFiles",x,{min:d})}`),p.length>y&&l.push(`${m}: ${k("maxFiles",x,{max:y})}`)},f=(m,p,h)=>{var v;if(o)return;const{state:b}=n,x="accept"in h?h.accept:void 0,d=He(x);if(d.length===0)return;const y=d.join(", ");for(const g of p){const E=b.resourceIndex.get(g),C=(v=E==null?void 0:E.name)!=null?v:g;we(C,d)||l.push(`${m}: ${k("invalidFileExtension",b,{name:C,formats:y})}`)}},c=(m,p,h)=>{var v;if(o)return;const{state:b}=n,x="maxSize"in h&&(v=h.maxSize)!=null?v:1/0;if(x!==1/0)for(const d of p){const y=b.resourceIndex.get(d);y&&y.size>x*1024*1024&&l.push(`${m}: ${k("fileTooLarge",b,{name:y.name,maxSize:x})}`)}};if(i){const m=ge(s,t),p=a.querySelector(`input[type="file"][name="${m}"]`),h=p==null?void 0:p.closest(".space-y-2"),v=(h==null?void 0:h.querySelector(".files-list"))||null,b=[];return v&&v.querySelectorAll(".resource-pill").forEach(x=>{const d=x.dataset.resourceId;d&&b.push(d)}),u(t,b,e),f(t,b,e),c(t,b,e),{value:b,errors:l}}else{const m=a.querySelector(`input[name$="${t}"][type="hidden"]`),p=(r=m==null?void 0:m.value)!=null?r:"";return!o&&e.required&&p===""?(l.push(`${t}: ${k("required",n.state)}`),{value:null,errors:l}):(!o&&p!==""&&(f(t,[p],e),c(t,[p],e)),{value:p||null,errors:l})}}function Ht(e,t,n,r){var l;const{scopeRoot:a,state:o}=r;if("multiple"in e&&e.multiple){if(!Array.isArray(n)){console.warn(`updateFileField: Expected array for multiple file field "${t}", got ${typeof n}`);return}n.forEach(s=>{var i;if(s&&typeof s=="string"&&!o.resourceIndex.has(s)){const u=s.split("/").pop()||"file",f=(i=u.split(".").pop())==null?void 0:i.toLowerCase();let c="application/octet-stream";f&&(["jpg","jpeg","png","gif","webp"].includes(f)?c=`image/${f==="jpg"?"jpeg":f}`:["mp4","webm","mov","avi"].includes(f)&&(c=`video/${f==="mov"?"quicktime":f}`)),o.resourceIndex.set(s,{name:u,type:c,size:0,uploadedAt:new Date,file:void 0})}}),console.info(`updateFileField: Multiple file field "${t}" updated. Preview update requires re-render.`)}else{const s=a.querySelector(`input[name="${t}"][type="hidden"]`);if(!s){console.warn(`updateFileField: Hidden input not found for file field "${t}"`);return}if(s.value=n!=null?String(n):"",n&&typeof n=="string"){if(!o.resourceIndex.has(n)){const i=n.split("/").pop()||"file",u=(l=i.split(".").pop())==null?void 0:l.toLowerCase();let f="application/octet-stream";u&&(["jpg","jpeg","png","gif","webp"].includes(u)?f=`image/${u==="jpg"?"jpeg":u}`:["mp4","webm","mov","avi"].includes(u)&&(f=`video/${u==="mov"?"quicktime":u}`)),o.resourceIndex.set(n,{name:i,type:f,size:0,uploadedAt:new Date,file:void 0})}console.info(`updateFileField: File field "${t}" updated. Preview update requires re-render.`)}}}function Se(e){return e?e.toUpperCase():"#000000"}function at(e){return/^#[0-9A-F]{6}$/i.test(e)||/^#[0-9A-F]{3}$/i.test(e)}function It(e){if(/^#[0-9A-F]{3}$/i.test(e)){const t=e[1],n=e[2],r=e[3];return`#${t}${t}${n}${n}${r}${r}`.toUpperCase()}return e.toUpperCase()}function Bt(e){const t=document.createElement("div");t.className="flex items-center gap-2";const n=Se(e),r=document.createElement("div");r.style.cssText=`
|
|
234
234
|
width: 32px;
|
|
235
235
|
height: 32px;
|
|
236
236
|
border-radius: var(--fb-border-radius);
|
|
@@ -240,7 +240,7 @@ var FormBuilder=(function(be){"use strict";function k(e,t,n){const r=t.config.lo
|
|
|
240
240
|
font-size: var(--fb-font-size);
|
|
241
241
|
color: var(--fb-text-color);
|
|
242
242
|
font-family: var(--fb-font-family-mono, monospace);
|
|
243
|
-
`,l.textContent=n,t.appendChild(r),t.appendChild(l),t}function
|
|
243
|
+
`,l.textContent=n,t.appendChild(r),t.appendChild(l),t}function Rt(e,t,n){const r=Se(e),l=document.createElement("div");l.className="colour-picker-wrapper",l.style.cssText=`
|
|
244
244
|
display: flex;
|
|
245
245
|
align-items: center;
|
|
246
246
|
gap: 8px;
|
|
@@ -263,18 +263,18 @@ var FormBuilder=(function(be){"use strict";function k(e,t,n){const r=t.config.lo
|
|
|
263
263
|
font-size: var(--fb-font-size);
|
|
264
264
|
font-family: var(--fb-font-family-mono, monospace);
|
|
265
265
|
transition: all var(--fb-transition-duration) ease-in-out;
|
|
266
|
-
`;const
|
|
266
|
+
`;const s=document.createElement("input");return s.type="color",s.className="colour-picker-hidden",s.value=r.toLowerCase(),s.style.cssText=`
|
|
267
267
|
position: absolute;
|
|
268
268
|
opacity: 0;
|
|
269
269
|
pointer-events: none;
|
|
270
|
-
`,o.addEventListener("input",()=>{const i=o.value.trim();if(
|
|
270
|
+
`,o.addEventListener("input",()=>{const i=o.value.trim();if(at(i)){const u=It(i);a.style.backgroundColor=u,s.value=u.toLowerCase(),o.classList.remove("invalid"),n.instance&&n.instance.triggerOnChange(t,u)}else o.classList.add("invalid")}),o.addEventListener("blur",()=>{const i=o.value.trim();if(at(i)){const u=It(i);o.value=u,a.style.backgroundColor=u,s.value=u.toLowerCase(),o.classList.remove("invalid")}}),s.addEventListener("change",()=>{const i=Se(s.value);o.value=i,a.style.backgroundColor=i,n.instance&&n.instance.triggerOnChange(t,i)}),a.addEventListener("click",()=>{s.click()}),a.addEventListener("mouseenter",()=>{a.style.borderColor="var(--fb-border-hover-color)"}),a.addEventListener("mouseleave",()=>{a.style.borderColor="var(--fb-border-color)"}),o.addEventListener("focus",()=>{o.style.borderColor="var(--fb-border-focus-color)",o.style.outline="var(--fb-focus-ring-width) solid var(--fb-focus-ring-color)",o.style.outlineOffset="0"}),o.addEventListener("blur",()=>{o.style.borderColor="var(--fb-border-color)",o.style.outline="none"}),o.addEventListener("mouseenter",()=>{document.activeElement!==o&&(o.style.borderColor="var(--fb-border-hover-color)")}),o.addEventListener("mouseleave",()=>{document.activeElement!==o&&(o.style.borderColor="var(--fb-border-color)")}),l.appendChild(a),l.appendChild(o),l.appendChild(s),l}function Qn(e,t,n,r){const l=t.state,a=t.prefill[e.key]||e.default||"#000000";if(l.config.readonly){const o=Bt(a);n.appendChild(o)}else{const o=Rt(a,r,t);n.appendChild(o)}if(!l.config.readonly){const o=document.createElement("p");o.className="mt-1",o.style.cssText=`
|
|
271
271
|
font-size: var(--fb-font-size-small);
|
|
272
272
|
color: var(--fb-text-secondary-color);
|
|
273
|
-
`,o.textContent=
|
|
273
|
+
`,o.textContent=ve(e,l),n.appendChild(o)}}function eo(e,t,n,r){var l,a;const o=t.state,s=t.prefill[e.key]||[],i=Array.isArray(s)?[...s]:[],u=(l=e.minCount)!=null?l:1,f=(a=e.maxCount)!=null?a:1/0;for(;i.length<u;)i.push(e.default||"#000000");const c=document.createElement("div");c.className="space-y-2",n.appendChild(c);function m(){c.querySelectorAll(".multiple-colour-item").forEach((d,y)=>{const g=d.querySelector("input");g&&(g.name=`${r}[${y}]`)})}function p(d="#000000",y=-1){const g=document.createElement("div");if(g.className="multiple-colour-item flex items-center gap-2",o.config.readonly){const E=Bt(d);for(;E.firstChild;)g.appendChild(E.firstChild)}else{const E=`${r}[${c.children.length}]`,C=Rt(d,E,t);C.style.flex="1",g.appendChild(C)}return y===-1?c.appendChild(g):c.insertBefore(g,c.children[y]),m(),g}function h(){if(o.config.readonly)return;const d=c.querySelectorAll(".multiple-colour-item"),y=d.length;d.forEach(g=>{let E=g.querySelector(".remove-item-btn");E||(E=document.createElement("button"),E.type="button",E.className="remove-item-btn px-2 py-1 rounded",E.style.cssText=`
|
|
274
274
|
color: var(--fb-error-color);
|
|
275
275
|
background-color: transparent;
|
|
276
276
|
transition: background-color var(--fb-transition-duration);
|
|
277
|
-
`,E.innerHTML="\u2715",E.addEventListener("mouseenter",()=>{E.style.backgroundColor="var(--fb-background-hover-color)"}),E.addEventListener("mouseleave",()=>{E.style.backgroundColor="transparent"}),E.onclick=()=>{const w=Array.from(
|
|
277
|
+
`,E.innerHTML="\u2715",E.addEventListener("mouseenter",()=>{E.style.backgroundColor="var(--fb-background-hover-color)"}),E.addEventListener("mouseleave",()=>{E.style.backgroundColor="transparent"}),E.onclick=()=>{const w=Array.from(c.children).indexOf(g);c.children.length>u&&(i.splice(w,1),g.remove(),m(),x(),h())},g.appendChild(E));const C=y<=u;E.disabled=C,E.style.opacity=C?"0.5":"1",E.style.pointerEvents=C?"none":"auto"})}let v=null,b=null;if(!o.config.readonly){v=document.createElement("div"),v.className="flex items-center gap-3 mt-2";const d=document.createElement("button");d.type="button",d.className="add-colour-btn px-3 py-1 rounded",d.style.cssText=`
|
|
278
278
|
color: var(--fb-primary-color);
|
|
279
279
|
border: var(--fb-border-width) solid var(--fb-primary-color);
|
|
280
280
|
background-color: transparent;
|
|
@@ -283,18 +283,18 @@ var FormBuilder=(function(be){"use strict";function k(e,t,n){const r=t.config.lo
|
|
|
283
283
|
`,d.textContent="+",d.addEventListener("mouseenter",()=>{d.style.backgroundColor="var(--fb-background-hover-color)"}),d.addEventListener("mouseleave",()=>{d.style.backgroundColor="transparent"}),d.onclick=()=>{const y=e.default||"#000000";i.push(y),p(y),x(),h()},b=document.createElement("span"),b.className="text-sm text-gray-500",v.appendChild(d),v.appendChild(b),n.appendChild(v)}function x(){if(!v||!b)return;const d=v.querySelector(".add-colour-btn");if(d){const y=i.length>=f;d.disabled=y,d.style.opacity=y?"0.5":"1",d.style.pointerEvents=y?"none":"auto"}b.textContent=`${i.length}/${f===1/0?"\u221E":f}`}if(i.forEach(d=>p(d)),x(),h(),!o.config.readonly){const d=document.createElement("p");d.className="mt-1",d.style.cssText=`
|
|
284
284
|
font-size: var(--fb-font-size-small);
|
|
285
285
|
color: var(--fb-text-secondary-color);
|
|
286
|
-
`,d.textContent=
|
|
286
|
+
`,d.textContent=ve(e,o),n.appendChild(d)}}function to(e,t,n){var r,l,a;const o=[],{scopeRoot:s,skipValidation:i}=n,u=(c,m)=>{var p,h;if(!c)return;const v=`error-${c.getAttribute("name")||Math.random().toString(36).substring(7)}`;let b=document.getElementById(v);m?(c.classList.add("invalid"),c.title=m,b||(b=document.createElement("div"),b.id=v,b.className="error-message",b.style.cssText=`
|
|
287
287
|
color: var(--fb-error-color);
|
|
288
288
|
font-size: var(--fb-font-size-small);
|
|
289
289
|
margin-top: 0.25rem;
|
|
290
|
-
`,
|
|
290
|
+
`,c.nextSibling?(p=c.parentNode)==null||p.insertBefore(b,c.nextSibling):(h=c.parentNode)==null||h.appendChild(b)),b.textContent=m,b.style.display="block"):(c.classList.remove("invalid"),c.title="",b&&b.remove())},f=(c,m,p)=>{const{state:h}=n;if(!m){if(!i&&e.required){const b=k("required",h);return o.push(`${p}: ${b}`),u(c,b),""}return u(c,null),""}const v=Se(m);if(!i&&!at(v)){const b=k("invalidHexColour",h);return o.push(`${p}: ${b}`),u(c,b),m}return u(c,null),v};if(e.multiple){const c=s.querySelectorAll(`[name^="${t}["].colour-hex-input`),m=[];if(c.forEach((p,h)=>{var v;const b=(v=p==null?void 0:p.value)!=null?v:"",x=f(p,b,`${t}[${h}]`);m.push(x)}),!i){const{state:p}=n,h=(r=e.minCount)!=null?r:1,v=(l=e.maxCount)!=null?l:1/0,b=m.filter(x=>x!=="");e.required&&b.length===0&&o.push(`${t}: ${k("required",p)}`),b.length<h&&o.push(`${t}: ${k("minItems",p,{min:h})}`),b.length>v&&o.push(`${t}: ${k("maxItems",p,{max:v})}`)}return{value:m,errors:o}}else{const c=s.querySelector(`[name="${t}"].colour-hex-input`),m=(a=c==null?void 0:c.value)!=null?a:"";if(!i&&e.required&&m===""){const p=k("required",n.state);return o.push(`${t}: ${p}`),u(c,p),{value:"",errors:o}}return{value:f(c,m,t),errors:o}}}function no(e,t,n,r){const{scopeRoot:l}=r;if(e.multiple){if(!Array.isArray(n)){console.warn(`updateColourField: Expected array for multiple field "${t}", got ${typeof n}`);return}const a=l.querySelectorAll(`[name^="${t}["].colour-hex-input`);a.forEach((o,s)=>{if(s<n.length){const i=Se(n[s]);o.value=i,o.classList.remove("invalid"),o.title="";const u=o.closest(".colour-picker-wrapper");if(u){const f=u.querySelector(".colour-swatch"),c=u.querySelector(".colour-picker-hidden");f&&(f.style.backgroundColor=i),c&&(c.value=i.toLowerCase())}}}),n.length!==a.length&&console.warn(`updateColourField: Multiple field "${t}" has ${a.length} inputs but received ${n.length} values. Consider re-rendering for add/remove.`)}else{const a=l.querySelector(`[name="${t}"].colour-hex-input`);if(a){const o=Se(n);a.value=o,a.classList.remove("invalid"),a.title="";const s=a.closest(".colour-picker-wrapper");if(s){const i=s.querySelector(".colour-swatch"),u=s.querySelector(".colour-picker-hidden");i&&(i.style.backgroundColor=o),u&&(u.value=o.toLowerCase())}}}}function Dt(e,t,n){if(t<=0)throw new Error("Exponential scale requires min > 0");const r=Math.log(t),l=Math.log(n);return Math.exp(r+e*(l-r))}function it(e,t,n){if(t<=0)throw new Error("Exponential scale requires min > 0");const r=Math.log(t),l=Math.log(n);return(Math.log(e)-r)/(l-r)}function Ve(e,t){return Math.round(e/t)*t}function jt(e,t,n,r,l){var a;const o=document.createElement("div");o.className="slider-container";const s=document.createElement("div");s.className="flex items-start gap-3";const i=document.createElement("div");i.className="flex-1";const u=document.createElement("input");u.type="range",u.name=t,u.className="slider-input w-full",u.disabled=l;const f=n.scale||"linear",c=n.min,m=n.max,p=(a=n.step)!=null?a:1;if(f==="exponential"){if(c<=0)throw new Error(`Slider "${n.key}": exponential scale requires min > 0 (got ${c})`);u.min="0",u.max="1000",u.step="1";const d=it(e,c,m);u.value=(d*1e3).toString()}else u.min=c.toString(),u.max=m.toString(),u.step=p.toString(),u.value=e.toString();u.style.cssText=`
|
|
291
291
|
height: 6px;
|
|
292
292
|
border-radius: 3px;
|
|
293
293
|
background: linear-gradient(
|
|
294
294
|
to right,
|
|
295
295
|
var(--fb-primary-color) 0%,
|
|
296
|
-
var(--fb-primary-color) ${(e-
|
|
297
|
-
var(--fb-border-color) ${(e-
|
|
296
|
+
var(--fb-primary-color) ${(e-c)/(m-c)*100}%,
|
|
297
|
+
var(--fb-border-color) ${(e-c)/(m-c)*100}%,
|
|
298
298
|
var(--fb-border-color) 100%
|
|
299
299
|
);
|
|
300
300
|
outline: none;
|
|
@@ -305,7 +305,7 @@ var FormBuilder=(function(be){"use strict";function k(e,t,n){const r=t.config.lo
|
|
|
305
305
|
font-size: var(--fb-font-size-small);
|
|
306
306
|
color: var(--fb-text-secondary-color);
|
|
307
307
|
margin-top: 4px;
|
|
308
|
-
`;const v=document.createElement("span");v.textContent=
|
|
308
|
+
`;const v=document.createElement("span");v.textContent=c.toString();const b=document.createElement("span");b.textContent=m.toString(),h.appendChild(v),h.appendChild(b),i.appendChild(h);const x=document.createElement("span");if(x.className="slider-value",x.style.cssText=`
|
|
309
309
|
min-width: 60px;
|
|
310
310
|
text-align: right;
|
|
311
311
|
font-size: var(--fb-font-size);
|
|
@@ -313,16 +313,16 @@ var FormBuilder=(function(be){"use strict";function k(e,t,n){const r=t.config.lo
|
|
|
313
313
|
font-family: var(--fb-font-family-mono, monospace);
|
|
314
314
|
font-weight: 500;
|
|
315
315
|
padding-top: 2px;
|
|
316
|
-
`,x.textContent=e.toFixed(p<1?2:0),
|
|
316
|
+
`,x.textContent=e.toFixed(p<1?2:0),s.appendChild(i),s.appendChild(x),o.appendChild(s),!l){const d=()=>{let y;if(f==="exponential"){const E=parseFloat(u.value)/1e3;y=Dt(E,c,m),y=Ve(y,p),y=Math.max(c,Math.min(m,y))}else y=parseFloat(u.value),y=Ve(y,p);x.textContent=y.toFixed(p<1?2:0);const g=(y-c)/(m-c)*100;u.style.background=`linear-gradient(
|
|
317
317
|
to right,
|
|
318
318
|
var(--fb-primary-color) 0%,
|
|
319
319
|
var(--fb-primary-color) ${g}%,
|
|
320
320
|
var(--fb-border-color) ${g}%,
|
|
321
321
|
var(--fb-border-color) 100%
|
|
322
|
-
)`,r.instance&&r.instance.triggerOnChange(t,y)};u.addEventListener("input",d),u.addEventListener("change",d)}return o}function
|
|
322
|
+
)`,r.instance&&r.instance.triggerOnChange(t,y)};u.addEventListener("input",d),u.addEventListener("change",d)}return o}function oo(e,t,n,r){var l;if(e.min===void 0||e.min===null)throw new Error(`Slider field "${e.key}" requires "min" property`);if(e.max===void 0||e.max===null)throw new Error(`Slider field "${e.key}" requires "max" property`);if(e.min>=e.max)throw new Error(`Slider field "${e.key}": min (${e.min}) must be less than max (${e.max})`);const a=t.state,o=e.default!==void 0?e.default:(e.min+e.max)/2,s=(l=t.prefill[e.key])!=null?l:o,i=jt(s,r,e,t,a.config.readonly);if(n.appendChild(i),!a.config.readonly){const u=document.createElement("p");u.className="mt-1",u.style.cssText=`
|
|
323
323
|
font-size: var(--fb-font-size-small);
|
|
324
324
|
color: var(--fb-text-secondary-color);
|
|
325
|
-
`,u.textContent=
|
|
325
|
+
`,u.textContent=ve(e,a),n.appendChild(u)}}function ro(e,t,n,r){var l,a;if(e.min===void 0||e.min===null)throw new Error(`Slider field "${e.key}" requires "min" property`);if(e.max===void 0||e.max===null)throw new Error(`Slider field "${e.key}" requires "max" property`);if(e.min>=e.max)throw new Error(`Slider field "${e.key}": min (${e.min}) must be less than max (${e.max})`);const o=t.state,s=t.prefill[e.key]||[],i=Array.isArray(s)?[...s]:[],u=(l=e.minCount)!=null?l:1,f=(a=e.maxCount)!=null?a:1/0,c=e.default!==void 0?e.default:(e.min+e.max)/2;for(;i.length<u;)i.push(c);const m=document.createElement("div");m.className="space-y-3",n.appendChild(m);function p(){m.querySelectorAll(".multiple-slider-item").forEach((y,g)=>{const E=y.querySelector("input[type=range]");E&&E.setAttribute("name",`${r}[${g}]`)})}function h(y=c,g=-1){const E=document.createElement("div");E.className="multiple-slider-item flex items-start gap-2";const C=`${r}[${m.children.length}]`,w=jt(y,C,e,t,o.config.readonly);return w.style.flex="1",E.appendChild(w),g===-1?m.appendChild(E):m.insertBefore(E,m.children[g]),p(),E}function v(){if(o.config.readonly)return;const y=m.querySelectorAll(".multiple-slider-item"),g=y.length;y.forEach(E=>{let C=E.querySelector(".remove-item-btn");C||(C=document.createElement("button"),C.type="button",C.className="remove-item-btn px-2 py-1 rounded",C.style.cssText=`
|
|
326
326
|
color: var(--fb-error-color);
|
|
327
327
|
background-color: transparent;
|
|
328
328
|
transition: background-color var(--fb-transition-duration);
|
|
@@ -333,44 +333,44 @@ var FormBuilder=(function(be){"use strict";function k(e,t,n){const r=t.config.lo
|
|
|
333
333
|
background-color: transparent;
|
|
334
334
|
font-size: var(--fb-font-size);
|
|
335
335
|
transition: all var(--fb-transition-duration);
|
|
336
|
-
`,y.textContent="+",y.addEventListener("mouseenter",()=>{y.style.backgroundColor="var(--fb-background-hover-color)"}),y.addEventListener("mouseleave",()=>{y.style.backgroundColor="transparent"}),y.onclick=()=>{i.push(
|
|
336
|
+
`,y.textContent="+",y.addEventListener("mouseenter",()=>{y.style.backgroundColor="var(--fb-background-hover-color)"}),y.addEventListener("mouseleave",()=>{y.style.backgroundColor="transparent"}),y.onclick=()=>{i.push(c),h(c),d(),v()},x=document.createElement("span"),x.className="text-sm text-gray-500",b.appendChild(y),b.appendChild(x),n.appendChild(b)}function d(){if(!b||!x)return;const y=b.querySelector(".add-slider-btn");if(y){const g=i.length>=f;y.disabled=g,y.style.opacity=g?"0.5":"1",y.style.pointerEvents=g?"none":"auto"}x.textContent=`${i.length}/${f===1/0?"\u221E":f}`}if(i.forEach(y=>h(y)),d(),v(),!o.config.readonly){const y=document.createElement("p");y.className="mt-1",y.style.cssText=`
|
|
337
337
|
font-size: var(--fb-font-size-small);
|
|
338
338
|
color: var(--fb-text-secondary-color);
|
|
339
|
-
`,y.textContent=
|
|
339
|
+
`,y.textContent=ve(e,o),n.appendChild(y)}}function lo(e,t,n){var r,l,a;const o=[],{scopeRoot:s,skipValidation:i}=n;if(e.min===void 0||e.min===null)throw new Error(`Slider validation: field "${t}" requires "min" property`);if(e.max===void 0||e.max===null)throw new Error(`Slider validation: field "${t}" requires "max" property`);const u=e.min,f=e.max,c=(r=e.step)!=null?r:1,m=e.scale||"linear",p=(v,b)=>{var x,d;if(!v)return;const y=`error-${v.getAttribute("name")||Math.random().toString(36).substring(7)}`;let g=document.getElementById(y);if(b){if(v.classList.add("invalid"),v.title=b,!g){g=document.createElement("div"),g.id=y,g.className="error-message",g.style.cssText=`
|
|
340
340
|
color: var(--fb-error-color);
|
|
341
341
|
font-size: var(--fb-font-size-small);
|
|
342
342
|
margin-top: 0.25rem;
|
|
343
|
-
`;const E=v.closest(".slider-container");E&&E.nextSibling?(x=E.parentNode)==null||x.insertBefore(g,E.nextSibling):E&&((d=E.parentNode)==null||d.appendChild(g))}g.textContent=b,g.style.display="block"}else v.classList.remove("invalid"),v.title="",g&&g.remove()},h=(v,b)=>{const{state:x}=n,d=v.value;if(!d){if(!i&&e.required){const g=k("required",x);return o.push(`${b}: ${g}`),p(v,g),null}return p(v,null),null}let y;if(m==="exponential"){const g=parseFloat(d)/1e3;y=
|
|
343
|
+
`;const E=v.closest(".slider-container");E&&E.nextSibling?(x=E.parentNode)==null||x.insertBefore(g,E.nextSibling):E&&((d=E.parentNode)==null||d.appendChild(g))}g.textContent=b,g.style.display="block"}else v.classList.remove("invalid"),v.title="",g&&g.remove()},h=(v,b)=>{const{state:x}=n,d=v.value;if(!d){if(!i&&e.required){const g=k("required",x);return o.push(`${b}: ${g}`),p(v,g),null}return p(v,null),null}let y;if(m==="exponential"){const g=parseFloat(d)/1e3;y=Dt(g,u,f),y=Ve(y,c)}else y=parseFloat(d),y=Ve(y,c);if(!i){if(y<u){const g=k("minValue",x,{min:u});return o.push(`${b}: ${g}`),p(v,g),y}if(y>f){const g=k("maxValue",x,{max:f});return o.push(`${b}: ${g}`),p(v,g),y}}return p(v,null),y};if(e.multiple){const v=s.querySelectorAll(`input[type="range"][name^="${t}["]`),b=[];if(v.forEach((x,d)=>{const y=h(x,`${t}[${d}]`);b.push(y)}),!i){const{state:x}=n,d=(l=e.minCount)!=null?l:1,y=(a=e.maxCount)!=null?a:1/0,g=b.filter(E=>E!==null);e.required&&g.length===0&&o.push(`${t}: ${k("required",x)}`),g.length<d&&o.push(`${t}: ${k("minItems",x,{min:d})}`),g.length>y&&o.push(`${t}: ${k("maxItems",x,{max:y})}`)}return{value:b,errors:o}}else{const v=s.querySelector(`input[type="range"][name="${t}"]`);return v?{value:h(v,t),errors:o}:(!i&&e.required&&o.push(`${t}: ${k("required",n.state)}`),{value:null,errors:o})}}function ao(e,t,n,r){var l;const{scopeRoot:a}=r,o=e.min,s=e.max,i=(l=e.step)!=null?l:1,u=e.scale||"linear";if(e.multiple){if(!Array.isArray(n)){console.warn(`updateSliderField: Expected array for multiple field "${t}", got ${typeof n}`);return}const f=a.querySelectorAll(`input[type="range"][name^="${t}["]`);f.forEach((c,m)=>{if(m<n.length&&n[m]!==null){const p=Number(n[m]);if(u==="exponential"){const v=it(p,o,s);c.value=(v*1e3).toString()}else c.value=p.toString();const h=c.closest(".slider-container");if(h){const v=h.querySelector(".slider-value");v&&(v.textContent=p.toFixed(i<1?2:0));const b=(p-o)/(s-o)*100;c.style.background=`linear-gradient(
|
|
344
344
|
to right,
|
|
345
345
|
var(--fb-primary-color) 0%,
|
|
346
346
|
var(--fb-primary-color) ${b}%,
|
|
347
347
|
var(--fb-border-color) ${b}%,
|
|
348
348
|
var(--fb-border-color) 100%
|
|
349
|
-
)`}
|
|
349
|
+
)`}c.classList.remove("invalid"),c.title=""}}),n.length!==f.length&&console.warn(`updateSliderField: Multiple field "${t}" has ${f.length} sliders but received ${n.length} values. Consider re-rendering for add/remove.`)}else{const f=a.querySelector(`input[type="range"][name="${t}"]`);if(f&&n!==null&&n!==void 0){const c=Number(n);if(u==="exponential"){const p=it(c,o,s);f.value=(p*1e3).toString()}else f.value=c.toString();const m=f.closest(".slider-container");if(m){const p=m.querySelector(".slider-value");p&&(p.textContent=c.toFixed(i<1?2:0));const h=(c-o)/(s-o)*100;f.style.background=`linear-gradient(
|
|
350
350
|
to right,
|
|
351
351
|
var(--fb-primary-color) 0%,
|
|
352
352
|
var(--fb-primary-color) ${h}%,
|
|
353
353
|
var(--fb-border-color) ${h}%,
|
|
354
354
|
var(--fb-border-color) 100%
|
|
355
|
-
)`}f.classList.remove("invalid"),f.title=""}}}function
|
|
355
|
+
)`}f.classList.remove("invalid"),f.title=""}}}function Ot(e){const t={};for(const n of e)"default"in n&&n.default!==void 0&&(t[n.key]=n.default);return t}function Ut(e,t){return{...t,...e}}function st(e){const t={};return e.querySelectorAll("input, select, textarea").forEach(n=>{const r=n.getAttribute("name");r&&!r.includes("[")&&!r.includes(".")&&(n instanceof HTMLSelectElement?t[r]=n.value:n instanceof HTMLInputElement?n.type==="checkbox"?t[r]=n.checked:n.type==="radio"?n.checked&&(t[r]=n.value):t[r]=n.value:n instanceof HTMLTextAreaElement&&(t[r]=n.value))}),t}let ct=null;function io(e){ct=e}function Ke(e,t){if(!ct)throw new Error("renderElement not initialized. Import from components/index.ts");return ct(e,t)}function Pt(e,t){if(!e.prefillHints||e.prefillHints.length===0)return null;const n=document.createElement("div");return n.className="fb-prefill-hints flex flex-wrap gap-2 mb-4",e.prefillHints.forEach((r,l)=>{const a=document.createElement("button");a.type="button",a.className="fb-prefill-hint",a.textContent=r.label,a.setAttribute("data-hint-values",JSON.stringify(r.values)),a.setAttribute("data-container-key",t),a.setAttribute("data-hint-index",String(l)),n.appendChild(a)}),n}function Vt(e,t,n,r){var l,a;const o=document.createElement("div");o.className="border border-gray-200 rounded-lg p-4 bg-gray-50",o.setAttribute("data-container",r);const s=document.createElement("div"),i=e.columns||1;if(i===1?s.className="space-y-4":s.className=`grid grid-cols-${i} gap-4`,!t.state.config.readonly){const p=Pt(e,r);p&&o.appendChild(p)}const u=Ot(e.elements),f=((l=t.prefill)==null?void 0:l[e.key])||{},c=Ut(f,u),m={path:ge(t.path,e.key),prefill:c,formData:(a=t.formData)!=null?a:t.prefill,state:t.state};e.elements.forEach(p=>{var h,v;if(p.hidden||p.type==="hidden"){const b=(v=(h=f[p.key])!=null?h:p.default)!=null?v:null;s.appendChild(qe(ge(m.path,p.key),b))}else s.appendChild(Ke(p,m))}),o.appendChild(s),n.appendChild(o)}function Kt(e,t,n,r){var l,a,o,s;const i=t.state,u=document.createElement("div");u.className="border border-gray-200 rounded-lg p-4 bg-gray-50";const f=document.createElement("span");f.className="text-sm text-gray-500";const c=document.createElement("div");if(c.className="space-y-4",!t.state.config.readonly){const g=Pt(e,e.key);g&&u.appendChild(g)}const m=(l=e.minCount)!=null?l:0,p=(a=e.maxCount)!=null?a:1/0,h=Array.isArray((o=t.prefill)==null?void 0:o[e.key])?t.prefill[e.key]:null,v=Ot(e.elements),b=()=>c.querySelectorAll(":scope > .containerItem").length,x=()=>{const g=document.createElement("button");return g.type="button",g.className="add-container-btn px-3 py-1 rounded",g.style.cssText=`
|
|
356
356
|
color: var(--fb-primary-color);
|
|
357
357
|
border: var(--fb-border-width) solid var(--fb-primary-color);
|
|
358
358
|
background-color: transparent;
|
|
359
359
|
font-size: var(--fb-font-size);
|
|
360
360
|
transition: all var(--fb-transition-duration);
|
|
361
|
-
`,g.textContent="+",g.addEventListener("mouseenter",()=>{g.style.backgroundColor="var(--fb-background-hover-color)"}),g.addEventListener("mouseleave",()=>{g.style.backgroundColor="transparent"}),g.onclick=()=>{if(b()<p){const E=b(),C=i.formRoot?
|
|
361
|
+
`,g.textContent="+",g.addEventListener("mouseenter",()=>{g.style.backgroundColor="var(--fb-background-hover-color)"}),g.addEventListener("mouseleave",()=>{g.style.backgroundColor="transparent"}),g.onclick=()=>{if(b()<p){const E=b(),C=i.formRoot?st(i.formRoot):{},w={state:t.state,path:ge(t.path,`${e.key}[${E}]`),prefill:v,formData:C},S=document.createElement("div");S.className="containerItem border border-gray-300 rounded-lg p-4 bg-white",S.setAttribute("data-container-item",`${e.key}[${E}]`);const z=document.createElement("div"),Z=e.columns||1;if(Z===1?z.className="space-y-4":z.className=`grid grid-cols-${Z} gap-4`,e.elements.forEach(R=>{var _;R.hidden||R.type==="hidden"?z.appendChild(qe(ge(w.path,R.key),(_=R.default)!=null?_:null)):z.appendChild(Ke(R,w))}),S.appendChild(z),!i.config.readonly){const R=document.createElement("button");R.type="button",R.className="absolute top-2 right-2 px-2 py-1 rounded",R.style.cssText=`
|
|
362
362
|
color: var(--fb-error-color);
|
|
363
363
|
background-color: transparent;
|
|
364
364
|
transition: background-color var(--fb-transition-duration);
|
|
365
|
-
`,
|
|
365
|
+
`,R.textContent="\u2715",R.addEventListener("mouseenter",()=>{R.style.backgroundColor="var(--fb-background-hover-color)"}),R.addEventListener("mouseleave",()=>{R.style.backgroundColor="transparent"}),R.onclick=()=>y(S),S.style.position="relative",S.appendChild(R)}c.appendChild(S),d()}},g},d=()=>{const g=b(),E=u.querySelector(".add-container-btn");E&&(E.disabled=g>=p,E.style.opacity=g>=p?"0.5":"1",E.style.pointerEvents=g>=p?"none":"auto"),f.textContent=`${g}/${p===1/0?"\u221E":p}`},y=g=>{g.remove(),d()};if(h&&Array.isArray(h)&&h.forEach((g,E)=>{var C;const w=Ut(g||{},v),S={state:t.state,path:ge(t.path,`${e.key}[${E}]`),prefill:w,formData:(C=t.formData)!=null?C:t.prefill},z=document.createElement("div");z.className="containerItem border border-gray-300 rounded-lg p-4 bg-white",z.setAttribute("data-container-item",`${e.key}[${E}]`);const Z=document.createElement("div"),R=e.columns||1;if(R===1?Z.className="space-y-4":Z.className=`grid grid-cols-${R} gap-4`,e.elements.forEach(_=>{var fe,Ee;if(_.hidden||_.type==="hidden"){const Ne=(Ee=(fe=g==null?void 0:g[_.key])!=null?fe:_.default)!=null?Ee:null;Z.appendChild(qe(ge(S.path,_.key),Ne))}else Z.appendChild(Ke(_,S))}),z.appendChild(Z),!i.config.readonly){const _=document.createElement("button");_.type="button",_.className="absolute top-2 right-2 px-2 py-1 rounded",_.style.cssText=`
|
|
366
366
|
color: var(--fb-error-color);
|
|
367
367
|
background-color: transparent;
|
|
368
368
|
transition: background-color var(--fb-transition-duration);
|
|
369
|
-
`,
|
|
369
|
+
`,_.textContent="\u2715",_.addEventListener("mouseenter",()=>{_.style.backgroundColor="var(--fb-background-hover-color)"}),_.addEventListener("mouseleave",()=>{_.style.backgroundColor="transparent"}),_.onclick=()=>y(z),z.style.position="relative",z.appendChild(_)}c.appendChild(z)}),!i.config.readonly)for(;b()<m;){const g=b(),E={state:t.state,path:ge(t.path,`${e.key}[${g}]`),prefill:v,formData:(s=t.formData)!=null?s:t.prefill},C=document.createElement("div");C.className="containerItem border border-gray-300 rounded-lg p-4 bg-white",C.setAttribute("data-container-item",`${e.key}[${g}]`);const w=document.createElement("div"),S=e.columns||1;S===1?w.className="space-y-4":w.className=`grid grid-cols-${S} gap-4`,e.elements.forEach(Z=>{var R;Z.hidden||Z.type==="hidden"?w.appendChild(qe(ge(E.path,Z.key),(R=Z.default)!=null?R:null)):w.appendChild(Ke(Z,E))}),C.appendChild(w);const z=document.createElement("button");z.type="button",z.className="absolute top-2 right-2 px-2 py-1 rounded",z.style.cssText=`
|
|
370
370
|
color: var(--fb-error-color);
|
|
371
371
|
background-color: transparent;
|
|
372
372
|
transition: background-color var(--fb-transition-duration);
|
|
373
|
-
`,z.textContent="\u2715",z.addEventListener("mouseenter",()=>{z.style.backgroundColor="var(--fb-background-hover-color)"}),z.addEventListener("mouseleave",()=>{z.style.backgroundColor="transparent"}),z.onclick=()=>{b()>m&&y(C)},C.style.position="relative",C.appendChild(z),
|
|
373
|
+
`,z.textContent="\u2715",z.addEventListener("mouseenter",()=>{z.style.backgroundColor="var(--fb-background-hover-color)"}),z.addEventListener("mouseleave",()=>{z.style.backgroundColor="transparent"}),z.onclick=()=>{b()>m&&y(C)},C.style.position="relative",C.appendChild(z),c.appendChild(C)}if(u.appendChild(c),!i.config.readonly){const g=document.createElement("div");g.className="flex items-center gap-3 mt-2",g.appendChild(x()),g.appendChild(f),u.appendChild(g)}d(),n.appendChild(u)}let ut=null;function so(e){ut=e}function _t(e,t,n){if(!ut)throw new Error("validateElement not initialized. Should be set from FormBuilderInstance");return ut(e,t,n)}function Wt(e,t,n){const r=[],{scopeRoot:l,skipValidation:a,path:o}=n;if(!("elements"in e))return{value:null,errors:r};const s=(i,u,f)=>{var c,m;if(a)return;const{state:p}=n,h="minCount"in f&&(c=f.minCount)!=null?c:0,v="maxCount"in f&&(m=f.maxCount)!=null?m:1/0;f.required&&u.length===0&&r.push(`${i}: ${k("required",p)}`),u.length<h&&r.push(`${i}: ${k("minItems",p,{min:h})}`),u.length>v&&r.push(`${i}: ${k("maxItems",p,{max:v})}`)};if("multiple"in e&&e.multiple){const i=[],u=l.querySelectorAll("[data-container-item]");return Array.from(u).filter(f=>{const c=f.getAttribute("data-container-item")||"";if(!c.startsWith(`${t}[`))return!1;const m=c.slice(t.length);return/^\[\d+\]$/.test(m)}).forEach(f=>{const c={},m=(f.getAttribute("data-container-item")||"").match(/\[(\d+)\]$/),p=m?parseInt(m[1],10):0;e.elements.forEach(h=>{var v;if(h.enableIf)try{const d=(v=n.instance)!=null&&v.getState().formRoot?st(n.instance.getState().formRoot):{};if(!$e(h.enableIf,d,c))return}catch(d){console.error(`Error evaluating enableIf for field "${h.key}" in container "${t}[${p}]":`,d)}const b=`${t}[${p}].${h.key}`,x=_t({...h,key:b},{path:o},f);x.spread&&x.value!==null&&typeof x.value=="object"?Object.assign(c,x.value):c[h.key]=x.value}),i.push(c)}),s(t,i,e),{value:i,errors:r}}else{const i={},u=l.querySelector(`[data-container="${t}"]`)||l;return e.elements.forEach(f=>{var c;if(f.enableIf)try{const m=(c=n.instance)!=null&&c.getState().formRoot?st(n.instance.getState().formRoot):{};if(!$e(f.enableIf,m,i))return}catch(m){console.error(`Error evaluating enableIf for field "${f.key}" in container "${t}":`,m)}{const m=`${t}.${f.key}`,p=_t({...f,key:m},{path:o},u);p.spread&&p.value!==null&&typeof p.value=="object"?Object.assign(i,p.value):i[f.key]=p.value}}),{value:i,errors:r}}}function Jt(e,t,n,r){const{instance:l,scopeRoot:a}=r;if("elements"in e)if("multiple"in e&&e.multiple){if(!Array.isArray(n)){console.warn(`updateContainerField: Expected array for multiple container field "${t}", got ${typeof n}`);return}n.forEach((s,i)=>{je(s)&&e.elements.forEach(u=>{var f,c;const m=`${t}[${i}].${u.key}`;if(u.type==="richinput"&&u.flatOutput){const p=u,h=(f=p.textKey)!=null?f:"text",v=(c=p.filesKey)!=null?c:"files",b=s,x={};h in b&&(x[h]=b[h]),v in b&&(x[v]=b[v]),Object.keys(x).length>0&&l.updateField(m,x)}else{const p=s[u.key];p!==void 0&&l.updateField(m,p)}})});const o=a.querySelectorAll(`[data-container-item^="${t}["]`);n.length!==o.length&&console.warn(`updateContainerField: Multiple container field "${t}" item count mismatch. Consider re-rendering for add/remove.`)}else{if(!je(n)){console.warn(`updateContainerField: Expected object for container field "${t}", got ${typeof n}`);return}e.elements.forEach(o=>{var s,i;const u=`${t}.${o.key}`;if(o.type==="richinput"&&o.flatOutput){const f=o,c=(s=f.textKey)!=null?s:"text",m=(i=f.filesKey)!=null?i:"files",p=n,h={};c in p&&(h[c]=p[c]),m in p&&(h[m]=p[m]),Object.keys(h).length>0&&l.updateField(u,h)}else{const f=n[o.key];f!==void 0&&l.updateField(u,f)}})}}function co(e,t,n,r){var l,a;typeof console!="undefined"&&console.warn&&console.warn(`[Form Builder] The "group" field type is deprecated and will be removed in a future version. Please use type: "container" with multiple: true instead. Field key: "${e.key}"`);const o={key:e.key,label:e.label,description:e.description,hint:e.hint,required:e.required,hidden:e.hidden,default:e.default,actions:e.actions,elements:e.elements,multiple:!!(e.repeat&&je(e.repeat)),minCount:(l=e.repeat)==null?void 0:l.min,maxCount:(a=e.repeat)==null?void 0:a.max};o.multiple?Kt(o,t,n):Vt(o,t,n,r)}function Yt(e){var t,n;const r=e;return{type:"container",key:r.key,label:r.label,description:r.description,hint:r.hint,required:r.required,hidden:r.hidden,default:r.default,actions:r.actions,elements:r.elements,multiple:!!(r.repeat&&je(r.repeat)),minCount:(t=r.repeat)==null?void 0:t.min,maxCount:(n=r.repeat)==null?void 0:n.max}}function uo(e,t,n){typeof console!="undefined"&&console.warn&&console.warn(`[Form Builder] The "group" field type is deprecated. Please use type: "container" instead. Field key: "${t}"`);const r=Yt(e);return Wt(r,t,n)}function po(e,t,n,r){typeof console!="undefined"&&console.warn&&console.warn(`[Form Builder] The "group" field type is deprecated. Please use type: "container" instead. Field path: "${t}"`);const l=Yt(e);return Jt(l,t,n,r)}function fo(e){return e!==null&&typeof e=="object"&&"row"in e&&"col"in e&&"rowspan"in e&&"colspan"in e}function mo(e){if(e===null||typeof e!="object")return!1;const t=e;return typeof t.top=="number"&&typeof t.left=="number"&&typeof t.bottom=="number"&&typeof t.right=="number"}function ho(e){return fo(e)?{top:e.row,left:e.col,bottom:e.row+e.rowspan-1,right:e.col+e.colspan-1}:mo(e)?e:null}function Te(e){return e.map(ho).filter(t=>t!==null)}function Xt(e,t){return Array.from({length:e},()=>Array.from({length:t},()=>""))}function dt(e,t,n){for(let r=0;r<e.length;r++){const l=e[r];if(l.top<0||l.left<0||l.bottom>=t||l.right>=n||l.top>l.bottom||l.left>l.right)return`Merge ${r} out of bounds`;for(let a=r+1;a<e.length;a++){const o=e[a];if(l.top<=o.bottom&&l.bottom>=o.top&&l.left<=o.right&&l.right>=o.left)return`Merges ${r} and ${a} overlap`}}return null}function Gt(e,t,n){for(const r of n){if(r.top===e&&r.left===t)return null;if(e>=r.top&&e<=r.bottom&&t>=r.left&&t<=r.right)return r}return null}function _e(e,t,n){var r;return(r=n.find(l=>l.top===e&&l.left===t))!=null?r:null}function xe(e){var t;if(!e.anchor)return null;const n=(t=e.focus)!=null?t:e.anchor;return{r1:Math.min(e.anchor.row,n.row),c1:Math.min(e.anchor.col,n.col),r2:Math.max(e.anchor.row,n.row),c2:Math.max(e.anchor.col,n.col)}}function Ae(e){const t=document.createElement("button");return t.type="button",t.textContent=e.label,t.title=e.title,t.style.cssText=`
|
|
374
374
|
position: absolute;
|
|
375
375
|
width: ${e.size}px;
|
|
376
376
|
height: ${e.size}px;
|
|
@@ -390,7 +390,7 @@ var FormBuilder=(function(be){"use strict";function k(e,t,n){const r=t.config.lo
|
|
|
390
390
|
box-shadow: 0 1px 4px rgba(0,0,0,0.2);
|
|
391
391
|
transition: transform 0.1s, opacity 0.1s;
|
|
392
392
|
pointer-events: all;
|
|
393
|
-
`,t.addEventListener("mouseenter",()=>{t.style.transform="scale(1.15)"}),t.addEventListener("mouseleave",()=>{t.style.transform="scale(1)"}),t.addEventListener("click",n=>{n.stopPropagation(),e.onClick(n)}),t}function
|
|
393
|
+
`,t.addEventListener("mouseenter",()=>{t.style.transform="scale(1.15)"}),t.addEventListener("mouseleave",()=>{t.style.transform="scale(1)"}),t.addEventListener("click",n=>{n.stopPropagation(),e.onClick(n)}),t}function vo(e,t){const{cells:n,merges:r=[]}=e;if(n.length===0)return;const l=n[0].length,a=document.createElement("table");a.style.cssText=`
|
|
394
394
|
width: 100%;
|
|
395
395
|
border-collapse: collapse;
|
|
396
396
|
border: var(--fb-border-width) solid var(--fb-border-color);
|
|
@@ -398,13 +398,13 @@ var FormBuilder=(function(be){"use strict";function k(e,t,n){const r=t.config.lo
|
|
|
398
398
|
font-size: var(--fb-font-size);
|
|
399
399
|
font-family: var(--fb-font-family);
|
|
400
400
|
color: var(--fb-text-color);
|
|
401
|
-
`,n.forEach((
|
|
401
|
+
`,n.forEach((s,i)=>{var u,f;const c=(i===0?a.createTHead():(u=a.tBodies[0])!=null?u:a.createTBody()).insertRow();for(let m=0;m<l;m++){if(Gt(i,m,r))continue;const p=_e(i,m,r),h=document.createElement(i===0?"th":"td");if(p){const v=p.bottom-p.top+1,b=p.right-p.left+1;v>1&&(h.rowSpan=v),b>1&&(h.colSpan=b)}h.textContent=(f=s[m])!=null?f:"",h.style.cssText=`
|
|
402
402
|
padding: 6px 10px;
|
|
403
403
|
border: var(--fb-border-width) solid var(--fb-border-color);
|
|
404
404
|
text-align: left;
|
|
405
405
|
vertical-align: top;
|
|
406
406
|
${i===0?"background-color: var(--fb-background-hover-color); font-weight: 600;":""}
|
|
407
|
-
`,
|
|
407
|
+
`,c.appendChild(h)}});const o=document.createElement("div");o.style.cssText="overflow-x: auto; max-width: 100%;",o.appendChild(a),t.appendChild(o)}function go(e,t,n,r,l,a){if(e.contentEditable==="true")return;e.contentEditable="true",e.focus();const o=document.createRange(),s=window.getSelection();o.selectNodeContents(e),o.collapse(!1),s==null||s.removeAllRanges(),s==null||s.addRange(o);function i(){var c;e.contentEditable="inherit";const m=r();m[t]&&(m[t][n]=(c=e.textContent)!=null?c:""),l()}function u(c){var m,p,h,v;const b=r(),x=(p=(m=b[0])==null?void 0:m.length)!=null?p:0;if(c.key==="Escape"){e.contentEditable="inherit",e.textContent=(v=(h=b[t])==null?void 0:h[n])!=null?v:"",e.removeEventListener("keydown",u),e.removeEventListener("blur",f);return}if(c.key==="Enter"&&!c.shiftKey){c.preventDefault(),c.stopPropagation(),i(),e.removeEventListener("keydown",u),e.removeEventListener("blur",f);const d=t+1<b.length?t+1:t;a(d,n);return}if(c.key==="Tab"){c.preventDefault(),c.stopPropagation(),i(),e.removeEventListener("keydown",u),e.removeEventListener("blur",f);let d=t,y=c.shiftKey?n-1:n+1;y<0&&(y=x-1,d=Math.max(0,t-1)),y>=x&&(y=0,d=Math.min(b.length-1,t+1)),a(d,y)}}function f(){e.contentEditable==="true"&&(i(),e.removeEventListener("keydown",u),e.removeEventListener("blur",f))}e.addEventListener("keydown",u),e.addEventListener("blur",f)}function bo(){if(document.getElementById("fb-spin-keyframes"))return;const e=document.createElement("style");e.id="fb-spin-keyframes",e.textContent="@keyframes fb-spin { to { transform: rotate(360deg); } }",document.head.appendChild(e)}function yo(e,t){bo();const n=document.createElement("div");n.className="fb-table-loading-overlay",n.style.cssText=`
|
|
408
408
|
position: absolute; top: 0; left: 0; right: 0; bottom: 0;
|
|
409
409
|
background: rgba(255,255,255,0.8); display: flex;
|
|
410
410
|
align-items: center; justify-content: center; flex-direction: column;
|
|
@@ -413,13 +413,13 @@ var FormBuilder=(function(be){"use strict";function k(e,t,n){const r=t.config.lo
|
|
|
413
413
|
width: 24px; height: 24px; border: 3px solid var(--fb-border-color, #ccc);
|
|
414
414
|
border-top-color: var(--fb-primary-color, #0066cc); border-radius: 50%;
|
|
415
415
|
animation: fb-spin 0.8s linear infinite;
|
|
416
|
-
`;const l=document.createElement("span");return l.textContent=t,l.style.cssText="font-size: var(--fb-font-size-small, 12px); color: var(--fb-text-color, #333);",n.appendChild(r),n.appendChild(l),e.appendChild(n),n}function
|
|
416
|
+
`;const l=document.createElement("span");return l.textContent=t,l.style.cssText="font-size: var(--fb-font-size-small, 12px); color: var(--fb-text-color, #333);",n.appendChild(r),n.appendChild(l),e.appendChild(n),n}function xo(e,t,n,r,l){var a,o,s,i,u,f,c,m;const p=r.state,h=r.instance,v=e.mergeAllowed!==!1,b=(o=(a=e.fieldNames)==null?void 0:a.cells)!=null?o:"cells",x=(i=(s=e.fieldNames)==null?void 0:s.merges)!=null?i:"merges",d=t.cells.length>0?t.cells.map(A=>[...A]):Xt((u=e.rows)!=null?u:3,(f=e.columns)!=null?f:3);let y=t.merges?[...t.merges]:[];const g={anchor:null,focus:null,dragging:!1},E=document.createElement("input");E.type="hidden",E.name=n,E.value=JSON.stringify({[b]:d,[x]:y}),l.appendChild(E);function C(){E.value=JSON.stringify({[b]:d,[x]:y}),h&&h.triggerOnChange(n,{[b]:d,[x]:y})}E._applyExternalUpdate=A=>{d.length=0,A.cells.forEach(T=>d.push([...T])),y.length=0,A.merges&&A.merges.forEach(T=>y.push({...T})),g.anchor=null,g.focus=null,C(),N()};const w=document.createElement("div");w.style.cssText="position: relative; padding: 20px 20px 20px 24px; overflow-x: auto; max-width: 100%;";const S=document.createElement("table");S.style.cssText=`
|
|
417
417
|
border-collapse: collapse;
|
|
418
418
|
font-size: var(--fb-font-size);
|
|
419
419
|
font-family: var(--fb-font-family);
|
|
420
420
|
color: var(--fb-text-color);
|
|
421
421
|
table-layout: fixed;
|
|
422
|
-
`,w.appendChild(S);const z=(m=(
|
|
422
|
+
`,w.appendChild(S);const z=(m=(c=e.importAccept)==null?void 0:c.map(A=>`.${A.toLowerCase()}`))!=null?m:[];async function Z(A){var T,L,B;if(!p.config.parseTableFile)return;if(z.length>0){const F=A.name.toLowerCase().replace(/^.*(\.[^.]+)$/,"$1");if(!z.includes(F))return}const D=yo(w,k("tableImporting",p));try{const F=await p.config.parseTableFile(A),Q=F.cells,O=(T=F.merges)!=null?T:[];if(O.length>0){const U=dt(O,Q.length,(B=(L=Q[0])==null?void 0:L.length)!=null?B:0);if(U)throw new Error(U)}d.length=0,Q.forEach(U=>d.push([...U])),y.length=0,O.forEach(U=>y.push({...U})),g.anchor=null,g.focus=null,C(),N()}catch(F){const Q=F instanceof Error?F.message:String(F);console.error(k("tableImportError",p).replace("{error}",Q))}finally{D.remove()}}if(e.importAccept&&p.config.parseTableFile){const A=document.createElement("button");A.type="button",A.title=k("tableImportFile",p),A.innerHTML='<svg width="14" height="14" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M21.44 11.05l-9.19 9.19a6 6 0 01-8.49-8.49l9.19-9.19a4 4 0 015.66 5.66l-9.2 9.19a2 2 0 01-2.83-2.83l8.49-8.48"/></svg>',A.style.cssText=`
|
|
423
423
|
position: absolute; top: 2px; left: 2px;
|
|
424
424
|
width: 20px; height: 20px;
|
|
425
425
|
padding: 0;
|
|
@@ -429,7 +429,7 @@ var FormBuilder=(function(be){"use strict";function k(e,t,n){const r=t.config.lo
|
|
|
429
429
|
background: transparent;
|
|
430
430
|
cursor: pointer;
|
|
431
431
|
z-index: 2;
|
|
432
|
-
`,A.addEventListener("mouseenter",()=>{A.style.color="var(--fb-primary-color, #0066cc)"}),A.addEventListener("mouseleave",()=>{A.style.color="var(--fb-text-color, #999)"});const T=document.createElement("input");T.type="file",T.accept=z.join(","),T.style.display="none",w.appendChild(T),A.addEventListener("click",()=>{T.click()}),T.addEventListener("change",()=>{var B;const
|
|
432
|
+
`,A.addEventListener("mouseenter",()=>{A.style.color="var(--fb-primary-color, #0066cc)"}),A.addEventListener("mouseleave",()=>{A.style.color="var(--fb-text-color, #999)"});const T=document.createElement("input");T.type="file",T.accept=z.join(","),T.style.display="none",w.appendChild(T),A.addEventListener("click",()=>{T.click()}),T.addEventListener("change",()=>{var B;const D=(B=T.files)==null?void 0:B[0];D&&Z(D),T.value=""}),w.appendChild(A);let L=0;w.addEventListener("dragenter",B=>{B.preventDefault(),L++,L===1&&(w.style.outline="2px dashed var(--fb-primary-color, #0066cc)",w.style.outlineOffset="-2px")}),w.addEventListener("dragover",B=>{B.preventDefault(),B.dataTransfer&&(B.dataTransfer.dropEffect="copy")}),w.addEventListener("dragleave",B=>{B.preventDefault(),L--,L<=0&&(L=0,w.style.outline="",w.style.outlineOffset="")}),w.addEventListener("drop",B=>{var D,F;B.preventDefault(),L=0,w.style.outline="",w.style.outlineOffset="";const Q=(F=(D=B.dataTransfer)==null?void 0:D.files)==null?void 0:F[0];Q&&Z(Q)})}l.appendChild(w);const R=document.createElement("div");R.style.cssText=`
|
|
433
433
|
position: fixed;
|
|
434
434
|
display: none;
|
|
435
435
|
background: white;
|
|
@@ -440,7 +440,7 @@ var FormBuilder=(function(be){"use strict";function k(e,t,n){const r=t.config.lo
|
|
|
440
440
|
z-index: 1000;
|
|
441
441
|
gap: 4px;
|
|
442
442
|
flex-direction: column;
|
|
443
|
-
`,l.appendChild(
|
|
443
|
+
`,l.appendChild(R);function _(A,T){const L=document.createElement("button");return L.type="button",L.textContent=A,L.style.cssText=`
|
|
444
444
|
padding: 4px 10px;
|
|
445
445
|
font-size: var(--fb-font-size-small);
|
|
446
446
|
color: var(--fb-text-color);
|
|
@@ -450,8 +450,8 @@ var FormBuilder=(function(be){"use strict";function k(e,t,n){const r=t.config.lo
|
|
|
450
450
|
cursor: pointer;
|
|
451
451
|
white-space: nowrap;
|
|
452
452
|
text-align: left;
|
|
453
|
-
`,L.addEventListener("mouseenter",()=>{L.style.background="var(--fb-background-hover-color)"}),L.addEventListener("mouseleave",()=>{L.style.background="transparent"}),L.addEventListener("click",()=>{
|
|
454
|
-
`),ae=`<table>${K.join("")}</table>`;(O=F.clipboardData)==null||O.setData("text/plain",ie),(V=F.clipboardData)==null||V.setData("text/html",ae)},S.onpaste=F=>{var Z,j,O,V,J,D,Y,_,te;const X=g.anchor;if(!X)return;const K=(j=(Z=F.clipboardData)==null?void 0:Z.getData("text/plain"))!=null?j:"",ie=K.includes(" ")||K.split(/\r?\n/).filter(se=>se).length>1,ae=S.querySelector("[contenteditable='true']");if(ae&&!ie)return;if(F.preventDefault(),ae){ae.contentEditable="inherit";const se=parseInt((V=(O=ae.closest("td"))==null?void 0:O.getAttribute("data-row"))!=null?V:"0",10),xe=parseInt((D=(J=ae.closest("td"))==null?void 0:J.getAttribute("data-col"))!=null?D:"0",10);d[se]&&(d[se][xe]=(Y=ae.textContent)!=null?Y:"")}if(!K.trim())return;const U=K.split(/\r?\n/).map(se=>se.split(" "));U.length>1&&U[U.length-1].length===1&&U[U.length-1][0]===""&&U.pop();const le=X.row,ue=X.col,de=le+U.length;for(;d.length<de;)d.push(Array((te=(_=d[0])==null?void 0:_.length)!=null?te:1).fill(""));const me=Math.max(...U.map(se=>se.length)),Ce=ue+me;if(d[0]&&Ce>d[0].length){const se=Ce-d[0].length;d.forEach(xe=>{for(let Be=0;Be<se;Be++)xe.push("")})}for(let se=0;se<U.length;se++)for(let xe=0;xe<U[se].length;xe++){const Be=le+se,Wo=ue+xe;d[Be]&&(d[Be][Wo]=U[se][xe])}C(),N()}}const H=Te({label:"+",title:k("tableAddColumn",p),size:20,color:"var(--fb-primary-color, #0066cc)",textColor:"white",onClick:()=>{var A;const T=parseInt((A=H.dataset.afterCol)!=null?A:"0",10);Ie(T)}});H.style.position="absolute",H.style.display="none",w.appendChild(H);const I=Te({label:"+",title:k("tableAddRow",p),size:20,color:"var(--fb-primary-color, #0066cc)",textColor:"white",onClick:()=>{var A;const T=parseInt((A=I.dataset.afterRow)!=null?A:"0",10);ge(T)}});I.style.position="absolute",I.style.display="none",w.appendChild(I);let Q=[],ee=[];const re=Te({label:"+",title:k("tableAddColumn",p),size:20,color:"var(--fb-primary-color, #0066cc)",textColor:"white",onClick:()=>Ie()});re.style.position="absolute",re.style.display="none",w.appendChild(re);const oe=Te({label:"+",title:k("tableAddRow",p),size:20,color:"var(--fb-primary-color, #0066cc)",textColor:"white",onClick:()=>ge()});oe.style.position="absolute",oe.style.display="none",w.appendChild(oe);function ce(){var A,T;Q.forEach(j=>j.remove()),Q=[],ee.forEach(j=>j.remove()),ee=[];const L=d.length>0?d[0].length:0,B=d.length;if(L>1){const j=Array.from(S.querySelectorAll("thead td[data-col]"));for(const O of j){const V=parseInt((A=O.getAttribute("data-col"))!=null?A:"0",10),J=Te({label:"\xD7",title:k("tableRemoveColumn",p),size:16,color:"var(--fb-error-color, #dc3545)",textColor:"white",onClick:()=>$(V)});J.setAttribute("data-action","remove-col"),J.setAttribute("data-col",String(V)),J.style.position="absolute",J.style.display="none",w.appendChild(J),Q.push(J)}}if(B>1){const j=[...S.tHead?Array.from(S.tHead.rows):[],...S.tBodies[0]?Array.from(S.tBodies[0].rows):[]].filter(O=>O.querySelector("td[data-row]"));for(const O of j){const V=O.querySelector("td[data-row]");if(!V)continue;const J=parseInt((T=V.getAttribute("data-row"))!=null?T:"0",10),D=Te({label:"\xD7",title:k("tableRemoveRow",p),size:16,color:"var(--fb-error-color, #dc3545)",textColor:"white",onClick:()=>Ze(J)});D.setAttribute("data-action","remove-row"),D.setAttribute("data-row",String(J)),D.style.position="absolute",D.style.display="none",w.appendChild(D),ee.push(D)}}function R(j,O,V,J,D){var Y;const _=D?Array.from(S.querySelectorAll("thead td[data-col]")):[];let te=-1,X=1/0,K=-1,ie=-1,ae=1/0;for(let U=0;U<_.length;U++){const le=_[U].getBoundingClientRect(),ue=(le.left+le.right)/2,de=Math.abs(j-ue);de<X&&(X=de,te=U);const me=Math.abs(j-le.right);me<ae&&me<20&&(ae=me,K=le.right-O.left+J,ie=parseInt((Y=_[U].getAttribute("data-col"))!=null?Y:"0",10))}Q.forEach((U,le)=>{if(!D||le!==te){U.style.display="none";return}const ue=_[le].getBoundingClientRect(),de=(ue.left+ue.right)/2-O.left+J;U.style.left=`${de-8}px`,U.style.top="2px",U.style.display="flex"}),D&&ie>=0?(H.style.display="flex",H.style.left=`${K-10}px`,H.style.top=`${V.top-O.top-10}px`,H.dataset.afterCol=String(ie)):H.style.display="none"}function F(j,O,V,J,D){var Y;const _=[];if(D){if(S.tHead)for(const U of Array.from(S.tHead.rows))U.querySelector("td[data-row]")&&_.push(U);if(S.tBodies[0])for(const U of Array.from(S.tBodies[0].rows))U.querySelector("td[data-row]")&&_.push(U)}let te=-1,X=1/0,K=-1,ie=-1,ae=1/0;for(let U=0;U<_.length;U++){const le=_[U].getBoundingClientRect(),ue=(le.top+le.bottom)/2,de=Math.abs(j-ue);de<X&&(X=de,te=U);const me=Math.abs(j-le.bottom);if(me<ae&&me<14){ae=me,K=le.bottom-O.top;const Ce=_[U].querySelector("td[data-row]");ie=parseInt((Y=Ce==null?void 0:Ce.getAttribute("data-row"))!=null?Y:"0",10)}}ee.forEach((U,le)=>{if(!D||le!==te){U.style.display="none";return}const ue=_[le].getBoundingClientRect(),de=(ue.top+ue.bottom)/2-O.top;U.style.left="4px",U.style.top=`${de-8}px`,U.style.display="flex"}),D&&ie>=0?(I.style.display="flex",I.style.top=`${K-10}px`,I.style.left=`${V.left-O.left+J-10}px`,I.dataset.afterRow=String(ie)):I.style.display="none"}let Z=!1;w.onmousemove=j=>{const O=j.target;if(O.tagName==="BUTTON"&&O.parentElement===w||Z)return;Z=!0;const V=j.clientX,J=j.clientY;requestAnimationFrame(()=>{Z=!1;const D=w.getBoundingClientRect(),Y=S.getBoundingClientRect(),_=w.scrollLeft,te=J>=D.top&&J<Y.top+4,X=V>=D.left&&V<Y.left+4,K=Math.min(Y.right,D.right),ie=V>K-20&&V<=D.right,ae=J>Y.bottom-4&&J<=D.bottom+20;if(R(V,D,Y,_,te),F(J,D,Y,_,X),re.style.display=ie?"flex":"none",ie&&(re.style.left=`${D.right-D.left+_-20}px`,re.style.top=`${(Y.top+Y.bottom)/2-D.top-10}px`),oe.style.display=ae?"flex":"none",ae){const U=(D.left+D.right)/2-D.left+_;oe.style.left=`${U-10}px`,oe.style.top=`${Y.bottom-D.top-10}px`}})},w.onmouseleave=()=>{Q.forEach(j=>{j.style.display="none"}),ee.forEach(j=>{j.style.display="none"}),H.style.display="none",I.style.display="none",re.style.display="none",oe.style.display="none"}}N()}function bo(e){var t,n;return{cells:Wt((t=e.rows)!=null?t:3,(n=e.columns)!=null?n:3),merges:[]}}function dt(e){return e!==null&&typeof e=="object"&&"cells"in e&&Array.isArray(e.cells)}function pt(e,t){return e!==null&&typeof e=="object"&&t in e&&Array.isArray(e[t])}function yo(e,t,n,r){var l,a,o,c;const i=t.state,u=t.prefill[e.key],f=(a=(l=e.fieldNames)==null?void 0:l.cells)!=null?a:"cells",s=(c=(o=e.fieldNames)==null?void 0:o.merges)!=null?c:"merges";let m;if(dt(u))m={cells:u.cells,merges:u.merges?Se(u.merges):[]};else if(u&&pt(u,f)){const p=u[s];m={cells:u[f],merges:p?Se(p):[]}}else if(dt(e.default))m={cells:e.default.cells,merges:e.default.merges?Se(e.default.merges):[]};else if(e.default&&pt(e.default,f)){const p=e.default[s];m={cells:e.default[f],merges:p?Se(p):[]}}else m=bo(e);if(m.merges&&m.merges.length>0){const p=m.cells.length,h=p>0?m.cells[0].length:0,v=ut(m.merges,p,h);v&&(console.warn(`Table "${e.key}": invalid prefill merges stripped (${v})`),m={...m,merges:[]})}i.config.readonly?fo(m,n):go(e,m,r,t,n)}function xo(e,t,n){var r,l;const{scopeRoot:a,skipValidation:o}=n,c=[],i=(l=(r=e.fieldNames)==null?void 0:r.cells)!=null?l:"cells",u=a.querySelector(`[name="${t}"]`);if(!u)return{value:null,errors:c};let f=null;try{f=JSON.parse(u.value)}catch(s){return c.push(`${t}: invalid table data`),{value:null,errors:c}}if(!o&&e.required){const s=f[i];s!=null&&s.some(m=>m.some(p=>p.trim()!==""))||c.push(`${t}: ${k("required",n.state)}`)}return{value:f,errors:c}}function Eo(e,t,n,r){var l,a,o,c;const{scopeRoot:i}=r,u=(a=(l=e.fieldNames)==null?void 0:l.cells)!=null?a:"cells",f=(c=(o=e.fieldNames)==null?void 0:o.merges)!=null?c:"merges",s=i.querySelector(`[name="${t}"]`);if(!s){console.warn(`updateTableField: no hidden input found for "${t}". Re-render to reflect new data.`);return}let m=null;if(dt(n))m={cells:n.cells,merges:n.merges?Se(n.merges):[]};else if(n&&pt(n,u)){const p=n[f];m={cells:n[u],merges:p?Se(p):[]}}m&&s._applyExternalUpdate?s._applyExternalUpdate(m):s.value=JSON.stringify(n)}function Co(e,t){e.style.overflow="hidden",e.style.resize="none";const n=(e.value.match(/\n/g)||[]).length+1;e.rows=Math.max(3,n);const r=()=>{e.isConnected&&(e.style.height="0",e.style.height=`${e.scrollHeight}px`,t&&(t.style.height=`${e.scrollHeight}px`))};e.addEventListener("input",r),setTimeout(()=>{e.isConnected&&r()},0)}function ft(e,t){var n,r,l,a;const o=new Map,c=new Map;for(const i of e){const u=t.resourceIndex.get(i),f=(n=u==null?void 0:u.name)!=null?n:i;c.set(f,((r=c.get(f))!=null?r:0)+1)}for(const i of e){const u=t.resourceIndex.get(i),f=(l=u==null?void 0:u.name)!=null?l:i;((a=c.get(f))!=null?a:1)>1&&u?o.set(i,`${f} (${mn(u.size)})`):o.set(i,f)}return o}function mt(e){return e?e.type.startsWith("image/"):!1}function Yt(e,t){const n=ft(e,t),r=new Map;for(const l of e){const a=n.get(l);a&&r.set(a,l)}return r}function ht(e){return/\s/.test(e)||e.includes('"')?`@"${e.replace(/\\/g,"\\\\").replace(/"/g,'\\"')}"`:`@${e}`}function Ke(e){const t=[],n=e.length;let r=0;for(;r<n;)if(e[r]==="@"){if(r>0&&!/\s/.test(e[r-1])){r++;continue}const l=r;if(r++,r<n&&e[r]==='"'){r++;let a="";for(;r<n&&e[r]!=='"';)e[r]==="\\"&&r+1<n?(a+=e[r+1],r+=2):(a+=e[r],r++);r<n&&e[r]==='"'&&(r++,(r>=n||/\s/.test(e[r]))&&t.push({start:l,end:r,raw:e.slice(l,r),name:a}))}else if(r<n&&!/\s/.test(e[r])){const a=r;for(;r<n&&!/\s/.test(e[r]);)r++;const o=e.slice(a,r);t.push({start:l,end:r,raw:e.slice(l,r),name:o})}}else r++;return t}function wo(e,t){if(t.size===0)return[];const n=Ke(e),r=[];for(const l of n){const a=t.get(l.name);a&&r.push({start:l.start,end:l.end,name:l.name,rid:a})}return r}function ko(e,t){const n=wo(e,t);if(n.length===0)return e;let r="",l=0;for(const a of n)r+=e.slice(l,a.start),r+=`@${a.rid}`,l=a.end;return r+=e.slice(l),r}function Xt(e,t,n){const r=ft(t,n),l=new Map;for(const i of t){const u=r.get(i);u&&l.set(i,u)}const a=Ke(e);if(a.length===0)return e;let o="",c=0;for(const i of a){o+=e.slice(c,i.start);const u=l.get(i.name);u?o+=ht(u):o+=i.raw,c=i.end}return o+=e.slice(c),o}function Gt(e,t,n,r){if(pe(e),n!=null&&n.file&&mt(n)){const l=document.createElement("img");l.alt=n.name,l.style.cssText="width: 100%; height: 100%; object-fit: cover; display: block;";const a=new FileReader;a.onload=o=>{var c;l.src=((c=o.target)==null?void 0:c.result)||""},a.readAsDataURL(n.file),e.appendChild(l)}else if(r.config.getThumbnail){r.config.getThumbnail(t).then(a=>{var o;if(!a||!e.isConnected)return;const c=document.createElement("img");c.alt=(o=n==null?void 0:n.name)!=null?o:t,c.src=a,c.style.cssText="width: 100%; height: 100%; object-fit: cover; display: block;",pe(e),e.appendChild(c)}).catch(a=>{var o,c;(c=(o=r.config).onThumbnailError)==null||c.call(o,a,t)});const l=document.createElement("div");l.style.cssText="width: 100%; height: 100%; background: var(--fb-background-hover-color, #f3f4f6); display: flex; align-items: center; justify-content: center;",l.innerHTML='<svg width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><rect x="3" y="3" width="18" height="18" rx="2"/><circle cx="8.5" cy="8.5" r="1.5"/><polyline points="21 15 16 10 5 21"/></svg>',e.appendChild(l)}else{const l=document.createElement("div");if(l.style.cssText="width: 100%; height: 100%; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 2px; padding: 2px; box-sizing: border-box;",l.innerHTML='<svg width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><path d="M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8z"/><polyline points="14 2 14 8 20 8"/></svg>',n!=null&&n.name){const a=document.createElement("span");a.style.cssText="font-size: 9px; text-align: center; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 44px; color: var(--fb-text-color, #111827);",a.textContent=n.name,l.appendChild(a)}e.appendChild(l)}}function Zt(e,t,n,r){if(pe(e),n!=null&&n.file&&mt(n)){const l=document.createElement("img");l.alt=n.name,l.style.cssText="max-width: 120px; max-height: 120px; object-fit: contain; display: block;";const a=new FileReader;a.onload=o=>{var c;l.src=((c=o.target)==null?void 0:c.result)||""},a.readAsDataURL(n.file),e.appendChild(l)}else r.config.getThumbnail&&r.config.getThumbnail(t).then(l=>{var a;if(!l||!e.isConnected)return;const o=document.createElement("img");o.alt=(a=n==null?void 0:n.name)!=null?a:t,o.src=l,o.style.cssText="max-width: 120px; max-height: 120px; object-fit: contain; display: block;",pe(e),e.appendChild(o)}).catch(l=>{var a,o;(o=(a=r.config).onThumbnailError)==null||o.call(a,l,t)})}function Qt(e,t){const n=t.getBoundingClientRect(),r=e.getBoundingClientRect(),l=Math.max(4,Math.min(n.left+n.width/2-r.width/2,window.innerWidth-r.width-4)),a=n.top-r.height-8,o=n.bottom+8,c=a>=4?a:o;e.style.left=`${l}px`,e.style.top=`${Math.max(4,c)}px`}function en(e,t,n){const r=n.resourceIndex.get(t),l=document.createElement("div");l.className="fb-richinput-portal-tooltip fb-richinput-mention-tooltip",l.style.cssText=`
|
|
453
|
+
`,L.addEventListener("mouseenter",()=>{L.style.background="var(--fb-background-hover-color)"}),L.addEventListener("mouseleave",()=>{L.style.background="transparent"}),L.addEventListener("click",()=>{Ee(),T()}),L}function fe(A,T){if(!v)return;R.innerHTML="",R.style.display="flex";const L=xe(g),B=L&&(L.r1!==L.r2||L.c1!==L.c2),D=g.anchor&&_e(g.anchor.row,g.anchor.col,y);if(B&&R.appendChild(_(k("tableMergeCells",p),q)),D&&R.appendChild(_(k("tableSplitCell",p),M)),!R.firstChild){Ee();return}const F=140,Q=R.children.length*32+8,O=window.innerWidth,U=window.innerHeight,V=A+F>O?A-F:A,Y=T+Q>U?T-Q:T;R.style.left=`${V}px`,R.style.top=`${Y}px`}function Ee(){R.style.display="none"}const Ne=new AbortController;document.addEventListener("mousedown",A=>{if(!l.isConnected){Ne.abort();return}R.contains(A.target)||Ee()},{signal:Ne.signal});function me(){const A=xe(g);S.querySelectorAll("td[data-row]").forEach(T=>{const L=parseInt(T.getAttribute("data-row")||"0",10),B=parseInt(T.getAttribute("data-col")||"0",10),D=g.anchor!==null&&g.anchor.row===L&&g.anchor.col===B,F=A!==null&&L>=A.r1&&L<=A.r2&&B>=A.c1&&B<=A.c2;T.style.outline=D?"2px solid var(--fb-primary-color, #0066cc)":"",T.style.outlineOffset=D?"-2px":"",L===0?T.style.backgroundColor="var(--fb-background-hover-color)":T.style.backgroundColor=F&&!D?"rgba(0,102,204,0.08)":""})}function Me(A,T){g.anchor={row:A,col:T},g.focus=null,me(),S.focus()}function Be(A,T){const L=S.querySelector(`td[data-row="${A}"][data-col="${T}"]`);if(!L)return;const B=L.querySelector("span");B&&(g.anchor={row:A,col:T},g.focus=null,me(),go(B,A,T,()=>d,C,Me))}function be(A){var T;const L=d.length>0?d[0].length:(T=e.columns)!=null?T:3,B=Array(L).fill(""),D=A!==void 0?A+1:d.length;d.splice(D,0,B),y=y.map(F=>F.top>=D?{...F,top:F.top+1,bottom:F.bottom+1}:F.top<D&&F.bottom>=D?{...F,bottom:F.bottom+1}:F),C(),N()}function Qe(A){if(d.length<=1)return;const T=A!==void 0?A:g.anchor?g.anchor.row:d.length-1;y=y.map(L=>L.top===T&&L.bottom===T?null:L.top===T?{...L,bottom:L.bottom-1}:L.bottom===T?{...L,bottom:L.bottom-1}:L.top<T&&L.bottom>T?{...L,bottom:L.bottom-1}:L.top>T?{...L,top:L.top-1,bottom:L.bottom-1}:L).filter(L=>L!==null),d.splice(T,1),g.anchor&&g.anchor.row>=d.length&&(g.anchor={row:d.length-1,col:g.anchor.col}),C(),N()}function Re(A){var T,L;const B=A!==void 0?A+1:(L=(T=d[0])==null?void 0:T.length)!=null?L:0;d.forEach(D=>D.splice(B,0,"")),y=y.map(D=>D.left>=B?{...D,left:D.left+1,right:D.right+1}:D.left<B&&D.right>=B?{...D,right:D.right+1}:D),C(),N()}function $(A){if(d.length===0||d[0].length<=1)return;const T=A!==void 0?A:g.anchor?g.anchor.col:d[0].length-1;y=y.map(L=>L.left===T&&L.right===T?null:L.left===T?{...L,right:L.right-1}:L.right===T?{...L,right:L.right-1}:L.left<T&&L.right>T?{...L,right:L.right-1}:L.left>T?{...L,left:L.left-1,right:L.right-1}:L).filter(L=>L!==null),d.forEach(L=>L.splice(T,1)),g.anchor&&g.anchor.col>=d[0].length&&(g.anchor={row:g.anchor.row,col:d[0].length-1}),C(),N()}function q(){var A,T;if(!v)return;const L=xe(g);if(!L)return;const{r1:B,c1:D,r2:F,c2:Q}=L;if(B===F&&D===Q)return;y=y.filter(j=>!(j.top<=F&&j.bottom>=B&&j.left<=Q&&j.right>=D));const O=d[B][D];for(let j=B;j<=F;j++)for(let X=D;X<=Q;X++)(j!==B||X!==D)&&(d[j][X]="");d[B][D]=O;const U={top:B,left:D,bottom:F,right:Q},V=[...y,U],Y=dt(V,d.length,(T=(A=d[0])==null?void 0:A.length)!=null?T:0);if(Y){console.warn("Merge validation failed:",Y);return}y.push(U),g.anchor={row:B,col:D},g.focus=null,C(),N()}function M(){if(!v||!g.anchor)return;const{row:A,col:T}=g.anchor,L=y.findIndex(B=>B.top===A&&B.left===T);L!==-1&&(y.splice(L,1),g.focus=null,C(),N())}function N(){var A,T;S.innerHTML="";const L=d.length,B=L>0?d[0].length:0,D=xe(g);for(let F=0;F<L;F++){const Q=(F===0?(A=S.tHead)!=null?A:S.createTHead():(T=S.tBodies[0])!=null?T:S.createTBody()).insertRow();for(let O=0;O<B;O++){if(Gt(F,O,y))continue;const U=_e(F,O,y),V=document.createElement("td");if(V.setAttribute("data-row",String(F)),V.setAttribute("data-col",String(O)),U){const G=U.bottom-U.top+1,K=U.right-U.left+1;G>1&&(V.rowSpan=G),K>1&&(V.colSpan=K)}const Y=D!==null&&F>=D.r1&&F<=D.r2&&O>=D.c1&&O<=D.c2,j=g.anchor!==null&&g.anchor.row===F&&g.anchor.col===O;V.style.cssText=["border: var(--fb-border-width) solid var(--fb-border-color);","padding: 4px 8px;","min-width: 80px;","vertical-align: top;","cursor: text;","position: relative;",F===0?"background-color: var(--fb-background-hover-color); font-weight: 600;":"",Y&&!j?"background-color: rgba(0,102,204,0.08);":"",j?"outline: 2px solid var(--fb-primary-color, #0066cc); outline-offset: -2px;":""].join(" ");const X=document.createElement("span");X.textContent=d[F][O],X.style.cssText="display: block; min-height: 1.4em; white-space: pre-wrap; word-break: break-word; outline: none;",V.appendChild(X);const W=F,ne=O;V.addEventListener("mousedown",G=>{if(G.target.tagName!=="BUTTON"&&G.target.contentEditable!=="true"){if(G.button===2){const K=xe(g);if(K&&W>=K.r1&&W<=K.r2&&ne>=K.c1&&ne<=K.c2)return}G.shiftKey&&g.anchor?(G.preventDefault(),g.focus={row:W,col:ne},g.dragging=!1,me()):(g.anchor={row:W,col:ne},g.focus=null,g.dragging=!0,me())}}),V.addEventListener("mouseup",G=>{if(G.target.tagName!=="BUTTON"&&g.dragging){g.dragging=!1;const K=xe(g);(!K||K.r1===K.r2&&K.c1===K.c2)&&Be(W,ne)}}),V.addEventListener("mousemove",G=>{if(g.dragging&&G.buttons===1){const K=g.anchor;K&&(K.row!==W||K.col!==ne)&&(g.focus={row:W,col:ne},me())}}),V.addEventListener("contextmenu",G=>{if(!v)return;const K=xe(g),ie=K&&(K.r1!==K.r2||K.c1!==K.c2),ae=g.anchor&&_e(g.anchor.row,g.anchor.col,y);(ie||ae)&&(G.preventDefault(),fe(G.clientX,G.clientY))}),Q.appendChild(V)}}ce(),S.setAttribute("tabindex","0"),S.onkeydown=F=>{var Q,O;if(S.querySelector("[contenteditable='true']"))return;const U=g.anchor;if(!U)return;const V=d.length,Y=V>0?d[0].length:0,j={ArrowUp:[-1,0],ArrowDown:[1,0],ArrowLeft:[0,-1],ArrowRight:[0,1]};if(j[F.key]){F.preventDefault();const[X,W]=j[F.key],ne=Math.max(0,Math.min(V-1,U.row+X)),G=Math.max(0,Math.min(Y-1,U.col+W));F.shiftKey?(g.focus={row:ne,col:G},me()):Me(ne,G);return}if(F.key==="Enter"){F.preventDefault(),Be(U.row,U.col);return}if(F.key==="Tab"){F.preventDefault();const X=(O=(Q=d[0])==null?void 0:Q.length)!=null?O:0;let W=U.row,ne=F.shiftKey?U.col-1:U.col+1;ne<0&&(ne=X-1,W=Math.max(0,W-1)),ne>=X&&(ne=0,W=Math.min(d.length-1,W+1)),Me(W,ne);return}if(v&&F.key==="m"&&F.ctrlKey&&!F.shiftKey){F.preventDefault(),q();return}v&&F.key==="M"&&F.ctrlKey&&F.shiftKey&&(F.preventDefault(),M())},S.oncopy=F=>{var Q,O,U,V;const Y=xe(g);if(!Y)return;F.preventDefault();const{r1:j,c1:X,r2:W,c2:ne}=Y,G=[],K=[];for(let P=j;P<=W;P++){const le=[],ue=[];for(let de=X;de<=ne;de++){const he=(O=(Q=d[P])==null?void 0:Q[de])!=null?O:"";le.push(he);const ke=he.replace(/&/g,"&").replace(/</g,"<").replace(/>/g,">");ue.push(`<td>${ke}</td>`)}G.push(le.join(" ")),K.push(`<tr>${ue.join("")}</tr>`)}const ie=G.join(`
|
|
454
|
+
`),ae=`<table>${K.join("")}</table>`;(U=F.clipboardData)==null||U.setData("text/plain",ie),(V=F.clipboardData)==null||V.setData("text/html",ae)},S.onpaste=F=>{var Q,O,U,V,Y,j,X,W,ne;const G=g.anchor;if(!G)return;const K=(O=(Q=F.clipboardData)==null?void 0:Q.getData("text/plain"))!=null?O:"",ie=K.includes(" ")||K.split(/\r?\n/).filter(se=>se).length>1,ae=S.querySelector("[contenteditable='true']");if(ae&&!ie)return;if(F.preventDefault(),ae){ae.contentEditable="inherit";const se=parseInt((V=(U=ae.closest("td"))==null?void 0:U.getAttribute("data-row"))!=null?V:"0",10),Ce=parseInt((j=(Y=ae.closest("td"))==null?void 0:Y.getAttribute("data-col"))!=null?j:"0",10);d[se]&&(d[se][Ce]=(X=ae.textContent)!=null?X:"")}if(!K.trim())return;const P=K.split(/\r?\n/).map(se=>se.split(" "));P.length>1&&P[P.length-1].length===1&&P[P.length-1][0]===""&&P.pop();const le=G.row,ue=G.col,de=le+P.length;for(;d.length<de;)d.push(Array((ne=(W=d[0])==null?void 0:W.length)!=null?ne:1).fill(""));const he=Math.max(...P.map(se=>se.length)),ke=ue+he;if(d[0]&&ke>d[0].length){const se=ke-d[0].length;d.forEach(Ce=>{for(let De=0;De<se;De++)Ce.push("")})}for(let se=0;se<P.length;se++)for(let Ce=0;Ce<P[se].length;Ce++){const De=le+se,Zo=ue+Ce;d[De]&&(d[De][Zo]=P[se][Ce])}C(),N()}}const H=Ae({label:"+",title:k("tableAddColumn",p),size:20,color:"var(--fb-primary-color, #0066cc)",textColor:"white",onClick:()=>{var A;const T=parseInt((A=H.dataset.afterCol)!=null?A:"0",10);Re(T)}});H.style.position="absolute",H.style.display="none",w.appendChild(H);const I=Ae({label:"+",title:k("tableAddRow",p),size:20,color:"var(--fb-primary-color, #0066cc)",textColor:"white",onClick:()=>{var A;const T=parseInt((A=I.dataset.afterRow)!=null?A:"0",10);be(T)}});I.style.position="absolute",I.style.display="none",w.appendChild(I);let ee=[],te=[];const re=Ae({label:"+",title:k("tableAddColumn",p),size:20,color:"var(--fb-primary-color, #0066cc)",textColor:"white",onClick:()=>Re()});re.style.position="absolute",re.style.display="none",w.appendChild(re);const oe=Ae({label:"+",title:k("tableAddRow",p),size:20,color:"var(--fb-primary-color, #0066cc)",textColor:"white",onClick:()=>be()});oe.style.position="absolute",oe.style.display="none",w.appendChild(oe);function ce(){var A,T;ee.forEach(O=>O.remove()),ee=[],te.forEach(O=>O.remove()),te=[];const L=d.length>0?d[0].length:0,B=d.length;if(L>1){const O=Array.from(S.querySelectorAll("thead td[data-col]"));for(const U of O){const V=parseInt((A=U.getAttribute("data-col"))!=null?A:"0",10),Y=Ae({label:"\xD7",title:k("tableRemoveColumn",p),size:16,color:"var(--fb-error-color, #dc3545)",textColor:"white",onClick:()=>$(V)});Y.setAttribute("data-action","remove-col"),Y.setAttribute("data-col",String(V)),Y.style.position="absolute",Y.style.display="none",w.appendChild(Y),ee.push(Y)}}if(B>1){const O=[...S.tHead?Array.from(S.tHead.rows):[],...S.tBodies[0]?Array.from(S.tBodies[0].rows):[]].filter(U=>U.querySelector("td[data-row]"));for(const U of O){const V=U.querySelector("td[data-row]");if(!V)continue;const Y=parseInt((T=V.getAttribute("data-row"))!=null?T:"0",10),j=Ae({label:"\xD7",title:k("tableRemoveRow",p),size:16,color:"var(--fb-error-color, #dc3545)",textColor:"white",onClick:()=>Qe(Y)});j.setAttribute("data-action","remove-row"),j.setAttribute("data-row",String(Y)),j.style.position="absolute",j.style.display="none",w.appendChild(j),te.push(j)}}function D(O,U,V,Y,j){var X;const W=j?Array.from(S.querySelectorAll("thead td[data-col]")):[];let ne=-1,G=1/0,K=-1,ie=-1,ae=1/0;for(let P=0;P<W.length;P++){const le=W[P].getBoundingClientRect(),ue=(le.left+le.right)/2,de=Math.abs(O-ue);de<G&&(G=de,ne=P);const he=Math.abs(O-le.right);he<ae&&he<20&&(ae=he,K=le.right-U.left+Y,ie=parseInt((X=W[P].getAttribute("data-col"))!=null?X:"0",10))}ee.forEach((P,le)=>{if(!j||le!==ne){P.style.display="none";return}const ue=W[le].getBoundingClientRect(),de=(ue.left+ue.right)/2-U.left+Y;P.style.left=`${de-8}px`,P.style.top="2px",P.style.display="flex"}),j&&ie>=0?(H.style.display="flex",H.style.left=`${K-10}px`,H.style.top=`${V.top-U.top-10}px`,H.dataset.afterCol=String(ie)):H.style.display="none"}function F(O,U,V,Y,j){var X;const W=[];if(j){if(S.tHead)for(const P of Array.from(S.tHead.rows))P.querySelector("td[data-row]")&&W.push(P);if(S.tBodies[0])for(const P of Array.from(S.tBodies[0].rows))P.querySelector("td[data-row]")&&W.push(P)}let ne=-1,G=1/0,K=-1,ie=-1,ae=1/0;for(let P=0;P<W.length;P++){const le=W[P].getBoundingClientRect(),ue=(le.top+le.bottom)/2,de=Math.abs(O-ue);de<G&&(G=de,ne=P);const he=Math.abs(O-le.bottom);if(he<ae&&he<14){ae=he,K=le.bottom-U.top;const ke=W[P].querySelector("td[data-row]");ie=parseInt((X=ke==null?void 0:ke.getAttribute("data-row"))!=null?X:"0",10)}}te.forEach((P,le)=>{if(!j||le!==ne){P.style.display="none";return}const ue=W[le].getBoundingClientRect(),de=(ue.top+ue.bottom)/2-U.top;P.style.left="4px",P.style.top=`${de-8}px`,P.style.display="flex"}),j&&ie>=0?(I.style.display="flex",I.style.top=`${K-10}px`,I.style.left=`${V.left-U.left+Y-10}px`,I.dataset.afterRow=String(ie)):I.style.display="none"}let Q=!1;w.onmousemove=O=>{const U=O.target;if(U.tagName==="BUTTON"&&U.parentElement===w||Q)return;Q=!0;const V=O.clientX,Y=O.clientY;requestAnimationFrame(()=>{Q=!1;const j=w.getBoundingClientRect(),X=S.getBoundingClientRect(),W=w.scrollLeft,ne=Y>=j.top&&Y<X.top+4,G=V>=j.left&&V<X.left+4,K=Math.min(X.right,j.right),ie=V>K-20&&V<=j.right,ae=Y>X.bottom-4&&Y<=j.bottom+20;if(D(V,j,X,W,ne),F(Y,j,X,W,G),re.style.display=ie?"flex":"none",ie&&(re.style.left=`${j.right-j.left+W-20}px`,re.style.top=`${(X.top+X.bottom)/2-j.top-10}px`),oe.style.display=ae?"flex":"none",ae){const P=(j.left+j.right)/2-j.left+W;oe.style.left=`${P-10}px`,oe.style.top=`${X.bottom-j.top-10}px`}})},w.onmouseleave=()=>{ee.forEach(O=>{O.style.display="none"}),te.forEach(O=>{O.style.display="none"}),H.style.display="none",I.style.display="none",re.style.display="none",oe.style.display="none"}}N()}function Eo(e){var t,n;return{cells:Xt((t=e.rows)!=null?t:3,(n=e.columns)!=null?n:3),merges:[]}}function pt(e){return e!==null&&typeof e=="object"&&"cells"in e&&Array.isArray(e.cells)}function ft(e,t){return e!==null&&typeof e=="object"&&t in e&&Array.isArray(e[t])}function Co(e,t,n,r){var l,a,o,s;const i=t.state,u=t.prefill[e.key],f=(a=(l=e.fieldNames)==null?void 0:l.cells)!=null?a:"cells",c=(s=(o=e.fieldNames)==null?void 0:o.merges)!=null?s:"merges";let m;if(pt(u))m={cells:u.cells,merges:u.merges?Te(u.merges):[]};else if(u&&ft(u,f)){const p=u[c];m={cells:u[f],merges:p?Te(p):[]}}else if(pt(e.default))m={cells:e.default.cells,merges:e.default.merges?Te(e.default.merges):[]};else if(e.default&&ft(e.default,f)){const p=e.default[c];m={cells:e.default[f],merges:p?Te(p):[]}}else m=Eo(e);if(m.merges&&m.merges.length>0){const p=m.cells.length,h=p>0?m.cells[0].length:0,v=dt(m.merges,p,h);v&&(console.warn(`Table "${e.key}": invalid prefill merges stripped (${v})`),m={...m,merges:[]})}i.config.readonly?vo(m,n):xo(e,m,r,t,n)}function wo(e,t,n){var r,l;const{scopeRoot:a,skipValidation:o}=n,s=[],i=(l=(r=e.fieldNames)==null?void 0:r.cells)!=null?l:"cells",u=a.querySelector(`[name="${t}"]`);if(!u)return{value:null,errors:s};let f=null;try{f=JSON.parse(u.value)}catch(c){return s.push(`${t}: invalid table data`),{value:null,errors:s}}if(!o&&e.required){const c=f[i];c!=null&&c.some(m=>m.some(p=>p.trim()!==""))||s.push(`${t}: ${k("required",n.state)}`)}return{value:f,errors:s}}function ko(e,t,n,r){var l,a,o,s;const{scopeRoot:i}=r,u=(a=(l=e.fieldNames)==null?void 0:l.cells)!=null?a:"cells",f=(s=(o=e.fieldNames)==null?void 0:o.merges)!=null?s:"merges",c=i.querySelector(`[name="${t}"]`);if(!c){console.warn(`updateTableField: no hidden input found for "${t}". Re-render to reflect new data.`);return}let m=null;if(pt(n))m={cells:n.cells,merges:n.merges?Te(n.merges):[]};else if(n&&ft(n,u)){const p=n[f];m={cells:n[u],merges:p?Te(p):[]}}m&&c._applyExternalUpdate?c._applyExternalUpdate(m):c.value=JSON.stringify(n)}function $o(e,t){e.style.overflow="hidden",e.style.resize="none";const n=(e.value.match(/\n/g)||[]).length+1;e.rows=Math.max(3,n);const r=()=>{e.isConnected&&(e.style.height="0",e.style.height=`${e.scrollHeight}px`,t&&(t.style.height=`${e.scrollHeight}px`))};e.addEventListener("input",r),setTimeout(()=>{e.isConnected&&r()},0)}function mt(e,t){var n,r,l,a;const o=new Map,s=new Map;for(const i of e){const u=t.resourceIndex.get(i),f=(n=u==null?void 0:u.name)!=null?n:i;s.set(f,((r=s.get(f))!=null?r:0)+1)}for(const i of e){const u=t.resourceIndex.get(i),f=(l=u==null?void 0:u.name)!=null?l:i;((a=s.get(f))!=null?a:1)>1&&u?o.set(i,`${f} (${gn(u.size)})`):o.set(i,f)}return o}function ht(e){return e?e.type.startsWith("image/"):!1}function Zt(e,t){const n=mt(e,t),r=new Map;for(const l of e){const a=n.get(l);a&&r.set(a,l)}return r}function vt(e){return/\s/.test(e)||e.includes('"')?`@"${e.replace(/\\/g,"\\\\").replace(/"/g,'\\"')}"`:`@${e}`}function We(e){const t=[],n=e.length;let r=0;for(;r<n;)if(e[r]==="@"){if(r>0&&!/\s/.test(e[r-1])){r++;continue}const l=r;if(r++,r<n&&e[r]==='"'){r++;let a="";for(;r<n&&e[r]!=='"';)e[r]==="\\"&&r+1<n?(a+=e[r+1],r+=2):(a+=e[r],r++);r<n&&e[r]==='"'&&(r++,(r>=n||/\s/.test(e[r]))&&t.push({start:l,end:r,raw:e.slice(l,r),name:a}))}else if(r<n&&!/\s/.test(e[r])){const a=r;for(;r<n&&!/\s/.test(e[r]);)r++;const o=e.slice(a,r);t.push({start:l,end:r,raw:e.slice(l,r),name:o})}}else r++;return t}function Lo(e,t){if(t.size===0)return[];const n=We(e),r=[];for(const l of n){const a=t.get(l.name);a&&r.push({start:l.start,end:l.end,name:l.name,rid:a})}return r}function So(e,t){const n=Lo(e,t);if(n.length===0)return e;let r="",l=0;for(const a of n)r+=e.slice(l,a.start),r+=`@${a.rid}`,l=a.end;return r+=e.slice(l),r}function Qt(e,t,n){const r=mt(t,n),l=new Map;for(const i of t){const u=r.get(i);u&&l.set(i,u)}const a=We(e);if(a.length===0)return e;let o="",s=0;for(const i of a){o+=e.slice(s,i.start);const u=l.get(i.name);u?o+=vt(u):o+=i.raw,s=i.end}return o+=e.slice(s),o}function en(e,t,n,r){if(pe(e),n!=null&&n.file&&ht(n)){const l=document.createElement("img");l.alt=n.name,l.style.cssText="width: 100%; height: 100%; object-fit: cover; display: block;";const a=new FileReader;a.onload=o=>{var s;l.src=((s=o.target)==null?void 0:s.result)||""},a.readAsDataURL(n.file),e.appendChild(l)}else if(r.config.getThumbnail){r.config.getThumbnail(t).then(a=>{var o;if(!a||!e.isConnected)return;const s=document.createElement("img");s.alt=(o=n==null?void 0:n.name)!=null?o:t,s.src=a,s.style.cssText="width: 100%; height: 100%; object-fit: cover; display: block;",pe(e),e.appendChild(s)}).catch(a=>{var o,s;(s=(o=r.config).onThumbnailError)==null||s.call(o,a,t)});const l=document.createElement("div");l.style.cssText="width: 100%; height: 100%; background: var(--fb-background-hover-color, #f3f4f6); display: flex; align-items: center; justify-content: center;",l.innerHTML='<svg width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><rect x="3" y="3" width="18" height="18" rx="2"/><circle cx="8.5" cy="8.5" r="1.5"/><polyline points="21 15 16 10 5 21"/></svg>',e.appendChild(l)}else{const l=document.createElement("div");if(l.style.cssText="width: 100%; height: 100%; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 2px; padding: 2px; box-sizing: border-box;",l.innerHTML='<svg width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><path d="M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8z"/><polyline points="14 2 14 8 20 8"/></svg>',n!=null&&n.name){const a=document.createElement("span");a.style.cssText="font-size: 9px; text-align: center; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 44px; color: var(--fb-text-color, #111827);",a.textContent=n.name,l.appendChild(a)}e.appendChild(l)}}function tn(e,t,n,r){if(pe(e),n!=null&&n.file&&ht(n)){const l=document.createElement("img");l.alt=n.name,l.style.cssText="max-width: 120px; max-height: 120px; object-fit: contain; display: block;";const a=new FileReader;a.onload=o=>{var s;l.src=((s=o.target)==null?void 0:s.result)||""},a.readAsDataURL(n.file),e.appendChild(l)}else r.config.getThumbnail&&r.config.getThumbnail(t).then(l=>{var a;if(!l||!e.isConnected)return;const o=document.createElement("img");o.alt=(a=n==null?void 0:n.name)!=null?a:t,o.src=l,o.style.cssText="max-width: 120px; max-height: 120px; object-fit: contain; display: block;",pe(e),e.appendChild(o)}).catch(l=>{var a,o;(o=(a=r.config).onThumbnailError)==null||o.call(a,l,t)})}function nn(e,t){const n=t.getBoundingClientRect(),r=e.getBoundingClientRect(),l=Math.max(4,Math.min(n.left+n.width/2-r.width/2,window.innerWidth-r.width-4)),a=n.top-r.height-8,o=n.bottom+8,s=a>=4?a:o;e.style.left=`${l}px`,e.style.top=`${Math.max(4,s)}px`}function on(e,t,n){const r=n.resourceIndex.get(t),l=document.createElement("div");l.className="fb-richinput-portal-tooltip fb-richinput-mention-tooltip",l.style.cssText=`
|
|
455
455
|
position: fixed;
|
|
456
456
|
z-index: 99999;
|
|
457
457
|
background: #fff;
|
|
@@ -462,7 +462,7 @@ var FormBuilder=(function(be){"use strict";function k(e,t,n){const r=t.config.lo
|
|
|
462
462
|
pointer-events: none;
|
|
463
463
|
min-width: 60px;
|
|
464
464
|
max-width: 140px;
|
|
465
|
-
`;const a=document.createElement("div");return a.style.cssText="min-height: 60px; max-height: 120px; display: flex; align-items: center; justify-content: center;",
|
|
465
|
+
`;const a=document.createElement("div");return a.style.cssText="min-height: 60px; max-height: 120px; display: flex; align-items: center; justify-content: center;",tn(a,t,r,n),l.appendChild(a),document.body.appendChild(l),nn(l,e),l}function rn(e,t){var n,r;const{rid:l,state:a,isReadonly:o,onMention:s,onRemove:i}=t,u=a.resourceIndex.get(l),f=(n=u==null?void 0:u.name)!=null?n:l,c=document.createElement("div");c.className="fb-richinput-portal-tooltip fb-richinput-file-tooltip",c.style.cssText=`
|
|
466
466
|
position: fixed;
|
|
467
467
|
z-index: 99999;
|
|
468
468
|
background: #fff;
|
|
@@ -473,17 +473,17 @@ var FormBuilder=(function(be){"use strict";function k(e,t,n){const r=t.config.lo
|
|
|
473
473
|
pointer-events: auto;
|
|
474
474
|
min-width: 80px;
|
|
475
475
|
max-width: 260px;
|
|
476
|
-
`;const m=document.createElement("div");m.style.cssText="min-height: 60px; max-height: 120px; display: flex; align-items: center; justify-content: center;",
|
|
476
|
+
`;const m=document.createElement("div");m.style.cssText="min-height: 60px; max-height: 120px; display: flex; align-items: center; justify-content: center;",tn(m,l,u,a),c.appendChild(m);const p=document.createElement("div");p.style.cssText="padding: 4px 6px 2px; font-size: 12px; color: var(--fb-text-color, #111827); word-break: break-word; border-top: 1px solid var(--fb-border-color, #d1d5db);",p.textContent=f,c.appendChild(p);const h=document.createElement("div");h.style.cssText="display: flex; align-items: center; gap: 2px; padding: 3px 4px 2px; border-top: 1px solid var(--fb-border-color, #d1d5db); justify-content: center;";const v="background: none; border: none; cursor: pointer; padding: 3px 5px; border-radius: 4px; color: var(--fb-text-muted-color, #6b7280); display: flex; align-items: center; transition: background 0.1s, color 0.1s;",b=d=>{d.style.background="var(--fb-background-hover-color, #f3f4f6)",d.style.color="var(--fb-text-color, #111827)"},x=d=>{d.style.background="none",d.style.color="var(--fb-text-muted-color, #6b7280)"};if(!o&&s){const d=document.createElement("button");d.type="button",d.title="Mention",d.style.cssText=v,d.innerHTML='<svg width="14" height="14" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2.5"><circle cx="12" cy="12" r="4"/><path d="M16 8v5a3 3 0 0 0 6 0v-1a10 10 0 1 0-3.92 7.94"/></svg>',d.addEventListener("mouseenter",()=>b(d)),d.addEventListener("mouseleave",()=>x(d)),d.addEventListener("click",y=>{y.stopPropagation(),s(),c.remove()}),h.appendChild(d)}if(a.config.downloadFile){const d=document.createElement("button");d.type="button",d.title="Download",d.style.cssText=v,d.innerHTML='<svg width="14" height="14" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M21 15v4a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2v-4"/><polyline points="7 10 12 15 17 10"/><line x1="12" y1="15" x2="12" y2="3"/></svg>',d.addEventListener("mouseenter",()=>b(d)),d.addEventListener("mouseleave",()=>x(d)),d.addEventListener("click",y=>{var g,E;y.stopPropagation(),(E=(g=a.config).downloadFile)==null||E.call(g,l,f)}),h.appendChild(d)}if((r=a.config.getDownloadUrl)!=null?r:a.config.getThumbnail){const d=document.createElement("button");d.type="button",d.title="Open in new window",d.style.cssText=v,d.innerHTML='<svg width="14" height="14" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M18 13v6a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2h6"/><polyline points="15 3 21 3 21 9"/><line x1="10" y1="14" x2="21" y2="3"/></svg>',d.addEventListener("mouseenter",()=>b(d)),d.addEventListener("mouseleave",()=>x(d)),d.addEventListener("click",y=>{var g,E,C,w;if(y.stopPropagation(),a.config.getDownloadUrl){const S=a.config.getDownloadUrl(l);S?window.open(S,"_blank"):(E=(g=a.config).getThumbnail)==null||E.call(g,l).then(z=>{z&&window.open(z,"_blank")}).catch(()=>{})}else(w=(C=a.config).getThumbnail)==null||w.call(C,l).then(S=>{S&&window.open(S,"_blank")}).catch(()=>{})}),h.appendChild(d)}if(!o&&i){const d=document.createElement("button");d.type="button",d.title="Remove",d.style.cssText=v,d.innerHTML='<svg width="14" height="14" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><polyline points="3 6 5 6 21 6"/><path d="M19 6v14a2 2 0 0 1-2 2H7a2 2 0 0 1-2-2V6m3 0V4a2 2 0 0 1 2-2h4a2 2 0 0 1 2 2v2"/><line x1="10" y1="11" x2="10" y2="17"/><line x1="14" y1="11" x2="14" y2="17"/></svg>',d.addEventListener("mouseenter",()=>{d.style.background="var(--fb-background-hover-color, #f3f4f6)",d.style.color="var(--fb-error-color, #ef4444)"}),d.addEventListener("mouseleave",()=>x(d)),d.addEventListener("click",y=>{y.stopPropagation(),c.remove(),i()}),h.appendChild(d)}return h.children.length>0&&c.appendChild(h),document.body.appendChild(c),nn(c,e),c}function ln(){return{element:null,hideTimer:null}}function Je(e,t=150){e.hideTimer===null&&(e.hideTimer=setTimeout(()=>{e.hideTimer=null,e.element&&(e.element.remove(),e.element=null)},t))}function Ye(e){e.hideTimer!==null&&(clearTimeout(e.hideTimer),e.hideTimer=null)}function Fe(e){return e&&e.remove(),null}function To(e){var t;const n=(t=e.selectionStart)!=null?t:0,r=e.value.slice(0,n);for(let l=r.length-1;l>=0;l--)if(r[l]==="@"){if(l===0||/\s/.test(r[l-1])){let a=r.slice(l+1);return a.startsWith('"')&&(a=a.slice(1)),{query:a,pos:l}}return null}return null}function an(e,t,n){const r=e.toLowerCase();return t.filter(l=>{var a;return((a=n.get(l))!=null?a:l).toLowerCase().includes(r)})}const Xe="font-size: var(--fb-font-size, 14px); font-family: var(--fb-font-family, inherit); line-height: 1.6;",sn="padding: 12px 52px 12px 14px;";function Ao(e,t,n,r,l){var a;const o=t.state,s=[...l.files],i={open:!1,query:"",triggerPos:-1,selectedIndex:0},u=new AbortController,f=document.createElement("input");f.type="hidden",f.name=r;function c(){var $,q;const M=w.value,N=Zt(s,o),H=M?So(M,N):null,I=($=e.textKey)!=null?$:"text",ee=(q=e.filesKey)!=null?q:"files";return{[I]:M===""?null:H,[ee]:[...s]}}function m(){f.value=JSON.stringify(c())}const p=document.createElement("div");p.className="fb-richinput-wrapper",p.style.cssText=`
|
|
477
477
|
position: relative;
|
|
478
478
|
border: 1px solid var(--fb-border-color, #d1d5db);
|
|
479
479
|
border-radius: 16px;
|
|
480
480
|
background: var(--fb-background-color, #f9fafb);
|
|
481
481
|
transition: box-shadow 0.15s, border-color 0.15s;
|
|
482
|
-
`,p.addEventListener("focusin",()=>{p.style.borderColor="var(--fb-primary-color, #0066cc)",p.style.boxShadow="0 0 0 2px color-mix(in srgb, var(--fb-primary-color, #0066cc) 25%, transparent)"}),p.addEventListener("focusout",()=>{p.style.borderColor="var(--fb-border-color, #d1d5db)",p.style.boxShadow="none"});const h=document.createElement("div");h.className="fb-richinput-error",h.style.cssText="display: none; color: var(--fb-error-color, #ef4444); font-size: var(--fb-font-size-small, 12px); padding: 4px 14px 8px;";let v=null;function b($){h.textContent=$,h.style.display="block",v&&clearTimeout(v),v=setTimeout(()=>{h.style.display="none",h.textContent="",v=null},5e3)}function x($){var q;const M=
|
|
482
|
+
`,p.addEventListener("focusin",()=>{p.style.borderColor="var(--fb-primary-color, #0066cc)",p.style.boxShadow="0 0 0 2px color-mix(in srgb, var(--fb-primary-color, #0066cc) 25%, transparent)"}),p.addEventListener("focusout",()=>{p.style.borderColor="var(--fb-border-color, #d1d5db)",p.style.boxShadow="none"});const h=document.createElement("div");h.className="fb-richinput-error",h.style.cssText="display: none; color: var(--fb-error-color, #ef4444); font-size: var(--fb-font-size-small, 12px); padding: 4px 14px 8px;";let v=null;function b($){h.textContent=$,h.style.display="block",v&&clearTimeout(v),v=setTimeout(()=>{h.style.display="none",h.textContent="",v=null},5e3)}function x($){var q;const M=He(e.accept);if(!we($.name,M)){const H=M.join(", ");return b(k("invalidFileExtension",o,{name:$.name,formats:H})),!1}const N=(q=e.maxSize)!=null?q:1/0;return Le($,N)?!0:(b(k("fileTooLarge",o,{name:$.name,maxSize:N})),!1)}let d=0;p.addEventListener("dragenter",$=>{$.preventDefault(),d++,p.style.borderColor="var(--fb-primary-color, #0066cc)",p.style.boxShadow="0 0 0 2px color-mix(in srgb, var(--fb-primary-color, #0066cc) 25%, transparent)"}),p.addEventListener("dragover",$=>{$.preventDefault()}),p.addEventListener("dragleave",$=>{$.preventDefault(),d--,d<=0&&(d=0,p.style.borderColor="var(--fb-border-color, #d1d5db)",p.style.boxShadow="none")}),p.addEventListener("drop",$=>{var q,M;$.preventDefault(),d=0,p.style.borderColor="var(--fb-border-color, #d1d5db)",p.style.boxShadow="none";const N=(q=$.dataTransfer)==null?void 0:q.files;if(!N||!o.config.uploadFile)return;const H=(M=e.maxFiles)!=null?M:1/0;for(let I=0;I<N.length;I++){if(s.length>=H){b(k("filesLimitExceeded",o,{skipped:N.length-I,max:H}));break}x(N[I])&&Qe(N[I])}});const y=document.createElement("div");y.className="fb-richinput-files",y.style.cssText="display: none; flex-wrap: wrap; gap: 6px; padding: 10px 14px 0; align-items: center;";const g=document.createElement("input");g.type="file",g.multiple=!0,g.style.display="none",e.accept&&(typeof e.accept=="string"?g.accept=e.accept:g.accept=e.accept.extensions.map($=>$.startsWith(".")?$:`.${$}`).join(","));const E=document.createElement("div");E.style.cssText="position: relative;";const C=document.createElement("div");C.className="fb-richinput-backdrop",C.style.cssText=`
|
|
483
483
|
position: absolute;
|
|
484
484
|
top: 0; left: 0; right: 0; bottom: 0;
|
|
485
|
-
${
|
|
486
|
-
${
|
|
485
|
+
${sn}
|
|
486
|
+
${Xe}
|
|
487
487
|
white-space: pre-wrap;
|
|
488
488
|
word-break: break-word;
|
|
489
489
|
color: transparent;
|
|
@@ -492,10 +492,10 @@ var FormBuilder=(function(be){"use strict";function k(e,t,n){const r=t.config.lo
|
|
|
492
492
|
border-radius: inherit;
|
|
493
493
|
box-sizing: border-box;
|
|
494
494
|
z-index: 2;
|
|
495
|
-
`;const w=document.createElement("textarea");w.name=`${r}__text`,w.placeholder=e.placeholder||k("richinputPlaceholder",o);const S=(a=l.text)!=null?a:"";w.value=S?
|
|
495
|
+
`;const w=document.createElement("textarea");w.name=`${r}__text`,w.placeholder=e.placeholder||k("richinputPlaceholder",o);const S=(a=l.text)!=null?a:"";w.value=S?Qt(S,s,o):"",w.style.cssText=`
|
|
496
496
|
width: 100%;
|
|
497
|
-
${
|
|
498
|
-
${
|
|
497
|
+
${sn}
|
|
498
|
+
${Xe}
|
|
499
499
|
background: transparent;
|
|
500
500
|
border: none;
|
|
501
501
|
outline: none;
|
|
@@ -505,9 +505,9 @@ var FormBuilder=(function(be){"use strict";function k(e,t,n){const r=t.config.lo
|
|
|
505
505
|
position: relative;
|
|
506
506
|
z-index: 1;
|
|
507
507
|
caret-color: var(--fb-text-color, #111827);
|
|
508
|
-
|
|
509
|
-
`;return}let N="",H=0;for(const I of M){N+=
|
|
510
|
-
`}const
|
|
508
|
+
`,$o(w,C),w.addEventListener("scroll",()=>{C.scrollTop=w.scrollTop});let z=null;C.addEventListener("mouseover",$=>{var q,M;const N=(M=(q=$.target).closest)==null?void 0:M.call(q,"mark");N!=null&&N.dataset.rid&&(z=Fe(z),z=on(N,N.dataset.rid,o))}),C.addEventListener("mouseout",$=>{var q,M,N;if(!((M=(q=$.target).closest)!=null&&M.call(q,"mark")))return;const H=$.relatedTarget;(N=H==null?void 0:H.closest)!=null&&N.call(H,"mark")||(z=Fe(z))}),C.addEventListener("mousedown",$=>{var q,M;if(!((M=(q=$.target).closest)!=null&&M.call(q,"mark")))return;z=Fe(z);const N=C.querySelectorAll("mark");N.forEach(I=>I.style.pointerEvents="none");const H=document.elementFromPoint($.clientX,$.clientY);H&&H.dispatchEvent(new MouseEvent("mousedown",{bubbles:!0,cancelable:!0,view:window,clientX:$.clientX,clientY:$.clientY,button:$.button,buttons:$.buttons,detail:$.detail})),document.addEventListener("mouseup",()=>{N.forEach(I=>I.style.pointerEvents="auto")},{once:!0})});function Z(){const $=w.value,q=Zt(s,o),M=We($);if(M.length===0){C.innerHTML=J($)+`
|
|
509
|
+
`;return}let N="",H=0;for(const I of M){N+=J($.slice(H,I.start));const ee=q.get(I.name);ee?N+=`<mark data-rid="${J(ee)}" style="background: color-mix(in srgb, var(--fb-primary-color, #0066cc) 15%, transparent); color: transparent; border-radius: 8px; padding: 0; border: none; box-shadow: 0 0 0 2px color-mix(in srgb, var(--fb-primary-color, #0066cc) 15%, transparent), 0 0 0 3px color-mix(in srgb, var(--fb-primary-color, #0066cc) 30%, transparent); box-decoration-break: clone; -webkit-box-decoration-break: clone; pointer-events: auto; cursor: text;">${J($.slice(I.start,I.end))}</mark>`:N+=`<mark style="color: transparent; background: none; padding: 0; border: none; text-decoration-line: underline; text-decoration-style: wavy; text-decoration-color: rgba(239, 68, 68, 0.45); text-underline-offset: 2px;">${J($.slice(I.start,I.end))}</mark>`,H=I.end}N+=J($.slice(H)),C.innerHTML=N+`
|
|
510
|
+
`}const R=document.createElement("button");R.type="button",R.title=k("richinputAttachFile",o),R.style.cssText=`
|
|
511
511
|
position: absolute;
|
|
512
512
|
right: 10px;
|
|
513
513
|
bottom: 10px;
|
|
@@ -523,7 +523,7 @@ var FormBuilder=(function(be){"use strict";function k(e,t,n){const r=t.config.lo
|
|
|
523
523
|
justify-content: center;
|
|
524
524
|
color: var(--fb-text-muted-color, #9ca3af);
|
|
525
525
|
transition: color 0.15s, background 0.15s;
|
|
526
|
-
`,
|
|
526
|
+
`,R.innerHTML='<svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M21.44 11.05l-9.19 9.19a6 6 0 0 1-8.49-8.49l9.19-9.19a4 4 0 0 1 5.66 5.66l-9.2 9.19a2 2 0 0 1-2.83-2.83l8.49-8.48"/></svg>',R.addEventListener("mouseenter",()=>{R.style.color="var(--fb-primary-color, #0066cc)",R.style.background="var(--fb-background-hover-color, #f3f4f6)"}),R.addEventListener("mouseleave",()=>{R.style.color="var(--fb-text-muted-color, #9ca3af)",R.style.background="transparent"}),R.addEventListener("click",()=>{var $;const q=($=e.maxFiles)!=null?$:1/0;if(s.length>=q){b(k("filesLimitExceeded",o,{skipped:1,max:q}));return}g.click()});const _=document.createElement("div");_.className="fb-richinput-dropdown",_.style.cssText=`
|
|
527
527
|
display: none;
|
|
528
528
|
position: absolute;
|
|
529
529
|
bottom: 100%;
|
|
@@ -538,8 +538,8 @@ var FormBuilder=(function(be){"use strict";function k(e,t,n){const r=t.config.lo
|
|
|
538
538
|
max-height: 200px;
|
|
539
539
|
overflow-y: auto;
|
|
540
540
|
margin-bottom: 4px;
|
|
541
|
-
${
|
|
542
|
-
`;function
|
|
541
|
+
${Xe}
|
|
542
|
+
`;function fe(){return mt(s,o)}function Ee($){pe(_);const q=fe();if($.length===0){_.style.display="none",i.open=!1;return}$.forEach((M,N)=>{var H;const I=o.resourceIndex.get(M),ee=document.createElement("div");ee.className="fb-richinput-dropdown-item",ee.dataset.rid=M,ee.style.cssText=`
|
|
543
543
|
padding: 5px 10px;
|
|
544
544
|
cursor: pointer;
|
|
545
545
|
color: var(--fb-text-color, #111827);
|
|
@@ -547,7 +547,7 @@ var FormBuilder=(function(be){"use strict";function k(e,t,n){const r=t.config.lo
|
|
|
547
547
|
display: flex;
|
|
548
548
|
align-items: center;
|
|
549
549
|
gap: 8px;
|
|
550
|
-
`;const
|
|
550
|
+
`;const te=document.createElement("div");if(te.style.cssText="width: 24px; height: 24px; border-radius: 4px; overflow: hidden; flex-shrink: 0; background: var(--fb-background-hover-color, #f3f4f6); display: flex; align-items: center; justify-content: center;",I!=null&&I.file&&ht(I)){const oe=document.createElement("img");oe.style.cssText="width: 100%; height: 100%; object-fit: cover; display: block;";const ce=new FileReader;ce.onload=A=>{var T;oe.src=((T=A.target)==null?void 0:T.result)||""},ce.readAsDataURL(I.file),te.appendChild(oe)}else o.config.getThumbnail&&o.config.getThumbnail(M).then(oe=>{if(!oe||!te.isConnected)return;const ce=document.createElement("img");ce.style.cssText="width: 100%; height: 100%; object-fit: cover; display: block;",ce.src=oe,pe(te),te.appendChild(ce)}).catch(()=>{}),te.innerHTML='<svg width="14" height="14" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><path d="M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8z"/><polyline points="14 2 14 8 20 8"/></svg>';ee.appendChild(te);const re=document.createElement("span");re.style.cssText="overflow: hidden; text-overflow: ellipsis; white-space: nowrap;",re.textContent=(H=q.get(M))!=null?H:M,ee.appendChild(re),_.appendChild(ee)}),_.onmousemove=M=>{var N,H,I;const ee=(H=(N=M.target).closest)==null?void 0:H.call(N,".fb-richinput-dropdown-item");if(!ee)return;const te=$.indexOf((I=ee.dataset.rid)!=null?I:"");te===-1||te===i.selectedIndex||(_.querySelectorAll(".fb-richinput-dropdown-item").forEach((re,oe)=>{re.style.background=oe===te?"var(--fb-background-hover-color, #f3f4f6)":"transparent"}),i.selectedIndex=te)},_.onmousedown=M=>{var N,H;M.preventDefault(),M.stopPropagation();const I=(H=(N=M.target).closest)==null?void 0:H.call(N,".fb-richinput-dropdown-item");I!=null&&I.dataset.rid&&Me(I.dataset.rid)},_.style.display="block",i.open=!0}function Ne(){const $=To(w);if(!$){me();return}i.query=$.query,i.triggerPos=$.pos,i.selectedIndex=0;const q=fe(),M=an($.query,s,q);Ee(M)}function me(){_.style.display="none",i.open=!1}function Me($){var q,M,N,H;const I=(N=(M=fe().get($))!=null?M:(q=o.resourceIndex.get($))==null?void 0:q.name)!=null?N:$,ee=(H=w.selectionStart)!=null?H:0,te=w.value.slice(0,i.triggerPos),re=w.value.slice(ee),oe=`${vt(I)} `;w.value=`${te}${oe}${re}`;const ce=te.length+oe.length;w.setSelectionRange(ce,ce),w.dispatchEvent(new Event("input")),me()}w.addEventListener("input",()=>{var $;Z(),m(),($=t.instance)==null||$.triggerOnChange(r,c()),s.length>0?Ne():me()});function Be(){_.querySelectorAll(".fb-richinput-dropdown-item").forEach(($,q)=>{$.style.background=q===i.selectedIndex?"var(--fb-background-hover-color, #f3f4f6)":"transparent"})}w.addEventListener("keydown",$=>{if(!i.open)return;const q=fe(),M=an(i.query,s,q);$.key==="ArrowDown"?($.preventDefault(),i.selectedIndex=Math.min(i.selectedIndex+1,M.length-1),Be()):$.key==="ArrowUp"?($.preventDefault(),i.selectedIndex=Math.max(i.selectedIndex-1,0),Be()):$.key==="Enter"&&M.length>0?($.preventDefault(),Me(M[i.selectedIndex])):$.key==="Escape"&&me()}),document.addEventListener("click",$=>{!p.contains($.target)&&!_.contains($.target)&&me()},{signal:u.signal});function be(){if(pe(y),s.length===0){y.style.display="none";return}y.style.display="flex",s.forEach($=>{const q=o.resourceIndex.get($),M=document.createElement("div");M.className="fb-richinput-file-thumb",M.style.cssText=`
|
|
551
551
|
position: relative;
|
|
552
552
|
width: 48px;
|
|
553
553
|
height: 48px;
|
|
@@ -557,14 +557,14 @@ var FormBuilder=(function(be){"use strict";function k(e,t,n){const r=t.config.lo
|
|
|
557
557
|
flex-shrink: 0;
|
|
558
558
|
cursor: pointer;
|
|
559
559
|
background: #fff;
|
|
560
|
-
`;const N=document.createElement("div");N.style.cssText="width: 48px; height: 48px; border-radius: inherit; overflow: hidden;",
|
|
561
|
-
`:""}${
|
|
560
|
+
`;const N=document.createElement("div");N.style.cssText="width: 48px; height: 48px; border-radius: inherit; overflow: hidden;",en(N,$,q,o),M.appendChild(N);const H=ln(),I=()=>{var te,re,oe;const ce=(te=w.selectionStart)!=null?te:w.value.length,A=(oe=(re=fe().get($))!=null?re:q==null?void 0:q.name)!=null?oe:$,T=w.value.slice(0,ce),L=w.value.slice(ce),B=`${T.length>0&&!/[\s\n]$/.test(T)?`
|
|
561
|
+
`:""}${vt(A)} `;w.value=`${T}${B}${L}`;const D=ce+B.length;w.setSelectionRange(D,D),w.focus(),w.dispatchEvent(new Event("input"))},ee=()=>{var te;const re=s.indexOf($);re!==-1&&s.splice(re,1),be(),Z(),m(),(te=t.instance)==null||te.triggerOnChange(r,c())};M.addEventListener("mouseenter",()=>{Ye(H),H.element||(H.element=rn(M,{rid:$,state:o,isReadonly:!1,onMention:I,onRemove:ee}),H.element.addEventListener("mouseenter",()=>{Ye(H)}),H.element.addEventListener("mouseleave",()=>{Je(H)}))}),M.addEventListener("mouseleave",()=>{Je(H)}),y.appendChild(M)})}function Qe($){if(!o.config.uploadFile)return;const q=`temp-${Date.now()}-${Math.random().toString(36).slice(2,6)}`;o.resourceIndex.set(q,{name:$.name,type:$.type,size:$.size,uploadedAt:new Date,file:$}),s.push(q),be();const M=y.querySelectorAll(".fb-richinput-file-thumb"),N=M[M.length-1];N&&(N.style.opacity="0.5"),o.config.uploadFile($).then(H=>{var I;const ee=s.indexOf(q);ee!==-1&&(s[ee]=H),o.resourceIndex.delete(q),o.resourceIndex.set(H,{name:$.name,type:$.type,size:$.size,uploadedAt:new Date,file:$}),be(),Z(),m(),(I=t.instance)==null||I.triggerOnChange(r,c())}).catch(H=>{var I,ee;const te=s.indexOf(q);te!==-1&&s.splice(te,1),o.resourceIndex.delete(q),be(),(ee=(I=o.config).onUploadError)==null||ee.call(I,H,$)})}if(g.addEventListener("change",()=>{var $;const q=g.files;if(!q||q.length===0)return;const M=($=e.maxFiles)!=null?$:1/0;for(let N=0;N<q.length;N++){if(s.length>=M){b(k("filesLimitExceeded",o,{skipped:q.length-N,max:M}));break}x(q[N])&&Qe(q[N])}g.value=""}),E.appendChild(C),E.appendChild(w),E.appendChild(R),E.appendChild(_),p.appendChild(y),p.appendChild(E),p.appendChild(h),e.minLength!=null||e.maxLength!=null){const $=document.createElement("div");$.style.cssText="position: relative; padding: 2px 14px 6px; text-align: right;";const q=ze(e,w,!1);q.style.cssText=`
|
|
562
562
|
position: static;
|
|
563
563
|
display: inline-block;
|
|
564
564
|
font-size: var(--fb-font-size-small);
|
|
565
565
|
color: var(--fb-text-secondary-color);
|
|
566
566
|
pointer-events: none;
|
|
567
|
-
`,$.appendChild(q),p.appendChild($)}p.appendChild(f),p.appendChild(g),m(),
|
|
567
|
+
`,$.appendChild(q),p.appendChild($)}p.appendChild(f),p.appendChild(g),m(),Z(),f._applyExternalUpdate=$=>{var q;const M=(q=$.text)!=null?q:"";w.value=M?Qt(M,s,o):"",w.dispatchEvent(new Event("input")),s.length=0;for(const N of $.files)s.push(N);be(),Z(),m()},n.appendChild(p),be();const Re=new MutationObserver(()=>{p.isConnected||(u.abort(),z=Fe(z),Re.disconnect())});p.parentElement&&Re.observe(p.parentElement,{childList:!0})}function Fo(e,t,n,r,l){var a,o;const s=t.state,{text:i,files:u}=l,f=new Map;for(const c of u){const m=s.resourceIndex.get(c);m!=null&&m.name&&f.set(c,m.name)}if(u.length>0){const c=document.createElement("div");c.style.cssText="display: flex; flex-wrap: wrap; gap: 6px; padding-bottom: 8px;",u.forEach(m=>{const p=s.resourceIndex.get(m),h=document.createElement("div");h.style.cssText=`
|
|
568
568
|
position: relative;
|
|
569
569
|
width: 48px; height: 48px;
|
|
570
570
|
border: 1px solid var(--fb-border-color, #d1d5db);
|
|
@@ -573,12 +573,12 @@ var FormBuilder=(function(be){"use strict";function k(e,t,n){const r=t.config.lo
|
|
|
573
573
|
flex-shrink: 0;
|
|
574
574
|
background: #fff;
|
|
575
575
|
cursor: default;
|
|
576
|
-
`;const v=document.createElement("div");v.style.cssText="width: 48px; height: 48px; border-radius: inherit; overflow: hidden;",
|
|
577
|
-
${
|
|
576
|
+
`;const v=document.createElement("div");v.style.cssText="width: 48px; height: 48px; border-radius: inherit; overflow: hidden;",en(v,m,p,s),h.appendChild(v);const b=ln();h.addEventListener("mouseenter",()=>{Ye(b),b.element||(b.element=rn(h,{rid:m,state:s,isReadonly:!0}),b.element.addEventListener("mouseenter",()=>{Ye(b)}),b.element.addEventListener("mouseleave",()=>{Je(b)}))}),h.addEventListener("mouseleave",()=>{Je(b)}),c.appendChild(h)}),n.appendChild(c)}if(i){const c=document.createElement("div");c.style.cssText=`
|
|
577
|
+
${Xe}
|
|
578
578
|
color: var(--fb-text-color, #111827);
|
|
579
579
|
white-space: pre-wrap;
|
|
580
580
|
word-break: break-word;
|
|
581
|
-
`;const m=
|
|
581
|
+
`;const m=We(i).filter(p=>f.has(p.name)||[...f.values()].includes(p.name));if(m.length===0)c.textContent=i;else{let p=0;for(const h of m){h.start>p&&c.appendChild(document.createTextNode(i.slice(p,h.start)));const v=document.createElement("span");v.style.cssText=`
|
|
582
582
|
display: inline;
|
|
583
583
|
background: color-mix(in srgb, var(--fb-primary-color, #0066cc) 15%, transparent);
|
|
584
584
|
color: var(--fb-primary-color, #0066cc);
|
|
@@ -586,12 +586,12 @@ var FormBuilder=(function(be){"use strict";function k(e,t,n){const r=t.config.lo
|
|
|
586
586
|
padding: 1px 6px;
|
|
587
587
|
font-weight: 500;
|
|
588
588
|
cursor: default;
|
|
589
|
-
`;const b=f.has(h.name)?h.name:(a=[...f.entries()].find(([,d])=>d===h.name))==null?void 0:a[0],x=(o=f.get(h.name))!=null?o:h.name;if(v.textContent=`@${x}`,b){let d=null;const y=b;v.addEventListener("mouseenter",()=>{d=Ae(d),d=en(v,y,c)}),v.addEventListener("mouseleave",()=>{d=Ae(d)})}s.appendChild(v),p=h.end}p<i.length&&s.appendChild(document.createTextNode(i.slice(p)))}n.appendChild(s)}if(!i&&u.length===0){const s=document.createElement("div");s.style.cssText="color: var(--fb-text-muted-color, #6b7280); font-size: var(--fb-font-size, 14px);",s.textContent="\u2014",n.appendChild(s)}}function To(e,t,n,r){var l,a,o,c;const i=t.state,u=(l=e.textKey)!=null?l:"text",f=(a=e.filesKey)!=null?a:"files";let s;if(e.flatOutput){const m=t.prefill[u],p=t.prefill[f];s={text:typeof m=="string"?m:null,files:Array.isArray(p)?p:[]}}else{const m=t.prefill[e.key];if(m&&typeof m=="object"&&!Array.isArray(m)){const p=m,h=(o=p[u])!=null?o:p.text,v=(c=p[f])!=null?c:p.files;s={text:typeof h=="string"?h:null,files:Array.isArray(v)?v:[]}}else typeof m=="string"?s={text:m||null,files:[]}:s={text:null,files:[]}}for(const m of s.files)i.resourceIndex.has(m)||i.resourceIndex.set(m,{name:m,type:"application/octet-stream",size:0,uploadedAt:new Date,file:void 0});if(i.config.readonly)So(e,t,n,r,s);else{if(!i.config.uploadFile)throw new Error(`RichInput field "${e.key}" requires uploadFile handler in config`);Lo(e,t,n,r,s)}}function Ao(e,t,n){var r,l;const{scopeRoot:a,state:o,skipValidation:c}=n,i=[],u=(r=e.textKey)!=null?r:"text",f=(l=e.filesKey)!=null?l:"files",s=a.querySelector(`[name="${t}"]`);if(!s)return{value:null,errors:i};let m={};try{const d=JSON.parse(s.value);if(d&&typeof d=="object"&&!Array.isArray(d))m=d;else return i.push(`${t}: invalid richinput data`),{value:null,errors:i}}catch(d){return i.push(`${t}: invalid richinput data`),{value:null,errors:i}}const p=m[u],h=m[f],v=p===null||typeof p=="string"?p:null,b=Array.isArray(h)?h:[],x={[u]:v!=null?v:null,[f]:b};if(!c){const d=!v||v.trim()==="",y=b.length===0;e.required&&d&&y&&i.push(`${t}: ${k("required",o)}`),!d&&v&&(e.minLength!=null&&v.length<e.minLength&&i.push(`${t}: ${k("minLength",o,{min:e.minLength})}`),e.maxLength!=null&&v.length>e.maxLength&&i.push(`${t}: ${k("maxLength",o,{max:e.maxLength})}`)),e.maxFiles!=null&&b.length>e.maxFiles&&i.push(`${t}: ${k("maxFiles",o,{max:e.maxFiles})}`)}return{value:x,errors:i,spread:!!e.flatOutput}}function Fo(e,t,n,r){var l,a,o,c;const{scopeRoot:i}=r,u=i.querySelector(`[name="${t}"]`);if(!u){console.warn(`updateRichInputField: no hidden input found for "${t}". Re-render to reflect new data.`);return}let f=null;if(n&&typeof n=="object"&&!Array.isArray(n)){const s=n,m=(l=e.textKey)!=null?l:"text",p=(a=e.filesKey)!=null?a:"files",h=(o=s[m])!=null?o:s.text,v=(c=s[p])!=null?c:s.files;(h!==void 0||v!==void 0)&&(f={text:typeof h=="string"?h:null,files:Array.isArray(v)?v:[]})}f&&u._applyExternalUpdate?u._applyExternalUpdate(f):f&&(u.value=JSON.stringify(f))}function No(e,t){const n=document.getElementById(e);if(!n)return;const r=!n.classList.contains("hidden");if(document.querySelectorAll('[id^="tooltip-"]').forEach(f=>{f.classList.add("hidden")}),r)return;const l=t.getBoundingClientRect(),a=window.innerWidth,o=window.innerHeight;n&&n.parentElement!==document.body&&document.body.appendChild(n),n.style.visibility="hidden",n.style.position="fixed",n.classList.remove("hidden");const c=n.getBoundingClientRect();n.classList.add("hidden"),n.style.visibility="visible";let i=l.left,u=l.bottom+5;i+c.width>a&&(i=l.right-c.width),u+c.height>o&&(u=l.top-c.height-5),i<10&&(i=10),u<10&&(u=l.bottom+5),n.style.left=`${i}px`,n.style.top=`${u}px`,n.classList.remove("hidden"),setTimeout(()=>{n.classList.add("hidden")},25e3)}typeof document!="undefined"&&document.addEventListener("click",e=>{const t=e.target,n=t.closest("button")&&t.closest("button").onclick,r=t.closest('[id^="tooltip-"]');!n&&!r&&document.querySelectorAll('[id^="tooltip-"]').forEach(l=>{l.classList.add("hidden")})});function Mo(e,t){var n,r,l;if(!e.enableIf)return!1;try{const a=(r=(n=t.formData)!=null?n:t.prefill)!=null?r:{},o=((l=e.enableIf.scope)!=null?l:"relative")==="relative"&&t.path?t.prefill:void 0;return!ke(e.enableIf,a,o)}catch(a){console.error(`Error evaluating enableIf for field "${e.key}":`,a)}return!1}function qo(e,t){const n=t.querySelector(`[name="${e}"]`);if(n){if(n instanceof HTMLSelectElement)return n.value;if(n instanceof HTMLInputElement){if(n.type==="checkbox")return n.checked;if(n.type==="radio"){const r=t.querySelector(`[name="${e}"]:checked`);return r?r.value:void 0}else return n.value}else if(n instanceof HTMLTextAreaElement)return n.value}}function Ye(e,t,n){var r,l;if(!t.enableIf)return;const a=n.state.formRoot;if(!a){console.error("Cannot re-evaluate enableIf: formRoot is null");return}const o=t.enableIf,c=(r=o.scope)!=null?r:"relative";let i={};const u={};if((!n.path||n.path===""?"absolute":c)==="relative"&&n.path){const f=n.path.match(/^(.+)\[(\d+)\]$/);if(f){const s=f[1],m=parseInt(f[2],10),p=a.querySelector(`[data-container-item="${s}[${m}]"]`);p&&p.querySelectorAll("input, select, textarea").forEach(h=>{const v=h.getAttribute("name");if(v){const b=v.match(/\.([^.[\]]+)$/);if(b){const x=b[1];h instanceof HTMLSelectElement?u[x]=h.value:h instanceof HTMLInputElement?h.type==="checkbox"?u[x]=h.checked:h.type==="radio"?h.checked&&(u[x]=h.value):u[x]=h.value:h instanceof HTMLTextAreaElement&&(u[x]=h.value)}}})}}else{const f=o.key,s=qo(f,a);s!==void 0?i[f]=s:i=(l=n.formData)!=null?l:n.prefill}try{ke(o,i,u)?(e.style.display="",e.classList.remove("fb-field-wrapper-disabled"),e.removeAttribute("data-conditionally-disabled")):(e.style.display="none",e.classList.add("fb-field-wrapper-disabled"),e.setAttribute("data-conditionally-disabled","true"))}catch(f){console.error(`Error re-evaluating enableIf for field "${t.key}":`,f)}}function zo(e,t,n){var r;if(!t.enableIf)return;const l=n.state.formRoot;if(!l){console.error("Cannot setup enableIf listeners: formRoot is null");return}const a=t.enableIf,o=(r=a.scope)!=null?r:"relative",c=a.key;let i;o==="relative"&&n.path?i=`${n.path}.${c}`:i=c;const u=l.querySelector(`[name="${i}"]`);if(!u){const f=new MutationObserver(()=>{const s=l.querySelector(`[name="${i}"]`);s&&(s.addEventListener("change",()=>{Ye(e,t,n)}),s.addEventListener("input",()=>{Ye(e,t,n)}),f.disconnect())});f.observe(l,{childList:!0,subtree:!0});return}u.addEventListener("change",()=>{Ye(e,t,n)}),u.addEventListener("input",()=>{Ye(e,t,n)})}function Ho(e){const t=document.createElement("label");if(t.className="text-sm font-medium text-gray-900",t.textContent=e.label||e.key,e.required){const n=document.createElement("span");n.className="text-red-500 ml-1",n.textContent="*",t.appendChild(n)}return t}function Io(e){const t=document.createElement("button");t.type="button",t.className="ml-2 text-gray-400 hover:text-gray-600",t.innerHTML='<svg class="w-4 h-4" fill="currentColor" viewBox="0 0 24 24"><path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm1 15h-2v-6h2v6zm0-8h-2V7h2v2z"/></svg>';const n=`tooltip-${e.key}-${Math.random().toString(36).substr(2,9)}`,r=document.createElement("div");return r.id=n,r.className="hidden absolute z-50 bg-gray-200 text-gray-900 text-sm rounded-lg p-3 max-w-sm border border-gray-300 shadow-lg",r.style.position="fixed",r.textContent=e.description||e.hint||"Field information",document.body.appendChild(r),t.onclick=l=>{l.preventDefault(),l.stopPropagation(),No(n,t)},t}function Bo(e){const t=document.createElement("div");t.className="flex items-center mb-2";const n=Ho(e);if(t.appendChild(n),e.description||e.hint){const r=Io(e);t.appendChild(r)}return t}function Ro(e,t,n,r){const l="multiple"in e&&e.multiple;switch(e.type){case"text":l?gn(e,t,n,r):vn(e,t,n,r);break;case"textarea":l?yn(e,t,n,r):bn(e,t,n,r);break;case"number":l?wn(e,t,n,r):Cn(e,t,n,r);break;case"select":l?Sn(e,t,n,r):Ln(e,t,n,r);break;case"switcher":l?Nn(e,t,n,r):Fn(e,t,n,r);break;case"file":l?Yn(e,t,n,r):Wn(e,t,n,r);break;case"files":Jn(e,t,n,r);break;case"colour":l?Gn(e,t,n,r):Xn(e,t,n,r);break;case"slider":l?to(e,t,n,r):eo(e,t,n,r);break;case"group":ao(e,t,n,r);break;case"container":l?Ut(e,t,n):Ot(e,t,n,r);break;case"table":yo(e,t,n,r);break;case"richinput":To(e,t,n,r);break;default:{const a=document.createElement("div");a.className="text-red-500 text-sm",a.textContent=k("unsupportedFieldType",t.state,{type:e.type}),n.appendChild(a)}}}function vt(e,t){const n=Mo(e,t),r=document.createElement("div");r.className="mb-6 fb-field-wrapper",r.setAttribute("data-field-key",e.key);const l=Bo(e);r.appendChild(l);const a=we(t.path,e.key);return Ro(e,t,r,a),n&&(r.style.display="none",r.classList.add("fb-field-wrapper-disabled"),r.setAttribute("data-conditionally-disabled","true")),zo(r,e,t),r}ro(vt);const gt={uploadFile:null,downloadFile:null,getThumbnail:null,getDownloadUrl:null,actionHandler:null,onChange:null,onFieldChange:null,onThumbnailError:null,onUploadError:null,onDownloadError:null,debounceMs:300,verboseErrors:!1,enableFilePreview:!0,maxPreviewSize:"200px",readonly:!1,parseTableFile:null,locale:"en",translations:{en:{removeElement:"Remove",clickDragText:"Click or drag file",clickDragTextMultiple:"Click or drag files",noFileSelected:"No file selected",noFilesSelected:"No files selected",downloadButton:"Download",changeButton:"Change",placeholderText:"Enter text",previewAlt:"Preview",previewUnavailable:"Preview unavailable",previewError:"Preview error",videoNotSupported:"Your browser does not support the video tag.",hintLengthRange:"{min}-{max} chars",hintMaxLength:"\u2264{max} chars",hintMinLength:"\u2265{min} chars",hintValueRange:"{min}-{max}",hintMaxValue:"\u2264{max}",hintMinValue:"\u2265{min}",hintMaxSize:"\u2264{size}MB",hintFormats:"{formats}",hintRequired:"Required",hintOptional:"Optional",hintPattern:"Format: {pattern}",fileCountSingle:"{count} file",fileCountPlural:"{count} files",fileCountRange:"({min}-{max})",required:"Required",minItems:"Minimum {min} items required",maxItems:"Maximum {max} items allowed",minLength:"Minimum {min} characters",maxLength:"Maximum {max} characters",minValue:"Must be at least {min}",maxValue:"Must be at most {max}",patternMismatch:"Invalid format",invalidPattern:"Invalid pattern in schema",notANumber:"Must be a number",invalidHexColour:"Invalid hex color",minFiles:"Minimum {min} files required",maxFiles:"Maximum {max} files allowed",invalidFileExtension:'File "{name}" has unsupported format. Allowed: {formats}',fileTooLarge:'File "{name}" exceeds maximum size of {maxSize}MB',filesLimitExceeded:"{skipped} file(s) skipped: maximum {max} files allowed",unsupportedFieldType:"Unsupported field type: {type}",invalidOption:"Invalid option",tableAddRow:"Add row",tableAddColumn:"Add column",tableRemoveRow:"Remove row",tableRemoveColumn:"Remove column",tableMergeCells:"Merge cells (Ctrl+M)",tableSplitCell:"Split cell (Ctrl+Shift+M)",tableImportFile:"Import",tableImporting:"Importing...",tableImportError:"Import failed: {error}",richinputPlaceholder:"Type text...",richinputAttachFile:"Attach file",richinputMention:"Mention",richinputRemoveFile:"Remove"},ru:{removeElement:"\u0423\u0434\u0430\u043B\u0438\u0442\u044C",clickDragText:"\u041D\u0430\u0436\u043C\u0438\u0442\u0435 \u0438\u043B\u0438 \u043F\u0435\u0440\u0435\u0442\u0430\u0449\u0438\u0442\u0435 \u0444\u0430\u0439\u043B",clickDragTextMultiple:"\u041D\u0430\u0436\u043C\u0438\u0442\u0435 \u0438\u043B\u0438 \u043F\u0435\u0440\u0435\u0442\u0430\u0449\u0438\u0442\u0435 \u0444\u0430\u0439\u043B\u044B",noFileSelected:"\u0424\u0430\u0439\u043B \u043D\u0435 \u0432\u044B\u0431\u0440\u0430\u043D",noFilesSelected:"\u041D\u0435\u0442 \u0444\u0430\u0439\u043B\u043E\u0432",downloadButton:"\u0421\u043A\u0430\u0447\u0430\u0442\u044C",changeButton:"\u0418\u0437\u043C\u0435\u043D\u0438\u0442\u044C",placeholderText:"\u0412\u0432\u0435\u0434\u0438\u0442\u0435 \u0442\u0435\u043A\u0441\u0442",previewAlt:"\u041F\u0440\u0435\u0434\u043F\u0440\u043E\u0441\u043C\u043E\u0442\u0440",previewUnavailable:"\u041F\u0440\u0435\u0434\u043F\u0440\u043E\u0441\u043C\u043E\u0442\u0440 \u043D\u0435\u0434\u043E\u0441\u0442\u0443\u043F\u0435\u043D",previewError:"\u041E\u0448\u0438\u0431\u043A\u0430 \u043F\u0440\u0435\u0434\u043F\u0440\u043E\u0441\u043C\u043E\u0442\u0440\u0430",videoNotSupported:"\u0412\u0430\u0448 \u0431\u0440\u0430\u0443\u0437\u0435\u0440 \u043D\u0435 \u043F\u043E\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u0435\u0442 \u0432\u0438\u0434\u0435\u043E.",hintLengthRange:"{min}-{max} \u0441\u0438\u043C\u0432\u043E\u043B\u043E\u0432",hintMaxLength:"\u2264{max} \u0441\u0438\u043C\u0432\u043E\u043B\u043E\u0432",hintMinLength:"\u2265{min} \u0441\u0438\u043C\u0432\u043E\u043B\u043E\u0432",hintValueRange:"{min}-{max}",hintMaxValue:"\u2264{max}",hintMinValue:"\u2265{min}",hintMaxSize:"\u2264{size}\u041C\u0411",hintFormats:"{formats}",hintRequired:"\u041E\u0431\u044F\u0437\u0430\u0442\u0435\u043B\u044C\u043D\u043E\u0435",hintOptional:"\u041D\u0435\u043E\u0431\u044F\u0437\u0430\u0442\u0435\u043B\u044C\u043D\u043E\u0435",hintPattern:"\u0424\u043E\u0440\u043C\u0430\u0442: {pattern}",fileCountSingle:"{count} \u0444\u0430\u0439\u043B",fileCountPlural:"{count} \u0444\u0430\u0439\u043B\u043E\u0432",fileCountRange:"({min}-{max})",required:"\u041E\u0431\u044F\u0437\u0430\u0442\u0435\u043B\u044C\u043D\u043E\u0435 \u043F\u043E\u043B\u0435",minItems:"\u041C\u0438\u043D\u0438\u043C\u0443\u043C {min} \u044D\u043B\u0435\u043C\u0435\u043D\u0442\u043E\u0432",maxItems:"\u041C\u0430\u043A\u0441\u0438\u043C\u0443\u043C {max} \u044D\u043B\u0435\u043C\u0435\u043D\u0442\u043E\u0432",minLength:"\u041C\u0438\u043D\u0438\u043C\u0443\u043C {min} \u0441\u0438\u043C\u0432\u043E\u043B\u043E\u0432",maxLength:"\u041C\u0430\u043A\u0441\u0438\u043C\u0443\u043C {max} \u0441\u0438\u043C\u0432\u043E\u043B\u043E\u0432",minValue:"\u0417\u043D\u0430\u0447\u0435\u043D\u0438\u0435 \u0434\u043E\u043B\u0436\u043D\u043E \u0431\u044B\u0442\u044C \u043D\u0435 \u043C\u0435\u043D\u0435\u0435 {min}",maxValue:"\u0417\u043D\u0430\u0447\u0435\u043D\u0438\u0435 \u0434\u043E\u043B\u0436\u043D\u043E \u0431\u044B\u0442\u044C \u043D\u0435 \u0431\u043E\u043B\u0435\u0435 {max}",patternMismatch:"\u041D\u0435\u0432\u0435\u0440\u043D\u044B\u0439 \u0444\u043E\u0440\u043C\u0430\u0442",invalidPattern:"\u041D\u0435\u0432\u0435\u0440\u043D\u044B\u0439 \u043F\u0430\u0442\u0442\u0435\u0440\u043D \u0432 \u0441\u0445\u0435\u043C\u0435",notANumber:"\u0414\u043E\u043B\u0436\u043D\u043E \u0431\u044B\u0442\u044C \u0447\u0438\u0441\u043B\u043E\u043C",invalidHexColour:"\u041D\u0435\u0432\u0435\u0440\u043D\u044B\u0439 \u0444\u043E\u0440\u043C\u0430\u0442 \u0446\u0432\u0435\u0442\u0430",minFiles:"\u041C\u0438\u043D\u0438\u043C\u0443\u043C {min} \u0444\u0430\u0439\u043B\u043E\u0432",maxFiles:"\u041C\u0430\u043A\u0441\u0438\u043C\u0443\u043C {max} \u0444\u0430\u0439\u043B\u043E\u0432",invalidFileExtension:'\u0424\u0430\u0439\u043B "{name}" \u0438\u043C\u0435\u0435\u0442 \u043D\u0435\u043F\u043E\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u0435\u043C\u044B\u0439 \u0444\u043E\u0440\u043C\u0430\u0442. \u0414\u043E\u043F\u0443\u0441\u0442\u0438\u043C\u044B\u0435: {formats}',fileTooLarge:'\u0424\u0430\u0439\u043B "{name}" \u043F\u0440\u0435\u0432\u044B\u0448\u0430\u0435\u0442 \u043C\u0430\u043A\u0441\u0438\u043C\u0430\u043B\u044C\u043D\u044B\u0439 \u0440\u0430\u0437\u043C\u0435\u0440 {maxSize}\u041C\u0411',filesLimitExceeded:"{skipped} \u0444\u0430\u0439\u043B(\u043E\u0432) \u043F\u0440\u043E\u043F\u0443\u0449\u0435\u043D\u043E: \u043C\u0430\u043A\u0441\u0438\u043C\u0443\u043C {max} \u0444\u0430\u0439\u043B\u043E\u0432",unsupportedFieldType:"\u041D\u0435\u043F\u043E\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u0435\u043C\u044B\u0439 \u0442\u0438\u043F \u043F\u043E\u043B\u044F: {type}",invalidOption:"\u041D\u0435\u0434\u043E\u043F\u0443\u0441\u0442\u0438\u043C\u043E\u0435 \u0437\u043D\u0430\u0447\u0435\u043D\u0438\u0435",tableAddRow:"\u0414\u043E\u0431\u0430\u0432\u0438\u0442\u044C \u0441\u0442\u0440\u043E\u043A\u0443",tableAddColumn:"\u0414\u043E\u0431\u0430\u0432\u0438\u0442\u044C \u0441\u0442\u043E\u043B\u0431\u0435\u0446",tableRemoveRow:"\u0423\u0434\u0430\u043B\u0438\u0442\u044C \u0441\u0442\u0440\u043E\u043A\u0443",tableRemoveColumn:"\u0423\u0434\u0430\u043B\u0438\u0442\u044C \u0441\u0442\u043E\u043B\u0431\u0435\u0446",tableMergeCells:"\u041E\u0431\u044A\u0435\u0434\u0438\u043D\u0438\u0442\u044C \u044F\u0447\u0435\u0439\u043A\u0438 (Ctrl+M)",tableSplitCell:"\u0420\u0430\u0437\u0434\u0435\u043B\u0438\u0442\u044C \u044F\u0447\u0435\u0439\u043A\u0443 (Ctrl+Shift+M)",tableImportFile:"\u0418\u043C\u043F\u043E\u0440\u0442",tableImporting:"\u0418\u043C\u043F\u043E\u0440\u0442...",tableImportError:"\u041E\u0448\u0438\u0431\u043A\u0430 \u0438\u043C\u043F\u043E\u0440\u0442\u0430: {error}",richinputPlaceholder:"\u0412\u0432\u0435\u0434\u0438\u0442\u0435 \u0442\u0435\u043A\u0441\u0442...",richinputAttachFile:"\u041F\u0440\u0438\u043A\u0440\u0435\u043F\u0438\u0442\u044C \u0444\u0430\u0439\u043B",richinputMention:"\u0423\u043F\u043E\u043C\u044F\u043D\u0443\u0442\u044C",richinputRemoveFile:"\u0423\u0434\u0430\u043B\u0438\u0442\u044C"}},theme:{}};function Do(e){const t={...gt.translations};if(e!=null&&e.translations)for(const[n,r]of Object.entries(e.translations))t[n]={...gt.translations[n]||{},...r};return{schema:null,formRoot:null,resourceIndex:new Map,externalActions:null,version:"1.0.0",config:{...gt,...e,translations:t},debounceTimer:null}}function jo(){const e=Date.now().toString(36),t=Math.random().toString(36).substring(2,9);return`inst-${e}-${t}`}const qe={primaryColor:"#3b82f6",primaryHoverColor:"#2563eb",errorColor:"#ef4444",errorHoverColor:"#dc2626",successColor:"#10b981",borderColor:"#d1d5db",borderHoverColor:"#9ca3af",borderFocusColor:"#3b82f6",backgroundColor:"#ffffff",backgroundHoverColor:"#f9fafb",backgroundReadonlyColor:"#f3f4f6",textColor:"#1f2937",textSecondaryColor:"#6b7280",textPlaceholderColor:"#9ca3af",textDisabledColor:"#d1d5db",buttonBgColor:"#3b82f6",buttonTextColor:"#ffffff",buttonBorderColor:"#2563eb",buttonHoverBgColor:"#2563eb",buttonHoverBorderColor:"#1d4ed8",actionBgColor:"#ffffff",actionTextColor:"#374151",actionBorderColor:"#e5e7eb",actionHoverBgColor:"#f9fafb",actionHoverBorderColor:"#d1d5db",fileUploadBgColor:"#f3f4f6",fileUploadBorderColor:"#d1d5db",fileUploadTextColor:"#9ca3af",fileUploadHoverBorderColor:"#3b82f6",inputPaddingX:"0.75rem",inputPaddingY:"0.5rem",borderRadius:"0.5rem",borderWidth:"1px",fontSize:"0.875rem",fontSizeSmall:"0.75rem",fontSizeExtraSmall:"0.625rem",fontFamily:'system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif',fontWeightNormal:"400",fontWeightMedium:"500",focusRingWidth:"2px",focusRingColor:"#3b82f6",focusRingOpacity:"0.5",transitionDuration:"200ms"};function Oo(e){const t={...qe,...e},n=[];return Object.entries(t).forEach(([r,l])=>{const a=r.replace(/([A-Z])/g,"-$1").toLowerCase();n.push(` --fb-${a}: ${l};`)}),n.join(`
|
|
590
|
-
`)}function
|
|
589
|
+
`;const b=f.has(h.name)?h.name:(a=[...f.entries()].find(([,d])=>d===h.name))==null?void 0:a[0],x=(o=f.get(h.name))!=null?o:h.name;if(v.textContent=`@${x}`,b){let d=null;const y=b;v.addEventListener("mouseenter",()=>{d=Fe(d),d=on(v,y,s)}),v.addEventListener("mouseleave",()=>{d=Fe(d)})}c.appendChild(v),p=h.end}p<i.length&&c.appendChild(document.createTextNode(i.slice(p)))}n.appendChild(c)}if(!i&&u.length===0){const c=document.createElement("div");c.style.cssText="color: var(--fb-text-muted-color, #6b7280); font-size: var(--fb-font-size, 14px);",c.textContent="\u2014",n.appendChild(c)}}function No(e,t,n,r){var l,a,o,s;const i=t.state,u=(l=e.textKey)!=null?l:"text",f=(a=e.filesKey)!=null?a:"files";let c;if(e.flatOutput){const m=t.prefill[u],p=t.prefill[f];c={text:typeof m=="string"?m:null,files:Array.isArray(p)?p:[]}}else{const m=t.prefill[e.key];if(m&&typeof m=="object"&&!Array.isArray(m)){const p=m,h=(o=p[u])!=null?o:p.text,v=(s=p[f])!=null?s:p.files;c={text:typeof h=="string"?h:null,files:Array.isArray(v)?v:[]}}else typeof m=="string"?c={text:m||null,files:[]}:c={text:null,files:[]}}for(const m of c.files)i.resourceIndex.has(m)||i.resourceIndex.set(m,{name:m,type:"application/octet-stream",size:0,uploadedAt:new Date,file:void 0});if(i.config.readonly)Fo(e,t,n,r,c);else{if(!i.config.uploadFile)throw new Error(`RichInput field "${e.key}" requires uploadFile handler in config`);Ao(e,t,n,r,c)}}function Mo(e,t,n){var r,l;const{scopeRoot:a,state:o,skipValidation:s}=n,i=[],u=(r=e.textKey)!=null?r:"text",f=(l=e.filesKey)!=null?l:"files",c=a.querySelector(`[name="${t}"]`);if(!c)return{value:null,errors:i};let m={};try{const d=JSON.parse(c.value);if(d&&typeof d=="object"&&!Array.isArray(d))m=d;else return i.push(`${t}: invalid richinput data`),{value:null,errors:i}}catch(d){return i.push(`${t}: invalid richinput data`),{value:null,errors:i}}const p=m[u],h=m[f],v=p===null||typeof p=="string"?p:null,b=Array.isArray(h)?h:[],x={[u]:v!=null?v:null,[f]:b};if(!s){const d=!v||v.trim()==="",y=b.length===0;e.required&&d&&y&&i.push(`${t}: ${k("required",o)}`),!d&&v&&(e.minLength!=null&&v.length<e.minLength&&i.push(`${t}: ${k("minLength",o,{min:e.minLength})}`),e.maxLength!=null&&v.length>e.maxLength&&i.push(`${t}: ${k("maxLength",o,{max:e.maxLength})}`)),e.maxFiles!=null&&b.length>e.maxFiles&&i.push(`${t}: ${k("maxFiles",o,{max:e.maxFiles})}`)}return{value:x,errors:i,spread:!!e.flatOutput}}function qo(e,t,n,r){var l,a,o,s;const{scopeRoot:i}=r,u=i.querySelector(`[name="${t}"]`);if(!u){console.warn(`updateRichInputField: no hidden input found for "${t}". Re-render to reflect new data.`);return}let f=null;if(n&&typeof n=="object"&&!Array.isArray(n)){const c=n,m=(l=e.textKey)!=null?l:"text",p=(a=e.filesKey)!=null?a:"files",h=(o=c[m])!=null?o:c.text,v=(s=c[p])!=null?s:c.files;(h!==void 0||v!==void 0)&&(f={text:typeof h=="string"?h:null,files:Array.isArray(v)?v:[]})}f&&u._applyExternalUpdate?u._applyExternalUpdate(f):f&&(u.value=JSON.stringify(f))}function zo(e,t){const n=document.getElementById(e);if(!n)return;const r=!n.classList.contains("hidden");if(document.querySelectorAll('[id^="tooltip-"]').forEach(f=>{f.classList.add("hidden")}),r)return;const l=t.getBoundingClientRect(),a=window.innerWidth,o=window.innerHeight;n&&n.parentElement!==document.body&&document.body.appendChild(n),n.style.visibility="hidden",n.style.position="fixed",n.classList.remove("hidden");const s=n.getBoundingClientRect();n.classList.add("hidden"),n.style.visibility="visible";let i=l.left,u=l.bottom+5;i+s.width>a&&(i=l.right-s.width),u+s.height>o&&(u=l.top-s.height-5),i<10&&(i=10),u<10&&(u=l.bottom+5),n.style.left=`${i}px`,n.style.top=`${u}px`,n.classList.remove("hidden"),setTimeout(()=>{n.classList.add("hidden")},25e3)}typeof document!="undefined"&&document.addEventListener("click",e=>{const t=e.target,n=t.closest("button")&&t.closest("button").onclick,r=t.closest('[id^="tooltip-"]');!n&&!r&&document.querySelectorAll('[id^="tooltip-"]').forEach(l=>{l.classList.add("hidden")})});function Ho(e,t){var n,r,l;if(!e.enableIf)return!1;try{const a=(r=(n=t.formData)!=null?n:t.prefill)!=null?r:{},o=((l=e.enableIf.scope)!=null?l:"relative")==="relative"&&t.path?t.prefill:void 0;return!$e(e.enableIf,a,o)}catch(a){console.error(`Error evaluating enableIf for field "${e.key}":`,a)}return!1}function Io(e,t){const n=t.querySelector(`[name="${e}"]`);if(n){if(n instanceof HTMLSelectElement)return n.value;if(n instanceof HTMLInputElement){if(n.type==="checkbox")return n.checked;if(n.type==="radio"){const r=t.querySelector(`[name="${e}"]:checked`);return r?r.value:void 0}else return n.value}else if(n instanceof HTMLTextAreaElement)return n.value}}function Ge(e,t,n){var r,l;if(!t.enableIf)return;const a=n.state.formRoot;if(!a){console.error("Cannot re-evaluate enableIf: formRoot is null");return}const o=t.enableIf,s=(r=o.scope)!=null?r:"relative";let i={};const u={};if((!n.path||n.path===""?"absolute":s)==="relative"&&n.path){const f=n.path.match(/^(.+)\[(\d+)\]$/);if(f){const c=f[1],m=parseInt(f[2],10),p=a.querySelector(`[data-container-item="${c}[${m}]"]`);p&&p.querySelectorAll("input, select, textarea").forEach(h=>{const v=h.getAttribute("name");if(v){const b=v.match(/\.([^.[\]]+)$/);if(b){const x=b[1];h instanceof HTMLSelectElement?u[x]=h.value:h instanceof HTMLInputElement?h.type==="checkbox"?u[x]=h.checked:h.type==="radio"?h.checked&&(u[x]=h.value):u[x]=h.value:h instanceof HTMLTextAreaElement&&(u[x]=h.value)}}})}}else{const f=o.key,c=Io(f,a);c!==void 0?i[f]=c:i=(l=n.formData)!=null?l:n.prefill}try{$e(o,i,u)?(e.style.display="",e.classList.remove("fb-field-wrapper-disabled"),e.removeAttribute("data-conditionally-disabled")):(e.style.display="none",e.classList.add("fb-field-wrapper-disabled"),e.setAttribute("data-conditionally-disabled","true"))}catch(f){console.error(`Error re-evaluating enableIf for field "${t.key}":`,f)}}function Bo(e,t,n){var r;if(!t.enableIf)return;const l=n.state.formRoot;if(!l){console.error("Cannot setup enableIf listeners: formRoot is null");return}const a=t.enableIf,o=(r=a.scope)!=null?r:"relative",s=a.key;let i;o==="relative"&&n.path?i=`${n.path}.${s}`:i=s;const u=l.querySelector(`[name="${i}"]`);if(!u){const f=new MutationObserver(()=>{const c=l.querySelector(`[name="${i}"]`);c&&(c.addEventListener("change",()=>{Ge(e,t,n)}),c.addEventListener("input",()=>{Ge(e,t,n)}),f.disconnect())});f.observe(l,{childList:!0,subtree:!0});return}u.addEventListener("change",()=>{Ge(e,t,n)}),u.addEventListener("input",()=>{Ge(e,t,n)})}function Ro(e){const t=document.createElement("label");if(t.className="text-sm font-medium text-gray-900",t.textContent=e.label||e.key,e.required){const n=document.createElement("span");n.className="text-red-500 ml-1",n.textContent="*",t.appendChild(n)}return t}function Do(e){const t=document.createElement("button");t.type="button",t.className="ml-2 text-gray-400 hover:text-gray-600",t.innerHTML='<svg class="w-4 h-4" fill="currentColor" viewBox="0 0 24 24"><path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm1 15h-2v-6h2v6zm0-8h-2V7h2v2z"/></svg>';const n=`tooltip-${e.key}-${Math.random().toString(36).substr(2,9)}`,r=document.createElement("div");return r.id=n,r.className="hidden absolute z-50 bg-gray-200 text-gray-900 text-sm rounded-lg p-3 max-w-sm border border-gray-300 shadow-lg",r.style.position="fixed",r.textContent=e.description||e.hint||"Field information",document.body.appendChild(r),t.onclick=l=>{l.preventDefault(),l.stopPropagation(),zo(n,t)},t}function jo(e){const t=document.createElement("div");t.className="flex items-center mb-2";const n=Ro(e);if(t.appendChild(n),e.description||e.hint){const r=Do(e);t.appendChild(r)}return t}function Oo(e,t,n,r){const l="multiple"in e&&e.multiple;switch(e.type){case"text":l?xn(e,t,n,r):yn(e,t,n,r);break;case"textarea":l?Cn(e,t,n,r):En(e,t,n,r);break;case"number":l?Ln(e,t,n,r):$n(e,t,n,r);break;case"select":l?Fn(e,t,n,r):An(e,t,n,r);break;case"switcher":l?zn(e,t,n,r):qn(e,t,n,r);break;case"file":l?Zn(e,t,n,r):Xn(e,t,n,r);break;case"files":Gn(e,t,n,r);break;case"colour":l?eo(e,t,n,r):Qn(e,t,n,r);break;case"slider":l?ro(e,t,n,r):oo(e,t,n,r);break;case"group":co(e,t,n,r);break;case"container":l?Kt(e,t,n):Vt(e,t,n,r);break;case"table":Co(e,t,n,r);break;case"richinput":No(e,t,n,r);break;default:{const a=document.createElement("div");a.className="text-red-500 text-sm",a.textContent=k("unsupportedFieldType",t.state,{type:e.type}),n.appendChild(a)}}}function gt(e,t){const n=Ho(e,t),r=document.createElement("div");r.className="mb-6 fb-field-wrapper",r.setAttribute("data-field-key",e.key);const l=jo(e);r.appendChild(l);const a=ge(t.path,e.key);return Oo(e,t,r,a),n&&(r.style.display="none",r.classList.add("fb-field-wrapper-disabled"),r.setAttribute("data-conditionally-disabled","true")),Bo(r,e,t),r}io(gt);const bt={uploadFile:null,downloadFile:null,getThumbnail:null,getDownloadUrl:null,actionHandler:null,onChange:null,onFieldChange:null,onThumbnailError:null,onUploadError:null,onDownloadError:null,debounceMs:300,verboseErrors:!1,enableFilePreview:!0,maxPreviewSize:"200px",readonly:!1,parseTableFile:null,locale:"en",translations:{en:{removeElement:"Remove",clickDragText:"Click or drag file",clickDragTextMultiple:"Click or drag files",noFileSelected:"No file selected",noFilesSelected:"No files selected",downloadButton:"Download",changeButton:"Change",placeholderText:"Enter text",previewAlt:"Preview",previewUnavailable:"Preview unavailable",previewError:"Preview error",videoNotSupported:"Your browser does not support the video tag.",hintLengthRange:"{min}-{max} chars",hintMaxLength:"\u2264{max} chars",hintMinLength:"\u2265{min} chars",hintValueRange:"{min}-{max}",hintMaxValue:"\u2264{max}",hintMinValue:"\u2265{min}",hintMaxSize:"\u2264{size}MB",hintFormats:"{formats}",hintRequired:"Required",hintOptional:"Optional",hintPattern:"Format: {pattern}",fileCountSingle:"{count} file",fileCountPlural:"{count} files",fileCountRange:"({min}-{max})",required:"Required",minItems:"Minimum {min} items required",maxItems:"Maximum {max} items allowed",minLength:"Minimum {min} characters",maxLength:"Maximum {max} characters",minValue:"Must be at least {min}",maxValue:"Must be at most {max}",patternMismatch:"Invalid format",invalidPattern:"Invalid pattern in schema",notANumber:"Must be a number",invalidHexColour:"Invalid hex color",minFiles:"Minimum {min} files required",maxFiles:"Maximum {max} files allowed",invalidFileExtension:'File "{name}" has unsupported format. Allowed: {formats}',fileTooLarge:'File "{name}" exceeds maximum size of {maxSize}MB',filesLimitExceeded:"{skipped} file(s) skipped: maximum {max} files allowed",unsupportedFieldType:"Unsupported field type: {type}",invalidOption:"Invalid option",tableAddRow:"Add row",tableAddColumn:"Add column",tableRemoveRow:"Remove row",tableRemoveColumn:"Remove column",tableMergeCells:"Merge cells (Ctrl+M)",tableSplitCell:"Split cell (Ctrl+Shift+M)",tableImportFile:"Import",tableImporting:"Importing...",tableImportError:"Import failed: {error}",richinputPlaceholder:"Type text...",richinputAttachFile:"Attach file",richinputMention:"Mention",richinputRemoveFile:"Remove"},ru:{removeElement:"\u0423\u0434\u0430\u043B\u0438\u0442\u044C",clickDragText:"\u041D\u0430\u0436\u043C\u0438\u0442\u0435 \u0438\u043B\u0438 \u043F\u0435\u0440\u0435\u0442\u0430\u0449\u0438\u0442\u0435 \u0444\u0430\u0439\u043B",clickDragTextMultiple:"\u041D\u0430\u0436\u043C\u0438\u0442\u0435 \u0438\u043B\u0438 \u043F\u0435\u0440\u0435\u0442\u0430\u0449\u0438\u0442\u0435 \u0444\u0430\u0439\u043B\u044B",noFileSelected:"\u0424\u0430\u0439\u043B \u043D\u0435 \u0432\u044B\u0431\u0440\u0430\u043D",noFilesSelected:"\u041D\u0435\u0442 \u0444\u0430\u0439\u043B\u043E\u0432",downloadButton:"\u0421\u043A\u0430\u0447\u0430\u0442\u044C",changeButton:"\u0418\u0437\u043C\u0435\u043D\u0438\u0442\u044C",placeholderText:"\u0412\u0432\u0435\u0434\u0438\u0442\u0435 \u0442\u0435\u043A\u0441\u0442",previewAlt:"\u041F\u0440\u0435\u0434\u043F\u0440\u043E\u0441\u043C\u043E\u0442\u0440",previewUnavailable:"\u041F\u0440\u0435\u0434\u043F\u0440\u043E\u0441\u043C\u043E\u0442\u0440 \u043D\u0435\u0434\u043E\u0441\u0442\u0443\u043F\u0435\u043D",previewError:"\u041E\u0448\u0438\u0431\u043A\u0430 \u043F\u0440\u0435\u0434\u043F\u0440\u043E\u0441\u043C\u043E\u0442\u0440\u0430",videoNotSupported:"\u0412\u0430\u0448 \u0431\u0440\u0430\u0443\u0437\u0435\u0440 \u043D\u0435 \u043F\u043E\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u0435\u0442 \u0432\u0438\u0434\u0435\u043E.",hintLengthRange:"{min}-{max} \u0441\u0438\u043C\u0432\u043E\u043B\u043E\u0432",hintMaxLength:"\u2264{max} \u0441\u0438\u043C\u0432\u043E\u043B\u043E\u0432",hintMinLength:"\u2265{min} \u0441\u0438\u043C\u0432\u043E\u043B\u043E\u0432",hintValueRange:"{min}-{max}",hintMaxValue:"\u2264{max}",hintMinValue:"\u2265{min}",hintMaxSize:"\u2264{size}\u041C\u0411",hintFormats:"{formats}",hintRequired:"\u041E\u0431\u044F\u0437\u0430\u0442\u0435\u043B\u044C\u043D\u043E\u0435",hintOptional:"\u041D\u0435\u043E\u0431\u044F\u0437\u0430\u0442\u0435\u043B\u044C\u043D\u043E\u0435",hintPattern:"\u0424\u043E\u0440\u043C\u0430\u0442: {pattern}",fileCountSingle:"{count} \u0444\u0430\u0439\u043B",fileCountPlural:"{count} \u0444\u0430\u0439\u043B\u043E\u0432",fileCountRange:"({min}-{max})",required:"\u041E\u0431\u044F\u0437\u0430\u0442\u0435\u043B\u044C\u043D\u043E\u0435 \u043F\u043E\u043B\u0435",minItems:"\u041C\u0438\u043D\u0438\u043C\u0443\u043C {min} \u044D\u043B\u0435\u043C\u0435\u043D\u0442\u043E\u0432",maxItems:"\u041C\u0430\u043A\u0441\u0438\u043C\u0443\u043C {max} \u044D\u043B\u0435\u043C\u0435\u043D\u0442\u043E\u0432",minLength:"\u041C\u0438\u043D\u0438\u043C\u0443\u043C {min} \u0441\u0438\u043C\u0432\u043E\u043B\u043E\u0432",maxLength:"\u041C\u0430\u043A\u0441\u0438\u043C\u0443\u043C {max} \u0441\u0438\u043C\u0432\u043E\u043B\u043E\u0432",minValue:"\u0417\u043D\u0430\u0447\u0435\u043D\u0438\u0435 \u0434\u043E\u043B\u0436\u043D\u043E \u0431\u044B\u0442\u044C \u043D\u0435 \u043C\u0435\u043D\u0435\u0435 {min}",maxValue:"\u0417\u043D\u0430\u0447\u0435\u043D\u0438\u0435 \u0434\u043E\u043B\u0436\u043D\u043E \u0431\u044B\u0442\u044C \u043D\u0435 \u0431\u043E\u043B\u0435\u0435 {max}",patternMismatch:"\u041D\u0435\u0432\u0435\u0440\u043D\u044B\u0439 \u0444\u043E\u0440\u043C\u0430\u0442",invalidPattern:"\u041D\u0435\u0432\u0435\u0440\u043D\u044B\u0439 \u043F\u0430\u0442\u0442\u0435\u0440\u043D \u0432 \u0441\u0445\u0435\u043C\u0435",notANumber:"\u0414\u043E\u043B\u0436\u043D\u043E \u0431\u044B\u0442\u044C \u0447\u0438\u0441\u043B\u043E\u043C",invalidHexColour:"\u041D\u0435\u0432\u0435\u0440\u043D\u044B\u0439 \u0444\u043E\u0440\u043C\u0430\u0442 \u0446\u0432\u0435\u0442\u0430",minFiles:"\u041C\u0438\u043D\u0438\u043C\u0443\u043C {min} \u0444\u0430\u0439\u043B\u043E\u0432",maxFiles:"\u041C\u0430\u043A\u0441\u0438\u043C\u0443\u043C {max} \u0444\u0430\u0439\u043B\u043E\u0432",invalidFileExtension:'\u0424\u0430\u0439\u043B "{name}" \u0438\u043C\u0435\u0435\u0442 \u043D\u0435\u043F\u043E\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u0435\u043C\u044B\u0439 \u0444\u043E\u0440\u043C\u0430\u0442. \u0414\u043E\u043F\u0443\u0441\u0442\u0438\u043C\u044B\u0435: {formats}',fileTooLarge:'\u0424\u0430\u0439\u043B "{name}" \u043F\u0440\u0435\u0432\u044B\u0448\u0430\u0435\u0442 \u043C\u0430\u043A\u0441\u0438\u043C\u0430\u043B\u044C\u043D\u044B\u0439 \u0440\u0430\u0437\u043C\u0435\u0440 {maxSize}\u041C\u0411',filesLimitExceeded:"{skipped} \u0444\u0430\u0439\u043B(\u043E\u0432) \u043F\u0440\u043E\u043F\u0443\u0449\u0435\u043D\u043E: \u043C\u0430\u043A\u0441\u0438\u043C\u0443\u043C {max} \u0444\u0430\u0439\u043B\u043E\u0432",unsupportedFieldType:"\u041D\u0435\u043F\u043E\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u0435\u043C\u044B\u0439 \u0442\u0438\u043F \u043F\u043E\u043B\u044F: {type}",invalidOption:"\u041D\u0435\u0434\u043E\u043F\u0443\u0441\u0442\u0438\u043C\u043E\u0435 \u0437\u043D\u0430\u0447\u0435\u043D\u0438\u0435",tableAddRow:"\u0414\u043E\u0431\u0430\u0432\u0438\u0442\u044C \u0441\u0442\u0440\u043E\u043A\u0443",tableAddColumn:"\u0414\u043E\u0431\u0430\u0432\u0438\u0442\u044C \u0441\u0442\u043E\u043B\u0431\u0435\u0446",tableRemoveRow:"\u0423\u0434\u0430\u043B\u0438\u0442\u044C \u0441\u0442\u0440\u043E\u043A\u0443",tableRemoveColumn:"\u0423\u0434\u0430\u043B\u0438\u0442\u044C \u0441\u0442\u043E\u043B\u0431\u0435\u0446",tableMergeCells:"\u041E\u0431\u044A\u0435\u0434\u0438\u043D\u0438\u0442\u044C \u044F\u0447\u0435\u0439\u043A\u0438 (Ctrl+M)",tableSplitCell:"\u0420\u0430\u0437\u0434\u0435\u043B\u0438\u0442\u044C \u044F\u0447\u0435\u0439\u043A\u0443 (Ctrl+Shift+M)",tableImportFile:"\u0418\u043C\u043F\u043E\u0440\u0442",tableImporting:"\u0418\u043C\u043F\u043E\u0440\u0442...",tableImportError:"\u041E\u0448\u0438\u0431\u043A\u0430 \u0438\u043C\u043F\u043E\u0440\u0442\u0430: {error}",richinputPlaceholder:"\u0412\u0432\u0435\u0434\u0438\u0442\u0435 \u0442\u0435\u043A\u0441\u0442...",richinputAttachFile:"\u041F\u0440\u0438\u043A\u0440\u0435\u043F\u0438\u0442\u044C \u0444\u0430\u0439\u043B",richinputMention:"\u0423\u043F\u043E\u043C\u044F\u043D\u0443\u0442\u044C",richinputRemoveFile:"\u0423\u0434\u0430\u043B\u0438\u0442\u044C"}},theme:{}};function Uo(e){const t={...bt.translations};if(e!=null&&e.translations)for(const[n,r]of Object.entries(e.translations))t[n]={...bt.translations[n]||{},...r};return{schema:null,formRoot:null,resourceIndex:new Map,externalActions:null,version:"1.0.0",config:{...bt,...e,translations:t},debounceTimer:null,prefill:{}}}function Po(){const e=Date.now().toString(36),t=Math.random().toString(36).substring(2,9);return`inst-${e}-${t}`}const Ie={primaryColor:"#3b82f6",primaryHoverColor:"#2563eb",errorColor:"#ef4444",errorHoverColor:"#dc2626",successColor:"#10b981",borderColor:"#d1d5db",borderHoverColor:"#9ca3af",borderFocusColor:"#3b82f6",backgroundColor:"#ffffff",backgroundHoverColor:"#f9fafb",backgroundReadonlyColor:"#f3f4f6",textColor:"#1f2937",textSecondaryColor:"#6b7280",textPlaceholderColor:"#9ca3af",textDisabledColor:"#d1d5db",buttonBgColor:"#3b82f6",buttonTextColor:"#ffffff",buttonBorderColor:"#2563eb",buttonHoverBgColor:"#2563eb",buttonHoverBorderColor:"#1d4ed8",actionBgColor:"#ffffff",actionTextColor:"#374151",actionBorderColor:"#e5e7eb",actionHoverBgColor:"#f9fafb",actionHoverBorderColor:"#d1d5db",fileUploadBgColor:"#f3f4f6",fileUploadBorderColor:"#d1d5db",fileUploadTextColor:"#9ca3af",fileUploadHoverBorderColor:"#3b82f6",inputPaddingX:"0.75rem",inputPaddingY:"0.5rem",borderRadius:"0.5rem",borderWidth:"1px",fontSize:"0.875rem",fontSizeSmall:"0.75rem",fontSizeExtraSmall:"0.625rem",fontFamily:'system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif',fontWeightNormal:"400",fontWeightMedium:"500",focusRingWidth:"2px",focusRingColor:"#3b82f6",focusRingOpacity:"0.5",transitionDuration:"200ms"};function Vo(e){const t={...Ie,...e},n=[];return Object.entries(t).forEach(([r,l])=>{const a=r.replace(/([A-Z])/g,"-$1").toLowerCase();n.push(` --fb-${a}: ${l};`)}),n.join(`
|
|
590
|
+
`)}function Ko(e,t){const n=Vo(t);let r=e.querySelector("style[data-fb-theme]");r||(r=document.createElement("style"),r.setAttribute("data-fb-theme","true"),e.appendChild(r)),r.textContent=`
|
|
591
591
|
[data-fb-root="true"] {
|
|
592
592
|
${n}
|
|
593
593
|
}
|
|
594
|
-
`}const
|
|
594
|
+
`}const _o={default:Ie,dark:{...Ie,primaryColor:"#60a5fa",primaryHoverColor:"#3b82f6",borderColor:"#4b5563",borderHoverColor:"#6b7280",borderFocusColor:"#60a5fa",backgroundColor:"#1f2937",backgroundHoverColor:"#374151",backgroundReadonlyColor:"#111827",textColor:"#f9fafb",textSecondaryColor:"#9ca3af",textPlaceholderColor:"#6b7280",fileUploadBgColor:"#374151",fileUploadBorderColor:"#4b5563",fileUploadTextColor:"#9ca3af"},klein:{...Ie,primaryColor:"#0066cc",primaryHoverColor:"#0052a3",errorColor:"#d32f2f",errorHoverColor:"#c62828",successColor:"#388e3c",borderColor:"#e0e0e0",borderHoverColor:"#bdbdbd",borderFocusColor:"#0066cc",borderRadius:"4px",fontSize:"16px",fontSizeSmall:"14px",fontFamily:'"Roboto", "Helvetica", "Arial", sans-serif'}};function cn(e,t=!1){e.style.cssText=`
|
|
595
595
|
background-color: var(--fb-action-bg-color);
|
|
596
596
|
color: var(--fb-action-text-color);
|
|
597
597
|
border: var(--fb-border-width) solid var(--fb-action-border-color);
|
|
@@ -601,6 +601,6 @@ ${n}
|
|
|
601
601
|
border-radius: var(--fb-border-radius);
|
|
602
602
|
transition: all var(--fb-transition-duration);
|
|
603
603
|
box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
|
|
604
|
-
`,e.addEventListener("mouseenter",()=>{e.style.backgroundColor="var(--fb-action-hover-bg-color)",e.style.borderColor="var(--fb-action-hover-border-color)"}),e.addEventListener("mouseleave",()=>{e.style.backgroundColor="var(--fb-action-bg-color)",e.style.borderColor="var(--fb-action-border-color)"})}const
|
|
604
|
+
`,e.addEventListener("mouseenter",()=>{e.style.backgroundColor="var(--fb-action-hover-bg-color)",e.style.borderColor="var(--fb-action-hover-border-color)"}),e.addEventListener("mouseleave",()=>{e.style.backgroundColor="var(--fb-action-bg-color)",e.style.borderColor="var(--fb-action-border-color)"})}function Wo(e,t,n){var r;const{scopeRoot:l}=n,a=l.querySelector(`input[type="hidden"][data-hidden-field="true"][name="${t}"]`),o=(r=a==null?void 0:a.value)!=null?r:"";if(o===""){const s="default"in e?e.default:null;return{value:s!==void 0?s:null,errors:[]}}return{value:xt(o),errors:[]}}function Jo(e,t,n,r){const{scopeRoot:l}=r,a=l.querySelector(`input[type="hidden"][data-hidden-field="true"][name="${t}"]`);a&&(a.value=yt(n))}const Yo={text:{validate:Et,update:Ct},textarea:{validate:wn,update:kn},number:{validate:Sn,update:Tn},select:{validate:Nn,update:Mn},switcher:{validate:Hn,update:In},file:{validate:zt,update:Ht},files:{validate:zt,update:Ht},colour:{validate:to,update:no},slider:{validate:lo,update:ao},container:{validate:Wt,update:Jt},group:{validate:uo,update:po},table:{validate:wo,update:ko},richinput:{validate:Mo,update:qo},hidden:{validate:Wo,update:Jo}};function un(e){return Yo[e]||null}function Xo(e,t,n){const r=un(e.type);return r&&r.validate?r.validate(e,t,n):null}function Go(e,t,n,r){const l=un(e.type);return l&&l.update?(l.update(e,t,n,r),!0):!1}class Ze{constructor(t){this.instanceId=Po(),this.state=Uo(t),this.state.config.verboseErrors&&(globalThis.__formBuilderInstances||(globalThis.__formBuilderInstances=new Set),globalThis.__formBuilderInstances.add(this.instanceId),globalThis.__formBuilderInstances.size>10&&console.warn(`[form-builder] ${globalThis.__formBuilderInstances.size} instances active. Possible memory leak - ensure you call destroy() when done.`))}getInstanceId(){return this.instanceId}getState(){return this.state}setFormRoot(t){this.state.formRoot=t}configure(t){Object.assign(this.state.config,t)}setUploadHandler(t){this.state.config.uploadFile=t}setDownloadHandler(t){this.state.config.downloadFile=t}setThumbnailHandler(t){this.state.config.getThumbnail=t}setActionHandler(t){this.state.config.actionHandler=t}setMode(t){this.state.config.readonly=t==="readonly"}setLocale(t){this.state.config.translations[t]&&(this.state.config.locale=t)}triggerOnChange(t,n){this.state.config.readonly||(this.state.debounceTimer!==null&&clearTimeout(this.state.debounceTimer),this.state.debounceTimer=setTimeout(()=>{const r=this.validateForm(!0);this.reevaluateConditionalFields(),this.state.config.onChange&&this.state.config.onChange(r),this.state.config.onFieldChange&&t!==void 0&&n!==void 0&&this.state.config.onFieldChange(t,n,r),this.state.debounceTimer=null},this.state.config.debounceMs))}registerAction(t){if(!t||!t.value)throw new Error("Action must have a value property");this.state.externalActions||(this.state.externalActions=[]);const n=this.state.externalActions.findIndex(r=>r.value===t.value&&r.related_field===t.related_field);n>=0?this.state.externalActions[n]=t:this.state.externalActions.push(t)}findFormElementByFieldPath(t){if(!this.state.formRoot)return null;if(!this.state.config.readonly){let l=this.state.formRoot.querySelector(`[name="${t}"]`);if(l)return l;const a=[t,t.replace(/\[(\d+)\]/g,"[$1]"),t.replace(/\./g,"[")+"]".repeat((t.match(/\./g)||[]).length)];for(const o of a)if(l=this.state.formRoot.querySelector(`[name="${o}"]`),l)return l}const n=this.findSchemaElement(t);if(!n)return null;const r=this.state.formRoot.querySelectorAll(".fb-field-wrapper");for(const l of r){const a=n.label||n.key,o=l.querySelector("label");if(o&&(o.textContent===a||o.textContent===`${a}*`)){let s=l.querySelector(".field-placeholder");return s||(s=document.createElement("div"),s.className="field-placeholder",s.style.display="none",l.appendChild(s)),s}}return null}findSchemaElement(t){if(!this.state.schema||!this.state.schema.elements)return null;let n=this.state.schema.elements,r=null;const l=t.replace(/\[\d+\]/g,"").split(".").filter(Boolean);for(const a of l){if(r=n.find(o=>o.key===a)||null,!r)return null;"elements"in r&&r.elements&&(n=r.elements)}return r}resolveActionLabel(t,n,r,l=!1){if(r&&"actions"in r&&r.actions){const a=r.actions.find(o=>o.key===t);if(a&&a.label)return a.label}if(l&&this.state.schema&&"actions"in this.state.schema&&this.state.schema.actions){const a=this.state.schema.actions.find(o=>o.key===t);if(a&&a.label)return a.label}return n||t}renderFormLevelActions(t,n=[]){if(!this.state.formRoot)return;const r=this.state.formRoot.querySelector(".form-level-actions-container");r&&r.remove();const l=document.createElement("div");l.className="form-level-actions-container mt-6 pt-4 flex flex-wrap gap-3 justify-center",l.style.cssText=`
|
|
605
605
|
border-top: var(--fb-border-width) solid var(--fb-border-color);
|
|
606
|
-
`,t.forEach(a=>{const o=document.createElement("button");o.type="button",
|
|
606
|
+
`,t.forEach(a=>{const o=document.createElement("button");o.type="button",cn(o,!0);const s=n.includes(a),i=this.resolveActionLabel(a.key,a.label,null,s);o.textContent=i,o.addEventListener("click",u=>{u.preventDefault(),u.stopPropagation(),this.state.config.actionHandler&&typeof this.state.config.actionHandler=="function"&&this.state.config.actionHandler(a.value,a.key,null)}),l.appendChild(o)}),this.state.formRoot.appendChild(l)}renderExternalActions(){if(!this.state.externalActions||!Array.isArray(this.state.externalActions))return;const t=new Map,n=[],r=[];this.state.externalActions.forEach(a=>{!a.key||!a.value||(a.related_field?(t.has(a.related_field)||t.set(a.related_field,[]),t.get(a.related_field).push(a)):n.push(a))}),t.forEach((a,o)=>{const s=this.findFormElementByFieldPath(o);if(!s){console.warn(`External action: Could not find form element for field "${o}", treating as form-level actions`),r.push(...a);return}let i=s.closest(".fb-field-wrapper");if(i||(i=s.parentElement),!i){console.warn(`External action: Could not find wrapper for field "${o}"`);return}const u=i.querySelector(".external-actions-container");u&&u.remove();const f=document.createElement("div");f.className="external-actions-container mt-3 flex flex-wrap gap-2";const c=this.findSchemaElement(o);a.forEach(m=>{const p=document.createElement("button");p.type="button",cn(p,!1);const h=this.resolveActionLabel(m.key,m.label,c);p.textContent=h,p.addEventListener("click",v=>{v.preventDefault(),v.stopPropagation(),this.state.config.actionHandler&&typeof this.state.config.actionHandler=="function"&&this.state.config.actionHandler(m.value,m.key,m.related_field)}),f.appendChild(p)}),i.appendChild(f)});const l=[...n,...r];l.length>0&&this.renderFormLevelActions(l,n)}handlePrefillHintClick(t){const n=t.target;if(!n.classList.contains("fb-prefill-hint"))return;t.preventDefault(),t.stopPropagation();const r=n.getAttribute("data-hint-values"),l=n.getAttribute("data-root-hint")==="true",a=n.getAttribute("data-container-key");if(!r||!l&&!a){console.warn("Prefill hint missing required data attributes");return}try{const o=JSON.parse(r);for(const s in o){const i=l?s:`${a}.${s}`,u=o[s];this.updateField(i,u)}}catch(o){console.error("Error parsing prefill hint values:",o)}}createRootPrefillHints(t){const n=document.createElement("div");return n.className="fb-prefill-hints flex flex-wrap gap-2 mb-4",t.forEach(r=>{const l=document.createElement("button");l.type="button",l.className="fb-prefill-hint",r.icon?l.textContent=`${r.icon} ${r.label}`:l.textContent=r.label,l.setAttribute("data-hint-values",JSON.stringify(r.values)),l.setAttribute("data-root-hint","true"),n.appendChild(l)}),n}renderForm(t,n,r,l){const a=et(n);if(a.length>0){console.error("Schema validation errors:",a);return}this.state.formRoot=t,this.state.schema=n,this.state.externalActions=l||null,this.state.prefill=r||{},pe(t),t.setAttribute("data-fb-root","true"),Ko(t,this.state.config.theme);const o=document.createElement("div");if(o.className="space-y-6",n.prefillHints&&!this.state.config.readonly){const u=this.createRootPrefillHints(n.prefillHints);o.appendChild(u)}const s=document.createElement("div"),i=n.columns||1;i===1?s.className="space-y-4":s.className=`grid grid-cols-${i} gap-4`,n.elements.forEach(u=>{var f,c;if(u.hidden||u.type==="hidden"){const p=(c=(f=r==null?void 0:r[u.key])!=null?f:u.default)!=null?c:null;s.appendChild(qe(u.key,p));return}const m=gt(u,{path:"",prefill:r||{},formData:r||{},state:this.state,instance:this});s.appendChild(m)}),o.appendChild(s),t.appendChild(o),this.state.config.readonly||t.addEventListener("click",this.handlePrefillHintClick.bind(this)),this.state.config.readonly&&this.state.externalActions&&Array.isArray(this.state.externalActions)&&this.renderExternalActions()}validateForm(t=!1){if(!this.state.schema||!this.state.formRoot)return{valid:!0,errors:[],data:{}};const n=[],r={},l=(a,o,s=null)=>{const i=a.key,u={scopeRoot:s||this.state.formRoot,state:this.state,instance:this,path:o.path,skipValidation:t},f=Xo(a,i,u);return f!==null?(n.push(...f.errors),{value:f.value,spread:!!f.spread}):(console.warn(`Unknown field type "${a.type}" for key "${i}"`),{value:null,spread:!1})};return so(l),this.state.schema.elements.forEach(a=>{var o;if(a.enableIf)try{if(!$e(a.enableIf,r))return}catch(s){console.error(`Error evaluating enableIf for field "${a.key}" during validation:`,s)}if(a.hidden||a.type==="hidden"){const s=this.state.formRoot.querySelector(`input[type="hidden"][data-hidden-field="true"][name="${a.key}"]`),i=(o=s==null?void 0:s.value)!=null?o:"";i!==""?r[a.key]=xt(i):r[a.key]=a.default!==void 0?a.default:null}else{const s=l(a,{path:""});s.spread&&s.value!==null&&typeof s.value=="object"?Object.assign(r,s.value):r[a.key]=s.value}}),{valid:n.length===0,errors:n,data:r}}getFormData(){return this.validateForm(!1)}submitForm(){const t=this.validateForm(!1);return t.valid&&typeof window!="undefined"&&window.parent&&window.parent.postMessage({type:"formSubmit",data:t.data,schema:this.state.schema},"*"),t}saveDraft(){const t=this.validateForm(!0);return typeof window!="undefined"&&window.parent&&window.parent.postMessage({type:"formDraft",data:t.data,schema:this.state.schema},"*"),t}clearForm(){if(!this.state.schema||!this.state.formRoot){console.warn("clearForm: Form not initialized. Call renderForm() first.");return}const t=this.state.schema,n=this.state.formRoot,r=this.state.externalActions,l=this.buildHiddenFieldsData(t.elements);this.renderForm(n,t,l,r||void 0)}buildHiddenFieldsData(t){const n={};for(const r of t){const l=r.key;if(r.hidden&&r.default!==void 0&&(n[l]=r.default),r.type==="container"||r.type==="group"){const a=r,o=this.buildHiddenFieldsData(a.elements);Object.keys(o).length>0&&(l in n?typeof n[l]=="object"&&n[l]!==null&&!Array.isArray(n[l])&&(n[l]={...n[l],...o}):n[l]=o)}}return n}buildFlatKeyMap(t){var n,r;const l=new Map;for(const a of t)if(a.type==="richinput"&&a.flatOutput){const o=a,s=(n=o.textKey)!=null?n:"text",i=(r=o.filesKey)!=null?r:"files";l.set(s,{schemaKey:a.key,role:"text"}),l.set(i,{schemaKey:a.key,role:"files"})}return l}setFormData(t){if(!this.state.schema||!this.state.formRoot){console.warn("setFormData: Form not initialized. Call renderForm() first.");return}const n=this.buildFlatKeyMap(this.state.schema.elements),r=new Map;for(const l in t){const a=n.get(l);a?(r.has(a.schemaKey)||r.set(a.schemaKey,{}),r.get(a.schemaKey)[l]=t[l]):this.updateField(l,t[l])}for(const[l,a]of r)this.updateField(l,a)}updateField(t,n){if(!this.state.schema||!this.state.formRoot){console.warn("updateField: Form not initialized. Call renderForm() first.");return}const r=this.findSchemaElement(t);if(!r){console.warn(`updateField: Schema element not found for path "${t}"`);return}const l=this.findFormElementByFieldPath(t);if(!l){console.warn(`updateField: DOM element not found for path "${t}"`);return}this.updateFieldValue(l,r,t,n),this.reevaluateConditionalFields(),(this.state.config.onChange||this.state.config.onFieldChange)&&this.triggerOnChange(t,n)}updateFieldValue(t,n,r,l){const a={scopeRoot:this.state.formRoot,state:this.state,instance:this,path:""};Go(n,r,l,a)||console.warn(`updateField: No updater found for field type "${n.type}" at path "${r}"`)}reevaluateConditionalFields(){if(!this.state.schema||!this.state.formRoot)return;const t=this.validateForm(!0).data,n=(r,l)=>{r.forEach(a=>{var o,s,i;const u=l?`${l}.${a.key}`:a.key;if(a.enableIf){let f=null;if(l){const c=l.match(/^(.+)\[(\d+)\]$/);if(c){const m=c[1],p=c[2],h=this.state.formRoot.querySelector(`[data-container-item="${m}[${p}]"]`);h&&(f=h.querySelector(`[data-field-key="${a.key}"]`))}else{const m=this.state.formRoot.querySelector(`[data-container="${l}"]`);m&&(f=m.querySelector(`[data-field-key="${a.key}"]`))}}else f=this.state.formRoot.querySelector(`[data-field-key="${a.key}"]`);if(f){const c=f;try{let m;((o=a.enableIf.scope)!=null?o:"relative")==="relative"&&l&&(m=tt(t,l));const p=$e(a.enableIf,t,m),h=c.getAttribute("data-conditionally-disabled")==="true";if(p&&h){const v=l?tt(t,l):t,b=gt(a,{path:l,prefill:v&&typeof v=="object"?v:{},formData:t,state:this.state,instance:this});(s=c.parentNode)==null||s.replaceChild(b,c)}else if(!p&&!h){const v=document.createElement("div");v.className="fb-field-wrapper-disabled",v.style.display="none",v.setAttribute("data-field-key",a.key),v.setAttribute("data-conditionally-disabled","true"),(i=c.parentNode)==null||i.replaceChild(v,c)}}catch(m){console.error(`Error re-evaluating enableIf for field "${a.key}" at path "${u}":`,m)}}}if((a.type==="container"||a.type==="group")&&"elements"in a&&a.elements){const f=t==null?void 0:t[a.key];if(Array.isArray(f)){const c=this.state.formRoot.querySelectorAll("[data-container-item]");Array.from(c).filter(m=>{const p=m.getAttribute("data-container-item")||"";if(!p.startsWith(`${u}[`))return!1;const h=p.slice(u.length);return/^\[\d+\]$/.test(h)}).forEach(m=>{const p=m.getAttribute("data-container-item")||"";n(a.elements,p)})}else n(a.elements,u)}})};n(this.state.schema.elements,"")}destroy(){var t;this.state.debounceTimer!==null&&(clearTimeout(this.state.debounceTimer),this.state.debounceTimer=null),this.state.resourceIndex.clear(),this.state.formRoot&&pe(this.state.formRoot),this.state.formRoot=null,this.state.schema=null,this.state.externalActions=null,this.state.config.verboseErrors&&((t=globalThis.__formBuilderInstances)==null||t.delete(this.instanceId))}}function dn(e){return new Ze(e)}return typeof window!="undefined"&&(window.FormBuilder=Ze,window.createFormBuilder=dn,window.validateSchema=et),ye.FormBuilderInstance=Ze,ye.createFormBuilder=dn,ye.default=Ze,ye.defaultTheme=Ie,ye.exampleThemes=_o,ye.validateSchema=et,Object.defineProperty(ye,"__esModule",{value:!0}),ye})({});
|