@devwareng/vanilla-ts 1.4.14 → 1.4.16
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/index.cjs +99 -2
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +3 -1
- package/dist/index.d.ts +3 -1
- package/dist/index.js +99 -2
- package/dist/index.js.map +1 -1
- package/package.json +1 -1
package/dist/index.d.cts
CHANGED
|
@@ -166,4 +166,6 @@ declare class TSRouter {
|
|
|
166
166
|
addRoute(route: RouteConfig): void;
|
|
167
167
|
}
|
|
168
168
|
|
|
169
|
-
|
|
169
|
+
declare const useTSFilebasedRouter: () => Promise<any>;
|
|
170
|
+
|
|
171
|
+
export { TSRouter, createEffect, createSignal, html, loadPyFiles, mapper, renderChildRoutes, useAnchor, useAnchorSingle, useInitialDOM, useTSAnchorMount, useTSAuth, useTSCollection, useTSComponent, useTSElementEach, useTSElements, useTSEvent, useTSEventAll, useTSExtractParams, useTSFilebasedRouter, useTSHashAnchor, useTSLazy, useTSMetaData, useTSNavigate, useTSNoReload, useTSOutlet, useTSParams, useTSPurifier, useTSSSRHydration, useTSSelect, useTSloadBrython };
|
package/dist/index.d.ts
CHANGED
|
@@ -166,4 +166,6 @@ declare class TSRouter {
|
|
|
166
166
|
addRoute(route: RouteConfig): void;
|
|
167
167
|
}
|
|
168
168
|
|
|
169
|
-
|
|
169
|
+
declare const useTSFilebasedRouter: () => Promise<any>;
|
|
170
|
+
|
|
171
|
+
export { TSRouter, createEffect, createSignal, html, loadPyFiles, mapper, renderChildRoutes, useAnchor, useAnchorSingle, useInitialDOM, useTSAnchorMount, useTSAuth, useTSCollection, useTSComponent, useTSElementEach, useTSElements, useTSEvent, useTSEventAll, useTSExtractParams, useTSFilebasedRouter, useTSHashAnchor, useTSLazy, useTSMetaData, useTSNavigate, useTSNoReload, useTSOutlet, useTSParams, useTSPurifier, useTSSSRHydration, useTSSelect, useTSloadBrython };
|
package/dist/index.js
CHANGED
|
@@ -1,2 +1,99 @@
|
|
|
1
|
-
function re(t){return(t==null?"":String(t)).replace(/<\s*(script|iframe|object|embed|link|style)[^>]*>.*?<\s*\/\s*\1\s*>/gi,"").replace(/<\s*(script|iframe|object|embed|link|style)[^>]*>/gi,"").replace(/\son\w+\s*=\s*(['"]).*?\1/gi,"").replace(/\s(href|src)\s*=\s*(['"])\s*javascript:[^'"]*\2/gi,"")}function H(t,...e){return t.reduce((n,r,o)=>{let s=o<e.length?re(e[o]):"";return n+r+s},"")}function T(){let t=new Set;document.querySelectorAll("*").forEach(e=>{let n=e.tagName.toLowerCase();n.includes("-")&&t.add(n)}),t.forEach(e=>{customElements.get(e)||customElements.define(e,class extends HTMLElement{connectedCallback(){this.innerHTML=`<div style="padding:10px;background:#eee;">${e} (Auto)</div>`}})})}var oe=t=>t.replace(/<\/?(script|iframe|object|embed|link|meta|style)[^>]*>/gi,"").replace(/\s+on[a-z]+\s*=\s*("[^"]*"|'[^']*'|[^\s>]+)/gi,"").replace(/\s+(href|src)\s*=\s*(['"]?)\s*javascript:[^'"\s>]*/gi,""),se=t=>t?.map(e=>oe(e)).join("")??"";import b from"dompurify";var C=(t,e)=>{let r={...{ADD_TAGS:["my-custom-tag"]},...e};return typeof t=="string"?b.sanitize(t,r):b.sanitize(t.innerHTML,r)};var D=(t,e,n)=>{if(typeof t=="string"){let r=document.getElementById(t);r?r.addEventListener(e,n):console.warn(`Element with id '${t}' not found.`)}else t===document?document.addEventListener(e,n):console.warn("Invalid id parameter provided.")};import{createStore as ie}from"zustand/vanilla";import O from"dompurify";function ae(t,e){let n=[],r=t.replace(/:[^/]+/g,a=>(n.push(a.slice(1)),"([^/]+)")),o=new RegExp(`^${r}$`),s=e.match(o),i={};return s&&n.forEach((a,c)=>{i[a]=O.sanitize(s[c+1]??"")}),i}function ce(t){let e={},n=new URLSearchParams(t);for(let[r,o]of n.entries())e[r]=O.sanitize(o);return e}var E=ie((t,e)=>({params:{},query:{},setFromPattern:n=>{let r=window.location.pathname,o=ae(n,r),s=ce(window.location.search);t({params:o,query:s})},getParam:n=>e().params[n],getQuery:n=>e().query[n]}));function k(t){let e=E.getState();e.setFromPattern(t);let n=e.params,r=e.query;return{...n,...r}}var $=(t,e,n)=>{let r=document.querySelectorAll(t);return r.forEach(o=>{o.addEventListener(e,n)}),()=>{r.forEach(o=>{o.removeEventListener(e,n)})}};import P from"dompurify";var z=(t,e,n,r={})=>{let o={USE_PROFILES:{svg:!0,html:!0},ALLOWED_TAGS:["svg","path","circle","rect","line","polyline","polygon","g","main","div","h1","h2","h3","h4","h5","h6","p","button","span","a","img","input","ul","li","i"],ALLOWED_ATTR:["class","id","href","src","alt","fill","stroke","stroke-width","viewBox","xmlns","d","x","y","cx","cy","r","width","height","data-onclick","data-onchange","data-onselect"],FORBID_TAGS:["script","iframe"],ALLOWED_URI_REGEXP:/^(?:(?:https?|mailto|tel|ftp):|[^a-z]|[a-z+.\-]+(?:[^a-z+.\-:]|$))/i,...n};P.addHook("uponSanitizeElement",(i,a)=>{let c=a.tagName.toLowerCase();c.includes("-")&&(a.allowedTags[c]=!0)}),P.addHook("uponSanitizeAttribute",(i,a)=>{a.attrName&&a.attrName.toLowerCase().startsWith("on")&&(a.keepAttr=!1)});let s=P.sanitize(e,o);t.innerHTML=s,t.querySelectorAll("[data-onclick]").forEach(i=>{let a=i.dataset.onclick;r[a]&&i.addEventListener("click",r[a])}),t.querySelectorAll("[data-onchange]").forEach(i=>{let a=i.dataset.onchange;r[a]&&i.addEventListener("change",r[a])}),t.querySelectorAll("[data-onselect]").forEach(i=>{let a=i.dataset.onselect;r[a]&&i.addEventListener("select",r[a])})};import le from"dompurify";var y=null,N=(t,e)=>{if(typeof document>"u")return;let n=document.getElementById(t);if(!n)return;let r=n.innerHTML,s=le.sanitize(r,{ALLOWED_TAGS:["div","span","p","h1","h2","h3","h4","h5","h6","ul","ol","li","strong","em","a","img","br"],ALLOWED_ATTR:["href","src","alt","title","class","id","data-onclick","data-onchange"],ALLOW_DATA_ATTR:!1,KEEP_CONTENT:!1}).replace(/\b(href|src)=["']?(?!https?:|mailto:|\/|#)/gi,'$1="#"');if(y!==null&&s!==y){let i=document.createElement("div");e(i),n.innerHTML=y}else y=s,n.innerHTML=s,e(n)};import q from"dompurify";typeof window<"u"&&!window.__anchorSinglePopstateHandlerAttached&&(window.addEventListener("popstate",t=>{let e=t.state;e?.scrollPosition!==void 0&&window.scrollTo(0,e.scrollPosition)}),window.__anchorSinglePopstateHandlerAttached=!0);var I=(t,e,n,r="",o=null)=>{if(!t)return;let s=q.sanitize(e,{ALLOWED_URI_REGEXP:/^(https?:|\/)/}),i=q.sanitize(n,{USE_PROFILES:{html:!1}});t.setAttribute("href",s),t.setAttribute("aria-label",i),r&&(t.className=r.trim()),o&&t.replaceChildren(o),typeof window<"u"&&t.addEventListener("click",a=>{a.preventDefault();let l=a.currentTarget.getAttribute("href");if(l){let m=window.scrollY;window.scrollTo(0,0),window.history.pushState({scrollPosition:m},"",l),dispatchEvent(new PopStateEvent("popstate"))}})};import g from"dompurify";var _=(t="'self' 'nonce-rAnd0m123' 'unsafe-inline' 'unsafe-eval'",e="'self' 'nonce-rAnd0m123'",n="'none'",r="'self' https://fonts.googleapis.com https://fonts.gstatic.com",o="'self' https://blogger.googleusercontent.com",s=["'self'","https://fonts.googleapis.com","https://fonts.gstatic.com","https://www.google.com/maps/"],i="'self' https://www.youtube.com",a="'self'",c="/csp-report",l=!1)=>{let m=()=>{try{let u=document.querySelector('meta[http-equiv="Content-Security-Policy"]');u||(u=document.createElement("meta"),u.setAttribute("http-equiv","Content-Security-Policy"),document.head.appendChild(u));let p=l?`report-uri ${c};`:"";u.setAttribute("content",`default-src 'self'; script-src ${t}; style-src ${e}; object-src ${n}; font-src ${r}; img-src ${o}; connect-src ${s.join(" ")}; frame-src ${i}; base-uri ${a}; ${p}`)}catch(u){console.error("Error adding CSP meta element:",u)}};document.readyState==="loading"?document.addEventListener("DOMContentLoaded",m):m()};var F=(t,e)=>{let n={name:g.sanitize(t.name||""),description:g.sanitize(t.description||"Default description"),author:g.sanitize(t.author||"")},r=d=>{n.name=g.sanitize(d),u("name",n.name)},o=d=>{n.description=g.sanitize(d),u("description",n.description)},s=d=>{n.author=g.sanitize(d),u("author",n.author)},i=()=>n.name,a=()=>n.description,c=()=>n.author,l=()=>n,m=(d,S)=>{let h=document.createElement("meta");h.setAttribute("name",d),h.setAttribute("content",S),document.head.appendChild(h)},u=(d,S)=>{let h=document.querySelector(`meta[name="${d}"]`);h?h.setAttribute("content",S):m(d,S)},p=()=>{u("name",n.name),u("description",n.description),u("author",n.author)};return e&&_(e.scriptSrc,e.styleSrc,e.objectSrc,Array.isArray(e.connectSrc)?e.connectSrc.join(" "):e.connectSrc,e.reportOnly!==void 0?String(e.reportOnly):void 0),p(),{setName:r,setDescription:o,setAuthor:s,getName:i,getDescription:a,getAuthor:c,getAllMetaData:l,appendMetaTagsToHead:p}};import ue from"dompurify";var L=(t,e,n,r,o)=>{let s=`#${t}`,i=e.querySelectorAll(s);if(i.length===0)throw new Error(`[useTSComponent] No element found with id '${t}' in the given parent.`);if(i.length>1)throw new Error(`[useTSComponent] Duplicate id '${t}' detected. Found ${i.length} elements.`);let a=i[0];a.innerHTML=ue.sanitize(a.innerHTML,{USE_PROFILES:{html:!0}}),n(a,r,o)};var U=(t,e,n,r=[])=>{let o=new Set;t.forEach((s,i)=>{if(o.has(s)){console.warn(`[useTSCollection] Duplicate ID in collection array: "${s}" \u2014 skipping.`);return}o.add(s);let a=e.querySelectorAll(`#${s}`);if(a.length>1){console.warn(`[useTSCollection] Duplicate ID in DOM: "${s}" (${a.length} elements found) \u2014 skipping component mount.`);return}let c=n[i],l=Array.isArray(r)?r[i]:void 0;typeof c=="function"?L(s,e,c,l):console.warn(`[useTSCollection] No valid component function found for ID: "${s}"`)})};var j=(t,e)=>{let r=(e??document).querySelectorAll(t);if(r.length===0)return process.env.NODE_ENV!=="production"&&console.warn(`[useTSSelect] No element found for selector: '${t}'`),null;if(t.startsWith("#")&&r.length>1){if(process.env.NODE_ENV!=="production")throw new Error(`[useTSSelect] Duplicate ID detected: '${t}'. Found ${r.length} elements with this ID.`);return r[0]}return r.length>1&&process.env.NODE_ENV!=="production"&&console.warn(`[useTSSelect] Multiple elements found for selector: '${t}'. Returning the first one.`),r[0]};import{jwtDecode as de}from"jwt-decode";var W=(t,e)=>{let n=localStorage.getItem("token");if(!n)return window.location.href=e,null;try{let r=de(n),o=Date.now()/1e3;return r.exp&&r.exp<o&&(console.error("Token has expired"),window.localStorage.removeItem("token"),window.location.href=e),null}catch(r){return console.error("Invalid token:",r),window.location.href=e,null}};var v=(t,e,n)=>{t.forEach(r=>{e.forEach(o=>{r.addEventListener(o,s=>{n(r,s)})})})};var B=()=>({back:()=>window.history.back(),forward:()=>window.history.forward()});var Q=(t,e)=>{let n=document.querySelector(`#${t}`)||document.querySelector(`.${t}`);if(!n)return;let r=window.location.pathname.replace(/\/$/,"");for(let o of e){let s=o.path.replace(/\/$/,"");if(r===s||r.startsWith(`${s}/`)){o.component(n);break}}};function G(t,e){let n=window.location.pathname.replace(/\/$/,"");e.routes.forEach(r=>{r.children?.length&&r.children.forEach(o=>{let s=o.path.replace(/\/$/,"");if(n===s||n.startsWith(`${s}/`)){let i=t.querySelector(`#${o.outlet}`)||t.querySelector(`.${o.outlet}`);i instanceof HTMLElement&&o.element&&o.element(i)}})})}import{createStore as me}from"zustand/vanilla";function V(t){let e=me(()=>({value:t})),n=new Set;return{get:()=>e.getState().value,set:r=>{e.setState({value:r}),n.forEach(o=>o(r))},subscribe:r=>(n.add(r),r(e.getState().value),()=>n.delete(r))}}function X(t){let e=t();typeof e=="function"&&e()}var w=()=>{let t=document.querySelectorAll('a[href^="#"]');v(t,["click"],(e,n)=>{n.preventDefault();let r=e.getAttribute("href")?.substring(1),o=r?document.getElementById(r):null;o&&o.scrollIntoView({behavior:"smooth",block:"start"})})};import{debounce as pe}from"lodash-es";var x=t=>t;typeof window<"u"&&typeof document<"u"&&(x=t=>{let e=document.createElement("div");return e.innerText=t,e.innerHTML});var fe=t=>{(t?Array.isArray(t)?t:t instanceof HTMLAnchorElement?[t]:Array.from(t):Array.from(document.querySelectorAll("a"))).forEach(n=>{if(!n||n.dataset.anchorEnhanced==="true")return;n.dataset.anchorEnhanced="true";let r=n.getAttribute("class")||"";n.setAttribute("class",x(r));let o=n.getAttribute("aria-label");o&&n.setAttribute("aria-label",x(o));let s=n.querySelector(":scope > *");s&&(n.innerHTML="",n.appendChild(s));let i=n.getAttribute("href")||"";if(!i.startsWith("#")){try{if(new URL(i,window.location.href).origin!==window.location.origin)return}catch{return}n.addEventListener("click",a=>{a.preventDefault();let c=n.getAttribute("href")||"";try{let l=new URL(c,window.location.href);window.history.pushState({},"",l.pathname+l.search+l.hash),window.dispatchEvent(new PopStateEvent("popstate"))}catch(l){console.error("Invalid URL in anchor:",c,l)}})}})},he=pe(fe,50),M=t=>{he(t)};var A=t=>{let e=t.querySelectorAll("a");M(e)};var J=t=>{w(),A(t)};var K=async()=>{let t="https://cdn.jsdelivr.net/npm/brython@3/brython.min.js",e="https://cdn.jsdelivr.net/npm/brython@3/brython_stdlib.js",n=r=>new Promise((o,s)=>{let i=document.createElement("script");i.src=r,i.onload=()=>o(),i.onerror=()=>s(new Error(`Failed to load ${r}`)),document.head.appendChild(i)});await n(t),await n(e),typeof window.brython=="function"?window.brython():console.error("Brython did not load correctly.")},Y=t=>new Promise((e,n)=>{let r=document.createElement("script");r.type="text/python",r.src=`/src/python/${t}`,r.onload=()=>e(),r.onerror=()=>n(new Error(`Failed to load ${t}`)),document.body.appendChild(r)});function Z(t){let e=null;return async(n,r)=>{try{if(!e){let o=await t();e=o.default||o}if(typeof e=="function")return e(n,r);if(e instanceof HTMLElement){n?.appendChild(e);return}if(e&&typeof e.render=="function")return e.render(n,r);console.warn("useTSLazy: Unsupported module type",e)}catch(o){console.error("useTSLazy failed:",o)}}}var ee=t=>typeof window>"u"?{isDOM:null}:{isDOM:t||document.body};import ne from"dompurify";import{createStore as ge}from"zustand/vanilla";import Se from"dompurify";var f=ge(t=>({params:{},query:{},setParams:e=>t(()=>({params:te(e)})),setQuery:e=>t(()=>({query:te(e)}))}));function te(t){let e={};for(let n in t)e[n]=Se.sanitize(t[n]);return e}var R=class{constructor(e,n){this.routes=[];this.routes=e,this.expectedParams=new Set(n),window.addEventListener("popstate",this.handlePopState.bind(this)),this.handlePopState()}handlePopState(){let e=window.location.pathname,n=window.location.search,r=this.parseQueryParams(n),o=this.findMatchingRoute(e,this.routes);if(o){if(o.routeto){this.navigate(o.routeto);return}let s=this.filterAndSanitizeParams(o.params);f.getState().setParams(s),f.getState().setQuery(r);let i=document.createElement("div");if(o.element?.(i,s,r),o.children){let a=e.slice(o.path.length),c=i.querySelector("#child");c&&this.renderChildren(o.children,a,c,s,r)}}else{let s=this.findMatchingRoute("*",this.routes);if(s){let i=this.filterAndSanitizeParams(s.params);f.getState().setParams(i),f.getState().setQuery(r);let a=document.createElement("div");s.element?.(a,i,r)}}}renderChildren(e,n,r,o,s){if(!e||e.length===0){let a=r.querySelector("#child");a&&a.remove();return}let i=this.findMatchingRoute(n,e);if(i){let a=document.createElement("div");a.id="child";let c={...o,...i.params},l=this.filterAndSanitizeParams(c);if(f.getState().setParams(l),f.getState().setQuery(s),i.element?.(a,l,s),r.appendChild(a),i.children){let m=n.slice(i.path.length);this.renderChildren(i.children,m,a,l,s)}}}parseQueryParams(e){let n={},r=new URLSearchParams(e);for(let[o,s]of r.entries())this.expectedParams.has(o)&&(n[o]=ne.sanitize(s));return n}findMatchingRoute(e,n,r={}){for(let o of n){let s=o.path;if(s==="*")return o;{let a=[],c=s.replace(/:[^\s/]+/g,u=>(a.push(u.substring(1)),"([^\\s/]+)")),l=new RegExp(`^${c}(?:/|$)`),m=e.match(l);if(m){let u={...r};if(a.forEach((p,d)=>{u[p]=m[d+1]??""}),o.children){let p=e.slice(m[0].length),d=this.findMatchingRoute(p,o.children,u);if(d)return d}return{...o,params:u}}}}}filterAndSanitizeParams(e){if(!e)return{};let n={};for(let r in e)this.expectedParams.has(r)&&(n[r]=ne.sanitize(e[r]??""));return n}navigate(e){history.pushState(null,"",e),this.handlePopState()}addRoute(e){this.routes.push(e)}};typeof window<"u"&&(window.addEventListener("popstate",()=>{T()}),document.addEventListener("DOMContentLoaded",T));export{R as TSRouter,X as createEffect,V as createSignal,H as html,Y as loadPyFiles,se as mapper,G as renderChildRoutes,M as useAnchor,I as useAnchorSingle,N as useInitialDOM,J as useTSAnchorMount,W as useTSAuth,U as useTSCollection,L as useTSComponent,v as useTSElementEach,z as useTSElements,D as useTSEvent,$ as useTSEventAll,k as useTSExtractParams,w as useTSHashAnchor,Z as useTSLazy,F as useTSMetaData,B as useTSNavigate,A as useTSNoReload,Q as useTSOutlet,E as useTSParams,C as useTSPurifier,ee as useTSSSRHydration,j as useTSSelect,K as useTSloadBrython};
|
|
2
|
-
|
|
1
|
+
import f from"process";function oe(s){return(s==null?"":String(s)).replace(/<\s*(script|iframe|object|embed|link|style)[^>]*>.*?<\s*\/\s*\1\s*>/gi,"").replace(/<\s*(script|iframe|object|embed|link|style)[^>]*>/gi,"").replace(/\son\w+\s*=\s*(['"]).*?\1/gi,"").replace(/\s(href|src)\s*=\s*(['"])\s*javascript:[^'"]*\2/gi,"")}function ut(s,...t){return s.reduce((e,n,r)=>{let i=r<t.length?oe(t[r]):"";return e+n+i},"")}function b(){let s=new Set;document.querySelectorAll("*").forEach(t=>{let e=t.tagName.toLowerCase();e.includes("-")&&s.add(e)}),s.forEach(t=>{customElements.get(t)||customElements.define(t,class extends HTMLElement{connectedCallback(){this.innerHTML=`<div style="padding:10px;background:#eee;">${t} (Auto)</div>`}})})}var ae=s=>s.replace(/<\/?(script|iframe|object|embed|link|meta|style)[^>]*>/gi,"").replace(/\s+on[a-z]+\s*=\s*("[^"]*"|'[^']*'|[^\s>]+)/gi,"").replace(/\s+(href|src)\s*=\s*(['"]?)\s*javascript:[^'"\s>]*/gi,""),ce=s=>s?.map(t=>ae(t)).join("")??"";import dt from"dompurify";var ht=(s,t)=>{let n={...{ADD_TAGS:["my-custom-tag"]},...t};return typeof s=="string"?dt.sanitize(s,n):dt.sanitize(s.innerHTML,n)};var ft=(s,t,e)=>{if(typeof s=="string"){let n=document.getElementById(s);n?n.addEventListener(t,e):console.warn(`Element with id '${s}' not found.`)}else s===document?document.addEventListener(t,e):console.warn("Invalid id parameter provided.")};import{createStore as le}from"zustand/vanilla";import mt from"dompurify";function ue(s,t){let e=[],n=s.replace(/:[^/]+/g,o=>(e.push(o.slice(1)),"([^/]+)")),r=new RegExp(`^${n}$`),i=t.match(r),a={};return i&&e.forEach((o,c)=>{a[o]=mt.sanitize(i[c+1]??"")}),a}function de(s){let t={},e=new URLSearchParams(s);for(let[n,r]of e.entries())t[n]=mt.sanitize(r);return t}var O=le((s,t)=>({params:{},query:{},setFromPattern:e=>{let n=window.location.pathname,r=ue(e,n),i=de(window.location.search);s({params:r,query:i})},getParam:e=>t().params[e],getQuery:e=>t().query[e]}));function pt(s){let t=O.getState();t.setFromPattern(s);let e=t.params,n=t.query;return{...e,...n}}var gt=(s,t,e)=>{let n=document.querySelectorAll(s);return n.forEach(r=>{r.addEventListener(t,e)}),()=>{n.forEach(r=>{r.removeEventListener(t,e)})}};import K from"dompurify";var Et=(s,t,e,n={})=>{let r={USE_PROFILES:{svg:!0,html:!0},ALLOWED_TAGS:["svg","path","circle","rect","line","polyline","polygon","g","main","div","h1","h2","h3","h4","h5","h6","p","button","span","a","img","input","ul","li","i"],ALLOWED_ATTR:["class","id","href","src","alt","fill","stroke","stroke-width","viewBox","xmlns","d","x","y","cx","cy","r","width","height","data-onclick","data-onchange","data-onselect"],FORBID_TAGS:["script","iframe"],ALLOWED_URI_REGEXP:/^(?:(?:https?|mailto|tel|ftp):|[^a-z]|[a-z+.\-]+(?:[^a-z+.\-:]|$))/i,...e};K.addHook("uponSanitizeElement",(a,o)=>{let c=o.tagName.toLowerCase();c.includes("-")&&(o.allowedTags[c]=!0)}),K.addHook("uponSanitizeAttribute",(a,o)=>{o.attrName&&o.attrName.toLowerCase().startsWith("on")&&(o.keepAttr=!1)});let i=K.sanitize(t,r);s.innerHTML=i,s.querySelectorAll("[data-onclick]").forEach(a=>{let o=a.dataset.onclick;n[o]&&a.addEventListener("click",n[o])}),s.querySelectorAll("[data-onchange]").forEach(a=>{let o=a.dataset.onchange;n[o]&&a.addEventListener("change",n[o])}),s.querySelectorAll("[data-onselect]").forEach(a=>{let o=a.dataset.onselect;n[o]&&a.addEventListener("select",n[o])})};import he from"dompurify";var C=null,wt=(s,t)=>{if(typeof document>"u")return;let e=document.getElementById(s);if(!e)return;let n=e.innerHTML,i=he.sanitize(n,{ALLOWED_TAGS:["div","span","p","h1","h2","h3","h4","h5","h6","ul","ol","li","strong","em","a","img","br"],ALLOWED_ATTR:["href","src","alt","title","class","id","data-onclick","data-onchange"],ALLOW_DATA_ATTR:!1,KEEP_CONTENT:!1}).replace(/\b(href|src)=["']?(?!https?:|mailto:|\/|#)/gi,'$1="#"');if(C!==null&&i!==C){let a=document.createElement("div");t(a),e.innerHTML=C}else C=i,e.innerHTML=i,t(e)};import yt from"dompurify";typeof window<"u"&&!window.__anchorSinglePopstateHandlerAttached&&(window.addEventListener("popstate",s=>{let t=s.state;t?.scrollPosition!==void 0&&window.scrollTo(0,t.scrollPosition)}),window.__anchorSinglePopstateHandlerAttached=!0);var Tt=(s,t,e,n="",r=null)=>{if(!s)return;let i=yt.sanitize(t,{ALLOWED_URI_REGEXP:/^(https?:|\/)/}),a=yt.sanitize(e,{USE_PROFILES:{html:!1}});s.setAttribute("href",i),s.setAttribute("aria-label",a),n&&(s.className=n.trim()),r&&s.replaceChildren(r),typeof window<"u"&&s.addEventListener("click",o=>{o.preventDefault();let l=o.currentTarget.getAttribute("href");if(l){let u=window.scrollY;window.scrollTo(0,0),window.history.pushState({scrollPosition:u},"",l),dispatchEvent(new PopStateEvent("popstate"))}})};import L from"dompurify";var _t=(s="'self' 'nonce-rAnd0m123' 'unsafe-inline' 'unsafe-eval'",t="'self' 'nonce-rAnd0m123'",e="'none'",n="'self' https://fonts.googleapis.com https://fonts.gstatic.com",r="'self' https://blogger.googleusercontent.com",i=["'self'","https://fonts.googleapis.com","https://fonts.gstatic.com","https://www.google.com/maps/"],a="'self' https://www.youtube.com",o="'self'",c="/csp-report",l=!1)=>{let u=()=>{try{let d=document.querySelector('meta[http-equiv="Content-Security-Policy"]');d||(d=document.createElement("meta"),d.setAttribute("http-equiv","Content-Security-Policy"),document.head.appendChild(d));let h=l?`report-uri ${c};`:"";d.setAttribute("content",`default-src 'self'; script-src ${s}; style-src ${t}; object-src ${e}; font-src ${n}; img-src ${r}; connect-src ${i.join(" ")}; frame-src ${a}; base-uri ${o}; ${h}`)}catch(d){console.error("Error adding CSP meta element:",d)}};document.readyState==="loading"?document.addEventListener("DOMContentLoaded",u):u()};var St=(s,t)=>{let e={name:L.sanitize(s.name||""),description:L.sanitize(s.description||"Default description"),author:L.sanitize(s.author||"")},n=m=>{e.name=L.sanitize(m),d("name",e.name)},r=m=>{e.description=L.sanitize(m),d("description",e.description)},i=m=>{e.author=L.sanitize(m),d("author",e.author)},a=()=>e.name,o=()=>e.description,c=()=>e.author,l=()=>e,u=(m,g)=>{let E=document.createElement("meta");E.setAttribute("name",m),E.setAttribute("content",g),document.head.appendChild(E)},d=(m,g)=>{let E=document.querySelector(`meta[name="${m}"]`);E?E.setAttribute("content",g):u(m,g)},h=()=>{d("name",e.name),d("description",e.description),d("author",e.author)};return t&&_t(t.scriptSrc,t.styleSrc,t.objectSrc,Array.isArray(t.connectSrc)?t.connectSrc.join(" "):t.connectSrc,t.reportOnly!==void 0?String(t.reportOnly):void 0),h(),{setName:n,setDescription:r,setAuthor:i,getName:a,getDescription:o,getAuthor:c,getAllMetaData:l,appendMetaTagsToHead:h}};import fe from"dompurify";var I=(s,t,e,n,r)=>{let i=`#${s}`,a=t.querySelectorAll(i);if(a.length===0)throw new Error(`[useTSComponent] No element found with id '${s}' in the given parent.`);if(a.length>1)throw new Error(`[useTSComponent] Duplicate id '${s}' detected. Found ${a.length} elements.`);let o=a[0];o.innerHTML=fe.sanitize(o.innerHTML,{USE_PROFILES:{html:!0}}),e(o,n,r)};var Pt=(s,t,e,n=[])=>{let r=new Set;s.forEach((i,a)=>{if(r.has(i)){console.warn(`[useTSCollection] Duplicate ID in collection array: "${i}" \u2014 skipping.`);return}r.add(i);let o=t.querySelectorAll(`#${i}`);if(o.length>1){console.warn(`[useTSCollection] Duplicate ID in DOM: "${i}" (${o.length} elements found) \u2014 skipping component mount.`);return}let c=e[a],l=Array.isArray(n)?n[a]:void 0;typeof c=="function"?I(i,t,c,l):console.warn(`[useTSCollection] No valid component function found for ID: "${i}"`)})};var vt=(s,t)=>{let n=(t??document).querySelectorAll(s);if(n.length===0)return f.env.NODE_ENV!=="production"&&console.warn(`[useTSSelect] No element found for selector: '${s}'`),null;if(s.startsWith("#")&&n.length>1){if(f.env.NODE_ENV!=="production")throw new Error(`[useTSSelect] Duplicate ID detected: '${s}'. Found ${n.length} elements with this ID.`);return n[0]}return n.length>1&&f.env.NODE_ENV!=="production"&&console.warn(`[useTSSelect] Multiple elements found for selector: '${s}'. Returning the first one.`),n[0]};import{jwtDecode as me}from"jwt-decode";var Rt=(s,t)=>{let e=localStorage.getItem("token");if(!e)return window.location.href=t,null;try{let n=me(e),r=Date.now()/1e3;return n.exp&&n.exp<r&&(console.error("Token has expired"),window.localStorage.removeItem("token"),window.location.href=t),null}catch(n){return console.error("Invalid token:",n),window.location.href=t,null}};var H=(s,t,e)=>{s.forEach(n=>{t.forEach(r=>{n.addEventListener(r,i=>{e(n,i)})})})};var Lt=()=>({back:()=>window.history.back(),forward:()=>window.history.forward()});var Dt=(s,t)=>{let e=document.querySelector(`#${s}`)||document.querySelector(`.${s}`);if(!e)return;let n=window.location.pathname.replace(/\/$/,"");for(let r of t){let i=r.path.replace(/\/$/,"");if(n===i||n.startsWith(`${i}/`)){r.component(e);break}}};function xt(s,t){let e=window.location.pathname.replace(/\/$/,"");t.routes.forEach(n=>{n.children?.length&&n.children.forEach(r=>{let i=r.path.replace(/\/$/,"");if(e===i||e.startsWith(`${i}/`)){let a=s.querySelector(`#${r.outlet}`)||s.querySelector(`.${r.outlet}`);a instanceof HTMLElement&&r.element&&r.element(a)}})})}import{createStore as pe}from"zustand/vanilla";function At(s){let t=pe(()=>({value:s})),e=new Set;return{get:()=>t.getState().value,set:n=>{t.setState({value:n}),e.forEach(r=>r(n))},subscribe:n=>(e.add(n),n(t.getState().value),()=>e.delete(n))}}function Mt(s){let t=s();typeof t=="function"&&t()}var N=()=>{let s=document.querySelectorAll('a[href^="#"]');H(s,["click"],(t,e)=>{e.preventDefault();let n=t.getAttribute("href")?.substring(1),r=n?document.getElementById(n):null;r&&r.scrollIntoView({behavior:"smooth",block:"start"})})};import{debounce as ge}from"lodash-es";var Q=s=>s;typeof window<"u"&&typeof document<"u"&&(Q=s=>{let t=document.createElement("div");return t.innerText=s,t.innerHTML});var Ee=s=>{(s?Array.isArray(s)?s:s instanceof HTMLAnchorElement?[s]:Array.from(s):Array.from(document.querySelectorAll("a"))).forEach(e=>{if(!e||e.dataset.anchorEnhanced==="true")return;e.dataset.anchorEnhanced="true";let n=e.getAttribute("class")||"";e.setAttribute("class",Q(n));let r=e.getAttribute("aria-label");r&&e.setAttribute("aria-label",Q(r));let i=e.querySelector(":scope > *");i&&(e.innerHTML="",e.appendChild(i));let a=e.getAttribute("href")||"";if(!a.startsWith("#")){try{if(new URL(a,window.location.href).origin!==window.location.origin)return}catch{return}e.addEventListener("click",o=>{o.preventDefault();let c=e.getAttribute("href")||"";try{let l=new URL(c,window.location.href);window.history.pushState({},"",l.pathname+l.search+l.hash),window.dispatchEvent(new PopStateEvent("popstate"))}catch(l){console.error("Invalid URL in anchor:",c,l)}})}})},we=ge(Ee,50),F=s=>{we(s)};var k=s=>{let t=s.querySelectorAll("a");F(t)};var bt=s=>{N(),k(s)};var Ot=async()=>{let s="https://cdn.jsdelivr.net/npm/brython@3/brython.min.js",t="https://cdn.jsdelivr.net/npm/brython@3/brython_stdlib.js",e=n=>new Promise((r,i)=>{let a=document.createElement("script");a.src=n,a.onload=()=>r(),a.onerror=()=>i(new Error(`Failed to load ${n}`)),document.head.appendChild(a)});await e(s),await e(t),typeof window.brython=="function"?window.brython():console.error("Brython did not load correctly.")},Ct=s=>new Promise((t,e)=>{let n=document.createElement("script");n.type="text/python",n.src=`/src/python/${s}`,n.onload=()=>t(),n.onerror=()=>e(new Error(`Failed to load ${s}`)),document.body.appendChild(n)});function It(s){let t=null;return async(e,n)=>{try{if(!t){let r=await s();t=r.default||r}if(typeof t=="function")return t(e,n);if(t instanceof HTMLElement){e?.appendChild(t);return}if(t&&typeof t.render=="function")return t.render(e,n);console.warn("useTSLazy: Unsupported module type",t)}catch(r){console.error("useTSLazy failed:",r)}}}var Ht=s=>typeof window>"u"?{isDOM:null}:{isDOM:s||document.body};import Ft from"dompurify";import{createStore as ye}from"zustand/vanilla";import Te from"dompurify";var P=ye(s=>({params:{},query:{},setParams:t=>s(()=>({params:Nt(t)})),setQuery:t=>s(()=>({query:Nt(t)}))}));function Nt(s){let t={};for(let e in s)t[e]=Te.sanitize(s[e]);return t}var J=class{constructor(t,e){this.routes=[];this.routes=t,this.expectedParams=new Set(e),window.addEventListener("popstate",this.handlePopState.bind(this)),this.handlePopState()}handlePopState(){let t=window.location.pathname,e=window.location.search,n=this.parseQueryParams(e),r=this.findMatchingRoute(t,this.routes);if(r){if(r.routeto){this.navigate(r.routeto);return}let i=this.filterAndSanitizeParams(r.params);P.getState().setParams(i),P.getState().setQuery(n);let a=document.createElement("div");if(r.element?.(a,i,n),r.children){let o=t.slice(r.path.length),c=a.querySelector("#child");c&&this.renderChildren(r.children,o,c,i,n)}}else{let i=this.findMatchingRoute("*",this.routes);if(i){let a=this.filterAndSanitizeParams(i.params);P.getState().setParams(a),P.getState().setQuery(n);let o=document.createElement("div");i.element?.(o,a,n)}}}renderChildren(t,e,n,r,i){if(!t||t.length===0){let o=n.querySelector("#child");o&&o.remove();return}let a=this.findMatchingRoute(e,t);if(a){let o=document.createElement("div");o.id="child";let c={...r,...a.params},l=this.filterAndSanitizeParams(c);if(P.getState().setParams(l),P.getState().setQuery(i),a.element?.(o,l,i),n.appendChild(o),a.children){let u=e.slice(a.path.length);this.renderChildren(a.children,u,o,l,i)}}}parseQueryParams(t){let e={},n=new URLSearchParams(t);for(let[r,i]of n.entries())this.expectedParams.has(r)&&(e[r]=Ft.sanitize(i));return e}findMatchingRoute(t,e,n={}){for(let r of e){let i=r.path;if(i==="*")return r;{let o=[],c=i.replace(/:[^\s/]+/g,d=>(o.push(d.substring(1)),"([^\\s/]+)")),l=new RegExp(`^${c}(?:/|$)`),u=t.match(l);if(u){let d={...n};if(o.forEach((h,m)=>{d[h]=u[m+1]??""}),r.children){let h=t.slice(u[0].length),m=this.findMatchingRoute(h,r.children,d);if(m)return m}return{...r,params:d}}}}}filterAndSanitizeParams(t){if(!t)return{};let e={};for(let n in t)this.expectedParams.has(n)&&(e[n]=Ft.sanitize(t[n]??""));return e}navigate(t){history.pushState(null,"",t),this.handlePopState()}addRoute(t){this.routes.push(t)}};import R from"fs/promises";import S from"path";import{stat as Qe}from"fs";import{stat as Je,readdir as Xe}from"fs/promises";import{EventEmitter as Ze}from"events";import*as p from"path";import{stat as _e,lstat as kt,readdir as Se,realpath as Pe}from"fs/promises";import{Readable as ve}from"stream";import{resolve as zt,relative as Re,join as Le,sep as De}from"path";var T={FILE_TYPE:"files",DIR_TYPE:"directories",FILE_DIR_TYPE:"files_directories",EVERYTHING_TYPE:"all"},X={root:".",fileFilter:s=>!0,directoryFilter:s=>!0,type:T.FILE_TYPE,lstat:!1,depth:2147483648,alwaysStat:!1,highWaterMark:4096};Object.freeze(X);var Ut="READDIRP_RECURSIVE_ERROR",xe=new Set(["ENOENT","EPERM","EACCES","ELOOP",Ut]),Wt=[T.DIR_TYPE,T.EVERYTHING_TYPE,T.FILE_DIR_TYPE,T.FILE_TYPE],Ae=new Set([T.DIR_TYPE,T.EVERYTHING_TYPE,T.FILE_DIR_TYPE]),Me=new Set([T.EVERYTHING_TYPE,T.FILE_DIR_TYPE,T.FILE_TYPE]),be=s=>xe.has(s.code),Oe=f.platform==="win32",$t=s=>!0,jt=s=>{if(s===void 0)return $t;if(typeof s=="function")return s;if(typeof s=="string"){let t=s.trim();return e=>e.basename===t}if(Array.isArray(s)){let t=s.map(e=>e.trim());return e=>t.some(n=>e.basename===n)}return $t},Z=class extends ve{constructor(t={}){super({objectMode:!0,autoDestroy:!0,highWaterMark:t.highWaterMark});let e={...X,...t},{root:n,type:r}=e;this._fileFilter=jt(e.fileFilter),this._directoryFilter=jt(e.directoryFilter);let i=e.lstat?kt:_e;Oe?this._stat=a=>i(a,{bigint:!0}):this._stat=i,this._maxDepth=e.depth??X.depth,this._wantsDir=r?Ae.has(r):!1,this._wantsFile=r?Me.has(r):!1,this._wantsEverything=r===T.EVERYTHING_TYPE,this._root=zt(n),this._isDirent=!e.alwaysStat,this._statsProp=this._isDirent?"dirent":"stats",this._rdOptions={encoding:"utf8",withFileTypes:this._isDirent},this.parents=[this._exploreDir(n,1)],this.reading=!1,this.parent=void 0}async _read(t){if(!this.reading){this.reading=!0;try{for(;!this.destroyed&&t>0;){let e=this.parent,n=e&&e.files;if(n&&n.length>0){let{path:r,depth:i}=e,a=n.splice(0,t).map(c=>this._formatEntry(c,r)),o=await Promise.all(a);for(let c of o){if(!c)continue;if(this.destroyed)return;let l=await this._getEntryType(c);l==="directory"&&this._directoryFilter(c)?(i<=this._maxDepth&&this.parents.push(this._exploreDir(c.fullPath,i+1)),this._wantsDir&&(this.push(c),t--)):(l==="file"||this._includeAsFile(c))&&this._fileFilter(c)&&this._wantsFile&&(this.push(c),t--)}}else{let r=this.parents.pop();if(!r){this.push(null);break}if(this.parent=await r,this.destroyed)return}}}catch(e){this.destroy(e)}finally{this.reading=!1}}}async _exploreDir(t,e){let n;try{n=await Se(t,this._rdOptions)}catch(r){this._onError(r)}return{files:n,depth:e,path:t}}async _formatEntry(t,e){let n,r=this._isDirent?t.name:t;try{let i=zt(Le(e,r));n={path:Re(this._root,i),fullPath:i,basename:r},n[this._statsProp]=this._isDirent?t:await this._stat(i)}catch(i){this._onError(i);return}return n}_onError(t){be(t)&&!this.destroyed?this.emit("warn",t):this.destroy(t)}async _getEntryType(t){if(!t&&this._statsProp in t)return"";let e=t[this._statsProp];if(e.isFile())return"file";if(e.isDirectory())return"directory";if(e&&e.isSymbolicLink()){let n=t.fullPath;try{let r=await Pe(n),i=await kt(r);if(i.isFile())return"file";if(i.isDirectory()){let a=r.length;if(n.startsWith(r)&&n.substr(a,1)===De){let o=new Error(`Circular symlink detected: "${n}" points to "${r}"`);return o.code=Ut,this._onError(o)}return"directory"}}catch(r){return this._onError(r),""}}}_includeAsFile(t){let e=t&&t[this._statsProp];return e&&this._wantsEverything&&!e.isDirectory()}};function qt(s,t={}){let e=t.entryType||t.type;if(e==="both"&&(e=T.FILE_DIR_TYPE),e&&(t.type=e),s){if(typeof s!="string")throw new TypeError("readdirp: root argument must be a string. Usage: readdirp(root, options)");if(e&&!Wt.includes(e))throw new Error(`readdirp: Invalid type passed. Use one of ${Wt.join(", ")}`)}else throw new Error("readdirp: root argument is required. Usage: readdirp(root, options)");return t.root=s,new Z(t)}import{watchFile as Ce,unwatchFile as Yt,watch as Ie}from"fs";import{open as He,stat as Bt,lstat as Ne,realpath as tt}from"fs/promises";import*as w from"path";import{type as Fe}from"os";var ke="data",nt="end",Vt="close",U=()=>{};var q=f.platform,rt=q==="win32",ze=q==="darwin",We=q==="linux",$e=q==="freebsd",Kt=Fe()==="OS400",y={ALL:"all",READY:"ready",ADD:"add",CHANGE:"change",ADD_DIR:"addDir",UNLINK:"unlink",UNLINK_DIR:"unlinkDir",RAW:"raw",ERROR:"error"},_=y,je="watch",Ue={lstat:Ne,stat:Bt},v="listeners",z="errHandlers",D="rawEmitters",qe=[v,z,D],Ye=new Set(["3dm","3ds","3g2","3gp","7z","a","aac","adp","afdesign","afphoto","afpub","ai","aif","aiff","alz","ape","apk","appimage","ar","arj","asf","au","avi","bak","baml","bh","bin","bk","bmp","btif","bz2","bzip2","cab","caf","cgm","class","cmx","cpio","cr2","cur","dat","dcm","deb","dex","djvu","dll","dmg","dng","doc","docm","docx","dot","dotm","dra","DS_Store","dsk","dts","dtshd","dvb","dwg","dxf","ecelp4800","ecelp7470","ecelp9600","egg","eol","eot","epub","exe","f4v","fbs","fh","fla","flac","flatpak","fli","flv","fpx","fst","fvt","g3","gh","gif","graffle","gz","gzip","h261","h263","h264","icns","ico","ief","img","ipa","iso","jar","jpeg","jpg","jpgv","jpm","jxr","key","ktx","lha","lib","lvp","lz","lzh","lzma","lzo","m3u","m4a","m4v","mar","mdi","mht","mid","midi","mj2","mka","mkv","mmr","mng","mobi","mov","movie","mp3","mp4","mp4a","mpeg","mpg","mpga","mxu","nef","npx","numbers","nupkg","o","odp","ods","odt","oga","ogg","ogv","otf","ott","pages","pbm","pcx","pdb","pdf","pea","pgm","pic","png","pnm","pot","potm","potx","ppa","ppam","ppm","pps","ppsm","ppsx","ppt","pptm","pptx","psd","pya","pyc","pyo","pyv","qt","rar","ras","raw","resources","rgb","rip","rlc","rmf","rmvb","rpm","rtf","rz","s3m","s7z","scpt","sgi","shar","snap","sil","sketch","slk","smv","snk","so","stl","suo","sub","swf","tar","tbz","tbz2","tga","tgz","thmx","tif","tiff","tlz","ttc","ttf","txz","udf","uvh","uvi","uvm","uvp","uvs","uvu","viv","vob","war","wav","wax","wbmp","wdp","weba","webm","webp","whl","wim","wm","wma","wmv","wmx","woff","woff2","wrm","wvx","xbm","xif","xla","xlam","xls","xlsb","xlsm","xlsx","xlt","xltm","xltx","xm","xmind","xpi","xpm","xwd","xz","z","zip","zipx"]),Ge=s=>Ye.has(w.extname(s).slice(1).toLowerCase()),st=(s,t)=>{s instanceof Set?s.forEach(t):t(s)},A=(s,t,e)=>{let n=s[t];n instanceof Set||(s[t]=n=new Set([n])),n.add(e)},Be=s=>t=>{let e=s[t];e instanceof Set?e.clear():delete s[t]},M=(s,t,e)=>{let n=s[t];n instanceof Set?n.delete(e):n===e&&delete s[t]},Qt=s=>s instanceof Set?s.size===0:!s,W=new Map;function Gt(s,t,e,n,r){let i=(a,o)=>{e(s),r(a,o,{watchedPath:s}),o&&s!==o&&$(w.resolve(s,o),v,w.join(s,o))};try{return Ie(s,{persistent:t.persistent},i)}catch(a){n(a);return}}var $=(s,t,e,n,r)=>{let i=W.get(s);i&&st(i[t],a=>{a(e,n,r)})},Ve=(s,t,e,n)=>{let{listener:r,errHandler:i,rawEmitter:a}=n,o=W.get(t),c;if(!e.persistent)return c=Gt(s,e,r,i,a),c?c.close.bind(c):void 0;if(o)A(o,v,r),A(o,z,i),A(o,D,a);else{if(c=Gt(s,e,$.bind(null,t,v),i,$.bind(null,t,D)),!c)return;c.on(_.ERROR,async l=>{let u=$.bind(null,t,z);if(o&&(o.watcherUnusable=!0),rt&&l.code==="EPERM")try{await(await He(s,"r")).close(),u(l)}catch{}else u(l)}),o={listeners:r,errHandlers:i,rawEmitters:a,watcher:c},W.set(t,o)}return()=>{M(o,v,r),M(o,z,i),M(o,D,a),Qt(o.listeners)&&(o.watcher.close(),W.delete(t),qe.forEach(Be(o)),o.watcher=void 0,Object.freeze(o))}},et=new Map,Ke=(s,t,e,n)=>{let{listener:r,rawEmitter:i}=n,a=et.get(t),o=a&&a.options;return o&&(o.persistent<e.persistent||o.interval>e.interval)&&(Yt(t),a=void 0),a?(A(a,v,r),A(a,D,i)):(a={listeners:r,rawEmitters:i,options:e,watcher:Ce(t,e,(c,l)=>{st(a.rawEmitters,d=>{d(_.CHANGE,t,{curr:c,prev:l})});let u=c.mtimeMs;(c.size!==l.size||u>l.mtimeMs||u===0)&&st(a.listeners,d=>d(s,c))})},et.set(t,a)),()=>{M(a,v,r),M(a,D,i),Qt(a.listeners)&&(et.delete(t),Yt(t),a.options=a.watcher=void 0,Object.freeze(a))}},j=class{constructor(t){this.fsw=t,this._boundHandleError=e=>t._handleError(e)}_watchWithNodeFs(t,e){let n=this.fsw.options,r=w.dirname(t),i=w.basename(t);this.fsw._getWatchedDir(r).add(i);let o=w.resolve(t),c={persistent:n.persistent};e||(e=U);let l;if(n.usePolling){let u=n.interval!==n.binaryInterval;c.interval=u&&Ge(i)?n.binaryInterval:n.interval,l=Ke(t,o,c,{listener:e,rawEmitter:this.fsw._emitRaw})}else l=Ve(t,o,c,{listener:e,errHandler:this._boundHandleError,rawEmitter:this.fsw._emitRaw});return l}_handleFile(t,e,n){if(this.fsw.closed)return;let r=w.dirname(t),i=w.basename(t),a=this.fsw._getWatchedDir(r),o=e;if(a.has(i))return;let c=async(u,d)=>{if(this.fsw._throttle(je,t,5)){if(!d||d.mtimeMs===0)try{let h=await Bt(t);if(this.fsw.closed)return;let m=h.atimeMs,g=h.mtimeMs;if((!m||m<=g||g!==o.mtimeMs)&&this.fsw._emit(_.CHANGE,t,h),(ze||We||$e)&&o.ino!==h.ino){this.fsw._closeFile(u),o=h;let E=this._watchWithNodeFs(t,c);E&&this.fsw._addPathCloser(u,E)}else o=h}catch{this.fsw._remove(r,i)}else if(a.has(i)){let h=d.atimeMs,m=d.mtimeMs;(!h||h<=m||m!==o.mtimeMs)&&this.fsw._emit(_.CHANGE,t,d),o=d}}},l=this._watchWithNodeFs(t,c);if(!(n&&this.fsw.options.ignoreInitial)&&this.fsw._isntIgnored(t)){if(!this.fsw._throttle(_.ADD,t,0))return;this.fsw._emit(_.ADD,t,e)}return l}async _handleSymlink(t,e,n,r){if(this.fsw.closed)return;let i=t.fullPath,a=this.fsw._getWatchedDir(e);if(!this.fsw.options.followSymlinks){this.fsw._incrReadyCount();let o;try{o=await tt(n)}catch{return this.fsw._emitReady(),!0}return this.fsw.closed?void 0:(a.has(r)?this.fsw._symlinkPaths.get(i)!==o&&(this.fsw._symlinkPaths.set(i,o),this.fsw._emit(_.CHANGE,n,t.stats)):(a.add(r),this.fsw._symlinkPaths.set(i,o),this.fsw._emit(_.ADD,n,t.stats)),this.fsw._emitReady(),!0)}if(this.fsw._symlinkPaths.has(i))return!0;this.fsw._symlinkPaths.set(i,!0)}_handleRead(t,e,n,r,i,a,o){if(t=w.join(t,""),o=this.fsw._throttle("readdir",t,1e3),!o)return;let c=this.fsw._getWatchedDir(n.path),l=new Set,u=this.fsw._readdirp(t,{fileFilter:d=>n.filterPath(d),directoryFilter:d=>n.filterDir(d)});if(u)return u.on(ke,async d=>{if(this.fsw.closed){u=void 0;return}let h=d.path,m=w.join(t,h);if(l.add(h),!(d.stats.isSymbolicLink()&&await this._handleSymlink(d,t,m,h))){if(this.fsw.closed){u=void 0;return}(h===r||!r&&!c.has(h))&&(this.fsw._incrReadyCount(),m=w.join(i,w.relative(i,m)),this._addToNodeFs(m,e,n,a+1))}}).on(_.ERROR,this._boundHandleError),new Promise((d,h)=>{if(!u)return h();u.once(nt,()=>{if(this.fsw.closed){u=void 0;return}let m=o?o.clear():!1;d(void 0),c.getChildren().filter(g=>g!==t&&!l.has(g)).forEach(g=>{this.fsw._remove(t,g)}),u=void 0,m&&this._handleRead(t,!1,n,r,i,a,o)})})}async _handleDir(t,e,n,r,i,a,o){let c=this.fsw._getWatchedDir(w.dirname(t)),l=c.has(w.basename(t));!(n&&this.fsw.options.ignoreInitial)&&!i&&!l&&this.fsw._emit(_.ADD_DIR,t,e),c.add(w.basename(t)),this.fsw._getWatchedDir(t);let u,d,h=this.fsw.options.depth;if((h==null||r<=h)&&!this.fsw._symlinkPaths.has(o)){if(!i&&(await this._handleRead(t,n,a,i,t,r,u),this.fsw.closed))return;d=this._watchWithNodeFs(t,(m,g)=>{g&&g.mtimeMs===0||this._handleRead(m,!1,a,i,t,r,u)})}return d}async _addToNodeFs(t,e,n,r,i){let a=this.fsw._emitReady;if(this.fsw._isIgnored(t)||this.fsw.closed)return a(),!1;let o=this.fsw._getWatchHelpers(t);n&&(o.filterPath=c=>n.filterPath(c),o.filterDir=c=>n.filterDir(c));try{let c=await Ue[o.statMethod](o.watchPath);if(this.fsw.closed)return;if(this.fsw._isIgnored(o.watchPath,c))return a(),!1;let l=this.fsw.options.followSymlinks,u;if(c.isDirectory()){let d=w.resolve(t),h=l?await tt(t):t;if(this.fsw.closed||(u=await this._handleDir(o.watchPath,c,e,r,i,o,h),this.fsw.closed))return;d!==h&&h!==void 0&&this.fsw._symlinkPaths.set(d,h)}else if(c.isSymbolicLink()){let d=l?await tt(t):t;if(this.fsw.closed)return;let h=w.dirname(o.watchPath);if(this.fsw._getWatchedDir(h).add(o.watchPath),this.fsw._emit(_.ADD,o.watchPath,c),u=await this._handleDir(h,c,e,r,t,o,d),this.fsw.closed)return;d!==void 0&&this.fsw._symlinkPaths.set(w.resolve(t),d)}else u=this._handleFile(o.watchPath,c,e);return a(),u&&this.fsw._addPathCloser(t,u),!1}catch(c){if(this.fsw._handleError(c))return a(),t}}};var it="/",ts="//",se=".",es="..",ss="string",ns=/\\/g,Jt=/\/\//,rs=/\..*\.(sw[px])$|~$|\.subl.*\.tmp/,is=/^\.[/\\]/;function Y(s){return Array.isArray(s)?s:[s]}var ot=s=>typeof s=="object"&&s!==null&&!(s instanceof RegExp);function os(s){return typeof s=="function"?s:typeof s=="string"?t=>s===t:s instanceof RegExp?t=>s.test(t):typeof s=="object"&&s!==null?t=>{if(s.path===t)return!0;if(s.recursive){let e=p.relative(s.path,t);return e?!e.startsWith("..")&&!p.isAbsolute(e):!1}return!1}:()=>!1}function as(s){if(typeof s!="string")throw new Error("string expected");s=p.normalize(s),s=s.replace(/\\/g,"/");let t=!1;s.startsWith("//")&&(t=!0);let e=/\/\//;for(;s.match(e);)s=s.replace(e,"/");return t&&(s="/"+s),s}function Xt(s,t,e){let n=as(t);for(let r=0;r<s.length;r++){let i=s[r];if(i(n,e))return!0}return!1}function cs(s,t){if(s==null)throw new TypeError("anymatch: specify first argument");let n=Y(s).map(r=>os(r));return t==null?(r,i)=>Xt(n,r,i):Xt(n,t)}var Zt=s=>{let t=Y(s).flat();if(!t.every(e=>typeof e===ss))throw new TypeError(`Non-string provided as watch path: ${t}`);return t.map(ne)},te=s=>{let t=s.replace(ns,it),e=!1;for(t.startsWith(ts)&&(e=!0);t.match(Jt);)t=t.replace(Jt,it);return e&&(t=it+t),t},ne=s=>te(p.normalize(te(s))),ee=(s="")=>t=>typeof t=="string"?ne(p.isAbsolute(t)?t:p.join(s,t)):t,ls=(s,t)=>p.isAbsolute(s)?s:p.join(t,s),us=Object.freeze(new Set),at=class{constructor(t,e){this.path=t,this._removeWatcher=e,this.items=new Set}add(t){let{items:e}=this;e&&t!==se&&t!==es&&e.add(t)}async remove(t){let{items:e}=this;if(!e||(e.delete(t),e.size>0))return;let n=this.path;try{await Xe(n)}catch{this._removeWatcher&&this._removeWatcher(p.dirname(n),p.basename(n))}}has(t){let{items:e}=this;if(e)return e.has(t)}getChildren(){let{items:t}=this;return t?[...t.values()]:[]}dispose(){this.items.clear(),this.path="",this._removeWatcher=U,this.items=us,Object.freeze(this)}},ds="stat",hs="lstat",ct=class{constructor(t,e,n){this.fsw=n;let r=t;this.path=t=t.replace(is,""),this.watchPath=r,this.fullWatchPath=p.resolve(r),this.dirParts=[],this.dirParts.forEach(i=>{i.length>1&&i.pop()}),this.followSymlinks=e,this.statMethod=e?ds:hs}entryPath(t){return p.join(this.watchPath,p.relative(this.watchPath,t.fullPath))}filterPath(t){let{stats:e}=t;if(e&&e.isSymbolicLink())return this.filterDir(t);let n=this.entryPath(t);return this.fsw._isntIgnored(n,e)&&this.fsw._hasReadPermissions(e)}filterDir(t){return this.fsw._isntIgnored(this.entryPath(t),t.stats)}},G=class extends Ze{constructor(t={}){super(),this.closed=!1,this._closers=new Map,this._ignoredPaths=new Set,this._throttled=new Map,this._streams=new Set,this._symlinkPaths=new Map,this._watched=new Map,this._pendingWrites=new Map,this._pendingUnlinks=new Map,this._readyCount=0,this._readyEmitted=!1;let e=t.awaitWriteFinish,n={stabilityThreshold:2e3,pollInterval:100},r={persistent:!0,ignoreInitial:!1,ignorePermissionErrors:!1,interval:100,binaryInterval:300,followSymlinks:!0,usePolling:!1,atomic:!0,...t,ignored:t.ignored?Y(t.ignored):Y([]),awaitWriteFinish:e===!0?n:typeof e=="object"?{...n,...e}:!1};Kt&&(r.usePolling=!0),r.atomic===void 0&&(r.atomic=!r.usePolling);let i=f.env.CHOKIDAR_USEPOLLING;if(i!==void 0){let c=i.toLowerCase();c==="false"||c==="0"?r.usePolling=!1:c==="true"||c==="1"?r.usePolling=!0:r.usePolling=!!c}let a=f.env.CHOKIDAR_INTERVAL;a&&(r.interval=Number.parseInt(a,10));let o=0;this._emitReady=()=>{o++,o>=this._readyCount&&(this._emitReady=U,this._readyEmitted=!0,f.nextTick(()=>this.emit(y.READY)))},this._emitRaw=(...c)=>this.emit(y.RAW,...c),this._boundRemove=this._remove.bind(this),this.options=r,this._nodeFsHandler=new j(this),Object.freeze(r)}_addIgnoredPath(t){if(ot(t)){for(let e of this._ignoredPaths)if(ot(e)&&e.path===t.path&&e.recursive===t.recursive)return}this._ignoredPaths.add(t)}_removeIgnoredPath(t){if(this._ignoredPaths.delete(t),typeof t=="string")for(let e of this._ignoredPaths)ot(e)&&e.path===t&&this._ignoredPaths.delete(e)}add(t,e,n){let{cwd:r}=this.options;this.closed=!1,this._closePromise=void 0;let i=Zt(t);return r&&(i=i.map(a=>ls(a,r))),i.forEach(a=>{this._removeIgnoredPath(a)}),this._userIgnored=void 0,this._readyCount||(this._readyCount=0),this._readyCount+=i.length,Promise.all(i.map(async a=>{let o=await this._nodeFsHandler._addToNodeFs(a,!n,void 0,0,e);return o&&this._emitReady(),o})).then(a=>{this.closed||a.forEach(o=>{o&&this.add(p.dirname(o),p.basename(e||o))})}),this}unwatch(t){if(this.closed)return this;let e=Zt(t),{cwd:n}=this.options;return e.forEach(r=>{!p.isAbsolute(r)&&!this._closers.has(r)&&(n&&(r=p.join(n,r)),r=p.resolve(r)),this._closePath(r),this._addIgnoredPath(r),this._watched.has(r)&&this._addIgnoredPath({path:r,recursive:!0}),this._userIgnored=void 0}),this}close(){if(this._closePromise)return this._closePromise;this.closed=!0,this.removeAllListeners();let t=[];return this._closers.forEach(e=>e.forEach(n=>{let r=n();r instanceof Promise&&t.push(r)})),this._streams.forEach(e=>e.destroy()),this._userIgnored=void 0,this._readyCount=0,this._readyEmitted=!1,this._watched.forEach(e=>e.dispose()),this._closers.clear(),this._watched.clear(),this._streams.clear(),this._symlinkPaths.clear(),this._throttled.clear(),this._closePromise=t.length?Promise.all(t).then(()=>{}):Promise.resolve(),this._closePromise}getWatched(){let t={};return this._watched.forEach((e,n)=>{let i=(this.options.cwd?p.relative(this.options.cwd,n):n)||se;t[i]=e.getChildren().sort()}),t}emitWithAll(t,e){this.emit(t,...e),t!==y.ERROR&&this.emit(y.ALL,t,...e)}async _emit(t,e,n){if(this.closed)return;let r=this.options;rt&&(e=p.normalize(e)),r.cwd&&(e=p.relative(r.cwd,e));let i=[e];n!=null&&i.push(n);let a=r.awaitWriteFinish,o;if(a&&(o=this._pendingWrites.get(e)))return o.lastChange=new Date,this;if(r.atomic){if(t===y.UNLINK)return this._pendingUnlinks.set(e,[t,...i]),setTimeout(()=>{this._pendingUnlinks.forEach((c,l)=>{this.emit(...c),this.emit(y.ALL,...c),this._pendingUnlinks.delete(l)})},typeof r.atomic=="number"?r.atomic:100),this;t===y.ADD&&this._pendingUnlinks.has(e)&&(t=y.CHANGE,this._pendingUnlinks.delete(e))}if(a&&(t===y.ADD||t===y.CHANGE)&&this._readyEmitted){let c=(l,u)=>{l?(t=y.ERROR,i[0]=l,this.emitWithAll(t,i)):u&&(i.length>1?i[1]=u:i.push(u),this.emitWithAll(t,i))};return this._awaitWriteFinish(e,a.stabilityThreshold,t,c),this}if(t===y.CHANGE&&!this._throttle(y.CHANGE,e,50))return this;if(r.alwaysStat&&n===void 0&&(t===y.ADD||t===y.ADD_DIR||t===y.CHANGE)){let c=r.cwd?p.join(r.cwd,e):e,l;try{l=await Je(c)}catch{}if(!l||this.closed)return;i.push(l)}return this.emitWithAll(t,i),this}_handleError(t){let e=t&&t.code;return t&&e!=="ENOENT"&&e!=="ENOTDIR"&&(!this.options.ignorePermissionErrors||e!=="EPERM"&&e!=="EACCES")&&this.emit(y.ERROR,t),t||this.closed}_throttle(t,e,n){this._throttled.has(t)||this._throttled.set(t,new Map);let r=this._throttled.get(t);if(!r)throw new Error("invalid throttle");let i=r.get(e);if(i)return i.count++,!1;let a,o=()=>{let l=r.get(e),u=l?l.count:0;return r.delete(e),clearTimeout(a),l&&clearTimeout(l.timeoutObject),u};a=setTimeout(o,n);let c={timeoutObject:a,clear:o,count:0};return r.set(e,c),c}_incrReadyCount(){return this._readyCount++}_awaitWriteFinish(t,e,n,r){let i=this.options.awaitWriteFinish;if(typeof i!="object")return;let a=i.pollInterval,o,c=t;this.options.cwd&&!p.isAbsolute(t)&&(c=p.join(this.options.cwd,t));let l=new Date,u=this._pendingWrites;function d(h){Qe(c,(m,g)=>{if(m||!u.has(t)){m&&m.code!=="ENOENT"&&r(m);return}let E=Number(new Date);h&&g.size!==h.size&&(u.get(t).lastChange=E);let V=u.get(t);E-V.lastChange>=e?(u.delete(t),r(void 0,g)):o=setTimeout(d,a,g)})}u.has(t)||(u.set(t,{lastChange:l,cancelWait:()=>(u.delete(t),clearTimeout(o),n)}),o=setTimeout(d,a))}_isIgnored(t,e){if(this.options.atomic&&rs.test(t))return!0;if(!this._userIgnored){let{cwd:n}=this.options,i=(this.options.ignored||[]).map(ee(n)),o=[...[...this._ignoredPaths].map(ee(n)),...i];this._userIgnored=cs(o,void 0)}return this._userIgnored(t,e)}_isntIgnored(t,e){return!this._isIgnored(t,e)}_getWatchHelpers(t){return new ct(t,this.options.followSymlinks,this)}_getWatchedDir(t){let e=p.resolve(t);return this._watched.has(e)||this._watched.set(e,new at(e,this._boundRemove)),this._watched.get(e)}_hasReadPermissions(t){return this.options.ignorePermissionErrors?!0:!!(Number(t.mode)&256)}_remove(t,e,n){let r=p.join(t,e),i=p.resolve(r);if(n=n??(this._watched.has(r)||this._watched.has(i)),!this._throttle("remove",r,100))return;!n&&this._watched.size===1&&this.add(t,e,!0),this._getWatchedDir(r).getChildren().forEach(h=>this._remove(r,h));let c=this._getWatchedDir(t),l=c.has(e);c.remove(e),this._symlinkPaths.has(i)&&this._symlinkPaths.delete(i);let u=r;if(this.options.cwd&&(u=p.relative(this.options.cwd,r)),this.options.awaitWriteFinish&&this._pendingWrites.has(u)&&this._pendingWrites.get(u).cancelWait()===y.ADD)return;this._watched.delete(r),this._watched.delete(i);let d=n?y.UNLINK_DIR:y.UNLINK;l&&!this._isIgnored(r)&&this._emit(d,r),this._closePath(r)}_closePath(t){this._closeFile(t);let e=p.dirname(t);this._getWatchedDir(e).remove(p.basename(t))}_closeFile(t){let e=this._closers.get(t);e&&(e.forEach(n=>n()),this._closers.delete(t))}_addPathCloser(t,e){if(!e)return;let n=this._closers.get(t);n||(n=[],this._closers.set(t,n)),n.push(e)}_readdirp(t,e){if(this.closed)return;let n={type:y.ALL,alwaysStat:!0,lstat:!0,...e,depth:0},r=qt(t,n);return this._streams.add(r),r.once(Vt,()=>{r=void 0}),r.once(nt,()=>{r&&(this._streams.delete(r),r=void 0)}),r}};function fs(s,t={}){let e=new G(t);return e.add(s),e}var lt={watch:fs,FSWatcher:G};var x=S.resolve("src/pages"),re=S.resolve("src/gen"),ie=S.resolve("src/routes"),ms=S.join(re,"tsrouter.gen.ts"),B=S.join(ie,"__root.ts"),ps=async()=>{async function s(c){try{await R.mkdir(c,{recursive:!0})}catch{}}await s(re),await s(ie);function t(c,l){let u="/"+S.relative(l,c).replace(/\\/g,"/");return u=u.replace(/\.ts$/,""),u=u.replace(/\/index$/,"")||"/",u=u.replace(/\[(.+?)\]/g,":$1"),u}function e(c){return c.replace(/^\//,"").split("/").map(l=>l.startsWith(":")?l.slice(1):l).filter(Boolean).join("-")||"index"}function n(c,l){let d=S.relative(l,c).replace(/\\/g,"/").split("/").filter(Boolean),h=d[d.length-1].replace(".ts",""),m=d.length>1?d[d.length-2]:"";if(h.startsWith("[")&&h.endsWith("]")){let g=h.slice(1,-1);return m.charAt(0).toUpperCase()+m.slice(1)+g.charAt(0).toUpperCase()+g.slice(1)+"Param"}else return h.charAt(0).toUpperCase()+h.slice(1)}async function r(c){let l=await R.readdir(c,{withFileTypes:!0}),u=[];for(let d of l){let h=S.join(c,d.name);if(d.isDirectory())u=u.concat(await r(h));else if(d.isFile()&&d.name.endsWith(".ts")){let m=t(h,x),g=e(m),E=n(h,x);u.push({file:h,route:m,routeName:g,importName:E})}}return u}function i(c,l){return`import { html, useTSElements, useTSExtractParams, useTSMetaData } from '@devwareng/vanilla-ts'
|
|
2
|
+
|
|
3
|
+
export default function ${c}(DOM: HTMLElement) {
|
|
4
|
+
useTSMetaData({
|
|
5
|
+
name: '${c.toLowerCase()}',
|
|
6
|
+
description: '',
|
|
7
|
+
author: ''
|
|
8
|
+
});
|
|
9
|
+
|
|
10
|
+
const params = useTSExtractParams("${l}")
|
|
11
|
+
|
|
12
|
+
return useTSElements(
|
|
13
|
+
DOM,
|
|
14
|
+
html\`
|
|
15
|
+
<div class="p-4">
|
|
16
|
+
<h1 class="font-semibold">${c}</h1>
|
|
17
|
+
<pre>\${JSON.stringify(params, null, 2)}</pre>
|
|
18
|
+
</div>
|
|
19
|
+
\`
|
|
20
|
+
)
|
|
21
|
+
}`}function a(){return`import { createRouter } from "@/gen/tsrouter.gen"
|
|
22
|
+
import { useTSParams } from "@devwareng/vanilla-ts"
|
|
23
|
+
|
|
24
|
+
// AUTO-GENERATED FILE. DO NOT EDIT MANUALLY.
|
|
25
|
+
|
|
26
|
+
export const Router = (DOM: HTMLElement) => {
|
|
27
|
+
useTSParams.getState()
|
|
28
|
+
const router = createRouter(DOM)
|
|
29
|
+
router.navigate(window.location.pathname)
|
|
30
|
+
|
|
31
|
+
window.addEventListener("popstate", () => {
|
|
32
|
+
router.navigate(window.location.pathname)
|
|
33
|
+
})
|
|
34
|
+
}`}async function o(){let c=await r(x),l=c.find(E=>E.route==="/notfound"),u=c.filter(E=>E.route!=="/notfound"),d=c.map(E=>{let V="../pages/"+S.relative(x,E.file).replace(/\\/g,"/").replace(/\.ts$/,"");return`import ${E.importName} from "${V}";`}).join(`
|
|
35
|
+
`),h=u.map(E=>`{ path: "${E.route}", name: "${E.routeName}", component: (DOM: HTMLElement) => ${E.importName}(DOM) }`).join(`,
|
|
36
|
+
`),m=l?`export const NotFound = ${l.importName}`:"export function NotFound(DOM: HTMLElement) {\n return useTSElements(DOM, html`<div><h1>404 - Page Not Found</h1></div>`)\n}",g=`// AUTO-GENERATED FILE. DO NOT EDIT MANUALLY.
|
|
37
|
+
import { html, useTSElements } from "@devwareng/vanilla-ts"
|
|
38
|
+
|
|
39
|
+
${d}
|
|
40
|
+
|
|
41
|
+
${m}
|
|
42
|
+
|
|
43
|
+
export function RootDocument(DOM: HTMLElement) {
|
|
44
|
+
return useTSElements(DOM, html\`<div><h1>Root</h1></div>\`)
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
export const routeTree = [
|
|
48
|
+
${h}
|
|
49
|
+
]
|
|
50
|
+
|
|
51
|
+
export function createRouter(DOM: HTMLElement) {
|
|
52
|
+
function matchRoute(path: string) {
|
|
53
|
+
for (const route of routeTree) {
|
|
54
|
+
const keys: string[] = []
|
|
55
|
+
const regex = new RegExp("^" + route.path.replace(/:([^/]+)/g, (_, key) => {
|
|
56
|
+
keys.push(key)
|
|
57
|
+
return "([^/]+)"
|
|
58
|
+
}) + "$")
|
|
59
|
+
const pathname = path.split("?")[0]
|
|
60
|
+
const match = pathname.match(regex)
|
|
61
|
+
if (match) {
|
|
62
|
+
const params: Record<string, string> = {}
|
|
63
|
+
keys.forEach((key, i) => (params[key] = match[i + 1]))
|
|
64
|
+
return { ...route, params }
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
return null
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
function navigate(path: string) {
|
|
71
|
+
const match = matchRoute(path)
|
|
72
|
+
if (match) {
|
|
73
|
+
match.component(DOM)
|
|
74
|
+
history.pushState({}, "", path)
|
|
75
|
+
} else {
|
|
76
|
+
NotFound(DOM)
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
window.addEventListener("popstate", () => {
|
|
81
|
+
const path = window.location.pathname + window.location.search
|
|
82
|
+
const match = matchRoute(path)
|
|
83
|
+
if (match) {
|
|
84
|
+
match.component(DOM)
|
|
85
|
+
} else {
|
|
86
|
+
NotFound(DOM)
|
|
87
|
+
}
|
|
88
|
+
})
|
|
89
|
+
|
|
90
|
+
navigate(window.location.pathname + window.location.search)
|
|
91
|
+
|
|
92
|
+
return { navigate, routes: routeTree }
|
|
93
|
+
}
|
|
94
|
+
`;await R.writeFile(ms,g,"utf-8"),await R.writeFile(B,a(),"utf-8"),console.log("\u2705 Generated router and __root.ts")}console.log("\u{1F440} Watching for changes in /src/pages and /src/routes/__root.ts..."),lt.watch(x).on("all",async(c,l)=>{if(c==="add"&&l.endsWith(".ts")){let u=S.basename(l,".ts"),d=u.replace(/\[|\]/g,"Param").replace(/(^\w|-\w)/g,g=>g.replace("-","").toUpperCase()),h=t(l,x);(await R.readFile(l,"utf-8")).trim()||(await R.writeFile(l,i(d,h),"utf-8"),console.log(`\u{1F4DD} Scaffolded page: ${u}.ts`))}await o()}),lt.watch(B).on("unlink",async()=>{console.log("\u26A0\uFE0F __root.ts deleted. Recreating..."),await R.writeFile(B,a(),"utf-8"),console.log("\u{1F7E2} Recreated:",B)}),console.log("\u{1F7E2} TS Filebased Router Mounted Successfully...")};typeof window<"u"&&(window.addEventListener("popstate",()=>{b()}),document.addEventListener("DOMContentLoaded",b));export{J as TSRouter,Mt as createEffect,At as createSignal,ut as html,Ct as loadPyFiles,ce as mapper,xt as renderChildRoutes,F as useAnchor,Tt as useAnchorSingle,wt as useInitialDOM,bt as useTSAnchorMount,Rt as useTSAuth,Pt as useTSCollection,I as useTSComponent,H as useTSElementEach,Et as useTSElements,ft as useTSEvent,gt as useTSEventAll,pt as useTSExtractParams,ps as useTSFilebasedRouter,N as useTSHashAnchor,It as useTSLazy,St as useTSMetaData,Lt as useTSNavigate,k as useTSNoReload,Dt as useTSOutlet,O as useTSParams,ht as useTSPurifier,Ht as useTSSSRHydration,vt as useTSSelect,Ot as useTSloadBrython};
|
|
95
|
+
/*! Bundled license information:
|
|
96
|
+
|
|
97
|
+
chokidar/esm/index.js:
|
|
98
|
+
(*! chokidar - MIT License (c) 2012 Paul Miller (paulmillr.com) *)
|
|
99
|
+
*/
|