@selfage/element
Version:
Create vanilla HTML elements/tags with visual structures.
198 lines • 30.3 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", { value: true });
exports.E = exports.ElementFactory = void 0;
const ref_1 = require("@selfage/ref");
class ElementFactory {
static setAttributes(ele, attributes) {
for (let [key, value] of Object.entries(attributes)) {
if (value != null) {
ele.setAttribute(key, value);
}
}
}
div(attributes, ...childNodes) {
let ele = document.createElement("div");
ElementFactory.setAttributes(ele, attributes);
ele.append(...childNodes);
return ele;
}
divRef(ref, attributes, ...childNodes) {
return (0, ref_1.assign)(ref, this.div(attributes, ...childNodes));
}
text(content = "") {
return document.createTextNode(content);
}
textRef(ref, content = "") {
return (0, ref_1.assign)(ref, this.text(content));
}
ol(attributes, ...childNodes) {
let ele = document.createElement("ol");
ElementFactory.setAttributes(ele, attributes);
ele.append(...childNodes);
return ele;
}
olRef(ref, attributes, ...childNodes) {
return (0, ref_1.assign)(ref, this.ol(attributes, ...childNodes));
}
ul(attributes, ...childNodes) {
let ele = document.createElement("ul");
ElementFactory.setAttributes(ele, attributes);
ele.append(...childNodes);
return ele;
}
ulRef(ref, attributes, ...childNodes) {
return (0, ref_1.assign)(ref, this.ul(attributes, ...childNodes));
}
li(attributes, ...childNodes) {
let ele = document.createElement("li");
ElementFactory.setAttributes(ele, attributes);
ele.append(...childNodes);
return ele;
}
liRef(ref, attributes, ...childNodes) {
return (0, ref_1.assign)(ref, this.li(attributes, ...childNodes));
}
label(attributes, ...childNodes) {
let ele = document.createElement("label");
ElementFactory.setAttributes(ele, attributes);
ele.append(...childNodes);
return ele;
}
labelRef(ref, attributes, ...childNodes) {
return (0, ref_1.assign)(ref, this.label(attributes, ...childNodes));
}
image(attributes) {
let ele = document.createElement("img");
ElementFactory.setAttributes(ele, attributes);
return ele;
}
imageRef(ref, attributes) {
return (0, ref_1.assign)(ref, this.image(attributes));
}
form(attributes, ...childNodes) {
let ele = document.createElement("form");
ElementFactory.setAttributes(ele, attributes);
ele.append(...childNodes);
return ele;
}
formRef(ref, attributes, ...childNodes) {
return (0, ref_1.assign)(ref, this.form(attributes, ...childNodes));
}
input(attributes) {
let ele = document.createElement("input");
ElementFactory.setAttributes(ele, attributes);
return ele;
}
inputRef(ref, attributes) {
return (0, ref_1.assign)(ref, this.input(attributes));
}
textarea(attributes, ...childNodes) {
let ele = document.createElement("textarea");
ElementFactory.setAttributes(ele, attributes);
ele.append(...childNodes);
return ele;
}
textareaRef(ref, attributes, ...childNodes) {
return (0, ref_1.assign)(ref, this.textarea(attributes, ...childNodes));
}
button(attributes, ...childNodes) {
let ele = document.createElement("button");
ElementFactory.setAttributes(ele, attributes);
ele.append(...childNodes);
return ele;
}
buttonRef(ref, attributes, ...childNodes) {
return (0, ref_1.assign)(ref, this.button(attributes, ...childNodes));
}
a(attributes, ...childNodes) {
let ele = document.createElement("a");
ElementFactory.setAttributes(ele, attributes);
ele.append(...childNodes);
return ele;
}
aRef(ref, attributes, ...childNodes) {
return (0, ref_1.assign)(ref, this.a(attributes, ...childNodes));
}
iframe(attributes) {
let ele = document.createElement("iframe");
ElementFactory.setAttributes(ele, attributes);
return ele;
}
iframeRef(ref, attributes) {
return (0, ref_1.assign)(ref, this.iframe(attributes));
}
video(attributes) {
let ele = document.createElement("video");
ElementFactory.setAttributes(ele, attributes);
return ele;
}
videoRef(ref, attributes) {
return (0, ref_1.assign)(ref, this.video(attributes));
}
canvas(attributes) {
let ele = document.createElement("canvas");
ElementFactory.setAttributes(ele, attributes);
return ele;
}
canvasRef(ref, attributes) {
return (0, ref_1.assign)(ref, this.canvas(attributes));
}
svg(attributes, ...childNodes) {
let ele = document.createElementNS("http://www.w3.org/2000/svg", "svg");
ElementFactory.setAttributes(ele, attributes);
ele.append(...childNodes);
return ele;
}
svgRef(ref, attributes, ...childNodes) {
return (0, ref_1.assign)(ref, this.svg(attributes, ...childNodes));
}
path(attributes) {
let ele = document.createElementNS("http://www.w3.org/2000/svg", "path");
ElementFactory.setAttributes(ele, attributes);
return ele;
}
pathRef(ref, attributes) {
return (0, ref_1.assign)(ref, this.path(attributes));
}
clipPath(attributes, ...childNodes) {
let ele = document.createElementNS("http://www.w3.org/2000/svg", "clipPath");
ElementFactory.setAttributes(ele, attributes);
ele.append(...childNodes);
return ele;
}
linearGradient(attributes, ...childNodes) {
let ele = document.createElementNS("http://www.w3.org/2000/svg", "linearGradient");
ElementFactory.setAttributes(ele, attributes);
ele.append(...childNodes);
return ele;
}
linearGradientRef(ref, attributes, ...childNodes) {
return (0, ref_1.assign)(ref, this.linearGradient(attributes, ...childNodes));
}
stop(attributes) {
let ele = document.createElementNS("http://www.w3.org/2000/svg", "stop");
ElementFactory.setAttributes(ele, attributes);
return ele;
}
stopRef(ref, attributes) {
return (0, ref_1.assign)(ref, this.stop(attributes));
}
defs(attributes, ...childNodes) {
let ele = document.createElementNS("http://www.w3.org/2000/svg", "defs");
ElementFactory.setAttributes(ele, attributes);
ele.append(...childNodes);
return ele;
}
use(attributes) {
let ele = document.createElementNS("http://www.w3.org/2000/svg", "use");
ElementFactory.setAttributes(ele, attributes);
return ele;
}
useRef(ref, attributes) {
return (0, ref_1.assign)(ref, this.use(attributes));
}
}
exports.ElementFactory = ElementFactory;
// Use abbreviation only to boost productivity.
exports.E = new ElementFactory();
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"factory.js","sourceRoot":"","sources":["factory.ts"],"names":[],"mappings":"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","sourcesContent":["import { Ref, assign } from \"@selfage/ref\";\n\nexport interface ElementAttributeMap {\n  [index: string]: string;\n}\n\nexport class ElementFactory {\n  private static setAttributes(\n    ele: Element,\n    attributes: ElementAttributeMap,\n  ): void {\n    for (let [key, value] of Object.entries(attributes)) {\n      if (value != null) {\n        ele.setAttribute(key, value);\n      }\n    }\n  }\n\n  public div(\n    attributes: ElementAttributeMap,\n    ...childNodes: Array<Node>\n  ): HTMLDivElement {\n    let ele = document.createElement(\"div\");\n    ElementFactory.setAttributes(ele, attributes);\n    ele.append(...childNodes);\n    return ele;\n  }\n\n  public divRef(\n    ref: Ref<HTMLDivElement>,\n    attributes: ElementAttributeMap,\n    ...childNodes: Array<Node>\n  ): HTMLDivElement {\n    return assign(ref, this.div(attributes, ...childNodes));\n  }\n\n  public text(content = \"\"): Text {\n    return document.createTextNode(content);\n  }\n\n  public textRef(ref: Ref<Text>, content = \"\"): Text {\n    return assign(ref, this.text(content));\n  }\n\n  public ol(\n    attributes: ElementAttributeMap,\n    ...childNodes: Array<Node>\n  ): HTMLOListElement {\n    let ele = document.createElement(\"ol\");\n    ElementFactory.setAttributes(ele, attributes);\n    ele.append(...childNodes);\n    return ele;\n  }\n\n  public olRef(\n    ref: Ref<HTMLOListElement>,\n    attributes: ElementAttributeMap,\n    ...childNodes: Array<Node>\n  ): HTMLOListElement {\n    return assign(ref, this.ol(attributes, ...childNodes));\n  }\n\n  public ul(\n    attributes: ElementAttributeMap,\n    ...childNodes: Array<Node>\n  ): HTMLUListElement {\n    let ele = document.createElement(\"ul\");\n    ElementFactory.setAttributes(ele, attributes);\n    ele.append(...childNodes);\n    return ele;\n  }\n\n  public ulRef(\n    ref: Ref<HTMLUListElement>,\n    attributes: ElementAttributeMap,\n    ...childNodes: Array<Node>\n  ): HTMLUListElement {\n    return assign(ref, this.ul(attributes, ...childNodes));\n  }\n\n  public li(\n    attributes: ElementAttributeMap,\n    ...childNodes: Array<Node>\n  ): HTMLLIElement {\n    let ele = document.createElement(\"li\");\n    ElementFactory.setAttributes(ele, attributes);\n    ele.append(...childNodes);\n    return ele;\n  }\n\n  public liRef(\n    ref: Ref<HTMLLIElement>,\n    attributes: ElementAttributeMap,\n    ...childNodes: Array<Node>\n  ): HTMLLIElement {\n    return assign(ref, this.li(attributes, ...childNodes));\n  }\n\n  public label(\n    attributes: ElementAttributeMap,\n    ...childNodes: Array<Node>\n  ): HTMLLabelElement {\n    let ele = document.createElement(\"label\");\n    ElementFactory.setAttributes(ele, attributes);\n    ele.append(...childNodes);\n    return ele;\n  }\n\n  public labelRef(\n    ref: Ref<HTMLLabelElement>,\n    attributes: ElementAttributeMap,\n    ...childNodes: Array<Node>\n  ): HTMLLabelElement {\n    return assign(ref, this.label(attributes, ...childNodes));\n  }\n\n  public image(attributes: ElementAttributeMap): HTMLImageElement {\n    let ele = document.createElement(\"img\");\n    ElementFactory.setAttributes(ele, attributes);\n    return ele;\n  }\n\n  public imageRef(\n    ref: Ref<HTMLImageElement>,\n    attributes: ElementAttributeMap,\n  ): HTMLImageElement {\n    return assign(ref, this.image(attributes));\n  }\n\n  public form(\n    attributes: ElementAttributeMap,\n    ...childNodes: Array<Node>\n  ): HTMLFormElement {\n    let ele = document.createElement(\"form\");\n    ElementFactory.setAttributes(ele, attributes);\n    ele.append(...childNodes);\n    return ele;\n  }\n\n  public formRef(\n    ref: Ref<HTMLFormElement>,\n    attributes: ElementAttributeMap,\n    ...childNodes: Array<Node>\n  ): HTMLFormElement {\n    return assign(ref, this.form(attributes, ...childNodes));\n  }\n\n  public input(attributes: ElementAttributeMap): HTMLInputElement {\n    let ele = document.createElement(\"input\");\n    ElementFactory.setAttributes(ele, attributes);\n    return ele;\n  }\n\n  public inputRef(\n    ref: Ref<HTMLInputElement>,\n    attributes: ElementAttributeMap,\n  ): HTMLInputElement {\n    return assign(ref, this.input(attributes));\n  }\n\n  public textarea(\n    attributes: ElementAttributeMap,\n    ...childNodes: Array<Node>\n  ): HTMLTextAreaElement {\n    let ele = document.createElement(\"textarea\");\n    ElementFactory.setAttributes(ele, attributes);\n    ele.append(...childNodes);\n    return ele;\n  }\n\n  public textareaRef(\n    ref: Ref<HTMLTextAreaElement>,\n    attributes: ElementAttributeMap,\n    ...childNodes: Array<Node>\n  ): HTMLTextAreaElement {\n    return assign(ref, this.textarea(attributes, ...childNodes));\n  }\n\n  public button(\n    attributes: ElementAttributeMap,\n    ...childNodes: Array<Node>\n  ): HTMLButtonElement {\n    let ele = document.createElement(\"button\");\n    ElementFactory.setAttributes(ele, attributes);\n    ele.append(...childNodes);\n    return ele;\n  }\n\n  public buttonRef(\n    ref: Ref<HTMLButtonElement>,\n    attributes: ElementAttributeMap,\n    ...childNodes: Array<Node>\n  ): HTMLButtonElement {\n    return assign(ref, this.button(attributes, ...childNodes));\n  }\n\n  public a(\n    attributes: ElementAttributeMap,\n    ...childNodes: Array<Node>\n  ): HTMLAnchorElement {\n    let ele = document.createElement(\"a\");\n    ElementFactory.setAttributes(ele, attributes);\n    ele.append(...childNodes);\n    return ele;\n  }\n\n  public aRef(\n    ref: Ref<HTMLAnchorElement>,\n    attributes: ElementAttributeMap,\n    ...childNodes: Array<Node>\n  ): HTMLAnchorElement {\n    return assign(ref, this.a(attributes, ...childNodes));\n  }\n\n  public iframe(attributes: ElementAttributeMap): HTMLIFrameElement {\n    let ele = document.createElement(\"iframe\");\n    ElementFactory.setAttributes(ele, attributes);\n    return ele;\n  }\n\n  public iframeRef(\n    ref: Ref<HTMLIFrameElement>,\n    attributes: ElementAttributeMap,\n  ): HTMLIFrameElement {\n    return assign(ref, this.iframe(attributes));\n  }\n\n  public video(attributes: ElementAttributeMap): HTMLVideoElement {\n    let ele = document.createElement(\"video\");\n    ElementFactory.setAttributes(ele, attributes);\n    return ele;\n  }\n\n  public videoRef(\n    ref: Ref<HTMLVideoElement>,\n    attributes: ElementAttributeMap,\n  ): HTMLVideoElement {\n    return assign(ref, this.video(attributes));\n  }\n\n  public canvas(attributes: ElementAttributeMap): HTMLCanvasElement {\n    let ele = document.createElement(\"canvas\");\n    ElementFactory.setAttributes(ele, attributes);\n    return ele;\n  }\n\n  public canvasRef(\n    ref: Ref<HTMLCanvasElement>,\n    attributes: ElementAttributeMap,\n  ): HTMLCanvasElement {\n    return assign(ref, this.canvas(attributes));\n  }\n\n  public svg(\n    attributes: ElementAttributeMap,\n    ...childNodes: Array<SVGElement>\n  ): SVGSVGElement {\n    let ele = document.createElementNS(\"http://www.w3.org/2000/svg\", \"svg\");\n    ElementFactory.setAttributes(ele, attributes);\n    ele.append(...childNodes);\n    return ele;\n  }\n\n  public svgRef(\n    ref: Ref<SVGSVGElement>,\n    attributes: ElementAttributeMap,\n    ...childNodes: Array<SVGElement>\n  ): SVGSVGElement {\n    return assign(ref, this.svg(attributes, ...childNodes));\n  }\n\n  public path(attributes: ElementAttributeMap): SVGPathElement {\n    let ele = document.createElementNS(\"http://www.w3.org/2000/svg\", \"path\");\n    ElementFactory.setAttributes(ele, attributes);\n    return ele;\n  }\n\n  public pathRef(\n    ref: Ref<SVGPathElement>,\n    attributes: ElementAttributeMap,\n  ): SVGPathElement {\n    return assign(ref, this.path(attributes));\n  }\n\n  public clipPath(\n    attributes: ElementAttributeMap,\n    ...childNodes: Array<SVGElement>\n  ): SVGClipPathElement {\n    let ele = document.createElementNS(\n      \"http://www.w3.org/2000/svg\",\n      \"clipPath\",\n    );\n    ElementFactory.setAttributes(ele, attributes);\n    ele.append(...childNodes);\n    return ele;\n  }\n\n  public linearGradient(\n    attributes: ElementAttributeMap,\n    ...childNodes: Array<SVGElement>\n  ): SVGLinearGradientElement {\n    let ele = document.createElementNS(\n      \"http://www.w3.org/2000/svg\",\n      \"linearGradient\",\n    );\n    ElementFactory.setAttributes(ele, attributes);\n    ele.append(...childNodes);\n    return ele;\n  }\n\n  public linearGradientRef(\n    ref: Ref<SVGLinearGradientElement>,\n    attributes: ElementAttributeMap,\n    ...childNodes: Array<SVGElement>\n  ): SVGLinearGradientElement {\n    return assign(ref, this.linearGradient(attributes, ...childNodes));\n  }\n\n  public stop(attributes: ElementAttributeMap): SVGStopElement {\n    let ele = document.createElementNS(\"http://www.w3.org/2000/svg\", \"stop\");\n    ElementFactory.setAttributes(ele, attributes);\n    return ele;\n  }\n\n  public stopRef(\n    ref: Ref<SVGStopElement>,\n    attributes: ElementAttributeMap,\n  ): SVGStopElement {\n    return assign(ref, this.stop(attributes));\n  }\n\n  public defs(\n    attributes: ElementAttributeMap,\n    ...childNodes: Array<SVGElement>\n  ): SVGDefsElement {\n    let ele = document.createElementNS(\"http://www.w3.org/2000/svg\", \"defs\");\n    ElementFactory.setAttributes(ele, attributes);\n    ele.append(...childNodes);\n    return ele;\n  }\n\n  public use(attributes: ElementAttributeMap): SVGUseElement {\n    let ele = document.createElementNS(\"http://www.w3.org/2000/svg\", \"use\");\n    ElementFactory.setAttributes(ele, attributes);\n    return ele;\n  }\n\n  public useRef(\n    ref: Ref<SVGUseElement>,\n    attributes: ElementAttributeMap,\n  ): SVGUseElement {\n    return assign(ref, this.use(attributes));\n  }\n}\n\n// Use abbreviation only to boost productivity.\nexport let E = new ElementFactory();\n"]}