@msbci/form-editor 1.3.3 → 1.3.4
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/README.md +9 -0
- package/dist/index.cjs +1 -1
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.mts +113 -3
- package/dist/index.d.ts +113 -3
- package/dist/index.mjs +1 -1
- package/dist/index.mjs.map +1 -1
- package/package.json +1 -1
package/dist/index.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
'use strict';var wr=require('react'),zustand=require('zustand'),formCore=require('@msbci/form-core'),jsxRuntime=require('react/jsx-runtime'),core=require('@dnd-kit/core'),sortable=require('@dnd-kit/sortable'),utilities=require('@dnd-kit/utilities');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var wr__default=/*#__PURE__*/_interopDefault(wr);function Xe(e,r){return {itemType:"variable",id:formCore.generateId(),code:e.code,name:e.name,type:e.variableType,order:r,isRequired:e.isRequired??false,isReadonly:e.isReadonly??false,isHidden:e.isHidden??false,description:e.description,placeholder:e.placeholder,options:e.options,validationRules:e.validationRules,conditions:e.conditions,expression:e.expression,dataSourceId:e.dataSourceId,dataSourceDependencies:e.dataSourceDependencies,style:e.style,metadata:e.metadata,templateId:e.id,templateOverrides:{}}}function Ze(e,r,a){return r==="variableType"?{...e,type:a}:{...e,[r]:a}}function Jo(e,r){return r==="variableType"?e.variableType:e[r]}var Xo=50;function Zo(){return {id:"",code:"",name:"New Form",version:"1.0.0",isPublished:false,pages:[]}}function E(e,r){let a=Array.isArray(e.items)?e.items:[...formCore.getPageVariables(e),...formCore.getPageRosters(e)],{variables:n,rosters:o,...t}=e;return {...t,items:r(a)}}var S=zustand.create((e,r)=>{function a(o){let t=r(),l={form:formCore.deepClone(t.form),description:o,timestamp:Date.now()},i=t.history.slice(0,t.historyIndex+1);i.push(l),i.length>Xo&&i.shift(),e({history:i,historyIndex:i.length-1});}function n(o,t){a(o);let l=r(),i=t(formCore.deepClone(l.form));e({form:i,isDirty:true});}return {form:Zo(),formTypes:[],selection:{type:"form"},view:"canvas",isDirty:false,isSaving:false,history:[],historyIndex:-1,adapter:null,availableTemplates:[],availableScopes:[],setForm:o=>{e({form:formCore.migrateFormToItems(formCore.deepClone(o)),isDirty:false,history:[],historyIndex:-1,selection:{type:"form"}});},updateFormMeta:o=>{n("Update form metadata",t=>({...t,...o}));},addPage:o=>{let t=Array.isArray(o.items)?o:{...o,items:[...o.variables??[],...o.rosters??[]]};n(`Add page "${t.name}"`,l=>({...l,pages:[...l.pages,t]}));},updatePage:(o,t)=>{n(`Update page "${o}"`,l=>({...l,pages:l.pages.map(i=>i.code===o?{...i,...t}:i)}));},removePage:o=>{n(`Remove page "${o}"`,l=>({...l,pages:l.pages.filter(i=>i.code!==o)}));let t=r();t.selection.type==="page"&&t.selection.pageCode===o&&e({selection:{type:"form"}});},reorderPages:o=>{n("Reorder pages",t=>{let l=new Map(t.pages.map(s=>[s.code,s])),i=o.map((s,d)=>{let c=l.get(s);return c?{...c,order:d}:void 0}).filter(s=>s!==void 0);return {...t,pages:i}});},addRoster:(o,t)=>{n(`Add roster "${t.name}" to page "${o}"`,l=>({...l,pages:l.pages.map(i=>i.code!==o?i:E(i,s=>[...s,{...t,itemType:"roster",order:s.length}]))}));},updateRoster:(o,t,l)=>{n(`Update roster "${t}"`,i=>({...i,pages:i.pages.map(s=>s.code!==o?s:E(s,d=>d.map(c=>formCore.isPageRoster(c)&&c.code===t?{...c,...l,itemType:"roster"}:c)))}));},removeRoster:(o,t)=>{n(`Remove roster "${t}"`,l=>({...l,pages:l.pages.map(i=>i.code!==o?i:E(i,s=>s.filter(d=>!(formCore.isPageRoster(d)&&d.code===t))))}));},addVariable:(o,t,l)=>{n(`Add variable "${t.name}"`,i=>({...i,pages:i.pages.map(s=>s.code!==o?s:l?E(s,d=>d.map(c=>formCore.isPageRoster(c)&&c.code===l?{...c,variables:[...c.variables,t]}:c)):E(s,d=>[...d,{...t,itemType:"variable",order:d.length}]))}));},updateVariable:(o,t,l,i)=>{n(`Update variable "${t}"`,s=>({...s,pages:s.pages.map(d=>d.code!==o?d:i?E(d,c=>c.map(y=>formCore.isPageRoster(y)&&y.code===i?{...y,variables:y.variables.map(m=>m.code===t?{...m,...l}:m)}:y)):E(d,c=>c.map(y=>formCore.isPageVariable(y)&&y.code===t?{...y,...l,itemType:"variable"}:y)))}));},removeVariable:(o,t,l)=>{n(`Remove variable "${t}"`,i=>({...i,pages:i.pages.map(s=>s.code!==o?s:l?E(s,d=>d.map(c=>formCore.isPageRoster(c)&&c.code===l?{...c,variables:c.variables.filter(y=>y.code!==t)}:c)):E(s,d=>d.filter(c=>!(formCore.isPageVariable(c)&&c.code===t))))}));},addVariableFromTemplate:(o,t,l)=>{n(`Add variable from template "${t.code}"`,i=>({...i,pages:i.pages.map(s=>s.code!==o?s:l?E(s,d=>d.map(c=>{if(!(formCore.isPageRoster(c)&&c.code===l))return c;let y=Xe(t,c.variables.length);return {...c,variables:[...c.variables,y]}})):E(s,d=>[...d,Xe(t,d.length)]))}));},setVariableOverride:(o,t,l,i,s)=>{n(`Override "${String(l)}" on "${t}"`,d=>({...d,pages:d.pages.map(c=>{if(c.code!==o)return c;let y=m=>{let p={...m.templateOverrides??{},[l]:i};return {...Ze(m,l,i),templateOverrides:p}};return s?E(c,m=>m.map(p=>formCore.isPageRoster(p)&&p.code===s?{...p,variables:p.variables.map(b=>b.code===t?y(b):b)}:p)):E(c,m=>m.map(p=>formCore.isPageVariable(p)&&p.code===t?y(p):p))})}));},resetVariableOverride:(o,t,l,i)=>{let s=r().availableTemplates;n(`Reset override "${String(l)}" on "${t}"`,d=>({...d,pages:d.pages.map(c=>{if(c.code!==o)return c;let y=m=>{let p={...m.templateOverrides??{}};delete p[l];let b=m.templateId?s.find(f=>f.id===m.templateId):void 0,g=b?Jo(b,l):void 0;return {...Ze(m,l,g),templateOverrides:p}};return i?E(c,m=>m.map(p=>formCore.isPageRoster(p)&&p.code===i?{...p,variables:p.variables.map(b=>b.code===t?y(b):b)}:p)):E(c,m=>m.map(p=>formCore.isPageVariable(p)&&p.code===t?y(p):p))})}));},moveVariable:(o,t,l,i,s,d)=>{n(`Move variable "${l}"`,c=>{let y,m=c.pages.map(b=>b.code!==o?b:s?E(b,g=>g.map(u=>{if(!(formCore.isPageRoster(u)&&u.code===s))return u;let f=u.variables.find(x=>x.code===l);return f&&(y={...f}),{...u,variables:u.variables.filter(x=>x.code!==l)}})):E(b,g=>g.filter(u=>formCore.isPageVariable(u)&&u.code===l?(y={...u},false):true)));if(!y)return c;y={...y,order:i,itemType:"variable"};let p=m.map(b=>b.code!==t?b:d?E(b,g=>g.map(u=>formCore.isPageRoster(u)&&u.code===d?{...u,variables:[...u.variables,y].sort((f,x)=>f.order-x.order)}:u)):E(b,g=>[...g,y].sort((u,f)=>u.order-f.order)));return {...c,pages:p}});},moveItem:(o,t,l)=>{n(`Reorder page items in "${o}"`,i=>({...i,pages:i.pages.map(s=>s.code!==o?s:E(s,d=>{if(t<0||t>=d.length||l<0||l>=d.length||t===l)return d;let c=d.slice(),[y]=c.splice(t,1);return c.splice(l,0,y),c.map((m,p)=>({...m,order:p}))}))}));},select:o=>e({selection:o}),clearSelection:()=>e({selection:{type:"form"}}),setView:o=>e({view:o}),undo:()=>{let{history:o,historyIndex:t,form:l}=r();if(!(t<0))if(t===o.length-1){let i={form:formCore.deepClone(l),description:"Current state",timestamp:Date.now()};e({form:formCore.deepClone(o[t].form),historyIndex:t-1,isDirty:true,history:[...o,i]});}else e({form:formCore.deepClone(o[t].form),historyIndex:t-1,isDirty:true});},redo:()=>{let{history:o,historyIndex:t}=r();if(t>=o.length-2)return;let l=t+2;l<o.length&&e({form:formCore.deepClone(o[l].form),historyIndex:l-1,isDirty:true});},canUndo:()=>r().historyIndex>=0,canRedo:()=>{let{history:o,historyIndex:t}=r();return t<o.length-2},addFormType:o=>{let t={...o,id:formCore.generateId()};e(l=>({formTypes:[...l.formTypes,t]}));},updateFormType:(o,t)=>{e(l=>({formTypes:l.formTypes.map(i=>i.id===o?{...i,...t}:i)}));},removeFormType:o=>{let t=r();if(t.form.formTypeId===o){let{formTypeId:l,...i}=t.form;e({form:{...i}});}e(l=>({formTypes:l.formTypes.filter(i=>i.id!==o)}));},setAvailableTemplates:o=>{e({availableTemplates:o});},setAvailableScopes:o=>{e({availableScopes:o});},setAdapter:o=>e({adapter:o}),save:async()=>{let{adapter:o,form:t}=r();if(o?.saveForm){e({isSaving:true});try{await o.saveForm(t),e({isDirty:!1});}finally{e({isSaving:false});}}},load:async o=>{let{adapter:t}=r();if(!t?.loadForm)return;let l=await t.loadForm(o);r().setForm(l);},exportJson:()=>formCore.serializeForm(r().form),importJson:o=>{let t=formCore.deserializeForm(o);r().setForm(t);}}});var Z={toolbar:{formNamePlaceholder:"Nom du formulaire",unsaved:"Non sauvegard\xE9",addPage:"+ Page",formProperties:"Propri\xE9t\xE9s du formulaire",types:"Types",manageFormTypesTitle:"G\xE9rer les types de formulaire",undo:"Annuler",redo:"R\xE9tablir",save:"Enregistrer",saving:"Enregistrement...",export:"Exporter",import:"Importer",viewEditor:"\xC9diteur",viewPreview:"Aper\xE7u",viewJson:"JSON"},toolbox:{searchPlaceholder:"Rechercher...",addPageFirst:"Ajoutez d\u2019abord une page",tabFields:"Champs",tabVariables:"Variables",noTemplates:"Aucune variable dans ce scope",noScope:"Configurez un scope pour acc\xE9der au r\xE9f\xE9rentiel",groupText:"Texte",groupSelection:"S\xE9lection",groupDateTime:"Date et heure",groupMedia:"M\xE9dias",groupAdvanced:"Avanc\xE9",groupRoster:"Roster",typeRosterCheck:"Cases \xE0 cocher",typeRosterList:"Liste",typeRosterCollection:"Collection",typeRosterCollectionExtend:"Collection \xE9tendue",types:{text:"Texte court",textarea:"Zone de texte",number:"Nombre",email:"Email",select:"Liste d\xE9roulante",multiselect:"Multi-s\xE9lection",radio:"Boutons radio",checkbox:"Cases \xE0 cocher",date:"Date",datetime:"Date et heure",time:"Heure",file:"Fichier",image:"Image",gps:"GPS",rating:"Note (\xE9toiles)",calculated:"Calcul\xE9",hidden:"Masqu\xE9",label:"\xC9tiquette"}},canvas:{emptyStateNoPage:"Cliquez sur \xAB + Page \xBB dans la barre d\u2019outils pour commencer",emptyStateNoPageDnd:"Glissez un champ depuis la bo\xEEte \xE0 outils ou ajoutez une page pour commencer",emptyStatePage:"Cliquez sur un type de champ dans la bo\xEEte \xE0 outils pour l\u2019ajouter ici",unnamedPage:"Page sans nom",repeatable:"R\xE9p\xE9table",fieldsRostersCount:(e,r)=>`${e} champ${e>1?"s":""} \xB7 ${r} roster${r>1?"s":""}`,fieldsCount:e=>`${e} champ${e>1?"s":""}`,rosterVarsCount:e=>`${e} variable${e>1?"s":""}`,addRoster:"+ Ajouter un roster",addFieldToRoster:"+ Ajouter un champ au roster",pilotPrefix:"pilote :",newRosterName:"Nouveau roster",newFieldName:"Nouveau champ",newVariableName:e=>`Nouveau ${e.toLowerCase()}`,hasConditionsTitle:"Contient des conditions",dataSourceConnectedTitle:"Source de donn\xE9es connect\xE9e"},properties:{title:"Propri\xE9t\xE9s",name:"Nom",code:"Code",description:"Description",placeholder:"Placeholder",version:"Version",formType:"Type de formulaire",noType:"\u2014 Aucun type \u2014",formSummary:(e,r)=>`${e} page${e>1?"s":""} \xB7 ${r} variable${r>1?"s":""}`,pageSummary:(e,r)=>`${e} variable${e>1?"s":""} \xB7 ${r} roster${r>1?"s":""}`,rosterSummary:(e,r)=>`${e} variable${e>1?"s":""} \xB7 ${r} option${r>1?"s":""}`,repeatablePage:"Page r\xE9p\xE9table",minInstances:"Minimum d\u2019instances",maxInstances:"Maximum d\u2019instances",controlVariableCode:"Code de la variable de contr\xF4le",instanceLabel:"Mod\xE8le de libell\xE9 d\u2019instance",rosterType:"Type de roster",pilotVariableCode:"Code de la variable pilote",rosterTypes:{check:"Cases \xE0 cocher (s\xE9lection multiple)",list:"Liste (dropdown par ligne)",collection:"Collection (ajout/suppression de lignes)",collection_extend:"Collection \xE9tendue (vue tableau)"},linkedTemplate:"Variable li\xE9e au r\xE9f\xE9rentiel",templateCode:"Code (non modifiable)",templateName:"Nom (non modifiable)",resetOverride:"R\xE9initialiser",type:"Type",ratingStyle:"Style de notation",ratingStyles:{star:"\u2605 \xC9toiles",number:"123 Nombres",color:"\u25CF Points de couleur"},layout:"Mise en page",startNewRow:"Nouvelle ligne",columnSpan:"Largeur (colonnes, 1-12)",columnSpanAuto:"Auto (part \xE9gale)",columnSpanHalf:" (moiti\xE9)",columnSpanThird:" (tiers)",columnSpanFull:" (pleine largeur)",required:"Obligatoire",readonly:"Lecture seule",hidden:"Masqu\xE9 par d\xE9faut",expression:"Expression",scopes:"Scopes (r\xE9f\xE9rentiel de variables)",scopesHint:"L\u2019ordre d\xE9finit la priorit\xE9 : le premier scope gagne en cas de conflit sur un code.",noScopesAvailable:"Aucun scope disponible \u2014 configurez-en un via l\u2019API ou le seed.",moveScopeUp:"Monter",moveScopeDown:"Descendre",removeScope:"Retirer",langConfigSection:"Langues",langConfigAvailable:"Langues disponibles",langConfigDefault:"Langue par d\xE9faut",langConfigStrategy:"Strat\xE9gie de d\xE9tection",langConfigStrategies:{prop:"Propri\xE9t\xE9 (prop)",browser:"Navigateur",selector:"S\xE9lecteur dans le formulaire",auto:"Auto (navigateur puis d\xE9faut)"},langConfigSelectorPosition:"Position du s\xE9lecteur",langConfigPositions:{top:"Haut",bottom:"Bas"},langConfigConfirmRemove:e=>`Supprimer la langue \xAB ${e.toUpperCase()} \xBB supprimera toutes les traductions ${e.toUpperCase()}. Confirmer ?`,langConfigConfirmYes:"Supprimer",langConfigConfirmNo:"Annuler"},optionsEditor:{optionsCount:e=>`Options (${e})`,noOptions:"Aucune option. Ajoutez-en une pour peupler les choix.",optionLabelPlaceholder:"Libell\xE9",optionValuePlaceholder:"valeur",addOption:"+ Ajouter une option",optionLabelAria:e=>`Libell\xE9 de l\u2019option ${e+1}`,optionValueAria:e=>`Valeur de l\u2019option ${e+1}`,removeOptionAria:e=>`Supprimer l\u2019option ${e+1}`},conditionBuilder:{conditionsCount:e=>`Conditions (${e})`,addCondition:"+ Ajouter une condition",rulesCount:e=>` (${e} r\xE8gle${e>1?"s":""})`,addRule:"+ Ajouter une r\xE8gle",action:"Action",match:"Correspondance",all:"TOUT (ET)",any:"AU MOINS UN (OU)",actions:{show:"Afficher si",hide:"Masquer si",validate:"Valider que",require:"Obligatoire si",readonly:"Lecture seule si",setValue:"D\xE9finir la valeur si"},operators:{equals:"est \xE9gal \xE0",not_equals:"est diff\xE9rent de",greater_than:"est sup\xE9rieur \xE0",less_than:"est inf\xE9rieur \xE0",greater_than_or_equal:"est sup\xE9rieur ou \xE9gal \xE0",less_than_or_equal:"est inf\xE9rieur ou \xE9gal \xE0",contains:"contient",not_contains:"ne contient pas",is_empty:"est vide",is_not_empty:"n\u2019est pas vide",starts_with:"commence par",ends_with:"se termine par",in:"est dans la liste",not_in:"n\u2019est pas dans la liste",between:"est entre",regex:"correspond au pattern"},variablePlaceholder:"Variable...",valuePlaceholder:"Valeur",errorMessage:"Message d\u2019erreur",errorMessagePlaceholder:"Message d\u2019erreur de validation",targetVariableCode:"Code de la variable cible",targetVariablePlaceholder:"VAR_CIBLE",valueToSet:"Valeur \xE0 d\xE9finir",valueToSetPlaceholder:"Valeur",modalTitle:e=>`Conditions (${e})`,configureButton:e=>e===0?"Configurer les conditions":`Configurer les conditions (${e})`,applyButton:"Appliquer",cancelButton:"Annuler",closeButton:"Fermer",formulasSummary:"Formules configur\xE9es",noConditions:"Aucune condition configur\xE9e",modeVisual:"Constructeur visuel",modeManual:"Saisie manuelle",manualWarning:"Expression complexe \u2014 le constructeur visuel ne peut pas la repr\xE9senter. Restez en mode manuel pour la modifier.",manualPlaceholder:"Ex : show(${AGE} >= 18)",manualHelp:"Fonctions : show / hide / setValue / validate / require / readonly / ConditionEval. Variables : ${CODE}.",validationExpression:"Expression de validation",validationExpressionPlaceholder:'Ex : ${CHAMP} != ""'},dataSource:{title:"Source de donn\xE9es",connector:"Connecteur",none:"Aucune (options statiques)",connectedTo:"Connect\xE9 \xE0 :",dependencies:e=>`D\xE9pendances (${e})`,selectVariable:"S\xE9lectionner une variable...",dependencyKeyPlaceholder:"Cl\xE9 de d\xE9pendance (ex : parentId)",addDependency:"+ Ajouter"},formTypesDialog:{dialogAriaLabel:"Types de formulaires",title:"Types de formulaires",closeAriaLabel:"Fermer",noTypes:"Aucun type d\xE9fini. Ajoutez-en un ci-dessous.",confirmDelete:"Ce type est utilis\xE9 par le formulaire courant. Confirmer la suppression ?",deleteConfirm:"Supprimer",deleteCancel:"Annuler",removeTypeAria:e=>`Supprimer ${e}`,newTypeNamePlaceholder:"Nom du nouveau type",newTypeCodePlaceholder:"CODE (auto)",addButton:"+ Ajouter"},formEditor:{previewMissing:"Passer la prop PreviewComponent pour activer l\u2019aper\xE7u"}};var eo={toolbar:{formNamePlaceholder:"Form name",unsaved:"Unsaved",addPage:"+ Page",formProperties:"Form properties",types:"Types",manageFormTypesTitle:"Manage form types",undo:"Undo",redo:"Redo",save:"Save",saving:"Saving...",export:"Export",import:"Import",viewEditor:"Editor",viewPreview:"Preview",viewJson:"JSON"},toolbox:{searchPlaceholder:"Search fields...",addPageFirst:"Add a page first",tabFields:"Fields",tabVariables:"Variables",noTemplates:"No variables in this scope",noScope:"Configure a scope to access the variable library",groupText:"Text",groupSelection:"Selection",groupDateTime:"Date & Time",groupMedia:"Media",groupAdvanced:"Advanced",groupRoster:"Roster",typeRosterCheck:"Checks",typeRosterList:"List",typeRosterCollection:"Collection",typeRosterCollectionExtend:"Collection extended",types:{text:"Text",textarea:"Text Area",number:"Number",email:"Email",select:"Dropdown",multiselect:"Multi Select",radio:"Radio",checkbox:"Checkbox",date:"Date",datetime:"DateTime",time:"Time",file:"File",image:"Image",gps:"GPS",rating:"Rating (stars)",calculated:"Calculated",hidden:"Hidden",label:"Label"}},canvas:{emptyStateNoPage:'Click "+ Page" in the toolbar to get started',emptyStateNoPageDnd:"Drag a field from the toolbox or add a page to get started",emptyStatePage:"Click a field type in the toolbox to add it here",unnamedPage:"Unnamed Page",repeatable:"Repeatable",fieldsRostersCount:(e,r)=>`${e} field${e===1?"":"s"} \xB7 ${r} roster${r===1?"":"s"}`,fieldsCount:e=>`${e} field${e===1?"":"s"}`,rosterVarsCount:e=>`${e} var${e===1?"":"s"}`,addRoster:"+ Add Roster",addFieldToRoster:"+ Add field to roster",pilotPrefix:"pilot:",newRosterName:"New Roster",newFieldName:"New field",newVariableName:e=>`New ${e}`,hasConditionsTitle:"Has conditions",dataSourceConnectedTitle:"Data source connected"},properties:{title:"Properties",name:"Name",code:"Code",description:"Description",placeholder:"Placeholder",version:"Version",formType:"Form type",noType:"\u2014 No type \u2014",formSummary:(e,r)=>`${e} page${e===1?"":"s"} \xB7 ${r} variable${r===1?"":"s"}`,pageSummary:(e,r)=>`${e} variable${e===1?"":"s"} \xB7 ${r} roster${r===1?"":"s"}`,rosterSummary:(e,r)=>`${e} variable${e===1?"":"s"} \xB7 ${r} option${r===1?"":"s"}`,repeatablePage:"Repeatable page",minInstances:"Min instances",maxInstances:"Max instances",controlVariableCode:"Control variable code",instanceLabel:"Instance label template",rosterType:"Roster Type",pilotVariableCode:"Pilot variable code",rosterTypes:{check:"Check (multi-select checkboxes)",list:"List (dropdown per row)",collection:"Collection (add/remove rows)",collection_extend:"Collection Extended (table view)"},linkedTemplate:"Linked to variable library",templateCode:"Code (read-only)",templateName:"Name (read-only)",resetOverride:"Reset",type:"Type",ratingStyle:"Rating style",ratingStyles:{star:"\u2605 Stars",number:"123 Numbers",color:"\u25CF Color dots"},layout:"Layout",startNewRow:"Start new row",columnSpan:"Column span (1-12)",columnSpanAuto:"Auto (equal share)",columnSpanHalf:" (half)",columnSpanThird:" (third)",columnSpanFull:" (full)",required:"Required",readonly:"Read only",hidden:"Hidden by default",expression:"Expression",scopes:"Scopes (variable library)",scopesHint:"Order defines priority: the first scope wins on code conflicts.",noScopesAvailable:"No scope available \u2014 create one via the API or seed.",moveScopeUp:"Move up",moveScopeDown:"Move down",removeScope:"Remove",langConfigSection:"Languages",langConfigAvailable:"Available languages",langConfigDefault:"Default language",langConfigStrategy:"Detection strategy",langConfigStrategies:{prop:"Prop (host-controlled)",browser:"Browser",selector:"In-form selector",auto:"Auto (browser then default)"},langConfigSelectorPosition:"Selector position",langConfigPositions:{top:"Top",bottom:"Bottom"},langConfigConfirmRemove:e=>`Removing "${e.toUpperCase()}" will delete every ${e.toUpperCase()} translation. Confirm?`,langConfigConfirmYes:"Delete",langConfigConfirmNo:"Cancel"},optionsEditor:{optionsCount:e=>`Options (${e})`,noOptions:"No options yet \u2014 add one to populate the choices.",optionLabelPlaceholder:"Label",optionValuePlaceholder:"value",addOption:"+ Add option",optionLabelAria:e=>`Option ${e+1} label`,optionValueAria:e=>`Option ${e+1} value`,removeOptionAria:e=>`Remove option ${e+1}`},conditionBuilder:{conditionsCount:e=>`Conditions (${e})`,addCondition:"+ Add condition",rulesCount:e=>` (${e} rule${e===1?"":"s"})`,addRule:"+ Add rule",action:"Action",match:"Match",all:"ALL (AND)",any:"ANY (OR)",actions:{show:"Show when",hide:"Hide when",validate:"Validate that",require:"Require when",readonly:"Read-only when",setValue:"Set value when"},operators:{equals:"equals",not_equals:"not equals",greater_than:"greater than",less_than:"less than",greater_than_or_equal:"greater than or equal",less_than_or_equal:"less than or equal",contains:"contains",not_contains:"not contains",is_empty:"is empty",is_not_empty:"is not empty",starts_with:"starts with",ends_with:"ends with",in:"in",not_in:"not in",between:"between",regex:"matches regex"},variablePlaceholder:"Variable...",valuePlaceholder:"Value",errorMessage:"Error message",errorMessagePlaceholder:"Validation error message",targetVariableCode:"Target variable code",targetVariablePlaceholder:"TARGET_VAR",valueToSet:"Value to set",valueToSetPlaceholder:"Value",modalTitle:e=>`Conditions (${e})`,configureButton:e=>e===0?"Configure conditions":`Configure conditions (${e})`,applyButton:"Apply",cancelButton:"Cancel",closeButton:"Close",formulasSummary:"Configured formulas",noConditions:"No condition configured",modeVisual:"Visual builder",modeManual:"Manual input",manualWarning:"Complex expression \u2014 the visual builder cannot represent it. Stay in manual mode to edit it.",manualPlaceholder:"e.g. show(${AGE} >= 18)",manualHelp:"Functions: show / hide / setValue / validate / require / readonly / ConditionEval. Variables: ${CODE}.",validationExpression:"Validation expression",validationExpressionPlaceholder:'e.g. ${FIELD} != ""'},dataSource:{title:"Data Source Connector",connector:"Connector",none:"None (static options)",connectedTo:"Connected to:",dependencies:e=>`Dependencies (${e})`,selectVariable:"Select variable...",dependencyKeyPlaceholder:"Dependency key (e.g. parentId)",addDependency:"+ Add"},formTypesDialog:{dialogAriaLabel:"Form types",title:"Form types",closeAriaLabel:"Close",noTypes:"No form types yet. Add one below.",confirmDelete:"This type is used by the current form. Confirm deletion?",deleteConfirm:"Delete",deleteCancel:"Cancel",removeTypeAria:e=>`Remove ${e}`,newTypeNamePlaceholder:"New type name",newTypeCodePlaceholder:"CODE (auto)",addButton:"+ Add"},formEditor:{previewMissing:"Pass PreviewComponent prop to enable preview"}};var oo=wr.createContext(Z);function xe({labels:e,children:r}){return jsxRuntime.jsx(oo.Provider,{value:e,children:r})}function R(){return wr.useContext(oo)}function ye(e){if(e===null||typeof e!="object")return false;let r=Object.getPrototypeOf(e);return r===Object.prototype||r===null}function ve(e,r){return r?to(e,r):e}function to(e,r){if(!ye(e)||!ye(r))return r===void 0?e:r;let a={...e};for(let n of Object.keys(r)){let o=e[n],t=r[n];ye(o)&&ye(t)?a[n]=to(o,t):t!==void 0&&(a[n]=t);}return a}function ro({open:e,onClose:r}){let{formTypes:a,form:n,addFormType:o,updateFormType:t,removeFormType:l}=S(),i=R(),[s,d]=wr.useState(""),[c,y]=wr.useState(""),[m,p]=wr.useState(null),[b,g]=wr.useState(""),[u,f]=wr.useState(null);if(!e)return null;let x=()=>{s.trim()&&(o({name:s.trim(),code:c.trim()||s.trim().toUpperCase().replace(/\s+/g,"_")}),d(""),y(""));},I=(C,N)=>{p(C),g(N);},L=()=>{m&&b.trim()&&t(m,{name:b.trim()}),p(null),g("");},v=C=>{n.formTypeId===C?f(C):l(C);},k=()=>{u&&l(u),f(null);};return jsxRuntime.jsx("div",{role:"dialog","aria-modal":"true","aria-label":i.formTypesDialog.dialogAriaLabel,"data-testid":"form-types-dialog",onClick:r,style:{position:"fixed",inset:0,backgroundColor:"rgba(0, 0, 0, 0.3)",zIndex:50,display:"flex",alignItems:"center",justifyContent:"center",padding:"16px"},children:jsxRuntime.jsxs("div",{onClick:C=>C.stopPropagation(),style:{backgroundColor:"#fff",borderRadius:"8px",maxWidth:"32rem",width:"100%",maxHeight:"80vh",overflow:"auto",boxShadow:"0 10px 25px rgba(0,0,0,0.2)",fontFamily:"system-ui, -apple-system, sans-serif",color:"#1e293b"},children:[jsxRuntime.jsxs("header",{style:{padding:"16px",borderBottom:"1px solid #e2e8f0",display:"flex",justifyContent:"space-between",alignItems:"center"},children:[jsxRuntime.jsx("h3",{style:{fontSize:"16px",fontWeight:600,margin:0},children:i.formTypesDialog.title}),jsxRuntime.jsx("button",{type:"button",onClick:r,"aria-label":i.formTypesDialog.closeAriaLabel,"data-testid":"form-types-dialog-close-x",style:{background:"transparent",border:"none",fontSize:"18px",cursor:"pointer",color:"#64748b",padding:"4px 8px"},children:"\xD7"})]}),jsxRuntime.jsxs("section",{style:{padding:"16px"},children:[a.length===0&&jsxRuntime.jsx("div",{"data-testid":"form-types-empty",style:{fontSize:"13px",color:"#94a3b8",marginBottom:"12px"},children:i.formTypesDialog.noTypes}),jsxRuntime.jsx("ul",{style:{listStyle:"none",padding:0,margin:0,display:"flex",flexDirection:"column",gap:"6px"},children:a.map(C=>{let N=m===C.id,oe=n.formTypeId===C.id,ue=u===C.id;return jsxRuntime.jsxs("li",{"data-testid":`form-type-row-${C.id}`,style:{display:"flex",alignItems:"center",gap:"8px",padding:"8px",border:"1px solid #e2e8f0",borderRadius:"6px",backgroundColor:oe?"#f1f5f9":"#fff"},children:[N?jsxRuntime.jsx("input",{type:"text",value:b,autoFocus:true,"data-testid":`form-type-name-edit-${C.id}`,onChange:se=>g(se.target.value),onBlur:L,onKeyDown:se=>{se.key==="Enter"&&L(),se.key==="Escape"&&(p(null),g(""));},style:{flex:1,padding:"4px 8px",border:"1px solid #cbd5e1",borderRadius:"4px",fontSize:"13px",color:"#000",outline:"none"}}):jsxRuntime.jsx("span",{"data-testid":`form-type-name-${C.id}`,onClick:()=>I(C.id,C.name),style:{flex:1,fontSize:"13px",cursor:"pointer",padding:"4px 8px"},children:C.name}),jsxRuntime.jsx("span",{style:{fontSize:"11px",color:"#94a3b8",fontFamily:"monospace"},children:C.code}),jsxRuntime.jsx("button",{type:"button","aria-label":i.formTypesDialog.removeTypeAria(C.name),"data-testid":`form-type-remove-${C.id}`,onClick:()=>v(C.id),style:{width:"24px",height:"24px",border:"1px solid #e2e8f0",borderRadius:"4px",backgroundColor:"#fff",color:"#64748b",cursor:"pointer",fontSize:"14px",lineHeight:1},children:"\xD7"}),ue&&jsxRuntime.jsxs("div",{"data-testid":`form-type-confirm-${C.id}`,style:{flexBasis:"100%",fontSize:"12px",color:"#b91c1c",backgroundColor:"#fef2f2",padding:"6px 8px",borderRadius:"4px",display:"flex",alignItems:"center",gap:"8px"},children:[jsxRuntime.jsx("span",{style:{flex:1},children:i.formTypesDialog.confirmDelete}),jsxRuntime.jsx("button",{type:"button","data-testid":`form-type-confirm-yes-${C.id}`,onClick:k,style:{padding:"4px 8px",border:"none",borderRadius:"4px",backgroundColor:"#ef4444",color:"#fff",fontSize:"12px",cursor:"pointer"},children:i.formTypesDialog.deleteConfirm}),jsxRuntime.jsx("button",{type:"button","data-testid":`form-type-confirm-no-${C.id}`,onClick:()=>f(null),style:{padding:"4px 8px",border:"1px solid #e2e8f0",borderRadius:"4px",backgroundColor:"#fff",color:"#334155",fontSize:"12px",cursor:"pointer"},children:i.formTypesDialog.deleteCancel})]})]},C.id)})})]}),jsxRuntime.jsxs("section",{style:{padding:"12px 16px",borderTop:"1px solid #e2e8f0",display:"flex",alignItems:"center",gap:"8px",backgroundColor:"#f8fafc"},children:[jsxRuntime.jsx("input",{type:"text",value:s,"data-testid":"form-types-new-name",placeholder:i.formTypesDialog.newTypeNamePlaceholder,onChange:C=>d(C.target.value),onKeyDown:C=>{C.key==="Enter"&&x();},style:{flex:1,padding:"6px 8px",border:"1px solid #cbd5e1",borderRadius:"4px",fontSize:"13px",color:"#000",outline:"none"}}),jsxRuntime.jsx("input",{type:"text",value:c,"data-testid":"form-types-new-code",placeholder:i.formTypesDialog.newTypeCodePlaceholder,onChange:C=>y(C.target.value),style:{width:"120px",padding:"6px 8px",border:"1px solid #cbd5e1",borderRadius:"4px",fontSize:"13px",color:"#000",outline:"none",fontFamily:"monospace"}}),jsxRuntime.jsx("button",{type:"button","data-testid":"form-types-add",onClick:x,disabled:s.trim()==="",style:{padding:"6px 12px",border:"none",borderRadius:"4px",backgroundColor:s.trim()===""?"#cbd5e1":"#2563eb",color:"#fff",fontSize:"13px",cursor:s.trim()===""?"not-allowed":"pointer"},children:i.formTypesDialog.addButton})]})]})})}function Fe({onSave:e,onExport:r,onImport:a}){let{form:n,updateFormMeta:o,view:t,setView:l,isDirty:i,isSaving:s,canUndo:d,canRedo:c,undo:y,redo:m,save:p,addPage:b,select:g}=S(),u=R(),[f,x]=wr.useState(false),I=async()=>{await p(),e?.();},L=()=>{let k=n.pages.length;b({id:`page-${Date.now()}`,code:`PAGE_${k+1}`,name:`Page ${k+1}`,order:k,isRepeatable:false,items:[]});},v=[{view:"canvas",label:u.toolbar.viewEditor},{view:"preview",label:u.toolbar.viewPreview},{view:"json",label:u.toolbar.viewJson}];return jsxRuntime.jsxs("div",{style:{display:"flex",alignItems:"center",padding:"8px 16px",borderBottom:"1px solid #e2e8f0",backgroundColor:"#fff",gap:"8px"},children:[jsxRuntime.jsx("input",{type:"text",value:formCore.resolveLabel(n.name,n.langConfig?.defaultLang??formCore.DEFAULT_LANG_CONFIG.defaultLang,n.langConfig?.defaultLang??formCore.DEFAULT_LANG_CONFIG.defaultLang),onChange:k=>{let C=n.langConfig?.defaultLang??formCore.DEFAULT_LANG_CONFIG.defaultLang,N;typeof n.name=="string"?N=k.target.value:N={...n.name??{},[C]:k.target.value},o({name:N});},style:{border:"none",fontSize:"16px",fontWeight:600,color:"#1e293b",padding:"4px 8px",borderRadius:"4px",outline:"none",minWidth:"200px",backgroundColor:"transparent"},placeholder:u.toolbar.formNamePlaceholder}),i&&jsxRuntime.jsx("span",{style:{fontSize:"11px",color:"#f59e0b",fontWeight:500},children:u.toolbar.unsaved}),jsxRuntime.jsx("div",{style:{flex:1}}),jsxRuntime.jsx("button",{type:"button",onClick:()=>g({type:"form"}),title:u.toolbar.formProperties,"data-testid":"toolbar-form-properties","aria-label":u.toolbar.formProperties,style:{padding:"6px 10px",borderRadius:"6px",border:"1px solid #e2e8f0",backgroundColor:"#fff",color:"#334155",fontSize:"14px",cursor:"pointer"},children:"\u2699"}),jsxRuntime.jsx(re,{onClick:L,label:u.toolbar.addPage}),jsxRuntime.jsx(re,{onClick:()=>x(true),label:u.toolbar.types,title:u.toolbar.manageFormTypesTitle}),jsxRuntime.jsx("div",{style:{width:"1px",height:"24px",backgroundColor:"#e2e8f0"}}),jsxRuntime.jsx(re,{onClick:y,label:"\u21A9",disabled:!d(),title:u.toolbar.undo}),jsxRuntime.jsx(re,{onClick:m,label:"\u21AA",disabled:!c(),title:u.toolbar.redo}),jsxRuntime.jsx("div",{style:{width:"1px",height:"24px",backgroundColor:"#e2e8f0"}}),jsxRuntime.jsx("div",{style:{display:"flex",borderRadius:"6px",overflow:"hidden",border:"1px solid #e2e8f0"},children:v.map(k=>jsxRuntime.jsx("button",{type:"button",onClick:()=>l(k.view),style:{padding:"4px 12px",fontSize:"12px",fontWeight:500,border:"none",cursor:"pointer",backgroundColor:t===k.view?"#2563eb":"#fff",color:t===k.view?"#fff":"#64748b"},children:k.label},k.view))}),jsxRuntime.jsx("div",{style:{width:"1px",height:"24px",backgroundColor:"#e2e8f0"}}),jsxRuntime.jsx(re,{onClick:I,label:s?u.toolbar.saving:u.toolbar.save,primary:true,disabled:s||!i}),r&&jsxRuntime.jsx(re,{onClick:r,label:u.toolbar.export}),a&&jsxRuntime.jsx(re,{onClick:a,label:u.toolbar.import}),jsxRuntime.jsx(ro,{open:f,onClose:()=>x(false)})]})}function re({onClick:e,label:r,primary:a,disabled:n,title:o}){return jsxRuntime.jsx("button",{type:"button",onClick:e,disabled:n,title:o,style:{padding:"6px 12px",borderRadius:"6px",border:a?"none":"1px solid #e2e8f0",backgroundColor:a?"#2563eb":"#fff",color:a?"#fff":"#334155",fontSize:"13px",fontWeight:500,cursor:n?"default":"pointer",opacity:n?.5:1},children:r})}function Ce(){let e=R(),[r,a]=wr.useState("fields"),[n,o]=wr.useState(""),{form:t,availableTemplates:l}=S(),i=t.langConfig?.defaultLang??formCore.DEFAULT_LANG_CONFIG.defaultLang,d=wr.useMemo(()=>[{label:e.toolbox.groupText,items:[{kind:"variable",type:"text",label:e.toolbox.types.text,icon:"T"},{kind:"variable",type:"textarea",label:e.toolbox.types.textarea,icon:"\xB6"},{kind:"variable",type:"number",label:e.toolbox.types.number,icon:"#"}]},{label:e.toolbox.groupSelection,items:[{kind:"variable",type:"select",label:e.toolbox.types.select,icon:"\u25BC"},{kind:"variable",type:"multiselect",label:e.toolbox.types.multiselect,icon:"\u2611"},{kind:"variable",type:"radio",label:e.toolbox.types.radio,icon:"\u25C9"},{kind:"variable",type:"checkbox",label:e.toolbox.types.checkbox,icon:"\u2610"}]},{label:e.toolbox.groupDateTime,items:[{kind:"variable",type:"date",label:e.toolbox.types.date,icon:"\u{1F4C5}"},{kind:"variable",type:"datetime",label:e.toolbox.types.datetime,icon:"\u{1F550}"},{kind:"variable",type:"time",label:e.toolbox.types.time,icon:"\u23F0"}]},{label:e.toolbox.groupAdvanced,items:[{kind:"variable",type:"file",label:e.toolbox.types.file,icon:"\u{1F4CE}"},{kind:"variable",type:"gps",label:e.toolbox.types.gps,icon:"\u{1F4CD}"},{kind:"variable",type:"calculated",label:e.toolbox.types.calculated,icon:"fx"},{kind:"variable",type:"hidden",label:e.toolbox.types.hidden,icon:"\u{1F441}"},{kind:"variable",type:"label",label:e.toolbox.types.label,icon:"Aa"}]},{label:e.toolbox.groupRoster,items:[{kind:"roster",rosterType:"check",label:e.toolbox.typeRosterCheck,icon:"\u25A4"},{kind:"roster",rosterType:"list",label:e.toolbox.typeRosterList,icon:"\u25A6"},{kind:"roster",rosterType:"collection",label:e.toolbox.typeRosterCollection,icon:"\u25A5"},{kind:"roster",rosterType:"collection_extend",label:e.toolbox.typeRosterCollectionExtend,icon:"\u25A9"}]}],[e]).map(c=>({...c,items:c.items.filter(y=>y.label.toLowerCase().includes(n.toLowerCase()))})).filter(c=>c.items.length>0);return jsxRuntime.jsxs("div",{style:{width:"220px",borderRight:"1px solid #e2e8f0",display:"flex",flexDirection:"column",backgroundColor:"#f8fafc",overflow:"hidden"},children:[jsxRuntime.jsx(st,{tab:r,setTab:a,labels:e}),jsxRuntime.jsx("div",{style:{padding:"12px",borderBottom:"1px solid #e2e8f0"},children:jsxRuntime.jsx("input",{type:"text",placeholder:e.toolbox.searchPlaceholder,value:n,onChange:c=>o(c.target.value),style:{width:"100%",padding:"6px 10px",border:"1px solid #e2e8f0",borderRadius:"6px",fontSize:"13px",outline:"none",boxSizing:"border-box"}})}),jsxRuntime.jsxs("div",{style:{flex:1,overflowY:"auto",padding:"8px"},children:[r==="fields"&&d.map(c=>jsxRuntime.jsxs("div",{style:{marginBottom:"16px"},children:[jsxRuntime.jsx("div",{style:{fontSize:"11px",fontWeight:600,color:"#94a3b8",textTransform:"uppercase",letterSpacing:"0.5px",marginBottom:"6px",padding:"0 4px"},children:c.label}),c.items.map(y=>jsxRuntime.jsx(dt,{entry:y},`${y.kind}-${y.kind==="roster"?y.rosterType:y.type}`))]},c.label)),r==="variables"&&jsxRuntime.jsx(pt,{templates:l,scopeIds:t.scopeIds,search:n,defaultLang:i,labels:e})]})]})}function st({tab:e,setTab:r,labels:a}){let n={flex:1,padding:"8px 0",fontSize:"12px",fontWeight:500,textAlign:"center",cursor:"pointer",userSelect:"none",color:"#64748b",borderBottomWidth:"2px",borderBottomStyle:"solid",borderBottomColor:"transparent"},o={...n,color:"#2563eb",fontWeight:600,borderBottomColor:"#2563eb"};return jsxRuntime.jsxs("div",{style:{display:"flex",borderBottom:"1px solid #e2e8f0",backgroundColor:"#fff"},children:[jsxRuntime.jsx("div",{role:"tab","aria-selected":e==="fields","data-testid":"toolbox-tab-fields",onClick:()=>r("fields"),style:e==="fields"?o:n,children:a.toolbox.tabFields}),jsxRuntime.jsx("div",{role:"tab","aria-selected":e==="variables","data-testid":"toolbox-tab-variables",onClick:()=>r("variables"),style:e==="variables"?o:n,children:a.toolbox.tabVariables})]})}function dt({entry:e}){let r=e.kind==="roster"?`toolbox-roster-${e.rosterType}`:`toolbox-variable-${e.type}`,a=e.kind==="roster"?{type:"new-roster",rosterType:e.rosterType}:{type:"new-variable",variableType:e.type},{attributes:n,listeners:o,setNodeRef:t,isDragging:l}=core.useDraggable({id:r,data:a});return jsxRuntime.jsxs("div",{ref:t,"data-testid":r,...o,...n,style:{display:"flex",alignItems:"center",gap:"8px",padding:"6px 8px",marginBottom:"2px",borderRadius:"6px",cursor:"grab",fontSize:"13px",color:"#334155",backgroundColor:l?"#e2e8f0":"transparent",userSelect:"none"},children:[jsxRuntime.jsx("span",{style:{width:"20px",textAlign:"center",fontSize:"14px"},children:e.icon}),jsxRuntime.jsx("span",{children:e.label})]})}function pt({templates:e,scopeIds:r,search:a,defaultLang:n,labels:o}){let t=s=>jsxRuntime.jsx("div",{"data-testid":"toolbox-variables-empty",style:{padding:"14px",color:"#94a3b8",fontSize:"12px",textAlign:"center",fontStyle:"italic"},children:s});if(!r||r.length===0)return t(o.toolbox.noScope);if(e.length===0)return t(o.toolbox.noTemplates);let l=a.toLowerCase(),i=e.filter(s=>{if(!l)return true;let d=s.code.toLowerCase().includes(l),c=io(s.name,n).toLowerCase().includes(l);return d||c}).slice().sort((s,d)=>s.code.localeCompare(d.code));return i.length===0?t(o.toolbox.noTemplates):jsxRuntime.jsx("div",{style:{display:"flex",flexDirection:"column",gap:"4px"},children:i.map(s=>jsxRuntime.jsx(ct,{template:s,defaultLang:n},s.id))})}function ct({template:e,defaultLang:r}){let a=`toolbox-template-${e.code}`,{attributes:n,listeners:o,setNodeRef:t,isDragging:l}=core.useDraggable({id:a,data:{type:"new-variable-from-template",template:e}});return jsxRuntime.jsxs("div",{ref:t,"data-testid":a,...o,...n,style:{display:"flex",alignItems:"center",gap:"8px",padding:"6px 8px",borderRadius:"6px",cursor:"grab",fontSize:"13px",color:"#334155",backgroundColor:l?"#e2e8f0":"transparent",userSelect:"none"},children:[jsxRuntime.jsx("span",{style:{fontSize:"10px",fontWeight:600,padding:"2px 6px",borderRadius:"4px",backgroundColor:"#e0e7ff",color:"#3730a3",textTransform:"uppercase",letterSpacing:"0.3px",minWidth:"42px",textAlign:"center"},children:e.variableType}),jsxRuntime.jsxs("div",{style:{display:"flex",flexDirection:"column",minWidth:0,flex:1},children:[jsxRuntime.jsx("span",{style:{fontFamily:"monospace",fontSize:"11px",color:"#475569",whiteSpace:"nowrap",overflow:"hidden",textOverflow:"ellipsis"},children:e.code}),jsxRuntime.jsx("span",{style:{fontSize:"12px",color:"#1e293b",whiteSpace:"nowrap",overflow:"hidden",textOverflow:"ellipsis"},children:io(e.name,r)})]})]})}function io(e,r){return formCore.resolveLabel(e,r,r)}function Ee(){let r=S(a=>a.form).langConfig?.defaultLang??formCore.DEFAULT_LANG_CONFIG.defaultLang;return a=>formCore.resolveLabel(a,r,r)}function he(){let{form:e,select:r}=S(),a=R(),n=l=>{l.target===l.currentTarget&&r({type:"form"});};if(e.pages.length===0)return jsxRuntime.jsx("div",{"data-testid":"canvas-empty",onClick:n,style:{flex:1,display:"flex",alignItems:"center",justifyContent:"center",color:"#94a3b8",fontSize:"14px",cursor:"pointer"},children:a.canvas.emptyStateNoPageDnd});let o=e.pages.slice().sort((l,i)=>l.order-i.order),t=o.map(l=>`page-${l.code}`);return jsxRuntime.jsx("div",{"data-testid":"canvas-root",onClick:n,style:{flex:1,overflowY:"auto",padding:"16px",backgroundColor:"#fff"},children:jsxRuntime.jsx(sortable.SortableContext,{items:t,strategy:sortable.verticalListSortingStrategy,children:o.map(l=>jsxRuntime.jsx(gt,{page:l},l.code))})})}function gt({page:e}){let{selection:r,select:a}=S(),n=R(),o=Ee(),t=r.type==="page"&&r.pageCode===e.code,{attributes:l,listeners:i,setNodeRef:s,transform:d,transition:c,isDragging:y,isOver:m}=sortable.useSortable({id:`page-${e.code}`,data:{type:"page",pageCode:e.code}}),p=(e.items??[...formCore.getPageVariables(e),...e.rosters??[]]).slice().sort((g,u)=>g.order-u.order),b=p.filter(g=>!formCore.isPageRoster(g)).length;return jsxRuntime.jsxs("div",{ref:s,style:{marginBottom:"16px",border:`2px solid ${t?"#2563eb":m?"#93c5fd":"#e2e8f0"}`,borderRadius:"8px",overflow:"hidden",transform:utilities.CSS.Transform.toString(d),transition:c,opacity:y?.6:1},children:[jsxRuntime.jsxs("div",{onClick:()=>a({type:"page",pageCode:e.code}),style:{padding:"10px 14px",backgroundColor:t?"#eff6ff":"#f8fafc",borderBottom:"1px solid #e2e8f0",cursor:"pointer",display:"flex",alignItems:"center",justifyContent:"space-between"},children:[jsxRuntime.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"8px"},children:[jsxRuntime.jsx("span",{...l,...i,"data-testid":`canvas-page-drag-handle-${e.code}`,"aria-label":`Reorder page ${e.code}`,title:"Drag to reorder",onClick:g=>g.stopPropagation(),style:{color:"#94a3b8",fontSize:"14px",cursor:"grab",padding:"2px 6px",borderRadius:"4px",userSelect:"none",touchAction:"none"},children:"\u283F"}),jsxRuntime.jsx("span",{style:{fontSize:"14px",fontWeight:600,color:"#1e293b"},children:o(e.name)||n.canvas.unnamedPage}),e.isRepeatable&&jsxRuntime.jsx("span",{style:{fontSize:"10px",padding:"1px 6px",borderRadius:"4px",backgroundColor:"#dbeafe",color:"#2563eb",fontWeight:500},children:n.canvas.repeatable})]}),jsxRuntime.jsx("span",{style:{fontSize:"12px",color:"#94a3b8"},children:n.canvas.fieldsCount(b)})]}),jsxRuntime.jsx(sortable.SortableContext,{items:p.map(g=>g.code),strategy:sortable.verticalListSortingStrategy,children:jsxRuntime.jsx("div",{style:{padding:"4px 0"},children:p.map(g=>formCore.isPageRoster(g)?jsxRuntime.jsx(yt,{roster:g,pageCode:e.code},g.code):jsxRuntime.jsx(co,{variable:g,pageCode:e.code},g.code))})})]})}function co({variable:e,pageCode:r,rosterCode:a}){let{selection:n,select:o}=S(),t=R(),l=Ee(),i=n.type==="variable"&&n.pageCode===r&&n.variableCode===e.code,{attributes:s,listeners:d,setNodeRef:c,transform:y,transition:m,isDragging:p}=sortable.useSortable({id:e.code,data:{type:"variable",pageCode:r,variableCode:e.code,rosterCode:a}});return jsxRuntime.jsxs("div",{ref:c,...s,...d,onClick:b=>{b.stopPropagation(),o({type:"variable",pageCode:r,variableCode:e.code,rosterCode:a});},style:{display:"flex",alignItems:"center",gap:"8px",padding:"6px 14px",margin:"1px 0",cursor:"pointer",backgroundColor:i?"#eff6ff":p?"#f1f5f9":"transparent",borderLeft:i?"3px solid #2563eb":"3px solid transparent",transform:utilities.CSS.Transform.toString(y),transition:m,opacity:p?.5:1,fontSize:"13px"},children:[jsxRuntime.jsx("span",{style:{color:"#94a3b8",fontSize:"11px",width:"60px",flexShrink:0},children:e.type}),jsxRuntime.jsx("span",{style:{color:"#334155",flex:1},children:l(e.name)||e.code}),e.isRequired&&jsxRuntime.jsx("span",{style:{color:"#ef4444",fontSize:"11px"},children:"*"}),e.conditions&&e.conditions.length>0&&jsxRuntime.jsx("span",{style:{color:"#f59e0b",fontSize:"11px"},title:t.canvas.hasConditionsTitle,children:"\u26A1"}),e.dataSourceId&&jsxRuntime.jsx("span",{style:{color:"#22c55e",fontSize:"11px"},title:t.canvas.dataSourceConnectedTitle,children:"\u27F3"})]})}function yt({roster:e,pageCode:r}){let{selection:a,select:n,addVariable:o}=S(),t=R(),l=Ee(),i=a.type==="roster"&&a.pageCode===r&&a.rosterCode===e.code,{attributes:s,listeners:d,setNodeRef:c,transform:y,transition:m,isDragging:p}=sortable.useSortable({id:e.code,data:{type:"roster",pageCode:r,rosterCode:e.code}}),{setNodeRef:b,isOver:g}=core.useDroppable({id:`roster-drop-${e.code}`,data:{type:"roster-drop",pageCode:r,rosterCode:e.code}}),u=f=>{f.stopPropagation();let x=`RV_${Date.now().toString(36).slice(-4).toUpperCase()}`;o(r,{id:`var-${Date.now()}`,code:x,name:t.canvas.newFieldName,type:"text",order:e.variables.length,isRequired:false,isReadonly:false,isHidden:false},e.code);};return jsxRuntime.jsxs("div",{ref:c,style:{margin:"4px 8px",border:`1px solid ${i?"#2563eb":g?"#f59e0b":"#e2e8f0"}`,borderRadius:"6px",overflow:"hidden",backgroundColor:g?"#fefce8":void 0,transform:utilities.CSS.Transform.toString(y),transition:m,opacity:p?.5:1},children:[jsxRuntime.jsxs("div",{...s,...d,onClick:f=>{f.stopPropagation(),n({type:"roster",pageCode:r,rosterCode:e.code});},style:{padding:"6px 10px",backgroundColor:i?"#fef3c7":"#fffbeb",fontSize:"12px",fontWeight:600,color:"#92400e",cursor:"grab",display:"flex",alignItems:"center",gap:"6px"},children:[jsxRuntime.jsx("span",{style:{fontSize:"10px"},children:"\u25A4"}),l(e.name)||e.code," (",e.rosterType,")"]}),jsxRuntime.jsxs("div",{ref:b,children:[e.variables.slice().sort((f,x)=>f.order-x.order).map(f=>jsxRuntime.jsx(co,{variable:f,pageCode:r,rosterCode:e.code},f.code)),jsxRuntime.jsx("div",{style:{padding:"4px 10px",borderTop:"1px solid #fde68a"},children:jsxRuntime.jsx("button",{type:"button",onClick:u,"data-testid":`canvas-add-field-to-roster-${e.code}`,style:{padding:"2px 8px",borderRadius:"3px",border:"1px dashed #d4a843",backgroundColor:"transparent",color:"#92400e",fontSize:"10px",cursor:"pointer"},children:t.canvas.addFieldToRoster})})]})]})}function Ft(e,r){let a=e.pages.find(n=>n.code===r);return a?Array.isArray(a.items)?a.items.slice().sort((n,o)=>n.order-o.order):[...formCore.getPageVariables(a),...formCore.getPageRosters(a)].sort((n,o)=>n.order-o.order):null}function fo(e){return `${e}_${Date.now().toString(36).slice(-4).toUpperCase()}`}function mo(e,r){return a=>{let{active:n,over:o}=a;if(!n||!o)return;let t=n.data.current;if(!t?.type)return;let l=r(),i=()=>{let s=o.data.current;return s?s.type==="page"&&s.pageCode?{pageCode:s.pageCode}:s.type==="variable"&&s.pageCode?{pageCode:s.pageCode,rosterCode:s.rosterCode}:s.type==="roster"&&s.pageCode?{pageCode:s.pageCode,rosterCode:s.rosterCode}:s.type==="roster-drop"&&s.pageCode?{pageCode:s.pageCode,rosterCode:s.rosterCode}:null:null};if(t.type==="new-variable"){let s=i()??{pageCode:l.pages[0]?.code??""};if(!s.pageCode)return;let d=t.variableType??"text";e.addVariable(s.pageCode,{id:`var-${Date.now()}`,code:fo(d.toUpperCase()),name:`New ${d}`,type:d,order:0,isRequired:false,isReadonly:false,isHidden:false},s.rosterCode);return}if(t.type==="new-roster"){let s=i()??{pageCode:l.pages[0]?.code??""};if(!s.pageCode)return;let d=t.rosterType??"collection";e.addRoster(s.pageCode,{id:`roster-${Date.now()}`,code:fo("ROSTER"),name:"New Roster",rosterType:d,order:0,variables:[]});return}if(t.type==="new-variable-from-template"&&t.template){let s=i()??{pageCode:l.pages[0]?.code??""};if(!s.pageCode)return;e.addVariableFromTemplate(s.pageCode,t.template,s.rosterCode);return}if(t.type==="page"){let s=o.data.current;if(s?.type!=="page"||!s.pageCode||!t.pageCode||t.pageCode===s.pageCode)return;let d=l.pages.slice().sort((p,b)=>p.order-b.order),c=d.findIndex(p=>p.code===t.pageCode),y=d.findIndex(p=>p.code===s.pageCode);if(c===-1||y===-1||c===y)return;let m=sortable.arrayMove(d,c,y).map(p=>p.code);e.reorderPages(m);return}if(t.type==="variable"||t.type==="roster"){let s=o.data.current,d=t.pageCode;if(!d||!s)return;let c=p=>p.type==="roster"||p.type==="variable"&&!p.rosterCode,y=c(t),m=c(s);if(s.pageCode===d&&s.type!=="page"&&y&&m){let p=Ft(l,d);if(!p)return;let b=String(n.id),g=String(o.id);if(b===g)return;let u=p.findIndex(x=>x.code===b),f=p.findIndex(x=>x.code===g);if(u===-1||f===-1)return;e.moveItem(d,u,f);return}if(t.type==="variable"&&t.variableCode){let p=s.pageCode??d,b=s.type==="page"?void 0:s.rosterCode;if(p===d&&(t.rosterCode??void 0)===(b??void 0))return;e.moveVariable(d,p,t.variableCode,0,t.rosterCode,b);return}}}}function ze({children:e}){let r=S(),[a,n]=wr.useState(null),o=core.useSensors(core.useSensor(core.PointerSensor,{activationConstraint:{distance:8}}),core.useSensor(core.KeyboardSensor,{coordinateGetter:sortable.sortableKeyboardCoordinates})),t=wr.useMemo(()=>mo({addVariable:r.addVariable,addRoster:r.addRoster,addVariableFromTemplate:r.addVariableFromTemplate,moveItem:r.moveItem,moveVariable:r.moveVariable,reorderPages:r.reorderPages},()=>S.getState().form),[r.addVariable,r.addRoster,r.addVariableFromTemplate,r.moveItem,r.moveVariable,r.reorderPages]);return jsxRuntime.jsxs(core.DndContext,{sensors:o,collisionDetection:core.closestCenter,onDragStart:i=>{let s=i.active.data.current;s&&(s.type==="new-variable"?n(s.variableType??"variable"):s.type==="new-roster"?n(`roster:${s.rosterType??""}`):s.type==="new-variable-from-template"?n(`tpl:${s.template?.code??""}`):s.type==="variable"?n(s.variableCode??""):s.type==="roster"?n(`\u25A4 ${String(i.active.id)}`):s.type==="page"&&n(`\u{1F4C4} ${s.pageCode??""}`));},onDragEnd:i=>{n(null),t(i);},children:[e,jsxRuntime.jsx(core.DragOverlay,{children:a&&jsxRuntime.jsx("div",{style:{padding:"6px 12px",borderRadius:"6px",backgroundColor:"#2563eb",color:"#fff",fontSize:"13px",fontWeight:500,boxShadow:"0 4px 12px rgba(0,0,0,0.15)"},children:a})})]})}function yo(e,r,a="fr"){if(e==null)return "";if(typeof e=="string")return e;let n=e[r];if(typeof n=="string"&&n!=="")return n;let o=e[a];if(typeof o=="string"&&o!=="")return o;for(let t of Object.values(e))if(typeof t=="string"&&t!=="")return t;return ""}var Se={width:"100%",padding:"6px 8px",border:"1px solid #e2e8f0",borderRadius:"4px",fontSize:"13px",color:"#334155",outline:"none",boxSizing:"border-box"},zt={padding:"4px 10px",border:"1px solid #e2e8f0",borderBottom:"none",borderTopLeftRadius:"4px",borderTopRightRadius:"4px",fontSize:"11px",fontWeight:600,cursor:"pointer",textTransform:"uppercase",letterSpacing:"0.5px",minWidth:"38px"};function go(e,r,a){if(e==null)return "";if(typeof e=="string")return r===a?e:"";let n=e[r];return typeof n=="string"?n:""}function me({value:e,onChange:r,availableLangs:a,defaultLang:n="fr",placeholder:o,multiline:t,testIdPrefix:l,disabled:i}){let s=a.length>0?a:[n],d=s.length>1,[c,y]=wr.useState(s[0]),m=R();s.includes(c)||y(s[0]);let p=(g,u)=>{if(!d){r(u);return}let f=typeof e=="string"?{[n]:e}:{...e??{}};f[g]=u,r(f);};if(!d){let g=s[0],u=go(e,g,n);return t?jsxRuntime.jsx("textarea",{value:u,rows:3,placeholder:o,disabled:i,"data-testid":l?`${l}-${g}`:void 0,onChange:f=>p(g,f.target.value),style:Se}):jsxRuntime.jsx("input",{type:"text",value:u,placeholder:o,disabled:i,"data-testid":l?`${l}-${g}`:void 0,onChange:f=>p(g,f.target.value),style:Se})}let b=go(e,c,n);return jsxRuntime.jsxs("div",{"data-testid":l,style:{display:"flex",flexDirection:"column"},children:[jsxRuntime.jsx("div",{role:"tablist","aria-label":m.properties.title,style:{display:"flex",gap:"2px"},children:s.map(g=>{let u=g===c;return jsxRuntime.jsx("button",{type:"button",role:"tab","aria-selected":u,"data-testid":l?`${l}-tab-${g}`:void 0,onClick:()=>y(g),style:{...zt,backgroundColor:u?"#fff":"#f1f5f9",color:u?"#2563eb":"#64748b",borderColor:"#e2e8f0"},children:g},g)})}),t?jsxRuntime.jsx("textarea",{value:b,rows:3,placeholder:o,disabled:i,"data-testid":l?`${l}-${c}`:void 0,onChange:g=>p(c,g.target.value),style:{...Se,borderTopLeftRadius:0}}):jsxRuntime.jsx("input",{type:"text",value:b,placeholder:o,disabled:i,"data-testid":l?`${l}-${c}`:void 0,onChange:g=>p(c,g.target.value),style:{...Se,borderTopLeftRadius:0}})]})}function W({label:e,value:r,onChange:a,placeholder:n,multiline:o,testIdPrefix:t,disabled:l}){let s=S(d=>d.form).langConfig??formCore.DEFAULT_LANG_CONFIG;return jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("label",{style:{display:"block",fontSize:"12px",fontWeight:500,color:"#64748b",marginBottom:"4px"},children:e}),jsxRuntime.jsx(me,{value:r,onChange:a,availableLangs:s.availableLangs,defaultLang:s.defaultLang,placeholder:n,multiline:o,testIdPrefix:t,disabled:l})]})}var Bt=["fr","en"];function ce(){let{form:e,formTypes:r,updateFormMeta:a,availableScopes:n}=S(),o=R(),t=e.langConfig??formCore.DEFAULT_LANG_CONFIG,l=e.pages.reduce((i,s)=>i+formCore.getPageVariables(s).length+formCore.getPageRosters(s).reduce((d,c)=>d+c.variables.length,0),0);return jsxRuntime.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"12px"},children:[jsxRuntime.jsx(W,{label:o.properties.name,value:e.name,onChange:i=>a({name:i}),testIdPrefix:"form-name"}),jsxRuntime.jsx(M,{label:o.properties.code,value:e.code,onChange:i=>a({code:i})}),jsxRuntime.jsx(W,{label:o.properties.description,value:e.description,onChange:i=>a({description:i}),multiline:true,testIdPrefix:"form-description"}),jsxRuntime.jsx(M,{label:o.properties.version,value:e.version,onChange:i=>a({version:i})}),jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("label",{style:{display:"block",fontSize:"12px",fontWeight:500,color:"#64748b",marginBottom:"4px"},children:o.properties.formType}),jsxRuntime.jsxs("select",{"data-testid":"form-properties-type-select",value:e.formTypeId??"",onChange:i=>a({formTypeId:i.target.value||void 0}),style:{width:"100%",padding:"6px 8px",border:"1px solid #e2e8f0",borderRadius:"4px",fontSize:"13px",color:"#334155",outline:"none",boxSizing:"border-box"},children:[jsxRuntime.jsx("option",{value:"",children:o.properties.noType}),r.map(i=>jsxRuntime.jsx("option",{value:i.id,children:i.name},i.id))]})]}),jsxRuntime.jsx(_t,{value:e.scopeIds??[],availableScopes:n,onChange:i=>a({scopeIds:i}),defaultLang:t.defaultLang,labels:o}),jsxRuntime.jsx(Mt,{langConfig:t}),jsxRuntime.jsx("div",{style:{fontSize:"12px",color:"#94a3b8",marginTop:"8px"},children:o.properties.formSummary(e.pages.length,l)})]})}function _t({value:e,availableScopes:r,onChange:a,defaultLang:n,labels:o}){let l={padding:"8px",backgroundColor:"#f8fafc",borderRadius:"6px",display:"flex",flexDirection:"column",gap:"8px",marginTop:"4px"},i=e.map(m=>r.find(p=>p.id===m)??r.find(p=>p.code===m)).filter(m=>!!m),s=r.filter(m=>!e.includes(m.id)&&!e.includes(m.code)),d=m=>{m&&a([...e,m]);},c=m=>{let p=e.slice();p.splice(m,1),a(p);},y=(m,p)=>{let b=m+p;if(b<0||b>=e.length)return;let g=e.slice(),[u]=g.splice(m,1);g.splice(b,0,u),a(g);};return jsxRuntime.jsxs("div",{"data-testid":"form-scopes-selector",style:l,children:[jsxRuntime.jsx("div",{style:{fontSize:"11px",fontWeight:600,color:"#64748b",textTransform:"uppercase",letterSpacing:"0.5px"},children:o.properties.scopes}),jsxRuntime.jsx("p",{style:{margin:0,fontSize:"11px",color:"#94a3b8"},children:o.properties.scopesHint}),i.length===0?jsxRuntime.jsx("div",{style:{fontSize:"12px",color:"#94a3b8",fontStyle:"italic"},children:"\u2014"}):jsxRuntime.jsx("ol",{"data-testid":"form-scopes-selected",style:{margin:0,padding:0,listStyle:"none",display:"flex",flexDirection:"column",gap:"4px"},children:i.map((m,p)=>jsxRuntime.jsxs("li",{"data-testid":`form-scope-${m.code}`,style:{display:"flex",alignItems:"center",gap:"6px",padding:"6px 8px",borderRadius:"4px",backgroundColor:"#fff",border:"1px solid #e2e8f0",fontSize:"12px"},children:[jsxRuntime.jsxs("span",{style:{fontSize:"10px",color:"#64748b",minWidth:"14px"},children:[p+1,"."]}),jsxRuntime.jsx("span",{style:{fontFamily:"monospace",color:"#475569"},children:m.code}),jsxRuntime.jsx("span",{style:{color:"#1e293b",flex:1,overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap"},children:formCore.resolveLabel(m.name,n,n)}),jsxRuntime.jsx("button",{type:"button","aria-label":o.properties.moveScopeUp,"data-testid":`form-scope-up-${m.code}`,onClick:()=>y(p,-1),disabled:p===0,style:Ae(p===0),children:"\u25B2"}),jsxRuntime.jsx("button",{type:"button","aria-label":o.properties.moveScopeDown,"data-testid":`form-scope-down-${m.code}`,onClick:()=>y(p,1),disabled:p===i.length-1,style:Ae(p===i.length-1),children:"\u25BC"}),jsxRuntime.jsx("button",{type:"button","aria-label":o.properties.removeScope,"data-testid":`form-scope-remove-${m.code}`,onClick:()=>c(p),style:{...Ae(false),color:"#ef4444"},children:"\xD7"})]},m.id))}),s.length>0?jsxRuntime.jsxs("select",{value:"","data-testid":"form-scopes-add",onChange:m=>{let p=m.target.value;p&&d(p),m.target.value="";},style:Nt,children:[jsxRuntime.jsxs("option",{value:"",children:["+ ",o.properties.scopes,"\u2026"]}),s.map(m=>jsxRuntime.jsxs("option",{value:m.id,children:[m.code," \u2014 ",formCore.resolveLabel(m.name,n,n)]},m.id))]}):r.length===0?jsxRuntime.jsx("div",{style:{fontSize:"11px",color:"#94a3b8",fontStyle:"italic"},"data-testid":"form-scopes-empty",children:o.properties.noScopesAvailable}):null]})}function Ae(e){return {border:"1px solid #e2e8f0",backgroundColor:"#fff",color:e?"#cbd5e1":"#64748b",fontSize:"10px",padding:"2px 6px",borderRadius:"4px",cursor:e?"default":"pointer"}}var Nt={width:"100%",padding:"6px 8px",border:"1px solid #e2e8f0",borderRadius:"4px",fontSize:"12px",color:"#334155",outline:"none",boxSizing:"border-box"};function Mt({langConfig:e}){let{form:r,updateFormMeta:a,setForm:n}=S(),o=R(),[t,l]=wr.useState(null),i={display:"block",fontSize:"12px",fontWeight:500,color:"#64748b",marginBottom:"4px"},s={width:"100%",padding:"6px 8px",border:"1px solid #e2e8f0",borderRadius:"4px",fontSize:"13px",color:"#334155",outline:"none",boxSizing:"border-box"},d=b=>{a({langConfig:b});},c=b=>{e.availableLangs.includes(b)||d({...e,availableLangs:[...e.availableLangs,b]});},y=b=>{e.availableLangs.length<=1||b!==e.defaultLang&&l(b);},m=b=>{let g=e.availableLangs.filter(I=>I!==b),u=g.includes(e.defaultLang)?e.defaultLang:g[0]??"fr",f=Wt(r,b,u,g.length===1),x={...e,defaultLang:u,availableLangs:g};n({...f,langConfig:x}),l(null);},p=()=>l(null);return jsxRuntime.jsxs("div",{"data-testid":"form-lang-config",style:{padding:"8px",backgroundColor:"#f8fafc",borderRadius:"6px",display:"flex",flexDirection:"column",gap:"8px",marginTop:"4px"},children:[jsxRuntime.jsx("div",{style:{fontSize:"11px",fontWeight:600,color:"#64748b",textTransform:"uppercase",letterSpacing:"0.5px"},children:o.properties.langConfigSection}),jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("label",{style:i,children:o.properties.langConfigAvailable}),jsxRuntime.jsx("div",{style:{display:"flex",gap:"8px",flexWrap:"wrap"},children:Bt.map(b=>{let g=e.availableLangs.includes(b),u=b===e.defaultLang,f=e.availableLangs.length<=1,x=g&&(u||f);return jsxRuntime.jsxs("label",{style:{display:"flex",alignItems:"center",gap:"6px",fontSize:"13px",color:"#334155",cursor:x?"default":"pointer",opacity:x?.6:1},children:[jsxRuntime.jsx("input",{type:"checkbox","data-testid":`lang-toggle-${b}`,checked:g,disabled:x,onChange:I=>{I.target.checked?c(b):y(b);}}),jsxRuntime.jsx("span",{children:b.toUpperCase()}),u&&jsxRuntime.jsxs("span",{style:{fontSize:"10px",color:"#94a3b8",fontStyle:"italic"},children:["(",o.properties.langConfigDefault,")"]})]},b)})})]}),jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("label",{style:i,children:o.properties.langConfigDefault}),jsxRuntime.jsx("select",{"data-testid":"lang-default-select",value:e.defaultLang,onChange:b=>d({...e,defaultLang:b.target.value}),style:s,children:e.availableLangs.map(b=>jsxRuntime.jsx("option",{value:b,children:b.toUpperCase()},b))})]}),jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("label",{style:i,children:o.properties.langConfigStrategy}),jsxRuntime.jsxs("select",{"data-testid":"lang-strategy-select",value:e.strategy,onChange:b=>d({...e,strategy:b.target.value}),style:s,children:[jsxRuntime.jsx("option",{value:"prop",children:o.properties.langConfigStrategies.prop}),jsxRuntime.jsx("option",{value:"browser",children:o.properties.langConfigStrategies.browser}),jsxRuntime.jsx("option",{value:"selector",children:o.properties.langConfigStrategies.selector}),jsxRuntime.jsx("option",{value:"auto",children:o.properties.langConfigStrategies.auto})]})]}),e.strategy==="selector"&&jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("label",{style:i,children:o.properties.langConfigSelectorPosition}),jsxRuntime.jsxs("select",{"data-testid":"lang-selector-position-select",value:e.selectorPosition??"top",onChange:b=>d({...e,selectorPosition:b.target.value}),style:s,children:[jsxRuntime.jsx("option",{value:"top",children:o.properties.langConfigPositions.top}),jsxRuntime.jsx("option",{value:"bottom",children:o.properties.langConfigPositions.bottom})]})]}),t&&jsxRuntime.jsxs("div",{"data-testid":"lang-remove-confirm",style:{padding:"8px",backgroundColor:"#fef2f2",border:"1px solid #fecaca",borderRadius:"6px",fontSize:"12px",color:"#b91c1c",display:"flex",flexDirection:"column",gap:"8px"},children:[jsxRuntime.jsx("span",{children:o.properties.langConfigConfirmRemove(t)}),jsxRuntime.jsxs("div",{style:{display:"flex",gap:"8px"},children:[jsxRuntime.jsx("button",{type:"button","data-testid":"lang-remove-confirm-yes",onClick:()=>m(t),style:{padding:"4px 10px",border:"none",borderRadius:"4px",backgroundColor:"#ef4444",color:"#fff",fontSize:"12px",cursor:"pointer"},children:o.properties.langConfigConfirmYes}),jsxRuntime.jsx("button",{type:"button","data-testid":"lang-remove-confirm-no",onClick:p,style:{padding:"4px 10px",border:"1px solid #e2e8f0",borderRadius:"4px",backgroundColor:"#fff",color:"#334155",fontSize:"12px",cursor:"pointer"},children:o.properties.langConfigConfirmNo})]})]})]})}function Wt(e,r,a,n){let o=p=>{if(p===void 0)return;if(typeof p=="string")return p;let b={...p};return delete b[r],n?yo(b,a,"fr"):b},t=p=>({...p,label:o(p.label)??""}),l=p=>({...p,message:o(p.message)??""}),i=p=>({...p,errorMessage:o(p.errorMessage)}),s=p=>({...p,name:o(p.name)??"",description:o(p.description),placeholder:o(p.placeholder),options:p.options?p.options.map(t):p.options,validationRules:p.validationRules?p.validationRules.map(l):p.validationRules,conditions:p.conditions?p.conditions.map(i):p.conditions}),d=p=>({...p,name:o(p.name)??"",options:p.options?p.options.map(t):p.options,variables:p.variables.map(s),conditions:p.conditions?p.conditions.map(i):p.conditions}),c=p=>({...p,instanceLabel:o(p.instanceLabel)}),y=p=>formCore.isPageRoster(p)?d(p):s(p),m=p=>{let b=Array.isArray(p.items)?p.items.map(y):[...formCore.getPageVariables(p).map(s),...formCore.getPageRosters(p).map(d)],{variables:g,rosters:u,...f}=p;return {...f,name:o(p.name)??"",repeatConfig:p.repeatConfig?c(p.repeatConfig):p.repeatConfig,items:b,conditions:p.conditions?p.conditions.map(i):p.conditions}};return {...e,name:o(e.name)??"",description:o(e.description),pages:e.pages.map(m)}}function M({label:e,value:r,onChange:a,multiline:n,type:o="text",readOnly:t}){let l={width:"100%",padding:"6px 8px",border:"1px solid #e2e8f0",borderRadius:"4px",fontSize:"13px",color:t?"#64748b":"#334155",backgroundColor:t?"#f1f5f9":"#fff",outline:"none",boxSizing:"border-box",cursor:t?"not-allowed":"text"};return jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("label",{style:{display:"block",fontSize:"12px",fontWeight:500,color:"#64748b",marginBottom:"4px"},children:e}),n?jsxRuntime.jsx("textarea",{value:r,onChange:i=>a(i.target.value),rows:3,style:l,readOnly:t}):jsxRuntime.jsx("input",{type:o,value:r,onChange:i=>a(i.target.value),style:l,readOnly:t})]})}function So({page:e}){let{updatePage:r}=S(),a=R();return jsxRuntime.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"12px"},children:[jsxRuntime.jsx(W,{label:a.properties.name,value:e.name,onChange:n=>r(e.code,{name:n}),testIdPrefix:"page-name"}),jsxRuntime.jsx(M,{label:a.properties.code,value:e.code,onChange:()=>{}}),jsxRuntime.jsx("div",{children:jsxRuntime.jsxs("label",{style:{display:"flex",alignItems:"center",gap:"8px",fontSize:"13px",color:"#334155",cursor:"pointer"},children:[jsxRuntime.jsx("input",{type:"checkbox",checked:e.isRepeatable,onChange:n=>r(e.code,{isRepeatable:n.target.checked,repeatConfig:n.target.checked?{min:1,max:10}:void 0})}),a.properties.repeatablePage]})}),e.isRepeatable&&e.repeatConfig&&jsxRuntime.jsxs("div",{style:{padding:"8px",backgroundColor:"#f8fafc",borderRadius:"6px",display:"flex",flexDirection:"column",gap:"8px"},children:[jsxRuntime.jsx(M,{label:a.properties.minInstances,value:String(e.repeatConfig.min??1),type:"number",onChange:n=>r(e.code,{repeatConfig:{...e.repeatConfig,min:parseInt(n)||1}})}),jsxRuntime.jsx(M,{label:a.properties.maxInstances,value:String(e.repeatConfig.max??10),type:"number",onChange:n=>r(e.code,{repeatConfig:{...e.repeatConfig,max:parseInt(n)||10}})}),jsxRuntime.jsx(M,{label:a.properties.controlVariableCode,value:e.repeatConfig.controlVariableCode??"",onChange:n=>r(e.code,{repeatConfig:{...e.repeatConfig,controlVariableCode:n||void 0}})}),jsxRuntime.jsx(W,{label:a.properties.instanceLabel,value:e.repeatConfig.instanceLabel,onChange:n=>r(e.code,{repeatConfig:{...e.repeatConfig,instanceLabel:n}}),testIdPrefix:"page-instance-label"})]}),jsxRuntime.jsx("div",{style:{fontSize:"12px",color:"#94a3b8"},children:a.properties.pageSummary(formCore.getPageVariables(e).length,formCore.getPageRosters(e).length)})]})}var jt=["equals","not_equals","greater_than","less_than","greater_than_or_equal","less_than_or_equal","contains","not_contains","is_empty","is_not_empty","starts_with","ends_with","in","regex"],Kt=["show","hide","validate","require","readonly","setValue"],Yt=["is_empty","is_not_empty"];function _e({conditions:e,onChange:r,availableVariables:a,rosterContext:n}){let o=R(),[t,l]=wr.useState(null),i=()=>{let c={id:formCore.generateId(),action:"show",expression:""};r([...e,c]),l(c.id);},s=c=>{r(e.filter(y=>y.id!==c)),t===c&&l(null);},d=(c,y)=>{r(e.map(m=>m.id===c?{...m,...y}:m));};return jsxRuntime.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"8px"},children:[jsxRuntime.jsx("div",{style:{fontSize:"11px",fontWeight:600,color:"#64748b",textTransform:"uppercase",letterSpacing:"0.5px"},children:o.conditionBuilder.conditionsCount(e.length)}),e.map(c=>jsxRuntime.jsx(Jt,{condition:c,isExpanded:t===c.id,onToggle:()=>l(t===c.id?null:c.id),onUpdate:y=>d(c.id,y),onRemove:()=>s(c.id),availableVariables:a,rosterContext:n},c.id)),jsxRuntime.jsx("button",{type:"button",onClick:i,style:{padding:"6px 12px",border:"1px dashed #cbd5e1",borderRadius:"6px",backgroundColor:"transparent",color:"#2563eb",fontSize:"12px",cursor:"pointer"},children:o.conditionBuilder.addCondition})]})}function Jt({condition:e,isExpanded:r,onToggle:a,onUpdate:n,onRemove:o,availableVariables:t,rosterContext:l}){let i=R(),[s,d]=wr.useState(()=>Qt(e.expression)),c=(f,x)=>{d(f);let I=Ro(f,x);n({expression:I});},y=f=>{n({action:f});let x=Ro(s,f);n({action:f,expression:x});},m=()=>{let f={id:formCore.generateId(),variableCode:"",operator:"equals",value:""},x={...s,rules:[...s.rules,f]};c(x,e.action);},p=f=>{let x={...s,rules:s.rules.filter(I=>I.id!==f)};c(x,e.action);},b=(f,x)=>{let I={...s,rules:s.rules.map(L=>L.id===f?{...L,...x}:L)};c(I,e.action);},g=f=>{let x={...s,logic:f};c(x,e.action);},u=i.conditionBuilder.actions[e.action]??e.action;return jsxRuntime.jsxs("div",{style:{border:"1px solid #e2e8f0",borderRadius:"6px",overflow:"hidden"},children:[jsxRuntime.jsxs("div",{onClick:a,style:{display:"flex",alignItems:"center",justifyContent:"space-between",padding:"6px 10px",backgroundColor:"#f8fafc",cursor:"pointer",fontSize:"12px",color:"#334155"},children:[jsxRuntime.jsxs("span",{style:{fontWeight:500},children:[u,s.rules.length>0?i.conditionBuilder.rulesCount(s.rules.length):""]}),jsxRuntime.jsxs("div",{style:{display:"flex",gap:"4px"},children:[jsxRuntime.jsx("span",{style:{color:"#94a3b8"},children:r?"\u25B2":"\u25BC"}),jsxRuntime.jsx("span",{onClick:f=>{f.stopPropagation(),o();},style:{color:"#ef4444",cursor:"pointer",padding:"0 4px"},role:"button",children:"\xD7"})]})]}),r&&jsxRuntime.jsxs("div",{style:{padding:"10px",display:"flex",flexDirection:"column",gap:"8px"},children:[jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("label",{style:{fontSize:"11px",fontWeight:500,color:"#64748b",display:"block",marginBottom:"2px"},children:i.conditionBuilder.action}),jsxRuntime.jsx("select",{value:e.action,onChange:f=>y(f.target.value),style:Oe,children:Kt.map(f=>jsxRuntime.jsx("option",{value:f,children:i.conditionBuilder.actions[f]},f))})]}),s.rules.length>1&&jsxRuntime.jsxs("div",{style:{display:"flex",gap:"4px",alignItems:"center"},children:[jsxRuntime.jsx("span",{style:{fontSize:"11px",color:"#64748b"},children:i.conditionBuilder.match}),jsxRuntime.jsx("button",{type:"button",onClick:()=>g("and"),style:{...To,backgroundColor:s.logic==="and"?"#2563eb":"#f1f5f9",color:s.logic==="and"?"#fff":"#64748b"},children:i.conditionBuilder.all}),jsxRuntime.jsx("button",{type:"button",onClick:()=>g("or"),style:{...To,backgroundColor:s.logic==="or"?"#2563eb":"#f1f5f9",color:s.logic==="or"?"#fff":"#64748b"},children:i.conditionBuilder.any})]}),s.rules.map(f=>jsxRuntime.jsxs("div",{style:{display:"flex",gap:"4px",alignItems:"center"},children:[jsxRuntime.jsxs("select",{value:f.variableCode,onChange:x=>b(f.id,{variableCode:x.target.value}),style:{...Oe,flex:1},children:[jsxRuntime.jsx("option",{value:"",children:i.conditionBuilder.variablePlaceholder}),t.map(x=>jsxRuntime.jsxs("option",{value:x.code,children:[x.name," (",x.code,")"]},x.code))]}),jsxRuntime.jsx("select",{value:f.operator,onChange:x=>b(f.id,{operator:x.target.value}),style:{...Oe,width:"130px"},children:jt.map(x=>jsxRuntime.jsx("option",{value:x,children:i.conditionBuilder.operators[x]},x))}),!Yt.includes(f.operator)&&jsxRuntime.jsx("input",{type:"text",value:f.value,onChange:x=>b(f.id,{value:x.target.value}),placeholder:i.conditionBuilder.valuePlaceholder,style:{...Be,flex:1}}),jsxRuntime.jsx("button",{type:"button",onClick:()=>p(f.id),style:{border:"none",background:"none",color:"#ef4444",cursor:"pointer",fontSize:"14px",padding:"2px"},children:"\xD7"})]},f.id)),jsxRuntime.jsx("button",{type:"button",onClick:m,style:{padding:"4px 8px",border:"1px dashed #cbd5e1",borderRadius:"4px",backgroundColor:"transparent",color:"#64748b",fontSize:"11px",cursor:"pointer"},children:i.conditionBuilder.addRule}),e.expression&&jsxRuntime.jsx("div",{style:{padding:"6px 8px",backgroundColor:"#f0fdf4",borderRadius:"4px",fontSize:"11px",fontFamily:"monospace",color:"#166534",wordBreak:"break-all"},children:e.expression}),l&&e.expression&&(()=>{let f=formCore.RosterConditionEngine.validateCondition(e.expression,l.variables,l.currentVariableCode,l.currentVariableOrder);return f.isValid?null:jsxRuntime.jsx("div",{"data-testid":"condition-builder-roster-errors",style:{padding:"6px 8px",backgroundColor:"#fef2f2",border:"1px solid #fecaca",borderRadius:"4px",fontSize:"11px",color:"#b91c1c",display:"flex",flexDirection:"column",gap:"4px"},children:f.errors.map((x,I)=>jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("strong",{children:x.type}),x.variableCode?`: \${${x.variableCode}}`:""," \u2014 ",x.message]},I))})})(),e.action==="validate"&&jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("label",{style:{fontSize:"11px",fontWeight:500,color:"#64748b",display:"block",marginBottom:"2px"},children:i.conditionBuilder.errorMessage}),jsxRuntime.jsx(Xt,{value:e.errorMessage,onChange:f=>n({errorMessage:f}),placeholder:i.conditionBuilder.errorMessagePlaceholder})]}),e.action==="setValue"&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("label",{style:{fontSize:"11px",fontWeight:500,color:"#64748b",display:"block",marginBottom:"2px"},children:i.conditionBuilder.targetVariableCode}),jsxRuntime.jsx("input",{type:"text",value:e.targetVariableCode??"",onChange:f=>n({targetVariableCode:f.target.value||void 0}),placeholder:i.conditionBuilder.targetVariablePlaceholder,style:Be})]}),jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("label",{style:{fontSize:"11px",fontWeight:500,color:"#64748b",display:"block",marginBottom:"2px"},children:i.conditionBuilder.valueToSet}),jsxRuntime.jsx("input",{type:"text",value:e.setValue!==void 0?String(e.setValue):"",onChange:f=>n({setValue:f.target.value}),placeholder:i.conditionBuilder.valueToSetPlaceholder,style:Be})]})]})]})]})}function Xt({value:e,onChange:r,placeholder:a}){let o=S(t=>t.form).langConfig??formCore.DEFAULT_LANG_CONFIG;return jsxRuntime.jsx(me,{value:e,onChange:t=>r(t),availableLangs:o.availableLangs,defaultLang:o.defaultLang,placeholder:a,testIdPrefix:"condition-error-message"})}function Zt(e){return {equals:"==",not_equals:"!=",contains:"contains",not_contains:"!contains",starts_with:"startsWith",ends_with:"endsWith",greater_than:">",less_than:"<",greater_than_or_equal:">=",less_than_or_equal:"<=",is_empty:"isEmpty",is_not_empty:"isNotEmpty",in:"in",not_in:"!in",between:"between",regex:"regex"}[e]??"=="}function Ro(e,r){if(e.rules.length===0)return "";let a=e.rules.filter(o=>o.variableCode).map(o=>{let t=`\${${o.variableCode}}`,l=Zt(o.operator);if(o.operator==="is_empty")return `isEmpty(${t})`;if(o.operator==="is_not_empty")return `isNotEmpty(${t})`;if(o.operator==="contains")return `contains(${t}, "${o.value}")`;if(o.operator==="starts_with")return `startsWith(${t}, "${o.value}")`;if(o.operator==="ends_with")return `endsWith(${t}, "${o.value}")`;let i=/^\d+(\.\d+)?$/.test(o.value)?o.value:`"${o.value}"`;return `${t} ${l} ${i}`});if(a.length===0)return "";let n=a.join(e.logic==="and"?" && ":" || ");return r==="show"?`show(${n})`:r==="hide"?`hide(${n})`:r==="validate"?`ConditionEval(${n})`:n}function Qt(e){return {logic:"and",rules:[]}}var Oe={padding:"4px 6px",border:"1px solid #e2e8f0",borderRadius:"4px",fontSize:"12px",color:"#334155",outline:"none"},Be={width:"100%",padding:"4px 6px",border:"1px solid #e2e8f0",borderRadius:"4px",fontSize:"12px",color:"#334155",outline:"none",boxSizing:"border-box"},To={padding:"2px 8px",borderRadius:"10px",border:"none",fontSize:"10px",fontWeight:600,cursor:"pointer"};function Fo({open:e,onClose:r,conditions:a,onApply:n,availableVariables:o,rosterContext:t}){let l=R(),i=wr.useRef(null),s=wr.useRef(null),[d,c]=wr.useState(a),[y,m]=wr.useState("visual");wr.useEffect(()=>{e&&(c(a),m("visual"));},[e,a]),wr.useEffect(()=>{if(!e)return;s.current=document.activeElement;let b=setTimeout(()=>{i.current?.querySelector('button, [href], input, select, textarea, [tabindex]:not([tabindex="-1"])')?.focus();},0),g=u=>{if(u.key==="Escape"){u.stopPropagation(),r();return}if(u.key!=="Tab"||!i.current)return;let f=Array.from(i.current.querySelectorAll('button:not([disabled]), [href], input:not([disabled]), select:not([disabled]), textarea:not([disabled]), [tabindex]:not([tabindex="-1"])')).filter(v=>v.offsetParent!==null);if(f.length===0)return;let x=f[0],I=f[f.length-1],L=document.activeElement;u.shiftKey&&L===x?(u.preventDefault(),I.focus()):!u.shiftKey&&L===I&&(u.preventDefault(),x.focus());};return window.addEventListener("keydown",g),()=>{clearTimeout(b),window.removeEventListener("keydown",g),s.current?.focus?.();}},[e,r]);let p=wr.useCallback(()=>{n(d),r();},[d,n,r]);return e?jsxRuntime.jsx("div",{"data-testid":"conditions-modal-overlay","aria-hidden":"false",style:{position:"fixed",inset:0,zIndex:1e3,backgroundColor:"rgba(15, 23, 42, 0.55)",display:"flex",alignItems:"center",justifyContent:"center",padding:"24px"},children:jsxRuntime.jsxs("div",{ref:i,role:"dialog","aria-modal":"true","aria-labelledby":"conditions-modal-title","data-testid":"conditions-modal",style:{backgroundColor:"#fff",borderRadius:"12px",boxShadow:"0 24px 48px rgba(0,0,0,0.25)",width:"100%",maxWidth:"720px",maxHeight:"calc(100vh - 48px)",display:"flex",flexDirection:"column",overflow:"hidden",fontFamily:"system-ui, -apple-system, sans-serif"},children:[jsxRuntime.jsxs("div",{style:{display:"flex",alignItems:"center",justifyContent:"space-between",padding:"14px 20px",borderBottom:"1px solid #e2e8f0"},children:[jsxRuntime.jsx("h2",{id:"conditions-modal-title",style:{margin:0,fontSize:"16px",fontWeight:600,color:"#0f172a"},children:l.conditionBuilder.modalTitle(d.length)}),jsxRuntime.jsx("button",{type:"button",onClick:r,"data-testid":"conditions-modal-close","aria-label":l.conditionBuilder.closeButton,style:{border:"none",background:"none",cursor:"pointer",fontSize:"20px",color:"#64748b",padding:"4px 8px",borderRadius:"6px"},children:"\u2715"})]}),jsxRuntime.jsxs("div",{style:{display:"flex",gap:"4px",padding:"12px 20px 0",borderBottom:"1px solid #f1f5f9"},children:[jsxRuntime.jsx(Po,{active:y==="visual",label:l.conditionBuilder.modeVisual,testId:"conditions-modal-mode-visual",onClick:()=>m("visual")}),jsxRuntime.jsx(Po,{active:y==="manual",label:l.conditionBuilder.modeManual,testId:"conditions-modal-mode-manual",onClick:()=>m("manual")})]}),jsxRuntime.jsxs("div",{style:{flex:1,overflowY:"auto",padding:"16px 20px"},children:[y==="visual"?jsxRuntime.jsx(_e,{conditions:d,onChange:c,availableVariables:o,rosterContext:t}):jsxRuntime.jsx(rr,{conditions:d,onChange:c}),jsxRuntime.jsx(sr,{conditions:d,title:l.conditionBuilder.formulasSummary,empty:l.conditionBuilder.noConditions})]}),jsxRuntime.jsxs("div",{style:{display:"flex",justifyContent:"flex-end",gap:"8px",padding:"12px 20px",borderTop:"1px solid #e2e8f0"},children:[jsxRuntime.jsx("button",{type:"button",onClick:r,"data-testid":"conditions-modal-cancel",style:{padding:"8px 16px",border:"1px solid #cbd5e1",borderRadius:"6px",backgroundColor:"#fff",color:"#334155",fontSize:"13px",fontWeight:500,cursor:"pointer"},children:l.conditionBuilder.cancelButton}),jsxRuntime.jsx("button",{type:"button",onClick:p,"data-testid":"conditions-modal-apply",style:{padding:"8px 16px",border:"none",borderRadius:"6px",backgroundColor:"#2563eb",color:"#fff",fontSize:"13px",fontWeight:600,cursor:"pointer"},children:l.conditionBuilder.applyButton})]})]})}):null}function Po({active:e,label:r,testId:a,onClick:n}){return jsxRuntime.jsx("button",{type:"button",onClick:n,"data-testid":a,"aria-pressed":e,style:{padding:"8px 14px",border:"none",backgroundColor:"transparent",color:e?"#2563eb":"#64748b",fontWeight:e?600:500,fontSize:"13px",cursor:"pointer",borderBottomWidth:"2px",borderBottomStyle:"solid",borderBottomColor:e?"#2563eb":"transparent",marginBottom:"-1px"},children:r})}function rr({conditions:e,onChange:r}){let a=R();if(e.length===0)return jsxRuntime.jsx("div",{style:{padding:"12px",color:"#94a3b8",fontSize:"13px",textAlign:"center",fontStyle:"italic"},children:a.conditionBuilder.noConditions});let n=(t,l)=>{r(e.map(i=>i.id===t?{...i,expression:l}:i));},o=t=>t.includes("ConditionEval(")||t.includes("||")||/show\(|hide\(|setValue\(/.test(t)===false||t.split("&&").length>2;return jsxRuntime.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"14px"},children:[jsxRuntime.jsx("p",{style:{margin:0,fontSize:"11px",color:"#64748b"},children:a.conditionBuilder.manualHelp}),e.map((t,l)=>jsxRuntime.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"6px"},children:[jsxRuntime.jsxs("label",{style:{fontSize:"11px",fontWeight:600,color:"#64748b"},children:["#",l+1," \u2014 ",a.conditionBuilder.actions[t.action]??t.action]}),jsxRuntime.jsx(lr,{value:t.expression,onChange:i=>n(t.id,i),placeholder:a.conditionBuilder.manualPlaceholder,testId:`conditions-modal-manual-${t.id}`}),o(t.expression)&&jsxRuntime.jsxs("p",{"data-testid":`conditions-modal-manual-warning-${t.id}`,style:{margin:0,fontSize:"11px",color:"#92400e",backgroundColor:"#fffbeb",border:"1px solid #fde68a",padding:"6px 8px",borderRadius:"4px"},children:["\u26A0 ",a.conditionBuilder.manualWarning]})]},t.id))]})}var nr={function:"#2563eb",variable:"#ea580c",operator:"#9333ea",string:"#16a34a",number:"#0891b2",plain:"inherit",identifier:"inherit"},ar=new Set(["show","hide","setValue","validate","require","readonly","ConditionEval","jump","contains","startsWith","endsWith","isEmpty","isNotEmpty","not_contains","in","between","regex"]);function ir(e){let r=[],a=0;for(;a<e.length;){let n=e[a];if(n==='"'||n==="'"){let o=a+1;for(;o<e.length&&e[o]!==n;)e[o]==="\\"&&o++,o++;r.push({type:"string",text:e.slice(a,Math.min(o+1,e.length))}),a=o+1;continue}if(n==="$"&&e[a+1]==="{"){let o=a+2;for(;o<e.length&&e[o]!=="}";)o++;r.push({type:"variable",text:e.slice(a,Math.min(o+1,e.length))}),a=o+1;continue}if(/[a-zA-Z_]/.test(n)){let o=a;for(;o<e.length&&/[a-zA-Z0-9_]/.test(e[o]);)o++;let t=e.slice(a,o);r.push({type:ar.has(t)?"function":"identifier",text:t}),a=o;continue}if(/\d/.test(n)){let o=a;for(;o<e.length&&/[\d.]/.test(e[o]);)o++;r.push({type:"number",text:e.slice(a,o)}),a=o;continue}if("=!<>&|".includes(n)){let o=e.slice(a,a+2);if(["==","!=","<=",">=","&&","||"].includes(o)){r.push({type:"operator",text:o}),a+=2;continue}r.push({type:"operator",text:n}),a++;continue}r.push({type:"plain",text:n}),a++;}return r}function lr({value:e,onChange:r,placeholder:a,testId:n}){let o=wr.useRef(null),t=wr.useRef(null),l=wr.useMemo(()=>ir(e),[e]),i=()=>{!o.current||!t.current||(t.current.scrollTop=o.current.scrollTop,t.current.scrollLeft=o.current.scrollLeft);},s={position:"absolute",top:0,left:0,width:"100%",height:"100%",margin:0,padding:"8px 10px",border:"none",fontFamily:'ui-monospace, "SF Mono", Menlo, Consolas, monospace',fontSize:"12.5px",lineHeight:"20px",whiteSpace:"pre-wrap",wordBreak:"break-word",boxSizing:"border-box"};return jsxRuntime.jsxs("div",{style:{position:"relative",minHeight:"60px",border:"1px solid #cbd5e1",borderRadius:"6px",backgroundColor:"#f8fafc",overflow:"hidden"},children:[jsxRuntime.jsx("div",{ref:t,"aria-hidden":"true",style:{...s,color:"#0f172a",overflow:"auto",pointerEvents:"none"},children:l.length===0?jsxRuntime.jsx("span",{style:{color:"#94a3b8"},children:a}):jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[l.map((d,c)=>jsxRuntime.jsx("span",{style:{color:nr[d.type]},children:d.text},c)),jsxRuntime.jsx("span",{children:"\u200B"})]})}),jsxRuntime.jsx("textarea",{ref:o,value:e,onChange:d=>r(d.target.value),onScroll:i,placeholder:a,"data-testid":n,spellCheck:false,style:{...s,color:"transparent",caretColor:"#0f172a",backgroundColor:"transparent",resize:"vertical",outline:"none",overflow:"auto"}})]})}function sr({conditions:e,title:r,empty:a}){return jsxRuntime.jsxs("div",{style:{marginTop:"16px",borderTop:"1px solid #e2e8f0",paddingTop:"12px"},children:[jsxRuntime.jsx("h3",{style:{margin:"0 0 8px",fontSize:"11px",fontWeight:600,color:"#64748b",textTransform:"uppercase",letterSpacing:"0.5px"},children:r}),e.length===0?jsxRuntime.jsx("p",{style:{margin:0,fontSize:"12px",color:"#94a3b8",fontStyle:"italic"},children:a}):jsxRuntime.jsx("ul",{"data-testid":"conditions-modal-summary",style:{margin:0,padding:0,listStyle:"none",display:"flex",flexDirection:"column",gap:"4px"},children:e.map(n=>jsxRuntime.jsx("li",{style:{fontFamily:'ui-monospace, "SF Mono", Menlo, Consolas, monospace',fontSize:"11.5px",color:"#0f172a",backgroundColor:"#f1f5f9",padding:"4px 8px",borderRadius:"4px",wordBreak:"break-all"},children:n.expression||"\u2205"},n.id))})]})}function Ne({dataSourceId:e,dependencies:r={},availableConnectors:a,availableVariables:n,onConnectorChange:o,onDependenciesChange:t}){let l=R(),[i,s]=wr.useState(""),d=a.find(b=>b.id===e),c=Object.entries(r),y=()=>{i.trim()&&(t({...r,[i.trim()]:""}),s(""));},m=b=>{let g={...r};delete g[b],t(g);},p=(b,g)=>{t({...r,[b]:g});};return jsxRuntime.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"10px",padding:"8px",backgroundColor:"#f0fdf4",borderRadius:"6px"},children:[jsxRuntime.jsx("div",{style:{fontSize:"11px",fontWeight:600,color:"#166534",textTransform:"uppercase",letterSpacing:"0.5px"},children:l.dataSource.title}),jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("label",{style:cr,children:l.dataSource.connector}),jsxRuntime.jsxs("select",{value:e??"",onChange:b=>{let g=b.target.value||void 0;o(g),g||t({});},style:Do,children:[jsxRuntime.jsx("option",{value:"",children:l.dataSource.none}),a.map(b=>jsxRuntime.jsxs("option",{value:b.id,children:[b.name," (",b.id,")"]},b.id))]})]}),d&&jsxRuntime.jsxs("div",{style:{fontSize:"11px",color:"#166534",padding:"4px 6px",backgroundColor:"#dcfce7",borderRadius:"4px"},children:[l.dataSource.connectedTo," ",jsxRuntime.jsx("strong",{children:d.name})]}),e&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx("div",{style:{fontSize:"11px",fontWeight:500,color:"#166534"},children:l.dataSource.dependencies(c.length)}),c.map(([b,g])=>jsxRuntime.jsxs("div",{style:{display:"flex",gap:"4px",alignItems:"center"},children:[jsxRuntime.jsx("span",{style:{fontSize:"11px",color:"#334155",minWidth:"60px",fontFamily:"monospace"},children:b}),jsxRuntime.jsx("span",{style:{fontSize:"11px",color:"#94a3b8"},children:"\u2192"}),jsxRuntime.jsxs("select",{value:g,onChange:u=>p(b,u.target.value),style:{...Do,flex:1},children:[jsxRuntime.jsx("option",{value:"",children:l.dataSource.selectVariable}),n.map(u=>jsxRuntime.jsxs("option",{value:u.code,children:[u.name," (",u.code,")"]},u.code))]}),jsxRuntime.jsx("button",{type:"button",onClick:()=>m(b),style:{border:"none",background:"none",color:"#ef4444",cursor:"pointer",fontSize:"14px"},children:"\xD7"})]},b)),jsxRuntime.jsxs("div",{style:{display:"flex",gap:"4px"},children:[jsxRuntime.jsx("input",{type:"text",value:i,onChange:b=>s(b.target.value),placeholder:l.dataSource.dependencyKeyPlaceholder,style:{...ur,flex:1},onKeyDown:b=>b.key==="Enter"&&y()}),jsxRuntime.jsx("button",{type:"button",onClick:y,disabled:!i.trim(),style:{padding:"4px 8px",border:"1px solid #cbd5e1",borderRadius:"4px",backgroundColor:"#fff",color:"#2563eb",fontSize:"11px",cursor:"pointer",opacity:i.trim()?1:.5},children:l.dataSource.addDependency})]})]})]})}var cr={fontSize:"11px",fontWeight:500,color:"#166534",display:"block",marginBottom:"2px"},Do={width:"100%",padding:"4px 6px",border:"1px solid #bbf7d0",borderRadius:"4px",fontSize:"12px",color:"#334155",outline:"none",backgroundColor:"#fff"},ur={padding:"4px 6px",border:"1px solid #bbf7d0",borderRadius:"4px",fontSize:"12px",color:"#334155",outline:"none",boxSizing:"border-box"};function mr(e){return e.normalize("NFD").replace(/[̀-ͯ]/g,"").toLowerCase().trim().replace(/\s+/g,"_").replace(/[^a-z0-9_-]/g,"")}function Vo(e){return typeof e=="string"?e:e==null?"":String(e)}function Me(e,r){if(e==null)return "";if(typeof e=="string")return e;let a=e[r];if(typeof a=="string"&&a!=="")return a;for(let n of Object.values(e))if(typeof n=="string"&&n!=="")return n;return ""}function zo({options:e,onChange:r,disabled:a}){let n=R(),t=S(g=>g.form).langConfig??formCore.DEFAULT_LANG_CONFIG,l=(g,u)=>{let f=e.map((x,I)=>I===g?{...x,...u}:x);r(f);},i=(g,u)=>{let f=e[g],x=Vo(f.value),I=Me(f.label,t.defaultLang),L=Me(u,t.defaultLang);x===""&&I===""&&L!==""?l(g,{label:u,value:mr(L)}):l(g,{label:u});},s=(g,u)=>{l(g,{value:u});},d=()=>{r([...e,{label:"",value:""}]);},c=g=>{r(e.filter((u,f)=>f!==g));},y={display:"block",fontSize:"12px",fontWeight:500,color:"#64748b",marginBottom:"4px"},m={flex:1,padding:"6px 8px",borderRadius:"4px",fontSize:"13px",color:"#000",outline:"none"},p="1px solid #e2e8f0",b="1px solid #ef4444";return jsxRuntime.jsxs("div",{"data-testid":"options-editor",children:[jsxRuntime.jsx("label",{style:y,children:n.optionsEditor.optionsCount(e.length)}),e.length===0&&jsxRuntime.jsx("div",{"data-testid":"options-editor-empty",style:{fontSize:"12px",color:"#94a3b8",marginBottom:"8px"},children:n.optionsEditor.noOptions}),jsxRuntime.jsx("div",{style:{display:"flex",flexDirection:"column",gap:"6px"},children:e.map((g,u)=>{let f=Me(g.label,t.defaultLang),x=Vo(g.value),I=f.trim()==="",L=x.trim()==="";return jsxRuntime.jsxs("div",{"data-testid":`option-row-${u}`,style:{display:"flex",alignItems:"flex-start",gap:"6px"},children:[jsxRuntime.jsx("div",{"aria-label":n.optionsEditor.optionLabelAria(u),"data-testid":`option-label-${u}`,style:{flex:1,border:I?b:p,borderRadius:"4px"},children:jsxRuntime.jsx(me,{value:g.label,onChange:v=>i(u,v),availableLangs:t.availableLangs,defaultLang:t.defaultLang,placeholder:n.optionsEditor.optionLabelPlaceholder,disabled:a,testIdPrefix:`option-label-input-${u}`})}),jsxRuntime.jsx("input",{type:"text","aria-label":n.optionsEditor.optionValueAria(u),"data-testid":`option-value-${u}`,value:x,placeholder:n.optionsEditor.optionValuePlaceholder,disabled:a,onChange:v=>s(u,v.target.value),style:{...m,border:L?b:p,maxWidth:"40%"}}),jsxRuntime.jsx("button",{type:"button","aria-label":n.optionsEditor.removeOptionAria(u),"data-testid":`option-remove-${u}`,onClick:()=>c(u),disabled:a,style:{width:"24px",height:"24px",border:"1px solid #e2e8f0",borderRadius:"4px",backgroundColor:"#fff",color:"#64748b",cursor:a?"not-allowed":"pointer",lineHeight:1,fontSize:"14px"},children:"\xD7"})]},u)})}),jsxRuntime.jsx("button",{type:"button","data-testid":"options-editor-add",onClick:d,disabled:a,style:{marginTop:"8px",padding:"6px 10px",border:"1px dashed #94a3b8",borderRadius:"4px",backgroundColor:"transparent",color:"#2563eb",fontSize:"12px",cursor:a?"not-allowed":"pointer"},children:n.optionsEditor.addOption})]})}var Cr=new Set(["type","description","placeholder","isRequired","isReadonly","isHidden","options","validationRules","conditions","expression","dataSourceId","dataSourceDependencies","style","metadata"]);function We(e){return e==="type"?"variableType":e}function $o({variable:e,pageCode:r,rosterCode:a,availableConnectors:n=[]}){let {form:o,updateVariable:t,setVariableOverride:l,resetVariableOverride:i,availableTemplates:s}=S(),d=R(),[c,y]=wr.useState(false),m=wr.useMemo(()=>[{value:"text",label:d.toolbox.types.text},{value:"textarea",label:d.toolbox.types.textarea},{value:"number",label:d.toolbox.types.number},{value:"date",label:d.toolbox.types.date},{value:"datetime",label:d.toolbox.types.datetime},{value:"time",label:d.toolbox.types.time},{value:"select",label:d.toolbox.types.select},{value:"multiselect",label:d.toolbox.types.multiselect},{value:"radio",label:d.toolbox.types.radio},{value:"checkbox",label:d.toolbox.types.checkbox},{value:"file",label:d.toolbox.types.file},{value:"gps",label:d.toolbox.types.gps},{value:"rating",label:d.toolbox.types.rating},{value:"calculated",label:d.toolbox.types.calculated},{value:"hidden",label:d.toolbox.types.hidden},{value:"label",label:d.toolbox.types.label}],[d]),p=!!e.templateId;p?s.find(v=>v.id===e.templateId):void 0;let g=o.langConfig?.defaultLang??formCore.DEFAULT_LANG_CONFIG.defaultLang,u=v=>{if(!p){t(r,e.code,v,a);return}let k={},C=false;for(let[N,oe]of Object.entries(v))if(Cr.has(N)){let ue=We(N);l(r,e.code,ue,oe,a);}else k[N]=oe,C=true;C&&t(r,e.code,k,a);},f=v=>{if(!p)return false;let k=We(v);return Object.prototype.hasOwnProperty.call(e.templateOverrides??{},k)},x=v=>{p&&i(r,e.code,We(v),a);},I=v=>formCore.resolveLabel(v,g,g),L=o.pages.flatMap(v=>[...formCore.getPageVariables(v).map(k=>({code:k.code,name:I(k.name)})),...formCore.getPageRosters(v).flatMap(k=>k.variables.map(C=>({code:C.code,name:I(C.name)})))]);return jsxRuntime.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"12px"},children:[p&&jsxRuntime.jsx(hr,{variable:e,templateCodeLabel:d.properties.templateCode,templateNameLabel:d.properties.templateName,bannerTitle:d.properties.linkedTemplate,defaultLang:g}),p?jsxRuntime.jsx(Sr,{label:d.properties.templateName,value:e.name,defaultLang:g,testId:"variable-name-readonly"}):jsxRuntime.jsx(W,{label:d.properties.name,value:e.name,onChange:v=>u({name:v}),testIdPrefix:"variable-name"}),jsxRuntime.jsx(M,{label:p?d.properties.templateCode:d.properties.code,value:e.code,onChange:()=>{},readOnly:true}),jsxRuntime.jsx(X,{isOverridden:f("description"),onReset:()=>x("description"),resetLabel:d.properties.resetOverride,children:jsxRuntime.jsx(W,{label:d.properties.description,value:e.description,onChange:v=>u({description:v}),testIdPrefix:"variable-description"})}),jsxRuntime.jsx(X,{isOverridden:f("placeholder"),onReset:()=>x("placeholder"),resetLabel:d.properties.resetOverride,children:jsxRuntime.jsx(W,{label:d.properties.placeholder,value:e.placeholder,onChange:v=>u({placeholder:v}),testIdPrefix:"variable-placeholder"})}),jsxRuntime.jsx(X,{isOverridden:f("type"),onReset:()=>x("type"),resetLabel:d.properties.resetOverride,children:jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("label",{style:{display:"block",fontSize:"12px",fontWeight:500,color:"#64748b",marginBottom:"4px"},children:d.properties.type}),jsxRuntime.jsx("select",{value:e.type,onChange:v=>u({type:v.target.value}),style:{width:"100%",padding:"6px 8px",border:"1px solid #e2e8f0",borderRadius:"4px",fontSize:"13px"},children:m.map(v=>jsxRuntime.jsx("option",{value:v.value,children:v.label},v.value))})]})}),e.type==="rating"&&jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("label",{style:{display:"block",fontSize:"12px",fontWeight:500,color:"#64748b",marginBottom:"4px"},children:d.properties.ratingStyle}),jsxRuntime.jsxs("select",{value:e.metadata?.ratingStyle??"star",onChange:v=>u({metadata:{...e.metadata,ratingStyle:v.target.value}}),style:{width:"100%",padding:"6px 8px",border:"1px solid #e2e8f0",borderRadius:"4px",fontSize:"13px"},children:[jsxRuntime.jsx("option",{value:"star",children:d.properties.ratingStyles.star}),jsxRuntime.jsx("option",{value:"number",children:d.properties.ratingStyles.number}),jsxRuntime.jsx("option",{value:"color",children:d.properties.ratingStyles.color})]})]}),jsxRuntime.jsxs("div",{style:{padding:"8px",backgroundColor:"#f8fafc",borderRadius:"6px",display:"flex",flexDirection:"column",gap:"6px"},children:[jsxRuntime.jsx("div",{style:{fontSize:"11px",fontWeight:600,color:"#64748b",textTransform:"uppercase"},children:d.properties.layout}),jsxRuntime.jsx(Te,{label:d.properties.startNewRow,checked:e.startWithNewLine!==false,onChange:v=>u({startWithNewLine:v?void 0:false})}),jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("label",{style:{display:"block",fontSize:"12px",fontWeight:500,color:"#64748b",marginBottom:"2px"},children:d.properties.columnSpan}),jsxRuntime.jsxs("select",{value:e.colSpan??"auto",onChange:v=>u({colSpan:v.target.value==="auto"?void 0:parseInt(v.target.value)}),style:{width:"100%",padding:"4px 8px",border:"1px solid #e2e8f0",borderRadius:"4px",fontSize:"13px"},children:[jsxRuntime.jsx("option",{value:"auto",children:d.properties.columnSpanAuto}),[1,2,3,4,5,6,7,8,9,10,11,12].map(v=>jsxRuntime.jsxs("option",{value:v,children:[v,"/12",v===6?d.properties.columnSpanHalf:v===4?d.properties.columnSpanThird:v===12?d.properties.columnSpanFull:""]},v))]})]})]}),jsxRuntime.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"6px"},children:[jsxRuntime.jsx(X,{isOverridden:f("isRequired"),onReset:()=>x("isRequired"),resetLabel:d.properties.resetOverride,inline:true,children:jsxRuntime.jsx(Te,{label:d.properties.required,checked:e.isRequired,onChange:v=>u({isRequired:v})})}),jsxRuntime.jsx(X,{isOverridden:f("isReadonly"),onReset:()=>x("isReadonly"),resetLabel:d.properties.resetOverride,inline:true,children:jsxRuntime.jsx(Te,{label:d.properties.readonly,checked:e.isReadonly,onChange:v=>u({isReadonly:v})})}),jsxRuntime.jsx(X,{isOverridden:f("isHidden"),onReset:()=>x("isHidden"),resetLabel:d.properties.resetOverride,inline:true,children:jsxRuntime.jsx(Te,{label:d.properties.hidden,checked:e.isHidden,onChange:v=>u({isHidden:v})})})]}),e.type==="calculated"&&jsxRuntime.jsx(X,{isOverridden:f("expression"),onReset:()=>x("expression"),resetLabel:d.properties.resetOverride,children:jsxRuntime.jsx(M,{label:d.properties.expression,value:e.expression??"",onChange:v=>u({expression:v||void 0}),multiline:true})}),["select","multiselect","radio"].includes(e.type)&&jsxRuntime.jsx(Ne,{dataSourceId:e.dataSourceId,dependencies:e.dataSourceDependencies,availableConnectors:n,availableVariables:L,onConnectorChange:v=>u({dataSourceId:v}),onDependenciesChange:v=>u({dataSourceDependencies:Object.keys(v).length>0?v:void 0})}),["select","multiselect","radio","checkbox"].includes(e.type)&&!e.dataSourceId&&jsxRuntime.jsx(X,{isOverridden:f("options"),onReset:()=>x("options"),resetLabel:d.properties.resetOverride,children:jsxRuntime.jsx(zo,{options:e.options??[],onChange:v=>u({options:v})})}),jsxRuntime.jsx(X,{isOverridden:f("conditions"),onReset:()=>x("conditions"),resetLabel:d.properties.resetOverride,children:jsxRuntime.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"6px"},children:[jsxRuntime.jsx("label",{style:{fontSize:"11px",fontWeight:600,color:"#64748b",textTransform:"uppercase",letterSpacing:"0.5px"},children:d.conditionBuilder.conditionsCount((e.conditions??[]).length)}),jsxRuntime.jsxs("button",{type:"button","data-testid":"conditions-modal-open",onClick:()=>y(true),style:{padding:"8px 14px",border:"1px solid #cbd5e1",borderRadius:"6px",backgroundColor:"#fff",color:"#1e293b",fontSize:"13px",fontWeight:500,cursor:"pointer",textAlign:"left"},children:["\u2699 ",d.conditionBuilder.configureButton((e.conditions??[]).length)]}),(e.conditions??[]).length>0&&jsxRuntime.jsx("ul",{"data-testid":"conditions-preview",style:{margin:0,padding:0,listStyle:"none",display:"flex",flexDirection:"column",gap:"3px"},children:(e.conditions??[]).map(v=>jsxRuntime.jsx("li",{style:{fontFamily:'ui-monospace, "SF Mono", Menlo, Consolas, monospace',fontSize:"11.5px",color:"#0f172a",backgroundColor:"#f1f5f9",padding:"4px 8px",borderRadius:"4px",wordBreak:"break-all"},children:v.expression||"\u2205"},v.id))})]})}),jsxRuntime.jsx(Fo,{open:c,onClose:()=>y(false),conditions:e.conditions??[],onApply:v=>u({conditions:v}),availableVariables:L,rosterContext:(()=>{if(!a)return;let v=o.pages.find(C=>C.code===r),k=v?formCore.getPageRosters(v).find(C=>C.code===a):void 0;if(k)return {variables:k.variables.map(C=>({code:C.code,order:C.order})),currentVariableCode:e.code,currentVariableOrder:e.order}})()})]})}function hr({variable:e,templateCodeLabel:r,templateNameLabel:a,bannerTitle:n,defaultLang:o}){return jsxRuntime.jsxs("div",{"data-testid":"variable-linked-banner",style:{padding:"10px 12px",backgroundColor:"#eff6ff",border:"1px solid #bfdbfe",borderRadius:"6px",fontSize:"12px",color:"#1e40af",display:"flex",flexDirection:"column",gap:"4px"},children:[jsxRuntime.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"6px",fontWeight:600},children:[jsxRuntime.jsx("span",{children:"\u{1F517}"}),jsxRuntime.jsx("span",{children:n})]}),jsxRuntime.jsxs("div",{style:{fontSize:"11px",color:"#1e3a8a"},children:[r," : ",jsxRuntime.jsx("span",{style:{fontFamily:"monospace"},children:e.code})]}),jsxRuntime.jsxs("div",{style:{fontSize:"11px",color:"#1e3a8a"},children:[a," : ",formCore.resolveLabel(e.name,o,o)]})]})}function Sr({label:e,value:r,defaultLang:a,testId:n}){return jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("label",{style:{display:"block",fontSize:"12px",fontWeight:500,color:"#64748b",marginBottom:"4px"},children:e}),jsxRuntime.jsx("div",{"data-testid":n,style:{padding:"6px 8px",backgroundColor:"#f1f5f9",color:"#64748b",border:"1px solid #e2e8f0",borderRadius:"4px",fontSize:"13px",cursor:"not-allowed",userSelect:"text"},children:formCore.resolveLabel(r,a,a)})]})}function X({isOverridden:e,onReset:r,resetLabel:a,children:n,inline:o=false}){if(!e)return jsxRuntime.jsx(jsxRuntime.Fragment,{children:n});let t=jsxRuntime.jsxs("button",{type:"button","data-testid":"reset-override",onClick:r,style:{padding:"2px 8px",border:"1px solid #fde68a",borderRadius:"4px",backgroundColor:"#fffbeb",color:"#92400e",fontSize:"10px",cursor:"pointer",fontWeight:500},children:["\u21BA ",a]});return o?jsxRuntime.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"8px"},children:[jsxRuntime.jsx("div",{style:{flex:1},children:n}),t]}):jsxRuntime.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"4px"},children:[n,jsxRuntime.jsx("div",{style:{display:"flex",justifyContent:"flex-end"},children:t})]})}function Te({label:e,checked:r,onChange:a}){return jsxRuntime.jsxs("label",{style:{display:"flex",alignItems:"center",gap:"8px",fontSize:"13px",color:"#334155",cursor:"pointer"},children:[jsxRuntime.jsx("input",{type:"checkbox",checked:r,onChange:n=>a(n.target.checked)}),e]})}function Bo({roster:e,pageCode:r}){let{updateRoster:a}=S(),n=R(),o=wr.useMemo(()=>[{value:"check",label:n.properties.rosterTypes.check},{value:"list",label:n.properties.rosterTypes.list},{value:"collection",label:n.properties.rosterTypes.collection},{value:"collection_extend",label:n.properties.rosterTypes.collection_extend}],[n]);return jsxRuntime.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"12px"},children:[jsxRuntime.jsx(W,{label:n.properties.name,value:e.name,onChange:t=>a(r,e.code,{name:t}),testIdPrefix:"roster-name"}),jsxRuntime.jsx(M,{label:n.properties.code,value:e.code,onChange:()=>{}}),jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("label",{style:{display:"block",fontSize:"12px",fontWeight:500,color:"#64748b",marginBottom:"4px"},children:n.properties.rosterType}),jsxRuntime.jsx("select",{value:e.rosterType,onChange:t=>a(r,e.code,{rosterType:t.target.value}),style:{width:"100%",padding:"6px 8px",border:"1px solid #e2e8f0",borderRadius:"4px",fontSize:"13px"},children:o.map(t=>jsxRuntime.jsx("option",{value:t.value,children:t.label},t.value))})]}),jsxRuntime.jsx(M,{label:n.properties.pilotVariableCode,value:e.pilotVariableCode??"",onChange:t=>a(r,e.code,{pilotVariableCode:t||void 0})}),jsxRuntime.jsx("div",{style:{fontSize:"12px",color:"#94a3b8"},children:n.properties.rosterSummary(e.variables.length,e.options?.length??0)})]})}function Ue({availableConnectors:e=[]}){let{selection:r,form:a}=S(),n=R(),o=(()=>{switch(r.type){case "form":return jsxRuntime.jsx(ce,{});case "page":{let t=a.pages.find(l=>l.code===r.pageCode);return t?jsxRuntime.jsx(So,{page:t}):jsxRuntime.jsx(ce,{})}case "roster":{let t=a.pages.find(i=>i.code===r.pageCode),l=t?formCore.getPageRosters(t).find(i=>i.code===r.rosterCode):void 0;return !t||!l?jsxRuntime.jsx(ce,{}):jsxRuntime.jsx(Bo,{roster:l,pageCode:t.code})}case "variable":{let t=a.pages.find(d=>d.code===r.pageCode);if(!t)return jsxRuntime.jsx(ce,{});let l=r.rosterCode?formCore.getPageRosters(t).find(d=>d.code===r.rosterCode):void 0,s=(l?l.variables:formCore.getPageVariables(t)).find(d=>d.code===r.variableCode);return s?jsxRuntime.jsx($o,{variable:s,pageCode:t.code,rosterCode:r.rosterCode,availableConnectors:e}):jsxRuntime.jsx(ce,{})}}})();return jsxRuntime.jsxs("div",{style:{width:"300px",borderLeft:"1px solid #e2e8f0",backgroundColor:"#fff",overflowY:"auto"},children:[jsxRuntime.jsx("div",{style:{padding:"12px 16px",borderBottom:"1px solid #e2e8f0",fontSize:"12px",fontWeight:600,color:"#64748b",textTransform:"uppercase",letterSpacing:"0.5px"},children:n.properties.title}),jsxRuntime.jsx("div",{style:{padding:"16px"},children:o})]})}function Pr({theme:e,dataSources:r,adapter:a,initialForm:n,formId:o,onChange:t,onSave:l,labels:i,PreviewComponent:s,ToolboxComponent:d,CanvasComponent:c,Wrapper:y}){let{form:m,view:p,setForm:b,setAdapter:g,load:u,setAvailableTemplates:f,setAvailableScopes:x}=S(),I=wr.useMemo(()=>ve(Z,i),[i]);wr.useEffect(()=>{a&&g(a);},[a,g]),wr.useEffect(()=>{n?b(n):o&&a?.loadForm&&u(o);},[n,o]);let L=(m.scopeIds??[]).join("|");wr.useEffect(()=>{let de=m.scopeIds??[];if(de.length===0||!a?.loadTemplates){f([]);return}let Ie=a.loadTemplates,ke=false;return Promise.all(de.map(we=>Ie(we).catch(()=>[]))).then(we=>{if(ke)return;let Ye=new Set,Je=[];for(let qo of we)for(let Le of qo)Ye.has(Le.code)||(Ye.add(Le.code),Je.push(Le));f(Je);}).catch(()=>{ke||f([]);}),()=>{ke=true;}},[L,a,f]),wr.useEffect(()=>{if(!a?.loadScopes){x([]);return}let de=false;return a.loadScopes().then(Ie=>{de||x(Ie);}).catch(()=>{de||x([]);}),()=>{de=true;}},[a,x]);let v=wr.useRef(t),k=wr.useRef(true);v.current=t,wr.useEffect(()=>{if(k.current){k.current=false;return}v.current?.(m);},[m]);let C=d??Ce,N=c??he,oe=wr.useRef(false);y&&!oe.current&&typeof console<"u"&&(oe.current=true,console.warn("[@msbci/form-editor] FormEditor.Wrapper is deprecated \u2014 drag & drop is now provided by the internal DndManager. The custom Wrapper will still be applied AROUND DndManager, but you should remove it."));let ue=y??wr__default.default.Fragment,se=jsxRuntime.jsxs("div",{style:{display:"flex",flexDirection:"column",height:"100%",fontFamily:"system-ui, -apple-system, sans-serif"},children:[jsxRuntime.jsx(Fe,{onSave:l}),jsxRuntime.jsxs("div",{style:{display:"flex",flex:1,overflow:"hidden"},children:[p==="canvas"&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx(C,{}),jsxRuntime.jsx(N,{}),jsxRuntime.jsx(Ue,{availableConnectors:r?Object.values(r):[]})]}),p==="preview"&&s&&jsxRuntime.jsx("div",{style:{flex:1,overflow:"auto"},children:jsxRuntime.jsx(s,{formSchema:m,theme:e,dataSources:r,mode:"fill"})}),p==="preview"&&!s&&jsxRuntime.jsx("div",{style:{flex:1,display:"flex",alignItems:"center",justifyContent:"center",color:"#94a3b8",fontSize:"14px"},children:I.formEditor.previewMissing}),p==="json"&&jsxRuntime.jsx("div",{style:{flex:1,overflow:"auto",padding:"16px"},children:jsxRuntime.jsx("pre",{style:{fontFamily:"monospace",fontSize:"12px",color:"#334155",backgroundColor:"#f8fafc",padding:"16px",borderRadius:"8px",border:"1px solid #e2e8f0",whiteSpace:"pre-wrap",wordBreak:"break-all"},children:JSON.stringify(m,null,2)})})]})]});return jsxRuntime.jsx(xe,{labels:I,children:jsxRuntime.jsx(ue,{children:jsxRuntime.jsx(ze,{children:se})})})}function zr(){let e=R(),[r,a]=wr.useState("fields"),[n,o]=wr.useState(""),{form:t,selection:l,addVariable:i,addRoster:s,addVariableFromTemplate:d,availableTemplates:c}=S(),y=wr.useMemo(()=>[{label:e.toolbox.groupText,items:[{kind:"variable",type:"text",label:e.toolbox.types.text,icon:"T"},{kind:"variable",type:"textarea",label:e.toolbox.types.textarea,icon:"\xB6"},{kind:"variable",type:"number",label:e.toolbox.types.number,icon:"#"},{kind:"variable",type:"email",label:e.toolbox.types.email,icon:"@"}]},{label:e.toolbox.groupSelection,items:[{kind:"variable",type:"select",label:e.toolbox.types.select,icon:"\u25BC"},{kind:"variable",type:"multiselect",label:e.toolbox.types.multiselect,icon:"\u2611"},{kind:"variable",type:"radio",label:e.toolbox.types.radio,icon:"\u25C9"},{kind:"variable",type:"checkbox",label:e.toolbox.types.checkbox,icon:"\u2610"}]},{label:e.toolbox.groupDateTime,items:[{kind:"variable",type:"date",label:e.toolbox.types.date,icon:"\u{1F4C5}"},{kind:"variable",type:"datetime",label:e.toolbox.types.datetime,icon:"\u{1F550}"},{kind:"variable",type:"time",label:e.toolbox.types.time,icon:"\u23F0"}]},{label:e.toolbox.groupMedia,items:[{kind:"variable",type:"file",label:e.toolbox.types.file,icon:"\u{1F4CE}"},{kind:"variable",type:"image",label:e.toolbox.types.image,icon:"\u{1F5BC}"},{kind:"variable",type:"gps",label:e.toolbox.types.gps,icon:"\u{1F4CD}"}]},{label:e.toolbox.groupAdvanced,items:[{kind:"variable",type:"rating",label:e.toolbox.types.rating,icon:"\u2605"},{kind:"variable",type:"calculated",label:e.toolbox.types.calculated,icon:"fx"},{kind:"variable",type:"hidden",label:e.toolbox.types.hidden,icon:"\u{1F441}"},{kind:"variable",type:"label",label:e.toolbox.types.label,icon:"Aa"}]},{label:e.toolbox.groupRoster,items:[{kind:"roster",rosterType:"check",label:e.toolbox.typeRosterCheck,icon:"\u25A4"},{kind:"roster",rosterType:"list",label:e.toolbox.typeRosterList,icon:"\u25A6"},{kind:"roster",rosterType:"collection",label:e.toolbox.typeRosterCollection,icon:"\u25A5"},{kind:"roster",rosterType:"collection_extend",label:e.toolbox.typeRosterCollectionExtend,icon:"\u25A9"}]}],[e]),m=l.type==="page"||l.type==="variable"||l.type==="roster"?l.pageCode:t.pages[0]?.code,p=u=>{if(!m||!t.pages.find(I=>I.code===m))return;if(u.kind==="roster"){let I=`ROSTER_${Date.now().toString(36).slice(-4).toUpperCase()}`;s(m,{id:`roster-${Date.now()}`,code:I,name:e.canvas.newRosterName,rosterType:u.rosterType,order:0,variables:[]});return}let x=`${u.type.toUpperCase()}_${Date.now().toString(36).slice(-4).toUpperCase()}`;i(m,{id:`var-${Date.now()}`,code:x,name:e.canvas.newVariableName(u.label),type:u.type,order:0,isRequired:false,isReadonly:false,isHidden:false});},b=u=>{m&&d(m,u);},g=y.map(u=>({...u,items:u.items.filter(f=>f.label.toLowerCase().includes(n.toLowerCase()))})).filter(u=>u.items.length>0);return jsxRuntime.jsxs("div",{style:{width:"220px",borderRight:"1px solid #e2e8f0",display:"flex",flexDirection:"column",backgroundColor:"#f8fafc",overflow:"hidden"},children:[jsxRuntime.jsx(Ar,{tab:r,setTab:a,labels:e}),jsxRuntime.jsx("div",{style:{padding:"12px",borderBottom:"1px solid #e2e8f0"},children:jsxRuntime.jsx("input",{type:"text",placeholder:e.toolbox.searchPlaceholder,value:n,onChange:u=>o(u.target.value),style:{width:"100%",padding:"6px 10px",border:"1px solid #e2e8f0",borderRadius:"6px",fontSize:"13px",outline:"none",boxSizing:"border-box"}})}),jsxRuntime.jsxs("div",{style:{flex:1,overflowY:"auto",padding:"8px"},children:[!m&&jsxRuntime.jsx("div",{style:{padding:"12px",color:"#94a3b8",fontSize:"12px",textAlign:"center"},children:e.toolbox.addPageFirst}),r==="fields"&&g.map(u=>jsxRuntime.jsxs("div",{style:{marginBottom:"16px"},children:[jsxRuntime.jsx("div",{style:{fontSize:"11px",fontWeight:600,color:"#94a3b8",textTransform:"uppercase",letterSpacing:"0.5px",marginBottom:"6px",padding:"0 4px"},children:u.label}),u.items.map(f=>{let x=f.kind==="roster"?`roster-${f.rosterType}`:`var-${f.type}`,I=f.kind==="roster"?`toolbox-roster-${f.rosterType}`:`toolbox-variable-${f.type}`;return jsxRuntime.jsxs("div",{"data-testid":I,onClick:()=>p(f),style:{display:"flex",alignItems:"center",gap:"8px",padding:"6px 8px",marginBottom:"2px",borderRadius:"6px",cursor:"pointer",fontSize:"13px",color:"#334155",userSelect:"none"},onMouseEnter:L=>{L.currentTarget.style.backgroundColor="#e2e8f0";},onMouseLeave:L=>{L.currentTarget.style.backgroundColor="transparent";},children:[jsxRuntime.jsx("span",{style:{width:"20px",textAlign:"center",fontSize:"14px"},children:f.icon}),jsxRuntime.jsx("span",{children:f.label})]},x)})]},u.label)),r==="variables"&&jsxRuntime.jsx($r,{templates:c,scopeIds:t.scopeIds,search:n,onAdd:b,defaultLang:t.langConfig?.defaultLang??formCore.DEFAULT_LANG_CONFIG.defaultLang,labels:e})]})]})}function Ar({tab:e,setTab:r,labels:a}){let n={flex:1,padding:"8px 0",fontSize:"12px",fontWeight:500,textAlign:"center",cursor:"pointer",userSelect:"none",color:"#64748b",borderBottomWidth:"2px",borderBottomStyle:"solid",borderBottomColor:"transparent"},o={...n,color:"#2563eb",fontWeight:600,borderBottomColor:"#2563eb"};return jsxRuntime.jsxs("div",{style:{display:"flex",borderBottom:"1px solid #e2e8f0",backgroundColor:"#fff"},children:[jsxRuntime.jsx("div",{role:"tab","aria-selected":e==="fields","data-testid":"toolbox-tab-fields",onClick:()=>r("fields"),style:e==="fields"?o:n,children:a.toolbox.tabFields}),jsxRuntime.jsx("div",{role:"tab","aria-selected":e==="variables","data-testid":"toolbox-tab-variables",onClick:()=>r("variables"),style:e==="variables"?o:n,children:a.toolbox.tabVariables})]})}function $r({templates:e,scopeIds:r,search:a,onAdd:n,defaultLang:o,labels:t}){let l=d=>jsxRuntime.jsx("div",{"data-testid":"toolbox-variables-empty",style:{padding:"14px",color:"#94a3b8",fontSize:"12px",textAlign:"center",fontStyle:"italic"},children:d});if(!r||r.length===0)return l(t.toolbox.noScope);if(e.length===0)return l(t.toolbox.noTemplates);let i=a.toLowerCase(),s=e.filter(d=>{if(!i)return true;let c=d.code.toLowerCase().includes(i),y=Mo(d.name,o).toLowerCase().includes(i);return c||y}).slice().sort((d,c)=>d.code.localeCompare(c.code));return s.length===0?l(t.toolbox.noTemplates):jsxRuntime.jsx("div",{style:{display:"flex",flexDirection:"column",gap:"4px"},children:s.map(d=>jsxRuntime.jsxs("div",{"data-testid":`toolbox-template-${d.code}`,onClick:()=>n(d),style:{display:"flex",alignItems:"center",gap:"8px",padding:"6px 8px",borderRadius:"6px",cursor:"pointer",fontSize:"13px",color:"#334155",userSelect:"none"},onMouseEnter:c=>{c.currentTarget.style.backgroundColor="#e2e8f0";},onMouseLeave:c=>{c.currentTarget.style.backgroundColor="transparent";},children:[jsxRuntime.jsx("span",{style:{fontSize:"10px",fontWeight:600,padding:"2px 6px",borderRadius:"4px",backgroundColor:"#e0e7ff",color:"#3730a3",textTransform:"uppercase",letterSpacing:"0.3px",minWidth:"42px",textAlign:"center"},children:d.variableType}),jsxRuntime.jsxs("div",{style:{display:"flex",flexDirection:"column",minWidth:0,flex:1},children:[jsxRuntime.jsx("span",{style:{fontFamily:"monospace",fontSize:"11px",color:"#475569",whiteSpace:"nowrap",overflow:"hidden",textOverflow:"ellipsis"},children:d.code}),jsxRuntime.jsx("span",{style:{fontSize:"12px",color:"#1e293b",whiteSpace:"nowrap",overflow:"hidden",textOverflow:"ellipsis"},children:Mo(d.name,o)})]})]},d.id))})}function Mo(e,r){return formCore.resolveLabel(e,r,r)}function Ke(){let r=S(a=>a.form).langConfig?.defaultLang??formCore.DEFAULT_LANG_CONFIG.defaultLang;return a=>formCore.resolveLabel(a,r,r)}function Mr(e){let r=e.slice().sort((o,t)=>o.order-t.order),a=[],n=null;for(let o of r){if(formCore.isPageRoster(o)){n&&(a.push({kind:"variables",variables:n}),n=null),a.push({kind:"roster",roster:o});continue}let t=o;t.startWithNewLine===false&&n&&n.length>0?n.push(t):(n&&a.push({kind:"variables",variables:n}),n=[t]);}return n&&a.push({kind:"variables",variables:n}),a}function Wr(){let{form:e,select:r}=S(),a=R(),n=o=>{o.target===o.currentTarget&&r({type:"form"});};return e.pages.length===0?jsxRuntime.jsx("div",{"data-testid":"canvas-empty",onClick:n,style:{flex:1,display:"flex",alignItems:"center",justifyContent:"center",color:"#94a3b8",fontSize:"14px",cursor:"pointer"},children:a.canvas.emptyStateNoPage}):jsxRuntime.jsx("div",{"data-testid":"canvas-root",onClick:n,style:{flex:1,overflowY:"auto",padding:"16px",backgroundColor:"#fff"},children:e.pages.slice().sort((o,t)=>o.order-t.order).map(o=>jsxRuntime.jsx(qr,{page:o},o.code))})}function qr({page:e}){let{selection:r,select:a,removePage:n}=S(),o=R(),t=Ke(),l=r.type==="page"&&r.pageCode===e.code,i=e.items??[...formCore.getPageVariables(e),...e.rosters??[]],s=i.filter(formCore.isPageVariable).length,d=i.filter(formCore.isPageRoster).length,c=Mr(i);return jsxRuntime.jsxs("div",{style:{marginBottom:"16px",border:`2px solid ${l?"#2563eb":"#e2e8f0"}`,borderRadius:"8px",overflow:"hidden"},children:[jsxRuntime.jsxs("div",{onClick:()=>a({type:"page",pageCode:e.code}),style:{padding:"10px 14px",backgroundColor:l?"#eff6ff":"#f8fafc",borderBottom:"1px solid #e2e8f0",cursor:"pointer",display:"flex",alignItems:"center",justifyContent:"space-between"},children:[jsxRuntime.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"8px"},children:[jsxRuntime.jsx("span",{style:{fontSize:"14px",fontWeight:600,color:"#1e293b"},children:t(e.name)||o.canvas.unnamedPage}),e.isRepeatable&&jsxRuntime.jsx("span",{style:{fontSize:"10px",padding:"1px 6px",borderRadius:"4px",backgroundColor:"#dbeafe",color:"#2563eb",fontWeight:500},children:o.canvas.repeatable})]}),jsxRuntime.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"8px"},children:[jsxRuntime.jsx("span",{style:{fontSize:"12px",color:"#94a3b8"},children:o.canvas.fieldsRostersCount(s,d)}),jsxRuntime.jsx("button",{onClick:y=>{y.stopPropagation(),n(e.code);},style:{border:"none",background:"none",color:"#ef4444",cursor:"pointer",fontSize:"14px",padding:"2px 4px"},children:"\xD7"})]})]}),jsxRuntime.jsxs("div",{style:{padding:"4px 0"},children:[c.map((y,m)=>y.kind==="roster"?jsxRuntime.jsx(Ur,{roster:y.roster,pageCode:e.code},`r-${y.roster.code}`):y.variables.length===1?jsxRuntime.jsx(je,{variable:y.variables[0],pageCode:e.code},y.variables[0].code):jsxRuntime.jsx("div",{style:{display:"flex",gap:"2px",backgroundColor:"#f0f4ff",borderLeft:"2px solid #c7d2fe",margin:"1px 0"},children:y.variables.map(p=>jsxRuntime.jsx("div",{style:{flex:p.colSpan?`0 0 ${p.colSpan/12*100}%`:"1 1 0%",minWidth:0},children:jsxRuntime.jsx(je,{variable:p,pageCode:e.code})},p.code))},`row-${m}`)),i.length===0&&jsxRuntime.jsx("div",{style:{padding:"12px 14px",color:"#94a3b8",fontSize:"12px",fontStyle:"italic"},children:o.canvas.emptyStatePage})]})]})}function je({variable:e,pageCode:r,rosterCode:a}){let{selection:n,select:o,removeVariable:t}=S(),l=R(),i=Ke(),s=n.type==="variable"&&n.variableCode===e.code;return jsxRuntime.jsxs("div",{onClick:d=>{d.stopPropagation(),o({type:"variable",pageCode:r,variableCode:e.code,rosterCode:a});},style:{display:"flex",alignItems:"center",gap:"8px",padding:"6px 14px",cursor:"pointer",backgroundColor:s?"#eff6ff":"transparent",borderLeft:s?"3px solid #2563eb":"3px solid transparent",fontSize:"13px"},children:[jsxRuntime.jsx("span",{style:{color:"#94a3b8",fontSize:"11px",width:"60px",flexShrink:0},children:e.type}),jsxRuntime.jsx("span",{style:{color:"#334155",flex:1},children:i(e.name)||e.code}),e.isRequired&&jsxRuntime.jsx("span",{style:{color:"#ef4444",fontSize:"11px"},children:"*"}),e.conditions&&e.conditions.length>0&&jsxRuntime.jsx("span",{style:{color:"#f59e0b",fontSize:"11px"},title:l.canvas.hasConditionsTitle,children:"\u26A1"}),e.dataSourceId&&jsxRuntime.jsx("span",{style:{color:"#22c55e",fontSize:"11px"},title:l.canvas.dataSourceConnectedTitle,children:"\u27F3"}),jsxRuntime.jsx("button",{onClick:d=>{d.stopPropagation(),t(r,e.code,a);},style:{border:"none",background:"none",color:"#ef4444",cursor:"pointer",fontSize:"12px",padding:"0 2px",opacity:.5},children:"\xD7"})]})}function Ur({roster:e,pageCode:r}){let{selection:a,select:n,removeRoster:o,addVariable:t}=S(),l=R(),i=Ke(),s=a.type==="roster"&&a.rosterCode===e.code,d=c=>{c.stopPropagation();let y=`RV_${Date.now().toString(36).slice(-4).toUpperCase()}`;t(r,{id:`var-${Date.now()}`,code:y,name:l.canvas.newFieldName,type:"text",order:e.variables.length,isRequired:false,isReadonly:false,isHidden:false},e.code);};return jsxRuntime.jsxs("div",{style:{margin:"4px 8px",border:`1px solid ${s?"#2563eb":"#e2e8f0"}`,borderRadius:"6px",overflow:"hidden"},children:[jsxRuntime.jsxs("div",{onClick:c=>{c.stopPropagation(),n({type:"roster",pageCode:r,rosterCode:e.code});},style:{padding:"6px 10px",backgroundColor:s?"#fef3c7":"#fffbeb",fontSize:"12px",fontWeight:600,color:"#92400e",cursor:"pointer",display:"flex",alignItems:"center",justifyContent:"space-between"},children:[jsxRuntime.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"6px"},children:[jsxRuntime.jsxs("span",{children:["\u25A4 ",i(e.name)||e.code]}),jsxRuntime.jsx("span",{style:{fontSize:"10px",padding:"1px 4px",borderRadius:"3px",backgroundColor:"#fde68a",color:"#78350f"},children:e.rosterType}),e.pilotVariableCode&&jsxRuntime.jsxs("span",{style:{fontSize:"10px",color:"#92400e",fontWeight:400},children:[l.canvas.pilotPrefix," ",e.pilotVariableCode]})]}),jsxRuntime.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"4px"},children:[jsxRuntime.jsx("span",{style:{fontSize:"11px",color:"#b45309"},children:l.canvas.rosterVarsCount(e.variables.length)}),jsxRuntime.jsx("button",{onClick:c=>{c.stopPropagation(),o(r,e.code);},style:{border:"none",background:"none",color:"#ef4444",cursor:"pointer",fontSize:"12px"},children:"\xD7"})]})]}),e.variables.slice().sort((c,y)=>c.order-y.order).map(c=>jsxRuntime.jsx(je,{variable:c,pageCode:r,rosterCode:e.code},c.code)),jsxRuntime.jsx("div",{style:{padding:"4px 10px",borderTop:"1px solid #fde68a"},children:jsxRuntime.jsx("button",{onClick:d,style:{padding:"2px 8px",borderRadius:"3px",border:"1px dashed #d4a843",backgroundColor:"transparent",color:"#92400e",fontSize:"10px",cursor:"pointer"},children:l.canvas.addFieldToRoster})})]})}exports.Canvas=he;exports.CanvasDnd=he;exports.CanvasSimple=Wr;exports.ConditionBuilder=_e;exports.DataSourceSelector=Ne;exports.DndManager=ze;exports.EditorLabelsProvider=xe;exports.EditorToolbar=Fe;exports.FormEditor=Pr;exports.PropertiesPanel=Ue;exports.Toolbox=Ce;exports.ToolboxDnd=Ce;exports.ToolboxSimple=zr;exports.createDragEndHandler=mo;exports.defaultLabels=Z;exports.enLabels=eo;exports.frLabels=Z;exports.mergeLabels=ve;exports.useEditorStore=S;exports.useLabels=R;//# sourceMappingURL=index.cjs.map
|
|
1
|
+
'use strict';var Kr=require('react'),zustand=require('zustand'),formCore=require('@msbci/form-core'),jsxRuntime=require('react/jsx-runtime'),core=require('@dnd-kit/core'),sortable=require('@dnd-kit/sortable'),utilities=require('@dnd-kit/utilities');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var Kr__default=/*#__PURE__*/_interopDefault(Kr);function po(e,r){return {itemType:"variable",id:formCore.generateId(),code:e.code,name:e.name,type:e.variableType,order:r,isRequired:e.isRequired??false,isReadonly:e.isReadonly??false,isHidden:e.isHidden??false,description:e.description,placeholder:e.placeholder,options:e.options,validationRules:e.validationRules,conditions:e.conditions,expression:e.expression,dataSourceId:e.dataSourceId,dataSourceDependencies:e.dataSourceDependencies,style:e.style,metadata:e.metadata,templateId:e.id,templateOverrides:{}}}function co(e,r,a){return r==="variableType"?{...e,type:a}:{...e,[r]:a}}function ct(e,r){return r==="variableType"?e.variableType:e[r]}var ut=50;function ft(){return {id:"",code:"",name:"New Form",version:"1.0.0",isPublished:false,pages:[]}}function B(e,r){let a=Array.isArray(e.items)?e.items:[...formCore.getPageVariables(e),...formCore.getPageRosters(e)],{variables:n,rosters:o,...t}=e;return {...t,items:r(a)}}var R=zustand.create((e,r)=>{function a(o){let t=r(),i={form:formCore.deepClone(t.form),description:o,timestamp:Date.now()},l=t.history.slice(0,t.historyIndex+1);l.push(i),l.length>ut&&l.shift(),e({history:l,historyIndex:l.length-1});}function n(o,t){a(o);let i=r(),l=t(formCore.deepClone(i.form));e({form:l,isDirty:true});}return {form:ft(),formTypes:[],selection:{type:"form"},view:"canvas",isDirty:false,isSaving:false,history:[],historyIndex:-1,adapter:null,availableTemplates:[],availableScopes:[],availableDataSources:[],setForm:o=>{e({form:formCore.migrateFormToItems(formCore.deepClone(o)),isDirty:false,history:[],historyIndex:-1,selection:{type:"form"}});},updateFormMeta:o=>{n("Update form metadata",t=>({...t,...o}));},addPage:o=>{let t=Array.isArray(o.items)?o:{...o,items:[...o.variables??[],...o.rosters??[]]};n(`Add page "${t.name}"`,i=>({...i,pages:[...i.pages,t]}));},updatePage:(o,t)=>{n(`Update page "${o}"`,i=>({...i,pages:i.pages.map(l=>l.code===o?{...l,...t}:l)}));},removePage:o=>{n(`Remove page "${o}"`,i=>({...i,pages:i.pages.filter(l=>l.code!==o)}));let t=r();t.selection.type==="page"&&t.selection.pageCode===o&&e({selection:{type:"form"}});},reorderPages:o=>{n("Reorder pages",t=>{let i=new Map(t.pages.map(d=>[d.code,d])),l=o.map((d,s)=>{let c=i.get(d);return c?{...c,order:s}:void 0}).filter(d=>d!==void 0);return {...t,pages:l}});},addRoster:(o,t)=>{n(`Add roster "${t.name}" to page "${o}"`,i=>({...i,pages:i.pages.map(l=>l.code!==o?l:B(l,d=>[...d,{...t,itemType:"roster",order:d.length}]))}));},updateRoster:(o,t,i)=>{n(`Update roster "${t}"`,l=>({...l,pages:l.pages.map(d=>d.code!==o?d:B(d,s=>s.map(c=>formCore.isPageRoster(c)&&c.code===t?{...c,...i,itemType:"roster"}:c)))}));},removeRoster:(o,t)=>{n(`Remove roster "${t}"`,i=>({...i,pages:i.pages.map(l=>l.code!==o?l:B(l,d=>d.filter(s=>!(formCore.isPageRoster(s)&&s.code===t))))}));},addVariable:(o,t,i)=>{n(`Add variable "${t.name}"`,l=>({...l,pages:l.pages.map(d=>d.code!==o?d:i?B(d,s=>s.map(c=>formCore.isPageRoster(c)&&c.code===i?{...c,variables:[...c.variables,t]}:c)):B(d,s=>[...s,{...t,itemType:"variable",order:s.length}]))}));},updateVariable:(o,t,i,l)=>{n(`Update variable "${t}"`,d=>({...d,pages:d.pages.map(s=>s.code!==o?s:l?B(s,c=>c.map(x=>formCore.isPageRoster(x)&&x.code===l?{...x,variables:x.variables.map(y=>y.code===t?{...y,...i}:y)}:x)):B(s,c=>c.map(x=>formCore.isPageVariable(x)&&x.code===t?{...x,...i,itemType:"variable"}:x)))}));},removeVariable:(o,t,i)=>{n(`Remove variable "${t}"`,l=>({...l,pages:l.pages.map(d=>d.code!==o?d:i?B(d,s=>s.map(c=>formCore.isPageRoster(c)&&c.code===i?{...c,variables:c.variables.filter(x=>x.code!==t)}:c)):B(d,s=>s.filter(c=>!(formCore.isPageVariable(c)&&c.code===t))))}));},addVariableFromTemplate:(o,t,i)=>{n(`Add variable from template "${t.code}"`,l=>({...l,pages:l.pages.map(d=>d.code!==o?d:i?B(d,s=>s.map(c=>{if(!(formCore.isPageRoster(c)&&c.code===i))return c;let x=po(t,c.variables.length);return {...c,variables:[...c.variables,x]}})):B(d,s=>[...s,po(t,s.length)]))}));},setVariableOverride:(o,t,i,l,d)=>{n(`Override "${String(i)}" on "${t}"`,s=>({...s,pages:s.pages.map(c=>{if(c.code!==o)return c;let x=y=>{let p={...y.templateOverrides??{},[i]:l};return {...co(y,i,l),templateOverrides:p}};return d?B(c,y=>y.map(p=>formCore.isPageRoster(p)&&p.code===d?{...p,variables:p.variables.map(f=>f.code===t?x(f):f)}:p)):B(c,y=>y.map(p=>formCore.isPageVariable(p)&&p.code===t?x(p):p))})}));},resetVariableOverride:(o,t,i,l)=>{let d=r().availableTemplates;n(`Reset override "${String(i)}" on "${t}"`,s=>({...s,pages:s.pages.map(c=>{if(c.code!==o)return c;let x=y=>{let p={...y.templateOverrides??{}};delete p[i];let f=y.templateId?d.find(b=>b.id===y.templateId):void 0,g=f?ct(f,i):void 0;return {...co(y,i,g),templateOverrides:p}};return l?B(c,y=>y.map(p=>formCore.isPageRoster(p)&&p.code===l?{...p,variables:p.variables.map(f=>f.code===t?x(f):f)}:p)):B(c,y=>y.map(p=>formCore.isPageVariable(p)&&p.code===t?x(p):p))})}));},moveVariable:(o,t,i,l,d,s)=>{n(`Move variable "${i}"`,c=>{let x,y=c.pages.map(f=>f.code!==o?f:d?B(f,g=>g.map(u=>{if(!(formCore.isPageRoster(u)&&u.code===d))return u;let b=u.variables.find(m=>m.code===i);return b&&(x={...b}),{...u,variables:u.variables.filter(m=>m.code!==i)}})):B(f,g=>g.filter(u=>formCore.isPageVariable(u)&&u.code===i?(x={...u},false):true)));if(!x)return c;x={...x,order:l,itemType:"variable"};let p=y.map(f=>f.code!==t?f:s?B(f,g=>g.map(u=>formCore.isPageRoster(u)&&u.code===s?{...u,variables:[...u.variables,x].sort((b,m)=>b.order-m.order)}:u)):B(f,g=>[...g,x].sort((u,b)=>u.order-b.order)));return {...c,pages:p}});},moveItem:(o,t,i)=>{n(`Reorder page items in "${o}"`,l=>({...l,pages:l.pages.map(d=>d.code!==o?d:B(d,s=>{if(t<0||t>=s.length||i<0||i>=s.length||t===i)return s;let c=s.slice(),[x]=c.splice(t,1);return c.splice(i,0,x),c.map((y,p)=>({...y,order:p}))}))}));},select:o=>e({selection:o}),clearSelection:()=>e({selection:{type:"form"}}),setView:o=>e({view:o}),undo:()=>{let{history:o,historyIndex:t,form:i}=r();if(!(t<0))if(t===o.length-1){let l={form:formCore.deepClone(i),description:"Current state",timestamp:Date.now()};e({form:formCore.deepClone(o[t].form),historyIndex:t-1,isDirty:true,history:[...o,l]});}else e({form:formCore.deepClone(o[t].form),historyIndex:t-1,isDirty:true});},redo:()=>{let{history:o,historyIndex:t}=r();if(t>=o.length-2)return;let i=t+2;i<o.length&&e({form:formCore.deepClone(o[i].form),historyIndex:i-1,isDirty:true});},canUndo:()=>r().historyIndex>=0,canRedo:()=>{let{history:o,historyIndex:t}=r();return t<o.length-2},addFormType:o=>{let t={...o,id:formCore.generateId()};e(i=>({formTypes:[...i.formTypes,t]}));},updateFormType:(o,t)=>{e(i=>({formTypes:i.formTypes.map(l=>l.id===o?{...l,...t}:l)}));},removeFormType:o=>{let t=r();if(t.form.formTypeId===o){let{formTypeId:i,...l}=t.form;e({form:{...l}});}e(i=>({formTypes:i.formTypes.filter(l=>l.id!==o)}));},setAvailableTemplates:o=>{e({availableTemplates:o});},setAvailableScopes:o=>{e({availableScopes:o});},setAvailableDataSources:o=>{e({availableDataSources:o});},setAdapter:o=>e({adapter:o}),save:async()=>{let{adapter:o,form:t}=r();if(o?.saveForm){e({isSaving:true});try{await o.saveForm(t),e({isDirty:!1});}finally{e({isSaving:false});}}},load:async o=>{let{adapter:t}=r();if(!t?.loadForm)return;let i=await t.loadForm(o);r().setForm(i);},exportJson:()=>formCore.serializeForm(r().form),importJson:o=>{let t=formCore.deserializeForm(o);r().setForm(t);}}});var de={toolbar:{formNamePlaceholder:"Nom du formulaire",unsaved:"Non sauvegard\xE9",addPage:"+ Page",formProperties:"Propri\xE9t\xE9s du formulaire",types:"Types",manageFormTypesTitle:"G\xE9rer les types de formulaire",dataSources:"Sources",manageDataSourcesTitle:"G\xE9rer les sources de donn\xE9es",undo:"Annuler",redo:"R\xE9tablir",save:"Enregistrer",saving:"Enregistrement...",export:"Exporter",import:"Importer",viewEditor:"\xC9diteur",viewPreview:"Aper\xE7u",viewJson:"JSON"},toolbox:{searchPlaceholder:"Rechercher...",addPageFirst:"Ajoutez d\u2019abord une page",tabFields:"Champs",tabVariables:"Variables",noTemplates:"Aucune variable dans ce scope",noScope:"Configurez un scope pour acc\xE9der au r\xE9f\xE9rentiel",groupText:"Texte",groupSelection:"S\xE9lection",groupDateTime:"Date et heure",groupMedia:"M\xE9dias",groupAdvanced:"Avanc\xE9",groupRoster:"Roster",typeRosterCheck:"Cases \xE0 cocher",typeRosterList:"Liste",typeRosterCollection:"Collection",typeRosterCollectionExtend:"Collection \xE9tendue",types:{text:"Texte court",textarea:"Zone de texte",number:"Nombre",email:"Email",select:"Liste d\xE9roulante",multiselect:"Multi-s\xE9lection",radio:"Boutons radio",checkbox:"Cases \xE0 cocher",date:"Date",datetime:"Date et heure",time:"Heure",file:"Fichier",image:"Image",gps:"GPS",rating:"Note (\xE9toiles)",calculated:"Calcul\xE9",hidden:"Masqu\xE9",label:"\xC9tiquette"}},canvas:{emptyStateNoPage:"Cliquez sur \xAB + Page \xBB dans la barre d\u2019outils pour commencer",emptyStateNoPageDnd:"Glissez un champ depuis la bo\xEEte \xE0 outils ou ajoutez une page pour commencer",emptyStatePage:"Cliquez sur un type de champ dans la bo\xEEte \xE0 outils pour l\u2019ajouter ici",unnamedPage:"Page sans nom",repeatable:"R\xE9p\xE9table",fieldsRostersCount:(e,r)=>`${e} champ${e>1?"s":""} \xB7 ${r} roster${r>1?"s":""}`,fieldsCount:e=>`${e} champ${e>1?"s":""}`,rosterVarsCount:e=>`${e} variable${e>1?"s":""}`,addRoster:"+ Ajouter un roster",addFieldToRoster:"+ Ajouter un champ au roster",pilotPrefix:"pilote :",newRosterName:"Nouveau roster",newFieldName:"Nouveau champ",newVariableName:e=>`Nouveau ${e.toLowerCase()}`,hasConditionsTitle:"Contient des conditions",dataSourceConnectedTitle:"Source de donn\xE9es connect\xE9e"},properties:{title:"Propri\xE9t\xE9s",name:"Nom",code:"Code",description:"Description",placeholder:"Placeholder",version:"Version",formType:"Type de formulaire",noType:"\u2014 Aucun type \u2014",formSummary:(e,r)=>`${e} page${e>1?"s":""} \xB7 ${r} variable${r>1?"s":""}`,pageSummary:(e,r)=>`${e} variable${e>1?"s":""} \xB7 ${r} roster${r>1?"s":""}`,rosterSummary:(e,r)=>`${e} variable${e>1?"s":""} \xB7 ${r} option${r>1?"s":""}`,repeatablePage:"Page r\xE9p\xE9table",minInstances:"Minimum d\u2019instances",maxInstances:"Maximum d\u2019instances",controlVariableCode:"Code de la variable de contr\xF4le",instanceLabel:"Mod\xE8le de libell\xE9 d\u2019instance",rosterType:"Type de roster",pilotVariableCode:"Code de la variable pilote",rosterTypes:{check:"Cases \xE0 cocher (s\xE9lection multiple)",list:"Liste (dropdown par ligne)",collection:"Collection (ajout/suppression de lignes)",collection_extend:"Collection \xE9tendue (vue tableau)"},linkedTemplate:"Variable li\xE9e au r\xE9f\xE9rentiel",templateCode:"Code (non modifiable)",templateName:"Nom (non modifiable)",resetOverride:"R\xE9initialiser",type:"Type",ratingStyle:"Style de notation",ratingStyles:{star:"\u2605 \xC9toiles",number:"123 Nombres",color:"\u25CF Points de couleur"},layout:"Mise en page",startNewRow:"Nouvelle ligne",columnSpan:"Largeur (colonnes, 1-12)",columnSpanAuto:"Auto (part \xE9gale)",columnSpanHalf:" (moiti\xE9)",columnSpanThird:" (tiers)",columnSpanFull:" (pleine largeur)",required:"Obligatoire",readonly:"Lecture seule",hidden:"Masqu\xE9 par d\xE9faut",expression:"Expression",scopes:"Scopes (r\xE9f\xE9rentiel de variables)",scopesHint:"L\u2019ordre d\xE9finit la priorit\xE9 : le premier scope gagne en cas de conflit sur un code.",noScopesAvailable:"Aucun scope disponible \u2014 configurez-en un via l\u2019API ou le seed.",moveScopeUp:"Monter",moveScopeDown:"Descendre",removeScope:"Retirer",langConfigSection:"Langues",langConfigAvailable:"Langues disponibles",langConfigDefault:"Langue par d\xE9faut",langConfigStrategy:"Strat\xE9gie de d\xE9tection",langConfigStrategies:{prop:"Propri\xE9t\xE9 (prop)",browser:"Navigateur",selector:"S\xE9lecteur dans le formulaire",auto:"Auto (navigateur puis d\xE9faut)"},langConfigSelectorPosition:"Position du s\xE9lecteur",langConfigPositions:{top:"Haut",bottom:"Bas"},langConfigConfirmRemove:e=>`Supprimer la langue \xAB ${e.toUpperCase()} \xBB supprimera toutes les traductions ${e.toUpperCase()}. Confirmer ?`,langConfigConfirmYes:"Supprimer",langConfigConfirmNo:"Annuler"},optionsEditor:{optionsCount:e=>`Options (${e})`,noOptions:"Aucune option. Ajoutez-en une pour peupler les choix.",optionLabelPlaceholder:"Libell\xE9",optionValuePlaceholder:"valeur",addOption:"+ Ajouter une option",optionLabelAria:e=>`Libell\xE9 de l\u2019option ${e+1}`,optionValueAria:e=>`Valeur de l\u2019option ${e+1}`,removeOptionAria:e=>`Supprimer l\u2019option ${e+1}`},conditionBuilder:{conditionsCount:e=>`Conditions (${e})`,addCondition:"+ Ajouter une condition",rulesCount:e=>` (${e} r\xE8gle${e>1?"s":""})`,addRule:"+ Ajouter une r\xE8gle",action:"Action",match:"Correspondance",all:"TOUT (ET)",any:"AU MOINS UN (OU)",actions:{show:"Afficher si",hide:"Masquer si",validate:"Valider que",require:"Obligatoire si",readonly:"Lecture seule si",setValue:"D\xE9finir la valeur si"},operators:{equals:"est \xE9gal \xE0",not_equals:"est diff\xE9rent de",greater_than:"est sup\xE9rieur \xE0",less_than:"est inf\xE9rieur \xE0",greater_than_or_equal:"est sup\xE9rieur ou \xE9gal \xE0",less_than_or_equal:"est inf\xE9rieur ou \xE9gal \xE0",contains:"contient",not_contains:"ne contient pas",is_empty:"est vide",is_not_empty:"n\u2019est pas vide",starts_with:"commence par",ends_with:"se termine par",in:"est dans la liste",not_in:"n\u2019est pas dans la liste",between:"est entre",regex:"correspond au pattern"},variablePlaceholder:"Variable...",valuePlaceholder:"Valeur",errorMessage:"Message d\u2019erreur",errorMessagePlaceholder:"Message d\u2019erreur de validation",targetVariableCode:"Code de la variable cible",targetVariablePlaceholder:"VAR_CIBLE",valueToSet:"Valeur \xE0 d\xE9finir",valueToSetPlaceholder:"Valeur",modalTitle:e=>`Conditions (${e})`,configureButton:e=>e===0?"Configurer les conditions":`Configurer les conditions (${e})`,applyButton:"Appliquer",cancelButton:"Annuler",closeButton:"Fermer",formulasSummary:"Formules configur\xE9es",noConditions:"Aucune condition configur\xE9e",modeVisual:"Constructeur visuel",modeManual:"Saisie manuelle",manualWarning:"Expression complexe \u2014 le constructeur visuel ne peut pas la repr\xE9senter. Restez en mode manuel pour la modifier.",manualPlaceholder:"Ex : show(${AGE} >= 18)",manualHelp:"Fonctions : show / hide / setValue / validate / require / readonly / ConditionEval. Variables : ${CODE}.",validationExpression:"Expression de validation",validationExpressionPlaceholder:'Ex : ${CHAMP} != ""'},dataSource:{title:"Source de donn\xE9es",connector:"Connecteur",none:"Aucune (options statiques)",connectedTo:"Connect\xE9 \xE0 :",dependencies:e=>`D\xE9pendances (${e})`,selectVariable:"S\xE9lectionner une variable...",dependencyKeyPlaceholder:"Cl\xE9 de d\xE9pendance (ex : parentId)",addDependency:"+ Ajouter"},dataSourceManager:{dialogAriaLabel:"Sources de donn\xE9es",title:"Sources de donn\xE9es",closeAriaLabel:"Fermer",addButton:"+ Ajouter une source",noSources:"Aucune source dans ce scope. Ajoutez-en une ci-dessous.",noScope:"Le formulaire n\u2019a aucun scope \u2014 ajoutez-en un dans les propri\xE9t\xE9s du formulaire.",scopeFilterLabel:"Scope",fieldCode:"Code",fieldName:"Nom",fieldUrl:"URL",fieldMethod:"M\xE9thode",fieldQueryParam:"Param\xE8tre de recherche",fieldValueField:"Champ valeur",fieldLabelField:"Champ libell\xE9",fieldHeaders:"Headers (chiffr\xE9s)",headerKeyPlaceholder:"Cl\xE9 (ex : Authorization)",headerValuePlaceholder:"Valeur",addHeader:"+ Ajouter un header",fieldDependencies:"D\xE9pendances",dependencyParamPlaceholder:"Param\xE8tre URL",dependencyVarPlaceholder:"Code variable",addDependency:"+ Ajouter une d\xE9pendance",save:"Enregistrer",cancel:"Annuler",editAria:e=>`Modifier la source ${e}`,deleteAria:e=>`Supprimer la source ${e}`,scopeBadge:e=>`Scope : ${e}`,confirmDelete:e=>`Supprimer la source "${e}" ?`},formTypesDialog:{dialogAriaLabel:"Types de formulaires",title:"Types de formulaires",closeAriaLabel:"Fermer",noTypes:"Aucun type d\xE9fini. Ajoutez-en un ci-dessous.",confirmDelete:"Ce type est utilis\xE9 par le formulaire courant. Confirmer la suppression ?",deleteConfirm:"Supprimer",deleteCancel:"Annuler",removeTypeAria:e=>`Supprimer ${e}`,newTypeNamePlaceholder:"Nom du nouveau type",newTypeCodePlaceholder:"CODE (auto)",addButton:"+ Ajouter"},formEditor:{previewMissing:"Passer la prop PreviewComponent pour activer l\u2019aper\xE7u"}};var fo={toolbar:{formNamePlaceholder:"Form name",unsaved:"Unsaved",addPage:"+ Page",formProperties:"Form properties",types:"Types",manageFormTypesTitle:"Manage form types",dataSources:"Sources",manageDataSourcesTitle:"Manage data sources",undo:"Undo",redo:"Redo",save:"Save",saving:"Saving...",export:"Export",import:"Import",viewEditor:"Editor",viewPreview:"Preview",viewJson:"JSON"},toolbox:{searchPlaceholder:"Search fields...",addPageFirst:"Add a page first",tabFields:"Fields",tabVariables:"Variables",noTemplates:"No variables in this scope",noScope:"Configure a scope to access the variable library",groupText:"Text",groupSelection:"Selection",groupDateTime:"Date & Time",groupMedia:"Media",groupAdvanced:"Advanced",groupRoster:"Roster",typeRosterCheck:"Checks",typeRosterList:"List",typeRosterCollection:"Collection",typeRosterCollectionExtend:"Collection extended",types:{text:"Text",textarea:"Text Area",number:"Number",email:"Email",select:"Dropdown",multiselect:"Multi Select",radio:"Radio",checkbox:"Checkbox",date:"Date",datetime:"DateTime",time:"Time",file:"File",image:"Image",gps:"GPS",rating:"Rating (stars)",calculated:"Calculated",hidden:"Hidden",label:"Label"}},canvas:{emptyStateNoPage:'Click "+ Page" in the toolbar to get started',emptyStateNoPageDnd:"Drag a field from the toolbox or add a page to get started",emptyStatePage:"Click a field type in the toolbox to add it here",unnamedPage:"Unnamed Page",repeatable:"Repeatable",fieldsRostersCount:(e,r)=>`${e} field${e===1?"":"s"} \xB7 ${r} roster${r===1?"":"s"}`,fieldsCount:e=>`${e} field${e===1?"":"s"}`,rosterVarsCount:e=>`${e} var${e===1?"":"s"}`,addRoster:"+ Add Roster",addFieldToRoster:"+ Add field to roster",pilotPrefix:"pilot:",newRosterName:"New Roster",newFieldName:"New field",newVariableName:e=>`New ${e}`,hasConditionsTitle:"Has conditions",dataSourceConnectedTitle:"Data source connected"},properties:{title:"Properties",name:"Name",code:"Code",description:"Description",placeholder:"Placeholder",version:"Version",formType:"Form type",noType:"\u2014 No type \u2014",formSummary:(e,r)=>`${e} page${e===1?"":"s"} \xB7 ${r} variable${r===1?"":"s"}`,pageSummary:(e,r)=>`${e} variable${e===1?"":"s"} \xB7 ${r} roster${r===1?"":"s"}`,rosterSummary:(e,r)=>`${e} variable${e===1?"":"s"} \xB7 ${r} option${r===1?"":"s"}`,repeatablePage:"Repeatable page",minInstances:"Min instances",maxInstances:"Max instances",controlVariableCode:"Control variable code",instanceLabel:"Instance label template",rosterType:"Roster Type",pilotVariableCode:"Pilot variable code",rosterTypes:{check:"Check (multi-select checkboxes)",list:"List (dropdown per row)",collection:"Collection (add/remove rows)",collection_extend:"Collection Extended (table view)"},linkedTemplate:"Linked to variable library",templateCode:"Code (read-only)",templateName:"Name (read-only)",resetOverride:"Reset",type:"Type",ratingStyle:"Rating style",ratingStyles:{star:"\u2605 Stars",number:"123 Numbers",color:"\u25CF Color dots"},layout:"Layout",startNewRow:"Start new row",columnSpan:"Column span (1-12)",columnSpanAuto:"Auto (equal share)",columnSpanHalf:" (half)",columnSpanThird:" (third)",columnSpanFull:" (full)",required:"Required",readonly:"Read only",hidden:"Hidden by default",expression:"Expression",scopes:"Scopes (variable library)",scopesHint:"Order defines priority: the first scope wins on code conflicts.",noScopesAvailable:"No scope available \u2014 create one via the API or seed.",moveScopeUp:"Move up",moveScopeDown:"Move down",removeScope:"Remove",langConfigSection:"Languages",langConfigAvailable:"Available languages",langConfigDefault:"Default language",langConfigStrategy:"Detection strategy",langConfigStrategies:{prop:"Prop (host-controlled)",browser:"Browser",selector:"In-form selector",auto:"Auto (browser then default)"},langConfigSelectorPosition:"Selector position",langConfigPositions:{top:"Top",bottom:"Bottom"},langConfigConfirmRemove:e=>`Removing "${e.toUpperCase()}" will delete every ${e.toUpperCase()} translation. Confirm?`,langConfigConfirmYes:"Delete",langConfigConfirmNo:"Cancel"},optionsEditor:{optionsCount:e=>`Options (${e})`,noOptions:"No options yet \u2014 add one to populate the choices.",optionLabelPlaceholder:"Label",optionValuePlaceholder:"value",addOption:"+ Add option",optionLabelAria:e=>`Option ${e+1} label`,optionValueAria:e=>`Option ${e+1} value`,removeOptionAria:e=>`Remove option ${e+1}`},conditionBuilder:{conditionsCount:e=>`Conditions (${e})`,addCondition:"+ Add condition",rulesCount:e=>` (${e} rule${e===1?"":"s"})`,addRule:"+ Add rule",action:"Action",match:"Match",all:"ALL (AND)",any:"ANY (OR)",actions:{show:"Show when",hide:"Hide when",validate:"Validate that",require:"Require when",readonly:"Read-only when",setValue:"Set value when"},operators:{equals:"equals",not_equals:"not equals",greater_than:"greater than",less_than:"less than",greater_than_or_equal:"greater than or equal",less_than_or_equal:"less than or equal",contains:"contains",not_contains:"not contains",is_empty:"is empty",is_not_empty:"is not empty",starts_with:"starts with",ends_with:"ends with",in:"in",not_in:"not in",between:"between",regex:"matches regex"},variablePlaceholder:"Variable...",valuePlaceholder:"Value",errorMessage:"Error message",errorMessagePlaceholder:"Validation error message",targetVariableCode:"Target variable code",targetVariablePlaceholder:"TARGET_VAR",valueToSet:"Value to set",valueToSetPlaceholder:"Value",modalTitle:e=>`Conditions (${e})`,configureButton:e=>e===0?"Configure conditions":`Configure conditions (${e})`,applyButton:"Apply",cancelButton:"Cancel",closeButton:"Close",formulasSummary:"Configured formulas",noConditions:"No condition configured",modeVisual:"Visual builder",modeManual:"Manual input",manualWarning:"Complex expression \u2014 the visual builder cannot represent it. Stay in manual mode to edit it.",manualPlaceholder:"e.g. show(${AGE} >= 18)",manualHelp:"Functions: show / hide / setValue / validate / require / readonly / ConditionEval. Variables: ${CODE}.",validationExpression:"Validation expression",validationExpressionPlaceholder:'e.g. ${FIELD} != ""'},dataSource:{title:"Data Source Connector",connector:"Connector",none:"None (static options)",connectedTo:"Connected to:",dependencies:e=>`Dependencies (${e})`,selectVariable:"Select variable...",dependencyKeyPlaceholder:"Dependency key (e.g. parentId)",addDependency:"+ Add"},dataSourceManager:{dialogAriaLabel:"Data sources",title:"Data sources",closeAriaLabel:"Close",addButton:"+ Add a source",noSources:"No source in this scope yet. Add one below.",noScope:"This form has no scope \u2014 link one in the form properties.",scopeFilterLabel:"Scope",fieldCode:"Code",fieldName:"Name",fieldUrl:"URL",fieldMethod:"Method",fieldQueryParam:"Search param",fieldValueField:"Value field",fieldLabelField:"Label field",fieldHeaders:"Headers (encrypted)",headerKeyPlaceholder:"Key (e.g. Authorization)",headerValuePlaceholder:"Value",addHeader:"+ Add header",fieldDependencies:"Dependencies",dependencyParamPlaceholder:"URL param",dependencyVarPlaceholder:"Variable code",addDependency:"+ Add dependency",save:"Save",cancel:"Cancel",editAria:e=>`Edit source ${e}`,deleteAria:e=>`Delete source ${e}`,scopeBadge:e=>`Scope: ${e}`,confirmDelete:e=>`Delete source "${e}"?`},formTypesDialog:{dialogAriaLabel:"Form types",title:"Form types",closeAriaLabel:"Close",noTypes:"No form types yet. Add one below.",confirmDelete:"This type is used by the current form. Confirm deletion?",deleteConfirm:"Delete",deleteCancel:"Cancel",removeTypeAria:e=>`Remove ${e}`,newTypeNamePlaceholder:"New type name",newTypeCodePlaceholder:"CODE (auto)",addButton:"+ Add"},formEditor:{previewMissing:"Pass PreviewComponent prop to enable preview"}};var bo=Kr.createContext(de);function De({labels:e,children:r}){return jsxRuntime.jsx(bo.Provider,{value:e,children:r})}function T(){return Kr.useContext(bo)}function Le(e){if(e===null||typeof e!="object")return false;let r=Object.getPrototypeOf(e);return r===Object.prototype||r===null}function Fe(e,r){return r?go(e,r):e}function go(e,r){if(!Le(e)||!Le(r))return r===void 0?e:r;let a={...e};for(let n of Object.keys(r)){let o=e[n],t=r[n];Le(o)&&Le(t)?a[n]=go(o,t):t!==void 0&&(a[n]=t);}return a}function mo({open:e,onClose:r}){let{formTypes:a,form:n,addFormType:o,updateFormType:t,removeFormType:i}=R(),l=T(),[d,s]=Kr.useState(""),[c,x]=Kr.useState(""),[y,p]=Kr.useState(null),[f,g]=Kr.useState(""),[u,b]=Kr.useState(null);if(!e)return null;let m=()=>{d.trim()&&(o({name:d.trim(),code:c.trim()||d.trim().toUpperCase().replace(/\s+/g,"_")}),s(""),x(""));},h=(S,V)=>{p(S),g(V);},P=()=>{y&&f.trim()&&t(y,{name:f.trim()}),p(null),g("");},v=S=>{n.formTypeId===S?b(S):i(S);},A=()=>{u&&i(u),b(null);};return jsxRuntime.jsx("div",{role:"dialog","aria-modal":"true","aria-label":l.formTypesDialog.dialogAriaLabel,"data-testid":"form-types-dialog",onClick:r,style:{position:"fixed",inset:0,backgroundColor:"rgba(0, 0, 0, 0.3)",zIndex:50,display:"flex",alignItems:"center",justifyContent:"center",padding:"16px"},children:jsxRuntime.jsxs("div",{onClick:S=>S.stopPropagation(),style:{backgroundColor:"#fff",borderRadius:"8px",maxWidth:"32rem",width:"100%",maxHeight:"80vh",overflow:"auto",boxShadow:"0 10px 25px rgba(0,0,0,0.2)",fontFamily:"system-ui, -apple-system, sans-serif",color:"#1e293b"},children:[jsxRuntime.jsxs("header",{style:{padding:"16px",borderBottom:"1px solid #e2e8f0",display:"flex",justifyContent:"space-between",alignItems:"center"},children:[jsxRuntime.jsx("h3",{style:{fontSize:"16px",fontWeight:600,margin:0},children:l.formTypesDialog.title}),jsxRuntime.jsx("button",{type:"button",onClick:r,"aria-label":l.formTypesDialog.closeAriaLabel,"data-testid":"form-types-dialog-close-x",style:{background:"transparent",border:"none",fontSize:"18px",cursor:"pointer",color:"#64748b",padding:"4px 8px"},children:"\xD7"})]}),jsxRuntime.jsxs("section",{style:{padding:"16px"},children:[a.length===0&&jsxRuntime.jsx("div",{"data-testid":"form-types-empty",style:{fontSize:"13px",color:"#94a3b8",marginBottom:"12px"},children:l.formTypesDialog.noTypes}),jsxRuntime.jsx("ul",{style:{listStyle:"none",padding:0,margin:0,display:"flex",flexDirection:"column",gap:"6px"},children:a.map(S=>{let V=y===S.id,K=n.formTypeId===S.id,Y=u===S.id;return jsxRuntime.jsxs("li",{"data-testid":`form-type-row-${S.id}`,style:{display:"flex",alignItems:"center",gap:"8px",padding:"8px",border:"1px solid #e2e8f0",borderRadius:"6px",backgroundColor:K?"#f1f5f9":"#fff"},children:[V?jsxRuntime.jsx("input",{type:"text",value:f,autoFocus:true,"data-testid":`form-type-name-edit-${S.id}`,onChange:se=>g(se.target.value),onBlur:P,onKeyDown:se=>{se.key==="Enter"&&P(),se.key==="Escape"&&(p(null),g(""));},style:{flex:1,padding:"4px 8px",border:"1px solid #cbd5e1",borderRadius:"4px",fontSize:"13px",color:"#000",outline:"none"}}):jsxRuntime.jsx("span",{"data-testid":`form-type-name-${S.id}`,onClick:()=>h(S.id,S.name),style:{flex:1,fontSize:"13px",cursor:"pointer",padding:"4px 8px"},children:S.name}),jsxRuntime.jsx("span",{style:{fontSize:"11px",color:"#94a3b8",fontFamily:"monospace"},children:S.code}),jsxRuntime.jsx("button",{type:"button","aria-label":l.formTypesDialog.removeTypeAria(S.name),"data-testid":`form-type-remove-${S.id}`,onClick:()=>v(S.id),style:{width:"24px",height:"24px",border:"1px solid #e2e8f0",borderRadius:"4px",backgroundColor:"#fff",color:"#64748b",cursor:"pointer",fontSize:"14px",lineHeight:1},children:"\xD7"}),Y&&jsxRuntime.jsxs("div",{"data-testid":`form-type-confirm-${S.id}`,style:{flexBasis:"100%",fontSize:"12px",color:"#b91c1c",backgroundColor:"#fef2f2",padding:"6px 8px",borderRadius:"4px",display:"flex",alignItems:"center",gap:"8px"},children:[jsxRuntime.jsx("span",{style:{flex:1},children:l.formTypesDialog.confirmDelete}),jsxRuntime.jsx("button",{type:"button","data-testid":`form-type-confirm-yes-${S.id}`,onClick:A,style:{padding:"4px 8px",border:"none",borderRadius:"4px",backgroundColor:"#ef4444",color:"#fff",fontSize:"12px",cursor:"pointer"},children:l.formTypesDialog.deleteConfirm}),jsxRuntime.jsx("button",{type:"button","data-testid":`form-type-confirm-no-${S.id}`,onClick:()=>b(null),style:{padding:"4px 8px",border:"1px solid #e2e8f0",borderRadius:"4px",backgroundColor:"#fff",color:"#334155",fontSize:"12px",cursor:"pointer"},children:l.formTypesDialog.deleteCancel})]})]},S.id)})})]}),jsxRuntime.jsxs("section",{style:{padding:"12px 16px",borderTop:"1px solid #e2e8f0",display:"flex",alignItems:"center",gap:"8px",backgroundColor:"#f8fafc"},children:[jsxRuntime.jsx("input",{type:"text",value:d,"data-testid":"form-types-new-name",placeholder:l.formTypesDialog.newTypeNamePlaceholder,onChange:S=>s(S.target.value),onKeyDown:S=>{S.key==="Enter"&&m();},style:{flex:1,padding:"6px 8px",border:"1px solid #cbd5e1",borderRadius:"4px",fontSize:"13px",color:"#000",outline:"none"}}),jsxRuntime.jsx("input",{type:"text",value:c,"data-testid":"form-types-new-code",placeholder:l.formTypesDialog.newTypeCodePlaceholder,onChange:S=>x(S.target.value),style:{width:"120px",padding:"6px 8px",border:"1px solid #cbd5e1",borderRadius:"4px",fontSize:"13px",color:"#000",outline:"none",fontFamily:"monospace"}}),jsxRuntime.jsx("button",{type:"button","data-testid":"form-types-add",onClick:m,disabled:d.trim()==="",style:{padding:"6px 12px",border:"none",borderRadius:"4px",backgroundColor:d.trim()===""?"#cbd5e1":"#2563eb",color:"#fff",fontSize:"13px",cursor:d.trim()===""?"not-allowed":"pointer"},children:l.formTypesDialog.addButton})]})]})})}function _e(){return {code:"",name:"",url:"",method:"GET",queryParam:"q",valueField:"",labelField:"",headers:[],dependencies:[]}}function vt(e,r){return {code:e.code,name:typeof e.name=="string"?e.name:formCore.resolveLabel(e.name,r,r),url:e.url,method:e.method,queryParam:e.queryParam??"q",valueField:e.valueField,labelField:e.labelField,headers:Object.entries(e.headersOverride??{}).map(([a,n])=>({key:a,value:n})),dependencies:Object.entries(e.dependencies??{}).map(([a,n])=>({param:a,varCode:n}))}}function Ct(e){let r={};for(let{key:n,value:o}of e.headers)n.trim()&&(r[n.trim()]=o);let a={};for(let{param:n,varCode:o}of e.dependencies)n.trim()&&o.trim()&&(a[n.trim()]=o.trim());return {code:e.code.trim(),name:e.name,url:e.url.trim(),method:e.method,queryParam:e.queryParam.trim()||"q",valueField:e.valueField.trim(),labelField:e.labelField.trim(),...Object.keys(r).length>0?{headersOverride:r}:{},...Object.keys(a).length>0?{dependencies:a}:{}}}function We({open:e,onClose:r}){let a=T(),{form:n,availableDataSources:o,availableScopes:t,adapter:i,setAvailableDataSources:l}=R(),d=n.langConfig?.defaultLang??formCore.DEFAULT_LANG_CONFIG.defaultLang,s=n.scopeIds??[],[c,x]=Kr.useState(s[0]),[y,p]=Kr.useState(null),[f,g]=Kr.useState(_e()),[u,b]=Kr.useState(false),[m,h]=Kr.useState(false),P=Kr.useMemo(()=>{let C=new Map;for(let L of t)C.set(L.id,L.code);return C},[t]),v=Kr.useMemo(()=>c?o.filter(C=>C.scopeId===c):o,[o,c]);if(!e)return null;let A=()=>{b(true),p(null),g(_e());},S=C=>{b(false),p(C.id),g(vt(C,d)),C.scopeId!==c&&x(C.scopeId);},V=()=>{p(null),b(false),g(_e());},K=C=>{l(C(o));},Y=async()=>{if(!i)return;let C=c??s[0];if(C){h(true);try{let L=Ct(f);if(y&&i.updateDataSource){let $=await i.updateDataSource(y,L);K(D=>D.map(te=>te.id===y?$:te));}else if(!y&&i.createDataSource){let $=await i.createDataSource(C,L);K(D=>[...D,$]);}V();}finally{h(false);}}},se=async C=>{if(i?.deleteDataSource&&!(typeof window<"u"&&!window.confirm(a.dataSourceManager.confirmDelete(C.code)))){h(true);try{await i.deleteDataSource(C.id),K(L=>L.filter($=>$.id!==C.id)),y===C.id&&V();}finally{h(false);}}};return jsxRuntime.jsx("div",{role:"dialog","aria-modal":"true","aria-label":a.dataSourceManager.dialogAriaLabel,"data-testid":"datasource-manager-dialog",onClick:r,style:{position:"fixed",inset:0,backgroundColor:"rgba(0, 0, 0, 0.3)",zIndex:50,display:"flex",alignItems:"center",justifyContent:"center",padding:"16px"},children:jsxRuntime.jsxs("div",{onClick:C=>C.stopPropagation(),style:{backgroundColor:"#fff",borderRadius:"8px",maxWidth:"40rem",width:"100%",maxHeight:"90vh",display:"flex",flexDirection:"column"},children:[jsxRuntime.jsxs("div",{style:{padding:"14px 16px",borderBottom:"1px solid #e2e8f0",display:"flex",alignItems:"center",justifyContent:"space-between"},children:[jsxRuntime.jsx("h2",{style:{margin:0,fontSize:"16px",fontWeight:600,color:"#0f172a"},children:a.dataSourceManager.title}),jsxRuntime.jsx("button",{type:"button",onClick:r,"aria-label":a.dataSourceManager.closeAriaLabel,style:{border:"none",background:"transparent",fontSize:"20px",cursor:"pointer",color:"#64748b"},children:"\u2715"})]}),jsxRuntime.jsxs("div",{style:{flex:1,overflowY:"auto",padding:"12px 16px"},children:[s.length===0&&jsxRuntime.jsx("div",{"data-testid":"datasource-manager-no-scope",style:vo,children:a.dataSourceManager.noScope}),s.length>1&&jsxRuntime.jsxs("div",{style:{marginBottom:"12px"},children:[jsxRuntime.jsx("label",{style:ze,children:a.dataSourceManager.scopeFilterLabel}),jsxRuntime.jsx("select",{"data-testid":"datasource-manager-scope-filter",value:c??"",onChange:C=>x(C.target.value||void 0),style:xo,children:s.map(C=>jsxRuntime.jsx("option",{value:C,children:P.get(C)??C},C))})]}),s.length>0&&v.length===0&&!u&&jsxRuntime.jsx("div",{"data-testid":"datasource-manager-empty",style:vo,children:a.dataSourceManager.noSources}),jsxRuntime.jsx("ul",{style:{listStyle:"none",margin:0,padding:0,display:"flex",flexDirection:"column",gap:"6px"},children:v.map(C=>jsxRuntime.jsxs("li",{"data-testid":`datasource-item-${C.code}`,style:{border:"1px solid #e2e8f0",borderRadius:"6px",padding:"8px 10px",display:"flex",alignItems:"center",gap:"8px",backgroundColor:y===C.id?"#f0fdf4":"#fff"},children:[jsxRuntime.jsx("span",{style:{fontSize:"13px",fontWeight:600,color:"#0f172a"},children:C.code}),jsxRuntime.jsx("span",{style:{fontSize:"11px",color:"#64748b"},children:C.method}),jsxRuntime.jsx("span",{style:{flex:1,fontSize:"11px",color:"#475569",overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap"},children:C.url}),P.has(C.scopeId)&&jsxRuntime.jsx("span",{style:{fontSize:"10px",color:"#0891b2",backgroundColor:"#ecfeff",padding:"2px 6px",borderRadius:"4px"},children:a.dataSourceManager.scopeBadge(P.get(C.scopeId))}),jsxRuntime.jsx("button",{type:"button","data-testid":`datasource-edit-${C.code}`,"aria-label":a.dataSourceManager.editAria(C.code),onClick:()=>S(C),disabled:m,style:Ve,children:"\u270F"}),jsxRuntime.jsx("button",{type:"button","data-testid":`datasource-delete-${C.code}`,"aria-label":a.dataSourceManager.deleteAria(C.code),onClick:()=>se(C),disabled:m,style:{...Ve,color:"#ef4444"},children:"\xD7"})]},C.id))}),s.length>0&&!u&&!y&&jsxRuntime.jsx("button",{type:"button","data-testid":"datasource-add-button",onClick:A,style:{marginTop:"12px",padding:"6px 12px",border:"1px solid #2563eb",borderRadius:"6px",color:"#2563eb",backgroundColor:"#fff",fontSize:"13px",fontWeight:500,cursor:"pointer"},children:a.dataSourceManager.addButton}),(u||y)&&jsxRuntime.jsxs("form",{"data-testid":"datasource-form",onSubmit:C=>{C.preventDefault(),Y();},style:{marginTop:"12px",padding:"12px",border:"1px solid #cbd5e1",borderRadius:"6px",backgroundColor:"#f8fafc",display:"flex",flexDirection:"column",gap:"8px"},children:[jsxRuntime.jsx(be,{label:a.dataSourceManager.fieldCode,children:jsxRuntime.jsx("input",{required:true,"data-testid":"datasource-form-code",value:f.code,onChange:C=>g({...f,code:C.target.value}),style:ee})}),jsxRuntime.jsx(be,{label:a.dataSourceManager.fieldName,children:jsxRuntime.jsx("input",{"data-testid":"datasource-form-name",value:f.name,onChange:C=>g({...f,name:C.target.value}),style:ee})}),jsxRuntime.jsx(be,{label:a.dataSourceManager.fieldUrl,children:jsxRuntime.jsx("input",{required:true,type:"url","data-testid":"datasource-form-url",value:f.url,onChange:C=>g({...f,url:C.target.value}),style:ee})}),jsxRuntime.jsxs("div",{style:{display:"flex",gap:"8px"},children:[jsxRuntime.jsx(be,{label:a.dataSourceManager.fieldMethod,style:{flex:1},children:jsxRuntime.jsxs("select",{"data-testid":"datasource-form-method",value:f.method,onChange:C=>g({...f,method:C.target.value}),style:xo,children:[jsxRuntime.jsx("option",{value:"GET",children:"GET"}),jsxRuntime.jsx("option",{value:"POST",children:"POST"})]})}),jsxRuntime.jsx(be,{label:a.dataSourceManager.fieldQueryParam,style:{flex:1},children:jsxRuntime.jsx("input",{"data-testid":"datasource-form-queryparam",value:f.queryParam,onChange:C=>g({...f,queryParam:C.target.value}),style:ee})})]}),jsxRuntime.jsxs("div",{style:{display:"flex",gap:"8px"},children:[jsxRuntime.jsx(be,{label:a.dataSourceManager.fieldValueField,style:{flex:1},children:jsxRuntime.jsx("input",{required:true,"data-testid":"datasource-form-valuefield",value:f.valueField,onChange:C=>g({...f,valueField:C.target.value}),style:ee})}),jsxRuntime.jsx(be,{label:a.dataSourceManager.fieldLabelField,style:{flex:1},children:jsxRuntime.jsx("input",{required:true,"data-testid":"datasource-form-labelfield",value:f.labelField,onChange:C=>g({...f,labelField:C.target.value}),style:ee})})]}),jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("label",{style:ze,children:a.dataSourceManager.fieldHeaders}),f.headers.map((C,L)=>jsxRuntime.jsxs("div",{style:{display:"flex",gap:"4px",marginBottom:"4px"},children:[jsxRuntime.jsx("input",{placeholder:a.dataSourceManager.headerKeyPlaceholder,value:C.key,onChange:$=>{let D=[...f.headers];D[L]={...D[L],key:$.target.value},g({...f,headers:D});},style:{...ee,flex:1}}),jsxRuntime.jsx("input",{type:"password",placeholder:a.dataSourceManager.headerValuePlaceholder,value:C.value,onChange:$=>{let D=[...f.headers];D[L]={...D[L],value:$.target.value},g({...f,headers:D});},style:{...ee,flex:1}}),jsxRuntime.jsx("button",{type:"button",onClick:()=>g({...f,headers:f.headers.filter(($,D)=>D!==L)}),style:{...Ve,color:"#ef4444"},children:"\xD7"})]},L)),jsxRuntime.jsx("button",{type:"button","data-testid":"datasource-form-add-header",onClick:()=>g({...f,headers:[...f.headers,{key:"",value:""}]}),style:Ee,children:a.dataSourceManager.addHeader})]}),jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("label",{style:ze,children:a.dataSourceManager.fieldDependencies}),f.dependencies.map((C,L)=>jsxRuntime.jsxs("div",{style:{display:"flex",gap:"4px",marginBottom:"4px"},children:[jsxRuntime.jsx("input",{placeholder:a.dataSourceManager.dependencyParamPlaceholder,value:C.param,onChange:$=>{let D=[...f.dependencies];D[L]={...D[L],param:$.target.value},g({...f,dependencies:D});},style:{...ee,flex:1}}),jsxRuntime.jsx("span",{style:{alignSelf:"center",color:"#94a3b8"},children:"\u2192"}),jsxRuntime.jsx("input",{placeholder:a.dataSourceManager.dependencyVarPlaceholder,value:C.varCode,onChange:$=>{let D=[...f.dependencies];D[L]={...D[L],varCode:$.target.value},g({...f,dependencies:D});},style:{...ee,flex:1}}),jsxRuntime.jsx("button",{type:"button",onClick:()=>g({...f,dependencies:f.dependencies.filter(($,D)=>D!==L)}),style:{...Ve,color:"#ef4444"},children:"\xD7"})]},L)),jsxRuntime.jsx("button",{type:"button","data-testid":"datasource-form-add-dependency",onClick:()=>g({...f,dependencies:[...f.dependencies,{param:"",varCode:""}]}),style:Ee,children:a.dataSourceManager.addDependency})]}),jsxRuntime.jsxs("div",{style:{display:"flex",justifyContent:"flex-end",gap:"8px",marginTop:"8px"},children:[jsxRuntime.jsx("button",{type:"button","data-testid":"datasource-form-cancel",onClick:V,disabled:m,style:Ee,children:a.dataSourceManager.cancel}),jsxRuntime.jsx("button",{type:"submit","data-testid":"datasource-form-save",disabled:m,style:{...Ee,backgroundColor:"#2563eb",color:"#fff",border:"none"},children:a.dataSourceManager.save})]})]})]})]})})}function be({label:e,children:r,style:a}){return jsxRuntime.jsxs("div",{style:a,children:[jsxRuntime.jsx("label",{style:ze,children:e}),r]})}var ze={display:"block",fontSize:"11px",fontWeight:500,color:"#475569",marginBottom:"2px"},ee={width:"100%",boxSizing:"border-box",padding:"4px 6px",border:"1px solid #cbd5e1",borderRadius:"4px",fontSize:"12px",color:"#0f172a",outline:"none",backgroundColor:"#fff"},xo={...ee},Ve={border:"none",background:"transparent",cursor:"pointer",fontSize:"14px",color:"#64748b",padding:"2px 4px"},Ee={padding:"4px 10px",border:"1px solid #cbd5e1",borderRadius:"4px",fontSize:"12px",color:"#334155",backgroundColor:"#fff",cursor:"pointer"},vo={fontSize:"12px",color:"#94a3b8",textAlign:"center",padding:"16px 0"};function Ue({onSave:e,onExport:r,onImport:a}){let{form:n,updateFormMeta:o,view:t,setView:i,isDirty:l,isSaving:d,canUndo:s,canRedo:c,undo:x,redo:y,save:p,addPage:f,select:g}=R(),u=T(),[b,m]=Kr.useState(false),[h,P]=Kr.useState(false),v=async()=>{await p(),e?.();},A=()=>{let V=n.pages.length;f({id:`page-${Date.now()}`,code:`PAGE_${V+1}`,name:`Page ${V+1}`,order:V,isRepeatable:false,items:[]});},S=[{view:"canvas",label:u.toolbar.viewEditor},{view:"preview",label:u.toolbar.viewPreview},{view:"json",label:u.toolbar.viewJson}];return jsxRuntime.jsxs("div",{style:{display:"flex",alignItems:"center",padding:"8px 16px",borderBottom:"1px solid #e2e8f0",backgroundColor:"#fff",gap:"8px"},children:[jsxRuntime.jsx("input",{type:"text",value:formCore.resolveLabel(n.name,n.langConfig?.defaultLang??formCore.DEFAULT_LANG_CONFIG.defaultLang,n.langConfig?.defaultLang??formCore.DEFAULT_LANG_CONFIG.defaultLang),onChange:V=>{let K=n.langConfig?.defaultLang??formCore.DEFAULT_LANG_CONFIG.defaultLang,Y;typeof n.name=="string"?Y=V.target.value:Y={...n.name??{},[K]:V.target.value},o({name:Y});},style:{border:"none",fontSize:"16px",fontWeight:600,color:"#1e293b",padding:"4px 8px",borderRadius:"4px",outline:"none",minWidth:"200px",backgroundColor:"transparent"},placeholder:u.toolbar.formNamePlaceholder}),l&&jsxRuntime.jsx("span",{style:{fontSize:"11px",color:"#f59e0b",fontWeight:500},children:u.toolbar.unsaved}),jsxRuntime.jsx("div",{style:{flex:1}}),jsxRuntime.jsx("button",{type:"button",onClick:()=>g({type:"form"}),title:u.toolbar.formProperties,"data-testid":"toolbar-form-properties","aria-label":u.toolbar.formProperties,style:{padding:"6px 10px",borderRadius:"6px",border:"1px solid #e2e8f0",backgroundColor:"#fff",color:"#334155",fontSize:"14px",cursor:"pointer"},children:"\u2699"}),jsxRuntime.jsx(ge,{onClick:A,label:u.toolbar.addPage}),jsxRuntime.jsx(ge,{onClick:()=>m(true),label:u.toolbar.types,title:u.toolbar.manageFormTypesTitle}),jsxRuntime.jsx("button",{type:"button",onClick:()=>P(true),title:u.toolbar.manageDataSourcesTitle,"data-testid":"toolbar-datasources","aria-label":u.toolbar.manageDataSourcesTitle,style:{padding:"6px 12px",borderRadius:"6px",border:"1px solid #e2e8f0",backgroundColor:"#fff",color:"#334155",fontSize:"13px",fontWeight:500,cursor:"pointer"},children:u.toolbar.dataSources}),jsxRuntime.jsx("div",{style:{width:"1px",height:"24px",backgroundColor:"#e2e8f0"}}),jsxRuntime.jsx(ge,{onClick:x,label:"\u21A9",disabled:!s(),title:u.toolbar.undo}),jsxRuntime.jsx(ge,{onClick:y,label:"\u21AA",disabled:!c(),title:u.toolbar.redo}),jsxRuntime.jsx("div",{style:{width:"1px",height:"24px",backgroundColor:"#e2e8f0"}}),jsxRuntime.jsx("div",{style:{display:"flex",borderRadius:"6px",overflow:"hidden",border:"1px solid #e2e8f0"},children:S.map(V=>jsxRuntime.jsx("button",{type:"button",onClick:()=>i(V.view),style:{padding:"4px 12px",fontSize:"12px",fontWeight:500,border:"none",cursor:"pointer",backgroundColor:t===V.view?"#2563eb":"#fff",color:t===V.view?"#fff":"#64748b"},children:V.label},V.view))}),jsxRuntime.jsx("div",{style:{width:"1px",height:"24px",backgroundColor:"#e2e8f0"}}),jsxRuntime.jsx(ge,{onClick:v,label:d?u.toolbar.saving:u.toolbar.save,primary:true,disabled:d||!l}),r&&jsxRuntime.jsx(ge,{onClick:r,label:u.toolbar.export}),a&&jsxRuntime.jsx(ge,{onClick:a,label:u.toolbar.import}),jsxRuntime.jsx(mo,{open:b,onClose:()=>m(false)}),jsxRuntime.jsx(We,{open:h,onClose:()=>P(false)})]})}function ge({onClick:e,label:r,primary:a,disabled:n,title:o}){return jsxRuntime.jsx("button",{type:"button",onClick:e,disabled:n,title:o,style:{padding:"6px 12px",borderRadius:"6px",border:a?"none":"1px solid #e2e8f0",backgroundColor:a?"#2563eb":"#fff",color:a?"#fff":"#334155",fontSize:"13px",fontWeight:500,cursor:n?"default":"pointer",opacity:n?.5:1},children:r})}function Ae(){let e=T(),[r,a]=Kr.useState("fields"),[n,o]=Kr.useState(""),{form:t,availableTemplates:i}=R(),l=t.langConfig?.defaultLang??formCore.DEFAULT_LANG_CONFIG.defaultLang,s=Kr.useMemo(()=>[{label:e.toolbox.groupText,items:[{kind:"variable",type:"text",label:e.toolbox.types.text,icon:"T"},{kind:"variable",type:"textarea",label:e.toolbox.types.textarea,icon:"\xB6"},{kind:"variable",type:"number",label:e.toolbox.types.number,icon:"#"}]},{label:e.toolbox.groupSelection,items:[{kind:"variable",type:"select",label:e.toolbox.types.select,icon:"\u25BC"},{kind:"variable",type:"multiselect",label:e.toolbox.types.multiselect,icon:"\u2611"},{kind:"variable",type:"radio",label:e.toolbox.types.radio,icon:"\u25C9"},{kind:"variable",type:"checkbox",label:e.toolbox.types.checkbox,icon:"\u2610"}]},{label:e.toolbox.groupDateTime,items:[{kind:"variable",type:"date",label:e.toolbox.types.date,icon:"\u{1F4C5}"},{kind:"variable",type:"datetime",label:e.toolbox.types.datetime,icon:"\u{1F550}"},{kind:"variable",type:"time",label:e.toolbox.types.time,icon:"\u23F0"}]},{label:e.toolbox.groupAdvanced,items:[{kind:"variable",type:"file",label:e.toolbox.types.file,icon:"\u{1F4CE}"},{kind:"variable",type:"gps",label:e.toolbox.types.gps,icon:"\u{1F4CD}"},{kind:"variable",type:"calculated",label:e.toolbox.types.calculated,icon:"fx"},{kind:"variable",type:"hidden",label:e.toolbox.types.hidden,icon:"\u{1F441}"},{kind:"variable",type:"label",label:e.toolbox.types.label,icon:"Aa"}]},{label:e.toolbox.groupRoster,items:[{kind:"roster",rosterType:"check",label:e.toolbox.typeRosterCheck,icon:"\u25A4"},{kind:"roster",rosterType:"list",label:e.toolbox.typeRosterList,icon:"\u25A6"},{kind:"roster",rosterType:"collection",label:e.toolbox.typeRosterCollection,icon:"\u25A5"},{kind:"roster",rosterType:"collection_extend",label:e.toolbox.typeRosterCollectionExtend,icon:"\u25A9"}]}],[e]).map(c=>({...c,items:c.items.filter(x=>x.label.toLowerCase().includes(n.toLowerCase()))})).filter(c=>c.items.length>0);return jsxRuntime.jsxs("div",{style:{width:"220px",borderRight:"1px solid #e2e8f0",display:"flex",flexDirection:"column",backgroundColor:"#f8fafc",overflow:"hidden"},children:[jsxRuntime.jsx(kt,{tab:r,setTab:a,labels:e}),jsxRuntime.jsx("div",{style:{padding:"12px",borderBottom:"1px solid #e2e8f0"},children:jsxRuntime.jsx("input",{type:"text",placeholder:e.toolbox.searchPlaceholder,value:n,onChange:c=>o(c.target.value),style:{width:"100%",padding:"6px 10px",border:"1px solid #e2e8f0",borderRadius:"6px",fontSize:"13px",outline:"none",boxSizing:"border-box"}})}),jsxRuntime.jsxs("div",{style:{flex:1,overflowY:"auto",padding:"8px"},children:[r==="fields"&&s.map(c=>jsxRuntime.jsxs("div",{style:{marginBottom:"16px"},children:[jsxRuntime.jsx("div",{style:{fontSize:"11px",fontWeight:600,color:"#94a3b8",textTransform:"uppercase",letterSpacing:"0.5px",marginBottom:"6px",padding:"0 4px"},children:c.label}),c.items.map(x=>jsxRuntime.jsx(wt,{entry:x},`${x.kind}-${x.kind==="roster"?x.rosterType:x.type}`))]},c.label)),r==="variables"&&jsxRuntime.jsx(Pt,{templates:i,scopeIds:t.scopeIds,search:n,defaultLang:l,labels:e})]})]})}function kt({tab:e,setTab:r,labels:a}){let n={flex:1,padding:"8px 0",fontSize:"12px",fontWeight:500,textAlign:"center",cursor:"pointer",userSelect:"none",color:"#64748b",borderBottomWidth:"2px",borderBottomStyle:"solid",borderBottomColor:"transparent"},o={...n,color:"#2563eb",fontWeight:600,borderBottomColor:"#2563eb"};return jsxRuntime.jsxs("div",{style:{display:"flex",borderBottom:"1px solid #e2e8f0",backgroundColor:"#fff"},children:[jsxRuntime.jsx("div",{role:"tab","aria-selected":e==="fields","data-testid":"toolbox-tab-fields",onClick:()=>r("fields"),style:e==="fields"?o:n,children:a.toolbox.tabFields}),jsxRuntime.jsx("div",{role:"tab","aria-selected":e==="variables","data-testid":"toolbox-tab-variables",onClick:()=>r("variables"),style:e==="variables"?o:n,children:a.toolbox.tabVariables})]})}function wt({entry:e}){let r=e.kind==="roster"?`toolbox-roster-${e.rosterType}`:`toolbox-variable-${e.type}`,a=e.kind==="roster"?{type:"new-roster",rosterType:e.rosterType}:{type:"new-variable",variableType:e.type},{attributes:n,listeners:o,setNodeRef:t,isDragging:i}=core.useDraggable({id:r,data:a});return jsxRuntime.jsxs("div",{ref:t,"data-testid":r,...o,...n,style:{display:"flex",alignItems:"center",gap:"8px",padding:"6px 8px",marginBottom:"2px",borderRadius:"6px",cursor:"grab",fontSize:"13px",color:"#334155",backgroundColor:i?"#e2e8f0":"transparent",userSelect:"none"},children:[jsxRuntime.jsx("span",{style:{width:"20px",textAlign:"center",fontSize:"14px"},children:e.icon}),jsxRuntime.jsx("span",{children:e.label})]})}function Pt({templates:e,scopeIds:r,search:a,defaultLang:n,labels:o}){let t=d=>jsxRuntime.jsx("div",{"data-testid":"toolbox-variables-empty",style:{padding:"14px",color:"#94a3b8",fontSize:"12px",textAlign:"center",fontStyle:"italic"},children:d});if(!r||r.length===0)return t(o.toolbox.noScope);if(e.length===0)return t(o.toolbox.noTemplates);let i=a.toLowerCase(),l=e.filter(d=>{if(!i)return true;let s=d.code.toLowerCase().includes(i),c=Ro(d.name,n).toLowerCase().includes(i);return s||c}).slice().sort((d,s)=>d.code.localeCompare(s.code));return l.length===0?t(o.toolbox.noTemplates):jsxRuntime.jsx("div",{style:{display:"flex",flexDirection:"column",gap:"4px"},children:l.map(d=>jsxRuntime.jsx(Lt,{template:d,defaultLang:n},d.id))})}function Lt({template:e,defaultLang:r}){let a=`toolbox-template-${e.code}`,{attributes:n,listeners:o,setNodeRef:t,isDragging:i}=core.useDraggable({id:a,data:{type:"new-variable-from-template",template:e}});return jsxRuntime.jsxs("div",{ref:t,"data-testid":a,...o,...n,style:{display:"flex",alignItems:"center",gap:"8px",padding:"6px 8px",borderRadius:"6px",cursor:"grab",fontSize:"13px",color:"#334155",backgroundColor:i?"#e2e8f0":"transparent",userSelect:"none"},children:[jsxRuntime.jsx("span",{style:{fontSize:"10px",fontWeight:600,padding:"2px 6px",borderRadius:"4px",backgroundColor:"#e0e7ff",color:"#3730a3",textTransform:"uppercase",letterSpacing:"0.3px",minWidth:"42px",textAlign:"center"},children:e.variableType}),jsxRuntime.jsxs("div",{style:{display:"flex",flexDirection:"column",minWidth:0,flex:1},children:[jsxRuntime.jsx("span",{style:{fontFamily:"monospace",fontSize:"11px",color:"#475569",whiteSpace:"nowrap",overflow:"hidden",textOverflow:"ellipsis"},children:e.code}),jsxRuntime.jsx("span",{style:{fontSize:"12px",color:"#1e293b",whiteSpace:"nowrap",overflow:"hidden",textOverflow:"ellipsis"},children:Ro(e.name,r)})]})]})}function Ro(e,r){return formCore.resolveLabel(e,r,r)}function je(){let r=R(a=>a.form).langConfig?.defaultLang??formCore.DEFAULT_LANG_CONFIG.defaultLang;return a=>formCore.resolveLabel(a,r,r)}function $e(){let{form:e,select:r}=R(),a=T(),n=i=>{i.target===i.currentTarget&&r({type:"form"});};if(e.pages.length===0)return jsxRuntime.jsx("div",{"data-testid":"canvas-empty",onClick:n,style:{flex:1,display:"flex",alignItems:"center",justifyContent:"center",color:"#94a3b8",fontSize:"14px",cursor:"pointer"},children:a.canvas.emptyStateNoPageDnd});let o=e.pages.slice().sort((i,l)=>i.order-l.order),t=o.map(i=>`page-${i.code}`);return jsxRuntime.jsx("div",{"data-testid":"canvas-root",onClick:n,style:{flex:1,overflowY:"auto",padding:"16px",backgroundColor:"#fff"},children:jsxRuntime.jsx(sortable.SortableContext,{items:t,strategy:sortable.verticalListSortingStrategy,children:o.map(i=>jsxRuntime.jsx(zt,{page:i},i.code))})})}function zt({page:e}){let{selection:r,select:a}=R(),n=T(),o=je(),t=r.type==="page"&&r.pageCode===e.code,{attributes:i,listeners:l,setNodeRef:d,transform:s,transition:c,isDragging:x,isOver:y}=sortable.useSortable({id:`page-${e.code}`,data:{type:"page",pageCode:e.code}}),p=(e.items??[...formCore.getPageVariables(e),...e.rosters??[]]).slice().sort((g,u)=>g.order-u.order),f=p.filter(g=>!formCore.isPageRoster(g)).length;return jsxRuntime.jsxs("div",{ref:d,style:{marginBottom:"16px",border:`2px solid ${t?"#2563eb":y?"#93c5fd":"#e2e8f0"}`,borderRadius:"8px",overflow:"hidden",transform:utilities.CSS.Transform.toString(s),transition:c,opacity:x?.6:1},children:[jsxRuntime.jsxs("div",{onClick:()=>a({type:"page",pageCode:e.code}),style:{padding:"10px 14px",backgroundColor:t?"#eff6ff":"#f8fafc",borderBottom:"1px solid #e2e8f0",cursor:"pointer",display:"flex",alignItems:"center",justifyContent:"space-between"},children:[jsxRuntime.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"8px"},children:[jsxRuntime.jsx("span",{...i,...l,"data-testid":`canvas-page-drag-handle-${e.code}`,"aria-label":`Reorder page ${e.code}`,title:"Drag to reorder",onClick:g=>g.stopPropagation(),style:{color:"#94a3b8",fontSize:"14px",cursor:"grab",padding:"2px 6px",borderRadius:"4px",userSelect:"none",touchAction:"none"},children:"\u283F"}),jsxRuntime.jsx("span",{style:{fontSize:"14px",fontWeight:600,color:"#1e293b"},children:o(e.name)||n.canvas.unnamedPage}),e.isRepeatable&&jsxRuntime.jsx("span",{style:{fontSize:"10px",padding:"1px 6px",borderRadius:"4px",backgroundColor:"#dbeafe",color:"#2563eb",fontWeight:500},children:n.canvas.repeatable})]}),jsxRuntime.jsx("span",{style:{fontSize:"12px",color:"#94a3b8"},children:n.canvas.fieldsCount(f)})]}),jsxRuntime.jsx(sortable.SortableContext,{items:p.map(g=>g.code),strategy:sortable.verticalListSortingStrategy,children:jsxRuntime.jsx("div",{style:{padding:"4px 0"},children:p.map(g=>formCore.isPageRoster(g)?jsxRuntime.jsx(At,{roster:g,pageCode:e.code},g.code):jsxRuntime.jsx(wo,{variable:g,pageCode:e.code},g.code))})})]})}function wo({variable:e,pageCode:r,rosterCode:a}){let{selection:n,select:o}=R(),t=T(),i=je(),l=n.type==="variable"&&n.pageCode===r&&n.variableCode===e.code,{attributes:d,listeners:s,setNodeRef:c,transform:x,transition:y,isDragging:p}=sortable.useSortable({id:e.code,data:{type:"variable",pageCode:r,variableCode:e.code,rosterCode:a}});return jsxRuntime.jsxs("div",{ref:c,...d,...s,onClick:f=>{f.stopPropagation(),o({type:"variable",pageCode:r,variableCode:e.code,rosterCode:a});},style:{display:"flex",alignItems:"center",gap:"8px",padding:"6px 14px",margin:"1px 0",cursor:"pointer",backgroundColor:l?"#eff6ff":p?"#f1f5f9":"transparent",borderLeft:l?"3px solid #2563eb":"3px solid transparent",transform:utilities.CSS.Transform.toString(x),transition:y,opacity:p?.5:1,fontSize:"13px"},children:[jsxRuntime.jsx("span",{style:{color:"#94a3b8",fontSize:"11px",width:"60px",flexShrink:0},children:e.type}),jsxRuntime.jsx("span",{style:{color:"#334155",flex:1},children:i(e.name)||e.code}),e.isRequired&&jsxRuntime.jsx("span",{style:{color:"#ef4444",fontSize:"11px"},children:"*"}),e.conditions&&e.conditions.length>0&&jsxRuntime.jsx("span",{style:{color:"#f59e0b",fontSize:"11px"},title:t.canvas.hasConditionsTitle,children:"\u26A1"}),e.dataSourceId&&jsxRuntime.jsx("span",{style:{color:"#22c55e",fontSize:"11px"},title:t.canvas.dataSourceConnectedTitle,children:"\u27F3"})]})}function At({roster:e,pageCode:r}){let{selection:a,select:n,addVariable:o}=R(),t=T(),i=je(),l=a.type==="roster"&&a.pageCode===r&&a.rosterCode===e.code,{attributes:d,listeners:s,setNodeRef:c,transform:x,transition:y,isDragging:p}=sortable.useSortable({id:e.code,data:{type:"roster",pageCode:r,rosterCode:e.code}}),{setNodeRef:f,isOver:g}=core.useDroppable({id:`roster-drop-${e.code}`,data:{type:"roster-drop",pageCode:r,rosterCode:e.code}}),u=b=>{b.stopPropagation();let m=`RV_${Date.now().toString(36).slice(-4).toUpperCase()}`;o(r,{id:`var-${Date.now()}`,code:m,name:t.canvas.newFieldName,type:"text",order:e.variables.length,isRequired:false,isReadonly:false,isHidden:false},e.code);};return jsxRuntime.jsxs("div",{ref:c,style:{margin:"4px 8px",border:`1px solid ${l?"#2563eb":g?"#f59e0b":"#e2e8f0"}`,borderRadius:"6px",overflow:"hidden",backgroundColor:g?"#fefce8":void 0,transform:utilities.CSS.Transform.toString(x),transition:y,opacity:p?.5:1},children:[jsxRuntime.jsxs("div",{...d,...s,onClick:b=>{b.stopPropagation(),n({type:"roster",pageCode:r,rosterCode:e.code});},style:{padding:"6px 10px",backgroundColor:l?"#fef3c7":"#fffbeb",fontSize:"12px",fontWeight:600,color:"#92400e",cursor:"grab",display:"flex",alignItems:"center",gap:"6px"},children:[jsxRuntime.jsx("span",{style:{fontSize:"10px"},children:"\u25A4"}),i(e.name)||e.code," (",e.rosterType,")"]}),jsxRuntime.jsxs("div",{ref:f,children:[e.variables.slice().sort((b,m)=>b.order-m.order).map(b=>jsxRuntime.jsx(wo,{variable:b,pageCode:r,rosterCode:e.code},b.code)),jsxRuntime.jsx("div",{style:{padding:"4px 10px",borderTop:"1px solid #fde68a"},children:jsxRuntime.jsx("button",{type:"button",onClick:u,"data-testid":`canvas-add-field-to-roster-${e.code}`,style:{padding:"2px 8px",borderRadius:"3px",border:"1px dashed #d4a843",backgroundColor:"transparent",color:"#92400e",fontSize:"10px",cursor:"pointer"},children:t.canvas.addFieldToRoster})})]})]})}function Kt(e,r){let a=e.pages.find(n=>n.code===r);return a?Array.isArray(a.items)?a.items.slice().sort((n,o)=>n.order-o.order):[...formCore.getPageVariables(a),...formCore.getPageRosters(a)].sort((n,o)=>n.order-o.order):null}function Lo(e){return `${e}_${Date.now().toString(36).slice(-4).toUpperCase()}`}function Fo(e,r){return a=>{let{active:n,over:o}=a;if(!n||!o)return;let t=n.data.current;if(!t?.type)return;let i=r(),l=()=>{let d=o.data.current;return d?d.type==="page"&&d.pageCode?{pageCode:d.pageCode}:d.type==="variable"&&d.pageCode?{pageCode:d.pageCode,rosterCode:d.rosterCode}:d.type==="roster"&&d.pageCode?{pageCode:d.pageCode,rosterCode:d.rosterCode}:d.type==="roster-drop"&&d.pageCode?{pageCode:d.pageCode,rosterCode:d.rosterCode}:null:null};if(t.type==="new-variable"){let d=l()??{pageCode:i.pages[0]?.code??""};if(!d.pageCode)return;let s=t.variableType??"text";e.addVariable(d.pageCode,{id:`var-${Date.now()}`,code:Lo(s.toUpperCase()),name:`New ${s}`,type:s,order:0,isRequired:false,isReadonly:false,isHidden:false},d.rosterCode);return}if(t.type==="new-roster"){let d=l()??{pageCode:i.pages[0]?.code??""};if(!d.pageCode)return;let s=t.rosterType??"collection";e.addRoster(d.pageCode,{id:`roster-${Date.now()}`,code:Lo("ROSTER"),name:"New Roster",rosterType:s,order:0,variables:[]});return}if(t.type==="new-variable-from-template"&&t.template){let d=l()??{pageCode:i.pages[0]?.code??""};if(!d.pageCode)return;e.addVariableFromTemplate(d.pageCode,t.template,d.rosterCode);return}if(t.type==="page"){let d=o.data.current;if(d?.type!=="page"||!d.pageCode||!t.pageCode||t.pageCode===d.pageCode)return;let s=i.pages.slice().sort((p,f)=>p.order-f.order),c=s.findIndex(p=>p.code===t.pageCode),x=s.findIndex(p=>p.code===d.pageCode);if(c===-1||x===-1||c===x)return;let y=sortable.arrayMove(s,c,x).map(p=>p.code);e.reorderPages(y);return}if(t.type==="variable"||t.type==="roster"){let d=o.data.current,s=t.pageCode;if(!s||!d)return;let c=p=>p.type==="roster"||p.type==="variable"&&!p.rosterCode,x=c(t),y=c(d);if(d.pageCode===s&&d.type!=="page"&&x&&y){let p=Kt(i,s);if(!p)return;let f=String(n.id),g=String(o.id);if(f===g)return;let u=p.findIndex(m=>m.code===f),b=p.findIndex(m=>m.code===g);if(u===-1||b===-1)return;e.moveItem(s,u,b);return}if(t.type==="variable"&&t.variableCode){let p=d.pageCode??s,f=d.type==="page"?void 0:d.rosterCode;if(p===s&&(t.rosterCode??void 0)===(f??void 0))return;e.moveVariable(s,p,t.variableCode,0,t.rosterCode,f);return}}}}function Ke({children:e}){let r=R(),[a,n]=Kr.useState(null),o=core.useSensors(core.useSensor(core.PointerSensor,{activationConstraint:{distance:8}}),core.useSensor(core.KeyboardSensor,{coordinateGetter:sortable.sortableKeyboardCoordinates})),t=Kr.useMemo(()=>Fo({addVariable:r.addVariable,addRoster:r.addRoster,addVariableFromTemplate:r.addVariableFromTemplate,moveItem:r.moveItem,moveVariable:r.moveVariable,reorderPages:r.reorderPages},()=>R.getState().form),[r.addVariable,r.addRoster,r.addVariableFromTemplate,r.moveItem,r.moveVariable,r.reorderPages]);return jsxRuntime.jsxs(core.DndContext,{sensors:o,collisionDetection:core.closestCenter,onDragStart:l=>{let d=l.active.data.current;d&&(d.type==="new-variable"?n(d.variableType??"variable"):d.type==="new-roster"?n(`roster:${d.rosterType??""}`):d.type==="new-variable-from-template"?n(`tpl:${d.template?.code??""}`):d.type==="variable"?n(d.variableCode??""):d.type==="roster"?n(`\u25A4 ${String(l.active.id)}`):d.type==="page"&&n(`\u{1F4C4} ${d.pageCode??""}`));},onDragEnd:l=>{n(null),t(l);},children:[e,jsxRuntime.jsx(core.DragOverlay,{children:a&&jsxRuntime.jsx("div",{style:{padding:"6px 12px",borderRadius:"6px",backgroundColor:"#2563eb",color:"#fff",fontSize:"13px",fontWeight:500,boxShadow:"0 4px 12px rgba(0,0,0,0.15)"},children:a})})]})}function Eo(e,r,a="fr"){if(e==null)return "";if(typeof e=="string")return e;let n=e[r];if(typeof n=="string"&&n!=="")return n;let o=e[a];if(typeof o=="string"&&o!=="")return o;for(let t of Object.values(e))if(typeof t=="string"&&t!=="")return t;return ""}var Oe={width:"100%",padding:"6px 8px",border:"1px solid #e2e8f0",borderRadius:"4px",fontSize:"13px",color:"#334155",outline:"none",boxSizing:"border-box"},Xt={padding:"4px 10px",border:"1px solid #e2e8f0",borderBottom:"none",borderTopLeftRadius:"4px",borderTopRightRadius:"4px",fontSize:"11px",fontWeight:600,cursor:"pointer",textTransform:"uppercase",letterSpacing:"0.5px",minWidth:"38px"};function Vo(e,r,a){if(e==null)return "";if(typeof e=="string")return r===a?e:"";let n=e[r];return typeof n=="string"?n:""}function Pe({value:e,onChange:r,availableLangs:a,defaultLang:n="fr",placeholder:o,multiline:t,testIdPrefix:i,disabled:l}){let d=a.length>0?a:[n],s=d.length>1,[c,x]=Kr.useState(d[0]),y=T();d.includes(c)||x(d[0]);let p=(g,u)=>{if(!s){r(u);return}let b=typeof e=="string"?{[n]:e}:{...e??{}};b[g]=u,r(b);};if(!s){let g=d[0],u=Vo(e,g,n);return t?jsxRuntime.jsx("textarea",{value:u,rows:3,placeholder:o,disabled:l,"data-testid":i?`${i}-${g}`:void 0,onChange:b=>p(g,b.target.value),style:Oe}):jsxRuntime.jsx("input",{type:"text",value:u,placeholder:o,disabled:l,"data-testid":i?`${i}-${g}`:void 0,onChange:b=>p(g,b.target.value),style:Oe})}let f=Vo(e,c,n);return jsxRuntime.jsxs("div",{"data-testid":i,style:{display:"flex",flexDirection:"column"},children:[jsxRuntime.jsx("div",{role:"tablist","aria-label":y.properties.title,style:{display:"flex",gap:"2px"},children:d.map(g=>{let u=g===c;return jsxRuntime.jsx("button",{type:"button",role:"tab","aria-selected":u,"data-testid":i?`${i}-tab-${g}`:void 0,onClick:()=>x(g),style:{...Xt,backgroundColor:u?"#fff":"#f1f5f9",color:u?"#2563eb":"#64748b",borderColor:"#e2e8f0"},children:g},g)})}),t?jsxRuntime.jsx("textarea",{value:f,rows:3,placeholder:o,disabled:l,"data-testid":i?`${i}-${c}`:void 0,onChange:g=>p(c,g.target.value),style:{...Oe,borderTopLeftRadius:0}}):jsxRuntime.jsx("input",{type:"text",value:f,placeholder:o,disabled:l,"data-testid":i?`${i}-${c}`:void 0,onChange:g=>p(c,g.target.value),style:{...Oe,borderTopLeftRadius:0}})]})}function J({label:e,value:r,onChange:a,placeholder:n,multiline:o,testIdPrefix:t,disabled:i}){let d=R(s=>s.form).langConfig??formCore.DEFAULT_LANG_CONFIG;return jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("label",{style:{display:"block",fontSize:"12px",fontWeight:500,color:"#64748b",marginBottom:"4px"},children:e}),jsxRuntime.jsx(Pe,{value:r,onChange:a,availableLangs:d.availableLangs,defaultLang:d.defaultLang,placeholder:n,multiline:o,testIdPrefix:t,disabled:i})]})}var tr=["fr","en"];function he(){let{form:e,formTypes:r,updateFormMeta:a,availableScopes:n}=R(),o=T(),t=e.langConfig??formCore.DEFAULT_LANG_CONFIG,i=e.pages.reduce((l,d)=>l+formCore.getPageVariables(d).length+formCore.getPageRosters(d).reduce((s,c)=>s+c.variables.length,0),0);return jsxRuntime.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"12px"},children:[jsxRuntime.jsx(J,{label:o.properties.name,value:e.name,onChange:l=>a({name:l}),testIdPrefix:"form-name"}),jsxRuntime.jsx(j,{label:o.properties.code,value:e.code,onChange:l=>a({code:l})}),jsxRuntime.jsx(J,{label:o.properties.description,value:e.description,onChange:l=>a({description:l}),multiline:true,testIdPrefix:"form-description"}),jsxRuntime.jsx(j,{label:o.properties.version,value:e.version,onChange:l=>a({version:l})}),jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("label",{style:{display:"block",fontSize:"12px",fontWeight:500,color:"#64748b",marginBottom:"4px"},children:o.properties.formType}),jsxRuntime.jsxs("select",{"data-testid":"form-properties-type-select",value:e.formTypeId??"",onChange:l=>a({formTypeId:l.target.value||void 0}),style:{width:"100%",padding:"6px 8px",border:"1px solid #e2e8f0",borderRadius:"4px",fontSize:"13px",color:"#334155",outline:"none",boxSizing:"border-box"},children:[jsxRuntime.jsx("option",{value:"",children:o.properties.noType}),r.map(l=>jsxRuntime.jsx("option",{value:l.id,children:l.name},l.id))]})]}),jsxRuntime.jsx(rr,{value:e.scopeIds??[],availableScopes:n,onChange:l=>a({scopeIds:l}),defaultLang:t.defaultLang,labels:o}),jsxRuntime.jsx(nr,{langConfig:t}),jsxRuntime.jsx("div",{style:{fontSize:"12px",color:"#94a3b8",marginTop:"8px"},children:o.properties.formSummary(e.pages.length,i)})]})}function rr({value:e,availableScopes:r,onChange:a,defaultLang:n,labels:o}){let i={padding:"8px",backgroundColor:"#f8fafc",borderRadius:"6px",display:"flex",flexDirection:"column",gap:"8px",marginTop:"4px"},l=e.map(y=>r.find(p=>p.id===y)??r.find(p=>p.code===y)).filter(y=>!!y),d=r.filter(y=>!e.includes(y.id)&&!e.includes(y.code)),s=y=>{y&&a([...e,y]);},c=y=>{let p=e.slice();p.splice(y,1),a(p);},x=(y,p)=>{let f=y+p;if(f<0||f>=e.length)return;let g=e.slice(),[u]=g.splice(y,1);g.splice(f,0,u),a(g);};return jsxRuntime.jsxs("div",{"data-testid":"form-scopes-selector",style:i,children:[jsxRuntime.jsx("div",{style:{fontSize:"11px",fontWeight:600,color:"#64748b",textTransform:"uppercase",letterSpacing:"0.5px"},children:o.properties.scopes}),jsxRuntime.jsx("p",{style:{margin:0,fontSize:"11px",color:"#94a3b8"},children:o.properties.scopesHint}),l.length===0?jsxRuntime.jsx("div",{style:{fontSize:"12px",color:"#94a3b8",fontStyle:"italic"},children:"\u2014"}):jsxRuntime.jsx("ol",{"data-testid":"form-scopes-selected",style:{margin:0,padding:0,listStyle:"none",display:"flex",flexDirection:"column",gap:"4px"},children:l.map((y,p)=>jsxRuntime.jsxs("li",{"data-testid":`form-scope-${y.code}`,style:{display:"flex",alignItems:"center",gap:"6px",padding:"6px 8px",borderRadius:"4px",backgroundColor:"#fff",border:"1px solid #e2e8f0",fontSize:"12px"},children:[jsxRuntime.jsxs("span",{style:{fontSize:"10px",color:"#64748b",minWidth:"14px"},children:[p+1,"."]}),jsxRuntime.jsx("span",{style:{fontFamily:"monospace",color:"#475569"},children:y.code}),jsxRuntime.jsx("span",{style:{color:"#1e293b",flex:1,overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap"},children:formCore.resolveLabel(y.name,n,n)}),jsxRuntime.jsx("button",{type:"button","aria-label":o.properties.moveScopeUp,"data-testid":`form-scope-up-${y.code}`,onClick:()=>x(p,-1),disabled:p===0,style:Ye(p===0),children:"\u25B2"}),jsxRuntime.jsx("button",{type:"button","aria-label":o.properties.moveScopeDown,"data-testid":`form-scope-down-${y.code}`,onClick:()=>x(p,1),disabled:p===l.length-1,style:Ye(p===l.length-1),children:"\u25BC"}),jsxRuntime.jsx("button",{type:"button","aria-label":o.properties.removeScope,"data-testid":`form-scope-remove-${y.code}`,onClick:()=>c(p),style:{...Ye(false),color:"#ef4444"},children:"\xD7"})]},y.id))}),d.length>0?jsxRuntime.jsxs("select",{value:"","data-testid":"form-scopes-add",onChange:y=>{let p=y.target.value;p&&s(p),y.target.value="";},style:ar,children:[jsxRuntime.jsxs("option",{value:"",children:["+ ",o.properties.scopes,"\u2026"]}),d.map(y=>jsxRuntime.jsxs("option",{value:y.id,children:[y.code," \u2014 ",formCore.resolveLabel(y.name,n,n)]},y.id))]}):r.length===0?jsxRuntime.jsx("div",{style:{fontSize:"11px",color:"#94a3b8",fontStyle:"italic"},"data-testid":"form-scopes-empty",children:o.properties.noScopesAvailable}):null]})}function Ye(e){return {border:"1px solid #e2e8f0",backgroundColor:"#fff",color:e?"#cbd5e1":"#64748b",fontSize:"10px",padding:"2px 6px",borderRadius:"4px",cursor:e?"default":"pointer"}}var ar={width:"100%",padding:"6px 8px",border:"1px solid #e2e8f0",borderRadius:"4px",fontSize:"12px",color:"#334155",outline:"none",boxSizing:"border-box"};function nr({langConfig:e}){let{form:r,updateFormMeta:a,setForm:n}=R(),o=T(),[t,i]=Kr.useState(null),l={display:"block",fontSize:"12px",fontWeight:500,color:"#64748b",marginBottom:"4px"},d={width:"100%",padding:"6px 8px",border:"1px solid #e2e8f0",borderRadius:"4px",fontSize:"13px",color:"#334155",outline:"none",boxSizing:"border-box"},s=f=>{a({langConfig:f});},c=f=>{e.availableLangs.includes(f)||s({...e,availableLangs:[...e.availableLangs,f]});},x=f=>{e.availableLangs.length<=1||f!==e.defaultLang&&i(f);},y=f=>{let g=e.availableLangs.filter(h=>h!==f),u=g.includes(e.defaultLang)?e.defaultLang:g[0]??"fr",b=ir(r,f,u,g.length===1),m={...e,defaultLang:u,availableLangs:g};n({...b,langConfig:m}),i(null);},p=()=>i(null);return jsxRuntime.jsxs("div",{"data-testid":"form-lang-config",style:{padding:"8px",backgroundColor:"#f8fafc",borderRadius:"6px",display:"flex",flexDirection:"column",gap:"8px",marginTop:"4px"},children:[jsxRuntime.jsx("div",{style:{fontSize:"11px",fontWeight:600,color:"#64748b",textTransform:"uppercase",letterSpacing:"0.5px"},children:o.properties.langConfigSection}),jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("label",{style:l,children:o.properties.langConfigAvailable}),jsxRuntime.jsx("div",{style:{display:"flex",gap:"8px",flexWrap:"wrap"},children:tr.map(f=>{let g=e.availableLangs.includes(f),u=f===e.defaultLang,b=e.availableLangs.length<=1,m=g&&(u||b);return jsxRuntime.jsxs("label",{style:{display:"flex",alignItems:"center",gap:"6px",fontSize:"13px",color:"#334155",cursor:m?"default":"pointer",opacity:m?.6:1},children:[jsxRuntime.jsx("input",{type:"checkbox","data-testid":`lang-toggle-${f}`,checked:g,disabled:m,onChange:h=>{h.target.checked?c(f):x(f);}}),jsxRuntime.jsx("span",{children:f.toUpperCase()}),u&&jsxRuntime.jsxs("span",{style:{fontSize:"10px",color:"#94a3b8",fontStyle:"italic"},children:["(",o.properties.langConfigDefault,")"]})]},f)})})]}),jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("label",{style:l,children:o.properties.langConfigDefault}),jsxRuntime.jsx("select",{"data-testid":"lang-default-select",value:e.defaultLang,onChange:f=>s({...e,defaultLang:f.target.value}),style:d,children:e.availableLangs.map(f=>jsxRuntime.jsx("option",{value:f,children:f.toUpperCase()},f))})]}),jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("label",{style:l,children:o.properties.langConfigStrategy}),jsxRuntime.jsxs("select",{"data-testid":"lang-strategy-select",value:e.strategy,onChange:f=>s({...e,strategy:f.target.value}),style:d,children:[jsxRuntime.jsx("option",{value:"prop",children:o.properties.langConfigStrategies.prop}),jsxRuntime.jsx("option",{value:"browser",children:o.properties.langConfigStrategies.browser}),jsxRuntime.jsx("option",{value:"selector",children:o.properties.langConfigStrategies.selector}),jsxRuntime.jsx("option",{value:"auto",children:o.properties.langConfigStrategies.auto})]})]}),e.strategy==="selector"&&jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("label",{style:l,children:o.properties.langConfigSelectorPosition}),jsxRuntime.jsxs("select",{"data-testid":"lang-selector-position-select",value:e.selectorPosition??"top",onChange:f=>s({...e,selectorPosition:f.target.value}),style:d,children:[jsxRuntime.jsx("option",{value:"top",children:o.properties.langConfigPositions.top}),jsxRuntime.jsx("option",{value:"bottom",children:o.properties.langConfigPositions.bottom})]})]}),t&&jsxRuntime.jsxs("div",{"data-testid":"lang-remove-confirm",style:{padding:"8px",backgroundColor:"#fef2f2",border:"1px solid #fecaca",borderRadius:"6px",fontSize:"12px",color:"#b91c1c",display:"flex",flexDirection:"column",gap:"8px"},children:[jsxRuntime.jsx("span",{children:o.properties.langConfigConfirmRemove(t)}),jsxRuntime.jsxs("div",{style:{display:"flex",gap:"8px"},children:[jsxRuntime.jsx("button",{type:"button","data-testid":"lang-remove-confirm-yes",onClick:()=>y(t),style:{padding:"4px 10px",border:"none",borderRadius:"4px",backgroundColor:"#ef4444",color:"#fff",fontSize:"12px",cursor:"pointer"},children:o.properties.langConfigConfirmYes}),jsxRuntime.jsx("button",{type:"button","data-testid":"lang-remove-confirm-no",onClick:p,style:{padding:"4px 10px",border:"1px solid #e2e8f0",borderRadius:"4px",backgroundColor:"#fff",color:"#334155",fontSize:"12px",cursor:"pointer"},children:o.properties.langConfigConfirmNo})]})]})]})}function ir(e,r,a,n){let o=p=>{if(p===void 0)return;if(typeof p=="string")return p;let f={...p};return delete f[r],n?Eo(f,a,"fr"):f},t=p=>({...p,label:o(p.label)??""}),i=p=>({...p,message:o(p.message)??""}),l=p=>({...p,errorMessage:o(p.errorMessage)}),d=p=>({...p,name:o(p.name)??"",description:o(p.description),placeholder:o(p.placeholder),options:p.options?p.options.map(t):p.options,validationRules:p.validationRules?p.validationRules.map(i):p.validationRules,conditions:p.conditions?p.conditions.map(l):p.conditions}),s=p=>({...p,name:o(p.name)??"",options:p.options?p.options.map(t):p.options,variables:p.variables.map(d),conditions:p.conditions?p.conditions.map(l):p.conditions}),c=p=>({...p,instanceLabel:o(p.instanceLabel)}),x=p=>formCore.isPageRoster(p)?s(p):d(p),y=p=>{let f=Array.isArray(p.items)?p.items.map(x):[...formCore.getPageVariables(p).map(d),...formCore.getPageRosters(p).map(s)],{variables:g,rosters:u,...b}=p;return {...b,name:o(p.name)??"",repeatConfig:p.repeatConfig?c(p.repeatConfig):p.repeatConfig,items:f,conditions:p.conditions?p.conditions.map(l):p.conditions}};return {...e,name:o(e.name)??"",description:o(e.description),pages:e.pages.map(y)}}function j({label:e,value:r,onChange:a,multiline:n,type:o="text",readOnly:t}){let i={width:"100%",padding:"6px 8px",border:"1px solid #e2e8f0",borderRadius:"4px",fontSize:"13px",color:t?"#64748b":"#334155",backgroundColor:t?"#f1f5f9":"#fff",outline:"none",boxSizing:"border-box",cursor:t?"not-allowed":"text"};return jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("label",{style:{display:"block",fontSize:"12px",fontWeight:500,color:"#64748b",marginBottom:"4px"},children:e}),n?jsxRuntime.jsx("textarea",{value:r,onChange:l=>a(l.target.value),rows:3,style:i,readOnly:t}):jsxRuntime.jsx("input",{type:o,value:r,onChange:l=>a(l.target.value),style:i,readOnly:t})]})}function Mo({page:e}){let{updatePage:r}=R(),a=T();return jsxRuntime.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"12px"},children:[jsxRuntime.jsx(J,{label:a.properties.name,value:e.name,onChange:n=>r(e.code,{name:n}),testIdPrefix:"page-name"}),jsxRuntime.jsx(j,{label:a.properties.code,value:e.code,onChange:()=>{}}),jsxRuntime.jsx("div",{children:jsxRuntime.jsxs("label",{style:{display:"flex",alignItems:"center",gap:"8px",fontSize:"13px",color:"#334155",cursor:"pointer"},children:[jsxRuntime.jsx("input",{type:"checkbox",checked:e.isRepeatable,onChange:n=>r(e.code,{isRepeatable:n.target.checked,repeatConfig:n.target.checked?{min:1,max:10}:void 0})}),a.properties.repeatablePage]})}),e.isRepeatable&&e.repeatConfig&&jsxRuntime.jsxs("div",{style:{padding:"8px",backgroundColor:"#f8fafc",borderRadius:"6px",display:"flex",flexDirection:"column",gap:"8px"},children:[jsxRuntime.jsx(j,{label:a.properties.minInstances,value:String(e.repeatConfig.min??1),type:"number",onChange:n=>r(e.code,{repeatConfig:{...e.repeatConfig,min:parseInt(n)||1}})}),jsxRuntime.jsx(j,{label:a.properties.maxInstances,value:String(e.repeatConfig.max??10),type:"number",onChange:n=>r(e.code,{repeatConfig:{...e.repeatConfig,max:parseInt(n)||10}})}),jsxRuntime.jsx(j,{label:a.properties.controlVariableCode,value:e.repeatConfig.controlVariableCode??"",onChange:n=>r(e.code,{repeatConfig:{...e.repeatConfig,controlVariableCode:n||void 0}})}),jsxRuntime.jsx(J,{label:a.properties.instanceLabel,value:e.repeatConfig.instanceLabel,onChange:n=>r(e.code,{repeatConfig:{...e.repeatConfig,instanceLabel:n}}),testIdPrefix:"page-instance-label"})]}),jsxRuntime.jsx("div",{style:{fontSize:"12px",color:"#94a3b8"},children:a.properties.pageSummary(formCore.getPageVariables(e).length,formCore.getPageRosters(e).length)})]})}var cr=["equals","not_equals","greater_than","less_than","greater_than_or_equal","less_than_or_equal","contains","not_contains","is_empty","is_not_empty","starts_with","ends_with","in","regex"],ur=["show","hide","validate","require","readonly","setValue"],fr=["is_empty","is_not_empty"];function Ze({conditions:e,onChange:r,availableVariables:a,rosterContext:n}){let o=T(),[t,i]=Kr.useState(null),l=()=>{let c={id:formCore.generateId(),action:"show",expression:""};r([...e,c]),i(c.id);},d=c=>{r(e.filter(x=>x.id!==c)),t===c&&i(null);},s=(c,x)=>{r(e.map(y=>y.id===c?{...y,...x}:y));};return jsxRuntime.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"8px"},children:[jsxRuntime.jsx("div",{style:{fontSize:"11px",fontWeight:600,color:"#64748b",textTransform:"uppercase",letterSpacing:"0.5px"},children:o.conditionBuilder.conditionsCount(e.length)}),e.map(c=>jsxRuntime.jsx(br,{condition:c,isExpanded:t===c.id,onToggle:()=>i(t===c.id?null:c.id),onUpdate:x=>s(c.id,x),onRemove:()=>d(c.id),availableVariables:a,rosterContext:n},c.id)),jsxRuntime.jsx("button",{type:"button",onClick:l,style:{padding:"6px 12px",border:"1px dashed #cbd5e1",borderRadius:"6px",backgroundColor:"transparent",color:"#2563eb",fontSize:"12px",cursor:"pointer"},children:o.conditionBuilder.addCondition})]})}function br({condition:e,isExpanded:r,onToggle:a,onUpdate:n,onRemove:o,availableVariables:t,rosterContext:i}){let l=T(),[d,s]=Kr.useState(()=>yr(e.expression)),c=(b,m)=>{s(b);let h=Bo(b,m);n({expression:h});},x=b=>{n({action:b});let m=Bo(d,b);n({action:b,expression:m});},y=()=>{let b={id:formCore.generateId(),variableCode:"",operator:"equals",value:""},m={...d,rules:[...d.rules,b]};c(m,e.action);},p=b=>{let m={...d,rules:d.rules.filter(h=>h.id!==b)};c(m,e.action);},f=(b,m)=>{let h={...d,rules:d.rules.map(P=>P.id===b?{...P,...m}:P)};c(h,e.action);},g=b=>{let m={...d,logic:b};c(m,e.action);},u=l.conditionBuilder.actions[e.action]??e.action;return jsxRuntime.jsxs("div",{style:{border:"1px solid #e2e8f0",borderRadius:"6px",overflow:"hidden"},children:[jsxRuntime.jsxs("div",{onClick:a,style:{display:"flex",alignItems:"center",justifyContent:"space-between",padding:"6px 10px",backgroundColor:"#f8fafc",cursor:"pointer",fontSize:"12px",color:"#334155"},children:[jsxRuntime.jsxs("span",{style:{fontWeight:500},children:[u,d.rules.length>0?l.conditionBuilder.rulesCount(d.rules.length):""]}),jsxRuntime.jsxs("div",{style:{display:"flex",gap:"4px"},children:[jsxRuntime.jsx("span",{style:{color:"#94a3b8"},children:r?"\u25B2":"\u25BC"}),jsxRuntime.jsx("span",{onClick:b=>{b.stopPropagation(),o();},style:{color:"#ef4444",cursor:"pointer",padding:"0 4px"},role:"button",children:"\xD7"})]})]}),r&&jsxRuntime.jsxs("div",{style:{padding:"10px",display:"flex",flexDirection:"column",gap:"8px"},children:[jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("label",{style:{fontSize:"11px",fontWeight:500,color:"#64748b",display:"block",marginBottom:"2px"},children:l.conditionBuilder.action}),jsxRuntime.jsx("select",{value:e.action,onChange:b=>x(b.target.value),style:Qe,children:ur.map(b=>jsxRuntime.jsx("option",{value:b,children:l.conditionBuilder.actions[b]},b))})]}),d.rules.length>1&&jsxRuntime.jsxs("div",{style:{display:"flex",gap:"4px",alignItems:"center"},children:[jsxRuntime.jsx("span",{style:{fontSize:"11px",color:"#64748b"},children:l.conditionBuilder.match}),jsxRuntime.jsx("button",{type:"button",onClick:()=>g("and"),style:{...No,backgroundColor:d.logic==="and"?"#2563eb":"#f1f5f9",color:d.logic==="and"?"#fff":"#64748b"},children:l.conditionBuilder.all}),jsxRuntime.jsx("button",{type:"button",onClick:()=>g("or"),style:{...No,backgroundColor:d.logic==="or"?"#2563eb":"#f1f5f9",color:d.logic==="or"?"#fff":"#64748b"},children:l.conditionBuilder.any})]}),d.rules.map(b=>jsxRuntime.jsxs("div",{style:{display:"flex",gap:"4px",alignItems:"center"},children:[jsxRuntime.jsxs("select",{value:b.variableCode,onChange:m=>f(b.id,{variableCode:m.target.value}),style:{...Qe,flex:1},children:[jsxRuntime.jsx("option",{value:"",children:l.conditionBuilder.variablePlaceholder}),t.map(m=>jsxRuntime.jsxs("option",{value:m.code,children:[m.name," (",m.code,")"]},m.code))]}),jsxRuntime.jsx("select",{value:b.operator,onChange:m=>f(b.id,{operator:m.target.value}),style:{...Qe,width:"130px"},children:cr.map(m=>jsxRuntime.jsx("option",{value:m,children:l.conditionBuilder.operators[m]},m))}),!fr.includes(b.operator)&&jsxRuntime.jsx("input",{type:"text",value:b.value,onChange:m=>f(b.id,{value:m.target.value}),placeholder:l.conditionBuilder.valuePlaceholder,style:{...Xe,flex:1}}),jsxRuntime.jsx("button",{type:"button",onClick:()=>p(b.id),style:{border:"none",background:"none",color:"#ef4444",cursor:"pointer",fontSize:"14px",padding:"2px"},children:"\xD7"})]},b.id)),jsxRuntime.jsx("button",{type:"button",onClick:y,style:{padding:"4px 8px",border:"1px dashed #cbd5e1",borderRadius:"4px",backgroundColor:"transparent",color:"#64748b",fontSize:"11px",cursor:"pointer"},children:l.conditionBuilder.addRule}),e.expression&&jsxRuntime.jsx("div",{style:{padding:"6px 8px",backgroundColor:"#f0fdf4",borderRadius:"4px",fontSize:"11px",fontFamily:"monospace",color:"#166534",wordBreak:"break-all"},children:e.expression}),i&&e.expression&&(()=>{let b=formCore.RosterConditionEngine.validateCondition(e.expression,i.variables,i.currentVariableCode,i.currentVariableOrder);return b.isValid?null:jsxRuntime.jsx("div",{"data-testid":"condition-builder-roster-errors",style:{padding:"6px 8px",backgroundColor:"#fef2f2",border:"1px solid #fecaca",borderRadius:"4px",fontSize:"11px",color:"#b91c1c",display:"flex",flexDirection:"column",gap:"4px"},children:b.errors.map((m,h)=>jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("strong",{children:m.type}),m.variableCode?`: \${${m.variableCode}}`:""," \u2014 ",m.message]},h))})})(),e.action==="validate"&&jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("label",{style:{fontSize:"11px",fontWeight:500,color:"#64748b",display:"block",marginBottom:"2px"},children:l.conditionBuilder.errorMessage}),jsxRuntime.jsx(gr,{value:e.errorMessage,onChange:b=>n({errorMessage:b}),placeholder:l.conditionBuilder.errorMessagePlaceholder})]}),e.action==="setValue"&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("label",{style:{fontSize:"11px",fontWeight:500,color:"#64748b",display:"block",marginBottom:"2px"},children:l.conditionBuilder.targetVariableCode}),jsxRuntime.jsx("input",{type:"text",value:e.targetVariableCode??"",onChange:b=>n({targetVariableCode:b.target.value||void 0}),placeholder:l.conditionBuilder.targetVariablePlaceholder,style:Xe})]}),jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("label",{style:{fontSize:"11px",fontWeight:500,color:"#64748b",display:"block",marginBottom:"2px"},children:l.conditionBuilder.valueToSet}),jsxRuntime.jsx("input",{type:"text",value:e.setValue!==void 0?String(e.setValue):"",onChange:b=>n({setValue:b.target.value}),placeholder:l.conditionBuilder.valueToSetPlaceholder,style:Xe})]})]})]})]})}function gr({value:e,onChange:r,placeholder:a}){let o=R(t=>t.form).langConfig??formCore.DEFAULT_LANG_CONFIG;return jsxRuntime.jsx(Pe,{value:e,onChange:t=>r(t),availableLangs:o.availableLangs,defaultLang:o.defaultLang,placeholder:a,testIdPrefix:"condition-error-message"})}function mr(e){return {equals:"==",not_equals:"!=",contains:"contains",not_contains:"!contains",starts_with:"startsWith",ends_with:"endsWith",greater_than:">",less_than:"<",greater_than_or_equal:">=",less_than_or_equal:"<=",is_empty:"isEmpty",is_not_empty:"isNotEmpty",in:"in",not_in:"!in",between:"between",regex:"regex"}[e]??"=="}function Bo(e,r){if(e.rules.length===0)return "";let a=e.rules.filter(o=>o.variableCode).map(o=>{let t=`\${${o.variableCode}}`,i=mr(o.operator);if(o.operator==="is_empty")return `isEmpty(${t})`;if(o.operator==="is_not_empty")return `isNotEmpty(${t})`;if(o.operator==="contains")return `contains(${t}, "${o.value}")`;if(o.operator==="starts_with")return `startsWith(${t}, "${o.value}")`;if(o.operator==="ends_with")return `endsWith(${t}, "${o.value}")`;let l=/^\d+(\.\d+)?$/.test(o.value)?o.value:`"${o.value}"`;return `${t} ${i} ${l}`});if(a.length===0)return "";let n=a.join(e.logic==="and"?" && ":" || ");return r==="show"?`show(${n})`:r==="hide"?`hide(${n})`:r==="validate"?`ConditionEval(${n})`:n}function yr(e){return {logic:"and",rules:[]}}var Qe={padding:"4px 6px",border:"1px solid #e2e8f0",borderRadius:"4px",fontSize:"12px",color:"#334155",outline:"none"},Xe={width:"100%",padding:"4px 6px",border:"1px solid #e2e8f0",borderRadius:"4px",fontSize:"12px",color:"#334155",outline:"none",boxSizing:"border-box"},No={padding:"2px 8px",borderRadius:"10px",border:"none",fontSize:"10px",fontWeight:600,cursor:"pointer"};function Go({open:e,onClose:r,conditions:a,onApply:n,availableVariables:o,rosterContext:t}){let i=T(),l=Kr.useRef(null),d=Kr.useRef(null),[s,c]=Kr.useState(a),[x,y]=Kr.useState("visual");Kr.useEffect(()=>{e&&(c(a),y("visual"));},[e,a]),Kr.useEffect(()=>{if(!e)return;d.current=document.activeElement;let f=setTimeout(()=>{l.current?.querySelector('button, [href], input, select, textarea, [tabindex]:not([tabindex="-1"])')?.focus();},0),g=u=>{if(u.key==="Escape"){u.stopPropagation(),r();return}if(u.key!=="Tab"||!l.current)return;let b=Array.from(l.current.querySelectorAll('button:not([disabled]), [href], input:not([disabled]), select:not([disabled]), textarea:not([disabled]), [tabindex]:not([tabindex="-1"])')).filter(v=>v.offsetParent!==null);if(b.length===0)return;let m=b[0],h=b[b.length-1],P=document.activeElement;u.shiftKey&&P===m?(u.preventDefault(),h.focus()):!u.shiftKey&&P===h&&(u.preventDefault(),m.focus());};return window.addEventListener("keydown",g),()=>{clearTimeout(f),window.removeEventListener("keydown",g),d.current?.focus?.();}},[e,r]);let p=Kr.useCallback(()=>{n(s),r();},[s,n,r]);return e?jsxRuntime.jsx("div",{"data-testid":"conditions-modal-overlay","aria-hidden":"false",style:{position:"fixed",inset:0,zIndex:1e3,backgroundColor:"rgba(15, 23, 42, 0.55)",display:"flex",alignItems:"center",justifyContent:"center",padding:"24px"},children:jsxRuntime.jsxs("div",{ref:l,role:"dialog","aria-modal":"true","aria-labelledby":"conditions-modal-title","data-testid":"conditions-modal",style:{backgroundColor:"#fff",borderRadius:"12px",boxShadow:"0 24px 48px rgba(0,0,0,0.25)",width:"100%",maxWidth:"720px",maxHeight:"calc(100vh - 48px)",display:"flex",flexDirection:"column",overflow:"hidden",fontFamily:"system-ui, -apple-system, sans-serif"},children:[jsxRuntime.jsxs("div",{style:{display:"flex",alignItems:"center",justifyContent:"space-between",padding:"14px 20px",borderBottom:"1px solid #e2e8f0"},children:[jsxRuntime.jsx("h2",{id:"conditions-modal-title",style:{margin:0,fontSize:"16px",fontWeight:600,color:"#0f172a"},children:i.conditionBuilder.modalTitle(s.length)}),jsxRuntime.jsx("button",{type:"button",onClick:r,"data-testid":"conditions-modal-close","aria-label":i.conditionBuilder.closeButton,style:{border:"none",background:"none",cursor:"pointer",fontSize:"20px",color:"#64748b",padding:"4px 8px",borderRadius:"6px"},children:"\u2715"})]}),jsxRuntime.jsxs("div",{style:{display:"flex",gap:"4px",padding:"12px 20px 0",borderBottom:"1px solid #f1f5f9"},children:[jsxRuntime.jsx(Ho,{active:x==="visual",label:i.conditionBuilder.modeVisual,testId:"conditions-modal-mode-visual",onClick:()=>y("visual")}),jsxRuntime.jsx(Ho,{active:x==="manual",label:i.conditionBuilder.modeManual,testId:"conditions-modal-mode-manual",onClick:()=>y("manual")})]}),jsxRuntime.jsxs("div",{style:{flex:1,overflowY:"auto",padding:"16px 20px"},children:[x==="visual"?jsxRuntime.jsx(Ze,{conditions:s,onChange:c,availableVariables:o,rosterContext:t}):jsxRuntime.jsx(hr,{conditions:s,onChange:c}),jsxRuntime.jsx(kr,{conditions:s,title:i.conditionBuilder.formulasSummary,empty:i.conditionBuilder.noConditions})]}),jsxRuntime.jsxs("div",{style:{display:"flex",justifyContent:"flex-end",gap:"8px",padding:"12px 20px",borderTop:"1px solid #e2e8f0"},children:[jsxRuntime.jsx("button",{type:"button",onClick:r,"data-testid":"conditions-modal-cancel",style:{padding:"8px 16px",border:"1px solid #cbd5e1",borderRadius:"6px",backgroundColor:"#fff",color:"#334155",fontSize:"13px",fontWeight:500,cursor:"pointer"},children:i.conditionBuilder.cancelButton}),jsxRuntime.jsx("button",{type:"button",onClick:p,"data-testid":"conditions-modal-apply",style:{padding:"8px 16px",border:"none",borderRadius:"6px",backgroundColor:"#2563eb",color:"#fff",fontSize:"13px",fontWeight:600,cursor:"pointer"},children:i.conditionBuilder.applyButton})]})]})}):null}function Ho({active:e,label:r,testId:a,onClick:n}){return jsxRuntime.jsx("button",{type:"button",onClick:n,"data-testid":a,"aria-pressed":e,style:{padding:"8px 14px",border:"none",backgroundColor:"transparent",color:e?"#2563eb":"#64748b",fontWeight:e?600:500,fontSize:"13px",cursor:"pointer",borderBottomWidth:"2px",borderBottomStyle:"solid",borderBottomColor:e?"#2563eb":"transparent",marginBottom:"-1px"},children:r})}function hr({conditions:e,onChange:r}){let a=T();if(e.length===0)return jsxRuntime.jsx("div",{style:{padding:"12px",color:"#94a3b8",fontSize:"13px",textAlign:"center",fontStyle:"italic"},children:a.conditionBuilder.noConditions});let n=(t,i)=>{r(e.map(l=>l.id===t?{...l,expression:i}:l));},o=t=>t.includes("ConditionEval(")||t.includes("||")||/show\(|hide\(|setValue\(/.test(t)===false||t.split("&&").length>2;return jsxRuntime.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"14px"},children:[jsxRuntime.jsx("p",{style:{margin:0,fontSize:"11px",color:"#64748b"},children:a.conditionBuilder.manualHelp}),e.map((t,i)=>jsxRuntime.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"6px"},children:[jsxRuntime.jsxs("label",{style:{fontSize:"11px",fontWeight:600,color:"#64748b"},children:["#",i+1," \u2014 ",a.conditionBuilder.actions[t.action]??t.action]}),jsxRuntime.jsx(Ir,{value:t.expression,onChange:l=>n(t.id,l),placeholder:a.conditionBuilder.manualPlaceholder,testId:`conditions-modal-manual-${t.id}`}),o(t.expression)&&jsxRuntime.jsxs("p",{"data-testid":`conditions-modal-manual-warning-${t.id}`,style:{margin:0,fontSize:"11px",color:"#92400e",backgroundColor:"#fffbeb",border:"1px solid #fde68a",padding:"6px 8px",borderRadius:"4px"},children:["\u26A0 ",a.conditionBuilder.manualWarning]})]},t.id))]})}var Sr={function:"#2563eb",variable:"#ea580c",operator:"#9333ea",string:"#16a34a",number:"#0891b2",plain:"inherit",identifier:"inherit"},Rr=new Set(["show","hide","setValue","validate","require","readonly","ConditionEval","jump","contains","startsWith","endsWith","isEmpty","isNotEmpty","not_contains","in","between","regex"]);function Tr(e){let r=[],a=0;for(;a<e.length;){let n=e[a];if(n==='"'||n==="'"){let o=a+1;for(;o<e.length&&e[o]!==n;)e[o]==="\\"&&o++,o++;r.push({type:"string",text:e.slice(a,Math.min(o+1,e.length))}),a=o+1;continue}if(n==="$"&&e[a+1]==="{"){let o=a+2;for(;o<e.length&&e[o]!=="}";)o++;r.push({type:"variable",text:e.slice(a,Math.min(o+1,e.length))}),a=o+1;continue}if(/[a-zA-Z_]/.test(n)){let o=a;for(;o<e.length&&/[a-zA-Z0-9_]/.test(e[o]);)o++;let t=e.slice(a,o);r.push({type:Rr.has(t)?"function":"identifier",text:t}),a=o;continue}if(/\d/.test(n)){let o=a;for(;o<e.length&&/[\d.]/.test(e[o]);)o++;r.push({type:"number",text:e.slice(a,o)}),a=o;continue}if("=!<>&|".includes(n)){let o=e.slice(a,a+2);if(["==","!=","<=",">=","&&","||"].includes(o)){r.push({type:"operator",text:o}),a+=2;continue}r.push({type:"operator",text:n}),a++;continue}r.push({type:"plain",text:n}),a++;}return r}function Ir({value:e,onChange:r,placeholder:a,testId:n}){let o=Kr.useRef(null),t=Kr.useRef(null),i=Kr.useMemo(()=>Tr(e),[e]),l=()=>{!o.current||!t.current||(t.current.scrollTop=o.current.scrollTop,t.current.scrollLeft=o.current.scrollLeft);},d={position:"absolute",top:0,left:0,width:"100%",height:"100%",margin:0,padding:"8px 10px",border:"none",fontFamily:'ui-monospace, "SF Mono", Menlo, Consolas, monospace',fontSize:"12.5px",lineHeight:"20px",whiteSpace:"pre-wrap",wordBreak:"break-word",boxSizing:"border-box"};return jsxRuntime.jsxs("div",{style:{position:"relative",minHeight:"60px",border:"1px solid #cbd5e1",borderRadius:"6px",backgroundColor:"#f8fafc",overflow:"hidden"},children:[jsxRuntime.jsx("div",{ref:t,"aria-hidden":"true",style:{...d,color:"#0f172a",overflow:"auto",pointerEvents:"none"},children:i.length===0?jsxRuntime.jsx("span",{style:{color:"#94a3b8"},children:a}):jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[i.map((s,c)=>jsxRuntime.jsx("span",{style:{color:Sr[s.type]},children:s.text},c)),jsxRuntime.jsx("span",{children:"\u200B"})]})}),jsxRuntime.jsx("textarea",{ref:o,value:e,onChange:s=>r(s.target.value),onScroll:l,placeholder:a,"data-testid":n,spellCheck:false,style:{...d,color:"transparent",caretColor:"#0f172a",backgroundColor:"transparent",resize:"vertical",outline:"none",overflow:"auto"}})]})}function kr({conditions:e,title:r,empty:a}){return jsxRuntime.jsxs("div",{style:{marginTop:"16px",borderTop:"1px solid #e2e8f0",paddingTop:"12px"},children:[jsxRuntime.jsx("h3",{style:{margin:"0 0 8px",fontSize:"11px",fontWeight:600,color:"#64748b",textTransform:"uppercase",letterSpacing:"0.5px"},children:r}),e.length===0?jsxRuntime.jsx("p",{style:{margin:0,fontSize:"12px",color:"#94a3b8",fontStyle:"italic"},children:a}):jsxRuntime.jsx("ul",{"data-testid":"conditions-modal-summary",style:{margin:0,padding:0,listStyle:"none",display:"flex",flexDirection:"column",gap:"4px"},children:e.map(n=>jsxRuntime.jsx("li",{style:{fontFamily:'ui-monospace, "SF Mono", Menlo, Consolas, monospace',fontSize:"11.5px",color:"#0f172a",backgroundColor:"#f1f5f9",padding:"4px 8px",borderRadius:"4px",wordBreak:"break-all"},children:n.expression||"\u2205"},n.id))})]})}function eo({dataSourceId:e,dependencies:r={},availableConnectors:a,availableVariables:n,onConnectorChange:o,onDependenciesChange:t}){let i=T(),[l,d]=Kr.useState(""),s=R(m=>m.availableDataSources),x=R(m=>m.form).langConfig?.defaultLang??formCore.DEFAULT_LANG_CONFIG.defaultLang,y=Kr.useMemo(()=>{let m=new Map;for(let h of a)m.set(h.id,{id:h.id,name:h.name});for(let h of s){let P=typeof h.name=="string"?h.name:formCore.resolveLabel(h.name,x,x);m.set(h.code,{id:h.code,name:P});}return Array.from(m.values())},[a,s,x]),p=y.find(m=>m.id===e),f=Object.entries(r),g=()=>{l.trim()&&(t({...r,[l.trim()]:""}),d(""));},u=m=>{let h={...r};delete h[m],t(h);},b=(m,h)=>{t({...r,[m]:h});};return jsxRuntime.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"10px",padding:"8px",backgroundColor:"#f0fdf4",borderRadius:"6px"},children:[jsxRuntime.jsx("div",{style:{fontSize:"11px",fontWeight:600,color:"#166534",textTransform:"uppercase",letterSpacing:"0.5px"},children:i.dataSource.title}),jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("label",{style:Vr,children:i.dataSource.connector}),jsxRuntime.jsxs("select",{value:e??"",onChange:m=>{let h=m.target.value||void 0;o(h),h||t({});},style:jo,children:[jsxRuntime.jsx("option",{value:"",children:i.dataSource.none}),y.map(m=>jsxRuntime.jsxs("option",{value:m.id,children:[m.name," (",m.id,")"]},m.id))]})]}),p&&jsxRuntime.jsxs("div",{style:{fontSize:"11px",color:"#166534",padding:"4px 6px",backgroundColor:"#dcfce7",borderRadius:"4px"},children:[i.dataSource.connectedTo," ",jsxRuntime.jsx("strong",{children:p.name})]}),e&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx("div",{style:{fontSize:"11px",fontWeight:500,color:"#166534"},children:i.dataSource.dependencies(f.length)}),f.map(([m,h])=>jsxRuntime.jsxs("div",{style:{display:"flex",gap:"4px",alignItems:"center"},children:[jsxRuntime.jsx("span",{style:{fontSize:"11px",color:"#334155",minWidth:"60px",fontFamily:"monospace"},children:m}),jsxRuntime.jsx("span",{style:{fontSize:"11px",color:"#94a3b8"},children:"\u2192"}),jsxRuntime.jsxs("select",{value:h,onChange:P=>b(m,P.target.value),style:{...jo,flex:1},children:[jsxRuntime.jsx("option",{value:"",children:i.dataSource.selectVariable}),n.map(P=>jsxRuntime.jsxs("option",{value:P.code,children:[P.name," (",P.code,")"]},P.code))]}),jsxRuntime.jsx("button",{type:"button",onClick:()=>u(m),style:{border:"none",background:"none",color:"#ef4444",cursor:"pointer",fontSize:"14px"},children:"\xD7"})]},m)),jsxRuntime.jsxs("div",{style:{display:"flex",gap:"4px"},children:[jsxRuntime.jsx("input",{type:"text",value:l,onChange:m=>d(m.target.value),placeholder:i.dataSource.dependencyKeyPlaceholder,style:{...Er,flex:1},onKeyDown:m=>m.key==="Enter"&&g()}),jsxRuntime.jsx("button",{type:"button",onClick:g,disabled:!l.trim(),style:{padding:"4px 8px",border:"1px solid #cbd5e1",borderRadius:"4px",backgroundColor:"#fff",color:"#2563eb",fontSize:"11px",cursor:"pointer",opacity:l.trim()?1:.5},children:i.dataSource.addDependency})]})]})]})}var Vr={fontSize:"11px",fontWeight:500,color:"#166534",display:"block",marginBottom:"2px"},jo={width:"100%",padding:"4px 6px",border:"1px solid #bbf7d0",borderRadius:"4px",fontSize:"12px",color:"#334155",outline:"none",backgroundColor:"#fff"},Er={padding:"4px 6px",border:"1px solid #bbf7d0",borderRadius:"4px",fontSize:"12px",color:"#334155",outline:"none",boxSizing:"border-box"};function $r(e){return e.normalize("NFD").replace(/[̀-ͯ]/g,"").toLowerCase().trim().replace(/\s+/g,"_").replace(/[^a-z0-9_-]/g,"")}function Ko(e){return typeof e=="string"?e:e==null?"":String(e)}function oo(e,r){if(e==null)return "";if(typeof e=="string")return e;let a=e[r];if(typeof a=="string"&&a!=="")return a;for(let n of Object.values(e))if(typeof n=="string"&&n!=="")return n;return ""}function Jo({options:e,onChange:r,disabled:a}){let n=T(),t=R(g=>g.form).langConfig??formCore.DEFAULT_LANG_CONFIG,i=(g,u)=>{let b=e.map((m,h)=>h===g?{...m,...u}:m);r(b);},l=(g,u)=>{let b=e[g],m=Ko(b.value),h=oo(b.label,t.defaultLang),P=oo(u,t.defaultLang);m===""&&h===""&&P!==""?i(g,{label:u,value:$r(P)}):i(g,{label:u});},d=(g,u)=>{i(g,{value:u});},s=()=>{r([...e,{label:"",value:""}]);},c=g=>{r(e.filter((u,b)=>b!==g));},x={display:"block",fontSize:"12px",fontWeight:500,color:"#64748b",marginBottom:"4px"},y={flex:1,padding:"6px 8px",borderRadius:"4px",fontSize:"13px",color:"#000",outline:"none"},p="1px solid #e2e8f0",f="1px solid #ef4444";return jsxRuntime.jsxs("div",{"data-testid":"options-editor",children:[jsxRuntime.jsx("label",{style:x,children:n.optionsEditor.optionsCount(e.length)}),e.length===0&&jsxRuntime.jsx("div",{"data-testid":"options-editor-empty",style:{fontSize:"12px",color:"#94a3b8",marginBottom:"8px"},children:n.optionsEditor.noOptions}),jsxRuntime.jsx("div",{style:{display:"flex",flexDirection:"column",gap:"6px"},children:e.map((g,u)=>{let b=oo(g.label,t.defaultLang),m=Ko(g.value),h=b.trim()==="",P=m.trim()==="";return jsxRuntime.jsxs("div",{"data-testid":`option-row-${u}`,style:{display:"flex",alignItems:"flex-start",gap:"6px"},children:[jsxRuntime.jsx("div",{"aria-label":n.optionsEditor.optionLabelAria(u),"data-testid":`option-label-${u}`,style:{flex:1,border:h?f:p,borderRadius:"4px"},children:jsxRuntime.jsx(Pe,{value:g.label,onChange:v=>l(u,v),availableLangs:t.availableLangs,defaultLang:t.defaultLang,placeholder:n.optionsEditor.optionLabelPlaceholder,disabled:a,testIdPrefix:`option-label-input-${u}`})}),jsxRuntime.jsx("input",{type:"text","aria-label":n.optionsEditor.optionValueAria(u),"data-testid":`option-value-${u}`,value:m,placeholder:n.optionsEditor.optionValuePlaceholder,disabled:a,onChange:v=>d(u,v.target.value),style:{...y,border:P?f:p,maxWidth:"40%"}}),jsxRuntime.jsx("button",{type:"button","aria-label":n.optionsEditor.removeOptionAria(u),"data-testid":`option-remove-${u}`,onClick:()=>c(u),disabled:a,style:{width:"24px",height:"24px",border:"1px solid #e2e8f0",borderRadius:"4px",backgroundColor:"#fff",color:"#64748b",cursor:a?"not-allowed":"pointer",lineHeight:1,fontSize:"14px"},children:"\xD7"})]},u)})}),jsxRuntime.jsx("button",{type:"button","data-testid":"options-editor-add",onClick:s,disabled:a,style:{marginTop:"8px",padding:"6px 10px",border:"1px dashed #94a3b8",borderRadius:"4px",backgroundColor:"transparent",color:"#2563eb",fontSize:"12px",cursor:a?"not-allowed":"pointer"},children:n.optionsEditor.addOption})]})}var _r=new Set(["type","description","placeholder","isRequired","isReadonly","isHidden","options","validationRules","conditions","expression","dataSourceId","dataSourceDependencies","style","metadata"]);function to(e){return e==="type"?"variableType":e}function Xo({variable:e,pageCode:r,rosterCode:a,availableConnectors:n=[]}){let {form:o,updateVariable:t,setVariableOverride:i,resetVariableOverride:l,availableTemplates:d}=R(),s=T(),[c,x]=Kr.useState(false),y=Kr.useMemo(()=>[{value:"text",label:s.toolbox.types.text},{value:"textarea",label:s.toolbox.types.textarea},{value:"number",label:s.toolbox.types.number},{value:"date",label:s.toolbox.types.date},{value:"datetime",label:s.toolbox.types.datetime},{value:"time",label:s.toolbox.types.time},{value:"select",label:s.toolbox.types.select},{value:"multiselect",label:s.toolbox.types.multiselect},{value:"radio",label:s.toolbox.types.radio},{value:"checkbox",label:s.toolbox.types.checkbox},{value:"file",label:s.toolbox.types.file},{value:"gps",label:s.toolbox.types.gps},{value:"rating",label:s.toolbox.types.rating},{value:"calculated",label:s.toolbox.types.calculated},{value:"hidden",label:s.toolbox.types.hidden},{value:"label",label:s.toolbox.types.label}],[s]),p=!!e.templateId;p?d.find(v=>v.id===e.templateId):void 0;let g=o.langConfig?.defaultLang??formCore.DEFAULT_LANG_CONFIG.defaultLang,u=v=>{if(!p){t(r,e.code,v,a);return}let A={},S=false;for(let[V,K]of Object.entries(v))if(_r.has(V)){let Y=to(V);i(r,e.code,Y,K,a);}else A[V]=K,S=true;S&&t(r,e.code,A,a);},b=v=>{if(!p)return false;let A=to(v);return Object.prototype.hasOwnProperty.call(e.templateOverrides??{},A)},m=v=>{p&&l(r,e.code,to(v),a);},h=v=>formCore.resolveLabel(v,g,g),P=o.pages.flatMap(v=>[...formCore.getPageVariables(v).map(A=>({code:A.code,name:h(A.name)})),...formCore.getPageRosters(v).flatMap(A=>A.variables.map(S=>({code:S.code,name:h(S.name)})))]);return jsxRuntime.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"12px"},children:[p&&jsxRuntime.jsx(Wr,{variable:e,templateCodeLabel:s.properties.templateCode,templateNameLabel:s.properties.templateName,bannerTitle:s.properties.linkedTemplate,defaultLang:g}),p?jsxRuntime.jsx(qr,{label:s.properties.templateName,value:e.name,defaultLang:g,testId:"variable-name-readonly"}):jsxRuntime.jsx(J,{label:s.properties.name,value:e.name,onChange:v=>u({name:v}),testIdPrefix:"variable-name"}),jsxRuntime.jsx(j,{label:p?s.properties.templateCode:s.properties.code,value:e.code,onChange:()=>{},readOnly:true}),jsxRuntime.jsx(le,{isOverridden:b("description"),onReset:()=>m("description"),resetLabel:s.properties.resetOverride,children:jsxRuntime.jsx(J,{label:s.properties.description,value:e.description,onChange:v=>u({description:v}),testIdPrefix:"variable-description"})}),jsxRuntime.jsx(le,{isOverridden:b("placeholder"),onReset:()=>m("placeholder"),resetLabel:s.properties.resetOverride,children:jsxRuntime.jsx(J,{label:s.properties.placeholder,value:e.placeholder,onChange:v=>u({placeholder:v}),testIdPrefix:"variable-placeholder"})}),jsxRuntime.jsx(le,{isOverridden:b("type"),onReset:()=>m("type"),resetLabel:s.properties.resetOverride,children:jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("label",{style:{display:"block",fontSize:"12px",fontWeight:500,color:"#64748b",marginBottom:"4px"},children:s.properties.type}),jsxRuntime.jsx("select",{value:e.type,onChange:v=>u({type:v.target.value}),style:{width:"100%",padding:"6px 8px",border:"1px solid #e2e8f0",borderRadius:"4px",fontSize:"13px"},children:y.map(v=>jsxRuntime.jsx("option",{value:v.value,children:v.label},v.value))})]})}),e.type==="rating"&&jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("label",{style:{display:"block",fontSize:"12px",fontWeight:500,color:"#64748b",marginBottom:"4px"},children:s.properties.ratingStyle}),jsxRuntime.jsxs("select",{value:e.metadata?.ratingStyle??"star",onChange:v=>u({metadata:{...e.metadata,ratingStyle:v.target.value}}),style:{width:"100%",padding:"6px 8px",border:"1px solid #e2e8f0",borderRadius:"4px",fontSize:"13px"},children:[jsxRuntime.jsx("option",{value:"star",children:s.properties.ratingStyles.star}),jsxRuntime.jsx("option",{value:"number",children:s.properties.ratingStyles.number}),jsxRuntime.jsx("option",{value:"color",children:s.properties.ratingStyles.color})]})]}),jsxRuntime.jsxs("div",{style:{padding:"8px",backgroundColor:"#f8fafc",borderRadius:"6px",display:"flex",flexDirection:"column",gap:"6px"},children:[jsxRuntime.jsx("div",{style:{fontSize:"11px",fontWeight:600,color:"#64748b",textTransform:"uppercase"},children:s.properties.layout}),jsxRuntime.jsx(Be,{label:s.properties.startNewRow,checked:e.startWithNewLine!==false,onChange:v=>u({startWithNewLine:v?void 0:false})}),jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("label",{style:{display:"block",fontSize:"12px",fontWeight:500,color:"#64748b",marginBottom:"2px"},children:s.properties.columnSpan}),jsxRuntime.jsxs("select",{value:e.colSpan??"auto",onChange:v=>u({colSpan:v.target.value==="auto"?void 0:parseInt(v.target.value)}),style:{width:"100%",padding:"4px 8px",border:"1px solid #e2e8f0",borderRadius:"4px",fontSize:"13px"},children:[jsxRuntime.jsx("option",{value:"auto",children:s.properties.columnSpanAuto}),[1,2,3,4,5,6,7,8,9,10,11,12].map(v=>jsxRuntime.jsxs("option",{value:v,children:[v,"/12",v===6?s.properties.columnSpanHalf:v===4?s.properties.columnSpanThird:v===12?s.properties.columnSpanFull:""]},v))]})]})]}),jsxRuntime.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"6px"},children:[jsxRuntime.jsx(le,{isOverridden:b("isRequired"),onReset:()=>m("isRequired"),resetLabel:s.properties.resetOverride,inline:true,children:jsxRuntime.jsx(Be,{label:s.properties.required,checked:e.isRequired,onChange:v=>u({isRequired:v})})}),jsxRuntime.jsx(le,{isOverridden:b("isReadonly"),onReset:()=>m("isReadonly"),resetLabel:s.properties.resetOverride,inline:true,children:jsxRuntime.jsx(Be,{label:s.properties.readonly,checked:e.isReadonly,onChange:v=>u({isReadonly:v})})}),jsxRuntime.jsx(le,{isOverridden:b("isHidden"),onReset:()=>m("isHidden"),resetLabel:s.properties.resetOverride,inline:true,children:jsxRuntime.jsx(Be,{label:s.properties.hidden,checked:e.isHidden,onChange:v=>u({isHidden:v})})})]}),e.type==="calculated"&&jsxRuntime.jsx(le,{isOverridden:b("expression"),onReset:()=>m("expression"),resetLabel:s.properties.resetOverride,children:jsxRuntime.jsx(j,{label:s.properties.expression,value:e.expression??"",onChange:v=>u({expression:v||void 0}),multiline:true})}),["select","multiselect","radio"].includes(e.type)&&jsxRuntime.jsx(eo,{dataSourceId:e.dataSourceId,dependencies:e.dataSourceDependencies,availableConnectors:n,availableVariables:P,onConnectorChange:v=>u({dataSourceId:v}),onDependenciesChange:v=>u({dataSourceDependencies:Object.keys(v).length>0?v:void 0})}),["select","multiselect","radio","checkbox"].includes(e.type)&&!e.dataSourceId&&jsxRuntime.jsx(le,{isOverridden:b("options"),onReset:()=>m("options"),resetLabel:s.properties.resetOverride,children:jsxRuntime.jsx(Jo,{options:e.options??[],onChange:v=>u({options:v})})}),jsxRuntime.jsx(le,{isOverridden:b("conditions"),onReset:()=>m("conditions"),resetLabel:s.properties.resetOverride,children:jsxRuntime.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"6px"},children:[jsxRuntime.jsx("label",{style:{fontSize:"11px",fontWeight:600,color:"#64748b",textTransform:"uppercase",letterSpacing:"0.5px"},children:s.conditionBuilder.conditionsCount((e.conditions??[]).length)}),jsxRuntime.jsxs("button",{type:"button","data-testid":"conditions-modal-open",onClick:()=>x(true),style:{padding:"8px 14px",border:"1px solid #cbd5e1",borderRadius:"6px",backgroundColor:"#fff",color:"#1e293b",fontSize:"13px",fontWeight:500,cursor:"pointer",textAlign:"left"},children:["\u2699 ",s.conditionBuilder.configureButton((e.conditions??[]).length)]}),(e.conditions??[]).length>0&&jsxRuntime.jsx("ul",{"data-testid":"conditions-preview",style:{margin:0,padding:0,listStyle:"none",display:"flex",flexDirection:"column",gap:"3px"},children:(e.conditions??[]).map(v=>jsxRuntime.jsx("li",{style:{fontFamily:'ui-monospace, "SF Mono", Menlo, Consolas, monospace',fontSize:"11.5px",color:"#0f172a",backgroundColor:"#f1f5f9",padding:"4px 8px",borderRadius:"4px",wordBreak:"break-all"},children:v.expression||"\u2205"},v.id))})]})}),jsxRuntime.jsx(Go,{open:c,onClose:()=>x(false),conditions:e.conditions??[],onApply:v=>u({conditions:v}),availableVariables:P,rosterContext:(()=>{if(!a)return;let v=o.pages.find(S=>S.code===r),A=v?formCore.getPageRosters(v).find(S=>S.code===a):void 0;if(A)return {variables:A.variables.map(S=>({code:S.code,order:S.order})),currentVariableCode:e.code,currentVariableOrder:e.order}})()})]})}function Wr({variable:e,templateCodeLabel:r,templateNameLabel:a,bannerTitle:n,defaultLang:o}){return jsxRuntime.jsxs("div",{"data-testid":"variable-linked-banner",style:{padding:"10px 12px",backgroundColor:"#eff6ff",border:"1px solid #bfdbfe",borderRadius:"6px",fontSize:"12px",color:"#1e40af",display:"flex",flexDirection:"column",gap:"4px"},children:[jsxRuntime.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"6px",fontWeight:600},children:[jsxRuntime.jsx("span",{children:"\u{1F517}"}),jsxRuntime.jsx("span",{children:n})]}),jsxRuntime.jsxs("div",{style:{fontSize:"11px",color:"#1e3a8a"},children:[r," : ",jsxRuntime.jsx("span",{style:{fontFamily:"monospace"},children:e.code})]}),jsxRuntime.jsxs("div",{style:{fontSize:"11px",color:"#1e3a8a"},children:[a," : ",formCore.resolveLabel(e.name,o,o)]})]})}function qr({label:e,value:r,defaultLang:a,testId:n}){return jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("label",{style:{display:"block",fontSize:"12px",fontWeight:500,color:"#64748b",marginBottom:"4px"},children:e}),jsxRuntime.jsx("div",{"data-testid":n,style:{padding:"6px 8px",backgroundColor:"#f1f5f9",color:"#64748b",border:"1px solid #e2e8f0",borderRadius:"4px",fontSize:"13px",cursor:"not-allowed",userSelect:"text"},children:formCore.resolveLabel(r,a,a)})]})}function le({isOverridden:e,onReset:r,resetLabel:a,children:n,inline:o=false}){if(!e)return jsxRuntime.jsx(jsxRuntime.Fragment,{children:n});let t=jsxRuntime.jsxs("button",{type:"button","data-testid":"reset-override",onClick:r,style:{padding:"2px 8px",border:"1px solid #fde68a",borderRadius:"4px",backgroundColor:"#fffbeb",color:"#92400e",fontSize:"10px",cursor:"pointer",fontWeight:500},children:["\u21BA ",a]});return o?jsxRuntime.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"8px"},children:[jsxRuntime.jsx("div",{style:{flex:1},children:n}),t]}):jsxRuntime.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"4px"},children:[n,jsxRuntime.jsx("div",{style:{display:"flex",justifyContent:"flex-end"},children:t})]})}function Be({label:e,checked:r,onChange:a}){return jsxRuntime.jsxs("label",{style:{display:"flex",alignItems:"center",gap:"8px",fontSize:"13px",color:"#334155",cursor:"pointer"},children:[jsxRuntime.jsx("input",{type:"checkbox",checked:r,onChange:n=>a(n.target.checked)}),e]})}function et({roster:e,pageCode:r}){let{updateRoster:a}=R(),n=T(),o=Kr.useMemo(()=>[{value:"check",label:n.properties.rosterTypes.check},{value:"list",label:n.properties.rosterTypes.list},{value:"collection",label:n.properties.rosterTypes.collection},{value:"collection_extend",label:n.properties.rosterTypes.collection_extend}],[n]);return jsxRuntime.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"12px"},children:[jsxRuntime.jsx(J,{label:n.properties.name,value:e.name,onChange:t=>a(r,e.code,{name:t}),testIdPrefix:"roster-name"}),jsxRuntime.jsx(j,{label:n.properties.code,value:e.code,onChange:()=>{}}),jsxRuntime.jsxs("div",{children:[jsxRuntime.jsx("label",{style:{display:"block",fontSize:"12px",fontWeight:500,color:"#64748b",marginBottom:"4px"},children:n.properties.rosterType}),jsxRuntime.jsx("select",{value:e.rosterType,onChange:t=>a(r,e.code,{rosterType:t.target.value}),style:{width:"100%",padding:"6px 8px",border:"1px solid #e2e8f0",borderRadius:"4px",fontSize:"13px"},children:o.map(t=>jsxRuntime.jsx("option",{value:t.value,children:t.label},t.value))})]}),jsxRuntime.jsx(j,{label:n.properties.pilotVariableCode,value:e.pilotVariableCode??"",onChange:t=>a(r,e.code,{pilotVariableCode:t||void 0})}),jsxRuntime.jsx("div",{style:{fontSize:"12px",color:"#94a3b8"},children:n.properties.rosterSummary(e.variables.length,e.options?.length??0)})]})}function ao({availableConnectors:e=[]}){let{selection:r,form:a}=R(),n=T(),o=(()=>{switch(r.type){case "form":return jsxRuntime.jsx(he,{});case "page":{let t=a.pages.find(i=>i.code===r.pageCode);return t?jsxRuntime.jsx(Mo,{page:t}):jsxRuntime.jsx(he,{})}case "roster":{let t=a.pages.find(l=>l.code===r.pageCode),i=t?formCore.getPageRosters(t).find(l=>l.code===r.rosterCode):void 0;return !t||!i?jsxRuntime.jsx(he,{}):jsxRuntime.jsx(et,{roster:i,pageCode:t.code})}case "variable":{let t=a.pages.find(s=>s.code===r.pageCode);if(!t)return jsxRuntime.jsx(he,{});let i=r.rosterCode?formCore.getPageRosters(t).find(s=>s.code===r.rosterCode):void 0,d=(i?i.variables:formCore.getPageVariables(t)).find(s=>s.code===r.variableCode);return d?jsxRuntime.jsx(Xo,{variable:d,pageCode:t.code,rosterCode:r.rosterCode,availableConnectors:e}):jsxRuntime.jsx(he,{})}}})();return jsxRuntime.jsxs("div",{style:{width:"300px",borderLeft:"1px solid #e2e8f0",backgroundColor:"#fff",overflowY:"auto"},children:[jsxRuntime.jsx("div",{style:{padding:"12px 16px",borderBottom:"1px solid #e2e8f0",fontSize:"12px",fontWeight:600,color:"#64748b",textTransform:"uppercase",letterSpacing:"0.5px"},children:n.properties.title}),jsxRuntime.jsx("div",{style:{padding:"16px"},children:o})]})}function Jr({theme:e,dataSources:r,adapter:a,initialForm:n,formId:o,onChange:t,onSave:i,labels:l,PreviewComponent:d,ToolboxComponent:s,CanvasComponent:c,Wrapper:x}){let{form:y,view:p,setForm:f,setAdapter:g,load:u,setAvailableTemplates:b,setAvailableScopes:m,setAvailableDataSources:h}=R(),P=Kr.useMemo(()=>Fe(de,l),[l]);Kr.useEffect(()=>{a&&g(a);},[a,g]),Kr.useEffect(()=>{n?f(n):o&&a?.loadForm&&u(o);},[n,o]);let v=(y.scopeIds??[]).join("|");Kr.useEffect(()=>{let L=y.scopeIds??[];if(L.length===0||!a?.loadTemplates){b([]);return}let $=a.loadTemplates,D=false;return Promise.all(L.map(te=>$(te).catch(()=>[]))).then(te=>{if(D)return;let Re=new Set,Te=[];for(let Ne of te)for(let ue of Ne)Re.has(ue.code)||(Re.add(ue.code),Te.push(ue));b(Te);}).catch(()=>{D||b([]);}),()=>{D=true;}},[v,a,b]),Kr.useEffect(()=>{if(!a?.loadScopes){m([]);return}let L=false;return a.loadScopes().then($=>{L||m($);}).catch(()=>{L||m([]);}),()=>{L=true;}},[a,m]),Kr.useEffect(()=>{let L=y.scopeIds??[];if(L.length===0||!a?.loadDataSources){h([]);return}let $=a.loadDataSources,D=false;return Promise.all(L.map(te=>$(te).catch(()=>[]))).then(te=>{if(D)return;let Re=new Set,Te=[];for(let Ne of te)for(let ue of Ne)Re.has(ue.code)||(Re.add(ue.code),Te.push(ue));h(Te);}).catch(()=>{D||h([]);}),()=>{D=true;}},[v,a,h]);let A=Kr.useRef(t),S=Kr.useRef(true);A.current=t,Kr.useEffect(()=>{if(S.current){S.current=false;return}A.current?.(y);},[y]);let V=s??Ae,K=c??$e,Y=Kr.useRef(false);x&&!Y.current&&typeof console<"u"&&(Y.current=true,console.warn("[@msbci/form-editor] FormEditor.Wrapper is deprecated \u2014 drag & drop is now provided by the internal DndManager. The custom Wrapper will still be applied AROUND DndManager, but you should remove it."));let se=x??Kr__default.default.Fragment,C=jsxRuntime.jsxs("div",{style:{display:"flex",flexDirection:"column",height:"100%",fontFamily:"system-ui, -apple-system, sans-serif"},children:[jsxRuntime.jsx(Ue,{onSave:i}),jsxRuntime.jsxs("div",{style:{display:"flex",flex:1,overflow:"hidden"},children:[p==="canvas"&&jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsx(V,{}),jsxRuntime.jsx(K,{}),jsxRuntime.jsx(ao,{availableConnectors:r?Object.values(r):[]})]}),p==="preview"&&d&&jsxRuntime.jsx("div",{style:{flex:1,overflow:"auto"},children:jsxRuntime.jsx(d,{formSchema:y,theme:e,dataSources:r,mode:"fill"})}),p==="preview"&&!d&&jsxRuntime.jsx("div",{style:{flex:1,display:"flex",alignItems:"center",justifyContent:"center",color:"#94a3b8",fontSize:"14px"},children:P.formEditor.previewMissing}),p==="json"&&jsxRuntime.jsx("div",{style:{flex:1,overflow:"auto",padding:"16px"},children:jsxRuntime.jsx("pre",{style:{fontFamily:"monospace",fontSize:"12px",color:"#334155",backgroundColor:"#f8fafc",padding:"16px",borderRadius:"8px",border:"1px solid #e2e8f0",whiteSpace:"pre-wrap",wordBreak:"break-all"},children:JSON.stringify(y,null,2)})})]})]});return jsxRuntime.jsx(De,{labels:P,children:jsxRuntime.jsx(se,{children:jsxRuntime.jsx(Ke,{children:C})})})}function oa(){let e=T(),[r,a]=Kr.useState("fields"),[n,o]=Kr.useState(""),{form:t,selection:i,addVariable:l,addRoster:d,addVariableFromTemplate:s,availableTemplates:c}=R(),x=Kr.useMemo(()=>[{label:e.toolbox.groupText,items:[{kind:"variable",type:"text",label:e.toolbox.types.text,icon:"T"},{kind:"variable",type:"textarea",label:e.toolbox.types.textarea,icon:"\xB6"},{kind:"variable",type:"number",label:e.toolbox.types.number,icon:"#"},{kind:"variable",type:"email",label:e.toolbox.types.email,icon:"@"}]},{label:e.toolbox.groupSelection,items:[{kind:"variable",type:"select",label:e.toolbox.types.select,icon:"\u25BC"},{kind:"variable",type:"multiselect",label:e.toolbox.types.multiselect,icon:"\u2611"},{kind:"variable",type:"radio",label:e.toolbox.types.radio,icon:"\u25C9"},{kind:"variable",type:"checkbox",label:e.toolbox.types.checkbox,icon:"\u2610"}]},{label:e.toolbox.groupDateTime,items:[{kind:"variable",type:"date",label:e.toolbox.types.date,icon:"\u{1F4C5}"},{kind:"variable",type:"datetime",label:e.toolbox.types.datetime,icon:"\u{1F550}"},{kind:"variable",type:"time",label:e.toolbox.types.time,icon:"\u23F0"}]},{label:e.toolbox.groupMedia,items:[{kind:"variable",type:"file",label:e.toolbox.types.file,icon:"\u{1F4CE}"},{kind:"variable",type:"image",label:e.toolbox.types.image,icon:"\u{1F5BC}"},{kind:"variable",type:"gps",label:e.toolbox.types.gps,icon:"\u{1F4CD}"}]},{label:e.toolbox.groupAdvanced,items:[{kind:"variable",type:"rating",label:e.toolbox.types.rating,icon:"\u2605"},{kind:"variable",type:"calculated",label:e.toolbox.types.calculated,icon:"fx"},{kind:"variable",type:"hidden",label:e.toolbox.types.hidden,icon:"\u{1F441}"},{kind:"variable",type:"label",label:e.toolbox.types.label,icon:"Aa"}]},{label:e.toolbox.groupRoster,items:[{kind:"roster",rosterType:"check",label:e.toolbox.typeRosterCheck,icon:"\u25A4"},{kind:"roster",rosterType:"list",label:e.toolbox.typeRosterList,icon:"\u25A6"},{kind:"roster",rosterType:"collection",label:e.toolbox.typeRosterCollection,icon:"\u25A5"},{kind:"roster",rosterType:"collection_extend",label:e.toolbox.typeRosterCollectionExtend,icon:"\u25A9"}]}],[e]),y=i.type==="page"||i.type==="variable"||i.type==="roster"?i.pageCode:t.pages[0]?.code,p=u=>{if(!y||!t.pages.find(h=>h.code===y))return;if(u.kind==="roster"){let h=`ROSTER_${Date.now().toString(36).slice(-4).toUpperCase()}`;d(y,{id:`roster-${Date.now()}`,code:h,name:e.canvas.newRosterName,rosterType:u.rosterType,order:0,variables:[]});return}let m=`${u.type.toUpperCase()}_${Date.now().toString(36).slice(-4).toUpperCase()}`;l(y,{id:`var-${Date.now()}`,code:m,name:e.canvas.newVariableName(u.label),type:u.type,order:0,isRequired:false,isReadonly:false,isHidden:false});},f=u=>{y&&s(y,u);},g=x.map(u=>({...u,items:u.items.filter(b=>b.label.toLowerCase().includes(n.toLowerCase()))})).filter(u=>u.items.length>0);return jsxRuntime.jsxs("div",{style:{width:"220px",borderRight:"1px solid #e2e8f0",display:"flex",flexDirection:"column",backgroundColor:"#f8fafc",overflow:"hidden"},children:[jsxRuntime.jsx(ta,{tab:r,setTab:a,labels:e}),jsxRuntime.jsx("div",{style:{padding:"12px",borderBottom:"1px solid #e2e8f0"},children:jsxRuntime.jsx("input",{type:"text",placeholder:e.toolbox.searchPlaceholder,value:n,onChange:u=>o(u.target.value),style:{width:"100%",padding:"6px 10px",border:"1px solid #e2e8f0",borderRadius:"6px",fontSize:"13px",outline:"none",boxSizing:"border-box"}})}),jsxRuntime.jsxs("div",{style:{flex:1,overflowY:"auto",padding:"8px"},children:[!y&&jsxRuntime.jsx("div",{style:{padding:"12px",color:"#94a3b8",fontSize:"12px",textAlign:"center"},children:e.toolbox.addPageFirst}),r==="fields"&&g.map(u=>jsxRuntime.jsxs("div",{style:{marginBottom:"16px"},children:[jsxRuntime.jsx("div",{style:{fontSize:"11px",fontWeight:600,color:"#94a3b8",textTransform:"uppercase",letterSpacing:"0.5px",marginBottom:"6px",padding:"0 4px"},children:u.label}),u.items.map(b=>{let m=b.kind==="roster"?`roster-${b.rosterType}`:`var-${b.type}`,h=b.kind==="roster"?`toolbox-roster-${b.rosterType}`:`toolbox-variable-${b.type}`;return jsxRuntime.jsxs("div",{"data-testid":h,onClick:()=>p(b),style:{display:"flex",alignItems:"center",gap:"8px",padding:"6px 8px",marginBottom:"2px",borderRadius:"6px",cursor:"pointer",fontSize:"13px",color:"#334155",userSelect:"none"},onMouseEnter:P=>{P.currentTarget.style.backgroundColor="#e2e8f0";},onMouseLeave:P=>{P.currentTarget.style.backgroundColor="transparent";},children:[jsxRuntime.jsx("span",{style:{width:"20px",textAlign:"center",fontSize:"14px"},children:b.icon}),jsxRuntime.jsx("span",{children:b.label})]},m)})]},u.label)),r==="variables"&&jsxRuntime.jsx(ra,{templates:c,scopeIds:t.scopeIds,search:n,onAdd:f,defaultLang:t.langConfig?.defaultLang??formCore.DEFAULT_LANG_CONFIG.defaultLang,labels:e})]})]})}function ta({tab:e,setTab:r,labels:a}){let n={flex:1,padding:"8px 0",fontSize:"12px",fontWeight:500,textAlign:"center",cursor:"pointer",userSelect:"none",color:"#64748b",borderBottomWidth:"2px",borderBottomStyle:"solid",borderBottomColor:"transparent"},o={...n,color:"#2563eb",fontWeight:600,borderBottomColor:"#2563eb"};return jsxRuntime.jsxs("div",{style:{display:"flex",borderBottom:"1px solid #e2e8f0",backgroundColor:"#fff"},children:[jsxRuntime.jsx("div",{role:"tab","aria-selected":e==="fields","data-testid":"toolbox-tab-fields",onClick:()=>r("fields"),style:e==="fields"?o:n,children:a.toolbox.tabFields}),jsxRuntime.jsx("div",{role:"tab","aria-selected":e==="variables","data-testid":"toolbox-tab-variables",onClick:()=>r("variables"),style:e==="variables"?o:n,children:a.toolbox.tabVariables})]})}function ra({templates:e,scopeIds:r,search:a,onAdd:n,defaultLang:o,labels:t}){let i=s=>jsxRuntime.jsx("div",{"data-testid":"toolbox-variables-empty",style:{padding:"14px",color:"#94a3b8",fontSize:"12px",textAlign:"center",fontStyle:"italic"},children:s});if(!r||r.length===0)return i(t.toolbox.noScope);if(e.length===0)return i(t.toolbox.noTemplates);let l=a.toLowerCase(),d=e.filter(s=>{if(!l)return true;let c=s.code.toLowerCase().includes(l),x=rt(s.name,o).toLowerCase().includes(l);return c||x}).slice().sort((s,c)=>s.code.localeCompare(c.code));return d.length===0?i(t.toolbox.noTemplates):jsxRuntime.jsx("div",{style:{display:"flex",flexDirection:"column",gap:"4px"},children:d.map(s=>jsxRuntime.jsxs("div",{"data-testid":`toolbox-template-${s.code}`,onClick:()=>n(s),style:{display:"flex",alignItems:"center",gap:"8px",padding:"6px 8px",borderRadius:"6px",cursor:"pointer",fontSize:"13px",color:"#334155",userSelect:"none"},onMouseEnter:c=>{c.currentTarget.style.backgroundColor="#e2e8f0";},onMouseLeave:c=>{c.currentTarget.style.backgroundColor="transparent";},children:[jsxRuntime.jsx("span",{style:{fontSize:"10px",fontWeight:600,padding:"2px 6px",borderRadius:"4px",backgroundColor:"#e0e7ff",color:"#3730a3",textTransform:"uppercase",letterSpacing:"0.3px",minWidth:"42px",textAlign:"center"},children:s.variableType}),jsxRuntime.jsxs("div",{style:{display:"flex",flexDirection:"column",minWidth:0,flex:1},children:[jsxRuntime.jsx("span",{style:{fontFamily:"monospace",fontSize:"11px",color:"#475569",whiteSpace:"nowrap",overflow:"hidden",textOverflow:"ellipsis"},children:s.code}),jsxRuntime.jsx("span",{style:{fontSize:"12px",color:"#1e293b",whiteSpace:"nowrap",overflow:"hidden",textOverflow:"ellipsis"},children:rt(s.name,o)})]})]},s.id))})}function rt(e,r){return formCore.resolveLabel(e,r,r)}function so(){let r=R(a=>a.form).langConfig?.defaultLang??formCore.DEFAULT_LANG_CONFIG.defaultLang;return a=>formCore.resolveLabel(a,r,r)}function sa(e){let r=e.slice().sort((o,t)=>o.order-t.order),a=[],n=null;for(let o of r){if(formCore.isPageRoster(o)){n&&(a.push({kind:"variables",variables:n}),n=null),a.push({kind:"roster",roster:o});continue}let t=o;t.startWithNewLine===false&&n&&n.length>0?n.push(t):(n&&a.push({kind:"variables",variables:n}),n=[t]);}return n&&a.push({kind:"variables",variables:n}),a}function da(){let{form:e,select:r}=R(),a=T(),n=o=>{o.target===o.currentTarget&&r({type:"form"});};return e.pages.length===0?jsxRuntime.jsx("div",{"data-testid":"canvas-empty",onClick:n,style:{flex:1,display:"flex",alignItems:"center",justifyContent:"center",color:"#94a3b8",fontSize:"14px",cursor:"pointer"},children:a.canvas.emptyStateNoPage}):jsxRuntime.jsx("div",{"data-testid":"canvas-root",onClick:n,style:{flex:1,overflowY:"auto",padding:"16px",backgroundColor:"#fff"},children:e.pages.slice().sort((o,t)=>o.order-t.order).map(o=>jsxRuntime.jsx(pa,{page:o},o.code))})}function pa({page:e}){let{selection:r,select:a,removePage:n}=R(),o=T(),t=so(),i=r.type==="page"&&r.pageCode===e.code,l=e.items??[...formCore.getPageVariables(e),...e.rosters??[]],d=l.filter(formCore.isPageVariable).length,s=l.filter(formCore.isPageRoster).length,c=sa(l);return jsxRuntime.jsxs("div",{style:{marginBottom:"16px",border:`2px solid ${i?"#2563eb":"#e2e8f0"}`,borderRadius:"8px",overflow:"hidden"},children:[jsxRuntime.jsxs("div",{onClick:()=>a({type:"page",pageCode:e.code}),style:{padding:"10px 14px",backgroundColor:i?"#eff6ff":"#f8fafc",borderBottom:"1px solid #e2e8f0",cursor:"pointer",display:"flex",alignItems:"center",justifyContent:"space-between"},children:[jsxRuntime.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"8px"},children:[jsxRuntime.jsx("span",{style:{fontSize:"14px",fontWeight:600,color:"#1e293b"},children:t(e.name)||o.canvas.unnamedPage}),e.isRepeatable&&jsxRuntime.jsx("span",{style:{fontSize:"10px",padding:"1px 6px",borderRadius:"4px",backgroundColor:"#dbeafe",color:"#2563eb",fontWeight:500},children:o.canvas.repeatable})]}),jsxRuntime.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"8px"},children:[jsxRuntime.jsx("span",{style:{fontSize:"12px",color:"#94a3b8"},children:o.canvas.fieldsRostersCount(d,s)}),jsxRuntime.jsx("button",{onClick:x=>{x.stopPropagation(),n(e.code);},style:{border:"none",background:"none",color:"#ef4444",cursor:"pointer",fontSize:"14px",padding:"2px 4px"},children:"\xD7"})]})]}),jsxRuntime.jsxs("div",{style:{padding:"4px 0"},children:[c.map((x,y)=>x.kind==="roster"?jsxRuntime.jsx(ca,{roster:x.roster,pageCode:e.code},`r-${x.roster.code}`):x.variables.length===1?jsxRuntime.jsx(lo,{variable:x.variables[0],pageCode:e.code},x.variables[0].code):jsxRuntime.jsx("div",{style:{display:"flex",gap:"2px",backgroundColor:"#f0f4ff",borderLeft:"2px solid #c7d2fe",margin:"1px 0"},children:x.variables.map(p=>jsxRuntime.jsx("div",{style:{flex:p.colSpan?`0 0 ${p.colSpan/12*100}%`:"1 1 0%",minWidth:0},children:jsxRuntime.jsx(lo,{variable:p,pageCode:e.code})},p.code))},`row-${y}`)),l.length===0&&jsxRuntime.jsx("div",{style:{padding:"12px 14px",color:"#94a3b8",fontSize:"12px",fontStyle:"italic"},children:o.canvas.emptyStatePage})]})]})}function lo({variable:e,pageCode:r,rosterCode:a}){let{selection:n,select:o,removeVariable:t}=R(),i=T(),l=so(),d=n.type==="variable"&&n.variableCode===e.code;return jsxRuntime.jsxs("div",{onClick:s=>{s.stopPropagation(),o({type:"variable",pageCode:r,variableCode:e.code,rosterCode:a});},style:{display:"flex",alignItems:"center",gap:"8px",padding:"6px 14px",cursor:"pointer",backgroundColor:d?"#eff6ff":"transparent",borderLeft:d?"3px solid #2563eb":"3px solid transparent",fontSize:"13px"},children:[jsxRuntime.jsx("span",{style:{color:"#94a3b8",fontSize:"11px",width:"60px",flexShrink:0},children:e.type}),jsxRuntime.jsx("span",{style:{color:"#334155",flex:1},children:l(e.name)||e.code}),e.isRequired&&jsxRuntime.jsx("span",{style:{color:"#ef4444",fontSize:"11px"},children:"*"}),e.conditions&&e.conditions.length>0&&jsxRuntime.jsx("span",{style:{color:"#f59e0b",fontSize:"11px"},title:i.canvas.hasConditionsTitle,children:"\u26A1"}),e.dataSourceId&&jsxRuntime.jsx("span",{style:{color:"#22c55e",fontSize:"11px"},title:i.canvas.dataSourceConnectedTitle,children:"\u27F3"}),jsxRuntime.jsx("button",{onClick:s=>{s.stopPropagation(),t(r,e.code,a);},style:{border:"none",background:"none",color:"#ef4444",cursor:"pointer",fontSize:"12px",padding:"0 2px",opacity:.5},children:"\xD7"})]})}function ca({roster:e,pageCode:r}){let{selection:a,select:n,removeRoster:o,addVariable:t}=R(),i=T(),l=so(),d=a.type==="roster"&&a.rosterCode===e.code,s=c=>{c.stopPropagation();let x=`RV_${Date.now().toString(36).slice(-4).toUpperCase()}`;t(r,{id:`var-${Date.now()}`,code:x,name:i.canvas.newFieldName,type:"text",order:e.variables.length,isRequired:false,isReadonly:false,isHidden:false},e.code);};return jsxRuntime.jsxs("div",{style:{margin:"4px 8px",border:`1px solid ${d?"#2563eb":"#e2e8f0"}`,borderRadius:"6px",overflow:"hidden"},children:[jsxRuntime.jsxs("div",{onClick:c=>{c.stopPropagation(),n({type:"roster",pageCode:r,rosterCode:e.code});},style:{padding:"6px 10px",backgroundColor:d?"#fef3c7":"#fffbeb",fontSize:"12px",fontWeight:600,color:"#92400e",cursor:"pointer",display:"flex",alignItems:"center",justifyContent:"space-between"},children:[jsxRuntime.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"6px"},children:[jsxRuntime.jsxs("span",{children:["\u25A4 ",l(e.name)||e.code]}),jsxRuntime.jsx("span",{style:{fontSize:"10px",padding:"1px 4px",borderRadius:"3px",backgroundColor:"#fde68a",color:"#78350f"},children:e.rosterType}),e.pilotVariableCode&&jsxRuntime.jsxs("span",{style:{fontSize:"10px",color:"#92400e",fontWeight:400},children:[i.canvas.pilotPrefix," ",e.pilotVariableCode]})]}),jsxRuntime.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"4px"},children:[jsxRuntime.jsx("span",{style:{fontSize:"11px",color:"#b45309"},children:i.canvas.rosterVarsCount(e.variables.length)}),jsxRuntime.jsx("button",{onClick:c=>{c.stopPropagation(),o(r,e.code);},style:{border:"none",background:"none",color:"#ef4444",cursor:"pointer",fontSize:"12px"},children:"\xD7"})]})]}),e.variables.slice().sort((c,x)=>c.order-x.order).map(c=>jsxRuntime.jsx(lo,{variable:c,pageCode:r,rosterCode:e.code},c.code)),jsxRuntime.jsx("div",{style:{padding:"4px 10px",borderTop:"1px solid #fde68a"},children:jsxRuntime.jsx("button",{onClick:s,style:{padding:"2px 8px",borderRadius:"3px",border:"1px dashed #d4a843",backgroundColor:"transparent",color:"#92400e",fontSize:"10px",cursor:"pointer"},children:i.canvas.addFieldToRoster})})]})}exports.Canvas=$e;exports.CanvasDnd=$e;exports.CanvasSimple=da;exports.ConditionBuilder=Ze;exports.DataSourceConfigManager=We;exports.DataSourceSelector=eo;exports.DndManager=Ke;exports.EditorLabelsProvider=De;exports.EditorToolbar=Ue;exports.FormEditor=Jr;exports.PropertiesPanel=ao;exports.Toolbox=Ae;exports.ToolboxDnd=Ae;exports.ToolboxSimple=oa;exports.createDragEndHandler=Fo;exports.defaultLabels=de;exports.enLabels=fo;exports.frLabels=de;exports.mergeLabels=Fe;exports.useEditorStore=R;exports.useLabels=T;//# sourceMappingURL=index.cjs.map
|
|
2
2
|
//# sourceMappingURL=index.cjs.map
|