@devwareng/vanilla-ts 1.9.96 → 1.9.98

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.cjs CHANGED
@@ -1,4 +1,4 @@
1
- "use strict";var De=Object.create;var V=Object.defineProperty;var Me=Object.getOwnPropertyDescriptor;var Ce=Object.getOwnPropertyNames;var Oe=Object.getPrototypeOf,Fe=Object.prototype.hasOwnProperty;var at=(s,t)=>()=>(s&&(t=s(s=0)),t);var Yt=(s,t)=>{for(var e in t)V(s,e,{get:t[e],enumerable:!0})},Bt=(s,t,e,r)=>{if(t&&typeof t=="object"||typeof t=="function")for(let n of Ce(t))!Fe.call(s,n)&&n!==e&&V(s,n,{get:()=>t[n],enumerable:!(r=Me(t,n))||r.enumerable});return s};var v=(s,t,e)=>(e=s!=null?De(Oe(s)):{},Bt(t||!s||!s.__esModule?V(e,"default",{value:s,enumerable:!0}):e,s)),Ie=s=>Bt(V({},"__esModule",{value:!0}),s);function ce(s,t={}){let e=t.entryType||t.type;if(e==="both"&&(e=R.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&&!ne.includes(e))throw new Error(`readdirp: Invalid type passed. Use one of ${ne.join(", ")}`)}else throw new Error("readdirp: root argument is required. Usage: readdirp(root, options)");return t.root=s,new Ht(t)}var M,oe,C,R,kt,ae,je,ne,Ue,qe,Ye,Be,re,ie,Ht,le=at(()=>{"use strict";M=require("fs/promises"),oe=require("stream"),C=require("path"),R={FILE_TYPE:"files",DIR_TYPE:"directories",FILE_DIR_TYPE:"files_directories",EVERYTHING_TYPE:"all"},kt={root:".",fileFilter:s=>!0,directoryFilter:s=>!0,type:R.FILE_TYPE,lstat:!1,depth:2147483648,alwaysStat:!1,highWaterMark:4096};Object.freeze(kt);ae="READDIRP_RECURSIVE_ERROR",je=new Set(["ENOENT","EPERM","EACCES","ELOOP",ae]),ne=[R.DIR_TYPE,R.EVERYTHING_TYPE,R.FILE_DIR_TYPE,R.FILE_TYPE],Ue=new Set([R.DIR_TYPE,R.EVERYTHING_TYPE,R.FILE_DIR_TYPE]),qe=new Set([R.EVERYTHING_TYPE,R.FILE_DIR_TYPE,R.FILE_TYPE]),Ye=s=>je.has(s.code),Be=process.platform==="win32",re=s=>!0,ie=s=>{if(s===void 0)return re;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(r=>e.basename===r)}return re},Ht=class extends oe.Readable{constructor(t={}){super({objectMode:!0,autoDestroy:!0,highWaterMark:t.highWaterMark});let e={...kt,...t},{root:r,type:n}=e;this._fileFilter=ie(e.fileFilter),this._directoryFilter=ie(e.directoryFilter);let i=e.lstat?M.lstat:M.stat;Be?this._stat=a=>i(a,{bigint:!0}):this._stat=i,this._maxDepth=e.depth??kt.depth,this._wantsDir=n?Ue.has(n):!1,this._wantsFile=n?qe.has(n):!1,this._wantsEverything=n===R.EVERYTHING_TYPE,this._root=(0,C.resolve)(r),this._isDirent=!e.alwaysStat,this._statsProp=this._isDirent?"dirent":"stats",this._rdOptions={encoding:"utf8",withFileTypes:this._isDirent},this.parents=[this._exploreDir(r,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,r=e&&e.files;if(r&&r.length>0){let{path:n,depth:i}=e,a=r.splice(0,t).map(c=>this._formatEntry(c,n)),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 n=this.parents.pop();if(!n){this.push(null);break}if(this.parent=await n,this.destroyed)return}}}catch(e){this.destroy(e)}finally{this.reading=!1}}}async _exploreDir(t,e){let r;try{r=await(0,M.readdir)(t,this._rdOptions)}catch(n){this._onError(n)}return{files:r,depth:e,path:t}}async _formatEntry(t,e){let r,n=this._isDirent?t.name:t;try{let i=(0,C.resolve)((0,C.join)(e,n));r={path:(0,C.relative)(this._root,i),fullPath:i,basename:n},r[this._statsProp]=this._isDirent?t:await this._stat(i)}catch(i){this._onError(i);return}return r}_onError(t){Ye(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 r=t.fullPath;try{let n=await(0,M.realpath)(r),i=await(0,M.lstat)(n);if(i.isFile())return"file";if(i.isDirectory()){let a=n.length;if(r.startsWith(n)&&r.substr(a,1)===C.sep){let o=new Error(`Circular symlink detected: "${r}" points to "${n}"`);return o.code=ae,this._onError(o)}return"directory"}}catch(n){return this._onError(n),""}}}_includeAsFile(t){let e=t&&t[this._statsProp];return e&&this._wantsEverything&&!e.isDirectory()}}});function ue(s,t,e,r,n){let i=(a,o)=>{e(s),n(a,o,{watchedPath:s}),o&&s!==o&&tt(w.resolve(s,o),F,w.join(s,o))};try{return(0,I.watch)(s,{persistent:t.persistent},i)}catch(a){r(a);return}}var I,x,w,de,Ge,$t,he,st,nt,Wt,Ve,Ke,Qe,fe,E,b,Ze,Xe,F,X,H,Je,ts,es,zt,W,ss,j,me,J,tt,ns,Nt,rs,et,pe=at(()=>{"use strict";I=require("fs"),x=require("fs/promises"),w=v(require("path"),1),de=require("os"),Ge="data",$t="end",he="close",st=()=>{},nt=process.platform,Wt=nt==="win32",Ve=nt==="darwin",Ke=nt==="linux",Qe=nt==="freebsd",fe=(0,de.type)()==="OS400",E={ALL:"all",READY:"ready",ADD:"add",CHANGE:"change",ADD_DIR:"addDir",UNLINK:"unlink",UNLINK_DIR:"unlinkDir",RAW:"raw",ERROR:"error"},b=E,Ze="watch",Xe={lstat:x.lstat,stat:x.stat},F="listeners",X="errHandlers",H="rawEmitters",Je=[F,X,H],ts=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"]),es=s=>ts.has(w.extname(s).slice(1).toLowerCase()),zt=(s,t)=>{s instanceof Set?s.forEach(t):t(s)},W=(s,t,e)=>{let r=s[t];r instanceof Set||(s[t]=r=new Set([r])),r.add(e)},ss=s=>t=>{let e=s[t];e instanceof Set?e.clear():delete s[t]},j=(s,t,e)=>{let r=s[t];r instanceof Set?r.delete(e):r===e&&delete s[t]},me=s=>s instanceof Set?s.size===0:!s,J=new Map;tt=(s,t,e,r,n)=>{let i=J.get(s);i&&zt(i[t],a=>{a(e,r,n)})},ns=(s,t,e,r)=>{let{listener:n,errHandler:i,rawEmitter:a}=r,o=J.get(t),c;if(!e.persistent)return c=ue(s,e,n,i,a),c?c.close.bind(c):void 0;if(o)W(o,F,n),W(o,X,i),W(o,H,a);else{if(c=ue(s,e,tt.bind(null,t,F),i,tt.bind(null,t,H)),!c)return;c.on(b.ERROR,async l=>{let u=tt.bind(null,t,X);if(o&&(o.watcherUnusable=!0),Wt&&l.code==="EPERM")try{await(await(0,x.open)(s,"r")).close(),u(l)}catch{}else u(l)}),o={listeners:n,errHandlers:i,rawEmitters:a,watcher:c},J.set(t,o)}return()=>{j(o,F,n),j(o,X,i),j(o,H,a),me(o.listeners)&&(o.watcher.close(),J.delete(t),Je.forEach(ss(o)),o.watcher=void 0,Object.freeze(o))}},Nt=new Map,rs=(s,t,e,r)=>{let{listener:n,rawEmitter:i}=r,a=Nt.get(t),o=a&&a.options;return o&&(o.persistent<e.persistent||o.interval>e.interval)&&((0,I.unwatchFile)(t),a=void 0),a?(W(a,F,n),W(a,H,i)):(a={listeners:n,rawEmitters:i,options:e,watcher:(0,I.watchFile)(t,e,(c,l)=>{zt(a.rawEmitters,d=>{d(b.CHANGE,t,{curr:c,prev:l})});let u=c.mtimeMs;(c.size!==l.size||u>l.mtimeMs||u===0)&&zt(a.listeners,d=>d(s,c))})},Nt.set(t,a)),()=>{j(a,F,n),j(a,H,i),me(a.listeners)&&(Nt.delete(t),(0,I.unwatchFile)(t),a.options=a.watcher=void 0,Object.freeze(a))}},et=class{constructor(t){this.fsw=t,this._boundHandleError=e=>t._handleError(e)}_watchWithNodeFs(t,e){let r=this.fsw.options,n=w.dirname(t),i=w.basename(t);this.fsw._getWatchedDir(n).add(i);let o=w.resolve(t),c={persistent:r.persistent};e||(e=st);let l;if(r.usePolling){let u=r.interval!==r.binaryInterval;c.interval=u&&es(i)?r.binaryInterval:r.interval,l=rs(t,o,c,{listener:e,rawEmitter:this.fsw._emitRaw})}else l=ns(t,o,c,{listener:e,errHandler:this._boundHandleError,rawEmitter:this.fsw._emitRaw});return l}_handleFile(t,e,r){if(this.fsw.closed)return;let n=w.dirname(t),i=w.basename(t),a=this.fsw._getWatchedDir(n),o=e;if(a.has(i))return;let c=async(u,d)=>{if(this.fsw._throttle(Ze,t,5)){if(!d||d.mtimeMs===0)try{let h=await(0,x.stat)(t);if(this.fsw.closed)return;let f=h.atimeMs,g=h.mtimeMs;if((!f||f<=g||g!==o.mtimeMs)&&this.fsw._emit(b.CHANGE,t,h),(Ve||Ke||Qe)&&o.ino!==h.ino){this.fsw._closeFile(u),o=h;let P=this._watchWithNodeFs(t,c);P&&this.fsw._addPathCloser(u,P)}else o=h}catch{this.fsw._remove(n,i)}else if(a.has(i)){let h=d.atimeMs,f=d.mtimeMs;(!h||h<=f||f!==o.mtimeMs)&&this.fsw._emit(b.CHANGE,t,d),o=d}}},l=this._watchWithNodeFs(t,c);if(!(r&&this.fsw.options.ignoreInitial)&&this.fsw._isntIgnored(t)){if(!this.fsw._throttle(b.ADD,t,0))return;this.fsw._emit(b.ADD,t,e)}return l}async _handleSymlink(t,e,r,n){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(0,x.realpath)(r)}catch{return this.fsw._emitReady(),!0}return this.fsw.closed?void 0:(a.has(n)?this.fsw._symlinkPaths.get(i)!==o&&(this.fsw._symlinkPaths.set(i,o),this.fsw._emit(b.CHANGE,r,t.stats)):(a.add(n),this.fsw._symlinkPaths.set(i,o),this.fsw._emit(b.ADD,r,t.stats)),this.fsw._emitReady(),!0)}if(this.fsw._symlinkPaths.has(i))return!0;this.fsw._symlinkPaths.set(i,!0)}_handleRead(t,e,r,n,i,a,o){if(t=w.join(t,""),o=this.fsw._throttle("readdir",t,1e3),!o)return;let c=this.fsw._getWatchedDir(r.path),l=new Set,u=this.fsw._readdirp(t,{fileFilter:d=>r.filterPath(d),directoryFilter:d=>r.filterDir(d)});if(u)return u.on(Ge,async d=>{if(this.fsw.closed){u=void 0;return}let h=d.path,f=w.join(t,h);if(l.add(h),!(d.stats.isSymbolicLink()&&await this._handleSymlink(d,t,f,h))){if(this.fsw.closed){u=void 0;return}(h===n||!n&&!c.has(h))&&(this.fsw._incrReadyCount(),f=w.join(i,w.relative(i,f)),this._addToNodeFs(f,e,r,a+1))}}).on(b.ERROR,this._boundHandleError),new Promise((d,h)=>{if(!u)return h();u.once($t,()=>{if(this.fsw.closed){u=void 0;return}let f=o?o.clear():!1;d(void 0),c.getChildren().filter(g=>g!==t&&!l.has(g)).forEach(g=>{this.fsw._remove(t,g)}),u=void 0,f&&this._handleRead(t,!1,r,n,i,a,o)})})}async _handleDir(t,e,r,n,i,a,o){let c=this.fsw._getWatchedDir(w.dirname(t)),l=c.has(w.basename(t));!(r&&this.fsw.options.ignoreInitial)&&!i&&!l&&this.fsw._emit(b.ADD_DIR,t,e),c.add(w.basename(t)),this.fsw._getWatchedDir(t);let u,d,h=this.fsw.options.depth;if((h==null||n<=h)&&!this.fsw._symlinkPaths.has(o)){if(!i&&(await this._handleRead(t,r,a,i,t,n,u),this.fsw.closed))return;d=this._watchWithNodeFs(t,(f,g)=>{g&&g.mtimeMs===0||this._handleRead(f,!1,a,i,t,n,u)})}return d}async _addToNodeFs(t,e,r,n,i){let a=this.fsw._emitReady;if(this.fsw._isIgnored(t)||this.fsw.closed)return a(),!1;let o=this.fsw._getWatchHelpers(t);r&&(o.filterPath=c=>r.filterPath(c),o.filterDir=c=>r.filterDir(c));try{let c=await Xe[o.statMethod](o.watchPath);if(this.fsw.closed)return;if(this.fsw._isIgnored(o.watchPath,c))return a(),!1;let l=this.fsw.options.followSymlinks,u;if(c.isDirectory()){let d=w.resolve(t),h=l?await(0,x.realpath)(t):t;if(this.fsw.closed||(u=await this._handleDir(o.watchPath,c,e,n,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(0,x.realpath)(t):t;if(this.fsw.closed)return;let h=w.dirname(o.watchPath);if(this.fsw._getWatchedDir(h).add(o.watchPath),this.fsw._emit(b.ADD,o.watchPath,c),u=await this._handleDir(h,c,e,n,t,o,d),this.fsw.closed)return;d!==void 0&&this.fsw._symlinkPaths.set(w.resolve(t),d)}else u=this._handleFile(o.watchPath,c,e);return a(),u&&this.fsw._addPathCloser(t,u),!1}catch(c){if(this.fsw._handleError(c))return a(),t}}}});var Le={};Yt(Le,{FSWatcher:()=>U,WatchHelper:()=>it,default:()=>ws,watch:()=>Re});function rt(s){return Array.isArray(s)?s:[s]}function ds(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=m.relative(s.path,t);return e?!e.startsWith("..")&&!m.isAbsolute(e):!1}return!1}:()=>!1}function hs(s){if(typeof s!="string")throw new Error("string expected");s=m.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 ye(s,t,e){let r=hs(t);for(let n=0;n<s.length;n++){let i=s[n];if(i(r,e))return!0}return!1}function fs(s,t){if(s==null)throw new TypeError("anymatch: specify first argument");let r=rt(s).map(n=>ds(n));return t==null?(n,i)=>ye(r,n,i):ye(r,t)}function Re(s,t={}){let e=new U(t);return e.add(s),e}var _e,ot,Se,m,jt,is,Pe,os,as,cs,ge,ls,us,Ut,we,Ee,ve,Te,ms,ps,qt,gs,ys,it,U,ws,be=at(()=>{"use strict";_e=require("fs"),ot=require("fs/promises"),Se=require("events"),m=v(require("path"),1);le();pe();jt="/",is="//",Pe=".",os="..",as="string",cs=/\\/g,ge=/\/\//,ls=/\..*\.(sw[px])$|~$|\.subl.*\.tmp/,us=/^\.[/\\]/;Ut=s=>typeof s=="object"&&s!==null&&!(s instanceof RegExp);we=s=>{let t=rt(s).flat();if(!t.every(e=>typeof e===as))throw new TypeError(`Non-string provided as watch path: ${t}`);return t.map(ve)},Ee=s=>{let t=s.replace(cs,jt),e=!1;for(t.startsWith(is)&&(e=!0);t.match(ge);)t=t.replace(ge,jt);return e&&(t=jt+t),t},ve=s=>Ee(m.normalize(Ee(s))),Te=(s="")=>t=>typeof t=="string"?ve(m.isAbsolute(t)?t:m.join(s,t)):t,ms=(s,t)=>m.isAbsolute(s)?s:m.join(t,s),ps=Object.freeze(new Set),qt=class{constructor(t,e){this.path=t,this._removeWatcher=e,this.items=new Set}add(t){let{items:e}=this;e&&t!==Pe&&t!==os&&e.add(t)}async remove(t){let{items:e}=this;if(!e||(e.delete(t),e.size>0))return;let r=this.path;try{await(0,ot.readdir)(r)}catch{this._removeWatcher&&this._removeWatcher(m.dirname(r),m.basename(r))}}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=st,this.items=ps,Object.freeze(this)}},gs="stat",ys="lstat",it=class{constructor(t,e,r){this.fsw=r;let n=t;this.path=t=t.replace(us,""),this.watchPath=n,this.fullWatchPath=m.resolve(n),this.dirParts=[],this.dirParts.forEach(i=>{i.length>1&&i.pop()}),this.followSymlinks=e,this.statMethod=e?gs:ys}entryPath(t){return m.join(this.watchPath,m.relative(this.watchPath,t.fullPath))}filterPath(t){let{stats:e}=t;if(e&&e.isSymbolicLink())return this.filterDir(t);let r=this.entryPath(t);return this.fsw._isntIgnored(r,e)&&this.fsw._hasReadPermissions(e)}filterDir(t){return this.fsw._isntIgnored(this.entryPath(t),t.stats)}},U=class extends Se.EventEmitter{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,r={stabilityThreshold:2e3,pollInterval:100},n={persistent:!0,ignoreInitial:!1,ignorePermissionErrors:!1,interval:100,binaryInterval:300,followSymlinks:!0,usePolling:!1,atomic:!0,...t,ignored:t.ignored?rt(t.ignored):rt([]),awaitWriteFinish:e===!0?r:typeof e=="object"?{...r,...e}:!1};fe&&(n.usePolling=!0),n.atomic===void 0&&(n.atomic=!n.usePolling);let i=process.env.CHOKIDAR_USEPOLLING;if(i!==void 0){let c=i.toLowerCase();c==="false"||c==="0"?n.usePolling=!1:c==="true"||c==="1"?n.usePolling=!0:n.usePolling=!!c}let a=process.env.CHOKIDAR_INTERVAL;a&&(n.interval=Number.parseInt(a,10));let o=0;this._emitReady=()=>{o++,o>=this._readyCount&&(this._emitReady=st,this._readyEmitted=!0,process.nextTick(()=>this.emit(E.READY)))},this._emitRaw=(...c)=>this.emit(E.RAW,...c),this._boundRemove=this._remove.bind(this),this.options=n,this._nodeFsHandler=new et(this),Object.freeze(n)}_addIgnoredPath(t){if(Ut(t)){for(let e of this._ignoredPaths)if(Ut(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)Ut(e)&&e.path===t&&this._ignoredPaths.delete(e)}add(t,e,r){let{cwd:n}=this.options;this.closed=!1,this._closePromise=void 0;let i=we(t);return n&&(i=i.map(a=>ms(a,n))),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,!r,void 0,0,e);return o&&this._emitReady(),o})).then(a=>{this.closed||a.forEach(o=>{o&&this.add(m.dirname(o),m.basename(e||o))})}),this}unwatch(t){if(this.closed)return this;let e=we(t),{cwd:r}=this.options;return e.forEach(n=>{!m.isAbsolute(n)&&!this._closers.has(n)&&(r&&(n=m.join(r,n)),n=m.resolve(n)),this._closePath(n),this._addIgnoredPath(n),this._watched.has(n)&&this._addIgnoredPath({path:n,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(r=>{let n=r();n instanceof Promise&&t.push(n)})),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,r)=>{let i=(this.options.cwd?m.relative(this.options.cwd,r):r)||Pe;t[i]=e.getChildren().sort()}),t}emitWithAll(t,e){this.emit(t,...e),t!==E.ERROR&&this.emit(E.ALL,t,...e)}async _emit(t,e,r){if(this.closed)return;let n=this.options;Wt&&(e=m.normalize(e)),n.cwd&&(e=m.relative(n.cwd,e));let i=[e];r!=null&&i.push(r);let a=n.awaitWriteFinish,o;if(a&&(o=this._pendingWrites.get(e)))return o.lastChange=new Date,this;if(n.atomic){if(t===E.UNLINK)return this._pendingUnlinks.set(e,[t,...i]),setTimeout(()=>{this._pendingUnlinks.forEach((c,l)=>{this.emit(...c),this.emit(E.ALL,...c),this._pendingUnlinks.delete(l)})},typeof n.atomic=="number"?n.atomic:100),this;t===E.ADD&&this._pendingUnlinks.has(e)&&(t=E.CHANGE,this._pendingUnlinks.delete(e))}if(a&&(t===E.ADD||t===E.CHANGE)&&this._readyEmitted){let c=(l,u)=>{l?(t=E.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===E.CHANGE&&!this._throttle(E.CHANGE,e,50))return this;if(n.alwaysStat&&r===void 0&&(t===E.ADD||t===E.ADD_DIR||t===E.CHANGE)){let c=n.cwd?m.join(n.cwd,e):e,l;try{l=await(0,ot.stat)(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(E.ERROR,t),t||this.closed}_throttle(t,e,r){this._throttled.has(t)||this._throttled.set(t,new Map);let n=this._throttled.get(t);if(!n)throw new Error("invalid throttle");let i=n.get(e);if(i)return i.count++,!1;let a,o=()=>{let l=n.get(e),u=l?l.count:0;return n.delete(e),clearTimeout(a),l&&clearTimeout(l.timeoutObject),u};a=setTimeout(o,r);let c={timeoutObject:a,clear:o,count:0};return n.set(e,c),c}_incrReadyCount(){return this._readyCount++}_awaitWriteFinish(t,e,r,n){let i=this.options.awaitWriteFinish;if(typeof i!="object")return;let a=i.pollInterval,o,c=t;this.options.cwd&&!m.isAbsolute(t)&&(c=m.join(this.options.cwd,t));let l=new Date,u=this._pendingWrites;function d(h){(0,_e.stat)(c,(f,g)=>{if(f||!u.has(t)){f&&f.code!=="ENOENT"&&n(f);return}let P=Number(new Date);h&&g.size!==h.size&&(u.get(t).lastChange=P);let T=u.get(t);P-T.lastChange>=e?(u.delete(t),n(void 0,g)):o=setTimeout(d,a,g)})}u.has(t)||(u.set(t,{lastChange:l,cancelWait:()=>(u.delete(t),clearTimeout(o),r)}),o=setTimeout(d,a))}_isIgnored(t,e){if(this.options.atomic&&ls.test(t))return!0;if(!this._userIgnored){let{cwd:r}=this.options,i=(this.options.ignored||[]).map(Te(r)),o=[...[...this._ignoredPaths].map(Te(r)),...i];this._userIgnored=fs(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=m.resolve(t);return this._watched.has(e)||this._watched.set(e,new qt(e,this._boundRemove)),this._watched.get(e)}_hasReadPermissions(t){return this.options.ignorePermissionErrors?!0:!!(Number(t.mode)&256)}_remove(t,e,r){let n=m.join(t,e),i=m.resolve(n);if(r=r??(this._watched.has(n)||this._watched.has(i)),!this._throttle("remove",n,100))return;!r&&this._watched.size===1&&this.add(t,e,!0),this._getWatchedDir(n).getChildren().forEach(h=>this._remove(n,h));let c=this._getWatchedDir(t),l=c.has(e);c.remove(e),this._symlinkPaths.has(i)&&this._symlinkPaths.delete(i);let u=n;if(this.options.cwd&&(u=m.relative(this.options.cwd,n)),this.options.awaitWriteFinish&&this._pendingWrites.has(u)&&this._pendingWrites.get(u).cancelWait()===E.ADD)return;this._watched.delete(n),this._watched.delete(i);let d=r?E.UNLINK_DIR:E.UNLINK;l&&!this._isIgnored(n)&&this._emit(d,n),this._closePath(n)}_closePath(t){this._closeFile(t);let e=m.dirname(t);this._getWatchedDir(e).remove(m.basename(t))}_closeFile(t){let e=this._closers.get(t);e&&(e.forEach(r=>r()),this._closers.delete(t))}_addPathCloser(t,e){if(!e)return;let r=this._closers.get(t);r||(r=[],this._closers.set(t,r)),r.push(e)}_readdirp(t,e){if(this.closed)return;let r={type:E.ALL,alwaysStat:!0,lstat:!0,...e,depth:0},n=ce(t,r);return this._streams.add(n),n.once(he,()=>{n=void 0}),n.once($t,()=>{n&&(this._streams.delete(n),n=void 0)}),n}};ws={watch:Re,FSWatcher:U}});var Es={};Yt(Es,{TSFilebasedRouter:()=>xe,TSRouter:()=>Z,createEffect:()=>xt,createSignal:()=>bt,html:()=>ct,loadPyFiles:()=>Dt,mapper:()=>Gt,renderChildRoutes:()=>Lt,useAnchor:()=>$,useAnchorSingle:()=>Tt,useInitialDOM:()=>wt,useTSAuth:()=>Pt,useTSCollection:()=>St,useTSComponent:()=>z,useTSElementEach:()=>Q,useTSElements:()=>gt,useTSEvent:()=>dt,useTSEventAll:()=>mt,useTSExtractParams:()=>ft,useTSLazy:()=>Mt,useTSMetaData:()=>_t,useTSNavigate:()=>vt,useTSNoReload:()=>Ft,useTSOutlet:()=>Rt,useTSParams:()=>N,useTSPurifier:()=>ut,useTSSSRHydration:()=>Ct,useTSSelect:()=>k,useTSloadBrython:()=>At});module.exports=Ie(Es);function ke(s){let t=s==null?"":String(s),e=t.toLowerCase();return(e.includes("<script")||e.includes("javascript:"))&&(t=""),t=t.replace(/url\(\s*(['"])?\s*\1?\s*\)/gi,""),t.replace(/<\s*(script|iframe|object|embed|link|style|meta|body)[^>]*>.*?<\s*\/\s*\1\s*>/gi,"").replace(/<\s*(script|iframe|object|embed|link|style|meta)[^>]*>/gi,"").replace(/\s+on\w+\s*=\s*(['"]).*?\1/gi,"").replace(/\s+on\w+\s*=\s*[^\s>]+/gi,"").replace(/\s(href|src)\s*=\s*(['"]?)\s*(javascript:|vbscript:|data:|file:)[^'">\s]*\2/gi,'$1="#"')}function ct(s,...t){return s.reduce((e,r,n)=>{let i=n<t.length?ke(t[n]):"";return e+r+i},"")}var He=s=>s.replace(/<\/?(script|iframe|object|embed|link|meta|style|form|textarea|svg|math|body)[^>]*>/gi,"").replace(/<(?!\/?(b|i|em|strong|p|br|ul|ol|li|a|div|span|h1|h2|h3|h4|h5|h6|section|article|input|button)\b)[^>]*>/gi,"").replace(/\s+on[a-z]+\s*=\s*("[^"]*"|'[^']*'|[^\s>]+)/gi,"").replace(/\s*style\s*=\s*("[^"]*"|'[^']*')/gi,"").replace(/<a\b([^>]*)href\s*=\s*(['"]?)(?!https?:|#)[^'"\s>]+(['"]?)([^>]*)>/gi,"<a$1$4>").replace(/\s+(href|src)\s*=\s*(['"]?)\s*(javascript:|data:)[^'"\s>]*/gi,"").replace(/<a\b([^>]*)\bhref\s*=\s*(['"])(\/blog|#blog)\2([^>]*)>/gi,'<a$1 href=$2$3$2 href-line="true"$4>').trim(),Gt=s=>s?.map(t=>He(t)).join("")??"";var lt=v(require("dompurify"),1),ut=(s,t)=>{let r={...{ADD_TAGS:["my-custom-tag"]},...t};return typeof s=="string"?lt.default.sanitize(s,r):lt.default.sanitize(s.innerHTML,r)};var dt=(s,t,e)=>{if(typeof s=="string"){let r=document.getElementById(s);r?r.addEventListener(t,e):console.warn(`Element with id '${s}' not found.`)}else s instanceof HTMLElement?s.addEventListener(t,e):s===document?document.addEventListener(t,e):console.warn("Invalid target parameter provided.")};var Vt=require("zustand/vanilla"),ht=v(require("dompurify"),1);function Ne(s,t){let e=[],r=s.replace(/:[^/]+/g,o=>(e.push(o.slice(1)),"([^/]+)")),n=new RegExp(`^${r}$`),i=t.match(n),a={};return i&&e.forEach((o,c)=>{a[o]=ht.default.sanitize(i[c+1]??"")}),a}function ze(s){let t={},e=new URLSearchParams(s);for(let[r,n]of e.entries())t[r]=ht.default.sanitize(n);return t}var N=(0,Vt.createStore)((s,t)=>({params:{},query:{},setFromPattern:e=>{let r=window.location.pathname,n=Ne(e,r),i=ze(window.location.search);s({params:n,query:i})},getParam:e=>t().params[e],getQuery:e=>t().query[e]}));function ft(s){let t=N.getState();t.setFromPattern(s);let e=t.params,r=t.query;return{...e,...r}}var mt=(s,t,e)=>{let r=document.querySelectorAll(s);return r.forEach(n=>{n.addEventListener(t,e)}),()=>{r.forEach(n=>{n.removeEventListener(t,e)})}};var pt=v(require("dompurify"),1),gt=(s,t,e={},r)=>{let n={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","label","form"],ALLOWED_ATTR:["class","id","href","src","alt","title","fill","stroke","stroke-width","viewBox","xmlns","d","x","y","cx","cy","r","width","height","type","name","value","placeholder","data-click","data-change","data-select","data-classlist","data-hover","data-submit","data-key","data-event"],FORBID_TAGS:["script","iframe","foreignObject","body","html"],FORBID_ATTR:["style","xlink:href"],ALLOWED_URI_REGEXP:/^(?:(?:https?|mailto|tel|ftp):|[^a-z]|[a-z+.\-]+(?:[^a-z+.\-:]|$))/i,...r};pt.default.addHook("uponSanitizeAttribute",(o,c)=>{let l=(c.attrName||"").toLowerCase(),u=(c.attrValue??"").toString().trim();if(l.startsWith("on")){c.keepAttr=!1;return}if(/^data-(click|change|submit|select|hover|classlist|key|event)$/.test(l)){c.keepAttr=!0;return}if(o.nodeName.toLowerCase()==="img"&&l==="src"){/^https?:\/\//i.test(u)||/^\/(?!\/)/.test(u)||/^data:image\/(png|jpeg|jpg|gif|webp);base64,/i.test(u)||(c.keepAttr=!1);return}if(l==="class"){let h=u.split(/\s+/).filter(Boolean).filter(f=>{if(/^[a-zA-Z0-9\-\:\/_\[\]\(\)]*$/.test(f)){if(/^bg-\[url\(.*\)\]$/.test(f)){let g=f.replace(/^bg-\[url\(/,"").replace(/\)\]$/,"").replace(/^['"]|['"]$/g,"");return g===""||/^https?:\/\//i.test(g)||/^\/(?!\/)/.test(g)||/^\.{0,2}\//.test(g)}return/^bg-\[\]$/.test(f),!0}return!1});c.attrValue=h.join(" ");return}});let i=pt.default.sanitize(t,{...n,RETURN_DOM_FRAGMENT:!0});for(;s.firstChild;)s.removeChild(s.firstChild);s.appendChild(i);let a=(o,c)=>{s.querySelectorAll(`[${o}]`).forEach(l=>{let u=l.getAttribute(o);u&&Object.prototype.hasOwnProperty.call(e,u)&&l.addEventListener(c,d=>{c==="submit"&&d.preventDefault(),e[u](d)})})};a("data-click","click"),a("data-change","change"),a("data-select","select"),a("data-submit","submit"),s.querySelectorAll("[data-key]").forEach(o=>{let c=o.dataset.key,l=o.dataset.event??"click";c&&Object.prototype.hasOwnProperty.call(e,c)&&o.addEventListener(l,e[c])}),s.querySelectorAll("[data-hover]").forEach(o=>{let c=o.dataset.hover;c&&Object.prototype.hasOwnProperty.call(e,c)&&(o.addEventListener("mouseenter",e[c]),o.addEventListener("mouseleave",e[c]))}),s.querySelectorAll("[data-classlist]").forEach(o=>{let c=o.dataset.classlist;/^[a-zA-Z0-9\-\s:_]+$/.test(c)&&o.classList.add(...c.split(/\s+/))})};var yt=v(require("dompurify"),1),K=null,wt=(s,t)=>{if(typeof document>"u")return;let e=document.getElementById(s);if(!e)return;yt.default.addHook("uponSanitizeAttribute",(a,o)=>{let c=(o.attrName||"").toLowerCase(),l=(o.attrValue??"").toString().trim();if(c.startsWith("on")){o.keepAttr=!1;return}if((c==="href"||c==="src")&&/^(javascript:|vbscript:|data:|file:|about:)/i.test(l)){o.keepAttr=!1;return}if(c==="class"){let d=l.split(/\s+/).filter(Boolean).filter(h=>{if(/^[a-zA-Z0-9\-\:\/_\[\]\(\)]+$/.test(h)){if(/^bg-\[url\(.*\)\]$/.test(h)){let f=h.replace(/^bg-\[url\(/,"").replace(/\)\]$/,"").replace(/^['"]|['"]$/g,"");return f===""||/^https?:\/\//i.test(f)||/^\/(?!\/)/.test(f)||/^\.{0,2}\//.test(f)}return!0}return!1});o.attrValue=d.join(" ");return}if(c==="style"){o.keepAttr=!1;return}});let r=e.cloneNode(!0),n=yt.default.sanitize(r.innerHTML,{USE_PROFILES:{html:!0},ALLOWED_TAGS:["div","span","p","h1","h2","h3","h4","h5","h6","ul","ol","li","strong","em","a","img","br","form","button","input","label"],ALLOWED_ATTR:["href","src","alt","title","class","id","type","name","value","placeholder","data-click","data-change","data-submit","data-select","data-hover","data-classlist"],FORBID_TAGS:["script","iframe","object","embed","body","html","svg","math","link","meta"],ALLOW_DATA_ATTR:!0,KEEP_CONTENT:!1,RETURN_DOM_FRAGMENT:!0}),i=Array.from(n.childNodes).map(a=>a.outerHTML||a.textContent||"").join("");if(K!==null&&i!==K){let a=document.createElement("div");t(a);let c=new DOMParser().parseFromString(K,"text/html");for(;e.firstChild;)e.removeChild(e.firstChild);c.body.childNodes.forEach(l=>e.appendChild(l.cloneNode(!0)))}else{for(K=i;e.firstChild;)e.removeChild(e.firstChild);e.appendChild(n),t(e)}};var Et=v(require("dompurify"),1);typeof window<"u"&&!window.__anchorSinglePopstateHandlerAttached&&(window.addEventListener("popstate",s=>{let t=s.state;t?.scrollPosition!==void 0&&window.scrollTo(0,t.scrollPosition)}),window.__anchorSinglePopstateHandlerAttached=!0);var Tt=(s,t,e,r="",n=null)=>{if(!s)return;let i=Et.default.sanitize(t,{ALLOWED_URI_REGEXP:/^(https?:|\/)/}),a=Et.default.sanitize(e,{USE_PROFILES:{html:!1}});s.setAttribute("href",i),s.setAttribute("aria-label",a),r&&(s.className=r.trim()),n&&s.replaceChildren(n),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"))}})};var A=v(require("dompurify"),1);var Kt=(s="'self' 'nonce-rAnd0m123' 'unsafe-inline' 'unsafe-eval'",t="'self' 'nonce-rAnd0m123'",e="'none'",r="'self' https://fonts.googleapis.com https://fonts.gstatic.com",n="'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 ${r}; img-src ${n}; 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 _t=(s,t)=>{let e={name:A.default.sanitize(s.name||""),title:A.default.sanitize(s.title||""),description:A.default.sanitize(s.description||"Default description"),author:A.default.sanitize(s.author||""),favicon:s.favicon},r=p=>{e.name=A.default.sanitize(p),P("name",e.name)},n=p=>{e.title=A.default.sanitize(p),document.title=e.title},i=p=>{e.description=A.default.sanitize(p),P("description",e.description)},a=p=>{e.author=A.default.sanitize(p),P("author",e.author)},o=p=>{e.favicon=A.default.sanitize(p);let y=document.querySelector('link[rel="icon"]');y||(y=document.createElement("link"),y.rel="icon",document.head.appendChild(y)),y.href=e.favicon},c=()=>e.name,l=()=>e.title,u=()=>e.description,d=()=>e.author,h=()=>e.favicon,f=()=>e,g=(p,y)=>{let _=document.createElement("meta");_.setAttribute("name",p),_.setAttribute("content",y),document.head.appendChild(_)},P=(p,y)=>{let _=document.querySelector(`meta[name="${p}"]`);_?_.setAttribute("content",y):g(p,y)},T=()=>{e.title&&(document.title=e.title),e.name&&P("name",e.name),e.description&&P("description",e.description),e.author&&P("author",e.author),e.favicon&&o(e.favicon)};return t&&Kt(t.scriptSrc,t.styleSrc,t.objectSrc,Array.isArray(t.connectSrc)?t.connectSrc.join(" "):t.connectSrc,t.reportOnly!==void 0?String(t.reportOnly):void 0),T(),{setName:r,setTitle:n,setDescription:i,setAuthor:a,setFavicon:o,getName:c,getTitle:l,getDescription:u,getAuthor:d,getFavicon:h,getAllMetaData:f,appendMetaTagsToHead:T}};var Qt=v(require("dompurify"),1),z=(s,t,e,r,n)=>{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=Qt.default.sanitize(o.innerHTML,{USE_PROFILES:{html:!0}}),e(o,r,n)};var St=(s,t,e,r=[])=>{let n=new Set;s.forEach((i,a)=>{if(n.has(i)){console.warn(`[useTSCollection] Duplicate ID in collection array: "${i}" \u2014 skipping.`);return}n.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(r)?r[a]:void 0;typeof c=="function"?z(i,t,c,l):console.warn(`[useTSCollection] No valid component function found for ID: "${i}"`)})};var k=(s,t)=>{let r=(t??document).querySelectorAll(s);if(r.length===0)return process.env.NODE_ENV!=="production"&&console.warn(`[useTSSelect] No element found for selector: '${s}'`),null;if(s.startsWith("#")&&r.length>1){if(process.env.NODE_ENV!=="production")throw new Error(`[useTSSelect] Duplicate ID detected: '${s}'. 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: '${s}'. Returning the first one.`),r[0]};var Zt=require("jwt-decode"),Pt=(s,t)=>{let e=localStorage.getItem("token");if(!e)return window.location.href=t,null;try{let r=(0,Zt.jwtDecode)(e),n=Date.now()/1e3;return r.exp&&r.exp<n&&(console.error("Token has expired"),window.localStorage.removeItem("token"),window.location.href=t),null}catch(r){return console.error("Invalid token:",r),window.location.href=t,null}};var Q=(s,t,e)=>{s.forEach(r=>{t.forEach(n=>{r.addEventListener(n,i=>{e(r,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 r=window.location.pathname.replace(/\/$/,"");for(let n of t){let i=n.path.replace(/\/$/,"");if(r===i||r.startsWith(`${i}/`)){n.component(e);break}}};function Lt(s,t){let e=window.location.pathname.replace(/\/$/,"");t.routes.forEach(r=>{r.children?.length&&r.children.forEach(n=>{let i=n.path.replace(/\/$/,"");if(e===i||e.startsWith(`${i}/`)){let a=s.querySelector(`#${n.outlet}`)||s.querySelector(`.${n.outlet}`);a instanceof HTMLElement&&n.element&&n.element(a)}})})}var Xt=require("zustand/vanilla");function bt(s){let t=(0,Xt.createStore)(()=>({value:s})),e=new Set;return{get:()=>t.getState().value,set:r=>{t.setState({value:r}),e.forEach(n=>n(r))},subscribe:r=>(e.add(r),r(t.getState().value),()=>e.delete(r))}}function xt(s){let t=s();typeof t=="function"&&t()}var At=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=r=>new Promise((n,i)=>{let a=document.createElement("script");a.src=r,a.onload=()=>n(),a.onerror=()=>i(new Error(`Failed to load ${r}`)),document.head.appendChild(a)});await e(s),await e(t),typeof window.brython=="function"?window.brython():console.error("Brython did not load correctly.")},Dt=s=>new Promise((t,e)=>{let r=document.createElement("script");r.type="text/python",r.src=`/src/python/${s}`,r.onload=()=>t(),r.onerror=()=>e(new Error(`Failed to load ${s}`)),document.body.appendChild(r)});function Mt(s){let t=null;return async(e,r)=>{try{if(!t){let n=await s();t=n.default||n}if(typeof t=="function")return t(e,r);if(t instanceof HTMLElement){let n=t.cloneNode(!0);return e?.appendChild(n),n}if(typeof t=="object"&&t!==null&&"render"in t&&typeof t.render=="function")return t.render(e,r);console.warn("useTSLazy: Unsupported module type",t)}catch(n){console.error("useTSLazy failed:",n)}}}var Ct=s=>typeof window>"u"?{isDOM:null}:{isDOM:s||document.body};var Jt=require("lodash-es"),Ot=s=>s;typeof window<"u"&&typeof document<"u"&&(Ot=s=>{let t=document.createElement("div");return t.innerText=s,t.innerHTML});var $e=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 r=e.getAttribute("class")||"";e.setAttribute("class",Ot(r));let n=e.getAttribute("aria-label");n&&e.setAttribute("aria-label",Ot(n));let i=e.querySelector(":scope > *");i&&(e.innerHTML="",e.appendChild(i));let a=e.getAttribute("href")||"";if(!a.startsWith("#")){try{if(new URL(a,window.location.href).origin!==window.location.origin)return}catch{return}e.addEventListener("click",o=>{o.preventDefault();let c=e.getAttribute("href")||"";try{let l=new URL(c,window.location.href);window.history.pushState({},"",l.pathname+l.search+l.hash),window.dispatchEvent(new PopStateEvent("popstate"))}catch(l){console.error("Invalid URL in anchor:",c,l)}})}})},We=(0,Jt.debounce)($e,50),$=s=>{We(s)};var Ft=s=>{if(!s)return;let t=k("a",s);$(t)};var It=v(require("dompurify"),1);var ee=require("zustand/vanilla"),se=v(require("dompurify"),1),O=(0,ee.createStore)(s=>({params:{},query:{},setParams:t=>s(()=>({params:te(t)})),setQuery:t=>s(()=>({query:te(t)}))}));function te(s){let t={};for(let e in s)t[e]=se.default.sanitize(s[e]);return t}var Z=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,r=this.parseQueryParams(e),n=this.findMatchingRoute(t,this.routes);if(n){if(n.routeto){this.navigate(n.routeto);return}let i=this.filterAndSanitizeParams(n.params);O.getState().setParams(i),O.getState().setQuery(r);let a=document.createElement("div");if(n.element?.(a,i,r),n.children){let o=t.slice(n.path.length),c=a.querySelector("#child");c&&this.renderChildren(n.children,o,c,i,r)}}else{let i=this.findMatchingRoute("*",this.routes);if(i){let a=this.filterAndSanitizeParams(i.params);O.getState().setParams(a),O.getState().setQuery(r);let o=document.createElement("div");i.element?.(o,a,r)}}}renderChildren(t,e,r,n,i){if(!t||t.length===0){let o=r.querySelector("#child");o&&o.remove();return}let a=this.findMatchingRoute(e,t);if(a){let o=document.createElement("div");o.id="child";let c={...n,...a.params},l=this.filterAndSanitizeParams(c);if(O.getState().setParams(l),O.getState().setQuery(i),a.element?.(o,l,i),r.appendChild(o),a.children){let u=e.slice(a.path.length);this.renderChildren(a.children,u,o,l,i)}}}parseQueryParams(t){let e={},r=new URLSearchParams(t);for(let[n,i]of r.entries())this.expectedParams.has(n)&&(e[n]=It.default.sanitize(i));return e}findMatchingRoute(t,e,r={}){for(let n of e){let i=n.path;if(i==="*")return n;{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={...r};if(o.forEach((h,f)=>{d[h]=u[f+1]??""}),n.children){let h=t.slice(u[0].length),f=this.findMatchingRoute(h,n.children,d);if(f)return f}return{...n,params:d}}}}}filterAndSanitizeParams(t){if(!t)return{};let e={};for(let r in t)this.expectedParams.has(r)&&(e[r]=It.default.sanitize(t[r]??""));return e}navigate(t){history.pushState(null,"",t),this.handlePopState()}addRoute(t){this.routes.push(t)}};var xe=()=>({name:"ts-filebased-router",async buildStart(){if(typeof process>"u"||!process.versions?.node)return;let s=await import("fs/promises"),t=await import("path"),e=await Promise.resolve().then(()=>(be(),Le)),r=t.resolve("src/pages"),n=t.resolve("src/gen"),i=t.resolve("src/routes"),a=t.join(n,"tsrouter.gen.ts"),o=t.join(i,"__root.ts"),c=process.env.NODE_ENV!=="production";async function l(T){try{await s.mkdir(T,{recursive:!0})}catch{}}function u(T,p){let y="/"+t.relative(p,T).replace(/\\/g,"/");return y=y.replace(/\.ts$/,"").replace(/\/index$/,"")||"/",y.replace(/\[(.+?)\]/g,":$1")}function d(T){return T.replace(/^\//,"").split("/").map(p=>p.startsWith(":")?p.slice(1):p).filter(Boolean).join("-")||"index"}function h(T,p){let _=t.relative(p,T).replace(/\\/g,"/").split("/").filter(Boolean),L=_[_.length-1].replace(".ts",""),D=_.length>1?_[_.length-2]:"";if(L==="index")return D?D.charAt(0).toUpperCase()+D.slice(1):"Index";if(L.startsWith("[")&&L.endsWith("]")){let S=L.slice(1,-1);return D.charAt(0).toUpperCase()+S.charAt(0).toUpperCase()+S.slice(1)}return L.charAt(0).toUpperCase()+L.slice(1)}async function f(T){let p=await s.readdir(T,{withFileTypes:!0}),y=[];for(let _ of p){let L=t.join(T,_.name);if(_.isDirectory())y=y.concat(await f(L));else if(_.isFile()&&_.name.endsWith(".ts")){let D=u(L,r),S=d(D),q=h(L,r);y.push({file:L,route:D,routeName:S,importName:q})}}return y}function g(){return`import { createRouter } from "@/gen/tsrouter.gen";
1
+ "use strict";var Ae=Object.create;var V=Object.defineProperty;var Me=Object.getOwnPropertyDescriptor;var Ce=Object.getOwnPropertyNames;var Oe=Object.getPrototypeOf,Fe=Object.prototype.hasOwnProperty;var at=(s,t)=>()=>(s&&(t=s(s=0)),t);var Yt=(s,t)=>{for(var e in t)V(s,e,{get:t[e],enumerable:!0})},Bt=(s,t,e,r)=>{if(t&&typeof t=="object"||typeof t=="function")for(let n of Ce(t))!Fe.call(s,n)&&n!==e&&V(s,n,{get:()=>t[n],enumerable:!(r=Me(t,n))||r.enumerable});return s};var v=(s,t,e)=>(e=s!=null?Ae(Oe(s)):{},Bt(t||!s||!s.__esModule?V(e,"default",{value:s,enumerable:!0}):e,s)),Ie=s=>Bt(V({},"__esModule",{value:!0}),s);function ce(s,t={}){let e=t.entryType||t.type;if(e==="both"&&(e=R.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&&!ne.includes(e))throw new Error(`readdirp: Invalid type passed. Use one of ${ne.join(", ")}`)}else throw new Error("readdirp: root argument is required. Usage: readdirp(root, options)");return t.root=s,new Ht(t)}var M,oe,C,R,kt,ae,je,ne,Ue,qe,Ye,Be,re,ie,Ht,le=at(()=>{"use strict";M=require("fs/promises"),oe=require("stream"),C=require("path"),R={FILE_TYPE:"files",DIR_TYPE:"directories",FILE_DIR_TYPE:"files_directories",EVERYTHING_TYPE:"all"},kt={root:".",fileFilter:s=>!0,directoryFilter:s=>!0,type:R.FILE_TYPE,lstat:!1,depth:2147483648,alwaysStat:!1,highWaterMark:4096};Object.freeze(kt);ae="READDIRP_RECURSIVE_ERROR",je=new Set(["ENOENT","EPERM","EACCES","ELOOP",ae]),ne=[R.DIR_TYPE,R.EVERYTHING_TYPE,R.FILE_DIR_TYPE,R.FILE_TYPE],Ue=new Set([R.DIR_TYPE,R.EVERYTHING_TYPE,R.FILE_DIR_TYPE]),qe=new Set([R.EVERYTHING_TYPE,R.FILE_DIR_TYPE,R.FILE_TYPE]),Ye=s=>je.has(s.code),Be=process.platform==="win32",re=s=>!0,ie=s=>{if(s===void 0)return re;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(r=>e.basename===r)}return re},Ht=class extends oe.Readable{constructor(t={}){super({objectMode:!0,autoDestroy:!0,highWaterMark:t.highWaterMark});let e={...kt,...t},{root:r,type:n}=e;this._fileFilter=ie(e.fileFilter),this._directoryFilter=ie(e.directoryFilter);let i=e.lstat?M.lstat:M.stat;Be?this._stat=a=>i(a,{bigint:!0}):this._stat=i,this._maxDepth=e.depth??kt.depth,this._wantsDir=n?Ue.has(n):!1,this._wantsFile=n?qe.has(n):!1,this._wantsEverything=n===R.EVERYTHING_TYPE,this._root=(0,C.resolve)(r),this._isDirent=!e.alwaysStat,this._statsProp=this._isDirent?"dirent":"stats",this._rdOptions={encoding:"utf8",withFileTypes:this._isDirent},this.parents=[this._exploreDir(r,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,r=e&&e.files;if(r&&r.length>0){let{path:n,depth:i}=e,a=r.splice(0,t).map(c=>this._formatEntry(c,n)),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 n=this.parents.pop();if(!n){this.push(null);break}if(this.parent=await n,this.destroyed)return}}}catch(e){this.destroy(e)}finally{this.reading=!1}}}async _exploreDir(t,e){let r;try{r=await(0,M.readdir)(t,this._rdOptions)}catch(n){this._onError(n)}return{files:r,depth:e,path:t}}async _formatEntry(t,e){let r,n=this._isDirent?t.name:t;try{let i=(0,C.resolve)((0,C.join)(e,n));r={path:(0,C.relative)(this._root,i),fullPath:i,basename:n},r[this._statsProp]=this._isDirent?t:await this._stat(i)}catch(i){this._onError(i);return}return r}_onError(t){Ye(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 r=t.fullPath;try{let n=await(0,M.realpath)(r),i=await(0,M.lstat)(n);if(i.isFile())return"file";if(i.isDirectory()){let a=n.length;if(r.startsWith(n)&&r.substr(a,1)===C.sep){let o=new Error(`Circular symlink detected: "${r}" points to "${n}"`);return o.code=ae,this._onError(o)}return"directory"}}catch(n){return this._onError(n),""}}}_includeAsFile(t){let e=t&&t[this._statsProp];return e&&this._wantsEverything&&!e.isDirectory()}}});function ue(s,t,e,r,n){let i=(a,o)=>{e(s),n(a,o,{watchedPath:s}),o&&s!==o&&tt(w.resolve(s,o),F,w.join(s,o))};try{return(0,I.watch)(s,{persistent:t.persistent},i)}catch(a){r(a);return}}var I,D,w,de,Ge,$t,he,st,nt,Wt,Ve,Ke,Qe,fe,E,b,Ze,Xe,F,X,H,Je,ts,es,zt,W,ss,j,me,J,tt,ns,Nt,rs,et,pe=at(()=>{"use strict";I=require("fs"),D=require("fs/promises"),w=v(require("path"),1),de=require("os"),Ge="data",$t="end",he="close",st=()=>{},nt=process.platform,Wt=nt==="win32",Ve=nt==="darwin",Ke=nt==="linux",Qe=nt==="freebsd",fe=(0,de.type)()==="OS400",E={ALL:"all",READY:"ready",ADD:"add",CHANGE:"change",ADD_DIR:"addDir",UNLINK:"unlink",UNLINK_DIR:"unlinkDir",RAW:"raw",ERROR:"error"},b=E,Ze="watch",Xe={lstat:D.lstat,stat:D.stat},F="listeners",X="errHandlers",H="rawEmitters",Je=[F,X,H],ts=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"]),es=s=>ts.has(w.extname(s).slice(1).toLowerCase()),zt=(s,t)=>{s instanceof Set?s.forEach(t):t(s)},W=(s,t,e)=>{let r=s[t];r instanceof Set||(s[t]=r=new Set([r])),r.add(e)},ss=s=>t=>{let e=s[t];e instanceof Set?e.clear():delete s[t]},j=(s,t,e)=>{let r=s[t];r instanceof Set?r.delete(e):r===e&&delete s[t]},me=s=>s instanceof Set?s.size===0:!s,J=new Map;tt=(s,t,e,r,n)=>{let i=J.get(s);i&&zt(i[t],a=>{a(e,r,n)})},ns=(s,t,e,r)=>{let{listener:n,errHandler:i,rawEmitter:a}=r,o=J.get(t),c;if(!e.persistent)return c=ue(s,e,n,i,a),c?c.close.bind(c):void 0;if(o)W(o,F,n),W(o,X,i),W(o,H,a);else{if(c=ue(s,e,tt.bind(null,t,F),i,tt.bind(null,t,H)),!c)return;c.on(b.ERROR,async l=>{let u=tt.bind(null,t,X);if(o&&(o.watcherUnusable=!0),Wt&&l.code==="EPERM")try{await(await(0,D.open)(s,"r")).close(),u(l)}catch{}else u(l)}),o={listeners:n,errHandlers:i,rawEmitters:a,watcher:c},J.set(t,o)}return()=>{j(o,F,n),j(o,X,i),j(o,H,a),me(o.listeners)&&(o.watcher.close(),J.delete(t),Je.forEach(ss(o)),o.watcher=void 0,Object.freeze(o))}},Nt=new Map,rs=(s,t,e,r)=>{let{listener:n,rawEmitter:i}=r,a=Nt.get(t),o=a&&a.options;return o&&(o.persistent<e.persistent||o.interval>e.interval)&&((0,I.unwatchFile)(t),a=void 0),a?(W(a,F,n),W(a,H,i)):(a={listeners:n,rawEmitters:i,options:e,watcher:(0,I.watchFile)(t,e,(c,l)=>{zt(a.rawEmitters,d=>{d(b.CHANGE,t,{curr:c,prev:l})});let u=c.mtimeMs;(c.size!==l.size||u>l.mtimeMs||u===0)&&zt(a.listeners,d=>d(s,c))})},Nt.set(t,a)),()=>{j(a,F,n),j(a,H,i),me(a.listeners)&&(Nt.delete(t),(0,I.unwatchFile)(t),a.options=a.watcher=void 0,Object.freeze(a))}},et=class{constructor(t){this.fsw=t,this._boundHandleError=e=>t._handleError(e)}_watchWithNodeFs(t,e){let r=this.fsw.options,n=w.dirname(t),i=w.basename(t);this.fsw._getWatchedDir(n).add(i);let o=w.resolve(t),c={persistent:r.persistent};e||(e=st);let l;if(r.usePolling){let u=r.interval!==r.binaryInterval;c.interval=u&&es(i)?r.binaryInterval:r.interval,l=rs(t,o,c,{listener:e,rawEmitter:this.fsw._emitRaw})}else l=ns(t,o,c,{listener:e,errHandler:this._boundHandleError,rawEmitter:this.fsw._emitRaw});return l}_handleFile(t,e,r){if(this.fsw.closed)return;let n=w.dirname(t),i=w.basename(t),a=this.fsw._getWatchedDir(n),o=e;if(a.has(i))return;let c=async(u,d)=>{if(this.fsw._throttle(Ze,t,5)){if(!d||d.mtimeMs===0)try{let h=await(0,D.stat)(t);if(this.fsw.closed)return;let f=h.atimeMs,g=h.mtimeMs;if((!f||f<=g||g!==o.mtimeMs)&&this.fsw._emit(b.CHANGE,t,h),(Ve||Ke||Qe)&&o.ino!==h.ino){this.fsw._closeFile(u),o=h;let P=this._watchWithNodeFs(t,c);P&&this.fsw._addPathCloser(u,P)}else o=h}catch{this.fsw._remove(n,i)}else if(a.has(i)){let h=d.atimeMs,f=d.mtimeMs;(!h||h<=f||f!==o.mtimeMs)&&this.fsw._emit(b.CHANGE,t,d),o=d}}},l=this._watchWithNodeFs(t,c);if(!(r&&this.fsw.options.ignoreInitial)&&this.fsw._isntIgnored(t)){if(!this.fsw._throttle(b.ADD,t,0))return;this.fsw._emit(b.ADD,t,e)}return l}async _handleSymlink(t,e,r,n){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(0,D.realpath)(r)}catch{return this.fsw._emitReady(),!0}return this.fsw.closed?void 0:(a.has(n)?this.fsw._symlinkPaths.get(i)!==o&&(this.fsw._symlinkPaths.set(i,o),this.fsw._emit(b.CHANGE,r,t.stats)):(a.add(n),this.fsw._symlinkPaths.set(i,o),this.fsw._emit(b.ADD,r,t.stats)),this.fsw._emitReady(),!0)}if(this.fsw._symlinkPaths.has(i))return!0;this.fsw._symlinkPaths.set(i,!0)}_handleRead(t,e,r,n,i,a,o){if(t=w.join(t,""),o=this.fsw._throttle("readdir",t,1e3),!o)return;let c=this.fsw._getWatchedDir(r.path),l=new Set,u=this.fsw._readdirp(t,{fileFilter:d=>r.filterPath(d),directoryFilter:d=>r.filterDir(d)});if(u)return u.on(Ge,async d=>{if(this.fsw.closed){u=void 0;return}let h=d.path,f=w.join(t,h);if(l.add(h),!(d.stats.isSymbolicLink()&&await this._handleSymlink(d,t,f,h))){if(this.fsw.closed){u=void 0;return}(h===n||!n&&!c.has(h))&&(this.fsw._incrReadyCount(),f=w.join(i,w.relative(i,f)),this._addToNodeFs(f,e,r,a+1))}}).on(b.ERROR,this._boundHandleError),new Promise((d,h)=>{if(!u)return h();u.once($t,()=>{if(this.fsw.closed){u=void 0;return}let f=o?o.clear():!1;d(void 0),c.getChildren().filter(g=>g!==t&&!l.has(g)).forEach(g=>{this.fsw._remove(t,g)}),u=void 0,f&&this._handleRead(t,!1,r,n,i,a,o)})})}async _handleDir(t,e,r,n,i,a,o){let c=this.fsw._getWatchedDir(w.dirname(t)),l=c.has(w.basename(t));!(r&&this.fsw.options.ignoreInitial)&&!i&&!l&&this.fsw._emit(b.ADD_DIR,t,e),c.add(w.basename(t)),this.fsw._getWatchedDir(t);let u,d,h=this.fsw.options.depth;if((h==null||n<=h)&&!this.fsw._symlinkPaths.has(o)){if(!i&&(await this._handleRead(t,r,a,i,t,n,u),this.fsw.closed))return;d=this._watchWithNodeFs(t,(f,g)=>{g&&g.mtimeMs===0||this._handleRead(f,!1,a,i,t,n,u)})}return d}async _addToNodeFs(t,e,r,n,i){let a=this.fsw._emitReady;if(this.fsw._isIgnored(t)||this.fsw.closed)return a(),!1;let o=this.fsw._getWatchHelpers(t);r&&(o.filterPath=c=>r.filterPath(c),o.filterDir=c=>r.filterDir(c));try{let c=await Xe[o.statMethod](o.watchPath);if(this.fsw.closed)return;if(this.fsw._isIgnored(o.watchPath,c))return a(),!1;let l=this.fsw.options.followSymlinks,u;if(c.isDirectory()){let d=w.resolve(t),h=l?await(0,D.realpath)(t):t;if(this.fsw.closed||(u=await this._handleDir(o.watchPath,c,e,n,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(0,D.realpath)(t):t;if(this.fsw.closed)return;let h=w.dirname(o.watchPath);if(this.fsw._getWatchedDir(h).add(o.watchPath),this.fsw._emit(b.ADD,o.watchPath,c),u=await this._handleDir(h,c,e,n,t,o,d),this.fsw.closed)return;d!==void 0&&this.fsw._symlinkPaths.set(w.resolve(t),d)}else u=this._handleFile(o.watchPath,c,e);return a(),u&&this.fsw._addPathCloser(t,u),!1}catch(c){if(this.fsw._handleError(c))return a(),t}}}});var Le={};Yt(Le,{FSWatcher:()=>U,WatchHelper:()=>it,default:()=>ws,watch:()=>Re});function rt(s){return Array.isArray(s)?s:[s]}function ds(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=m.relative(s.path,t);return e?!e.startsWith("..")&&!m.isAbsolute(e):!1}return!1}:()=>!1}function hs(s){if(typeof s!="string")throw new Error("string expected");s=m.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 ye(s,t,e){let r=hs(t);for(let n=0;n<s.length;n++){let i=s[n];if(i(r,e))return!0}return!1}function fs(s,t){if(s==null)throw new TypeError("anymatch: specify first argument");let r=rt(s).map(n=>ds(n));return t==null?(n,i)=>ye(r,n,i):ye(r,t)}function Re(s,t={}){let e=new U(t);return e.add(s),e}var _e,ot,Se,m,jt,is,Pe,os,as,cs,ge,ls,us,Ut,we,Ee,ve,Te,ms,ps,qt,gs,ys,it,U,ws,be=at(()=>{"use strict";_e=require("fs"),ot=require("fs/promises"),Se=require("events"),m=v(require("path"),1);le();pe();jt="/",is="//",Pe=".",os="..",as="string",cs=/\\/g,ge=/\/\//,ls=/\..*\.(sw[px])$|~$|\.subl.*\.tmp/,us=/^\.[/\\]/;Ut=s=>typeof s=="object"&&s!==null&&!(s instanceof RegExp);we=s=>{let t=rt(s).flat();if(!t.every(e=>typeof e===as))throw new TypeError(`Non-string provided as watch path: ${t}`);return t.map(ve)},Ee=s=>{let t=s.replace(cs,jt),e=!1;for(t.startsWith(is)&&(e=!0);t.match(ge);)t=t.replace(ge,jt);return e&&(t=jt+t),t},ve=s=>Ee(m.normalize(Ee(s))),Te=(s="")=>t=>typeof t=="string"?ve(m.isAbsolute(t)?t:m.join(s,t)):t,ms=(s,t)=>m.isAbsolute(s)?s:m.join(t,s),ps=Object.freeze(new Set),qt=class{constructor(t,e){this.path=t,this._removeWatcher=e,this.items=new Set}add(t){let{items:e}=this;e&&t!==Pe&&t!==os&&e.add(t)}async remove(t){let{items:e}=this;if(!e||(e.delete(t),e.size>0))return;let r=this.path;try{await(0,ot.readdir)(r)}catch{this._removeWatcher&&this._removeWatcher(m.dirname(r),m.basename(r))}}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=st,this.items=ps,Object.freeze(this)}},gs="stat",ys="lstat",it=class{constructor(t,e,r){this.fsw=r;let n=t;this.path=t=t.replace(us,""),this.watchPath=n,this.fullWatchPath=m.resolve(n),this.dirParts=[],this.dirParts.forEach(i=>{i.length>1&&i.pop()}),this.followSymlinks=e,this.statMethod=e?gs:ys}entryPath(t){return m.join(this.watchPath,m.relative(this.watchPath,t.fullPath))}filterPath(t){let{stats:e}=t;if(e&&e.isSymbolicLink())return this.filterDir(t);let r=this.entryPath(t);return this.fsw._isntIgnored(r,e)&&this.fsw._hasReadPermissions(e)}filterDir(t){return this.fsw._isntIgnored(this.entryPath(t),t.stats)}},U=class extends Se.EventEmitter{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,r={stabilityThreshold:2e3,pollInterval:100},n={persistent:!0,ignoreInitial:!1,ignorePermissionErrors:!1,interval:100,binaryInterval:300,followSymlinks:!0,usePolling:!1,atomic:!0,...t,ignored:t.ignored?rt(t.ignored):rt([]),awaitWriteFinish:e===!0?r:typeof e=="object"?{...r,...e}:!1};fe&&(n.usePolling=!0),n.atomic===void 0&&(n.atomic=!n.usePolling);let i=process.env.CHOKIDAR_USEPOLLING;if(i!==void 0){let c=i.toLowerCase();c==="false"||c==="0"?n.usePolling=!1:c==="true"||c==="1"?n.usePolling=!0:n.usePolling=!!c}let a=process.env.CHOKIDAR_INTERVAL;a&&(n.interval=Number.parseInt(a,10));let o=0;this._emitReady=()=>{o++,o>=this._readyCount&&(this._emitReady=st,this._readyEmitted=!0,process.nextTick(()=>this.emit(E.READY)))},this._emitRaw=(...c)=>this.emit(E.RAW,...c),this._boundRemove=this._remove.bind(this),this.options=n,this._nodeFsHandler=new et(this),Object.freeze(n)}_addIgnoredPath(t){if(Ut(t)){for(let e of this._ignoredPaths)if(Ut(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)Ut(e)&&e.path===t&&this._ignoredPaths.delete(e)}add(t,e,r){let{cwd:n}=this.options;this.closed=!1,this._closePromise=void 0;let i=we(t);return n&&(i=i.map(a=>ms(a,n))),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,!r,void 0,0,e);return o&&this._emitReady(),o})).then(a=>{this.closed||a.forEach(o=>{o&&this.add(m.dirname(o),m.basename(e||o))})}),this}unwatch(t){if(this.closed)return this;let e=we(t),{cwd:r}=this.options;return e.forEach(n=>{!m.isAbsolute(n)&&!this._closers.has(n)&&(r&&(n=m.join(r,n)),n=m.resolve(n)),this._closePath(n),this._addIgnoredPath(n),this._watched.has(n)&&this._addIgnoredPath({path:n,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(r=>{let n=r();n instanceof Promise&&t.push(n)})),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,r)=>{let i=(this.options.cwd?m.relative(this.options.cwd,r):r)||Pe;t[i]=e.getChildren().sort()}),t}emitWithAll(t,e){this.emit(t,...e),t!==E.ERROR&&this.emit(E.ALL,t,...e)}async _emit(t,e,r){if(this.closed)return;let n=this.options;Wt&&(e=m.normalize(e)),n.cwd&&(e=m.relative(n.cwd,e));let i=[e];r!=null&&i.push(r);let a=n.awaitWriteFinish,o;if(a&&(o=this._pendingWrites.get(e)))return o.lastChange=new Date,this;if(n.atomic){if(t===E.UNLINK)return this._pendingUnlinks.set(e,[t,...i]),setTimeout(()=>{this._pendingUnlinks.forEach((c,l)=>{this.emit(...c),this.emit(E.ALL,...c),this._pendingUnlinks.delete(l)})},typeof n.atomic=="number"?n.atomic:100),this;t===E.ADD&&this._pendingUnlinks.has(e)&&(t=E.CHANGE,this._pendingUnlinks.delete(e))}if(a&&(t===E.ADD||t===E.CHANGE)&&this._readyEmitted){let c=(l,u)=>{l?(t=E.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===E.CHANGE&&!this._throttle(E.CHANGE,e,50))return this;if(n.alwaysStat&&r===void 0&&(t===E.ADD||t===E.ADD_DIR||t===E.CHANGE)){let c=n.cwd?m.join(n.cwd,e):e,l;try{l=await(0,ot.stat)(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(E.ERROR,t),t||this.closed}_throttle(t,e,r){this._throttled.has(t)||this._throttled.set(t,new Map);let n=this._throttled.get(t);if(!n)throw new Error("invalid throttle");let i=n.get(e);if(i)return i.count++,!1;let a,o=()=>{let l=n.get(e),u=l?l.count:0;return n.delete(e),clearTimeout(a),l&&clearTimeout(l.timeoutObject),u};a=setTimeout(o,r);let c={timeoutObject:a,clear:o,count:0};return n.set(e,c),c}_incrReadyCount(){return this._readyCount++}_awaitWriteFinish(t,e,r,n){let i=this.options.awaitWriteFinish;if(typeof i!="object")return;let a=i.pollInterval,o,c=t;this.options.cwd&&!m.isAbsolute(t)&&(c=m.join(this.options.cwd,t));let l=new Date,u=this._pendingWrites;function d(h){(0,_e.stat)(c,(f,g)=>{if(f||!u.has(t)){f&&f.code!=="ENOENT"&&n(f);return}let P=Number(new Date);h&&g.size!==h.size&&(u.get(t).lastChange=P);let T=u.get(t);P-T.lastChange>=e?(u.delete(t),n(void 0,g)):o=setTimeout(d,a,g)})}u.has(t)||(u.set(t,{lastChange:l,cancelWait:()=>(u.delete(t),clearTimeout(o),r)}),o=setTimeout(d,a))}_isIgnored(t,e){if(this.options.atomic&&ls.test(t))return!0;if(!this._userIgnored){let{cwd:r}=this.options,i=(this.options.ignored||[]).map(Te(r)),o=[...[...this._ignoredPaths].map(Te(r)),...i];this._userIgnored=fs(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=m.resolve(t);return this._watched.has(e)||this._watched.set(e,new qt(e,this._boundRemove)),this._watched.get(e)}_hasReadPermissions(t){return this.options.ignorePermissionErrors?!0:!!(Number(t.mode)&256)}_remove(t,e,r){let n=m.join(t,e),i=m.resolve(n);if(r=r??(this._watched.has(n)||this._watched.has(i)),!this._throttle("remove",n,100))return;!r&&this._watched.size===1&&this.add(t,e,!0),this._getWatchedDir(n).getChildren().forEach(h=>this._remove(n,h));let c=this._getWatchedDir(t),l=c.has(e);c.remove(e),this._symlinkPaths.has(i)&&this._symlinkPaths.delete(i);let u=n;if(this.options.cwd&&(u=m.relative(this.options.cwd,n)),this.options.awaitWriteFinish&&this._pendingWrites.has(u)&&this._pendingWrites.get(u).cancelWait()===E.ADD)return;this._watched.delete(n),this._watched.delete(i);let d=r?E.UNLINK_DIR:E.UNLINK;l&&!this._isIgnored(n)&&this._emit(d,n),this._closePath(n)}_closePath(t){this._closeFile(t);let e=m.dirname(t);this._getWatchedDir(e).remove(m.basename(t))}_closeFile(t){let e=this._closers.get(t);e&&(e.forEach(r=>r()),this._closers.delete(t))}_addPathCloser(t,e){if(!e)return;let r=this._closers.get(t);r||(r=[],this._closers.set(t,r)),r.push(e)}_readdirp(t,e){if(this.closed)return;let r={type:E.ALL,alwaysStat:!0,lstat:!0,...e,depth:0},n=ce(t,r);return this._streams.add(n),n.once(he,()=>{n=void 0}),n.once($t,()=>{n&&(this._streams.delete(n),n=void 0)}),n}};ws={watch:Re,FSWatcher:U}});var Es={};Yt(Es,{TSFilebasedRouter:()=>De,TSRouter:()=>Z,createEffect:()=>Dt,createSignal:()=>bt,html:()=>ct,loadPyFiles:()=>At,mapper:()=>Gt,renderChildRoutes:()=>Lt,useAnchor:()=>$,useAnchorSingle:()=>Tt,useInitialDOM:()=>wt,useTSAuth:()=>Pt,useTSCollection:()=>St,useTSComponent:()=>z,useTSElementEach:()=>Q,useTSElements:()=>gt,useTSEvent:()=>dt,useTSEventAll:()=>mt,useTSExtractParams:()=>ft,useTSLazy:()=>Mt,useTSMetaData:()=>_t,useTSNavigate:()=>vt,useTSNoReload:()=>Ft,useTSOutlet:()=>Rt,useTSParams:()=>N,useTSPurifier:()=>ut,useTSSSRHydration:()=>Ct,useTSSelect:()=>k,useTSloadBrython:()=>xt});module.exports=Ie(Es);function ke(s){let t=s==null?"":String(s),e=t.toLowerCase();return(e.includes("<script")||e.includes("javascript:"))&&(t=""),t=t.replace(/url\(\s*(['"])?\s*\1?\s*\)/gi,""),t.replace(/<\s*(script|iframe|object|embed|link|style|meta|body)[^>]*>.*?<\s*\/\s*\1\s*>/gi,"").replace(/<\s*(script|iframe|object|embed|link|style|meta)[^>]*>/gi,"").replace(/\s+on\w+\s*=\s*(['"]).*?\1/gi,"").replace(/\s+on\w+\s*=\s*[^\s>]+/gi,"").replace(/\s(href|src)\s*=\s*(['"]?)\s*(javascript:|vbscript:|data:|file:)[^'">\s]*\2/gi,'$1="#"')}function ct(s,...t){return s.reduce((e,r,n)=>{let i=n<t.length?ke(t[n]):"";return e+r+i},"")}var He=s=>s.replace(/<\/?(script|iframe|object|embed|link|meta|style|form|textarea|svg|math|body)[^>]*>/gi,"").replace(/<(?!\/?(b|i|em|strong|p|br|ul|ol|li|a|div|span|h1|h2|h3|h4|h5|h6|section|article|input|button)\b)[^>]*>/gi,"").replace(/\s+on[a-z]+\s*=\s*("[^"]*"|'[^']*'|[^\s>]+)/gi,"").replace(/\s*style\s*=\s*("[^"]*"|'[^']*')/gi,"").replace(/<a\b([^>]*)href\s*=\s*(['"]?)(?!https?:|#)[^'"\s>]+(['"]?)([^>]*)>/gi,"<a$1$4>").replace(/\s+(href|src)\s*=\s*(['"]?)\s*(javascript:|data:)[^'"\s>]*/gi,"").replace(/<a\b([^>]*)\bhref\s*=\s*(['"])(\/blog|#blog)\2([^>]*)>/gi,'<a$1 href=$2$3$2 href-line="true"$4>').trim(),Gt=s=>s?.map(t=>He(t)).join("")??"";var lt=v(require("dompurify"),1),ut=(s,t)=>{let r={...{ADD_TAGS:["my-custom-tag"]},...t};return typeof s=="string"?lt.default.sanitize(s,r):lt.default.sanitize(s.innerHTML,r)};var dt=(s,t,e)=>{if(typeof s=="string"){let r=document.getElementById(s);r?r.addEventListener(t,e):console.warn(`Element with id '${s}' not found.`)}else s instanceof HTMLElement?s.addEventListener(t,e):s===document?document.addEventListener(t,e):console.warn("Invalid target parameter provided.")};var Vt=require("zustand/vanilla"),ht=v(require("dompurify"),1);function Ne(s,t){let e=[],r=s.replace(/:[^/]+/g,o=>(e.push(o.slice(1)),"([^/]+)")),n=new RegExp(`^${r}$`),i=t.match(n),a={};return i&&e.forEach((o,c)=>{a[o]=ht.default.sanitize(i[c+1]??"")}),a}function ze(s){let t={},e=new URLSearchParams(s);for(let[r,n]of e.entries())t[r]=ht.default.sanitize(n);return t}var N=(0,Vt.createStore)((s,t)=>({params:{},query:{},setFromPattern:e=>{let r=window.location.pathname,n=Ne(e,r),i=ze(window.location.search);s({params:n,query:i})},getParam:e=>t().params[e],getQuery:e=>t().query[e]}));function ft(s){let t=N.getState();t.setFromPattern(s);let e=t.params,r=t.query;return{...e,...r}}var mt=(s,t,e)=>{let r=document.querySelectorAll(s);return r.forEach(n=>{n.addEventListener(t,e)}),()=>{r.forEach(n=>{n.removeEventListener(t,e)})}};var pt=v(require("dompurify"),1),gt=(s,t,e={},r)=>{let n={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","label","form"],ALLOWED_ATTR:["class","id","href","src","alt","title","fill","stroke","stroke-width","viewBox","xmlns","d","x","y","cx","cy","r","width","height","type","name","value","placeholder","data-click","data-change","data-select","data-classlist","data-hover","data-submit","data-key","data-event"],FORBID_TAGS:["script","iframe","foreignObject","body","html"],FORBID_ATTR:["style","xlink:href"],ALLOWED_URI_REGEXP:/^(?:(?:https?|mailto|tel|ftp):|[^a-z]|[a-z+.\-]+(?:[^a-z+.\-:]|$))/i,...r};pt.default.addHook("uponSanitizeAttribute",(o,c)=>{let l=(c.attrName||"").toLowerCase(),u=(c.attrValue??"").toString().trim();if(l.startsWith("on")){c.keepAttr=!1;return}if(/^data-(click|change|submit|select|hover|classlist|key|event)$/.test(l)){c.keepAttr=!0;return}if(o.nodeName.toLowerCase()==="img"&&l==="src"){/^https?:\/\//i.test(u)||/^\/(?!\/)/.test(u)||/^data:image\/(png|jpeg|jpg|gif|webp);base64,/i.test(u)||(c.keepAttr=!1);return}if(l==="class"){let h=u.split(/\s+/).filter(Boolean).filter(f=>{if(/^[a-zA-Z0-9\-\:\/_\[\]\(\)]*$/.test(f)){if(/^bg-\[url\(.*\)\]$/.test(f)){let g=f.replace(/^bg-\[url\(/,"").replace(/\)\]$/,"").replace(/^['"]|['"]$/g,"");return g===""||/^https?:\/\//i.test(g)||/^\/(?!\/)/.test(g)||/^\.{0,2}\//.test(g)}return/^bg-\[\]$/.test(f),!0}return!1});c.attrValue=h.join(" ");return}});let i=pt.default.sanitize(t,{...n,RETURN_DOM_FRAGMENT:!0});for(;s.firstChild;)s.removeChild(s.firstChild);s.appendChild(i);let a=(o,c)=>{s.querySelectorAll(`[${o}]`).forEach(l=>{let u=l.getAttribute(o);u&&Object.prototype.hasOwnProperty.call(e,u)&&l.addEventListener(c,d=>{c==="submit"&&d.preventDefault(),e[u](d)})})};a("data-click","click"),a("data-change","change"),a("data-select","select"),a("data-submit","submit"),s.querySelectorAll("[data-key]").forEach(o=>{let c=o.dataset.key,l=o.dataset.event??"click";c&&Object.prototype.hasOwnProperty.call(e,c)&&o.addEventListener(l,e[c])}),s.querySelectorAll("[data-hover]").forEach(o=>{let c=o.dataset.hover;c&&Object.prototype.hasOwnProperty.call(e,c)&&(o.addEventListener("mouseenter",e[c]),o.addEventListener("mouseleave",e[c]))}),s.querySelectorAll("[data-classlist]").forEach(o=>{let c=o.dataset.classlist;/^[a-zA-Z0-9\-\s:_]+$/.test(c)&&o.classList.add(...c.split(/\s+/))})};var yt=v(require("dompurify"),1),K=null,wt=(s,t)=>{if(typeof document>"u")return;let e=document.getElementById(s);if(!e)return;yt.default.addHook("uponSanitizeAttribute",(a,o)=>{let c=(o.attrName||"").toLowerCase(),l=(o.attrValue??"").toString().trim();if(c.startsWith("on")){o.keepAttr=!1;return}if((c==="href"||c==="src")&&/^(javascript:|vbscript:|data:|file:|about:)/i.test(l)){o.keepAttr=!1;return}if(c==="class"){let d=l.split(/\s+/).filter(Boolean).filter(h=>{if(/^[a-zA-Z0-9\-\:\/_\[\]\(\)]+$/.test(h)){if(/^bg-\[url\(.*\)\]$/.test(h)){let f=h.replace(/^bg-\[url\(/,"").replace(/\)\]$/,"").replace(/^['"]|['"]$/g,"");return f===""||/^https?:\/\//i.test(f)||/^\/(?!\/)/.test(f)||/^\.{0,2}\//.test(f)}return!0}return!1});o.attrValue=d.join(" ");return}if(c==="style"){o.keepAttr=!1;return}});let r=e.cloneNode(!0),n=yt.default.sanitize(r.innerHTML,{USE_PROFILES:{html:!0},ALLOWED_TAGS:["div","span","p","h1","h2","h3","h4","h5","h6","ul","ol","li","strong","em","a","img","br","form","button","input","label"],ALLOWED_ATTR:["href","src","alt","title","class","id","type","name","value","placeholder","data-click","data-change","data-submit","data-select","data-hover","data-classlist"],FORBID_TAGS:["script","iframe","object","embed","body","html","svg","math","link","meta"],ALLOW_DATA_ATTR:!0,KEEP_CONTENT:!1,RETURN_DOM_FRAGMENT:!0}),i=Array.from(n.childNodes).map(a=>a.outerHTML||a.textContent||"").join("");if(K!==null&&i!==K){let a=document.createElement("div");t(a);let c=new DOMParser().parseFromString(K,"text/html");for(;e.firstChild;)e.removeChild(e.firstChild);c.body.childNodes.forEach(l=>e.appendChild(l.cloneNode(!0)))}else{for(K=i;e.firstChild;)e.removeChild(e.firstChild);e.appendChild(n),t(e)}};var Et=v(require("dompurify"),1);typeof window<"u"&&!window.__anchorSinglePopstateHandlerAttached&&(window.addEventListener("popstate",s=>{let t=s.state;t?.scrollPosition!==void 0&&window.scrollTo(0,t.scrollPosition)}),window.__anchorSinglePopstateHandlerAttached=!0);var Tt=(s,t,e,r="",n=null)=>{if(!s)return;let i=Et.default.sanitize(t,{ALLOWED_URI_REGEXP:/^(https?:|\/)/}),a=Et.default.sanitize(e,{USE_PROFILES:{html:!1}});s.setAttribute("href",i),s.setAttribute("aria-label",a),r&&(s.className=r.trim()),n&&s.replaceChildren(n),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"))}})};var x=v(require("dompurify"),1);var Kt=(s="'self' 'nonce-rAnd0m123' 'unsafe-inline' 'unsafe-eval'",t="'self' 'nonce-rAnd0m123'",e="'none'",r="'self' https://fonts.googleapis.com https://fonts.gstatic.com",n="'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 ${r}; img-src ${n}; 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 _t=(s,t)=>{let e={name:x.default.sanitize(s.name||""),title:x.default.sanitize(s.title||""),description:x.default.sanitize(s.description||"Default description"),author:x.default.sanitize(s.author||""),favicon:s.favicon},r=p=>{e.name=x.default.sanitize(p),P("name",e.name)},n=p=>{e.title=x.default.sanitize(p),document.title=e.title},i=p=>{e.description=x.default.sanitize(p),P("description",e.description)},a=p=>{e.author=x.default.sanitize(p),P("author",e.author)},o=p=>{e.favicon=x.default.sanitize(p);let y=document.querySelector('link[rel="icon"]');y||(y=document.createElement("link"),y.rel="icon",document.head.appendChild(y)),y.href=e.favicon},c=()=>e.name,l=()=>e.title,u=()=>e.description,d=()=>e.author,h=()=>e.favicon,f=()=>e,g=(p,y)=>{let _=document.createElement("meta");_.setAttribute("name",p),_.setAttribute("content",y),document.head.appendChild(_)},P=(p,y)=>{let _=document.querySelector(`meta[name="${p}"]`);_?_.setAttribute("content",y):g(p,y)},T=()=>{e.title&&(document.title=e.title),e.name&&P("name",e.name),e.description&&P("description",e.description),e.author&&P("author",e.author),e.favicon&&o(e.favicon)};return t&&Kt(t.scriptSrc,t.styleSrc,t.objectSrc,Array.isArray(t.connectSrc)?t.connectSrc.join(" "):t.connectSrc,t.reportOnly!==void 0?String(t.reportOnly):void 0),T(),{setName:r,setTitle:n,setDescription:i,setAuthor:a,setFavicon:o,getName:c,getTitle:l,getDescription:u,getAuthor:d,getFavicon:h,getAllMetaData:f,appendMetaTagsToHead:T}};var Qt=v(require("dompurify"),1),z=(s,t,e,r,n)=>{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=Qt.default.sanitize(o.innerHTML,{USE_PROFILES:{html:!0}}),e(o,r,n)};var St=(s,t,e,r=[])=>{let n=new Set;s.forEach((i,a)=>{if(n.has(i)){console.warn(`[useTSCollection] Duplicate ID in collection array: "${i}" \u2014 skipping.`);return}n.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(r)?r[a]:void 0;typeof c=="function"?z(i,t,c,l):console.warn(`[useTSCollection] No valid component function found for ID: "${i}"`)})};var k=(s,t)=>{let r=(t??document).querySelectorAll(s);if(r.length===0)return process.env.NODE_ENV!=="production"&&console.warn(`[useTSSelect] No element found for selector: '${s}'`),null;if(s.startsWith("#")&&r.length>1){if(process.env.NODE_ENV!=="production")throw new Error(`[useTSSelect] Duplicate ID detected: '${s}'. 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: '${s}'. Returning the first one.`),r[0]};var Zt=require("jwt-decode"),Pt=(s,t)=>{let e=localStorage.getItem("token");if(!e)return window.location.href=t,null;try{let r=(0,Zt.jwtDecode)(e),n=Date.now()/1e3;return r.exp&&r.exp<n&&(console.error("Token has expired"),window.localStorage.removeItem("token"),window.location.href=t),null}catch(r){return console.error("Invalid token:",r),window.location.href=t,null}};var Q=(s,t,e)=>{s.forEach(r=>{t.forEach(n=>{r.addEventListener(n,i=>{e(r,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 r=window.location.pathname.replace(/\/$/,"");for(let n of t){let i=n.path.replace(/\/$/,"");if(r===i||r.startsWith(`${i}/`)){n.component(e);break}}};function Lt(s,t){let e=window.location.pathname.replace(/\/$/,"");t.routes.forEach(r=>{r.children?.length&&r.children.forEach(n=>{let i=n.path.replace(/\/$/,"");if(e===i||e.startsWith(`${i}/`)){let a=s.querySelector(`#${n.outlet}`)||s.querySelector(`.${n.outlet}`);a instanceof HTMLElement&&n.element&&n.element(a)}})})}var Xt=require("zustand/vanilla");function bt(s){let t=(0,Xt.createStore)(()=>({value:s})),e=new Set;return{get:()=>t.getState().value,set:r=>{t.setState({value:r}),e.forEach(n=>n(r))},subscribe:r=>(e.add(r),r(t.getState().value),()=>e.delete(r))}}function Dt(s){let t=s();typeof t=="function"&&t()}var xt=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=r=>new Promise((n,i)=>{let a=document.createElement("script");a.src=r,a.onload=()=>n(),a.onerror=()=>i(new Error(`Failed to load ${r}`)),document.head.appendChild(a)});await e(s),await e(t),typeof window.brython=="function"?window.brython():console.error("Brython did not load correctly.")},At=s=>new Promise((t,e)=>{let r=document.createElement("script");r.type="text/python",r.src=`/src/python/${s}`,r.onload=()=>t(),r.onerror=()=>e(new Error(`Failed to load ${s}`)),document.body.appendChild(r)});function Mt(s){let t=null;return async(e,r)=>{try{if(!t){let n=await s();t=n.default||n}if(typeof t=="function")return t(e,r);if(t instanceof HTMLElement){let n=t.cloneNode(!0);return e?.appendChild(n),n}if(typeof t=="object"&&t!==null&&"render"in t&&typeof t.render=="function")return t.render(e,r);console.warn("useTSLazy: Unsupported module type",t)}catch(n){console.error("useTSLazy failed:",n)}}}var Ct=s=>typeof window>"u"?{isDOM:null}:{isDOM:s||document.body};var Jt=require("lodash-es"),Ot=s=>s;typeof window<"u"&&typeof document<"u"&&(Ot=s=>{let t=document.createElement("div");return t.innerText=s,t.innerHTML});var $e=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 r=e.getAttribute("class")||"";e.setAttribute("class",Ot(r));let n=e.getAttribute("aria-label");n&&e.setAttribute("aria-label",Ot(n));let i=e.querySelector(":scope > *");i&&(e.innerHTML="",e.appendChild(i));let a=e.getAttribute("href")||"";if(!a.startsWith("#")){try{if(new URL(a,window.location.href).origin!==window.location.origin)return}catch{return}e.addEventListener("click",o=>{o.preventDefault();let c=e.getAttribute("href")||"";try{let l=new URL(c,window.location.href);window.history.pushState({},"",l.pathname+l.search+l.hash),window.dispatchEvent(new PopStateEvent("popstate"))}catch(l){console.error("Invalid URL in anchor:",c,l)}})}})},We=(0,Jt.debounce)($e,50),$=s=>{We(s)};var Ft=s=>{if(!s)return;let t=k("a",s);$(t)};var It=v(require("dompurify"),1);var ee=require("zustand/vanilla"),se=v(require("dompurify"),1),O=(0,ee.createStore)(s=>({params:{},query:{},setParams:t=>s(()=>({params:te(t)})),setQuery:t=>s(()=>({query:te(t)}))}));function te(s){let t={};for(let e in s)t[e]=se.default.sanitize(s[e]);return t}var Z=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,r=this.parseQueryParams(e),n=this.findMatchingRoute(t,this.routes);if(n){if(n.routeto){this.navigate(n.routeto);return}let i=this.filterAndSanitizeParams(n.params);O.getState().setParams(i),O.getState().setQuery(r);let a=document.createElement("div");if(n.element?.(a,i,r),n.children){let o=t.slice(n.path.length),c=a.querySelector("#child");c&&this.renderChildren(n.children,o,c,i,r)}}else{let i=this.findMatchingRoute("*",this.routes);if(i){let a=this.filterAndSanitizeParams(i.params);O.getState().setParams(a),O.getState().setQuery(r);let o=document.createElement("div");i.element?.(o,a,r)}}}renderChildren(t,e,r,n,i){if(!t||t.length===0){let o=r.querySelector("#child");o&&o.remove();return}let a=this.findMatchingRoute(e,t);if(a){let o=document.createElement("div");o.id="child";let c={...n,...a.params},l=this.filterAndSanitizeParams(c);if(O.getState().setParams(l),O.getState().setQuery(i),a.element?.(o,l,i),r.appendChild(o),a.children){let u=e.slice(a.path.length);this.renderChildren(a.children,u,o,l,i)}}}parseQueryParams(t){let e={},r=new URLSearchParams(t);for(let[n,i]of r.entries())this.expectedParams.has(n)&&(e[n]=It.default.sanitize(i));return e}findMatchingRoute(t,e,r={}){for(let n of e){let i=n.path;if(i==="*")return n;{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={...r};if(o.forEach((h,f)=>{d[h]=u[f+1]??""}),n.children){let h=t.slice(u[0].length),f=this.findMatchingRoute(h,n.children,d);if(f)return f}return{...n,params:d}}}}}filterAndSanitizeParams(t){if(!t)return{};let e={};for(let r in t)this.expectedParams.has(r)&&(e[r]=It.default.sanitize(t[r]??""));return e}navigate(t){history.pushState(null,"",t),this.handlePopState()}addRoute(t){this.routes.push(t)}};var De=()=>({name:"ts-filebased-router",async buildStart(){if(typeof process>"u"||!process.versions?.node)return;let s=await import("fs/promises"),t=await import("path"),e=await Promise.resolve().then(()=>(be(),Le)),r=t.resolve("src/pages"),n=t.resolve("src/gen"),i=t.resolve("src/routes"),a=t.join(n,"tsrouter.gen.ts"),o=t.join(i,"__root.ts"),c=process.env.NODE_ENV!=="production";async function l(T){try{await s.mkdir(T,{recursive:!0})}catch{}}function u(T,p){let y="/"+t.relative(p,T).replace(/\\/g,"/");return y=y.replace(/\.ts$/,"").replace(/\/index$/,"")||"/",y.replace(/\[(.+?)\]/g,":$1")}function d(T){return T.replace(/^\//,"").split("/").map(p=>p.startsWith(":")?p.slice(1):p).filter(Boolean).join("-")||"index"}function h(T,p){let _=t.relative(p,T).replace(/\\/g,"/").split("/").filter(Boolean),L=_[_.length-1].replace(".ts",""),A=_.length>1?_[_.length-2]:"";if(L==="index")return A?A.charAt(0).toUpperCase()+A.slice(1):"Index";if(L.startsWith("[")&&L.endsWith("]")){let S=L.slice(1,-1);return A.charAt(0).toUpperCase()+S.charAt(0).toUpperCase()+S.slice(1)}return L.charAt(0).toUpperCase()+L.slice(1)}async function f(T){let p=await s.readdir(T,{withFileTypes:!0}),y=[];for(let _ of p){let L=t.join(T,_.name);if(_.isDirectory())y=y.concat(await f(L));else if(_.isFile()&&_.name.endsWith(".ts")){let A=u(L,r),S=d(A),q=h(L,r);y.push({file:L,route:A,routeName:S,importName:q})}}return y}function g(){return`import { createRouter } from "@/gen/tsrouter.gen";
2
2
  import { useTSParams } from "@devwareng/vanilla-ts";
3
3
 
4
4
  export const Router = async (DOM: HTMLElement) => {
@@ -12,9 +12,9 @@ export const Router = async (DOM: HTMLElement) => {
12
12
  window.addEventListener("popstate", () => {
13
13
  void router.navigate(window.location.pathname + window.location.search, false);
14
14
  });
15
- };`}async function P(){let T=await f(r),p=T.find(S=>S.route==="/notfound"),y=T.filter(S=>S.route!=="/notfound");for(let S of T)if(!(await s.readFile(S.file,"utf-8")).trim()){let Y=S.importName,B=S.route.match(/:([^/]+)/g),Ae=B?`{ ${B.map(G=>`${G.slice(1)}: string`).join("; ")} }`:"{}";await s.writeFile(S.file,`import { html, useTSElements, useTSMetaData } from "@devwareng/vanilla-ts";
15
+ };`}async function P(){let T=await f(r),p=T.find(S=>S.route==="/notfound"),y=T.filter(S=>S.route!=="/notfound");for(let S of T)if(!(await s.readFile(S.file,"utf-8")).trim()){let Y=S.importName,B=S.route.match(/:([^/]+)/g),xe=B?`{ ${B.map(G=>`${G.slice(1)}: string`).join("; ")} }`:"{}";await s.writeFile(S.file,`import { html, useTSElements, useTSMetaData } from "@devwareng/vanilla-ts";
16
16
 
17
- export default function ${Y}(DOM: HTMLElement, params: ${Ae}) {
17
+ export default function ${Y}(DOM: HTMLElement, params: ${xe}) {
18
18
 
19
19
  useTSMetaData({
20
20
  title: "${Y}",
@@ -32,19 +32,21 @@ export default function ${Y}(DOM: HTMLElement, params: ${Ae}) {
32
32
  `):""}
33
33
  </div>
34
34
  \`);
35
- }`,"utf-8")}let _=y.map(S=>{let q="../pages/"+t.relative(r,S.file).replace(/\\/g,"/").replace(/\.ts$/,"");return`{
36
- path: "${S.route}",
37
- name: "${S.routeName}",
38
- component: useTSLazy(() => import("${q}"))
39
- }`}).join(`,
40
- `),D=`// AUTO-GENERATED FILE. DO NOT EDIT MANUALLY.
41
- import { useTSLazy,html,useTSElements } from "@devwareng/vanilla-ts";
35
+ }`,"utf-8")}let _=y.map(S=>{let q="../pages/"+t.relative(r,S.file).replace(/\\/g,"/").replace(/\.ts$/,"");return`{ path: "${S.route}", name: "${S.routeName}", component: useTSLazy(() => import("${q}")) }`}).join(`,
36
+ `),A=`// AUTO-GENERATED FILE. DO NOT EDIT MANUALLY.
37
+ import { useTSLazy, html, useTSElements } from "@devwareng/vanilla-ts";
42
38
 
43
- ${p?`export const NotFound = useTSLazy(() => import("../pages/${t.relative(r,p.file).replace(/\\/g,"/").replace(/\.ts$/,"")}"))`:'export function NotFound(DOM: HTMLElement) {\n return useTSElements(DOM, html`<div class="p-4 animate__animated animate__fadeIn"><h1>404 - Page Not Found</h1></div>`)\n}'}
39
+ type Route = {
40
+ path: string;
41
+ name: string;
42
+ component: (DOM: HTMLElement, params: Record<string,string>) => Promise<any>;
43
+ };
44
44
 
45
- export const routeTree = [
45
+ ${p?`export const NotFound: Route['component'] = useTSLazy(() => import("../pages/${t.relative(r,p.file).replace(/\\/g,"/").replace(/\.ts$/,"")}"))`:'export function NotFound(DOM: HTMLElement) {\n return useTSElements(DOM, html`<div class="p-4 animate__animated animate__fadeIn"><h1>404 - Page Not Found</h1></div>`)\n}'}
46
+
47
+ export const routeTree: Route[] = [
46
48
  ${_}
47
- ]
49
+ ];
48
50
 
49
51
  export async function createRouter(DOM: HTMLElement) {
50
52
  function matchRoute(path: string) {
@@ -54,32 +56,31 @@ export async function createRouter(DOM: HTMLElement) {
54
56
  keys.push(key);
55
57
  return "([^/]+)"
56
58
  }) + "$")
57
- const pathname = path.split("?")[0]
58
- const match = pathname?.match(regex)
59
+ const pathname = path.split("?")[0];
60
+ const match = pathname?.match(regex);
59
61
  if (match) {
60
- const params: Record<string, string> = {}
61
- keys.forEach((key, i) => (params[key] = match[i + 1] || ""))
62
- return { ...route, params }
62
+ const params: Record<string,string> = {};
63
+ keys.forEach((key, i) => (params[key] = match[i+1] || ""));
64
+ return { ...route, params };
63
65
  }
64
66
  }
65
- return null
67
+ return null;
66
68
  }
67
69
 
68
- async function navigate(path: string, pushState: boolean = true) {
69
- const match = matchRoute(path);
70
- if (match) {
71
- // ensure params is always at least an empty object
72
- const params = match.params || {};
73
- await match.component(DOM, params);
74
- if (pushState) history.pushState({}, "", path);
75
- } else {
76
- NotFound(DOM);
70
+ async function navigate(path: string, pushState: boolean = true) {
71
+ const match = matchRoute(path);
72
+ if (match) {
73
+ // TS knows component always accepts params
74
+ await match.component(DOM, match.params);
75
+ if (pushState) history.pushState({}, "", path);
76
+ } else {
77
+ NotFound(DOM);
78
+ }
77
79
  }
78
- }
79
80
 
80
- return { navigate, routes: routeTree }
81
+ return { navigate, routes: routeTree };
81
82
  }
82
- `;await l(n),await s.writeFile(a,D,"utf-8"),await s.writeFile(o,g(),"utf-8")}await l(n),await l(i),await l(r),await P(),c&&(e.watch(r).on("all",async(p,y)=>{y.endsWith(".ts")&&await P()}),e.watch(o).on("unlink",async()=>{await s.writeFile(o,g(),"utf-8")})),console.log("\u{1F7E2} TS Filebased Router Generated with Lazy Routes and Params Support...")}});0&&(module.exports={TSFilebasedRouter,TSRouter,createEffect,createSignal,html,loadPyFiles,mapper,renderChildRoutes,useAnchor,useAnchorSingle,useInitialDOM,useTSAuth,useTSCollection,useTSComponent,useTSElementEach,useTSElements,useTSEvent,useTSEventAll,useTSExtractParams,useTSLazy,useTSMetaData,useTSNavigate,useTSNoReload,useTSOutlet,useTSParams,useTSPurifier,useTSSSRHydration,useTSSelect,useTSloadBrython});
83
+ `;await l(n),await s.writeFile(a,A,"utf-8"),await s.writeFile(o,g(),"utf-8")}await l(n),await l(i),await l(r),await P(),c&&(e.watch(r).on("all",async(p,y)=>{y.endsWith(".ts")&&await P()}),e.watch(o).on("unlink",async()=>{await s.writeFile(o,g(),"utf-8")})),console.log("\u{1F7E2} TS Filebased Router Generated with Lazy Routes and Params Support...")}});0&&(module.exports={TSFilebasedRouter,TSRouter,createEffect,createSignal,html,loadPyFiles,mapper,renderChildRoutes,useAnchor,useAnchorSingle,useInitialDOM,useTSAuth,useTSCollection,useTSComponent,useTSElementEach,useTSElements,useTSEvent,useTSEventAll,useTSExtractParams,useTSLazy,useTSMetaData,useTSNavigate,useTSNoReload,useTSOutlet,useTSParams,useTSPurifier,useTSSSRHydration,useTSSelect,useTSloadBrython});
83
84
  /*! Bundled license information:
84
85
 
85
86
  chokidar/esm/index.js:
package/dist/index.js CHANGED
@@ -1,4 +1,4 @@
1
- function pe(n){let e=n==null?"":String(n),t=e.toLowerCase();return(t.includes("<script")||t.includes("javascript:"))&&(e=""),e=e.replace(/url\(\s*(['"])?\s*\1?\s*\)/gi,""),e.replace(/<\s*(script|iframe|object|embed|link|style|meta|body)[^>]*>.*?<\s*\/\s*\1\s*>/gi,"").replace(/<\s*(script|iframe|object|embed|link|style|meta)[^>]*>/gi,"").replace(/\s+on\w+\s*=\s*(['"]).*?\1/gi,"").replace(/\s+on\w+\s*=\s*[^\s>]+/gi,"").replace(/\s(href|src)\s*=\s*(['"]?)\s*(javascript:|vbscript:|data:|file:)[^'">\s]*\2/gi,'$1="#"')}function F(n,...e){return n.reduce((t,r,o)=>{let i=o<e.length?pe(e[o]):"";return t+r+i},"")}var fe=n=>n.replace(/<\/?(script|iframe|object|embed|link|meta|style|form|textarea|svg|math|body)[^>]*>/gi,"").replace(/<(?!\/?(b|i|em|strong|p|br|ul|ol|li|a|div|span|h1|h2|h3|h4|h5|h6|section|article|input|button)\b)[^>]*>/gi,"").replace(/\s+on[a-z]+\s*=\s*("[^"]*"|'[^']*'|[^\s>]+)/gi,"").replace(/\s*style\s*=\s*("[^"]*"|'[^']*')/gi,"").replace(/<a\b([^>]*)href\s*=\s*(['"]?)(?!https?:|#)[^'"\s>]+(['"]?)([^>]*)>/gi,"<a$1$4>").replace(/\s+(href|src)\s*=\s*(['"]?)\s*(javascript:|data:)[^'"\s>]*/gi,"").replace(/<a\b([^>]*)\bhref\s*=\s*(['"])(\/blog|#blog)\2([^>]*)>/gi,'<a$1 href=$2$3$2 href-line="true"$4>').trim(),he=n=>n?.map(e=>fe(e)).join("")??"";import z from"dompurify";var _=(n,e)=>{let r={...{ADD_TAGS:["my-custom-tag"]},...e};return typeof n=="string"?z.sanitize(n,r):z.sanitize(n.innerHTML,r)};var I=(n,e,t)=>{if(typeof n=="string"){let r=document.getElementById(n);r?r.addEventListener(e,t):console.warn(`Element with id '${n}' not found.`)}else n instanceof HTMLElement?n.addEventListener(e,t):n===document?document.addEventListener(e,t):console.warn("Invalid target parameter provided.")};import{createStore as ge}from"zustand/vanilla";import j from"dompurify";function Te(n,e){let t=[],r=n.replace(/:[^/]+/g,s=>(t.push(s.slice(1)),"([^/]+)")),o=new RegExp(`^${r}$`),i=e.match(o),a={};return i&&t.forEach((s,c)=>{a[s]=j.sanitize(i[c+1]??"")}),a}function ye(n){let e={},t=new URLSearchParams(n);for(let[r,o]of t.entries())e[r]=j.sanitize(o);return e}var C=ge((n,e)=>({params:{},query:{},setFromPattern:t=>{let r=window.location.pathname,o=Te(t,r),i=ye(window.location.search);n({params:o,query:i})},getParam:t=>e().params[t],getQuery:t=>e().query[t]}));function q(n){let e=C.getState();e.setFromPattern(n);let t=e.params,r=e.query;return{...t,...r}}var U=(n,e,t)=>{let r=document.querySelectorAll(n);return r.forEach(o=>{o.addEventListener(e,t)}),()=>{r.forEach(o=>{o.removeEventListener(e,t)})}};import B from"dompurify";var W=(n,e,t={},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","label","form"],ALLOWED_ATTR:["class","id","href","src","alt","title","fill","stroke","stroke-width","viewBox","xmlns","d","x","y","cx","cy","r","width","height","type","name","value","placeholder","data-click","data-change","data-select","data-classlist","data-hover","data-submit","data-key","data-event"],FORBID_TAGS:["script","iframe","foreignObject","body","html"],FORBID_ATTR:["style","xlink:href"],ALLOWED_URI_REGEXP:/^(?:(?:https?|mailto|tel|ftp):|[^a-z]|[a-z+.\-]+(?:[^a-z+.\-:]|$))/i,...r};B.addHook("uponSanitizeAttribute",(s,c)=>{let l=(c.attrName||"").toLowerCase(),d=(c.attrValue??"").toString().trim();if(l.startsWith("on")){c.keepAttr=!1;return}if(/^data-(click|change|submit|select|hover|classlist|key|event)$/.test(l)){c.keepAttr=!0;return}if(s.nodeName.toLowerCase()==="img"&&l==="src"){/^https?:\/\//i.test(d)||/^\/(?!\/)/.test(d)||/^data:image\/(png|jpeg|jpg|gif|webp);base64,/i.test(d)||(c.keepAttr=!1);return}if(l==="class"){let y=d.split(/\s+/).filter(Boolean).filter(f=>{if(/^[a-zA-Z0-9\-\:\/_\[\]\(\)]*$/.test(f)){if(/^bg-\[url\(.*\)\]$/.test(f)){let v=f.replace(/^bg-\[url\(/,"").replace(/\)\]$/,"").replace(/^['"]|['"]$/g,"");return v===""||/^https?:\/\//i.test(v)||/^\/(?!\/)/.test(v)||/^\.{0,2}\//.test(v)}return/^bg-\[\]$/.test(f),!0}return!1});c.attrValue=y.join(" ");return}});let i=B.sanitize(e,{...o,RETURN_DOM_FRAGMENT:!0});for(;n.firstChild;)n.removeChild(n.firstChild);n.appendChild(i);let a=(s,c)=>{n.querySelectorAll(`[${s}]`).forEach(l=>{let d=l.getAttribute(s);d&&Object.prototype.hasOwnProperty.call(t,d)&&l.addEventListener(c,m=>{c==="submit"&&m.preventDefault(),t[d](m)})})};a("data-click","click"),a("data-change","change"),a("data-select","select"),a("data-submit","submit"),n.querySelectorAll("[data-key]").forEach(s=>{let c=s.dataset.key,l=s.dataset.event??"click";c&&Object.prototype.hasOwnProperty.call(t,c)&&s.addEventListener(l,t[c])}),n.querySelectorAll("[data-hover]").forEach(s=>{let c=s.dataset.hover;c&&Object.prototype.hasOwnProperty.call(t,c)&&(s.addEventListener("mouseenter",t[c]),s.addEventListener("mouseleave",t[c]))}),n.querySelectorAll("[data-classlist]").forEach(s=>{let c=s.dataset.classlist;/^[a-zA-Z0-9\-\s:_]+$/.test(c)&&s.classList.add(...c.split(/\s+/))})};import G from"dompurify";var D=null,V=(n,e)=>{if(typeof document>"u")return;let t=document.getElementById(n);if(!t)return;G.addHook("uponSanitizeAttribute",(a,s)=>{let c=(s.attrName||"").toLowerCase(),l=(s.attrValue??"").toString().trim();if(c.startsWith("on")){s.keepAttr=!1;return}if((c==="href"||c==="src")&&/^(javascript:|vbscript:|data:|file:|about:)/i.test(l)){s.keepAttr=!1;return}if(c==="class"){let m=l.split(/\s+/).filter(Boolean).filter(y=>{if(/^[a-zA-Z0-9\-\:\/_\[\]\(\)]+$/.test(y)){if(/^bg-\[url\(.*\)\]$/.test(y)){let f=y.replace(/^bg-\[url\(/,"").replace(/\)\]$/,"").replace(/^['"]|['"]$/g,"");return f===""||/^https?:\/\//i.test(f)||/^\/(?!\/)/.test(f)||/^\.{0,2}\//.test(f)}return!0}return!1});s.attrValue=m.join(" ");return}if(c==="style"){s.keepAttr=!1;return}});let r=t.cloneNode(!0),o=G.sanitize(r.innerHTML,{USE_PROFILES:{html:!0},ALLOWED_TAGS:["div","span","p","h1","h2","h3","h4","h5","h6","ul","ol","li","strong","em","a","img","br","form","button","input","label"],ALLOWED_ATTR:["href","src","alt","title","class","id","type","name","value","placeholder","data-click","data-change","data-submit","data-select","data-hover","data-classlist"],FORBID_TAGS:["script","iframe","object","embed","body","html","svg","math","link","meta"],ALLOW_DATA_ATTR:!0,KEEP_CONTENT:!1,RETURN_DOM_FRAGMENT:!0}),i=Array.from(o.childNodes).map(a=>a.outerHTML||a.textContent||"").join("");if(D!==null&&i!==D){let a=document.createElement("div");e(a);let c=new DOMParser().parseFromString(D,"text/html");for(;t.firstChild;)t.removeChild(t.firstChild);c.body.childNodes.forEach(l=>t.appendChild(l.cloneNode(!0)))}else{for(D=i;t.firstChild;)t.removeChild(t.firstChild);t.appendChild(o),e(t)}};import Q from"dompurify";typeof window<"u"&&!window.__anchorSinglePopstateHandlerAttached&&(window.addEventListener("popstate",n=>{let e=n.state;e?.scrollPosition!==void 0&&window.scrollTo(0,e.scrollPosition)}),window.__anchorSinglePopstateHandlerAttached=!0);var K=(n,e,t,r="",o=null)=>{if(!n)return;let i=Q.sanitize(e,{ALLOWED_URI_REGEXP:/^(https?:|\/)/}),a=Q.sanitize(t,{USE_PROFILES:{html:!1}});n.setAttribute("href",i),n.setAttribute("aria-label",a),r&&(n.className=r.trim()),o&&n.replaceChildren(o),typeof window<"u"&&n.addEventListener("click",s=>{s.preventDefault();let l=s.currentTarget.getAttribute("href");if(l){let d=window.scrollY;window.scrollTo(0,0),window.history.pushState({scrollPosition:d},"",l),dispatchEvent(new PopStateEvent("popstate"))}})};import L from"dompurify";var Y=(n="'self' 'nonce-rAnd0m123' 'unsafe-inline' 'unsafe-eval'",e="'self' 'nonce-rAnd0m123'",t="'none'",r="'self' https://fonts.googleapis.com https://fonts.gstatic.com",o="'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",s="'self'",c="/csp-report",l=!1)=>{let d=()=>{try{let m=document.querySelector('meta[http-equiv="Content-Security-Policy"]');m||(m=document.createElement("meta"),m.setAttribute("http-equiv","Content-Security-Policy"),document.head.appendChild(m));let y=l?`report-uri ${c};`:"";m.setAttribute("content",`default-src 'self'; script-src ${n}; style-src ${e}; object-src ${t}; font-src ${r}; img-src ${o}; connect-src ${i.join(" ")}; frame-src ${a}; base-uri ${s}; ${y}`)}catch(m){console.error("Error adding CSP meta element:",m)}};document.readyState==="loading"?document.addEventListener("DOMContentLoaded",d):d()};var Z=(n,e)=>{let t={name:L.sanitize(n.name||""),title:L.sanitize(n.title||""),description:L.sanitize(n.description||"Default description"),author:L.sanitize(n.author||""),favicon:n.favicon},r=u=>{t.name=L.sanitize(u),E("name",t.name)},o=u=>{t.title=L.sanitize(u),document.title=t.title},i=u=>{t.description=L.sanitize(u),E("description",t.description)},a=u=>{t.author=L.sanitize(u),E("author",t.author)},s=u=>{t.favicon=L.sanitize(u);let p=document.querySelector('link[rel="icon"]');p||(p=document.createElement("link"),p.rel="icon",document.head.appendChild(p)),p.href=t.favicon},c=()=>t.name,l=()=>t.title,d=()=>t.description,m=()=>t.author,y=()=>t.favicon,f=()=>t,v=(u,p)=>{let h=document.createElement("meta");h.setAttribute("name",u),h.setAttribute("content",p),document.head.appendChild(h)},E=(u,p)=>{let h=document.querySelector(`meta[name="${u}"]`);h?h.setAttribute("content",p):v(u,p)},g=()=>{t.title&&(document.title=t.title),t.name&&E("name",t.name),t.description&&E("description",t.description),t.author&&E("author",t.author),t.favicon&&s(t.favicon)};return e&&Y(e.scriptSrc,e.styleSrc,e.objectSrc,Array.isArray(e.connectSrc)?e.connectSrc.join(" "):e.connectSrc,e.reportOnly!==void 0?String(e.reportOnly):void 0),g(),{setName:r,setTitle:o,setDescription:i,setAuthor:a,setFavicon:s,getName:c,getTitle:l,getDescription:d,getAuthor:m,getFavicon:y,getAllMetaData:f,appendMetaTagsToHead:g}};import Se from"dompurify";var H=(n,e,t,r,o)=>{let i=`#${n}`,a=e.querySelectorAll(i);if(a.length===0)throw new Error(`[useTSComponent] No element found with id '${n}' in the given parent.`);if(a.length>1)throw new Error(`[useTSComponent] Duplicate id '${n}' detected. Found ${a.length} elements.`);let s=a[0];s.innerHTML=Se.sanitize(s.innerHTML,{USE_PROFILES:{html:!0}}),t(s,r,o)};var X=(n,e,t,r=[])=>{let o=new Set;n.forEach((i,a)=>{if(o.has(i)){console.warn(`[useTSCollection] Duplicate ID in collection array: "${i}" \u2014 skipping.`);return}o.add(i);let s=e.querySelectorAll(`#${i}`);if(s.length>1){console.warn(`[useTSCollection] Duplicate ID in DOM: "${i}" (${s.length} elements found) \u2014 skipping component mount.`);return}let c=t[a],l=Array.isArray(r)?r[a]:void 0;typeof c=="function"?H(i,e,c,l):console.warn(`[useTSCollection] No valid component function found for ID: "${i}"`)})};var R=(n,e)=>{let r=(e??document).querySelectorAll(n);if(r.length===0)return process.env.NODE_ENV!=="production"&&console.warn(`[useTSSelect] No element found for selector: '${n}'`),null;if(n.startsWith("#")&&r.length>1){if(process.env.NODE_ENV!=="production")throw new Error(`[useTSSelect] Duplicate ID detected: '${n}'. 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: '${n}'. Returning the first one.`),r[0]};import{jwtDecode as Ee}from"jwt-decode";var J=(n,e)=>{let t=localStorage.getItem("token");if(!t)return window.location.href=e,null;try{let r=Ee(t),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 $=(n,e,t)=>{n.forEach(r=>{e.forEach(o=>{r.addEventListener(o,i=>{t(r,i)})})})};var ee=()=>({back:()=>window.history.back(),forward:()=>window.history.forward()});var te=(n,e)=>{let t=document.querySelector(`#${n}`)||document.querySelector(`.${n}`);if(!t)return;let r=window.location.pathname.replace(/\/$/,"");for(let o of e){let i=o.path.replace(/\/$/,"");if(r===i||r.startsWith(`${i}/`)){o.component(t);break}}};function ne(n,e){let t=window.location.pathname.replace(/\/$/,"");e.routes.forEach(r=>{r.children?.length&&r.children.forEach(o=>{let i=o.path.replace(/\/$/,"");if(t===i||t.startsWith(`${i}/`)){let a=n.querySelector(`#${o.outlet}`)||n.querySelector(`.${o.outlet}`);a instanceof HTMLElement&&o.element&&o.element(a)}})})}import{createStore as ve}from"zustand/vanilla";function re(n){let e=ve(()=>({value:n})),t=new Set;return{get:()=>e.getState().value,set:r=>{e.setState({value:r}),t.forEach(o=>o(r))},subscribe:r=>(t.add(r),r(e.getState().value),()=>t.delete(r))}}function oe(n){let e=n();typeof e=="function"&&e()}var se=async()=>{let n="https://cdn.jsdelivr.net/npm/brython@3/brython.min.js",e="https://cdn.jsdelivr.net/npm/brython@3/brython_stdlib.js",t=r=>new Promise((o,i)=>{let a=document.createElement("script");a.src=r,a.onload=()=>o(),a.onerror=()=>i(new Error(`Failed to load ${r}`)),document.head.appendChild(a)});await t(n),await t(e),typeof window.brython=="function"?window.brython():console.error("Brython did not load correctly.")},ie=n=>new Promise((e,t)=>{let r=document.createElement("script");r.type="text/python",r.src=`/src/python/${n}`,r.onload=()=>e(),r.onerror=()=>t(new Error(`Failed to load ${n}`)),document.body.appendChild(r)});function ae(n){let e=null;return async(t,r)=>{try{if(!e){let o=await n();e=o.default||o}if(typeof e=="function")return e(t,r);if(e instanceof HTMLElement){let o=e.cloneNode(!0);return t?.appendChild(o),o}if(typeof e=="object"&&e!==null&&"render"in e&&typeof e.render=="function")return e.render(t,r);console.warn("useTSLazy: Unsupported module type",e)}catch(o){console.error("useTSLazy failed:",o)}}}var ce=n=>typeof window>"u"?{isDOM:null}:{isDOM:n||document.body};import{debounce as we}from"lodash-es";var k=n=>n;typeof window<"u"&&typeof document<"u"&&(k=n=>{let e=document.createElement("div");return e.innerText=n,e.innerHTML});var Le=n=>{(n?Array.isArray(n)?n:n instanceof HTMLAnchorElement?[n]:Array.from(n):Array.from(document.querySelectorAll("a"))).forEach(t=>{if(!t||t.dataset.anchorEnhanced==="true")return;t.dataset.anchorEnhanced="true";let r=t.getAttribute("class")||"";t.setAttribute("class",k(r));let o=t.getAttribute("aria-label");o&&t.setAttribute("aria-label",k(o));let i=t.querySelector(":scope > *");i&&(t.innerHTML="",t.appendChild(i));let a=t.getAttribute("href")||"";if(!a.startsWith("#")){try{if(new URL(a,window.location.href).origin!==window.location.origin)return}catch{return}t.addEventListener("click",s=>{s.preventDefault();let c=t.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)}})}})},Me=we(Le,50),O=n=>{Me(n)};var le=n=>{if(!n)return;let e=R("a",n);O(e)};import de from"dompurify";import{createStore as Re}from"zustand/vanilla";import be from"dompurify";var M=Re(n=>({params:{},query:{},setParams:e=>n(()=>({params:ue(e)})),setQuery:e=>n(()=>({query:ue(e)}))}));function ue(n){let e={};for(let t in n)e[t]=be.sanitize(n[t]);return e}var N=class{constructor(e,t){this.routes=[];this.routes=e,this.expectedParams=new Set(t),window.addEventListener("popstate",this.handlePopState.bind(this)),this.handlePopState()}handlePopState(){let e=window.location.pathname,t=window.location.search,r=this.parseQueryParams(t),o=this.findMatchingRoute(e,this.routes);if(o){if(o.routeto){this.navigate(o.routeto);return}let i=this.filterAndSanitizeParams(o.params);M.getState().setParams(i),M.getState().setQuery(r);let a=document.createElement("div");if(o.element?.(a,i,r),o.children){let s=e.slice(o.path.length),c=a.querySelector("#child");c&&this.renderChildren(o.children,s,c,i,r)}}else{let i=this.findMatchingRoute("*",this.routes);if(i){let a=this.filterAndSanitizeParams(i.params);M.getState().setParams(a),M.getState().setQuery(r);let s=document.createElement("div");i.element?.(s,a,r)}}}renderChildren(e,t,r,o,i){if(!e||e.length===0){let s=r.querySelector("#child");s&&s.remove();return}let a=this.findMatchingRoute(t,e);if(a){let s=document.createElement("div");s.id="child";let c={...o,...a.params},l=this.filterAndSanitizeParams(c);if(M.getState().setParams(l),M.getState().setQuery(i),a.element?.(s,l,i),r.appendChild(s),a.children){let d=t.slice(a.path.length);this.renderChildren(a.children,d,s,l,i)}}}parseQueryParams(e){let t={},r=new URLSearchParams(e);for(let[o,i]of r.entries())this.expectedParams.has(o)&&(t[o]=de.sanitize(i));return t}findMatchingRoute(e,t,r={}){for(let o of t){let i=o.path;if(i==="*")return o;{let s=[],c=i.replace(/:[^\s/]+/g,m=>(s.push(m.substring(1)),"([^\\s/]+)")),l=new RegExp(`^${c}(?:/|$)`),d=e.match(l);if(d){let m={...r};if(s.forEach((y,f)=>{m[y]=d[f+1]??""}),o.children){let y=e.slice(d[0].length),f=this.findMatchingRoute(y,o.children,m);if(f)return f}return{...o,params:m}}}}}filterAndSanitizeParams(e){if(!e)return{};let t={};for(let r in e)this.expectedParams.has(r)&&(t[r]=de.sanitize(e[r]??""));return t}navigate(e){history.pushState(null,"",e),this.handlePopState()}addRoute(e){this.routes.push(e)}};var Ae=()=>({name:"ts-filebased-router",async buildStart(){if(typeof process>"u"||!process.versions?.node)return;let n=await import("fs/promises"),e=await import("path"),t=await import("./esm-KRNKVVL7.js"),r=e.resolve("src/pages"),o=e.resolve("src/gen"),i=e.resolve("src/routes"),a=e.join(o,"tsrouter.gen.ts"),s=e.join(i,"__root.ts"),c=process.env.NODE_ENV!=="production";async function l(g){try{await n.mkdir(g,{recursive:!0})}catch{}}function d(g,u){let p="/"+e.relative(u,g).replace(/\\/g,"/");return p=p.replace(/\.ts$/,"").replace(/\/index$/,"")||"/",p.replace(/\[(.+?)\]/g,":$1")}function m(g){return g.replace(/^\//,"").split("/").map(u=>u.startsWith(":")?u.slice(1):u).filter(Boolean).join("-")||"index"}function y(g,u){let h=e.relative(u,g).replace(/\\/g,"/").split("/").filter(Boolean),S=h[h.length-1].replace(".ts",""),w=h.length>1?h[h.length-2]:"";if(S==="index")return w?w.charAt(0).toUpperCase()+w.slice(1):"Index";if(S.startsWith("[")&&S.endsWith("]")){let T=S.slice(1,-1);return w.charAt(0).toUpperCase()+T.charAt(0).toUpperCase()+T.slice(1)}return S.charAt(0).toUpperCase()+S.slice(1)}async function f(g){let u=await n.readdir(g,{withFileTypes:!0}),p=[];for(let h of u){let S=e.join(g,h.name);if(h.isDirectory())p=p.concat(await f(S));else if(h.isFile()&&h.name.endsWith(".ts")){let w=d(S,r),T=m(w),b=y(S,r);p.push({file:S,route:w,routeName:T,importName:b})}}return p}function v(){return`import { createRouter } from "@/gen/tsrouter.gen";
1
+ function pe(n){let e=n==null?"":String(n),t=e.toLowerCase();return(t.includes("<script")||t.includes("javascript:"))&&(e=""),e=e.replace(/url\(\s*(['"])?\s*\1?\s*\)/gi,""),e.replace(/<\s*(script|iframe|object|embed|link|style|meta|body)[^>]*>.*?<\s*\/\s*\1\s*>/gi,"").replace(/<\s*(script|iframe|object|embed|link|style|meta)[^>]*>/gi,"").replace(/\s+on\w+\s*=\s*(['"]).*?\1/gi,"").replace(/\s+on\w+\s*=\s*[^\s>]+/gi,"").replace(/\s(href|src)\s*=\s*(['"]?)\s*(javascript:|vbscript:|data:|file:)[^'">\s]*\2/gi,'$1="#"')}function F(n,...e){return n.reduce((t,r,o)=>{let i=o<e.length?pe(e[o]):"";return t+r+i},"")}var fe=n=>n.replace(/<\/?(script|iframe|object|embed|link|meta|style|form|textarea|svg|math|body)[^>]*>/gi,"").replace(/<(?!\/?(b|i|em|strong|p|br|ul|ol|li|a|div|span|h1|h2|h3|h4|h5|h6|section|article|input|button)\b)[^>]*>/gi,"").replace(/\s+on[a-z]+\s*=\s*("[^"]*"|'[^']*'|[^\s>]+)/gi,"").replace(/\s*style\s*=\s*("[^"]*"|'[^']*')/gi,"").replace(/<a\b([^>]*)href\s*=\s*(['"]?)(?!https?:|#)[^'"\s>]+(['"]?)([^>]*)>/gi,"<a$1$4>").replace(/\s+(href|src)\s*=\s*(['"]?)\s*(javascript:|data:)[^'"\s>]*/gi,"").replace(/<a\b([^>]*)\bhref\s*=\s*(['"])(\/blog|#blog)\2([^>]*)>/gi,'<a$1 href=$2$3$2 href-line="true"$4>').trim(),he=n=>n?.map(e=>fe(e)).join("")??"";import z from"dompurify";var _=(n,e)=>{let r={...{ADD_TAGS:["my-custom-tag"]},...e};return typeof n=="string"?z.sanitize(n,r):z.sanitize(n.innerHTML,r)};var I=(n,e,t)=>{if(typeof n=="string"){let r=document.getElementById(n);r?r.addEventListener(e,t):console.warn(`Element with id '${n}' not found.`)}else n instanceof HTMLElement?n.addEventListener(e,t):n===document?document.addEventListener(e,t):console.warn("Invalid target parameter provided.")};import{createStore as ge}from"zustand/vanilla";import q from"dompurify";function Te(n,e){let t=[],r=n.replace(/:[^/]+/g,s=>(t.push(s.slice(1)),"([^/]+)")),o=new RegExp(`^${r}$`),i=e.match(o),a={};return i&&t.forEach((s,c)=>{a[s]=q.sanitize(i[c+1]??"")}),a}function Se(n){let e={},t=new URLSearchParams(n);for(let[r,o]of t.entries())e[r]=q.sanitize(o);return e}var D=ge((n,e)=>({params:{},query:{},setFromPattern:t=>{let r=window.location.pathname,o=Te(t,r),i=Se(window.location.search);n({params:o,query:i})},getParam:t=>e().params[t],getQuery:t=>e().query[t]}));function U(n){let e=D.getState();e.setFromPattern(n);let t=e.params,r=e.query;return{...t,...r}}var j=(n,e,t)=>{let r=document.querySelectorAll(n);return r.forEach(o=>{o.addEventListener(e,t)}),()=>{r.forEach(o=>{o.removeEventListener(e,t)})}};import B from"dompurify";var W=(n,e,t={},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","label","form"],ALLOWED_ATTR:["class","id","href","src","alt","title","fill","stroke","stroke-width","viewBox","xmlns","d","x","y","cx","cy","r","width","height","type","name","value","placeholder","data-click","data-change","data-select","data-classlist","data-hover","data-submit","data-key","data-event"],FORBID_TAGS:["script","iframe","foreignObject","body","html"],FORBID_ATTR:["style","xlink:href"],ALLOWED_URI_REGEXP:/^(?:(?:https?|mailto|tel|ftp):|[^a-z]|[a-z+.\-]+(?:[^a-z+.\-:]|$))/i,...r};B.addHook("uponSanitizeAttribute",(s,c)=>{let l=(c.attrName||"").toLowerCase(),d=(c.attrValue??"").toString().trim();if(l.startsWith("on")){c.keepAttr=!1;return}if(/^data-(click|change|submit|select|hover|classlist|key|event)$/.test(l)){c.keepAttr=!0;return}if(s.nodeName.toLowerCase()==="img"&&l==="src"){/^https?:\/\//i.test(d)||/^\/(?!\/)/.test(d)||/^data:image\/(png|jpeg|jpg|gif|webp);base64,/i.test(d)||(c.keepAttr=!1);return}if(l==="class"){let S=d.split(/\s+/).filter(Boolean).filter(f=>{if(/^[a-zA-Z0-9\-\:\/_\[\]\(\)]*$/.test(f)){if(/^bg-\[url\(.*\)\]$/.test(f)){let v=f.replace(/^bg-\[url\(/,"").replace(/\)\]$/,"").replace(/^['"]|['"]$/g,"");return v===""||/^https?:\/\//i.test(v)||/^\/(?!\/)/.test(v)||/^\.{0,2}\//.test(v)}return/^bg-\[\]$/.test(f),!0}return!1});c.attrValue=S.join(" ");return}});let i=B.sanitize(e,{...o,RETURN_DOM_FRAGMENT:!0});for(;n.firstChild;)n.removeChild(n.firstChild);n.appendChild(i);let a=(s,c)=>{n.querySelectorAll(`[${s}]`).forEach(l=>{let d=l.getAttribute(s);d&&Object.prototype.hasOwnProperty.call(t,d)&&l.addEventListener(c,m=>{c==="submit"&&m.preventDefault(),t[d](m)})})};a("data-click","click"),a("data-change","change"),a("data-select","select"),a("data-submit","submit"),n.querySelectorAll("[data-key]").forEach(s=>{let c=s.dataset.key,l=s.dataset.event??"click";c&&Object.prototype.hasOwnProperty.call(t,c)&&s.addEventListener(l,t[c])}),n.querySelectorAll("[data-hover]").forEach(s=>{let c=s.dataset.hover;c&&Object.prototype.hasOwnProperty.call(t,c)&&(s.addEventListener("mouseenter",t[c]),s.addEventListener("mouseleave",t[c]))}),n.querySelectorAll("[data-classlist]").forEach(s=>{let c=s.dataset.classlist;/^[a-zA-Z0-9\-\s:_]+$/.test(c)&&s.classList.add(...c.split(/\s+/))})};import G from"dompurify";var O=null,V=(n,e)=>{if(typeof document>"u")return;let t=document.getElementById(n);if(!t)return;G.addHook("uponSanitizeAttribute",(a,s)=>{let c=(s.attrName||"").toLowerCase(),l=(s.attrValue??"").toString().trim();if(c.startsWith("on")){s.keepAttr=!1;return}if((c==="href"||c==="src")&&/^(javascript:|vbscript:|data:|file:|about:)/i.test(l)){s.keepAttr=!1;return}if(c==="class"){let m=l.split(/\s+/).filter(Boolean).filter(S=>{if(/^[a-zA-Z0-9\-\:\/_\[\]\(\)]+$/.test(S)){if(/^bg-\[url\(.*\)\]$/.test(S)){let f=S.replace(/^bg-\[url\(/,"").replace(/\)\]$/,"").replace(/^['"]|['"]$/g,"");return f===""||/^https?:\/\//i.test(f)||/^\/(?!\/)/.test(f)||/^\.{0,2}\//.test(f)}return!0}return!1});s.attrValue=m.join(" ");return}if(c==="style"){s.keepAttr=!1;return}});let r=t.cloneNode(!0),o=G.sanitize(r.innerHTML,{USE_PROFILES:{html:!0},ALLOWED_TAGS:["div","span","p","h1","h2","h3","h4","h5","h6","ul","ol","li","strong","em","a","img","br","form","button","input","label"],ALLOWED_ATTR:["href","src","alt","title","class","id","type","name","value","placeholder","data-click","data-change","data-submit","data-select","data-hover","data-classlist"],FORBID_TAGS:["script","iframe","object","embed","body","html","svg","math","link","meta"],ALLOW_DATA_ATTR:!0,KEEP_CONTENT:!1,RETURN_DOM_FRAGMENT:!0}),i=Array.from(o.childNodes).map(a=>a.outerHTML||a.textContent||"").join("");if(O!==null&&i!==O){let a=document.createElement("div");e(a);let c=new DOMParser().parseFromString(O,"text/html");for(;t.firstChild;)t.removeChild(t.firstChild);c.body.childNodes.forEach(l=>t.appendChild(l.cloneNode(!0)))}else{for(O=i;t.firstChild;)t.removeChild(t.firstChild);t.appendChild(o),e(t)}};import Q from"dompurify";typeof window<"u"&&!window.__anchorSinglePopstateHandlerAttached&&(window.addEventListener("popstate",n=>{let e=n.state;e?.scrollPosition!==void 0&&window.scrollTo(0,e.scrollPosition)}),window.__anchorSinglePopstateHandlerAttached=!0);var K=(n,e,t,r="",o=null)=>{if(!n)return;let i=Q.sanitize(e,{ALLOWED_URI_REGEXP:/^(https?:|\/)/}),a=Q.sanitize(t,{USE_PROFILES:{html:!1}});n.setAttribute("href",i),n.setAttribute("aria-label",a),r&&(n.className=r.trim()),o&&n.replaceChildren(o),typeof window<"u"&&n.addEventListener("click",s=>{s.preventDefault();let l=s.currentTarget.getAttribute("href");if(l){let d=window.scrollY;window.scrollTo(0,0),window.history.pushState({scrollPosition:d},"",l),dispatchEvent(new PopStateEvent("popstate"))}})};import L from"dompurify";var Y=(n="'self' 'nonce-rAnd0m123' 'unsafe-inline' 'unsafe-eval'",e="'self' 'nonce-rAnd0m123'",t="'none'",r="'self' https://fonts.googleapis.com https://fonts.gstatic.com",o="'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",s="'self'",c="/csp-report",l=!1)=>{let d=()=>{try{let m=document.querySelector('meta[http-equiv="Content-Security-Policy"]');m||(m=document.createElement("meta"),m.setAttribute("http-equiv","Content-Security-Policy"),document.head.appendChild(m));let S=l?`report-uri ${c};`:"";m.setAttribute("content",`default-src 'self'; script-src ${n}; style-src ${e}; object-src ${t}; font-src ${r}; img-src ${o}; connect-src ${i.join(" ")}; frame-src ${a}; base-uri ${s}; ${S}`)}catch(m){console.error("Error adding CSP meta element:",m)}};document.readyState==="loading"?document.addEventListener("DOMContentLoaded",d):d()};var Z=(n,e)=>{let t={name:L.sanitize(n.name||""),title:L.sanitize(n.title||""),description:L.sanitize(n.description||"Default description"),author:L.sanitize(n.author||""),favicon:n.favicon},r=u=>{t.name=L.sanitize(u),E("name",t.name)},o=u=>{t.title=L.sanitize(u),document.title=t.title},i=u=>{t.description=L.sanitize(u),E("description",t.description)},a=u=>{t.author=L.sanitize(u),E("author",t.author)},s=u=>{t.favicon=L.sanitize(u);let p=document.querySelector('link[rel="icon"]');p||(p=document.createElement("link"),p.rel="icon",document.head.appendChild(p)),p.href=t.favicon},c=()=>t.name,l=()=>t.title,d=()=>t.description,m=()=>t.author,S=()=>t.favicon,f=()=>t,v=(u,p)=>{let h=document.createElement("meta");h.setAttribute("name",u),h.setAttribute("content",p),document.head.appendChild(h)},E=(u,p)=>{let h=document.querySelector(`meta[name="${u}"]`);h?h.setAttribute("content",p):v(u,p)},g=()=>{t.title&&(document.title=t.title),t.name&&E("name",t.name),t.description&&E("description",t.description),t.author&&E("author",t.author),t.favicon&&s(t.favicon)};return e&&Y(e.scriptSrc,e.styleSrc,e.objectSrc,Array.isArray(e.connectSrc)?e.connectSrc.join(" "):e.connectSrc,e.reportOnly!==void 0?String(e.reportOnly):void 0),g(),{setName:r,setTitle:o,setDescription:i,setAuthor:a,setFavicon:s,getName:c,getTitle:l,getDescription:d,getAuthor:m,getFavicon:S,getAllMetaData:f,appendMetaTagsToHead:g}};import ye from"dompurify";var C=(n,e,t,r,o)=>{let i=`#${n}`,a=e.querySelectorAll(i);if(a.length===0)throw new Error(`[useTSComponent] No element found with id '${n}' in the given parent.`);if(a.length>1)throw new Error(`[useTSComponent] Duplicate id '${n}' detected. Found ${a.length} elements.`);let s=a[0];s.innerHTML=ye.sanitize(s.innerHTML,{USE_PROFILES:{html:!0}}),t(s,r,o)};var X=(n,e,t,r=[])=>{let o=new Set;n.forEach((i,a)=>{if(o.has(i)){console.warn(`[useTSCollection] Duplicate ID in collection array: "${i}" \u2014 skipping.`);return}o.add(i);let s=e.querySelectorAll(`#${i}`);if(s.length>1){console.warn(`[useTSCollection] Duplicate ID in DOM: "${i}" (${s.length} elements found) \u2014 skipping component mount.`);return}let c=t[a],l=Array.isArray(r)?r[a]:void 0;typeof c=="function"?C(i,e,c,l):console.warn(`[useTSCollection] No valid component function found for ID: "${i}"`)})};var R=(n,e)=>{let r=(e??document).querySelectorAll(n);if(r.length===0)return process.env.NODE_ENV!=="production"&&console.warn(`[useTSSelect] No element found for selector: '${n}'`),null;if(n.startsWith("#")&&r.length>1){if(process.env.NODE_ENV!=="production")throw new Error(`[useTSSelect] Duplicate ID detected: '${n}'. 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: '${n}'. Returning the first one.`),r[0]};import{jwtDecode as Ee}from"jwt-decode";var J=(n,e)=>{let t=localStorage.getItem("token");if(!t)return window.location.href=e,null;try{let r=Ee(t),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 $=(n,e,t)=>{n.forEach(r=>{e.forEach(o=>{r.addEventListener(o,i=>{t(r,i)})})})};var ee=()=>({back:()=>window.history.back(),forward:()=>window.history.forward()});var te=(n,e)=>{let t=document.querySelector(`#${n}`)||document.querySelector(`.${n}`);if(!t)return;let r=window.location.pathname.replace(/\/$/,"");for(let o of e){let i=o.path.replace(/\/$/,"");if(r===i||r.startsWith(`${i}/`)){o.component(t);break}}};function ne(n,e){let t=window.location.pathname.replace(/\/$/,"");e.routes.forEach(r=>{r.children?.length&&r.children.forEach(o=>{let i=o.path.replace(/\/$/,"");if(t===i||t.startsWith(`${i}/`)){let a=n.querySelector(`#${o.outlet}`)||n.querySelector(`.${o.outlet}`);a instanceof HTMLElement&&o.element&&o.element(a)}})})}import{createStore as ve}from"zustand/vanilla";function re(n){let e=ve(()=>({value:n})),t=new Set;return{get:()=>e.getState().value,set:r=>{e.setState({value:r}),t.forEach(o=>o(r))},subscribe:r=>(t.add(r),r(e.getState().value),()=>t.delete(r))}}function oe(n){let e=n();typeof e=="function"&&e()}var se=async()=>{let n="https://cdn.jsdelivr.net/npm/brython@3/brython.min.js",e="https://cdn.jsdelivr.net/npm/brython@3/brython_stdlib.js",t=r=>new Promise((o,i)=>{let a=document.createElement("script");a.src=r,a.onload=()=>o(),a.onerror=()=>i(new Error(`Failed to load ${r}`)),document.head.appendChild(a)});await t(n),await t(e),typeof window.brython=="function"?window.brython():console.error("Brython did not load correctly.")},ie=n=>new Promise((e,t)=>{let r=document.createElement("script");r.type="text/python",r.src=`/src/python/${n}`,r.onload=()=>e(),r.onerror=()=>t(new Error(`Failed to load ${n}`)),document.body.appendChild(r)});function ae(n){let e=null;return async(t,r)=>{try{if(!e){let o=await n();e=o.default||o}if(typeof e=="function")return e(t,r);if(e instanceof HTMLElement){let o=e.cloneNode(!0);return t?.appendChild(o),o}if(typeof e=="object"&&e!==null&&"render"in e&&typeof e.render=="function")return e.render(t,r);console.warn("useTSLazy: Unsupported module type",e)}catch(o){console.error("useTSLazy failed:",o)}}}var ce=n=>typeof window>"u"?{isDOM:null}:{isDOM:n||document.body};import{debounce as we}from"lodash-es";var k=n=>n;typeof window<"u"&&typeof document<"u"&&(k=n=>{let e=document.createElement("div");return e.innerText=n,e.innerHTML});var Le=n=>{(n?Array.isArray(n)?n:n instanceof HTMLAnchorElement?[n]:Array.from(n):Array.from(document.querySelectorAll("a"))).forEach(t=>{if(!t||t.dataset.anchorEnhanced==="true")return;t.dataset.anchorEnhanced="true";let r=t.getAttribute("class")||"";t.setAttribute("class",k(r));let o=t.getAttribute("aria-label");o&&t.setAttribute("aria-label",k(o));let i=t.querySelector(":scope > *");i&&(t.innerHTML="",t.appendChild(i));let a=t.getAttribute("href")||"";if(!a.startsWith("#")){try{if(new URL(a,window.location.href).origin!==window.location.origin)return}catch{return}t.addEventListener("click",s=>{s.preventDefault();let c=t.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)}})}})},Me=we(Le,50),H=n=>{Me(n)};var le=n=>{if(!n)return;let e=R("a",n);H(e)};import de from"dompurify";import{createStore as Re}from"zustand/vanilla";import Ae from"dompurify";var M=Re(n=>({params:{},query:{},setParams:e=>n(()=>({params:ue(e)})),setQuery:e=>n(()=>({query:ue(e)}))}));function ue(n){let e={};for(let t in n)e[t]=Ae.sanitize(n[t]);return e}var N=class{constructor(e,t){this.routes=[];this.routes=e,this.expectedParams=new Set(t),window.addEventListener("popstate",this.handlePopState.bind(this)),this.handlePopState()}handlePopState(){let e=window.location.pathname,t=window.location.search,r=this.parseQueryParams(t),o=this.findMatchingRoute(e,this.routes);if(o){if(o.routeto){this.navigate(o.routeto);return}let i=this.filterAndSanitizeParams(o.params);M.getState().setParams(i),M.getState().setQuery(r);let a=document.createElement("div");if(o.element?.(a,i,r),o.children){let s=e.slice(o.path.length),c=a.querySelector("#child");c&&this.renderChildren(o.children,s,c,i,r)}}else{let i=this.findMatchingRoute("*",this.routes);if(i){let a=this.filterAndSanitizeParams(i.params);M.getState().setParams(a),M.getState().setQuery(r);let s=document.createElement("div");i.element?.(s,a,r)}}}renderChildren(e,t,r,o,i){if(!e||e.length===0){let s=r.querySelector("#child");s&&s.remove();return}let a=this.findMatchingRoute(t,e);if(a){let s=document.createElement("div");s.id="child";let c={...o,...a.params},l=this.filterAndSanitizeParams(c);if(M.getState().setParams(l),M.getState().setQuery(i),a.element?.(s,l,i),r.appendChild(s),a.children){let d=t.slice(a.path.length);this.renderChildren(a.children,d,s,l,i)}}}parseQueryParams(e){let t={},r=new URLSearchParams(e);for(let[o,i]of r.entries())this.expectedParams.has(o)&&(t[o]=de.sanitize(i));return t}findMatchingRoute(e,t,r={}){for(let o of t){let i=o.path;if(i==="*")return o;{let s=[],c=i.replace(/:[^\s/]+/g,m=>(s.push(m.substring(1)),"([^\\s/]+)")),l=new RegExp(`^${c}(?:/|$)`),d=e.match(l);if(d){let m={...r};if(s.forEach((S,f)=>{m[S]=d[f+1]??""}),o.children){let S=e.slice(d[0].length),f=this.findMatchingRoute(S,o.children,m);if(f)return f}return{...o,params:m}}}}}filterAndSanitizeParams(e){if(!e)return{};let t={};for(let r in e)this.expectedParams.has(r)&&(t[r]=de.sanitize(e[r]??""));return t}navigate(e){history.pushState(null,"",e),this.handlePopState()}addRoute(e){this.routes.push(e)}};var be=()=>({name:"ts-filebased-router",async buildStart(){if(typeof process>"u"||!process.versions?.node)return;let n=await import("fs/promises"),e=await import("path"),t=await import("./esm-KRNKVVL7.js"),r=e.resolve("src/pages"),o=e.resolve("src/gen"),i=e.resolve("src/routes"),a=e.join(o,"tsrouter.gen.ts"),s=e.join(i,"__root.ts"),c=process.env.NODE_ENV!=="production";async function l(g){try{await n.mkdir(g,{recursive:!0})}catch{}}function d(g,u){let p="/"+e.relative(u,g).replace(/\\/g,"/");return p=p.replace(/\.ts$/,"").replace(/\/index$/,"")||"/",p.replace(/\[(.+?)\]/g,":$1")}function m(g){return g.replace(/^\//,"").split("/").map(u=>u.startsWith(":")?u.slice(1):u).filter(Boolean).join("-")||"index"}function S(g,u){let h=e.relative(u,g).replace(/\\/g,"/").split("/").filter(Boolean),y=h[h.length-1].replace(".ts",""),w=h.length>1?h[h.length-2]:"";if(y==="index")return w?w.charAt(0).toUpperCase()+w.slice(1):"Index";if(y.startsWith("[")&&y.endsWith("]")){let T=y.slice(1,-1);return w.charAt(0).toUpperCase()+T.charAt(0).toUpperCase()+T.slice(1)}return y.charAt(0).toUpperCase()+y.slice(1)}async function f(g){let u=await n.readdir(g,{withFileTypes:!0}),p=[];for(let h of u){let y=e.join(g,h.name);if(h.isDirectory())p=p.concat(await f(y));else if(h.isFile()&&h.name.endsWith(".ts")){let w=d(y,r),T=m(w),A=S(y,r);p.push({file:y,route:w,routeName:T,importName:A})}}return p}function v(){return`import { createRouter } from "@/gen/tsrouter.gen";
2
2
  import { useTSParams } from "@devwareng/vanilla-ts";
3
3
 
4
4
  export const Router = async (DOM: HTMLElement) => {
@@ -12,13 +12,13 @@ export const Router = async (DOM: HTMLElement) => {
12
12
  window.addEventListener("popstate", () => {
13
13
  void router.navigate(window.location.pathname + window.location.search, false);
14
14
  });
15
- };`}async function E(){let g=await f(r),u=g.find(T=>T.route==="/notfound"),p=g.filter(T=>T.route!=="/notfound");for(let T of g)if(!(await n.readFile(T.file,"utf-8")).trim()){let A=T.importName,P=T.route.match(/:([^/]+)/g),me=P?`{ ${P.map(x=>`${x.slice(1)}: string`).join("; ")} }`:"{}";await n.writeFile(T.file,`import { html, useTSElements, useTSMetaData } from "@devwareng/vanilla-ts";
15
+ };`}async function E(){let g=await f(r),u=g.find(T=>T.route==="/notfound"),p=g.filter(T=>T.route!=="/notfound");for(let T of g)if(!(await n.readFile(T.file,"utf-8")).trim()){let b=T.importName,P=T.route.match(/:([^/]+)/g),me=P?`{ ${P.map(x=>`${x.slice(1)}: string`).join("; ")} }`:"{}";await n.writeFile(T.file,`import { html, useTSElements, useTSMetaData } from "@devwareng/vanilla-ts";
16
16
 
17
- export default function ${A}(DOM: HTMLElement, params: ${me}) {
17
+ export default function ${b}(DOM: HTMLElement, params: ${me}) {
18
18
 
19
19
  useTSMetaData({
20
- title: "${A}",
21
- description: "${A}",
20
+ title: "${b}",
21
+ description: "${b}",
22
22
  author: "Your name here",
23
23
  favicon: "/favicon.ico",
24
24
  });
@@ -27,24 +27,26 @@ export default function ${A}(DOM: HTMLElement, params: ${me}) {
27
27
  DOM,
28
28
  html\`
29
29
  <div>
30
- <h1>${A}</h1>
30
+ <h1>${b}</h1>
31
31
  ${P?P.map(x=>`<p>${x.slice(1)}: \${params.${x.slice(1)}}</p>`).join(`
32
32
  `):""}
33
33
  </div>
34
34
  \`);
35
- }`,"utf-8")}let h=p.map(T=>{let b="../pages/"+e.relative(r,T.file).replace(/\\/g,"/").replace(/\.ts$/,"");return`{
36
- path: "${T.route}",
37
- name: "${T.routeName}",
38
- component: useTSLazy(() => import("${b}"))
39
- }`}).join(`,
35
+ }`,"utf-8")}let h=p.map(T=>{let A="../pages/"+e.relative(r,T.file).replace(/\\/g,"/").replace(/\.ts$/,"");return`{ path: "${T.route}", name: "${T.routeName}", component: useTSLazy(() => import("${A}")) }`}).join(`,
40
36
  `),w=`// AUTO-GENERATED FILE. DO NOT EDIT MANUALLY.
41
- import { useTSLazy,html,useTSElements } from "@devwareng/vanilla-ts";
37
+ import { useTSLazy, html, useTSElements } from "@devwareng/vanilla-ts";
42
38
 
43
- ${u?`export const NotFound = useTSLazy(() => import("../pages/${e.relative(r,u.file).replace(/\\/g,"/").replace(/\.ts$/,"")}"))`:'export function NotFound(DOM: HTMLElement) {\n return useTSElements(DOM, html`<div class="p-4 animate__animated animate__fadeIn"><h1>404 - Page Not Found</h1></div>`)\n}'}
39
+ type Route = {
40
+ path: string;
41
+ name: string;
42
+ component: (DOM: HTMLElement, params: Record<string,string>) => Promise<any>;
43
+ };
44
44
 
45
- export const routeTree = [
45
+ ${u?`export const NotFound: Route['component'] = useTSLazy(() => import("../pages/${e.relative(r,u.file).replace(/\\/g,"/").replace(/\.ts$/,"")}"))`:'export function NotFound(DOM: HTMLElement) {\n return useTSElements(DOM, html`<div class="p-4 animate__animated animate__fadeIn"><h1>404 - Page Not Found</h1></div>`)\n}'}
46
+
47
+ export const routeTree: Route[] = [
46
48
  ${h}
47
- ]
49
+ ];
48
50
 
49
51
  export async function createRouter(DOM: HTMLElement) {
50
52
  function matchRoute(path: string) {
@@ -54,29 +56,28 @@ export async function createRouter(DOM: HTMLElement) {
54
56
  keys.push(key);
55
57
  return "([^/]+)"
56
58
  }) + "$")
57
- const pathname = path.split("?")[0]
58
- const match = pathname?.match(regex)
59
+ const pathname = path.split("?")[0];
60
+ const match = pathname?.match(regex);
59
61
  if (match) {
60
- const params: Record<string, string> = {}
61
- keys.forEach((key, i) => (params[key] = match[i + 1] || ""))
62
- return { ...route, params }
62
+ const params: Record<string,string> = {};
63
+ keys.forEach((key, i) => (params[key] = match[i+1] || ""));
64
+ return { ...route, params };
63
65
  }
64
66
  }
65
- return null
67
+ return null;
66
68
  }
67
69
 
68
- async function navigate(path: string, pushState: boolean = true) {
69
- const match = matchRoute(path);
70
- if (match) {
71
- // ensure params is always at least an empty object
72
- const params = match.params || {};
73
- await match.component(DOM, params);
74
- if (pushState) history.pushState({}, "", path);
75
- } else {
76
- NotFound(DOM);
70
+ async function navigate(path: string, pushState: boolean = true) {
71
+ const match = matchRoute(path);
72
+ if (match) {
73
+ // TS knows component always accepts params
74
+ await match.component(DOM, match.params);
75
+ if (pushState) history.pushState({}, "", path);
76
+ } else {
77
+ NotFound(DOM);
78
+ }
77
79
  }
78
- }
79
80
 
80
- return { navigate, routes: routeTree }
81
+ return { navigate, routes: routeTree };
81
82
  }
82
- `;await l(o),await n.writeFile(a,w,"utf-8"),await n.writeFile(s,v(),"utf-8")}await l(o),await l(i),await l(r),await E(),c&&(t.watch(r).on("all",async(u,p)=>{p.endsWith(".ts")&&await E()}),t.watch(s).on("unlink",async()=>{await n.writeFile(s,v(),"utf-8")})),console.log("\u{1F7E2} TS Filebased Router Generated with Lazy Routes and Params Support...")}});export{Ae as TSFilebasedRouter,N as TSRouter,oe as createEffect,re as createSignal,F as html,ie as loadPyFiles,he as mapper,ne as renderChildRoutes,O as useAnchor,K as useAnchorSingle,V as useInitialDOM,J as useTSAuth,X as useTSCollection,H as useTSComponent,$ as useTSElementEach,W as useTSElements,I as useTSEvent,U as useTSEventAll,q as useTSExtractParams,ae as useTSLazy,Z as useTSMetaData,ee as useTSNavigate,le as useTSNoReload,te as useTSOutlet,C as useTSParams,_ as useTSPurifier,ce as useTSSSRHydration,R as useTSSelect,se as useTSloadBrython};
83
+ `;await l(o),await n.writeFile(a,w,"utf-8"),await n.writeFile(s,v(),"utf-8")}await l(o),await l(i),await l(r),await E(),c&&(t.watch(r).on("all",async(u,p)=>{p.endsWith(".ts")&&await E()}),t.watch(s).on("unlink",async()=>{await n.writeFile(s,v(),"utf-8")})),console.log("\u{1F7E2} TS Filebased Router Generated with Lazy Routes and Params Support...")}});export{be as TSFilebasedRouter,N as TSRouter,oe as createEffect,re as createSignal,F as html,ie as loadPyFiles,he as mapper,ne as renderChildRoutes,H as useAnchor,K as useAnchorSingle,V as useInitialDOM,J as useTSAuth,X as useTSCollection,C as useTSComponent,$ as useTSElementEach,W as useTSElements,I as useTSEvent,j as useTSEventAll,U as useTSExtractParams,ae as useTSLazy,Z as useTSMetaData,ee as useTSNavigate,le as useTSNoReload,te as useTSOutlet,D as useTSParams,_ as useTSPurifier,ce as useTSSSRHydration,R as useTSSelect,se as useTSloadBrython};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@devwareng/vanilla-ts",
3
- "version": "1.9.96",
3
+ "version": "1.9.98",
4
4
  "description": "Framework-less TypeScript hooks for SPA development.",
5
5
  "author": "Waren Arapoc Gador",
6
6
  "license": "MIT",