@devwareng/vanilla-ts 1.4.10 → 1.4.11

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.d.cts CHANGED
@@ -144,6 +144,8 @@ declare const useTSHashAnchor: () => void;
144
144
  type AnchorInput = NodeListOf<HTMLAnchorElement> | HTMLAnchorElement[] | HTMLAnchorElement | null | undefined;
145
145
  declare const useAnchor: (anchors?: AnchorInput) => void;
146
146
 
147
+ declare function generate(): any;
148
+
147
149
  type RouteCallback = (errorElement?: HTMLElement, params?: Record<string, string>, query?: Record<string, string>) => void;
148
150
  interface RouteConfig {
149
151
  path: string;
@@ -166,4 +168,4 @@ declare class TSRouter {
166
168
  addRoute(route: RouteConfig): void;
167
169
  }
168
170
 
169
- export { TSRouter, createEffect, createSignal, html, loadPyFiles, mapper, renderChildRoutes, useAnchor, useAnchorSingle, useInitialDOM, useTSAnchorMount, useTSAuth, useTSCollection, useTSComponent, useTSElementEach, useTSElements, useTSEvent, useTSEventAll, useTSExtractParams, useTSHashAnchor, useTSLazy, useTSMetaData, useTSNavigate, useTSNoReload, useTSOutlet, useTSParams, useTSPurifier, useTSSSRHydration, useTSSelect, useTSloadBrython };
171
+ export { TSRouter, createEffect, createSignal, html, loadPyFiles, mapper, renderChildRoutes, useAnchor, useAnchorSingle, useInitialDOM, useTSAnchorMount, useTSAuth, useTSCollection, useTSComponent, useTSElementEach, useTSElements, useTSEvent, useTSEventAll, useTSExtractParams, generate as useTSFilebasedRouter, useTSHashAnchor, useTSLazy, useTSMetaData, useTSNavigate, useTSNoReload, useTSOutlet, useTSParams, useTSPurifier, useTSSSRHydration, useTSSelect, useTSloadBrython };
package/dist/index.d.ts CHANGED
@@ -144,6 +144,8 @@ declare const useTSHashAnchor: () => void;
144
144
  type AnchorInput = NodeListOf<HTMLAnchorElement> | HTMLAnchorElement[] | HTMLAnchorElement | null | undefined;
145
145
  declare const useAnchor: (anchors?: AnchorInput) => void;
146
146
 
147
+ declare function generate(): any;
148
+
147
149
  type RouteCallback = (errorElement?: HTMLElement, params?: Record<string, string>, query?: Record<string, string>) => void;
148
150
  interface RouteConfig {
149
151
  path: string;
@@ -166,4 +168,4 @@ declare class TSRouter {
166
168
  addRoute(route: RouteConfig): void;
167
169
  }
168
170
 
169
- export { TSRouter, createEffect, createSignal, html, loadPyFiles, mapper, renderChildRoutes, useAnchor, useAnchorSingle, useInitialDOM, useTSAnchorMount, useTSAuth, useTSCollection, useTSComponent, useTSElementEach, useTSElements, useTSEvent, useTSEventAll, useTSExtractParams, useTSHashAnchor, useTSLazy, useTSMetaData, useTSNavigate, useTSNoReload, useTSOutlet, useTSParams, useTSPurifier, useTSSSRHydration, useTSSelect, useTSloadBrython };
171
+ export { TSRouter, createEffect, createSignal, html, loadPyFiles, mapper, renderChildRoutes, useAnchor, useAnchorSingle, useInitialDOM, useTSAnchorMount, useTSAuth, useTSCollection, useTSComponent, useTSElementEach, useTSElements, useTSEvent, useTSEventAll, useTSExtractParams, generate as useTSFilebasedRouter, useTSHashAnchor, useTSLazy, useTSMetaData, useTSNavigate, useTSNoReload, useTSOutlet, useTSParams, useTSPurifier, useTSSSRHydration, useTSSelect, useTSloadBrython };
package/dist/index.js CHANGED
@@ -1,2 +1,101 @@
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};
1
+ function ce(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 dt(s,...t){return s.reduce((e,n,r)=>{let i=r<t.length?ce(t[r]):"";return e+n+i},"")}function M(){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 le=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,""),ue=s=>s?.map(t=>le(t)).join("")??"";import ht from"dompurify";var ft=(s,t)=>{let n={...{ADD_TAGS:["my-custom-tag"]},...t};return typeof s=="string"?ht.sanitize(s,n):ht.sanitize(s.innerHTML,n)};var mt=(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 de}from"zustand/vanilla";import pt from"dompurify";function he(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]=pt.sanitize(i[c+1]??"")}),a}function fe(s){let t={},e=new URLSearchParams(s);for(let[n,r]of e.entries())t[n]=pt.sanitize(r);return t}var b=de((s,t)=>({params:{},query:{},setFromPattern:e=>{let n=window.location.pathname,r=he(e,n),i=fe(window.location.search);s({params:r,query:i})},getParam:e=>t().params[e],getQuery:e=>t().query[e]}));function gt(s){let t=b.getState();t.setFromPattern(s);let e=t.params,n=t.query;return{...e,...n}}var Et=(s,t,e)=>{let n=document.querySelectorAll(s);return n.forEach(r=>{r.addEventListener(t,e)}),()=>{n.forEach(r=>{r.removeEventListener(t,e)})}};import G from"dompurify";var wt=(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};G.addHook("uponSanitizeElement",(a,o)=>{let c=o.tagName.toLowerCase();c.includes("-")&&(o.allowedTags[c]=!0)}),G.addHook("uponSanitizeAttribute",(a,o)=>{o.attrName&&o.attrName.toLowerCase().startsWith("on")&&(o.keepAttr=!1)});let i=G.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 me from"dompurify";var O=null,yt=(s,t)=>{if(typeof document>"u")return;let e=document.getElementById(s);if(!e)return;let n=e.innerHTML,i=me.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(O!==null&&i!==O){let a=document.createElement("div");t(a),e.innerHTML=O}else O=i,e.innerHTML=i,t(e)};import Tt 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 _t=(s,t,e,n="",r=null)=>{if(!s)return;let i=Tt.sanitize(t,{ALLOWED_URI_REGEXP:/^(https?:|\/)/}),a=Tt.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 R from"dompurify";var St=(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 Pt=(s,t)=>{let e={name:R.sanitize(s.name||""),description:R.sanitize(s.description||"Default description"),author:R.sanitize(s.author||"")},n=m=>{e.name=R.sanitize(m),d("name",e.name)},r=m=>{e.description=R.sanitize(m),d("description",e.description)},i=m=>{e.author=R.sanitize(m),d("author",e.author)},a=()=>e.name,o=()=>e.description,c=()=>e.author,l=()=>e,u=(m,E)=>{let y=document.createElement("meta");y.setAttribute("name",m),y.setAttribute("content",E),document.head.appendChild(y)},d=(m,E)=>{let y=document.querySelector(`meta[name="${m}"]`);y?y.setAttribute("content",E):u(m,E)},h=()=>{d("name",e.name),d("description",e.description),d("author",e.author)};return t&&St(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 pe from"dompurify";var C=(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=pe.sanitize(o.innerHTML,{USE_PROFILES:{html:!0}}),e(o,n,r)};var vt=(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"?C(i,t,c,l):console.warn(`[useTSCollection] No valid component function found for ID: "${i}"`)})};var Rt=(s,t)=>{let n=(t??document).querySelectorAll(s);if(n.length===0)return process.env.NODE_ENV!=="production"&&console.warn(`[useTSSelect] No element found for selector: '${s}'`),null;if(s.startsWith("#")&&n.length>1){if(process.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&&process.env.NODE_ENV!=="production"&&console.warn(`[useTSSelect] Multiple elements found for selector: '${s}'. Returning the first one.`),n[0]};import{jwtDecode as ge}from"jwt-decode";var Lt=(s,t)=>{let e=localStorage.getItem("token");if(!e)return window.location.href=t,null;try{let n=ge(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 I=(s,t,e)=>{s.forEach(n=>{t.forEach(r=>{n.addEventListener(r,i=>{e(n,i)})})})};var Dt=()=>({back:()=>window.history.back(),forward:()=>window.history.forward()});var xt=(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 At(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 Ee}from"zustand/vanilla";function Mt(s){let t=Ee(()=>({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 bt(s){let t=s();typeof t=="function"&&t()}var H=()=>{let s=document.querySelectorAll('a[href^="#"]');I(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 we}from"lodash-es";var B=s=>s;typeof window<"u"&&typeof document<"u"&&(B=s=>{let t=document.createElement("div");return t.innerText=s,t.innerHTML});var ye=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",B(n));let r=e.getAttribute("aria-label");r&&e.setAttribute("aria-label",B(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)}})}})},Te=we(ye,50),N=s=>{Te(s)};var F=s=>{let t=s.querySelectorAll("a");N(t)};var Ot=s=>{H(),F(s)};var Ct=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.")},It=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 Ht(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 Nt=s=>typeof window>"u"?{isDOM:null}:{isDOM:s||document.body};import S from"fs";import _ 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 f from"path";import{stat as _e,lstat as Ft,readdir as Se,realpath as Pe}from"fs/promises";import{Readable as ve}from"stream";import{resolve as kt,relative as Re,join as Le,sep as De}from"path";var w={FILE_TYPE:"files",DIR_TYPE:"directories",FILE_DIR_TYPE:"files_directories",EVERYTHING_TYPE:"all"},V={root:".",fileFilter:s=>!0,directoryFilter:s=>!0,type:w.FILE_TYPE,lstat:!1,depth:2147483648,alwaysStat:!1,highWaterMark:4096};Object.freeze(V);var jt="READDIRP_RECURSIVE_ERROR",xe=new Set(["ENOENT","EPERM","EACCES","ELOOP",jt]),zt=[w.DIR_TYPE,w.EVERYTHING_TYPE,w.FILE_DIR_TYPE,w.FILE_TYPE],Ae=new Set([w.DIR_TYPE,w.EVERYTHING_TYPE,w.FILE_DIR_TYPE]),Me=new Set([w.EVERYTHING_TYPE,w.FILE_DIR_TYPE,w.FILE_TYPE]),be=s=>xe.has(s.code),Oe=process.platform==="win32",Wt=s=>!0,$t=s=>{if(s===void 0)return Wt;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 Wt},K=class extends ve{constructor(t={}){super({objectMode:!0,autoDestroy:!0,highWaterMark:t.highWaterMark});let e={...V,...t},{root:n,type:r}=e;this._fileFilter=$t(e.fileFilter),this._directoryFilter=$t(e.directoryFilter);let i=e.lstat?Ft:_e;Oe?this._stat=a=>i(a,{bigint:!0}):this._stat=i,this._maxDepth=e.depth??V.depth,this._wantsDir=r?Ae.has(r):!1,this._wantsFile=r?Me.has(r):!1,this._wantsEverything=r===w.EVERYTHING_TYPE,this._root=kt(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=kt(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 Ft(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=jt,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 Ut(s,t={}){let e=t.entryType||t.type;if(e==="both"&&(e=w.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&&!zt.includes(e))throw new Error(`readdirp: Invalid type passed. Use one of ${zt.join(", ")}`)}else throw new Error("readdirp: root argument is required. Usage: readdirp(root, options)");return t.root=s,new K(t)}import{watchFile as Ce,unwatchFile as qt,watch as Ie}from"fs";import{open as He,stat as Gt,lstat as Ne,realpath as Q}from"fs/promises";import*as p from"path";import{type as Fe}from"os";var ke="data",Z="end",Bt="close",j=()=>{};var U=process.platform,tt=U==="win32",ze=U==="darwin",We=U==="linux",$e=U==="freebsd",Vt=Fe()==="OS400",g={ALL:"all",READY:"ready",ADD:"add",CHANGE:"change",ADD_DIR:"addDir",UNLINK:"unlink",UNLINK_DIR:"unlinkDir",RAW:"raw",ERROR:"error"},T=g,je="watch",Ue={lstat:Ne,stat:Gt},v="listeners",k="errHandlers",L="rawEmitters",qe=[v,k,L],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(p.extname(s).slice(1).toLowerCase()),X=(s,t)=>{s instanceof Set?s.forEach(t):t(s)},x=(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]},A=(s,t,e)=>{let n=s[t];n instanceof Set?n.delete(e):n===e&&delete s[t]},Kt=s=>s instanceof Set?s.size===0:!s,z=new Map;function Yt(s,t,e,n,r){let i=(a,o)=>{e(s),r(a,o,{watchedPath:s}),o&&s!==o&&W(p.resolve(s,o),v,p.join(s,o))};try{return Ie(s,{persistent:t.persistent},i)}catch(a){n(a);return}}var W=(s,t,e,n,r)=>{let i=z.get(s);i&&X(i[t],a=>{a(e,n,r)})},Ve=(s,t,e,n)=>{let{listener:r,errHandler:i,rawEmitter:a}=n,o=z.get(t),c;if(!e.persistent)return c=Yt(s,e,r,i,a),c?c.close.bind(c):void 0;if(o)x(o,v,r),x(o,k,i),x(o,L,a);else{if(c=Yt(s,e,W.bind(null,t,v),i,W.bind(null,t,L)),!c)return;c.on(T.ERROR,async l=>{let u=W.bind(null,t,k);if(o&&(o.watcherUnusable=!0),tt&&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},z.set(t,o)}return()=>{A(o,v,r),A(o,k,i),A(o,L,a),Kt(o.listeners)&&(o.watcher.close(),z.delete(t),qe.forEach(Be(o)),o.watcher=void 0,Object.freeze(o))}},J=new Map,Ke=(s,t,e,n)=>{let{listener:r,rawEmitter:i}=n,a=J.get(t),o=a&&a.options;return o&&(o.persistent<e.persistent||o.interval>e.interval)&&(qt(t),a=void 0),a?(x(a,v,r),x(a,L,i)):(a={listeners:r,rawEmitters:i,options:e,watcher:Ce(t,e,(c,l)=>{X(a.rawEmitters,d=>{d(T.CHANGE,t,{curr:c,prev:l})});let u=c.mtimeMs;(c.size!==l.size||u>l.mtimeMs||u===0)&&X(a.listeners,d=>d(s,c))})},J.set(t,a)),()=>{A(a,v,r),A(a,L,i),Kt(a.listeners)&&(J.delete(t),qt(t),a.options=a.watcher=void 0,Object.freeze(a))}},$=class{constructor(t){this.fsw=t,this._boundHandleError=e=>t._handleError(e)}_watchWithNodeFs(t,e){let n=this.fsw.options,r=p.dirname(t),i=p.basename(t);this.fsw._getWatchedDir(r).add(i);let o=p.resolve(t),c={persistent:n.persistent};e||(e=j);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=p.dirname(t),i=p.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 Gt(t);if(this.fsw.closed)return;let m=h.atimeMs,E=h.mtimeMs;if((!m||m<=E||E!==o.mtimeMs)&&this.fsw._emit(T.CHANGE,t,h),(ze||We||$e)&&o.ino!==h.ino){this.fsw._closeFile(u),o=h;let y=this._watchWithNodeFs(t,c);y&&this.fsw._addPathCloser(u,y)}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(T.CHANGE,t,d),o=d}}},l=this._watchWithNodeFs(t,c);if(!(n&&this.fsw.options.ignoreInitial)&&this.fsw._isntIgnored(t)){if(!this.fsw._throttle(T.ADD,t,0))return;this.fsw._emit(T.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 Q(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(T.CHANGE,n,t.stats)):(a.add(r),this.fsw._symlinkPaths.set(i,o),this.fsw._emit(T.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=p.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=p.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=p.join(i,p.relative(i,m)),this._addToNodeFs(m,e,n,a+1))}}).on(T.ERROR,this._boundHandleError),new Promise((d,h)=>{if(!u)return h();u.once(Z,()=>{if(this.fsw.closed){u=void 0;return}let m=o?o.clear():!1;d(void 0),c.getChildren().filter(E=>E!==t&&!l.has(E)).forEach(E=>{this.fsw._remove(t,E)}),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(p.dirname(t)),l=c.has(p.basename(t));!(n&&this.fsw.options.ignoreInitial)&&!i&&!l&&this.fsw._emit(T.ADD_DIR,t,e),c.add(p.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,E)=>{E&&E.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=p.resolve(t),h=l?await Q(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 Q(t):t;if(this.fsw.closed)return;let h=p.dirname(o.watchPath);if(this.fsw._getWatchedDir(h).add(o.watchPath),this.fsw._emit(T.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(p.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 et="/",ts="//",ee=".",es="..",ss="string",ns=/\\/g,Qt=/\/\//,rs=/\..*\.(sw[px])$|~$|\.subl.*\.tmp/,is=/^\.[/\\]/;function q(s){return Array.isArray(s)?s:[s]}var st=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=f.relative(s.path,t);return e?!e.startsWith("..")&&!f.isAbsolute(e):!1}return!1}:()=>!1}function as(s){if(typeof s!="string")throw new Error("string expected");s=f.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 Jt(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=q(s).map(r=>os(r));return t==null?(r,i)=>Jt(n,r,i):Jt(n,t)}var Xt=s=>{let t=q(s).flat();if(!t.every(e=>typeof e===ss))throw new TypeError(`Non-string provided as watch path: ${t}`);return t.map(se)},Zt=s=>{let t=s.replace(ns,et),e=!1;for(t.startsWith(ts)&&(e=!0);t.match(Qt);)t=t.replace(Qt,et);return e&&(t=et+t),t},se=s=>Zt(f.normalize(Zt(s))),te=(s="")=>t=>typeof t=="string"?se(f.isAbsolute(t)?t:f.join(s,t)):t,ls=(s,t)=>f.isAbsolute(s)?s:f.join(t,s),us=Object.freeze(new Set),nt=class{constructor(t,e){this.path=t,this._removeWatcher=e,this.items=new Set}add(t){let{items:e}=this;e&&t!==ee&&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(f.dirname(n),f.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=j,this.items=us,Object.freeze(this)}},ds="stat",hs="lstat",rt=class{constructor(t,e,n){this.fsw=n;let r=t;this.path=t=t.replace(is,""),this.watchPath=r,this.fullWatchPath=f.resolve(r),this.dirParts=[],this.dirParts.forEach(i=>{i.length>1&&i.pop()}),this.followSymlinks=e,this.statMethod=e?ds:hs}entryPath(t){return f.join(this.watchPath,f.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)}},Y=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?q(t.ignored):q([]),awaitWriteFinish:e===!0?n:typeof e=="object"?{...n,...e}:!1};Vt&&(r.usePolling=!0),r.atomic===void 0&&(r.atomic=!r.usePolling);let i=process.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=process.env.CHOKIDAR_INTERVAL;a&&(r.interval=Number.parseInt(a,10));let o=0;this._emitReady=()=>{o++,o>=this._readyCount&&(this._emitReady=j,this._readyEmitted=!0,process.nextTick(()=>this.emit(g.READY)))},this._emitRaw=(...c)=>this.emit(g.RAW,...c),this._boundRemove=this._remove.bind(this),this.options=r,this._nodeFsHandler=new $(this),Object.freeze(r)}_addIgnoredPath(t){if(st(t)){for(let e of this._ignoredPaths)if(st(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)st(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=Xt(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(f.dirname(o),f.basename(e||o))})}),this}unwatch(t){if(this.closed)return this;let e=Xt(t),{cwd:n}=this.options;return e.forEach(r=>{!f.isAbsolute(r)&&!this._closers.has(r)&&(n&&(r=f.join(n,r)),r=f.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?f.relative(this.options.cwd,n):n)||ee;t[i]=e.getChildren().sort()}),t}emitWithAll(t,e){this.emit(t,...e),t!==g.ERROR&&this.emit(g.ALL,t,...e)}async _emit(t,e,n){if(this.closed)return;let r=this.options;tt&&(e=f.normalize(e)),r.cwd&&(e=f.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===g.UNLINK)return this._pendingUnlinks.set(e,[t,...i]),setTimeout(()=>{this._pendingUnlinks.forEach((c,l)=>{this.emit(...c),this.emit(g.ALL,...c),this._pendingUnlinks.delete(l)})},typeof r.atomic=="number"?r.atomic:100),this;t===g.ADD&&this._pendingUnlinks.has(e)&&(t=g.CHANGE,this._pendingUnlinks.delete(e))}if(a&&(t===g.ADD||t===g.CHANGE)&&this._readyEmitted){let c=(l,u)=>{l?(t=g.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===g.CHANGE&&!this._throttle(g.CHANGE,e,50))return this;if(r.alwaysStat&&n===void 0&&(t===g.ADD||t===g.ADD_DIR||t===g.CHANGE)){let c=r.cwd?f.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(g.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&&!f.isAbsolute(t)&&(c=f.join(this.options.cwd,t));let l=new Date,u=this._pendingWrites;function d(h){Qe(c,(m,E)=>{if(m||!u.has(t)){m&&m.code!=="ENOENT"&&r(m);return}let y=Number(new Date);h&&E.size!==h.size&&(u.get(t).lastChange=y);let ae=u.get(t);y-ae.lastChange>=e?(u.delete(t),r(void 0,E)):o=setTimeout(d,a,E)})}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(te(n)),o=[...[...this._ignoredPaths].map(te(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 rt(t,this.options.followSymlinks,this)}_getWatchedDir(t){let e=f.resolve(t);return this._watched.has(e)||this._watched.set(e,new nt(e,this._boundRemove)),this._watched.get(e)}_hasReadPermissions(t){return this.options.ignorePermissionErrors?!0:!!(Number(t.mode)&256)}_remove(t,e,n){let r=f.join(t,e),i=f.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=f.relative(this.options.cwd,r)),this.options.awaitWriteFinish&&this._pendingWrites.has(u)&&this._pendingWrites.get(u).cancelWait()===g.ADD)return;this._watched.delete(r),this._watched.delete(i);let d=n?g.UNLINK_DIR:g.UNLINK;l&&!this._isIgnored(r)&&this._emit(d,r),this._closePath(r)}_closePath(t){this._closeFile(t);let e=f.dirname(t);this._getWatchedDir(e).remove(f.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:g.ALL,alwaysStat:!0,lstat:!0,...e,depth:0},r=Ut(t,n);return this._streams.add(r),r.once(Bt,()=>{r=void 0}),r.once(Z,()=>{r&&(this._streams.delete(r),r=void 0)}),r}};function fs(s,t={}){let e=new Y(t);return e.add(s),e}var it={watch:fs,FSWatcher:Y};var D=_.resolve("src/pages"),at=_.resolve("src/gen"),ct=_.resolve("src/routes"),Fn=_.join(at,"tsrouter.gen.ts"),ot=_.join(ct,"__root.ts");S.existsSync(at)||S.mkdirSync(at,{recursive:!0});S.existsSync(ct)||S.mkdirSync(ct,{recursive:!0});function ne(s,t){let e="/"+_.relative(t,s).replace(/\\/g,"/");return e=e.replace(/\.ts$/,""),e=e.replace(/\/index$/,"")||"/",e=e.replace(/\[(.+?)\]/g,":$1"),e}function ms(s){return s.replace(/^\//,"").split("/").map(t=>t.startsWith(":")?t.slice(1):t).filter(Boolean).join("-")||"index"}function ps(s,t){let n=_.relative(t,s).replace(/\\/g,"/").split("/").filter(Boolean),r=n[n.length-1].replace(".ts",""),i=n.length>1?n[n.length-2]:"";if(r.startsWith("[")&&r.endsWith("]")){let a=r.slice(1,-1);return i.charAt(0).toUpperCase()+i.slice(1)+a.charAt(0).toUpperCase()+a.slice(1)+"Param"}else return r.charAt(0).toUpperCase()+r.slice(1)}function re(s){let t=S.readdirSync(s,{withFileTypes:!0}),e=[];for(let n of t){let r=_.join(s,n.name);if(n.isDirectory())e=e.concat(re(r));else if(n.isFile()&&n.name.endsWith(".ts")){let i=ne(r,D),a=ms(i),o=ps(r,D);e.push({file:r,route:i,routeName:a,importName:o})}}return e}function gs(s,t){return`import { html, useTSElements, useTSExtractParams, useTSMetaData } from '@devwareng/vanilla-ts'
2
+
3
+ export default function ${s}(DOM: HTMLElement) {
4
+ useTSMetaData({
5
+ name: '${s.toLowerCase()}',
6
+ description: '',
7
+ author: ''
8
+ });
9
+
10
+ const params = useTSExtractParams("${t}")
11
+
12
+ return useTSElements(
13
+ DOM,
14
+ html\`
15
+ <div class="p-4">
16
+ <h1 class="font-semibold">${s}</h1>
17
+ <pre>\${JSON.stringify(params, null, 2)}</pre>
18
+ </div>
19
+ \`
20
+ )
21
+ }
22
+ `}function Es(){return`import { createRouter } from "@/gen/tsrouter.gen"
23
+ import { useTSParams } from "@devwareng/vanilla-ts"
24
+
25
+ // AUTO-GENERATED FILE. DO NOT EDIT MANUALLY.
26
+
27
+ export const Router = (DOM: HTMLElement) => {
28
+ useTSParams.getState()
29
+ const router = createRouter(DOM)
30
+ router.navigate(window.location.pathname)
31
+
32
+ window.addEventListener("popstate", () => {
33
+ router.navigate(window.location.pathname)
34
+ })
35
+ }`}function lt(){let s=re(D),t=s.find(o=>o.route==="/notfound"),e=s.filter(o=>o.route!=="/notfound"),n=s.map(o=>{let c="../pages/"+_.relative(D,o.file).replace(/\\/g,"/").replace(/\.ts$/,"");return`import ${o.importName} from "${c}";`}).join(`
36
+ `),r=e.map(o=>`{ path: "${o.route}", name: "${o.routeName}", component: (DOM: HTMLElement) => ${o.importName}(DOM) }`).join(`,
37
+ `),i=t?`export const NotFound = ${t.importName}`:"export function NotFound(DOM: HTMLElement) {\n return useTSElements(DOM, html`<div><h1>404 - Page Not Found</h1></div>`)\n}",a=`// AUTO-GENERATED FILE. DO NOT EDIT MANUALLY.
38
+ import { html, useTSElements } from "@devwareng/vanilla-ts"
39
+
40
+ ${n}
41
+
42
+ ${i}
43
+
44
+ export function RootDocument(DOM: HTMLElement) {
45
+ return useTSElements(DOM, html\`<div><h1>Root</h1></div>\`)
46
+ }
47
+
48
+ export const routeTree = [
49
+ ${r}
50
+ ]
51
+
52
+ export function createRouter(DOM: HTMLElement) {
53
+ function matchRoute(path: string) {
54
+ for (const route of routeTree) {
55
+ const keys: string[] = []
56
+ const regex = new RegExp("^" + route.path.replace(/:([^/]+)/g, (_, key) => {
57
+ keys.push(key)
58
+ return "([^/]+)"
59
+ }) + "$")
60
+ const pathname = path.split("?")[0]
61
+ const match = pathname.match(regex)
62
+ if (match) {
63
+ const params: Record<string, string> = {}
64
+ keys.forEach((key, i) => (params[key] = match[i + 1]))
65
+ return { ...route, params }
66
+ }
67
+ }
68
+ return null
69
+ }
70
+
71
+ function navigate(path: string) {
72
+ const match = matchRoute(path)
73
+ if (match) {
74
+ match.component(DOM)
75
+ history.pushState({}, "", path)
76
+ } else {
77
+ NotFound(DOM)
78
+ }
79
+ }
80
+
81
+ window.addEventListener("popstate", () => {
82
+ const path = window.location.pathname + window.location.search
83
+ const match = matchRoute(path)
84
+ if (match) {
85
+ match.component(DOM)
86
+ } else {
87
+ NotFound(DOM)
88
+ }
89
+ })
90
+
91
+ navigate(window.location.pathname + window.location.search)
92
+
93
+ return { navigate, routes: routeTree }
94
+ }
95
+ `}console.log("\u{1F440} Watching for changes in /src/pages and /src/routes/__root.ts...");it.watch(D).on("all",(s,t)=>{if(s==="add"&&t.endsWith(".ts")){let e=_.basename(t,".ts"),n=e.replace(/\[|\]/g,"Param").replace(/(^\w|-\w)/g,a=>a.replace("-","").toUpperCase()),r=ne(t,D);S.readFileSync(t,"utf-8").trim()||(S.writeFileSync(t,gs(n,r),"utf-8"),console.log(`\u{1F4DD} Scaffolded page: ${e}.ts`))}lt()});it.watch(ot).on("unlink",()=>{console.log("\u26A0\uFE0F __root.ts deleted. Recreating..."),S.writeFileSync(ot,Es(),"utf-8"),console.log("\u{1F7E2} Recreated:",ot)});console.log("\u{1F7E2} TS Filebased Router Mounted Successfully...");import oe from"dompurify";import{createStore as ws}from"zustand/vanilla";import ys from"dompurify";var P=ws(s=>({params:{},query:{},setParams:t=>s(()=>({params:ie(t)})),setQuery:t=>s(()=>({query:ie(t)}))}));function ie(s){let t={};for(let e in s)t[e]=ys.sanitize(s[e]);return t}var ut=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]=oe.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]=oe.sanitize(t[n]??""));return e}navigate(t){history.pushState(null,"",t),this.handlePopState()}addRoute(t){this.routes.push(t)}};typeof window<"u"&&(window.addEventListener("popstate",()=>{M()}),document.addEventListener("DOMContentLoaded",M));export{ut as TSRouter,bt as createEffect,Mt as createSignal,dt as html,It as loadPyFiles,ue as mapper,At as renderChildRoutes,N as useAnchor,_t as useAnchorSingle,yt as useInitialDOM,Ot as useTSAnchorMount,Lt as useTSAuth,vt as useTSCollection,C as useTSComponent,I as useTSElementEach,wt as useTSElements,mt as useTSEvent,Et as useTSEventAll,gt as useTSExtractParams,lt as useTSFilebasedRouter,H as useTSHashAnchor,Ht as useTSLazy,Pt as useTSMetaData,Dt as useTSNavigate,F as useTSNoReload,xt as useTSOutlet,b as useTSParams,ft as useTSPurifier,Nt as useTSSSRHydration,Rt as useTSSelect,Ct as useTSloadBrython};
96
+ /*! Bundled license information:
97
+
98
+ chokidar/esm/index.js:
99
+ (*! chokidar - MIT License (c) 2012 Paul Miller (paulmillr.com) *)
100
+ */
2
101
  //# sourceMappingURL=index.js.map