@notmrabhi/flowforge 0.1.52 → 0.1.53

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/core.d.ts CHANGED
@@ -17,6 +17,18 @@ export declare interface ApiWorkflowTemplate {
17
17
  templateUI?: Partial<Omit<WorkflowTemplate, 'triggerKey' | 'label' | 'description' | 'availableTasks'>>;
18
18
  }
19
19
 
20
+ export declare interface ApplicationTaskLike {
21
+ name?: string;
22
+ taskKey?: string;
23
+ applicationUuid?: string;
24
+ configuration?: unknown[];
25
+ ui?: {
26
+ bpmnEmit?: BpmnEmitSpec;
27
+ [key: string]: unknown;
28
+ };
29
+ [key: string]: unknown;
30
+ }
31
+
20
32
  /**
21
33
  * Base defaults shared by every node descriptor. A new node only has to specify
22
34
  * what makes it different — these fill in the rest.
@@ -33,6 +45,16 @@ export declare interface BpmnElement {
33
45
  [key: string]: unknown;
34
46
  }
35
47
 
48
+ export declare interface BpmnEmitSpec {
49
+ kind: 'linear' | 'gated' | 'filter' | 'approval';
50
+ serviceTasks?: ServiceTaskSpec[];
51
+ gateway?: GatewaySpec;
52
+ templateFlows?: TemplateFlowSpec[];
53
+ outgoingConditions?: Record<string, string>;
54
+ dmnEmit?: DmnEmitSpec;
55
+ callActivity?: Record<string, unknown>;
56
+ }
57
+
36
58
  export declare interface BpmnSaveOptions {
37
59
  processId?: string;
38
60
  processName?: string;
@@ -46,6 +68,62 @@ export declare interface BranchMap {
46
68
  };
47
69
  }
48
70
 
71
+ /**
72
+ * Generate a backend-ready payload from canvas state + task definitions.
73
+ *
74
+ * @example
75
+ * const payload = buildBackendPayload({
76
+ * state: { slots, branches },
77
+ * tasksByKey: { USER_CREATION: {...}, USER_GROUP_ASSIGNMENT: {...} },
78
+ * context: { customerKey: '51995', workflowName: 'My WF' },
79
+ * config: { triggerToCategory: { CUSTOM_TRIGGER: 'CUSTOM_CATEGORY' } },
80
+ * });
81
+ * await api.post('/process', payload);
82
+ */
83
+ export declare function buildBackendPayload(opts: BuildPayloadOptions): Record<string, unknown>;
84
+
85
+ export declare interface BuildPayloadConfig {
86
+ /**
87
+ * Map of trigger eventType → workflowCategory string. Defaults to a small
88
+ * IAM-shaped fallback; consumers should pass the full map they use.
89
+ */
90
+ triggerToCategory?: Record<string, string>;
91
+ /** eventType values that should set `sources: ['SCHEDULER']` and skip the message block. */
92
+ schedulerEventTypes?: string[];
93
+ /** DMN LHS prefix for condition expressions (default IAM-style). */
94
+ conditionPathPrefix?: string;
95
+ /** Fallback workflowCategory when eventType isn't mapped. */
96
+ defaultWorkflowCategory?: string;
97
+ /** End-event ids — override per backend convention. */
98
+ endEventIds?: {
99
+ success: string;
100
+ failure: string;
101
+ rejected: string;
102
+ };
103
+ /** Names rendered on end events. */
104
+ endEventNames?: {
105
+ success: string;
106
+ failure: string;
107
+ rejected: string;
108
+ };
109
+ /** Start event id used in the outer chain. */
110
+ startEventId?: string;
111
+ }
112
+
113
+ export declare interface BuildPayloadContext {
114
+ customerKey: string;
115
+ workflowName: string;
116
+ /** Anything else the host wants exposed via `from: 'ctx', key: '...'`. */
117
+ [key: string]: unknown;
118
+ }
119
+
120
+ export declare interface BuildPayloadOptions {
121
+ state: CanvasState_2;
122
+ tasksByKey: Record<string, ApplicationTaskLike>;
123
+ context: BuildPayloadContext;
124
+ config?: BuildPayloadConfig;
125
+ }
126
+
49
127
  export declare interface CanvasSlot {
50
128
  id: string;
51
129
  kind: SlotKind;
@@ -59,6 +137,38 @@ export declare interface CanvasSlot {
59
137
  branchLabels?: Record<string, string>;
60
138
  }
61
139
 
140
+ /**
141
+ * buildBackendPayload — generic BPMN/DMN/canvasState emitter driven by each
142
+ * task's `ui.bpmnEmit` block. Consumer ships per-task bpmnEmit specs from
143
+ * the backend; the package handles the walk.
144
+ *
145
+ * Originally lived in IAM as `flowforgeStateToBackendJson`. Moved into the
146
+ * package so every consumer gets the same emitter — and so DMN/filter/
147
+ * approval fixes ship once, to everyone.
148
+ *
149
+ * Consumer injects:
150
+ * - canvasState — `{ slots, branches }` from the canvas
151
+ * - tasksByKey — `{ [descriptorType]: ApplicationTask }` lookup
152
+ * - context — host-specific scalars (customerKey, workflowName)
153
+ * - config — IAM-shaped defaults (path prefix, end-event ids,
154
+ * trigger→category map, scheduler events)
155
+ *
156
+ * Returns a JSON object ready to POST to the backend.
157
+ */
158
+ declare type CanvasSlot_2 = {
159
+ id: string;
160
+ kind?: string;
161
+ descriptorType?: string;
162
+ nodeData?: Record<string, unknown>;
163
+ formData?: Record<string, unknown>;
164
+ [key: string]: unknown;
165
+ };
166
+
167
+ declare type CanvasState_2 = {
168
+ slots?: CanvasSlot_2[];
169
+ branches?: Record<string, unknown>;
170
+ };
171
+
62
172
  export declare const conditionBranchDescriptor: NodeDescriptor;
63
173
 
64
174
  /** One column in a per-field condition row */
@@ -114,6 +224,22 @@ export declare interface DmnDefinition {
114
224
  [key: string]: unknown;
115
225
  }
116
226
 
227
+ export declare interface DmnEmitSpec {
228
+ tableName: string;
229
+ inputExpr: string;
230
+ hitPolicy?: string;
231
+ outputs?: DmnOutputSpec[];
232
+ operatorMap?: Record<string, string>;
233
+ valuesField?: string;
234
+ }
235
+
236
+ export declare interface DmnOutputSpec {
237
+ id: string;
238
+ label?: string;
239
+ name: string;
240
+ typeRef?: string;
241
+ }
242
+
117
243
  /**
118
244
  * End event — a fixed skeleton node with no user-editable form.
119
245
  * The canvas seeds the main-spine end as the literal slot id `'end'`, and one
@@ -125,6 +251,18 @@ export declare interface DmnDefinition {
125
251
  */
126
252
  export declare const endEventDescriptor: NodeDescriptor;
127
253
 
254
+ export declare interface ExtensionFieldSpec {
255
+ name: string;
256
+ source?: {
257
+ type: 'literal' | 'json' | 'taskConfig' | 'formData';
258
+ value?: unknown;
259
+ shape?: Record<string, FieldRef>;
260
+ passthrough?: boolean;
261
+ exclude?: string[];
262
+ key?: string;
263
+ };
264
+ }
265
+
128
266
  /** Condition definition attached to a FieldDescriptor */
129
267
  declare interface FieldConditionDef {
130
268
  fields: ConditionFieldDef[];
@@ -205,6 +343,12 @@ declare interface FieldDescriptor {
205
343
  [key: string]: unknown;
206
344
  }
207
345
 
346
+ export declare interface FieldRef {
347
+ from: 'literal' | 'task' | 'ctx' | 'slot' | 'formData';
348
+ key?: string;
349
+ value?: unknown;
350
+ }
351
+
208
352
  declare interface FieldTransform {
209
353
  in?: (value: unknown) => unknown;
210
354
  out?: (value: unknown) => unknown;
@@ -241,6 +385,11 @@ export declare interface FlowForgeMessages {
241
385
  cancel: string;
242
386
  }
243
387
 
388
+ export declare interface GatewaySpec {
389
+ idTemplate: string;
390
+ name?: string;
391
+ }
392
+
244
393
  /**
245
394
  * Context passed to `NodeDescriptor.canInsert(ctx)` describing where on the
246
395
  * canvas the user clicked "+ Add step". Used by position-aware insertion rules.
@@ -369,6 +518,13 @@ export declare const restApiDescriptor: NodeDescriptor;
369
518
 
370
519
  export declare function saveWorkflowToBpmn(workflow: WorkflowState, options?: BpmnSaveOptions): string;
371
520
 
521
+ export declare interface ServiceTaskSpec {
522
+ idTemplate: string;
523
+ name?: string;
524
+ flowableClass?: string;
525
+ extensionFields?: ExtensionFieldSpec[];
526
+ }
527
+
372
528
  declare type SlotKind = 'start' | 'end' | 'addTrigger' | 'triggerFixed' | 'userTask' | 'addStep' | 'filter' | 'approval';
373
529
 
374
530
  /**
@@ -403,6 +559,13 @@ export declare interface SubWorkflowDescriptorOptions {
403
559
  }>>;
404
560
  }
405
561
 
562
+ export declare interface TemplateFlowSpec {
563
+ from: string;
564
+ to: string;
565
+ idTemplate?: string;
566
+ condition?: string | null;
567
+ }
568
+
406
569
  export declare class TemplateRegistry {
407
570
  private templates;
408
571
  /**
package/dist/core.js CHANGED
@@ -1,25 +1,27 @@
1
- import { NodeTypeRegistry as r, baseNodeDefaults as t, conditionBranchDescriptor as s, defineNode as i, endEventDescriptor as p, makeSubWorkflowDescriptor as a, nodeTypeRegistry as f, notificationDescriptor as l, restApiDescriptor as n, startEventDescriptor as c, subWorkflowDescriptor as m, webhookTriggerDescriptor as d, webhookTriggerTemplate as g } from "./nodeRegistry.js";
2
- import { TemplateRegistry as k, templateRegistry as w } from "./templateRegistry.js";
1
+ import { NodeTypeRegistry as r, baseNodeDefaults as t, conditionBranchDescriptor as s, defineNode as i, endEventDescriptor as p, makeSubWorkflowDescriptor as a, nodeTypeRegistry as l, notificationDescriptor as d, restApiDescriptor as f, startEventDescriptor as n, subWorkflowDescriptor as c, webhookTriggerDescriptor as m, webhookTriggerTemplate as g } from "./nodeRegistry.js";
2
+ import { TemplateRegistry as k, templateRegistry as b } from "./templateRegistry.js";
3
3
  import { d as y } from "./messages-CO299wPN.js";
4
4
  import { l as u, s as x } from "./bpmn-CtfWDaOY.js";
5
+ import { b as R } from "./buildBackendPayload-4SwOp7St.js";
5
6
  export {
6
7
  r as NodeTypeRegistry,
7
8
  k as TemplateRegistry,
8
9
  t as baseNodeDefaults,
10
+ R as buildBackendPayload,
9
11
  s as conditionBranchDescriptor,
10
12
  y as defaultFlowForgeMessages,
11
13
  i as defineNode,
12
14
  p as endEventDescriptor,
13
15
  u as loadWorkflowFromBpmn,
14
16
  a as makeSubWorkflowDescriptor,
15
- f as nodeTypeRegistry,
16
- l as notificationDescriptor,
17
- n as restApiDescriptor,
17
+ l as nodeTypeRegistry,
18
+ d as notificationDescriptor,
19
+ f as restApiDescriptor,
18
20
  x as saveWorkflowToBpmn,
19
- c as startEventDescriptor,
20
- m as subWorkflowDescriptor,
21
- w as templateRegistry,
22
- d as webhookTriggerDescriptor,
21
+ n as startEventDescriptor,
22
+ c as subWorkflowDescriptor,
23
+ b as templateRegistry,
24
+ m as webhookTriggerDescriptor,
23
25
  g as webhookTriggerTemplate
24
26
  };
25
27
  //# sourceMappingURL=core.js.map
package/dist/core.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"core.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;"}
1
+ {"version":3,"file":"core.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;"}
package/dist/index.cjs CHANGED
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const l=require("./index-DUbQPmIx.js"),x=require("./SchemaBuilderDrawer-CIxQGffa.js");require("react/jsx-runtime");require("react");require("@mui/material");require("react-icons/md");const v=require("./nodeRegistry.cjs"),L=require("./templateRegistry.cjs"),S=require("./templateSkeletons-gOva2Xus.js"),z=require("./messages-O9Tw_XXR.js"),B=require("./bpmn-CcuE2X_Q.js"),F=require("./GatewayBranchEdge-CMY30xhz.js");class H{constructor(){this.channels=new Map}register(t,n){this.channels.set(t,n)}get(t){return this.channels.get(t)}list(){return Array.from(this.channels.entries()).map(([t,n])=>({key:t,...n}))}has(t){return this.channels.has(t)}}const G=new H;function Y(e){const{currentNodeId:t,nodes:n,getParents:s,getOutputSchema:i,nodePath:r,nodeLabel:p,getNodeId:a=y=>y.id}=e,u=n.find(y=>a(y)===t);if(!u)return[];const m=J(u,n,s,a),T=[];for(const y of m){const b=i(y);if(!b||b.length===0)continue;const N=r(y);T.push({label:p?p(y):N,items:b.map(o=>q(o,N))})}return T}function J(e,t,n,s){const i=new Set,r=[],p=[...n(e,t)];for(;p.length>0;){const a=p.shift(),u=s(a);i.has(u)||(i.add(u),r.push(a),p.push(...n(a,t)))}return r}function q(e,t){const n=`${t}.${e.key}`,s=e.description??(e.sample!==void 0&&e.sample!==null?String(e.sample):void 0),i={label:e.label,path:n};return s!==void 0&&(i.description=s),e.children&&e.children.length>0&&(i.children=e.children.map(r=>q(r,n))),i}const O={triggerToCategory:{END_USER_CREATION:"END_USER_CREATION",END_USER_UPDATION:"END_USER_UPDATION",DELETE_DORMANT_ACCOUNT:"DELETE_DORMANT_ACCOUNT",NOTIFY_EXPIRED_PASSWORD:"NOTIFY_EXPIRED_PASSWORD"},schedulerEventTypes:["DELETE_DORMANT_ACCOUNT","NOTIFY_EXPIRED_PASSWORD"],conditionPathPrefix:"startEvent.endUser",defaultWorkflowCategory:"END_USER_CREATION",endEventIds:{success:"endEventSuccess",failure:"endEventFailure",rejected:"endEventRejected"},endEventNames:{success:"Task Completed successfully",failure:"User Not Created",rejected:"Approval Rejected"},startEventId:"startEvent"},K=new Set(["start","end","triggerFixed","addTrigger","addStep"]),X=e=>!!e&&!K.has(String(e.kind??""));function C(e,t){return e==null?"":String(e).replace(/\$\{(\w+)\}/g,(n,s)=>Object.prototype.hasOwnProperty.call(t,s)?String(t[s]):n)}function Q(e,t){var r,p,a,u,m;if(!e||typeof e!="object")return"";const{from:n,key:s,value:i}=e;return n==="literal"?i===void 0?"":String(i):n==="task"?String(((r=t.task)==null?void 0:r[s??""])??""):n==="ctx"?String(((p=t.ctx)==null?void 0:p[s??""])??""):n==="slot"?String(((a=t.slot)==null?void 0:a[s??""])??""):n==="formData"?String(((m=(u=t.slot)==null?void 0:u.formData)==null?void 0:m[s??""])??""):""}function Z(e,t){var s,i,r;const n=e==null?void 0:e.source;if(!n)return"";if(n.type==="literal")return typeof n.value=="string"?n.value:JSON.stringify(n.value??"");if(n.type==="json"||n.type==="taskConfig"){const p=n.shape||{},a={};return Object.keys(p).forEach(u=>{a[u]=Q(p[u],t)}),JSON.stringify(a)}if(n.type==="formData"){if(n.passthrough){const p=new Set(n.exclude||[]),a={},u=((s=t.slot)==null?void 0:s.formData)??{};return Object.keys(u).forEach(m=>{p.has(m)||(a[m]=u[m])}),JSON.stringify(a)}return String(((r=(i=t.slot)==null?void 0:i.formData)==null?void 0:r[n.key??""])??"")}return""}function ee(e,t){if(!(!e||typeof e!="object"||!t))return t.split(".").reduce((n,s)=>{if(!(n==null||typeof n!="object"))return n[s]},e)}function te(e,t,n){var N;const s=e.operatorMap||{},i=e.valuesField||"groups",r=o=>{const f=s[String((o==null?void 0:o.operator)??"")]??"==",d=`${n}.${(o==null?void 0:o.key)??(o==null?void 0:o.field)??""}`,E=`'${String((o==null?void 0:o.value)??"")}'`;return f.startsWith(".")?`${d}${f}(${E})`:f.startsWith("!.")?`!${d}${f.slice(1)}(${E})`:`${d} ${f} ${E}`},p=o=>{var w,g;const f=Array.isArray(o)?o:[];if(f.length===0)return null;const d=f.map(r),h=((w=f[0])==null?void 0:w.connector)==="or"||((g=f[0])==null?void 0:g.logicalOperator)==="OR"?"||":"&&";return d.join(` ${h} `)},a=[];let u=1;const m=(o,f)=>{a.push({id:`rule${u}`,inputEntries:[{id:`rule${u}InputEntry1`,text:o?`\${(${o})}`:""}],outputEntries:[{id:`rule${u}OutputEntry1`,text:`"${f}"`}]}),u+=1},T=Array.isArray((N=t==null?void 0:t.formData)==null?void 0:N.groupBlocks)?t.formData.groupBlocks:[];if(T.length>0)return T.forEach(o=>{const f=Array.isArray(o==null?void 0:o[i])?o[i]:[],d=p(o==null?void 0:o.conditions);f.forEach(E=>m(d,E))}),a;const y=(t==null?void 0:t.formData)??{},b=y._conditionConfig??y.conditionConfig;return b&&typeof b=="object"&&Object.keys(b).forEach(o=>{const f=b[o],d=p(f),E=Object.prototype.hasOwnProperty.call(y,o)?y[o]:ee(y,o);Array.isArray(E)?E.forEach(h=>{const w=typeof h=="object"&&h!==null?h.value??h.label??h:h;m(d,w)}):E!=null&&E!==""?m(d,E):d&&m(d,"")}),a}function ne(e,t,n){return{mappings:[],name:e.tableName,decision:{id:e.tableName,name:e.tableName,decisionTable:{id:`decisionTable_${e.tableName}`,hitPolicy:e.hitPolicy||"FIRST",inputs:[{id:`input_${e.tableName}`,inputExpression:{id:`inputExpr_${e.tableName}`,typeRef:"string",text:e.inputExpr}}],outputs:(e.outputs||[]).map(s=>({id:s.id,label:s.label,typeRef:s.typeRef||"string",name:s.name})),rules:te(e,t,n)}}}}function re(e,t,n,s){var E,h,w;const i=(E=t==null?void 0:t.ui)==null?void 0:E.bpmnEmit;if(!i)return{serviceTasks:[{id:e.id,name:(t==null?void 0:t.name)||e.descriptorType,configuration:Array.isArray(t==null?void 0:t.configuration)?t.configuration:[],input:e.formData||{}}],gateways:[],callActivities:[],templateFlows:[],dmn:null,bpmnEntry:e.id,bpmnExit:e.id,outgoingConditions:{},endsNeeded:new Set};const r={id:e.id,endFailure:s.endEventIds.failure,endRejected:s.endEventIds.rejected,endSuccess:s.endEventIds.success},p={task:t,slot:e,ctx:n},a=(i.serviceTasks||[]).map(g=>({id:C(g.idTemplate,r),name:g.name,flowableClass:g.flowableClass,extensionElements:{fields:(g.extensionFields||[]).map(R=>({name:R.name,stringValue:Z(R,p)}))}}));let u=null;const m=[];i.gateway&&(u=C(i.gateway.idTemplate,r),r.gateway=u,m.push({id:u,name:i.gateway.name}));const T=new Set,y=(i.templateFlows||[]).map(g=>{const R=C(g.from,r),D=C(g.to,r);return D===s.endEventIds.failure&&T.add(s.endEventIds.failure),D===s.endEventIds.rejected&&T.add(s.endEventIds.rejected),{id:g.idTemplate?C(g.idTemplate,r):`${R}-to-${D}`,sourceRef:R,targetRef:D,conditionExpression:g.condition?C(g.condition,r):null}}),b=[],N=i.dmnEmit?ne(i.dmnEmit,e,s.conditionPathPrefix):null,o=((h=a[0])==null?void 0:h.id)??e.id,f=u??((w=a[a.length-1])==null?void 0:w.id)??e.id,d={};return Object.keys(i.outgoingConditions||{}).forEach(g=>{d[g]=C(i.outgoingConditions[g],r)}),{serviceTasks:a,gateways:m,callActivities:b,templateFlows:y,dmn:N,bpmnEntry:o,bpmnExit:f,outgoingConditions:d,endsNeeded:T}}function oe(e){var P,$,_,j;const{state:t,tasksByKey:n,context:s,config:i}=e,r={...O,...i??{},triggerToCategory:{...O.triggerToCategory,...(i==null?void 0:i.triggerToCategory)??{}},schedulerEventTypes:(i==null?void 0:i.schedulerEventTypes)??O.schedulerEventTypes,endEventIds:{...O.endEventIds,...(i==null?void 0:i.endEventIds)??{}},endEventNames:{...O.endEventNames,...(i==null?void 0:i.endEventNames)??{}}},p=Array.isArray(t==null?void 0:t.slots)?t.slots:[],a=p.find(c=>c.kind==="triggerFixed"),u=(P=a==null?void 0:a.nodeData)==null?void 0:P.eventType,m=(($=a==null?void 0:a.nodeData)==null?void 0:$.type)||"event",T=(_=a==null?void 0:a.nodeData)==null?void 0:_.sources,y=Array.isArray(T)?T.map(c=>typeof c=="string"?c:(c==null?void 0:c.value)??(c==null?void 0:c.key)??"").filter(Boolean):[],b=r.triggerToCategory[u??""]??r.defaultWorkflowCategory,o=!!u&&r.schedulerEventTypes.includes(u)?["SCHEDULER"]:y,d=p.filter(X).map(c=>({slot:c,emit:re(c,n[c.descriptorType??""]??{},s,r)})),E=[],h=[],w=[],g=[],R=[],D=new Set;d.forEach(({emit:c})=>{E.push(...c.serviceTasks),h.push(...c.gateways),w.push(...c.callActivities),g.push(...c.templateFlows),c.dmn&&R.push(c.dmn),c.endsNeeded.forEach(k=>D.add(k))});const I=[];if(d.length>0){I.push({id:`${r.startEventId}-to-${d[0].emit.bpmnEntry}`,sourceRef:r.startEventId,targetRef:d[0].emit.bpmnEntry,conditionExpression:null});for(let k=0;k<d.length-1;k+=1){const A=d[k].emit,W=d[k+1].emit,M=A.outgoingConditions.success??A.outgoingConditions.pass??A.outgoingConditions.approved??null;I.push({id:`${A.bpmnExit}-to-${W.bpmnEntry}`,sourceRef:A.bpmnExit,targetRef:W.bpmnEntry,conditionExpression:M})}const c=d[d.length-1].emit;I.push({id:`${c.bpmnExit}-to-${r.endEventIds.success}`,sourceRef:c.bpmnExit,targetRef:r.endEventIds.success,conditionExpression:null})}else I.push({id:`${r.startEventId}-to-${r.endEventIds.success}`,sourceRef:r.startEventId,targetRef:r.endEventIds.success,conditionExpression:null});const V=[{id:r.endEventIds.success,name:r.endEventNames.success,executionListener:null},...D.has(r.endEventIds.failure)?[{id:r.endEventIds.failure,name:r.endEventNames.failure}]:[],...D.has(r.endEventIds.rejected)?[{id:r.endEventIds.rejected,name:r.endEventNames.rejected}]:[]],U={id:r.startEventId,name:"Start",...m==="event"?{messageEventDefinition:{messageRef:`msg_${(u||"EVENT").toLowerCase()}_${o.length>0?o.join("_").toLowerCase():"default"}_${s.customerKey}`}}:{}};return{canvasState:{slots:p,branches:(t==null?void 0:t.branches)??{}},bpmn:{customerId:`${s.customerKey}`,workflowCategory:b,sources:o,process:{name:s.workflowName,isExecutable:"true"},startEvent:U,endEvent:V,sequenceFlows:[...I,...g],exclusiveGateways:h,serviceTasks:E,callActivities:w},...m==="event"?{message:{id:`msg_${(u||"event").toLowerCase()}_${o.length>0?o.join("_").toLowerCase():"default"}_${s.customerKey}`,name:`msg_${(u||"event").toLowerCase()}_${o.length>0?o.join("_").toLowerCase():"default"}_${s.customerKey}`},dmns:R}:{eventConfig:[{eventType:u,config:{type:u,...((j=a==null?void 0:a.nodeData)==null?void 0:j.scheduler)??{}}}]}}}exports.DynamicFormRenderer=l.DynamicFormRenderer;exports.FF=l.FF;exports.FlowForgeRegistry=l.FlowForgeRegistry;exports.FlowForm=l.FlowForm;exports.FormulaInput=l.FormulaInput;exports.InfiniteSelectField=l.InfiniteSelectField;exports.OptionsResolversProvider=l.OptionsResolversProvider;exports.TablePickerField=l.TablePickerField;exports.VariablePicker=l.VariablePicker;exports.VariablePickerProvider=l.VariablePickerProvider;exports.astHasRefs=l.astHasRefs;exports.astToTokens=l.astToTokens;exports.buildEvaluationPayload=l.buildEvaluationPayload;exports.buildFieldConfig=l.buildFieldConfig;exports.buildFormulaPath=l.buildFormulaPath;exports.buildSelectStyles=l.buildSelectStyles;exports.buildValidationSchema=l.buildValidationSchema;exports.dataSourceRegistry=l.dataSourceRegistry;exports.errorTextStyle=l.errorTextStyle;exports.extractLabel=l.extractLabel;exports.fieldRegistry=l.fieldRegistry;exports.hasFormulaTokens=l.hasFormulaTokens;exports.helperTextStyle=l.helperTextStyle;exports.inputStyle=l.inputStyle;exports.isFormula=l.isFormula;exports.parseToAST=l.parseToAST;exports.serializeAST=l.serializeAST;exports.serializeASTAsConfig=l.serializeASTAsConfig;exports.serializeConditionExpressions=l.serializeConditionExpressions;exports.stripFormulaTokens=l.stripFormulaTokens;exports.tokenize=l.tokenize;exports.unwrapFormula=l.unwrapFormula;exports.useDynamicOptions=l.useDynamicOptions;exports.useOptionsResolvers=l.useOptionsResolvers;exports.useVariablePickerContext=l.useVariablePickerContext;exports.wrapFormula=l.wrapFormula;exports.FIELD_TYPE_OPTIONS=x.FIELD_TYPE_OPTIONS;exports.SchemaBuilder=x.SchemaBuilder;exports.SchemaBuilderDrawer=x.SchemaBuilderDrawer;exports.useFlowForm=x.useFlowForm;exports.NodeTypeRegistry=v.NodeTypeRegistry;exports.baseNodeDefaults=v.baseNodeDefaults;exports.conditionBranchDescriptor=v.conditionBranchDescriptor;exports.defineNode=v.defineNode;exports.endEventDescriptor=v.endEventDescriptor;exports.makeSubWorkflowDescriptor=v.makeSubWorkflowDescriptor;exports.nodeTypeRegistry=v.nodeTypeRegistry;exports.notificationDescriptor=v.notificationDescriptor;exports.restApiDescriptor=v.restApiDescriptor;exports.startEventDescriptor=v.startEventDescriptor;exports.subWorkflowDescriptor=v.subWorkflowDescriptor;exports.webhookTriggerDescriptor=v.webhookTriggerDescriptor;exports.webhookTriggerTemplate=v.webhookTriggerTemplate;exports.TemplateRegistry=L.TemplateRegistry;exports.templateRegistry=L.templateRegistry;exports.FlowForgeCanvas=S.FlowForgeCanvas;exports.FlowForgeHeader=S.FlowForgeHeader;exports.SubWorkflowPreviewDrawer=S.SubWorkflowPreviewDrawer;exports.WorkflowCanvas=S.FlowForgeCanvas;exports.WorkflowExecutionHistory=S.WorkflowExecutionHistory;exports.WorkflowTemplateLibrary=S.WorkflowTemplateLibrary;exports.accessRequestSkeleton=S.accessRequestSkeleton;exports.offboardingSkeleton=S.offboardingSkeleton;exports.userOnboardingSkeleton=S.userOnboardingSkeleton;exports.webhookIntegrationSkeleton=S.webhookIntegrationSkeleton;exports.defaultFlowForgeMessages=z.defaultFlowForgeMessages;exports.loadWorkflowFromBpmn=B.loadWorkflowFromBpmn;exports.saveWorkflowToBpmn=B.saveWorkflowToBpmn;exports.ActionNode=F.ActionNode;exports.ApprovalNode=F.ApprovalNode;exports.EdgeWithPlusLabel=F.EdgeWithPlusLabel;exports.EndNode=F.EndNode;exports.FilterNode=F.FilterNode;exports.RestApiNode=F.RestApiNode;exports.StartNode=F.StartNode;exports.TriggerNode=F.TriggerNode;exports.WebhookTriggerNode=F.WebhookTriggerNode;exports.builtInNodeTypes=F.builtInNodeTypes;exports.buildBackendPayload=oe;exports.buildVariableGroups=Y;exports.notificationChannelRegistry=G;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./index-DUbQPmIx.js"),b=require("./SchemaBuilderDrawer-CIxQGffa.js");require("react/jsx-runtime");require("react");require("@mui/material");require("react-icons/md");const i=require("./nodeRegistry.cjs"),f=require("./templateRegistry.cjs"),s=require("./templateSkeletons-gOva2Xus.js"),S=require("./messages-O9Tw_XXR.js"),k=require("./bpmn-CcuE2X_Q.js"),a=require("./GatewayBranchEdge-CMY30xhz.js"),R=require("./buildBackendPayload-BvrjW1uM.js");class D{constructor(){this.channels=new Map}register(o,t){this.channels.set(o,t)}get(o){return this.channels.get(o)}list(){return Array.from(this.channels.entries()).map(([o,t])=>({key:o,...t}))}has(o){return this.channels.has(o)}}const N=new D;function P(r){const{currentNodeId:o,nodes:t,getParents:d,getOutputSchema:n,nodePath:c,nodeLabel:u,getNodeId:p=l=>l.id}=r,g=t.find(l=>p(l)===o);if(!g)return[];const w=v(g,t,d,p),m=[];for(const l of w){const h=n(l);if(!h||h.length===0)continue;const F=c(l);m.push({label:u?u(l):F,items:h.map(T=>y(T,F))})}return m}function v(r,o,t,d){const n=new Set,c=[],u=[...t(r,o)];for(;u.length>0;){const p=u.shift(),g=d(p);n.has(g)||(n.add(g),c.push(p),u.push(...t(p,o)))}return c}function y(r,o){const t=`${o}.${r.key}`,d=r.description??(r.sample!==void 0&&r.sample!==null?String(r.sample):void 0),n={label:r.label,path:t};return d!==void 0&&(n.description=d),r.children&&r.children.length>0&&(n.children=r.children.map(c=>y(c,t))),n}exports.DynamicFormRenderer=e.DynamicFormRenderer;exports.FF=e.FF;exports.FlowForgeRegistry=e.FlowForgeRegistry;exports.FlowForm=e.FlowForm;exports.FormulaInput=e.FormulaInput;exports.InfiniteSelectField=e.InfiniteSelectField;exports.OptionsResolversProvider=e.OptionsResolversProvider;exports.TablePickerField=e.TablePickerField;exports.VariablePicker=e.VariablePicker;exports.VariablePickerProvider=e.VariablePickerProvider;exports.astHasRefs=e.astHasRefs;exports.astToTokens=e.astToTokens;exports.buildEvaluationPayload=e.buildEvaluationPayload;exports.buildFieldConfig=e.buildFieldConfig;exports.buildFormulaPath=e.buildFormulaPath;exports.buildSelectStyles=e.buildSelectStyles;exports.buildValidationSchema=e.buildValidationSchema;exports.dataSourceRegistry=e.dataSourceRegistry;exports.errorTextStyle=e.errorTextStyle;exports.extractLabel=e.extractLabel;exports.fieldRegistry=e.fieldRegistry;exports.hasFormulaTokens=e.hasFormulaTokens;exports.helperTextStyle=e.helperTextStyle;exports.inputStyle=e.inputStyle;exports.isFormula=e.isFormula;exports.parseToAST=e.parseToAST;exports.serializeAST=e.serializeAST;exports.serializeASTAsConfig=e.serializeASTAsConfig;exports.serializeConditionExpressions=e.serializeConditionExpressions;exports.stripFormulaTokens=e.stripFormulaTokens;exports.tokenize=e.tokenize;exports.unwrapFormula=e.unwrapFormula;exports.useDynamicOptions=e.useDynamicOptions;exports.useOptionsResolvers=e.useOptionsResolvers;exports.useVariablePickerContext=e.useVariablePickerContext;exports.wrapFormula=e.wrapFormula;exports.FIELD_TYPE_OPTIONS=b.FIELD_TYPE_OPTIONS;exports.SchemaBuilder=b.SchemaBuilder;exports.SchemaBuilderDrawer=b.SchemaBuilderDrawer;exports.useFlowForm=b.useFlowForm;exports.NodeTypeRegistry=i.NodeTypeRegistry;exports.baseNodeDefaults=i.baseNodeDefaults;exports.conditionBranchDescriptor=i.conditionBranchDescriptor;exports.defineNode=i.defineNode;exports.endEventDescriptor=i.endEventDescriptor;exports.makeSubWorkflowDescriptor=i.makeSubWorkflowDescriptor;exports.nodeTypeRegistry=i.nodeTypeRegistry;exports.notificationDescriptor=i.notificationDescriptor;exports.restApiDescriptor=i.restApiDescriptor;exports.startEventDescriptor=i.startEventDescriptor;exports.subWorkflowDescriptor=i.subWorkflowDescriptor;exports.webhookTriggerDescriptor=i.webhookTriggerDescriptor;exports.webhookTriggerTemplate=i.webhookTriggerTemplate;exports.TemplateRegistry=f.TemplateRegistry;exports.templateRegistry=f.templateRegistry;exports.FlowForgeCanvas=s.FlowForgeCanvas;exports.FlowForgeHeader=s.FlowForgeHeader;exports.SubWorkflowPreviewDrawer=s.SubWorkflowPreviewDrawer;exports.WorkflowCanvas=s.FlowForgeCanvas;exports.WorkflowExecutionHistory=s.WorkflowExecutionHistory;exports.WorkflowTemplateLibrary=s.WorkflowTemplateLibrary;exports.accessRequestSkeleton=s.accessRequestSkeleton;exports.offboardingSkeleton=s.offboardingSkeleton;exports.userOnboardingSkeleton=s.userOnboardingSkeleton;exports.webhookIntegrationSkeleton=s.webhookIntegrationSkeleton;exports.defaultFlowForgeMessages=S.defaultFlowForgeMessages;exports.loadWorkflowFromBpmn=k.loadWorkflowFromBpmn;exports.saveWorkflowToBpmn=k.saveWorkflowToBpmn;exports.ActionNode=a.ActionNode;exports.ApprovalNode=a.ApprovalNode;exports.EdgeWithPlusLabel=a.EdgeWithPlusLabel;exports.EndNode=a.EndNode;exports.FilterNode=a.FilterNode;exports.RestApiNode=a.RestApiNode;exports.StartNode=a.StartNode;exports.TriggerNode=a.TriggerNode;exports.WebhookTriggerNode=a.WebhookTriggerNode;exports.builtInNodeTypes=a.builtInNodeTypes;exports.buildBackendPayload=R.buildBackendPayload;exports.buildVariableGroups=P;exports.notificationChannelRegistry=N;
2
2
  //# sourceMappingURL=index.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.cjs","sources":["../src/notificationChannelRegistry/index.ts","../src/datapills/buildVariableGroups.ts","../src/payload/buildBackendPayload.ts"],"sourcesContent":["export interface NotificationChannelOption {\n value: string;\n label: string;\n}\n\nexport interface NotificationChannelConfig {\n label: string;\n /** Fetch recipients/channels for this notification channel at runtime */\n fetchRecipients?: () => Promise<NotificationChannelOption[]>;\n}\n\nclass NotificationChannelRegistry {\n private channels = new Map<string, NotificationChannelConfig>();\n\n register(key: string, config: NotificationChannelConfig): void {\n this.channels.set(key, config);\n }\n\n get(key: string): NotificationChannelConfig | undefined {\n return this.channels.get(key);\n }\n\n list(): Array<{ key: string } & NotificationChannelConfig> {\n return Array.from(this.channels.entries()).map(([key, cfg]) => ({ key, ...cfg }));\n }\n\n has(key: string): boolean {\n return this.channels.has(key);\n }\n}\n\nexport const notificationChannelRegistry = new NotificationChannelRegistry();\nexport default NotificationChannelRegistry;\n","/**\n * buildVariableGroups — graph walker that turns upstream nodes' outputSchemas\n * into Smart Values picker groups.\n *\n * Pattern matches Workato's datapill model: every node declares what it\n * outputs; downstream nodes see the union of upstream outputs. The package\n * doesn't know your node-id scheme, your API, or your edge model — pass\n * those in via the four predicates and we do the rest.\n *\n * Usage (IAM-side):\n *\n * const variableGroups = buildVariableGroups({\n * currentNodeId,\n * nodes, // canvas state slots\n * getParents: (node) => upstreamSlotsOf(node, edges),\n * getOutputSchema: (node) => tasksByKey[node.descriptorType]?.outputSchema ?? [],\n * nodePath: (node) => node.id === 'trigger' ? 'endUser' : `data.${index(node)}`,\n * nodeLabel: (node) => node.label,\n * });\n *\n * <FlowForm variableGroups={variableGroups} ... />\n */\n\nimport type { VariableGroup, VariableItem } from '../FlowForm/VariablePicker/VariablePickerContext';\n\nexport interface OutputSchemaItem {\n key: string;\n label: string;\n /** Optional — display only. Lets the picker show a type chip (\"ABC\" / 123). */\n type?: string;\n /** Optional — shown under/beside the label in the picker (Workato-style). */\n sample?: string | number | boolean;\n /** Optional tooltip text (independent of `sample`). */\n description?: string;\n /** Nested fields — renders as an expandable subgroup. */\n children?: OutputSchemaItem[];\n}\n\nexport interface BuildVariableGroupsOptions<TNode> {\n /** Id of the node currently being configured (its outputs are NOT included). */\n currentNodeId: string;\n /** All nodes in the canvas / workflow. */\n nodes: TNode[];\n /** Return the immediate parent node(s) — consumer walks its own edge model. */\n getParents: (node: TNode, nodes: TNode[]) => TNode[];\n /** Return the node's output schema array (empty array if none). */\n getOutputSchema: (node: TNode) => OutputSchemaItem[];\n /** Return the runtime path prefix for this node (e.g. 'endUser', 'data.1'). */\n nodePath: (node: TNode) => string;\n /** Optional — group label shown in the picker. Defaults to `nodePath(node)`. */\n nodeLabel?: (node: TNode) => string;\n /**\n * Optional — function reading a node's id. Defaults to `(n) => (n as any).id`.\n * Override if your node model nests the id (e.g. `n.data.id`).\n */\n getNodeId?: (node: TNode) => string;\n}\n\n/**\n * Walks upstream from `currentNodeId` (excluding it), collects each ancestor's\n * outputSchema, and returns a `VariableGroup[]` ready for `<FlowForm variableGroups>`.\n *\n * - Excludes the current node (a node never references its own outputs).\n * - Deduplicates ancestors via id — diamond graphs don't produce duplicate groups.\n * - Skips ancestors with empty outputSchema (no group rendered for nodes that emit nothing).\n * - Preserves traversal order — the closest parent appears first in the picker.\n */\nexport function buildVariableGroups<TNode>(\n opts: BuildVariableGroupsOptions<TNode>\n): VariableGroup[] {\n const {\n currentNodeId,\n nodes,\n getParents,\n getOutputSchema,\n nodePath,\n nodeLabel,\n getNodeId = (n: TNode) => (n as unknown as { id: string }).id,\n } = opts;\n\n const current = nodes.find((n) => getNodeId(n) === currentNodeId);\n if (!current) return [];\n\n const upstream = collectUpstream(current, nodes, getParents, getNodeId);\n\n const groups: VariableGroup[] = [];\n for (const node of upstream) {\n const schema = getOutputSchema(node);\n if (!schema || schema.length === 0) continue;\n const prefix = nodePath(node);\n groups.push({\n label: nodeLabel ? nodeLabel(node) : prefix,\n items: schema.map((item) => mapToVariableItem(item, prefix)),\n });\n }\n return groups;\n}\n\n// ─── Internals ──────────────────────────────────────────────────────────────\n\nfunction collectUpstream<TNode>(\n start: TNode,\n nodes: TNode[],\n getParents: (node: TNode, nodes: TNode[]) => TNode[],\n getNodeId: (node: TNode) => string\n): TNode[] {\n const seen = new Set<string>();\n const ordered: TNode[] = [];\n // BFS upstream — the closest parent ends up first, mirroring how Workato\n // groups the most recent step at the top of the datapill panel.\n const queue: TNode[] = [...getParents(start, nodes)];\n while (queue.length > 0) {\n const node = queue.shift() as TNode;\n const id = getNodeId(node);\n if (seen.has(id)) continue;\n seen.add(id);\n ordered.push(node);\n queue.push(...getParents(node, nodes));\n }\n return ordered;\n}\n\nfunction mapToVariableItem(\n item: OutputSchemaItem,\n prefix: string\n): VariableItem {\n const path = `${prefix}.${item.key}`;\n // Workato-style: show the sample value under the label when present.\n const description =\n item.description ??\n (item.sample !== undefined && item.sample !== null\n ? String(item.sample)\n : undefined);\n const result: VariableItem = { label: item.label, path };\n if (description !== undefined) result.description = description;\n if (item.children && item.children.length > 0) {\n result.children = item.children.map((c) => mapToVariableItem(c, path));\n }\n return result;\n}\n","/**\n * buildBackendPayload — generic BPMN/DMN/canvasState emitter driven by each\n * task's `ui.bpmnEmit` block. Consumer ships per-task bpmnEmit specs from\n * the backend; the package handles the walk.\n *\n * Originally lived in IAM as `flowforgeStateToBackendJson`. Moved into the\n * package so every consumer gets the same emitter — and so DMN/filter/\n * approval fixes ship once, to everyone.\n *\n * Consumer injects:\n * - canvasState — `{ slots, branches }` from the canvas\n * - tasksByKey — `{ [descriptorType]: ApplicationTask }` lookup\n * - context — host-specific scalars (customerKey, workflowName)\n * - config — IAM-shaped defaults (path prefix, end-event ids,\n * trigger→category map, scheduler events)\n *\n * Returns a JSON object ready to POST to the backend.\n */\n\n// ─── Types ──────────────────────────────────────────────────────────────────\n\nexport type CanvasSlot = {\n id: string;\n kind?: string;\n descriptorType?: string;\n nodeData?: Record<string, unknown>;\n formData?: Record<string, unknown>;\n [key: string]: unknown;\n};\n\nexport type CanvasState = {\n slots?: CanvasSlot[];\n branches?: Record<string, unknown>;\n};\n\nexport interface FieldRef {\n from: 'literal' | 'task' | 'ctx' | 'slot' | 'formData';\n key?: string;\n value?: unknown;\n}\n\nexport interface ExtensionFieldSpec {\n name: string;\n source?: {\n type: 'literal' | 'json' | 'taskConfig' | 'formData';\n value?: unknown;\n shape?: Record<string, FieldRef>;\n passthrough?: boolean;\n exclude?: string[];\n key?: string;\n };\n}\n\nexport interface ServiceTaskSpec {\n idTemplate: string;\n name?: string;\n flowableClass?: string;\n extensionFields?: ExtensionFieldSpec[];\n}\n\nexport interface GatewaySpec {\n idTemplate: string;\n name?: string;\n}\n\nexport interface TemplateFlowSpec {\n from: string;\n to: string;\n idTemplate?: string;\n condition?: string | null;\n}\n\nexport interface DmnOutputSpec {\n id: string;\n label?: string;\n name: string;\n typeRef?: string;\n}\n\nexport interface DmnEmitSpec {\n tableName: string;\n inputExpr: string;\n hitPolicy?: string;\n outputs?: DmnOutputSpec[];\n operatorMap?: Record<string, string>;\n valuesField?: string;\n}\n\nexport interface BpmnEmitSpec {\n kind: 'linear' | 'gated' | 'filter' | 'approval';\n serviceTasks?: ServiceTaskSpec[];\n gateway?: GatewaySpec;\n templateFlows?: TemplateFlowSpec[];\n outgoingConditions?: Record<string, string>;\n dmnEmit?: DmnEmitSpec;\n callActivity?: Record<string, unknown>;\n}\n\nexport interface ApplicationTaskLike {\n name?: string;\n taskKey?: string;\n applicationUuid?: string;\n configuration?: unknown[];\n ui?: { bpmnEmit?: BpmnEmitSpec; [key: string]: unknown };\n [key: string]: unknown;\n}\n\nexport interface BuildPayloadContext {\n customerKey: string;\n workflowName: string;\n /** Anything else the host wants exposed via `from: 'ctx', key: '...'`. */\n [key: string]: unknown;\n}\n\nexport interface BuildPayloadConfig {\n /**\n * Map of trigger eventType → workflowCategory string. Defaults to a small\n * IAM-shaped fallback; consumers should pass the full map they use.\n */\n triggerToCategory?: Record<string, string>;\n /** eventType values that should set `sources: ['SCHEDULER']` and skip the message block. */\n schedulerEventTypes?: string[];\n /** DMN LHS prefix for condition expressions (default IAM-style). */\n conditionPathPrefix?: string;\n /** Fallback workflowCategory when eventType isn't mapped. */\n defaultWorkflowCategory?: string;\n /** End-event ids — override per backend convention. */\n endEventIds?: { success: string; failure: string; rejected: string };\n /** Names rendered on end events. */\n endEventNames?: { success: string; failure: string; rejected: string };\n /** Start event id used in the outer chain. */\n startEventId?: string;\n}\n\nexport interface BuildPayloadOptions {\n state: CanvasState;\n tasksByKey: Record<string, ApplicationTaskLike>;\n context: BuildPayloadContext;\n config?: BuildPayloadConfig;\n}\n\n// ─── Defaults ──────────────────────────────────────────────────────────────\n\nconst DEFAULTS: Required<BuildPayloadConfig> = {\n triggerToCategory: {\n END_USER_CREATION: 'END_USER_CREATION',\n END_USER_UPDATION: 'END_USER_UPDATION',\n DELETE_DORMANT_ACCOUNT: 'DELETE_DORMANT_ACCOUNT',\n NOTIFY_EXPIRED_PASSWORD: 'NOTIFY_EXPIRED_PASSWORD',\n },\n schedulerEventTypes: ['DELETE_DORMANT_ACCOUNT', 'NOTIFY_EXPIRED_PASSWORD'],\n conditionPathPrefix: 'startEvent.endUser',\n defaultWorkflowCategory: 'END_USER_CREATION',\n endEventIds: {\n success: 'endEventSuccess',\n failure: 'endEventFailure',\n rejected: 'endEventRejected',\n },\n endEventNames: {\n success: 'Task Completed successfully',\n failure: 'User Not Created',\n rejected: 'Approval Rejected',\n },\n startEventId: 'startEvent',\n};\n\nconst NON_TASK_KINDS = new Set([\n 'start',\n 'end',\n 'triggerFixed',\n 'addTrigger',\n 'addStep',\n]);\nconst isTaskSlot = (slot: CanvasSlot): boolean =>\n !!slot && !NON_TASK_KINDS.has(String(slot.kind ?? ''));\n\n// ─── Helpers ───────────────────────────────────────────────────────────────\n\nfunction interpolate(tpl: string | null | undefined, ctx: Record<string, unknown>): string {\n if (tpl == null) return '';\n return String(tpl).replace(/\\$\\{(\\w+)\\}/g, (m, k) =>\n Object.prototype.hasOwnProperty.call(ctx, k) ? String(ctx[k]) : m\n );\n}\n\ninterface ResolveCtx {\n task: ApplicationTaskLike;\n slot: CanvasSlot;\n ctx: BuildPayloadContext;\n}\n\nfunction resolveFieldRef(ref: FieldRef | undefined, ctx: ResolveCtx): string {\n if (!ref || typeof ref !== 'object') return '';\n const { from, key, value } = ref;\n if (from === 'literal') return value === undefined ? '' : String(value);\n if (from === 'task') return String((ctx.task as Record<string, unknown>)?.[key ?? ''] ?? '');\n if (from === 'ctx') return String((ctx.ctx as Record<string, unknown>)?.[key ?? ''] ?? '');\n if (from === 'slot') return String((ctx.slot as Record<string, unknown>)?.[key ?? ''] ?? '');\n if (from === 'formData') return String(ctx.slot?.formData?.[key ?? ''] ?? '');\n return '';\n}\n\nfunction buildExtensionStringValue(field: ExtensionFieldSpec, ctx: ResolveCtx): string {\n const source = field?.source;\n if (!source) return '';\n if (source.type === 'literal') {\n return typeof source.value === 'string'\n ? source.value\n : JSON.stringify(source.value ?? '');\n }\n if (source.type === 'json' || source.type === 'taskConfig') {\n const shape = source.shape || {};\n const out: Record<string, string> = {};\n Object.keys(shape).forEach((k) => {\n out[k] = resolveFieldRef(shape[k], ctx);\n });\n return JSON.stringify(out);\n }\n if (source.type === 'formData') {\n if (source.passthrough) {\n const exclude = new Set(source.exclude || []);\n const out: Record<string, unknown> = {};\n const fd = ctx.slot?.formData ?? {};\n Object.keys(fd).forEach((k) => {\n if (!exclude.has(k)) out[k] = fd[k];\n });\n return JSON.stringify(out);\n }\n return String(ctx.slot?.formData?.[source.key ?? ''] ?? '');\n }\n return '';\n}\n\n/** Walk a dotted path against a plain object. Returns undefined on miss. */\nfunction getValueByPath(obj: unknown, path: string): unknown {\n if (!obj || typeof obj !== 'object' || !path) return undefined;\n return path.split('.').reduce<unknown>((acc, key) => {\n if (acc == null || typeof acc !== 'object') return undefined;\n return (acc as Record<string, unknown>)[key];\n }, obj);\n}\n\n// ─── DMN rule builder ──────────────────────────────────────────────────────\n\ninterface ConditionEntry {\n field?: string;\n fieldLabel?: string;\n key?: string;\n operator?: string;\n value?: string | number | boolean | null;\n connector?: 'and' | 'or';\n logicalOperator?: 'AND' | 'OR';\n}\n\nfunction buildDmnRules(\n dmnSpec: DmnEmitSpec,\n slot: CanvasSlot,\n pathPrefix: string\n): Array<{\n id: string;\n inputEntries: Array<{ id: string; text: string }>;\n outputEntries: Array<{ id: string; text: string }>;\n}> {\n const opMap = dmnSpec.operatorMap || {};\n const valuesField = dmnSpec.valuesField || 'groups';\n\n const toJuel = (cond: ConditionEntry): string => {\n const op = opMap[String(cond?.operator ?? '')] ?? '==';\n const lhs = `${pathPrefix}.${cond?.key ?? cond?.field ?? ''}`;\n const rhs = `'${String(cond?.value ?? '')}'`;\n if (op.startsWith('.')) return `${lhs}${op}(${rhs})`;\n if (op.startsWith('!.')) return `!${lhs}${op.slice(1)}(${rhs})`;\n return `${lhs} ${op} ${rhs}`;\n };\n\n const entriesToExpression = (entries: ConditionEntry[] | undefined): string | null => {\n const list = Array.isArray(entries) ? entries : [];\n if (list.length === 0) return null;\n const parts = list.map(toJuel);\n const isOr = list[0]?.connector === 'or' || list[0]?.logicalOperator === 'OR';\n const logical = isOr ? '||' : '&&';\n return parts.join(` ${logical} `);\n };\n\n const rules: Array<{\n id: string;\n inputEntries: Array<{ id: string; text: string }>;\n outputEntries: Array<{ id: string; text: string }>;\n }> = [];\n let ruleNum = 1;\n const pushRule = (expression: string | null, outputValue: unknown) => {\n rules.push({\n id: `rule${ruleNum}`,\n inputEntries: [\n {\n id: `rule${ruleNum}InputEntry1`,\n text: expression ? `\\${(${expression})}` : '',\n },\n ],\n outputEntries: [\n {\n id: `rule${ruleNum}OutputEntry1`,\n text: `\"${outputValue}\"`,\n },\n ],\n });\n ruleNum += 1;\n };\n\n // Shape A — IAM-legacy groupBlocks[].\n const blocks = Array.isArray(slot?.formData?.groupBlocks)\n ? (slot.formData!.groupBlocks as Array<{\n conditions?: ConditionEntry[];\n [k: string]: unknown;\n }>)\n : [];\n if (blocks.length > 0) {\n blocks.forEach((block) => {\n const values = Array.isArray(block?.[valuesField])\n ? (block[valuesField] as unknown[])\n : [];\n const expression = entriesToExpression(block?.conditions);\n values.forEach((v) => pushRule(expression, v));\n });\n return rules;\n }\n\n // Shape B — FlowForm When-builder.\n const fd = (slot?.formData ?? {}) as Record<string, unknown>;\n // eslint-disable-next-line no-underscore-dangle\n const condCfg = (fd._conditionConfig ?? fd.conditionConfig) as\n | Record<string, ConditionEntry[]>\n | undefined;\n if (condCfg && typeof condCfg === 'object') {\n Object.keys(condCfg).forEach((fieldKey) => {\n const conditions = condCfg[fieldKey];\n const expression = entriesToExpression(conditions);\n // The conditionConfig key can be either a plain field name OR a dotted\n // formik path (e.g. `attributeMapping.rules.0.targetField`). Resolve\n // both shapes — first try direct, then walk the path.\n const fieldValue =\n Object.prototype.hasOwnProperty.call(fd, fieldKey)\n ? fd[fieldKey]\n : getValueByPath(fd, fieldKey);\n if (Array.isArray(fieldValue)) {\n fieldValue.forEach((v) => {\n const out =\n typeof v === 'object' && v !== null\n ? (v as { value?: unknown; label?: unknown }).value ??\n (v as { label?: unknown }).label ??\n v\n : v;\n pushRule(expression, out);\n });\n } else if (\n fieldValue !== undefined &&\n fieldValue !== null &&\n fieldValue !== ''\n ) {\n pushRule(expression, fieldValue);\n } else if (expression) {\n // Conditions present but no output value — still emit the rule with\n // an empty output so the table doesn't silently drop it. Backend\n // can treat an empty output as a no-op or surface it as a config gap.\n pushRule(expression, '');\n }\n });\n }\n return rules;\n}\n\nfunction buildDmn(dmnSpec: DmnEmitSpec, slot: CanvasSlot, pathPrefix: string) {\n return {\n mappings: [],\n name: dmnSpec.tableName,\n decision: {\n id: dmnSpec.tableName,\n name: dmnSpec.tableName,\n decisionTable: {\n id: `decisionTable_${dmnSpec.tableName}`,\n hitPolicy: dmnSpec.hitPolicy || 'FIRST',\n inputs: [\n {\n id: `input_${dmnSpec.tableName}`,\n inputExpression: {\n id: `inputExpr_${dmnSpec.tableName}`,\n typeRef: 'string',\n text: dmnSpec.inputExpr,\n },\n },\n ],\n outputs: (dmnSpec.outputs || []).map((o) => ({\n id: o.id,\n label: o.label,\n typeRef: o.typeRef || 'string',\n name: o.name,\n })),\n rules: buildDmnRules(dmnSpec, slot, pathPrefix),\n },\n },\n };\n}\n\n// ─── Task emitter ──────────────────────────────────────────────────────────\n\ninterface Emission {\n serviceTasks: unknown[];\n gateways: Array<{ id: string; name?: string }>;\n callActivities: unknown[];\n templateFlows: Array<{\n id: string;\n sourceRef: string;\n targetRef: string;\n conditionExpression: string | null;\n }>;\n dmn: ReturnType<typeof buildDmn> | null;\n bpmnEntry: string;\n bpmnExit: string;\n outgoingConditions: Record<string, string>;\n endsNeeded: Set<string>;\n}\n\nfunction emitTask(\n slot: CanvasSlot,\n task: ApplicationTaskLike,\n saveCtx: BuildPayloadContext,\n cfg: Required<BuildPayloadConfig>\n): Emission {\n const spec = task?.ui?.bpmnEmit;\n if (!spec) {\n return {\n serviceTasks: [\n {\n id: slot.id,\n name: task?.name || slot.descriptorType,\n configuration: Array.isArray(task?.configuration) ? task.configuration : [],\n input: slot.formData || {},\n },\n ],\n gateways: [],\n callActivities: [],\n templateFlows: [],\n dmn: null,\n bpmnEntry: slot.id,\n bpmnExit: slot.id,\n outgoingConditions: {},\n endsNeeded: new Set(),\n };\n }\n\n const interpCtx: Record<string, unknown> = {\n id: slot.id,\n endFailure: cfg.endEventIds.failure,\n endRejected: cfg.endEventIds.rejected,\n endSuccess: cfg.endEventIds.success,\n };\n\n const ctx: ResolveCtx = { task, slot, ctx: saveCtx };\n\n const serviceTasks = (spec.serviceTasks || []).map((st) => ({\n id: interpolate(st.idTemplate, interpCtx),\n name: st.name,\n flowableClass: st.flowableClass,\n extensionElements: {\n fields: (st.extensionFields || []).map((f) => ({\n name: f.name,\n stringValue: buildExtensionStringValue(f, ctx),\n })),\n },\n }));\n\n let gatewayId: string | null = null;\n const gateways: Array<{ id: string; name?: string }> = [];\n if (spec.gateway) {\n gatewayId = interpolate(spec.gateway.idTemplate, interpCtx);\n interpCtx.gateway = gatewayId;\n gateways.push({ id: gatewayId, name: spec.gateway.name });\n }\n\n const endsNeeded = new Set<string>();\n const templateFlows = (spec.templateFlows || []).map((f) => {\n const source = interpolate(f.from, interpCtx);\n const target = interpolate(f.to, interpCtx);\n if (target === cfg.endEventIds.failure) endsNeeded.add(cfg.endEventIds.failure);\n if (target === cfg.endEventIds.rejected) endsNeeded.add(cfg.endEventIds.rejected);\n const id = f.idTemplate\n ? interpolate(f.idTemplate, interpCtx)\n : `${source}-to-${target}`;\n return {\n id,\n sourceRef: source,\n targetRef: target,\n conditionExpression: f.condition ? interpolate(f.condition, interpCtx) : null,\n };\n });\n\n const callActivities: unknown[] = [];\n const dmn = spec.dmnEmit ? buildDmn(spec.dmnEmit, slot, cfg.conditionPathPrefix) : null;\n\n const bpmnEntry = (serviceTasks[0] as { id?: string })?.id ?? slot.id;\n const bpmnExit =\n gatewayId ??\n (serviceTasks[serviceTasks.length - 1] as { id?: string })?.id ??\n slot.id;\n\n const outgoingConditions: Record<string, string> = {};\n Object.keys(spec.outgoingConditions || {}).forEach((branch) => {\n outgoingConditions[branch] = interpolate(\n spec.outgoingConditions![branch],\n interpCtx\n );\n });\n\n return {\n serviceTasks,\n gateways,\n callActivities,\n templateFlows,\n dmn,\n bpmnEntry,\n bpmnExit,\n outgoingConditions,\n endsNeeded,\n };\n}\n\n// ─── Main entry point ──────────────────────────────────────────────────────\n\n/**\n * Generate a backend-ready payload from canvas state + task definitions.\n *\n * @example\n * const payload = buildBackendPayload({\n * state: { slots, branches },\n * tasksByKey: { USER_CREATION: {...}, USER_GROUP_ASSIGNMENT: {...} },\n * context: { customerKey: '51995', workflowName: 'My WF' },\n * config: { triggerToCategory: { CUSTOM_TRIGGER: 'CUSTOM_CATEGORY' } },\n * });\n * await api.post('/process', payload);\n */\nexport function buildBackendPayload(opts: BuildPayloadOptions): Record<string, unknown> {\n const { state, tasksByKey, context, config } = opts;\n const cfg: Required<BuildPayloadConfig> = {\n ...DEFAULTS,\n ...(config ?? {}),\n triggerToCategory: { ...DEFAULTS.triggerToCategory, ...(config?.triggerToCategory ?? {}) },\n schedulerEventTypes: config?.schedulerEventTypes ?? DEFAULTS.schedulerEventTypes,\n endEventIds: { ...DEFAULTS.endEventIds, ...(config?.endEventIds ?? {}) },\n endEventNames: { ...DEFAULTS.endEventNames, ...(config?.endEventNames ?? {}) },\n };\n\n const slots = Array.isArray(state?.slots) ? state.slots! : [];\n\n // 1. Trigger metadata\n const triggerSlot = slots.find((s) => s.kind === 'triggerFixed');\n const eventType = (triggerSlot?.nodeData as { eventType?: string } | undefined)?.eventType;\n const triggerType =\n (triggerSlot?.nodeData as { type?: string } | undefined)?.type || 'event';\n const sourcesData = (triggerSlot?.nodeData as { sources?: unknown[] } | undefined)?.sources;\n const pickedSources = Array.isArray(sourcesData)\n ? sourcesData\n .map((s) =>\n typeof s === 'string'\n ? s\n : (s as { value?: string; key?: string })?.value ??\n (s as { value?: string; key?: string })?.key ??\n ''\n )\n .filter(Boolean)\n : [];\n const workflowCategory =\n cfg.triggerToCategory[eventType ?? ''] ?? cfg.defaultWorkflowCategory;\n const isSchedulerEvent =\n !!eventType && cfg.schedulerEventTypes.includes(eventType);\n const sources = isSchedulerEvent ? ['SCHEDULER'] : pickedSources;\n\n // 2. Walk each task slot through the emitter\n const taskSlots = slots.filter(isTaskSlot);\n const emissions = taskSlots.map((slot) => ({\n slot,\n emit: emitTask(slot, tasksByKey[slot.descriptorType ?? ''] ?? {}, context, cfg),\n }));\n\n // 3. Collect emitted parts\n const allServiceTasks: unknown[] = [];\n const allGateways: Array<{ id: string; name?: string }> = [];\n const allCallActivities: unknown[] = [];\n const allTemplateFlows: Array<{\n id: string;\n sourceRef: string;\n targetRef: string;\n conditionExpression: string | null;\n }> = [];\n const allDmns: unknown[] = [];\n const endsNeeded = new Set<string>();\n\n emissions.forEach(({ emit }) => {\n allServiceTasks.push(...emit.serviceTasks);\n allGateways.push(...emit.gateways);\n allCallActivities.push(...emit.callActivities);\n allTemplateFlows.push(...emit.templateFlows);\n if (emit.dmn) allDmns.push(emit.dmn);\n emit.endsNeeded.forEach((e) => endsNeeded.add(e));\n });\n\n // 4. Outer chain — link each task's exit to the next task's entry\n const outerFlows: Array<{\n id: string;\n sourceRef: string;\n targetRef: string;\n conditionExpression: string | null;\n }> = [];\n\n if (emissions.length > 0) {\n outerFlows.push({\n id: `${cfg.startEventId}-to-${emissions[0].emit.bpmnEntry}`,\n sourceRef: cfg.startEventId,\n targetRef: emissions[0].emit.bpmnEntry,\n conditionExpression: null,\n });\n\n for (let i = 0; i < emissions.length - 1; i += 1) {\n const cur = emissions[i].emit;\n const next = emissions[i + 1].emit;\n const condition =\n cur.outgoingConditions.success ??\n cur.outgoingConditions.pass ??\n cur.outgoingConditions.approved ??\n null;\n outerFlows.push({\n id: `${cur.bpmnExit}-to-${next.bpmnEntry}`,\n sourceRef: cur.bpmnExit,\n targetRef: next.bpmnEntry,\n conditionExpression: condition,\n });\n }\n\n const last = emissions[emissions.length - 1].emit;\n outerFlows.push({\n id: `${last.bpmnExit}-to-${cfg.endEventIds.success}`,\n sourceRef: last.bpmnExit,\n targetRef: cfg.endEventIds.success,\n conditionExpression: null,\n });\n } else {\n outerFlows.push({\n id: `${cfg.startEventId}-to-${cfg.endEventIds.success}`,\n sourceRef: cfg.startEventId,\n targetRef: cfg.endEventIds.success,\n conditionExpression: null,\n });\n }\n\n // 5. End events\n const endEvent: Array<{ id: string; name: string; executionListener?: null }> = [\n {\n id: cfg.endEventIds.success,\n name: cfg.endEventNames.success,\n executionListener: null,\n },\n ...(endsNeeded.has(cfg.endEventIds.failure)\n ? [{ id: cfg.endEventIds.failure, name: cfg.endEventNames.failure }]\n : []),\n ...(endsNeeded.has(cfg.endEventIds.rejected)\n ? [{ id: cfg.endEventIds.rejected, name: cfg.endEventNames.rejected }]\n : []),\n ];\n\n // 6. Start event\n const startEvent: Record<string, unknown> = {\n id: cfg.startEventId,\n name: 'Start',\n ...(triggerType === 'event'\n ? {\n messageEventDefinition: {\n messageRef: `msg_${(eventType || 'EVENT').toLowerCase()}_${\n sources.length > 0 ? sources.join('_').toLowerCase() : 'default'\n }_${context.customerKey}`,\n },\n }\n : {}),\n };\n\n // 7. Final payload\n const json: Record<string, unknown> = {\n canvasState: {\n slots,\n branches: state?.branches ?? {},\n },\n bpmn: {\n customerId: `${context.customerKey}`,\n workflowCategory,\n sources,\n process: {\n name: context.workflowName,\n isExecutable: 'true',\n },\n startEvent,\n endEvent,\n sequenceFlows: [...outerFlows, ...allTemplateFlows],\n exclusiveGateways: allGateways,\n serviceTasks: allServiceTasks,\n callActivities: allCallActivities,\n },\n ...(triggerType === 'event'\n ? {\n message: {\n id: `msg_${(eventType || 'event').toLowerCase()}_${\n sources.length > 0 ? sources.join('_').toLowerCase() : 'default'\n }_${context.customerKey}`,\n name: `msg_${(eventType || 'event').toLowerCase()}_${\n sources.length > 0 ? sources.join('_').toLowerCase() : 'default'\n }_${context.customerKey}`,\n },\n dmns: allDmns,\n }\n : {\n eventConfig: [\n {\n eventType,\n config: {\n type: eventType,\n ...((triggerSlot?.nodeData as { scheduler?: Record<string, unknown> })?.scheduler ?? {}),\n },\n },\n ],\n }),\n };\n\n return json;\n}\n"],"names":["NotificationChannelRegistry","key","config","cfg","notificationChannelRegistry","buildVariableGroups","opts","currentNodeId","nodes","getParents","getOutputSchema","nodePath","nodeLabel","getNodeId","n","current","upstream","collectUpstream","groups","node","schema","prefix","item","mapToVariableItem","start","seen","ordered","queue","id","path","description","result","c","DEFAULTS","NON_TASK_KINDS","isTaskSlot","slot","interpolate","tpl","ctx","m","k","resolveFieldRef","ref","from","value","_a","_b","_c","_e","_d","buildExtensionStringValue","field","source","shape","out","exclude","fd","getValueByPath","obj","acc","buildDmnRules","dmnSpec","pathPrefix","opMap","valuesField","toJuel","cond","op","lhs","rhs","entriesToExpression","entries","list","parts","logical","rules","ruleNum","pushRule","expression","outputValue","blocks","block","values","v","condCfg","fieldKey","conditions","fieldValue","buildDmn","o","emitTask","task","saveCtx","spec","interpCtx","serviceTasks","st","f","gatewayId","gateways","endsNeeded","templateFlows","target","callActivities","dmn","bpmnEntry","bpmnExit","outgoingConditions","branch","buildBackendPayload","state","tasksByKey","context","slots","triggerSlot","s","eventType","triggerType","sourcesData","pickedSources","workflowCategory","sources","emissions","allServiceTasks","allGateways","allCallActivities","allTemplateFlows","allDmns","emit","e","outerFlows","i","cur","next","condition","last","endEvent","startEvent"],"mappings":"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"}
1
+ {"version":3,"file":"index.cjs","sources":["../src/notificationChannelRegistry/index.ts","../src/datapills/buildVariableGroups.ts"],"sourcesContent":["export interface NotificationChannelOption {\n value: string;\n label: string;\n}\n\nexport interface NotificationChannelConfig {\n label: string;\n /** Fetch recipients/channels for this notification channel at runtime */\n fetchRecipients?: () => Promise<NotificationChannelOption[]>;\n}\n\nclass NotificationChannelRegistry {\n private channels = new Map<string, NotificationChannelConfig>();\n\n register(key: string, config: NotificationChannelConfig): void {\n this.channels.set(key, config);\n }\n\n get(key: string): NotificationChannelConfig | undefined {\n return this.channels.get(key);\n }\n\n list(): Array<{ key: string } & NotificationChannelConfig> {\n return Array.from(this.channels.entries()).map(([key, cfg]) => ({ key, ...cfg }));\n }\n\n has(key: string): boolean {\n return this.channels.has(key);\n }\n}\n\nexport const notificationChannelRegistry = new NotificationChannelRegistry();\nexport default NotificationChannelRegistry;\n","/**\n * buildVariableGroups — graph walker that turns upstream nodes' outputSchemas\n * into Smart Values picker groups.\n *\n * Pattern matches Workato's datapill model: every node declares what it\n * outputs; downstream nodes see the union of upstream outputs. The package\n * doesn't know your node-id scheme, your API, or your edge model — pass\n * those in via the four predicates and we do the rest.\n *\n * Usage (IAM-side):\n *\n * const variableGroups = buildVariableGroups({\n * currentNodeId,\n * nodes, // canvas state slots\n * getParents: (node) => upstreamSlotsOf(node, edges),\n * getOutputSchema: (node) => tasksByKey[node.descriptorType]?.outputSchema ?? [],\n * nodePath: (node) => node.id === 'trigger' ? 'endUser' : `data.${index(node)}`,\n * nodeLabel: (node) => node.label,\n * });\n *\n * <FlowForm variableGroups={variableGroups} ... />\n */\n\nimport type { VariableGroup, VariableItem } from '../FlowForm/VariablePicker/VariablePickerContext';\n\nexport interface OutputSchemaItem {\n key: string;\n label: string;\n /** Optional — display only. Lets the picker show a type chip (\"ABC\" / 123). */\n type?: string;\n /** Optional — shown under/beside the label in the picker (Workato-style). */\n sample?: string | number | boolean;\n /** Optional tooltip text (independent of `sample`). */\n description?: string;\n /** Nested fields — renders as an expandable subgroup. */\n children?: OutputSchemaItem[];\n}\n\nexport interface BuildVariableGroupsOptions<TNode> {\n /** Id of the node currently being configured (its outputs are NOT included). */\n currentNodeId: string;\n /** All nodes in the canvas / workflow. */\n nodes: TNode[];\n /** Return the immediate parent node(s) — consumer walks its own edge model. */\n getParents: (node: TNode, nodes: TNode[]) => TNode[];\n /** Return the node's output schema array (empty array if none). */\n getOutputSchema: (node: TNode) => OutputSchemaItem[];\n /** Return the runtime path prefix for this node (e.g. 'endUser', 'data.1'). */\n nodePath: (node: TNode) => string;\n /** Optional — group label shown in the picker. Defaults to `nodePath(node)`. */\n nodeLabel?: (node: TNode) => string;\n /**\n * Optional — function reading a node's id. Defaults to `(n) => (n as any).id`.\n * Override if your node model nests the id (e.g. `n.data.id`).\n */\n getNodeId?: (node: TNode) => string;\n}\n\n/**\n * Walks upstream from `currentNodeId` (excluding it), collects each ancestor's\n * outputSchema, and returns a `VariableGroup[]` ready for `<FlowForm variableGroups>`.\n *\n * - Excludes the current node (a node never references its own outputs).\n * - Deduplicates ancestors via id — diamond graphs don't produce duplicate groups.\n * - Skips ancestors with empty outputSchema (no group rendered for nodes that emit nothing).\n * - Preserves traversal order — the closest parent appears first in the picker.\n */\nexport function buildVariableGroups<TNode>(\n opts: BuildVariableGroupsOptions<TNode>\n): VariableGroup[] {\n const {\n currentNodeId,\n nodes,\n getParents,\n getOutputSchema,\n nodePath,\n nodeLabel,\n getNodeId = (n: TNode) => (n as unknown as { id: string }).id,\n } = opts;\n\n const current = nodes.find((n) => getNodeId(n) === currentNodeId);\n if (!current) return [];\n\n const upstream = collectUpstream(current, nodes, getParents, getNodeId);\n\n const groups: VariableGroup[] = [];\n for (const node of upstream) {\n const schema = getOutputSchema(node);\n if (!schema || schema.length === 0) continue;\n const prefix = nodePath(node);\n groups.push({\n label: nodeLabel ? nodeLabel(node) : prefix,\n items: schema.map((item) => mapToVariableItem(item, prefix)),\n });\n }\n return groups;\n}\n\n// ─── Internals ──────────────────────────────────────────────────────────────\n\nfunction collectUpstream<TNode>(\n start: TNode,\n nodes: TNode[],\n getParents: (node: TNode, nodes: TNode[]) => TNode[],\n getNodeId: (node: TNode) => string\n): TNode[] {\n const seen = new Set<string>();\n const ordered: TNode[] = [];\n // BFS upstream — the closest parent ends up first, mirroring how Workato\n // groups the most recent step at the top of the datapill panel.\n const queue: TNode[] = [...getParents(start, nodes)];\n while (queue.length > 0) {\n const node = queue.shift() as TNode;\n const id = getNodeId(node);\n if (seen.has(id)) continue;\n seen.add(id);\n ordered.push(node);\n queue.push(...getParents(node, nodes));\n }\n return ordered;\n}\n\nfunction mapToVariableItem(\n item: OutputSchemaItem,\n prefix: string\n): VariableItem {\n const path = `${prefix}.${item.key}`;\n // Workato-style: show the sample value under the label when present.\n const description =\n item.description ??\n (item.sample !== undefined && item.sample !== null\n ? String(item.sample)\n : undefined);\n const result: VariableItem = { label: item.label, path };\n if (description !== undefined) result.description = description;\n if (item.children && item.children.length > 0) {\n result.children = item.children.map((c) => mapToVariableItem(c, path));\n }\n return result;\n}\n"],"names":["NotificationChannelRegistry","key","config","cfg","notificationChannelRegistry","buildVariableGroups","opts","currentNodeId","nodes","getParents","getOutputSchema","nodePath","nodeLabel","getNodeId","n","current","upstream","collectUpstream","groups","node","schema","prefix","item","mapToVariableItem","start","seen","ordered","queue","id","path","description","result"],"mappings":"8hBAWA,MAAMA,CAA4B,CAAlC,aAAA,CACE,KAAQ,aAAe,GAAuC,CAE9D,SAASC,EAAaC,EAAyC,CAC7D,KAAK,SAAS,IAAID,EAAKC,CAAM,CAC/B,CAEA,IAAID,EAAoD,CACtD,OAAO,KAAK,SAAS,IAAIA,CAAG,CAC9B,CAEA,MAA2D,CACzD,OAAO,MAAM,KAAK,KAAK,SAAS,QAAA,CAAS,EAAE,IAAI,CAAC,CAACA,EAAKE,CAAG,KAAO,CAAE,IAAAF,EAAK,GAAGE,GAAM,CAClF,CAEA,IAAIF,EAAsB,CACxB,OAAO,KAAK,SAAS,IAAIA,CAAG,CAC9B,CACF,CAEO,MAAMG,EAA8B,IAAIJ,ECoCxC,SAASK,EACdC,EACiB,CACjB,KAAM,CACJ,cAAAC,EACA,MAAAC,EACA,WAAAC,EACA,gBAAAC,EACA,SAAAC,EACA,UAAAC,EACA,UAAAC,EAAaC,GAAcA,EAAgC,EAAA,EACzDR,EAEES,EAAUP,EAAM,KAAMM,GAAMD,EAAUC,CAAC,IAAMP,CAAa,EAChE,GAAI,CAACQ,EAAS,MAAO,CAAA,EAErB,MAAMC,EAAWC,EAAgBF,EAASP,EAAOC,EAAYI,CAAS,EAEhEK,EAA0B,CAAA,EAChC,UAAWC,KAAQH,EAAU,CAC3B,MAAMI,EAASV,EAAgBS,CAAI,EACnC,GAAI,CAACC,GAAUA,EAAO,SAAW,EAAG,SACpC,MAAMC,EAASV,EAASQ,CAAI,EAC5BD,EAAO,KAAK,CACV,MAAON,EAAYA,EAAUO,CAAI,EAAIE,EACrC,MAAOD,EAAO,IAAKE,GAASC,EAAkBD,EAAMD,CAAM,CAAC,CAAA,CAC5D,CACH,CACA,OAAOH,CACT,CAIA,SAASD,EACPO,EACAhB,EACAC,EACAI,EACS,CACT,MAAMY,MAAW,IACXC,EAAmB,CAAA,EAGnBC,EAAiB,CAAC,GAAGlB,EAAWe,EAAOhB,CAAK,CAAC,EACnD,KAAOmB,EAAM,OAAS,GAAG,CACvB,MAAMR,EAAOQ,EAAM,MAAA,EACbC,EAAKf,EAAUM,CAAI,EACrBM,EAAK,IAAIG,CAAE,IACfH,EAAK,IAAIG,CAAE,EACXF,EAAQ,KAAKP,CAAI,EACjBQ,EAAM,KAAK,GAAGlB,EAAWU,EAAMX,CAAK,CAAC,EACvC,CACA,OAAOkB,CACT,CAEA,SAASH,EACPD,EACAD,EACc,CACd,MAAMQ,EAAO,GAAGR,CAAM,IAAIC,EAAK,GAAG,GAE5BQ,EACJR,EAAK,cACJA,EAAK,SAAW,QAAaA,EAAK,SAAW,KAC1C,OAAOA,EAAK,MAAM,EAClB,QACAS,EAAuB,CAAE,MAAOT,EAAK,MAAO,KAAAO,CAAA,EAClD,OAAIC,IAAgB,SAAWC,EAAO,YAAcD,GAChDR,EAAK,UAAYA,EAAK,SAAS,OAAS,IAC1CS,EAAO,SAAWT,EAAK,SAAS,IAAK,GAAMC,EAAkB,EAAGM,CAAI,CAAC,GAEhEE,CACT"}