import { builtinFunctions } from "../../lib/builtin_query_functions.ts"; import { assertEquals } from "$lib/test_deps.ts"; import { renderTemplate } from "./render.ts"; import { parseTemplate } from "./template_parser.ts"; Deno.test("Test template", async () => { const functionMap = builtinFunctions; const variables = { page: { name: "this page" }, }; // Base case assertEquals(await parseAndRender(`Hello World`, {}), `Hello World`); // Variable assertEquals( await parseAndRender(`Hello {{name}}`, { name: "World" }), `Hello World`, ); // Global variable assertEquals( await parseAndRender(`Hello {{@page.name}}`, {}), `Hello this page`, ); // Function invocation assertEquals( await parseAndRender(`Hello {{replace(name, "o", "e")}}`, { name: "World", }), `Hello Werld`, ); // Two variables assertEquals( await parseAndRender(`Hello {{firstName}} {{lastName}}`, { firstName: "Pete", lastName: "Smith", }), `Hello Pete Smith`, ); // Each directive assertEquals( await parseAndRender( `a{{#each .}}* {{name}}\n{{/each}}b`, [ { name: "Pete" }, { name: "John" }, ], ), `a* Pete\n* John\nb`, ); // If directive assertEquals( await parseAndRender( `{{#if .}}Hello{{/if}}`, true, ), `Hello`, ); assertEquals( await parseAndRender( `{{#if .}}Hello{{/if}}`, false, ), ``, ); assertEquals( await parseAndRender( `{{#if .}}Hello{{else}}Bye{{/if}}`, false, ), `Bye`, ); assertEquals( await parseAndRender( `{{#if .}}Hello{{else}}Bye{{/if}}`, true, ), `Hello`, ); assertEquals( await parseAndRender( `{{#if true}}{{#each people}}* {{name}}\n{{/each}}{{/if}}`, { people: [ { name: "Pete" }, { name: "John" }, ], }, ), `* Pete\n* John\n`, ); // Let directive assertEquals( await parseAndRender( `{{#let @name = "Pete"}}Hello {{@name}}{{/let}} and now {{@name}}`, {}, ), `Hello Pete and now undefined`, ); // Test line removal console.log( "Got this", JSON.stringify( parseTemplate( "{{#if .}}\nHello\n{{/if}}", ), null, 2, ), ); assertEquals( await parseAndRender( "{{#if .}}\nHello\n{{/if}}", true, ), "Hello\n", ); assertEquals( await parseAndRender( "{{#each [1, 2, 3]}}\n{{.}}\n{{/each}}", true, ), "1\n2\n3\n", ); assertEquals( await parseAndRender( "{{#each @v in [1, 2, 3]}}\n{{@v}}\n{{/each}}", true, ), "1\n2\n3\n", ); function parseAndRender(template: string, value: any): Promise { const parsedTemplate = parseTemplate(template); return renderTemplate(parsedTemplate, value, variables, functionMap); } });