@estjs/template 0.0.14 → 0.0.15-beta.5
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/README.md +14 -0
- package/dist/template.cjs.js +4 -3
- package/dist/template.cjs.js.map +1 -1
- package/dist/template.d.cts +459 -2364
- package/dist/template.d.ts +459 -2364
- package/dist/template.dev.cjs.js +1809 -774
- package/dist/template.dev.esm.js +1778 -772
- package/dist/template.esm.js +4 -3
- package/dist/template.esm.js.map +1 -1
- package/package.json +5 -5
- package/types/component.d.ts +0 -21
- package/types/index.d.ts +0 -3
- package/types/jsx.d.ts +0 -2182
- package/types/node.d.ts +0 -15
package/dist/template.esm.js
CHANGED
|
@@ -1,7 +1,8 @@
|
|
|
1
|
-
import {isString,
|
|
2
|
-
* @estjs/template v0.0.
|
|
1
|
+
import {isObject,startsWith,isHTMLElement,isString,error,isArray,camelCase,capitalize,isSpecialBooleanAttr,isBooleanAttr,includeBooleanAttr,isSymbol,isUndefined,isPromise,isFunction,coerceArray,isFalsy,isNumber,isPrimitive,isNil,kebabCase}from'@estjs/shared';export{escapeHTML}from'@estjs/shared';import {effect,shallowReactive,isSignal,signal,isComputed}from'@estjs/signals';/**
|
|
2
|
+
* @estjs/template v0.0.15-beta.5
|
|
3
3
|
* (c) 2023-Present jiangxd <jiangxd2016@gmail.com>
|
|
4
4
|
* @license MIT
|
|
5
5
|
**/
|
|
6
|
-
var w="on",A="update",g="children",H="",B="0",q="1";var _="ref",O=" __PLACEHOLDER__ ";var D=class{constructor(){this.renderMode=0;}get isSSG(){return this.renderMode===1}get isSSR(){return this.renderMode===2}get isClient(){return this.renderMode===0}setSSR(){this.renderMode=2;}setSSG(){this.renderMode=1;}setClient(){this.renderMode=0;}},u=new D,z=new Map;function W(n,t){z.set(n,{index:t});}function Q(n){var t;return (t=z.get(n))==null?void 0:t.index}var y=class y{constructor(){this.hooks={mounted:new Set,destroy:new Set};}addEventListener(){}removeEventListener(){}addHook(t,e){var o;(o=this.hooks[t])==null||o.add(e);}getContext(t){return y.context[t]}setContext(t,e){y.context[t]=e;}initRef(){y.ref=this;}removeRef(){y.ref=null;}clearHooks(){Object.values(this.hooks).forEach(t=>t.clear());}};y.ref=null,y.context={};var l=y;function $(n){return n instanceof M}var b=1,M=class extends l{constructor(e,o={},r){super();this.template=e;this.props=o;this.key=r;W(e,b),this.templates=this.processTemplate();}processTemplate(){if(isArray(this.template)){let e=this.template.join(O);return this.processHtmlString(e).split(O)}return []}processHtmlString(e){return e.replaceAll(/(<[^>]+>)|([^<]+)/g,(o,r,i)=>r?r.includes("data-ci")?o:r.replace(/<\s*([\da-z]+)(\s[^>]*)?>/i,(s,c,a)=>`<${c} data-ci="${b}"${a||""}>`):i&&i.replace(O,"").trim()?`<!--0-${b}-->${i}<!$>`:o)}mount(){this.initRef();let e=this.render();return this.removeRef(),e}render(){if(isFunction(this.template)){let e=this.template(this.props);return $(e)?e.mount():String(e)}return this.renderTemplate()}renderTemplate(){return Object.entries(this.props).forEach(([e,o])=>{let r=o.children;this.normalizeProps(o);let i=this.templates.findIndex(s=>s.includes(`data-hk="${e}"`));r&&this.renderChildren(r,i),this.templates[i]=this.templates[i].replace(`data-hk="${e}"`,`data-hk="${e}" ${this.generateAttributes(o)}`);}),this.templates.join("")}normalizeProps(e){Object.entries(e).forEach(([o,r])=>{o===g||isFunction(r)?delete e[o]:isSignal(r)&&(e[o]=r.value);});}generateAttributes(e){return Object.entries(e).filter(([o,r])=>o!==g&&!isFunction(r)).map(([o,r])=>`${o}="${escape(String(r))}"`).join(" ")}renderChildren(e,o){e.forEach(([r])=>{b++;let i=this.renderChild(r);this.templates[o]+=i;});}renderChild(e){if(isSignal(e))return `<!--1-${b}-->${e.value}<!$>`;if(isFunction(e))return this.renderChild(e(this.props));if($(e)){let o=e.mount();return isFunction(o)?o(this.props):I(o)}else return `<!--1-${b}-->${e}<!$>`}};var Ee="area,base,br,col,embed,hr,img,input,link,meta,param,source,track,wbr".split(",");function F(n){if(h(n)||n instanceof Node||$(n))return n;let t=isFalsy(n)?"":String(n);return document.createTextNode(t)}function T(n,t,e=null){let o=h(e)?e.firstChild:e,r=u.isSSR;h(t)?t.mount(n,o):o&&!r?o.before(t):r||n.append(t);}function k(n){h(n)?n.unmount():n.parentNode&&n.remove();}function J(n,t,e){T(n,t,e),k(e);}function te(n,t,e){t==="class"?ge(n,e):t==="style"?Te(n,e):ye(n,t,e);}function ge(n,t){typeof t=="string"?n.className=t:isArray(t)?n.className=t.join(" "):t&&typeof t=="object"&&(n.className=Object.entries(t).reduce((e,[o,r])=>e+(r?` ${o}`:""),"").trim());}function Te(n,t){typeof t=="string"?n.style.cssText=t:t&&typeof t=="object"&&Object.entries(t).forEach(([o,r])=>{n.style.setProperty(kebabCase(o),String(r));});}function ye(n,t,e){isFalsy(e)?n.removeAttribute(t):e===!0?n.setAttribute(t,""):n instanceof HTMLInputElement&&t==="value"?n.value=String(e):n.setAttribute(t,String(e));}function oe(n,t){if(n instanceof HTMLInputElement)switch(n.type){case"checkbox":return m(n,"change",()=>{t(!!n.checked);});case"date":return m(n,"change",()=>{t(n.value?n.value:"");});case"file":return m(n,"change",()=>{n.files&&t(n.files);});case"number":return m(n,"input",()=>{let e=Number.parseFloat(n.value);t(Number.isNaN(e)?"":String(e));});case"radio":return m(n,"change",()=>{t(n.checked?n.value:"");});case"text":return m(n,"input",()=>{t(n.value);})}if(n instanceof HTMLSelectElement)return m(n,"change",()=>{t(n.value);});if(n instanceof HTMLTextAreaElement)return m(n,"input",()=>{t(n.value);})}function m(n,t,e){return n.addEventListener(t,e),()=>n.removeEventListener(t,e)}function ne(n){return Ee.includes(n)?`<${n}/>`:`<${n}></${n}>`}function I(n){return isSignal(n)?n.value:n}var S=class extends l{constructor(e,o,r){super();this.template=e;this.props=o;this.key=r;this.emitter=new Set;this.rootNode=null;this.trackMap=new Map;this.nodes=[];this.parent=null;this.before=null;this.key||(this.key=o&&o.key),this.proxyProps||(this.proxyProps=shallowReactive(o||{}));}get firstChild(){var e,o;return (o=(e=this.rootNode)==null?void 0:e.firstChild)!=null?o:null}get isConnected(){var e,o;return (o=(e=this.rootNode)==null?void 0:e.isConnected)!=null?o:!1}mount(e,o){var r,i,s,c;if(this.parent=e,!isFunction(this.template))throw new Error("Template must be a function");return this.isConnected?(i=(r=this.rootNode)==null?void 0:r.mount(e,o))!=null?i:[]:(this.initRef(),this.rootNode=this.template(useReactive(this.proxyProps,[g])),this.nodes=(c=(s=this.rootNode)==null?void 0:s.mount(e,o))!=null?c:[],this.callMountHooks(),this.patchProps(this.props),this.removeRef(),this.nodes)}unmount(){var e;this.callLifecycleHooks("destroy"),this.cleanup(),(e=this.rootNode)==null||e.unmount(),this.resetState(),this.key&&L.delete(this.key);}resetState(){this.rootNode=null,this.proxyProps={},this.nodes=[],this.parent=null;}callLifecycleHooks(e){this.hooks[e].forEach(o=>o());}callMountHooks(){this.hooks.mounted.forEach(e=>e());}callDestroyHooks(){this.hooks.destroy.forEach(e=>e());}clearEmitter(){for(let e of this.emitter)e();this.emitter.clear();}inheritNode(e){if(Object.assign(this.proxyProps,e.proxyProps),this.rootNode=e.rootNode,this.trackMap=e.trackMap,this.hooks=e.hooks,hasChanged(e.props,this.props)){let o=this.props;this.props=e.props,this.patchProps(o);}}getNodeTrack(e){let o=this.trackMap.get(e);return o||(o={cleanup:()=>{}},this.trackMap.set(e,o)),o.cleanup(),o}patchProps(e){var o;if(e){for(let[r,i]of Object.entries(e))startsWith(r,w)&&((o=this.rootNode)!=null&&o.firstChild)?this.patchEventListener(r,i):r===_?this.patchRef(i):startsWith(r,A)?this.patchUpdateHandler(r,i):r!==g&&this.patchNormalProp(r,i);this.props=e;}}patchEventListener(e,o){let r=e.slice(2).toLowerCase(),i=m(this.rootNode.nodes[0],r,o);this.emitter.add(i);}patchRef(e){var o,r;e.value=(r=(o=this.rootNode)==null?void 0:o.firstChild)!=null?r:null;}patchUpdateHandler(e,o){this.proxyProps[e]=I(o);}patchNormalProp(e,o){let r=this.getNodeTrack(e);r.cleanup=useEffect(()=>{this.proxyProps[e]=isFunction(o)?o():o;});}cleanup(){this.trackMap.forEach(e=>{var o;return (o=e.cleanup)==null?void 0:o.call(e)}),this.trackMap.clear(),this.emitter.forEach(e=>e()),this.emitter.clear();}};function se(n,t,e,o){let r=new Map,i=Array.from(t.values());if(i.length&&e.length===0)return be(n,i,o),r;let s=[],c=ke(e),a=0;for(let[d,p]of e.entries()){let f=i[a],C=x(f,d);for(;f&&!c.has(C);)k(f),t.delete(C),f=i[++a],C=x(f,d);let Y=x(p,d),G=t.get(Y);if(G&&(p=Me(n,G,p)),f)if(f===G)a++;else {let U=document.createComment("");T(n,U,f),s.push([U,p]);}else T(n,p,o);r.set(Y,p);}return s.forEach(([d,p])=>{J(n,p,d);}),t.forEach((d,p)=>{d.isConnected&&!r.has(p)&&k(d);}),r}function be(n,t,e){if(n.childNodes.length===t.length+(e?1:0))n.innerHTML="",e&&T(n,e);else {let o=document.createRange(),r=t[0],i=h(r)?r.firstChild:r;o.setStartBefore(i),e?o.setEndBefore(e):o.setEndAfter(n),o.deleteContents();}t.forEach(o=>{h(o)&&o.unmount();});}function Me(n,t,e){return t===e?t:h(t)&&h(e)&&t.template===e.template?(e.inheritNode(t),e):t instanceof Text&&e instanceof Text?(t.textContent!==e.textContent&&(t.textContent=e.textContent),t):(J(n,e,t),e)}function ke(n){let t=new Map;for(let[e,o]of n.entries()){let r=x(o,e);t.set(r,o);}return t}function x(n,t){if(h(n)){let e=n.key;if(e!=null)return String(e)}return `_$${t}$`}var v=class{constructor(t,e,o){this.template=t;this.props=e;this.key=o;this.treeMap=new Map;this.mounted=!1;this.nodes=[];this.trackMap=new Map;this.bindValueKeys=[];this.parent=null;u.isSSR&&(this.componentIndex=Q(this.template));}get firstChild(){var t;return (t=this.nodes[0])!=null?t:null}get isConnected(){return this.mounted}addEventListener(){}removeEventListener(){}mount(t,e){var i;if(this.parent=t,this.isConnected)return this.nodes.forEach(s=>T(t,s,e)),this.nodes;isArray(this.template)&&(this.template=R(this.template.join("")));let o=this.template.content.cloneNode(!0),r=o.firstChild;return (i=r==null?void 0:r.hasAttribute)!=null&&i.call(r,"_svg_")&&(r.remove(),r.childNodes.forEach(s=>{o.append(s);})),this.nodes=Array.from(o.childNodes),u.isSSR?this.mapSSGNodeTree(t):this.mapNodeTree(t,o),T(t,o,e),this.patchProps(this.props),this.mounted=!0,this.nodes}unmount(){this.trackMap.forEach(t=>{t.cleanup&&t.cleanup();}),this.trackMap.clear(),this.treeMap.clear(),this.nodes.forEach(t=>k(t)),this.nodes=[],this.mounted=!1,this.key&&L.delete(this.key);}inheritNode(t){this.mounted=t.mounted,this.nodes=t.nodes,this.trackMap=t.trackMap,this.treeMap=t.treeMap;let e=this.props;this.props=t.props,this.patchProps(e);}mapSSGNodeTree(t){this.treeMap.set(0,t),this.walkNodeTree(t,this.handleSSGNode.bind(this));}mapNodeTree(t,e){let o=1;this.treeMap.set(0,t);let r=[t],i=s=>{s.nodeType!==Node.DOCUMENT_FRAGMENT_NODE&&(this.treeMap.set(o++,s),r.push(s));};this.walkNodeTree(e,i);}walkNodeTree(t,e){t.nodeType!==Node.DOCUMENT_FRAGMENT_NODE&&e(t);let o=t.firstChild;for(;o;)this.walkNodeTree(o,e),o=o.nextSibling;}handleSSGNode(t){var e;if(t.nodeType===Node.COMMENT_NODE){let[o,r]=((e=t.textContent)==null?void 0:e.split("-"))||[];if(0===+o&&+r===this.componentIndex){let i=t.nextSibling;this.treeMap.set(+r,i);}}else if(t.nodeType!==Node.TEXT_NODE){let{ci:o="-1",hk:r}=(t==null?void 0:t.dataset)||{};r&&+o===this.componentIndex&&this.treeMap.set(+r,t);}}patchProps(t){t&&(Object.entries(t).forEach(([e,o])=>{let r=Number(e),i=this.treeMap.get(r);i&&this.patchProp(e,i,o,r===0);}),this.props=t);}patchProp(t,e,o,r){o&&Object.entries(o).forEach(([i,s])=>{if(i===g&&s)this.patchChildren(t,e,s,r);else if(i===_)o[i].value=e;else if(startsWith(i,w))this.patchEventListener(t,e,i,s);else {if(this.bindValueKeys.includes(i))return;let c=this.getBindUpdateValue(o,t,i);this.patchAttribute(t,e,i,s,c);}});}getBindUpdateValue(t,e,o){let r=`${A}${capitalize(o)}`;if(r&&t[r]&&isFunction(t[r]))return this.bindValueKeys.push(r),t[r]}patchChildren(t,e,o,r){if(isArray(o))o.filter(Boolean).forEach((i,s)=>{var C;let[c,a]=isArray(i)?i:[i,null],d=isNil(a)?null:(C=this.treeMap.get(a))!=null?C:null,p=`${t}:${g}:${s}`,f=this.getNodeTrack(p,!0,r);this.patchChild(f,e,c,d);});else {let i=`${t}:${g}:0`,s=this.getNodeTrack(i,!0,r);this.patchChild(s,e,o,null);}}patchEventListener(t,e,o,r){let i=o.slice(2).toLowerCase(),s=this.getNodeTrack(`${t}:${o}`);s.cleanup=m(e,i,r);}patchAttribute(t,e,o,r,i){let s=this.getNodeTrack(`${t}:${o}`),c=shallowSignal(),a=useEffect(()=>{c.value=isSignal(r)||isComputed(r)?r.value:r,te(e,o,c.value);}),d;i&&isHTMLElement(e)&&(d=oe(e,p=>{i(p);})),s.cleanup=()=>{a&&a(),d&&d();};}getNodeTrack(t,e,o){let r=this.trackMap.get(t);return r||(r={cleanup:()=>{}},e&&(r.lastNodes=new Map),o&&(r.isRoot=!0),this.trackMap.set(t,r)),r.cleanup&&r.cleanup(),r}patchChild(t,e,o,r){isFunction(o)?t.cleanup=useEffect(()=>{let i=coerceArray(o()).map(F);u.isSSR?t.lastNodes=this.reconcileChildren(e,i,r):t.lastNodes=se(e,t.lastNodes,i,r);}):coerceArray(o).forEach((i,s)=>{let c=F(i),a=x(c,s);u.isSSR?t.lastNodes=this.reconcileChildren(e,[c],r):(t.lastNodes.set(a,c),T(e,c,r));});}reconcileChildren(t,e,o){let r=new Map,i=Array.from(t.childNodes).filter(s=>{var c,a;return s.nodeType===Node.TEXT_NODE&&((c=s.previousSibling)==null?void 0:c.nodeType)===Node.COMMENT_NODE&&((a=s.nextSibling)==null?void 0:a.nodeType)===Node.COMMENT_NODE});return e.forEach((s,c)=>{let a=x(s,c);s.nodeType===Node.TEXT_NODE?i.forEach(d=>{s.textContent===d.textContent&&t.replaceChild(s,d);}):T(t,s,o),r.set(a,s);}),r}};var L=new Map;function j(n,t,e={},o){if(o){let i=L.get(o);if(i)return i}typeof t=="string"&&(t=R(t));let r=new n(t,e,o);return o&&r instanceof S&&L.set(o,r),r}function K(n,t={},e){if(n===H)return le(n,t);if(isString(n)){let o=ne(n),r={[q]:t};return j(v,o,r,e)}return isFunction(n)?j(S,n,t,e):j(v,n,t,e)}function Ie(n){return n instanceof S}function h(n){return n instanceof S||n instanceof v}function R(n){let t=document.createElement("template");return t.innerHTML=n,t}function le(n,t){let e=t.children?{[B]:{children:Array.isArray(t.children)?t.children.filter(Boolean):[t.children]}}:t,o=n===H?R(H):n;return j(v,o,e)}function je(n){l.ref&&l.ref.addHook("mounted",n);}function Ke(n){l.ref&&l.ref.addHook("destroy",n);}function Xe(n,t){l.ref&&l.ref.setContext(n,t);}function Ge(n,t){var e;return (e=l.ref&&l.ref.getContext(n))!=null?e:t}function De(n,t){u.setSSG();let o=new M(n,t||{}).mount();return u.setClient(),o}function Fe(n,t){let e=typeof t=="string"?document.querySelector(t):t;if(!e)throw new Error(`Could not find container: ${t}`);u.setSSR(),K(n).mount(e),u.setClient();}function Je(n,t){return u.isSSG?new M(n,t):K(n,t)}export{le as Fragment,K as h,Fe as hydrate,Ge as inject,Ie as isComponent,h as isJsxElement,Ke as onDestroy,je as onMount,Xe as provide,De as renderToString,Je as ssg,R as template};//# sourceMappingURL=template.esm.js.map
|
|
6
|
+
var ft=Object.defineProperty;var xe=Object.getOwnPropertySymbols;var at=Object.prototype.hasOwnProperty,ut=Object.prototype.propertyIsEnumerable;var Ee=(e,t,n)=>t in e?ft(e,t,{enumerable:true,configurable:true,writable:true,value:n}):e[t]=n,z=(e,t)=>{for(var n in t||(t={}))at.call(t,n)&&Ee(e,n,t[n]);if(xe)for(var n of xe(t))ut.call(t,n)&&Ee(e,n,t[n]);return e};var $=(e,t,n)=>new Promise((r,o)=>{var s=c=>{try{f(n.next(c));}catch(a){o(a);}},i=c=>{try{f(n.throw(c));}catch(a){o(a);}},f=c=>c.done?r(c.value):Promise.resolve(c.value).then(s,i);f((n=n.apply(e,t)).next());});var R=null,lt=0,B=[];function x(){return R}function dt(e){R=e;}function Ae(e=R){let t={id:++lt,parent:e,children:null,provides:null,cleanup:null,onMount:null,onUpdate:null,onDestroy:null,isMounted:false,isDestroyed:false};return e&&(e.children||(e.children=new Set),e.children.add(t)),t}function k(e,t){let n=R;n&&B.push(n),R=e;try{return t()}finally{R=B.length>0?B.pop():n;}}function J(e){var t,n,r,o,s;if(!(!e||e.isDestroyed)){if(e.children){let i=Array.from(e.children);for(let f of i)J(f);}if(e.onDestroy){for(let i of e.onDestroy)try{i();}catch(f){}e.onDestroy.clear();}if(e.cleanup){for(let i of e.cleanup)try{i();}catch(f){}e.cleanup.clear();}(t=e.parent)!=null&&t.children&&e.parent.children.delete(e),(n=e.children)==null||n.clear(),(r=e.provides)==null||r.clear(),(o=e.onMount)==null||o.clear(),(s=e.onUpdate)==null||s.clear(),dt(e.parent),e.parent=null,e.isDestroyed=true;}}function K(e){let t=R;t&&(t.cleanup||(t.cleanup=new Set),t.cleanup.add(e));}var ve="_$spread$";var be="http://www.w3.org/2000/svg",Q="http://www.w3.org/2000/xlink",Z="http://www.w3.org/2000/xmlns/",ee=/^\d+-\d+$/;var _e=1e3,ke=new WeakMap;function Ce(e){let t=ke.get(e);if(!t){let n=e.name||"anonymous",r=De(e.toString()).toString(36);t=`${n}_${r}`,ke.set(e,t);}return t}function De(e){let t=0,n=e.length<100?e.length:100;for(let r=0;r<n;r++)t=Math.trunc((t<<5)-t+e.charCodeAt(r));return t<0?-t:t}var ht=0;function ne(e){if(!isFalsy(e)){if(isString(e))return e.length<=_e?e:`${e.slice(0,_e-10)}_${De(e).toString(36)}`;if(isNumber(e))return String(e);if(isSymbol(e)){let t=Symbol.keyFor(e);if(t)return `_s.${t}`;let n=e.description;return n?`_s.${n}`:`${ht++}`}return String(e)}}var te=Symbol("essor.key");function F(e,t){if(m(e)||!e||e.nodeType===Node.DOCUMENT_NODE)return;let n=ne(t);isFalsy(n)?delete e[te]:e[te]=n;}function T(e){if(e)return m(e)?e.key:e[te]}function Nt(e,t){let n=new Set(t);return new Proxy(e,{get(r,o){if(!n.has(o))return Reflect.get(r,o)},ownKeys(r){return Reflect.ownKeys(r).filter(o=>!n.has(o))},getOwnPropertyDescriptor(r,o){if(!n.has(o))return Reflect.getOwnPropertyDescriptor(r,o)},has(r,o){return n.has(o)?false:Reflect.has(r,o)}})}function A(e){if(e)try{if(m(e))e.destroy();else {let t=e;t.parentElement&&t.remove();}}catch(t){error("Failed to remove node:",t);}}function S(e,t,n){if(!(!e||!t))try{let r=m(n)?n.firstChild:n;if(m(t)){t.mount(e,r);return}r?e.insertBefore(t,r):e.appendChild(t);}catch(r){error("Failed to insert node:",r);}}function oe(e,t,n){if(!(!e||!t||!n||t===n))try{let r=m(n)?n.beforeNode:n.nextSibling;A(n),S(e,t,r);}catch(r){error("Failed to replace node:",r);}}function C(e){if(e){if(m(e))return e.firstChild;if(!isPrimitive(e))return e}}function D(e,t){let n=T(e),r=T(t);if(n!==r)return false;let o=m(e),s=m(t);if(o&&s)return e.component===t.component;if(o!==s)return false;if(isPrimitive(e)||isPrimitive(t))return e===t;let i=e,f=t;return i.nodeType!==f.nodeType?false:i.nodeType===Node.ELEMENT_NODE?i.tagName===f.tagName:true}function L(e){if(isHTMLElement(e))return e;if(isPrimitive(e)){let t=isFalsy(e)?"":String(e);return document.createTextNode(t)}return e}function Le(e){return e instanceof HTMLInputElement}function Pe(e){return e instanceof HTMLSelectElement}function we(e){return e instanceof HTMLTextAreaElement}function ie(e){return e instanceof Text}function Re(e,t){if(e===t)return true;if(!e||!t||Array.isArray(e)!==Array.isArray(t))return false;for(let n in e)if(e[n]!==t[n])return false;for(let n in t)if(!(n in e))return false;return true}function He(e,t){if(m(e)||m(t))return;let n=T(e);n&&!T(t)&&F(t,n);}function P(e,t,n){if(n===t)return t;let r=isHTMLElement(t);if(isHTMLElement(n)&&r){if(n.isEqualNode(t))return t;if(t.tagName===n.tagName){let f=t.attributes,c=n.attributes;for(let a=f.length-1;a>=0;a--){let l=f[a].name;n.hasAttribute(l)||t.removeAttribute(l);}for(let a=0,l=c.length;a<l;a++){let u=c[a];t.getAttribute(u.name)!==u.value&&t.setAttribute(u.name,u.value);}return He(t,n),t}}if(ie(t)&&ie(n))return t.textContent!==n.textContent&&(t.textContent=n.textContent),He(t,n),t;let s=m(t),i=m(n);return s&&i&&t.component===n.component?n.update(t):(oe(e,n,t),n)}function Ie(e,t,n,r){let o=t.length,s=n.length;if(o===0&&s===0)return [];if(o===0){for(let i=0;i<s;i++)S(e,n[i],r);return n}if(s===0){for(let i=0;i<o;i++)A(t[i]);return []}if(o===1&&s===1){let i=t[0],f=n[0];return D(i,f)?(P(e,i,f),n[0]=i):oe(e,f,i),n}if(o===2&&s===2){let i=t[0],f=t[1],c=n[0],a=n[1];if(D(i,c)&&D(f,a))return P(e,i,c),P(e,f,a),n[0]=i,n[1]=f,n;if(D(i,a)&&D(f,c)){P(e,i,a),P(e,f,c);let l=C(f),u=C(i);return l&&u&&l.parentNode===e&&e.insertBefore(l,u),n[0]=f,n[1]=i,n}}return xt(e,t,n,r)}function xt(e,t,n,r){let o=0,s=0,i=t.length-1,f=n.length-1,c=t[0],a=t[i],l=n[0],u=n[f];for(;o<=i&&s<=f;)if(!c)c=t[++o];else if(!a)a=t[--i];else if(D(c,l))P(e,c,l),n[s]=c,c=t[++o],l=n[++s];else break;for(;o<=i&&s<=f;)if(!c)c=t[++o];else if(!a)a=t[--i];else if(D(a,u))P(e,a,u),n[f]=a,a=t[--i],u=n[--f];else break;if(o>i){if(s<=f){let h=f+1<n.length?C(n[f+1]):r;for(let y=s;y<=f;y++)S(e,n[y],h);}}else if(s>f)for(let h=o;h<=i;h++){let y=t[h];y&&A(y);}else Et(e,t,n,o,i,s,f,r);return n}function Et(e,t,n,r,o,s,i,f){let c=i-s+1,a=n.length,l;for(let g=s;g<=i;g++){let N=T(n[g]);N!==void 0&&(l||(l=Object.create(null)),l[N]=g);}let u=new Int32Array(c),h=false,y=0,b=0;for(let g=r;g<=o;g++){let N=t[g];if(!N)continue;if(b>=c){A(N);continue}let E,w=T(N);if(w!==void 0&&l&&w in l)E=l[w];else for(let _=s;_<=i;_++)if(u[_-s]===0&&w===void 0&&T(n[_])===void 0&&D(N,n[_])){E=_;break}E===void 0?A(N):(u[E-s]=g+1,E>=y?y=E:h=true,P(e,N,n[E]),n[E]=N,b++);}let I=h?At(u):[],q=I.length-1;for(let g=c-1;g>=0;g--){let N=s+g,E=n[N],w=N+1<a?C(n[N+1]):f;if(u[g]===0)S(e,E,w);else if(h)if(q<0||g!==I[q]){let _=C(E);_&&_.parentNode===e&&S(e,_,w);}else q--;}}function At(e){let t=e.length;if(t===0)return [];if(t===1)return e[0]!==0?[0]:[];let n=[],r=new Int32Array(t),o,s,i,f,c;for(o=0;o<t;o++){let a=e[o];if(a!==0){if(s=n[n.length-1],n.length===0||e[s]<a){r[o]=s,n.push(o);continue}for(i=0,f=n.length-1;i<f;)c=i+f>>1,e[n[c]]<a?i=c+1:f=c;a<e[n[i]]&&(i>0&&(r[o]=n[i-1]),n[i]=o);}}for(i=n.length,f=n[i-1];i-- >0;)n[i]=f,f=r[f];return n}function v(e,t,n,r){e.addEventListener(t,n,r),K(()=>{e.removeEventListener(t,n,r);});}function _t(e,t,n,r){if(Le(e))switch(e.type){case "checkbox":v(e,"change",()=>{r(!!e.checked);});break;case "radio":v(e,"change",()=>{r(e.checked?e.value:"");});break;case "file":v(e,"change",()=>{r(e.files);});break;case "number":case "range":v(e,"input",()=>{r(e.value||"");});break;case "date":case "datetime-local":case "month":case "time":case "week":v(e,"change",()=>{r(e.value||"");});break;default:v(e,"input",()=>{r(e.value);});break}else Pe(e)?v(e,"change",()=>{if(e.multiple){let o=Array.from(e.options).filter(s=>s.selected).map(s=>s.value);r(o);}else r(e.value);}):we(e)&&v(e,"input",()=>{r(e.value);});}function se(e,t,n){if(!e)return;let r=x(),o=[],s=effect(()=>{let i=()=>{let f=isFunction(t)?t():t,c=coerceArray(f).map(a=>isFunction(a)?a():a).flatMap(a=>a).map(L);o=Ie(e,o,c,n);};r&&!r.isDestroyed?k(r,i):i();});return K(()=>{s(),o.forEach(i=>A(i)),o.length=0;}),o}function ce(e,t){let n=t.length,r=new Array(n),o=new Set(t),s=1,i=0,f=c=>{if(c.nodeType!==Node.DOCUMENT_FRAGMENT_NODE){if(o.has(s)&&(r[i++]=c,i===n))return true;s++;}let a=c.firstChild;for(;a;){if(f(a))return true;a=a.nextSibling;}return false};return f(e),r}function kt(e){let t=x();if(t){if(t.isMounted){try{e();}catch(n){}return}t.onMount||(t.onMount=new Set),t.onMount.add(e);}}function Tt(e){let t=x();t&&(t.onUpdate||(t.onUpdate=new Set),t.onUpdate.add(e));}function Ct(e){let t=x();t&&(t.onDestroy||(t.onDestroy=new Set),t.onDestroy.add(e));}function Ke(e){!e||e.isDestroyed||e.isMounted||(e.isMounted=true,e.onMount&&k(e,()=>{for(let t of e.onMount)try{t();}catch(n){}}));}function fe(e){if(!(!e||e.isDestroyed)&&e.onUpdate)for(let t of e.onUpdate)try{t();}catch(n){}}function ae(e){kt(e);}function ue(e){Ct(e);}function Dt(e){Tt(e);}var Ue;Ue="normal";var G=class{constructor(t,n){this.component=t;this.props=n;this.renderedNodes=[];this.scope=null;this.parentNode=void 0;this.beforeNode=void 0;this.reactiveProps={};this.state=0;this.parentScope=null;this[Ue]=true;this.key=n!=null&&n.key?ne(n.key):Ce(t),this.reactiveProps=shallowReactive(z({},this.props||{})),this.parentScope=x();}get isConnected(){return this.state===2}get firstChild(){for(let t of this.renderedNodes){let n=C(t);if(n)return n}}mount(t,n){var s;if(this.parentNode=t,this.beforeNode=n,this.state=1,this.renderedNodes.length>0){for(let i of this.renderedNodes)S(t,i,n);return this.state=2,this.renderedNodes}let r=(s=this.parentScope)!=null?s:x();this.scope=Ae(r);let o=k(this.scope,()=>{var c;let i=this.component(this.reactiveProps);return isFunction(i)&&(i=i(this.reactiveProps)),(isSignal(i)||isComputed(i))&&(i=i.value),(c=se(t,i,n))!=null?c:[]});return this.renderedNodes=o,k(this.scope,()=>{this.applyProps(this.props||{});}),this.state=2,this.scope&&Ke(this.scope),this.renderedNodes}update(t){if(this.key!==t.key)return this.mount(t.parentNode,t.beforeNode),this;if(this.parentNode=t.parentNode,this.beforeNode=t.beforeNode,this.scope=t.scope,this.parentScope=t.parentScope,this.renderedNodes=t.renderedNodes,this.state=t.state,this.reactiveProps=t.reactiveProps,this.props)for(let n in this.props){if(n==="key")continue;let r=this.props[n],o=this.reactiveProps[n];Object.is(o,r)||isObject(o)&&isObject(r)&&Re(o,r)||(this.reactiveProps[n]=r);}return !this.isConnected&&this.parentNode&&this.mount(this.parentNode,this.beforeNode),this.scope&&(k(this.scope,()=>{this.applyProps(this.props||{});}),fe(this.scope)),this}forceUpdate(){return $(this,null,function*(){if(yield Promise.resolve(),this.state===5||!this.parentNode||!this.scope)return;let t=[...this.renderedNodes];try{k(this.scope,()=>{let n=this.component(this.reactiveProps);isFunction(n)&&(n=n(this.reactiveProps)),(isSignal(n)||isComputed(n))&&(n=n.value);let r=coerceArray(n);if(this.parentNode){let o=this.beforeNode;if(!o&&this.renderedNodes.length>0){let s=this.renderedNodes[this.renderedNodes.length-1],i=C(s);i&&(o=i.nextSibling);}for(let s of this.renderedNodes)A(s);for(let s of r)S(this.parentNode,s,o);this.renderedNodes=r;}}),this.scope&&fe(this.scope);}catch(n){throw this.renderedNodes=t,n}})}destroy(){if(this.state===4||this.state===5)return;this.state=4;let t=this.scope;t&&(J(t),this.scope=null);for(let n of this.renderedNodes)A(n);this.renderedNodes=[],this.parentNode=void 0,this.beforeNode=void 0,this.parentScope=null,this.reactiveProps={},this.props=void 0,this.state=5;}applyProps(t){if(!t)return;let n=this.firstChild;for(let[r,o]of Object.entries(t))if(startsWith(r,"on")&&n){let s=r.slice(2).toLowerCase();isHTMLElement(n)&&v(n,s,o);}else r==="ref"&&isSignal(o)&&(o.value=n);this.props=t;}};function m(e){return !!e&&!!e.normal}function O(e,t){return m(e)?e:new G(e,t)}function de(e){let t,n=()=>{let r=document.createElement("template");r.innerHTML=e;let o=r.content.firstChild;if(!o)throw new Error("Invalid template: empty content");return o};return ()=>(t||(t=n())).cloneNode(true)}function Ht(e,t){let n=isString(t)?document.querySelector(t):t;if(!n){error(`Target element not found: ${t}`);return}n.innerHTML&&(error(`Target element is not empty, it will be delete: ${t}`),n.innerHTML="");let o=O(e);return o.mount(n),o}function pe(e,t){let n=x();n&&(n.provides||(n.provides=new Map),n.provides.set(e,t));}function me(e,t){let n=x();if(console.log(n),!n)return t;let r=n;for(;r;){if(r.provides){console.log(r.provides);let o=r.provides.get(e);if(o)return o}r=r.parent;}return t}function $t(e){let t=e.target,n=`${e.type}`,r=e.target,o=e.currentTarget,s=c=>Object.defineProperty(e,"target",{configurable:true,value:c}),i=()=>{let c=t[`_$${n}`];if(c&&isFunction(c)&&!t.disabled){let a=t[`${n}Data`];if(a?c.call(t,a,e):c.call(t,e),e.cancelBubble)return false}return t.host&&!isString(t.host)&&!t.host._$host&&isFunction(t.contains)&&t.contains(e.target)&&s(t.host),true},f=()=>{for(;i()&&(t=t._$host||t.parentNode||t.host););};if(Object.defineProperty(e,"currentTarget",{configurable:true,get(){return t||document}}),e.composedPath){let c=e.composedPath();s(c[0]);for(let a=0;a<c.length-2&&(t=c[a],!!i());a++){if(t._$host){t=t._$host,f();break}if(t.parentNode===o)break}}else f();s(r);}var Ge=Symbol("_$EVENTS");function Kt(e,t=window.document){let n=t,r=n[Ge]||(n[Ge]=new Set);for(let o of e)r.has(o)||(r.add(o),t.addEventListener(o,$t));}function jt(e,t,n,r=false){if(t===n)return;let o=X(n),s=X(t);o&&s===o||(o?r?e.setAttribute("class",o):e.className=o:e.removeAttribute("class"));}function X(e){if(e==null)return "";if(typeof e=="string")return e.trim();if(isArray(e))return e.map(X).filter(Boolean).join(" ");if(isObject(e)){let t=[];for(let n in e)e[n]&&t.push(n);return t.join(" ")}return String(e).trim()}var Xe=/\s*!important$/,Gt=["Webkit","Moz","ms"],ye={};function Xt(e,t,n){let r=e.style,o=isString(n);if(n&&o){t!==n&&(r.cssText=n);return}if(!n){t&&e.removeAttribute("style");return}if(t&&!isString(t))for(let s in t)(!n||n[s]==null)&&U(r,s,"");else if(t&&isString(t)){let s=t.split(";");for(let i of s){let f=i.indexOf(":");if(f>0){let c=i.slice(0,f).trim();n&&isObject(n)&&n[c]==null&&U(r,c,"");}}}if(n&&!isString(n))for(let s in n){let i=n[s];(!t||isString(t)||t[s]!==i)&&i!=null&&U(r,s,i);}}function U(e,t,n){if(isArray(n)){for(let o of n)U(e,t,o);return}if((n==null||n==="")&&(n=""),t.startsWith("--")){e.setProperty(t,n);return}let r=Yt(e,t);typeof n=="string"&&Xe.test(n)?e.setProperty(camelCase(r),n.replace(Xe,""),"important"):e[r]=n;}function Yt(e,t){let n=ye[t];if(n)return n;let r=camelCase(t);if(r!=="filter"&&r in e)return ye[t]=r;r=capitalize(r);for(let o of Gt){let s=o+r;if(s in e)return ye[t]=s}return t}function We(e,t,n,r){if(t==="key"){r==null?F(e,void 0):F(e,String(r));return}if(t===ve){Object.keys(r).forEach(u=>{We(e,u,n==null?void 0:n[u],r==null?void 0:r[u]);});return}let o=(e==null?void 0:e.namespaceURI)===be,s=o&&t.startsWith("xlink:"),i=o&&t.startsWith("xmlns:"),f=isSpecialBooleanAttr(t)||isBooleanAttr(t);if(n===r)return;let c=t.toLowerCase();if(/^on[a-z]+/.test(c)||c==="innerhtml")return;if(r==null){if(s)e.removeAttributeNS(Q,t.slice(6));else if(i){let u=t.slice(6);e.removeAttributeNS(Z,u);}else e.removeAttribute(t);return}if(s){e.setAttributeNS(Q,t,String(r));return}if(i){e.setAttributeNS(Z,t,String(r));return}if(f){includeBooleanAttr(r)?e.setAttribute(t,""):e.removeAttribute(t);return}let a=isSymbol(r)?String(r):r;if((c==="href"||c==="src"||c==="xlink:href")&&typeof a=="string"){let u=a.trim().toLowerCase();if(u.startsWith("javascript:")||u.startsWith("data:"))return}if(o)e.setAttribute(t,String(a));else if(t in e)try{e[t]=a;}catch(u){e.setAttribute(t,String(a));}else e.setAttribute(t,String(a));}function Zt(e,t,n,r){if(!(r!=null&&r.delegate))return e.addEventListener(t,n,r),()=>e.removeEventListener(t,n,r);let o=r.delegate,s=f=>{let c=f.target;(c.matches(o)||c.closest(o))&&n.call(e,f);},i=z({},r);return i.delegate=void 0,e.addEventListener(t,s,i),()=>{e.removeEventListener(t,s,i);}}function en(e){return e==null?void 0:e.children}en.fragment=true;function io(e){return !!e&&!!e.fragment}function nn(e){if(typeof document=="undefined"){let r=e.children;return r?(isArray(r)?r:[r]).map(s=>String(s||"")).join(""):""}let t=document.createComment("portal");t.portal=true;let n=e.children;if(n){let r=isArray(n)?n:[n],o=[];ae(()=>{let s=isString(e.target)?document.querySelector(e.target):e.target;s&&(r.forEach(i=>{if(i!=null){let f=L(i);f&&(S(s,f),o.push(f));}}),K(()=>{o.forEach(i=>{typeof i!="string"&&i.parentNode===s&&s.removeChild(i);});}));});}return t}nn.portal=true;function mo(e){return !!e&&!!e.portal}var ge=Symbol("SuspenseContext");function sn(e){if(isUndefined(document)){let u=e.fallback;return u?String(u||""):""}let t=document.createElement("div");t.style.display="contents";let n=true,r=0,o=false,s=null,i=()=>{if(!o){for(o=true;t.firstChild;)t.removeChild(t.firstChild);if(e.fallback!=null){let u=L(e.fallback);u&&S(t,u);}}},f=()=>{if(!(!o||!(s||e.children!=null&&!isPromise(e.children)))){for(o=false;t.firstChild;)t.removeChild(t.firstChild);s?c(s):e.children!=null&&!isPromise(e.children)&&c(e.children);}},c=u=>{for(;t.firstChild;)t.removeChild(t.firstChild);if(u==null)return;let h=x();if((isArray(u)?u:[u]).forEach(b=>{if(b!=null){m(b)&&(b.parentContext=h);let I=L(b);I&&S(t,I);}}),o){for(;t.firstChild;)t.removeChild(t.firstChild);if(e.fallback!=null){let b=L(e.fallback);b&&S(t,b);}}},a={register:u=>{r++,i(),u.then(()=>{n&&(r--,r===0&&f());}).catch(h=>{n&&(r--,r===0&&f());});},increment:()=>{r++,i();},decrement:()=>{r--,r===0&&f();}};pe(ge,a);let l=e.children;return isPromise(l)?(l.then(u=>{s=u;}).catch(()=>{}),a.register(l)):l!=null?c(l):i(),ue(()=>{for(n=false;t.firstChild;)t.removeChild(t.firstChild);}),t}sn.suspense=true;function bo(e){return !!e&&!!e.suspense}function Lo(e,t){let n=signal(t==null?void 0:t.initialValue),r=signal(true),o=signal(null),s=signal("pending"),i=0,f=null,c=()=>$(null,null,function*(){let u=++i;r.value=true,s.value="pending",o.value=null;let h=e();f=h.then(()=>{});try{let y=yield h;u===i&&(n.value=y,s.value="ready",r.value=!1);}catch(y){u===i&&(o.value=y instanceof Error?y:new Error(String(y)),s.value="errored",r.value=false);}});c();let a=(()=>{if(r.value&&f){let u=me(ge,null);u&&u.register(f);}return n.value});return a.loading=r,a.error=o,a.state=s,[a,{mutate:u=>{n.value=u,s.value="ready",r.value=false,o.value=null;},refetch:()=>$(null,null,function*(){yield c();})}]}var Be=0;function Se(){return `${Be++}`}function W(){Be=0;}function Ne(){}function M(e,t=false){return isNil(e)?"":isString(e)?e:isArray(e)?e.map(n=>M(n,t)).join(""):isFunction(e)?M(e(),t):String(e)}function Ze(e,t){let n=/^<([a-z]+)(\s*)([^>]*)>/i,r=/data-idx="(\d+)"/g,o=/<!--(.*?)-->/g;return e.replace(n,`<$1$2$3 data-hk="${t}">`).replaceAll(r,`data-idx="${t}-$1"`).replaceAll(o,`<!--${t}-$1-->`)}function ln(e,t){if(!isFunction(e))return error("Component must be a function"),"";W();let n=e(t);return M(n)}function dn(e,t,...n){let r="",o=0;for(let i of e)if(r+=i,o<n.length){let f=n[o++];f&&(r+=M(f));}return Ze(r,t)}function pn(e,t={}){if(!isFunction(e))return error("create ssg component: Component is not a function"),"";let n=e(t);return M(n)}function ot(e){if(isArray(e)){let t={};for(let n of e){let r=isString(n)?En(n):ot(n);if(r)for(let o in r)t[o]=r[o];}return t}if(isString(e)||isObject(e))return e}var Sn=/;(?![^(]*\))/g,Nn=/:([\s\S]+)/,xn=/\/\*[\s\S]*?\*\//g;function En(e){let t={};return e.replaceAll(xn,"").split(Sn).forEach(n=>{if(n){let r=n.split(Nn);r.length>1&&(t[r[0].trim()]=r[1].trim());}}),t}function An(e){if(!e)return "";if(isString(e))return e;let t="";for(let n in e){let r=e[n];if(isString(r)||isNumber(r)){let o=n.startsWith("--")?n:kebabCase(n);t+=`${o}:${r};`;}}return t}function it(e){let t="";if(isString(e))t=e;else if(isArray(e))for(let n of e){let r=it(n);r&&(t+=`${r} `);}else if(isObject(e))for(let n in e)e[n]&&(t+=`${n} `);return t.trim()}function st(e,t,n){if(isSignal(t)||isComputed(t))return st(e,t.value);if(!t&&t!==0)return "";if(e==="style"){let r=ot(t);return r?isString(r)?` style="${r}"`:` style="${An(r)}"`:""}if(e==="class"){let r=it(t);return r?` class="${r}"`:""}return e.startsWith("on")?"":t===true?` ${e}`:` ${e}="${t}"`}function bn(e){return ()=>{let t=Se();return document.querySelector(`[data-hk="${t}"]`)||de(e)()}}function _n(e,t){let n=e.dataset.hk;if(!n)return ce(e,t);let r=[],o=e.querySelectorAll(`[data-idx^="${n}"]`);o.length>0&&r.push(...Array.from(o).filter(c=>{let a=c.dataset.idx;return a!==null&&ee.test(a)}).map(c=>{let a=c.dataset.idx||"",[l,u]=a.split("-");return {hk:l,idx:u,node:c}}));let s=[],i=c=>{if(c.nodeType===Node.COMMENT_NODE&&c.textContent&&ee.test(c.textContent)){let[l,u]=c.textContent.split("-");s.push({hk:l,idx:u,node:c});}let a=c.firstChild;for(;a;)i(a),a=a.nextSibling;};i(e),r.push(...s);let f=[e];return t.forEach(c=>{let a=r.find(l=>l.idx===String(c));a&&f.push(a.node);}),f}function kn(e,t,n={}){W();try{let r=isString(t)?document.querySelector(t):t;if(!r){error("Hydration error: Root element not found");return}let o=O(e,n);return o.mount(r),Ne(),o}catch(r){error("Hydration error:",r);return}}
|
|
7
|
+
export{G as Component,en as Fragment,nn as Portal,sn as Suspense,ge as SuspenseContext,Zt as addEvent,v as addEventListener,_t as bindElement,Ht as createApp,O as createComponent,Lo as createResource,pn as createSSGComponent,Kt as delegateEvents,Se as getHydrationKey,bn as getRenderedElement,kn as hydrate,me as inject,se as insert,m as isComponent,io as isFragment,mo as isPortal,bo as isSuspense,ce as mapNodes,_n as mapSSRNodes,X as normalizeClass,Nt as omitProps,ue as onDestroy,ae as onMount,Dt as onUpdate,We as patchAttr,jt as patchClass,Xt as patchStyle,pe as provide,dn as render,ln as renderToString,st as setSSGAttr,U as setStyle,de as template};//# sourceMappingURL=template.esm.js.map
|
|
7
8
|
//# sourceMappingURL=template.esm.js.map
|