function __cfHardenFn(fn: Function) { Object.freeze(fn); const prototype = fn.prototype; if (prototype && typeof prototype === "object") { Object.freeze(prototype); } return fn; } import { __cfHelpers } from "commonfabric"; import { pattern, UI } from "commonfabric"; const define = undefined; const runtimeDeps = undefined; const __cfAmdHooks = undefined; interface State { sections: { tasks: { label: string; }[]; tags: { name: string; }[]; }[]; } const __cfPattern_1 = __cfHelpers.pattern(__cf_pattern_input => { const tag = __cf_pattern_input.key("element"); const tasks = __cf_pattern_input.key("params", "tasks"); return ( {tag.key("name")}:{tasks.key("length")} ); }, { type: "object", properties: { element: { type: "object", properties: { name: { type: "string" } }, required: ["name"] }, params: { type: "object", properties: { tasks: { type: "object", properties: { length: { type: "number" } }, required: ["length"] } }, required: ["tasks"] } }, required: ["element", "params"] } as const satisfies __cfHelpers.JSONSchema, { anyOf: [{ $ref: "https://commonfabric.org/schemas/vnode.json" }, { $ref: "#/$defs/UIRenderable" }, { type: "object", properties: {} }], $defs: { UIRenderable: { type: "object", properties: { $UI: { $ref: "https://commonfabric.org/schemas/vnode.json" } }, required: ["$UI"] } } } as const satisfies __cfHelpers.JSONSchema); const __cfPattern_2 = __cfHelpers.pattern(__cf_pattern_input => { const section = __cf_pattern_input.key("element"); const tasks = section.key("tasks"); return (
{section.key("tags").mapWithPattern(__cfPattern_1, { tasks: { length: tasks.key("length") } })}
); }, { type: "object", properties: { element: { type: "object", properties: { tasks: { type: "array", items: { type: "object", properties: { label: { type: "string" } }, required: ["label"] } }, tags: { type: "array", items: { type: "object", properties: { name: { type: "string" } }, required: ["name"] } } }, required: ["tasks", "tags"] } }, required: ["element"] } as const satisfies __cfHelpers.JSONSchema, { anyOf: [{ $ref: "https://commonfabric.org/schemas/vnode.json" }, { $ref: "#/$defs/UIRenderable" }, { type: "object", properties: {} }], $defs: { UIRenderable: { type: "object", properties: { $UI: { $ref: "https://commonfabric.org/schemas/vnode.json" } }, required: ["$UI"] } } } as const satisfies __cfHelpers.JSONSchema); // FIXTURE: map-destructured-opaque-local-capture // Verifies: destructured opaque locals captured by nested map callbacks stay reactive // const { tasks } = section → const tasks = __cf_pattern_input.key("params", "tasks") // nested tag callback reads tasks.length through key("length"), not plain params values export default pattern((state) => ({ [UI]: (
{state.key("sections").mapWithPattern(__cfPattern_2, {})}
), }), { type: "object", properties: { sections: { type: "array", items: { type: "object", properties: { tasks: { type: "array", items: { type: "object", properties: { label: { type: "string" } }, required: ["label"] } }, tags: { type: "array", items: { type: "object", properties: { name: { type: "string" } }, required: ["name"] } } }, required: ["tasks", "tags"] } } }, required: ["sections"] } as const satisfies __cfHelpers.JSONSchema, { type: "object", properties: { $UI: { $ref: "#/$defs/JSXElement" } }, required: ["$UI"], $defs: { JSXElement: { anyOf: [{ $ref: "https://commonfabric.org/schemas/vnode.json" }, { $ref: "#/$defs/UIRenderable" }, { type: "object", properties: {} }] }, UIRenderable: { type: "object", properties: { $UI: { $ref: "https://commonfabric.org/schemas/vnode.json" } }, required: ["$UI"] } } } as const satisfies __cfHelpers.JSONSchema); // @ts-ignore: Internals function h(...args: any[]) { return __cfHelpers.h.apply(null, args); } __cfHardenFn(h); __cfReg({ __cfPattern_1, __cfPattern_2 });