Skip to content

Commit

Permalink
[IMP] config: getTemplate function
Browse files Browse the repository at this point in the history
  • Loading branch information
Polymorphe57 committed Jan 10, 2024
1 parent 70101e4 commit 51865c5
Show file tree
Hide file tree
Showing 3 changed files with 35 additions and 3 deletions.
5 changes: 4 additions & 1 deletion src/runtime/template_set.ts
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@ export interface TemplateSetConfig {
translatableAttributes?: string[];
translateFn?: (s: string) => string;
templates?: string | Document | Record<string, string>;
getTemplate?: (s: string) => (Element|string|null);
}

export class TemplateSet {
Expand All @@ -22,6 +23,7 @@ export class TemplateSet {
dev: boolean;
rawTemplates: typeof globalTemplates = Object.create(globalTemplates);
templates: { [name: string]: Template } = {};
getRawTemplate?: (s: string) => (Element|string|null);
translateFn?: (s: string) => string;
translatableAttributes?: string[];
Portal = Portal;
Expand All @@ -39,6 +41,7 @@ export class TemplateSet {
}
}
}
this.getRawTemplate = config.getTemplate;
}

addTemplate(name: string, template: string | Element) {
Expand Down Expand Up @@ -77,7 +80,7 @@ export class TemplateSet {

getTemplate(name: string): Template {
if (!(name in this.templates)) {
const rawTemplate = this.rawTemplates[name];
const rawTemplate = this.getRawTemplate?.(name) || this.rawTemplates[name];
if (rawTemplate === undefined) {
let extraInfo = "";
try {
Expand Down
17 changes: 17 additions & 0 deletions tests/compiler/__snapshots__/template_set.test.ts.snap
Original file line number Diff line number Diff line change
Expand Up @@ -101,3 +101,20 @@ exports[`loading templates can load a few templates from an XMLDocument 2`] = `
}
}"
`;
exports[`loading templates function getTemplate in config 1`] = `
"function anonymous(app, bdom, helpers
) {
let { text, createBlock, list, multi, html, toggler, comment } = bdom;
let { markRaw } = helpers;
const comp1 = app.createComponent(\`DIV\`, true, true, false, []);
function slot1(ctx, node, key = \\"\\") {
return text(\`Hello World!\`);
}
return function template(ctx, node, key = \\"\\") {
return comp1({slots: markRaw({'default': {__render: slot1.bind(this), __ctx: ctx}})}, key + \`__1\`, node, this, null);
}
}"
`;
16 changes: 14 additions & 2 deletions tests/compiler/template_set.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -63,19 +63,31 @@ describe("loading templates", () => {
const result = context.renderToString("main");
expect(result).toBe("<ul><li>ok</li><li>foo</li></ul>");
});

test("does not crash if string does not have templates", () => {
const data = "";
const context = new TestContext();
context.addTemplates(data);
expect(Object.keys(context.rawTemplates)).toEqual([]);
});

test("does not crash if XMLDocument does not have templates", () => {
const data = "";
const xml = new DOMParser().parseFromString(data, "text/xml");
const context = new TestContext();
context.addTemplates(xml);
expect(Object.keys(context.rawTemplates)).toEqual([]);
});
test("function getTemplate in config", () => {
const context = new TestContext({
getTemplate: (name) => {
if (name === "main") {
const div = document.createElement("div") as Element;
div.append(document.createTextNode("Hello World!"));
return div;
}
return null;
}
});
const result = context.renderToString("main");
expect(result).toBe("<div>Hello World!</div>");
});
});

0 comments on commit 51865c5

Please sign in to comment.