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 { items: number[]; settings: { multiplier: number; }; } const __cfLift_1 = __cfHelpers.lift<{ item: number; settings: { multiplier: number; }; }, number>(({ item, settings }) => item * settings.multiplier, { type: "object", properties: { item: { type: "number" }, settings: { type: "object", properties: { multiplier: { type: "number" } }, required: ["multiplier"] } }, required: ["item", "settings"] } as const satisfies __cfHelpers.JSONSchema, { type: "number" } as const satisfies __cfHelpers.JSONSchema); const __cfPattern_1 = __cfHelpers.pattern(__cf_pattern_input => { const item = __cf_pattern_input.key("element"); const settings = __cf_pattern_input.key("params", "settings"); return ({__cfLift_1({ item: item, settings: { multiplier: settings.key("multiplier") } })}); }, { type: "object", properties: { element: { type: "number" }, params: { type: "object", properties: { settings: { type: "object", properties: { multiplier: { type: "number" } }, required: ["multiplier"] } }, required: ["settings"] } }, 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); // FIXTURE: map-capture-derived-from-param // Verifies: variable derived from state (const settings = state.settings) is captured correctly // .map(fn) → .mapWithPattern(pattern(...), { settings: { multiplier: settings.key("multiplier") } }) // item * settings.multiplier → derive() keeps item as an explicit input and closes over the callback-owned settings param export default pattern((state) => { const settings = state.key("settings"); return { [UI]: (
{state.key("items").mapWithPattern(__cfPattern_1, { settings: { multiplier: settings.key("multiplier") } })}
), }; }, { type: "object", properties: { items: { type: "array", items: { type: "number" } }, settings: { type: "object", properties: { multiplier: { type: "number" } }, required: ["multiplier"] } }, required: ["items", "settings"] } 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({ __cfLift_1, __cfPattern_1 });