Page MenuHomeSealhub

component-input.tsx
No OneTemporary

component-input.tsx

import type { TableData } from "@sealcode/jdd";
import { ComponentArguments, Enum, Image, List, Structured, Table } from "@sealcode/jdd";
import type { ComponentArgument } from "@sealcode/jdd";
import type { StatefulPage } from "@sealcode/sealgen";
import { TempstreamJSX } from "tempstream";
import type { ComponentPreviewState } from "../components.sreact.js";
import { ComponentInputEnum } from "./component-input-enum.js";
import { ComponentInputImage } from "./component-input-image.js";
import { ComponentInputList } from "./component-input-list.js";
import { ComponentInputStructured } from "./component-input-structured.js";
import { ComponentInputTable } from "./component-input-table.js";
import { printArgPath } from "./print-arg-path.js";
import type { ComponentPreviewActions } from "./component-preview-actions.js";
import { is, predicates } from "@sealcode/ts-predicates";
export const actionName = "Components";
const absoluteUrlPattern = "http(s?)(://)((www.)?)(([^.]+).)?([a-zA-z0-9-_]+)";
export function ComponentInput<State extends ComponentPreviewState, T>({
state,
arg_path,
arg,
value,
page,
}: {
state: State;
arg_path: string[];
arg: ComponentArgument<T>;
value: T;
page: StatefulPage<ComponentPreviewState, typeof ComponentPreviewActions>;
}) {
if (value === undefined) {
value = arg.getEmptyValue();
}
if (arg instanceof List) {
// eslint-disable-next-line @typescript-eslint/consistent-type-assertions
return ComponentInputList({ state, arg_path, arg, value: value as T[], page });
}
const argType = arg.getTypeName();
const isUrlAbsolute =
arg instanceof ComponentArguments.URL && arg.urlType === "absolute";
const inputType = isUrlAbsolute ? "url" : "text";
if (arg instanceof Structured) {
return ComponentInputStructured({
state,
arg_path,
arg,
// eslint-disable-next-line @typescript-eslint/consistent-type-assertions
value: value as Record<string, unknown>,
page,
});
}
if (arg instanceof Enum) {
return ComponentInputEnum({
state,
arg_path,
arg,
// eslint-disable-next-line @typescript-eslint/consistent-type-assertions
value: value as string,
onchange: page.rerender(),
});
}
if (arg instanceof Image) {
return ComponentInputImage({
state,
arg_path,
arg,
// eslint-disable-next-line @typescript-eslint/consistent-type-assertions
value: value as string,
page,
});
}
if (arg instanceof Table) {
return ComponentInputTable({
state,
arg_path,
arg,
// eslint-disable-next-line @typescript-eslint/consistent-type-assertions
value: value as TableData<unknown, unknown>,
page,
});
}
return (
<div>
<label>
{arg_path.at(-1) || ""}
{argType == "markdown" ? (
<textarea
name={`$.component_args${printArgPath(arg_path)}`}
onblur={page.rerender()}
cols="40"
>
{is(value, predicates.string) ? value : ""}
</textarea>
) : (
<input
type={inputType}
name={`$.component_args${printArgPath(arg_path)}`}
value={is(value, predicates.string) ? value : ""}
size="40"
pattern={isUrlAbsolute ? absoluteUrlPattern : undefined}
/>
)}
</label>
</div>
);
}

File Metadata

Mime Type
text/x-java
Expires
Thu, Jan 23, 19:19 (16 h, 46 m)
Storage Engine
blob
Storage Format
Raw Data
Storage Handle
598675
Default Alt Text
component-input.tsx (3 KB)

Event Timeline