@beforesemicolon/site-builder 0.20.0 → 0.22.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/parse-style.js +1 -1
- package/dist/cjs/parse-widget.js +1 -1
- package/dist/client.js +6 -6
- package/dist/client.js.map +3 -3
- package/dist/esm/parse-style.js +1 -1
- package/dist/esm/parse-widget.js +1 -1
- package/dist/types/parse-style.d.ts +1 -1
- package/dist/types/types.d.ts +1 -0
- package/package.json +1 -1
package/dist/cjs/parse-style.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";var
|
|
1
|
+
"use strict";var u=Object.defineProperty;var b=Object.getOwnPropertyDescriptor;var $=Object.getOwnPropertyNames;var h=Object.prototype.hasOwnProperty;var m=(e,t)=>u(e,"name",{value:t,configurable:!0});var y=(e,t)=>{for(var s in t)u(e,s,{get:t[s],enumerable:!0})},j=(e,t,s,o)=>{if(t&&typeof t=="object"||typeof t=="function")for(let n of $(t))!h.call(e,n)&&n!==s&&u(e,n,{get:()=>t[n],enumerable:!(o=b(t,n))||o.enumerable});return e};var S=e=>j(u({},"__esModule",{value:!0}),e);var d={};y(d,{parseStyle:()=>f});module.exports=S(d);var g=require("./utils/turn-camel-to-kebab-casing.js");function f(e,t=""){if(typeof e=="string")return e;const s=[],o=[];for(const[r,i]of Object.entries(e))if(typeof i=="object"&&i!==null){let l;const c=(0,g.turnCamelToKebabCasing)(r);r.startsWith("&")?l=r.replace(/&/g,t.trim()):t&&c===t.trim()?l=t:l=t?`${t} ${c}`:c;const a=f(i,l);a&&o.push(a)}else s.push(`${(0,g.turnCamelToKebabCasing)(r)}: ${i};`);let n="";return s.length&&t&&(n+=`${t} { ${s.join(" ")} }`),o.length&&(n+=(n?" ":"")+o.join(" ")),n.trim()}m(f,"parseStyle");0&&(module.exports={parseStyle});
|
package/dist/cjs/parse-widget.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";var d=Object.defineProperty;var O=Object.getOwnPropertyDescriptor;var w=Object.getOwnPropertyNames;var
|
|
1
|
+
"use strict";var d=Object.defineProperty;var O=Object.getOwnPropertyDescriptor;var w=Object.getOwnPropertyNames;var S=Object.prototype.hasOwnProperty;var f=(e,t)=>d(e,"name",{value:t,configurable:!0});var b=(e,t)=>{for(var o in t)d(e,o,{get:t[o],enumerable:!0})},h=(e,t,o,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let i of w(t))!S.call(e,i)&&i!==o&&d(e,i,{get:()=>t[i],enumerable:!(n=O(t,i))||n.enumerable});return e};var M=e=>h(d({},"__esModule",{value:!0}),e);var W={};b(W,{parseTemplateContent:()=>l,parseWidget:()=>C});module.exports=M(W);var m=require("./default-parse-options.js"),u=require("./utils/input-definitions-to-object.js"),g=require("./parse-style.js"),y=require("./utils/attributes-to-string.js"),$=require("./utils/replace-string-value.js");const c=new Map;async function C(e,t={},o,n=m.defaultOptions){let{name:i,children:a,...s}=e;if(e["data-render-id"]=e["data-render-id"]||Math.random().toString(36).substring(2,15),{name:i,children:a,...s}=e,s.id){const r=c.get(s.id)||await n.fetchWidget?.(s.id);if(r){const p={...(0,u.inputDefinitionsToObject)(r?.inputs??[]),...s,env:{...t,assetsOrigin:n.assetsOrigin,prod:n.prod}};if(typeof r.render=="function"?a=[r.render(p)]:a=r.content?[r.content]:[],r.style){const T=typeof r.style=="function"?r.style(p):r.style;o.set(r.id||s.id,(0,g.parseStyle)(T,r.cssSelector??""))}c.set(s.id,r)}}return n.prod?a.join(""):`<${i} id="${s.id}" data-render-id="${s["data-render-id"]}">${await l(a,t,o,n)}</${i}>`}f(C,"parseWidget");async function l(e,t={},o,n=m.defaultOptions){return e?(await Promise.all(e.map(async i=>{if(typeof i=="string")return(0,$.replaceStringValue)(i,t);const{name:a,children:s,...r}=i;if(a==="widget")return C(i,t,o,n);const p=(0,y.attributeToString)(r,t);return`<${a}`+(p?` ${p}`:"")+`>${await l(s,t,o,n)}</${a}>`}))).join(""):""}f(l,"parseTemplateContent");0&&(module.exports={parseTemplateContent,parseWidget});
|
package/dist/client.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
"use strict";(()=>{var V=Object.defineProperty;var
|
|
1
|
+
"use strict";(()=>{var V=Object.defineProperty;var c=(e,t)=>V(e,"name",{value:t,configurable:!0});function W(e){return e.replace(/([a-z0-9])([A-Z])/g,"$1-$2").toLowerCase()}c(W,"turnCamelToKebabCasing");function y(e,t=""){if(typeof e=="string")return e;let n=[],r=[];for(let[o,a]of Object.entries(e))if(typeof a=="object"&&a!==null){let l,p=W(o);o.startsWith("&")?l=o.replace(/&/g,t.trim()):t&&p===t.trim()?l=t:l=t?`${t} ${p}`:p;let $=y(a,l);$&&r.push($)}else n.push(`${W(o)}: ${a};`);let i="";return n.length&&t&&(i+=`${t} { ${n.join(" ")} }`),r.length&&(i+=(i?" ":"")+r.join(" ")),i.trim()}c(y,"parseStyle");function O(e,t){if(e===null||typeof e!="object"||t===null||typeof t!="object")return t;if(Array.isArray(e)&&Array.isArray(t))return Array.from(new Set([...e,...t]));let n=Array.isArray(e)?[...e]:{...e};for(let r in t)t.hasOwnProperty(r)&&(Array.isArray(e[r])&&Array.isArray(t[r])?n[r]=Array.from(new Set([...e[r],...t[r]])):n[r]=O(n[r],t[r]));return n}c(O,"mergeObjects");var h={fetchWidget:async()=>null,fetchTemplate:async()=>null,prod:!1,assetsOrigin:"/"};function b(e){return e.reduce((t,{name:n="",value:r,type:i,definitions:o=[]})=>{switch(i){case"group":t[n]=b(o);break;case"options":t[n]={value:r,options:o.map(a=>Object.values(b([a]))[0])};break;case"list":t[n]=o.map(a=>Object.values(b([a]))[0]);break;default:t[n]=r}return t},{})}c(b,"inputDefinitionsToObject");var v=c((e,t)=>String(t??"").split(".").filter(Boolean).reduce((r,i)=>{try{return r&&typeof r=="object"?r[i]:void 0}catch{return null}},e),"deepValue");var j=c((e,t)=>{let n=null;for(;(n=/{{([a-z0-9.$_]+)}}/gim.exec(e))!==null;){let[r,i]=n,o=v(t,i);e=e.replace(r,String(o))}return e},"replaceStringValue");var k=c((e,t={})=>Object.entries(e).map(([n,r])=>(typeof r=="string"&&(r=j(r,t)),`${n}="${r}"`)).join(" "),"attributeToString");var N=new Map;async function E(e,t={},n,r=h){let{name:i,children:o,...a}=e;if(e["data-render-id"]=e["data-render-id"]||Math.random().toString(36).substring(2,15),{name:i,children:o,...a}=e,a.id){let l=N.get(a.id)||await r.fetchWidget?.(a.id);if(l){let p={...b(l?.inputs??[]),...a,env:{...t,assetsOrigin:r.assetsOrigin,prod:r.prod}};if(typeof l.render=="function"?o=[l.render(p)]:o=l.content?[l.content]:[],l.style){let $=typeof l.style=="function"?l.style(p):l.style;n.set(l.id||a.id,y($,l.cssSelector??""))}N.set(a.id,l)}}return r.prod?o.join(""):`<${i} id="${a.id}" data-render-id="${a["data-render-id"]}">${await w(o,t,n,r)}</${i}>`}c(E,"parseWidget");async function w(e,t={},n,r=h){return e?(await Promise.all(e.map(async i=>{if(typeof i=="string")return j(i,t);let{name:o,children:a,...l}=i;if(o==="widget")return E(i,t,n,r);let p=k(l,t);return`<${o}`+(p?` ${p}`:"")+`>${await w(a,t,n,r)}</${o}>`}))).join(""):""}c(w,"parseTemplateContent");var L=new Map,R=c(async(e,t=h)=>{if(t=O(h,t),L.set(e.id,e),e.extends){let s=L.get(e.extends)||await t.fetchTemplate?.(e.extends);if(!s)throw new Error(`Template "${e.extends}" not found`);L.set(e.extends,s),e=O(s,e)}let{metadata:n={},scripts:r=[],stylesheets:i=[],links:o=[],fonts:a=[],favicons:l=[],content:p="",manifest:$,...d}=e??{},P=new Map,F=typeof p=="string"?p:await w(p,d,P,t);n.charset||(n.charset="UTF-8"),n.viewport||(n.viewport="width=device-width, initial-scale=1.0");let M=Object.entries(n).map(([s,m])=>s.startsWith("property:")?`<meta property="${s.replace("property:","")}" content="${m}">`:(s==="msapplication-TileImage"&&(m=`${t.assetsOrigin}${m}`),`<meta name="${s}" content="${m}">`)).join(""),C="";o.forEach(s=>{let m="<link ";Object.entries(s).forEach(([g,T])=>{m+=`${g}="${T}" `}),C+=m+"/>"});let x="";l.forEach(s=>{let m="<link ";Object.entries(s).forEach(([g,T])=>{m+=`${g}="${g==="href"?`${t.assetsOrigin}assets/favicons/`:""}${T}" `}),x+=m+"/>"});let A="";a.forEach(s=>{A+=`<link rel="preload" href="${t.assetsOrigin}assets/fonts/${s}" as="font" crossorigin>`});let f="";[...i,...Array.from(P.entries())].forEach(s=>{if(typeof s=="string")s.startsWith("http")?f+=`<link rel="stylesheet" href="${s}" >`:s.endsWith(".css")?f+=`<link rel="stylesheet" href="${t.assetsOrigin}stylesheets/${s}">`:f+=`<style>${s}</style>`;else if(Array.isArray(s)){let[m,g]=s;f+=`<style id="${m}">${y(g)}</style>`}else f+="<style",Object.entries(s.attributes).forEach(([m,g])=>{f+=`${m}="${g}" `}),f+="></style>"});let u="";return r.forEach(s=>{typeof s=="string"?s.startsWith("http")?u+=`<script src="${s}"><\/script>`:s.endsWith(".js")?u+=`<script src="${t.assetsOrigin}scripts/${s}"><\/script>`:u+=`<script>${s}<\/script>`:(u+="<script ",Object.entries(s).forEach(([m,g])=>{u+=`${m}="${g}" `}),u+="><\/script>")}),`<!doctype html>
|
|
2
2
|
<html lang="${d.lang??"en"}">
|
|
3
3
|
<head>
|
|
4
4
|
<title>${d.title}</title>
|
|
@@ -12,15 +12,15 @@
|
|
|
12
12
|
<meta property="og:url" content="${d.domain}">
|
|
13
13
|
<meta property="og:site_name" content="${d.title}">
|
|
14
14
|
${M?`<!-- metas -->${M}`:""}
|
|
15
|
-
${
|
|
15
|
+
${x?`<!-- favicons -->${x}`:""}
|
|
16
16
|
${A?`<!-- fonts -->${A}`:""}
|
|
17
|
-
${
|
|
18
|
-
${
|
|
17
|
+
${C?`<!-- links -->${C}`:""}
|
|
18
|
+
${$?`<link rel="manifest" href="${t.assetsOrigin}assets/${$}">`:""}
|
|
19
19
|
${f?`<!-- stylesheets -->${f}`:""}
|
|
20
20
|
</head>
|
|
21
21
|
<body>
|
|
22
|
-
${
|
|
22
|
+
${F}
|
|
23
23
|
${u?"<!-- scripts -->"+u:""}
|
|
24
24
|
</body>
|
|
25
|
-
</html>`.replace(/\s{2,}/g," ").replace(/[\t\n]+/g,"")},"parseTemplate");var
|
|
25
|
+
</html>`.replace(/\s{2,}/g," ").replace(/[\t\n]+/g,"")},"parseTemplate");var B=c(e=>{switch(typeof e){case"number":return"number";case"boolean":return"boolean";case"object":return Array.isArray(e)?"list":"group";default:return"text"}},"dataTypeToInputType");function S(e,t){switch(t.type){case"group":return{...t,definitions:Object.entries(e??{}).map(([n,r])=>S(r,(t.definitions??[]).find(i=>i.name===n)??{name:n,type:B(r),value:r}))};case"list":return{...t,definitions:(e??[]).map((n,r)=>S(n,(t.definitions??[])[r]??{name:String(r),type:B(n),value:n}))};default:return{...t,value:e}}}c(S,"mergeDataIntoInputDefinition");window&&(window.BFS={...window.BFS||{},SITE_BUILDER:{inputDefinitionsToObject:b,mergeDataIntoInputDefinition:S,attributeToString:k,parseTemplate:R,parseTemplateContent:w,parseWidget:E,parseStyle:y}});})();
|
|
26
26
|
//# sourceMappingURL=client.js.map
|
package/dist/client.js.map
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../src/utils/turn-camel-to-kebab-casing.ts", "../src/parse-style.ts", "../src/utils/merge-objects.ts", "../src/default-parse-options.ts", "../src/utils/input-definitions-to-object.ts", "../src/utils/deep-value.ts", "../src/utils/replace-string-value.ts", "../src/utils/attributes-to-string.ts", "../src/parse-widget.ts", "../src/parse-template.ts", "../src/utils/merge-data-into-input-definition.ts", "../src/client.ts"],
|
|
4
|
-
"sourcesContent": ["export function turnCamelToKebabCasing(str: string): string {\n return str.replace(/([a-z0-9])([A-Z])/g, '$1-$2').toLowerCase()\n}\n", "import { Style } from './types.ts'\nimport { turnCamelToKebabCasing } from './utils/turn-camel-to-kebab-casing.ts'\n\nexport function parseStyle(style: Style): string {\n if (typeof style === 'string') {\n return style\n }\n\n return Object.entries(style)\n .map(([key, value]) => {\n if (typeof value === 'object') {\n return `${turnCamelToKebabCasing(key)} { ${parseStyle(value)} }`\n }\n\n return `${turnCamelToKebabCasing(key)}: ${value};`\n })\n .join(' ')\n}\n", "export function mergeObjects(a: unknown, b: unknown) {\n if (a === null || typeof a !== 'object') return b\n if (b === null || typeof b !== 'object') return b\n\n if (Array.isArray(a) && Array.isArray(b)) {\n return Array.from(new Set([...a, ...b]))\n }\n\n const obj = Array.isArray(a) ? [...a] : { ...a }\n\n for (const key in b) {\n if (b.hasOwnProperty(key)) {\n // @ts-expect-error a or b in unknown\n if (Array.isArray(a[key]) && Array.isArray(b[key])) {\n // @ts-expect-error a or b in unknown\n obj[key] = Array.from(new Set([...a[key], ...b[key]]))\n } else {\n // @ts-expect-error a or b in unknown\n obj[key] = mergeObjects(obj[key], b[key])\n }\n }\n }\n\n return obj\n}\n", "import { parseOptions } from './types.ts'\n\nexport const defaultOptions: parseOptions = {\n fetchWidget: async () => null,\n fetchTemplate: async () => null,\n prod: false,\n assetsOrigin: '/',\n}\n", "import { ObjectLiteral, InputDefinition } from '../types.ts'\n\nexport function inputDefinitionsToObject(inputDefinitions: InputDefinition[]) {\n return inputDefinitions.reduce(\n (acc, { name = '', value, type, definitions = [] }) => {\n switch (type) {\n case 'group':\n acc[name] = inputDefinitionsToObject(definitions)\n break\n case 'options':\n acc[name] = {\n value,\n options: definitions.map((item) => {\n return Object.values(\n inputDefinitionsToObject([item])\n )[0]\n }),\n }\n break\n case 'list':\n acc[name] = definitions.map((item) => {\n return Object.values(\n inputDefinitionsToObject([item])\n )[0]\n })\n break\n default:\n acc[name] = value\n }\n\n return acc\n },\n {} as ObjectLiteral\n )\n}\n", "import { ObjectLiteral } from '../types.ts'\n\nexport const deepValue = (obj: ObjectLiteral | unknown[], key: string) => {\n const keyParts = String(key ?? '')\n .split('.')\n .filter(Boolean)\n\n return keyParts.reduce((acc, k) => {\n try {\n // @ts-expect-error No index signature with a parameter of type string\n return acc && typeof acc === 'object' ? acc[k] : undefined\n } catch (e) {\n return null\n }\n }, obj) as unknown\n}\n", "import { deepValue } from './deep-value.ts'\n\nexport const replaceStringValue = (\n value: string,\n data: Record<string, unknown>\n) => {\n let match = null\n\n while ((match = /{{([a-z0-9.$_]+)}}/gim.exec(value)) !== null) {\n const [full, key] = match\n const dv = deepValue(data, key)\n\n value = value.replace(full, String(dv))\n }\n\n return value\n}\n", "import { replaceStringValue } from './replace-string-value.ts'\n\nexport const attributeToString = (\n attributes: Record<string, unknown>,\n data = {}\n) => {\n return Object.entries(attributes)\n .map(([name, value]) => {\n if (typeof value === 'string') {\n value = replaceStringValue(value, data)\n }\n\n return `${name}=\"${value}\"`\n })\n .join(' ')\n}\n", "import {\n parseOptions,\n TemplateContentNode,\n Widget,\n Style,\n TemplateContent,\n} from './types.js'\nimport { defaultOptions } from './default-parse-options.ts'\nimport { inputDefinitionsToObject } from './utils/input-definitions-to-object.ts'\nimport { parseStyle } from './parse-style.ts'\nimport { attributeToString } from './utils/attributes-to-string.ts'\nimport { replaceStringValue } from './utils/replace-string-value.ts'\n\nconst widgetCache: Map<string, Widget> = new Map()\n\nexport async function parseWidget(\n node: TemplateContentNode,\n data = {},\n widgetStyles: Map<string, Style>,\n opt: parseOptions = defaultOptions\n) {\n let { name, children, ...attributes } = node\n\n node['data-render-id'] =\n node['data-render-id'] || Math.random().toString(36).substring(2, 15)\n ;({ name, children, ...attributes } = node)\n\n if (attributes.id) {\n const widget =\n widgetCache.get(attributes.id) ||\n (await opt.fetchWidget?.(attributes.id))\n\n if (widget) {\n const props = {\n ...inputDefinitionsToObject(widget?.inputs ?? []),\n ...attributes,\n env: {\n ...data,\n assetsOrigin: opt.assetsOrigin,\n prod: opt.prod,\n },\n }\n\n if (typeof widget.render === 'function') {\n children = [widget.render(props)]\n } else {\n children = widget.content ? [widget.content] : []\n }\n\n if (widget.style) {\n const styleContent =\n typeof widget.style === 'function'\n ? widget.style(props)\n : widget.style\n widgetStyles.set(\n widget.id || attributes.id,\n parseStyle(styleContent)\n )\n }\n\n widgetCache.set(attributes.id, widget)\n }\n }\n\n if (opt.prod) {\n return children.join('')\n }\n\n return (\n `<${name} id=\"${attributes.id}\" data-render-id=\"${attributes['data-render-id']}\"` +\n `>${await parseTemplateContent(children, data, widgetStyles, opt)}</${name}>`\n )\n}\n\nexport async function parseTemplateContent(\n content: TemplateContent,\n data = {},\n widgetStyles: Map<string, Style>,\n opt: parseOptions = defaultOptions\n): Promise<string> {\n if (!content) {\n return ''\n }\n\n return (\n await Promise.all(\n content.map(async (node) => {\n if (typeof node === 'string') {\n return replaceStringValue(node, data)\n }\n\n const { name, children, ...attributes } = node\n\n if (name === 'widget') {\n return parseWidget(\n node as TemplateContentNode,\n data,\n widgetStyles,\n opt\n )\n }\n\n const attrs = attributeToString(attributes, data)\n\n return (\n `<${name}` +\n (attrs ? ` ${attrs}` : '') +\n `>${await parseTemplateContent(children, data, widgetStyles, opt)}</${name}>`\n )\n })\n )\n ).join('')\n}\n", "import { parseOptions, Template, TemplateContent } from './types.ts'\nimport { mergeObjects } from './utils/merge-objects.ts'\nimport { defaultOptions } from './default-parse-options.ts'\nimport { parseTemplateContent } from './parse-widget.ts'\nimport { parseStyle } from './parse-style.ts'\n\nconst tempCache: Map<string, Template> = new Map()\n\nexport const parseTemplate = async (\n temp: Template,\n opt: parseOptions = defaultOptions\n) => {\n opt = mergeObjects(defaultOptions, opt) as parseOptions\n tempCache.set(temp.id, temp)\n\n if (temp.extends) {\n const base =\n tempCache.get(temp.extends) ||\n (await opt.fetchTemplate?.(temp.extends))\n\n if (!base) {\n throw new Error(`Template \"${temp.extends}\" not found`)\n }\n\n tempCache.set(temp.extends, base)\n temp = mergeObjects(base, temp) as Template\n }\n\n const {\n metadata = {},\n scripts = [],\n stylesheets = [],\n links = [],\n fonts = [],\n favicons = [],\n content = '',\n manifest,\n ...data\n } = temp ?? {}\n\n const widgetStyles = new Map()\n\n const bodyContent =\n typeof content === 'string'\n ? content\n : await parseTemplateContent(\n content as TemplateContent,\n data,\n widgetStyles,\n opt\n )\n\n if (!metadata['charset']) {\n metadata['charset'] = 'UTF-8'\n }\n\n if (!metadata['viewport']) {\n metadata['viewport'] = 'width=device-width, initial-scale=1.0'\n }\n\n const metas = Object.entries(metadata)\n .map(([key, value]) => {\n if (key.startsWith('property:')) {\n return `<meta property=\"${key.replace('property:', '')}\" content=\"${value}\">`\n }\n\n if (key === 'msapplication-TileImage') {\n value = `${opt.assetsOrigin}${value}`\n }\n\n return `<meta name=\"${key}\" content=\"${value}\">`\n })\n .join('')\n\n let ls = ''\n\n links.forEach((link) => {\n let l = '<link '\n\n Object.entries(link).forEach(([key, value]) => {\n l += `${key}=\"${value}\" `\n })\n\n ls += l + '/>'\n })\n\n let fi = ''\n\n favicons.forEach((link) => {\n let l = '<link '\n\n Object.entries(link).forEach(([key, value]) => {\n l += `${key}=\"${key === 'href' ? `${opt.assetsOrigin}assets/favicons/` : ''}${value}\" `\n })\n\n fi += l + '/>'\n })\n\n let ft = ''\n\n fonts.forEach((font) => {\n ft += `<link rel=\"preload\" href=\"${opt.assetsOrigin}assets/fonts/${font}\" as=\"font\" crossorigin>`\n })\n\n let st = ''\n\n ;[...stylesheets, ...Array.from(widgetStyles.entries())].forEach(\n (stylesheet) => {\n if (typeof stylesheet === 'string') {\n if (stylesheet.startsWith('http')) {\n st += `<link rel=\"stylesheet\" href=\"${stylesheet}\" >`\n } else if (stylesheet.endsWith('.css')) {\n st += `<link rel=\"stylesheet\" href=\"${opt.assetsOrigin}stylesheets/${stylesheet}\">`\n } else {\n st += `<style>${stylesheet}</style>`\n }\n } else if (Array.isArray(stylesheet)) {\n const [id, style] = stylesheet\n st += `<style id=\"${id}\">${parseStyle(style)}</style>`\n } else {\n st += `<style`\n\n Object.entries(stylesheet.attributes).forEach(\n ([key, value]) => {\n st += `${key}=\"${value}\" `\n }\n )\n\n st += '></style>'\n }\n }\n )\n\n let sc = ''\n\n scripts.forEach((script) => {\n if (typeof script === 'string') {\n if (script.startsWith('http')) {\n sc += `<script src=\"${script}\"></script>`\n } else if (script.endsWith('.js')) {\n sc += `<script src=\"${opt.assetsOrigin}scripts/${script}\"></script>`\n } else {\n sc += `<script>${script}</script>`\n }\n } else {\n sc += '<script '\n\n Object.entries(script).forEach(([key, value]) => {\n sc += `${key}=\"${value}\" `\n })\n\n sc += `></script>`\n }\n })\n\n return `<!doctype html>\n<html lang=\"${data.lang ?? 'en'}\">\n<head>\n <title>${data.title}</title>\n <meta charset=\"UTF-8\">\n <meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0\">\n <!-- og -->\n <meta property=\"og:title\" content=\"${data.title}\">\n <meta property=\"og:type\" content=\"website\">\n <meta property=\"og:description\" content=\"${data.description}\">\n <meta property=\"og:image\" content=\"${data.image}\">\n <meta property=\"og:url\" content=\"${data.domain}\">\n <meta property=\"og:site_name\" content=\"${data.title}\">\n ${metas ? `<!-- metas -->${metas}` : ''}\n ${fi ? `<!-- favicons -->${fi}` : ''}\n ${ft ? `<!-- fonts -->${ft}` : ''}\n ${ls ? `<!-- links -->${ls}` : ''}\n ${manifest ? `<link rel=\"manifest\" href=\"${opt.assetsOrigin}assets/${manifest}\">` : ''}\n ${st ? `<!-- stylesheets -->${st}` : ''}\n</head>\n<body>\n${bodyContent}\n${sc ? '<!-- scripts -->' + sc : ''}\n</body>\n</html>`\n .replace(/\\s{2,}/g, ' ')\n .replace(/[\\t\\n]+/g, '')\n}\n", "import {\n InputDefinition,\n ObjectLiteral,\n InputDefinitionType,\n} from '../types.ts'\n\nconst dataTypeToInputType = (data: unknown) => {\n switch (typeof data) {\n case 'number':\n return InputDefinitionType.Number\n case 'boolean':\n return InputDefinitionType.Boolean\n case 'object':\n if (Array.isArray(data)) {\n return InputDefinitionType.List\n } else {\n return InputDefinitionType.Group\n }\n default:\n return InputDefinitionType.Text\n }\n}\n\nexport function mergeDataIntoInputDefinition(\n data: unknown,\n def: InputDefinition\n): InputDefinition {\n switch (def.type) {\n case 'group':\n return {\n ...def,\n definitions: Object.entries((data ?? {}) as ObjectLiteral).map(\n ([k, v]) => {\n return mergeDataIntoInputDefinition(\n v,\n ((def.definitions ?? []) as InputDefinition[]).find(\n (item) => item.name === k\n ) ?? {\n name: k,\n type: dataTypeToInputType(v),\n value: v,\n }\n )\n }\n ),\n }\n case 'list':\n return {\n ...def,\n definitions: ((data ?? []) as Array<unknown>).map(\n (item, idx) => {\n return mergeDataIntoInputDefinition(\n item,\n ((def.definitions ?? [])[idx] ?? {\n name: String(idx),\n type: dataTypeToInputType(item),\n value: item,\n }) as InputDefinition\n )\n }\n ),\n }\n default:\n return {\n ...def,\n value: data,\n }\n }\n}\n", "import { parseStyle } from './parse-style.ts'\nimport { parseTemplate } from './parse-template.ts'\nimport { parseTemplateContent, parseWidget } from './parse-widget.ts'\nimport { attributeToString } from './utils/attributes-to-string.ts'\nimport { inputDefinitionsToObject } from './utils/input-definitions-to-object.ts'\nimport { mergeDataIntoInputDefinition } from './utils/merge-data-into-input-definition.ts'\n\n// eslint-disable-next-line @typescript-eslint/ban-ts-comment\n// @ts-ignore\nif (window) {\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n window.BFS = {\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n ...(window.BFS || {}),\n SITE_BUILDER: {\n inputDefinitionsToObject,\n mergeDataIntoInputDefinition,\n attributeToString,\n parseTemplate,\n parseTemplateContent,\n parseWidget,\n parseStyle,\n },\n }\n}\n"],
|
|
5
|
-
"mappings": "kGAAO,SAASA,EAAuBC,EAAqB,CACxD,OAAOA,EAAI,QAAQ,qBAAsB,OAAO,EAAE,YAAY,CAClE,CAFgBC,EAAAF,EAAA,0BCGT,SAASG,EAAWC,
|
|
6
|
-
"names": ["turnCamelToKebabCasing", "str", "__name", "parseStyle", "style", "key", "value", "turnCamelToKebabCasing", "__name", "mergeObjects", "a", "b", "obj", "key", "__name", "defaultOptions", "inputDefinitionsToObject", "inputDefinitions", "acc", "name", "value", "type", "definitions", "item", "__name", "deepValue", "__name", "obj", "key", "acc", "k", "replaceStringValue", "__name", "value", "data", "match", "full", "key", "dv", "deepValue", "attributeToString", "__name", "attributes", "data", "name", "value", "replaceStringValue", "widgetCache", "parseWidget", "node", "data", "widgetStyles", "opt", "defaultOptions", "name", "children", "attributes", "widget", "props", "inputDefinitionsToObject", "styleContent", "parseStyle", "parseTemplateContent", "__name", "content", "replaceStringValue", "attrs", "attributeToString", "tempCache", "parseTemplate", "__name", "temp", "opt", "defaultOptions", "mergeObjects", "base", "metadata", "scripts", "stylesheets", "links", "fonts", "favicons", "content", "manifest", "data", "widgetStyles", "bodyContent", "parseTemplateContent", "metas", "key", "value", "ls", "link", "l", "fi", "ft", "font", "st", "stylesheet", "id", "style", "parseStyle", "sc", "script", "dataTypeToInputType", "__name", "data", "mergeDataIntoInputDefinition", "def", "k", "v", "item", "idx", "inputDefinitionsToObject", "mergeDataIntoInputDefinition", "attributeToString", "parseTemplate", "parseTemplateContent", "parseWidget", "parseStyle"]
|
|
4
|
+
"sourcesContent": ["export function turnCamelToKebabCasing(str: string): string {\n return str.replace(/([a-z0-9])([A-Z])/g, '$1-$2').toLowerCase()\n}\n", "import { Style } from './types.ts'\nimport { turnCamelToKebabCasing } from './utils/turn-camel-to-kebab-casing.ts'\n\nexport function parseStyle(style: Style, prefix: string = ''): string {\n if (typeof style === 'string') {\n return style\n }\n\n const rules: string[] = []\n const nested: string[] = []\n\n for (const [key, value] of Object.entries(style)) {\n if (typeof value === 'object' && value !== null) {\n let selector: string\n const kebabKey = turnCamelToKebabCasing(key)\n if (key.startsWith('&')) {\n selector = key.replace(/&/g, prefix.trim())\n } else if (prefix && kebabKey === prefix.trim()) {\n // Avoid repeating the selector\n selector = prefix\n } else {\n selector = prefix ? `${prefix} ${kebabKey}` : kebabKey\n }\n const nestedResult = parseStyle(value, selector)\n if (nestedResult) {\n nested.push(nestedResult)\n }\n } else {\n rules.push(`${turnCamelToKebabCasing(key)}: ${value};`)\n }\n }\n\n let result = ''\n if (rules.length && prefix) {\n result += `${prefix} { ${rules.join(' ')} }`\n }\n if (nested.length) {\n result += (result ? ' ' : '') + nested.join(' ')\n }\n return result.trim()\n}\n", "export function mergeObjects(a: unknown, b: unknown) {\n if (a === null || typeof a !== 'object') return b\n if (b === null || typeof b !== 'object') return b\n\n if (Array.isArray(a) && Array.isArray(b)) {\n return Array.from(new Set([...a, ...b]))\n }\n\n const obj = Array.isArray(a) ? [...a] : { ...a }\n\n for (const key in b) {\n if (b.hasOwnProperty(key)) {\n // @ts-expect-error a or b in unknown\n if (Array.isArray(a[key]) && Array.isArray(b[key])) {\n // @ts-expect-error a or b in unknown\n obj[key] = Array.from(new Set([...a[key], ...b[key]]))\n } else {\n // @ts-expect-error a or b in unknown\n obj[key] = mergeObjects(obj[key], b[key])\n }\n }\n }\n\n return obj\n}\n", "import { parseOptions } from './types.ts'\n\nexport const defaultOptions: parseOptions = {\n fetchWidget: async () => null,\n fetchTemplate: async () => null,\n prod: false,\n assetsOrigin: '/',\n}\n", "import { ObjectLiteral, InputDefinition } from '../types.ts'\n\nexport function inputDefinitionsToObject(inputDefinitions: InputDefinition[]) {\n return inputDefinitions.reduce(\n (acc, { name = '', value, type, definitions = [] }) => {\n switch (type) {\n case 'group':\n acc[name] = inputDefinitionsToObject(definitions)\n break\n case 'options':\n acc[name] = {\n value,\n options: definitions.map((item) => {\n return Object.values(\n inputDefinitionsToObject([item])\n )[0]\n }),\n }\n break\n case 'list':\n acc[name] = definitions.map((item) => {\n return Object.values(\n inputDefinitionsToObject([item])\n )[0]\n })\n break\n default:\n acc[name] = value\n }\n\n return acc\n },\n {} as ObjectLiteral\n )\n}\n", "import { ObjectLiteral } from '../types.ts'\n\nexport const deepValue = (obj: ObjectLiteral | unknown[], key: string) => {\n const keyParts = String(key ?? '')\n .split('.')\n .filter(Boolean)\n\n return keyParts.reduce((acc, k) => {\n try {\n // @ts-expect-error No index signature with a parameter of type string\n return acc && typeof acc === 'object' ? acc[k] : undefined\n } catch (e) {\n return null\n }\n }, obj) as unknown\n}\n", "import { deepValue } from './deep-value.ts'\n\nexport const replaceStringValue = (\n value: string,\n data: Record<string, unknown>\n) => {\n let match = null\n\n while ((match = /{{([a-z0-9.$_]+)}}/gim.exec(value)) !== null) {\n const [full, key] = match\n const dv = deepValue(data, key)\n\n value = value.replace(full, String(dv))\n }\n\n return value\n}\n", "import { replaceStringValue } from './replace-string-value.ts'\n\nexport const attributeToString = (\n attributes: Record<string, unknown>,\n data = {}\n) => {\n return Object.entries(attributes)\n .map(([name, value]) => {\n if (typeof value === 'string') {\n value = replaceStringValue(value, data)\n }\n\n return `${name}=\"${value}\"`\n })\n .join(' ')\n}\n", "import {\n parseOptions,\n TemplateContentNode,\n Widget,\n Style,\n TemplateContent,\n} from './types.js'\nimport { defaultOptions } from './default-parse-options.ts'\nimport { inputDefinitionsToObject } from './utils/input-definitions-to-object.ts'\nimport { parseStyle } from './parse-style.ts'\nimport { attributeToString } from './utils/attributes-to-string.ts'\nimport { replaceStringValue } from './utils/replace-string-value.ts'\n\nconst widgetCache: Map<string, Widget> = new Map()\n\nexport async function parseWidget(\n node: TemplateContentNode,\n data = {},\n widgetStyles: Map<string, Style>,\n opt: parseOptions = defaultOptions\n) {\n let { name, children, ...attributes } = node\n\n node['data-render-id'] =\n node['data-render-id'] || Math.random().toString(36).substring(2, 15)\n ;({ name, children, ...attributes } = node)\n\n if (attributes.id) {\n const widget =\n widgetCache.get(attributes.id) ||\n (await opt.fetchWidget?.(attributes.id))\n\n if (widget) {\n const props = {\n ...inputDefinitionsToObject(widget?.inputs ?? []),\n ...attributes,\n env: {\n ...data,\n assetsOrigin: opt.assetsOrigin,\n prod: opt.prod,\n },\n }\n\n if (typeof widget.render === 'function') {\n children = [widget.render(props)]\n } else {\n children = widget.content ? [widget.content] : []\n }\n\n if (widget.style) {\n const styleContent =\n typeof widget.style === 'function'\n ? widget.style(props)\n : widget.style\n widgetStyles.set(\n widget.id || attributes.id,\n parseStyle(styleContent, widget.cssSelector ?? '')\n )\n }\n\n widgetCache.set(attributes.id, widget)\n }\n }\n\n if (opt.prod) {\n return children.join('')\n }\n\n return (\n `<${name} id=\"${attributes.id}\" data-render-id=\"${attributes['data-render-id']}\"` +\n `>${await parseTemplateContent(children, data, widgetStyles, opt)}</${name}>`\n )\n}\n\nexport async function parseTemplateContent(\n content: TemplateContent,\n data = {},\n widgetStyles: Map<string, Style>,\n opt: parseOptions = defaultOptions\n): Promise<string> {\n if (!content) {\n return ''\n }\n\n return (\n await Promise.all(\n content.map(async (node) => {\n if (typeof node === 'string') {\n return replaceStringValue(node, data)\n }\n\n const { name, children, ...attributes } = node\n\n if (name === 'widget') {\n return parseWidget(\n node as TemplateContentNode,\n data,\n widgetStyles,\n opt\n )\n }\n\n const attrs = attributeToString(attributes, data)\n\n return (\n `<${name}` +\n (attrs ? ` ${attrs}` : '') +\n `>${await parseTemplateContent(children, data, widgetStyles, opt)}</${name}>`\n )\n })\n )\n ).join('')\n}\n", "import { parseOptions, Template, TemplateContent } from './types.ts'\nimport { mergeObjects } from './utils/merge-objects.ts'\nimport { defaultOptions } from './default-parse-options.ts'\nimport { parseTemplateContent } from './parse-widget.ts'\nimport { parseStyle } from './parse-style.ts'\n\nconst tempCache: Map<string, Template> = new Map()\n\nexport const parseTemplate = async (\n temp: Template,\n opt: parseOptions = defaultOptions\n) => {\n opt = mergeObjects(defaultOptions, opt) as parseOptions\n tempCache.set(temp.id, temp)\n\n if (temp.extends) {\n const base =\n tempCache.get(temp.extends) ||\n (await opt.fetchTemplate?.(temp.extends))\n\n if (!base) {\n throw new Error(`Template \"${temp.extends}\" not found`)\n }\n\n tempCache.set(temp.extends, base)\n temp = mergeObjects(base, temp) as Template\n }\n\n const {\n metadata = {},\n scripts = [],\n stylesheets = [],\n links = [],\n fonts = [],\n favicons = [],\n content = '',\n manifest,\n ...data\n } = temp ?? {}\n\n const widgetStyles = new Map()\n\n const bodyContent =\n typeof content === 'string'\n ? content\n : await parseTemplateContent(\n content as TemplateContent,\n data,\n widgetStyles,\n opt\n )\n\n if (!metadata['charset']) {\n metadata['charset'] = 'UTF-8'\n }\n\n if (!metadata['viewport']) {\n metadata['viewport'] = 'width=device-width, initial-scale=1.0'\n }\n\n const metas = Object.entries(metadata)\n .map(([key, value]) => {\n if (key.startsWith('property:')) {\n return `<meta property=\"${key.replace('property:', '')}\" content=\"${value}\">`\n }\n\n if (key === 'msapplication-TileImage') {\n value = `${opt.assetsOrigin}${value}`\n }\n\n return `<meta name=\"${key}\" content=\"${value}\">`\n })\n .join('')\n\n let ls = ''\n\n links.forEach((link) => {\n let l = '<link '\n\n Object.entries(link).forEach(([key, value]) => {\n l += `${key}=\"${value}\" `\n })\n\n ls += l + '/>'\n })\n\n let fi = ''\n\n favicons.forEach((link) => {\n let l = '<link '\n\n Object.entries(link).forEach(([key, value]) => {\n l += `${key}=\"${key === 'href' ? `${opt.assetsOrigin}assets/favicons/` : ''}${value}\" `\n })\n\n fi += l + '/>'\n })\n\n let ft = ''\n\n fonts.forEach((font) => {\n ft += `<link rel=\"preload\" href=\"${opt.assetsOrigin}assets/fonts/${font}\" as=\"font\" crossorigin>`\n })\n\n let st = ''\n\n ;[...stylesheets, ...Array.from(widgetStyles.entries())].forEach(\n (stylesheet) => {\n if (typeof stylesheet === 'string') {\n if (stylesheet.startsWith('http')) {\n st += `<link rel=\"stylesheet\" href=\"${stylesheet}\" >`\n } else if (stylesheet.endsWith('.css')) {\n st += `<link rel=\"stylesheet\" href=\"${opt.assetsOrigin}stylesheets/${stylesheet}\">`\n } else {\n st += `<style>${stylesheet}</style>`\n }\n } else if (Array.isArray(stylesheet)) {\n const [id, style] = stylesheet\n st += `<style id=\"${id}\">${parseStyle(style)}</style>`\n } else {\n st += `<style`\n\n Object.entries(stylesheet.attributes).forEach(\n ([key, value]) => {\n st += `${key}=\"${value}\" `\n }\n )\n\n st += '></style>'\n }\n }\n )\n\n let sc = ''\n\n scripts.forEach((script) => {\n if (typeof script === 'string') {\n if (script.startsWith('http')) {\n sc += `<script src=\"${script}\"></script>`\n } else if (script.endsWith('.js')) {\n sc += `<script src=\"${opt.assetsOrigin}scripts/${script}\"></script>`\n } else {\n sc += `<script>${script}</script>`\n }\n } else {\n sc += '<script '\n\n Object.entries(script).forEach(([key, value]) => {\n sc += `${key}=\"${value}\" `\n })\n\n sc += `></script>`\n }\n })\n\n return `<!doctype html>\n<html lang=\"${data.lang ?? 'en'}\">\n<head>\n <title>${data.title}</title>\n <meta charset=\"UTF-8\">\n <meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0\">\n <!-- og -->\n <meta property=\"og:title\" content=\"${data.title}\">\n <meta property=\"og:type\" content=\"website\">\n <meta property=\"og:description\" content=\"${data.description}\">\n <meta property=\"og:image\" content=\"${data.image}\">\n <meta property=\"og:url\" content=\"${data.domain}\">\n <meta property=\"og:site_name\" content=\"${data.title}\">\n ${metas ? `<!-- metas -->${metas}` : ''}\n ${fi ? `<!-- favicons -->${fi}` : ''}\n ${ft ? `<!-- fonts -->${ft}` : ''}\n ${ls ? `<!-- links -->${ls}` : ''}\n ${manifest ? `<link rel=\"manifest\" href=\"${opt.assetsOrigin}assets/${manifest}\">` : ''}\n ${st ? `<!-- stylesheets -->${st}` : ''}\n</head>\n<body>\n${bodyContent}\n${sc ? '<!-- scripts -->' + sc : ''}\n</body>\n</html>`\n .replace(/\\s{2,}/g, ' ')\n .replace(/[\\t\\n]+/g, '')\n}\n", "import {\n InputDefinition,\n ObjectLiteral,\n InputDefinitionType,\n} from '../types.ts'\n\nconst dataTypeToInputType = (data: unknown) => {\n switch (typeof data) {\n case 'number':\n return InputDefinitionType.Number\n case 'boolean':\n return InputDefinitionType.Boolean\n case 'object':\n if (Array.isArray(data)) {\n return InputDefinitionType.List\n } else {\n return InputDefinitionType.Group\n }\n default:\n return InputDefinitionType.Text\n }\n}\n\nexport function mergeDataIntoInputDefinition(\n data: unknown,\n def: InputDefinition\n): InputDefinition {\n switch (def.type) {\n case 'group':\n return {\n ...def,\n definitions: Object.entries((data ?? {}) as ObjectLiteral).map(\n ([k, v]) => {\n return mergeDataIntoInputDefinition(\n v,\n ((def.definitions ?? []) as InputDefinition[]).find(\n (item) => item.name === k\n ) ?? {\n name: k,\n type: dataTypeToInputType(v),\n value: v,\n }\n )\n }\n ),\n }\n case 'list':\n return {\n ...def,\n definitions: ((data ?? []) as Array<unknown>).map(\n (item, idx) => {\n return mergeDataIntoInputDefinition(\n item,\n ((def.definitions ?? [])[idx] ?? {\n name: String(idx),\n type: dataTypeToInputType(item),\n value: item,\n }) as InputDefinition\n )\n }\n ),\n }\n default:\n return {\n ...def,\n value: data,\n }\n }\n}\n", "import { parseStyle } from './parse-style.ts'\nimport { parseTemplate } from './parse-template.ts'\nimport { parseTemplateContent, parseWidget } from './parse-widget.ts'\nimport { attributeToString } from './utils/attributes-to-string.ts'\nimport { inputDefinitionsToObject } from './utils/input-definitions-to-object.ts'\nimport { mergeDataIntoInputDefinition } from './utils/merge-data-into-input-definition.ts'\n\n// eslint-disable-next-line @typescript-eslint/ban-ts-comment\n// @ts-ignore\nif (window) {\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n window.BFS = {\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n ...(window.BFS || {}),\n SITE_BUILDER: {\n inputDefinitionsToObject,\n mergeDataIntoInputDefinition,\n attributeToString,\n parseTemplate,\n parseTemplateContent,\n parseWidget,\n parseStyle,\n },\n }\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["turnCamelToKebabCasing", "str", "__name", "parseStyle", "style", "prefix", "rules", "nested", "key", "value", "selector", "kebabKey", "turnCamelToKebabCasing", "nestedResult", "result", "__name", "mergeObjects", "a", "b", "obj", "key", "__name", "defaultOptions", "inputDefinitionsToObject", "inputDefinitions", "acc", "name", "value", "type", "definitions", "item", "__name", "deepValue", "__name", "obj", "key", "acc", "k", "replaceStringValue", "__name", "value", "data", "match", "full", "key", "dv", "deepValue", "attributeToString", "__name", "attributes", "data", "name", "value", "replaceStringValue", "widgetCache", "parseWidget", "node", "data", "widgetStyles", "opt", "defaultOptions", "name", "children", "attributes", "widget", "props", "inputDefinitionsToObject", "styleContent", "parseStyle", "parseTemplateContent", "__name", "content", "replaceStringValue", "attrs", "attributeToString", "tempCache", "parseTemplate", "__name", "temp", "opt", "defaultOptions", "mergeObjects", "base", "metadata", "scripts", "stylesheets", "links", "fonts", "favicons", "content", "manifest", "data", "widgetStyles", "bodyContent", "parseTemplateContent", "metas", "key", "value", "ls", "link", "l", "fi", "ft", "font", "st", "stylesheet", "id", "style", "parseStyle", "sc", "script", "dataTypeToInputType", "__name", "data", "mergeDataIntoInputDefinition", "def", "k", "v", "item", "idx", "inputDefinitionsToObject", "mergeDataIntoInputDefinition", "attributeToString", "parseTemplate", "parseTemplateContent", "parseWidget", "parseStyle"]
|
|
7
7
|
}
|
package/dist/esm/parse-style.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
var
|
|
1
|
+
var m=Object.defineProperty;var g=(e,t)=>m(e,"name",{value:t,configurable:!0});import{turnCamelToKebabCasing as a}from"./utils/turn-camel-to-kebab-casing.js";function f(e,t=""){if(typeof e=="string")return e;const i=[],l=[];for(const[s,o]of Object.entries(e))if(typeof o=="object"&&o!==null){let r;const u=a(s);s.startsWith("&")?r=s.replace(/&/g,t.trim()):t&&u===t.trim()?r=t:r=t?`${t} ${u}`:u;const c=f(o,r);c&&l.push(c)}else i.push(`${a(s)}: ${o};`);let n="";return i.length&&t&&(n+=`${t} { ${i.join(" ")} }`),l.length&&(n+=(n?" ":"")+l.join(" ")),n.trim()}g(f,"parseStyle");export{f as parseStyle};
|
package/dist/esm/parse-widget.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
var u=Object.defineProperty;var d=(r,i)=>u(r,"name",{value:i,configurable:!0});import{defaultOptions as f}from"./default-parse-options.js";import{inputDefinitionsToObject as g}from"./utils/input-definitions-to-object.js";import{parseStyle as y}from"./parse-style.js";import{attributeToString as $}from"./utils/attributes-to-string.js";import{replaceStringValue as C}from"./utils/replace-string-value.js";const m=new Map;async function T(r,i={},
|
|
1
|
+
var u=Object.defineProperty;var d=(r,i)=>u(r,"name",{value:i,configurable:!0});import{defaultOptions as f}from"./default-parse-options.js";import{inputDefinitionsToObject as g}from"./utils/input-definitions-to-object.js";import{parseStyle as y}from"./parse-style.js";import{attributeToString as $}from"./utils/attributes-to-string.js";import{replaceStringValue as C}from"./utils/replace-string-value.js";const m=new Map;async function T(r,i={},a,s=f){let{name:o,children:n,...e}=r;if(r["data-render-id"]=r["data-render-id"]||Math.random().toString(36).substring(2,15),{name:o,children:n,...e}=r,e.id){const t=m.get(e.id)||await s.fetchWidget?.(e.id);if(t){const p={...g(t?.inputs??[]),...e,env:{...i,assetsOrigin:s.assetsOrigin,prod:s.prod}};if(typeof t.render=="function"?n=[t.render(p)]:n=t.content?[t.content]:[],t.style){const c=typeof t.style=="function"?t.style(p):t.style;a.set(t.id||e.id,y(c,t.cssSelector??""))}m.set(e.id,t)}}return s.prod?n.join(""):`<${o} id="${e.id}" data-render-id="${e["data-render-id"]}">${await l(n,i,a,s)}</${o}>`}d(T,"parseWidget");async function l(r,i={},a,s=f){return r?(await Promise.all(r.map(async o=>{if(typeof o=="string")return C(o,i);const{name:n,children:e,...t}=o;if(n==="widget")return T(o,i,a,s);const p=$(t,i);return`<${n}`+(p?` ${p}`:"")+`>${await l(e,i,a,s)}</${n}>`}))).join(""):""}d(l,"parseTemplateContent");export{l as parseTemplateContent,T as parseWidget};
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
import { Style } from './types.ts';
|
|
2
|
-
export declare function parseStyle(style: Style): string;
|
|
2
|
+
export declare function parseStyle(style: Style, prefix?: string): string;
|
package/dist/types/types.d.ts
CHANGED