import * as __ctHelpers from "commontools";
import { cell, pattern, UI } from "commontools";
// Tests mixed && and || operators: (a && b) || c
// The && should use when, the || should use unless
export default pattern((_state) => {
const user = cell<{
name: string;
age: number;
}>({ name: "", age: 0 }, {
type: "object",
properties: {
name: {
type: "string"
},
age: {
type: "number"
}
},
required: ["name", "age"]
} as const satisfies __ctHelpers.JSONSchema);
const defaultMessage = cell("Guest", {
type: "string"
} as const satisfies __ctHelpers.JSONSchema);
return {
[UI]: (
{/* (condition && value) || fallback pattern */}
{__ctHelpers.unless({
type: ["boolean", "string"]
} as const satisfies __ctHelpers.JSONSchema, {
type: "string"
} as const satisfies __ctHelpers.JSONSchema, {
type: "string"
} as const satisfies __ctHelpers.JSONSchema, __ctHelpers.derive({
type: "object",
properties: {
user: {
type: "object",
properties: {
name: {
type: "string"
},
age: {
type: "number"
}
},
required: ["name", "age"],
asCell: true
}
},
required: ["user"]
} as const satisfies __ctHelpers.JSONSchema, {
anyOf: [{
type: "string"
}, {
type: "boolean",
"enum": [false]
}]
} as const satisfies __ctHelpers.JSONSchema, { user: user }, ({ user }) => (user.get().name.length > 0 && user.get().name)), defaultMessage.get())}
{/* condition && (value || fallback) pattern */}
{__ctHelpers.when({
type: "boolean"
} as const satisfies __ctHelpers.JSONSchema, {
type: "string"
} as const satisfies __ctHelpers.JSONSchema, {
type: ["boolean", "string"]
} as const satisfies __ctHelpers.JSONSchema, __ctHelpers.derive({
type: "object",
properties: {
user: {
type: "object",
properties: {
name: {
type: "string"
},
age: {
type: "number"
}
},
required: ["name", "age"],
asCell: true
}
},
required: ["user"]
} as const satisfies __ctHelpers.JSONSchema, {
type: "boolean"
} as const satisfies __ctHelpers.JSONSchema, { user: user }, ({ user }) => user.get().age > 18), __ctHelpers.derive({
type: "object",
properties: {
user: {
type: "object",
properties: {
name: {
type: "string"
},
age: {
type: "number"
}
},
required: ["name", "age"],
asCell: true
}
},
required: ["user"]
} as const satisfies __ctHelpers.JSONSchema, {
type: "string"
} as const satisfies __ctHelpers.JSONSchema, { user: user }, ({ user }) => user.get().name || "Anonymous Adult"))}
{/* Complex: (a && b) || (c && d) */}
{__ctHelpers.derive({
type: "object",
properties: {
user: {
type: "object",
properties: {
name: {
type: "string"
},
age: {
type: "number"
}
},
required: ["name", "age"],
asCell: true
}
},
required: ["user"]
} as const satisfies __ctHelpers.JSONSchema, {
type: "string"
} as const satisfies __ctHelpers.JSONSchema, { user: user }, ({ user }) => (user.get().name.length > 0 && `Hello ${user.get().name}`) ||
(user.get().age > 0 && `Age: ${user.get().age}`) ||
"Unknown user")}
),
};
}, false as const satisfies __ctHelpers.JSONSchema, {
type: "object",
properties: {
$UI: {
$ref: "#/$defs/JSXElement"
}
},
required: ["$UI"],
$defs: {
JSXElement: {
anyOf: [{
$ref: "https://commonfabric.org/schemas/vnode.json"
}, {
type: "object",
properties: {}
}, {
$ref: "#/$defs/UIRenderable",
asOpaque: true
}]
},
UIRenderable: {
type: "object",
properties: {
$UI: {
$ref: "https://commonfabric.org/schemas/vnode.json"
}
},
required: ["$UI"]
}
}
} as const satisfies __ctHelpers.JSONSchema);
// @ts-ignore: Internals
function h(...args: any[]) { return __ctHelpers.h.apply(null, args); }
// @ts-ignore: Internals
h.fragment = __ctHelpers.h.fragment;