@goplasmatic/datalogic-ui 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +201 -0
- package/README.md +198 -0
- package/dist/datalogic_wasm-r9jsW6oT.js +314 -0
- package/dist/datalogic_wasm-r9jsW6oT.js.map +1 -0
- package/dist/datalogic_wasm-vS4KZjmk.cjs +410 -0
- package/dist/datalogic_wasm-vS4KZjmk.cjs.map +1 -0
- package/dist/demo.gif +0 -0
- package/dist/index.cjs +9007 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.ts +166 -0
- package/dist/index.js +8791 -0
- package/dist/index.js.map +1 -0
- package/dist/manifest.json +11 -0
- package/dist/robots.txt +4 -0
- package/dist/styles.css +1987 -0
- package/package.json +91 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../src/components/logic-editor/constants/colors.ts","../src/components/logic-editor/utils/type-helpers.ts","../src/components/logic-editor/utils/formatting/expression-text.ts","../src/components/logic-editor/constants/operators.ts","../src/components/logic-editor/constants/formatting.ts","../src/components/logic-editor/constants/layout.ts","../src/components/logic-editor/constants/handles.ts","../node_modules/lucide-react/dist/esm/shared/src/utils.js","../node_modules/lucide-react/dist/esm/defaultAttributes.js","../node_modules/lucide-react/dist/esm/Icon.js","../node_modules/lucide-react/dist/esm/createLucideIcon.js","../node_modules/lucide-react/dist/esm/icons/ban.js","../node_modules/lucide-react/dist/esm/icons/box.js","../node_modules/lucide-react/dist/esm/icons/boxes.js","../node_modules/lucide-react/dist/esm/icons/bug.js","../node_modules/lucide-react/dist/esm/icons/calculator.js","../node_modules/lucide-react/dist/esm/icons/calendar.js","../node_modules/lucide-react/dist/esm/icons/check.js","../node_modules/lucide-react/dist/esm/icons/chevron-left.js","../node_modules/lucide-react/dist/esm/icons/chevron-right.js","../node_modules/lucide-react/dist/esm/icons/circle-question-mark.js","../node_modules/lucide-react/dist/esm/icons/circle-x.js","../node_modules/lucide-react/dist/esm/icons/cog.js","../node_modules/lucide-react/dist/esm/icons/database.js","../node_modules/lucide-react/dist/esm/icons/diamond.js","../node_modules/lucide-react/dist/esm/icons/divide.js","../node_modules/lucide-react/dist/esm/icons/git-commit-horizontal.js","../node_modules/lucide-react/dist/esm/icons/git-merge.js","../node_modules/lucide-react/dist/esm/icons/hash.js","../node_modules/lucide-react/dist/esm/icons/list.js","../node_modules/lucide-react/dist/esm/icons/pause.js","../node_modules/lucide-react/dist/esm/icons/play.js","../node_modules/lucide-react/dist/esm/icons/quote.js","../node_modules/lucide-react/dist/esm/icons/repeat.js","../node_modules/lucide-react/dist/esm/icons/scale.js","../node_modules/lucide-react/dist/esm/icons/search.js","../node_modules/lucide-react/dist/esm/icons/skip-back.js","../node_modules/lucide-react/dist/esm/icons/skip-forward.js","../node_modules/lucide-react/dist/esm/icons/text-align-start.js","../node_modules/lucide-react/dist/esm/icons/toggle-left.js","../node_modules/lucide-react/dist/esm/icons/toggle-right.js","../node_modules/lucide-react/dist/esm/icons/type.js","../node_modules/lucide-react/dist/esm/icons/x.js","../src/components/logic-editor/utils/Icon.tsx","../src/components/logic-editor/utils/icons.ts","../src/components/logic-editor/utils/formatting/arg-summary.ts","../src/components/logic-editor/utils/formatting/value-formatter.ts","../src/components/logic-editor/utils/converters/types.ts","../node_modules/uuid/dist/stringify.js","../node_modules/uuid/dist/rng.js","../node_modules/uuid/dist/native.js","../node_modules/uuid/dist/v4.js","../src/components/logic-editor/utils/node-factory.ts","../src/components/logic-editor/utils/converters/primitive-converter.ts","../src/components/logic-editor/utils/converters/variable-converter.ts","../src/components/logic-editor/utils/converters/if-else-converter.ts","../src/components/logic-editor/utils/converters/operator-converter.ts","../src/components/logic-editor/utils/converters/index.ts","../src/components/logic-editor/utils/jsonlogic-to-nodes.ts","../src/components/logic-editor/utils/trace-to-nodes.ts","../node_modules/@dagrejs/graphlib/lib/graph.js","../node_modules/@dagrejs/graphlib/lib/version.js","../node_modules/@dagrejs/graphlib/lib/index.js","../node_modules/@dagrejs/graphlib/lib/json.js","../node_modules/@dagrejs/graphlib/lib/alg/components.js","../node_modules/@dagrejs/graphlib/lib/data/priority-queue.js","../node_modules/@dagrejs/graphlib/lib/alg/dijkstra.js","../node_modules/@dagrejs/graphlib/lib/alg/dijkstra-all.js","../node_modules/@dagrejs/graphlib/lib/alg/tarjan.js","../node_modules/@dagrejs/graphlib/lib/alg/find-cycles.js","../node_modules/@dagrejs/graphlib/lib/alg/floyd-warshall.js","../node_modules/@dagrejs/graphlib/lib/alg/topsort.js","../node_modules/@dagrejs/graphlib/lib/alg/is-acyclic.js","../node_modules/@dagrejs/graphlib/lib/alg/dfs.js","../node_modules/@dagrejs/graphlib/lib/alg/postorder.js","../node_modules/@dagrejs/graphlib/lib/alg/preorder.js","../node_modules/@dagrejs/graphlib/lib/alg/prim.js","../node_modules/@dagrejs/graphlib/lib/alg/index.js","../node_modules/@dagrejs/graphlib/index.js","../node_modules/@dagrejs/dagre/lib/data/list.js","../node_modules/@dagrejs/dagre/lib/greedy-fas.js","../node_modules/@dagrejs/dagre/lib/util.js","../node_modules/@dagrejs/dagre/lib/acyclic.js","../node_modules/@dagrejs/dagre/lib/normalize.js","../node_modules/@dagrejs/dagre/lib/rank/util.js","../node_modules/@dagrejs/dagre/lib/rank/feasible-tree.js","../node_modules/@dagrejs/dagre/lib/rank/network-simplex.js","../node_modules/@dagrejs/dagre/lib/rank/index.js","../node_modules/@dagrejs/dagre/lib/parent-dummy-chains.js","../node_modules/@dagrejs/dagre/lib/nesting-graph.js","../node_modules/@dagrejs/dagre/lib/add-border-segments.js","../node_modules/@dagrejs/dagre/lib/coordinate-system.js","../node_modules/@dagrejs/dagre/lib/order/init-order.js","../node_modules/@dagrejs/dagre/lib/order/cross-count.js","../node_modules/@dagrejs/dagre/lib/order/barycenter.js","../node_modules/@dagrejs/dagre/lib/order/resolve-conflicts.js","../node_modules/@dagrejs/dagre/lib/order/sort.js","../node_modules/@dagrejs/dagre/lib/order/sort-subgraph.js","../node_modules/@dagrejs/dagre/lib/order/build-layer-graph.js","../node_modules/@dagrejs/dagre/lib/order/add-subgraph-constraints.js","../node_modules/@dagrejs/dagre/lib/order/index.js","../node_modules/@dagrejs/dagre/lib/position/bk.js","../node_modules/@dagrejs/dagre/lib/position/index.js","../node_modules/@dagrejs/dagre/lib/layout.js","../node_modules/@dagrejs/dagre/lib/debug.js","../node_modules/@dagrejs/dagre/lib/version.js","../node_modules/@dagrejs/dagre/index.js","../src/components/logic-editor/utils/type-guards.ts","../src/components/logic-editor/utils/layout.ts","../src/components/logic-editor/hooks/useLogicEditor.ts","../src/components/logic-editor/context/EvaluationContext.tsx","../src/components/logic-editor/context/DebuggerContext.tsx","../src/components/logic-editor/context/ConnectedHandlesContextDef.ts","../src/components/logic-editor/context/ConnectedHandlesContext.tsx","../src/components/logic-editor/context/useConnectedHandles.ts","../src/components/logic-editor/hooks/useDebugClassName.ts","../src/components/logic-editor/hooks/useNodeCollapse.ts","../src/components/logic-editor/hooks/useDebugEvaluation.ts","../src/components/logic-editor/hooks/useWasmEvaluator.ts","../src/components/logic-editor/nodes/shared/NodeInputHandles.tsx","../src/components/logic-editor/nodes/shared/CollapseToggleButton.tsx","../src/components/logic-editor/nodes/DebugInfoBubble.tsx","../src/components/logic-editor/nodes/shared/NodeDebugBubble.tsx","../src/components/logic-editor/utils/ExpressionSyntax.tsx","../src/components/logic-editor/nodes/OperatorNode.tsx","../src/components/logic-editor/nodes/VariableNode.tsx","../src/components/logic-editor/nodes/LiteralNode.tsx","../src/components/logic-editor/nodes/CellHandles.tsx","../src/components/logic-editor/nodes/CellRow.tsx","../src/components/logic-editor/nodes/VerticalCellNode.tsx","../src/components/logic-editor/nodes/nodeTypes.ts","../src/components/logic-editor/utils/visibility.ts","../src/components/logic-editor/debugger-controls/DebuggerControls.tsx","../src/components/logic-editor/DataLogicEditor.tsx"],"sourcesContent":["import type { OperatorCategory } from '../types';\n\n// Colors for branch edges and labels\nexport const BRANCH_COLORS = {\n yes: '#22C55E',\n no: '#EF4444',\n} as const;\n\n// Color mappings for operator categories\nexport const CATEGORY_COLORS: Record<OperatorCategory, string> = {\n variable: '#3B82F6',\n comparison: '#8B5CF6',\n logical: '#F97316',\n arithmetic: '#22C55E',\n string: '#14B8A6',\n array: '#6366F1',\n control: '#EF4444',\n datetime: '#F59E0B',\n error: '#F43F5E',\n literal: '#6B7280',\n};\n","import type { JsonLogicValue, LiteralNodeData } from '../types';\n\n// Check if value is a plain object (not array, not null)\nexport function isPlainObject(value: unknown): value is Record<string, unknown> {\n return typeof value === 'object' && value !== null && !Array.isArray(value);\n}\n\n// Get the value type for literals\nexport function getValueType(value: JsonLogicValue): LiteralNodeData['valueType'] {\n if (value === null) return 'null';\n if (typeof value === 'boolean') return 'boolean';\n if (typeof value === 'number') return 'number';\n if (typeof value === 'string') return 'string';\n if (Array.isArray(value)) return 'array';\n return 'string';\n}\n\n// Check if a string looks like a date\nexport function looksLikeDate(str: string): boolean {\n // Check common date patterns\n const datePatterns = [\n /^\\d{4}-\\d{2}-\\d{2}/, // ISO date\n /^\\d{2}\\/\\d{2}\\/\\d{4}/, // MM/DD/YYYY\n /^\\d{2}-\\d{2}-\\d{4}/, // DD-MM-YYYY\n ];\n return datePatterns.some(pattern => pattern.test(str));\n}\n\n// Check if an operand is \"simple\" (can be displayed inline)\n// Only literals are simple - variable operators (var, val, exists) get their own nodes\n// so their debug context/results show correctly\nexport function isSimpleOperand(operand: JsonLogicValue): boolean {\n // Primitives (literals) are simple\n if (operand === null || typeof operand !== 'object') {\n return true;\n }\n\n // Arrays are not simple (except empty arrays for display)\n if (Array.isArray(operand)) {\n return operand.length === 0;\n }\n\n // Objects (including var/val/exists operators) are not simple\n // They need their own visual nodes for proper debug highlighting\n return false;\n}\n","import type { JsonLogicValue } from '../../types';\nimport { isPlainObject } from '../type-helpers';\n\n// Operator categories for expression formatting\nconst COMPARISON_OPERATORS = ['==', '===', '!=', '!==', '>', '>=', '<', '<='];\nconst ITERATOR_OPERATORS = ['map', 'reduce', 'filter', 'some', 'none', 'all'];\nconst UNARY_OPERATORS = ['!', '!!'];\nconst ARITHMETIC_BINARY_OPERATORS = ['+', '-', '*', '/', '%'];\n\n// Generate full expression text for a JSONLogic value (for collapsed view)\nexport function generateExpressionText(value: JsonLogicValue, maxLength = 100): string {\n // Get the operator of a value (if it's an operator expression)\n function getOperator(val: JsonLogicValue): string | null {\n if (isPlainObject(val)) {\n const keys = Object.keys(val);\n if (keys.length === 1) return keys[0];\n }\n return null;\n }\n\n // Check if a sub-expression needs parentheses when used inside a parent operator\n function needsParens(subVal: JsonLogicValue, parentOp: string): boolean {\n const subOp = getOperator(subVal);\n if (!subOp) return false;\n\n // AND inside OR or OR inside AND needs parens\n if ((parentOp === 'and' && subOp === 'or') || (parentOp === 'or' && subOp === 'and')) {\n return true;\n }\n // Logical inside comparison needs parens\n if (COMPARISON_OPERATORS.includes(parentOp) && (subOp === 'and' || subOp === 'or')) {\n return true;\n }\n // Lower precedence arithmetic\n if ((parentOp === '*' || parentOp === '/') && (subOp === '+' || subOp === '-')) {\n return true;\n }\n return false;\n }\n\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n function toText(val: JsonLogicValue, _parentOp?: string): string {\n if (val === null) return 'null';\n if (typeof val === 'boolean') return String(val);\n if (typeof val === 'number') return String(val);\n if (typeof val === 'string') return `\"${val}\"`;\n\n if (Array.isArray(val)) {\n if (val.length === 0) return '[]';\n const items = val.map(v => toText(v)).join(', ');\n return `[${items}]`;\n }\n\n if (isPlainObject(val)) {\n const keys = Object.keys(val);\n if (keys.length !== 1) return JSON.stringify(val);\n\n const op = keys[0];\n const operands = val[op];\n\n // Variable access\n if (op === 'var') {\n const path = Array.isArray(operands) ? operands[0] : operands;\n return String(path ?? '');\n }\n if (op === 'val') {\n const path = Array.isArray(operands) ? operands[0] : operands;\n return `val(${path ?? ''})`;\n }\n if (op === 'exists') {\n return `exists(${operands})`;\n }\n\n const args: JsonLogicValue[] = Array.isArray(operands) ? operands : [operands];\n\n // Helper to wrap sub-expression in parens if needed\n const wrapIfNeeded = (subVal: JsonLogicValue): string => {\n const text = toText(subVal, op);\n return needsParens(subVal, op) ? `(${text})` : text;\n };\n\n // Comparison and arithmetic: infix notation\n if ([...COMPARISON_OPERATORS, ...ARITHMETIC_BINARY_OPERATORS].includes(op)) {\n if (args.length === 2) {\n return `${wrapIfNeeded(args[0])} ${op} ${wrapIfNeeded(args[1])}`;\n }\n // Chained comparison: a < b < c\n if (args.length > 2) {\n return args.map(wrapIfNeeded).join(` ${op} `);\n }\n }\n\n // Logical operators\n if (op === 'and') {\n return args.map(wrapIfNeeded).join(' AND ');\n }\n if (op === 'or') {\n return args.map(wrapIfNeeded).join(' OR ');\n }\n\n // Unary operators\n if (UNARY_OPERATORS.includes(op)) {\n const argText = toText(args[0], op);\n const subOp = getOperator(args[0]);\n // Wrap if the argument is a complex expression\n if (subOp && (subOp === 'and' || subOp === 'or' || COMPARISON_OPERATORS.includes(subOp))) {\n return `${op}(${argText})`;\n }\n return `${op}${argText}`;\n }\n\n // Iterator operators\n if (ITERATOR_OPERATORS.includes(op)) {\n const [arr] = args;\n return `${op}(${toText(arr)}, ...)`;\n }\n\n // If/else - handle full if-elseif-else chains\n if (op === 'if' || op === '?:') {\n const parts: string[] = [];\n let i = 0;\n while (i < args.length) {\n if (i + 1 < args.length) {\n // condition-then pair\n const prefix = i === 0 ? 'if' : 'else if';\n parts.push(`${prefix} ${toText(args[i])} then ${toText(args[i + 1])}`);\n i += 2;\n } else {\n // final else value\n parts.push(`else ${toText(args[i])}`);\n i++;\n }\n }\n return parts.join(' ');\n }\n\n // Default: function notation\n return `${op}(${args.map(a => toText(a)).join(', ')})`;\n }\n\n return String(val);\n }\n\n const text = toText(value);\n if (text.length > maxLength) {\n return text.slice(0, maxLength - 3) + '...';\n }\n return text;\n}\n","import type { OperatorMeta, OperatorCategory } from '../types';\n\n// Complete registry of JSONLogic operators\nexport const OPERATORS: Record<string, OperatorMeta> = {\n // Variable operators\n var: {\n name: 'var',\n category: 'variable',\n label: 'var',\n description: 'Get a value from the data object',\n minArgs: 1,\n maxArgs: 2,\n argLabels: ['path', 'default'],\n },\n val: {\n name: 'val',\n category: 'variable',\n label: 'val',\n description: 'Get a constant value',\n minArgs: 1,\n maxArgs: 1,\n argLabels: ['path'],\n },\n exists: {\n name: 'exists',\n category: 'variable',\n label: 'exists',\n description: 'Check if a variable exists',\n minArgs: 1,\n maxArgs: 1,\n argLabels: ['path'],\n },\n\n // Comparison operators\n '==': {\n name: '==',\n category: 'comparison',\n label: '==',\n description: 'Loose equality',\n minArgs: 2,\n maxArgs: 2,\n argLabels: ['left', 'right'],\n },\n '===': {\n name: '===',\n category: 'comparison',\n label: '===',\n description: 'Strict equality',\n minArgs: 2,\n maxArgs: 2,\n argLabels: ['left', 'right'],\n },\n '!=': {\n name: '!=',\n category: 'comparison',\n label: '!=',\n description: 'Loose inequality',\n minArgs: 2,\n maxArgs: 2,\n argLabels: ['left', 'right'],\n },\n '!==': {\n name: '!==',\n category: 'comparison',\n label: '!==',\n description: 'Strict inequality',\n minArgs: 2,\n maxArgs: 2,\n argLabels: ['left', 'right'],\n },\n '>': {\n name: '>',\n category: 'comparison',\n label: '>',\n description: 'Greater than',\n minArgs: 2,\n maxArgs: 3,\n argLabels: ['left', 'right'],\n },\n '>=': {\n name: '>=',\n category: 'comparison',\n label: '>=',\n description: 'Greater than or equal',\n minArgs: 2,\n maxArgs: 3,\n argLabels: ['left', 'right'],\n },\n '<': {\n name: '<',\n category: 'comparison',\n label: '<',\n description: 'Less than',\n minArgs: 2,\n maxArgs: 3,\n argLabels: ['left', 'right'],\n },\n '<=': {\n name: '<=',\n category: 'comparison',\n label: '<=',\n description: 'Less than or equal',\n minArgs: 2,\n maxArgs: 3,\n argLabels: ['left', 'right'],\n },\n\n // Logical operators\n and: {\n name: 'and',\n category: 'logical',\n label: 'AND',\n description: 'Logical AND - all conditions must be true',\n minArgs: 1,\n },\n or: {\n name: 'or',\n category: 'logical',\n label: 'OR',\n description: 'Logical OR - at least one condition must be true',\n minArgs: 1,\n },\n '!': {\n name: '!',\n category: 'logical',\n label: 'NOT',\n description: 'Logical NOT - negates the value',\n minArgs: 1,\n maxArgs: 1,\n argLabels: ['value'],\n },\n '!!': {\n name: '!!',\n category: 'logical',\n label: 'BOOL',\n description: 'Convert to boolean',\n minArgs: 1,\n maxArgs: 1,\n argLabels: ['value'],\n },\n\n // Arithmetic operators\n '+': {\n name: '+',\n category: 'arithmetic',\n label: '+',\n description: 'Addition or string concatenation',\n minArgs: 1,\n },\n '-': {\n name: '-',\n category: 'arithmetic',\n label: '-',\n description: 'Subtraction',\n minArgs: 1,\n maxArgs: 2,\n argLabels: ['left', 'right'],\n },\n '*': {\n name: '*',\n category: 'arithmetic',\n label: '×',\n description: 'Multiplication',\n minArgs: 2,\n },\n '/': {\n name: '/',\n category: 'arithmetic',\n label: '÷',\n description: 'Division',\n minArgs: 2,\n maxArgs: 2,\n argLabels: ['dividend', 'divisor'],\n },\n '%': {\n name: '%',\n category: 'arithmetic',\n label: '%',\n description: 'Modulo',\n minArgs: 2,\n maxArgs: 2,\n argLabels: ['dividend', 'divisor'],\n },\n max: {\n name: 'max',\n category: 'arithmetic',\n label: 'max',\n description: 'Maximum value',\n minArgs: 1,\n },\n min: {\n name: 'min',\n category: 'arithmetic',\n label: 'min',\n description: 'Minimum value',\n minArgs: 1,\n },\n abs: {\n name: 'abs',\n category: 'arithmetic',\n label: 'abs',\n description: 'Absolute value',\n minArgs: 1,\n maxArgs: 1,\n argLabels: ['value'],\n },\n ceil: {\n name: 'ceil',\n category: 'arithmetic',\n label: 'ceil',\n description: 'Round up to nearest integer',\n minArgs: 1,\n maxArgs: 1,\n argLabels: ['value'],\n },\n floor: {\n name: 'floor',\n category: 'arithmetic',\n label: 'floor',\n description: 'Round down to nearest integer',\n minArgs: 1,\n maxArgs: 1,\n argLabels: ['value'],\n },\n\n // String operators\n cat: {\n name: 'cat',\n category: 'string',\n label: 'cat',\n description: 'Concatenate strings',\n minArgs: 1,\n },\n substr: {\n name: 'substr',\n category: 'string',\n label: 'substr',\n description: 'Extract substring',\n minArgs: 2,\n maxArgs: 3,\n argLabels: ['string', 'start', 'length'],\n },\n in: {\n name: 'in',\n category: 'string',\n label: 'in',\n description: 'Check if string contains substring or array contains element',\n minArgs: 2,\n maxArgs: 2,\n argLabels: ['needle', 'haystack'],\n },\n length: {\n name: 'length',\n category: 'string',\n label: 'length',\n description: 'Get string or array length',\n minArgs: 1,\n maxArgs: 1,\n argLabels: ['value'],\n },\n starts_with: {\n name: 'starts_with',\n category: 'string',\n label: 'starts_with',\n description: 'Check if string starts with substring',\n minArgs: 2,\n maxArgs: 2,\n argLabels: ['string', 'prefix'],\n },\n ends_with: {\n name: 'ends_with',\n category: 'string',\n label: 'ends_with',\n description: 'Check if string ends with substring',\n minArgs: 2,\n maxArgs: 2,\n argLabels: ['string', 'suffix'],\n },\n upper: {\n name: 'upper',\n category: 'string',\n label: 'upper',\n description: 'Convert to uppercase',\n minArgs: 1,\n maxArgs: 1,\n argLabels: ['string'],\n },\n lower: {\n name: 'lower',\n category: 'string',\n label: 'lower',\n description: 'Convert to lowercase',\n minArgs: 1,\n maxArgs: 1,\n argLabels: ['string'],\n },\n trim: {\n name: 'trim',\n category: 'string',\n label: 'trim',\n description: 'Remove leading/trailing whitespace',\n minArgs: 1,\n maxArgs: 1,\n argLabels: ['string'],\n },\n split: {\n name: 'split',\n category: 'string',\n label: 'split',\n description: 'Split string by delimiter',\n minArgs: 2,\n maxArgs: 2,\n argLabels: ['string', 'delimiter'],\n },\n\n // Array operators\n map: {\n name: 'map',\n category: 'array',\n label: 'map',\n description: 'Transform each element',\n minArgs: 2,\n maxArgs: 2,\n argLabels: ['array', 'expression'],\n },\n filter: {\n name: 'filter',\n category: 'array',\n label: 'filter',\n description: 'Filter elements by condition',\n minArgs: 2,\n maxArgs: 2,\n argLabels: ['array', 'condition'],\n },\n reduce: {\n name: 'reduce',\n category: 'array',\n label: 'reduce',\n description: 'Reduce array to single value',\n minArgs: 3,\n maxArgs: 3,\n argLabels: ['array', 'expression', 'initial'],\n },\n all: {\n name: 'all',\n category: 'array',\n label: 'all',\n description: 'Check if all elements match condition',\n minArgs: 2,\n maxArgs: 2,\n argLabels: ['array', 'condition'],\n },\n some: {\n name: 'some',\n category: 'array',\n label: 'some',\n description: 'Check if any element matches condition',\n minArgs: 2,\n maxArgs: 2,\n argLabels: ['array', 'condition'],\n },\n none: {\n name: 'none',\n category: 'array',\n label: 'none',\n description: 'Check if no elements match condition',\n minArgs: 2,\n maxArgs: 2,\n argLabels: ['array', 'condition'],\n },\n merge: {\n name: 'merge',\n category: 'array',\n label: 'merge',\n description: 'Merge multiple arrays',\n minArgs: 1,\n },\n sort: {\n name: 'sort',\n category: 'array',\n label: 'sort',\n description: 'Sort array elements',\n minArgs: 1,\n maxArgs: 2,\n argLabels: ['array', 'expression'],\n },\n slice: {\n name: 'slice',\n category: 'array',\n label: 'slice',\n description: 'Extract portion of array',\n minArgs: 2,\n maxArgs: 3,\n argLabels: ['array', 'start', 'end'],\n },\n\n // Control flow operators\n if: {\n name: 'if',\n category: 'control',\n label: 'if',\n description: 'Conditional branching',\n minArgs: 2,\n argLabels: ['condition', 'then', 'else'],\n },\n '?:': {\n name: '?:',\n category: 'control',\n label: '?:',\n description: 'Ternary operator',\n minArgs: 3,\n maxArgs: 3,\n argLabels: ['condition', 'then', 'else'],\n },\n '??': {\n name: '??',\n category: 'control',\n label: '??',\n description: 'Nullish coalescing',\n minArgs: 2,\n maxArgs: 2,\n argLabels: ['value', 'fallback'],\n },\n\n // DateTime operators\n now: {\n name: 'now',\n category: 'datetime',\n label: 'now',\n description: 'Current timestamp',\n minArgs: 0,\n maxArgs: 0,\n },\n datetime: {\n name: 'datetime',\n category: 'datetime',\n label: 'datetime',\n description: 'Create datetime from components',\n minArgs: 1,\n maxArgs: 7,\n argLabels: ['year', 'month', 'day', 'hour', 'minute', 'second', 'ms'],\n },\n timestamp: {\n name: 'timestamp',\n category: 'datetime',\n label: 'timestamp',\n description: 'Convert to timestamp',\n minArgs: 1,\n maxArgs: 1,\n argLabels: ['datetime'],\n },\n parse_date: {\n name: 'parse_date',\n category: 'datetime',\n label: 'parse_date',\n description: 'Parse date string',\n minArgs: 1,\n maxArgs: 2,\n argLabels: ['string', 'format'],\n },\n format_date: {\n name: 'format_date',\n category: 'datetime',\n label: 'format_date',\n description: 'Format date to string',\n minArgs: 2,\n maxArgs: 2,\n argLabels: ['datetime', 'format'],\n },\n date_diff: {\n name: 'date_diff',\n category: 'datetime',\n label: 'date_diff',\n description: 'Difference between dates',\n minArgs: 2,\n maxArgs: 3,\n argLabels: ['date1', 'date2', 'unit'],\n },\n\n // Error handling operators\n try: {\n name: 'try',\n category: 'error',\n label: 'try',\n description: 'Try expression with fallback',\n minArgs: 2,\n maxArgs: 2,\n argLabels: ['expression', 'fallback'],\n },\n throw: {\n name: 'throw',\n category: 'error',\n label: 'throw',\n description: 'Throw an error',\n minArgs: 1,\n maxArgs: 1,\n argLabels: ['message'],\n },\n};\n\n// Get operator metadata with fallback for unknown operators\nexport function getOperatorMeta(operator: string): OperatorMeta {\n return (\n OPERATORS[operator] || {\n name: operator,\n category: 'literal' as OperatorCategory,\n label: operator,\n description: `Unknown operator: ${operator}`,\n }\n );\n}\n\n// Check if a key is a known operator\nexport function isOperator(key: string): boolean {\n return key in OPERATORS;\n}\n","// Truncation limits for various display contexts\nexport const TRUNCATION_LIMITS = {\n shortLabel: 20,\n expressionText: 50,\n collapsedView: 100,\n} as const;\n","// Layout configuration constants for the dagre tree layout\n\n// Node dimension constraints\nexport const NODE_DIMENSIONS = {\n minWidth: 160,\n maxWidth: 450,\n defaultHeight: 80,\n} as const;\n\n// Vertical cell node specific dimensions\nexport const VERTICAL_CELL_DIMENSIONS = {\n rowHeight: 32,\n headerHeight: 28,\n collapsedBodyHeight: 40,\n} as const;\n\n// Text measurement estimates for width calculation\nexport const TEXT_METRICS = {\n // Monospace font width (~8px per character for safety margin)\n charWidthMono: 8,\n // Regular font width (~7.5px per character)\n charWidthRegular: 7.5,\n} as const;\n\n// Padding and spacing for nodes\nexport const NODE_PADDING = {\n // Total padding for borders, icons, margins, collapse buttons, result badges\n contentPadding: 80,\n // Icon width estimate\n iconWidth: 30,\n // Type icon prefix width\n typeIconWidth: 25,\n} as const;\n\n// Dagre layout algorithm options\nexport const DAGRE_OPTIONS = {\n // Gap between ranks (horizontal for LR layout)\n rankSep: 80,\n // Vertical separation between nodes in same rank\n nodeSep: 40,\n // Separation between edges\n edgeSep: 20,\n // Margins\n marginX: 50,\n marginY: 50,\n // Layout direction (left-to-right for horizontal flow)\n rankDir: 'LR' as const,\n} as const;\n\n// Fixed widths for specific node types\nexport const FIXED_WIDTHS = {\n fallbackNode: 100,\n decisionNode: 180,\n} as const;\n\n// Decision node specific dimensions\nexport const DECISION_NODE_DIMENSIONS = {\n minWidth: 180,\n // Header (28px) + 3 rows (32px each) + padding (8px) = 132px\n height: 132,\n} as const;\n","// Centralized handle ID generation for consistent edge connections\n\n// Handle ID generators\nexport const HANDLE_IDS = {\n // Argument handles (for operator children)\n arg: (index: number): string => `arg-${index}`,\n\n // Branch handles (for vertical cell branches)\n branch: (index: number): string => `branch-${index}`,\n\n // Fixed handle IDs for specific purposes\n top: 'top',\n left: 'left',\n right: 'right',\n bottom: 'bottom',\n\n // Conditional handles\n condition: 'condition',\n thenBranch: 'then',\n elseBranch: 'else',\n} as const;\n\n// Handle positions for vertical cell rows (in pixels from top of 32px row)\nexport const HANDLE_POSITIONS = {\n // Condition branch - positioned at 30% of row height\n conditionTop: 10,\n // Then/Yes branch - positioned at 70% of row height\n thenTop: 22,\n // Standard single branch - centered vertically\n centeredTop: 16,\n} as const;\n\n// Edge ID generators for consistent edge naming\nexport const EDGE_IDS = {\n // Standard parent-child edge\n parentChild: (parentId: string, childId: string): string =>\n `${parentId}-${childId}`,\n\n // Branch edge\n branch: (parentId: string, branchId: string): string =>\n `${parentId}-branch-${branchId}`,\n\n // Condition edge\n condition: (parentId: string, conditionId: string): string =>\n `${parentId}-cond-${conditionId}`,\n\n // Then edge\n then: (parentId: string, thenId: string): string =>\n `${parentId}-then-${thenId}`,\n\n // Else edge\n else: (parentId: string, elseId: string): string =>\n `${parentId}-else-${elseId}`,\n} as const;\n","/**\n * @license lucide-react v0.562.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nconst toKebabCase = (string) => string.replace(/([a-z0-9])([A-Z])/g, \"$1-$2\").toLowerCase();\nconst toCamelCase = (string) => string.replace(\n /^([A-Z])|[\\s-_]+(\\w)/g,\n (match, p1, p2) => p2 ? p2.toUpperCase() : p1.toLowerCase()\n);\nconst toPascalCase = (string) => {\n const camelCase = toCamelCase(string);\n return camelCase.charAt(0).toUpperCase() + camelCase.slice(1);\n};\nconst mergeClasses = (...classes) => classes.filter((className, index, array) => {\n return Boolean(className) && className.trim() !== \"\" && array.indexOf(className) === index;\n}).join(\" \").trim();\nconst hasA11yProp = (props) => {\n for (const prop in props) {\n if (prop.startsWith(\"aria-\") || prop === \"role\" || prop === \"title\") {\n return true;\n }\n }\n};\n\nexport { hasA11yProp, mergeClasses, toCamelCase, toKebabCase, toPascalCase };\n//# sourceMappingURL=utils.js.map\n","/**\n * @license lucide-react v0.562.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nvar defaultAttributes = {\n xmlns: \"http://www.w3.org/2000/svg\",\n width: 24,\n height: 24,\n viewBox: \"0 0 24 24\",\n fill: \"none\",\n stroke: \"currentColor\",\n strokeWidth: 2,\n strokeLinecap: \"round\",\n strokeLinejoin: \"round\"\n};\n\nexport { defaultAttributes as default };\n//# sourceMappingURL=defaultAttributes.js.map\n","/**\n * @license lucide-react v0.562.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport { forwardRef, createElement } from 'react';\nimport defaultAttributes from './defaultAttributes.js';\nimport { mergeClasses, hasA11yProp } from './shared/src/utils.js';\n\nconst Icon = forwardRef(\n ({\n color = \"currentColor\",\n size = 24,\n strokeWidth = 2,\n absoluteStrokeWidth,\n className = \"\",\n children,\n iconNode,\n ...rest\n }, ref) => createElement(\n \"svg\",\n {\n ref,\n ...defaultAttributes,\n width: size,\n height: size,\n stroke: color,\n strokeWidth: absoluteStrokeWidth ? Number(strokeWidth) * 24 / Number(size) : strokeWidth,\n className: mergeClasses(\"lucide\", className),\n ...!children && !hasA11yProp(rest) && { \"aria-hidden\": \"true\" },\n ...rest\n },\n [\n ...iconNode.map(([tag, attrs]) => createElement(tag, attrs)),\n ...Array.isArray(children) ? children : [children]\n ]\n )\n);\n\nexport { Icon as default };\n//# sourceMappingURL=Icon.js.map\n","/**\n * @license lucide-react v0.562.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport { forwardRef, createElement } from 'react';\nimport { mergeClasses, toKebabCase, toPascalCase } from './shared/src/utils.js';\nimport Icon from './Icon.js';\n\nconst createLucideIcon = (iconName, iconNode) => {\n const Component = forwardRef(\n ({ className, ...props }, ref) => createElement(Icon, {\n ref,\n iconNode,\n className: mergeClasses(\n `lucide-${toKebabCase(toPascalCase(iconName))}`,\n `lucide-${iconName}`,\n className\n ),\n ...props\n })\n );\n Component.displayName = toPascalCase(iconName);\n return Component;\n};\n\nexport { createLucideIcon as default };\n//# sourceMappingURL=createLucideIcon.js.map\n","/**\n * @license lucide-react v0.562.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport createLucideIcon from '../createLucideIcon.js';\n\nconst __iconNode = [\n [\"path\", { d: \"M4.929 4.929 19.07 19.071\", key: \"196cmz\" }],\n [\"circle\", { cx: \"12\", cy: \"12\", r: \"10\", key: \"1mglay\" }]\n];\nconst Ban = createLucideIcon(\"ban\", __iconNode);\n\nexport { __iconNode, Ban as default };\n//# sourceMappingURL=ban.js.map\n","/**\n * @license lucide-react v0.562.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport createLucideIcon from '../createLucideIcon.js';\n\nconst __iconNode = [\n [\n \"path\",\n {\n d: \"M21 8a2 2 0 0 0-1-1.73l-7-4a2 2 0 0 0-2 0l-7 4A2 2 0 0 0 3 8v8a2 2 0 0 0 1 1.73l7 4a2 2 0 0 0 2 0l7-4A2 2 0 0 0 21 16Z\",\n key: \"hh9hay\"\n }\n ],\n [\"path\", { d: \"m3.3 7 8.7 5 8.7-5\", key: \"g66t2b\" }],\n [\"path\", { d: \"M12 22V12\", key: \"d0xqtd\" }]\n];\nconst Box = createLucideIcon(\"box\", __iconNode);\n\nexport { __iconNode, Box as default };\n//# sourceMappingURL=box.js.map\n","/**\n * @license lucide-react v0.562.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport createLucideIcon from '../createLucideIcon.js';\n\nconst __iconNode = [\n [\n \"path\",\n {\n d: \"M2.97 12.92A2 2 0 0 0 2 14.63v3.24a2 2 0 0 0 .97 1.71l3 1.8a2 2 0 0 0 2.06 0L12 19v-5.5l-5-3-4.03 2.42Z\",\n key: \"lc1i9w\"\n }\n ],\n [\"path\", { d: \"m7 16.5-4.74-2.85\", key: \"1o9zyk\" }],\n [\"path\", { d: \"m7 16.5 5-3\", key: \"va8pkn\" }],\n [\"path\", { d: \"M7 16.5v5.17\", key: \"jnp8gn\" }],\n [\n \"path\",\n {\n d: \"M12 13.5V19l3.97 2.38a2 2 0 0 0 2.06 0l3-1.8a2 2 0 0 0 .97-1.71v-3.24a2 2 0 0 0-.97-1.71L17 10.5l-5 3Z\",\n key: \"8zsnat\"\n }\n ],\n [\"path\", { d: \"m17 16.5-5-3\", key: \"8arw3v\" }],\n [\"path\", { d: \"m17 16.5 4.74-2.85\", key: \"8rfmw\" }],\n [\"path\", { d: \"M17 16.5v5.17\", key: \"k6z78m\" }],\n [\n \"path\",\n {\n d: \"M7.97 4.42A2 2 0 0 0 7 6.13v4.37l5 3 5-3V6.13a2 2 0 0 0-.97-1.71l-3-1.8a2 2 0 0 0-2.06 0l-3 1.8Z\",\n key: \"1xygjf\"\n }\n ],\n [\"path\", { d: \"M12 8 7.26 5.15\", key: \"1vbdud\" }],\n [\"path\", { d: \"m12 8 4.74-2.85\", key: \"3rx089\" }],\n [\"path\", { d: \"M12 13.5V8\", key: \"1io7kd\" }]\n];\nconst Boxes = createLucideIcon(\"boxes\", __iconNode);\n\nexport { __iconNode, Boxes as default };\n//# sourceMappingURL=boxes.js.map\n","/**\n * @license lucide-react v0.562.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport createLucideIcon from '../createLucideIcon.js';\n\nconst __iconNode = [\n [\"path\", { d: \"M12 20v-9\", key: \"1qisl0\" }],\n [\"path\", { d: \"M14 7a4 4 0 0 1 4 4v3a6 6 0 0 1-12 0v-3a4 4 0 0 1 4-4z\", key: \"uouzyp\" }],\n [\"path\", { d: \"M14.12 3.88 16 2\", key: \"qol33r\" }],\n [\"path\", { d: \"M21 21a4 4 0 0 0-3.81-4\", key: \"1b0z45\" }],\n [\"path\", { d: \"M21 5a4 4 0 0 1-3.55 3.97\", key: \"5cxbf6\" }],\n [\"path\", { d: \"M22 13h-4\", key: \"1jl80f\" }],\n [\"path\", { d: \"M3 21a4 4 0 0 1 3.81-4\", key: \"1fjd4g\" }],\n [\"path\", { d: \"M3 5a4 4 0 0 0 3.55 3.97\", key: \"1d7oge\" }],\n [\"path\", { d: \"M6 13H2\", key: \"82j7cp\" }],\n [\"path\", { d: \"m8 2 1.88 1.88\", key: \"fmnt4t\" }],\n [\"path\", { d: \"M9 7.13V6a3 3 0 1 1 6 0v1.13\", key: \"1vgav8\" }]\n];\nconst Bug = createLucideIcon(\"bug\", __iconNode);\n\nexport { __iconNode, Bug as default };\n//# sourceMappingURL=bug.js.map\n","/**\n * @license lucide-react v0.562.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport createLucideIcon from '../createLucideIcon.js';\n\nconst __iconNode = [\n [\"rect\", { width: \"16\", height: \"20\", x: \"4\", y: \"2\", rx: \"2\", key: \"1nb95v\" }],\n [\"line\", { x1: \"8\", x2: \"16\", y1: \"6\", y2: \"6\", key: \"x4nwl0\" }],\n [\"line\", { x1: \"16\", x2: \"16\", y1: \"14\", y2: \"18\", key: \"wjye3r\" }],\n [\"path\", { d: \"M16 10h.01\", key: \"1m94wz\" }],\n [\"path\", { d: \"M12 10h.01\", key: \"1nrarc\" }],\n [\"path\", { d: \"M8 10h.01\", key: \"19clt8\" }],\n [\"path\", { d: \"M12 14h.01\", key: \"1etili\" }],\n [\"path\", { d: \"M8 14h.01\", key: \"6423bh\" }],\n [\"path\", { d: \"M12 18h.01\", key: \"mhygvu\" }],\n [\"path\", { d: \"M8 18h.01\", key: \"lrp35t\" }]\n];\nconst Calculator = createLucideIcon(\"calculator\", __iconNode);\n\nexport { __iconNode, Calculator as default };\n//# sourceMappingURL=calculator.js.map\n","/**\n * @license lucide-react v0.562.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport createLucideIcon from '../createLucideIcon.js';\n\nconst __iconNode = [\n [\"path\", { d: \"M8 2v4\", key: \"1cmpym\" }],\n [\"path\", { d: \"M16 2v4\", key: \"4m81vk\" }],\n [\"rect\", { width: \"18\", height: \"18\", x: \"3\", y: \"4\", rx: \"2\", key: \"1hopcy\" }],\n [\"path\", { d: \"M3 10h18\", key: \"8toen8\" }]\n];\nconst Calendar = createLucideIcon(\"calendar\", __iconNode);\n\nexport { __iconNode, Calendar as default };\n//# sourceMappingURL=calendar.js.map\n","/**\n * @license lucide-react v0.562.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport createLucideIcon from '../createLucideIcon.js';\n\nconst __iconNode = [[\"path\", { d: \"M20 6 9 17l-5-5\", key: \"1gmf2c\" }]];\nconst Check = createLucideIcon(\"check\", __iconNode);\n\nexport { __iconNode, Check as default };\n//# sourceMappingURL=check.js.map\n","/**\n * @license lucide-react v0.562.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport createLucideIcon from '../createLucideIcon.js';\n\nconst __iconNode = [[\"path\", { d: \"m15 18-6-6 6-6\", key: \"1wnfg3\" }]];\nconst ChevronLeft = createLucideIcon(\"chevron-left\", __iconNode);\n\nexport { __iconNode, ChevronLeft as default };\n//# sourceMappingURL=chevron-left.js.map\n","/**\n * @license lucide-react v0.562.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport createLucideIcon from '../createLucideIcon.js';\n\nconst __iconNode = [[\"path\", { d: \"m9 18 6-6-6-6\", key: \"mthhwq\" }]];\nconst ChevronRight = createLucideIcon(\"chevron-right\", __iconNode);\n\nexport { __iconNode, ChevronRight as default };\n//# sourceMappingURL=chevron-right.js.map\n","/**\n * @license lucide-react v0.562.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport createLucideIcon from '../createLucideIcon.js';\n\nconst __iconNode = [\n [\"circle\", { cx: \"12\", cy: \"12\", r: \"10\", key: \"1mglay\" }],\n [\"path\", { d: \"M9.09 9a3 3 0 0 1 5.83 1c0 2-3 3-3 3\", key: \"1u773s\" }],\n [\"path\", { d: \"M12 17h.01\", key: \"p32p05\" }]\n];\nconst CircleQuestionMark = createLucideIcon(\"circle-question-mark\", __iconNode);\n\nexport { __iconNode, CircleQuestionMark as default };\n//# sourceMappingURL=circle-question-mark.js.map\n","/**\n * @license lucide-react v0.562.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport createLucideIcon from '../createLucideIcon.js';\n\nconst __iconNode = [\n [\"circle\", { cx: \"12\", cy: \"12\", r: \"10\", key: \"1mglay\" }],\n [\"path\", { d: \"m15 9-6 6\", key: \"1uzhvr\" }],\n [\"path\", { d: \"m9 9 6 6\", key: \"z0biqf\" }]\n];\nconst CircleX = createLucideIcon(\"circle-x\", __iconNode);\n\nexport { __iconNode, CircleX as default };\n//# sourceMappingURL=circle-x.js.map\n","/**\n * @license lucide-react v0.562.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport createLucideIcon from '../createLucideIcon.js';\n\nconst __iconNode = [\n [\"path\", { d: \"M11 10.27 7 3.34\", key: \"16pf9h\" }],\n [\"path\", { d: \"m11 13.73-4 6.93\", key: \"794ttg\" }],\n [\"path\", { d: \"M12 22v-2\", key: \"1osdcq\" }],\n [\"path\", { d: \"M12 2v2\", key: \"tus03m\" }],\n [\"path\", { d: \"M14 12h8\", key: \"4f43i9\" }],\n [\"path\", { d: \"m17 20.66-1-1.73\", key: \"eq3orb\" }],\n [\"path\", { d: \"m17 3.34-1 1.73\", key: \"2wel8s\" }],\n [\"path\", { d: \"M2 12h2\", key: \"1t8f8n\" }],\n [\"path\", { d: \"m20.66 17-1.73-1\", key: \"sg0v6f\" }],\n [\"path\", { d: \"m20.66 7-1.73 1\", key: \"1ow05n\" }],\n [\"path\", { d: \"m3.34 17 1.73-1\", key: \"nuk764\" }],\n [\"path\", { d: \"m3.34 7 1.73 1\", key: \"1ulond\" }],\n [\"circle\", { cx: \"12\", cy: \"12\", r: \"2\", key: \"1c9p78\" }],\n [\"circle\", { cx: \"12\", cy: \"12\", r: \"8\", key: \"46899m\" }]\n];\nconst Cog = createLucideIcon(\"cog\", __iconNode);\n\nexport { __iconNode, Cog as default };\n//# sourceMappingURL=cog.js.map\n","/**\n * @license lucide-react v0.562.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport createLucideIcon from '../createLucideIcon.js';\n\nconst __iconNode = [\n [\"ellipse\", { cx: \"12\", cy: \"5\", rx: \"9\", ry: \"3\", key: \"msslwz\" }],\n [\"path\", { d: \"M3 5V19A9 3 0 0 0 21 19V5\", key: \"1wlel7\" }],\n [\"path\", { d: \"M3 12A9 3 0 0 0 21 12\", key: \"mv7ke4\" }]\n];\nconst Database = createLucideIcon(\"database\", __iconNode);\n\nexport { __iconNode, Database as default };\n//# sourceMappingURL=database.js.map\n","/**\n * @license lucide-react v0.562.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport createLucideIcon from '../createLucideIcon.js';\n\nconst __iconNode = [\n [\n \"path\",\n {\n d: \"M2.7 10.3a2.41 2.41 0 0 0 0 3.41l7.59 7.59a2.41 2.41 0 0 0 3.41 0l7.59-7.59a2.41 2.41 0 0 0 0-3.41l-7.59-7.59a2.41 2.41 0 0 0-3.41 0Z\",\n key: \"1f1r0c\"\n }\n ]\n];\nconst Diamond = createLucideIcon(\"diamond\", __iconNode);\n\nexport { __iconNode, Diamond as default };\n//# sourceMappingURL=diamond.js.map\n","/**\n * @license lucide-react v0.562.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport createLucideIcon from '../createLucideIcon.js';\n\nconst __iconNode = [\n [\"circle\", { cx: \"12\", cy: \"6\", r: \"1\", key: \"1bh7o1\" }],\n [\"line\", { x1: \"5\", x2: \"19\", y1: \"12\", y2: \"12\", key: \"13b5wn\" }],\n [\"circle\", { cx: \"12\", cy: \"18\", r: \"1\", key: \"lqb9t5\" }]\n];\nconst Divide = createLucideIcon(\"divide\", __iconNode);\n\nexport { __iconNode, Divide as default };\n//# sourceMappingURL=divide.js.map\n","/**\n * @license lucide-react v0.562.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport createLucideIcon from '../createLucideIcon.js';\n\nconst __iconNode = [\n [\"circle\", { cx: \"12\", cy: \"12\", r: \"3\", key: \"1v7zrd\" }],\n [\"line\", { x1: \"3\", x2: \"9\", y1: \"12\", y2: \"12\", key: \"1dyftd\" }],\n [\"line\", { x1: \"15\", x2: \"21\", y1: \"12\", y2: \"12\", key: \"oup4p8\" }]\n];\nconst GitCommitHorizontal = createLucideIcon(\"git-commit-horizontal\", __iconNode);\n\nexport { __iconNode, GitCommitHorizontal as default };\n//# sourceMappingURL=git-commit-horizontal.js.map\n","/**\n * @license lucide-react v0.562.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport createLucideIcon from '../createLucideIcon.js';\n\nconst __iconNode = [\n [\"circle\", { cx: \"18\", cy: \"18\", r: \"3\", key: \"1xkwt0\" }],\n [\"circle\", { cx: \"6\", cy: \"6\", r: \"3\", key: \"1lh9wr\" }],\n [\"path\", { d: \"M6 21V9a9 9 0 0 0 9 9\", key: \"7kw0sc\" }]\n];\nconst GitMerge = createLucideIcon(\"git-merge\", __iconNode);\n\nexport { __iconNode, GitMerge as default };\n//# sourceMappingURL=git-merge.js.map\n","/**\n * @license lucide-react v0.562.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport createLucideIcon from '../createLucideIcon.js';\n\nconst __iconNode = [\n [\"line\", { x1: \"4\", x2: \"20\", y1: \"9\", y2: \"9\", key: \"4lhtct\" }],\n [\"line\", { x1: \"4\", x2: \"20\", y1: \"15\", y2: \"15\", key: \"vyu0kd\" }],\n [\"line\", { x1: \"10\", x2: \"8\", y1: \"3\", y2: \"21\", key: \"1ggp8o\" }],\n [\"line\", { x1: \"16\", x2: \"14\", y1: \"3\", y2: \"21\", key: \"weycgp\" }]\n];\nconst Hash = createLucideIcon(\"hash\", __iconNode);\n\nexport { __iconNode, Hash as default };\n//# sourceMappingURL=hash.js.map\n","/**\n * @license lucide-react v0.562.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport createLucideIcon from '../createLucideIcon.js';\n\nconst __iconNode = [\n [\"path\", { d: \"M3 5h.01\", key: \"18ugdj\" }],\n [\"path\", { d: \"M3 12h.01\", key: \"nlz23k\" }],\n [\"path\", { d: \"M3 19h.01\", key: \"noohij\" }],\n [\"path\", { d: \"M8 5h13\", key: \"1pao27\" }],\n [\"path\", { d: \"M8 12h13\", key: \"1za7za\" }],\n [\"path\", { d: \"M8 19h13\", key: \"m83p4d\" }]\n];\nconst List = createLucideIcon(\"list\", __iconNode);\n\nexport { __iconNode, List as default };\n//# sourceMappingURL=list.js.map\n","/**\n * @license lucide-react v0.562.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport createLucideIcon from '../createLucideIcon.js';\n\nconst __iconNode = [\n [\"rect\", { x: \"14\", y: \"3\", width: \"5\", height: \"18\", rx: \"1\", key: \"kaeet6\" }],\n [\"rect\", { x: \"5\", y: \"3\", width: \"5\", height: \"18\", rx: \"1\", key: \"1wsw3u\" }]\n];\nconst Pause = createLucideIcon(\"pause\", __iconNode);\n\nexport { __iconNode, Pause as default };\n//# sourceMappingURL=pause.js.map\n","/**\n * @license lucide-react v0.562.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport createLucideIcon from '../createLucideIcon.js';\n\nconst __iconNode = [\n [\n \"path\",\n {\n d: \"M5 5a2 2 0 0 1 3.008-1.728l11.997 6.998a2 2 0 0 1 .003 3.458l-12 7A2 2 0 0 1 5 19z\",\n key: \"10ikf1\"\n }\n ]\n];\nconst Play = createLucideIcon(\"play\", __iconNode);\n\nexport { __iconNode, Play as default };\n//# sourceMappingURL=play.js.map\n","/**\n * @license lucide-react v0.562.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport createLucideIcon from '../createLucideIcon.js';\n\nconst __iconNode = [\n [\n \"path\",\n {\n d: \"M16 3a2 2 0 0 0-2 2v6a2 2 0 0 0 2 2 1 1 0 0 1 1 1v1a2 2 0 0 1-2 2 1 1 0 0 0-1 1v2a1 1 0 0 0 1 1 6 6 0 0 0 6-6V5a2 2 0 0 0-2-2z\",\n key: \"rib7q0\"\n }\n ],\n [\n \"path\",\n {\n d: \"M5 3a2 2 0 0 0-2 2v6a2 2 0 0 0 2 2 1 1 0 0 1 1 1v1a2 2 0 0 1-2 2 1 1 0 0 0-1 1v2a1 1 0 0 0 1 1 6 6 0 0 0 6-6V5a2 2 0 0 0-2-2z\",\n key: \"1ymkrd\"\n }\n ]\n];\nconst Quote = createLucideIcon(\"quote\", __iconNode);\n\nexport { __iconNode, Quote as default };\n//# sourceMappingURL=quote.js.map\n","/**\n * @license lucide-react v0.562.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport createLucideIcon from '../createLucideIcon.js';\n\nconst __iconNode = [\n [\"path\", { d: \"m17 2 4 4-4 4\", key: \"nntrym\" }],\n [\"path\", { d: \"M3 11v-1a4 4 0 0 1 4-4h14\", key: \"84bu3i\" }],\n [\"path\", { d: \"m7 22-4-4 4-4\", key: \"1wqhfi\" }],\n [\"path\", { d: \"M21 13v1a4 4 0 0 1-4 4H3\", key: \"1rx37r\" }]\n];\nconst Repeat = createLucideIcon(\"repeat\", __iconNode);\n\nexport { __iconNode, Repeat as default };\n//# sourceMappingURL=repeat.js.map\n","/**\n * @license lucide-react v0.562.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport createLucideIcon from '../createLucideIcon.js';\n\nconst __iconNode = [\n [\"path\", { d: \"M12 3v18\", key: \"108xh3\" }],\n [\"path\", { d: \"m19 8 3 8a5 5 0 0 1-6 0zV7\", key: \"zcdpyk\" }],\n [\"path\", { d: \"M3 7h1a17 17 0 0 0 8-2 17 17 0 0 0 8 2h1\", key: \"1yorad\" }],\n [\"path\", { d: \"m5 8 3 8a5 5 0 0 1-6 0zV7\", key: \"eua70x\" }],\n [\"path\", { d: \"M7 21h10\", key: \"1b0cd5\" }]\n];\nconst Scale = createLucideIcon(\"scale\", __iconNode);\n\nexport { __iconNode, Scale as default };\n//# sourceMappingURL=scale.js.map\n","/**\n * @license lucide-react v0.562.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport createLucideIcon from '../createLucideIcon.js';\n\nconst __iconNode = [\n [\"path\", { d: \"m21 21-4.34-4.34\", key: \"14j7rj\" }],\n [\"circle\", { cx: \"11\", cy: \"11\", r: \"8\", key: \"4ej97u\" }]\n];\nconst Search = createLucideIcon(\"search\", __iconNode);\n\nexport { __iconNode, Search as default };\n//# sourceMappingURL=search.js.map\n","/**\n * @license lucide-react v0.562.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport createLucideIcon from '../createLucideIcon.js';\n\nconst __iconNode = [\n [\n \"path\",\n {\n d: \"M17.971 4.285A2 2 0 0 1 21 6v12a2 2 0 0 1-3.029 1.715l-9.997-5.998a2 2 0 0 1-.003-3.432z\",\n key: \"15892j\"\n }\n ],\n [\"path\", { d: \"M3 20V4\", key: \"1ptbpl\" }]\n];\nconst SkipBack = createLucideIcon(\"skip-back\", __iconNode);\n\nexport { __iconNode, SkipBack as default };\n//# sourceMappingURL=skip-back.js.map\n","/**\n * @license lucide-react v0.562.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport createLucideIcon from '../createLucideIcon.js';\n\nconst __iconNode = [\n [\"path\", { d: \"M21 4v16\", key: \"7j8fe9\" }],\n [\n \"path\",\n {\n d: \"M6.029 4.285A2 2 0 0 0 3 6v12a2 2 0 0 0 3.029 1.715l9.997-5.998a2 2 0 0 0 .003-3.432z\",\n key: \"zs4d6\"\n }\n ]\n];\nconst SkipForward = createLucideIcon(\"skip-forward\", __iconNode);\n\nexport { __iconNode, SkipForward as default };\n//# sourceMappingURL=skip-forward.js.map\n","/**\n * @license lucide-react v0.562.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport createLucideIcon from '../createLucideIcon.js';\n\nconst __iconNode = [\n [\"path\", { d: \"M21 5H3\", key: \"1fi0y6\" }],\n [\"path\", { d: \"M15 12H3\", key: \"6jk70r\" }],\n [\"path\", { d: \"M17 19H3\", key: \"z6ezky\" }]\n];\nconst TextAlignStart = createLucideIcon(\"text-align-start\", __iconNode);\n\nexport { __iconNode, TextAlignStart as default };\n//# sourceMappingURL=text-align-start.js.map\n","/**\n * @license lucide-react v0.562.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport createLucideIcon from '../createLucideIcon.js';\n\nconst __iconNode = [\n [\"circle\", { cx: \"9\", cy: \"12\", r: \"3\", key: \"u3jwor\" }],\n [\"rect\", { width: \"20\", height: \"14\", x: \"2\", y: \"5\", rx: \"7\", key: \"g7kal2\" }]\n];\nconst ToggleLeft = createLucideIcon(\"toggle-left\", __iconNode);\n\nexport { __iconNode, ToggleLeft as default };\n//# sourceMappingURL=toggle-left.js.map\n","/**\n * @license lucide-react v0.562.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport createLucideIcon from '../createLucideIcon.js';\n\nconst __iconNode = [\n [\"circle\", { cx: \"15\", cy: \"12\", r: \"3\", key: \"1afu0r\" }],\n [\"rect\", { width: \"20\", height: \"14\", x: \"2\", y: \"5\", rx: \"7\", key: \"g7kal2\" }]\n];\nconst ToggleRight = createLucideIcon(\"toggle-right\", __iconNode);\n\nexport { __iconNode, ToggleRight as default };\n//# sourceMappingURL=toggle-right.js.map\n","/**\n * @license lucide-react v0.562.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport createLucideIcon from '../createLucideIcon.js';\n\nconst __iconNode = [\n [\"path\", { d: \"M12 4v16\", key: \"1654pz\" }],\n [\"path\", { d: \"M4 7V5a1 1 0 0 1 1-1h14a1 1 0 0 1 1 1v2\", key: \"e0r10z\" }],\n [\"path\", { d: \"M9 20h6\", key: \"s66wpe\" }]\n];\nconst Type = createLucideIcon(\"type\", __iconNode);\n\nexport { __iconNode, Type as default };\n//# sourceMappingURL=type.js.map\n","/**\n * @license lucide-react v0.562.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport createLucideIcon from '../createLucideIcon.js';\n\nconst __iconNode = [\n [\"path\", { d: \"M18 6 6 18\", key: \"1bl5f8\" }],\n [\"path\", { d: \"m6 6 12 12\", key: \"d8bk6v\" }]\n];\nconst X = createLucideIcon(\"x\", __iconNode);\n\nexport { __iconNode, X as default };\n//# sourceMappingURL=x.js.map\n","import React from 'react';\nimport type { LucideIcon } from 'lucide-react';\nimport {\n Scale,\n Diamond,\n Calculator,\n Repeat,\n Type,\n Box,\n GitMerge,\n Text,\n Hash,\n ToggleLeft,\n ToggleRight,\n Check,\n X,\n Ban,\n List,\n Calendar,\n Cog,\n Database,\n Boxes,\n CircleHelp,\n CircleX,\n GitCommitHorizontal,\n Search,\n Divide,\n Quote,\n} from 'lucide-react';\nimport type { IconName } from './icons';\n\n// Map icon names to Lucide components\nconst ICON_COMPONENTS: Record<IconName, LucideIcon> = {\n 'scale': Scale,\n 'diamond': Diamond,\n 'calculator': Calculator,\n 'repeat': Repeat,\n 'type': Type,\n 'box': Box,\n 'git-merge': GitMerge,\n 'text': Text,\n 'hash': Hash,\n 'toggle-left': ToggleLeft,\n 'toggle-right': ToggleRight,\n 'check': Check,\n 'x': X,\n 'ban': Ban,\n 'list': List,\n 'calendar': Calendar,\n 'cog': Cog,\n 'database': Database,\n 'boxes': Boxes,\n 'circle-help': CircleHelp,\n 'circle-x': CircleX,\n 'git-commit-horizontal': GitCommitHorizontal,\n 'search': Search,\n 'divide': Divide,\n 'quote': Quote,\n};\n\n// Render an icon by name\ninterface IconProps {\n name: IconName;\n size?: number;\n className?: string;\n style?: React.CSSProperties;\n}\n\nexport function Icon({ name, size = 14, className, style }: IconProps): React.ReactElement {\n const IconComponent = ICON_COMPONENTS[name];\n return <IconComponent size={size} className={className} style={style} />;\n}\n","import type { JsonLogicValue, LiteralNodeData } from '../types';\nimport { isPlainObject, looksLikeDate } from './type-helpers';\n\n// Icon name type for all available icons\nexport type IconName =\n | 'scale'\n | 'diamond'\n | 'calculator'\n | 'repeat'\n | 'type'\n | 'box'\n | 'git-merge'\n | 'text'\n | 'hash'\n | 'toggle-left'\n | 'toggle-right'\n | 'check'\n | 'x'\n | 'ban'\n | 'list'\n | 'calendar'\n | 'cog'\n | 'database'\n | 'boxes'\n | 'circle-help'\n | 'circle-x'\n | 'git-commit-horizontal'\n | 'search'\n | 'divide'\n | 'quote';\n\n// Category icons\nexport const CATEGORY_ICONS: Record<string, IconName> = {\n comparison: 'scale',\n logical: 'diamond',\n arithmetic: 'calculator',\n array: 'repeat',\n string: 'type',\n variable: 'box',\n control: 'git-merge',\n};\n\n// Iterator argument icons\nexport const ITERATOR_ARG_ICONS: Record<string, IconName[]> = {\n map: ['database', 'cog'],\n reduce: ['database', 'cog', 'boxes'],\n filter: ['database', 'cog'],\n some: ['database', 'cog'],\n none: ['database', 'cog'],\n all: ['database', 'cog'],\n};\n\n// Type icons for arg display\nexport const TYPE_ICONS: Record<string, IconName> = {\n string: 'text',\n number: 'hash',\n boolean: 'toggle-left',\n boolean_true: 'check',\n boolean_false: 'x',\n null: 'ban',\n array: 'list',\n date: 'calendar',\n variable: 'box',\n expression: 'cog',\n};\n\n// Literal type icons (for LiteralNode display)\nexport const LITERAL_TYPE_ICONS: Record<LiteralNodeData['valueType'], IconName> = {\n string: 'quote',\n number: 'hash',\n boolean: 'toggle-right',\n null: 'ban',\n array: 'list',\n};\n\n// Control flow icons\nexport const CONTROL_ICONS = {\n ifCondition: 'git-merge' as IconName,\n elseClause: 'git-commit-horizontal' as IconName,\n ifThenElse: 'git-merge' as IconName,\n orOperator: 'diamond' as IconName,\n};\n\n// Variable operator icons\nexport const VARIABLE_ICONS = {\n var: 'box' as IconName,\n val: 'database' as IconName,\n exists: 'search' as IconName,\n};\n\n// Get type icon for an operand\nexport function getOperandTypeIcon(operand: JsonLogicValue): IconName {\n if (operand === null) return TYPE_ICONS.null;\n if (typeof operand === 'boolean') return TYPE_ICONS.boolean;\n if (typeof operand === 'number') return TYPE_ICONS.number;\n if (typeof operand === 'string') {\n if (looksLikeDate(operand)) return TYPE_ICONS.date;\n return TYPE_ICONS.string;\n }\n if (Array.isArray(operand)) return TYPE_ICONS.array;\n\n if (isPlainObject(operand)) {\n const keys = Object.keys(operand);\n if (keys.length === 1) {\n const op = keys[0];\n if (op === 'var' || op === 'val' || op === 'exists') {\n return TYPE_ICONS.variable;\n }\n }\n return TYPE_ICONS.expression;\n }\n\n return TYPE_ICONS.expression;\n}\n\n// Re-export the Icon component from its own file\nexport { Icon } from './Icon';\n","import type { JsonLogicValue, ArgSummary } from '../../types';\nimport { getOperatorMeta, TRUNCATION_LIMITS } from '../../constants';\nimport { isPlainObject, looksLikeDate } from '../type-helpers';\nimport { TYPE_ICONS, VARIABLE_ICONS } from '../icons';\n\n// Generate argument summary for collapsed view\nexport function generateArgSummary(value: JsonLogicValue): ArgSummary {\n // Handle null\n if (value === null) {\n return { icon: TYPE_ICONS.null, label: 'null', valueType: 'null' };\n }\n\n // Handle primitives\n if (typeof value === 'boolean') {\n return {\n icon: value ? TYPE_ICONS.boolean_true : TYPE_ICONS.boolean_false,\n label: String(value),\n valueType: 'boolean',\n };\n }\n\n if (typeof value === 'number') {\n return { icon: TYPE_ICONS.number, label: String(value), valueType: 'number' };\n }\n\n if (typeof value === 'string') {\n if (looksLikeDate(value)) {\n return { icon: TYPE_ICONS.date, label: value, valueType: 'date' };\n }\n // Truncate long strings\n const displayStr = value.length > TRUNCATION_LIMITS.shortLabel ? value.slice(0, TRUNCATION_LIMITS.shortLabel - 3) + '...' : value;\n return { icon: TYPE_ICONS.string, label: `\"${displayStr}\"`, valueType: 'string' };\n }\n\n // Handle arrays\n if (Array.isArray(value)) {\n if (value.length === 0) {\n return { icon: TYPE_ICONS.array, label: '[]', valueType: 'array' };\n }\n return { icon: TYPE_ICONS.array, label: `[${value.length} items]`, valueType: 'array' };\n }\n\n // Handle objects (expressions)\n if (isPlainObject(value)) {\n const keys = Object.keys(value);\n if (keys.length === 1) {\n const op = keys[0];\n\n // Variable access\n if (op === 'var') {\n const path = value[op];\n const pathStr = Array.isArray(path) ? String(path[0] ?? '') : String(path ?? '');\n return { icon: VARIABLE_ICONS.var, label: pathStr || 'var', valueType: 'expression' };\n }\n\n if (op === 'val') {\n const path = value[op];\n const pathStr = Array.isArray(path) ? String(path[0] ?? '') : String(path ?? '');\n return { icon: VARIABLE_ICONS.val, label: `val(${pathStr})`, valueType: 'expression' };\n }\n\n if (op === 'exists') {\n return { icon: VARIABLE_ICONS.exists, label: `exists(${value[op]})`, valueType: 'expression' };\n }\n\n // Other operators - show as expression\n const operands = value[op];\n const argCount = Array.isArray(operands) ? operands.length : 1;\n const meta = getOperatorMeta(op);\n return {\n icon: TYPE_ICONS.expression,\n label: `${meta.label} (${argCount} arg${argCount !== 1 ? 's' : ''})`,\n valueType: 'expression',\n };\n }\n }\n\n return { icon: TYPE_ICONS.expression, label: '...', valueType: 'expression' };\n}\n\n// Format a single operand for display\nexport function formatOperandLabel(operand: JsonLogicValue): string {\n if (operand === null) return 'null';\n if (typeof operand === 'boolean') return String(operand);\n if (typeof operand === 'number') return String(operand);\n if (typeof operand === 'string') return `\"${operand}\"`;\n\n if (Array.isArray(operand)) {\n if (operand.length === 0) return '[]';\n return '[...]';\n }\n\n if (isPlainObject(operand)) {\n const keys = Object.keys(operand);\n if (keys.length === 1) {\n const op = keys[0];\n if (op === 'var') {\n const path = operand[op];\n if (Array.isArray(path)) {\n return typeof path[0] === 'string' ? path[0] : String(path[0]);\n }\n return typeof path === 'string' ? path : String(path);\n }\n if (op === 'val') {\n const path = operand[op];\n if (Array.isArray(path)) {\n return path.length === 0 ? 'val()' : `val(${path[0]})`;\n }\n return typeof path === 'string' ? `val(${path})` : 'val()';\n }\n if (op === 'exists') {\n const path = operand[op];\n return `exists(${path})`;\n }\n }\n }\n\n return '...';\n}\n","import type { JsonLogicValue } from '../../types';\n\n// Format value for display in literal nodes (recursive for small arrays)\nexport function formatValue(value: JsonLogicValue): string {\n if (value === null) return 'null';\n if (typeof value === 'boolean') return value ? 'true' : 'false';\n if (typeof value === 'number') return String(value);\n if (typeof value === 'string') return `\"${value}\"`;\n if (Array.isArray(value)) {\n if (value.length <= 3) {\n return `[${value.map(formatValue).join(', ')}]`;\n }\n return `[${value.length} items]`;\n }\n return JSON.stringify(value);\n}\n\n// Format evaluation result value for compact display (with truncation)\nexport function formatResultValue(value: unknown): string {\n if (value === null) return 'null';\n if (value === undefined) return 'undefined';\n if (typeof value === 'boolean') return value ? 'true' : 'false';\n if (typeof value === 'number') return String(value);\n if (typeof value === 'string') {\n // Truncate long strings\n if (value.length > 15) {\n return `\"${value.slice(0, 12)}...\"`;\n }\n return `\"${value}\"`;\n }\n if (Array.isArray(value)) {\n if (value.length === 0) return '[]';\n return `[${value.length}]`;\n }\n if (typeof value === 'object') {\n const keys = Object.keys(value as object);\n if (keys.length === 0) return '{}';\n return `{${keys.length}}`;\n }\n return String(value);\n}\n\n// Check if a value is complex enough to show in a popover\nexport function isComplexValue(value: unknown): boolean {\n if (value === null || value === undefined) return false;\n if (typeof value === 'boolean' || typeof value === 'number') return false;\n if (typeof value === 'string') return value.length > 50;\n if (Array.isArray(value)) return value.length > 0;\n if (typeof value === 'object') return Object.keys(value as object).length > 0;\n return false;\n}\n\n// Get CSS class for color-coding values by type\nexport function getValueColorClass(value: unknown): string {\n if (value === null) return 'debug-value-null';\n if (value === undefined) return 'debug-value-undefined';\n if (typeof value === 'boolean') {\n return value ? 'debug-value-boolean-true' : 'debug-value-boolean-false';\n }\n if (typeof value === 'number') return 'debug-value-number';\n if (typeof value === 'string') return 'debug-value-string';\n if (Array.isArray(value)) return 'debug-value-array';\n if (typeof value === 'object') return 'debug-value-object';\n return '';\n}\n\n// Token types for JSON syntax highlighting\nexport type JsonTokenType = 'key' | 'string' | 'number' | 'boolean-true' | 'boolean-false' | 'null' | 'punctuation';\n\nexport interface JsonToken {\n type: JsonTokenType | null;\n content: string;\n}\n\n// Tokenize JSON string for syntax highlighting\nexport function tokenizeJson(value: unknown): JsonToken[] {\n const json = JSON.stringify(value, null, 2);\n if (!json) return [{ type: null, content: 'undefined' }];\n\n const tokens: JsonToken[] = [];\n let i = 0;\n\n while (i < json.length) {\n const char = json[i];\n\n // Whitespace\n if (/\\s/.test(char)) {\n let whitespace = '';\n while (i < json.length && /\\s/.test(json[i])) {\n whitespace += json[i];\n i++;\n }\n tokens.push({ type: null, content: whitespace });\n continue;\n }\n\n // Punctuation: { } [ ] : ,\n if (/[{}[\\]:,]/.test(char)) {\n tokens.push({ type: 'punctuation', content: char });\n i++;\n continue;\n }\n\n // String (could be key or value)\n if (char === '\"') {\n let str = '\"';\n i++;\n while (i < json.length && json[i] !== '\"') {\n if (json[i] === '\\\\' && i + 1 < json.length) {\n str += json[i] + json[i + 1];\n i += 2;\n } else {\n str += json[i];\n i++;\n }\n }\n str += '\"';\n i++;\n\n // Check if this is a key (followed by :)\n let lookAhead = i;\n while (lookAhead < json.length && /\\s/.test(json[lookAhead])) {\n lookAhead++;\n }\n const isKey = json[lookAhead] === ':';\n\n tokens.push({ type: isKey ? 'key' : 'string', content: str });\n continue;\n }\n\n // Number\n if (/[-\\d]/.test(char)) {\n let num = '';\n while (i < json.length && /[-\\d.eE+]/.test(json[i])) {\n num += json[i];\n i++;\n }\n tokens.push({ type: 'number', content: num });\n continue;\n }\n\n // true\n if (json.slice(i, i + 4) === 'true') {\n tokens.push({ type: 'boolean-true', content: 'true' });\n i += 4;\n continue;\n }\n\n // false\n if (json.slice(i, i + 5) === 'false') {\n tokens.push({ type: 'boolean-false', content: 'false' });\n i += 5;\n continue;\n }\n\n // null\n if (json.slice(i, i + 4) === 'null') {\n tokens.push({ type: 'null', content: 'null' });\n i += 4;\n continue;\n }\n\n // Unknown character\n tokens.push({ type: null, content: char });\n i++;\n }\n\n return tokens;\n}\n","import type { JsonLogicValue, LogicNode, LogicEdge } from '../../types';\n\n// Context passed to all converters\nexport interface ConversionContext {\n nodes: LogicNode[];\n edges: LogicEdge[];\n parentId?: string;\n argIndex?: number;\n branchType?: 'yes' | 'no';\n}\n\n// Common parent info for node creation\nexport interface ParentInfo {\n parentId?: string;\n argIndex?: number;\n branchType?: 'yes' | 'no';\n}\n\n// Converter function signature - returns the created node ID\nexport type ConverterFn = (\n value: JsonLogicValue,\n context: ConversionContext\n) => string;\n\n// Extract parent info from context\nexport function getParentInfo(context: ConversionContext): ParentInfo {\n return {\n parentId: context.parentId,\n argIndex: context.argIndex,\n branchType: context.branchType,\n };\n}\n","import validate from './validate.js';\nconst byteToHex = [];\nfor (let i = 0; i < 256; ++i) {\n byteToHex.push((i + 0x100).toString(16).slice(1));\n}\nexport function unsafeStringify(arr, offset = 0) {\n return (byteToHex[arr[offset + 0]] +\n byteToHex[arr[offset + 1]] +\n byteToHex[arr[offset + 2]] +\n byteToHex[arr[offset + 3]] +\n '-' +\n byteToHex[arr[offset + 4]] +\n byteToHex[arr[offset + 5]] +\n '-' +\n byteToHex[arr[offset + 6]] +\n byteToHex[arr[offset + 7]] +\n '-' +\n byteToHex[arr[offset + 8]] +\n byteToHex[arr[offset + 9]] +\n '-' +\n byteToHex[arr[offset + 10]] +\n byteToHex[arr[offset + 11]] +\n byteToHex[arr[offset + 12]] +\n byteToHex[arr[offset + 13]] +\n byteToHex[arr[offset + 14]] +\n byteToHex[arr[offset + 15]]).toLowerCase();\n}\nfunction stringify(arr, offset = 0) {\n const uuid = unsafeStringify(arr, offset);\n if (!validate(uuid)) {\n throw TypeError('Stringified UUID is invalid');\n }\n return uuid;\n}\nexport default stringify;\n","let getRandomValues;\nconst rnds8 = new Uint8Array(16);\nexport default function rng() {\n if (!getRandomValues) {\n if (typeof crypto === 'undefined' || !crypto.getRandomValues) {\n throw new Error('crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported');\n }\n getRandomValues = crypto.getRandomValues.bind(crypto);\n }\n return getRandomValues(rnds8);\n}\n","const randomUUID = typeof crypto !== 'undefined' && crypto.randomUUID && crypto.randomUUID.bind(crypto);\nexport default { randomUUID };\n","import native from './native.js';\nimport rng from './rng.js';\nimport { unsafeStringify } from './stringify.js';\nfunction _v4(options, buf, offset) {\n options = options || {};\n const rnds = options.random ?? options.rng?.() ?? rng();\n if (rnds.length < 16) {\n throw new Error('Random bytes length must be >= 16');\n }\n rnds[6] = (rnds[6] & 0x0f) | 0x40;\n rnds[8] = (rnds[8] & 0x3f) | 0x80;\n if (buf) {\n offset = offset || 0;\n if (offset < 0 || offset + 16 > buf.length) {\n throw new RangeError(`UUID byte range ${offset}:${offset + 15} is out of buffer bounds`);\n }\n for (let i = 0; i < 16; ++i) {\n buf[offset + i] = rnds[i];\n }\n return buf;\n }\n return unsafeStringify(rnds);\n}\nfunction v4(options, buf, offset) {\n if (native.randomUUID && !buf && !options) {\n return native.randomUUID();\n }\n return _v4(options, buf, offset);\n}\nexport default v4;\n","import { v4 as uuidv4 } from 'uuid';\nimport type {\n JsonLogicValue,\n LogicNode,\n LogicEdge,\n LiteralNodeData,\n OperatorNodeData,\n VariableNodeData,\n VerticalCellNodeData,\n DecisionNodeData,\n OperatorCategory,\n CellData,\n} from '../types';\nimport type { IconName } from './icons';\nimport type { ParentInfo } from './converters/types';\nimport { getValueType } from './type-helpers';\nimport { BRANCH_COLORS } from '../constants';\n\n// Factory function to create a literal node\nexport function createLiteralNode(\n value: JsonLogicValue,\n parentInfo: ParentInfo = {}\n): LogicNode {\n const nodeId = uuidv4();\n return {\n id: nodeId,\n type: 'literal',\n position: { x: 0, y: 0 },\n data: {\n type: 'literal',\n value,\n valueType: getValueType(value),\n expression: value,\n parentId: parentInfo.parentId,\n argIndex: parentInfo.argIndex,\n branchType: parentInfo.branchType,\n } as LiteralNodeData,\n };\n}\n\n// Factory function to create a variable node\nexport function createVariableNode(\n operator: 'var' | 'val' | 'exists',\n path: string,\n defaultValue: JsonLogicValue | undefined,\n originalExpr: JsonLogicValue,\n parentInfo: ParentInfo = {}\n): LogicNode {\n const nodeId = uuidv4();\n return {\n id: nodeId,\n type: 'variable',\n position: { x: 0, y: 0 },\n data: {\n type: 'variable',\n operator,\n path,\n defaultValue,\n expression: originalExpr,\n parentId: parentInfo.parentId,\n argIndex: parentInfo.argIndex,\n branchType: parentInfo.branchType,\n } as VariableNodeData,\n };\n}\n\n// Options for creating operator nodes\ninterface OperatorNodeOptions {\n operator: string;\n category: OperatorCategory;\n label: string;\n childIds: string[];\n collapsed?: boolean;\n expressionText?: string;\n expression: JsonLogicValue;\n inlineDisplay?: string;\n}\n\n// Factory function to create an operator node\nexport function createOperatorNode(\n options: OperatorNodeOptions,\n parentInfo: ParentInfo = {}\n): LogicNode {\n const nodeId = uuidv4();\n return {\n id: nodeId,\n type: 'operator',\n position: { x: 0, y: 0 },\n data: {\n type: 'operator',\n operator: options.operator,\n category: options.category,\n label: options.label,\n childIds: options.childIds,\n collapsed: options.collapsed ?? false,\n expressionText: options.expressionText,\n expression: options.expression,\n inlineDisplay: options.inlineDisplay,\n parentId: parentInfo.parentId,\n argIndex: parentInfo.argIndex,\n branchType: parentInfo.branchType,\n } as OperatorNodeData,\n };\n}\n\n// Options for creating vertical cell nodes\ninterface VerticalCellNodeOptions {\n operator: string;\n category: OperatorCategory;\n label: string;\n icon: IconName;\n cells: CellData[];\n collapsed?: boolean;\n expressionText?: string;\n expression: JsonLogicValue;\n}\n\n// Factory function to create a vertical cell node\nexport function createVerticalCellNode(\n options: VerticalCellNodeOptions,\n parentInfo: ParentInfo = {}\n): LogicNode {\n const nodeId = uuidv4();\n return {\n id: nodeId,\n type: 'verticalCell',\n position: { x: 0, y: 0 },\n data: {\n type: 'verticalCell',\n operator: options.operator,\n category: options.category,\n label: options.label,\n icon: options.icon,\n cells: options.cells,\n collapsed: options.collapsed ?? false,\n expressionText: options.expressionText,\n expression: options.expression,\n parentId: parentInfo.parentId,\n argIndex: parentInfo.argIndex,\n branchType: parentInfo.branchType,\n } as VerticalCellNodeData,\n };\n}\n\n// Edge creation options\ninterface EdgeOptions {\n source: string;\n target: string;\n sourceHandle?: string;\n targetHandle?: string;\n label?: string;\n className?: string;\n style?: Record<string, string>;\n}\n\n// Factory function to create an edge\nexport function createEdge(options: EdgeOptions): LogicEdge {\n const edge: LogicEdge = {\n id: `${options.source}-${options.target}`,\n source: options.source,\n target: options.target,\n };\n\n if (options.sourceHandle) {\n edge.sourceHandle = options.sourceHandle;\n }\n if (options.targetHandle) {\n edge.targetHandle = options.targetHandle;\n }\n if (options.label) {\n edge.label = options.label;\n }\n if (options.className) {\n edge.className = options.className;\n }\n if (options.style) {\n edge.style = options.style;\n }\n\n return edge;\n}\n\n// Create edge from parent to child using argument index\nexport function createArgEdge(parentId: string, childId: string, argIndex: number): LogicEdge {\n return createEdge({\n source: parentId,\n target: childId,\n sourceHandle: `arg-${argIndex}`,\n targetHandle: 'left',\n });\n}\n\n// Create edge from parent to branch using branch index\nexport function createBranchEdge(\n parentId: string,\n branchId: string,\n branchIndex: number,\n options: { label?: string; className?: string; style?: Record<string, string> } = {}\n): LogicEdge {\n return createEdge({\n source: parentId,\n target: branchId,\n sourceHandle: `branch-${branchIndex}`,\n targetHandle: 'left',\n ...options,\n });\n}\n\n// Options for creating decision nodes\ninterface DecisionNodeOptions {\n conditionText: string;\n conditionExpression: JsonLogicValue;\n isConditionComplex: boolean;\n conditionBranchId?: string;\n yesBranchId: string;\n noBranchId: string;\n collapsed?: boolean;\n expressionText?: string;\n expression: JsonLogicValue;\n}\n\n// Factory function to create a decision node\nexport function createDecisionNode(\n options: DecisionNodeOptions,\n parentInfo: ParentInfo = {}\n): LogicNode {\n const nodeId = uuidv4();\n return {\n id: nodeId,\n type: 'decision',\n position: { x: 0, y: 0 },\n data: {\n type: 'decision',\n conditionText: options.conditionText,\n conditionExpression: options.conditionExpression,\n isConditionComplex: options.isConditionComplex,\n conditionBranchId: options.conditionBranchId,\n yesBranchId: options.yesBranchId,\n noBranchId: options.noBranchId,\n collapsed: options.collapsed ?? false,\n expressionText: options.expressionText,\n expression: options.expression,\n parentId: parentInfo.parentId,\n argIndex: parentInfo.argIndex,\n branchType: parentInfo.branchType,\n } as DecisionNodeData,\n };\n}\n\n// Create \"Yes\" branch edge from decision node\n// branchIndex: 0 if no condition branch, 1 if condition branch exists\nexport function createYesEdge(parentId: string, childId: string, hasConditionBranch: boolean): LogicEdge {\n const branchIndex = hasConditionBranch ? 1 : 0;\n return {\n id: `${parentId}-yes-${childId}`,\n source: parentId,\n target: childId,\n sourceHandle: `branch-${branchIndex}`,\n targetHandle: 'left',\n label: 'Yes',\n className: 'yes-edge',\n style: { stroke: BRANCH_COLORS.yes },\n };\n}\n\n// Create \"No\" branch edge from decision node\n// branchIndex: 1 if no condition branch, 2 if condition branch exists\nexport function createNoEdge(parentId: string, childId: string, hasConditionBranch: boolean): LogicEdge {\n const branchIndex = hasConditionBranch ? 2 : 1;\n return {\n id: `${parentId}-no-${childId}`,\n source: parentId,\n target: childId,\n sourceHandle: `branch-${branchIndex}`,\n targetHandle: 'left',\n label: 'No',\n className: 'no-edge',\n style: { stroke: BRANCH_COLORS.no },\n };\n}\n\n// Create condition branch edge from decision node (for complex conditions)\n// Always branch-0 when it exists\nexport function createConditionEdge(parentId: string, childId: string): LogicEdge {\n return {\n id: `${parentId}-cond-${childId}`,\n source: parentId,\n target: childId,\n sourceHandle: 'branch-0',\n targetHandle: 'left',\n };\n}\n","import type { JsonLogicValue } from '../../types';\nimport type { ConversionContext } from './types';\nimport { getParentInfo } from './types';\nimport { createLiteralNode, createArgEdge } from '../node-factory';\n\n// Convert a primitive value (or non-object) to a literal node\nexport function convertPrimitive(\n value: JsonLogicValue,\n context: ConversionContext\n): string {\n const parentInfo = getParentInfo(context);\n const node = createLiteralNode(value, parentInfo);\n\n context.nodes.push(node);\n\n // Add edge from parent if exists and not a branch type\n if (parentInfo.parentId && !parentInfo.branchType) {\n const edge = createArgEdge(parentInfo.parentId, node.id, parentInfo.argIndex ?? 0);\n context.edges.push(edge);\n }\n\n return node.id;\n}\n\n// Convert an invalid JSONLogic object (not exactly 1 key) to a literal node\nexport function convertInvalidObject(\n value: JsonLogicValue,\n context: ConversionContext\n): string {\n const parentInfo = getParentInfo(context);\n const node = createLiteralNode(value, {\n ...parentInfo,\n });\n\n // Override valueType to 'array' for invalid objects\n if (node.data.type === 'literal') {\n node.data.valueType = 'array';\n }\n\n context.nodes.push(node);\n\n // Add edge from parent if exists and not a branch type\n if (parentInfo.parentId && !parentInfo.branchType) {\n const edge = createArgEdge(parentInfo.parentId, node.id, parentInfo.argIndex ?? 0);\n context.edges.push(edge);\n }\n\n return node.id;\n}\n","import type { JsonLogicValue } from '../../types';\nimport type { ConversionContext } from './types';\nimport { getParentInfo } from './types';\nimport { createVariableNode, createArgEdge } from '../node-factory';\n\n// Variable operators\nconst VARIABLE_OPERATORS = ['var', 'val', 'exists'] as const;\ntype VariableOperator = (typeof VARIABLE_OPERATORS)[number];\n\n// Check if operator is a variable operator\nexport function isVariableOperator(operator: string): operator is VariableOperator {\n return VARIABLE_OPERATORS.includes(operator as VariableOperator);\n}\n\n// Convert a variable operator (var, val, exists) to a variable node\nexport function convertVariable(\n operator: VariableOperator,\n operands: JsonLogicValue,\n context: ConversionContext\n): string {\n let path: string;\n let defaultValue: JsonLogicValue | undefined;\n\n if (Array.isArray(operands)) {\n path = String(operands[0] ?? '');\n defaultValue = operands[1];\n } else {\n path = String(operands ?? '');\n }\n\n // Store the original expression for this variable node\n const originalExpr = { [operator]: operands };\n const parentInfo = getParentInfo(context);\n\n const node = createVariableNode(\n operator,\n path,\n defaultValue,\n originalExpr,\n parentInfo\n );\n\n context.nodes.push(node);\n\n // Add edge from parent if exists and not a branch type\n if (parentInfo.parentId && !parentInfo.branchType) {\n const edge = createArgEdge(parentInfo.parentId, node.id, parentInfo.argIndex ?? 0);\n context.edges.push(edge);\n }\n\n return node.id;\n}\n","import type { JsonLogicValue, LogicNode, VerticalCellNodeData, CellData } from '../../types';\nimport type { ConversionContext, ConverterFn } from './types';\nimport { getParentInfo } from './types';\nimport { generateExpressionText } from '../formatting';\nimport { createArgEdge } from '../node-factory';\nimport { v4 as uuidv4 } from 'uuid';\n\n// Convert if/else to a single VerticalCellNode with all branches\n// Each condition and then value gets its own row for handle clarity\nexport function convertIfElse(\n ifArgs: JsonLogicValue[],\n context: ConversionContext,\n convertValue: ConverterFn\n): string {\n const parentInfo = getParentInfo(context);\n const nodeId = uuidv4();\n\n // If there's only a single value (no condition), just convert it directly\n if (ifArgs.length === 1) {\n return convertValue(ifArgs[0], {\n nodes: context.nodes,\n edges: context.edges,\n parentId: parentInfo.parentId,\n argIndex: parentInfo.argIndex,\n branchType: parentInfo.branchType,\n });\n }\n\n const cells: CellData[] = [];\n let cellIndex = 0;\n let branchIndex = 0;\n\n // Parse the if-else chain\n let idx = 0;\n while (idx < ifArgs.length - 1) {\n const condition = ifArgs[idx];\n const thenValue = ifArgs[idx + 1];\n const isFirst = idx === 0;\n\n // Convert condition branch\n const conditionBranchId = convertValue(condition, {\n nodes: context.nodes,\n edges: context.edges,\n parentId: nodeId,\n argIndex: idx,\n });\n\n // Create condition edge\n context.edges.push({\n id: `${nodeId}-cond-${conditionBranchId}`,\n source: nodeId,\n target: conditionBranchId,\n sourceHandle: `branch-${branchIndex}`,\n targetHandle: 'left',\n });\n\n // Create cell for condition (If or Else If)\n const conditionText = generateExpressionText(condition, 40);\n cells.push({\n type: 'branch',\n icon: 'diamond',\n rowLabel: isFirst ? 'If' : 'Else If',\n label: conditionText,\n branchId: conditionBranchId,\n index: cellIndex,\n });\n cellIndex++;\n branchIndex++;\n\n // Convert then branch\n const thenBranchId = convertValue(thenValue, {\n nodes: context.nodes,\n edges: context.edges,\n parentId: nodeId,\n argIndex: idx + 1,\n branchType: 'yes',\n });\n\n // Create then edge\n context.edges.push({\n id: `${nodeId}-then-${thenBranchId}`,\n source: nodeId,\n target: thenBranchId,\n sourceHandle: `branch-${branchIndex}`,\n targetHandle: 'left',\n });\n\n // Create cell for then value\n const thenText = generateExpressionText(thenValue, 40);\n cells.push({\n type: 'branch',\n icon: 'check',\n rowLabel: 'Then',\n label: thenText,\n branchId: thenBranchId,\n index: cellIndex,\n });\n cellIndex++;\n branchIndex++;\n\n idx += 2;\n }\n\n // Handle final else (if exists)\n const hasFinalElse = ifArgs.length % 2 === 1;\n if (hasFinalElse) {\n const elseValue = ifArgs[ifArgs.length - 1];\n\n // Convert else branch\n const elseBranchId = convertValue(elseValue, {\n nodes: context.nodes,\n edges: context.edges,\n parentId: nodeId,\n argIndex: ifArgs.length - 1,\n branchType: 'no',\n });\n\n // Create else edge\n context.edges.push({\n id: `${nodeId}-else-${elseBranchId}`,\n source: nodeId,\n target: elseBranchId,\n sourceHandle: `branch-${branchIndex}`,\n targetHandle: 'left',\n });\n\n const elseText = generateExpressionText(elseValue, 40);\n\n cells.push({\n type: 'branch',\n icon: 'x',\n rowLabel: 'Else',\n label: elseText,\n branchId: elseBranchId,\n index: cellIndex,\n });\n }\n\n // Generate expression text for the entire if/else\n const originalExpr = { if: ifArgs };\n const expressionText = generateExpressionText(originalExpr);\n\n // Create the VerticalCellNode\n const ifElseNode: LogicNode = {\n id: nodeId,\n type: 'verticalCell',\n position: { x: 0, y: 0 },\n data: {\n type: 'verticalCell',\n operator: 'if',\n category: 'control',\n label: 'If / Then / Else',\n icon: 'diamond',\n cells,\n collapsed: false,\n expressionText,\n collapsedCellIndices: [],\n parentId: parentInfo.parentId,\n argIndex: parentInfo.argIndex,\n branchType: parentInfo.branchType,\n expression: originalExpr,\n } as VerticalCellNodeData,\n };\n\n context.nodes.push(ifElseNode);\n\n // Add edge from parent if exists and not a branch connection\n if (parentInfo.parentId && !parentInfo.branchType) {\n context.edges.push(\n createArgEdge(parentInfo.parentId, nodeId, parentInfo.argIndex ?? 0)\n );\n }\n\n return nodeId;\n}\n","import { v4 as uuidv4 } from 'uuid';\nimport type { JsonLogicValue, CellData, LogicNode, VerticalCellNodeData, OperatorNodeData } from '../../types';\nimport type { ConversionContext, ConverterFn } from './types';\nimport { getParentInfo } from './types';\nimport { getOperatorMeta, TRUNCATION_LIMITS } from '../../constants';\nimport { CATEGORY_ICONS, ITERATOR_ARG_ICONS, getOperandTypeIcon, CONTROL_ICONS, type IconName } from '../icons';\nimport { generateExpressionText, generateArgSummary, formatOperandLabel } from '../formatting';\nimport { isSimpleOperand } from '../type-helpers';\nimport { createBranchEdge, createArgEdge } from '../node-factory';\n\n// Unary operators for special handling\nconst UNARY_OPERATORS = ['!', '!!'];\n\n// Convert to vertical cell node for comparison, logical, and iterator operators\nexport function convertToVerticalCell(\n operator: string,\n operandArray: JsonLogicValue[],\n context: ConversionContext,\n convertValue: ConverterFn\n): string {\n const nodeId = uuidv4();\n const meta = getOperatorMeta(operator);\n const cells: CellData[] = [];\n let branchIndex = 0;\n\n // Determine icon based on operator type\n let icon: IconName = CATEGORY_ICONS[meta.category] || 'list';\n if (operator === 'or') icon = CONTROL_ICONS.orOperator;\n\n // Get iterator argument icons if applicable\n const iteratorIcons = ITERATOR_ARG_ICONS[operator];\n\n operandArray.forEach((operand, idx) => {\n // Determine the cell icon - use type-based icon, but override with iterator icons for iterators\n const typeIcon = getOperandTypeIcon(operand);\n const cellIcon = iteratorIcons ? iteratorIcons[idx] || typeIcon : typeIcon;\n\n // Check if operand can be displayed inline (simple literal or variable)\n if (isSimpleOperand(operand)) {\n cells.push({\n type: 'inline',\n label: formatOperandLabel(operand),\n icon: cellIcon,\n index: idx,\n });\n } else {\n // Complex expression - create branch with summary and expression text\n const branchId = convertValue(operand, {\n nodes: context.nodes,\n edges: context.edges,\n parentId: nodeId,\n argIndex: idx,\n });\n const summary = generateArgSummary(operand);\n summary.label = generateExpressionText(operand, TRUNCATION_LIMITS.expressionText);\n cells.push({\n type: 'branch',\n icon: cellIcon,\n branchId,\n index: idx,\n summary,\n });\n\n // Add edge from this node to the branch\n context.edges.push(createBranchEdge(nodeId, branchId, branchIndex));\n branchIndex++;\n }\n });\n\n // Generate full expression text for the node\n const originalExpr = { [operator]: operandArray };\n const expressionText = generateExpressionText(originalExpr);\n const parentInfo = getParentInfo(context);\n\n const verticalCellNode: LogicNode = {\n id: nodeId,\n type: 'verticalCell',\n position: { x: 0, y: 0 },\n data: {\n type: 'verticalCell',\n operator,\n category: meta.category,\n label: meta.label,\n icon,\n cells,\n collapsed: false,\n expressionText,\n expression: originalExpr,\n parentId: parentInfo.parentId,\n argIndex: parentInfo.argIndex,\n branchType: parentInfo.branchType,\n } as VerticalCellNodeData,\n };\n context.nodes.push(verticalCellNode);\n\n // Add edge from parent if exists\n if (parentInfo.parentId && !parentInfo.branchType) {\n context.edges.push(\n createArgEdge(parentInfo.parentId, nodeId, parentInfo.argIndex ?? 0)\n );\n }\n\n return nodeId;\n}\n\n// Convert unary operator with simple argument (inline display)\nexport function convertUnaryInline(\n operator: string,\n expressionText: string,\n value: JsonLogicValue,\n context: ConversionContext\n): string {\n const nodeId = uuidv4();\n const meta = getOperatorMeta(operator);\n const parentInfo = getParentInfo(context);\n\n const operatorNode: LogicNode = {\n id: nodeId,\n type: 'operator',\n position: { x: 0, y: 0 },\n data: {\n type: 'operator',\n operator,\n category: meta.category,\n label: meta.label,\n childIds: [], // No children - inline display\n collapsed: false,\n expressionText,\n expression: value,\n inlineDisplay: expressionText, // Show inline\n parentId: parentInfo.parentId,\n argIndex: parentInfo.argIndex,\n branchType: parentInfo.branchType,\n } as OperatorNodeData,\n };\n context.nodes.push(operatorNode);\n\n if (parentInfo.parentId && !parentInfo.branchType) {\n context.edges.push(\n createArgEdge(parentInfo.parentId, nodeId, parentInfo.argIndex ?? 0)\n );\n }\n\n return nodeId;\n}\n\n// Convert standard operator with child nodes\nexport function convertOperatorWithChildren(\n operator: string,\n operandArray: JsonLogicValue[],\n value: JsonLogicValue,\n context: ConversionContext,\n convertValue: ConverterFn\n): string {\n const nodeId = uuidv4();\n const meta = getOperatorMeta(operator);\n const expressionText = generateExpressionText(value);\n const childIds: string[] = [];\n\n // Process each operand recursively\n operandArray.forEach((operand, idx) => {\n const childId = convertValue(operand, {\n nodes: context.nodes,\n edges: context.edges,\n parentId: nodeId,\n argIndex: idx,\n });\n childIds.push(childId);\n });\n\n const parentInfo = getParentInfo(context);\n\n const operatorNode: LogicNode = {\n id: nodeId,\n type: 'operator',\n position: { x: 0, y: 0 },\n data: {\n type: 'operator',\n operator,\n category: meta.category,\n label: meta.label,\n childIds,\n collapsed: false,\n expressionText,\n expression: value,\n parentId: parentInfo.parentId,\n argIndex: parentInfo.argIndex,\n branchType: parentInfo.branchType,\n } as OperatorNodeData,\n };\n context.nodes.push(operatorNode);\n\n if (parentInfo.parentId && !parentInfo.branchType) {\n context.edges.push(\n createArgEdge(parentInfo.parentId, nodeId, parentInfo.argIndex ?? 0)\n );\n }\n\n return nodeId;\n}\n\n// Check if operator is a unary operator\nexport function isUnaryOperator(operator: string): boolean {\n return UNARY_OPERATORS.includes(operator);\n}\n","import type { JsonLogicValue } from '../../types';\nimport type { ConversionContext } from './types';\nimport { isPlainObject, isSimpleOperand } from '../type-helpers';\nimport { generateExpressionText } from '../formatting';\nimport { convertPrimitive, convertInvalidObject } from './primitive-converter';\nimport { isVariableOperator, convertVariable } from './variable-converter';\nimport { convertIfElse } from './if-else-converter';\nimport {\n convertToVerticalCell,\n convertUnaryInline,\n convertOperatorWithChildren,\n isUnaryOperator,\n} from './operator-converter';\n\nexport type { ConversionContext, ParentInfo, ConverterFn } from './types';\n\n// Main conversion function - converts a JSONLogic value to nodes\nexport function convertValue(\n value: JsonLogicValue,\n context: ConversionContext\n): string {\n // Handle primitives and arrays as literals\n if (!isPlainObject(value)) {\n return convertPrimitive(value, context);\n }\n\n // Handle objects (operators)\n const keys = Object.keys(value);\n if (keys.length !== 1) {\n // Invalid JSONLogic, treat as literal\n return convertInvalidObject(value, context);\n }\n\n const operator = keys[0];\n const operands = value[operator];\n\n // Handle if/else - convert to vertical cell node\n if (operator === 'if' || operator === '?:') {\n const ifArgs: JsonLogicValue[] = Array.isArray(operands) ? operands : [operands];\n return convertIfElse(ifArgs, context, convertValue);\n }\n\n // Handle variable operators specially\n if (isVariableOperator(operator)) {\n return convertVariable(operator, operands, context);\n }\n\n // Normalize operands to array\n const operandArray: JsonLogicValue[] = Array.isArray(operands) ? operands : [operands];\n\n // Use VerticalCellNode for ALL operators with more than 1 argument\n if (operandArray.length > 1) {\n return convertToVerticalCell(operator, operandArray, context, convertValue);\n }\n\n // For unary operators (single arg), use standard operator node\n const expressionText = generateExpressionText(value);\n\n // Check if this is a unary operator with a simple operand - show inline without expansion\n const singleOperand = operandArray[0];\n const isUnaryWithSimpleArg = isUnaryOperator(operator) && isSimpleOperand(singleOperand);\n\n if (isUnaryWithSimpleArg) {\n return convertUnaryInline(operator, expressionText, value, context);\n }\n\n // For other single-arg operators, create with child node\n return convertOperatorWithChildren(operator, operandArray, value, context, convertValue);\n}\n","import type {\n JsonLogicValue,\n LogicNode,\n LogicEdge,\n ConversionResult,\n} from '../types';\nimport { convertValue } from './converters';\n\n// Main conversion function\nexport function jsonLogicToNodes(expr: JsonLogicValue | null): ConversionResult {\n if (expr === null || expr === undefined) {\n return { nodes: [], edges: [], rootId: null };\n }\n\n const nodes: LogicNode[] = [];\n const edges: LogicEdge[] = [];\n\n const rootId = convertValue(expr, { nodes, edges });\n\n return { nodes, edges, rootId };\n}\n","import type {\n LogicNode,\n LogicEdge,\n ConversionResult,\n JsonLogicValue,\n CellData,\n LiteralNodeData,\n VariableNodeData,\n VerticalCellNodeData,\n OperatorNodeData,\n} from '../types';\nimport type { TracedResult, ExpressionNode } from '../types/trace';\nimport type { ParentInfo } from './converters/types';\n\n// Extended result type that includes trace-to-visual node mapping\nexport interface TraceConversionResult extends ConversionResult {\n traceNodeMap: Map<string, string>; // trace-{id} -> visual node ID\n}\nimport { getOperatorMeta, TRUNCATION_LIMITS } from '../constants';\nimport { CATEGORY_ICONS, ITERATOR_ARG_ICONS, getOperandTypeIcon, CONTROL_ICONS, type IconName } from './icons';\nimport { generateExpressionText, generateArgSummary, formatOperandLabel } from './formatting';\nimport { isSimpleOperand, getValueType } from './type-helpers';\nimport { createBranchEdge } from './node-factory';\n\n// Convert trace node ID to string node ID\nfunction traceIdToNodeId(id: number): string {\n return `trace-${id}`;\n}\n\ntype ValueType = 'boolean' | 'number' | 'string' | 'null' | 'array' | 'object' | 'undefined';\n\n// Build evaluation results map from trace execution steps\nexport function buildEvaluationResultsFromTrace(trace: TracedResult): Map<string, { value: unknown; error: string | null; type: ValueType }> {\n const results = new Map<string, { value: unknown; error: string | null; type: ValueType }>();\n\n if (!trace.steps) {\n return results;\n }\n\n for (const step of trace.steps) {\n const nodeId = traceIdToNodeId(step.node_id);\n\n // Determine the value type\n let valueType: ValueType = 'undefined';\n const value = step.result;\n if (value === null) valueType = 'null';\n else if (value === undefined) valueType = 'undefined';\n else if (Array.isArray(value)) valueType = 'array';\n else if (typeof value === 'boolean') valueType = 'boolean';\n else if (typeof value === 'number') valueType = 'number';\n else if (typeof value === 'string') valueType = 'string';\n else if (typeof value === 'object') valueType = 'object';\n\n results.set(nodeId, {\n value: step.result,\n error: step.error ?? null,\n type: valueType,\n });\n }\n\n return results;\n}\n\n// Main conversion function\nexport function traceToNodes(trace: TracedResult): TraceConversionResult {\n if (!trace.expression_tree) {\n return { nodes: [], edges: [], rootId: null, traceNodeMap: new Map() };\n }\n\n const nodes: LogicNode[] = [];\n const edges: LogicEdge[] = [];\n const traceNodeMap: Map<string, string> = new Map();\n\n processExpressionNode(trace.expression_tree, { nodes, edges, traceNodeMap });\n\n return {\n nodes,\n edges,\n rootId: traceIdToNodeId(trace.expression_tree.id),\n traceNodeMap,\n };\n}\n\ninterface TraceContext {\n nodes: LogicNode[];\n edges: LogicEdge[];\n traceNodeMap: Map<string, string>;\n}\n\n// Map all children of an expression node to a parent visual node ID (for inlined children)\nfunction mapInlinedChildren(\n children: ExpressionNode[],\n parentVisualId: string,\n traceNodeMap: Map<string, string>\n): void {\n for (const child of children) {\n const traceId = traceIdToNodeId(child.id);\n traceNodeMap.set(traceId, parentVisualId);\n // Also recursively map any nested children\n if (child.children && child.children.length > 0) {\n mapInlinedChildren(child.children, parentVisualId, traceNodeMap);\n }\n }\n}\n\n// Process a single expression node from the trace\nfunction processExpressionNode(\n exprNode: ExpressionNode,\n context: TraceContext,\n parentInfo: ParentInfo = {}\n): string {\n const nodeId = traceIdToNodeId(exprNode.id);\n const expression: JsonLogicValue = JSON.parse(exprNode.expression);\n\n // Register this node in the trace map - it maps to itself since it creates a visual node\n context.traceNodeMap.set(nodeId, nodeId);\n\n // Determine the type of expression and create appropriate node\n const nodeType = determineNodeType(expression);\n\n switch (nodeType) {\n case 'literal':\n createLiteralNodeFromTrace(nodeId, expression, exprNode.children, context, parentInfo);\n break;\n case 'variable':\n createVariableNodeFromTrace(nodeId, expression, exprNode.children, context, parentInfo);\n break;\n case 'if':\n createIfElseNodeFromTrace(nodeId, expression, exprNode.children, context, parentInfo);\n break;\n case 'verticalCell':\n createVerticalCellNodeFromTrace(nodeId, expression, exprNode.children, context, parentInfo);\n break;\n case 'operator':\n createOperatorNodeFromTrace(nodeId, expression, exprNode.children, context, parentInfo);\n break;\n }\n\n return nodeId;\n}\n\ntype NodeType = 'literal' | 'variable' | 'if' | 'verticalCell' | 'operator';\n\n// Determine what kind of node to create based on expression\nfunction determineNodeType(expr: JsonLogicValue): NodeType {\n // Primitives and arrays -> literal\n if (expr === null || typeof expr !== 'object' || Array.isArray(expr)) {\n return 'literal';\n }\n\n const keys = Object.keys(expr);\n if (keys.length !== 1) return 'literal'; // Invalid JSONLogic, treat as literal\n\n const operator = keys[0];\n\n // Variable operators\n if (['var', 'val', 'exists'].includes(operator)) {\n return 'variable';\n }\n\n // If/else -> special handling\n if (operator === 'if' || operator === '?:') {\n return 'if';\n }\n\n // Multi-arg operators -> verticalCell\n const operands = (expr as Record<string, unknown>)[operator];\n const args = Array.isArray(operands) ? operands : [operands];\n if (args.length > 1) {\n return 'verticalCell';\n }\n\n return 'operator';\n}\n\n// Create a literal node\nfunction createLiteralNodeFromTrace(\n nodeId: string,\n value: JsonLogicValue,\n children: ExpressionNode[],\n context: TraceContext,\n parentInfo: ParentInfo\n): void {\n // Map any children to this node (shouldn't happen for literals, but be safe)\n if (children && children.length > 0) {\n mapInlinedChildren(children, nodeId, context.traceNodeMap);\n }\n\n const node: LogicNode = {\n id: nodeId,\n type: 'literal',\n position: { x: 0, y: 0 },\n data: {\n type: 'literal',\n value,\n valueType: getValueType(value),\n expression: value,\n parentId: parentInfo.parentId,\n argIndex: parentInfo.argIndex,\n branchType: parentInfo.branchType,\n } as LiteralNodeData,\n };\n context.nodes.push(node);\n}\n\n// Create a variable node\nfunction createVariableNodeFromTrace(\n nodeId: string,\n expression: JsonLogicValue,\n children: ExpressionNode[],\n context: TraceContext,\n parentInfo: ParentInfo\n): void {\n // Map any children to this node (e.g., nested default value expressions)\n if (children && children.length > 0) {\n mapInlinedChildren(children, nodeId, context.traceNodeMap);\n }\n\n const obj = expression as Record<string, unknown>;\n const operator = Object.keys(obj)[0] as 'var' | 'val' | 'exists';\n const operands = obj[operator];\n\n let path: string;\n let defaultValue: JsonLogicValue | undefined;\n\n if (Array.isArray(operands)) {\n path = String(operands[0] ?? '');\n defaultValue = operands[1] as JsonLogicValue | undefined;\n } else {\n path = String(operands ?? '');\n }\n\n const node: LogicNode = {\n id: nodeId,\n type: 'variable',\n position: { x: 0, y: 0 },\n data: {\n type: 'variable',\n operator,\n path,\n defaultValue,\n expression,\n parentId: parentInfo.parentId,\n argIndex: parentInfo.argIndex,\n branchType: parentInfo.branchType,\n } as VariableNodeData,\n };\n context.nodes.push(node);\n}\n\n// Create a VerticalCellNode for if/else expressions\n// Each condition and then value gets its own row for handle clarity\nfunction createIfElseNodeFromTrace(\n nodeId: string,\n expression: JsonLogicValue,\n children: ExpressionNode[],\n context: TraceContext,\n parentInfo: ParentInfo\n): void {\n const obj = expression as Record<string, unknown>;\n const operator = Object.keys(obj)[0];\n const ifArgs = obj[operator] as JsonLogicValue[];\n const usedChildIndices = new Set<number>();\n\n const cells: CellData[] = [];\n let cellIndex = 0;\n let branchIndex = 0;\n\n // Parse the if-else chain\n let idx = 0;\n while (idx < ifArgs.length - 1) {\n const condition = ifArgs[idx];\n const thenValue = ifArgs[idx + 1];\n const isFirst = idx === 0;\n\n // Process condition branch\n let conditionBranchId: string;\n const condMatch = findMatchingChild(condition, children, usedChildIndices);\n if (condMatch) {\n usedChildIndices.add(condMatch.index);\n conditionBranchId = processExpressionNode(condMatch.child, context, {\n parentId: nodeId,\n argIndex: idx,\n });\n } else {\n // Fallback: create literal node for simple condition values\n conditionBranchId = `${nodeId}-cond-${idx}`;\n const condNode: LogicNode = {\n id: conditionBranchId,\n type: 'literal',\n position: { x: 0, y: 0 },\n data: {\n type: 'literal',\n value: condition,\n valueType: getValueType(condition),\n expression: condition,\n parentId: nodeId,\n argIndex: idx,\n } as LiteralNodeData,\n };\n context.nodes.push(condNode);\n }\n\n // Create condition edge\n context.edges.push(createBranchEdge(nodeId, conditionBranchId, branchIndex));\n\n // Create cell for condition (If or Else If)\n const conditionText = generateExpressionText(condition, 40);\n cells.push({\n type: 'branch',\n icon: 'diamond',\n rowLabel: isFirst ? 'If' : 'Else If',\n label: conditionText,\n branchId: conditionBranchId,\n index: cellIndex,\n });\n cellIndex++;\n branchIndex++;\n\n // Process then branch\n let thenBranchId: string;\n const thenMatch = findMatchingChild(thenValue, children, usedChildIndices);\n if (thenMatch) {\n usedChildIndices.add(thenMatch.index);\n thenBranchId = processExpressionNode(thenMatch.child, context, {\n parentId: nodeId,\n argIndex: idx + 1,\n branchType: 'yes',\n });\n } else {\n // Fallback: create literal node for simple then values\n thenBranchId = `${nodeId}-then-${idx}`;\n const thenNode: LogicNode = {\n id: thenBranchId,\n type: 'literal',\n position: { x: 0, y: 0 },\n data: {\n type: 'literal',\n value: thenValue,\n valueType: getValueType(thenValue),\n expression: thenValue,\n parentId: nodeId,\n argIndex: idx + 1,\n branchType: 'yes',\n } as LiteralNodeData,\n };\n context.nodes.push(thenNode);\n }\n\n // Create then edge\n context.edges.push(createBranchEdge(nodeId, thenBranchId, branchIndex));\n\n // Create cell for then value\n const thenText = generateExpressionText(thenValue, 40);\n cells.push({\n type: 'branch',\n icon: 'check',\n rowLabel: 'Then',\n label: thenText,\n branchId: thenBranchId,\n index: cellIndex,\n });\n cellIndex++;\n branchIndex++;\n\n idx += 2;\n }\n\n // Handle final else (if exists)\n const hasFinalElse = ifArgs.length % 2 === 1;\n if (hasFinalElse) {\n const elseValue = ifArgs[ifArgs.length - 1];\n\n // Process else branch\n let elseBranchId: string;\n const elseMatch = findMatchingChild(elseValue, children, usedChildIndices);\n if (elseMatch) {\n usedChildIndices.add(elseMatch.index);\n elseBranchId = processExpressionNode(elseMatch.child, context, {\n parentId: nodeId,\n argIndex: ifArgs.length - 1,\n branchType: 'no',\n });\n } else {\n // Fallback: create literal node for simple else values\n elseBranchId = `${nodeId}-else`;\n const elseNode: LogicNode = {\n id: elseBranchId,\n type: 'literal',\n position: { x: 0, y: 0 },\n data: {\n type: 'literal',\n value: elseValue,\n valueType: getValueType(elseValue),\n expression: elseValue,\n parentId: nodeId,\n argIndex: ifArgs.length - 1,\n branchType: 'no',\n } as LiteralNodeData,\n };\n context.nodes.push(elseNode);\n }\n\n // Create else edge\n context.edges.push(createBranchEdge(nodeId, elseBranchId, branchIndex));\n\n const elseText = generateExpressionText(elseValue, 40);\n\n cells.push({\n type: 'branch',\n icon: 'x',\n rowLabel: 'Else',\n label: elseText,\n branchId: elseBranchId,\n index: cellIndex,\n });\n }\n\n // Generate expression text for the entire if/else\n const expressionText = generateExpressionText(expression);\n\n // Create the VerticalCellNode\n const ifElseNode: LogicNode = {\n id: nodeId,\n type: 'verticalCell',\n position: { x: 0, y: 0 },\n data: {\n type: 'verticalCell',\n operator: 'if',\n category: 'control',\n label: 'If / Then / Else',\n icon: 'diamond',\n cells,\n collapsed: false,\n expressionText,\n collapsedCellIndices: [],\n parentId: parentInfo.parentId,\n argIndex: parentInfo.argIndex,\n branchType: parentInfo.branchType,\n expression,\n } as VerticalCellNodeData,\n };\n context.nodes.push(ifElseNode);\n}\n\n// Find the matching child node for an operand by comparing expressions\nfunction findMatchingChild(\n operand: JsonLogicValue,\n children: ExpressionNode[],\n usedIndices: Set<number>\n): { child: ExpressionNode; index: number } | null {\n const operandStr = JSON.stringify(operand);\n\n for (let i = 0; i < children.length; i++) {\n if (usedIndices.has(i)) continue;\n // Normalize child expression by parsing and re-stringifying to ensure consistent format\n try {\n const childExprStr = JSON.stringify(JSON.parse(children[i].expression));\n if (childExprStr === operandStr) {\n return { child: children[i], index: i };\n }\n } catch {\n // If parsing fails, try direct comparison\n if (children[i].expression === operandStr) {\n return { child: children[i], index: i };\n }\n }\n }\n return null;\n}\n\n// Create a vertical cell node for multi-arg operators\nfunction createVerticalCellNodeFromTrace(\n nodeId: string,\n expression: JsonLogicValue,\n children: ExpressionNode[],\n context: TraceContext,\n parentInfo: ParentInfo\n): void {\n const obj = expression as Record<string, unknown>;\n const operator = Object.keys(obj)[0];\n const operands = obj[operator];\n const operandArray: JsonLogicValue[] = Array.isArray(operands) ? operands : [operands];\n\n const meta = getOperatorMeta(operator);\n const cells: CellData[] = [];\n let branchIndex = 0;\n const usedChildIndices = new Set<number>();\n\n // Determine icon\n let icon: IconName = CATEGORY_ICONS[meta.category] || 'list';\n if (operator === 'or') icon = CONTROL_ICONS.orOperator;\n\n const iteratorIcons = ITERATOR_ARG_ICONS[operator];\n\n operandArray.forEach((operand, idx) => {\n const typeIcon = getOperandTypeIcon(operand as JsonLogicValue);\n const cellIcon = iteratorIcons ? iteratorIcons[idx] || typeIcon : typeIcon;\n\n if (isSimpleOperand(operand as JsonLogicValue)) {\n // Simple operand is inlined - map the trace child to this parent node\n const match = findMatchingChild(operand as JsonLogicValue, children, usedChildIndices);\n if (match) {\n usedChildIndices.add(match.index);\n const traceId = traceIdToNodeId(match.child.id);\n context.traceNodeMap.set(traceId, nodeId);\n // Also map any nested children\n if (match.child.children && match.child.children.length > 0) {\n mapInlinedChildren(match.child.children, nodeId, context.traceNodeMap);\n }\n }\n\n cells.push({\n type: 'inline',\n label: formatOperandLabel(operand as JsonLogicValue),\n icon: cellIcon,\n index: idx,\n });\n } else {\n // Complex expression - find matching child by expression content\n const match = findMatchingChild(operand as JsonLogicValue, children, usedChildIndices);\n let branchId: string;\n\n if (match) {\n usedChildIndices.add(match.index);\n branchId = processExpressionNode(match.child, context, {\n parentId: nodeId,\n argIndex: idx,\n });\n } else {\n // Fallback if no matching child found\n branchId = `${nodeId}-arg-${idx}`;\n }\n\n const summary = generateArgSummary(operand as JsonLogicValue);\n summary.label = generateExpressionText(operand as JsonLogicValue, TRUNCATION_LIMITS.expressionText);\n\n cells.push({\n type: 'branch',\n icon: cellIcon,\n branchId,\n index: idx,\n summary,\n });\n\n context.edges.push(createBranchEdge(nodeId, branchId, branchIndex));\n branchIndex++;\n }\n });\n\n const expressionText = generateExpressionText(expression);\n\n const node: LogicNode = {\n id: nodeId,\n type: 'verticalCell',\n position: { x: 0, y: 0 },\n data: {\n type: 'verticalCell',\n operator,\n category: meta.category,\n label: meta.label,\n icon,\n cells,\n collapsed: false,\n expressionText,\n expression,\n parentId: parentInfo.parentId,\n argIndex: parentInfo.argIndex,\n branchType: parentInfo.branchType,\n } as VerticalCellNodeData,\n };\n context.nodes.push(node);\n}\n\n// Create an operator node (single-arg or unary)\nfunction createOperatorNodeFromTrace(\n nodeId: string,\n expression: JsonLogicValue,\n children: ExpressionNode[],\n context: TraceContext,\n parentInfo: ParentInfo\n): void {\n const obj = expression as Record<string, unknown>;\n const operator = Object.keys(obj)[0];\n const operands = obj[operator];\n const operandArray: JsonLogicValue[] = Array.isArray(operands) ? operands : [operands];\n\n const meta = getOperatorMeta(operator);\n const expressionText = generateExpressionText(expression);\n const childIds: string[] = [];\n\n // For unary operators with simple operands, show inline\n const singleOperand = operandArray[0];\n const isUnaryWithSimpleArg = operandArray.length === 1 && isSimpleOperand(singleOperand);\n\n if (isUnaryWithSimpleArg) {\n // Map the simple operand child to this node (since it's inlined)\n const match = findMatchingChild(singleOperand, children, new Set());\n if (match) {\n const traceId = traceIdToNodeId(match.child.id);\n context.traceNodeMap.set(traceId, nodeId);\n // Also map any nested children\n if (match.child.children && match.child.children.length > 0) {\n mapInlinedChildren(match.child.children, nodeId, context.traceNodeMap);\n }\n }\n\n // Create inline operator node\n const node: LogicNode = {\n id: nodeId,\n type: 'operator',\n position: { x: 0, y: 0 },\n data: {\n type: 'operator',\n operator,\n category: meta.category,\n label: meta.label,\n childIds: [],\n collapsed: false,\n expressionText,\n expression,\n inlineDisplay: expressionText,\n parentId: parentInfo.parentId,\n argIndex: parentInfo.argIndex,\n branchType: parentInfo.branchType,\n } as OperatorNodeData,\n };\n context.nodes.push(node);\n return;\n }\n\n // Process children - match by expression content\n const usedChildIndices = new Set<number>();\n operandArray.forEach((operand, idx) => {\n if (!isSimpleOperand(operand)) {\n const match = findMatchingChild(operand, children, usedChildIndices);\n if (match) {\n usedChildIndices.add(match.index);\n const childId = processExpressionNode(match.child, context, {\n parentId: nodeId,\n argIndex: idx,\n });\n childIds.push(childId);\n }\n } else {\n // Simple operand is inlined - map the trace child to this parent node\n const match = findMatchingChild(operand, children, usedChildIndices);\n if (match) {\n usedChildIndices.add(match.index);\n const traceId = traceIdToNodeId(match.child.id);\n context.traceNodeMap.set(traceId, nodeId);\n // Also map any nested children\n if (match.child.children && match.child.children.length > 0) {\n mapInlinedChildren(match.child.children, nodeId, context.traceNodeMap);\n }\n }\n }\n });\n\n const node: LogicNode = {\n id: nodeId,\n type: 'operator',\n position: { x: 0, y: 0 },\n data: {\n type: 'operator',\n operator,\n category: meta.category,\n label: meta.label,\n childIds,\n collapsed: false,\n expressionText,\n expression,\n parentId: parentInfo.parentId,\n argIndex: parentInfo.argIndex,\n branchType: parentInfo.branchType,\n } as OperatorNodeData,\n };\n context.nodes.push(node);\n}\n","\"use strict\";\n\nvar DEFAULT_EDGE_NAME = \"\\x00\";\nvar GRAPH_NODE = \"\\x00\";\nvar EDGE_KEY_DELIM = \"\\x01\";\n\n// Implementation notes:\n//\n// * Node id query functions should return string ids for the nodes\n// * Edge id query functions should return an \"edgeObj\", edge object, that is\n// composed of enough information to uniquely identify an edge: {v, w, name}.\n// * Internally we use an \"edgeId\", a stringified form of the edgeObj, to\n// reference edges. This is because we need a performant way to look these\n// edges up and, object properties, which have string keys, are the closest\n// we're going to get to a performant hashtable in JavaScript.\n\nclass Graph {\n _isDirected = true;\n _isMultigraph = false;\n _isCompound = false;\n\n // Label for the graph itself\n _label;\n\n // Defaults to be set when creating a new node\n _defaultNodeLabelFn = () => undefined;\n\n // Defaults to be set when creating a new edge\n _defaultEdgeLabelFn = () => undefined;\n\n // v -> label\n _nodes = {};\n\n // v -> edgeObj\n _in = {};\n\n // u -> v -> Number\n _preds = {};\n\n // v -> edgeObj\n _out = {};\n\n // v -> w -> Number\n _sucs = {};\n\n // e -> edgeObj\n _edgeObjs = {};\n\n // e -> label\n _edgeLabels = {};\n\n /* Number of nodes in the graph. Should only be changed by the implementation. */\n _nodeCount = 0;\n\n /* Number of edges in the graph. Should only be changed by the implementation. */\n _edgeCount = 0;\n\n _parent;\n\n _children;\n\n constructor(opts) {\n if (opts) {\n this._isDirected = Object.hasOwn(opts, \"directed\") ? opts.directed : true;\n this._isMultigraph = Object.hasOwn(opts, \"multigraph\") ? opts.multigraph : false;\n this._isCompound = Object.hasOwn(opts, \"compound\") ? opts.compound : false;\n }\n\n if (this._isCompound) {\n // v -> parent\n this._parent = {};\n\n // v -> children\n this._children = {};\n this._children[GRAPH_NODE] = {};\n }\n }\n\n /* === Graph functions ========= */\n\n /**\n * Whether graph was created with 'directed' flag set to true or not.\n */\n isDirected() {\n return this._isDirected;\n }\n\n /**\n * Whether graph was created with 'multigraph' flag set to true or not.\n */\n isMultigraph() {\n return this._isMultigraph;\n }\n\n /**\n * Whether graph was created with 'compound' flag set to true or not.\n */\n isCompound() {\n return this._isCompound;\n }\n\n /**\n * Sets the label of the graph.\n */\n setGraph(label) {\n this._label = label;\n return this;\n }\n\n /**\n * Gets the graph label.\n */\n graph() {\n return this._label;\n }\n\n\n /* === Node functions ========== */\n\n /**\n * Sets the default node label. If newDefault is a function, it will be\n * invoked ach time when setting a label for a node. Otherwise, this label\n * will be assigned as default label in case if no label was specified while\n * setting a node.\n * Complexity: O(1).\n */\n setDefaultNodeLabel(newDefault) {\n this._defaultNodeLabelFn = newDefault;\n if (typeof newDefault !== 'function') {\n this._defaultNodeLabelFn = () => newDefault;\n }\n\n return this;\n }\n\n /**\n * Gets the number of nodes in the graph.\n * Complexity: O(1).\n */\n nodeCount() {\n return this._nodeCount;\n }\n\n /**\n * Gets all nodes of the graph. Note, the in case of compound graph subnodes are\n * not included in list.\n * Complexity: O(1).\n */\n nodes() {\n return Object.keys(this._nodes);\n }\n\n /**\n * Gets list of nodes without in-edges.\n * Complexity: O(|V|).\n */\n sources() {\n var self = this;\n return this.nodes().filter(v => Object.keys(self._in[v]).length === 0);\n }\n\n /**\n * Gets list of nodes without out-edges.\n * Complexity: O(|V|).\n */\n sinks() {\n var self = this;\n return this.nodes().filter(v => Object.keys(self._out[v]).length === 0);\n }\n\n /**\n * Invokes setNode method for each node in names list.\n * Complexity: O(|names|).\n */\n setNodes(vs, value) {\n var args = arguments;\n var self = this;\n vs.forEach(function(v) {\n if (args.length > 1) {\n self.setNode(v, value);\n } else {\n self.setNode(v);\n }\n });\n return this;\n }\n\n /**\n * Creates or updates the value for the node v in the graph. If label is supplied\n * it is set as the value for the node. If label is not supplied and the node was\n * created by this call then the default node label will be assigned.\n * Complexity: O(1).\n */\n setNode(v, value) {\n if (Object.hasOwn(this._nodes, v)) {\n if (arguments.length > 1) {\n this._nodes[v] = value;\n }\n return this;\n }\n\n this._nodes[v] = arguments.length > 1 ? value : this._defaultNodeLabelFn(v);\n if (this._isCompound) {\n this._parent[v] = GRAPH_NODE;\n this._children[v] = {};\n this._children[GRAPH_NODE][v] = true;\n }\n this._in[v] = {};\n this._preds[v] = {};\n this._out[v] = {};\n this._sucs[v] = {};\n ++this._nodeCount;\n return this;\n }\n\n /**\n * Gets the label of node with specified name.\n * Complexity: O(|V|).\n */\n node(v) {\n return this._nodes[v];\n }\n\n /**\n * Detects whether graph has a node with specified name or not.\n */\n hasNode(v) {\n return Object.hasOwn(this._nodes, v);\n }\n\n /**\n * Remove the node with the name from the graph or do nothing if the node is not in\n * the graph. If the node was removed this function also removes any incident\n * edges.\n * Complexity: O(1).\n */\n removeNode(v) {\n var self = this;\n if (Object.hasOwn(this._nodes, v)) {\n var removeEdge = e => self.removeEdge(self._edgeObjs[e]);\n delete this._nodes[v];\n if (this._isCompound) {\n this._removeFromParentsChildList(v);\n delete this._parent[v];\n this.children(v).forEach(function(child) {\n self.setParent(child);\n });\n delete this._children[v];\n }\n Object.keys(this._in[v]).forEach(removeEdge);\n delete this._in[v];\n delete this._preds[v];\n Object.keys(this._out[v]).forEach(removeEdge);\n delete this._out[v];\n delete this._sucs[v];\n --this._nodeCount;\n }\n return this;\n }\n\n /**\n * Sets node p as a parent for node v if it is defined, or removes the\n * parent for v if p is undefined. Method throws an exception in case of\n * invoking it in context of noncompound graph.\n * Average-case complexity: O(1).\n */\n setParent(v, parent) {\n if (!this._isCompound) {\n throw new Error(\"Cannot set parent in a non-compound graph\");\n }\n\n if (parent === undefined) {\n parent = GRAPH_NODE;\n } else {\n // Coerce parent to string\n parent += \"\";\n for (var ancestor = parent; ancestor !== undefined; ancestor = this.parent(ancestor)) {\n if (ancestor === v) {\n throw new Error(\"Setting \" + parent+ \" as parent of \" + v +\n \" would create a cycle\");\n }\n }\n\n this.setNode(parent);\n }\n\n this.setNode(v);\n this._removeFromParentsChildList(v);\n this._parent[v] = parent;\n this._children[parent][v] = true;\n return this;\n }\n\n _removeFromParentsChildList(v) {\n delete this._children[this._parent[v]][v];\n }\n\n /**\n * Gets parent node for node v.\n * Complexity: O(1).\n */\n parent(v) {\n if (this._isCompound) {\n var parent = this._parent[v];\n if (parent !== GRAPH_NODE) {\n return parent;\n }\n }\n }\n\n /**\n * Gets list of direct children of node v.\n * Complexity: O(1).\n */\n children(v = GRAPH_NODE) {\n if (this._isCompound) {\n var children = this._children[v];\n if (children) {\n return Object.keys(children);\n }\n } else if (v === GRAPH_NODE) {\n return this.nodes();\n } else if (this.hasNode(v)) {\n return [];\n }\n }\n\n /**\n * Return all nodes that are predecessors of the specified node or undefined if node v is not in\n * the graph. Behavior is undefined for undirected graphs - use neighbors instead.\n * Complexity: O(|V|).\n */\n predecessors(v) {\n var predsV = this._preds[v];\n if (predsV) {\n return Object.keys(predsV);\n }\n }\n\n /**\n * Return all nodes that are successors of the specified node or undefined if node v is not in\n * the graph. Behavior is undefined for undirected graphs - use neighbors instead.\n * Complexity: O(|V|).\n */\n successors(v) {\n var sucsV = this._sucs[v];\n if (sucsV) {\n return Object.keys(sucsV);\n }\n }\n\n /**\n * Return all nodes that are predecessors or successors of the specified node or undefined if\n * node v is not in the graph.\n * Complexity: O(|V|).\n */\n neighbors(v) {\n var preds = this.predecessors(v);\n if (preds) {\n const union = new Set(preds);\n for (var succ of this.successors(v)) {\n union.add(succ);\n }\n\n return Array.from(union.values());\n }\n }\n\n isLeaf(v) {\n var neighbors;\n if (this.isDirected()) {\n neighbors = this.successors(v);\n } else {\n neighbors = this.neighbors(v);\n }\n return neighbors.length === 0;\n }\n\n /**\n * Creates new graph with nodes filtered via filter. Edges incident to rejected node\n * are also removed. In case of compound graph, if parent is rejected by filter,\n * than all its children are rejected too.\n * Average-case complexity: O(|E|+|V|).\n */\n filterNodes(filter) {\n var copy = new this.constructor({\n directed: this._isDirected,\n multigraph: this._isMultigraph,\n compound: this._isCompound\n });\n\n copy.setGraph(this.graph());\n\n var self = this;\n Object.entries(this._nodes).forEach(function([v, value]) {\n if (filter(v)) {\n copy.setNode(v, value);\n }\n });\n\n Object.values(this._edgeObjs).forEach(function(e) {\n if (copy.hasNode(e.v) && copy.hasNode(e.w)) {\n copy.setEdge(e, self.edge(e));\n }\n });\n\n var parents = {};\n function findParent(v) {\n var parent = self.parent(v);\n if (parent === undefined || copy.hasNode(parent)) {\n parents[v] = parent;\n return parent;\n } else if (parent in parents) {\n return parents[parent];\n } else {\n return findParent(parent);\n }\n }\n\n if (this._isCompound) {\n copy.nodes().forEach(v => copy.setParent(v, findParent(v)));\n }\n\n return copy;\n }\n\n /* === Edge functions ========== */\n\n /**\n * Sets the default edge label or factory function. This label will be\n * assigned as default label in case if no label was specified while setting\n * an edge or this function will be invoked each time when setting an edge\n * with no label specified and returned value * will be used as a label for edge.\n * Complexity: O(1).\n */\n setDefaultEdgeLabel(newDefault) {\n this._defaultEdgeLabelFn = newDefault;\n if (typeof newDefault !== 'function') {\n this._defaultEdgeLabelFn = () => newDefault;\n }\n\n return this;\n }\n\n /**\n * Gets the number of edges in the graph.\n * Complexity: O(1).\n */\n edgeCount() {\n return this._edgeCount;\n }\n\n /**\n * Gets edges of the graph. In case of compound graph subgraphs are not considered.\n * Complexity: O(|E|).\n */\n edges() {\n return Object.values(this._edgeObjs);\n }\n\n /**\n * Establish an edges path over the nodes in nodes list. If some edge is already\n * exists, it will update its label, otherwise it will create an edge between pair\n * of nodes with label provided or default label if no label provided.\n * Complexity: O(|nodes|).\n */\n setPath(vs, value) {\n var self = this;\n var args = arguments;\n vs.reduce(function(v, w) {\n if (args.length > 1) {\n self.setEdge(v, w, value);\n } else {\n self.setEdge(v, w);\n }\n return w;\n });\n return this;\n }\n\n /**\n * Creates or updates the label for the edge (v, w) with the optionally supplied\n * name. If label is supplied it is set as the value for the edge. If label is not\n * supplied and the edge was created by this call then the default edge label will\n * be assigned. The name parameter is only useful with multigraphs.\n */\n setEdge() {\n var v, w, name, value;\n var valueSpecified = false;\n var arg0 = arguments[0];\n\n if (typeof arg0 === \"object\" && arg0 !== null && \"v\" in arg0) {\n v = arg0.v;\n w = arg0.w;\n name = arg0.name;\n if (arguments.length === 2) {\n value = arguments[1];\n valueSpecified = true;\n }\n } else {\n v = arg0;\n w = arguments[1];\n name = arguments[3];\n if (arguments.length > 2) {\n value = arguments[2];\n valueSpecified = true;\n }\n }\n\n v = \"\" + v;\n w = \"\" + w;\n if (name !== undefined) {\n name = \"\" + name;\n }\n\n var e = edgeArgsToId(this._isDirected, v, w, name);\n if (Object.hasOwn(this._edgeLabels, e)) {\n if (valueSpecified) {\n this._edgeLabels[e] = value;\n }\n return this;\n }\n\n if (name !== undefined && !this._isMultigraph) {\n throw new Error(\"Cannot set a named edge when isMultigraph = false\");\n }\n\n // It didn't exist, so we need to create it.\n // First ensure the nodes exist.\n this.setNode(v);\n this.setNode(w);\n\n this._edgeLabels[e] = valueSpecified ? value : this._defaultEdgeLabelFn(v, w, name);\n\n var edgeObj = edgeArgsToObj(this._isDirected, v, w, name);\n // Ensure we add undirected edges in a consistent way.\n v = edgeObj.v;\n w = edgeObj.w;\n\n Object.freeze(edgeObj);\n this._edgeObjs[e] = edgeObj;\n incrementOrInitEntry(this._preds[w], v);\n incrementOrInitEntry(this._sucs[v], w);\n this._in[w][e] = edgeObj;\n this._out[v][e] = edgeObj;\n this._edgeCount++;\n return this;\n }\n\n /**\n * Gets the label for the specified edge.\n * Complexity: O(1).\n */\n edge(v, w, name) {\n var e = (arguments.length === 1\n ? edgeObjToId(this._isDirected, arguments[0])\n : edgeArgsToId(this._isDirected, v, w, name));\n return this._edgeLabels[e];\n }\n\n /**\n * Gets the label for the specified edge and converts it to an object.\n * Complexity: O(1)\n */\n edgeAsObj() {\n const edge = this.edge(...arguments);\n if (typeof edge !== \"object\") {\n return {label: edge};\n }\n\n return edge;\n }\n\n /**\n * Detects whether the graph contains specified edge or not. No subgraphs are considered.\n * Complexity: O(1).\n */\n hasEdge(v, w, name) {\n var e = (arguments.length === 1\n ? edgeObjToId(this._isDirected, arguments[0])\n : edgeArgsToId(this._isDirected, v, w, name));\n return Object.hasOwn(this._edgeLabels, e);\n }\n\n /**\n * Removes the specified edge from the graph. No subgraphs are considered.\n * Complexity: O(1).\n */\n removeEdge(v, w, name) {\n var e = (arguments.length === 1\n ? edgeObjToId(this._isDirected, arguments[0])\n : edgeArgsToId(this._isDirected, v, w, name));\n var edge = this._edgeObjs[e];\n if (edge) {\n v = edge.v;\n w = edge.w;\n delete this._edgeLabels[e];\n delete this._edgeObjs[e];\n decrementOrRemoveEntry(this._preds[w], v);\n decrementOrRemoveEntry(this._sucs[v], w);\n delete this._in[w][e];\n delete this._out[v][e];\n this._edgeCount--;\n }\n return this;\n }\n\n /**\n * Return all edges that point to the node v. Optionally filters those edges down to just those\n * coming from node u. Behavior is undefined for undirected graphs - use nodeEdges instead.\n * Complexity: O(|E|).\n */\n inEdges(v, u) {\n var inV = this._in[v];\n if (inV) {\n var edges = Object.values(inV);\n if (!u) {\n return edges;\n }\n return edges.filter(edge => edge.v === u);\n }\n }\n\n /**\n * Return all edges that are pointed at by node v. Optionally filters those edges down to just\n * those point to w. Behavior is undefined for undirected graphs - use nodeEdges instead.\n * Complexity: O(|E|).\n */\n outEdges(v, w) {\n var outV = this._out[v];\n if (outV) {\n var edges = Object.values(outV);\n if (!w) {\n return edges;\n }\n return edges.filter(edge => edge.w === w);\n }\n }\n\n /**\n * Returns all edges to or from node v regardless of direction. Optionally filters those edges\n * down to just those between nodes v and w regardless of direction.\n * Complexity: O(|E|).\n */\n nodeEdges(v, w) {\n var inEdges = this.inEdges(v, w);\n if (inEdges) {\n return inEdges.concat(this.outEdges(v, w));\n }\n }\n}\n\nfunction incrementOrInitEntry(map, k) {\n if (map[k]) {\n map[k]++;\n } else {\n map[k] = 1;\n }\n}\n\nfunction decrementOrRemoveEntry(map, k) {\n if (!--map[k]) { delete map[k]; }\n}\n\nfunction edgeArgsToId(isDirected, v_, w_, name) {\n var v = \"\" + v_;\n var w = \"\" + w_;\n if (!isDirected && v > w) {\n var tmp = v;\n v = w;\n w = tmp;\n }\n return v + EDGE_KEY_DELIM + w + EDGE_KEY_DELIM +\n (name === undefined ? DEFAULT_EDGE_NAME : name);\n}\n\nfunction edgeArgsToObj(isDirected, v_, w_, name) {\n var v = \"\" + v_;\n var w = \"\" + w_;\n if (!isDirected && v > w) {\n var tmp = v;\n v = w;\n w = tmp;\n }\n var edgeObj = { v: v, w: w };\n if (name) {\n edgeObj.name = name;\n }\n return edgeObj;\n}\n\nfunction edgeObjToId(isDirected, edgeObj) {\n return edgeArgsToId(isDirected, edgeObj.v, edgeObj.w, edgeObj.name);\n}\n\nmodule.exports = Graph;\n","module.exports = '2.2.4';\n","// Includes only the \"core\" of graphlib\nmodule.exports = {\n Graph: require(\"./graph\"),\n version: require(\"./version\")\n};\n","var Graph = require(\"./graph\");\n\nmodule.exports = {\n write: write,\n read: read\n};\n\n/**\n * Creates a JSON representation of the graph that can be serialized to a string with\n * JSON.stringify. The graph can later be restored using json.read.\n */\nfunction write(g) {\n var json = {\n options: {\n directed: g.isDirected(),\n multigraph: g.isMultigraph(),\n compound: g.isCompound()\n },\n nodes: writeNodes(g),\n edges: writeEdges(g)\n };\n\n if (g.graph() !== undefined) {\n json.value = structuredClone(g.graph());\n }\n return json;\n}\n\nfunction writeNodes(g) {\n return g.nodes().map(function(v) {\n var nodeValue = g.node(v);\n var parent = g.parent(v);\n var node = { v: v };\n if (nodeValue !== undefined) {\n node.value = nodeValue;\n }\n if (parent !== undefined) {\n node.parent = parent;\n }\n return node;\n });\n}\n\nfunction writeEdges(g) {\n return g.edges().map(function(e) {\n var edgeValue = g.edge(e);\n var edge = { v: e.v, w: e.w };\n if (e.name !== undefined) {\n edge.name = e.name;\n }\n if (edgeValue !== undefined) {\n edge.value = edgeValue;\n }\n return edge;\n });\n}\n\n/**\n * Takes JSON as input and returns the graph representation.\n *\n * @example\n * var g2 = graphlib.json.read(JSON.parse(str));\n * g2.nodes();\n * // ['a', 'b']\n * g2.edges()\n * // [ { v: 'a', w: 'b' } ]\n */\nfunction read(json) {\n var g = new Graph(json.options).setGraph(json.value);\n json.nodes.forEach(function(entry) {\n g.setNode(entry.v, entry.value);\n if (entry.parent) {\n g.setParent(entry.v, entry.parent);\n }\n });\n json.edges.forEach(function(entry) {\n g.setEdge({ v: entry.v, w: entry.w, name: entry.name }, entry.value);\n });\n return g;\n}\n","module.exports = components;\n\nfunction components(g) {\n var visited = {};\n var cmpts = [];\n var cmpt;\n\n function dfs(v) {\n if (Object.hasOwn(visited, v)) return;\n visited[v] = true;\n cmpt.push(v);\n g.successors(v).forEach(dfs);\n g.predecessors(v).forEach(dfs);\n }\n\n g.nodes().forEach(function(v) {\n cmpt = [];\n dfs(v);\n if (cmpt.length) {\n cmpts.push(cmpt);\n }\n });\n\n return cmpts;\n}\n","/**\n * A min-priority queue data structure. This algorithm is derived from Cormen,\n * et al., \"Introduction to Algorithms\". The basic idea of a min-priority\n * queue is that you can efficiently (in O(1) time) get the smallest key in\n * the queue. Adding and removing elements takes O(log n) time. A key can\n * have its priority decreased in O(log n) time.\n */\nclass PriorityQueue {\n _arr = [];\n _keyIndices = {};\n\n /**\n * Returns the number of elements in the queue. Takes `O(1)` time.\n */\n size() {\n return this._arr.length;\n }\n\n /**\n * Returns the keys that are in the queue. Takes `O(n)` time.\n */\n keys() {\n return this._arr.map(function(x) { return x.key; });\n }\n\n /**\n * Returns `true` if **key** is in the queue and `false` if not.\n */\n has(key) {\n return Object.hasOwn(this._keyIndices, key);\n }\n\n /**\n * Returns the priority for **key**. If **key** is not present in the queue\n * then this function returns `undefined`. Takes `O(1)` time.\n *\n * @param {Object} key\n */\n priority(key) {\n var index = this._keyIndices[key];\n if (index !== undefined) {\n return this._arr[index].priority;\n }\n }\n\n /**\n * Returns the key for the minimum element in this queue. If the queue is\n * empty this function throws an Error. Takes `O(1)` time.\n */\n min() {\n if (this.size() === 0) {\n throw new Error(\"Queue underflow\");\n }\n return this._arr[0].key;\n }\n\n /**\n * Inserts a new key into the priority queue. If the key already exists in\n * the queue this function returns `false`; otherwise it will return `true`.\n * Takes `O(n)` time.\n *\n * @param {Object} key the key to add\n * @param {Number} priority the initial priority for the key\n */\n add(key, priority) {\n var keyIndices = this._keyIndices;\n key = String(key);\n if (!Object.hasOwn(keyIndices, key)) {\n var arr = this._arr;\n var index = arr.length;\n keyIndices[key] = index;\n arr.push({key: key, priority: priority});\n this._decrease(index);\n return true;\n }\n return false;\n }\n\n /**\n * Removes and returns the smallest key in the queue. Takes `O(log n)` time.\n */\n removeMin() {\n this._swap(0, this._arr.length - 1);\n var min = this._arr.pop();\n delete this._keyIndices[min.key];\n this._heapify(0);\n return min.key;\n }\n\n /**\n * Decreases the priority for **key** to **priority**. If the new priority is\n * greater than the previous priority, this function will throw an Error.\n *\n * @param {Object} key the key for which to raise priority\n * @param {Number} priority the new priority for the key\n */\n decrease(key, priority) {\n var index = this._keyIndices[key];\n if (priority > this._arr[index].priority) {\n throw new Error(\"New priority is greater than current priority. \" +\n \"Key: \" + key + \" Old: \" + this._arr[index].priority + \" New: \" + priority);\n }\n this._arr[index].priority = priority;\n this._decrease(index);\n }\n\n _heapify(i) {\n var arr = this._arr;\n var l = 2 * i;\n var r = l + 1;\n var largest = i;\n if (l < arr.length) {\n largest = arr[l].priority < arr[largest].priority ? l : largest;\n if (r < arr.length) {\n largest = arr[r].priority < arr[largest].priority ? r : largest;\n }\n if (largest !== i) {\n this._swap(i, largest);\n this._heapify(largest);\n }\n }\n }\n\n _decrease(index) {\n var arr = this._arr;\n var priority = arr[index].priority;\n var parent;\n while (index !== 0) {\n parent = index >> 1;\n if (arr[parent].priority < priority) {\n break;\n }\n this._swap(index, parent);\n index = parent;\n }\n }\n\n _swap(i, j) {\n var arr = this._arr;\n var keyIndices = this._keyIndices;\n var origArrI = arr[i];\n var origArrJ = arr[j];\n arr[i] = origArrJ;\n arr[j] = origArrI;\n keyIndices[origArrJ.key] = i;\n keyIndices[origArrI.key] = j;\n }\n}\n\nmodule.exports = PriorityQueue;\n","var PriorityQueue = require(\"../data/priority-queue\");\n\nmodule.exports = dijkstra;\n\nvar DEFAULT_WEIGHT_FUNC = () => 1;\n\nfunction dijkstra(g, source, weightFn, edgeFn) {\n return runDijkstra(g, String(source),\n weightFn || DEFAULT_WEIGHT_FUNC,\n edgeFn || function(v) { return g.outEdges(v); });\n}\n\nfunction runDijkstra(g, source, weightFn, edgeFn) {\n var results = {};\n var pq = new PriorityQueue();\n var v, vEntry;\n\n var updateNeighbors = function(edge) {\n var w = edge.v !== v ? edge.v : edge.w;\n var wEntry = results[w];\n var weight = weightFn(edge);\n var distance = vEntry.distance + weight;\n\n if (weight < 0) {\n throw new Error(\"dijkstra does not allow negative edge weights. \" +\n \"Bad edge: \" + edge + \" Weight: \" + weight);\n }\n\n if (distance < wEntry.distance) {\n wEntry.distance = distance;\n wEntry.predecessor = v;\n pq.decrease(w, distance);\n }\n };\n\n g.nodes().forEach(function(v) {\n var distance = v === source ? 0 : Number.POSITIVE_INFINITY;\n results[v] = { distance: distance };\n pq.add(v, distance);\n });\n\n while (pq.size() > 0) {\n v = pq.removeMin();\n vEntry = results[v];\n if (vEntry.distance === Number.POSITIVE_INFINITY) {\n break;\n }\n\n edgeFn(v).forEach(updateNeighbors);\n }\n\n return results;\n}\n","var dijkstra = require(\"./dijkstra\");\n\nmodule.exports = dijkstraAll;\n\nfunction dijkstraAll(g, weightFunc, edgeFunc) {\n return g.nodes().reduce(function(acc, v) {\n acc[v] = dijkstra(g, v, weightFunc, edgeFunc);\n return acc;\n }, {});\n}\n","module.exports = tarjan;\n\nfunction tarjan(g) {\n var index = 0;\n var stack = [];\n var visited = {}; // node id -> { onStack, lowlink, index }\n var results = [];\n\n function dfs(v) {\n var entry = visited[v] = {\n onStack: true,\n lowlink: index,\n index: index++\n };\n stack.push(v);\n\n g.successors(v).forEach(function(w) {\n if (!Object.hasOwn(visited, w)) {\n dfs(w);\n entry.lowlink = Math.min(entry.lowlink, visited[w].lowlink);\n } else if (visited[w].onStack) {\n entry.lowlink = Math.min(entry.lowlink, visited[w].index);\n }\n });\n\n if (entry.lowlink === entry.index) {\n var cmpt = [];\n var w;\n do {\n w = stack.pop();\n visited[w].onStack = false;\n cmpt.push(w);\n } while (v !== w);\n results.push(cmpt);\n }\n }\n\n g.nodes().forEach(function(v) {\n if (!Object.hasOwn(visited, v)) {\n dfs(v);\n }\n });\n\n return results;\n}\n","var tarjan = require(\"./tarjan\");\n\nmodule.exports = findCycles;\n\nfunction findCycles(g) {\n return tarjan(g).filter(function(cmpt) {\n return cmpt.length > 1 || (cmpt.length === 1 && g.hasEdge(cmpt[0], cmpt[0]));\n });\n}\n","module.exports = floydWarshall;\n\nvar DEFAULT_WEIGHT_FUNC = () => 1;\n\nfunction floydWarshall(g, weightFn, edgeFn) {\n return runFloydWarshall(g,\n weightFn || DEFAULT_WEIGHT_FUNC,\n edgeFn || function(v) { return g.outEdges(v); });\n}\n\nfunction runFloydWarshall(g, weightFn, edgeFn) {\n var results = {};\n var nodes = g.nodes();\n\n nodes.forEach(function(v) {\n results[v] = {};\n results[v][v] = { distance: 0 };\n nodes.forEach(function(w) {\n if (v !== w) {\n results[v][w] = { distance: Number.POSITIVE_INFINITY };\n }\n });\n edgeFn(v).forEach(function(edge) {\n var w = edge.v === v ? edge.w : edge.v;\n var d = weightFn(edge);\n results[v][w] = { distance: d, predecessor: v };\n });\n });\n\n nodes.forEach(function(k) {\n var rowK = results[k];\n nodes.forEach(function(i) {\n var rowI = results[i];\n nodes.forEach(function(j) {\n var ik = rowI[k];\n var kj = rowK[j];\n var ij = rowI[j];\n var altDistance = ik.distance + kj.distance;\n if (altDistance < ij.distance) {\n ij.distance = altDistance;\n ij.predecessor = kj.predecessor;\n }\n });\n });\n });\n\n return results;\n}\n","function topsort(g) {\n var visited = {};\n var stack = {};\n var results = [];\n\n function visit(node) {\n if (Object.hasOwn(stack, node)) {\n throw new CycleException();\n }\n\n if (!Object.hasOwn(visited, node)) {\n stack[node] = true;\n visited[node] = true;\n g.predecessors(node).forEach(visit);\n delete stack[node];\n results.push(node);\n }\n }\n\n g.sinks().forEach(visit);\n\n if (Object.keys(visited).length !== g.nodeCount()) {\n throw new CycleException();\n }\n\n return results;\n}\n\nclass CycleException extends Error {\n constructor() {\n super(...arguments);\n }\n}\n\nmodule.exports = topsort;\ntopsort.CycleException = CycleException;\n","var topsort = require(\"./topsort\");\n\nmodule.exports = isAcyclic;\n\nfunction isAcyclic(g) {\n try {\n topsort(g);\n } catch (e) {\n if (e instanceof topsort.CycleException) {\n return false;\n }\n throw e;\n }\n return true;\n}\n","module.exports = dfs;\n\n/*\n * A helper that preforms a pre- or post-order traversal on the input graph\n * and returns the nodes in the order they were visited. If the graph is\n * undirected then this algorithm will navigate using neighbors. If the graph\n * is directed then this algorithm will navigate using successors.\n *\n * If the order is not \"post\", it will be treated as \"pre\".\n */\nfunction dfs(g, vs, order) {\n if (!Array.isArray(vs)) {\n vs = [vs];\n }\n\n var navigation = g.isDirected() ? v => g.successors(v) : v => g.neighbors(v);\n var orderFunc = order === \"post\" ? postOrderDfs : preOrderDfs;\n\n var acc = [];\n var visited = {};\n vs.forEach(v => {\n if (!g.hasNode(v)) {\n throw new Error(\"Graph does not have node: \" + v);\n }\n\n orderFunc(v, navigation, visited, acc);\n });\n\n return acc;\n}\n\nfunction postOrderDfs(v, navigation, visited, acc) {\n var stack = [[v, false]];\n while (stack.length > 0) {\n var curr = stack.pop();\n if (curr[1]) {\n acc.push(curr[0]);\n } else {\n if (!Object.hasOwn(visited, curr[0])) {\n visited[curr[0]] = true;\n stack.push([curr[0], true]);\n forEachRight(navigation(curr[0]), w => stack.push([w, false]));\n }\n }\n }\n}\n\nfunction preOrderDfs(v, navigation, visited, acc) {\n var stack = [v];\n while (stack.length > 0) {\n var curr = stack.pop();\n if (!Object.hasOwn(visited, curr)) {\n visited[curr] = true;\n acc.push(curr);\n forEachRight(navigation(curr), w => stack.push(w));\n }\n }\n}\n\nfunction forEachRight(array, iteratee) {\n var length = array.length;\n while (length--) {\n iteratee(array[length], length, array);\n }\n\n return array;\n}\n","var dfs = require(\"./dfs\");\n\nmodule.exports = postorder;\n\nfunction postorder(g, vs) {\n return dfs(g, vs, \"post\");\n}\n","var dfs = require(\"./dfs\");\n\nmodule.exports = preorder;\n\nfunction preorder(g, vs) {\n return dfs(g, vs, \"pre\");\n}\n","var Graph = require(\"../graph\");\nvar PriorityQueue = require(\"../data/priority-queue\");\n\nmodule.exports = prim;\n\nfunction prim(g, weightFunc) {\n var result = new Graph();\n var parents = {};\n var pq = new PriorityQueue();\n var v;\n\n function updateNeighbors(edge) {\n var w = edge.v === v ? edge.w : edge.v;\n var pri = pq.priority(w);\n if (pri !== undefined) {\n var edgeWeight = weightFunc(edge);\n if (edgeWeight < pri) {\n parents[w] = v;\n pq.decrease(w, edgeWeight);\n }\n }\n }\n\n if (g.nodeCount() === 0) {\n return result;\n }\n\n g.nodes().forEach(function(v) {\n pq.add(v, Number.POSITIVE_INFINITY);\n result.setNode(v);\n });\n\n // Start from an arbitrary node\n pq.decrease(g.nodes()[0], 0);\n\n var init = false;\n while (pq.size() > 0) {\n v = pq.removeMin();\n if (Object.hasOwn(parents, v)) {\n result.setEdge(v, parents[v]);\n } else if (init) {\n throw new Error(\"Input graph is not connected: \" + g);\n } else {\n init = true;\n }\n\n g.nodeEdges(v).forEach(updateNeighbors);\n }\n\n return result;\n}\n","module.exports = {\n components: require(\"./components\"),\n dijkstra: require(\"./dijkstra\"),\n dijkstraAll: require(\"./dijkstra-all\"),\n findCycles: require(\"./find-cycles\"),\n floydWarshall: require(\"./floyd-warshall\"),\n isAcyclic: require(\"./is-acyclic\"),\n postorder: require(\"./postorder\"),\n preorder: require(\"./preorder\"),\n prim: require(\"./prim\"),\n tarjan: require(\"./tarjan\"),\n topsort: require(\"./topsort\")\n};\n","/**\n * Copyright (c) 2014, Chris Pettitt\n * All rights reserved.\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are met:\n *\n * 1. Redistributions of source code must retain the above copyright notice, this\n * list of conditions and the following disclaimer.\n *\n * 2. Redistributions in binary form must reproduce the above copyright notice,\n * this list of conditions and the following disclaimer in the documentation\n * and/or other materials provided with the distribution.\n *\n * 3. Neither the name of the copyright holder nor the names of its contributors\n * may be used to endorse or promote products derived from this software without\n * specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\n * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\n * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\n * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\n * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\n * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\nvar lib = require(\"./lib\");\n\nmodule.exports = {\n Graph: lib.Graph,\n json: require(\"./lib/json\"),\n alg: require(\"./lib/alg\"),\n version: lib.version\n};\n","/*\n * Simple doubly linked list implementation derived from Cormen, et al.,\n * \"Introduction to Algorithms\".\n */\n\nclass List {\n constructor() {\n let sentinel = {};\n sentinel._next = sentinel._prev = sentinel;\n this._sentinel = sentinel;\n }\n\n dequeue() {\n let sentinel = this._sentinel;\n let entry = sentinel._prev;\n if (entry !== sentinel) {\n unlink(entry);\n return entry;\n }\n }\n\n enqueue(entry) {\n let sentinel = this._sentinel;\n if (entry._prev && entry._next) {\n unlink(entry);\n }\n entry._next = sentinel._next;\n sentinel._next._prev = entry;\n sentinel._next = entry;\n entry._prev = sentinel;\n }\n\n toString() {\n let strs = [];\n let sentinel = this._sentinel;\n let curr = sentinel._prev;\n while (curr !== sentinel) {\n strs.push(JSON.stringify(curr, filterOutLinks));\n curr = curr._prev;\n }\n return \"[\" + strs.join(\", \") + \"]\";\n }\n}\n\nfunction unlink(entry) {\n entry._prev._next = entry._next;\n entry._next._prev = entry._prev;\n delete entry._next;\n delete entry._prev;\n}\n\nfunction filterOutLinks(k, v) {\n if (k !== \"_next\" && k !== \"_prev\") {\n return v;\n }\n}\n\nmodule.exports = List;\n","let Graph = require(\"@dagrejs/graphlib\").Graph;\nlet List = require(\"./data/list\");\n\n/*\n * A greedy heuristic for finding a feedback arc set for a graph. A feedback\n * arc set is a set of edges that can be removed to make a graph acyclic.\n * The algorithm comes from: P. Eades, X. Lin, and W. F. Smyth, \"A fast and\n * effective heuristic for the feedback arc set problem.\" This implementation\n * adjusts that from the paper to allow for weighted edges.\n */\nmodule.exports = greedyFAS;\n\nlet DEFAULT_WEIGHT_FN = () => 1;\n\nfunction greedyFAS(g, weightFn) {\n if (g.nodeCount() <= 1) {\n return [];\n }\n let state = buildState(g, weightFn || DEFAULT_WEIGHT_FN);\n let results = doGreedyFAS(state.graph, state.buckets, state.zeroIdx);\n\n // Expand multi-edges\n return results.flatMap(e => g.outEdges(e.v, e.w));\n}\n\nfunction doGreedyFAS(g, buckets, zeroIdx) {\n let results = [];\n let sources = buckets[buckets.length - 1];\n let sinks = buckets[0];\n\n let entry;\n while (g.nodeCount()) {\n while ((entry = sinks.dequeue())) { removeNode(g, buckets, zeroIdx, entry); }\n while ((entry = sources.dequeue())) { removeNode(g, buckets, zeroIdx, entry); }\n if (g.nodeCount()) {\n for (let i = buckets.length - 2; i > 0; --i) {\n entry = buckets[i].dequeue();\n if (entry) {\n results = results.concat(removeNode(g, buckets, zeroIdx, entry, true));\n break;\n }\n }\n }\n }\n\n return results;\n}\n\nfunction removeNode(g, buckets, zeroIdx, entry, collectPredecessors) {\n let results = collectPredecessors ? [] : undefined;\n\n g.inEdges(entry.v).forEach(edge => {\n let weight = g.edge(edge);\n let uEntry = g.node(edge.v);\n\n if (collectPredecessors) {\n results.push({ v: edge.v, w: edge.w });\n }\n\n uEntry.out -= weight;\n assignBucket(buckets, zeroIdx, uEntry);\n });\n\n g.outEdges(entry.v).forEach(edge => {\n let weight = g.edge(edge);\n let w = edge.w;\n let wEntry = g.node(w);\n wEntry[\"in\"] -= weight;\n assignBucket(buckets, zeroIdx, wEntry);\n });\n\n g.removeNode(entry.v);\n\n return results;\n}\n\nfunction buildState(g, weightFn) {\n let fasGraph = new Graph();\n let maxIn = 0;\n let maxOut = 0;\n\n g.nodes().forEach(v => {\n fasGraph.setNode(v, { v: v, \"in\": 0, out: 0 });\n });\n\n // Aggregate weights on nodes, but also sum the weights across multi-edges\n // into a single edge for the fasGraph.\n g.edges().forEach(e => {\n let prevWeight = fasGraph.edge(e.v, e.w) || 0;\n let weight = weightFn(e);\n let edgeWeight = prevWeight + weight;\n fasGraph.setEdge(e.v, e.w, edgeWeight);\n maxOut = Math.max(maxOut, fasGraph.node(e.v).out += weight);\n maxIn = Math.max(maxIn, fasGraph.node(e.w)[\"in\"] += weight);\n });\n\n let buckets = range(maxOut + maxIn + 3).map(() => new List());\n let zeroIdx = maxIn + 1;\n\n fasGraph.nodes().forEach(v => {\n assignBucket(buckets, zeroIdx, fasGraph.node(v));\n });\n\n return { graph: fasGraph, buckets: buckets, zeroIdx: zeroIdx };\n}\n\nfunction assignBucket(buckets, zeroIdx, entry) {\n if (!entry.out) {\n buckets[0].enqueue(entry);\n } else if (!entry[\"in\"]) {\n buckets[buckets.length - 1].enqueue(entry);\n } else {\n buckets[entry.out - entry[\"in\"] + zeroIdx].enqueue(entry);\n }\n}\n\nfunction range(limit) {\n const range = [];\n for (let i = 0; i < limit; i++) {\n range.push(i);\n }\n\n return range;\n}\n","/* eslint \"no-console\": off */\n\n\"use strict\";\n\nlet Graph = require(\"@dagrejs/graphlib\").Graph;\n\nmodule.exports = {\n addBorderNode,\n addDummyNode,\n applyWithChunking,\n asNonCompoundGraph,\n buildLayerMatrix,\n intersectRect,\n mapValues,\n maxRank,\n normalizeRanks,\n notime,\n partition,\n pick,\n predecessorWeights,\n range,\n removeEmptyRanks,\n simplify,\n successorWeights,\n time,\n uniqueId,\n zipObject,\n};\n\n/*\n * Adds a dummy node to the graph and return v.\n */\nfunction addDummyNode(g, type, attrs, name) {\n var v = name;\n while (g.hasNode(v)) {\n v = uniqueId(name);\n }\n\n attrs.dummy = type;\n g.setNode(v, attrs);\n return v;\n}\n\n/*\n * Returns a new graph with only simple edges. Handles aggregation of data\n * associated with multi-edges.\n */\nfunction simplify(g) {\n let simplified = new Graph().setGraph(g.graph());\n g.nodes().forEach(v => simplified.setNode(v, g.node(v)));\n g.edges().forEach(e => {\n let simpleLabel = simplified.edge(e.v, e.w) || { weight: 0, minlen: 1 };\n let label = g.edge(e);\n simplified.setEdge(e.v, e.w, {\n weight: simpleLabel.weight + label.weight,\n minlen: Math.max(simpleLabel.minlen, label.minlen)\n });\n });\n return simplified;\n}\n\nfunction asNonCompoundGraph(g) {\n let simplified = new Graph({ multigraph: g.isMultigraph() }).setGraph(g.graph());\n g.nodes().forEach(v => {\n if (!g.children(v).length) {\n simplified.setNode(v, g.node(v));\n }\n });\n g.edges().forEach(e => {\n simplified.setEdge(e, g.edge(e));\n });\n return simplified;\n}\n\nfunction successorWeights(g) {\n let weightMap = g.nodes().map(v => {\n let sucs = {};\n g.outEdges(v).forEach(e => {\n sucs[e.w] = (sucs[e.w] || 0) + g.edge(e).weight;\n });\n return sucs;\n });\n return zipObject(g.nodes(), weightMap);\n}\n\nfunction predecessorWeights(g) {\n let weightMap = g.nodes().map(v => {\n let preds = {};\n g.inEdges(v).forEach(e => {\n preds[e.v] = (preds[e.v] || 0) + g.edge(e).weight;\n });\n return preds;\n });\n return zipObject(g.nodes(), weightMap);\n}\n\n/*\n * Finds where a line starting at point ({x, y}) would intersect a rectangle\n * ({x, y, width, height}) if it were pointing at the rectangle's center.\n */\nfunction intersectRect(rect, point) {\n let x = rect.x;\n let y = rect.y;\n\n // Rectangle intersection algorithm from:\n // http://math.stackexchange.com/questions/108113/find-edge-between-two-boxes\n let dx = point.x - x;\n let dy = point.y - y;\n let w = rect.width / 2;\n let h = rect.height / 2;\n\n if (!dx && !dy) {\n throw new Error(\"Not possible to find intersection inside of the rectangle\");\n }\n\n let sx, sy;\n if (Math.abs(dy) * w > Math.abs(dx) * h) {\n // Intersection is top or bottom of rect.\n if (dy < 0) {\n h = -h;\n }\n sx = h * dx / dy;\n sy = h;\n } else {\n // Intersection is left or right of rect.\n if (dx < 0) {\n w = -w;\n }\n sx = w;\n sy = w * dy / dx;\n }\n\n return { x: x + sx, y: y + sy };\n}\n\n/*\n * Given a DAG with each node assigned \"rank\" and \"order\" properties, this\n * function will produce a matrix with the ids of each node.\n */\nfunction buildLayerMatrix(g) {\n let layering = range(maxRank(g) + 1).map(() => []);\n g.nodes().forEach(v => {\n let node = g.node(v);\n let rank = node.rank;\n if (rank !== undefined) {\n layering[rank][node.order] = v;\n }\n });\n return layering;\n}\n\n/*\n * Adjusts the ranks for all nodes in the graph such that all nodes v have\n * rank(v) >= 0 and at least one node w has rank(w) = 0.\n */\nfunction normalizeRanks(g) {\n let nodeRanks = g.nodes().map(v => {\n let rank = g.node(v).rank;\n if (rank === undefined) {\n return Number.MAX_VALUE;\n }\n\n return rank;\n });\n let min = applyWithChunking(Math.min, nodeRanks);\n g.nodes().forEach(v => {\n let node = g.node(v);\n if (Object.hasOwn(node, \"rank\")) {\n node.rank -= min;\n }\n });\n}\n\nfunction removeEmptyRanks(g) {\n // Ranks may not start at 0, so we need to offset them\n let nodeRanks = g.nodes().map(v => g.node(v).rank);\n let offset = applyWithChunking(Math.min, nodeRanks);\n\n let layers = [];\n g.nodes().forEach(v => {\n let rank = g.node(v).rank - offset;\n if (!layers[rank]) {\n layers[rank] = [];\n }\n layers[rank].push(v);\n });\n\n let delta = 0;\n let nodeRankFactor = g.graph().nodeRankFactor;\n Array.from(layers).forEach((vs, i) => {\n if (vs === undefined && i % nodeRankFactor !== 0) {\n --delta;\n } else if (vs !== undefined && delta) {\n vs.forEach(v => g.node(v).rank += delta);\n }\n });\n}\n\nfunction addBorderNode(g, prefix, rank, order) {\n let node = {\n width: 0,\n height: 0\n };\n if (arguments.length >= 4) {\n node.rank = rank;\n node.order = order;\n }\n return addDummyNode(g, \"border\", node, prefix);\n}\n\nfunction splitToChunks(array, chunkSize = CHUNKING_THRESHOLD) {\n const chunks = [];\n for (let i = 0; i < array.length; i += chunkSize) {\n const chunk = array.slice(i, i + chunkSize);\n chunks.push(chunk);\n }\n return chunks;\n}\n\nconst CHUNKING_THRESHOLD = 65535;\n\nfunction applyWithChunking(fn, argsArray) {\n if(argsArray.length > CHUNKING_THRESHOLD) {\n const chunks = splitToChunks(argsArray);\n return fn.apply(null, chunks.map(chunk => fn.apply(null, chunk)));\n } else {\n return fn.apply(null, argsArray);\n }\n}\n\nfunction maxRank(g) {\n const nodes = g.nodes();\n const nodeRanks = nodes.map(v => {\n let rank = g.node(v).rank;\n if (rank === undefined) {\n return Number.MIN_VALUE;\n }\n return rank;\n });\n\n return applyWithChunking(Math.max, nodeRanks);\n}\n\n/*\n * Partition a collection into two groups: `lhs` and `rhs`. If the supplied\n * function returns true for an entry it goes into `lhs`. Otherwise it goes\n * into `rhs.\n */\nfunction partition(collection, fn) {\n let result = { lhs: [], rhs: [] };\n collection.forEach(value => {\n if (fn(value)) {\n result.lhs.push(value);\n } else {\n result.rhs.push(value);\n }\n });\n return result;\n}\n\n/*\n * Returns a new function that wraps `fn` with a timer. The wrapper logs the\n * time it takes to execute the function.\n */\nfunction time(name, fn) {\n let start = Date.now();\n try {\n return fn();\n } finally {\n console.log(name + \" time: \" + (Date.now() - start) + \"ms\");\n }\n}\n\nfunction notime(name, fn) {\n return fn();\n}\n\nlet idCounter = 0;\nfunction uniqueId(prefix) {\n var id = ++idCounter;\n return prefix + (\"\" + id);\n}\n\nfunction range(start, limit, step = 1) {\n if (limit == null) {\n limit = start;\n start = 0;\n }\n\n let endCon = (i) => i < limit;\n if (step < 0) {\n endCon = (i) => limit < i;\n }\n\n const range = [];\n for (let i = start; endCon(i); i += step) {\n range.push(i);\n }\n\n return range;\n}\n\nfunction pick(source, keys) {\n const dest = {};\n for (const key of keys) {\n if (source[key] !== undefined) {\n dest[key] = source[key];\n }\n }\n\n return dest;\n}\n\nfunction mapValues(obj, funcOrProp) {\n let func = funcOrProp;\n if (typeof funcOrProp === 'string') {\n func = (val) => val[funcOrProp];\n }\n\n return Object.entries(obj).reduce((acc, [k, v]) => {\n acc[k] = func(v, k);\n return acc;\n }, {});\n}\n\nfunction zipObject(props, values) {\n return props.reduce((acc, key, i) => {\n acc[key] = values[i];\n return acc;\n }, {});\n}\n","\"use strict\";\n\nlet greedyFAS = require(\"./greedy-fas\");\nlet uniqueId = require(\"./util\").uniqueId;\n\nmodule.exports = {\n run: run,\n undo: undo\n};\n\nfunction run(g) {\n let fas = (g.graph().acyclicer === \"greedy\"\n ? greedyFAS(g, weightFn(g))\n : dfsFAS(g));\n fas.forEach(e => {\n let label = g.edge(e);\n g.removeEdge(e);\n label.forwardName = e.name;\n label.reversed = true;\n g.setEdge(e.w, e.v, label, uniqueId(\"rev\"));\n });\n\n function weightFn(g) {\n return e => {\n return g.edge(e).weight;\n };\n }\n}\n\nfunction dfsFAS(g) {\n let fas = [];\n let stack = {};\n let visited = {};\n\n function dfs(v) {\n if (Object.hasOwn(visited, v)) {\n return;\n }\n visited[v] = true;\n stack[v] = true;\n g.outEdges(v).forEach(e => {\n if (Object.hasOwn(stack, e.w)) {\n fas.push(e);\n } else {\n dfs(e.w);\n }\n });\n delete stack[v];\n }\n\n g.nodes().forEach(dfs);\n return fas;\n}\n\nfunction undo(g) {\n g.edges().forEach(e => {\n let label = g.edge(e);\n if (label.reversed) {\n g.removeEdge(e);\n\n let forwardName = label.forwardName;\n delete label.reversed;\n delete label.forwardName;\n g.setEdge(e.w, e.v, label, forwardName);\n }\n });\n}\n","\"use strict\";\n\nlet util = require(\"./util\");\n\nmodule.exports = {\n run: run,\n undo: undo\n};\n\n/*\n * Breaks any long edges in the graph into short segments that span 1 layer\n * each. This operation is undoable with the denormalize function.\n *\n * Pre-conditions:\n *\n * 1. The input graph is a DAG.\n * 2. Each node in the graph has a \"rank\" property.\n *\n * Post-condition:\n *\n * 1. All edges in the graph have a length of 1.\n * 2. Dummy nodes are added where edges have been split into segments.\n * 3. The graph is augmented with a \"dummyChains\" attribute which contains\n * the first dummy in each chain of dummy nodes produced.\n */\nfunction run(g) {\n g.graph().dummyChains = [];\n g.edges().forEach(edge => normalizeEdge(g, edge));\n}\n\nfunction normalizeEdge(g, e) {\n let v = e.v;\n let vRank = g.node(v).rank;\n let w = e.w;\n let wRank = g.node(w).rank;\n let name = e.name;\n let edgeLabel = g.edge(e);\n let labelRank = edgeLabel.labelRank;\n\n if (wRank === vRank + 1) return;\n\n g.removeEdge(e);\n\n let dummy, attrs, i;\n for (i = 0, ++vRank; vRank < wRank; ++i, ++vRank) {\n edgeLabel.points = [];\n attrs = {\n width: 0, height: 0,\n edgeLabel: edgeLabel, edgeObj: e,\n rank: vRank\n };\n dummy = util.addDummyNode(g, \"edge\", attrs, \"_d\");\n if (vRank === labelRank) {\n attrs.width = edgeLabel.width;\n attrs.height = edgeLabel.height;\n attrs.dummy = \"edge-label\";\n attrs.labelpos = edgeLabel.labelpos;\n }\n g.setEdge(v, dummy, { weight: edgeLabel.weight }, name);\n if (i === 0) {\n g.graph().dummyChains.push(dummy);\n }\n v = dummy;\n }\n\n g.setEdge(v, w, { weight: edgeLabel.weight }, name);\n}\n\nfunction undo(g) {\n g.graph().dummyChains.forEach(v => {\n let node = g.node(v);\n let origLabel = node.edgeLabel;\n let w;\n g.setEdge(node.edgeObj, origLabel);\n while (node.dummy) {\n w = g.successors(v)[0];\n g.removeNode(v);\n origLabel.points.push({ x: node.x, y: node.y });\n if (node.dummy === \"edge-label\") {\n origLabel.x = node.x;\n origLabel.y = node.y;\n origLabel.width = node.width;\n origLabel.height = node.height;\n }\n v = w;\n node = g.node(v);\n }\n });\n}\n","\"use strict\";\n\nconst { applyWithChunking } = require(\"../util\");\n\nmodule.exports = {\n longestPath: longestPath,\n slack: slack\n};\n\n/*\n * Initializes ranks for the input graph using the longest path algorithm. This\n * algorithm scales well and is fast in practice, it yields rather poor\n * solutions. Nodes are pushed to the lowest layer possible, leaving the bottom\n * ranks wide and leaving edges longer than necessary. However, due to its\n * speed, this algorithm is good for getting an initial ranking that can be fed\n * into other algorithms.\n *\n * This algorithm does not normalize layers because it will be used by other\n * algorithms in most cases. If using this algorithm directly, be sure to\n * run normalize at the end.\n *\n * Pre-conditions:\n *\n * 1. Input graph is a DAG.\n * 2. Input graph node labels can be assigned properties.\n *\n * Post-conditions:\n *\n * 1. Each node will be assign an (unnormalized) \"rank\" property.\n */\nfunction longestPath(g) {\n var visited = {};\n\n function dfs(v) {\n var label = g.node(v);\n if (Object.hasOwn(visited, v)) {\n return label.rank;\n }\n visited[v] = true;\n\n let outEdgesMinLens = g.outEdges(v).map(e => {\n if (e == null) {\n return Number.POSITIVE_INFINITY;\n }\n\n return dfs(e.w) - g.edge(e).minlen;\n });\n\n var rank = applyWithChunking(Math.min, outEdgesMinLens);\n\n if (rank === Number.POSITIVE_INFINITY) {\n rank = 0;\n }\n\n return (label.rank = rank);\n }\n\n g.sources().forEach(dfs);\n}\n\n/*\n * Returns the amount of slack for the given edge. The slack is defined as the\n * difference between the length of the edge and its minimum length.\n */\nfunction slack(g, e) {\n return g.node(e.w).rank - g.node(e.v).rank - g.edge(e).minlen;\n}\n","\"use strict\";\n\nvar Graph = require(\"@dagrejs/graphlib\").Graph;\nvar slack = require(\"./util\").slack;\n\nmodule.exports = feasibleTree;\n\n/*\n * Constructs a spanning tree with tight edges and adjusted the input node's\n * ranks to achieve this. A tight edge is one that is has a length that matches\n * its \"minlen\" attribute.\n *\n * The basic structure for this function is derived from Gansner, et al., \"A\n * Technique for Drawing Directed Graphs.\"\n *\n * Pre-conditions:\n *\n * 1. Graph must be a DAG.\n * 2. Graph must be connected.\n * 3. Graph must have at least one node.\n * 5. Graph nodes must have been previously assigned a \"rank\" property that\n * respects the \"minlen\" property of incident edges.\n * 6. Graph edges must have a \"minlen\" property.\n *\n * Post-conditions:\n *\n * - Graph nodes will have their rank adjusted to ensure that all edges are\n * tight.\n *\n * Returns a tree (undirected graph) that is constructed using only \"tight\"\n * edges.\n */\nfunction feasibleTree(g) {\n var t = new Graph({ directed: false });\n\n // Choose arbitrary node from which to start our tree\n var start = g.nodes()[0];\n var size = g.nodeCount();\n t.setNode(start, {});\n\n var edge, delta;\n while (tightTree(t, g) < size) {\n edge = findMinSlackEdge(t, g);\n delta = t.hasNode(edge.v) ? slack(g, edge) : -slack(g, edge);\n shiftRanks(t, g, delta);\n }\n\n return t;\n}\n\n/*\n * Finds a maximal tree of tight edges and returns the number of nodes in the\n * tree.\n */\nfunction tightTree(t, g) {\n function dfs(v) {\n g.nodeEdges(v).forEach(e => {\n var edgeV = e.v,\n w = (v === edgeV) ? e.w : edgeV;\n if (!t.hasNode(w) && !slack(g, e)) {\n t.setNode(w, {});\n t.setEdge(v, w, {});\n dfs(w);\n }\n });\n }\n\n t.nodes().forEach(dfs);\n return t.nodeCount();\n}\n\n/*\n * Finds the edge with the smallest slack that is incident on tree and returns\n * it.\n */\nfunction findMinSlackEdge(t, g) {\n const edges = g.edges();\n\n return edges.reduce((acc, edge) => {\n let edgeSlack = Number.POSITIVE_INFINITY;\n if (t.hasNode(edge.v) !== t.hasNode(edge.w)) {\n edgeSlack = slack(g, edge);\n }\n\n if (edgeSlack < acc[0]) {\n return [edgeSlack, edge];\n }\n\n return acc;\n }, [Number.POSITIVE_INFINITY, null])[1];\n}\n\nfunction shiftRanks(t, g, delta) {\n t.nodes().forEach(v => g.node(v).rank += delta);\n}\n","\"use strict\";\n\nvar feasibleTree = require(\"./feasible-tree\");\nvar slack = require(\"./util\").slack;\nvar initRank = require(\"./util\").longestPath;\nvar preorder = require(\"@dagrejs/graphlib\").alg.preorder;\nvar postorder = require(\"@dagrejs/graphlib\").alg.postorder;\nvar simplify = require(\"../util\").simplify;\n\nmodule.exports = networkSimplex;\n\n// Expose some internals for testing purposes\nnetworkSimplex.initLowLimValues = initLowLimValues;\nnetworkSimplex.initCutValues = initCutValues;\nnetworkSimplex.calcCutValue = calcCutValue;\nnetworkSimplex.leaveEdge = leaveEdge;\nnetworkSimplex.enterEdge = enterEdge;\nnetworkSimplex.exchangeEdges = exchangeEdges;\n\n/*\n * The network simplex algorithm assigns ranks to each node in the input graph\n * and iteratively improves the ranking to reduce the length of edges.\n *\n * Preconditions:\n *\n * 1. The input graph must be a DAG.\n * 2. All nodes in the graph must have an object value.\n * 3. All edges in the graph must have \"minlen\" and \"weight\" attributes.\n *\n * Postconditions:\n *\n * 1. All nodes in the graph will have an assigned \"rank\" attribute that has\n * been optimized by the network simplex algorithm. Ranks start at 0.\n *\n *\n * A rough sketch of the algorithm is as follows:\n *\n * 1. Assign initial ranks to each node. We use the longest path algorithm,\n * which assigns ranks to the lowest position possible. In general this\n * leads to very wide bottom ranks and unnecessarily long edges.\n * 2. Construct a feasible tight tree. A tight tree is one such that all\n * edges in the tree have no slack (difference between length of edge\n * and minlen for the edge). This by itself greatly improves the assigned\n * rankings by shorting edges.\n * 3. Iteratively find edges that have negative cut values. Generally a\n * negative cut value indicates that the edge could be removed and a new\n * tree edge could be added to produce a more compact graph.\n *\n * Much of the algorithms here are derived from Gansner, et al., \"A Technique\n * for Drawing Directed Graphs.\" The structure of the file roughly follows the\n * structure of the overall algorithm.\n */\nfunction networkSimplex(g) {\n g = simplify(g);\n initRank(g);\n var t = feasibleTree(g);\n initLowLimValues(t);\n initCutValues(t, g);\n\n var e, f;\n while ((e = leaveEdge(t))) {\n f = enterEdge(t, g, e);\n exchangeEdges(t, g, e, f);\n }\n}\n\n/*\n * Initializes cut values for all edges in the tree.\n */\nfunction initCutValues(t, g) {\n var vs = postorder(t, t.nodes());\n vs = vs.slice(0, vs.length - 1);\n vs.forEach(v => assignCutValue(t, g, v));\n}\n\nfunction assignCutValue(t, g, child) {\n var childLab = t.node(child);\n var parent = childLab.parent;\n t.edge(child, parent).cutvalue = calcCutValue(t, g, child);\n}\n\n/*\n * Given the tight tree, its graph, and a child in the graph calculate and\n * return the cut value for the edge between the child and its parent.\n */\nfunction calcCutValue(t, g, child) {\n var childLab = t.node(child);\n var parent = childLab.parent;\n // True if the child is on the tail end of the edge in the directed graph\n var childIsTail = true;\n // The graph's view of the tree edge we're inspecting\n var graphEdge = g.edge(child, parent);\n // The accumulated cut value for the edge between this node and its parent\n var cutValue = 0;\n\n if (!graphEdge) {\n childIsTail = false;\n graphEdge = g.edge(parent, child);\n }\n\n cutValue = graphEdge.weight;\n\n g.nodeEdges(child).forEach(e => {\n var isOutEdge = e.v === child,\n other = isOutEdge ? e.w : e.v;\n\n if (other !== parent) {\n var pointsToHead = isOutEdge === childIsTail,\n otherWeight = g.edge(e).weight;\n\n cutValue += pointsToHead ? otherWeight : -otherWeight;\n if (isTreeEdge(t, child, other)) {\n var otherCutValue = t.edge(child, other).cutvalue;\n cutValue += pointsToHead ? -otherCutValue : otherCutValue;\n }\n }\n });\n\n return cutValue;\n}\n\nfunction initLowLimValues(tree, root) {\n if (arguments.length < 2) {\n root = tree.nodes()[0];\n }\n dfsAssignLowLim(tree, {}, 1, root);\n}\n\nfunction dfsAssignLowLim(tree, visited, nextLim, v, parent) {\n var low = nextLim;\n var label = tree.node(v);\n\n visited[v] = true;\n tree.neighbors(v).forEach(w => {\n if (!Object.hasOwn(visited, w)) {\n nextLim = dfsAssignLowLim(tree, visited, nextLim, w, v);\n }\n });\n\n label.low = low;\n label.lim = nextLim++;\n if (parent) {\n label.parent = parent;\n } else {\n // TODO should be able to remove this when we incrementally update low lim\n delete label.parent;\n }\n\n return nextLim;\n}\n\nfunction leaveEdge(tree) {\n return tree.edges().find(e => tree.edge(e).cutvalue < 0);\n}\n\nfunction enterEdge(t, g, edge) {\n var v = edge.v;\n var w = edge.w;\n\n // For the rest of this function we assume that v is the tail and w is the\n // head, so if we don't have this edge in the graph we should flip it to\n // match the correct orientation.\n if (!g.hasEdge(v, w)) {\n v = edge.w;\n w = edge.v;\n }\n\n var vLabel = t.node(v);\n var wLabel = t.node(w);\n var tailLabel = vLabel;\n var flip = false;\n\n // If the root is in the tail of the edge then we need to flip the logic that\n // checks for the head and tail nodes in the candidates function below.\n if (vLabel.lim > wLabel.lim) {\n tailLabel = wLabel;\n flip = true;\n }\n\n var candidates = g.edges().filter(edge => {\n return flip === isDescendant(t, t.node(edge.v), tailLabel) &&\n flip !== isDescendant(t, t.node(edge.w), tailLabel);\n });\n\n return candidates.reduce((acc, edge) => {\n if (slack(g, edge) < slack(g, acc)) {\n return edge;\n }\n\n return acc;\n });\n}\n\nfunction exchangeEdges(t, g, e, f) {\n var v = e.v;\n var w = e.w;\n t.removeEdge(v, w);\n t.setEdge(f.v, f.w, {});\n initLowLimValues(t);\n initCutValues(t, g);\n updateRanks(t, g);\n}\n\nfunction updateRanks(t, g) {\n var root = t.nodes().find(v => !g.node(v).parent);\n var vs = preorder(t, root);\n vs = vs.slice(1);\n vs.forEach(v => {\n var parent = t.node(v).parent,\n edge = g.edge(v, parent),\n flipped = false;\n\n if (!edge) {\n edge = g.edge(parent, v);\n flipped = true;\n }\n\n g.node(v).rank = g.node(parent).rank + (flipped ? edge.minlen : -edge.minlen);\n });\n}\n\n/*\n * Returns true if the edge is in the tree.\n */\nfunction isTreeEdge(tree, u, v) {\n return tree.hasEdge(u, v);\n}\n\n/*\n * Returns true if the specified node is descendant of the root node per the\n * assigned low and lim attributes in the tree.\n */\nfunction isDescendant(tree, vLabel, rootLabel) {\n return rootLabel.low <= vLabel.lim && vLabel.lim <= rootLabel.lim;\n}\n","\"use strict\";\n\nvar rankUtil = require(\"./util\");\nvar longestPath = rankUtil.longestPath;\nvar feasibleTree = require(\"./feasible-tree\");\nvar networkSimplex = require(\"./network-simplex\");\n\nmodule.exports = rank;\n\n/*\n * Assigns a rank to each node in the input graph that respects the \"minlen\"\n * constraint specified on edges between nodes.\n *\n * This basic structure is derived from Gansner, et al., \"A Technique for\n * Drawing Directed Graphs.\"\n *\n * Pre-conditions:\n *\n * 1. Graph must be a connected DAG\n * 2. Graph nodes must be objects\n * 3. Graph edges must have \"weight\" and \"minlen\" attributes\n *\n * Post-conditions:\n *\n * 1. Graph nodes will have a \"rank\" attribute based on the results of the\n * algorithm. Ranks can start at any index (including negative), we'll\n * fix them up later.\n */\nfunction rank(g) {\n var ranker = g.graph().ranker;\n if (ranker instanceof Function) {\n return ranker(g);\n }\n\n switch(g.graph().ranker) {\n case \"network-simplex\": networkSimplexRanker(g); break;\n case \"tight-tree\": tightTreeRanker(g); break;\n case \"longest-path\": longestPathRanker(g); break;\n case \"none\": break;\n default: networkSimplexRanker(g);\n }\n}\n\n// A fast and simple ranker, but results are far from optimal.\nvar longestPathRanker = longestPath;\n\nfunction tightTreeRanker(g) {\n longestPath(g);\n feasibleTree(g);\n}\n\nfunction networkSimplexRanker(g) {\n networkSimplex(g);\n}\n","module.exports = parentDummyChains;\n\nfunction parentDummyChains(g) {\n let postorderNums = postorder(g);\n\n g.graph().dummyChains.forEach(v => {\n let node = g.node(v);\n let edgeObj = node.edgeObj;\n let pathData = findPath(g, postorderNums, edgeObj.v, edgeObj.w);\n let path = pathData.path;\n let lca = pathData.lca;\n let pathIdx = 0;\n let pathV = path[pathIdx];\n let ascending = true;\n\n while (v !== edgeObj.w) {\n node = g.node(v);\n\n if (ascending) {\n while ((pathV = path[pathIdx]) !== lca &&\n g.node(pathV).maxRank < node.rank) {\n pathIdx++;\n }\n\n if (pathV === lca) {\n ascending = false;\n }\n }\n\n if (!ascending) {\n while (pathIdx < path.length - 1 &&\n g.node(pathV = path[pathIdx + 1]).minRank <= node.rank) {\n pathIdx++;\n }\n pathV = path[pathIdx];\n }\n\n g.setParent(v, pathV);\n v = g.successors(v)[0];\n }\n });\n}\n\n// Find a path from v to w through the lowest common ancestor (LCA). Return the\n// full path and the LCA.\nfunction findPath(g, postorderNums, v, w) {\n let vPath = [];\n let wPath = [];\n let low = Math.min(postorderNums[v].low, postorderNums[w].low);\n let lim = Math.max(postorderNums[v].lim, postorderNums[w].lim);\n let parent;\n let lca;\n\n // Traverse up from v to find the LCA\n parent = v;\n do {\n parent = g.parent(parent);\n vPath.push(parent);\n } while (parent &&\n (postorderNums[parent].low > low || lim > postorderNums[parent].lim));\n lca = parent;\n\n // Traverse from w to LCA\n parent = w;\n while ((parent = g.parent(parent)) !== lca) {\n wPath.push(parent);\n }\n\n return { path: vPath.concat(wPath.reverse()), lca: lca };\n}\n\nfunction postorder(g) {\n let result = {};\n let lim = 0;\n\n function dfs(v) {\n let low = lim;\n g.children(v).forEach(dfs);\n result[v] = { low: low, lim: lim++ };\n }\n g.children().forEach(dfs);\n\n return result;\n}\n","let util = require(\"./util\");\n\nmodule.exports = {\n run,\n cleanup,\n};\n\n/*\n * A nesting graph creates dummy nodes for the tops and bottoms of subgraphs,\n * adds appropriate edges to ensure that all cluster nodes are placed between\n * these boundaries, and ensures that the graph is connected.\n *\n * In addition we ensure, through the use of the minlen property, that nodes\n * and subgraph border nodes to not end up on the same rank.\n *\n * Preconditions:\n *\n * 1. Input graph is a DAG\n * 2. Nodes in the input graph has a minlen attribute\n *\n * Postconditions:\n *\n * 1. Input graph is connected.\n * 2. Dummy nodes are added for the tops and bottoms of subgraphs.\n * 3. The minlen attribute for nodes is adjusted to ensure nodes do not\n * get placed on the same rank as subgraph border nodes.\n *\n * The nesting graph idea comes from Sander, \"Layout of Compound Directed\n * Graphs.\"\n */\nfunction run(g) {\n let root = util.addDummyNode(g, \"root\", {}, \"_root\");\n let depths = treeDepths(g);\n let depthsArr = Object.values(depths);\n let height = util.applyWithChunking(Math.max, depthsArr) - 1; // Note: depths is an Object not an array\n let nodeSep = 2 * height + 1;\n\n g.graph().nestingRoot = root;\n\n // Multiply minlen by nodeSep to align nodes on non-border ranks.\n g.edges().forEach(e => g.edge(e).minlen *= nodeSep);\n\n // Calculate a weight that is sufficient to keep subgraphs vertically compact\n let weight = sumWeights(g) + 1;\n\n // Create border nodes and link them up\n g.children().forEach(child => dfs(g, root, nodeSep, weight, height, depths, child));\n\n // Save the multiplier for node layers for later removal of empty border\n // layers.\n g.graph().nodeRankFactor = nodeSep;\n}\n\nfunction dfs(g, root, nodeSep, weight, height, depths, v) {\n let children = g.children(v);\n if (!children.length) {\n if (v !== root) {\n g.setEdge(root, v, { weight: 0, minlen: nodeSep });\n }\n return;\n }\n\n let top = util.addBorderNode(g, \"_bt\");\n let bottom = util.addBorderNode(g, \"_bb\");\n let label = g.node(v);\n\n g.setParent(top, v);\n label.borderTop = top;\n g.setParent(bottom, v);\n label.borderBottom = bottom;\n\n children.forEach(child => {\n dfs(g, root, nodeSep, weight, height, depths, child);\n\n let childNode = g.node(child);\n let childTop = childNode.borderTop ? childNode.borderTop : child;\n let childBottom = childNode.borderBottom ? childNode.borderBottom : child;\n let thisWeight = childNode.borderTop ? weight : 2 * weight;\n let minlen = childTop !== childBottom ? 1 : height - depths[v] + 1;\n\n g.setEdge(top, childTop, {\n weight: thisWeight,\n minlen: minlen,\n nestingEdge: true\n });\n\n g.setEdge(childBottom, bottom, {\n weight: thisWeight,\n minlen: minlen,\n nestingEdge: true\n });\n });\n\n if (!g.parent(v)) {\n g.setEdge(root, top, { weight: 0, minlen: height + depths[v] });\n }\n}\n\nfunction treeDepths(g) {\n var depths = {};\n function dfs(v, depth) {\n var children = g.children(v);\n if (children && children.length) {\n children.forEach(child => dfs(child, depth + 1));\n }\n depths[v] = depth;\n }\n g.children().forEach(v => dfs(v, 1));\n return depths;\n}\n\nfunction sumWeights(g) {\n return g.edges().reduce((acc, e) => acc + g.edge(e).weight, 0);\n}\n\nfunction cleanup(g) {\n var graphLabel = g.graph();\n g.removeNode(graphLabel.nestingRoot);\n delete graphLabel.nestingRoot;\n g.edges().forEach(e => {\n var edge = g.edge(e);\n if (edge.nestingEdge) {\n g.removeEdge(e);\n }\n });\n}\n","let util = require(\"./util\");\n\nmodule.exports = addBorderSegments;\n\nfunction addBorderSegments(g) {\n function dfs(v) {\n let children = g.children(v);\n let node = g.node(v);\n if (children.length) {\n children.forEach(dfs);\n }\n\n if (Object.hasOwn(node, \"minRank\")) {\n node.borderLeft = [];\n node.borderRight = [];\n for (let rank = node.minRank, maxRank = node.maxRank + 1;\n rank < maxRank;\n ++rank) {\n addBorderNode(g, \"borderLeft\", \"_bl\", v, node, rank);\n addBorderNode(g, \"borderRight\", \"_br\", v, node, rank);\n }\n }\n }\n\n g.children().forEach(dfs);\n}\n\nfunction addBorderNode(g, prop, prefix, sg, sgNode, rank) {\n let label = { width: 0, height: 0, rank: rank, borderType: prop };\n let prev = sgNode[prop][rank - 1];\n let curr = util.addDummyNode(g, \"border\", label, prefix);\n sgNode[prop][rank] = curr;\n g.setParent(curr, sg);\n if (prev) {\n g.setEdge(prev, curr, { weight: 1 });\n }\n}\n","\"use strict\";\n\nmodule.exports = {\n adjust: adjust,\n undo: undo\n};\n\nfunction adjust(g) {\n let rankDir = g.graph().rankdir.toLowerCase();\n if (rankDir === \"lr\" || rankDir === \"rl\") {\n swapWidthHeight(g);\n }\n}\n\nfunction undo(g) {\n let rankDir = g.graph().rankdir.toLowerCase();\n if (rankDir === \"bt\" || rankDir === \"rl\") {\n reverseY(g);\n }\n\n if (rankDir === \"lr\" || rankDir === \"rl\") {\n swapXY(g);\n swapWidthHeight(g);\n }\n}\n\nfunction swapWidthHeight(g) {\n g.nodes().forEach(v => swapWidthHeightOne(g.node(v)));\n g.edges().forEach(e => swapWidthHeightOne(g.edge(e)));\n}\n\nfunction swapWidthHeightOne(attrs) {\n let w = attrs.width;\n attrs.width = attrs.height;\n attrs.height = w;\n}\n\nfunction reverseY(g) {\n g.nodes().forEach(v => reverseYOne(g.node(v)));\n\n g.edges().forEach(e => {\n let edge = g.edge(e);\n edge.points.forEach(reverseYOne);\n if (Object.hasOwn(edge, \"y\")) {\n reverseYOne(edge);\n }\n });\n}\n\nfunction reverseYOne(attrs) {\n attrs.y = -attrs.y;\n}\n\nfunction swapXY(g) {\n g.nodes().forEach(v => swapXYOne(g.node(v)));\n\n g.edges().forEach(e => {\n let edge = g.edge(e);\n edge.points.forEach(swapXYOne);\n if (Object.hasOwn(edge, \"x\")) {\n swapXYOne(edge);\n }\n });\n}\n\nfunction swapXYOne(attrs) {\n let x = attrs.x;\n attrs.x = attrs.y;\n attrs.y = x;\n}\n","\"use strict\";\n\nlet util = require(\"../util\");\n\nmodule.exports = initOrder;\n\n/*\n * Assigns an initial order value for each node by performing a DFS search\n * starting from nodes in the first rank. Nodes are assigned an order in their\n * rank as they are first visited.\n *\n * This approach comes from Gansner, et al., \"A Technique for Drawing Directed\n * Graphs.\"\n *\n * Returns a layering matrix with an array per layer and each layer sorted by\n * the order of its nodes.\n */\nfunction initOrder(g) {\n let visited = {};\n let simpleNodes = g.nodes().filter(v => !g.children(v).length);\n let simpleNodesRanks = simpleNodes.map(v => g.node(v).rank);\n let maxRank = util.applyWithChunking(Math.max, simpleNodesRanks);\n let layers = util.range(maxRank + 1).map(() => []);\n\n function dfs(v) {\n if (visited[v]) return;\n visited[v] = true;\n let node = g.node(v);\n layers[node.rank].push(v);\n g.successors(v).forEach(dfs);\n }\n\n let orderedVs = simpleNodes.sort((a, b) => g.node(a).rank - g.node(b).rank);\n orderedVs.forEach(dfs);\n\n return layers;\n}\n","\"use strict\";\n\nlet zipObject = require(\"../util\").zipObject;\n\nmodule.exports = crossCount;\n\n/*\n * A function that takes a layering (an array of layers, each with an array of\n * ordererd nodes) and a graph and returns a weighted crossing count.\n *\n * Pre-conditions:\n *\n * 1. Input graph must be simple (not a multigraph), directed, and include\n * only simple edges.\n * 2. Edges in the input graph must have assigned weights.\n *\n * Post-conditions:\n *\n * 1. The graph and layering matrix are left unchanged.\n *\n * This algorithm is derived from Barth, et al., \"Bilayer Cross Counting.\"\n */\nfunction crossCount(g, layering) {\n let cc = 0;\n for (let i = 1; i < layering.length; ++i) {\n cc += twoLayerCrossCount(g, layering[i-1], layering[i]);\n }\n return cc;\n}\n\nfunction twoLayerCrossCount(g, northLayer, southLayer) {\n // Sort all of the edges between the north and south layers by their position\n // in the north layer and then the south. Map these edges to the position of\n // their head in the south layer.\n let southPos = zipObject(southLayer, southLayer.map((v, i) => i));\n let southEntries = northLayer.flatMap(v => {\n return g.outEdges(v).map(e => {\n return { pos: southPos[e.w], weight: g.edge(e).weight };\n }).sort((a, b) => a.pos - b.pos);\n });\n\n // Build the accumulator tree\n let firstIndex = 1;\n while (firstIndex < southLayer.length) firstIndex <<= 1;\n let treeSize = 2 * firstIndex - 1;\n firstIndex -= 1;\n let tree = new Array(treeSize).fill(0);\n\n // Calculate the weighted crossings\n let cc = 0;\n southEntries.forEach(entry => {\n let index = entry.pos + firstIndex;\n tree[index] += entry.weight;\n let weightSum = 0;\n while (index > 0) {\n if (index % 2) {\n weightSum += tree[index + 1];\n }\n index = (index - 1) >> 1;\n tree[index] += entry.weight;\n }\n cc += entry.weight * weightSum;\n });\n\n return cc;\n}\n","module.exports = barycenter;\n\nfunction barycenter(g, movable = []) {\n return movable.map(v => {\n let inV = g.inEdges(v);\n if (!inV.length) {\n return { v: v };\n } else {\n let result = inV.reduce((acc, e) => {\n let edge = g.edge(e),\n nodeU = g.node(e.v);\n return {\n sum: acc.sum + (edge.weight * nodeU.order),\n weight: acc.weight + edge.weight\n };\n }, { sum: 0, weight: 0 });\n\n return {\n v: v,\n barycenter: result.sum / result.weight,\n weight: result.weight\n };\n }\n });\n}\n\n","\"use strict\";\n\nlet util = require(\"../util\");\n\nmodule.exports = resolveConflicts;\n\n/*\n * Given a list of entries of the form {v, barycenter, weight} and a\n * constraint graph this function will resolve any conflicts between the\n * constraint graph and the barycenters for the entries. If the barycenters for\n * an entry would violate a constraint in the constraint graph then we coalesce\n * the nodes in the conflict into a new node that respects the contraint and\n * aggregates barycenter and weight information.\n *\n * This implementation is based on the description in Forster, \"A Fast and\n * Simple Hueristic for Constrained Two-Level Crossing Reduction,\" thought it\n * differs in some specific details.\n *\n * Pre-conditions:\n *\n * 1. Each entry has the form {v, barycenter, weight}, or if the node has\n * no barycenter, then {v}.\n *\n * Returns:\n *\n * A new list of entries of the form {vs, i, barycenter, weight}. The list\n * `vs` may either be a singleton or it may be an aggregation of nodes\n * ordered such that they do not violate constraints from the constraint\n * graph. The property `i` is the lowest original index of any of the\n * elements in `vs`.\n */\nfunction resolveConflicts(entries, cg) {\n let mappedEntries = {};\n entries.forEach((entry, i) => {\n let tmp = mappedEntries[entry.v] = {\n indegree: 0,\n \"in\": [],\n out: [],\n vs: [entry.v],\n i: i\n };\n if (entry.barycenter !== undefined) {\n tmp.barycenter = entry.barycenter;\n tmp.weight = entry.weight;\n }\n });\n\n cg.edges().forEach(e => {\n let entryV = mappedEntries[e.v];\n let entryW = mappedEntries[e.w];\n if (entryV !== undefined && entryW !== undefined) {\n entryW.indegree++;\n entryV.out.push(mappedEntries[e.w]);\n }\n });\n\n let sourceSet = Object.values(mappedEntries).filter(entry => !entry.indegree);\n\n return doResolveConflicts(sourceSet);\n}\n\nfunction doResolveConflicts(sourceSet) {\n let entries = [];\n\n function handleIn(vEntry) {\n return uEntry => {\n if (uEntry.merged) {\n return;\n }\n if (uEntry.barycenter === undefined ||\n vEntry.barycenter === undefined ||\n uEntry.barycenter >= vEntry.barycenter) {\n mergeEntries(vEntry, uEntry);\n }\n };\n }\n\n function handleOut(vEntry) {\n return wEntry => {\n wEntry[\"in\"].push(vEntry);\n if (--wEntry.indegree === 0) {\n sourceSet.push(wEntry);\n }\n };\n }\n\n while (sourceSet.length) {\n let entry = sourceSet.pop();\n entries.push(entry);\n entry[\"in\"].reverse().forEach(handleIn(entry));\n entry.out.forEach(handleOut(entry));\n }\n\n return entries.filter(entry => !entry.merged).map(entry => {\n return util.pick(entry, [\"vs\", \"i\", \"barycenter\", \"weight\"]);\n });\n}\n\nfunction mergeEntries(target, source) {\n let sum = 0;\n let weight = 0;\n\n if (target.weight) {\n sum += target.barycenter * target.weight;\n weight += target.weight;\n }\n\n if (source.weight) {\n sum += source.barycenter * source.weight;\n weight += source.weight;\n }\n\n target.vs = source.vs.concat(target.vs);\n target.barycenter = sum / weight;\n target.weight = weight;\n target.i = Math.min(source.i, target.i);\n source.merged = true;\n}\n","let util = require(\"../util\");\n\nmodule.exports = sort;\n\nfunction sort(entries, biasRight) {\n let parts = util.partition(entries, entry => {\n return Object.hasOwn(entry, \"barycenter\");\n });\n let sortable = parts.lhs,\n unsortable = parts.rhs.sort((a, b) => b.i - a.i),\n vs = [],\n sum = 0,\n weight = 0,\n vsIndex = 0;\n\n sortable.sort(compareWithBias(!!biasRight));\n\n vsIndex = consumeUnsortable(vs, unsortable, vsIndex);\n\n sortable.forEach(entry => {\n vsIndex += entry.vs.length;\n vs.push(entry.vs);\n sum += entry.barycenter * entry.weight;\n weight += entry.weight;\n vsIndex = consumeUnsortable(vs, unsortable, vsIndex);\n });\n\n let result = { vs: vs.flat(true) };\n if (weight) {\n result.barycenter = sum / weight;\n result.weight = weight;\n }\n return result;\n}\n\nfunction consumeUnsortable(vs, unsortable, index) {\n let last;\n while (unsortable.length && (last = unsortable[unsortable.length - 1]).i <= index) {\n unsortable.pop();\n vs.push(last.vs);\n index++;\n }\n return index;\n}\n\nfunction compareWithBias(bias) {\n return (entryV, entryW) => {\n if (entryV.barycenter < entryW.barycenter) {\n return -1;\n } else if (entryV.barycenter > entryW.barycenter) {\n return 1;\n }\n\n return !bias ? entryV.i - entryW.i : entryW.i - entryV.i;\n };\n}\n","let barycenter = require(\"./barycenter\");\nlet resolveConflicts = require(\"./resolve-conflicts\");\nlet sort = require(\"./sort\");\n\nmodule.exports = sortSubgraph;\n\nfunction sortSubgraph(g, v, cg, biasRight) {\n let movable = g.children(v);\n let node = g.node(v);\n let bl = node ? node.borderLeft : undefined;\n let br = node ? node.borderRight: undefined;\n let subgraphs = {};\n\n if (bl) {\n movable = movable.filter(w => w !== bl && w !== br);\n }\n\n let barycenters = barycenter(g, movable);\n barycenters.forEach(entry => {\n if (g.children(entry.v).length) {\n let subgraphResult = sortSubgraph(g, entry.v, cg, biasRight);\n subgraphs[entry.v] = subgraphResult;\n if (Object.hasOwn(subgraphResult, \"barycenter\")) {\n mergeBarycenters(entry, subgraphResult);\n }\n }\n });\n\n let entries = resolveConflicts(barycenters, cg);\n expandSubgraphs(entries, subgraphs);\n\n let result = sort(entries, biasRight);\n\n if (bl) {\n result.vs = [bl, result.vs, br].flat(true);\n if (g.predecessors(bl).length) {\n let blPred = g.node(g.predecessors(bl)[0]),\n brPred = g.node(g.predecessors(br)[0]);\n if (!Object.hasOwn(result, \"barycenter\")) {\n result.barycenter = 0;\n result.weight = 0;\n }\n result.barycenter = (result.barycenter * result.weight +\n blPred.order + brPred.order) / (result.weight + 2);\n result.weight += 2;\n }\n }\n\n return result;\n}\n\nfunction expandSubgraphs(entries, subgraphs) {\n entries.forEach(entry => {\n entry.vs = entry.vs.flatMap(v => {\n if (subgraphs[v]) {\n return subgraphs[v].vs;\n }\n return v;\n });\n });\n}\n\nfunction mergeBarycenters(target, other) {\n if (target.barycenter !== undefined) {\n target.barycenter = (target.barycenter * target.weight +\n other.barycenter * other.weight) /\n (target.weight + other.weight);\n target.weight += other.weight;\n } else {\n target.barycenter = other.barycenter;\n target.weight = other.weight;\n }\n}\n","let Graph = require(\"@dagrejs/graphlib\").Graph;\nlet util = require(\"../util\");\n\nmodule.exports = buildLayerGraph;\n\n/*\n * Constructs a graph that can be used to sort a layer of nodes. The graph will\n * contain all base and subgraph nodes from the request layer in their original\n * hierarchy and any edges that are incident on these nodes and are of the type\n * requested by the \"relationship\" parameter.\n *\n * Nodes from the requested rank that do not have parents are assigned a root\n * node in the output graph, which is set in the root graph attribute. This\n * makes it easy to walk the hierarchy of movable nodes during ordering.\n *\n * Pre-conditions:\n *\n * 1. Input graph is a DAG\n * 2. Base nodes in the input graph have a rank attribute\n * 3. Subgraph nodes in the input graph has minRank and maxRank attributes\n * 4. Edges have an assigned weight\n * 5. If `nodesWithRank` is not undefined, it must contains only the nodes\n * which belong to `g` and belong to `rank`.\n *\n * Post-conditions:\n *\n * 1. Output graph has all nodes in the movable rank with preserved\n * hierarchy.\n * 2. Root nodes in the movable layer are made children of the node\n * indicated by the root attribute of the graph.\n * 3. Non-movable nodes incident on movable nodes, selected by the\n * relationship parameter, are included in the graph (without hierarchy).\n * 4. Edges incident on movable nodes, selected by the relationship\n * parameter, are added to the output graph.\n * 5. The weights for copied edges are aggregated as need, since the output\n * graph is not a multi-graph.\n */\nfunction buildLayerGraph(g, rank, relationship, nodesWithRank) {\n if (!nodesWithRank) {\n nodesWithRank = g.nodes();\n }\n let root = createRootNode(g),\n result = new Graph({ compound: true })\n .setGraph({ root: root })\n .setDefaultNodeLabel((v) => g.node(v));\n\n nodesWithRank.forEach((v) => {\n let node = g.node(v),\n parent = g.parent(v);\n\n if (node.rank === rank || node.minRank <= rank && rank <= node.maxRank) {\n result.setNode(v);\n result.setParent(v, parent || root);\n\n // This assumes we have only short edges!\n g[relationship](v).forEach(e => {\n let u = e.v === v ? e.w : e.v,\n edge = result.edge(u, v),\n weight = edge !== undefined ? edge.weight : 0;\n result.setEdge(u, v, { weight: g.edge(e).weight + weight });\n });\n\n if (Object.hasOwn(node, \"minRank\")) {\n result.setNode(v, {\n borderLeft: node.borderLeft[rank],\n borderRight: node.borderRight[rank]\n });\n }\n }\n });\n\n return result;\n}\n\nfunction createRootNode(g) {\n var v;\n while (g.hasNode((v = util.uniqueId(\"_root\"))));\n return v;\n}\n","module.exports = addSubgraphConstraints;\n\nfunction addSubgraphConstraints(g, cg, vs) {\n let prev = {},\n rootPrev;\n\n vs.forEach(v => {\n let child = g.parent(v),\n parent,\n prevChild;\n while (child) {\n parent = g.parent(child);\n if (parent) {\n prevChild = prev[parent];\n prev[parent] = child;\n } else {\n prevChild = rootPrev;\n rootPrev = child;\n }\n if (prevChild && prevChild !== child) {\n cg.setEdge(prevChild, child);\n return;\n }\n child = parent;\n }\n });\n\n /*\n function dfs(v) {\n var children = v ? g.children(v) : g.children();\n if (children.length) {\n var min = Number.POSITIVE_INFINITY,\n subgraphs = [];\n children.forEach(function(child) {\n var childMin = dfs(child);\n if (g.children(child).length) {\n subgraphs.push({ v: child, order: childMin });\n }\n min = Math.min(min, childMin);\n });\n _.sortBy(subgraphs, \"order\").reduce(function(prev, curr) {\n cg.setEdge(prev.v, curr.v);\n return curr;\n });\n return min;\n }\n return g.node(v).order;\n }\n dfs(undefined);\n */\n}\n","\"use strict\";\n\nlet initOrder = require(\"./init-order\");\nlet crossCount = require(\"./cross-count\");\nlet sortSubgraph = require(\"./sort-subgraph\");\nlet buildLayerGraph = require(\"./build-layer-graph\");\nlet addSubgraphConstraints = require(\"./add-subgraph-constraints\");\nlet Graph = require(\"@dagrejs/graphlib\").Graph;\nlet util = require(\"../util\");\n\nmodule.exports = order;\n\n/*\n * Applies heuristics to minimize edge crossings in the graph and sets the best\n * order solution as an order attribute on each node.\n *\n * Pre-conditions:\n *\n * 1. Graph must be DAG\n * 2. Graph nodes must be objects with a \"rank\" attribute\n * 3. Graph edges must have the \"weight\" attribute\n *\n * Post-conditions:\n *\n * 1. Graph nodes will have an \"order\" attribute based on the results of the\n * algorithm.\n */\nfunction order(g, opts) {\n if (opts && typeof opts.customOrder === 'function') {\n opts.customOrder(g, order);\n return;\n }\n\n let maxRank = util.maxRank(g),\n downLayerGraphs = buildLayerGraphs(g, util.range(1, maxRank + 1), \"inEdges\"),\n upLayerGraphs = buildLayerGraphs(g, util.range(maxRank - 1, -1, -1), \"outEdges\");\n\n let layering = initOrder(g);\n assignOrder(g, layering);\n\n if (opts && opts.disableOptimalOrderHeuristic) {\n return;\n }\n\n let bestCC = Number.POSITIVE_INFINITY,\n best;\n\n for (let i = 0, lastBest = 0; lastBest < 4; ++i, ++lastBest) {\n sweepLayerGraphs(i % 2 ? downLayerGraphs : upLayerGraphs, i % 4 >= 2);\n\n layering = util.buildLayerMatrix(g);\n let cc = crossCount(g, layering);\n if (cc < bestCC) {\n lastBest = 0;\n best = Object.assign({}, layering);\n bestCC = cc;\n }\n }\n\n assignOrder(g, best);\n}\n\nfunction buildLayerGraphs(g, ranks, relationship) {\n // Build an index mapping from rank to the nodes with that rank.\n // This helps to avoid a quadratic search for all nodes with the same rank as\n // the current node.\n const nodesByRank = new Map();\n const addNodeToRank = (rank, node) => {\n if (!nodesByRank.has(rank)) {\n nodesByRank.set(rank, []);\n }\n nodesByRank.get(rank).push(node);\n };\n\n // Visit the nodes in their original order in the graph, and add each\n // node to the ranks(s) that it belongs to.\n for (const v of g.nodes()) {\n const node = g.node(v);\n if (typeof node.rank === \"number\") {\n addNodeToRank(node.rank, v);\n }\n // If there is a range of ranks, add it to each, but skip the `node.rank` which\n // has already had the node added.\n if (typeof node.minRank === \"number\" && typeof node.maxRank === \"number\") {\n for (let r = node.minRank; r <= node.maxRank; r++) {\n if (r !== node.rank) {\n // Don't add this node to its `node.rank` twice.\n addNodeToRank(r, v);\n }\n }\n }\n }\n\n return ranks.map(function (rank) {\n return buildLayerGraph(g, rank, relationship, nodesByRank.get(rank) || []);\n });\n}\n\nfunction sweepLayerGraphs(layerGraphs, biasRight) {\n let cg = new Graph();\n layerGraphs.forEach(function(lg) {\n let root = lg.graph().root;\n let sorted = sortSubgraph(lg, root, cg, biasRight);\n sorted.vs.forEach((v, i) => lg.node(v).order = i);\n addSubgraphConstraints(lg, cg, sorted.vs);\n });\n}\n\nfunction assignOrder(g, layering) {\n Object.values(layering).forEach(layer => layer.forEach((v, i) => g.node(v).order = i));\n}\n","\"use strict\";\n\nlet Graph = require(\"@dagrejs/graphlib\").Graph;\nlet util = require(\"../util\");\n\n/*\n * This module provides coordinate assignment based on Brandes and Köpf, \"Fast\n * and Simple Horizontal Coordinate Assignment.\"\n */\n\nmodule.exports = {\n positionX: positionX,\n findType1Conflicts: findType1Conflicts,\n findType2Conflicts: findType2Conflicts,\n addConflict: addConflict,\n hasConflict: hasConflict,\n verticalAlignment: verticalAlignment,\n horizontalCompaction: horizontalCompaction,\n alignCoordinates: alignCoordinates,\n findSmallestWidthAlignment: findSmallestWidthAlignment,\n balance: balance\n};\n\n/*\n * Marks all edges in the graph with a type-1 conflict with the \"type1Conflict\"\n * property. A type-1 conflict is one where a non-inner segment crosses an\n * inner segment. An inner segment is an edge with both incident nodes marked\n * with the \"dummy\" property.\n *\n * This algorithm scans layer by layer, starting with the second, for type-1\n * conflicts between the current layer and the previous layer. For each layer\n * it scans the nodes from left to right until it reaches one that is incident\n * on an inner segment. It then scans predecessors to determine if they have\n * edges that cross that inner segment. At the end a final scan is done for all\n * nodes on the current rank to see if they cross the last visited inner\n * segment.\n *\n * This algorithm (safely) assumes that a dummy node will only be incident on a\n * single node in the layers being scanned.\n */\nfunction findType1Conflicts(g, layering) {\n let conflicts = {};\n\n function visitLayer(prevLayer, layer) {\n let\n // last visited node in the previous layer that is incident on an inner\n // segment.\n k0 = 0,\n // Tracks the last node in this layer scanned for crossings with a type-1\n // segment.\n scanPos = 0,\n prevLayerLength = prevLayer.length,\n lastNode = layer[layer.length - 1];\n\n layer.forEach((v, i) => {\n let w = findOtherInnerSegmentNode(g, v),\n k1 = w ? g.node(w).order : prevLayerLength;\n\n if (w || v === lastNode) {\n layer.slice(scanPos, i+1).forEach(scanNode => {\n g.predecessors(scanNode).forEach(u => {\n let uLabel = g.node(u),\n uPos = uLabel.order;\n if ((uPos < k0 || k1 < uPos) &&\n !(uLabel.dummy && g.node(scanNode).dummy)) {\n addConflict(conflicts, u, scanNode);\n }\n });\n });\n scanPos = i + 1;\n k0 = k1;\n }\n });\n\n return layer;\n }\n\n layering.length && layering.reduce(visitLayer);\n\n return conflicts;\n}\n\nfunction findType2Conflicts(g, layering) {\n let conflicts = {};\n\n function scan(south, southPos, southEnd, prevNorthBorder, nextNorthBorder) {\n let v;\n util.range(southPos, southEnd).forEach(i => {\n v = south[i];\n if (g.node(v).dummy) {\n g.predecessors(v).forEach(u => {\n let uNode = g.node(u);\n if (uNode.dummy &&\n (uNode.order < prevNorthBorder || uNode.order > nextNorthBorder)) {\n addConflict(conflicts, u, v);\n }\n });\n }\n });\n }\n\n\n function visitLayer(north, south) {\n let prevNorthPos = -1,\n nextNorthPos,\n southPos = 0;\n\n south.forEach((v, southLookahead) => {\n if (g.node(v).dummy === \"border\") {\n let predecessors = g.predecessors(v);\n if (predecessors.length) {\n nextNorthPos = g.node(predecessors[0]).order;\n scan(south, southPos, southLookahead, prevNorthPos, nextNorthPos);\n southPos = southLookahead;\n prevNorthPos = nextNorthPos;\n }\n }\n scan(south, southPos, south.length, nextNorthPos, north.length);\n });\n\n return south;\n }\n\n layering.length && layering.reduce(visitLayer);\n\n return conflicts;\n}\n\nfunction findOtherInnerSegmentNode(g, v) {\n if (g.node(v).dummy) {\n return g.predecessors(v).find(u => g.node(u).dummy);\n }\n}\n\nfunction addConflict(conflicts, v, w) {\n if (v > w) {\n let tmp = v;\n v = w;\n w = tmp;\n }\n\n let conflictsV = conflicts[v];\n if (!conflictsV) {\n conflicts[v] = conflictsV = {};\n }\n conflictsV[w] = true;\n}\n\nfunction hasConflict(conflicts, v, w) {\n if (v > w) {\n let tmp = v;\n v = w;\n w = tmp;\n }\n return !!conflicts[v] && Object.hasOwn(conflicts[v], w);\n}\n\n/*\n * Try to align nodes into vertical \"blocks\" where possible. This algorithm\n * attempts to align a node with one of its median neighbors. If the edge\n * connecting a neighbor is a type-1 conflict then we ignore that possibility.\n * If a previous node has already formed a block with a node after the node\n * we're trying to form a block with, we also ignore that possibility - our\n * blocks would be split in that scenario.\n */\nfunction verticalAlignment(g, layering, conflicts, neighborFn) {\n let root = {},\n align = {},\n pos = {};\n\n // We cache the position here based on the layering because the graph and\n // layering may be out of sync. The layering matrix is manipulated to\n // generate different extreme alignments.\n layering.forEach(layer => {\n layer.forEach((v, order) => {\n root[v] = v;\n align[v] = v;\n pos[v] = order;\n });\n });\n\n layering.forEach(layer => {\n let prevIdx = -1;\n layer.forEach(v => {\n let ws = neighborFn(v);\n if (ws.length) {\n ws = ws.sort((a, b) => pos[a] - pos[b]);\n let mp = (ws.length - 1) / 2;\n for (let i = Math.floor(mp), il = Math.ceil(mp); i <= il; ++i) {\n let w = ws[i];\n if (align[v] === v &&\n prevIdx < pos[w] &&\n !hasConflict(conflicts, v, w)) {\n align[w] = v;\n align[v] = root[v] = root[w];\n prevIdx = pos[w];\n }\n }\n }\n });\n });\n\n return { root: root, align: align };\n}\n\nfunction horizontalCompaction(g, layering, root, align, reverseSep) {\n // This portion of the algorithm differs from BK due to a number of problems.\n // Instead of their algorithm we construct a new block graph and do two\n // sweeps. The first sweep places blocks with the smallest possible\n // coordinates. The second sweep removes unused space by moving blocks to the\n // greatest coordinates without violating separation.\n let xs = {},\n blockG = buildBlockGraph(g, layering, root, reverseSep),\n borderType = reverseSep ? \"borderLeft\" : \"borderRight\";\n\n function iterate(setXsFunc, nextNodesFunc) {\n let stack = blockG.nodes();\n let elem = stack.pop();\n let visited = {};\n while (elem) {\n if (visited[elem]) {\n setXsFunc(elem);\n } else {\n visited[elem] = true;\n stack.push(elem);\n stack = stack.concat(nextNodesFunc(elem));\n }\n\n elem = stack.pop();\n }\n }\n\n // First pass, assign smallest coordinates\n function pass1(elem) {\n xs[elem] = blockG.inEdges(elem).reduce((acc, e) => {\n return Math.max(acc, xs[e.v] + blockG.edge(e));\n }, 0);\n }\n\n // Second pass, assign greatest coordinates\n function pass2(elem) {\n let min = blockG.outEdges(elem).reduce((acc, e) => {\n return Math.min(acc, xs[e.w] - blockG.edge(e));\n }, Number.POSITIVE_INFINITY);\n\n let node = g.node(elem);\n if (min !== Number.POSITIVE_INFINITY && node.borderType !== borderType) {\n xs[elem] = Math.max(xs[elem], min);\n }\n }\n\n iterate(pass1, blockG.predecessors.bind(blockG));\n iterate(pass2, blockG.successors.bind(blockG));\n\n // Assign x coordinates to all nodes\n Object.keys(align).forEach(v => xs[v] = xs[root[v]]);\n\n return xs;\n}\n\n\nfunction buildBlockGraph(g, layering, root, reverseSep) {\n let blockGraph = new Graph(),\n graphLabel = g.graph(),\n sepFn = sep(graphLabel.nodesep, graphLabel.edgesep, reverseSep);\n\n layering.forEach(layer => {\n let u;\n layer.forEach(v => {\n let vRoot = root[v];\n blockGraph.setNode(vRoot);\n if (u) {\n var uRoot = root[u],\n prevMax = blockGraph.edge(uRoot, vRoot);\n blockGraph.setEdge(uRoot, vRoot, Math.max(sepFn(g, v, u), prevMax || 0));\n }\n u = v;\n });\n });\n\n return blockGraph;\n}\n\n/*\n * Returns the alignment that has the smallest width of the given alignments.\n */\nfunction findSmallestWidthAlignment(g, xss) {\n return Object.values(xss).reduce((currentMinAndXs, xs) => {\n let max = Number.NEGATIVE_INFINITY;\n let min = Number.POSITIVE_INFINITY;\n\n Object.entries(xs).forEach(([v, x]) => {\n let halfWidth = width(g, v) / 2;\n\n max = Math.max(x + halfWidth, max);\n min = Math.min(x - halfWidth, min);\n });\n\n const newMin = max - min;\n if (newMin < currentMinAndXs[0]) {\n currentMinAndXs = [newMin, xs];\n }\n return currentMinAndXs;\n }, [Number.POSITIVE_INFINITY, null])[1];\n}\n\n/*\n * Align the coordinates of each of the layout alignments such that\n * left-biased alignments have their minimum coordinate at the same point as\n * the minimum coordinate of the smallest width alignment and right-biased\n * alignments have their maximum coordinate at the same point as the maximum\n * coordinate of the smallest width alignment.\n */\nfunction alignCoordinates(xss, alignTo) {\n let alignToVals = Object.values(alignTo),\n alignToMin = util.applyWithChunking(Math.min, alignToVals),\n alignToMax = util.applyWithChunking(Math.max, alignToVals);\n\n [\"u\", \"d\"].forEach(vert => {\n [\"l\", \"r\"].forEach(horiz => {\n let alignment = vert + horiz,\n xs = xss[alignment];\n\n if (xs === alignTo) return;\n\n let xsVals = Object.values(xs);\n let delta = alignToMin - util.applyWithChunking(Math.min, xsVals);\n if (horiz !== \"l\") {\n delta = alignToMax - util.applyWithChunking(Math.max,xsVals);\n }\n\n if (delta) {\n xss[alignment] = util.mapValues(xs, x => x + delta);\n }\n });\n });\n}\n\nfunction balance(xss, align) {\n return util.mapValues(xss.ul, (num, v) => {\n if (align) {\n return xss[align.toLowerCase()][v];\n } else {\n let xs = Object.values(xss).map(xs => xs[v]).sort((a, b) => a - b);\n return (xs[1] + xs[2]) / 2;\n }\n });\n}\n\nfunction positionX(g) {\n let layering = util.buildLayerMatrix(g);\n let conflicts = Object.assign(\n findType1Conflicts(g, layering),\n findType2Conflicts(g, layering));\n\n let xss = {};\n let adjustedLayering;\n [\"u\", \"d\"].forEach(vert => {\n adjustedLayering = vert === \"u\" ? layering : Object.values(layering).reverse();\n [\"l\", \"r\"].forEach(horiz => {\n if (horiz === \"r\") {\n adjustedLayering = adjustedLayering.map(inner => {\n return Object.values(inner).reverse();\n });\n }\n\n let neighborFn = (vert === \"u\" ? g.predecessors : g.successors).bind(g);\n let align = verticalAlignment(g, adjustedLayering, conflicts, neighborFn);\n let xs = horizontalCompaction(g, adjustedLayering,\n align.root, align.align, horiz === \"r\");\n if (horiz === \"r\") {\n xs = util.mapValues(xs, x => -x);\n }\n xss[vert + horiz] = xs;\n });\n });\n\n\n let smallestWidth = findSmallestWidthAlignment(g, xss);\n alignCoordinates(xss, smallestWidth);\n return balance(xss, g.graph().align);\n}\n\nfunction sep(nodeSep, edgeSep, reverseSep) {\n return (g, v, w) => {\n let vLabel = g.node(v);\n let wLabel = g.node(w);\n let sum = 0;\n let delta;\n\n sum += vLabel.width / 2;\n if (Object.hasOwn(vLabel, \"labelpos\")) {\n switch (vLabel.labelpos.toLowerCase()) {\n case \"l\": delta = -vLabel.width / 2; break;\n case \"r\": delta = vLabel.width / 2; break;\n }\n }\n if (delta) {\n sum += reverseSep ? delta : -delta;\n }\n delta = 0;\n\n sum += (vLabel.dummy ? edgeSep : nodeSep) / 2;\n sum += (wLabel.dummy ? edgeSep : nodeSep) / 2;\n\n sum += wLabel.width / 2;\n if (Object.hasOwn(wLabel, \"labelpos\")) {\n switch (wLabel.labelpos.toLowerCase()) {\n case \"l\": delta = wLabel.width / 2; break;\n case \"r\": delta = -wLabel.width / 2; break;\n }\n }\n if (delta) {\n sum += reverseSep ? delta : -delta;\n }\n delta = 0;\n\n return sum;\n };\n}\n\nfunction width(g, v) {\n return g.node(v).width;\n}\n","\"use strict\";\n\nlet util = require(\"../util\");\nlet positionX = require(\"./bk\").positionX;\n\nmodule.exports = position;\n\nfunction position(g) {\n g = util.asNonCompoundGraph(g);\n\n positionY(g);\n Object.entries(positionX(g)).forEach(([v, x]) => g.node(v).x = x);\n}\n\nfunction positionY(g) {\n let layering = util.buildLayerMatrix(g);\n let rankSep = g.graph().ranksep;\n let prevY = 0;\n layering.forEach(layer => {\n const maxHeight = layer.reduce((acc, v) => {\n const height = g.node(v).height;\n if (acc > height) {\n return acc;\n } else {\n return height;\n }\n }, 0);\n layer.forEach(v => g.node(v).y = prevY + maxHeight / 2);\n prevY += maxHeight + rankSep;\n });\n}\n\n","\"use strict\";\n\nlet acyclic = require(\"./acyclic\");\nlet normalize = require(\"./normalize\");\nlet rank = require(\"./rank\");\nlet normalizeRanks = require(\"./util\").normalizeRanks;\nlet parentDummyChains = require(\"./parent-dummy-chains\");\nlet removeEmptyRanks = require(\"./util\").removeEmptyRanks;\nlet nestingGraph = require(\"./nesting-graph\");\nlet addBorderSegments = require(\"./add-border-segments\");\nlet coordinateSystem = require(\"./coordinate-system\");\nlet order = require(\"./order\");\nlet position = require(\"./position\");\nlet util = require(\"./util\");\nlet Graph = require(\"@dagrejs/graphlib\").Graph;\n\nmodule.exports = layout;\n\nfunction layout(g, opts) {\n let time = opts && opts.debugTiming ? util.time : util.notime;\n time(\"layout\", () => {\n let layoutGraph =\n time(\" buildLayoutGraph\", () => buildLayoutGraph(g));\n time(\" runLayout\", () => runLayout(layoutGraph, time, opts));\n time(\" updateInputGraph\", () => updateInputGraph(g, layoutGraph));\n });\n}\n\nfunction runLayout(g, time, opts) {\n time(\" makeSpaceForEdgeLabels\", () => makeSpaceForEdgeLabels(g));\n time(\" removeSelfEdges\", () => removeSelfEdges(g));\n time(\" acyclic\", () => acyclic.run(g));\n time(\" nestingGraph.run\", () => nestingGraph.run(g));\n time(\" rank\", () => rank(util.asNonCompoundGraph(g)));\n time(\" injectEdgeLabelProxies\", () => injectEdgeLabelProxies(g));\n time(\" removeEmptyRanks\", () => removeEmptyRanks(g));\n time(\" nestingGraph.cleanup\", () => nestingGraph.cleanup(g));\n time(\" normalizeRanks\", () => normalizeRanks(g));\n time(\" assignRankMinMax\", () => assignRankMinMax(g));\n time(\" removeEdgeLabelProxies\", () => removeEdgeLabelProxies(g));\n time(\" normalize.run\", () => normalize.run(g));\n time(\" parentDummyChains\", () => parentDummyChains(g));\n time(\" addBorderSegments\", () => addBorderSegments(g));\n time(\" order\", () => order(g, opts));\n time(\" insertSelfEdges\", () => insertSelfEdges(g));\n time(\" adjustCoordinateSystem\", () => coordinateSystem.adjust(g));\n time(\" position\", () => position(g));\n time(\" positionSelfEdges\", () => positionSelfEdges(g));\n time(\" removeBorderNodes\", () => removeBorderNodes(g));\n time(\" normalize.undo\", () => normalize.undo(g));\n time(\" fixupEdgeLabelCoords\", () => fixupEdgeLabelCoords(g));\n time(\" undoCoordinateSystem\", () => coordinateSystem.undo(g));\n time(\" translateGraph\", () => translateGraph(g));\n time(\" assignNodeIntersects\", () => assignNodeIntersects(g));\n time(\" reversePoints\", () => reversePointsForReversedEdges(g));\n time(\" acyclic.undo\", () => acyclic.undo(g));\n}\n\n/*\n * Copies final layout information from the layout graph back to the input\n * graph. This process only copies whitelisted attributes from the layout graph\n * to the input graph, so it serves as a good place to determine what\n * attributes can influence layout.\n */\nfunction updateInputGraph(inputGraph, layoutGraph) {\n inputGraph.nodes().forEach(v => {\n let inputLabel = inputGraph.node(v);\n let layoutLabel = layoutGraph.node(v);\n\n if (inputLabel) {\n inputLabel.x = layoutLabel.x;\n inputLabel.y = layoutLabel.y;\n inputLabel.rank = layoutLabel.rank;\n\n if (layoutGraph.children(v).length) {\n inputLabel.width = layoutLabel.width;\n inputLabel.height = layoutLabel.height;\n }\n }\n });\n\n inputGraph.edges().forEach(e => {\n let inputLabel = inputGraph.edge(e);\n let layoutLabel = layoutGraph.edge(e);\n\n inputLabel.points = layoutLabel.points;\n if (Object.hasOwn(layoutLabel, \"x\")) {\n inputLabel.x = layoutLabel.x;\n inputLabel.y = layoutLabel.y;\n }\n });\n\n inputGraph.graph().width = layoutGraph.graph().width;\n inputGraph.graph().height = layoutGraph.graph().height;\n}\n\nlet graphNumAttrs = [\"nodesep\", \"edgesep\", \"ranksep\", \"marginx\", \"marginy\"];\nlet graphDefaults = { ranksep: 50, edgesep: 20, nodesep: 50, rankdir: \"tb\" };\nlet graphAttrs = [\"acyclicer\", \"ranker\", \"rankdir\", \"align\"];\nlet nodeNumAttrs = [\"width\", \"height\", \"rank\"];\nlet nodeDefaults = { width: 0, height: 0 };\nlet edgeNumAttrs = [\"minlen\", \"weight\", \"width\", \"height\", \"labeloffset\"];\nlet edgeDefaults = {\n minlen: 1, weight: 1, width: 0, height: 0,\n labeloffset: 10, labelpos: \"r\"\n};\nlet edgeAttrs = [\"labelpos\"];\n\n/*\n * Constructs a new graph from the input graph, which can be used for layout.\n * This process copies only whitelisted attributes from the input graph to the\n * layout graph. Thus this function serves as a good place to determine what\n * attributes can influence layout.\n */\nfunction buildLayoutGraph(inputGraph) {\n let g = new Graph({ multigraph: true, compound: true });\n let graph = canonicalize(inputGraph.graph());\n\n g.setGraph(Object.assign({},\n graphDefaults,\n selectNumberAttrs(graph, graphNumAttrs),\n util.pick(graph, graphAttrs)));\n\n inputGraph.nodes().forEach(v => {\n let node = canonicalize(inputGraph.node(v));\n const newNode = selectNumberAttrs(node, nodeNumAttrs);\n Object.keys(nodeDefaults).forEach(k => {\n if (newNode[k] === undefined) {\n newNode[k] = nodeDefaults[k];\n }\n });\n\n g.setNode(v, newNode);\n g.setParent(v, inputGraph.parent(v));\n });\n\n inputGraph.edges().forEach(e => {\n let edge = canonicalize(inputGraph.edge(e));\n g.setEdge(e, Object.assign({},\n edgeDefaults,\n selectNumberAttrs(edge, edgeNumAttrs),\n util.pick(edge, edgeAttrs)));\n });\n\n return g;\n}\n\n/*\n * This idea comes from the Gansner paper: to account for edge labels in our\n * layout we split each rank in half by doubling minlen and halving ranksep.\n * Then we can place labels at these mid-points between nodes.\n *\n * We also add some minimal padding to the width to push the label for the edge\n * away from the edge itself a bit.\n */\nfunction makeSpaceForEdgeLabels(g) {\n let graph = g.graph();\n graph.ranksep /= 2;\n g.edges().forEach(e => {\n let edge = g.edge(e);\n edge.minlen *= 2;\n if (edge.labelpos.toLowerCase() !== \"c\") {\n if (graph.rankdir === \"TB\" || graph.rankdir === \"BT\") {\n edge.width += edge.labeloffset;\n } else {\n edge.height += edge.labeloffset;\n }\n }\n });\n}\n\n/*\n * Creates temporary dummy nodes that capture the rank in which each edge's\n * label is going to, if it has one of non-zero width and height. We do this\n * so that we can safely remove empty ranks while preserving balance for the\n * label's position.\n */\nfunction injectEdgeLabelProxies(g) {\n g.edges().forEach(e => {\n let edge = g.edge(e);\n if (edge.width && edge.height) {\n let v = g.node(e.v);\n let w = g.node(e.w);\n let label = { rank: (w.rank - v.rank) / 2 + v.rank, e: e };\n util.addDummyNode(g, \"edge-proxy\", label, \"_ep\");\n }\n });\n}\n\nfunction assignRankMinMax(g) {\n let maxRank = 0;\n g.nodes().forEach(v => {\n let node = g.node(v);\n if (node.borderTop) {\n node.minRank = g.node(node.borderTop).rank;\n node.maxRank = g.node(node.borderBottom).rank;\n maxRank = Math.max(maxRank, node.maxRank);\n }\n });\n g.graph().maxRank = maxRank;\n}\n\nfunction removeEdgeLabelProxies(g) {\n g.nodes().forEach(v => {\n let node = g.node(v);\n if (node.dummy === \"edge-proxy\") {\n g.edge(node.e).labelRank = node.rank;\n g.removeNode(v);\n }\n });\n}\n\nfunction translateGraph(g) {\n let minX = Number.POSITIVE_INFINITY;\n let maxX = 0;\n let minY = Number.POSITIVE_INFINITY;\n let maxY = 0;\n let graphLabel = g.graph();\n let marginX = graphLabel.marginx || 0;\n let marginY = graphLabel.marginy || 0;\n\n function getExtremes(attrs) {\n let x = attrs.x;\n let y = attrs.y;\n let w = attrs.width;\n let h = attrs.height;\n minX = Math.min(minX, x - w / 2);\n maxX = Math.max(maxX, x + w / 2);\n minY = Math.min(minY, y - h / 2);\n maxY = Math.max(maxY, y + h / 2);\n }\n\n g.nodes().forEach(v => getExtremes(g.node(v)));\n g.edges().forEach(e => {\n let edge = g.edge(e);\n if (Object.hasOwn(edge, \"x\")) {\n getExtremes(edge);\n }\n });\n\n minX -= marginX;\n minY -= marginY;\n\n g.nodes().forEach(v => {\n let node = g.node(v);\n node.x -= minX;\n node.y -= minY;\n });\n\n g.edges().forEach(e => {\n let edge = g.edge(e);\n edge.points.forEach(p => {\n p.x -= minX;\n p.y -= minY;\n });\n if (Object.hasOwn(edge, \"x\")) { edge.x -= minX; }\n if (Object.hasOwn(edge, \"y\")) { edge.y -= minY; }\n });\n\n graphLabel.width = maxX - minX + marginX;\n graphLabel.height = maxY - minY + marginY;\n}\n\nfunction assignNodeIntersects(g) {\n g.edges().forEach(e => {\n let edge = g.edge(e);\n let nodeV = g.node(e.v);\n let nodeW = g.node(e.w);\n let p1, p2;\n if (!edge.points) {\n edge.points = [];\n p1 = nodeW;\n p2 = nodeV;\n } else {\n p1 = edge.points[0];\n p2 = edge.points[edge.points.length - 1];\n }\n edge.points.unshift(util.intersectRect(nodeV, p1));\n edge.points.push(util.intersectRect(nodeW, p2));\n });\n}\n\nfunction fixupEdgeLabelCoords(g) {\n g.edges().forEach(e => {\n let edge = g.edge(e);\n if (Object.hasOwn(edge, \"x\")) {\n if (edge.labelpos === \"l\" || edge.labelpos === \"r\") {\n edge.width -= edge.labeloffset;\n }\n switch (edge.labelpos) {\n case \"l\": edge.x -= edge.width / 2 + edge.labeloffset; break;\n case \"r\": edge.x += edge.width / 2 + edge.labeloffset; break;\n }\n }\n });\n}\n\nfunction reversePointsForReversedEdges(g) {\n g.edges().forEach(e => {\n let edge = g.edge(e);\n if (edge.reversed) {\n edge.points.reverse();\n }\n });\n}\n\nfunction removeBorderNodes(g) {\n g.nodes().forEach(v => {\n if (g.children(v).length) {\n let node = g.node(v);\n let t = g.node(node.borderTop);\n let b = g.node(node.borderBottom);\n let l = g.node(node.borderLeft[node.borderLeft.length - 1]);\n let r = g.node(node.borderRight[node.borderRight.length - 1]);\n\n node.width = Math.abs(r.x - l.x);\n node.height = Math.abs(b.y - t.y);\n node.x = l.x + node.width / 2;\n node.y = t.y + node.height / 2;\n }\n });\n\n g.nodes().forEach(v => {\n if (g.node(v).dummy === \"border\") {\n g.removeNode(v);\n }\n });\n}\n\nfunction removeSelfEdges(g) {\n g.edges().forEach(e => {\n if (e.v === e.w) {\n var node = g.node(e.v);\n if (!node.selfEdges) {\n node.selfEdges = [];\n }\n node.selfEdges.push({ e: e, label: g.edge(e) });\n g.removeEdge(e);\n }\n });\n}\n\nfunction insertSelfEdges(g) {\n var layers = util.buildLayerMatrix(g);\n layers.forEach(layer => {\n var orderShift = 0;\n layer.forEach((v, i) => {\n var node = g.node(v);\n node.order = i + orderShift;\n (node.selfEdges || []).forEach(selfEdge => {\n util.addDummyNode(g, \"selfedge\", {\n width: selfEdge.label.width,\n height: selfEdge.label.height,\n rank: node.rank,\n order: i + (++orderShift),\n e: selfEdge.e,\n label: selfEdge.label\n }, \"_se\");\n });\n delete node.selfEdges;\n });\n });\n}\n\nfunction positionSelfEdges(g) {\n g.nodes().forEach(v => {\n var node = g.node(v);\n if (node.dummy === \"selfedge\") {\n var selfNode = g.node(node.e.v);\n var x = selfNode.x + selfNode.width / 2;\n var y = selfNode.y;\n var dx = node.x - x;\n var dy = selfNode.height / 2;\n g.setEdge(node.e, node.label);\n g.removeNode(v);\n node.label.points = [\n { x: x + 2 * dx / 3, y: y - dy },\n { x: x + 5 * dx / 6, y: y - dy },\n { x: x + dx , y: y },\n { x: x + 5 * dx / 6, y: y + dy },\n { x: x + 2 * dx / 3, y: y + dy }\n ];\n node.label.x = node.x;\n node.label.y = node.y;\n }\n });\n}\n\nfunction selectNumberAttrs(obj, attrs) {\n return util.mapValues(util.pick(obj, attrs), Number);\n}\n\nfunction canonicalize(attrs) {\n var newAttrs = {};\n if (attrs) {\n Object.entries(attrs).forEach(([k, v]) => {\n if (typeof k === \"string\") {\n k = k.toLowerCase();\n }\n\n newAttrs[k] = v;\n });\n }\n return newAttrs;\n}\n","let util = require(\"./util\");\nlet Graph = require(\"@dagrejs/graphlib\").Graph;\n\nmodule.exports = {\n debugOrdering: debugOrdering\n};\n\n/* istanbul ignore next */\nfunction debugOrdering(g) {\n let layerMatrix = util.buildLayerMatrix(g);\n\n let h = new Graph({ compound: true, multigraph: true }).setGraph({});\n\n g.nodes().forEach(v => {\n h.setNode(v, { label: v });\n h.setParent(v, \"layer\" + g.node(v).rank);\n });\n\n g.edges().forEach(e => h.setEdge(e.v, e.w, {}, e.name));\n\n layerMatrix.forEach((layer, i) => {\n let layerV = \"layer\" + i;\n h.setNode(layerV, { rank: \"same\" });\n layer.reduce((u, v) => {\n h.setEdge(u, v, { style: \"invis\" });\n return v;\n });\n });\n\n return h;\n}\n","module.exports = \"1.1.8\";\n","/*\nCopyright (c) 2012-2014 Chris Pettitt\n\nPermission is hereby granted, free of charge, to any person obtaining a copy\nof this software and associated documentation files (the \"Software\"), to deal\nin the Software without restriction, including without limitation the rights\nto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the Software is\nfurnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in\nall copies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\nTHE SOFTWARE.\n*/\n\nmodule.exports = {\n graphlib: require(\"@dagrejs/graphlib\"),\n\n layout: require(\"./lib/layout\"),\n debug: require(\"./lib/debug\"),\n util: {\n time: require(\"./lib/util\").time,\n notime: require(\"./lib/util\").notime\n },\n version: require(\"./lib/version\")\n};\n","import type { Node } from '@xyflow/react';\nimport type {\n LogicNode,\n OperatorNodeData,\n VariableNodeData,\n LiteralNodeData,\n VerticalCellNodeData,\n DecisionNodeData,\n} from '../types';\n\n// Type guard for operator nodes\nexport function isOperatorNode(node: LogicNode): node is Node<OperatorNodeData> {\n return node.data.type === 'operator';\n}\n\n// Type guard for variable nodes\nexport function isVariableNode(node: LogicNode): node is Node<VariableNodeData> {\n return node.data.type === 'variable';\n}\n\n// Type guard for literal nodes\nexport function isLiteralNode(node: LogicNode): node is Node<LiteralNodeData> {\n return node.data.type === 'literal';\n}\n\n// Type guard for vertical cell nodes\nexport function isVerticalCellNode(node: LogicNode): node is Node<VerticalCellNodeData> {\n return node.data.type === 'verticalCell';\n}\n\n// Type guard for decision nodes\nexport function isDecisionNode(node: LogicNode): node is Node<DecisionNodeData> {\n return node.data.type === 'decision';\n}\n\n// Type guard for collapsible nodes (operator or verticalCell)\nexport function isCollapsibleNode(\n node: LogicNode\n): node is Node<OperatorNodeData> | Node<VerticalCellNodeData> {\n return node.data.type === 'operator' || node.data.type === 'verticalCell';\n}\n\n// Helper to safely get operator node data\nexport function getOperatorNodeData(node: LogicNode): OperatorNodeData | null {\n return isOperatorNode(node) ? node.data : null;\n}\n\n// Helper to safely get vertical cell node data\nexport function getVerticalCellNodeData(node: LogicNode): VerticalCellNodeData | null {\n return isVerticalCellNode(node) ? node.data : null;\n}\n","import Dagre from '@dagrejs/dagre';\nimport type { LogicNode, LogicEdge } from '../types';\nimport {\n NODE_DIMENSIONS,\n VERTICAL_CELL_DIMENSIONS,\n TEXT_METRICS,\n NODE_PADDING,\n DAGRE_OPTIONS,\n FIXED_WIDTHS,\n} from '../constants';\nimport { isOperatorNode, isVerticalCellNode, isVariableNode, isLiteralNode } from './type-guards';\n\n// Estimate text width based on content\nfunction estimateTextWidth(text: string, isMonospace = false): number {\n const charWidth = isMonospace ? TEXT_METRICS.charWidthMono : TEXT_METRICS.charWidthRegular;\n return text.length * charWidth;\n}\n\n// Calculate width needed for a node based on its content\nfunction calculateNodeWidth(node: LogicNode): number {\n let contentWidth = 0;\n\n if (isOperatorNode(node)) {\n const opData = node.data;\n // Width based on label or expression text\n const labelWidth = estimateTextWidth(opData.label);\n if (opData.collapsed && opData.expressionText) {\n contentWidth = Math.max(labelWidth, estimateTextWidth(opData.expressionText, true));\n } else if (opData.inlineDisplay) {\n contentWidth = Math.max(labelWidth, estimateTextWidth(opData.inlineDisplay, true));\n } else {\n contentWidth = labelWidth;\n }\n } else if (isVariableNode(node)) {\n const varData = node.data;\n // Width based on operator + path\n const pathWidth = estimateTextWidth(varData.path || '(empty)', true);\n contentWidth = NODE_PADDING.iconWidth + pathWidth;\n } else if (isLiteralNode(node)) {\n const litData = node.data;\n // Width based on value display\n const valueStr = JSON.stringify(litData.value);\n contentWidth = NODE_PADDING.typeIconWidth + estimateTextWidth(valueStr, true);\n } else if (isVerticalCellNode(node)) {\n const vcData = node.data;\n // Width based on header label and cell contents\n let maxCellWidth = estimateTextWidth(vcData.label);\n\n if (!vcData.collapsed) {\n vcData.cells.forEach((cell) => {\n const cellText = cell.label || cell.summary?.label || '';\n const cellWidth = NODE_PADDING.iconWidth + estimateTextWidth(cellText, true);\n maxCellWidth = Math.max(maxCellWidth, cellWidth);\n });\n } else if (vcData.expressionText) {\n maxCellWidth = Math.max(maxCellWidth, estimateTextWidth(vcData.expressionText, true));\n }\n contentWidth = maxCellWidth;\n } else {\n contentWidth = FIXED_WIDTHS.fallbackNode;\n }\n\n // Add padding and clamp to min/max\n const totalWidth = contentWidth + NODE_PADDING.contentPadding;\n return Math.max(NODE_DIMENSIONS.minWidth, Math.min(NODE_DIMENSIONS.maxWidth, totalWidth));\n}\n\n// Get node dimensions based on type and content\nfunction getNodeDimensions(node: LogicNode): { width: number; height: number } {\n const width = calculateNodeWidth(node);\n\n if (isVerticalCellNode(node)) {\n const vcData = node.data;\n if (vcData.collapsed) {\n return {\n width,\n height: VERTICAL_CELL_DIMENSIONS.headerHeight + VERTICAL_CELL_DIMENSIONS.collapsedBodyHeight,\n };\n }\n const cellCount = vcData.cells.length;\n return {\n width,\n height: VERTICAL_CELL_DIMENSIONS.headerHeight + cellCount * VERTICAL_CELL_DIMENSIONS.rowHeight,\n };\n }\n\n return { width, height: NODE_DIMENSIONS.defaultHeight };\n}\n\n// Apply dagre layout to nodes and edges\nexport function applyTreeLayout(nodes: LogicNode[], edges?: LogicEdge[]): LogicNode[] {\n if (nodes.length === 0) return nodes;\n\n // Create a new dagre graph\n const g = new Dagre.graphlib.Graph().setDefaultEdgeLabel(() => ({}));\n\n // Set graph options - use LR (left-to-right) for horizontal flow\n g.setGraph({\n rankdir: DAGRE_OPTIONS.rankDir,\n nodesep: DAGRE_OPTIONS.nodeSep,\n ranksep: DAGRE_OPTIONS.rankSep,\n edgesep: DAGRE_OPTIONS.edgeSep,\n marginx: DAGRE_OPTIONS.marginX,\n marginy: DAGRE_OPTIONS.marginY,\n });\n\n // Add nodes to the graph with their dimensions\n nodes.forEach((node) => {\n const { width, height } = getNodeDimensions(node);\n g.setNode(node.id, { width, height });\n });\n\n // Build edges from node relationships if edges not provided\n const edgesToUse = edges || buildEdgesFromNodes(nodes);\n\n // Build set of valid node IDs for edge validation\n const nodeIdSet = new Set(nodes.map((n) => n.id));\n\n // Add edges to the graph (only if both source and target exist)\n // Track edge index per source node to help Dagre maintain child order\n const sourceEdgeCount = new Map<string, number>();\n edgesToUse.forEach((edge) => {\n if (nodeIdSet.has(edge.source) && nodeIdSet.has(edge.target)) {\n // Get current edge index for this source node\n const edgeIndex = sourceEdgeCount.get(edge.source) || 0;\n sourceEdgeCount.set(edge.source, edgeIndex + 1);\n\n // Pass edge weight to help maintain order (higher index = higher weight = lower position)\n g.setEdge(edge.source, edge.target, { weight: edgeIndex + 1 });\n }\n });\n\n // Run the dagre layout algorithm\n Dagre.layout(g);\n\n // Apply the calculated positions and dimensions to nodes\n return nodes.map((node) => {\n const nodeWithPosition = g.node(node.id);\n if (nodeWithPosition) {\n const { width, height } = getNodeDimensions(node);\n return {\n ...node,\n position: {\n // Dagre returns center positions, convert to top-left\n x: nodeWithPosition.x - width / 2,\n y: nodeWithPosition.y - height / 2,\n },\n // Store calculated dimensions for node components to use\n width,\n height,\n style: {\n width: `${width}px`,\n },\n };\n }\n return node;\n });\n}\n\n// Build edges from node parent relationships\nfunction buildEdgesFromNodes(nodes: LogicNode[]): LogicEdge[] {\n const edges: LogicEdge[] = [];\n\n nodes.forEach((node) => {\n // Handle operator nodes with childIds\n if (isOperatorNode(node)) {\n const opData = node.data;\n if (!opData.collapsed) {\n opData.childIds.forEach((childId, idx) => {\n edges.push({\n id: `${node.id}-${childId}`,\n source: node.id,\n target: childId,\n sourceHandle: `arg-${idx}`,\n targetHandle: 'left',\n });\n });\n }\n }\n\n // Handle verticalCell nodes with branch children\n if (isVerticalCellNode(node)) {\n const vcData = node.data;\n if (!vcData.collapsed) {\n const collapsedIndices = vcData.collapsedCellIndices || [];\n let branchIndex = 0;\n\n vcData.cells.forEach((cell) => {\n if (collapsedIndices.includes(cell.index)) return;\n\n if (cell.branchId) {\n edges.push({\n id: `${node.id}-branch-${cell.branchId}`,\n source: node.id,\n target: cell.branchId,\n sourceHandle: `branch-${branchIndex}`,\n targetHandle: 'left',\n });\n branchIndex++;\n }\n if (cell.conditionBranchId) {\n edges.push({\n id: `${node.id}-cond-${cell.conditionBranchId}`,\n source: node.id,\n target: cell.conditionBranchId,\n sourceHandle: `branch-${branchIndex}`,\n targetHandle: 'left',\n });\n branchIndex++;\n }\n if (cell.thenBranchId) {\n edges.push({\n id: `${node.id}-then-${cell.thenBranchId}`,\n source: node.id,\n target: cell.thenBranchId,\n sourceHandle: `branch-${branchIndex}`,\n targetHandle: 'left',\n });\n branchIndex++;\n }\n });\n }\n }\n });\n\n return edges;\n}\n","import { useState, useEffect, useMemo } from 'react';\nimport type {\n LogicNode,\n LogicEdge,\n JsonLogicValue,\n TracedResult,\n ExecutionStep,\n} from '../types';\nimport { jsonLogicToNodes } from '../utils/jsonlogic-to-nodes';\nimport { traceToNodes, buildEvaluationResultsFromTrace } from '../utils/trace-to-nodes';\nimport { applyTreeLayout } from '../utils/layout';\n\nexport interface EvaluationResult {\n value: unknown;\n error: string | null;\n type: 'boolean' | 'number' | 'string' | 'null' | 'array' | 'object' | 'undefined';\n}\n\nexport type EvaluationResultsMap = Map<string, EvaluationResult>;\n\ninterface UseLogicEditorOptions {\n value: JsonLogicValue | null;\n evaluateWithTrace?: (logic: unknown, data: unknown) => TracedResult;\n data?: unknown;\n}\n\ninterface UseLogicEditorReturn {\n nodes: LogicNode[];\n edges: LogicEdge[];\n error: string | null;\n evaluationResults: EvaluationResultsMap;\n usingTraceMode: boolean;\n steps: ExecutionStep[];\n traceNodeMap: Map<string, string>; // Maps trace node IDs to visual node IDs\n}\n\n// Maximum recursion depth to prevent stack overflow\nconst MAX_RECURSION_DEPTH = 100;\n\n// Simple depth check for JSONLogic expressions\nfunction checkDepth(value: unknown, depth = 0): boolean {\n if (depth > MAX_RECURSION_DEPTH) {\n return false;\n }\n if (value === null || typeof value !== 'object') {\n return true;\n }\n if (Array.isArray(value)) {\n return value.every((item) => checkDepth(item, depth + 1));\n }\n return Object.values(value).every((v) => checkDepth(v, depth + 1));\n}\n\nconst emptyResults: EvaluationResultsMap = new Map();\nconst emptySteps: ExecutionStep[] = [];\nconst emptyTraceNodeMap: Map<string, string> = new Map();\n\nexport function useLogicEditor({\n value,\n evaluateWithTrace,\n data,\n}: UseLogicEditorOptions): UseLogicEditorReturn {\n const [nodes, setNodes] = useState<LogicNode[]>([]);\n const [edges, setEdges] = useState<LogicEdge[]>([]);\n const [error, setError] = useState<string | null>(null);\n const [evaluationResults, setEvaluationResults] = useState<EvaluationResultsMap>(emptyResults);\n const [usingTraceMode, setUsingTraceMode] = useState(false);\n const [steps, setSteps] = useState<ExecutionStep[]>(emptySteps);\n const [traceNodeMap, setTraceNodeMap] = useState<Map<string, string>>(emptyTraceNodeMap);\n const [lastExternalValue, setLastExternalValue] = useState<string>('');\n const [lastData, setLastData] = useState<string>('');\n const [lastHadTrace, setLastHadTrace] = useState<boolean>(false);\n\n // Convert JSONLogic to nodes when value changes from outside\n /* eslint-disable react-hooks/set-state-in-effect -- Derived state computation from value/data props */\n useEffect(() => {\n const valueStr = JSON.stringify(value);\n const dataStr = JSON.stringify(data);\n const hasTrace = !!evaluateWithTrace;\n\n // Re-process if value, data, or trace availability changed\n if (valueStr === lastExternalValue && dataStr === lastData && hasTrace === lastHadTrace) {\n return;\n }\n\n try {\n // Validate recursion depth\n if (!checkDepth(value)) {\n setError(`Expression exceeds maximum nesting depth of ${MAX_RECURSION_DEPTH}`);\n setNodes([]);\n setEdges([]);\n setEvaluationResults(emptyResults);\n setSteps(emptySteps);\n setTraceNodeMap(emptyTraceNodeMap);\n setUsingTraceMode(false);\n setLastExternalValue(valueStr);\n setLastData(dataStr);\n setLastHadTrace(hasTrace);\n return;\n }\n\n // Try trace-based conversion first if available\n if (evaluateWithTrace && value) {\n try {\n const trace = evaluateWithTrace(value, data ?? {});\n const { nodes: newNodes, edges: newEdges, traceNodeMap: newTraceNodeMap } = traceToNodes(trace);\n const layoutedNodes = applyTreeLayout(newNodes, newEdges);\n const traceResults = buildEvaluationResultsFromTrace(trace);\n setNodes(layoutedNodes);\n setEdges(newEdges);\n setEvaluationResults(traceResults);\n setSteps(trace.steps);\n setTraceNodeMap(newTraceNodeMap);\n setUsingTraceMode(true);\n setError(null);\n setLastExternalValue(valueStr);\n setLastData(dataStr);\n setLastHadTrace(hasTrace);\n return;\n } catch (traceErr) {\n // Trace conversion failed, fall back to JS parsing\n console.warn('Trace conversion failed, falling back to JS:', traceErr);\n }\n }\n\n // Fallback to JS parsing (no built-in evaluation results)\n const { nodes: newNodes, edges: newEdges } = jsonLogicToNodes(value);\n const layoutedNodes = applyTreeLayout(newNodes, newEdges);\n setNodes(layoutedNodes);\n setEdges(newEdges);\n setEvaluationResults(emptyResults);\n setSteps(emptySteps);\n setTraceNodeMap(emptyTraceNodeMap);\n setUsingTraceMode(false);\n setError(null);\n } catch (err) {\n const errorMessage = err instanceof Error ? err.message : 'Unknown error during conversion';\n setError(errorMessage);\n setNodes([]);\n setEdges([]);\n setEvaluationResults(emptyResults);\n setSteps(emptySteps);\n setTraceNodeMap(emptyTraceNodeMap);\n setUsingTraceMode(false);\n }\n setLastExternalValue(valueStr);\n setLastData(dataStr);\n setLastHadTrace(hasTrace);\n }, [value, data, evaluateWithTrace, lastExternalValue, lastData, lastHadTrace]);\n /* eslint-enable react-hooks/set-state-in-effect */\n\n // Memoize return value to maintain stable identity\n return useMemo(\n () => ({\n nodes,\n edges,\n error,\n evaluationResults,\n usingTraceMode,\n steps,\n traceNodeMap,\n }),\n [nodes, edges, error, evaluationResults, usingTraceMode, steps, traceNodeMap]\n );\n}\n","import { createContext, useContext } from 'react';\nimport type { EvaluationResultsMap } from '../hooks/useLogicEditor';\n\nexport const EvaluationContext = createContext<EvaluationResultsMap>(new Map());\n\nexport function useEvaluationResult(nodeId: string) {\n const results = useContext(EvaluationContext);\n return results.get(nodeId);\n}\n\nexport function useEvaluationResults() {\n return useContext(EvaluationContext);\n}\n","import {\n createContext,\n useContext,\n useReducer,\n useEffect,\n useMemo,\n useCallback,\n type ReactNode,\n} from 'react';\nimport type { ExecutionStep } from '../types/trace';\nimport type { LogicNode } from '../types';\n\n// Playback states\ntype PlaybackState = 'playing' | 'paused' | 'stopped';\n\n// Debugger state\ninterface DebuggerState {\n isActive: boolean;\n steps: ExecutionStep[];\n currentStepIndex: number;\n playbackState: PlaybackState;\n playbackSpeed: number; // milliseconds per step\n}\n\n// Actions\ntype DebuggerAction =\n | { type: 'INITIALIZE'; steps: ExecutionStep[] }\n | { type: 'PLAY' }\n | { type: 'PAUSE' }\n | { type: 'STOP' }\n | { type: 'STEP_FORWARD' }\n | { type: 'STEP_BACKWARD' }\n | { type: 'GO_TO_STEP'; index: number }\n | { type: 'SET_SPEED'; speed: number }\n | { type: 'RESET' }\n | { type: 'AUTO_STEP_FORWARD' };\n\n// Initial state\nconst initialState: DebuggerState = {\n isActive: false,\n steps: [],\n currentStepIndex: 0,\n playbackState: 'stopped',\n playbackSpeed: 500, // Default 500ms per step\n};\n\n// Reducer\nfunction debuggerReducer(state: DebuggerState, action: DebuggerAction): DebuggerState {\n switch (action.type) {\n case 'INITIALIZE':\n return {\n ...state,\n isActive: action.steps.length > 0,\n steps: action.steps,\n currentStepIndex: 0,\n playbackState: 'stopped',\n };\n\n case 'PLAY':\n if (state.steps.length === 0) return state;\n // If at the end, reset to start\n if (state.currentStepIndex >= state.steps.length - 1) {\n return { ...state, currentStepIndex: 0, playbackState: 'playing' };\n }\n return { ...state, playbackState: 'playing' };\n\n case 'PAUSE':\n return { ...state, playbackState: 'paused' };\n\n case 'STOP':\n return { ...state, playbackState: 'stopped', currentStepIndex: 0 };\n\n case 'STEP_FORWARD':\n if (state.currentStepIndex < state.steps.length - 1) {\n return {\n ...state,\n currentStepIndex: state.currentStepIndex + 1,\n playbackState: 'paused',\n };\n }\n return { ...state, playbackState: 'paused' };\n\n case 'AUTO_STEP_FORWARD':\n // Used during auto-play - doesn't change playback state\n if (state.currentStepIndex < state.steps.length - 1) {\n return {\n ...state,\n currentStepIndex: state.currentStepIndex + 1,\n };\n }\n // At end, pause playback\n return { ...state, playbackState: 'paused' };\n\n case 'STEP_BACKWARD':\n if (state.currentStepIndex > 0) {\n return {\n ...state,\n currentStepIndex: state.currentStepIndex - 1,\n playbackState: 'paused',\n };\n }\n return { ...state, playbackState: 'paused' };\n\n case 'GO_TO_STEP': {\n const clampedIndex = Math.max(0, Math.min(action.index, state.steps.length - 1));\n return {\n ...state,\n currentStepIndex: clampedIndex,\n playbackState: 'paused',\n };\n }\n\n case 'SET_SPEED':\n return { ...state, playbackSpeed: action.speed };\n\n case 'RESET':\n return { ...state, currentStepIndex: 0, playbackState: 'stopped' };\n\n default:\n return state;\n }\n}\n\n// Context value type\ninterface DebuggerContextValue {\n state: DebuggerState;\n currentStep: ExecutionStep | null;\n currentNodeId: string | null;\n executedNodeIds: Set<string>;\n pathNodeIds: Set<string>; // Node IDs on the path from current node to root\n // Controls\n play: () => void;\n pause: () => void;\n stop: () => void;\n reset: () => void;\n stepForward: () => void;\n stepBackward: () => void;\n goToStep: (index: number) => void;\n setSpeed: (ms: number) => void;\n}\n\n// Create context\nconst DebuggerContext = createContext<DebuggerContextValue | null>(null);\n\n// Provider props\ninterface DebuggerProviderProps {\n children: ReactNode;\n steps: ExecutionStep[];\n traceNodeMap: Map<string, string>; // Maps trace node IDs to visual node IDs\n nodes: LogicNode[]; // For building parent map\n}\n\n// Provider component\nexport function DebuggerProvider({ children, steps, traceNodeMap, nodes }: DebuggerProviderProps) {\n const [state, dispatch] = useReducer(debuggerReducer, initialState);\n\n // Initialize with steps when they change\n useEffect(() => {\n dispatch({ type: 'INITIALIZE', steps });\n }, [steps]);\n\n // Auto-advance during playback\n useEffect(() => {\n if (state.playbackState !== 'playing') return;\n\n const timer = setInterval(() => {\n dispatch({ type: 'AUTO_STEP_FORWARD' });\n }, state.playbackSpeed);\n\n return () => clearInterval(timer);\n }, [state.playbackState, state.playbackSpeed]);\n\n // Current step\n const currentStep = useMemo(() => {\n if (state.steps.length === 0 || state.currentStepIndex < 0) return null;\n return state.steps[state.currentStepIndex] ?? null;\n }, [state.steps, state.currentStepIndex]);\n\n // Current node ID (formatted for React Flow) - use mapping to resolve inlined nodes\n const currentNodeId = useMemo(() => {\n if (!currentStep) return null;\n const traceId = `trace-${currentStep.node_id}`;\n // Use mapping to find visual node, fallback to trace ID itself\n return traceNodeMap.get(traceId) ?? traceId;\n }, [currentStep, traceNodeMap]);\n\n // Set of executed node IDs (all steps up to current) - use mapping for each\n const executedNodeIds = useMemo(() => {\n const ids = new Set<string>();\n for (let i = 0; i < state.currentStepIndex; i++) {\n const step = state.steps[i];\n if (step) {\n const traceId = `trace-${step.node_id}`;\n const visualId = traceNodeMap.get(traceId) ?? traceId;\n ids.add(visualId);\n }\n }\n return ids;\n }, [state.steps, state.currentStepIndex, traceNodeMap]);\n\n // Build parent map from nodes for path highlighting\n const parentMap = useMemo(() => {\n const map = new Map<string, string>();\n for (const node of nodes) {\n if (node.data.parentId) {\n map.set(node.id, node.data.parentId);\n }\n }\n return map;\n }, [nodes]);\n\n // Compute path from current node to root\n const pathNodeIds = useMemo(() => {\n const path = new Set<string>();\n if (!currentNodeId) return path;\n\n let nodeId: string | undefined = currentNodeId;\n while (nodeId) {\n path.add(nodeId);\n nodeId = parentMap.get(nodeId);\n }\n return path;\n }, [currentNodeId, parentMap]);\n\n // Control callbacks\n const play = useCallback(() => dispatch({ type: 'PLAY' }), []);\n const pause = useCallback(() => dispatch({ type: 'PAUSE' }), []);\n const stop = useCallback(() => dispatch({ type: 'STOP' }), []);\n const reset = useCallback(() => dispatch({ type: 'RESET' }), []);\n const stepForward = useCallback(() => dispatch({ type: 'STEP_FORWARD' }), []);\n const stepBackward = useCallback(() => dispatch({ type: 'STEP_BACKWARD' }), []);\n const goToStep = useCallback((index: number) => dispatch({ type: 'GO_TO_STEP', index }), []);\n const setSpeed = useCallback((speed: number) => dispatch({ type: 'SET_SPEED', speed }), []);\n\n const value = useMemo(\n () => ({\n state,\n currentStep,\n currentNodeId,\n executedNodeIds,\n pathNodeIds,\n play,\n pause,\n stop,\n reset,\n stepForward,\n stepBackward,\n goToStep,\n setSpeed,\n }),\n [\n state,\n currentStep,\n currentNodeId,\n executedNodeIds,\n pathNodeIds,\n play,\n pause,\n stop,\n reset,\n stepForward,\n stepBackward,\n goToStep,\n setSpeed,\n ]\n );\n\n return <DebuggerContext.Provider value={value}>{children}</DebuggerContext.Provider>;\n}\n\n// Hook to get full debugger context\n// eslint-disable-next-line react-refresh/only-export-components\nexport function useDebuggerContext() {\n const context = useContext(DebuggerContext);\n if (!context) {\n throw new Error('useDebuggerContext must be used within a DebuggerProvider');\n }\n return context;\n}\n\n// Hook to get debug state for a specific node\ninterface NodeDebugState {\n isCurrent: boolean;\n isExecuted: boolean;\n isPending: boolean;\n isOnPath: boolean; // Node is on the path from current node to root\n step: ExecutionStep | null;\n}\n\n// eslint-disable-next-line react-refresh/only-export-components\nexport function useNodeDebugState(nodeId: string): NodeDebugState | null {\n const context = useContext(DebuggerContext);\n\n return useMemo(() => {\n if (!context || !context.state.isActive) return null;\n\n const isCurrent = context.currentNodeId === nodeId;\n const isExecuted = context.executedNodeIds.has(nodeId);\n const isOnPath = context.pathNodeIds.has(nodeId);\n const isPending = !isCurrent && !isExecuted && !isOnPath;\n\n return {\n isCurrent,\n isExecuted,\n isPending,\n isOnPath,\n step: isCurrent ? context.currentStep : null,\n };\n }, [context, nodeId]);\n}\n","import { createContext } from 'react';\n\n// Map from nodeId to Set of connected handle IDs\nexport type ConnectedHandlesMap = Map<string, Set<string>>;\n\nexport const ConnectedHandlesContext = createContext<ConnectedHandlesMap>(new Map());\n","import { useMemo, type ReactNode } from 'react';\nimport type { LogicEdge } from '../types';\nimport { ConnectedHandlesContext, type ConnectedHandlesMap } from './ConnectedHandlesContextDef';\n\ninterface ConnectedHandlesProviderProps {\n edges: LogicEdge[];\n children: ReactNode;\n}\n\nexport function ConnectedHandlesProvider({\n edges,\n children,\n}: ConnectedHandlesProviderProps) {\n const connectedHandles = useMemo(() => {\n const map: ConnectedHandlesMap = new Map();\n\n for (const edge of edges) {\n // Track source handles\n const sourceHandleId = edge.sourceHandle || 'default';\n if (!map.has(edge.source)) {\n map.set(edge.source, new Set());\n }\n map.get(edge.source)!.add(sourceHandleId);\n\n // Track target handles\n const targetHandleId = edge.targetHandle || 'default';\n if (!map.has(edge.target)) {\n map.set(edge.target, new Set());\n }\n map.get(edge.target)!.add(targetHandleId);\n }\n\n return map;\n }, [edges]);\n\n return (\n <ConnectedHandlesContext.Provider value={connectedHandles}>\n {children}\n </ConnectedHandlesContext.Provider>\n );\n}\n","import { useContext } from 'react';\nimport { ConnectedHandlesContext } from './ConnectedHandlesContextDef';\n\n// Hook to check if a specific handle on a node is connected\nexport function useIsHandleConnected(nodeId: string, handleId: string): boolean {\n const connectedHandles = useContext(ConnectedHandlesContext);\n const nodeHandles = connectedHandles.get(nodeId);\n return nodeHandles?.has(handleId) ?? false;\n}\n\n// Hook to get all connected handles for a node\nexport function useConnectedHandles(nodeId: string): Set<string> {\n const connectedHandles = useContext(ConnectedHandlesContext);\n return connectedHandles.get(nodeId) ?? new Set();\n}\n","import { useNodeDebugState } from '../context';\n\n/**\n * Hook that generates debug-related CSS class names for a node based on its debug state.\n * Returns a space-separated string of class names that can be added to the node's className.\n */\nexport function useDebugClassName(nodeId: string): string {\n const debugState = useNodeDebugState(nodeId);\n\n if (!debugState) return '';\n\n return [\n debugState.isCurrent && 'debug-current',\n debugState.isExecuted && 'debug-executed',\n debugState.isPending && 'debug-pending',\n debugState.isOnPath && !debugState.isCurrent && 'debug-on-path',\n ].filter(Boolean).join(' ');\n}\n","import { useCallback } from 'react';\nimport { useReactFlow } from '@xyflow/react';\nimport type { LogicNode, OperatorNodeData, VerticalCellNodeData } from '../types';\n\ntype CollapsibleNodeData = OperatorNodeData | VerticalCellNodeData;\n\n/**\n * Hook that provides a toggle callback for collapsing/expanding nodes.\n * Works with both OperatorNode and VerticalCellNode.\n */\nexport function useNodeCollapse(nodeId: string): (e: React.MouseEvent) => void {\n const { setNodes } = useReactFlow();\n\n return useCallback(\n (e: React.MouseEvent) => {\n e.stopPropagation();\n setNodes((nodes) =>\n nodes.map((node) => {\n if (node.id === nodeId) {\n const nodeData = node.data as CollapsibleNodeData;\n return {\n ...node,\n data: {\n ...nodeData,\n collapsed: !nodeData.collapsed,\n },\n } as LogicNode;\n }\n return node;\n })\n );\n },\n [nodeId, setNodes]\n );\n}\n","import { useMemo } from 'react';\nimport type { LogicNode } from '../types';\n\nexport interface EvaluationResult {\n value: unknown;\n error: string | null;\n type: 'boolean' | 'number' | 'string' | 'null' | 'array' | 'object' | 'undefined';\n}\n\nexport type EvaluationResults = Map<string, EvaluationResult>;\n\ninterface UseDebugEvaluationProps {\n nodes: LogicNode[];\n data: unknown;\n evaluate: ((logic: unknown, data: unknown) => unknown) | null;\n enabled: boolean;\n}\n\nfunction getValueType(value: unknown): EvaluationResult['type'] {\n if (value === null) return 'null';\n if (value === undefined) return 'undefined';\n if (Array.isArray(value)) return 'array';\n if (typeof value === 'boolean') return 'boolean';\n if (typeof value === 'number') return 'number';\n if (typeof value === 'string') return 'string';\n if (typeof value === 'object') return 'object';\n return 'undefined';\n}\n\nexport function useDebugEvaluation({\n nodes,\n data,\n evaluate,\n enabled,\n}: UseDebugEvaluationProps): EvaluationResults {\n return useMemo(() => {\n const results = new Map<string, EvaluationResult>();\n\n if (!enabled || !evaluate || !data) {\n return results;\n }\n\n // Evaluate each node's expression\n for (const node of nodes) {\n const expression = node.data.expression;\n\n if (expression === undefined) {\n continue;\n }\n\n try {\n const value = evaluate(expression, data);\n results.set(node.id, {\n value,\n error: null,\n type: getValueType(value),\n });\n } catch (err) {\n results.set(node.id, {\n value: null,\n error: err instanceof Error ? err.message : String(err),\n type: 'undefined',\n });\n }\n }\n\n return results;\n }, [nodes, data, evaluate, enabled]);\n}\n","import { useEffect, useState, useCallback, useRef } from 'react';\nimport type { TracedResult } from '../types';\n\ninterface WasmModule {\n evaluate: (logic: string, data: string) => string;\n evaluate_with_trace: (logic: string, data: string) => string;\n CompiledRule: new (logic: string) => {\n evaluate: (data: string) => string;\n free: () => void;\n };\n}\n\ninterface UseWasmEvaluatorResult {\n ready: boolean;\n loading: boolean;\n error: string | null;\n evaluate: (logic: unknown, data: unknown) => unknown;\n evaluateWithTrace: (logic: unknown, data: unknown) => TracedResult;\n}\n\nexport function useWasmEvaluator(): UseWasmEvaluatorResult {\n const [ready, setReady] = useState(false);\n const [loading, setLoading] = useState(true);\n const [error, setError] = useState<string | null>(null);\n const moduleRef = useRef<WasmModule | null>(null);\n\n useEffect(() => {\n let cancelled = false;\n\n async function initWasm() {\n try {\n setLoading(true);\n setError(null);\n\n // Dynamic import of the WASM module\n const wasm = await import('@goplasmatic/datalogic');\n\n // Initialize the WASM module\n await wasm.default();\n\n if (!cancelled) {\n moduleRef.current = {\n evaluate: wasm.evaluate,\n evaluate_with_trace: wasm.evaluate_with_trace,\n CompiledRule: wasm.CompiledRule,\n };\n setReady(true);\n setLoading(false);\n }\n } catch (err) {\n if (!cancelled) {\n setError(err instanceof Error ? err.message : 'Failed to load WASM module');\n setLoading(false);\n }\n }\n }\n\n initWasm();\n\n return () => {\n cancelled = true;\n };\n }, []);\n\n const evaluate = useCallback((logic: unknown, data: unknown): unknown => {\n if (!moduleRef.current) {\n throw new Error('WASM module not initialized');\n }\n\n try {\n const logicStr = JSON.stringify(logic);\n const dataStr = JSON.stringify(data);\n const resultStr = moduleRef.current.evaluate(logicStr, dataStr);\n return JSON.parse(resultStr);\n } catch (err) {\n throw new Error(err instanceof Error ? err.message : 'Evaluation failed');\n }\n }, []);\n\n const evaluateWithTrace = useCallback((logic: unknown, data: unknown): TracedResult => {\n if (!moduleRef.current) {\n throw new Error('WASM module not initialized');\n }\n\n if (!moduleRef.current.evaluate_with_trace) {\n throw new Error('evaluate_with_trace not available in WASM module');\n }\n\n try {\n const logicStr = JSON.stringify(logic);\n const dataStr = JSON.stringify(data);\n const resultStr = moduleRef.current.evaluate_with_trace(logicStr, dataStr);\n return JSON.parse(resultStr) as TracedResult;\n } catch (err) {\n throw new Error(err instanceof Error ? err.message : 'Trace evaluation failed');\n }\n }, []);\n\n return {\n ready,\n loading,\n error,\n evaluate,\n evaluateWithTrace,\n };\n}\n","import { memo } from 'react';\nimport { Handle, Position } from '@xyflow/react';\nimport { useIsHandleConnected } from '../../context';\n\ninterface NodeInputHandlesProps {\n nodeId: string;\n color: string;\n}\n\n/**\n * Renders input handles (top and left) for a node.\n * Only shows handles if they have connections.\n */\nexport const NodeInputHandles = memo(function NodeInputHandles({\n nodeId,\n color,\n}: NodeInputHandlesProps) {\n const hasTopConnection = useIsHandleConnected(nodeId, 'top');\n const hasLeftConnection = useIsHandleConnected(nodeId, 'left');\n\n return (\n <>\n {/* Input handle from top (for vertical parent-child connections) - only show if connected */}\n {hasTopConnection && (\n <Handle\n type=\"target\"\n position={Position.Top}\n id=\"top\"\n style={{ background: color }}\n />\n )}\n {/* Input handle from left (for horizontal parent-child connections) - only show if connected */}\n {hasLeftConnection && (\n <Handle\n type=\"target\"\n position={Position.Left}\n id=\"left\"\n style={{ background: color, top: '50%' }}\n />\n )}\n </>\n );\n});\n","import { memo } from 'react';\n\ninterface CollapseToggleButtonProps {\n isCollapsed: boolean;\n onClick: (e: React.MouseEvent) => void;\n /**\n * Style variant: 'header' for node headers (white text), 'cell' for cell rows (tertiary text).\n * Defaults to 'header'.\n */\n variant?: 'header' | 'cell';\n}\n\n/**\n * Reusable collapse/expand toggle button for nodes and cell rows.\n */\nexport const CollapseToggleButton = memo(function CollapseToggleButton({\n isCollapsed,\n onClick,\n variant = 'header',\n}: CollapseToggleButtonProps) {\n return (\n <button\n className={variant === 'cell' ? 'cell-collapse-toggle' : 'collapse-toggle'}\n onClick={onClick}\n title={isCollapsed ? 'Expand' : 'Collapse'}\n >\n {isCollapsed ? '▶' : '▼'}\n </button>\n );\n});\n","import { memo } from 'react';\nimport type { ExecutionStep } from '../types/trace';\nimport { formatResultValue, isComplexValue, getValueColorClass, tokenizeJson } from '../utils/formatting';\nimport type { JsonToken, JsonTokenType } from '../utils/formatting';\n\ninterface DebugInfoBubbleProps {\n step: ExecutionStep;\n position?: 'top' | 'right' | 'bottom';\n}\n\n// Map token type to CSS class\nfunction getTokenClass(type: JsonTokenType | null): string {\n if (!type) return '';\n return `json-syntax-${type}`;\n}\n\n// Render syntax-highlighted JSON\nfunction renderHighlightedJson(value: unknown): React.ReactNode {\n const tokens = tokenizeJson(value);\n return tokens.map((token: JsonToken, index: number) => {\n const className = getTokenClass(token.type);\n if (className) {\n return <span key={index} className={className}>{token.content}</span>;\n }\n return <span key={index}>{token.content}</span>;\n });\n}\n\nexport const DebugInfoBubble = memo(function DebugInfoBubble({\n step,\n position = 'top',\n}: DebugInfoBubbleProps) {\n const hasError = !!step.error;\n const hasIteration = step.iteration_index !== undefined && step.iteration_total !== undefined;\n const result = step.result;\n const displayResult = formatResultValue(result);\n const isComplex = isComplexValue(result);\n const valueColorClass = getValueColorClass(result);\n\n return (\n <div className={`debug-info-bubble debug-info-${position} ${hasError ? 'error' : ''}`}>\n {/* Iteration info */}\n {hasIteration && (\n <div className=\"debug-info-iteration\">\n Iteration {(step.iteration_index ?? 0) + 1} of {step.iteration_total}\n </div>\n )}\n\n {/* Context section */}\n <div className=\"debug-info-section\">\n <span className=\"debug-info-label\">Context:</span>\n <pre className=\"debug-info-value\">\n {renderHighlightedJson(step.context)}\n </pre>\n </div>\n\n {/* Result section */}\n <div className=\"debug-info-section\">\n <span className=\"debug-info-label\">\n {hasError ? 'Error:' : 'Result:'}\n </span>\n {hasError ? (\n <pre className=\"debug-info-value debug-info-error\">{step.error}</pre>\n ) : (\n <div className=\"debug-info-result\">\n {isComplex ? (\n <pre className=\"debug-info-value\">\n {renderHighlightedJson(result)}\n </pre>\n ) : (\n <span className={`debug-info-simple-value ${valueColorClass}`}>\n {displayResult}\n </span>\n )}\n </div>\n )}\n </div>\n </div>\n );\n});\n","import { memo } from 'react';\nimport { useNodeDebugState } from '../../context';\nimport { DebugInfoBubble } from '../DebugInfoBubble';\n\ninterface NodeDebugBubbleProps {\n nodeId: string;\n position?: 'top' | 'right' | 'bottom';\n}\n\n/**\n * Wrapper component that conditionally renders a DebugInfoBubble\n * when the node is the current step in debugging.\n */\nexport const NodeDebugBubble = memo(function NodeDebugBubble({\n nodeId,\n position = 'top',\n}: NodeDebugBubbleProps) {\n const debugState = useNodeDebugState(nodeId);\n\n if (!debugState?.isCurrent || !debugState.step) {\n return null;\n }\n\n return <DebugInfoBubble step={debugState.step} position={position} />;\n});\n","import { memo, useMemo, type ReactElement } from 'react';\n\ntype TokenType =\n | 'operator' // AND, OR\n | 'keyword' // if, then, else\n | 'comparison' // ==, >=, <, etc.\n | 'arithmetic' // +, -, *, /, %\n | 'unary' // !, !!\n | 'function' // map, filter, val, exists, etc.\n | 'string' // \"quoted strings\"\n | 'number' // numeric values\n | 'boolean' // true, false\n | 'null' // null\n | 'variable' // variable paths like user.age\n | 'bracket' // (), [], {}\n | 'punctuation' // commas, colons\n | 'whitespace'\n | 'text'; // fallback\n\ninterface Token {\n type: TokenType;\n value: string;\n}\n\n// Keywords and operators to highlight\nconst COMPARISON_OPERATORS = ['===', '!==', '==', '!=', '>=', '<=', '>', '<'];\nconst ARITHMETIC_OPERATORS = ['+', '-', '*', '/', '%'];\nconst UNARY_OPERATORS = ['!!', '!'];\nconst FUNCTIONS = ['map', 'reduce', 'filter', 'some', 'none', 'all', 'val', 'exists', 'in', 'cat', 'substr', 'merge', 'missing', 'missing_some'];\n\n// Tokenize expression text for syntax highlighting\nfunction tokenizeExpression(text: string): Token[] {\n const tokens: Token[] = [];\n let i = 0;\n\n while (i < text.length) {\n const remaining = text.slice(i);\n\n // Whitespace\n const wsMatch = remaining.match(/^(\\s+)/);\n if (wsMatch) {\n tokens.push({ type: 'whitespace', value: wsMatch[1] });\n i += wsMatch[1].length;\n continue;\n }\n\n // String literals\n if (remaining[0] === '\"') {\n let str = '\"';\n let j = 1;\n while (j < remaining.length && remaining[j] !== '\"') {\n if (remaining[j] === '\\\\' && j + 1 < remaining.length) {\n str += remaining[j] + remaining[j + 1];\n j += 2;\n } else {\n str += remaining[j];\n j++;\n }\n }\n if (j < remaining.length) {\n str += '\"';\n j++;\n }\n tokens.push({ type: 'string', value: str });\n i += j;\n continue;\n }\n\n // Logical operators (AND, OR) - must be whole words\n const logicalMatch = remaining.match(/^(AND|OR)(?![a-zA-Z0-9_])/);\n if (logicalMatch) {\n tokens.push({ type: 'operator', value: logicalMatch[1] });\n i += logicalMatch[1].length;\n continue;\n }\n\n // Keywords (if, then, else) - must be whole words\n const keywordMatch = remaining.match(/^(if|then|else)(?![a-zA-Z0-9_])/);\n if (keywordMatch) {\n tokens.push({ type: 'keyword', value: keywordMatch[1] });\n i += keywordMatch[1].length;\n continue;\n }\n\n // Boolean literals\n const boolMatch = remaining.match(/^(true|false)(?![a-zA-Z0-9_])/);\n if (boolMatch) {\n tokens.push({ type: 'boolean', value: boolMatch[1] });\n i += boolMatch[1].length;\n continue;\n }\n\n // Null literal\n const nullMatch = remaining.match(/^(null)(?![a-zA-Z0-9_])/);\n if (nullMatch) {\n tokens.push({ type: 'null', value: nullMatch[1] });\n i += nullMatch[1].length;\n continue;\n }\n\n // Function calls - word followed by (\n const funcMatch = remaining.match(/^([a-zA-Z_][a-zA-Z0-9_]*)(?=\\()/);\n if (funcMatch && FUNCTIONS.includes(funcMatch[1])) {\n tokens.push({ type: 'function', value: funcMatch[1] });\n i += funcMatch[1].length;\n continue;\n }\n\n // Comparison operators (check longer ones first)\n let foundComparison = false;\n for (const op of COMPARISON_OPERATORS) {\n if (remaining.startsWith(op)) {\n tokens.push({ type: 'comparison', value: op });\n i += op.length;\n foundComparison = true;\n break;\n }\n }\n if (foundComparison) continue;\n\n // Unary operators (check longer ones first)\n let foundUnary = false;\n for (const op of UNARY_OPERATORS) {\n if (remaining.startsWith(op)) {\n tokens.push({ type: 'unary', value: op });\n i += op.length;\n foundUnary = true;\n break;\n }\n }\n if (foundUnary) continue;\n\n // Arithmetic operators\n if (ARITHMETIC_OPERATORS.includes(remaining[0])) {\n tokens.push({ type: 'arithmetic', value: remaining[0] });\n i++;\n continue;\n }\n\n // Brackets\n if ('()[]{}' .includes(remaining[0])) {\n tokens.push({ type: 'bracket', value: remaining[0] });\n i++;\n continue;\n }\n\n // Punctuation\n if (',;:'.includes(remaining[0])) {\n tokens.push({ type: 'punctuation', value: remaining[0] });\n i++;\n continue;\n }\n\n // Numbers (including negative and decimals)\n const numMatch = remaining.match(/^(-?\\d+\\.?\\d*(?:[eE][+-]?\\d+)?)/);\n if (numMatch) {\n tokens.push({ type: 'number', value: numMatch[1] });\n i += numMatch[1].length;\n continue;\n }\n\n // Variable paths (identifiers with dots) or plain identifiers\n const varMatch = remaining.match(/^([a-zA-Z_][a-zA-Z0-9_]*(?:\\.[a-zA-Z_][a-zA-Z0-9_]*)*)/);\n if (varMatch) {\n tokens.push({ type: 'variable', value: varMatch[1] });\n i += varMatch[1].length;\n continue;\n }\n\n // Ellipsis (...)\n if (remaining.startsWith('...')) {\n tokens.push({ type: 'punctuation', value: '...' });\n i += 3;\n continue;\n }\n\n // Any other character\n tokens.push({ type: 'text', value: remaining[0] });\n i++;\n }\n\n return tokens;\n}\n\n// CSS class mapping for token types\nconst TOKEN_CLASSES: Record<TokenType, string> = {\n operator: 'expr-operator',\n keyword: 'expr-keyword',\n comparison: 'expr-comparison',\n arithmetic: 'expr-arithmetic',\n unary: 'expr-unary',\n function: 'expr-function',\n string: 'expr-string',\n number: 'expr-number',\n boolean: 'expr-boolean',\n null: 'expr-null',\n variable: 'expr-variable',\n bracket: 'expr-bracket',\n punctuation: 'expr-punctuation',\n whitespace: '',\n text: '',\n};\n\n// Render tokens as highlighted spans\nfunction renderTokens(tokens: Token[]): ReactElement[] {\n return tokens.map((token, index) => {\n const className = TOKEN_CLASSES[token.type];\n if (!className) {\n return <span key={index}>{token.value}</span>;\n }\n return (\n <span key={index} className={className}>\n {token.value}\n </span>\n );\n });\n}\n\ninterface ExpressionSyntaxProps {\n text: string;\n}\n\n/**\n * Expression syntax highlighting component for use in nodes\n */\nexport const ExpressionSyntax = memo(function ExpressionSyntax({ text }: ExpressionSyntaxProps) {\n const highlighted = useMemo(() => {\n if (!text) return null;\n const tokens = tokenizeExpression(text);\n return renderTokens(tokens);\n }, [text]);\n\n return <>{highlighted}</>;\n});\n","import { memo } from 'react';\nimport { Handle, Position } from '@xyflow/react';\nimport type { OperatorNodeData } from '../types';\nimport { CATEGORY_COLORS } from '../types';\nimport { useDebugClassName, useNodeCollapse } from '../hooks';\nimport { NodeInputHandles, CollapseToggleButton, NodeDebugBubble } from './shared';\nimport { ExpressionSyntax } from '../utils/ExpressionSyntax';\n\ninterface OperatorNodeProps {\n id: string;\n data: OperatorNodeData;\n selected?: boolean;\n}\n\nexport const OperatorNode = memo(function OperatorNode({\n id,\n data,\n selected,\n}: OperatorNodeProps) {\n const color = CATEGORY_COLORS[data.category];\n const debugClassName = useDebugClassName(id);\n const toggleCollapse = useNodeCollapse(id);\n\n // Check if this is an inline-only node (unary operator with simple arg)\n const isInlineOnly = !!data.inlineDisplay;\n\n // Any operator expression is collapsible (shows expression text when collapsed)\n // But inline-only nodes cannot collapse\n const canCollapse = !isInlineOnly && data.childIds.length >= 1;\n const isCollapsed = canCollapse ? (data.collapsed ?? false) : false;\n\n return (\n <div\n className={`operator-node ${selected ? 'selected' : ''} ${isCollapsed ? 'collapsed' : ''} ${debugClassName}`}\n style={{\n borderColor: color,\n backgroundColor: `${color}10`,\n }}\n >\n <NodeDebugBubble nodeId={id} position=\"top\" />\n <NodeInputHandles nodeId={id} color={color} />\n\n <div className=\"operator-node-header\" style={{ backgroundColor: color }}>\n <div className=\"operator-header-content\">\n <span className=\"operator-label\">{data.label}</span>\n {canCollapse && (\n <CollapseToggleButton isCollapsed={isCollapsed} onClick={toggleCollapse} />\n )}\n </div>\n </div>\n\n <div className=\"operator-node-body\">\n {isInlineOnly ? (\n // Inline-only display for unary operators with simple args\n <div className=\"expression-text inline-expression\">\n <ExpressionSyntax text={data.inlineDisplay || ''} />\n </div>\n ) : isCollapsed ? (\n <div className=\"expression-text\">\n <ExpressionSyntax text={data.expressionText || '...'} />\n </div>\n ) : (\n <>\n <span className=\"operator-category\">{data.category}</span>\n <span className=\"operator-children-count\">\n {data.childIds.length} arg{data.childIds.length !== 1 ? 's' : ''}\n </span>\n </>\n )}\n </div>\n\n {/* Output handles for children - only show when expanded, positioned on right side */}\n {!isCollapsed &&\n data.childIds.map((_, index) => {\n // Calculate vertical position for each handle\n // Header is ~36px, body starts after, distribute handles evenly on right side\n const headerHeight = 36;\n const bodyHeight = 48; // Approximate body height\n const handleTop = headerHeight + ((index + 1) / (data.childIds.length + 1)) * bodyHeight;\n\n return (\n <Handle\n key={index}\n type=\"source\"\n position={Position.Right}\n id={`arg-${index}`}\n style={{\n background: color,\n top: `${handleTop}px`,\n }}\n />\n );\n })}\n </div>\n );\n});\n","import { memo } from 'react';\nimport { Box, Database, Search } from 'lucide-react';\nimport type { VariableNodeData } from '../types';\nimport { CATEGORY_COLORS } from '../types';\nimport { useDebugClassName } from '../hooks';\nimport { NodeInputHandles, NodeDebugBubble } from './shared';\n\ninterface VariableNodeProps {\n id: string;\n data: VariableNodeData;\n selected?: boolean;\n}\n\nexport const VariableNode = memo(function VariableNode({\n id,\n data,\n selected,\n}: VariableNodeProps) {\n const color = CATEGORY_COLORS.variable;\n const debugClassName = useDebugClassName(id);\n\n // Get the icon component based on operator type\n const OperatorIcon = data.operator === 'var' ? Box : data.operator === 'val' ? Database : Search;\n const operatorLabel = data.operator;\n\n return (\n <div\n className={`variable-node ${selected ? 'selected' : ''} ${debugClassName}`}\n style={{\n borderColor: color,\n backgroundColor: `${color}20`,\n }}\n >\n <NodeDebugBubble nodeId={id} position=\"top\" />\n <NodeInputHandles nodeId={id} color={color} />\n\n <div className=\"variable-node-content\">\n <span className=\"variable-operator\" style={{ color, display: 'inline-flex', alignItems: 'center', gap: '4px' }}>\n <OperatorIcon size={14} />\n {operatorLabel}\n </span>\n <span className=\"variable-path\">{data.path || '(empty)'}</span>\n </div>\n\n {data.defaultValue !== undefined && (\n <div className=\"variable-default\">\n <span className=\"variable-default-label\">default:</span>\n <span className=\"variable-default-value\">\n {JSON.stringify(data.defaultValue)}\n </span>\n </div>\n )}\n </div>\n );\n});\n","import { memo } from 'react';\nimport type { LiteralNodeData } from '../types';\nimport { CATEGORY_COLORS } from '../types';\nimport { LITERAL_TYPE_ICONS, Icon } from '../utils/icons';\nimport { formatValue } from '../utils/formatting';\nimport { useDebugClassName } from '../hooks';\nimport { NodeInputHandles, NodeDebugBubble } from './shared';\n\ninterface LiteralNodeProps {\n id: string;\n data: LiteralNodeData;\n selected?: boolean;\n}\n\nexport const LiteralNode = memo(function LiteralNode({\n id,\n data,\n selected,\n}: LiteralNodeProps) {\n const color = CATEGORY_COLORS.literal;\n const typeIcon = LITERAL_TYPE_ICONS[data.valueType];\n const debugClassName = useDebugClassName(id);\n\n return (\n <div\n className={`literal-node ${selected ? 'selected' : ''} ${debugClassName}`}\n style={{\n borderColor: color,\n backgroundColor: `${color}20`,\n }}\n >\n <NodeDebugBubble nodeId={id} position=\"top\" />\n <NodeInputHandles nodeId={id} color={color} />\n\n <div className=\"literal-node-content\">\n <span className=\"literal-type-icon\" style={{ color }}>\n <Icon name={typeIcon} size={14} />\n </span>\n <span className=\"literal-value\">{formatValue(data.value)}</span>\n </div>\n </div>\n );\n});\n","import { memo } from 'react';\nimport { Handle, Position } from '@xyflow/react';\nimport type { CellData } from '../types';\nimport { HANDLE_POSITIONS } from '../constants';\n\ninterface CellHandlesProps {\n cell: CellData;\n branchIndex: number;\n color: string;\n}\n\nexport const CellHandles = memo(function CellHandles({\n cell,\n branchIndex,\n color,\n}: CellHandlesProps) {\n return (\n <>\n {/* Condition branch handle - positioned at 30% of row height */}\n {cell.conditionBranchId && (\n <Handle\n type=\"source\"\n position={Position.Right}\n id={`branch-${branchIndex}`}\n className=\"cell-handle condition-handle\"\n style={{ background: color, top: `${HANDLE_POSITIONS.conditionTop}px` }}\n />\n )}\n {/* Then/Yes branch handle - positioned at 70% of row height */}\n {cell.thenBranchId && (\n <Handle\n type=\"source\"\n position={Position.Right}\n id={`branch-${branchIndex + (cell.conditionBranchId ? 1 : 0)}`}\n className=\"cell-handle then-handle\"\n style={{ background: '#22C55E', top: `${HANDLE_POSITIONS.thenTop}px` }}\n />\n )}\n {/* Standard single branch handle - centered vertically */}\n {cell.branchId && !cell.conditionBranchId && !cell.thenBranchId && (\n <Handle\n type=\"source\"\n position={Position.Right}\n id={`branch-${branchIndex}`}\n className=\"cell-handle\"\n style={{ background: color, top: `${HANDLE_POSITIONS.centeredTop}px` }}\n />\n )}\n </>\n );\n});\n","import { memo, useCallback } from 'react';\nimport type { CellData } from '../types';\nimport { Icon } from '../utils/icons';\nimport { CellHandles } from './CellHandles';\nimport { ExpressionSyntax } from '../utils/ExpressionSyntax';\nimport { CollapseToggleButton } from './shared';\nimport { BRANCH_COLORS } from '../constants';\n\ninterface CellRowProps {\n cell: CellData;\n cells: CellData[];\n collapsedIndices: number[];\n color: string;\n onToggleCollapse: (cellIndex: number, e: React.MouseEvent) => void;\n}\n\n// Calculate branch index based on previous cells\nfunction calculateBranchIndex(cells: CellData[], currentIndex: number): number {\n let branchIdx = 0;\n for (let i = 0; i < currentIndex; i++) {\n const prevCell = cells.find((c) => c.index === i);\n if (prevCell) {\n if (prevCell.conditionBranchId) branchIdx++;\n if (prevCell.thenBranchId) branchIdx++;\n if (prevCell.branchId) branchIdx++;\n }\n }\n return branchIdx;\n}\n\nexport const CellRow = memo(function CellRow({\n cell,\n cells,\n collapsedIndices,\n color,\n onToggleCollapse,\n}: CellRowProps) {\n const isCellCollapsed = collapsedIndices.includes(cell.index);\n\n // Check if this is an if/then cell (has condition/then branches)\n const isIfThenCell = cell.conditionBranchId || cell.thenBranchId;\n const hasAnyBranch = cell.type === 'branch' || isIfThenCell;\n const isExpanded = hasAnyBranch && !isCellCollapsed;\n\n // Calculate branch index for handle IDs\n const branchIndex = calculateBranchIndex(cells, cell.index);\n\n const handleToggle = useCallback(\n (e: React.MouseEvent) => {\n onToggleCollapse(cell.index, e);\n },\n [cell.index, onToggleCollapse]\n );\n\n // Check if this is a \"Then\" row (should be indented)\n const isThenRow = cell.icon === 'check';\n\n return (\n <div className={`vertical-cell-row ${isThenRow ? 'vertical-cell-row-then' : ''}`}>\n {cell.icon && (\n <span className=\"vertical-cell-row-icon\">\n <Icon name={cell.icon} size={12} />\n </span>\n )}\n\n {/* Row label (If, Then, Else, etc.) */}\n {cell.rowLabel && (\n <span className=\"vertical-cell-row-label\">\n {cell.rowLabel}\n </span>\n )}\n\n {/* Display expression - same for all cell types */}\n <span className={`vertical-cell-inline ${hasAnyBranch ? 'branch-expression' : ''}`}>\n <ExpressionSyntax text={cell.label || cell.summary?.label || '...'} />\n </span>\n\n {/* Toggle button for branch cells */}\n {hasAnyBranch && (\n <CollapseToggleButton\n isCollapsed={isCellCollapsed}\n onClick={handleToggle}\n variant=\"cell\"\n />\n )}\n\n {/* Handles for expanded branches */}\n {isExpanded && (\n <CellHandles cell={cell} branchIndex={branchIndex} color={isThenRow ? BRANCH_COLORS.yes : color} />\n )}\n </div>\n );\n});\n","import { memo, useCallback } from 'react';\nimport { useReactFlow } from '@xyflow/react';\nimport type { VerticalCellNodeData, LogicNode } from '../types';\nimport { CATEGORY_COLORS } from '../types';\nimport { useDebugClassName, useNodeCollapse } from '../hooks';\nimport { NodeInputHandles, CollapseToggleButton, NodeDebugBubble } from './shared';\nimport { CellRow } from './CellRow';\nimport { Icon } from '../utils/icons';\nimport { ExpressionSyntax } from '../utils/ExpressionSyntax';\n\ninterface VerticalCellNodeProps {\n id: string;\n data: VerticalCellNodeData;\n selected?: boolean;\n}\n\nexport const VerticalCellNode = memo(function VerticalCellNode({\n id,\n data,\n selected,\n}: VerticalCellNodeProps) {\n const { setNodes } = useReactFlow();\n const color = CATEGORY_COLORS[data.category];\n const collapsedIndices = data.collapsedCellIndices || [];\n const debugClassName = useDebugClassName(id);\n const toggleNodeCollapse = useNodeCollapse(id);\n\n // Node is collapsible if it has more than 1 arg (any type)\n const canCollapse = data.cells.length > 1;\n const isCollapsed = canCollapse ? (data.collapsed ?? false) : false;\n\n // Toggle collapse for individual cells\n const toggleCellCollapse = useCallback(\n (cellIndex: number, e: React.MouseEvent) => {\n e.stopPropagation();\n setNodes((nodes) =>\n nodes.map((node) => {\n if (node.id === id) {\n const nodeData = node.data as VerticalCellNodeData;\n const currentCollapsed = nodeData.collapsedCellIndices || [];\n const isCellCollapsed = currentCollapsed.includes(cellIndex);\n\n const newCollapsed = isCellCollapsed\n ? currentCollapsed.filter((i) => i !== cellIndex)\n : [...currentCollapsed, cellIndex];\n\n return {\n ...node,\n data: {\n ...nodeData,\n collapsedCellIndices: newCollapsed,\n },\n } as LogicNode;\n }\n return node;\n })\n );\n },\n [id, setNodes]\n );\n\n return (\n <div\n className={`vertical-cell-node ${selected ? 'selected' : ''} ${isCollapsed ? 'collapsed' : ''} ${debugClassName}`}\n style={{\n borderColor: color,\n backgroundColor: `${color}10`,\n }}\n >\n <NodeDebugBubble nodeId={id} position=\"top\" />\n <NodeInputHandles nodeId={id} color={color} />\n\n {/* Header with icon, operator, and collapse toggle */}\n <div className=\"vertical-cell-header\" style={{ backgroundColor: color }}>\n <span className=\"vertical-cell-icon\">\n <Icon name={data.icon} size={14} />\n </span>\n <span className=\"vertical-cell-label\">{data.label}</span>\n {canCollapse && (\n <CollapseToggleButton isCollapsed={isCollapsed} onClick={toggleNodeCollapse} />\n )}\n </div>\n\n {/* Body: either expression text (collapsed) or cell list (expanded) */}\n {isCollapsed ? (\n <div className=\"vertical-cell-body collapsed-body\">\n <div className=\"expression-text\">\n <ExpressionSyntax text={data.expressionText || '...'} />\n </div>\n </div>\n ) : (\n <div className=\"vertical-cell-body\">\n {data.cells.map((cell) => (\n <CellRow\n key={cell.index}\n cell={cell}\n cells={data.cells}\n collapsedIndices={collapsedIndices}\n color={color}\n onToggleCollapse={toggleCellCollapse}\n />\n ))}\n </div>\n )}\n </div>\n );\n});\n","import type { NodeTypes } from '@xyflow/react';\nimport { OperatorNode } from './OperatorNode';\nimport { VariableNode } from './VariableNode';\nimport { LiteralNode } from './LiteralNode';\nimport { VerticalCellNode } from './VerticalCellNode';\n\n// Cast to NodeTypes to satisfy ReactFlow's type requirements\n// The components are correctly typed internally but ReactFlow's generic constraints are strict\nexport const nodeTypes: NodeTypes = {\n operator: OperatorNode as NodeTypes['string'],\n variable: VariableNode as NodeTypes['string'],\n literal: LiteralNode as NodeTypes['string'],\n verticalCell: VerticalCellNode as NodeTypes['string'],\n};\n","import type { LogicNode, VerticalCellNodeData } from '../types';\nimport { isOperatorNode, isVerticalCellNode } from './type-guards';\n\n// Helper to collect all branch IDs from a cell\nfunction collectCellBranchIds(cell: VerticalCellNodeData['cells'][0], target: Set<string>): void {\n if (cell.branchId) target.add(cell.branchId);\n if (cell.conditionBranchId) target.add(cell.conditionBranchId);\n if (cell.thenBranchId) target.add(cell.thenBranchId);\n}\n\n// Build a parent-child map for O(1) child lookups\nfunction buildParentChildMap(nodes: LogicNode[]): Map<string, string[]> {\n const parentChildMap = new Map<string, string[]>();\n\n nodes.forEach((node) => {\n const parentId = node.data.parentId;\n if (parentId) {\n const children = parentChildMap.get(parentId) || [];\n children.push(node.id);\n parentChildMap.set(parentId, children);\n }\n });\n\n return parentChildMap;\n}\n\n// Get all hidden node IDs (descendants of collapsed nodes or collapsed cells)\nexport function getHiddenNodeIds(nodes: LogicNode[]): Set<string> {\n const hiddenIds = new Set<string>();\n const collapsedNodeIds = new Set<string>();\n const collapsedBranchIds = new Set<string>();\n\n // Build parent-child map for efficient lookups\n const parentChildMap = buildParentChildMap(nodes);\n\n // Find all collapsed operator nodes and collapsed cells in vertical cell nodes\n nodes.forEach((node) => {\n if (isOperatorNode(node)) {\n if (node.data.collapsed) {\n collapsedNodeIds.add(node.id);\n }\n } else if (isVerticalCellNode(node)) {\n const vcData = node.data;\n\n // If the entire node is collapsed, hide all its branch children\n if (vcData.collapsed) {\n vcData.cells.forEach((cell) => {\n collectCellBranchIds(cell, collapsedBranchIds);\n });\n } else {\n // Otherwise, only hide individually collapsed cells\n const collapsedIndices = vcData.collapsedCellIndices || [];\n vcData.cells.forEach((cell) => {\n if (collapsedIndices.includes(cell.index)) {\n collectCellBranchIds(cell, collapsedBranchIds);\n }\n });\n }\n }\n });\n\n // Recursively mark children of a node as hidden using the map\n function markDescendantsHidden(parentId: string): void {\n const children = parentChildMap.get(parentId);\n if (!children) return;\n\n for (const childId of children) {\n if (!hiddenIds.has(childId)) {\n hiddenIds.add(childId);\n // Also mark this node's children as hidden\n markDescendantsHidden(childId);\n }\n }\n }\n\n // Mark descendants of all collapsed nodes\n collapsedNodeIds.forEach((collapsedId) => {\n markDescendantsHidden(collapsedId);\n });\n\n // Mark collapsed branch nodes and their descendants as hidden\n collapsedBranchIds.forEach((branchId) => {\n hiddenIds.add(branchId);\n markDescendantsHidden(branchId);\n });\n\n return hiddenIds;\n}\n","import { useEffect, useCallback } from 'react';\nimport {\n Bug,\n SkipBack,\n ChevronLeft,\n Play,\n Pause,\n ChevronRight,\n SkipForward,\n} from 'lucide-react';\nimport { useDebuggerContext } from '../context';\nimport './DebuggerControls.css';\n\nexport function DebuggerControls() {\n const {\n state,\n play,\n pause,\n reset,\n stepForward,\n stepBackward,\n goToStep,\n setSpeed,\n } = useDebuggerContext();\n\n const { steps, currentStepIndex, playbackState, playbackSpeed } = state;\n const isPlaying = playbackState === 'playing';\n const totalSteps = steps.length;\n const isAtStart = currentStepIndex === 0;\n const isAtEnd = currentStepIndex >= totalSteps - 1;\n\n // Keyboard shortcuts\n const handleKeyDown = useCallback(\n (e: KeyboardEvent) => {\n // Ignore if user is typing in an input\n if (\n e.target instanceof HTMLInputElement ||\n e.target instanceof HTMLTextAreaElement\n ) {\n return;\n }\n\n switch (e.key) {\n case ' ':\n e.preventDefault();\n if (isPlaying) {\n pause();\n } else {\n play();\n }\n break;\n case 'ArrowLeft':\n e.preventDefault();\n stepBackward();\n break;\n case 'ArrowRight':\n e.preventDefault();\n stepForward();\n break;\n case 'Home':\n e.preventDefault();\n reset();\n break;\n case 'End':\n e.preventDefault();\n goToStep(totalSteps - 1);\n break;\n }\n },\n [isPlaying, pause, play, stepBackward, stepForward, reset, goToStep, totalSteps]\n );\n\n useEffect(() => {\n window.addEventListener('keydown', handleKeyDown);\n return () => window.removeEventListener('keydown', handleKeyDown);\n }, [handleKeyDown]);\n\n // Convert speed (ms) to display value (inverted for intuitive slider)\n // Lower ms = faster, but slider should go left-to-right as faster\n const speedToSlider = (ms: number) => 2100 - ms; // Range: 100-2000 -> 2000-100\n const sliderToSpeed = (val: number) => 2100 - val;\n\n if (totalSteps === 0) {\n return null;\n }\n\n return (\n <div className=\"debugger-controls\">\n <div className=\"debugger-controls-inner\">\n {/* Bug icon indicator */}\n <div className=\"debugger-icon\">\n <Bug size={18} />\n </div>\n\n {/* Navigation buttons */}\n <div className=\"debugger-buttons\">\n <button\n className=\"debugger-btn\"\n onClick={reset}\n disabled={isAtStart}\n title=\"Reset to start (Home)\"\n >\n <SkipBack size={16} />\n </button>\n\n <button\n className=\"debugger-btn\"\n onClick={stepBackward}\n disabled={isAtStart}\n title=\"Step backward (Left Arrow)\"\n >\n <ChevronLeft size={18} />\n </button>\n\n <button\n className=\"debugger-btn debugger-btn-primary\"\n onClick={isPlaying ? pause : play}\n title={isPlaying ? 'Pause (Space)' : 'Play (Space)'}\n >\n {isPlaying ? <Pause size={18} /> : <Play size={18} />}\n </button>\n\n <button\n className=\"debugger-btn\"\n onClick={stepForward}\n disabled={isAtEnd}\n title=\"Step forward (Right Arrow)\"\n >\n <ChevronRight size={18} />\n </button>\n\n <button\n className=\"debugger-btn\"\n onClick={() => goToStep(totalSteps - 1)}\n disabled={isAtEnd}\n title=\"Jump to end (End)\"\n >\n <SkipForward size={16} />\n </button>\n </div>\n\n {/* Step counter */}\n <div className=\"debugger-step-counter\">\n <span className=\"step-current\">{currentStepIndex + 1}</span>\n <span className=\"step-separator\">/</span>\n <span className=\"step-total\">{totalSteps}</span>\n </div>\n\n {/* Speed control */}\n <div className=\"debugger-speed\">\n <label className=\"speed-label\">Speed</label>\n <input\n type=\"range\"\n className=\"speed-slider\"\n min={100}\n max={2000}\n step={100}\n value={speedToSlider(playbackSpeed)}\n onChange={(e) => setSpeed(sliderToSpeed(parseInt(e.target.value, 10)))}\n title={`${playbackSpeed}ms per step`}\n />\n </div>\n </div>\n </div>\n );\n}\n","import { useEffect, useMemo, useState } from 'react';\nimport {\n ReactFlow,\n Background,\n Controls,\n useNodesState,\n useEdgesState,\n useReactFlow,\n ReactFlowProvider,\n} from '@xyflow/react';\nimport '@xyflow/react/dist/style.css';\n\nimport type { DataLogicEditorProps, LogicNode, LogicEdge } from './types';\nimport { nodeTypes } from './nodes';\nimport { useLogicEditor, useWasmEvaluator, useDebugEvaluation, type EvaluationResultsMap } from './hooks';\nimport { getHiddenNodeIds } from './utils/visibility';\nimport { EvaluationContext, DebuggerProvider, ConnectedHandlesProvider } from './context';\nimport { DebuggerControls } from './debugger-controls';\nimport './styles/nodes.css';\nimport './LogicEditor.css';\n\nconst emptyResults: EvaluationResultsMap = new Map();\n\n// Hook to detect system theme\nfunction useSystemTheme(): 'light' | 'dark' {\n const [systemTheme, setSystemTheme] = useState<'light' | 'dark'>(() => {\n if (typeof window === 'undefined') return 'light';\n return window.matchMedia('(prefers-color-scheme: dark)').matches ? 'dark' : 'light';\n });\n\n useEffect(() => {\n if (typeof window === 'undefined') return;\n\n const mediaQuery = window.matchMedia('(prefers-color-scheme: dark)');\n const handler = (e: MediaQueryListEvent) => {\n setSystemTheme(e.matches ? 'dark' : 'light');\n };\n\n mediaQuery.addEventListener('change', handler);\n return () => mediaQuery.removeEventListener('change', handler);\n }, []);\n\n return systemTheme;\n}\n\n// Helper component to auto-fit view (must be inside ReactFlow)\nfunction AutoFitView({ nodeCount }: { nodeCount: number }) {\n const { fitView } = useReactFlow();\n\n useEffect(() => {\n const timer = setTimeout(() => {\n fitView({ padding: 0.2, maxZoom: 0.75 });\n }, 50);\n return () => clearTimeout(timer);\n }, [nodeCount, fitView]);\n\n return null;\n}\n\n// Inner component that handles ReactFlow state\nfunction DataLogicEditorInner({\n initialNodes,\n initialEdges,\n readOnly,\n evaluationResults,\n theme,\n showDebugger,\n}: {\n initialNodes: LogicNode[];\n initialEdges: LogicEdge[];\n readOnly: boolean;\n evaluationResults: EvaluationResultsMap;\n theme: 'light' | 'dark';\n showDebugger: boolean;\n}) {\n // Background dot colors based on theme\n const bgColor = theme === 'dark' ? '#404040' : '#cccccc';\n const [nodes, setNodes, onNodesChange] = useNodesState<LogicNode>(initialNodes);\n const [edges, setEdges, onEdgesChange] = useEdgesState<LogicEdge>(initialEdges);\n\n // Update when initial values change\n useEffect(() => {\n setNodes(initialNodes);\n setEdges(initialEdges);\n }, [initialNodes, initialEdges, setNodes, setEdges]);\n\n // Compute hidden node IDs based on collapsed state\n const hiddenNodeIds = useMemo(() => getHiddenNodeIds(nodes), [nodes]);\n\n // Build set of all node IDs for edge validation\n const nodeIds = useMemo(() => new Set(nodes.map((n) => n.id)), [nodes]);\n\n // Filter visible nodes (exclude hidden descendants of collapsed nodes)\n const visibleNodes = useMemo(\n () => nodes.filter((node) => !hiddenNodeIds.has(node.id)),\n [nodes, hiddenNodeIds]\n );\n\n // Filter visible edges (exclude edges connected to hidden or non-existent nodes)\n const visibleEdges = useMemo(\n () =>\n edges.filter(\n (edge) =>\n nodeIds.has(edge.source) &&\n nodeIds.has(edge.target) &&\n !hiddenNodeIds.has(edge.source) &&\n !hiddenNodeIds.has(edge.target)\n ),\n [edges, nodeIds, hiddenNodeIds]\n );\n\n return (\n <EvaluationContext.Provider value={evaluationResults}>\n <ConnectedHandlesProvider edges={visibleEdges}>\n <ReactFlowProvider>\n <ReactFlow\n nodes={visibleNodes}\n edges={visibleEdges}\n onNodesChange={readOnly ? undefined : onNodesChange}\n onEdgesChange={readOnly ? undefined : onEdgesChange}\n nodeTypes={nodeTypes}\n fitView\n fitViewOptions={{ padding: 0.2, maxZoom: 0.75 }}\n minZoom={0.1}\n maxZoom={2}\n defaultEdgeOptions={{\n type: 'default',\n animated: false,\n }}\n >\n <Background color={bgColor} gap={20} size={1} />\n <Controls showInteractive={!readOnly} />\n {showDebugger && <DebuggerControls />}\n <AutoFitView nodeCount={initialNodes.length} />\n </ReactFlow>\n </ReactFlowProvider>\n\n {visibleNodes.length === 0 && (\n <div className=\"logic-editor-empty\">\n <p>No expression</p>\n <p className=\"logic-editor-empty-hint\">\n Enter valid JSONLogic in the input panel to visualize it\n </p>\n </div>\n )}\n </ConnectedHandlesProvider>\n </EvaluationContext.Provider>\n );\n}\n\nexport function DataLogicEditor({\n value,\n onChange: _onChange,\n data,\n mode = 'visualize',\n theme: themeProp,\n className = '',\n}: DataLogicEditorProps) {\n // Warn about edit mode not being implemented\n if (mode === 'edit') {\n console.warn('[DataLogicEditor] Edit mode is not yet implemented. Component will render in read-only mode with debug evaluation if data is provided.');\n }\n void _onChange; // Editor mode not yet implemented\n\n // Theme handling - use prop override or system preference\n const systemTheme = useSystemTheme();\n const resolvedTheme = themeProp ?? systemTheme;\n\n // Internal WASM evaluator\n const {\n ready: wasmReady,\n evaluate,\n evaluateWithTrace,\n } = useWasmEvaluator();\n\n // Determine if debugging is enabled\n const debugEnabled = mode === 'debug' && data !== undefined;\n\n // Use trace-based evaluation when in debug mode\n const editor = useLogicEditor({\n value,\n evaluateWithTrace: debugEnabled && wasmReady ? evaluateWithTrace : undefined,\n data: debugEnabled ? data : undefined,\n });\n\n // Use root node ID as key - it's a UUID that changes with each new expression\n const expressionKey = editor.nodes.length > 0 ? editor.nodes[0].id : 'empty';\n\n // Fallback: Compute evaluation results using multiple evaluate calls (only when not in trace mode)\n const fallbackResults = useDebugEvaluation({\n nodes: editor.nodes,\n data,\n evaluate: wasmReady ? evaluate : null,\n enabled: debugEnabled && !editor.usingTraceMode && wasmReady,\n });\n\n // Use trace-based results when available, otherwise fall back to multi-evaluation\n const results = editor.usingTraceMode\n ? editor.evaluationResults\n : fallbackResults.size > 0\n ? fallbackResults\n : emptyResults;\n\n // Handle error state\n if (editor.error) {\n return (\n <div className={`logic-editor ${className}`} data-theme={resolvedTheme}>\n <div className=\"logic-editor-error\">\n <p className=\"logic-editor-error-title\">Error rendering expression</p>\n <p className=\"logic-editor-error-message\">{editor.error}</p>\n </div>\n </div>\n );\n }\n\n // Check if debugger should be active (trace mode with steps)\n const showDebugger = debugEnabled && editor.usingTraceMode && editor.steps.length > 0;\n\n // Determine if editing is enabled (future feature)\n const readOnly = mode !== 'edit';\n\n const editorInner = (\n <DataLogicEditorInner\n key={expressionKey}\n initialNodes={editor.nodes}\n initialEdges={editor.edges}\n readOnly={readOnly}\n evaluationResults={results}\n theme={resolvedTheme}\n showDebugger={showDebugger}\n />\n );\n\n return (\n <div className={`logic-editor ${className}`} data-theme={resolvedTheme}>\n {showDebugger ? (\n <DebuggerProvider\n steps={editor.steps}\n traceNodeMap={editor.traceNodeMap}\n nodes={editor.nodes}\n >\n {editorInner}\n </DebuggerProvider>\n ) : (\n editorInner\n )}\n </div>\n );\n}\n\nexport default DataLogicEditor;\n"],"names":["getValueType","COMPARISON_OPERATORS","UNARY_OPERATORS","text","Icon","__iconNode","Text","CircleHelp","uuidv4","node","version","require$$0","require$$1","require$$2","require$$3","require$$4","require$$5","require$$6","require$$7","require$$8","require$$9","require$$10","util","emptyResults","newNodes","newEdges","layoutedNodes","NodeInputHandles","CollapseToggleButton","DebugInfoBubble","NodeDebugBubble","ExpressionSyntax","OperatorNode","VariableNode","LiteralNode","CellHandles","CellRow","VerticalCellNode"],"mappings":"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","x_google_ignoreList":[7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,48,49,50,51,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100,101,102,103,104,105,106]}
|