import * as __ctHelpers from "commontools";
import { recipe, UI } from "commontools";
interface Point {
x: number;
y: number;
}
interface State {
points: Point[];
scale: number;
}
export default recipe({
type: "object",
properties: {
points: {
type: "array",
items: {
$ref: "#/$defs/Point"
}
},
scale: {
type: "number"
}
},
required: ["points", "scale"],
$defs: {
Point: {
type: "object",
properties: {
x: {
type: "number"
},
y: {
type: "number"
}
},
required: ["x", "y"]
}
}
} as const satisfies __ctHelpers.JSONSchema, {
type: "object",
properties: {
$UI: {
$ref: "#/$defs/Element"
}
},
required: ["$UI"],
$defs: {
Element: {
type: "object",
properties: {
type: {
type: "string",
"enum": ["vnode"]
},
name: {
type: "string"
},
props: {
$ref: "#/$defs/Props"
},
children: {
$ref: "#/$defs/RenderNode"
},
$UI: {
$ref: "#/$defs/VNode"
}
},
required: ["type", "name", "props"]
},
VNode: {
type: "object",
properties: {
type: {
type: "string",
"enum": ["vnode"]
},
name: {
type: "string"
},
props: {
$ref: "#/$defs/Props"
},
children: {
$ref: "#/$defs/RenderNode"
},
$UI: {
$ref: "#/$defs/VNode"
}
},
required: ["type", "name", "props"]
},
RenderNode: {
anyOf: [{
type: "string"
}, {
type: "number"
}, {
type: "boolean",
"enum": [false]
}, {
type: "boolean",
"enum": [true]
}, {
$ref: "#/$defs/VNode"
}, {
type: "object",
properties: {}
}, {
type: "array",
items: {
$ref: "#/$defs/RenderNode"
}
}]
},
Props: {
type: "object",
properties: {},
additionalProperties: {
anyOf: [{
type: "string"
}, {
type: "number"
}, {
type: "boolean",
"enum": [false]
}, {
type: "boolean",
"enum": [true]
}, {
type: "object",
additionalProperties: true
}, {
type: "array",
items: true
}, {
asCell: true
}, {
asStream: true
}, {
type: "null"
}]
}
}
}
} as const satisfies __ctHelpers.JSONSchema, (state) => {
return {
[UI]: (
{/* Map with destructured parameter and capture */}
{state.points.mapWithPattern(__ctHelpers.recipe({
type: "object",
properties: {
element: {
$ref: "#/$defs/Point"
},
params: {
type: "object",
properties: {
state: {
type: "object",
properties: {
scale: {
type: "number",
asOpaque: true
}
},
required: ["scale"]
}
},
required: ["state"]
}
},
required: ["element", "params"],
$defs: {
Point: {
type: "object",
properties: {
x: {
type: "number"
},
y: {
type: "number"
}
},
required: ["x", "y"]
}
}
} as const satisfies __ctHelpers.JSONSchema, {
type: "object",
properties: {
type: {
type: "string",
"enum": ["vnode"]
},
name: {
type: "string"
},
props: {
$ref: "#/$defs/Props"
},
children: {
$ref: "#/$defs/RenderNode"
},
$UI: {
$ref: "#/$defs/VNode"
}
},
required: ["type", "name", "props"],
$defs: {
VNode: {
type: "object",
properties: {
type: {
type: "string",
"enum": ["vnode"]
},
name: {
type: "string"
},
props: {
$ref: "#/$defs/Props"
},
children: {
$ref: "#/$defs/RenderNode"
},
$UI: {
$ref: "#/$defs/VNode"
}
},
required: ["type", "name", "props"]
},
RenderNode: {
anyOf: [{
type: "string"
}, {
type: "number"
}, {
type: "boolean",
"enum": [false]
}, {
type: "boolean",
"enum": [true]
}, {
$ref: "#/$defs/VNode"
}, {
type: "object",
properties: {}
}, {
type: "array",
items: {
$ref: "#/$defs/RenderNode"
}
}]
},
Props: {
type: "object",
properties: {},
additionalProperties: {
anyOf: [{
type: "string"
}, {
type: "number"
}, {
type: "boolean",
"enum": [false]
}, {
type: "boolean",
"enum": [true]
}, {
type: "object",
additionalProperties: true
}, {
type: "array",
items: true
}, {
asCell: true
}, {
asStream: true
}, {
type: "null"
}]
}
}
}
} as const satisfies __ctHelpers.JSONSchema, ({ element: { x, y }, params: { state } }) => (
Point: ({__ctHelpers.derive({
type: "object",
properties: {
x: {
type: "number",
asOpaque: true
},
state: {
type: "object",
properties: {
scale: {
type: "number",
asOpaque: true
}
},
required: ["scale"]
}
},
required: ["x", "state"]
} as const satisfies __ctHelpers.JSONSchema, {
type: "number"
} as const satisfies __ctHelpers.JSONSchema, {
x: x,
state: {
scale: state.scale
}
}, ({ x, state }) => x * state.scale)}, {__ctHelpers.derive({
type: "object",
properties: {
y: {
type: "number",
asOpaque: true
},
state: {
type: "object",
properties: {
scale: {
type: "number",
asOpaque: true
}
},
required: ["scale"]
}
},
required: ["y", "state"]
} as const satisfies __ctHelpers.JSONSchema, {
type: "number"
} as const satisfies __ctHelpers.JSONSchema, {
y: y,
state: {
scale: state.scale
}
}, ({ y, state }) => y * state.scale)})
)), {
state: {
scale: state.scale
}
})}
),
};
});
// @ts-ignore: Internals
function h(...args: any[]) { return __ctHelpers.h.apply(null, args); }
// @ts-ignore: Internals
h.fragment = __ctHelpers.h.fragment;