@devwaren/vanilla-ts 1.0.13 → 1.0.15
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 +34 -12
- package/dist/index.js +34 -12
- package/package.json +1 -1
package/dist/index.cjs
CHANGED
|
@@ -1,16 +1,40 @@
|
|
|
1
|
-
"use strict";var Ke=Object.create;var K=Object.defineProperty;var Be=Object.getOwnPropertyDescriptor;var Ge=Object.getOwnPropertyNames;var Ve=Object.getPrototypeOf,Qe=Object.prototype.hasOwnProperty;var lt=(n,t)=>()=>(n&&(t=n(n=0)),t);var Gt=(n,t)=>{for(var e in t)K(n,e,{get:t[e],enumerable:!0})},Vt=(n,t,e,s)=>{if(t&&typeof t=="object"||typeof t=="function")for(let r of Ge(t))!Qe.call(n,r)&&r!==e&&K(n,r,{get:()=>t[r],enumerable:!(s=Be(t,r))||s.enumerable});return n};var P=(n,t,e)=>(e=n!=null?Ke(Ve(n)):{},Vt(t||!n||!n.__esModule?K(e,"default",{value:n,enumerable:!0}):e,n)),Xe=n=>Vt(K({},"__esModule",{value:!0}),n);function _e(n,t={}){let e=t.entryType||t.type;if(e==="both"&&(e=R.FILE_DIR_TYPE),e&&(t.type=e),n){if(typeof n!="string")throw new TypeError("readdirp: root argument must be a string. Usage: readdirp(root, options)");if(e&&!ye.includes(e))throw new Error(`readdirp: Invalid type passed. Use one of ${ye.join(", ")}`)}else throw new Error("readdirp: root argument is required. Usage: readdirp(root, options)");return t.root=n,new Wt(t)}var M,Te,A,R,zt,Se,mn,ye,pn,gn,yn,wn,we,Ee,Wt,Pe=lt(()=>{"use strict";M=require("fs/promises"),Te=require("stream"),A=require("path"),R={FILE_TYPE:"files",DIR_TYPE:"directories",FILE_DIR_TYPE:"files_directories",EVERYTHING_TYPE:"all"},zt={root:".",fileFilter:n=>!0,directoryFilter:n=>!0,type:R.FILE_TYPE,lstat:!1,depth:2147483648,alwaysStat:!1,highWaterMark:4096};Object.freeze(zt);Se="READDIRP_RECURSIVE_ERROR",mn=new Set(["ENOENT","EPERM","EACCES","ELOOP",Se]),ye=[R.DIR_TYPE,R.EVERYTHING_TYPE,R.FILE_DIR_TYPE,R.FILE_TYPE],pn=new Set([R.DIR_TYPE,R.EVERYTHING_TYPE,R.FILE_DIR_TYPE]),gn=new Set([R.EVERYTHING_TYPE,R.FILE_DIR_TYPE,R.FILE_TYPE]),yn=n=>mn.has(n.code),wn=process.platform==="win32",we=n=>!0,Ee=n=>{if(n===void 0)return we;if(typeof n=="function")return n;if(typeof n=="string"){let t=n.trim();return e=>e.basename===t}if(Array.isArray(n)){let t=n.map(e=>e.trim());return e=>t.some(s=>e.basename===s)}return we},Wt=class extends Te.Readable{constructor(t={}){super({objectMode:!0,autoDestroy:!0,highWaterMark:t.highWaterMark});let e={...zt,...t},{root:s,type:r}=e;this._fileFilter=Ee(e.fileFilter),this._directoryFilter=Ee(e.directoryFilter);let i=e.lstat?M.lstat:M.stat;wn?this._stat=a=>i(a,{bigint:!0}):this._stat=i,this._maxDepth=e.depth??zt.depth,this._wantsDir=r?pn.has(r):!1,this._wantsFile=r?gn.has(r):!1,this._wantsEverything=r===R.EVERYTHING_TYPE,this._root=(0,A.resolve)(s),this._isDirent=!e.alwaysStat,this._statsProp=this._isDirent?"dirent":"stats",this._rdOptions={encoding:"utf8",withFileTypes:this._isDirent},this.parents=[this._exploreDir(s,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,s=e&&e.files;if(s&&s.length>0){let{path:r,depth:i}=e,a=s.splice(0,t).map(c=>this._formatEntry(c,r)),o=await Promise.all(a);for(let c of o){if(!c)continue;if(this.destroyed)return;let u=await this._getEntryType(c);u==="directory"&&this._directoryFilter(c)?(i<=this._maxDepth&&this.parents.push(this._exploreDir(c.fullPath,i+1)),this._wantsDir&&(this.push(c),t--)):(u==="file"||this._includeAsFile(c))&&this._fileFilter(c)&&this._wantsFile&&(this.push(c),t--)}}else{let r=this.parents.pop();if(!r){this.push(null);break}if(this.parent=await r,this.destroyed)return}}}catch(e){this.destroy(e)}finally{this.reading=!1}}}async _exploreDir(t,e){let s;try{s=await(0,M.readdir)(t,this._rdOptions)}catch(r){this._onError(r)}return{files:s,depth:e,path:t}}async _formatEntry(t,e){let s,r=this._isDirent?t.name:t;try{let i=(0,A.resolve)((0,A.join)(e,r));s={path:(0,A.relative)(this._root,i),fullPath:i,basename:r},s[this._statsProp]=this._isDirent?t:await this._stat(i)}catch(i){this._onError(i);return}return s}_onError(t){yn(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 s=t.fullPath;try{let r=await(0,M.realpath)(s),i=await(0,M.lstat)(r);if(i.isFile())return"file";if(i.isDirectory()){let a=r.length;if(s.startsWith(r)&&s.substr(a,1)===A.sep){let o=new Error(`Circular symlink detected: "${s}" points to "${r}"`);return o.code=Se,this._onError(o)}return"directory"}}catch(r){return this._onError(r),""}}}_includeAsFile(t){let e=t&&t[this._statsProp];return e&&this._wantsEverything&&!e.isDirectory()}}});function ve(n,t,e,s,r){let i=(a,o)=>{e(n),r(a,o,{watchedPath:n}),o&&n!==o&&nt(g.resolve(n,o),H,g.join(n,o))};try{return(0,O.watch)(n,{persistent:t.persistent},i)}catch(a){s(a);return}}var O,L,g,Re,En,jt,be,st,it,Ut,Tn,Sn,_n,Le,w,b,Pn,vn,H,tt,N,Rn,bn,Ln,qt,j,xn,U,xe,et,nt,Mn,$t,An,rt,Me=lt(()=>{"use strict";O=require("fs"),L=require("fs/promises"),g=P(require("path"),1),Re=require("os"),En="data",jt="end",be="close",st=()=>{},it=process.platform,Ut=it==="win32",Tn=it==="darwin",Sn=it==="linux",_n=it==="freebsd",Le=(0,Re.type)()==="OS400",w={ALL:"all",READY:"ready",ADD:"add",CHANGE:"change",ADD_DIR:"addDir",UNLINK:"unlink",UNLINK_DIR:"unlinkDir",RAW:"raw",ERROR:"error"},b=w,Pn="watch",vn={lstat:L.lstat,stat:L.stat},H="listeners",tt="errHandlers",N="rawEmitters",Rn=[H,tt,N],bn=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"]),Ln=n=>bn.has(g.extname(n).slice(1).toLowerCase()),qt=(n,t)=>{n instanceof Set?n.forEach(t):t(n)},j=(n,t,e)=>{let s=n[t];s instanceof Set||(n[t]=s=new Set([s])),s.add(e)},xn=n=>t=>{let e=n[t];e instanceof Set?e.clear():delete n[t]},U=(n,t,e)=>{let s=n[t];s instanceof Set?s.delete(e):s===e&&delete n[t]},xe=n=>n instanceof Set?n.size===0:!n,et=new Map;nt=(n,t,e,s,r)=>{let i=et.get(n);i&&qt(i[t],a=>{a(e,s,r)})},Mn=(n,t,e,s)=>{let{listener:r,errHandler:i,rawEmitter:a}=s,o=et.get(t),c;if(!e.persistent)return c=ve(n,e,r,i,a),c?c.close.bind(c):void 0;if(o)j(o,H,r),j(o,tt,i),j(o,N,a);else{if(c=ve(n,e,nt.bind(null,t,H),i,nt.bind(null,t,N)),!c)return;c.on(b.ERROR,async u=>{let l=nt.bind(null,t,tt);if(o&&(o.watcherUnusable=!0),Ut&&u.code==="EPERM")try{await(await(0,L.open)(n,"r")).close(),l(u)}catch{}else l(u)}),o={listeners:r,errHandlers:i,rawEmitters:a,watcher:c},et.set(t,o)}return()=>{U(o,H,r),U(o,tt,i),U(o,N,a),xe(o.listeners)&&(o.watcher.close(),et.delete(t),Rn.forEach(xn(o)),o.watcher=void 0,Object.freeze(o))}},$t=new Map,An=(n,t,e,s)=>{let{listener:r,rawEmitter:i}=s,a=$t.get(t),o=a&&a.options;return o&&(o.persistent<e.persistent||o.interval>e.interval)&&((0,O.unwatchFile)(t),a=void 0),a?(j(a,H,r),j(a,N,i)):(a={listeners:r,rawEmitters:i,options:e,watcher:(0,O.watchFile)(t,e,(c,u)=>{qt(a.rawEmitters,d=>{d(b.CHANGE,t,{curr:c,prev:u})});let l=c.mtimeMs;(c.size!==u.size||l>u.mtimeMs||l===0)&&qt(a.listeners,d=>d(n,c))})},$t.set(t,a)),()=>{U(a,H,r),U(a,N,i),xe(a.listeners)&&($t.delete(t),(0,O.unwatchFile)(t),a.options=a.watcher=void 0,Object.freeze(a))}},rt=class{constructor(t){this.fsw=t,this._boundHandleError=e=>t._handleError(e)}_watchWithNodeFs(t,e){let s=this.fsw.options,r=g.dirname(t),i=g.basename(t);this.fsw._getWatchedDir(r).add(i);let o=g.resolve(t),c={persistent:s.persistent};e||(e=st);let u;if(s.usePolling){let l=s.interval!==s.binaryInterval;c.interval=l&&Ln(i)?s.binaryInterval:s.interval,u=An(t,o,c,{listener:e,rawEmitter:this.fsw._emitRaw})}else u=Mn(t,o,c,{listener:e,errHandler:this._boundHandleError,rawEmitter:this.fsw._emitRaw});return u}_handleFile(t,e,s){if(this.fsw.closed)return;let r=g.dirname(t),i=g.basename(t),a=this.fsw._getWatchedDir(r),o=e;if(a.has(i))return;let c=async(l,d)=>{if(this.fsw._throttle(Pn,t,5)){if(!d||d.mtimeMs===0)try{let f=await(0,L.stat)(t);if(this.fsw.closed)return;let h=f.atimeMs,S=f.mtimeMs;if((!h||h<=S||S!==o.mtimeMs)&&this.fsw._emit(b.CHANGE,t,f),(Tn||Sn||_n)&&o.ino!==f.ino){this.fsw._closeFile(l),o=f;let _=this._watchWithNodeFs(t,c);_&&this.fsw._addPathCloser(l,_)}else o=f}catch{this.fsw._remove(r,i)}else if(a.has(i)){let f=d.atimeMs,h=d.mtimeMs;(!f||f<=h||h!==o.mtimeMs)&&this.fsw._emit(b.CHANGE,t,d),o=d}}},u=this._watchWithNodeFs(t,c);if(!(s&&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 u}async _handleSymlink(t,e,s,r){if(this.fsw.closed)return;let i=t.fullPath,a=this.fsw._getWatchedDir(e);if(!this.fsw.options.followSymlinks){this.fsw._incrReadyCount();let o;try{o=await(0,L.realpath)(s)}catch{return this.fsw._emitReady(),!0}return this.fsw.closed?void 0:(a.has(r)?this.fsw._symlinkPaths.get(i)!==o&&(this.fsw._symlinkPaths.set(i,o),this.fsw._emit(b.CHANGE,s,t.stats)):(a.add(r),this.fsw._symlinkPaths.set(i,o),this.fsw._emit(b.ADD,s,t.stats)),this.fsw._emitReady(),!0)}if(this.fsw._symlinkPaths.has(i))return!0;this.fsw._symlinkPaths.set(i,!0)}_handleRead(t,e,s,r,i,a,o){if(t=g.join(t,""),o=this.fsw._throttle("readdir",t,1e3),!o)return;let c=this.fsw._getWatchedDir(s.path),u=new Set,l=this.fsw._readdirp(t,{fileFilter:d=>s.filterPath(d),directoryFilter:d=>s.filterDir(d)});if(l)return l.on(En,async d=>{if(this.fsw.closed){l=void 0;return}let f=d.path,h=g.join(t,f);if(u.add(f),!(d.stats.isSymbolicLink()&&await this._handleSymlink(d,t,h,f))){if(this.fsw.closed){l=void 0;return}(f===r||!r&&!c.has(f))&&(this.fsw._incrReadyCount(),h=g.join(i,g.relative(i,h)),this._addToNodeFs(h,e,s,a+1))}}).on(b.ERROR,this._boundHandleError),new Promise((d,f)=>{if(!l)return f();l.once(jt,()=>{if(this.fsw.closed){l=void 0;return}let h=o?o.clear():!1;d(void 0),c.getChildren().filter(S=>S!==t&&!u.has(S)).forEach(S=>{this.fsw._remove(t,S)}),l=void 0,h&&this._handleRead(t,!1,s,r,i,a,o)})})}async _handleDir(t,e,s,r,i,a,o){let c=this.fsw._getWatchedDir(g.dirname(t)),u=c.has(g.basename(t));!(s&&this.fsw.options.ignoreInitial)&&!i&&!u&&this.fsw._emit(b.ADD_DIR,t,e),c.add(g.basename(t)),this.fsw._getWatchedDir(t);let l,d,f=this.fsw.options.depth;if((f==null||r<=f)&&!this.fsw._symlinkPaths.has(o)){if(!i&&(await this._handleRead(t,s,a,i,t,r,l),this.fsw.closed))return;d=this._watchWithNodeFs(t,(h,S)=>{S&&S.mtimeMs===0||this._handleRead(h,!1,a,i,t,r,l)})}return d}async _addToNodeFs(t,e,s,r,i){let a=this.fsw._emitReady;if(this.fsw._isIgnored(t)||this.fsw.closed)return a(),!1;let o=this.fsw._getWatchHelpers(t);s&&(o.filterPath=c=>s.filterPath(c),o.filterDir=c=>s.filterDir(c));try{let c=await vn[o.statMethod](o.watchPath);if(this.fsw.closed)return;if(this.fsw._isIgnored(o.watchPath,c))return a(),!1;let u=this.fsw.options.followSymlinks,l;if(c.isDirectory()){let d=g.resolve(t),f=u?await(0,L.realpath)(t):t;if(this.fsw.closed||(l=await this._handleDir(o.watchPath,c,e,r,i,o,f),this.fsw.closed))return;d!==f&&f!==void 0&&this.fsw._symlinkPaths.set(d,f)}else if(c.isSymbolicLink()){let d=u?await(0,L.realpath)(t):t;if(this.fsw.closed)return;let f=g.dirname(o.watchPath);if(this.fsw._getWatchedDir(f).add(o.watchPath),this.fsw._emit(b.ADD,o.watchPath,c),l=await this._handleDir(f,c,e,r,t,o,d),this.fsw.closed)return;d!==void 0&&this.fsw._symlinkPaths.set(g.resolve(t),d)}else l=this._handleFile(o.watchPath,c,e);return a(),l&&this.fsw._addPathCloser(t,l),!1}catch(c){if(this.fsw._handleError(c))return a(),t}}}});var We={};Gt(We,{FSWatcher:()=>Y,WatchHelper:()=>at,default:()=>Un,watch:()=>ze});function ot(n){return Array.isArray(n)?n:[n]}function kn(n){return typeof n=="function"?n:typeof n=="string"?t=>n===t:n instanceof RegExp?t=>n.test(t):typeof n=="object"&&n!==null?t=>{if(n.path===t)return!0;if(n.recursive){let e=m.relative(n.path,t);return e?!e.startsWith("..")&&!m.isAbsolute(e):!1}return!1}:()=>!1}function Nn(n){if(typeof n!="string")throw new Error("string expected");n=m.normalize(n),n=n.replace(/\\/g,"/");let t=!1;n.startsWith("//")&&(t=!0);let e=/\/\//;for(;n.match(e);)n=n.replace(e,"/");return t&&(n="/"+n),n}function De(n,t,e){let s=Nn(t);for(let r=0;r<n.length;r++){let i=n[r];if(i(s,e))return!0}return!1}function zn(n,t){if(n==null)throw new TypeError("anymatch: specify first argument");let s=ot(n).map(r=>kn(r));return t==null?(r,i)=>De(s,r,i):De(s,t)}function ze(n,t={}){let e=new Y(t);return e.add(n),e}var Oe,ct,Ie,m,Yt,Dn,ke,Cn,Fn,Hn,Ae,On,In,Kt,Ce,Fe,Ne,He,Wn,$n,Bt,qn,jn,at,Y,Un,$e=lt(()=>{"use strict";Oe=require("fs"),ct=require("fs/promises"),Ie=require("events"),m=P(require("path"),1);Pe();Me();Yt="/",Dn="//",ke=".",Cn="..",Fn="string",Hn=/\\/g,Ae=/\/\//,On=/\..*\.(sw[px])$|~$|\.subl.*\.tmp/,In=/^\.[/\\]/;Kt=n=>typeof n=="object"&&n!==null&&!(n instanceof RegExp);Ce=n=>{let t=ot(n).flat();if(!t.every(e=>typeof e===Fn))throw new TypeError(`Non-string provided as watch path: ${t}`);return t.map(Ne)},Fe=n=>{let t=n.replace(Hn,Yt),e=!1;for(t.startsWith(Dn)&&(e=!0);t.match(Ae);)t=t.replace(Ae,Yt);return e&&(t=Yt+t),t},Ne=n=>Fe(m.normalize(Fe(n))),He=(n="")=>t=>typeof t=="string"?Ne(m.isAbsolute(t)?t:m.join(n,t)):t,Wn=(n,t)=>m.isAbsolute(n)?n:m.join(t,n),$n=Object.freeze(new Set),Bt=class{constructor(t,e){this.path=t,this._removeWatcher=e,this.items=new Set}add(t){let{items:e}=this;e&&t!==ke&&t!==Cn&&e.add(t)}async remove(t){let{items:e}=this;if(!e||(e.delete(t),e.size>0))return;let s=this.path;try{await(0,ct.readdir)(s)}catch{this._removeWatcher&&this._removeWatcher(m.dirname(s),m.basename(s))}}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=$n,Object.freeze(this)}},qn="stat",jn="lstat",at=class{constructor(t,e,s){this.fsw=s;let r=t;this.path=t=t.replace(In,""),this.watchPath=r,this.fullWatchPath=m.resolve(r),this.dirParts=[],this.dirParts.forEach(i=>{i.length>1&&i.pop()}),this.followSymlinks=e,this.statMethod=e?qn:jn}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 s=this.entryPath(t);return this.fsw._isntIgnored(s,e)&&this.fsw._hasReadPermissions(e)}filterDir(t){return this.fsw._isntIgnored(this.entryPath(t),t.stats)}},Y=class extends Ie.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,s={stabilityThreshold:2e3,pollInterval:100},r={persistent:!0,ignoreInitial:!1,ignorePermissionErrors:!1,interval:100,binaryInterval:300,followSymlinks:!0,usePolling:!1,atomic:!0,...t,ignored:t.ignored?ot(t.ignored):ot([]),awaitWriteFinish:e===!0?s:typeof e=="object"?{...s,...e}:!1};Le&&(r.usePolling=!0),r.atomic===void 0&&(r.atomic=!r.usePolling);let i=process.env.CHOKIDAR_USEPOLLING;if(i!==void 0){let c=i.toLowerCase();c==="false"||c==="0"?r.usePolling=!1:c==="true"||c==="1"?r.usePolling=!0:r.usePolling=!!c}let a=process.env.CHOKIDAR_INTERVAL;a&&(r.interval=Number.parseInt(a,10));let o=0;this._emitReady=()=>{o++,o>=this._readyCount&&(this._emitReady=st,this._readyEmitted=!0,process.nextTick(()=>this.emit(w.READY)))},this._emitRaw=(...c)=>this.emit(w.RAW,...c),this._boundRemove=this._remove.bind(this),this.options=r,this._nodeFsHandler=new rt(this),Object.freeze(r)}_addIgnoredPath(t){if(Kt(t)){for(let e of this._ignoredPaths)if(Kt(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)Kt(e)&&e.path===t&&this._ignoredPaths.delete(e)}add(t,e,s){let{cwd:r}=this.options;this.closed=!1,this._closePromise=void 0;let i=Ce(t);return r&&(i=i.map(a=>Wn(a,r))),i.forEach(a=>{this._removeIgnoredPath(a)}),this._userIgnored=void 0,this._readyCount||(this._readyCount=0),this._readyCount+=i.length,Promise.all(i.map(async a=>{let o=await this._nodeFsHandler._addToNodeFs(a,!s,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=Ce(t),{cwd:s}=this.options;return e.forEach(r=>{!m.isAbsolute(r)&&!this._closers.has(r)&&(s&&(r=m.join(s,r)),r=m.resolve(r)),this._closePath(r),this._addIgnoredPath(r),this._watched.has(r)&&this._addIgnoredPath({path:r,recursive:!0}),this._userIgnored=void 0}),this}close(){if(this._closePromise)return this._closePromise;this.closed=!0,this.removeAllListeners();let t=[];return this._closers.forEach(e=>e.forEach(s=>{let r=s();r instanceof Promise&&t.push(r)})),this._streams.forEach(e=>e.destroy()),this._userIgnored=void 0,this._readyCount=0,this._readyEmitted=!1,this._watched.forEach(e=>e.dispose()),this._closers.clear(),this._watched.clear(),this._streams.clear(),this._symlinkPaths.clear(),this._throttled.clear(),this._closePromise=t.length?Promise.all(t).then(()=>{}):Promise.resolve(),this._closePromise}getWatched(){let t={};return this._watched.forEach((e,s)=>{let i=(this.options.cwd?m.relative(this.options.cwd,s):s)||ke;t[i]=e.getChildren().sort()}),t}emitWithAll(t,e){this.emit(t,...e),t!==w.ERROR&&this.emit(w.ALL,t,...e)}async _emit(t,e,s){if(this.closed)return;let r=this.options;Ut&&(e=m.normalize(e)),r.cwd&&(e=m.relative(r.cwd,e));let i=[e];s!=null&&i.push(s);let a=r.awaitWriteFinish,o;if(a&&(o=this._pendingWrites.get(e)))return o.lastChange=new Date,this;if(r.atomic){if(t===w.UNLINK)return this._pendingUnlinks.set(e,[t,...i]),setTimeout(()=>{this._pendingUnlinks.forEach((c,u)=>{this.emit(...c),this.emit(w.ALL,...c),this._pendingUnlinks.delete(u)})},typeof r.atomic=="number"?r.atomic:100),this;t===w.ADD&&this._pendingUnlinks.has(e)&&(t=w.CHANGE,this._pendingUnlinks.delete(e))}if(a&&(t===w.ADD||t===w.CHANGE)&&this._readyEmitted){let c=(u,l)=>{u?(t=w.ERROR,i[0]=u,this.emitWithAll(t,i)):l&&(i.length>1?i[1]=l:i.push(l),this.emitWithAll(t,i))};return this._awaitWriteFinish(e,a.stabilityThreshold,t,c),this}if(t===w.CHANGE&&!this._throttle(w.CHANGE,e,50))return this;if(r.alwaysStat&&s===void 0&&(t===w.ADD||t===w.ADD_DIR||t===w.CHANGE)){let c=r.cwd?m.join(r.cwd,e):e,u;try{u=await(0,ct.stat)(c)}catch{}if(!u||this.closed)return;i.push(u)}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(w.ERROR,t),t||this.closed}_throttle(t,e,s){this._throttled.has(t)||this._throttled.set(t,new Map);let r=this._throttled.get(t);if(!r)throw new Error("invalid throttle");let i=r.get(e);if(i)return i.count++,!1;let a,o=()=>{let u=r.get(e),l=u?u.count:0;return r.delete(e),clearTimeout(a),u&&clearTimeout(u.timeoutObject),l};a=setTimeout(o,s);let c={timeoutObject:a,clear:o,count:0};return r.set(e,c),c}_incrReadyCount(){return this._readyCount++}_awaitWriteFinish(t,e,s,r){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 u=new Date,l=this._pendingWrites;function d(f){(0,Oe.stat)(c,(h,S)=>{if(h||!l.has(t)){h&&h.code!=="ENOENT"&&r(h);return}let _=Number(new Date);f&&S.size!==f.size&&(l.get(t).lastChange=_);let E=l.get(t);_-E.lastChange>=e?(l.delete(t),r(void 0,S)):o=setTimeout(d,a,S)})}l.has(t)||(l.set(t,{lastChange:u,cancelWait:()=>(l.delete(t),clearTimeout(o),s)}),o=setTimeout(d,a))}_isIgnored(t,e){if(this.options.atomic&&On.test(t))return!0;if(!this._userIgnored){let{cwd:s}=this.options,i=(this.options.ignored||[]).map(He(s)),o=[...[...this._ignoredPaths].map(He(s)),...i];this._userIgnored=zn(o,void 0)}return this._userIgnored(t,e)}_isntIgnored(t,e){return!this._isIgnored(t,e)}_getWatchHelpers(t){return new at(t,this.options.followSymlinks,this)}_getWatchedDir(t){let e=m.resolve(t);return this._watched.has(e)||this._watched.set(e,new Bt(e,this._boundRemove)),this._watched.get(e)}_hasReadPermissions(t){return this.options.ignorePermissionErrors?!0:!!(Number(t.mode)&256)}_remove(t,e,s){let r=m.join(t,e),i=m.resolve(r);if(s=s??(this._watched.has(r)||this._watched.has(i)),!this._throttle("remove",r,100))return;!s&&this._watched.size===1&&this.add(t,e,!0),this._getWatchedDir(r).getChildren().forEach(f=>this._remove(r,f));let c=this._getWatchedDir(t),u=c.has(e);c.remove(e),this._symlinkPaths.has(i)&&this._symlinkPaths.delete(i);let l=r;if(this.options.cwd&&(l=m.relative(this.options.cwd,r)),this.options.awaitWriteFinish&&this._pendingWrites.has(l)&&this._pendingWrites.get(l).cancelWait()===w.ADD)return;this._watched.delete(r),this._watched.delete(i);let d=s?w.UNLINK_DIR:w.UNLINK;u&&!this._isIgnored(r)&&this._emit(d,r),this._closePath(r)}_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(s=>s()),this._closers.delete(t))}_addPathCloser(t,e){if(!e)return;let s=this._closers.get(t);s||(s=[],this._closers.set(t,s)),s.push(e)}_readdirp(t,e){if(this.closed)return;let s={type:w.ALL,alwaysStat:!0,lstat:!0,...e,depth:0},r=_e(t,s);return this._streams.add(r),r.once(be,()=>{r=void 0}),r.once(jt,()=>{r&&(this._streams.delete(r),r=void 0)}),r}};Un={watch:ze,FSWatcher:Y}});var Yn={};Gt(Yn,{TSFilebasedRouter:()=>qe,TSRouter:()=>Z,createClientFunc:()=>Zt,createSignal:()=>Ot,createTSServerFunc:()=>Jt,html:()=>dt,initializeRoute:()=>je,loadPyFiles:()=>At,mapper:()=>Xt,renderChildRoutes:()=>xt,useAnchor:()=>$,useAnchorSingle:()=>_t,useInitialDOM:()=>Tt,useTSAuth:()=>Rt,useTSCollection:()=>vt,useTSComponent:()=>W,useTSElementEach:()=>Q,useTSElements:()=>wt,useTSEvent:()=>mt,useTSEventAll:()=>gt,useTSExtractParams:()=>pt,useTSLazy:()=>Dt,useTSMetaData:()=>Pt,useTSNavigate:()=>bt,useTSNoReload:()=>Ht,useTSOutlet:()=>Lt,useTSParams:()=>z,useTSPurifier:()=>ht,useTSQuery:()=>J,useTSReactor:()=>It,useTSSSRHydration:()=>Ct,useTSSelect:()=>k,useTSloadBrython:()=>Mt});module.exports=Xe(Yn);var Qt=P(require("dompurify"),1),ut=null;function Je(){return typeof window>"u"?null:(ut||(ut=(0,Qt.default)(window)),ut)}var Ze=["div","span","p","a","button","ul","li","img","input","form","label","h1","h2","h3","h4","h5","h6","section","main","article","svg","path","circle","rect","line","polyline","polygon","g"],tn=["class","id","href","src","alt","title","type","value","name","placeholder","target","rel","data-click","data-change","data-select","data-effect","data-hover","data-submit","data-key","data-event","data-component","data-stagger","data-input"];function en(n){return/^(https?:\/\/|\/|#)/i.test(n.trim())}function nn(n){if(typeof window>"u")return n;let t=document.createElement("template");return t.innerHTML=n,t.content.querySelectorAll("*").forEach(e=>{[...e.attributes].forEach(s=>{let r=s.name.toLowerCase();if(r.startsWith("on")||r.startsWith("xlink")||r.startsWith("xml")){e.removeAttribute(s.name);return}(r==="href"||r==="src")&&!en(s.value)&&e.setAttribute(r,"#")}),e.tagName==="A"&&e.getAttribute("target")==="_blank"&&e.setAttribute("rel","noopener noreferrer")}),t.innerHTML}function dt(n,...t){let e=Je(),s=n.reduce((i,a,o)=>{let c=o<t.length?String(t[o]??""):"";return i+a+c},"");if(!e)return s;let r=e.sanitize(s,{ALLOWED_TAGS:Ze,ALLOWED_ATTR:tn,RETURN_DOM:!1});return nn(r)}var Xt=(n,t)=>n.reduce((e,s,r)=>e+t(s,r),"");function Jt(n){return n}function Zt(n){return new Proxy({},{get(t,e){return async s=>n(e,s)}})}var ft=P(require("dompurify"),1),ht=(n,t)=>{let s={...{ADD_TAGS:["my-custom-tag"]},...t};return typeof n=="string"?ft.default.sanitize(n,s):ft.default.sanitize(n.innerHTML,s)};var mt=(n,t,e)=>{if(!(typeof window>"u"||typeof document>"u"))if(typeof n=="string"){let s=document.getElementById(n);s?s.addEventListener(t,e):console.warn(`Element with id '${n}' not found.`)}else n instanceof HTMLElement?n.addEventListener(t,e):n===document?document.addEventListener(t,e):console.warn("Invalid target parameter provided.")};var te=require("zustand/vanilla"),ee=P(require("dompurify"),1);function G(n){return ee.default.sanitize(n??"")}function B(n,t){let e=Object.keys(n),s=Object.keys(t);if(e.length!==s.length)return!1;for(let r of e)if(n[r]!==t[r])return!1;return!0}function rn(n,t){let e=[],s=n.replace(/:[^/]+/g,o=>(e.push(o.slice(1)),"([^/]+)")),r=new RegExp(`^${s}$`),i=t.match(r),a={};return i&&e.forEach((o,c)=>{a[o]=G(i[c+1]??"")}),a}function sn(n){let t={},e=new URLSearchParams(n);for(let[s,r]of e.entries())t[s]=G(r);return t}var z=(0,te.createStore)((n,t)=>({params:{},query:{},setFromPattern:e=>{let s=window.location.pathname,r=rn(e,s),i=sn(window.location.search),a=t();(!B(a.params,r)||!B(a.query,i))&&n({params:r,query:i})},setFromPatternValues:(e,s)=>{let r={};e.forEach((a,o)=>{r[a]=G(s[o]??"")});let i=t();B(i.params,r)||n({params:r})},setQuery:e=>{let s={};for(let i in e)s[i]=G(e[i]);let r=t();B(r.query,s)||n({query:s})},getParam:e=>t().params[e],getQuery:e=>t().query[e]}));function pt(n){let t=z.getState();t.setFromPattern(n);let e=t.params,s=t.query;return{...e,...s}}var gt=(n,t,e)=>{let s=document.querySelectorAll(n);return s.forEach(r=>{r.addEventListener(t,e)}),()=>{s.forEach(r=>{r.removeEventListener(t,e)})}};var oe=require("motion"),ae=P(require("dompurify"),1),yt=typeof window<"u"&&typeof document<"u",ne=["div","span","p","a","button","ul","li","img","input","form","label","h1","h2","h3","h4","h5","h6","section","main","article"],re=["class","id","href","src","alt","title","type","value","name","placeholder","data-click","data-change","data-select","data-effect","data-hover","data-submit","data-key","data-event","data-component","data-stagger","data-input","data-children","data-slot","target","rel"],se=yt?(0,ae.default)(window):{sanitize:(n,t)=>n};function on(n){return/^(https?:\/\/|\/|#)/i.test(n.trim())}function an(n){yt&&n.querySelectorAll("*").forEach(t=>{[...t.attributes].forEach(e=>{let s=e.name.toLowerCase();if(s.startsWith("on")){t.removeAttribute(e.name);return}(s==="href"||s==="src")&&!on(e.value)&&t.setAttribute(s,"#")}),t.tagName==="A"&&t.getAttribute("target")==="_blank"&&t.setAttribute("rel","noopener noreferrer")})}function ie(n){let t={},e={},s=400,r=0,i="ease-in-out",a=0,o=!1,c,u;return n.split(/\s+/).forEach(l=>{l==="fade-in"&&(t.opacity=0,e.opacity=1),l==="fade-out"&&(t.opacity=1,e.opacity=0),l==="slide-up"&&(t.y=20,e.y=0),l==="slide-down"&&(t.y=-20,e.y=0),l==="slide-left"&&(t.x=20,e.x=0),l==="slide-right"&&(t.x=-20,e.x=0),l.startsWith("duration-")&&(s=+l.replace("duration-","")),l.startsWith("delay-")&&(r=+l.replace("delay-","")),(l==="linear"||l.startsWith("ease"))&&(i=l),l==="infinite"&&(a=1/0),l==="replay"&&(o=!0),l.startsWith("parallax-y-")&&(c=+l.replace("parallax-y-","")),l.startsWith("parallax-x-")&&(u=+l.replace("parallax-x-",""))}),{from:t,to:e,duration:s,easing:i,delay:r,repeat:a,replay:o,parallaxY:c,parallaxX:u}}function cn(n,t){n.querySelectorAll("[data-component]").forEach(e=>{let s=e.dataset.component;t[s]?.(e)})}var wt=(n,t,e={},s)=>{if(!yt||!n)return{html:se.sanitize(t,{ALLOWED_TAGS:ne,ALLOWED_ATTR:re,...s})};let r=se.sanitize(t,{ALLOWED_TAGS:ne,ALLOWED_ATTR:re,...s});n.innerHTML=r,an(n);let i=l=>{let d=l.target.closest("[data-click]");d&&e[d.dataset.click]?.(d)};n.addEventListener("click",i),n.querySelectorAll("[data-input]").forEach(l=>{let d=l.dataset.input;e[d]?.(l),l.addEventListener("input",()=>{e[d]?.(l)})}),cn(n,e);let a=[];n.querySelectorAll("[data-effect]").forEach(l=>{let d=ie(l.dataset.effect||"");(d.parallaxX||d.parallaxY)&&a.push({el:l,...d})});let o=!1,c=()=>{o||(o=!0,requestAnimationFrame(()=>{let l=window.scrollY;a.forEach(({el:d,parallaxX:f,parallaxY:h})=>{d.style.transform=`translate3d(${(f||0)*l}px, ${(h||0)*l}px, 0)`}),o=!1}))};window.addEventListener("scroll",c);let u=new IntersectionObserver(l=>{l.forEach(d=>{let f=d.target,h=ie(f.dataset.effect||"");d.isIntersecting?(Object.assign(f.style,h.from),setTimeout(()=>{(0,oe.animate)(f,h.to,{duration:h.duration/1e3,easing:h.easing,repeat:h.repeat})},h.delay),h.replay||u.unobserve(f)):h.replay&&Object.assign(f.style,h.from)})});return n.querySelectorAll("[data-effect]").forEach(l=>u.observe(l)),{cleanup(){u.disconnect(),window.removeEventListener("scroll",c),n.removeEventListener("click",i)}}};var Et=P(require("dompurify"),1),V=null,Tt=(n,t)=>{if(typeof document>"u")return;let e=document.getElementById(n);if(!e)return;Et.default.addHook("uponSanitizeAttribute",(a,o)=>{let c=(o.attrName||"").toLowerCase(),u=(o.attrValue??"").toString().trim();if(c.startsWith("on")){o.keepAttr=!1;return}if((c==="href"||c==="src")&&/^(javascript:|vbscript:|data:|file:|about:)/i.test(u)){o.keepAttr=!1;return}if(c==="class"){let d=u.split(/\s+/).filter(Boolean).filter(f=>{if(/^[a-zA-Z0-9\-\:\/_\[\]\(\)]+$/.test(f)){if(/^bg-\[url\(.*\)\]$/.test(f)){let h=f.replace(/^bg-\[url\(/,"").replace(/\)\]$/,"").replace(/^['"]|['"]$/g,"");return h===""||/^https?:\/\//i.test(h)||/^\/(?!\/)/.test(h)||/^\.{0,2}\//.test(h)}return!0}return!1});o.attrValue=d.join(" ");return}if(c==="style"){o.keepAttr=!1;return}});let s=e.cloneNode(!0),r=Et.default.sanitize(s.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(r.childNodes).map(a=>a.outerHTML||a.textContent||"").join("");if(V!==null&&i!==V){let a=document.createElement("div");t(a);let c=new DOMParser().parseFromString(V,"text/html");for(;e.firstChild;)e.removeChild(e.firstChild);c.body.childNodes.forEach(u=>e.appendChild(u.cloneNode(!0)))}else{for(V=i;e.firstChild;)e.removeChild(e.firstChild);e.appendChild(r),t(e)}};var St=P(require("dompurify"),1);typeof window<"u"&&!window.__anchorSinglePopstateHandlerAttached&&(window.addEventListener("popstate",n=>{let t=n.state;t?.scrollPosition!==void 0&&window.scrollTo(0,t.scrollPosition)}),window.__anchorSinglePopstateHandlerAttached=!0);var _t=(n,t,e,s="",r=null)=>{if(!n)return;let i=St.default.sanitize(t,{ALLOWED_URI_REGEXP:/^(https?:|\/)/}),a=St.default.sanitize(e,{USE_PROFILES:{html:!1}});n.setAttribute("href",i),n.setAttribute("aria-label",a),s&&(n.className=s.trim()),r&&n.replaceChildren(r),typeof window<"u"&&n.addEventListener("click",o=>{o.preventDefault();let u=o.currentTarget.getAttribute("href");if(u){let l=window.scrollY;window.scrollTo(0,0),window.history.pushState({scrollPosition:l},"",u),dispatchEvent(new PopStateEvent("popstate"))}})};var x=P(require("dompurify"),1);var ce=(n="'self' 'nonce-rAnd0m123' 'unsafe-inline' 'unsafe-eval'",t="'self' 'nonce-rAnd0m123'",e="'none'",s="'self' https://fonts.googleapis.com https://fonts.gstatic.com",r="'self' https://blogger.googleusercontent.com",i=["'self'","https://fonts.googleapis.com","https://fonts.gstatic.com","https://www.google.com/maps/"],a="'self' https://www.youtube.com",o="'self'",c="/csp-report",u=!1)=>{let l=()=>{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 f=u?`report-uri ${c};`:"";d.setAttribute("content",`default-src 'self'; script-src ${n}; style-src ${t}; object-src ${e}; font-src ${s}; img-src ${r}; connect-src ${i.join(" ")}; frame-src ${a}; base-uri ${o}; ${f}`)}catch(d){console.error("Error adding CSP meta element:",d)}};document.readyState==="loading"?document.addEventListener("DOMContentLoaded",l):l()};var Pt=(n,t)=>{let e={name:x.default.sanitize(n.name||""),title:x.default.sanitize(n.title||""),description:x.default.sanitize(n.description||"Default description"),author:x.default.sanitize(n.author||""),favicon:n.favicon},s=p=>{e.name=x.default.sanitize(p),_("name",e.name)},r=p=>{e.title=x.default.sanitize(p),document.title=e.title},i=p=>{e.description=x.default.sanitize(p),_("description",e.description)},a=p=>{e.author=x.default.sanitize(p),_("author",e.author)},o=p=>{e.favicon=x.default.sanitize(p);let T=document.querySelector('link[rel="icon"]');T||(T=document.createElement("link"),T.rel="icon",document.head.appendChild(T)),T.href=e.favicon},c=()=>e.name,u=()=>e.title,l=()=>e.description,d=()=>e.author,f=()=>e.favicon,h=()=>e,S=(p,T)=>{let v=document.createElement("meta");v.setAttribute("name",p),v.setAttribute("content",T),document.head.appendChild(v)},_=(p,T)=>{let v=document.querySelector(`meta[name="${p}"]`);v?v.setAttribute("content",T):S(p,T)},E=()=>{e.title&&(document.title=e.title),e.name&&_("name",e.name),e.description&&_("description",e.description),e.author&&_("author",e.author),e.favicon&&o(e.favicon)};return t&&ce(t.scriptSrc,t.styleSrc,t.objectSrc,Array.isArray(t.connectSrc)?t.connectSrc.join(" "):t.connectSrc,t.reportOnly!==void 0?String(t.reportOnly):void 0),E(),{setName:s,setTitle:r,setDescription:i,setAuthor:a,setFavicon:o,getName:c,getTitle:u,getDescription:l,getAuthor:d,getFavicon:f,getAllMetaData:h,appendMetaTagsToHead:E}};var le=P(require("dompurify"),1),W=(n,t,e,s,r)=>{let i=`#${n}`,a=t.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 o=a[0];o.innerHTML=le.default.sanitize(o.innerHTML,{USE_PROFILES:{html:!0}}),e(o,s,r)};var vt=(n,t,e,s=[])=>{let r=new Set;n.forEach((i,a)=>{if(r.has(i)){console.warn(`[useTSCollection] Duplicate ID in collection array: "${i}" \u2014 skipping.`);return}r.add(i);let o=t.querySelectorAll(`#${i}`);if(o.length>1){console.warn(`[useTSCollection] Duplicate ID in DOM: "${i}" (${o.length} elements found) \u2014 skipping component mount.`);return}let c=e[a],u=Array.isArray(s)?s[a]:void 0;typeof c=="function"?W(i,t,c,u):console.warn(`[useTSCollection] No valid component function found for ID: "${i}"`)})};var k=(n,t)=>{let s=(t??document).querySelectorAll(n);if(s.length===0)return process.env.NODE_ENV!=="production"&&console.warn(`[useTSSelect] No element found for selector: '${n}'`),null;if(n.startsWith("#")&&s.length>1){if(process.env.NODE_ENV!=="production")throw new Error(`[useTSSelect] Duplicate ID detected: '${n}'. Found ${s.length} elements with this ID.`);return s[0]}return s.length>1&&process.env.NODE_ENV!=="production"&&console.warn(`[useTSSelect] Multiple elements found for selector: '${n}'. Returning the first one.`),s[0]};var ue=require("jwt-decode"),Rt=(n,t)=>{let e=localStorage.getItem("token");if(!e)return window.location.href=t,null;try{let s=(0,ue.jwtDecode)(e),r=Date.now()/1e3;return s.exp&&s.exp<r&&(console.error("Token has expired"),window.localStorage.removeItem("token"),window.location.href=t),null}catch(s){return console.error("Invalid token:",s),window.location.href=t,null}};var Q=(n,t,e)=>{n.forEach(s=>{t.forEach(r=>{s.addEventListener(r,i=>{e(s,i)})})})};var bt=()=>({back:()=>window.history.back(),forward:()=>window.history.forward()});var Lt=(n,t)=>{let e=document.querySelector(`#${n}`)||document.querySelector(`.${n}`);if(!e)return;let s=window.location.pathname.replace(/\/$/,"");for(let r of t){let i=r.path.replace(/\/$/,"");if(s===i||s.startsWith(`${i}/`)){r.component(e);break}}};function xt(n,t){let e=window.location.pathname.replace(/\/$/,"");t.routes.forEach(s=>{s.children?.length&&s.children.forEach(r=>{let i=r.path.replace(/\/$/,"");if(e===i||e.startsWith(`${i}/`)){let a=n.querySelector(`#${r.outlet}`)||n.querySelector(`.${r.outlet}`);a instanceof HTMLElement&&r.element&&r.element(a)}})})}var Mt=async()=>{let n="https://cdn.jsdelivr.net/npm/brython@3/brython.min.js",t="https://cdn.jsdelivr.net/npm/brython@3/brython_stdlib.js",e=s=>new Promise((r,i)=>{let a=document.createElement("script");a.src=s,a.onload=()=>r(),a.onerror=()=>i(new Error(`Failed to load ${s}`)),document.head.appendChild(a)});await e(n),await e(t),typeof window.brython=="function"?window.brython():console.error("Brython did not load correctly.")},At=n=>new Promise((t,e)=>{let s=document.createElement("script");s.type="text/python",s.src=`/src/python/${n}`,s.onload=()=>t(),s.onerror=()=>e(new Error(`Failed to load ${n}`)),document.body.appendChild(s)});function Dt(n){let t=null;return async(e,s)=>{try{if(!t){let r=await n();t=r.default||r}if(typeof t=="function")return t(e,s);if(t instanceof HTMLElement){let r=t.cloneNode(!0);return e?.appendChild(r),r}if(typeof t=="object"&&t!==null&&"render"in t&&typeof t.render=="function")return t.render(e,s);console.warn("useTSLazy: Unsupported module type",t)}catch(r){console.error("useTSLazy failed:",r)}}}var Ct=n=>typeof window>"u"?{isDOM:null}:{isDOM:n||document.body};var de=require("lodash-es"),Ft=n=>n;typeof window<"u"&&typeof document<"u"&&(Ft=n=>{let t=document.createElement("div");return t.innerText=n,t.innerHTML});var ln=n=>{(n?Array.isArray(n)?n:n instanceof HTMLAnchorElement?[n]:Array.from(n):Array.from(document.querySelectorAll("a"))).forEach(e=>{if(!e||e.dataset.anchorEnhanced==="true")return;e.dataset.anchorEnhanced="true";let s=e.getAttribute("class")||"";e.setAttribute("class",Ft(s));let r=e.getAttribute("aria-label");r&&e.setAttribute("aria-label",Ft(r));let i=e.querySelector(":scope > *");i&&(e.innerHTML="",e.appendChild(i));let a=e.getAttribute("href")||"";if(!a.startsWith("#")){try{if(new URL(a,window.location.href).origin!==window.location.origin)return}catch{return}e.addEventListener("click",o=>{o.preventDefault();let c=e.getAttribute("href")||"";try{let u=new URL(c,window.location.href);window.history.pushState({},"",u.pathname+u.search+u.hash),window.dispatchEvent(new PopStateEvent("popstate"))}catch(u){console.error("Invalid URL in anchor:",c,u)}})}})},un=(0,de.debounce)(ln,50),$=n=>{un(n)};var Ht=n=>{if(!n)return;let t=k("a",n);$(t)};var fe=n=>{let t=n,e=[];return[()=>t,a=>{t=typeof a=="function"?a(t):a,e.forEach(o=>o(t))},a=>{e.push(a),a(t)}]};function he(n,t,e){let s=()=>{n.textContent=t().toString(),e?.(t())};s();let r=t.set;r&&(t.set=i=>{r(i),s()})}function Ot(n){let[t,e,s]=fe(n),r=[],i=(()=>t());return i.set=a=>{e(a),r.forEach(o=>o(i()))},i.bind=a=>he(a,i),i.subscribe=a=>{r.push(a),a(i())},i}function It(n,t){let e={deps:t.map(r=>typeof r=="function"?r():r)},s=n();typeof s=="function"&&(e.cleanup=s),t.forEach((r,i)=>{typeof r=="function"&&"bind"in r&&r.subscribe?.(()=>{let o=r(),c=e.deps[i];if(o!==c){e.cleanup?.(),e.deps[i]=o;let u=n();typeof u=="function"&&(e.cleanup=u)}})})}var y={params:{},query:{}},kt=new Set;function dn(){return{params:{...y.params},query:{...y.query}}}function q(n,t){let e=Object.keys(n),s=Object.keys(t);if(e.length!==s.length)return!1;for(let r of e)if(n[r]!==t[r])return!1;return!0}function F(){let n=dn();kt.forEach(t=>t(n))}function fn(n){let t={};if(!n)return t;let e=n.startsWith("?")?n.slice(1):n;for(let s of e.split("&")){if(!s)continue;let[r,i]=s.split("=");r&&(t[decodeURIComponent(r)]=decodeURIComponent(i||""))}return t}function hn(n){let t=new URLSearchParams;for(let s in n){let r=n[s];r!=null&&r!==""&&t.set(s,r)}let e=t.toString();return e?`?${e}`:""}function X(){if(typeof window>"u")return;let n=window.location.pathname,t=window.location.hash,e=hn(y.query);history.replaceState({},"",n+e+t)}var J={getState(){return{params:y.params,query:y.query,getParam:n=>y.params[n],getQuery:n=>y.query[n],setFromPattern(n){if(typeof window>"u")return;let t=n.match(/:([^/]+)/g)?.map(r=>r.slice(1))||[],e=window.location.pathname.split("/").filter(Boolean),s={};t.forEach((r,i)=>{s[r]=e[i]}),q(y.params,s)||(y.params=s,F())},setFromPatternValues(n,t){let e={};n.forEach((s,r)=>{e[s]=t[r]}),q(y.params,e)||(y.params=e,F())},setQuery(n){let t={...y.query,...n};q(y.query,t)||(y.query=t,X(),F())},replaceQuery(n){q(y.query,n)||(y.query={...n},X(),F())},removeQuery(n){if(!(n in y.query))return;let t={...y.query};delete t[n],y.query=t,X(),F()},clearQuery(){Object.keys(y.query).length!==0&&(y.query={},X(),F())},setQueryFromURL(n){let t=fn(n);q(y.query,t)||(y.query=t,F())},subscribe(n){return kt.add(n),()=>kt.delete(n)}}}};typeof window<"u"&&window.addEventListener("popstate",()=>{J.getState().setQueryFromURL(window.location.search)});var Nt=P(require("dompurify"),1);var pe=require("zustand/vanilla"),ge=P(require("dompurify"),1),D=(0,pe.createStore)(n=>({params:{},query:{},setParams:t=>n(()=>({params:me(t)})),setQuery:t=>n(()=>({query:me(t)}))}));function me(n){let t={};for(let e in n)t[e]=ge.default.sanitize(n[e]);return t}var Z=class{routes=[];expectedParams;apiFetcher;constructor(t,e,s){this.routes=t,this.expectedParams=new Set(e),this.apiFetcher=s,window.addEventListener("popstate",this.handlePopState.bind(this)),this.handlePopState()}handlePopState(){let t=window.location.pathname,e=window.location.search,s=this.parseQueryParams(e);if(t.startsWith("/api")&&this.apiFetcher){let a=t.replace("/api/","").split("/")[0],o=Object.fromEntries(new URLSearchParams(e));this.apiFetcher(a,o).then(c=>console.log("API response:",c)).catch(c=>console.error("API error:",c));return}let r=this.findMatchingRoute(t,this.routes);if(r){if(r.routeto){this.navigate(r.routeto);return}let i=this.filterAndSanitizeParams(r.params);D.getState().setParams(i),D.getState().setQuery(s);let a=document.createElement("div");if(r.element?.(a,i,s),r.children){let o=t.slice(r.path.length),c=a.querySelector("#child");c&&this.renderChildren(r.children,o,c,i,s)}}else{let i=this.findMatchingRoute("*",this.routes);if(i){let a=this.filterAndSanitizeParams(i.params);D.getState().setParams(a),D.getState().setQuery(s);let o=document.createElement("div");i.element?.(o,a,s)}}}renderChildren(t,e,s,r,i){if(!t||t.length===0){let o=s.querySelector("#child");o&&o.remove();return}let a=this.findMatchingRoute(e,t);if(a){let o=document.createElement("div");o.id="child";let c={...r,...a.params},u=this.filterAndSanitizeParams(c);if(D.getState().setParams(u),D.getState().setQuery(i),a.element?.(o,u,i),s.appendChild(o),a.children){let l=e.slice(a.path.length);this.renderChildren(a.children,l,o,u,i)}}}parseQueryParams(t){let e={},s=new URLSearchParams(t);for(let[r,i]of s.entries())this.expectedParams.has(r)&&(e[r]=Nt.default.sanitize(i));return e}findMatchingRoute(t,e,s={}){for(let r of e){let i=r.path;if(i==="*")return r;{let o=[],c=i.replace(/:[^\s/]+/g,d=>(o.push(d.substring(1)),"([^\\s/]+)")),u=new RegExp(`^${c}(?:/|$)`),l=t.match(u);if(l){let d={...s};if(o.forEach((f,h)=>{d[f]=l[h+1]??""}),r.children){let f=t.slice(l[0].length),h=this.findMatchingRoute(f,r.children,d);if(h)return h}return{...r,params:d}}}}}filterAndSanitizeParams(t){if(!t)return{};let e={};for(let s in t)this.expectedParams.has(s)&&(e[s]=Nt.default.sanitize(t[s]??""));return e}navigate(t){history.pushState(null,"",t),this.handlePopState()}addRoute(t){this.routes.push(t)}};var qe=()=>({name:"ts-filebased-router",async buildStart(){let n=await import("fs/promises"),t=await import("path"),e=await Promise.resolve().then(()=>($e(),We)),s=t.resolve("src/pages"),r=t.resolve("src/gen"),i=t.resolve("src/routes"),a=t.join(r,"tsrouter.gen.ts"),o=t.join(i,"__root.ts"),c=process.env.NODE_ENV!=="production",u=async E=>n.mkdir(E,{recursive:!0}).catch(()=>{}),l=E=>E.charAt(0).toUpperCase()+E.slice(1),d=E=>{let p="/"+t.relative(s,E).replace(/\\/g,"/");return p=p.replace(/\.ts$/,"").replace(/\/index$/,"")||"/",p.replace(/\[\.\.\.(.+?)\]/g,"*").replace(/\[(.+?)\]/g,":$1")},f=E=>E.replace(/^\//,"").split("/").map(p=>p.startsWith(":")?l(p.slice(1)):p.replace(/\b\w/g,T=>T.toUpperCase()).replace(/[-_]/g,"")).filter(Boolean).join("")||"Index",h=async E=>{let p=await n.readdir(E,{withFileTypes:!0}),T=[];for(let v of p){let I=t.join(E,v.name);v.isDirectory()?T.push(...await h(I)):v.isFile()&&v.name.endsWith(".ts")&&T.push({file:I,route:d(I),name:f(d(I))})}return T},S=async()=>{let E=await h(s),p=E.find(C=>C.route==="/notfound"),T=E.filter(C=>C.route!=="/notfound"),v=p?`export const NotFound = async (DOM: HTMLElement) => {
|
|
2
|
-
|
|
1
|
+
"use strict";var Qt=Object.create;var B=Object.defineProperty;var Xt=Object.getOwnPropertyDescriptor;var Jt=Object.getOwnPropertyNames;var Zt=Object.getPrototypeOf,en=Object.prototype.hasOwnProperty;var de=(n,e)=>()=>(n&&(e=n(n=0)),e);var Je=(n,e)=>{for(var t in e)B(n,t,{get:e[t],enumerable:!0})},Ze=(n,e,t,s)=>{if(e&&typeof e=="object"||typeof e=="function")for(let r of Jt(e))!en.call(n,r)&&r!==t&&B(n,r,{get:()=>e[r],enumerable:!(s=Xt(e,r))||s.enumerable});return n};var v=(n,e,t)=>(t=n!=null?Qt(Zt(n)):{},Ze(e||!n||!n.__esModule?B(t,"default",{value:n,enumerable:!0}):t,n)),tn=n=>Ze(B({},"__esModule",{value:!0}),n);function bt(n,e={}){let t=e.entryType||e.type;if(t==="both"&&(t=b.FILE_DIR_TYPE),t&&(e.type=t),n){if(typeof n!="string")throw new TypeError("readdirp: root argument must be a string. Usage: readdirp(root, options)");if(t&&!St.includes(t))throw new Error(`readdirp: Invalid type passed. Use one of ${St.join(", ")}`)}else throw new Error("readdirp: root argument is required. Usage: readdirp(root, options)");return e.root=n,new qe(e)}var A,vt,D,b,$e,Rt,wn,St,En,Tn,Sn,_n,_t,Pt,qe,Lt=de(()=>{"use strict";A=require("fs/promises"),vt=require("stream"),D=require("path"),b={FILE_TYPE:"files",DIR_TYPE:"directories",FILE_DIR_TYPE:"files_directories",EVERYTHING_TYPE:"all"},$e={root:".",fileFilter:n=>!0,directoryFilter:n=>!0,type:b.FILE_TYPE,lstat:!1,depth:2147483648,alwaysStat:!1,highWaterMark:4096};Object.freeze($e);Rt="READDIRP_RECURSIVE_ERROR",wn=new Set(["ENOENT","EPERM","EACCES","ELOOP",Rt]),St=[b.DIR_TYPE,b.EVERYTHING_TYPE,b.FILE_DIR_TYPE,b.FILE_TYPE],En=new Set([b.DIR_TYPE,b.EVERYTHING_TYPE,b.FILE_DIR_TYPE]),Tn=new Set([b.EVERYTHING_TYPE,b.FILE_DIR_TYPE,b.FILE_TYPE]),Sn=n=>wn.has(n.code),_n=process.platform==="win32",_t=n=>!0,Pt=n=>{if(n===void 0)return _t;if(typeof n=="function")return n;if(typeof n=="string"){let e=n.trim();return t=>t.basename===e}if(Array.isArray(n)){let e=n.map(t=>t.trim());return t=>e.some(s=>t.basename===s)}return _t},qe=class extends vt.Readable{constructor(e={}){super({objectMode:!0,autoDestroy:!0,highWaterMark:e.highWaterMark});let t={...$e,...e},{root:s,type:r}=t;this._fileFilter=Pt(t.fileFilter),this._directoryFilter=Pt(t.directoryFilter);let i=t.lstat?A.lstat:A.stat;_n?this._stat=a=>i(a,{bigint:!0}):this._stat=i,this._maxDepth=t.depth??$e.depth,this._wantsDir=r?En.has(r):!1,this._wantsFile=r?Tn.has(r):!1,this._wantsEverything=r===b.EVERYTHING_TYPE,this._root=(0,D.resolve)(s),this._isDirent=!t.alwaysStat,this._statsProp=this._isDirent?"dirent":"stats",this._rdOptions={encoding:"utf8",withFileTypes:this._isDirent},this.parents=[this._exploreDir(s,1)],this.reading=!1,this.parent=void 0}async _read(e){if(!this.reading){this.reading=!0;try{for(;!this.destroyed&&e>0;){let t=this.parent,s=t&&t.files;if(s&&s.length>0){let{path:r,depth:i}=t,a=s.splice(0,e).map(c=>this._formatEntry(c,r)),o=await Promise.all(a);for(let c of o){if(!c)continue;if(this.destroyed)return;let u=await this._getEntryType(c);u==="directory"&&this._directoryFilter(c)?(i<=this._maxDepth&&this.parents.push(this._exploreDir(c.fullPath,i+1)),this._wantsDir&&(this.push(c),e--)):(u==="file"||this._includeAsFile(c))&&this._fileFilter(c)&&this._wantsFile&&(this.push(c),e--)}}else{let r=this.parents.pop();if(!r){this.push(null);break}if(this.parent=await r,this.destroyed)return}}}catch(t){this.destroy(t)}finally{this.reading=!1}}}async _exploreDir(e,t){let s;try{s=await(0,A.readdir)(e,this._rdOptions)}catch(r){this._onError(r)}return{files:s,depth:t,path:e}}async _formatEntry(e,t){let s,r=this._isDirent?e.name:e;try{let i=(0,D.resolve)((0,D.join)(t,r));s={path:(0,D.relative)(this._root,i),fullPath:i,basename:r},s[this._statsProp]=this._isDirent?e:await this._stat(i)}catch(i){this._onError(i);return}return s}_onError(e){Sn(e)&&!this.destroyed?this.emit("warn",e):this.destroy(e)}async _getEntryType(e){if(!e&&this._statsProp in e)return"";let t=e[this._statsProp];if(t.isFile())return"file";if(t.isDirectory())return"directory";if(t&&t.isSymbolicLink()){let s=e.fullPath;try{let r=await(0,A.realpath)(s),i=await(0,A.lstat)(r);if(i.isFile())return"file";if(i.isDirectory()){let a=r.length;if(s.startsWith(r)&&s.substr(a,1)===D.sep){let o=new Error(`Circular symlink detected: "${s}" points to "${r}"`);return o.code=Rt,this._onError(o)}return"directory"}}catch(r){return this._onError(r),""}}}_includeAsFile(e){let t=e&&e[this._statsProp];return t&&this._wantsEverything&&!t.isDirectory()}}});function xt(n,e,t,s,r){let i=(a,o)=>{t(n),r(a,o,{watchedPath:n}),o&&n!==o&&re(g.resolve(n,o),H,g.join(n,o))};try{return(0,O.watch)(n,{persistent:e.persistent},i)}catch(a){s(a);return}}var O,x,g,Mt,Pn,Ye,At,ie,oe,Ke,vn,Rn,bn,Dt,w,L,Ln,xn,H,te,N,Mn,An,Dn,Ue,j,Cn,U,Ct,ne,re,Fn,je,Hn,se,Ft=de(()=>{"use strict";O=require("fs"),x=require("fs/promises"),g=v(require("path"),1),Mt=require("os"),Pn="data",Ye="end",At="close",ie=()=>{},oe=process.platform,Ke=oe==="win32",vn=oe==="darwin",Rn=oe==="linux",bn=oe==="freebsd",Dt=(0,Mt.type)()==="OS400",w={ALL:"all",READY:"ready",ADD:"add",CHANGE:"change",ADD_DIR:"addDir",UNLINK:"unlink",UNLINK_DIR:"unlinkDir",RAW:"raw",ERROR:"error"},L=w,Ln="watch",xn={lstat:x.lstat,stat:x.stat},H="listeners",te="errHandlers",N="rawEmitters",Mn=[H,te,N],An=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"]),Dn=n=>An.has(g.extname(n).slice(1).toLowerCase()),Ue=(n,e)=>{n instanceof Set?n.forEach(e):e(n)},j=(n,e,t)=>{let s=n[e];s instanceof Set||(n[e]=s=new Set([s])),s.add(t)},Cn=n=>e=>{let t=n[e];t instanceof Set?t.clear():delete n[e]},U=(n,e,t)=>{let s=n[e];s instanceof Set?s.delete(t):s===t&&delete n[e]},Ct=n=>n instanceof Set?n.size===0:!n,ne=new Map;re=(n,e,t,s,r)=>{let i=ne.get(n);i&&Ue(i[e],a=>{a(t,s,r)})},Fn=(n,e,t,s)=>{let{listener:r,errHandler:i,rawEmitter:a}=s,o=ne.get(e),c;if(!t.persistent)return c=xt(n,t,r,i,a),c?c.close.bind(c):void 0;if(o)j(o,H,r),j(o,te,i),j(o,N,a);else{if(c=xt(n,t,re.bind(null,e,H),i,re.bind(null,e,N)),!c)return;c.on(L.ERROR,async u=>{let l=re.bind(null,e,te);if(o&&(o.watcherUnusable=!0),Ke&&u.code==="EPERM")try{await(await(0,x.open)(n,"r")).close(),l(u)}catch{}else l(u)}),o={listeners:r,errHandlers:i,rawEmitters:a,watcher:c},ne.set(e,o)}return()=>{U(o,H,r),U(o,te,i),U(o,N,a),Ct(o.listeners)&&(o.watcher.close(),ne.delete(e),Mn.forEach(Cn(o)),o.watcher=void 0,Object.freeze(o))}},je=new Map,Hn=(n,e,t,s)=>{let{listener:r,rawEmitter:i}=s,a=je.get(e),o=a&&a.options;return o&&(o.persistent<t.persistent||o.interval>t.interval)&&((0,O.unwatchFile)(e),a=void 0),a?(j(a,H,r),j(a,N,i)):(a={listeners:r,rawEmitters:i,options:t,watcher:(0,O.watchFile)(e,t,(c,u)=>{Ue(a.rawEmitters,d=>{d(L.CHANGE,e,{curr:c,prev:u})});let l=c.mtimeMs;(c.size!==u.size||l>u.mtimeMs||l===0)&&Ue(a.listeners,d=>d(n,c))})},je.set(e,a)),()=>{U(a,H,r),U(a,N,i),Ct(a.listeners)&&(je.delete(e),(0,O.unwatchFile)(e),a.options=a.watcher=void 0,Object.freeze(a))}},se=class{constructor(e){this.fsw=e,this._boundHandleError=t=>e._handleError(t)}_watchWithNodeFs(e,t){let s=this.fsw.options,r=g.dirname(e),i=g.basename(e);this.fsw._getWatchedDir(r).add(i);let o=g.resolve(e),c={persistent:s.persistent};t||(t=ie);let u;if(s.usePolling){let l=s.interval!==s.binaryInterval;c.interval=l&&Dn(i)?s.binaryInterval:s.interval,u=Hn(e,o,c,{listener:t,rawEmitter:this.fsw._emitRaw})}else u=Fn(e,o,c,{listener:t,errHandler:this._boundHandleError,rawEmitter:this.fsw._emitRaw});return u}_handleFile(e,t,s){if(this.fsw.closed)return;let r=g.dirname(e),i=g.basename(e),a=this.fsw._getWatchedDir(r),o=t;if(a.has(i))return;let c=async(l,d)=>{if(this.fsw._throttle(Ln,e,5)){if(!d||d.mtimeMs===0)try{let f=await(0,x.stat)(e);if(this.fsw.closed)return;let h=f.atimeMs,S=f.mtimeMs;if((!h||h<=S||S!==o.mtimeMs)&&this.fsw._emit(L.CHANGE,e,f),(vn||Rn||bn)&&o.ino!==f.ino){this.fsw._closeFile(l),o=f;let P=this._watchWithNodeFs(e,c);P&&this.fsw._addPathCloser(l,P)}else o=f}catch{this.fsw._remove(r,i)}else if(a.has(i)){let f=d.atimeMs,h=d.mtimeMs;(!f||f<=h||h!==o.mtimeMs)&&this.fsw._emit(L.CHANGE,e,d),o=d}}},u=this._watchWithNodeFs(e,c);if(!(s&&this.fsw.options.ignoreInitial)&&this.fsw._isntIgnored(e)){if(!this.fsw._throttle(L.ADD,e,0))return;this.fsw._emit(L.ADD,e,t)}return u}async _handleSymlink(e,t,s,r){if(this.fsw.closed)return;let i=e.fullPath,a=this.fsw._getWatchedDir(t);if(!this.fsw.options.followSymlinks){this.fsw._incrReadyCount();let o;try{o=await(0,x.realpath)(s)}catch{return this.fsw._emitReady(),!0}return this.fsw.closed?void 0:(a.has(r)?this.fsw._symlinkPaths.get(i)!==o&&(this.fsw._symlinkPaths.set(i,o),this.fsw._emit(L.CHANGE,s,e.stats)):(a.add(r),this.fsw._symlinkPaths.set(i,o),this.fsw._emit(L.ADD,s,e.stats)),this.fsw._emitReady(),!0)}if(this.fsw._symlinkPaths.has(i))return!0;this.fsw._symlinkPaths.set(i,!0)}_handleRead(e,t,s,r,i,a,o){if(e=g.join(e,""),o=this.fsw._throttle("readdir",e,1e3),!o)return;let c=this.fsw._getWatchedDir(s.path),u=new Set,l=this.fsw._readdirp(e,{fileFilter:d=>s.filterPath(d),directoryFilter:d=>s.filterDir(d)});if(l)return l.on(Pn,async d=>{if(this.fsw.closed){l=void 0;return}let f=d.path,h=g.join(e,f);if(u.add(f),!(d.stats.isSymbolicLink()&&await this._handleSymlink(d,e,h,f))){if(this.fsw.closed){l=void 0;return}(f===r||!r&&!c.has(f))&&(this.fsw._incrReadyCount(),h=g.join(i,g.relative(i,h)),this._addToNodeFs(h,t,s,a+1))}}).on(L.ERROR,this._boundHandleError),new Promise((d,f)=>{if(!l)return f();l.once(Ye,()=>{if(this.fsw.closed){l=void 0;return}let h=o?o.clear():!1;d(void 0),c.getChildren().filter(S=>S!==e&&!u.has(S)).forEach(S=>{this.fsw._remove(e,S)}),l=void 0,h&&this._handleRead(e,!1,s,r,i,a,o)})})}async _handleDir(e,t,s,r,i,a,o){let c=this.fsw._getWatchedDir(g.dirname(e)),u=c.has(g.basename(e));!(s&&this.fsw.options.ignoreInitial)&&!i&&!u&&this.fsw._emit(L.ADD_DIR,e,t),c.add(g.basename(e)),this.fsw._getWatchedDir(e);let l,d,f=this.fsw.options.depth;if((f==null||r<=f)&&!this.fsw._symlinkPaths.has(o)){if(!i&&(await this._handleRead(e,s,a,i,e,r,l),this.fsw.closed))return;d=this._watchWithNodeFs(e,(h,S)=>{S&&S.mtimeMs===0||this._handleRead(h,!1,a,i,e,r,l)})}return d}async _addToNodeFs(e,t,s,r,i){let a=this.fsw._emitReady;if(this.fsw._isIgnored(e)||this.fsw.closed)return a(),!1;let o=this.fsw._getWatchHelpers(e);s&&(o.filterPath=c=>s.filterPath(c),o.filterDir=c=>s.filterDir(c));try{let c=await xn[o.statMethod](o.watchPath);if(this.fsw.closed)return;if(this.fsw._isIgnored(o.watchPath,c))return a(),!1;let u=this.fsw.options.followSymlinks,l;if(c.isDirectory()){let d=g.resolve(e),f=u?await(0,x.realpath)(e):e;if(this.fsw.closed||(l=await this._handleDir(o.watchPath,c,t,r,i,o,f),this.fsw.closed))return;d!==f&&f!==void 0&&this.fsw._symlinkPaths.set(d,f)}else if(c.isSymbolicLink()){let d=u?await(0,x.realpath)(e):e;if(this.fsw.closed)return;let f=g.dirname(o.watchPath);if(this.fsw._getWatchedDir(f).add(o.watchPath),this.fsw._emit(L.ADD,o.watchPath,c),l=await this._handleDir(f,c,t,r,e,o,d),this.fsw.closed)return;d!==void 0&&this.fsw._symlinkPaths.set(g.resolve(e),d)}else l=this._handleFile(o.watchPath,c,t);return a(),l&&this.fsw._addPathCloser(e,l),!1}catch(c){if(this.fsw._handleError(c))return a(),e}}}});var Ut={};Je(Ut,{FSWatcher:()=>Y,WatchHelper:()=>ce,default:()=>Gn,watch:()=>jt});function ae(n){return Array.isArray(n)?n:[n]}function $n(n){return typeof n=="function"?n:typeof n=="string"?e=>n===e:n instanceof RegExp?e=>n.test(e):typeof n=="object"&&n!==null?e=>{if(n.path===e)return!0;if(n.recursive){let t=m.relative(n.path,e);return t?!t.startsWith("..")&&!m.isAbsolute(t):!1}return!1}:()=>!1}function qn(n){if(typeof n!="string")throw new Error("string expected");n=m.normalize(n),n=n.replace(/\\/g,"/");let e=!1;n.startsWith("//")&&(e=!0);let t=/\/\//;for(;n.match(t);)n=n.replace(t,"/");return e&&(n="/"+n),n}function Ot(n,e,t){let s=qn(e);for(let r=0;r<n.length;r++){let i=n[r];if(i(s,t))return!0}return!1}function jn(n,e){if(n==null)throw new TypeError("anymatch: specify first argument");let s=ae(n).map(r=>$n(r));return e==null?(r,i)=>Ot(s,r,i):Ot(s,e)}function jt(n,e={}){let t=new Y(e);return t.add(n),t}var zt,le,Wt,m,Be,On,$t,In,kn,Nn,Ht,zn,Wn,Ge,It,kt,qt,Nt,Un,Yn,Ve,Kn,Bn,ce,Y,Gn,Yt=de(()=>{"use strict";zt=require("fs"),le=require("fs/promises"),Wt=require("events"),m=v(require("path"),1);Lt();Ft();Be="/",On="//",$t=".",In="..",kn="string",Nn=/\\/g,Ht=/\/\//,zn=/\..*\.(sw[px])$|~$|\.subl.*\.tmp/,Wn=/^\.[/\\]/;Ge=n=>typeof n=="object"&&n!==null&&!(n instanceof RegExp);It=n=>{let e=ae(n).flat();if(!e.every(t=>typeof t===kn))throw new TypeError(`Non-string provided as watch path: ${e}`);return e.map(qt)},kt=n=>{let e=n.replace(Nn,Be),t=!1;for(e.startsWith(On)&&(t=!0);e.match(Ht);)e=e.replace(Ht,Be);return t&&(e=Be+e),e},qt=n=>kt(m.normalize(kt(n))),Nt=(n="")=>e=>typeof e=="string"?qt(m.isAbsolute(e)?e:m.join(n,e)):e,Un=(n,e)=>m.isAbsolute(n)?n:m.join(e,n),Yn=Object.freeze(new Set),Ve=class{constructor(e,t){this.path=e,this._removeWatcher=t,this.items=new Set}add(e){let{items:t}=this;t&&e!==$t&&e!==In&&t.add(e)}async remove(e){let{items:t}=this;if(!t||(t.delete(e),t.size>0))return;let s=this.path;try{await(0,le.readdir)(s)}catch{this._removeWatcher&&this._removeWatcher(m.dirname(s),m.basename(s))}}has(e){let{items:t}=this;if(t)return t.has(e)}getChildren(){let{items:e}=this;return e?[...e.values()]:[]}dispose(){this.items.clear(),this.path="",this._removeWatcher=ie,this.items=Yn,Object.freeze(this)}},Kn="stat",Bn="lstat",ce=class{constructor(e,t,s){this.fsw=s;let r=e;this.path=e=e.replace(Wn,""),this.watchPath=r,this.fullWatchPath=m.resolve(r),this.dirParts=[],this.dirParts.forEach(i=>{i.length>1&&i.pop()}),this.followSymlinks=t,this.statMethod=t?Kn:Bn}entryPath(e){return m.join(this.watchPath,m.relative(this.watchPath,e.fullPath))}filterPath(e){let{stats:t}=e;if(t&&t.isSymbolicLink())return this.filterDir(e);let s=this.entryPath(e);return this.fsw._isntIgnored(s,t)&&this.fsw._hasReadPermissions(t)}filterDir(e){return this.fsw._isntIgnored(this.entryPath(e),e.stats)}},Y=class extends Wt.EventEmitter{constructor(e={}){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 t=e.awaitWriteFinish,s={stabilityThreshold:2e3,pollInterval:100},r={persistent:!0,ignoreInitial:!1,ignorePermissionErrors:!1,interval:100,binaryInterval:300,followSymlinks:!0,usePolling:!1,atomic:!0,...e,ignored:e.ignored?ae(e.ignored):ae([]),awaitWriteFinish:t===!0?s:typeof t=="object"?{...s,...t}:!1};Dt&&(r.usePolling=!0),r.atomic===void 0&&(r.atomic=!r.usePolling);let i=process.env.CHOKIDAR_USEPOLLING;if(i!==void 0){let c=i.toLowerCase();c==="false"||c==="0"?r.usePolling=!1:c==="true"||c==="1"?r.usePolling=!0:r.usePolling=!!c}let a=process.env.CHOKIDAR_INTERVAL;a&&(r.interval=Number.parseInt(a,10));let o=0;this._emitReady=()=>{o++,o>=this._readyCount&&(this._emitReady=ie,this._readyEmitted=!0,process.nextTick(()=>this.emit(w.READY)))},this._emitRaw=(...c)=>this.emit(w.RAW,...c),this._boundRemove=this._remove.bind(this),this.options=r,this._nodeFsHandler=new se(this),Object.freeze(r)}_addIgnoredPath(e){if(Ge(e)){for(let t of this._ignoredPaths)if(Ge(t)&&t.path===e.path&&t.recursive===e.recursive)return}this._ignoredPaths.add(e)}_removeIgnoredPath(e){if(this._ignoredPaths.delete(e),typeof e=="string")for(let t of this._ignoredPaths)Ge(t)&&t.path===e&&this._ignoredPaths.delete(t)}add(e,t,s){let{cwd:r}=this.options;this.closed=!1,this._closePromise=void 0;let i=It(e);return r&&(i=i.map(a=>Un(a,r))),i.forEach(a=>{this._removeIgnoredPath(a)}),this._userIgnored=void 0,this._readyCount||(this._readyCount=0),this._readyCount+=i.length,Promise.all(i.map(async a=>{let o=await this._nodeFsHandler._addToNodeFs(a,!s,void 0,0,t);return o&&this._emitReady(),o})).then(a=>{this.closed||a.forEach(o=>{o&&this.add(m.dirname(o),m.basename(t||o))})}),this}unwatch(e){if(this.closed)return this;let t=It(e),{cwd:s}=this.options;return t.forEach(r=>{!m.isAbsolute(r)&&!this._closers.has(r)&&(s&&(r=m.join(s,r)),r=m.resolve(r)),this._closePath(r),this._addIgnoredPath(r),this._watched.has(r)&&this._addIgnoredPath({path:r,recursive:!0}),this._userIgnored=void 0}),this}close(){if(this._closePromise)return this._closePromise;this.closed=!0,this.removeAllListeners();let e=[];return this._closers.forEach(t=>t.forEach(s=>{let r=s();r instanceof Promise&&e.push(r)})),this._streams.forEach(t=>t.destroy()),this._userIgnored=void 0,this._readyCount=0,this._readyEmitted=!1,this._watched.forEach(t=>t.dispose()),this._closers.clear(),this._watched.clear(),this._streams.clear(),this._symlinkPaths.clear(),this._throttled.clear(),this._closePromise=e.length?Promise.all(e).then(()=>{}):Promise.resolve(),this._closePromise}getWatched(){let e={};return this._watched.forEach((t,s)=>{let i=(this.options.cwd?m.relative(this.options.cwd,s):s)||$t;e[i]=t.getChildren().sort()}),e}emitWithAll(e,t){this.emit(e,...t),e!==w.ERROR&&this.emit(w.ALL,e,...t)}async _emit(e,t,s){if(this.closed)return;let r=this.options;Ke&&(t=m.normalize(t)),r.cwd&&(t=m.relative(r.cwd,t));let i=[t];s!=null&&i.push(s);let a=r.awaitWriteFinish,o;if(a&&(o=this._pendingWrites.get(t)))return o.lastChange=new Date,this;if(r.atomic){if(e===w.UNLINK)return this._pendingUnlinks.set(t,[e,...i]),setTimeout(()=>{this._pendingUnlinks.forEach((c,u)=>{this.emit(...c),this.emit(w.ALL,...c),this._pendingUnlinks.delete(u)})},typeof r.atomic=="number"?r.atomic:100),this;e===w.ADD&&this._pendingUnlinks.has(t)&&(e=w.CHANGE,this._pendingUnlinks.delete(t))}if(a&&(e===w.ADD||e===w.CHANGE)&&this._readyEmitted){let c=(u,l)=>{u?(e=w.ERROR,i[0]=u,this.emitWithAll(e,i)):l&&(i.length>1?i[1]=l:i.push(l),this.emitWithAll(e,i))};return this._awaitWriteFinish(t,a.stabilityThreshold,e,c),this}if(e===w.CHANGE&&!this._throttle(w.CHANGE,t,50))return this;if(r.alwaysStat&&s===void 0&&(e===w.ADD||e===w.ADD_DIR||e===w.CHANGE)){let c=r.cwd?m.join(r.cwd,t):t,u;try{u=await(0,le.stat)(c)}catch{}if(!u||this.closed)return;i.push(u)}return this.emitWithAll(e,i),this}_handleError(e){let t=e&&e.code;return e&&t!=="ENOENT"&&t!=="ENOTDIR"&&(!this.options.ignorePermissionErrors||t!=="EPERM"&&t!=="EACCES")&&this.emit(w.ERROR,e),e||this.closed}_throttle(e,t,s){this._throttled.has(e)||this._throttled.set(e,new Map);let r=this._throttled.get(e);if(!r)throw new Error("invalid throttle");let i=r.get(t);if(i)return i.count++,!1;let a,o=()=>{let u=r.get(t),l=u?u.count:0;return r.delete(t),clearTimeout(a),u&&clearTimeout(u.timeoutObject),l};a=setTimeout(o,s);let c={timeoutObject:a,clear:o,count:0};return r.set(t,c),c}_incrReadyCount(){return this._readyCount++}_awaitWriteFinish(e,t,s,r){let i=this.options.awaitWriteFinish;if(typeof i!="object")return;let a=i.pollInterval,o,c=e;this.options.cwd&&!m.isAbsolute(e)&&(c=m.join(this.options.cwd,e));let u=new Date,l=this._pendingWrites;function d(f){(0,zt.stat)(c,(h,S)=>{if(h||!l.has(e)){h&&h.code!=="ENOENT"&&r(h);return}let P=Number(new Date);f&&S.size!==f.size&&(l.get(e).lastChange=P);let E=l.get(e);P-E.lastChange>=t?(l.delete(e),r(void 0,S)):o=setTimeout(d,a,S)})}l.has(e)||(l.set(e,{lastChange:u,cancelWait:()=>(l.delete(e),clearTimeout(o),s)}),o=setTimeout(d,a))}_isIgnored(e,t){if(this.options.atomic&&zn.test(e))return!0;if(!this._userIgnored){let{cwd:s}=this.options,i=(this.options.ignored||[]).map(Nt(s)),o=[...[...this._ignoredPaths].map(Nt(s)),...i];this._userIgnored=jn(o,void 0)}return this._userIgnored(e,t)}_isntIgnored(e,t){return!this._isIgnored(e,t)}_getWatchHelpers(e){return new ce(e,this.options.followSymlinks,this)}_getWatchedDir(e){let t=m.resolve(e);return this._watched.has(t)||this._watched.set(t,new Ve(t,this._boundRemove)),this._watched.get(t)}_hasReadPermissions(e){return this.options.ignorePermissionErrors?!0:!!(Number(e.mode)&256)}_remove(e,t,s){let r=m.join(e,t),i=m.resolve(r);if(s=s??(this._watched.has(r)||this._watched.has(i)),!this._throttle("remove",r,100))return;!s&&this._watched.size===1&&this.add(e,t,!0),this._getWatchedDir(r).getChildren().forEach(f=>this._remove(r,f));let c=this._getWatchedDir(e),u=c.has(t);c.remove(t),this._symlinkPaths.has(i)&&this._symlinkPaths.delete(i);let l=r;if(this.options.cwd&&(l=m.relative(this.options.cwd,r)),this.options.awaitWriteFinish&&this._pendingWrites.has(l)&&this._pendingWrites.get(l).cancelWait()===w.ADD)return;this._watched.delete(r),this._watched.delete(i);let d=s?w.UNLINK_DIR:w.UNLINK;u&&!this._isIgnored(r)&&this._emit(d,r),this._closePath(r)}_closePath(e){this._closeFile(e);let t=m.dirname(e);this._getWatchedDir(t).remove(m.basename(e))}_closeFile(e){let t=this._closers.get(e);t&&(t.forEach(s=>s()),this._closers.delete(e))}_addPathCloser(e,t){if(!t)return;let s=this._closers.get(e);s||(s=[],this._closers.set(e,s)),s.push(t)}_readdirp(e,t){if(this.closed)return;let s={type:w.ALL,alwaysStat:!0,lstat:!0,...t,depth:0},r=bt(e,s);return this._streams.add(r),r.once(At,()=>{r=void 0}),r.once(Ye,()=>{r&&(this._streams.delete(r),r=void 0)}),r}};Gn={watch:jt,FSWatcher:Y}});var Vn={};Je(Vn,{TSFilebasedRouter:()=>Kt,TSRouter:()=>ee,createClientFunc:()=>rt,createSignal:()=>ke,createTSServerFunc:()=>nt,html:()=>he,initializeRoute:()=>Bt,loadPyFiles:()=>Ce,mapper:()=>tt,renderChildRoutes:()=>Ae,useAnchor:()=>$,useAnchorSingle:()=>ve,useInitialDOM:()=>_e,useTSAuth:()=>Le,useTSCollection:()=>be,useTSComponent:()=>W,useTSElementEach:()=>X,useTSElements:()=>Te,useTSEvent:()=>ge,useTSEventAll:()=>we,useTSExtractParams:()=>ye,useTSLazy:()=>Fe,useTSMetaData:()=>Re,useTSNavigate:()=>xe,useTSNoReload:()=>Ie,useTSOutlet:()=>Me,useTSParams:()=>z,useTSPurifier:()=>pe,useTSQuery:()=>Z,useTSReactor:()=>Ne,useTSSSRHydration:()=>He,useTSSelect:()=>k,useTSloadBrython:()=>De});module.exports=tn(Vn);var et=v(require("dompurify"),1),fe=null;function nn(){return typeof window>"u"?null:(fe||(fe=(0,et.default)(window)),fe)}var rn=["div","span","p","a","button","ul","li","img","input","form","label","h1","h2","h3","h4","h5","h6","section","main","article","svg","path","circle","rect","line","polyline","polygon","g"],sn=["class","id","href","src","alt","title","type","value","name","placeholder","target","rel","data-click","data-change","data-select","data-effect","data-hover","data-submit","data-key","data-event","data-component","data-stagger","data-input"];function on(n){return/^(https?:\/\/|\/|#)/i.test(n.trim())}function an(n){if(typeof window>"u")return n;let e=document.createElement("template");return e.innerHTML=n,e.content.querySelectorAll("*").forEach(t=>{[...t.attributes].forEach(s=>{let r=s.name.toLowerCase();if(r.startsWith("on")||r.startsWith("xlink")||r.startsWith("xml")){t.removeAttribute(s.name);return}(r==="href"||r==="src")&&!on(s.value)&&t.setAttribute(r,"#")}),t.tagName==="A"&&t.getAttribute("target")==="_blank"&&t.setAttribute("rel","noopener noreferrer")}),e.innerHTML}function he(n,...e){let t=nn(),s=n.reduce((i,a,o)=>{let c=o<e.length?String(e[o]??""):"";return i+a+c},"");if(!t)return s;let r=t.sanitize(s,{ALLOWED_TAGS:rn,ALLOWED_ATTR:sn,RETURN_DOM:!1});return an(r)}var tt=(n,e)=>n.reduce((t,s,r)=>t+e(s,r),"");function nt(n){return n}function rt(n){return new Proxy({},{get(e,t){return async s=>n(t,s)}})}var me=v(require("dompurify"),1),pe=(n,e)=>{let s={...{ADD_TAGS:["my-custom-tag"]},...e};return typeof n=="string"?me.default.sanitize(n,s):me.default.sanitize(n.innerHTML,s)};var ge=(n,e,t)=>{if(!(typeof window>"u"||typeof document>"u"))if(typeof n=="string"){let s=document.getElementById(n);s?s.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.")};var st=require("zustand/vanilla"),it=v(require("dompurify"),1);function V(n){return it.default.sanitize(n??"")}function G(n,e){let t=Object.keys(n),s=Object.keys(e);if(t.length!==s.length)return!1;for(let r of t)if(n[r]!==e[r])return!1;return!0}function cn(n,e){let t=[],s=n.replace(/:[^/]+/g,o=>(t.push(o.slice(1)),"([^/]+)")),r=new RegExp(`^${s}$`),i=e.match(r),a={};return i&&t.forEach((o,c)=>{a[o]=V(i[c+1]??"")}),a}function ln(n){let e={},t=new URLSearchParams(n);for(let[s,r]of t.entries())e[s]=V(r);return e}var z=(0,st.createStore)((n,e)=>({params:{},query:{},setFromPattern:t=>{let s=window.location.pathname,r=cn(t,s),i=ln(window.location.search),a=e();(!G(a.params,r)||!G(a.query,i))&&n({params:r,query:i})},setFromPatternValues:(t,s)=>{let r={};t.forEach((a,o)=>{r[a]=V(s[o]??"")});let i=e();G(i.params,r)||n({params:r})},setQuery:t=>{let s={};for(let i in t)s[i]=V(t[i]);let r=e();G(r.query,s)||n({query:s})},getParam:t=>e().params[t],getQuery:t=>e().query[t]}));function ye(n){let e=z.getState();e.setFromPattern(n);let t=e.params,s=e.query;return{...t,...s}}var we=(n,e,t)=>{let s=document.querySelectorAll(n);return s.forEach(r=>{r.addEventListener(e,t)}),()=>{s.forEach(r=>{r.removeEventListener(e,t)})}};var ut=require("motion"),dt=v(require("dompurify"),1),Ee=typeof window<"u"&&typeof document<"u",ot=["div","span","p","a","button","ul","li","img","input","form","label","h1","h2","h3","h4","h5","h6","section","main","article"],at=["class","id","href","src","alt","title","type","value","name","placeholder","data-click","data-change","data-select","data-effect","data-hover","data-submit","data-key","data-event","data-component","data-stagger","data-input","data-children","data-slot","target","rel"],ct=Ee?(0,dt.default)(window):{sanitize:(n,e)=>n};function un(n){return/^(https?:\/\/|\/|#)/i.test(n.trim())}function dn(n){Ee&&n.querySelectorAll("*").forEach(e=>{[...e.attributes].forEach(t=>{let s=t.name.toLowerCase();if(s.startsWith("on")){e.removeAttribute(t.name);return}(s==="href"||s==="src")&&!un(t.value)&&e.setAttribute(s,"#")}),e.tagName==="A"&&e.getAttribute("target")==="_blank"&&e.setAttribute("rel","noopener noreferrer")})}function lt(n){let e={},t={},s=400,r=0,i="ease-in-out",a=0,o=!1,c,u;return n.split(/\s+/).forEach(l=>{l==="fade-in"&&(e.opacity=0,t.opacity=1),l==="fade-out"&&(e.opacity=1,t.opacity=0),l==="slide-up"&&(e.y=20,t.y=0),l==="slide-down"&&(e.y=-20,t.y=0),l==="slide-left"&&(e.x=20,t.x=0),l==="slide-right"&&(e.x=-20,t.x=0),l.startsWith("duration-")&&(s=+l.replace("duration-","")),l.startsWith("delay-")&&(r=+l.replace("delay-","")),(l==="linear"||l.startsWith("ease"))&&(i=l),l==="infinite"&&(a=1/0),l==="replay"&&(o=!0),l.startsWith("parallax-y-")&&(c=+l.replace("parallax-y-","")),l.startsWith("parallax-x-")&&(u=+l.replace("parallax-x-",""))}),{from:e,to:t,duration:s,easing:i,delay:r,repeat:a,replay:o,parallaxY:c,parallaxX:u}}function fn(n,e){n.querySelectorAll("[data-component]").forEach(t=>{let s=t.dataset.component;e[s]?.(t)})}var Te=(n,e,t={},s)=>{if(!Ee||!n)return{html:ct.sanitize(e,{ALLOWED_TAGS:ot,ALLOWED_ATTR:at,...s})};let r=ct.sanitize(e,{ALLOWED_TAGS:ot,ALLOWED_ATTR:at,...s});n.innerHTML=r,dn(n);let i=l=>{let d=l.target.closest("[data-click]");d&&t[d.dataset.click]?.(d)};n.addEventListener("click",i),n.querySelectorAll("[data-input]").forEach(l=>{let d=l.dataset.input;t[d]?.(l),l.addEventListener("input",()=>{t[d]?.(l)})}),fn(n,t);let a=[];n.querySelectorAll("[data-effect]").forEach(l=>{let d=lt(l.dataset.effect||"");(d.parallaxX||d.parallaxY)&&a.push({el:l,...d})});let o=!1,c=()=>{o||(o=!0,requestAnimationFrame(()=>{let l=window.scrollY;a.forEach(({el:d,parallaxX:f,parallaxY:h})=>{d.style.transform=`translate3d(${(f||0)*l}px, ${(h||0)*l}px, 0)`}),o=!1}))};window.addEventListener("scroll",c);let u=new IntersectionObserver(l=>{l.forEach(d=>{let f=d.target,h=lt(f.dataset.effect||"");d.isIntersecting?(Object.assign(f.style,h.from),setTimeout(()=>{(0,ut.animate)(f,h.to,{duration:h.duration/1e3,easing:h.easing,repeat:h.repeat})},h.delay),h.replay||u.unobserve(f)):h.replay&&Object.assign(f.style,h.from)})});return n.querySelectorAll("[data-effect]").forEach(l=>u.observe(l)),{cleanup(){u.disconnect(),window.removeEventListener("scroll",c),n.removeEventListener("click",i)}}};var Se=v(require("dompurify"),1),Q=null,_e=(n,e)=>{if(typeof document>"u")return;let t=document.getElementById(n);if(!t)return;Se.default.addHook("uponSanitizeAttribute",(a,o)=>{let c=(o.attrName||"").toLowerCase(),u=(o.attrValue??"").toString().trim();if(c.startsWith("on")){o.keepAttr=!1;return}if((c==="href"||c==="src")&&/^(javascript:|vbscript:|data:|file:|about:)/i.test(u)){o.keepAttr=!1;return}if(c==="class"){let d=u.split(/\s+/).filter(Boolean).filter(f=>{if(/^[a-zA-Z0-9\-\:\/_\[\]\(\)]+$/.test(f)){if(/^bg-\[url\(.*\)\]$/.test(f)){let h=f.replace(/^bg-\[url\(/,"").replace(/\)\]$/,"").replace(/^['"]|['"]$/g,"");return h===""||/^https?:\/\//i.test(h)||/^\/(?!\/)/.test(h)||/^\.{0,2}\//.test(h)}return!0}return!1});o.attrValue=d.join(" ");return}if(c==="style"){o.keepAttr=!1;return}});let s=t.cloneNode(!0),r=Se.default.sanitize(s.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(r.childNodes).map(a=>a.outerHTML||a.textContent||"").join("");if(Q!==null&&i!==Q){let a=document.createElement("div");e(a);let c=new DOMParser().parseFromString(Q,"text/html");for(;t.firstChild;)t.removeChild(t.firstChild);c.body.childNodes.forEach(u=>t.appendChild(u.cloneNode(!0)))}else{for(Q=i;t.firstChild;)t.removeChild(t.firstChild);t.appendChild(r),e(t)}};var Pe=v(require("dompurify"),1);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 ve=(n,e,t,s="",r=null)=>{if(!n)return;let i=Pe.default.sanitize(e,{ALLOWED_URI_REGEXP:/^(https?:|\/)/}),a=Pe.default.sanitize(t,{USE_PROFILES:{html:!1}});n.setAttribute("href",i),n.setAttribute("aria-label",a),s&&(n.className=s.trim()),r&&n.replaceChildren(r),typeof window<"u"&&n.addEventListener("click",o=>{o.preventDefault();let u=o.currentTarget.getAttribute("href");if(u){let l=window.scrollY;window.scrollTo(0,0),window.history.pushState({scrollPosition:l},"",u),dispatchEvent(new PopStateEvent("popstate"))}})};var M=v(require("dompurify"),1);var ft=(n="'self' 'nonce-rAnd0m123' 'unsafe-inline' 'unsafe-eval'",e="'self' 'nonce-rAnd0m123'",t="'none'",s="'self' https://fonts.googleapis.com https://fonts.gstatic.com",r="'self' https://blogger.googleusercontent.com",i=["'self'","https://fonts.googleapis.com","https://fonts.gstatic.com","https://www.google.com/maps/"],a="'self' https://www.youtube.com",o="'self'",c="/csp-report",u=!1)=>{let l=()=>{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 f=u?`report-uri ${c};`:"";d.setAttribute("content",`default-src 'self'; script-src ${n}; style-src ${e}; object-src ${t}; font-src ${s}; img-src ${r}; connect-src ${i.join(" ")}; frame-src ${a}; base-uri ${o}; ${f}`)}catch(d){console.error("Error adding CSP meta element:",d)}};document.readyState==="loading"?document.addEventListener("DOMContentLoaded",l):l()};var Re=(n,e)=>{let t={name:M.default.sanitize(n.name||""),title:M.default.sanitize(n.title||""),description:M.default.sanitize(n.description||"Default description"),author:M.default.sanitize(n.author||""),favicon:n.favicon},s=p=>{t.name=M.default.sanitize(p),P("name",t.name)},r=p=>{t.title=M.default.sanitize(p),document.title=t.title},i=p=>{t.description=M.default.sanitize(p),P("description",t.description)},a=p=>{t.author=M.default.sanitize(p),P("author",t.author)},o=p=>{t.favicon=M.default.sanitize(p);let T=document.querySelector('link[rel="icon"]');T||(T=document.createElement("link"),T.rel="icon",document.head.appendChild(T)),T.href=t.favicon},c=()=>t.name,u=()=>t.title,l=()=>t.description,d=()=>t.author,f=()=>t.favicon,h=()=>t,S=(p,T)=>{let R=document.createElement("meta");R.setAttribute("name",p),R.setAttribute("content",T),document.head.appendChild(R)},P=(p,T)=>{let R=document.querySelector(`meta[name="${p}"]`);R?R.setAttribute("content",T):S(p,T)},E=()=>{t.title&&(document.title=t.title),t.name&&P("name",t.name),t.description&&P("description",t.description),t.author&&P("author",t.author),t.favicon&&o(t.favicon)};return e&&ft(e.scriptSrc,e.styleSrc,e.objectSrc,Array.isArray(e.connectSrc)?e.connectSrc.join(" "):e.connectSrc,e.reportOnly!==void 0?String(e.reportOnly):void 0),E(),{setName:s,setTitle:r,setDescription:i,setAuthor:a,setFavicon:o,getName:c,getTitle:u,getDescription:l,getAuthor:d,getFavicon:f,getAllMetaData:h,appendMetaTagsToHead:E}};var ht=v(require("dompurify"),1),W=(n,e,t,s,r)=>{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 o=a[0];o.innerHTML=ht.default.sanitize(o.innerHTML,{USE_PROFILES:{html:!0}}),t(o,s,r)};var be=(n,e,t,s=[])=>{let r=new Set;n.forEach((i,a)=>{if(r.has(i)){console.warn(`[useTSCollection] Duplicate ID in collection array: "${i}" \u2014 skipping.`);return}r.add(i);let o=e.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=t[a],u=Array.isArray(s)?s[a]:void 0;typeof c=="function"?W(i,e,c,u):console.warn(`[useTSCollection] No valid component function found for ID: "${i}"`)})};var k=(n,e)=>{let s=(e??document).querySelectorAll(n);if(s.length===0)return process.env.NODE_ENV!=="production"&&console.warn(`[useTSSelect] No element found for selector: '${n}'`),null;if(n.startsWith("#")&&s.length>1){if(process.env.NODE_ENV!=="production")throw new Error(`[useTSSelect] Duplicate ID detected: '${n}'. Found ${s.length} elements with this ID.`);return s[0]}return s.length>1&&process.env.NODE_ENV!=="production"&&console.warn(`[useTSSelect] Multiple elements found for selector: '${n}'. Returning the first one.`),s[0]};var mt=require("jwt-decode"),Le=(n,e)=>{let t=localStorage.getItem("token");if(!t)return window.location.href=e,null;try{let s=(0,mt.jwtDecode)(t),r=Date.now()/1e3;return s.exp&&s.exp<r&&(console.error("Token has expired"),window.localStorage.removeItem("token"),window.location.href=e),null}catch(s){return console.error("Invalid token:",s),window.location.href=e,null}};var X=(n,e,t)=>{n.forEach(s=>{e.forEach(r=>{s.addEventListener(r,i=>{t(s,i)})})})};var xe=()=>({back:()=>window.history.back(),forward:()=>window.history.forward()});var Me=(n,e)=>{let t=document.querySelector(`#${n}`)||document.querySelector(`.${n}`);if(!t)return;let s=window.location.pathname.replace(/\/$/,"");for(let r of e){let i=r.path.replace(/\/$/,"");if(s===i||s.startsWith(`${i}/`)){r.component(t);break}}};function Ae(n,e){let t=window.location.pathname.replace(/\/$/,"");e.routes.forEach(s=>{s.children?.length&&s.children.forEach(r=>{let i=r.path.replace(/\/$/,"");if(t===i||t.startsWith(`${i}/`)){let a=n.querySelector(`#${r.outlet}`)||n.querySelector(`.${r.outlet}`);a instanceof HTMLElement&&r.element&&r.element(a)}})})}var De=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=s=>new Promise((r,i)=>{let a=document.createElement("script");a.src=s,a.onload=()=>r(),a.onerror=()=>i(new Error(`Failed to load ${s}`)),document.head.appendChild(a)});await t(n),await t(e),typeof window.brython=="function"?window.brython():console.error("Brython did not load correctly.")},Ce=n=>new Promise((e,t)=>{let s=document.createElement("script");s.type="text/python",s.src=`/src/python/${n}`,s.onload=()=>e(),s.onerror=()=>t(new Error(`Failed to load ${n}`)),document.body.appendChild(s)});function Fe(n){let e=null;return async(t,s)=>{try{if(!e){let r=await n();e=r.default||r}if(typeof e=="function")return e(t,s);if(e instanceof HTMLElement){let r=e.cloneNode(!0);return t?.appendChild(r),r}if(typeof e=="object"&&e!==null&&"render"in e&&typeof e.render=="function")return e.render(t,s);console.warn("useTSLazy: Unsupported module type",e)}catch(r){console.error("useTSLazy failed:",r)}}}var He=n=>typeof window>"u"?{isDOM:null}:{isDOM:n||document.body};var pt=require("lodash-es"),Oe=n=>n;typeof window<"u"&&typeof document<"u"&&(Oe=n=>{let e=document.createElement("div");return e.innerText=n,e.innerHTML});var hn=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 s=t.getAttribute("class")||"";t.setAttribute("class",Oe(s));let r=t.getAttribute("aria-label");r&&t.setAttribute("aria-label",Oe(r));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",o=>{o.preventDefault();let c=t.getAttribute("href")||"";try{let u=new URL(c,window.location.href);window.history.pushState({},"",u.pathname+u.search+u.hash),window.dispatchEvent(new PopStateEvent("popstate"))}catch(u){console.error("Invalid URL in anchor:",c,u)}})}})},mn=(0,pt.debounce)(hn,50),$=n=>{mn(n)};var Ie=n=>{if(!n)return;let e=k("a",n);$(e)};var gt=n=>{let e=n,t=[];return[()=>e,a=>{e=typeof a=="function"?a(e):a,t.forEach(o=>o(e))},a=>{t.push(a),a(e)}]};function yt(n,e,t){let s=()=>{n.textContent=e().toString(),t?.(e())};s();let r=e.set;r&&(e.set=i=>{r(i),s()})}function ke(n){let[e,t,s]=gt(n),r=[],i=(()=>e());return i.set=a=>{t(a),r.forEach(o=>o(i()))},i.bind=a=>yt(a,i),i.subscribe=a=>{r.push(a),a(i())},i}function Ne(n,e){let t={deps:e.map(r=>typeof r=="function"?r():r)},s=n();typeof s=="function"&&(t.cleanup=s),e.forEach((r,i)=>{typeof r=="function"&&"bind"in r&&r.subscribe?.(()=>{let o=r(),c=t.deps[i];if(o!==c){t.cleanup?.(),t.deps[i]=o;let u=n();typeof u=="function"&&(t.cleanup=u)}})})}var y={params:{},query:{}},ze=new Set;function pn(){return{params:{...y.params},query:{...y.query}}}function q(n,e){let t=Object.keys(n),s=Object.keys(e);if(t.length!==s.length)return!1;for(let r of t)if(n[r]!==e[r])return!1;return!0}function F(){let n=pn();ze.forEach(e=>e(n))}function gn(n){let e={};if(!n)return e;let t=n.startsWith("?")?n.slice(1):n;for(let s of t.split("&")){if(!s)continue;let[r,i]=s.split("=");r&&(e[decodeURIComponent(r)]=decodeURIComponent(i||""))}return e}function yn(n){let e=new URLSearchParams;for(let s in n){let r=n[s];r!=null&&r!==""&&e.set(s,r)}let t=e.toString();return t?`?${t}`:""}function J(){if(typeof window>"u")return;let n=window.location.pathname,e=window.location.hash,t=yn(y.query);history.replaceState({},"",n+t+e)}var Z={getState(){return{params:y.params,query:y.query,getParam:n=>y.params[n],getQuery:n=>y.query[n],setFromPattern(n){if(typeof window>"u")return;let e=n.match(/:([^/]+)/g)?.map(r=>r.slice(1))||[],t=window.location.pathname.split("/").filter(Boolean),s={};e.forEach((r,i)=>{s[r]=t[i]}),q(y.params,s)||(y.params=s,F())},setFromPatternValues(n,e){let t={};n.forEach((s,r)=>{t[s]=e[r]}),q(y.params,t)||(y.params=t,F())},setQuery(n){let e={...y.query,...n};q(y.query,e)||(y.query=e,J(),F())},replaceQuery(n){q(y.query,n)||(y.query={...n},J(),F())},removeQuery(n){if(!(n in y.query))return;let e={...y.query};delete e[n],y.query=e,J(),F()},clearQuery(){Object.keys(y.query).length!==0&&(y.query={},J(),F())},setQueryFromURL(n){let e=gn(n);q(y.query,e)||(y.query=e,F())},subscribe(n){return ze.add(n),()=>ze.delete(n)}}}};typeof window<"u"&&window.addEventListener("popstate",()=>{Z.getState().setQueryFromURL(window.location.search)});var We=v(require("dompurify"),1);var Et=require("zustand/vanilla"),Tt=v(require("dompurify"),1),C=(0,Et.createStore)(n=>({params:{},query:{},setParams:e=>n(()=>({params:wt(e)})),setQuery:e=>n(()=>({query:wt(e)}))}));function wt(n){let e={};for(let t in n)e[t]=Tt.default.sanitize(n[t]);return e}var ee=class{routes=[];expectedParams;apiFetcher;constructor(e,t,s){this.routes=e,this.expectedParams=new Set(t),this.apiFetcher=s,window.addEventListener("popstate",this.handlePopState.bind(this)),this.handlePopState()}handlePopState(){let e=window.location.pathname,t=window.location.search,s=this.parseQueryParams(t);if(e.startsWith("/api")&&this.apiFetcher){let a=e.replace("/api/","").split("/")[0],o=Object.fromEntries(new URLSearchParams(t));this.apiFetcher(a,o).then(c=>console.log("API response:",c)).catch(c=>console.error("API error:",c));return}let r=this.findMatchingRoute(e,this.routes);if(r){if(r.routeto){this.navigate(r.routeto);return}let i=this.filterAndSanitizeParams(r.params);C.getState().setParams(i),C.getState().setQuery(s);let a=document.createElement("div");if(r.element?.(a,i,s),r.children){let o=e.slice(r.path.length),c=a.querySelector("#child");c&&this.renderChildren(r.children,o,c,i,s)}}else{let i=this.findMatchingRoute("*",this.routes);if(i){let a=this.filterAndSanitizeParams(i.params);C.getState().setParams(a),C.getState().setQuery(s);let o=document.createElement("div");i.element?.(o,a,s)}}}renderChildren(e,t,s,r,i){if(!e||e.length===0){let o=s.querySelector("#child");o&&o.remove();return}let a=this.findMatchingRoute(t,e);if(a){let o=document.createElement("div");o.id="child";let c={...r,...a.params},u=this.filterAndSanitizeParams(c);if(C.getState().setParams(u),C.getState().setQuery(i),a.element?.(o,u,i),s.appendChild(o),a.children){let l=t.slice(a.path.length);this.renderChildren(a.children,l,o,u,i)}}}parseQueryParams(e){let t={},s=new URLSearchParams(e);for(let[r,i]of s.entries())this.expectedParams.has(r)&&(t[r]=We.default.sanitize(i));return t}findMatchingRoute(e,t,s={}){for(let r of t){let i=r.path;if(i==="*")return r;{let o=[],c=i.replace(/:[^\s/]+/g,d=>(o.push(d.substring(1)),"([^\\s/]+)")),u=new RegExp(`^${c}(?:/|$)`),l=e.match(u);if(l){let d={...s};if(o.forEach((f,h)=>{d[f]=l[h+1]??""}),r.children){let f=e.slice(l[0].length),h=this.findMatchingRoute(f,r.children,d);if(h)return h}return{...r,params:d}}}}}filterAndSanitizeParams(e){if(!e)return{};let t={};for(let s in e)this.expectedParams.has(s)&&(t[s]=We.default.sanitize(e[s]??""));return t}navigate(e){history.pushState(null,"",e),this.handlePopState()}addRoute(e){this.routes.push(e)}};var Kt=()=>({name:"ts-filebased-router",async buildStart(){let n=await import("fs/promises"),e=await import("path"),t=await Promise.resolve().then(()=>(Yt(),Ut)),s=e.resolve("src/pages"),r=e.resolve("src/gen"),i=e.resolve("src/routes"),a=e.join(r,"tsrouter.gen.ts"),o=e.join(i,"__root.ts"),c=process.env.NODE_ENV!=="production",u=async E=>n.mkdir(E,{recursive:!0}).catch(()=>{}),l=E=>E.charAt(0).toUpperCase()+E.slice(1),d=E=>{let p="/"+e.relative(s,E).replace(/\\/g,"/");return p=p.replace(/\.ts$/,"").replace(/\/index$/,"")||"/",p.replace(/\[\.\.\.(.+?)\]/g,"*").replace(/\[(.+?)\]/g,":$1")},f=E=>E.replace(/^\//,"").split("/").map(p=>p.startsWith(":")?l(p.slice(1)):p.replace(/\b\w/g,T=>T.toUpperCase()).replace(/[-_]/g,"")).filter(Boolean).join("")||"Index",h=async E=>{let p=await n.readdir(E,{withFileTypes:!0}),T=[];for(let R of p){let I=e.join(E,R.name);R.isDirectory()?T.push(...await h(I)):R.isFile()&&R.name.endsWith(".ts")&&T.push({file:I,route:d(I),name:f(d(I))})}return T},S=async()=>{let E=await h(s),p=E.find(_=>_.route==="/notfound"),T=E.filter(_=>_.route!=="/notfound");for(let _ of E)if(!(await n.readFile(_.file,"utf-8")).trim()){let K=_.route.includes(":"),Xe=K?_.route.split("/").filter(ue=>ue.startsWith(":")).map(ue=>ue.slice(1)):[],Vt=K?`const { ${Xe.join(", ")} } = useTSExtractParams("${_.route}");`:"";await n.writeFile(_.file,`import { html, useTSElements, useTSMetaData${K?", useTSExtractParams":""} } from "@devwaren/vanilla-ts";
|
|
2
|
+
|
|
3
|
+
export default function ${_.name}(DOM: HTMLElement) {
|
|
4
|
+
useTSMetaData({
|
|
5
|
+
title: "${_.name.toLowerCase()}",
|
|
6
|
+
description: "${_.name.toLowerCase()}",
|
|
7
|
+
});
|
|
8
|
+
|
|
9
|
+
${Vt}
|
|
10
|
+
|
|
11
|
+
return useTSElements(DOM, html\`
|
|
12
|
+
<div>
|
|
13
|
+
<h1>${_.name.toLowerCase()}</h1>
|
|
14
|
+
${K?`<pre>\${${Xe.join("}, ${")}}</pre>`:""}
|
|
15
|
+
</div>
|
|
16
|
+
\`);
|
|
17
|
+
};
|
|
18
|
+
`,"utf-8")}let R=p?`export const NotFound = async (DOM: HTMLElement) => {
|
|
19
|
+
const mod = await import("../pages/${e.relative(s,p.file).replace(/\\/g,"/").replace(/\\.ts$/,"")}") as unknown as Module;
|
|
3
20
|
return mod.default(DOM);
|
|
4
|
-
};`:"export const NotFound = (DOM: HTMLElement) =>\n useTSElements(DOM, html`<h1>404 - Page Not Found</h1>`);",I=T.map(
|
|
5
|
-
`),
|
|
21
|
+
};`:"export const NotFound = (DOM: HTMLElement) =>\n useTSElements(DOM, html`<h1>404 - Page Not Found</h1>`);",I=T.map(_=>{let Qe="../pages/"+e.relative(s,_.file).replace(/\\/g,"/").replace(/\.ts$/,"");return`{ path: "${_.route}", name: "${_.name}", component: () => import("${Qe}") as unknown as Module }`}).join(`,
|
|
22
|
+
`),Gt=`// AUTO-GENERATED ROUTER
|
|
6
23
|
import { useTSElements, useTSParams, html } from "@devwaren/vanilla-ts";
|
|
7
|
-
import type { Module, Component } from "@devwaren/vanilla-ts";
|
|
8
24
|
|
|
9
25
|
// -----------------------------
|
|
10
|
-
|
|
26
|
+
// Types for all routes
|
|
27
|
+
// -----------------------------
|
|
28
|
+
type Cleanup = undefined | (() => void);
|
|
29
|
+
type RenderResult = Cleanup | Promise<Cleanup> | string;
|
|
30
|
+
type Component = (DOM: HTMLElement) => RenderResult;
|
|
31
|
+
type Module = { default: Component };
|
|
32
|
+
|
|
33
|
+
// -----------------------------
|
|
34
|
+
${R}
|
|
11
35
|
|
|
12
36
|
// -----------------------------
|
|
13
|
-
export const routeTree: { path: string; name: string; component: () => Promise<Module
|
|
37
|
+
export const routeTree: { path: string; name: string; component: () => Promise<Module> }[] = [
|
|
14
38
|
${I}
|
|
15
39
|
];
|
|
16
40
|
|
|
@@ -78,9 +102,7 @@ export async function createRouter(DOM: HTMLElement) {
|
|
|
78
102
|
useTSParams.getState().setFromPatternValues(Object.keys(params), Object.values(params));
|
|
79
103
|
|
|
80
104
|
const query: Record<string, string> = {};
|
|
81
|
-
url.searchParams.forEach((v, k) => {
|
|
82
|
-
query[k] = v; // \u2705 no return
|
|
83
|
-
});
|
|
105
|
+
url.searchParams.forEach((v, k) => { query[k] = v; });
|
|
84
106
|
useTSParams.getState().setQuery(query);
|
|
85
107
|
|
|
86
108
|
currentComponentUnmount?.();
|
|
@@ -91,7 +113,7 @@ export async function createRouter(DOM: HTMLElement) {
|
|
|
91
113
|
},
|
|
92
114
|
};
|
|
93
115
|
};
|
|
94
|
-
`;await u(r),await u(i),await n.writeFile(a,
|
|
116
|
+
`;await u(r),await u(i),await n.writeFile(a,Gt,"utf-8"),await n.writeFile(o,P(),"utf-8")},P=()=>`
|
|
95
117
|
import { createRouter } from "../gen/tsrouter.gen";
|
|
96
118
|
import { useTSParams, initializeRoute } from "@devwaren/vanilla-ts";
|
|
97
119
|
|
|
@@ -101,7 +123,7 @@ export const Router = async (DOM: HTMLElement) => {
|
|
|
101
123
|
await initializeRoute(router);
|
|
102
124
|
return router;
|
|
103
125
|
};
|
|
104
|
-
`;await u(s),await S(),c&&
|
|
126
|
+
`;await u(s),await S(),c&&t.watch(s,{ignoreInitial:!0}).on("all",async(p,T)=>{T.endsWith(".ts")&&(await S(),console.log("\u267B\uFE0F TS Router regenerated"))}),console.log("\u{1F7E2} TS Filebased Router initialized")}});var Bt=async n=>{typeof window>"u"||typeof document>"u"||(await n.navigate(window.location.pathname+window.location.search,!1),window.addEventListener("popstate",()=>{n.navigate(window.location.pathname+window.location.search,!1)}),document.addEventListener("click",e=>{let t=e;if(t.defaultPrevented||t.button!==0||t.metaKey||t.ctrlKey||t.shiftKey||t.altKey)return;let s=t.target.closest("a");if(!s)return;let r=new URL(s.href);r.origin===window.location.origin&&(t.preventDefault(),n.navigate(r.pathname+r.search))}))};0&&(module.exports={TSFilebasedRouter,TSRouter,createClientFunc,createSignal,createTSServerFunc,html,initializeRoute,loadPyFiles,mapper,renderChildRoutes,useAnchor,useAnchorSingle,useInitialDOM,useTSAuth,useTSCollection,useTSComponent,useTSElementEach,useTSElements,useTSEvent,useTSEventAll,useTSExtractParams,useTSLazy,useTSMetaData,useTSNavigate,useTSNoReload,useTSOutlet,useTSParams,useTSPurifier,useTSQuery,useTSReactor,useTSSSRHydration,useTSSelect,useTSloadBrython});
|
|
105
127
|
/*! Bundled license information:
|
|
106
128
|
|
|
107
129
|
chokidar/esm/index.js:
|
package/dist/index.js
CHANGED
|
@@ -1,16 +1,40 @@
|
|
|
1
|
-
import Le from"dompurify";var k=null;function Re(){return typeof window>"u"?null:(k||(k=Le(window)),k)}var be=["div","span","p","a","button","ul","li","img","input","form","label","h1","h2","h3","h4","h5","h6","section","main","article","svg","path","circle","rect","line","polyline","polygon","g"],Me=["class","id","href","src","alt","title","type","value","name","placeholder","target","rel","data-click","data-change","data-select","data-effect","data-hover","data-submit","data-key","data-event","data-component","data-stagger","data-input"];function Pe(n){return/^(https?:\/\/|\/|#)/i.test(n.trim())}function xe(n){if(typeof window>"u")return n;let e=document.createElement("template");return e.innerHTML=n,e.content.querySelectorAll("*").forEach(t=>{[...t.attributes].forEach(r=>{let o=r.name.toLowerCase();if(o.startsWith("on")||o.startsWith("xlink")||o.startsWith("xml")){t.removeAttribute(r.name);return}(o==="href"||o==="src")&&!Pe(r.value)&&t.setAttribute(o,"#")}),t.tagName==="A"&&t.getAttribute("target")==="_blank"&&t.setAttribute("rel","noopener noreferrer")}),e.innerHTML}function U(n,...e){let t=Re(),r=n.reduce((s,i,a)=>{let l=a<e.length?String(e[a]??""):"";return s+i+l},"");if(!t)return r;let o=t.sanitize(r,{ALLOWED_TAGS:be,ALLOWED_ATTR:Me,RETURN_DOM:!1});return xe(o)}var Ae=(n,e)=>n.reduce((t,r,o)=>t+e(r,o),"");function He(n){return n}function Ce(n){return new Proxy({},{get(e,t){return async r=>n(t,r)}})}import W from"dompurify";var j=(n,e)=>{let r={...{ADD_TAGS:["my-custom-tag"]},...e};return typeof n=="string"?W.sanitize(n,r):W.sanitize(n.innerHTML,r)};var Q=(n,e,t)=>{if(!(typeof window>"u"||typeof document>"u"))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 Oe}from"zustand/vanilla";import De from"dompurify";function A(n){return De.sanitize(n??"")}function x(n,e){let t=Object.keys(n),r=Object.keys(e);if(t.length!==r.length)return!1;for(let o of t)if(n[o]!==e[o])return!1;return!0}function Fe(n,e){let t=[],r=n.replace(/:[^/]+/g,a=>(t.push(a.slice(1)),"([^/]+)")),o=new RegExp(`^${r}$`),s=e.match(o),i={};return s&&t.forEach((a,l)=>{i[a]=A(s[l+1]??"")}),i}function ke(n){let e={},t=new URLSearchParams(n);for(let[r,o]of t.entries())e[r]=A(o);return e}var H=Oe((n,e)=>({params:{},query:{},setFromPattern:t=>{let r=window.location.pathname,o=Fe(t,r),s=ke(window.location.search),i=e();(!x(i.params,o)||!x(i.query,s))&&n({params:o,query:s})},setFromPatternValues:(t,r)=>{let o={};t.forEach((i,a)=>{o[i]=A(r[a]??"")});let s=e();x(s.params,o)||n({params:o})},setQuery:t=>{let r={};for(let s in t)r[s]=A(t[s]);let o=e();x(o.query,r)||n({query:r})},getParam:t=>e().params[t],getQuery:t=>e().query[t]}));function K(n){let e=H.getState();e.setFromPattern(n);let t=e.params,r=e.query;return{...t,...r}}var B=(n,e,t)=>{let r=document.querySelectorAll(n);return r.forEach(o=>{o.addEventListener(e,t)}),()=>{r.forEach(o=>{o.removeEventListener(e,t)})}};import{animate as qe}from"motion";import $e from"dompurify";var q=typeof window<"u"&&typeof document<"u",V=["div","span","p","a","button","ul","li","img","input","form","label","h1","h2","h3","h4","h5","h6","section","main","article"],G=["class","id","href","src","alt","title","type","value","name","placeholder","data-click","data-change","data-select","data-effect","data-hover","data-submit","data-key","data-event","data-component","data-stagger","data-input","data-children","data-slot","target","rel"],Y=q?$e(window):{sanitize:(n,e)=>n};function Ne(n){return/^(https?:\/\/|\/|#)/i.test(n.trim())}function Ie(n){q&&n.querySelectorAll("*").forEach(e=>{[...e.attributes].forEach(t=>{let r=t.name.toLowerCase();if(r.startsWith("on")){e.removeAttribute(t.name);return}(r==="href"||r==="src")&&!Ne(t.value)&&e.setAttribute(r,"#")}),e.tagName==="A"&&e.getAttribute("target")==="_blank"&&e.setAttribute("rel","noopener noreferrer")})}function X(n){let e={},t={},r=400,o=0,s="ease-in-out",i=0,a=!1,l,u;return n.split(/\s+/).forEach(c=>{c==="fade-in"&&(e.opacity=0,t.opacity=1),c==="fade-out"&&(e.opacity=1,t.opacity=0),c==="slide-up"&&(e.y=20,t.y=0),c==="slide-down"&&(e.y=-20,t.y=0),c==="slide-left"&&(e.x=20,t.x=0),c==="slide-right"&&(e.x=-20,t.x=0),c.startsWith("duration-")&&(r=+c.replace("duration-","")),c.startsWith("delay-")&&(o=+c.replace("delay-","")),(c==="linear"||c.startsWith("ease"))&&(s=c),c==="infinite"&&(i=1/0),c==="replay"&&(a=!0),c.startsWith("parallax-y-")&&(l=+c.replace("parallax-y-","")),c.startsWith("parallax-x-")&&(u=+c.replace("parallax-x-",""))}),{from:e,to:t,duration:r,easing:s,delay:o,repeat:i,replay:a,parallaxY:l,parallaxX:u}}function ze(n,e){n.querySelectorAll("[data-component]").forEach(t=>{let r=t.dataset.component;e[r]?.(t)})}var J=(n,e,t={},r)=>{if(!q||!n)return{html:Y.sanitize(e,{ALLOWED_TAGS:V,ALLOWED_ATTR:G,...r})};let o=Y.sanitize(e,{ALLOWED_TAGS:V,ALLOWED_ATTR:G,...r});n.innerHTML=o,Ie(n);let s=c=>{let d=c.target.closest("[data-click]");d&&t[d.dataset.click]?.(d)};n.addEventListener("click",s),n.querySelectorAll("[data-input]").forEach(c=>{let d=c.dataset.input;t[d]?.(c),c.addEventListener("input",()=>{t[d]?.(c)})}),ze(n,t);let i=[];n.querySelectorAll("[data-effect]").forEach(c=>{let d=X(c.dataset.effect||"");(d.parallaxX||d.parallaxY)&&i.push({el:c,...d})});let a=!1,l=()=>{a||(a=!0,requestAnimationFrame(()=>{let c=window.scrollY;i.forEach(({el:d,parallaxX:g,parallaxY:p})=>{d.style.transform=`translate3d(${(g||0)*c}px, ${(p||0)*c}px, 0)`}),a=!1}))};window.addEventListener("scroll",l);let u=new IntersectionObserver(c=>{c.forEach(d=>{let g=d.target,p=X(g.dataset.effect||"");d.isIntersecting?(Object.assign(g.style,p.from),setTimeout(()=>{qe(g,p.to,{duration:p.duration/1e3,easing:p.easing,repeat:p.repeat})},p.delay),p.replay||u.unobserve(g)):p.replay&&Object.assign(g.style,p.from)})});return n.querySelectorAll("[data-effect]").forEach(c=>u.observe(c)),{cleanup(){u.disconnect(),window.removeEventListener("scroll",l),n.removeEventListener("click",s)}}};import Z from"dompurify";var C=null,ee=(n,e)=>{if(typeof document>"u")return;let t=document.getElementById(n);if(!t)return;Z.addHook("uponSanitizeAttribute",(i,a)=>{let l=(a.attrName||"").toLowerCase(),u=(a.attrValue??"").toString().trim();if(l.startsWith("on")){a.keepAttr=!1;return}if((l==="href"||l==="src")&&/^(javascript:|vbscript:|data:|file:|about:)/i.test(u)){a.keepAttr=!1;return}if(l==="class"){let d=u.split(/\s+/).filter(Boolean).filter(g=>{if(/^[a-zA-Z0-9\-\:\/_\[\]\(\)]+$/.test(g)){if(/^bg-\[url\(.*\)\]$/.test(g)){let p=g.replace(/^bg-\[url\(/,"").replace(/\)\]$/,"").replace(/^['"]|['"]$/g,"");return p===""||/^https?:\/\//i.test(p)||/^\/(?!\/)/.test(p)||/^\.{0,2}\//.test(p)}return!0}return!1});a.attrValue=d.join(" ");return}if(l==="style"){a.keepAttr=!1;return}});let r=t.cloneNode(!0),o=Z.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}),s=Array.from(o.childNodes).map(i=>i.outerHTML||i.textContent||"").join("");if(C!==null&&s!==C){let i=document.createElement("div");e(i);let l=new DOMParser().parseFromString(C,"text/html");for(;t.firstChild;)t.removeChild(t.firstChild);l.body.childNodes.forEach(u=>t.appendChild(u.cloneNode(!0)))}else{for(C=s;t.firstChild;)t.removeChild(t.firstChild);t.appendChild(o),e(t)}};import te 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 ne=(n,e,t,r="",o=null)=>{if(!n)return;let s=te.sanitize(e,{ALLOWED_URI_REGEXP:/^(https?:|\/)/}),i=te.sanitize(t,{USE_PROFILES:{html:!1}});n.setAttribute("href",s),n.setAttribute("aria-label",i),r&&(n.className=r.trim()),o&&n.replaceChildren(o),typeof window<"u"&&n.addEventListener("click",a=>{a.preventDefault();let u=a.currentTarget.getAttribute("href");if(u){let c=window.scrollY;window.scrollTo(0,0),window.history.pushState({scrollPosition:c},"",u),dispatchEvent(new PopStateEvent("popstate"))}})};import S from"dompurify";var re=(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",s=["'self'","https://fonts.googleapis.com","https://fonts.gstatic.com","https://www.google.com/maps/"],i="'self' https://www.youtube.com",a="'self'",l="/csp-report",u=!1)=>{let c=()=>{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 g=u?`report-uri ${l};`:"";d.setAttribute("content",`default-src 'self'; script-src ${n}; style-src ${e}; object-src ${t}; font-src ${r}; img-src ${o}; connect-src ${s.join(" ")}; frame-src ${i}; base-uri ${a}; ${g}`)}catch(d){console.error("Error adding CSP meta element:",d)}};document.readyState==="loading"?document.addEventListener("DOMContentLoaded",c):c()};var oe=(n,e)=>{let t={name:S.sanitize(n.name||""),title:S.sanitize(n.title||""),description:S.sanitize(n.description||"Default description"),author:S.sanitize(n.author||""),favicon:n.favicon},r=m=>{t.name=S.sanitize(m),E("name",t.name)},o=m=>{t.title=S.sanitize(m),document.title=t.title},s=m=>{t.description=S.sanitize(m),E("description",t.description)},i=m=>{t.author=S.sanitize(m),E("author",t.author)},a=m=>{t.favicon=S.sanitize(m);let h=document.querySelector('link[rel="icon"]');h||(h=document.createElement("link"),h.rel="icon",document.head.appendChild(h)),h.href=t.favicon},l=()=>t.name,u=()=>t.title,c=()=>t.description,d=()=>t.author,g=()=>t.favicon,p=()=>t,P=(m,h)=>{let T=document.createElement("meta");T.setAttribute("name",m),T.setAttribute("content",h),document.head.appendChild(T)},E=(m,h)=>{let T=document.querySelector(`meta[name="${m}"]`);T?T.setAttribute("content",h):P(m,h)},y=()=>{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&&a(t.favicon)};return e&&re(e.scriptSrc,e.styleSrc,e.objectSrc,Array.isArray(e.connectSrc)?e.connectSrc.join(" "):e.connectSrc,e.reportOnly!==void 0?String(e.reportOnly):void 0),y(),{setName:r,setTitle:o,setDescription:s,setAuthor:i,setFavicon:a,getName:l,getTitle:u,getDescription:c,getAuthor:d,getFavicon:g,getAllMetaData:p,appendMetaTagsToHead:y}};import _e from"dompurify";var O=(n,e,t,r,o)=>{let s=`#${n}`,i=e.querySelectorAll(s);if(i.length===0)throw new Error(`[useTSComponent] No element found with id '${n}' in the given parent.`);if(i.length>1)throw new Error(`[useTSComponent] Duplicate id '${n}' detected. Found ${i.length} elements.`);let a=i[0];a.innerHTML=_e.sanitize(a.innerHTML,{USE_PROFILES:{html:!0}}),t(a,r,o)};var se=(n,e,t,r=[])=>{let o=new Set;n.forEach((s,i)=>{if(o.has(s)){console.warn(`[useTSCollection] Duplicate ID in collection array: "${s}" \u2014 skipping.`);return}o.add(s);let a=e.querySelectorAll(`#${s}`);if(a.length>1){console.warn(`[useTSCollection] Duplicate ID in DOM: "${s}" (${a.length} elements found) \u2014 skipping component mount.`);return}let l=t[i],u=Array.isArray(r)?r[i]:void 0;typeof l=="function"?O(s,e,l,u):console.warn(`[useTSCollection] No valid component function found for ID: "${s}"`)})};var b=(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 Ue}from"jwt-decode";var ie=(n,e)=>{let t=localStorage.getItem("token");if(!t)return window.location.href=e,null;try{let r=Ue(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,s=>{t(r,s)})})})};var ae=()=>({back:()=>window.history.back(),forward:()=>window.history.forward()});var ce=(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 s=o.path.replace(/\/$/,"");if(r===s||r.startsWith(`${s}/`)){o.component(t);break}}};function le(n,e){let t=window.location.pathname.replace(/\/$/,"");e.routes.forEach(r=>{r.children?.length&&r.children.forEach(o=>{let s=o.path.replace(/\/$/,"");if(t===s||t.startsWith(`${s}/`)){let i=n.querySelector(`#${o.outlet}`)||n.querySelector(`.${o.outlet}`);i instanceof HTMLElement&&o.element&&o.element(i)}})})}var ue=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,s)=>{let i=document.createElement("script");i.src=r,i.onload=()=>o(),i.onerror=()=>s(new Error(`Failed to load ${r}`)),document.head.appendChild(i)});await t(n),await t(e),typeof window.brython=="function"?window.brython():console.error("Brython did not load correctly.")},de=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 me(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 pe=n=>typeof window>"u"?{isDOM:null}:{isDOM:n||document.body};import{debounce as We}from"lodash-es";var N=n=>n;typeof window<"u"&&typeof document<"u"&&(N=n=>{let e=document.createElement("div");return e.innerText=n,e.innerHTML});var je=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",N(r));let o=t.getAttribute("aria-label");o&&t.setAttribute("aria-label",N(o));let s=t.querySelector(":scope > *");s&&(t.innerHTML="",t.appendChild(s));let i=t.getAttribute("href")||"";if(!i.startsWith("#")){try{if(new URL(i,window.location.href).origin!==window.location.origin)return}catch{return}t.addEventListener("click",a=>{a.preventDefault();let l=t.getAttribute("href")||"";try{let u=new URL(l,window.location.href);window.history.pushState({},"",u.pathname+u.search+u.hash),window.dispatchEvent(new PopStateEvent("popstate"))}catch(u){console.error("Invalid URL in anchor:",l,u)}})}})},Qe=We(je,50),D=n=>{Qe(n)};var fe=n=>{if(!n)return;let e=b("a",n);D(e)};var ge=n=>{let e=n,t=[];return[()=>e,i=>{e=typeof i=="function"?i(e):i,t.forEach(a=>a(e))},i=>{t.push(i),i(e)}]};function he(n,e,t){let r=()=>{n.textContent=e().toString(),t?.(e())};r();let o=e.set;o&&(e.set=s=>{o(s),r()})}function ye(n){let[e,t,r]=ge(n),o=[],s=(()=>e());return s.set=i=>{t(i),o.forEach(a=>a(s()))},s.bind=i=>he(i,s),s.subscribe=i=>{o.push(i),i(s())},s}function Te(n,e){let t={deps:e.map(o=>typeof o=="function"?o():o)},r=n();typeof r=="function"&&(t.cleanup=r),e.forEach((o,s)=>{typeof o=="function"&&"bind"in o&&o.subscribe?.(()=>{let a=o(),l=t.deps[s];if(a!==l){t.cleanup?.(),t.deps[s]=a;let u=n();typeof u=="function"&&(t.cleanup=u)}})})}var f={params:{},query:{}},I=new Set;function Ke(){return{params:{...f.params},query:{...f.query}}}function M(n,e){let t=Object.keys(n),r=Object.keys(e);if(t.length!==r.length)return!1;for(let o of t)if(n[o]!==e[o])return!1;return!0}function L(){let n=Ke();I.forEach(e=>e(n))}function Be(n){let e={};if(!n)return e;let t=n.startsWith("?")?n.slice(1):n;for(let r of t.split("&")){if(!r)continue;let[o,s]=r.split("=");o&&(e[decodeURIComponent(o)]=decodeURIComponent(s||""))}return e}function Ve(n){let e=new URLSearchParams;for(let r in n){let o=n[r];o!=null&&o!==""&&e.set(r,o)}let t=e.toString();return t?`?${t}`:""}function F(){if(typeof window>"u")return;let n=window.location.pathname,e=window.location.hash,t=Ve(f.query);history.replaceState({},"",n+t+e)}var z={getState(){return{params:f.params,query:f.query,getParam:n=>f.params[n],getQuery:n=>f.query[n],setFromPattern(n){if(typeof window>"u")return;let e=n.match(/:([^/]+)/g)?.map(o=>o.slice(1))||[],t=window.location.pathname.split("/").filter(Boolean),r={};e.forEach((o,s)=>{r[o]=t[s]}),M(f.params,r)||(f.params=r,L())},setFromPatternValues(n,e){let t={};n.forEach((r,o)=>{t[r]=e[o]}),M(f.params,t)||(f.params=t,L())},setQuery(n){let e={...f.query,...n};M(f.query,e)||(f.query=e,F(),L())},replaceQuery(n){M(f.query,n)||(f.query={...n},F(),L())},removeQuery(n){if(!(n in f.query))return;let e={...f.query};delete e[n],f.query=e,F(),L()},clearQuery(){Object.keys(f.query).length!==0&&(f.query={},F(),L())},setQueryFromURL(n){let e=Be(n);M(f.query,e)||(f.query=e,L())},subscribe(n){return I.add(n),()=>I.delete(n)}}}};typeof window<"u"&&window.addEventListener("popstate",()=>{z.getState().setQueryFromURL(window.location.search)});import Ee from"dompurify";import{createStore as Ge}from"zustand/vanilla";import Ye from"dompurify";var v=Ge(n=>({params:{},query:{},setParams:e=>n(()=>({params:Se(e)})),setQuery:e=>n(()=>({query:Se(e)}))}));function Se(n){let e={};for(let t in n)e[t]=Ye.sanitize(n[t]);return e}var _=class{routes=[];expectedParams;apiFetcher;constructor(e,t,r){this.routes=e,this.expectedParams=new Set(t),this.apiFetcher=r,window.addEventListener("popstate",this.handlePopState.bind(this)),this.handlePopState()}handlePopState(){let e=window.location.pathname,t=window.location.search,r=this.parseQueryParams(t);if(e.startsWith("/api")&&this.apiFetcher){let i=e.replace("/api/","").split("/")[0],a=Object.fromEntries(new URLSearchParams(t));this.apiFetcher(i,a).then(l=>console.log("API response:",l)).catch(l=>console.error("API error:",l));return}let o=this.findMatchingRoute(e,this.routes);if(o){if(o.routeto){this.navigate(o.routeto);return}let s=this.filterAndSanitizeParams(o.params);v.getState().setParams(s),v.getState().setQuery(r);let i=document.createElement("div");if(o.element?.(i,s,r),o.children){let a=e.slice(o.path.length),l=i.querySelector("#child");l&&this.renderChildren(o.children,a,l,s,r)}}else{let s=this.findMatchingRoute("*",this.routes);if(s){let i=this.filterAndSanitizeParams(s.params);v.getState().setParams(i),v.getState().setQuery(r);let a=document.createElement("div");s.element?.(a,i,r)}}}renderChildren(e,t,r,o,s){if(!e||e.length===0){let a=r.querySelector("#child");a&&a.remove();return}let i=this.findMatchingRoute(t,e);if(i){let a=document.createElement("div");a.id="child";let l={...o,...i.params},u=this.filterAndSanitizeParams(l);if(v.getState().setParams(u),v.getState().setQuery(s),i.element?.(a,u,s),r.appendChild(a),i.children){let c=t.slice(i.path.length);this.renderChildren(i.children,c,a,u,s)}}}parseQueryParams(e){let t={},r=new URLSearchParams(e);for(let[o,s]of r.entries())this.expectedParams.has(o)&&(t[o]=Ee.sanitize(s));return t}findMatchingRoute(e,t,r={}){for(let o of t){let s=o.path;if(s==="*")return o;{let a=[],l=s.replace(/:[^\s/]+/g,d=>(a.push(d.substring(1)),"([^\\s/]+)")),u=new RegExp(`^${l}(?:/|$)`),c=e.match(u);if(c){let d={...r};if(a.forEach((g,p)=>{d[g]=c[p+1]??""}),o.children){let g=e.slice(c[0].length),p=this.findMatchingRoute(g,o.children,d);if(p)return p}return{...o,params:d}}}}}filterAndSanitizeParams(e){if(!e)return{};let t={};for(let r in e)this.expectedParams.has(r)&&(t[r]=Ee.sanitize(e[r]??""));return t}navigate(e){history.pushState(null,"",e),this.handlePopState()}addRoute(e){this.routes.push(e)}};var Xe=()=>({name:"ts-filebased-router",async buildStart(){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"),s=e.resolve("src/routes"),i=e.join(o,"tsrouter.gen.ts"),a=e.join(s,"__root.ts"),l=process.env.NODE_ENV!=="production",u=async y=>n.mkdir(y,{recursive:!0}).catch(()=>{}),c=y=>y.charAt(0).toUpperCase()+y.slice(1),d=y=>{let m="/"+e.relative(r,y).replace(/\\/g,"/");return m=m.replace(/\.ts$/,"").replace(/\/index$/,"")||"/",m.replace(/\[\.\.\.(.+?)\]/g,"*").replace(/\[(.+?)\]/g,":$1")},g=y=>y.replace(/^\//,"").split("/").map(m=>m.startsWith(":")?c(m.slice(1)):m.replace(/\b\w/g,h=>h.toUpperCase()).replace(/[-_]/g,"")).filter(Boolean).join("")||"Index",p=async y=>{let m=await n.readdir(y,{withFileTypes:!0}),h=[];for(let T of m){let R=e.join(y,T.name);T.isDirectory()?h.push(...await p(R)):T.isFile()&&T.name.endsWith(".ts")&&h.push({file:R,route:d(R),name:g(d(R))})}return h},P=async()=>{let y=await p(r),m=y.find(w=>w.route==="/notfound"),h=y.filter(w=>w.route!=="/notfound"),T=m?`export const NotFound = async (DOM: HTMLElement) => {
|
|
2
|
-
|
|
1
|
+
import Pe from"dompurify";var q=null;function xe(){return typeof window>"u"?null:(q||(q=Pe(window)),q)}var Ae=["div","span","p","a","button","ul","li","img","input","form","label","h1","h2","h3","h4","h5","h6","section","main","article","svg","path","circle","rect","line","polyline","polygon","g"],Ce=["class","id","href","src","alt","title","type","value","name","placeholder","target","rel","data-click","data-change","data-select","data-effect","data-hover","data-submit","data-key","data-event","data-component","data-stagger","data-input"];function He(n){return/^(https?:\/\/|\/|#)/i.test(n.trim())}function Oe(n){if(typeof window>"u")return n;let e=document.createElement("template");return e.innerHTML=n,e.content.querySelectorAll("*").forEach(t=>{[...t.attributes].forEach(r=>{let o=r.name.toLowerCase();if(o.startsWith("on")||o.startsWith("xlink")||o.startsWith("xml")){t.removeAttribute(r.name);return}(o==="href"||o==="src")&&!He(r.value)&&t.setAttribute(o,"#")}),t.tagName==="A"&&t.getAttribute("target")==="_blank"&&t.setAttribute("rel","noopener noreferrer")}),e.innerHTML}function K(n,...e){let t=xe(),r=n.reduce((s,i,a)=>{let l=a<e.length?String(e[a]??""):"";return s+i+l},"");if(!t)return r;let o=t.sanitize(r,{ALLOWED_TAGS:Ae,ALLOWED_ATTR:Ce,RETURN_DOM:!1});return Oe(o)}var De=(n,e)=>n.reduce((t,r,o)=>t+e(r,o),"");function Fe(n){return n}function ke(n){return new Proxy({},{get(e,t){return async r=>n(t,r)}})}import B from"dompurify";var V=(n,e)=>{let r={...{ADD_TAGS:["my-custom-tag"]},...e};return typeof n=="string"?B.sanitize(n,r):B.sanitize(n.innerHTML,r)};var G=(n,e,t)=>{if(!(typeof window>"u"||typeof document>"u"))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 $e}from"zustand/vanilla";import qe from"dompurify";function C(n){return qe.sanitize(n??"")}function A(n,e){let t=Object.keys(n),r=Object.keys(e);if(t.length!==r.length)return!1;for(let o of t)if(n[o]!==e[o])return!1;return!0}function Ne(n,e){let t=[],r=n.replace(/:[^/]+/g,a=>(t.push(a.slice(1)),"([^/]+)")),o=new RegExp(`^${r}$`),s=e.match(o),i={};return s&&t.forEach((a,l)=>{i[a]=C(s[l+1]??"")}),i}function Ie(n){let e={},t=new URLSearchParams(n);for(let[r,o]of t.entries())e[r]=C(o);return e}var H=$e((n,e)=>({params:{},query:{},setFromPattern:t=>{let r=window.location.pathname,o=Ne(t,r),s=Ie(window.location.search),i=e();(!A(i.params,o)||!A(i.query,s))&&n({params:o,query:s})},setFromPatternValues:(t,r)=>{let o={};t.forEach((i,a)=>{o[i]=C(r[a]??"")});let s=e();A(s.params,o)||n({params:o})},setQuery:t=>{let r={};for(let s in t)r[s]=C(t[s]);let o=e();A(o.query,r)||n({query:r})},getParam:t=>e().params[t],getQuery:t=>e().query[t]}));function Y(n){let e=H.getState();e.setFromPattern(n);let t=e.params,r=e.query;return{...t,...r}}var X=(n,e,t)=>{let r=document.querySelectorAll(n);return r.forEach(o=>{o.addEventListener(e,t)}),()=>{r.forEach(o=>{o.removeEventListener(e,t)})}};import{animate as ze}from"motion";import _e from"dompurify";var N=typeof window<"u"&&typeof document<"u",J=["div","span","p","a","button","ul","li","img","input","form","label","h1","h2","h3","h4","h5","h6","section","main","article"],Z=["class","id","href","src","alt","title","type","value","name","placeholder","data-click","data-change","data-select","data-effect","data-hover","data-submit","data-key","data-event","data-component","data-stagger","data-input","data-children","data-slot","target","rel"],ee=N?_e(window):{sanitize:(n,e)=>n};function Ue(n){return/^(https?:\/\/|\/|#)/i.test(n.trim())}function je(n){N&&n.querySelectorAll("*").forEach(e=>{[...e.attributes].forEach(t=>{let r=t.name.toLowerCase();if(r.startsWith("on")){e.removeAttribute(t.name);return}(r==="href"||r==="src")&&!Ue(t.value)&&e.setAttribute(r,"#")}),e.tagName==="A"&&e.getAttribute("target")==="_blank"&&e.setAttribute("rel","noopener noreferrer")})}function te(n){let e={},t={},r=400,o=0,s="ease-in-out",i=0,a=!1,l,u;return n.split(/\s+/).forEach(c=>{c==="fade-in"&&(e.opacity=0,t.opacity=1),c==="fade-out"&&(e.opacity=1,t.opacity=0),c==="slide-up"&&(e.y=20,t.y=0),c==="slide-down"&&(e.y=-20,t.y=0),c==="slide-left"&&(e.x=20,t.x=0),c==="slide-right"&&(e.x=-20,t.x=0),c.startsWith("duration-")&&(r=+c.replace("duration-","")),c.startsWith("delay-")&&(o=+c.replace("delay-","")),(c==="linear"||c.startsWith("ease"))&&(s=c),c==="infinite"&&(i=1/0),c==="replay"&&(a=!0),c.startsWith("parallax-y-")&&(l=+c.replace("parallax-y-","")),c.startsWith("parallax-x-")&&(u=+c.replace("parallax-x-",""))}),{from:e,to:t,duration:r,easing:s,delay:o,repeat:i,replay:a,parallaxY:l,parallaxX:u}}function We(n,e){n.querySelectorAll("[data-component]").forEach(t=>{let r=t.dataset.component;e[r]?.(t)})}var ne=(n,e,t={},r)=>{if(!N||!n)return{html:ee.sanitize(e,{ALLOWED_TAGS:J,ALLOWED_ATTR:Z,...r})};let o=ee.sanitize(e,{ALLOWED_TAGS:J,ALLOWED_ATTR:Z,...r});n.innerHTML=o,je(n);let s=c=>{let d=c.target.closest("[data-click]");d&&t[d.dataset.click]?.(d)};n.addEventListener("click",s),n.querySelectorAll("[data-input]").forEach(c=>{let d=c.dataset.input;t[d]?.(c),c.addEventListener("input",()=>{t[d]?.(c)})}),We(n,t);let i=[];n.querySelectorAll("[data-effect]").forEach(c=>{let d=te(c.dataset.effect||"");(d.parallaxX||d.parallaxY)&&i.push({el:c,...d})});let a=!1,l=()=>{a||(a=!0,requestAnimationFrame(()=>{let c=window.scrollY;i.forEach(({el:d,parallaxX:h,parallaxY:p})=>{d.style.transform=`translate3d(${(h||0)*c}px, ${(p||0)*c}px, 0)`}),a=!1}))};window.addEventListener("scroll",l);let u=new IntersectionObserver(c=>{c.forEach(d=>{let h=d.target,p=te(h.dataset.effect||"");d.isIntersecting?(Object.assign(h.style,p.from),setTimeout(()=>{ze(h,p.to,{duration:p.duration/1e3,easing:p.easing,repeat:p.repeat})},p.delay),p.replay||u.unobserve(h)):p.replay&&Object.assign(h.style,p.from)})});return n.querySelectorAll("[data-effect]").forEach(c=>u.observe(c)),{cleanup(){u.disconnect(),window.removeEventListener("scroll",l),n.removeEventListener("click",s)}}};import re from"dompurify";var O=null,oe=(n,e)=>{if(typeof document>"u")return;let t=document.getElementById(n);if(!t)return;re.addHook("uponSanitizeAttribute",(i,a)=>{let l=(a.attrName||"").toLowerCase(),u=(a.attrValue??"").toString().trim();if(l.startsWith("on")){a.keepAttr=!1;return}if((l==="href"||l==="src")&&/^(javascript:|vbscript:|data:|file:|about:)/i.test(u)){a.keepAttr=!1;return}if(l==="class"){let d=u.split(/\s+/).filter(Boolean).filter(h=>{if(/^[a-zA-Z0-9\-\:\/_\[\]\(\)]+$/.test(h)){if(/^bg-\[url\(.*\)\]$/.test(h)){let p=h.replace(/^bg-\[url\(/,"").replace(/\)\]$/,"").replace(/^['"]|['"]$/g,"");return p===""||/^https?:\/\//i.test(p)||/^\/(?!\/)/.test(p)||/^\.{0,2}\//.test(p)}return!0}return!1});a.attrValue=d.join(" ");return}if(l==="style"){a.keepAttr=!1;return}});let r=t.cloneNode(!0),o=re.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}),s=Array.from(o.childNodes).map(i=>i.outerHTML||i.textContent||"").join("");if(O!==null&&s!==O){let i=document.createElement("div");e(i);let l=new DOMParser().parseFromString(O,"text/html");for(;t.firstChild;)t.removeChild(t.firstChild);l.body.childNodes.forEach(u=>t.appendChild(u.cloneNode(!0)))}else{for(O=s;t.firstChild;)t.removeChild(t.firstChild);t.appendChild(o),e(t)}};import se 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 ie=(n,e,t,r="",o=null)=>{if(!n)return;let s=se.sanitize(e,{ALLOWED_URI_REGEXP:/^(https?:|\/)/}),i=se.sanitize(t,{USE_PROFILES:{html:!1}});n.setAttribute("href",s),n.setAttribute("aria-label",i),r&&(n.className=r.trim()),o&&n.replaceChildren(o),typeof window<"u"&&n.addEventListener("click",a=>{a.preventDefault();let u=a.currentTarget.getAttribute("href");if(u){let c=window.scrollY;window.scrollTo(0,0),window.history.pushState({scrollPosition:c},"",u),dispatchEvent(new PopStateEvent("popstate"))}})};import E from"dompurify";var ae=(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",s=["'self'","https://fonts.googleapis.com","https://fonts.gstatic.com","https://www.google.com/maps/"],i="'self' https://www.youtube.com",a="'self'",l="/csp-report",u=!1)=>{let c=()=>{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=u?`report-uri ${l};`:"";d.setAttribute("content",`default-src 'self'; script-src ${n}; style-src ${e}; object-src ${t}; font-src ${r}; img-src ${o}; connect-src ${s.join(" ")}; frame-src ${i}; base-uri ${a}; ${h}`)}catch(d){console.error("Error adding CSP meta element:",d)}};document.readyState==="loading"?document.addEventListener("DOMContentLoaded",c):c()};var ce=(n,e)=>{let t={name:E.sanitize(n.name||""),title:E.sanitize(n.title||""),description:E.sanitize(n.description||"Default description"),author:E.sanitize(n.author||""),favicon:n.favicon},r=m=>{t.name=E.sanitize(m),v("name",t.name)},o=m=>{t.title=E.sanitize(m),document.title=t.title},s=m=>{t.description=E.sanitize(m),v("description",t.description)},i=m=>{t.author=E.sanitize(m),v("author",t.author)},a=m=>{t.favicon=E.sanitize(m);let g=document.querySelector('link[rel="icon"]');g||(g=document.createElement("link"),g.rel="icon",document.head.appendChild(g)),g.href=t.favicon},l=()=>t.name,u=()=>t.title,c=()=>t.description,d=()=>t.author,h=()=>t.favicon,p=()=>t,P=(m,g)=>{let S=document.createElement("meta");S.setAttribute("name",m),S.setAttribute("content",g),document.head.appendChild(S)},v=(m,g)=>{let S=document.querySelector(`meta[name="${m}"]`);S?S.setAttribute("content",g):P(m,g)},y=()=>{t.title&&(document.title=t.title),t.name&&v("name",t.name),t.description&&v("description",t.description),t.author&&v("author",t.author),t.favicon&&a(t.favicon)};return e&&ae(e.scriptSrc,e.styleSrc,e.objectSrc,Array.isArray(e.connectSrc)?e.connectSrc.join(" "):e.connectSrc,e.reportOnly!==void 0?String(e.reportOnly):void 0),y(),{setName:r,setTitle:o,setDescription:s,setAuthor:i,setFavicon:a,getName:l,getTitle:u,getDescription:c,getAuthor:d,getFavicon:h,getAllMetaData:p,appendMetaTagsToHead:y}};import Qe from"dompurify";var D=(n,e,t,r,o)=>{let s=`#${n}`,i=e.querySelectorAll(s);if(i.length===0)throw new Error(`[useTSComponent] No element found with id '${n}' in the given parent.`);if(i.length>1)throw new Error(`[useTSComponent] Duplicate id '${n}' detected. Found ${i.length} elements.`);let a=i[0];a.innerHTML=Qe.sanitize(a.innerHTML,{USE_PROFILES:{html:!0}}),t(a,r,o)};var le=(n,e,t,r=[])=>{let o=new Set;n.forEach((s,i)=>{if(o.has(s)){console.warn(`[useTSCollection] Duplicate ID in collection array: "${s}" \u2014 skipping.`);return}o.add(s);let a=e.querySelectorAll(`#${s}`);if(a.length>1){console.warn(`[useTSCollection] Duplicate ID in DOM: "${s}" (${a.length} elements found) \u2014 skipping component mount.`);return}let l=t[i],u=Array.isArray(r)?r[i]:void 0;typeof l=="function"?D(s,e,l,u):console.warn(`[useTSCollection] No valid component function found for ID: "${s}"`)})};var M=(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 Ke}from"jwt-decode";var ue=(n,e)=>{let t=localStorage.getItem("token");if(!t)return window.location.href=e,null;try{let r=Ke(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 I=(n,e,t)=>{n.forEach(r=>{e.forEach(o=>{r.addEventListener(o,s=>{t(r,s)})})})};var de=()=>({back:()=>window.history.back(),forward:()=>window.history.forward()});var me=(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 s=o.path.replace(/\/$/,"");if(r===s||r.startsWith(`${s}/`)){o.component(t);break}}};function pe(n,e){let t=window.location.pathname.replace(/\/$/,"");e.routes.forEach(r=>{r.children?.length&&r.children.forEach(o=>{let s=o.path.replace(/\/$/,"");if(t===s||t.startsWith(`${s}/`)){let i=n.querySelector(`#${o.outlet}`)||n.querySelector(`.${o.outlet}`);i instanceof HTMLElement&&o.element&&o.element(i)}})})}var fe=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,s)=>{let i=document.createElement("script");i.src=r,i.onload=()=>o(),i.onerror=()=>s(new Error(`Failed to load ${r}`)),document.head.appendChild(i)});await t(n),await t(e),typeof window.brython=="function"?window.brython():console.error("Brython did not load correctly.")},he=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 ge(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 ye=n=>typeof window>"u"?{isDOM:null}:{isDOM:n||document.body};import{debounce as Be}from"lodash-es";var z=n=>n;typeof window<"u"&&typeof document<"u"&&(z=n=>{let e=document.createElement("div");return e.innerText=n,e.innerHTML});var Ve=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",z(r));let o=t.getAttribute("aria-label");o&&t.setAttribute("aria-label",z(o));let s=t.querySelector(":scope > *");s&&(t.innerHTML="",t.appendChild(s));let i=t.getAttribute("href")||"";if(!i.startsWith("#")){try{if(new URL(i,window.location.href).origin!==window.location.origin)return}catch{return}t.addEventListener("click",a=>{a.preventDefault();let l=t.getAttribute("href")||"";try{let u=new URL(l,window.location.href);window.history.pushState({},"",u.pathname+u.search+u.hash),window.dispatchEvent(new PopStateEvent("popstate"))}catch(u){console.error("Invalid URL in anchor:",l,u)}})}})},Ge=Be(Ve,50),F=n=>{Ge(n)};var Te=n=>{if(!n)return;let e=M("a",n);F(e)};var Se=n=>{let e=n,t=[];return[()=>e,i=>{e=typeof i=="function"?i(e):i,t.forEach(a=>a(e))},i=>{t.push(i),i(e)}]};function Ee(n,e,t){let r=()=>{n.textContent=e().toString(),t?.(e())};r();let o=e.set;o&&(e.set=s=>{o(s),r()})}function ve(n){let[e,t,r]=Se(n),o=[],s=(()=>e());return s.set=i=>{t(i),o.forEach(a=>a(s()))},s.bind=i=>Ee(i,s),s.subscribe=i=>{o.push(i),i(s())},s}function we(n,e){let t={deps:e.map(o=>typeof o=="function"?o():o)},r=n();typeof r=="function"&&(t.cleanup=r),e.forEach((o,s)=>{typeof o=="function"&&"bind"in o&&o.subscribe?.(()=>{let a=o(),l=t.deps[s];if(a!==l){t.cleanup?.(),t.deps[s]=a;let u=n();typeof u=="function"&&(t.cleanup=u)}})})}var f={params:{},query:{}},_=new Set;function Ye(){return{params:{...f.params},query:{...f.query}}}function b(n,e){let t=Object.keys(n),r=Object.keys(e);if(t.length!==r.length)return!1;for(let o of t)if(n[o]!==e[o])return!1;return!0}function L(){let n=Ye();_.forEach(e=>e(n))}function Xe(n){let e={};if(!n)return e;let t=n.startsWith("?")?n.slice(1):n;for(let r of t.split("&")){if(!r)continue;let[o,s]=r.split("=");o&&(e[decodeURIComponent(o)]=decodeURIComponent(s||""))}return e}function Je(n){let e=new URLSearchParams;for(let r in n){let o=n[r];o!=null&&o!==""&&e.set(r,o)}let t=e.toString();return t?`?${t}`:""}function k(){if(typeof window>"u")return;let n=window.location.pathname,e=window.location.hash,t=Je(f.query);history.replaceState({},"",n+t+e)}var U={getState(){return{params:f.params,query:f.query,getParam:n=>f.params[n],getQuery:n=>f.query[n],setFromPattern(n){if(typeof window>"u")return;let e=n.match(/:([^/]+)/g)?.map(o=>o.slice(1))||[],t=window.location.pathname.split("/").filter(Boolean),r={};e.forEach((o,s)=>{r[o]=t[s]}),b(f.params,r)||(f.params=r,L())},setFromPatternValues(n,e){let t={};n.forEach((r,o)=>{t[r]=e[o]}),b(f.params,t)||(f.params=t,L())},setQuery(n){let e={...f.query,...n};b(f.query,e)||(f.query=e,k(),L())},replaceQuery(n){b(f.query,n)||(f.query={...n},k(),L())},removeQuery(n){if(!(n in f.query))return;let e={...f.query};delete e[n],f.query=e,k(),L()},clearQuery(){Object.keys(f.query).length!==0&&(f.query={},k(),L())},setQueryFromURL(n){let e=Xe(n);b(f.query,e)||(f.query=e,L())},subscribe(n){return _.add(n),()=>_.delete(n)}}}};typeof window<"u"&&window.addEventListener("popstate",()=>{U.getState().setQueryFromURL(window.location.search)});import Re from"dompurify";import{createStore as Ze}from"zustand/vanilla";import et from"dompurify";var w=Ze(n=>({params:{},query:{},setParams:e=>n(()=>({params:Le(e)})),setQuery:e=>n(()=>({query:Le(e)}))}));function Le(n){let e={};for(let t in n)e[t]=et.sanitize(n[t]);return e}var j=class{routes=[];expectedParams;apiFetcher;constructor(e,t,r){this.routes=e,this.expectedParams=new Set(t),this.apiFetcher=r,window.addEventListener("popstate",this.handlePopState.bind(this)),this.handlePopState()}handlePopState(){let e=window.location.pathname,t=window.location.search,r=this.parseQueryParams(t);if(e.startsWith("/api")&&this.apiFetcher){let i=e.replace("/api/","").split("/")[0],a=Object.fromEntries(new URLSearchParams(t));this.apiFetcher(i,a).then(l=>console.log("API response:",l)).catch(l=>console.error("API error:",l));return}let o=this.findMatchingRoute(e,this.routes);if(o){if(o.routeto){this.navigate(o.routeto);return}let s=this.filterAndSanitizeParams(o.params);w.getState().setParams(s),w.getState().setQuery(r);let i=document.createElement("div");if(o.element?.(i,s,r),o.children){let a=e.slice(o.path.length),l=i.querySelector("#child");l&&this.renderChildren(o.children,a,l,s,r)}}else{let s=this.findMatchingRoute("*",this.routes);if(s){let i=this.filterAndSanitizeParams(s.params);w.getState().setParams(i),w.getState().setQuery(r);let a=document.createElement("div");s.element?.(a,i,r)}}}renderChildren(e,t,r,o,s){if(!e||e.length===0){let a=r.querySelector("#child");a&&a.remove();return}let i=this.findMatchingRoute(t,e);if(i){let a=document.createElement("div");a.id="child";let l={...o,...i.params},u=this.filterAndSanitizeParams(l);if(w.getState().setParams(u),w.getState().setQuery(s),i.element?.(a,u,s),r.appendChild(a),i.children){let c=t.slice(i.path.length);this.renderChildren(i.children,c,a,u,s)}}}parseQueryParams(e){let t={},r=new URLSearchParams(e);for(let[o,s]of r.entries())this.expectedParams.has(o)&&(t[o]=Re.sanitize(s));return t}findMatchingRoute(e,t,r={}){for(let o of t){let s=o.path;if(s==="*")return o;{let a=[],l=s.replace(/:[^\s/]+/g,d=>(a.push(d.substring(1)),"([^\\s/]+)")),u=new RegExp(`^${l}(?:/|$)`),c=e.match(u);if(c){let d={...r};if(a.forEach((h,p)=>{d[h]=c[p+1]??""}),o.children){let h=e.slice(c[0].length),p=this.findMatchingRoute(h,o.children,d);if(p)return p}return{...o,params:d}}}}}filterAndSanitizeParams(e){if(!e)return{};let t={};for(let r in e)this.expectedParams.has(r)&&(t[r]=Re.sanitize(e[r]??""));return t}navigate(e){history.pushState(null,"",e),this.handlePopState()}addRoute(e){this.routes.push(e)}};var tt=()=>({name:"ts-filebased-router",async buildStart(){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"),s=e.resolve("src/routes"),i=e.join(o,"tsrouter.gen.ts"),a=e.join(s,"__root.ts"),l=process.env.NODE_ENV!=="production",u=async y=>n.mkdir(y,{recursive:!0}).catch(()=>{}),c=y=>y.charAt(0).toUpperCase()+y.slice(1),d=y=>{let m="/"+e.relative(r,y).replace(/\\/g,"/");return m=m.replace(/\.ts$/,"").replace(/\/index$/,"")||"/",m.replace(/\[\.\.\.(.+?)\]/g,"*").replace(/\[(.+?)\]/g,":$1")},h=y=>y.replace(/^\//,"").split("/").map(m=>m.startsWith(":")?c(m.slice(1)):m.replace(/\b\w/g,g=>g.toUpperCase()).replace(/[-_]/g,"")).filter(Boolean).join("")||"Index",p=async y=>{let m=await n.readdir(y,{withFileTypes:!0}),g=[];for(let S of m){let R=e.join(y,S.name);S.isDirectory()?g.push(...await p(R)):S.isFile()&&S.name.endsWith(".ts")&&g.push({file:R,route:d(R),name:h(d(R))})}return g},P=async()=>{let y=await p(r),m=y.find(T=>T.route==="/notfound"),g=y.filter(T=>T.route!=="/notfound");for(let T of y)if(!(await n.readFile(T.file,"utf-8")).trim()){let x=T.route.includes(":"),Q=x?T.route.split("/").filter($=>$.startsWith(":")).map($=>$.slice(1)):[],be=x?`const { ${Q.join(", ")} } = useTSExtractParams("${T.route}");`:"";await n.writeFile(T.file,`import { html, useTSElements, useTSMetaData${x?", useTSExtractParams":""} } from "@devwaren/vanilla-ts";
|
|
2
|
+
|
|
3
|
+
export default function ${T.name}(DOM: HTMLElement) {
|
|
4
|
+
useTSMetaData({
|
|
5
|
+
title: "${T.name.toLowerCase()}",
|
|
6
|
+
description: "${T.name.toLowerCase()}",
|
|
7
|
+
});
|
|
8
|
+
|
|
9
|
+
${be}
|
|
10
|
+
|
|
11
|
+
return useTSElements(DOM, html\`
|
|
12
|
+
<div>
|
|
13
|
+
<h1>${T.name.toLowerCase()}</h1>
|
|
14
|
+
${x?`<pre>\${${Q.join("}, ${")}}</pre>`:""}
|
|
15
|
+
</div>
|
|
16
|
+
\`);
|
|
17
|
+
};
|
|
18
|
+
`,"utf-8")}let S=m?`export const NotFound = async (DOM: HTMLElement) => {
|
|
19
|
+
const mod = await import("../pages/${e.relative(r,m.file).replace(/\\/g,"/").replace(/\\.ts$/,"")}") as unknown as Module;
|
|
3
20
|
return mod.default(DOM);
|
|
4
|
-
};`:"export const NotFound = (DOM: HTMLElement) =>\n useTSElements(DOM, html`<h1>404 - Page Not Found</h1>`);",R=
|
|
5
|
-
`),
|
|
21
|
+
};`:"export const NotFound = (DOM: HTMLElement) =>\n useTSElements(DOM, html`<h1>404 - Page Not Found</h1>`);",R=g.map(T=>{let W="../pages/"+e.relative(r,T.file).replace(/\\/g,"/").replace(/\.ts$/,"");return`{ path: "${T.route}", name: "${T.name}", component: () => import("${W}") as unknown as Module }`}).join(`,
|
|
22
|
+
`),Me=`// AUTO-GENERATED ROUTER
|
|
6
23
|
import { useTSElements, useTSParams, html } from "@devwaren/vanilla-ts";
|
|
7
|
-
import type { Module, Component } from "@devwaren/vanilla-ts";
|
|
8
24
|
|
|
9
25
|
// -----------------------------
|
|
10
|
-
|
|
26
|
+
// Types for all routes
|
|
27
|
+
// -----------------------------
|
|
28
|
+
type Cleanup = undefined | (() => void);
|
|
29
|
+
type RenderResult = Cleanup | Promise<Cleanup> | string;
|
|
30
|
+
type Component = (DOM: HTMLElement) => RenderResult;
|
|
31
|
+
type Module = { default: Component };
|
|
32
|
+
|
|
33
|
+
// -----------------------------
|
|
34
|
+
${S}
|
|
11
35
|
|
|
12
36
|
// -----------------------------
|
|
13
|
-
export const routeTree: { path: string; name: string; component: () => Promise<Module
|
|
37
|
+
export const routeTree: { path: string; name: string; component: () => Promise<Module> }[] = [
|
|
14
38
|
${R}
|
|
15
39
|
];
|
|
16
40
|
|
|
@@ -78,9 +102,7 @@ export async function createRouter(DOM: HTMLElement) {
|
|
|
78
102
|
useTSParams.getState().setFromPatternValues(Object.keys(params), Object.values(params));
|
|
79
103
|
|
|
80
104
|
const query: Record<string, string> = {};
|
|
81
|
-
url.searchParams.forEach((v, k) => {
|
|
82
|
-
query[k] = v; // \u2705 no return
|
|
83
|
-
});
|
|
105
|
+
url.searchParams.forEach((v, k) => { query[k] = v; });
|
|
84
106
|
useTSParams.getState().setQuery(query);
|
|
85
107
|
|
|
86
108
|
currentComponentUnmount?.();
|
|
@@ -91,7 +113,7 @@ export async function createRouter(DOM: HTMLElement) {
|
|
|
91
113
|
},
|
|
92
114
|
};
|
|
93
115
|
};
|
|
94
|
-
`;await u(o),await u(s),await n.writeFile(i,
|
|
116
|
+
`;await u(o),await u(s),await n.writeFile(i,Me,"utf-8"),await n.writeFile(a,v(),"utf-8")},v=()=>`
|
|
95
117
|
import { createRouter } from "../gen/tsrouter.gen";
|
|
96
118
|
import { useTSParams, initializeRoute } from "@devwaren/vanilla-ts";
|
|
97
119
|
|
|
@@ -101,4 +123,4 @@ export const Router = async (DOM: HTMLElement) => {
|
|
|
101
123
|
await initializeRoute(router);
|
|
102
124
|
return router;
|
|
103
125
|
};
|
|
104
|
-
`;await u(r),await P(),l&&t.watch(r,{ignoreInitial:!0}).on("all",async(m,
|
|
126
|
+
`;await u(r),await P(),l&&t.watch(r,{ignoreInitial:!0}).on("all",async(m,g)=>{g.endsWith(".ts")&&(await P(),console.log("\u267B\uFE0F TS Router regenerated"))}),console.log("\u{1F7E2} TS Filebased Router initialized")}});var nt=async n=>{typeof window>"u"||typeof document>"u"||(await n.navigate(window.location.pathname+window.location.search,!1),window.addEventListener("popstate",()=>{n.navigate(window.location.pathname+window.location.search,!1)}),document.addEventListener("click",e=>{let t=e;if(t.defaultPrevented||t.button!==0||t.metaKey||t.ctrlKey||t.shiftKey||t.altKey)return;let r=t.target.closest("a");if(!r)return;let o=new URL(r.href);o.origin===window.location.origin&&(t.preventDefault(),n.navigate(o.pathname+o.search))}))};export{tt as TSFilebasedRouter,j as TSRouter,ke as createClientFunc,ve as createSignal,Fe as createTSServerFunc,K as html,nt as initializeRoute,he as loadPyFiles,De as mapper,pe as renderChildRoutes,F as useAnchor,ie as useAnchorSingle,oe as useInitialDOM,ue as useTSAuth,le as useTSCollection,D as useTSComponent,I as useTSElementEach,ne as useTSElements,G as useTSEvent,X as useTSEventAll,Y as useTSExtractParams,ge as useTSLazy,ce as useTSMetaData,de as useTSNavigate,Te as useTSNoReload,me as useTSOutlet,H as useTSParams,V as useTSPurifier,U as useTSQuery,we as useTSReactor,ye as useTSSSRHydration,M as useTSSelect,fe as useTSloadBrython};
|