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 Item {
id: number;
name: string;
active: boolean;
}
interface State {
items: Item[];
}
const __cfPattern_1 = __cfHelpers.pattern(__cf_pattern_input => {
const item = __cf_pattern_input.key("element");
return item.key("active");
}, {
type: "object",
properties: {
element: {
$ref: "#/$defs/Item"
}
},
required: ["element"],
$defs: {
Item: {
type: "object",
properties: {
id: {
type: "number"
},
name: {
type: "string"
},
active: {
type: "boolean"
}
},
required: ["id", "name", "active"]
}
}
} as const satisfies __cfHelpers.JSONSchema, {
type: "boolean"
} as const satisfies __cfHelpers.JSONSchema);
const __cfPattern_2 = __cfHelpers.pattern(__cf_pattern_input => {
const item = __cf_pattern_input.key("element");
return (
Item #{item.key("id")}: {item.key("name")}
);
}, {
type: "object",
properties: {
element: {
$ref: "#/$defs/Item"
}
},
required: ["element"],
$defs: {
Item: {
type: "object",
properties: {
id: {
type: "number"
},
name: {
type: "string"
},
active: {
type: "boolean"
}
},
required: ["id", "name", "active"]
}
}
} 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: filter-basic
// Verifies: .filter() + .map() chain on reactive arrays are both transformed
// .filter(fn) → .filterWithPattern(pattern(...), {})
// .map(fn) → .mapWithPattern(pattern(...), {})
// Context: No captured outer variables — params objects are empty {}. Basic
// filter-then-map chain where filter checks a boolean field and map renders.
export default pattern((state) => {
return {
[UI]: (
{state.key("items").filterWithPattern(__cfPattern_1, {}).mapWithPattern(__cfPattern_2, {})}
),
};
}, {
type: "object",
properties: {
items: {
type: "array",
items: {
$ref: "#/$defs/Item"
}
}
},
required: ["items"],
$defs: {
Item: {
type: "object",
properties: {
id: {
type: "number"
},
name: {
type: "string"
},
active: {
type: "boolean"
}
},
required: ["id", "name", "active"]
}
}
} 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
});