@devwareng/vanilla-ts 1.4.5 → 1.4.6

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.js CHANGED
@@ -1,4 +1,4 @@
1
- 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 ct(s,...t){return s.reduce((e,n,r)=>{let i=r<t.length?oe(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 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 lt from"dompurify";var dt=(s,t)=>{let n={...{ADD_TAGS:["my-custom-tag"]},...t};return typeof s=="string"?lt.sanitize(s,n):lt.sanitize(s.innerHTML,n)};var ut=(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 ht from"dompurify";function de(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]=ht.sanitize(i[c+1]??"")}),a}function ue(s){let t={},e=new URLSearchParams(s);for(let[n,r]of e.entries())t[n]=ht.sanitize(r);return t}var C=le((s,t)=>({params:{},query:{},setFromPattern:e=>{let n=window.location.pathname,r=de(e,n),i=ue(window.location.search);s({params:r,query:i})},getParam:e=>t().params[e],getQuery:e=>t().query[e]}));function ft(s){let t=C.getState();t.setFromPattern(s);let e=t.params,n=t.query;return{...e,...n}}var mt=(s,t,e)=>{let n=document.querySelectorAll(s);return n.forEach(r=>{r.addEventListener(t,e)}),()=>{n.forEach(r=>{r.removeEventListener(t,e)})}};import B from"dompurify";var pt=(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};B.addHook("uponSanitizeElement",(a,o)=>{let c=o.tagName.toLowerCase();c.includes("-")&&(o.allowedTags[c]=!0)}),B.addHook("uponSanitizeAttribute",(a,o)=>{o.attrName&&o.attrName.toLowerCase().startsWith("on")&&(o.keepAttr=!1)});let i=B.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 H=null,gt=(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(H!==null&&i!==H){let a=document.createElement("div");t(a),e.innerHTML=H}else H=i,e.innerHTML=i,t(e)};import Et 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 yt=(s,t,e,n="",r=null)=>{if(!s)return;let i=Et.sanitize(t,{ALLOWED_URI_REGEXP:/^(https?:|\/)/}),a=Et.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 d=window.scrollY;window.scrollTo(0,0),window.history.pushState({scrollPosition:d},"",l),dispatchEvent(new PopStateEvent("popstate"))}})};import v from"dompurify";var wt=(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 d=()=>{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 h=l?`report-uri ${c};`:"";u.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(u){console.error("Error adding CSP meta element:",u)}};document.readyState==="loading"?document.addEventListener("DOMContentLoaded",d):d()};var Tt=(s,t)=>{let e={name:v.sanitize(s.name||""),description:v.sanitize(s.description||"Default description"),author:v.sanitize(s.author||"")},n=m=>{e.name=v.sanitize(m),u("name",e.name)},r=m=>{e.description=v.sanitize(m),u("description",e.description)},i=m=>{e.author=v.sanitize(m),u("author",e.author)},a=()=>e.name,o=()=>e.description,c=()=>e.author,l=()=>e,d=(m,E)=>{let w=document.createElement("meta");w.setAttribute("name",m),w.setAttribute("content",E),document.head.appendChild(w)},u=(m,E)=>{let w=document.querySelector(`meta[name="${m}"]`);w?w.setAttribute("content",E):d(m,E)},h=()=>{u("name",e.name),u("description",e.description),u("author",e.author)};return t&&wt(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 O=(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 _t=(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"?O(i,t,c,l):console.warn(`[useTSCollection] No valid component function found for ID: "${i}"`)})};var St=(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 me}from"jwt-decode";var Pt=(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 I=(s,t,e)=>{s.forEach(n=>{t.forEach(r=>{n.addEventListener(r,i=>{e(n,i)})})})};var vt=()=>({back:()=>window.history.back(),forward:()=>window.history.forward()});var Rt=(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 Lt(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 xt(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 Dt(s){let t=s();typeof t=="function"&&t()}var k=()=>{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 ge}from"lodash-es";var V=s=>s;typeof window<"u"&&typeof document<"u"&&(V=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",V(n));let r=e.getAttribute("aria-label");r&&e.setAttribute("aria-label",V(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)}})}})},ye=ge(Ee,50),F=s=>{ye(s)};var N=s=>{let t=s.querySelectorAll("a");F(t)};var At=s=>{k(),N(s)};var bt=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.")},Mt=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 Ct(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 x from"fs";import _ from"path";import{stat as Ve}from"fs";import{stat as Ke,readdir as Qe}from"fs/promises";import{EventEmitter as Xe}from"events";import*as f from"path";import{stat as we,lstat as Ot,readdir as Te,realpath as _e}from"fs/promises";import{Readable as Se}from"stream";import{resolve as It,relative as Pe,join as ve,sep as Re}from"path";var y={FILE_TYPE:"files",DIR_TYPE:"directories",FILE_DIR_TYPE:"files_directories",EVERYTHING_TYPE:"all"},K={root:".",fileFilter:s=>!0,directoryFilter:s=>!0,type:y.FILE_TYPE,lstat:!1,depth:2147483648,alwaysStat:!1,highWaterMark:4096};Object.freeze(K);var zt="READDIRP_RECURSIVE_ERROR",Le=new Set(["ENOENT","EPERM","EACCES","ELOOP",zt]),kt=[y.DIR_TYPE,y.EVERYTHING_TYPE,y.FILE_DIR_TYPE,y.FILE_TYPE],xe=new Set([y.DIR_TYPE,y.EVERYTHING_TYPE,y.FILE_DIR_TYPE]),De=new Set([y.EVERYTHING_TYPE,y.FILE_DIR_TYPE,y.FILE_TYPE]),Ae=s=>Le.has(s.code),be=process.platform==="win32",Ft=s=>!0,Nt=s=>{if(s===void 0)return Ft;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 Ft},Q=class extends Se{constructor(t={}){super({objectMode:!0,autoDestroy:!0,highWaterMark:t.highWaterMark});let e={...K,...t},{root:n,type:r}=e;this._fileFilter=Nt(e.fileFilter),this._directoryFilter=Nt(e.directoryFilter);let i=e.lstat?Ot:we;be?this._stat=a=>i(a,{bigint:!0}):this._stat=i,this._maxDepth=e.depth??K.depth,this._wantsDir=r?xe.has(r):!1,this._wantsFile=r?De.has(r):!1,this._wantsEverything=r===y.EVERYTHING_TYPE,this._root=It(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 Te(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=It(ve(e,r));n={path:Pe(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){Ae(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 _e(n),i=await Ot(r);if(i.isFile())return"file";if(i.isDirectory()){let a=r.length;if(n.startsWith(r)&&n.substr(a,1)===Re){let o=new Error(`Circular symlink detected: "${n}" points to "${r}"`);return o.code=zt,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 Wt(s,t={}){let e=t.entryType||t.type;if(e==="both"&&(e=y.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&&!kt.includes(e))throw new Error(`readdirp: Invalid type passed. Use one of ${kt.join(", ")}`)}else throw new Error("readdirp: root argument is required. Usage: readdirp(root, options)");return t.root=s,new Q(t)}import{watchFile as Me,unwatchFile as $t,watch as Ce}from"fs";import{open as He,stat as Ut,lstat as Oe,realpath as X}from"fs/promises";import*as p from"path";import{type as Ie}from"os";var ke="data",tt="end",qt="close",U=()=>{};var q=process.platform,et=q==="win32",Fe=q==="darwin",Ne=q==="linux",ze=q==="freebsd",Yt=Ie()==="OS400",g={ALL:"all",READY:"ready",ADD:"add",CHANGE:"change",ADD_DIR:"addDir",UNLINK:"unlink",UNLINK_DIR:"unlinkDir",RAW:"raw",ERROR:"error"},T=g,We="watch",$e={lstat:Oe,stat:Ut},P="listeners",z="errHandlers",R="rawEmitters",je=[P,z,R],Ue=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"]),qe=s=>Ue.has(p.extname(s).slice(1).toLowerCase()),J=(s,t)=>{s instanceof Set?s.forEach(t):t(s)},D=(s,t,e)=>{let n=s[t];n instanceof Set||(s[t]=n=new Set([n])),n.add(e)},Ye=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]},Gt=s=>s instanceof Set?s.size===0:!s,W=new Map;function jt(s,t,e,n,r){let i=(a,o)=>{e(s),r(a,o,{watchedPath:s}),o&&s!==o&&$(p.resolve(s,o),P,p.join(s,o))};try{return Ce(s,{persistent:t.persistent},i)}catch(a){n(a);return}}var $=(s,t,e,n,r)=>{let i=W.get(s);i&&J(i[t],a=>{a(e,n,r)})},Ge=(s,t,e,n)=>{let{listener:r,errHandler:i,rawEmitter:a}=n,o=W.get(t),c;if(!e.persistent)return c=jt(s,e,r,i,a),c?c.close.bind(c):void 0;if(o)D(o,P,r),D(o,z,i),D(o,R,a);else{if(c=jt(s,e,$.bind(null,t,P),i,$.bind(null,t,R)),!c)return;c.on(T.ERROR,async l=>{let d=$.bind(null,t,z);if(o&&(o.watcherUnusable=!0),et&&l.code==="EPERM")try{await(await He(s,"r")).close(),d(l)}catch{}else d(l)}),o={listeners:r,errHandlers:i,rawEmitters:a,watcher:c},W.set(t,o)}return()=>{A(o,P,r),A(o,z,i),A(o,R,a),Gt(o.listeners)&&(o.watcher.close(),W.delete(t),je.forEach(Ye(o)),o.watcher=void 0,Object.freeze(o))}},Z=new Map,Be=(s,t,e,n)=>{let{listener:r,rawEmitter:i}=n,a=Z.get(t),o=a&&a.options;return o&&(o.persistent<e.persistent||o.interval>e.interval)&&($t(t),a=void 0),a?(D(a,P,r),D(a,R,i)):(a={listeners:r,rawEmitters:i,options:e,watcher:Me(t,e,(c,l)=>{J(a.rawEmitters,u=>{u(T.CHANGE,t,{curr:c,prev:l})});let d=c.mtimeMs;(c.size!==l.size||d>l.mtimeMs||d===0)&&J(a.listeners,u=>u(s,c))})},Z.set(t,a)),()=>{A(a,P,r),A(a,R,i),Gt(a.listeners)&&(Z.delete(t),$t(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=p.dirname(t),i=p.basename(t);this.fsw._getWatchedDir(r).add(i);let o=p.resolve(t),c={persistent:n.persistent};e||(e=U);let l;if(n.usePolling){let d=n.interval!==n.binaryInterval;c.interval=d&&qe(i)?n.binaryInterval:n.interval,l=Be(t,o,c,{listener:e,rawEmitter:this.fsw._emitRaw})}else l=Ge(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(d,u)=>{if(this.fsw._throttle(We,t,5)){if(!u||u.mtimeMs===0)try{let h=await Ut(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),(Fe||Ne||ze)&&o.ino!==h.ino){this.fsw._closeFile(d),o=h;let w=this._watchWithNodeFs(t,c);w&&this.fsw._addPathCloser(d,w)}else o=h}catch{this.fsw._remove(r,i)}else if(a.has(i)){let h=u.atimeMs,m=u.mtimeMs;(!h||h<=m||m!==o.mtimeMs)&&this.fsw._emit(T.CHANGE,t,u),o=u}}},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 X(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,d=this.fsw._readdirp(t,{fileFilter:u=>n.filterPath(u),directoryFilter:u=>n.filterDir(u)});if(d)return d.on(ke,async u=>{if(this.fsw.closed){d=void 0;return}let h=u.path,m=p.join(t,h);if(l.add(h),!(u.stats.isSymbolicLink()&&await this._handleSymlink(u,t,m,h))){if(this.fsw.closed){d=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((u,h)=>{if(!d)return h();d.once(tt,()=>{if(this.fsw.closed){d=void 0;return}let m=o?o.clear():!1;u(void 0),c.getChildren().filter(E=>E!==t&&!l.has(E)).forEach(E=>{this.fsw._remove(t,E)}),d=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 d,u,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,d),this.fsw.closed))return;u=this._watchWithNodeFs(t,(m,E)=>{E&&E.mtimeMs===0||this._handleRead(m,!1,a,i,t,r,d)})}return u}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 $e[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,d;if(c.isDirectory()){let u=p.resolve(t),h=l?await X(t):t;if(this.fsw.closed||(d=await this._handleDir(o.watchPath,c,e,r,i,o,h),this.fsw.closed))return;u!==h&&h!==void 0&&this.fsw._symlinkPaths.set(u,h)}else if(c.isSymbolicLink()){let u=l?await X(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),d=await this._handleDir(h,c,e,r,t,o,u),this.fsw.closed)return;u!==void 0&&this.fsw._symlinkPaths.set(p.resolve(t),u)}else d=this._handleFile(o.watchPath,c,e);return a(),d&&this.fsw._addPathCloser(t,d),!1}catch(c){if(this.fsw._handleError(c))return a(),t}}};var st="/",Ze="//",Zt=".",Je="..",ts="string",es=/\\/g,Bt=/\/\//,ss=/\..*\.(sw[px])$|~$|\.subl.*\.tmp/,ns=/^\.[/\\]/;function Y(s){return Array.isArray(s)?s:[s]}var nt=s=>typeof s=="object"&&s!==null&&!(s instanceof RegExp);function rs(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 is(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 Vt(s,t,e){let n=is(t);for(let r=0;r<s.length;r++){let i=s[r];if(i(n,e))return!0}return!1}function os(s,t){if(s==null)throw new TypeError("anymatch: specify first argument");let n=Y(s).map(r=>rs(r));return t==null?(r,i)=>Vt(n,r,i):Vt(n,t)}var Kt=s=>{let t=Y(s).flat();if(!t.every(e=>typeof e===ts))throw new TypeError(`Non-string provided as watch path: ${t}`);return t.map(Jt)},Qt=s=>{let t=s.replace(es,st),e=!1;for(t.startsWith(Ze)&&(e=!0);t.match(Bt);)t=t.replace(Bt,st);return e&&(t=st+t),t},Jt=s=>Qt(f.normalize(Qt(s))),Xt=(s="")=>t=>typeof t=="string"?Jt(f.isAbsolute(t)?t:f.join(s,t)):t,as=(s,t)=>f.isAbsolute(s)?s:f.join(t,s),cs=Object.freeze(new Set),rt=class{constructor(t,e){this.path=t,this._removeWatcher=e,this.items=new Set}add(t){let{items:e}=this;e&&t!==Zt&&t!==Je&&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 Qe(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=U,this.items=cs,Object.freeze(this)}},ls="stat",ds="lstat",it=class{constructor(t,e,n){this.fsw=n;let r=t;this.path=t=t.replace(ns,""),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?ls:ds}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)}},G=class extends Xe{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};Yt&&(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=U,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 j(this),Object.freeze(r)}_addIgnoredPath(t){if(nt(t)){for(let e of this._ignoredPaths)if(nt(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)nt(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=Kt(t);return r&&(i=i.map(a=>as(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=Kt(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)||Zt;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;et&&(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,d)=>{l?(t=g.ERROR,i[0]=l,this.emitWithAll(t,i)):d&&(i.length>1?i[1]=d:i.push(d),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 Ke(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),d=l?l.count:0;return r.delete(e),clearTimeout(a),l&&clearTimeout(l.timeoutObject),d};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,d=this._pendingWrites;function u(h){Ve(c,(m,E)=>{if(m||!d.has(t)){m&&m.code!=="ENOENT"&&r(m);return}let w=Number(new Date);h&&E.size!==h.size&&(d.get(t).lastChange=w);let ie=d.get(t);w-ie.lastChange>=e?(d.delete(t),r(void 0,E)):o=setTimeout(u,a,E)})}d.has(t)||(d.set(t,{lastChange:l,cancelWait:()=>(d.delete(t),clearTimeout(o),n)}),o=setTimeout(u,a))}_isIgnored(t,e){if(this.options.atomic&&ss.test(t))return!0;if(!this._userIgnored){let{cwd:n}=this.options,i=(this.options.ignored||[]).map(Xt(n)),o=[...[...this._ignoredPaths].map(Xt(n)),...i];this._userIgnored=os(o,void 0)}return this._userIgnored(t,e)}_isntIgnored(t,e){return!this._isIgnored(t,e)}_getWatchHelpers(t){return new it(t,this.options.followSymlinks,this)}_getWatchedDir(t){let e=f.resolve(t);return this._watched.has(e)||this._watched.set(e,new rt(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 d=r;if(this.options.cwd&&(d=f.relative(this.options.cwd,r)),this.options.awaitWriteFinish&&this._pendingWrites.has(d)&&this._pendingWrites.get(d).cancelWait()===g.ADD)return;this._watched.delete(r),this._watched.delete(i);let u=n?g.UNLINK_DIR:g.UNLINK;l&&!this._isIgnored(r)&&this._emit(u,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=Wt(t,n);return this._streams.add(r),r.once(qt,()=>{r=void 0}),r.once(tt,()=>{r&&(this._streams.delete(r),r=void 0)}),r}};function us(s,t={}){let e=new G(t);return e.add(s),e}var te={watch:us,FSWatcher:G};var b=_.resolve("src/pages"),ot=_.resolve("src/gen"),ee=_.join(ot,"tsrouter.gen.ts");x.existsSync(ot)||x.mkdirSync(ot,{recursive:!0});function hs(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 fs(s,t){return _.relative(t,s).replace(/\\/g,"-").replace(/\.ts$/,"").replace(/\[|\]/g,"Param").replace(/[^a-zA-Z0-9]/g,"-").split("-").map(n=>n.charAt(0).toUpperCase()+n.slice(1)).join("")}function se(s){let t=x.readdirSync(s,{withFileTypes:!0}),e=[];for(let n of t){let r=_.join(s,n.name);n.isDirectory()?e=e.concat(se(r)):n.isFile()&&n.name.endsWith(".ts")&&e.push({file:r,route:hs(r,b),importName:fs(r,b)})}return e}function ms(s){return`import { html, useTSElements, useTSMetaData } from '@devwareng/vanilla-ts'
1
+ 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 ct(s,...t){return s.reduce((e,n,r)=>{let i=r<t.length?oe(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 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 lt from"dompurify";var dt=(s,t)=>{let n={...{ADD_TAGS:["my-custom-tag"]},...t};return typeof s=="string"?lt.sanitize(s,n):lt.sanitize(s.innerHTML,n)};var ut=(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 ht from"dompurify";function de(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]=ht.sanitize(i[c+1]??"")}),a}function ue(s){let t={},e=new URLSearchParams(s);for(let[n,r]of e.entries())t[n]=ht.sanitize(r);return t}var C=le((s,t)=>({params:{},query:{},setFromPattern:e=>{let n=window.location.pathname,r=de(e,n),i=ue(window.location.search);s({params:r,query:i})},getParam:e=>t().params[e],getQuery:e=>t().query[e]}));function ft(s){let t=C.getState();t.setFromPattern(s);let e=t.params,n=t.query;return{...e,...n}}var mt=(s,t,e)=>{let n=document.querySelectorAll(s);return n.forEach(r=>{r.addEventListener(t,e)}),()=>{n.forEach(r=>{r.removeEventListener(t,e)})}};import B from"dompurify";var pt=(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};B.addHook("uponSanitizeElement",(a,o)=>{let c=o.tagName.toLowerCase();c.includes("-")&&(o.allowedTags[c]=!0)}),B.addHook("uponSanitizeAttribute",(a,o)=>{o.attrName&&o.attrName.toLowerCase().startsWith("on")&&(o.keepAttr=!1)});let i=B.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 H=null,gt=(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(H!==null&&i!==H){let a=document.createElement("div");t(a),e.innerHTML=H}else H=i,e.innerHTML=i,t(e)};import Et 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 yt=(s,t,e,n="",r=null)=>{if(!s)return;let i=Et.sanitize(t,{ALLOWED_URI_REGEXP:/^(https?:|\/)/}),a=Et.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 d=window.scrollY;window.scrollTo(0,0),window.history.pushState({scrollPosition:d},"",l),dispatchEvent(new PopStateEvent("popstate"))}})};import v from"dompurify";var wt=(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 d=()=>{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 h=l?`report-uri ${c};`:"";u.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(u){console.error("Error adding CSP meta element:",u)}};document.readyState==="loading"?document.addEventListener("DOMContentLoaded",d):d()};var Tt=(s,t)=>{let e={name:v.sanitize(s.name||""),description:v.sanitize(s.description||"Default description"),author:v.sanitize(s.author||"")},n=m=>{e.name=v.sanitize(m),u("name",e.name)},r=m=>{e.description=v.sanitize(m),u("description",e.description)},i=m=>{e.author=v.sanitize(m),u("author",e.author)},a=()=>e.name,o=()=>e.description,c=()=>e.author,l=()=>e,d=(m,E)=>{let w=document.createElement("meta");w.setAttribute("name",m),w.setAttribute("content",E),document.head.appendChild(w)},u=(m,E)=>{let w=document.querySelector(`meta[name="${m}"]`);w?w.setAttribute("content",E):d(m,E)},h=()=>{u("name",e.name),u("description",e.description),u("author",e.author)};return t&&wt(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 O=(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 _t=(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"?O(i,t,c,l):console.warn(`[useTSCollection] No valid component function found for ID: "${i}"`)})};var St=(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 me}from"jwt-decode";var Pt=(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 I=(s,t,e)=>{s.forEach(n=>{t.forEach(r=>{n.addEventListener(r,i=>{e(n,i)})})})};var vt=()=>({back:()=>window.history.back(),forward:()=>window.history.forward()});var Lt=(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 Rt(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 Dt(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 xt(s){let t=s();typeof t=="function"&&t()}var F=()=>{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 ge}from"lodash-es";var V=s=>s;typeof window<"u"&&typeof document<"u"&&(V=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",V(n));let r=e.getAttribute("aria-label");r&&e.setAttribute("aria-label",V(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)}})}})},ye=ge(Ee,50),N=s=>{ye(s)};var k=s=>{let t=s.querySelectorAll("a");N(t)};var At=s=>{F(),k(s)};var bt=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.")},Mt=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 Ct(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 D from"fs";import _ from"path";import{stat as Ve}from"fs";import{stat as Ke,readdir as Qe}from"fs/promises";import{EventEmitter as Xe}from"events";import*as f from"path";import{stat as we,lstat as Ot,readdir as Te,realpath as _e}from"fs/promises";import{Readable as Se}from"stream";import{resolve as It,relative as Pe,join as ve,sep as Le}from"path";var y={FILE_TYPE:"files",DIR_TYPE:"directories",FILE_DIR_TYPE:"files_directories",EVERYTHING_TYPE:"all"},K={root:".",fileFilter:s=>!0,directoryFilter:s=>!0,type:y.FILE_TYPE,lstat:!1,depth:2147483648,alwaysStat:!1,highWaterMark:4096};Object.freeze(K);var zt="READDIRP_RECURSIVE_ERROR",Re=new Set(["ENOENT","EPERM","EACCES","ELOOP",zt]),Ft=[y.DIR_TYPE,y.EVERYTHING_TYPE,y.FILE_DIR_TYPE,y.FILE_TYPE],De=new Set([y.DIR_TYPE,y.EVERYTHING_TYPE,y.FILE_DIR_TYPE]),xe=new Set([y.EVERYTHING_TYPE,y.FILE_DIR_TYPE,y.FILE_TYPE]),Ae=s=>Re.has(s.code),be=process.platform==="win32",Nt=s=>!0,kt=s=>{if(s===void 0)return Nt;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 Nt},Q=class extends Se{constructor(t={}){super({objectMode:!0,autoDestroy:!0,highWaterMark:t.highWaterMark});let e={...K,...t},{root:n,type:r}=e;this._fileFilter=kt(e.fileFilter),this._directoryFilter=kt(e.directoryFilter);let i=e.lstat?Ot:we;be?this._stat=a=>i(a,{bigint:!0}):this._stat=i,this._maxDepth=e.depth??K.depth,this._wantsDir=r?De.has(r):!1,this._wantsFile=r?xe.has(r):!1,this._wantsEverything=r===y.EVERYTHING_TYPE,this._root=It(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 Te(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=It(ve(e,r));n={path:Pe(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){Ae(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 _e(n),i=await Ot(r);if(i.isFile())return"file";if(i.isDirectory()){let a=r.length;if(n.startsWith(r)&&n.substr(a,1)===Le){let o=new Error(`Circular symlink detected: "${n}" points to "${r}"`);return o.code=zt,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 Wt(s,t={}){let e=t.entryType||t.type;if(e==="both"&&(e=y.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&&!Ft.includes(e))throw new Error(`readdirp: Invalid type passed. Use one of ${Ft.join(", ")}`)}else throw new Error("readdirp: root argument is required. Usage: readdirp(root, options)");return t.root=s,new Q(t)}import{watchFile as Me,unwatchFile as $t,watch as Ce}from"fs";import{open as He,stat as Ut,lstat as Oe,realpath as X}from"fs/promises";import*as p from"path";import{type as Ie}from"os";var Fe="data",tt="end",qt="close",U=()=>{};var q=process.platform,et=q==="win32",Ne=q==="darwin",ke=q==="linux",ze=q==="freebsd",Yt=Ie()==="OS400",g={ALL:"all",READY:"ready",ADD:"add",CHANGE:"change",ADD_DIR:"addDir",UNLINK:"unlink",UNLINK_DIR:"unlinkDir",RAW:"raw",ERROR:"error"},T=g,We="watch",$e={lstat:Oe,stat:Ut},P="listeners",z="errHandlers",L="rawEmitters",je=[P,z,L],Ue=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"]),qe=s=>Ue.has(p.extname(s).slice(1).toLowerCase()),Z=(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)},Ye=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]},Gt=s=>s instanceof Set?s.size===0:!s,W=new Map;function jt(s,t,e,n,r){let i=(a,o)=>{e(s),r(a,o,{watchedPath:s}),o&&s!==o&&$(p.resolve(s,o),P,p.join(s,o))};try{return Ce(s,{persistent:t.persistent},i)}catch(a){n(a);return}}var $=(s,t,e,n,r)=>{let i=W.get(s);i&&Z(i[t],a=>{a(e,n,r)})},Ge=(s,t,e,n)=>{let{listener:r,errHandler:i,rawEmitter:a}=n,o=W.get(t),c;if(!e.persistent)return c=jt(s,e,r,i,a),c?c.close.bind(c):void 0;if(o)x(o,P,r),x(o,z,i),x(o,L,a);else{if(c=jt(s,e,$.bind(null,t,P),i,$.bind(null,t,L)),!c)return;c.on(T.ERROR,async l=>{let d=$.bind(null,t,z);if(o&&(o.watcherUnusable=!0),et&&l.code==="EPERM")try{await(await He(s,"r")).close(),d(l)}catch{}else d(l)}),o={listeners:r,errHandlers:i,rawEmitters:a,watcher:c},W.set(t,o)}return()=>{A(o,P,r),A(o,z,i),A(o,L,a),Gt(o.listeners)&&(o.watcher.close(),W.delete(t),je.forEach(Ye(o)),o.watcher=void 0,Object.freeze(o))}},J=new Map,Be=(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)&&($t(t),a=void 0),a?(x(a,P,r),x(a,L,i)):(a={listeners:r,rawEmitters:i,options:e,watcher:Me(t,e,(c,l)=>{Z(a.rawEmitters,u=>{u(T.CHANGE,t,{curr:c,prev:l})});let d=c.mtimeMs;(c.size!==l.size||d>l.mtimeMs||d===0)&&Z(a.listeners,u=>u(s,c))})},J.set(t,a)),()=>{A(a,P,r),A(a,L,i),Gt(a.listeners)&&(J.delete(t),$t(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=p.dirname(t),i=p.basename(t);this.fsw._getWatchedDir(r).add(i);let o=p.resolve(t),c={persistent:n.persistent};e||(e=U);let l;if(n.usePolling){let d=n.interval!==n.binaryInterval;c.interval=d&&qe(i)?n.binaryInterval:n.interval,l=Be(t,o,c,{listener:e,rawEmitter:this.fsw._emitRaw})}else l=Ge(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(d,u)=>{if(this.fsw._throttle(We,t,5)){if(!u||u.mtimeMs===0)try{let h=await Ut(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),(Ne||ke||ze)&&o.ino!==h.ino){this.fsw._closeFile(d),o=h;let w=this._watchWithNodeFs(t,c);w&&this.fsw._addPathCloser(d,w)}else o=h}catch{this.fsw._remove(r,i)}else if(a.has(i)){let h=u.atimeMs,m=u.mtimeMs;(!h||h<=m||m!==o.mtimeMs)&&this.fsw._emit(T.CHANGE,t,u),o=u}}},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 X(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,d=this.fsw._readdirp(t,{fileFilter:u=>n.filterPath(u),directoryFilter:u=>n.filterDir(u)});if(d)return d.on(Fe,async u=>{if(this.fsw.closed){d=void 0;return}let h=u.path,m=p.join(t,h);if(l.add(h),!(u.stats.isSymbolicLink()&&await this._handleSymlink(u,t,m,h))){if(this.fsw.closed){d=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((u,h)=>{if(!d)return h();d.once(tt,()=>{if(this.fsw.closed){d=void 0;return}let m=o?o.clear():!1;u(void 0),c.getChildren().filter(E=>E!==t&&!l.has(E)).forEach(E=>{this.fsw._remove(t,E)}),d=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 d,u,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,d),this.fsw.closed))return;u=this._watchWithNodeFs(t,(m,E)=>{E&&E.mtimeMs===0||this._handleRead(m,!1,a,i,t,r,d)})}return u}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 $e[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,d;if(c.isDirectory()){let u=p.resolve(t),h=l?await X(t):t;if(this.fsw.closed||(d=await this._handleDir(o.watchPath,c,e,r,i,o,h),this.fsw.closed))return;u!==h&&h!==void 0&&this.fsw._symlinkPaths.set(u,h)}else if(c.isSymbolicLink()){let u=l?await X(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),d=await this._handleDir(h,c,e,r,t,o,u),this.fsw.closed)return;u!==void 0&&this.fsw._symlinkPaths.set(p.resolve(t),u)}else d=this._handleFile(o.watchPath,c,e);return a(),d&&this.fsw._addPathCloser(t,d),!1}catch(c){if(this.fsw._handleError(c))return a(),t}}};var st="/",Je="//",Jt=".",Ze="..",ts="string",es=/\\/g,Bt=/\/\//,ss=/\..*\.(sw[px])$|~$|\.subl.*\.tmp/,ns=/^\.[/\\]/;function Y(s){return Array.isArray(s)?s:[s]}var nt=s=>typeof s=="object"&&s!==null&&!(s instanceof RegExp);function rs(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 is(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 Vt(s,t,e){let n=is(t);for(let r=0;r<s.length;r++){let i=s[r];if(i(n,e))return!0}return!1}function os(s,t){if(s==null)throw new TypeError("anymatch: specify first argument");let n=Y(s).map(r=>rs(r));return t==null?(r,i)=>Vt(n,r,i):Vt(n,t)}var Kt=s=>{let t=Y(s).flat();if(!t.every(e=>typeof e===ts))throw new TypeError(`Non-string provided as watch path: ${t}`);return t.map(Zt)},Qt=s=>{let t=s.replace(es,st),e=!1;for(t.startsWith(Je)&&(e=!0);t.match(Bt);)t=t.replace(Bt,st);return e&&(t=st+t),t},Zt=s=>Qt(f.normalize(Qt(s))),Xt=(s="")=>t=>typeof t=="string"?Zt(f.isAbsolute(t)?t:f.join(s,t)):t,as=(s,t)=>f.isAbsolute(s)?s:f.join(t,s),cs=Object.freeze(new Set),rt=class{constructor(t,e){this.path=t,this._removeWatcher=e,this.items=new Set}add(t){let{items:e}=this;e&&t!==Jt&&t!==Ze&&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 Qe(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=U,this.items=cs,Object.freeze(this)}},ls="stat",ds="lstat",it=class{constructor(t,e,n){this.fsw=n;let r=t;this.path=t=t.replace(ns,""),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?ls:ds}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)}},G=class extends Xe{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};Yt&&(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=U,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 j(this),Object.freeze(r)}_addIgnoredPath(t){if(nt(t)){for(let e of this._ignoredPaths)if(nt(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)nt(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=Kt(t);return r&&(i=i.map(a=>as(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=Kt(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)||Jt;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;et&&(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,d)=>{l?(t=g.ERROR,i[0]=l,this.emitWithAll(t,i)):d&&(i.length>1?i[1]=d:i.push(d),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 Ke(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),d=l?l.count:0;return r.delete(e),clearTimeout(a),l&&clearTimeout(l.timeoutObject),d};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,d=this._pendingWrites;function u(h){Ve(c,(m,E)=>{if(m||!d.has(t)){m&&m.code!=="ENOENT"&&r(m);return}let w=Number(new Date);h&&E.size!==h.size&&(d.get(t).lastChange=w);let ie=d.get(t);w-ie.lastChange>=e?(d.delete(t),r(void 0,E)):o=setTimeout(u,a,E)})}d.has(t)||(d.set(t,{lastChange:l,cancelWait:()=>(d.delete(t),clearTimeout(o),n)}),o=setTimeout(u,a))}_isIgnored(t,e){if(this.options.atomic&&ss.test(t))return!0;if(!this._userIgnored){let{cwd:n}=this.options,i=(this.options.ignored||[]).map(Xt(n)),o=[...[...this._ignoredPaths].map(Xt(n)),...i];this._userIgnored=os(o,void 0)}return this._userIgnored(t,e)}_isntIgnored(t,e){return!this._isIgnored(t,e)}_getWatchHelpers(t){return new it(t,this.options.followSymlinks,this)}_getWatchedDir(t){let e=f.resolve(t);return this._watched.has(e)||this._watched.set(e,new rt(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 d=r;if(this.options.cwd&&(d=f.relative(this.options.cwd,r)),this.options.awaitWriteFinish&&this._pendingWrites.has(d)&&this._pendingWrites.get(d).cancelWait()===g.ADD)return;this._watched.delete(r),this._watched.delete(i);let u=n?g.UNLINK_DIR:g.UNLINK;l&&!this._isIgnored(r)&&this._emit(u,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=Wt(t,n);return this._streams.add(r),r.once(qt,()=>{r=void 0}),r.once(tt,()=>{r&&(this._streams.delete(r),r=void 0)}),r}};function us(s,t={}){let e=new G(t);return e.add(s),e}var te={watch:us,FSWatcher:G};var b=_.resolve("src/pages"),ot=_.resolve("src/gen"),ee=_.join(ot,"tsrouter.gen.ts");D.existsSync(ot)||D.mkdirSync(ot,{recursive:!0});function hs(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 fs(s,t){return _.relative(t,s).replace(/\\/g,"-").replace(/\.ts$/,"").replace(/\[|\]/g,"Param").replace(/[^a-zA-Z0-9]/g,"-").split("-").map(n=>n.charAt(0).toUpperCase()+n.slice(1)).join("")}function se(s){let t=D.readdirSync(s,{withFileTypes:!0}),e=[];for(let n of t){let r=_.join(s,n.name);n.isDirectory()?e=e.concat(se(r)):n.isFile()&&n.name.endsWith(".ts")&&e.push({file:r,route:hs(r,b),importName:fs(r,b)})}return e}function ms(s){return`import { html, useTSElements, useTSMetaData } from '@devwareng/vanilla-ts'
2
2
 
3
3
  export default function ${s}(DOM: HTMLElement) {
4
4
  useTSMetaData({
@@ -11,17 +11,16 @@ export default function ${s}(DOM: HTMLElement) {
11
11
  DOM,
12
12
  html\`
13
13
  <div class="p-4">
14
- <h1 class="font-semibold">${s}</h1>
14
+ <h1 class="text-semibold">${s}</h1>
15
15
  </div>
16
16
  \`
17
17
  );
18
18
  return ui
19
19
  }
20
- `}function L(){let s=se(b),t=s.find(o=>o.route==="/notfound"),e=s.filter(o=>o.route!=="/notfound"),n=s.map(o=>`import ${o.importName} from "../pages/${_.relative(b,o.file).replace(/\\/g,"/").replace(/\.ts$/,"")}";`).join(`
21
- `),r=e.map(o=>`{ path: "${o.route}", name: "${o.importName}", component: (DOM: HTMLElement) => ${o.importName}(DOM) }`).join(`,
20
+ `}function R(){let s=se(b),t=s.find(o=>o.route==="/404"),e=s.filter(o=>o.route!=="/404"),n=s.map(o=>`import ${o.importName} from "../pages/${_.relative(b,o.file).replace(/\\/g,"/").replace(/\.ts$/,"")}";`).join(`
21
+ `),r=e.map(o=>`{ path: "${o.route}", component: (DOM: HTMLElement) => ${o.importName}(DOM) }`).join(`,
22
22
  `),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.
23
23
  import { html, useTSElements } from "@devwareng/vanilla-ts"
24
- import { useTSParams } from "@/utils/hooks/useTSParams"
25
24
 
26
25
  ${n}
27
26
 
@@ -36,38 +35,17 @@ export const routeTree = [
36
35
  ]
37
36
 
38
37
  export function createRouter(DOM: HTMLElement) {
39
- function matchRoute(path: string) {
40
- for (const route of routeTree) {
41
- const keys: string[] = []
42
- const regex = new RegExp("^" + route.path.replace(/:([^/]+)/g, (_, key) => {
43
- keys.push(key)
44
- return "([^/]+)"
45
- }) + "$")
46
- const pathname = path.split("?")[0]
47
- const match = pathname.match(regex)
48
- if (match) {
49
- const params: Record<string, string> = {}
50
- keys.forEach((key, i) => (params[key] = match[i + 1]))
51
- return { ...route, params }
52
- }
53
- }
54
- return null
55
- }
56
-
57
38
  function navigate(path: string) {
58
- const match = matchRoute(path)
59
- if (match) {
60
- // sync params + query to Zustand store
61
- useTSParams.getState().setFromPattern(match.path as any)
62
- match.component(DOM)
39
+ const route = routeTree.find((r) => r.path === path)
40
+ if (route) {
41
+ route.component(DOM)
63
42
  } else {
64
43
  NotFound(DOM)
65
44
  }
66
45
  }
67
-
68
46
  return { navigate }
69
47
  }
70
- `;x.writeFileSync(ee,a,"utf-8"),console.log("\u2705 Generated:",ee)}L();console.log("\u{1F440} Watching for changes in /src/pages...");te.watch(b).on("add",s=>{if(s.endsWith(".ts")){let t=_.basename(s,".ts"),e=t.replace(/\[|\]/g,"Param").replace(/(^\w|-\w)/g,r=>r.replace("-","").toUpperCase());x.readFileSync(s,"utf-8").trim()||(x.writeFileSync(s,ms(e),"utf-8"),console.log(`\u{1F4DD} Scaffolded page: ${t}.ts`))}L()}).on("unlink",()=>{L()}).on("change",()=>{L()});import re from"dompurify";import{createStore as ps}from"zustand/vanilla";import gs from"dompurify";var S=ps(s=>({params:{},query:{},setParams:t=>s(()=>({params:ne(t)})),setQuery:t=>s(()=>({query:ne(t)}))}));function ne(s){let t={};for(let e in s)t[e]=gs.sanitize(s[e]);return t}var at=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);S.getState().setParams(i),S.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);S.getState().setParams(a),S.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(S.getState().setParams(l),S.getState().setQuery(i),a.element?.(o,l,i),n.appendChild(o),a.children){let d=e.slice(a.path.length);this.renderChildren(a.children,d,o,l,i)}}}parseQueryParams(t){let e={},n=new URLSearchParams(t);for(let[r,i]of n.entries())this.expectedParams.has(r)&&(e[r]=re.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,u=>(o.push(u.substring(1)),"([^\\s/]+)")),l=new RegExp(`^${c}(?:/|$)`),d=t.match(l);if(d){let u={...n};if(o.forEach((h,m)=>{u[h]=d[m+1]??""}),r.children){let h=t.slice(d[0].length),m=this.findMatchingRoute(h,r.children,u);if(m)return m}return{...r,params:u}}}}}filterAndSanitizeParams(t){if(!t)return{};let e={};for(let n in t)this.expectedParams.has(n)&&(e[n]=re.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{at as TSRouter,Dt as createEffect,xt as createSignal,ct as html,Mt as loadPyFiles,ce as mapper,Lt as renderChildRoutes,F as useAnchor,yt as useAnchorSingle,gt as useInitialDOM,At as useTSAnchorMount,Pt as useTSAuth,_t as useTSCollection,O as useTSComponent,I as useTSElementEach,pt as useTSElements,ut as useTSEvent,mt as useTSEventAll,ft as useTSExtractParams,L as useTSFilebasedRouter,k as useTSHashAnchor,Ct as useTSLazy,Tt as useTSMetaData,vt as useTSNavigate,N as useTSNoReload,Rt as useTSOutlet,C as useTSParams,dt as useTSPurifier,Ht as useTSSSRHydration,St as useTSSelect,bt as useTSloadBrython};
48
+ `;D.writeFileSync(ee,a,"utf-8"),console.log("\u2705 Generated:",ee)}R();console.log("\u{1F440} Watching for changes in /src/pages...");te.watch(b).on("add",s=>{if(s.endsWith(".ts")){let t=_.basename(s,".ts"),e=t.replace(/\[|\]/g,"Param").replace(/(^\w|-\w)/g,r=>r.replace("-","").toUpperCase());D.readFileSync(s,"utf-8").trim()||(D.writeFileSync(s,ms(e),"utf-8"),console.log(`\u{1F4DD} Scaffolded page: ${t}.ts`))}R()}).on("unlink",()=>{R()}).on("change",()=>{R()});import re from"dompurify";import{createStore as ps}from"zustand/vanilla";import gs from"dompurify";var S=ps(s=>({params:{},query:{},setParams:t=>s(()=>({params:ne(t)})),setQuery:t=>s(()=>({query:ne(t)}))}));function ne(s){let t={};for(let e in s)t[e]=gs.sanitize(s[e]);return t}var at=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);S.getState().setParams(i),S.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);S.getState().setParams(a),S.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(S.getState().setParams(l),S.getState().setQuery(i),a.element?.(o,l,i),n.appendChild(o),a.children){let d=e.slice(a.path.length);this.renderChildren(a.children,d,o,l,i)}}}parseQueryParams(t){let e={},n=new URLSearchParams(t);for(let[r,i]of n.entries())this.expectedParams.has(r)&&(e[r]=re.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,u=>(o.push(u.substring(1)),"([^\\s/]+)")),l=new RegExp(`^${c}(?:/|$)`),d=t.match(l);if(d){let u={...n};if(o.forEach((h,m)=>{u[h]=d[m+1]??""}),r.children){let h=t.slice(d[0].length),m=this.findMatchingRoute(h,r.children,u);if(m)return m}return{...r,params:u}}}}}filterAndSanitizeParams(t){if(!t)return{};let e={};for(let n in t)this.expectedParams.has(n)&&(e[n]=re.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{at as TSRouter,xt as createEffect,Dt as createSignal,ct as html,Mt as loadPyFiles,ce as mapper,Rt as renderChildRoutes,N as useAnchor,yt as useAnchorSingle,gt as useInitialDOM,At as useTSAnchorMount,Pt as useTSAuth,_t as useTSCollection,O as useTSComponent,I as useTSElementEach,pt as useTSElements,ut as useTSEvent,mt as useTSEventAll,ft as useTSExtractParams,R as useTSFilebasedRouter,F as useTSHashAnchor,Ct as useTSLazy,Tt as useTSMetaData,vt as useTSNavigate,k as useTSNoReload,Lt as useTSOutlet,C as useTSParams,dt as useTSPurifier,Ht as useTSSSRHydration,St as useTSSelect,bt as useTSloadBrython};
71
49
  /*! Bundled license information:
72
50
 
73
51
  chokidar/esm/index.js: