arcanajs 3.0.0 → 4.0.0

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.
Files changed (53) hide show
  1. package/dist/arcanajs.client.js +2 -0
  2. package/dist/arcanajs.client.js.map +1 -0
  3. package/dist/arcanajs.js +2 -1
  4. package/dist/arcanajs.js.LICENSE.txt +14 -0
  5. package/dist/arcanajs.js.map +1 -1
  6. package/dist/arcanox.js +2 -0
  7. package/dist/arcanox.js.map +1 -0
  8. package/dist/cli/commands/db.d.ts +1 -0
  9. package/dist/cli/commands/make.d.ts +1 -0
  10. package/dist/cli/commands/migrate.d.ts +1 -0
  11. package/dist/cli/index.d.ts +1 -0
  12. package/dist/cli/index.js +1 -1
  13. package/dist/cli/index.js.map +1 -1
  14. package/dist/lib/arcanox/Model.d.ts +203 -0
  15. package/dist/lib/arcanox/QueryBuilder.d.ts +141 -0
  16. package/dist/lib/arcanox/adapters/MongoAdapter.d.ts +22 -0
  17. package/dist/lib/arcanox/adapters/MySQLAdapter.d.ts +27 -0
  18. package/dist/lib/arcanox/adapters/PostgresAdapter.d.ts +27 -0
  19. package/dist/lib/arcanox/extensions/MongoExtensions.d.ts +33 -0
  20. package/dist/lib/arcanox/factory/Factory.d.ts +26 -0
  21. package/dist/lib/arcanox/factory/index.d.ts +1 -0
  22. package/dist/lib/arcanox/index.d.ts +13 -0
  23. package/dist/lib/arcanox/providers/DatabaseProvider.d.ts +5 -0
  24. package/dist/lib/arcanox/relations/BelongsTo.d.ts +11 -0
  25. package/dist/lib/arcanox/relations/BelongsToMany.d.ts +15 -0
  26. package/dist/lib/arcanox/relations/HasMany.d.ts +11 -0
  27. package/dist/lib/arcanox/relations/HasOne.d.ts +11 -0
  28. package/dist/lib/arcanox/relations/Relation.d.ts +14 -0
  29. package/dist/lib/arcanox/schema/Blueprint.d.ts +183 -0
  30. package/dist/lib/arcanox/schema/Migration.d.ts +76 -0
  31. package/dist/lib/arcanox/schema/Schema.d.ts +49 -0
  32. package/dist/lib/arcanox/schema/index.d.ts +4 -0
  33. package/dist/lib/arcanox/seeder/Seeder.d.ts +13 -0
  34. package/dist/lib/arcanox/seeder/index.d.ts +1 -0
  35. package/dist/lib/arcanox/support/Macroable.d.ts +19 -0
  36. package/dist/lib/arcanox/types.d.ts +76 -0
  37. package/dist/lib/index.arcanox.d.ts +6 -0
  38. package/dist/lib/index.client.d.ts +11 -0
  39. package/dist/lib/{index.d.ts → index.server.d.ts} +7 -11
  40. package/dist/lib/server/ArcanaJSServer.d.ts +35 -9
  41. package/dist/lib/server/Container.d.ts +31 -0
  42. package/dist/lib/server/MiddlewareBinder.d.ts +4 -0
  43. package/dist/lib/server/ResponseHandlerMiddleware.d.ts +0 -25
  44. package/dist/lib/server/Router.d.ts +12 -3
  45. package/dist/lib/server/http/FormRequest.d.ts +10 -0
  46. package/dist/lib/server/http/JsonResource.d.ts +13 -0
  47. package/dist/lib/server/http/Middleware.d.ts +4 -0
  48. package/dist/lib/server/support/ServiceProvider.d.ts +13 -0
  49. package/dist/lib/server/utils/dynamicRequire.d.ts +6 -0
  50. package/dist/lib/server/validation/ValidationException.d.ts +5 -0
  51. package/dist/lib/server/validation/Validator.d.ts +12 -0
  52. package/package.json +32 -7
  53. package/dist/lib/global.d.ts +0 -61
@@ -0,0 +1,2 @@
1
+ (()=>{"use strict";var e={n:t=>{var a=t&&t.__esModule?()=>t.default:()=>t;return e.d(a,{a}),a},d:(t,a)=>{for(var r in a)e.o(a,r)&&!e.o(t,r)&&Object.defineProperty(t,r,{enumerable:!0,get:a[r]})},o:(e,t)=>Object.prototype.hasOwnProperty.call(e,t),r:e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})}},t={};e.r(t),e.d(t,{Body:()=>n,Head:()=>c,Link:()=>u,NavLink:()=>h,Page:()=>w,hydrateArcanaJS:()=>b,useLocation:()=>y,usePage:()=>R,useParams:()=>N,useQuery:()=>k,useRouter:()=>d});const a=require("react");var r=e.n(a);const n=({children:e})=>r().createElement(r().Fragment,null,e);function o(e,t){const r=global,n=Symbol.for(`ARCANAJS_CONTEXT_${e}`);return r[n]||(r[n]=(0,a.createContext)(t)),r[n]}const l=o("HeadContext",null),c=({children:e})=>{const t=(0,a.useContext)(l);return"undefined"==typeof window&&t&&r().Children.forEach(e,e=>{r().isValidElement(e)&&t.push(r().cloneElement(e,{"data-arcanajs-head":"true"}))}),(0,a.useEffect)(()=>{const t=[];return r().Children.forEach(e,e=>{if(r().isValidElement(e)){const a=e;if("title"===a.type)document.title=a.props.children;else if("meta"===a.type){const e=a.props;let r="meta";if(e.name&&(r+=`[name="${e.name}"]`),e.property&&(r+=`[property="${e.property}"]`),e.name||e.property){let a=document.querySelector(r+'[data-arcanajs-head="true"]')||document.querySelector(r);if(a)a.setAttribute("content",e.content),a.setAttribute("data-arcanajs-head","true"),t.push(a);else{const a=document.createElement("meta");Object.keys(e).forEach(t=>{a.setAttribute(t,e[t])}),a.setAttribute("data-arcanajs-head","true"),document.head.appendChild(a),t.push(a)}}}else if("link"===a.type){const e=a.props;let r="link";e.rel&&(r+=`[rel="${e.rel}"]`),e.href&&(r+=`[href="${e.href}"]`);let n=document.querySelector(r+'[data-arcanajs-head="true"]')||document.querySelector(r);if(n)n.setAttribute("data-arcanajs-head","true"),t.push(n);else{const a=document.createElement("link");Object.keys(e).forEach(t=>{a.setAttribute(t,e[t])}),a.setAttribute("data-arcanajs-head","true"),document.head.appendChild(a),t.push(a)}}}}),()=>{t.forEach(e=>{e.remove()})}},[e]),null},s=o("RouterContext",null),i=({value:e,children:t})=>r().createElement(s.Provider,{value:e},t),d=()=>{const e=(0,a.useContext)(s);if(!e)throw new Error("useRouter must be used within an ArcanaJSApp");return e};function m(){return m=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var a=arguments[t];for(var r in a)({}).hasOwnProperty.call(a,r)&&(e[r]=a[r])}return e},m.apply(null,arguments)}const u=({href:e,children:t,prefetch:a=!1,...n})=>{const{navigateTo:o,navigateToAsync:l}=d(),c=/^https?:\/\//.test(e);return r().createElement("a",m({href:e,onClick:async t=>{t.preventDefault(),c?window.open(e,"_blank","noopener,noreferrer"):l?await l(e):o(e)},onMouseEnter:()=>{a&&!c&&fetch(e,{method:"HEAD"}).catch(()=>{})},target:c?"_blank":void 0,rel:c?"noopener noreferrer":void 0},n),t)};function p(){return p=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var a=arguments[t];for(var r in a)({}).hasOwnProperty.call(a,r)&&(e[r]=a[r])}return e},p.apply(null,arguments)}const h=({href:e,activeClassName:t="active",className:a="",exact:n=!1,prefetch:o=!1,children:l,...c})=>{const{currentUrl:s}=d(),i=`${a} ${(n?s===e:s.startsWith(e))?t:""}`.trim();return r().createElement(u,p({href:e,className:i,prefetch:o},c),l)},f=o("PageContext",null),w=({data:e,title:t,children:a})=>r().createElement(f.Provider,{value:e},t&&r().createElement(c,null,r().createElement("title",null,t)),a),g=require("react-dom/client"),v=e=>{const{initialPage:t,initialData:n,initialParams:o={},initialUrl:l,csrfToken:c,views:s,layout:d,onNavigate:m,cacheLimit:u=50}=e,[p,h]=(0,a.useState)(t),[f,g]=(0,a.useState)(n),[v,x]=(0,a.useState)(o),[E,b]=(0,a.useState)(l||("undefined"!=typeof window?window.location.pathname:"/")),[y,R]=(0,a.useState)(!1),N=r().useRef(new Map),k=r().useRef(null);(0,a.useEffect)(()=>{"undefined"==typeof window||window.history.state||window.history.replaceState({page:t,data:n,params:o},"",window.location.href);const e=e=>{if(e.state)h(e.state.page),g(e.state.data),x(e.state.params||{}),b(window.location.pathname);else{const e=window.location.pathname;j(e).catch(()=>{window.location.reload()})}};return window.addEventListener("popstate",e),()=>{var t;window.removeEventListener("popstate",e),null===(t=k.current)||void 0===t||t.abort()}},[]);const j=async e=>{var t;const a=N.current;if(a.has(e)){const t=a.get(e);if(h(t.page),g(t.data),x(t.params||{}),b(e),window.history.pushState(t,"",e),"undefined"!=typeof window)try{window.scrollTo({top:0,behavior:"smooth"})}catch{}return void(m&&m(e))}R(!0),null===(t=k.current)||void 0===t||t.abort();const r=new AbortController;k.current=r;try{const t=await fetch(e,{headers:{"X-ArcanaJS-Request":"true"},cache:"no-store",signal:r.signal});if(!t.ok){if(404===t.status)return h("NotFoundPage"),b(e),void window.history.pushState({page:"NotFoundPage",data:{}},"",e);throw new Error(`Navigation failed: ${t.status} ${t.statusText}`)}if(!(t.headers.get("content-type")||"").includes("application/json"))return void(window.location.href=e);const a=await t.json(),n={page:a.page,data:a.data,params:a.params||{}};if(((e,t)=>{const a=N.current;if(a.has(e)&&a.delete(e),a.set(e,t),a.size>u){const e=a.keys().next().value;void 0!==e&&a.delete(e)}})(e,n),window.history.pushState({page:n.page,data:n.data,params:n.params},"",e),h(n.page),g(n.data),x(n.params||{}),b(e),"undefined"!=typeof window)try{window.scrollTo({top:0,behavior:"smooth"})}catch{}m&&m(e)}catch(e){if("AbortError"===(null==e?void 0:e.name))return;throw console.error("Navigation failed",e),e}finally{k.current===r&&(k.current=null),R(!1)}},S=(()=>{const e=s[p]||s.NotFoundPage||(()=>r().createElement("div",null,"404 Not Found"));return r().createElement(w,{data:f},r().createElement(e,{data:f,navigateTo:j,params:v}))})();return r().createElement(i,{value:{navigateTo:(...e)=>{j(e[0])},navigateToAsync:j,currentPage:p,currentUrl:E,params:v,csrfToken:c,onNavigate:m,isNavigating:y}},d?r().createElement(d,null,S):r().createElement(r().Fragment,null,S))};function x({message:e="Something went wrong",statusCode:t=500,stack:a}){const r="development"===process.env.NODE_ENV;return React.createElement(w,null,React.createElement(c,null,React.createElement("title",null,t," - Server Error"),React.createElement("meta",{name:"description",content:"An error occurred on the server"})),React.createElement(n,null,React.createElement("div",{className:"relative min-h-screen overflow-hidden bg-black text-white flex flex-col justify-center items-center px-4 font-sans"},React.createElement("div",{className:"fixed inset-0 z-0 overflow-hidden pointer-events-none"},React.createElement("div",{className:"absolute inset-0 grid-pattern opacity-30"}),React.createElement("div",{className:"absolute top-1/4 right-1/4 w-96 h-96 bg-red-600 rounded-full opacity-20 blur-3xl animate-glow"}),React.createElement("div",{className:"absolute bottom-1/4 left-1/4 w-96 h-96 bg-orange-600 rounded-full opacity-10 blur-3xl animate-glow",style:{animationDelay:"2s"}}),React.createElement("div",{className:"absolute inset-0 hero-gradient"})),React.createElement("div",{className:"relative z-10 max-w-2xl w-full text-center animate-scale-in"},React.createElement("div",{className:"glass-card rounded-3xl p-12 border border-white/10 shadow-2xl"},React.createElement("div",{className:"mb-8"},React.createElement("div",{className:"text-6xl mb-6 animate-float"},React.createElement("span",{className:"text-red-500 drop-shadow-lg filter"},"⚠️")),React.createElement("h1",{className:"text-8xl font-bold text-transparent bg-clip-text bg-gradient-to-br from-red-500 to-orange-500 mb-4"},t),React.createElement("h2",{className:"text-3xl font-bold text-white mb-4"},"Server Error"),React.createElement("p",{className:"text-gray-400 text-lg leading-relaxed"},e)),React.createElement("div",{className:"flex flex-col sm:flex-row gap-4 justify-center mb-8"},React.createElement(u,{href:"/",className:"btn-primary px-8 py-3.5 text-white font-semibold rounded-xl inline-flex items-center justify-center gap-2 w-full sm:w-auto bg-gradient-to-r from-red-600 to-orange-600 hover:from-red-500 hover:to-orange-500 border-none shadow-red-900/20"},React.createElement("svg",{className:"w-5 h-5",fill:"none",stroke:"currentColor",viewBox:"0 0 24 24"},React.createElement("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M3 12l2-2m0 0l7-7 7 7M5 10v10a1 1 0 001 1h3m10-11l2 2m-2-2v10a1 1 0 01-1 1h-3m-6 0a1 1 0 001-1v-4a1 1 0 011-1h2a1 1 0 011 1v4a1 1 0 001 1m-6 0h6"})),"Go Home"),React.createElement("button",{onClick:()=>window.location.reload(),className:"btn-secondary px-8 py-3.5 text-white font-semibold rounded-xl inline-flex items-center justify-center gap-2 w-full sm:w-auto"},React.createElement("svg",{className:"w-5 h-5",fill:"none",stroke:"currentColor",viewBox:"0 0 24 24"},React.createElement("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M4 4v5h.582m15.356 2A8.001 8.001 0 004.582 9m0 0H9m11 11v-5h-.581m0 0a8.003 8.003 0 01-15.357-2m15.357 2H15"})),"Try Again")),r&&a&&React.createElement("div",{className:"mt-8 text-left animate-slide-up"},React.createElement("details",{className:"bg-black/40 border border-white/10 rounded-xl overflow-hidden group"},React.createElement("summary",{className:"cursor-pointer font-medium text-gray-300 p-4 hover:bg-white/5 transition-colors flex items-center justify-between select-none"},React.createElement("span",null,"Stack Trace (Development Only)"),React.createElement("svg",{className:"w-5 h-5 text-gray-500 group-open:rotate-180 transition-transform",fill:"none",stroke:"currentColor",viewBox:"0 0 24 24"},React.createElement("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M19 9l-7 7-7-7"}))),React.createElement("pre",{className:"text-xs text-red-300/80 p-4 overflow-x-auto whitespace-pre-wrap font-mono border-t border-white/5 bg-black/20"},a)))),React.createElement("div",{className:"mt-8 text-gray-500 text-sm"},"If this problem persists, please"," ",React.createElement(u,{href:"/contact",className:"text-red-400 hover:text-red-300 underline transition-colors"},"contact support"),".")))))}function E({url:e}){return React.createElement(w,null,React.createElement(c,null,React.createElement("title",null,"404 - Page Not Found"),React.createElement("meta",{name:"description",content:"The page you're looking for doesn't exist"})),React.createElement(n,null,React.createElement("div",{className:"relative min-h-screen overflow-hidden bg-black text-white flex flex-col justify-center items-center px-4 font-sans"},React.createElement("div",{className:"fixed inset-0 z-0 overflow-hidden pointer-events-none"},React.createElement("div",{className:"absolute inset-0 grid-pattern opacity-30"}),React.createElement("div",{className:"absolute top-1/4 left-1/4 w-96 h-96 bg-orange-500 rounded-full opacity-20 blur-3xl animate-glow"}),React.createElement("div",{className:"absolute bottom-1/4 right-1/4 w-96 h-96 bg-purple-500 rounded-full opacity-10 blur-3xl animate-glow",style:{animationDelay:"2s"}}),React.createElement("div",{className:"absolute inset-0 hero-gradient"})),React.createElement("div",{className:"relative z-10 max-w-lg w-full text-center animate-scale-in"},React.createElement("div",{className:"glass-card rounded-3xl p-12 border border-white/10 shadow-2xl"},React.createElement("div",{className:"mb-8"},React.createElement("h1",{className:"text-9xl font-bold text-transparent bg-clip-text bg-gradient-to-br from-white to-gray-500 mb-4 animate-float"},"404"),React.createElement("h2",{className:"text-3xl font-bold text-white mb-4"},"Page Not Found"),React.createElement("p",{className:"text-gray-400 text-lg leading-relaxed"},e?React.createElement(React.Fragment,null,"The page ",React.createElement("span",{className:"text-orange-400"},'"',e,'"')," ","you're looking for doesn't exist."):"The page you're looking for doesn't exist.")),React.createElement("div",{className:"flex flex-col sm:flex-row gap-4 justify-center"},React.createElement(u,{href:"/",className:"btn-primary px-8 py-3.5 text-white font-semibold rounded-xl inline-flex items-center justify-center gap-2 w-full sm:w-auto"},React.createElement("svg",{className:"w-5 h-5",fill:"none",stroke:"currentColor",viewBox:"0 0 24 24"},React.createElement("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M3 12l2-2m0 0l7-7 7 7M5 10v10a1 1 0 001 1h3m10-11l2 2m-2-2v10a1 1 0 01-1 1h-3m-6 0a1 1 0 001-1v-4a1 1 0 011-1h2a1 1 0 011 1v4a1 1 0 001 1m-6 0h6"})),"Go Home"),React.createElement("button",{onClick:()=>window.history.back(),className:"btn-secondary px-8 py-3.5 text-white font-semibold rounded-xl inline-flex items-center justify-center gap-2 w-full sm:w-auto"},React.createElement("svg",{className:"w-5 h-5",fill:"none",stroke:"currentColor",viewBox:"0 0 24 24"},React.createElement("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M10 19l-7-7m0 0l7-7m-7 7h18"})),"Go Back"))),React.createElement("div",{className:"mt-8 text-gray-500 text-sm"},"If you believe this is an error, please"," ",React.createElement(u,{href:"/contact",className:"text-orange-400 hover:text-orange-300 underline transition-colors"},"contact support"),".")))))}const b=(e,t,a)=>{let n={};e.keys&&"function"==typeof e.keys?e.keys().forEach(t=>{const a=t.replace(/^\.\/(.*)\.tsx$/,"$1");n[a]=e(t).default}):n=e,n.NotFoundPage||(n.NotFoundPage=E),n.ErrorPage||(n.ErrorPage=x);const o=document.getElementById("root"),c=document.getElementById("__ARCANAJS_DATA__"),s={tags:[],push:()=>{}};if(o&&c)try{const{page:e,data:i,params:d,csrfToken:m}=JSON.parse(c.textContent||"{}");(0,g.hydrateRoot)(o,r().createElement(l.Provider,{value:s},r().createElement(v,{initialPage:e,initialData:i,initialParams:d,csrfToken:m,views:n,layout:t,onNavigate:(null==a?void 0:a.onNavigate)||(()=>{})})))}catch(e){console.error("Failed to parse initial data",e)}},y=()=>{const{currentUrl:e}=d();return{pathname:e,search:"undefined"!=typeof window?window.location.search:"",hash:"undefined"!=typeof window?window.location.hash:""}},R=()=>(0,a.useContext)(f),N=()=>{const e=(0,a.useContext)(s);if(!e)throw new Error("useParams must be used within an ArcanaJSApp");return e.params},k=()=>{const{search:e}=y();return new URLSearchParams(e)};var j=exports;for(var S in t)j[S]=t[S];t.__esModule&&Object.defineProperty(j,"__esModule",{value:!0})})();
2
+ //# sourceMappingURL=arcanajs.client.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"arcanajs.client.js","mappings":"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","sources":["webpack://arcanajs/webpack/bootstrap","webpack://arcanajs/webpack/runtime/compat get default export","webpack://arcanajs/webpack/runtime/define property getters","webpack://arcanajs/webpack/runtime/hasOwnProperty shorthand","webpack://arcanajs/webpack/runtime/make namespace object","webpack://arcanajs/external commonjs \"react\"","webpack://arcanajs/./src/lib/shared/components/Body.tsx","webpack://arcanajs/./src/lib/shared/utils/createSingletonContext.ts","webpack://arcanajs/./src/lib/shared/context/HeadContext.tsx","webpack://arcanajs/./src/lib/shared/components/Head.tsx","webpack://arcanajs/./src/lib/shared/hooks/useHead.ts","webpack://arcanajs/./src/lib/shared/context/RouterContext.tsx","webpack://arcanajs/./src/lib/shared/hooks/useRouter.ts","webpack://arcanajs/./src/lib/shared/components/Link.tsx","webpack://arcanajs/./src/lib/shared/components/NavLink.tsx","webpack://arcanajs/./src/lib/shared/context/PageContext.tsx","webpack://arcanajs/./src/lib/shared/components/Page.tsx","webpack://arcanajs/external commonjs \"react-dom/client\"","webpack://arcanajs/./src/lib/shared/core/ArcanaJSApp.tsx","webpack://arcanajs/./src/lib/shared/views/ErrorPage.tsx","webpack://arcanajs/./src/lib/shared/views/NotFoundPage.tsx","webpack://arcanajs/./src/lib/client/index.tsx","webpack://arcanajs/./src/lib/shared/hooks/useLocation.ts","webpack://arcanajs/./src/lib/shared/hooks/usePage.ts","webpack://arcanajs/./src/lib/shared/hooks/useParams.ts","webpack://arcanajs/./src/lib/shared/hooks/useQuery.ts"],"sourcesContent":["// The require scope\nvar __webpack_require__ = {};\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = (module) => {\n\tvar getter = module && module.__esModule ?\n\t\t() => (module['default']) :\n\t\t() => (module);\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","const __WEBPACK_NAMESPACE_OBJECT__ = require(\"react\");","import React from \"react\";\n\ninterface BodyProps {\n children: React.ReactNode;\n}\n\nconst Body: React.FC<BodyProps> = ({ children }) => {\n return <>{children}</>;\n};\nexport default Body;\n","import React, { createContext } from \"react\";\n\n/**\n * Creates a React Context that persists across multiple module loads (Webpack bundles vs Node require).\n * This is essential for SSR applications where the server bundle and dynamically loaded views\n * might reference different instances of the \"same\" context module.\n *\n * @param key A unique string key to identify this context globally\n * @param defaultValue The default value for the context\n * @returns A React Context instance (singleton)\n */\nexport function createSingletonContext<T>(\n key: string,\n defaultValue: T\n): React.Context<T> {\n const globalAny = global as any;\n const symbolKey = Symbol.for(`ARCANAJS_CONTEXT_${key}`);\n\n if (!globalAny[symbolKey]) {\n globalAny[symbolKey] = createContext<T>(defaultValue);\n }\n\n return globalAny[symbolKey];\n}\n","import React from \"react\";\nimport { createSingletonContext } from \"../utils/createSingletonContext\";\n\nexport interface HeadManager {\n tags: React.ReactNode[];\n push: (tags: React.ReactNode) => void;\n}\n\nexport const HeadContext = createSingletonContext<HeadManager | null>(\n \"HeadContext\",\n null\n);\n","import React, { useEffect } from \"react\";\nimport { useHead } from \"../hooks/useHead\";\n\nconst Head: React.FC<{ children: React.ReactNode }> = ({ children }) => {\n const headManager = useHead();\n\n // Server-side: Push tags to context\n if (typeof window === \"undefined\" && headManager) {\n React.Children.forEach(children, (child) => {\n if (React.isValidElement(child)) {\n headManager.push(\n React.cloneElement(child as React.ReactElement<any>, {\n \"data-arcanajs-head\": \"true\",\n })\n );\n }\n });\n }\n\n // Client-side: Update DOM\n useEffect(() => {\n const managedElements: HTMLElement[] = [];\n\n React.Children.forEach(children, (child) => {\n if (React.isValidElement(child)) {\n const reactElement = child as React.ReactElement<any>;\n if (reactElement.type === \"title\") {\n document.title = reactElement.props.children as string;\n } else if (reactElement.type === \"meta\") {\n const props = reactElement.props;\n // Try to find existing meta tag\n let selector = \"meta\";\n if (props.name) selector += `[name=\"${props.name}\"]`;\n if (props.property) selector += `[property=\"${props.property}\"]`;\n\n // Only select if we have a specific identifier\n if (props.name || props.property) {\n let element =\n document.querySelector(\n selector + '[data-arcanajs-head=\"true\"]'\n ) || document.querySelector(selector);\n\n if (element) {\n // Update existing\n element.setAttribute(\"content\", props.content);\n element.setAttribute(\"data-arcanajs-head\", \"true\");\n managedElements.push(element as HTMLElement);\n } else {\n // Create new\n const newMeta = document.createElement(\"meta\");\n Object.keys(props).forEach((key) => {\n newMeta.setAttribute(key, props[key]);\n });\n newMeta.setAttribute(\"data-arcanajs-head\", \"true\");\n document.head.appendChild(newMeta);\n managedElements.push(newMeta);\n }\n }\n } else if (reactElement.type === \"link\") {\n const props = reactElement.props;\n let selector = \"link\";\n if (props.rel) selector += `[rel=\"${props.rel}\"]`;\n if (props.href) selector += `[href=\"${props.href}\"]`;\n\n let element =\n document.querySelector(selector + '[data-arcanajs-head=\"true\"]') ||\n document.querySelector(selector);\n\n if (element) {\n element.setAttribute(\"data-arcanajs-head\", \"true\");\n managedElements.push(element as HTMLElement);\n } else {\n const newLink = document.createElement(\"link\");\n Object.keys(props).forEach((key) => {\n newLink.setAttribute(key, props[key]);\n });\n newLink.setAttribute(\"data-arcanajs-head\", \"true\");\n document.head.appendChild(newLink);\n managedElements.push(newLink);\n }\n }\n }\n });\n\n return () => {\n // Cleanup managed elements\n managedElements.forEach((el) => {\n // We remove the element to ensure clean state for the next page\n // Note: This might cause a momentary flicker if the next page re-adds it immediately\n el.remove();\n });\n };\n }, [children]);\n\n return null;\n};\nexport default Head;\n","import { useContext } from \"react\";\nimport { HeadContext } from \"../context/HeadContext\";\n\nexport const useHead = () => useContext(HeadContext);\n","import React from \"react\";\nimport { createSingletonContext } from \"../utils/createSingletonContext\";\n\nexport interface RouterContextType {\n navigateTo: (url: string) => void;\n // optional async variant for consumers that want a promise\n navigateToAsync?: (url: string) => Promise<void>;\n currentPage: string;\n currentUrl: string;\n params: Record<string, string>;\n csrfToken?: string;\n onNavigate?: (url: string) => void;\n isNavigating: boolean;\n}\n\nexport const RouterContext = createSingletonContext<RouterContextType | null>(\n \"RouterContext\",\n null\n);\n\nexport const RouterProvider: React.FC<{\n value: RouterContextType;\n children: React.ReactNode;\n}> = ({ value, children }) => {\n return (\n <RouterContext.Provider value={value}>{children}</RouterContext.Provider>\n );\n};\n","import { useContext } from \"react\";\nimport { RouterContext } from \"../context/RouterContext\";\n\nconst useRouter = () => {\n const context = useContext(RouterContext);\n if (!context) {\n throw new Error(\"useRouter must be used within an ArcanaJSApp\");\n }\n return context;\n};\nexport default useRouter;\n","import React from \"react\";\nimport useRouter from \"../hooks/useRouter\";\n\ninterface LinkProps extends React.AnchorHTMLAttributes<HTMLAnchorElement> {\n href: string;\n prefetch?: boolean;\n}\n\nconst Link: React.FC<LinkProps> = ({\n href,\n children,\n prefetch = false,\n ...props\n}) => {\n const { navigateTo, navigateToAsync } = useRouter();\n\n const isExternal = /^https?:\\/\\//.test(href);\n\n const handleClick = async (e: React.MouseEvent<HTMLAnchorElement>) => {\n e.preventDefault();\n if (isExternal) {\n // Open external links in a new tab\n window.open(href, \"_blank\", \"noopener,noreferrer\");\n } else if (navigateToAsync) {\n await navigateToAsync(href);\n } else {\n navigateTo(href);\n }\n };\n\n const handleMouseEnter = () => {\n if (prefetch && !isExternal) {\n // Prefetch using HEAD request to warm cache\n fetch(href, { method: \"HEAD\" }).catch(() => {});\n }\n };\n\n return (\n <a\n href={href}\n onClick={handleClick}\n onMouseEnter={handleMouseEnter}\n target={isExternal ? \"_blank\" : undefined}\n rel={isExternal ? \"noopener noreferrer\" : undefined}\n {...props}\n >\n {children}\n </a>\n );\n};\nexport default Link;\n","import React from \"react\";\nimport useRouter from \"../hooks/useRouter\";\nimport Link from \"./Link\";\n\ninterface NavLinkProps extends React.AnchorHTMLAttributes<HTMLAnchorElement> {\n href: string;\n activeClassName?: string;\n exact?: boolean;\n prefetch?: boolean;\n}\n\nconst NavLink: React.FC<NavLinkProps> = ({\n href,\n activeClassName = \"active\",\n className = \"\",\n exact = false,\n prefetch = false,\n children,\n ...props\n}) => {\n const { currentUrl } = useRouter();\n\n const isActive = exact ? currentUrl === href : currentUrl.startsWith(href);\n\n const combinedClassName = `${className} ${\n isActive ? activeClassName : \"\"\n }`.trim();\n\n return (\n <Link\n href={href}\n className={combinedClassName}\n prefetch={prefetch}\n {...props}\n >\n {children}\n </Link>\n );\n};\nexport default NavLink;\n","import { createSingletonContext } from \"../utils/createSingletonContext\";\n\n// PageContext holds the page data (may be null before hydration).\nexport const PageContext = createSingletonContext<any | null>(\n \"PageContext\",\n null\n);\n","import React from \"react\";\nimport { PageContext } from \"../context/PageContext\";\nimport Head from \"./Head\";\n\nconst Page = <T,>({\n data,\n title,\n children,\n}: {\n data?: T;\n title?: string;\n children: React.ReactNode;\n}) => {\n return (\n <PageContext.Provider value={data as unknown}>\n {title && (\n <Head>\n <title>{title}</title>\n </Head>\n )}\n {children}\n </PageContext.Provider>\n );\n};\nexport default Page;\n","const __WEBPACK_NAMESPACE_OBJECT__ = require(\"react-dom/client\");","import React, { useEffect, useState } from \"react\";\nimport Page from \"../components/Page\";\nimport { RouterProvider } from \"../context/RouterContext\";\n\nexport interface ArcanaJSAppProps<\n TData = any,\n TParams extends Record<string, string> = Record<string, string>\n> {\n initialPage: string;\n initialData: TData;\n initialParams?: TParams;\n initialUrl?: string;\n csrfToken?: string;\n views: Record<\n string,\n React.ComponentType<{\n data: TData;\n navigateTo: (url: string) => Promise<void>;\n params: TParams;\n }>\n >;\n layout?: React.FC<{ children: React.ReactNode }>;\n onNavigate?: (url: string) => void;\n /** Maximum number of entries to keep in the navigation cache */\n cacheLimit?: number;\n}\n\nexport const ArcanaJSApp = <\n TData = any,\n TParams extends Record<string, string> = Record<string, string>\n>(\n props: ArcanaJSAppProps<TData, TParams>\n) => {\n const {\n initialPage,\n initialData,\n initialParams = {} as TParams,\n initialUrl,\n csrfToken,\n views,\n layout: Layout,\n onNavigate,\n cacheLimit = 50,\n } = props;\n\n const [page, setPage] = useState<string>(initialPage);\n const [data, setData] = useState<TData>(initialData);\n const [params, setParams] = useState<TParams>(initialParams);\n const [url, setUrl] = useState<string>(\n initialUrl ||\n (typeof window !== \"undefined\" ? window.location.pathname : \"/\")\n );\n const [isNavigating, setIsNavigating] = useState(false);\n\n // Navigation cache to store previously visited pages (LRU via Map ordering)\n const navigationCache = React.useRef(\n new Map<string, { page: string; data: TData; params: TParams }>()\n );\n\n // Abort controller for in-flight navigation fetch\n const currentAbort = React.useRef<AbortController | null>(null);\n\n useEffect(() => {\n if (typeof window !== \"undefined\" && !window.history.state) {\n window.history.replaceState(\n { page: initialPage, data: initialData, params: initialParams },\n \"\",\n window.location.href\n );\n }\n\n const handlePopState = (event: PopStateEvent) => {\n if (event.state) {\n setPage(event.state.page);\n setData(event.state.data);\n setParams(event.state.params || ({} as TParams));\n setUrl(window.location.pathname);\n } else {\n // Try to fetch the page state instead of hard reload\n const path = window.location.pathname;\n void navigateTo(path).catch(() => {\n window.location.reload();\n });\n }\n };\n\n window.addEventListener(\"popstate\", handlePopState);\n return () => {\n window.removeEventListener(\"popstate\", handlePopState);\n currentAbort.current?.abort();\n };\n }, []);\n\n const setCache = (\n key: string,\n value: { page: string; data: TData; params: TParams }\n ) => {\n const map = navigationCache.current;\n if (map.has(key)) map.delete(key);\n map.set(key, value);\n if (map.size > cacheLimit) {\n const firstKey = map.keys().next().value;\n if (firstKey !== undefined) map.delete(firstKey);\n }\n };\n\n const navigateTo = async (newUrl: string): Promise<void> => {\n // Check cache first for instant navigation\n const map = navigationCache.current;\n if (map.has(newUrl)) {\n const cached = map.get(newUrl)!;\n setPage(cached.page);\n setData(cached.data);\n setParams(cached.params || ({} as TParams));\n setUrl(newUrl);\n window.history.pushState(cached, \"\", newUrl);\n\n if (typeof window !== \"undefined\") {\n try {\n window.scrollTo({ top: 0, behavior: \"smooth\" });\n } catch {\n // ignore in non-browser env or when smooth not supported\n }\n }\n\n if (onNavigate) onNavigate(newUrl);\n return;\n }\n\n setIsNavigating(true);\n\n // Abort previous request\n currentAbort.current?.abort();\n const controller = new AbortController();\n currentAbort.current = controller;\n\n try {\n const response = await fetch(newUrl, {\n headers: { \"X-ArcanaJS-Request\": \"true\" },\n cache: \"no-store\",\n signal: controller.signal,\n });\n\n if (!response.ok) {\n if (response.status === 404) {\n setPage(\"NotFoundPage\");\n setUrl(newUrl);\n window.history.pushState(\n { page: \"NotFoundPage\", data: {} },\n \"\",\n newUrl\n );\n return;\n }\n throw new Error(\n `Navigation failed: ${response.status} ${response.statusText}`\n );\n }\n\n const contentType = response.headers.get(\"content-type\") || \"\";\n if (!contentType.includes(\"application/json\")) {\n window.location.href = newUrl;\n return;\n }\n\n const json = await response.json();\n\n const payload = {\n page: json.page as string,\n data: json.data as TData,\n params: (json.params || {}) as TParams,\n };\n setCache(newUrl, payload);\n\n window.history.pushState(\n { page: payload.page, data: payload.data, params: payload.params },\n \"\",\n newUrl\n );\n\n setPage(payload.page);\n setData(payload.data);\n setParams(payload.params || ({} as TParams));\n setUrl(newUrl);\n\n if (typeof window !== \"undefined\") {\n try {\n window.scrollTo({ top: 0, behavior: \"smooth\" });\n } catch {\n // ignore\n }\n }\n\n if (onNavigate) onNavigate(newUrl);\n } catch (err: any) {\n if (err?.name === \"AbortError\") return;\n console.error(\"Navigation failed\", err);\n throw err;\n } finally {\n // Clear abort controller if it's still the one we set\n if (currentAbort.current === controller) currentAbort.current = null;\n setIsNavigating(false);\n }\n };\n\n const renderPage = () => {\n const Component = (views[page] ||\n views[\"NotFoundPage\"] ||\n (() => <div>404 Not Found</div>)) as React.ComponentType<{\n data: TData;\n navigateTo: (url: string) => Promise<void>;\n params: TParams;\n }>;\n\n return (\n <Page data={data}>\n <Component data={data} navigateTo={navigateTo} params={params} />\n </Page>\n );\n };\n\n const content = renderPage();\n\n return (\n <RouterProvider\n value={{\n // keep backward-compatible wrapper that doesn't return a promise\n navigateTo: (...args: any[]) => {\n void navigateTo(args[0]);\n },\n // new async API consumers can use `navigateToAsync` when available\n navigateToAsync: navigateTo,\n currentPage: page,\n currentUrl: url,\n params,\n csrfToken,\n onNavigate,\n isNavigating,\n }}\n >\n {Layout ? <Layout>{content}</Layout> : <>{content}</>}\n </RouterProvider>\n );\n};\n","import Body from \"../components/Body\";\nimport Head from \"../components/Head\";\nimport Link from \"../components/Link\";\nimport Page from \"../components/Page\";\ninterface ErrorPageProps {\n message?: string;\n statusCode?: number;\n stack?: string;\n}\n\nexport default function ErrorPage({\n message = \"Something went wrong\",\n statusCode = 500,\n stack,\n}: ErrorPageProps) {\n const isDevelopment = process.env.NODE_ENV === \"development\";\n\n return (\n <Page>\n <Head>\n <title>{statusCode} - Server Error</title>\n <meta name=\"description\" content=\"An error occurred on the server\" />\n </Head>\n <Body>\n <div className=\"relative min-h-screen overflow-hidden bg-black text-white flex flex-col justify-center items-center px-4 font-sans\">\n {/* Animated Background */}\n <div className=\"fixed inset-0 z-0 overflow-hidden pointer-events-none\">\n <div className=\"absolute inset-0 grid-pattern opacity-30\"></div>\n <div className=\"absolute top-1/4 right-1/4 w-96 h-96 bg-red-600 rounded-full opacity-20 blur-3xl animate-glow\"></div>\n <div\n className=\"absolute bottom-1/4 left-1/4 w-96 h-96 bg-orange-600 rounded-full opacity-10 blur-3xl animate-glow\"\n style={{ animationDelay: \"2s\" }}\n ></div>\n <div className=\"absolute inset-0 hero-gradient\"></div>\n </div>\n\n <div className=\"relative z-10 max-w-2xl w-full text-center animate-scale-in\">\n <div className=\"glass-card rounded-3xl p-12 border border-white/10 shadow-2xl\">\n <div className=\"mb-8\">\n <div className=\"text-6xl mb-6 animate-float\">\n <span className=\"text-red-500 drop-shadow-lg filter\">⚠️</span>\n </div>\n <h1 className=\"text-8xl font-bold text-transparent bg-clip-text bg-gradient-to-br from-red-500 to-orange-500 mb-4\">\n {statusCode}\n </h1>\n <h2 className=\"text-3xl font-bold text-white mb-4\">\n Server Error\n </h2>\n <p className=\"text-gray-400 text-lg leading-relaxed\">\n {message}\n </p>\n </div>\n\n <div className=\"flex flex-col sm:flex-row gap-4 justify-center mb-8\">\n <Link\n href=\"/\"\n className=\"btn-primary px-8 py-3.5 text-white font-semibold rounded-xl inline-flex items-center justify-center gap-2 w-full sm:w-auto bg-gradient-to-r from-red-600 to-orange-600 hover:from-red-500 hover:to-orange-500 border-none shadow-red-900/20\"\n >\n <svg\n className=\"w-5 h-5\"\n fill=\"none\"\n stroke=\"currentColor\"\n viewBox=\"0 0 24 24\"\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n strokeWidth={2}\n d=\"M3 12l2-2m0 0l7-7 7 7M5 10v10a1 1 0 001 1h3m10-11l2 2m-2-2v10a1 1 0 01-1 1h-3m-6 0a1 1 0 001-1v-4a1 1 0 011-1h2a1 1 0 011 1v4a1 1 0 001 1m-6 0h6\"\n />\n </svg>\n Go Home\n </Link>\n\n <button\n onClick={() => window.location.reload()}\n className=\"btn-secondary px-8 py-3.5 text-white font-semibold rounded-xl inline-flex items-center justify-center gap-2 w-full sm:w-auto\"\n >\n <svg\n className=\"w-5 h-5\"\n fill=\"none\"\n stroke=\"currentColor\"\n viewBox=\"0 0 24 24\"\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n strokeWidth={2}\n d=\"M4 4v5h.582m15.356 2A8.001 8.001 0 004.582 9m0 0H9m11 11v-5h-.581m0 0a8.003 8.003 0 01-15.357-2m15.357 2H15\"\n />\n </svg>\n Try Again\n </button>\n </div>\n\n {isDevelopment && stack && (\n <div className=\"mt-8 text-left animate-slide-up\">\n <details className=\"bg-black/40 border border-white/10 rounded-xl overflow-hidden group\">\n <summary className=\"cursor-pointer font-medium text-gray-300 p-4 hover:bg-white/5 transition-colors flex items-center justify-between select-none\">\n <span>Stack Trace (Development Only)</span>\n <svg\n className=\"w-5 h-5 text-gray-500 group-open:rotate-180 transition-transform\"\n fill=\"none\"\n stroke=\"currentColor\"\n viewBox=\"0 0 24 24\"\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n strokeWidth={2}\n d=\"M19 9l-7 7-7-7\"\n />\n </svg>\n </summary>\n <pre className=\"text-xs text-red-300/80 p-4 overflow-x-auto whitespace-pre-wrap font-mono border-t border-white/5 bg-black/20\">\n {stack}\n </pre>\n </details>\n </div>\n )}\n </div>\n\n <div className=\"mt-8 text-gray-500 text-sm\">\n If this problem persists, please{\" \"}\n <Link\n href=\"/contact\"\n className=\"text-red-400 hover:text-red-300 underline transition-colors\"\n >\n contact support\n </Link>\n .\n </div>\n </div>\n </div>\n </Body>\n </Page>\n );\n}\n","import Body from \"../components/Body\";\nimport Head from \"../components/Head\";\nimport Link from \"../components/Link\";\nimport Page from \"../components/Page\";\ninterface NotFoundPageProps {\n url?: string;\n}\n\nexport default function NotFoundPage({ url }: NotFoundPageProps) {\n return (\n <Page>\n <Head>\n <title>404 - Page Not Found</title>\n <meta\n name=\"description\"\n content=\"The page you're looking for doesn't exist\"\n />\n </Head>\n <Body>\n <div className=\"relative min-h-screen overflow-hidden bg-black text-white flex flex-col justify-center items-center px-4 font-sans\">\n {/* Animated Background */}\n <div className=\"fixed inset-0 z-0 overflow-hidden pointer-events-none\">\n <div className=\"absolute inset-0 grid-pattern opacity-30\"></div>\n <div className=\"absolute top-1/4 left-1/4 w-96 h-96 bg-orange-500 rounded-full opacity-20 blur-3xl animate-glow\"></div>\n <div\n className=\"absolute bottom-1/4 right-1/4 w-96 h-96 bg-purple-500 rounded-full opacity-10 blur-3xl animate-glow\"\n style={{ animationDelay: \"2s\" }}\n ></div>\n <div className=\"absolute inset-0 hero-gradient\"></div>\n </div>\n\n <div className=\"relative z-10 max-w-lg w-full text-center animate-scale-in\">\n <div className=\"glass-card rounded-3xl p-12 border border-white/10 shadow-2xl\">\n <div className=\"mb-8\">\n <h1 className=\"text-9xl font-bold text-transparent bg-clip-text bg-gradient-to-br from-white to-gray-500 mb-4 animate-float\">\n 404\n </h1>\n <h2 className=\"text-3xl font-bold text-white mb-4\">\n Page Not Found\n </h2>\n <p className=\"text-gray-400 text-lg leading-relaxed\">\n {url ? (\n <>\n The page <span className=\"text-orange-400\">\"{url}\"</span>{\" \"}\n you're looking for doesn't exist.\n </>\n ) : (\n \"The page you're looking for doesn't exist.\"\n )}\n </p>\n </div>\n\n <div className=\"flex flex-col sm:flex-row gap-4 justify-center\">\n <Link\n href=\"/\"\n className=\"btn-primary px-8 py-3.5 text-white font-semibold rounded-xl inline-flex items-center justify-center gap-2 w-full sm:w-auto\"\n >\n <svg\n className=\"w-5 h-5\"\n fill=\"none\"\n stroke=\"currentColor\"\n viewBox=\"0 0 24 24\"\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n strokeWidth={2}\n d=\"M3 12l2-2m0 0l7-7 7 7M5 10v10a1 1 0 001 1h3m10-11l2 2m-2-2v10a1 1 0 01-1 1h-3m-6 0a1 1 0 001-1v-4a1 1 0 011-1h2a1 1 0 011 1v4a1 1 0 001 1m-6 0h6\"\n />\n </svg>\n Go Home\n </Link>\n\n <button\n onClick={() => window.history.back()}\n className=\"btn-secondary px-8 py-3.5 text-white font-semibold rounded-xl inline-flex items-center justify-center gap-2 w-full sm:w-auto\"\n >\n <svg\n className=\"w-5 h-5\"\n fill=\"none\"\n stroke=\"currentColor\"\n viewBox=\"0 0 24 24\"\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n strokeWidth={2}\n d=\"M10 19l-7-7m0 0l7-7m-7 7h18\"\n />\n </svg>\n Go Back\n </button>\n </div>\n </div>\n <div className=\"mt-8 text-gray-500 text-sm\">\n If you believe this is an error, please{\" \"}\n <Link\n href=\"/contact\"\n className=\"text-orange-400 hover:text-orange-300 underline transition-colors\"\n >\n contact support\n </Link>\n .\n </div>\n </div>\n </div>\n </Body>\n </Page>\n );\n}\n","import React from \"react\";\nimport { hydrateRoot } from \"react-dom/client\";\nimport { HeadContext, HeadManager } from \"../shared/context/HeadContext\";\nimport { ArcanaJSApp } from \"../shared/core/ArcanaJSApp\";\nimport ErrorPage from \"../shared/views/ErrorPage\";\nimport NotFoundPage from \"../shared/views/NotFoundPage\";\n\n/**\n * Navigation options for configuring ArcanaJS behavior\n */\ninterface NavigationOptions {\n /**\n * Callback function called after each successful navigation\n * Useful for analytics, logging, or custom scroll behavior\n */\n onNavigate?: (url: string) => void;\n}\n\n// ============================================================================\n// Client Hydration Function\n// ============================================================================\n\n/**\n * Hydrate the ArcanaJS application on the client side\n *\n * This function initializes the React application on the client,\n * hydrating the server-rendered HTML with client-side interactivity.\n *\n * @param viewsOrContext - Either a views registry object or a webpack require.context\n * @param layout - Optional layout component to wrap all pages\n * @param options - Optional navigation configuration options\n *\n * @example\n * ```typescript\n * // With navigation options\n * import { hydrateArcanaJS } from 'arcanajs/client';\n *\n * // @ts-ignore\n * const views = require(\"arcana-views\");\n * \n * hydrateArcanaJS(views, undefined, {\n * onNavigate: (url) => {\n * // Track page views\n * gtag('event', 'page_view', { page_path: url });\n * }\n * });\n * ```\n */\nconst hydrateArcanaJS = (\n viewsOrContext: Record<string, React.FC<any>> | any,\n layout?: React.FC<any>,\n options?: NavigationOptions\n) => {\n let views: Record<string, React.FC<any>> = {};\n\n if (viewsOrContext.keys && typeof viewsOrContext.keys === \"function\") {\n viewsOrContext.keys().forEach((key: string) => {\n const viewName = key.replace(/^\\.\\/(.*)\\.tsx$/, \"$1\");\n views[viewName] = viewsOrContext(key).default;\n });\n } else {\n views = viewsOrContext;\n }\n\n // Add default error views if not present\n if (!views[\"NotFoundPage\"]) {\n views[\"NotFoundPage\"] = NotFoundPage;\n }\n if (!views[\"ErrorPage\"]) {\n views[\"ErrorPage\"] = ErrorPage;\n }\n\n const container = document.getElementById(\"root\");\n const dataScript = document.getElementById(\"__ARCANAJS_DATA__\");\n\n // Client-side HeadManager (noop for push, as Head handles client updates via useEffect)\n const headManager: HeadManager = {\n tags: [],\n push: () => {},\n };\n\n if (container && dataScript) {\n try {\n const { page, data, params, csrfToken } = JSON.parse(\n dataScript.textContent || \"{}\"\n );\n hydrateRoot(\n container,\n <HeadContext.Provider value={headManager}>\n <ArcanaJSApp\n initialPage={page}\n initialData={data}\n initialParams={params}\n csrfToken={csrfToken}\n views={views}\n layout={layout}\n onNavigate={options?.onNavigate || (() => {})}\n />\n </HeadContext.Provider>\n );\n } catch (e) {\n console.error(\"Failed to parse initial data\", e);\n }\n }\n};\nexport default hydrateArcanaJS;\n","import useRouter from \"./useRouter\";\n\nconst useLocation = () => {\n const { currentUrl } = useRouter();\n return {\n pathname: currentUrl,\n search: typeof window !== \"undefined\" ? window.location.search : \"\",\n hash: typeof window !== \"undefined\" ? window.location.hash : \"\",\n };\n};\nexport default useLocation;\n","import { useContext } from \"react\";\nimport { PageContext } from \"../context/PageContext\";\n\nconst usePage = <T = any>(): T => useContext(PageContext) as T;\nexport default usePage;\n","import { useContext } from \"react\";\nimport { RouterContext } from \"../context/RouterContext\";\n\nconst useParams = () => {\n const context = useContext(RouterContext);\n if (!context) {\n throw new Error(\"useParams must be used within an ArcanaJSApp\");\n }\n return context.params;\n};\nexport default useParams;\n","import useLocation from \"./useLocation\";\n\nconst useQuery = () => {\n const { search } = useLocation();\n return new URLSearchParams(search);\n};\nexport default useQuery;\n"],"names":["__webpack_require__","module","getter","__esModule","d","a","exports","definition","key","o","Object","defineProperty","enumerable","get","obj","prop","prototype","hasOwnProperty","call","Symbol","toStringTag","value","require","Body","children","React","createSingletonContext","defaultValue","globalAny","global","symbolKey","for","createContext","HeadContext","Head","headManager","useContext","window","forEach","child","push","useEffect","managedElements","reactElement","type","document","title","props","selector","name","property","element","querySelector","setAttribute","content","newMeta","createElement","keys","head","appendChild","rel","href","newLink","el","remove","RouterContext","RouterProvider","Provider","useRouter","context","Error","Link","prefetch","navigateTo","navigateToAsync","isExternal","test","_extends","onClick","async","e","preventDefault","open","onMouseEnter","handleMouseEnter","fetch","method","catch","target","undefined","NavLink","activeClassName","className","exact","currentUrl","combinedClassName","startsWith","trim","PageContext","Page","data","ArcanaJSApp","initialPage","initialData","initialParams","initialUrl","csrfToken","views","layout","Layout","onNavigate","cacheLimit","page","setPage","useState","setData","params","setParams","url","setUrl","location","pathname","isNavigating","setIsNavigating","navigationCache","Map","currentAbort","history","state","replaceState","handlePopState","event","path","reload","addEventListener","_currentAbort$current","removeEventListener","current","abort","_currentAbort$current2","map","has","newUrl","cached","pushState","scrollTo","top","behavior","controller","AbortController","response","headers","cache","signal","ok","status","statusText","includes","json","payload","setCache","delete","set","size","firstKey","next","err","console","error","renderPage","Component","args","currentPage","ErrorPage","message","statusCode","stack","isDevelopment","process","env","NODE_ENV","style","animationDelay","fill","stroke","viewBox","strokeLinecap","strokeLinejoin","strokeWidth","NotFoundPage","Fragment","back","hydrateArcanaJS","viewsOrContext","options","viewName","replace","default","container","getElementById","dataScript","tags","JSON","parse","textContent","hydrateRoot","useLocation","search","hash","usePage","useParams","useQuery","URLSearchParams"],"ignoreList":[],"sourceRoot":""}
package/dist/arcanajs.js CHANGED
@@ -1,2 +1,3 @@
1
- (()=>{"use strict";var __webpack_modules__={3:(e,t,r)=>{r.d(t,{g:()=>a});const a=(0,r(100).$)("HeadContext",null)},15:e=>{e.exports=require("react")},38:(e,t,r)=>{r.d(t,{p:()=>a});const a=e=>(t,r,a)=>{let n=t.path.substring(1);if(""===n&&(n="index"),e[n])return r.renderPage(n,{});for(const t of Object.keys(e)){if(!t.includes("["))continue;const e=t.split("/"),a=n.split("/");if(e.length!==a.length)continue;let o=!0;const s={};for(let t=0;t<e.length;t++){const r=e[t],n=a[t];if(r.startsWith("[")&&r.endsWith("]"))s[r.slice(1,-1)]=n;else if(r!==n){o=!1;break}}if(o)return r.renderPage(t,{},s)}a()}},47:(e,t,r)=>{r.d(t,{C:()=>u}),r(252);var a=r(896),n=r.n(a),o=r(15),s=r.n(o);const c=require("react-dom/server");var i=r(3),l=r(178);const _='<!DOCTYPE html>\n<html lang="en">\n <head>\n <meta charset="UTF-8" />\n <meta name="viewport" content="width=device-width, initial-scale=1.0" />\n \x3c!--HEAD_CONTENT--\x3e\n </head>\n <body>\n <div id="root">\x3c!--APP_CONTENT--\x3e</div>\n \x3c!--ARCANAJS_DATA_SCRIPT--\x3e\n </body>\n</html>',u=e=>{const{views:t,indexFile:r,layout:a}=e;let o=null;return(e,u,d)=>{u.renderPage=(d,p={},h={})=>{const m=u.locals.csrfToken;if(e.get("X-ArcanaJS-Request")||"json"===e.query.format)return u.json({page:d,data:p,params:h,csrfToken:m});try{const f=[],E={tags:f,push:e=>f.push(e)},w=(0,c.renderToString)(s().createElement(i.g.Provider,{value:E},s().createElement(l.l,{initialPage:d,initialData:p,initialParams:h,initialUrl:e.path,csrfToken:m,views:t,layout:a}))),g=(0,c.renderToString)(s().createElement(s().Fragment,null,...f));(e=>{if("production"===process.env.NODE_ENV&&o)return e(null,o);r&&n().existsSync(r)?n().readFile(r,"utf8",(t,r)=>{t||"production"!==process.env.NODE_ENV||(o=r),e(t,r)}):("production"===process.env.NODE_ENV&&(o=_),e(null,_))})((e,t)=>{if(e)return console.error("Error reading index.html",e),u.status(500).send("Server Error");var r;const a=`<script id="__ARCANAJS_DATA__" type="application/json">${r={page:d,data:p,params:h,csrfToken:m},JSON.stringify(r).replace(/</g,"\\u003c")}<\/script>`,n=process.env.ARCANA_HMR_PORT?`\n <script>\n (function() {\n const socket = new WebSocket("ws://localhost:${process.env.ARCANA_HMR_PORT}");\n socket.onmessage = function(event) {\n const data = JSON.parse(event.data);\n if (data.type === "reload") {\n window.location.reload();\n }\n };\n })();\n <\/script>`:"",o=t.replace("\x3c!--HEAD_CONTENT--\x3e",g).replace("\x3c!--APP_CONTENT--\x3e",w).replace("\x3c!--ARCANAJS_DATA_SCRIPT--\x3e",a+n);u.send(o)})}catch(e){return console.error("SSR Error:",e),u.status(500).send("Internal Server Error")}return u},d()}}},100:(e,t,r)=>{r.d(t,{$:()=>n});var a=r(15);function n(e,t){const r=global,n=Symbol.for(`ARCANAJS_CONTEXT_${e}`);return r[n]||(r[n]=(0,a.createContext)(t)),r[n]}},168:(e,t,r)=>{r.d(t,{A:()=>s});var a=r(15),n=r.n(a),o=r(3);const s=({children:e})=>{const t=(0,a.useContext)(o.g);return"undefined"==typeof window&&t&&n().Children.forEach(e,e=>{n().isValidElement(e)&&t.push(n().cloneElement(e,{"data-arcanajs-head":"true"}))}),(0,a.useEffect)(()=>{const t=[];return n().Children.forEach(e,e=>{if(n().isValidElement(e)){const r=e;if("title"===r.type)document.title=r.props.children;else if("meta"===r.type){const e=r.props;let a="meta";if(e.name&&(a+=`[name="${e.name}"]`),e.property&&(a+=`[property="${e.property}"]`),e.name||e.property){let r=document.querySelector(a+'[data-arcanajs-head="true"]')||document.querySelector(a);if(r)r.setAttribute("content",e.content),r.setAttribute("data-arcanajs-head","true"),t.push(r);else{const r=document.createElement("meta");Object.keys(e).forEach(t=>{r.setAttribute(t,e[t])}),r.setAttribute("data-arcanajs-head","true"),document.head.appendChild(r),t.push(r)}}}else if("link"===r.type){const e=r.props;let a="link";e.rel&&(a+=`[rel="${e.rel}"]`),e.href&&(a+=`[href="${e.href}"]`);let n=document.querySelector(a+'[data-arcanajs-head="true"]')||document.querySelector(a);if(n)n.setAttribute("data-arcanajs-head","true"),t.push(n);else{const r=document.createElement("link");Object.keys(e).forEach(t=>{r.setAttribute(t,e[t])}),r.setAttribute("data-arcanajs-head","true"),document.head.appendChild(r),t.push(r)}}}}),()=>{t.forEach(e=>{e.remove()})}},[e]),null}},174:e=>{e.exports=require("compression")},178:(e,t,r)=>{r.d(t,{l:()=>c});var a=r(15),n=r.n(a),o=r(226),s=r(680);const c=e=>{const{initialPage:t,initialData:r,initialParams:c={},initialUrl:i,csrfToken:l,views:_,layout:u,onNavigate:d,cacheLimit:p=50}=e,[h,m]=(0,a.useState)(t),[f,E]=(0,a.useState)(r),[w,g]=(0,a.useState)(c),[v,x]=(0,a.useState)(i||("undefined"!=typeof window?window.location.pathname:"/")),[b,y]=(0,a.useState)(!1),P=n().useRef(new Map),R=n().useRef(null);(0,a.useEffect)(()=>{"undefined"==typeof window||window.history.state||window.history.replaceState({page:t,data:r,params:c},"",window.location.href);const e=e=>{if(e.state)m(e.state.page),E(e.state.data),g(e.state.params||{}),x(window.location.pathname);else{const e=window.location.pathname;k(e).catch(()=>{window.location.reload()})}};return window.addEventListener("popstate",e),()=>{var t;window.removeEventListener("popstate",e),null===(t=R.current)||void 0===t||t.abort()}},[]);const k=async e=>{var t;const r=P.current;if(r.has(e)){const t=r.get(e);if(m(t.page),E(t.data),g(t.params||{}),x(e),window.history.pushState(t,"",e),"undefined"!=typeof window)try{window.scrollTo({top:0,behavior:"smooth"})}catch{}return void(d&&d(e))}y(!0),null===(t=R.current)||void 0===t||t.abort();const a=new AbortController;R.current=a;try{const t=await fetch(e,{headers:{"X-ArcanaJS-Request":"true"},cache:"no-store",signal:a.signal});if(!t.ok){if(404===t.status)return m("NotFoundPage"),x(e),void window.history.pushState({page:"NotFoundPage",data:{}},"",e);throw new Error(`Navigation failed: ${t.status} ${t.statusText}`)}if(!(t.headers.get("content-type")||"").includes("application/json"))return void(window.location.href=e);const r=await t.json(),n={page:r.page,data:r.data,params:r.params||{}};if(((e,t)=>{const r=P.current;if(r.has(e)&&r.delete(e),r.set(e,t),r.size>p){const e=r.keys().next().value;void 0!==e&&r.delete(e)}})(e,n),window.history.pushState({page:n.page,data:n.data,params:n.params},"",e),m(n.page),E(n.data),g(n.params||{}),x(e),"undefined"!=typeof window)try{window.scrollTo({top:0,behavior:"smooth"})}catch{}d&&d(e)}catch(e){if("AbortError"===(null==e?void 0:e.name))return;throw console.error("Navigation failed",e),e}finally{R.current===a&&(R.current=null),y(!1)}},A=(()=>{const e=_[h]||_.NotFoundPage||(()=>n().createElement("div",null,"404 Not Found"));return n().createElement(o.A,{data:f},n().createElement(e,{data:f,navigateTo:k,params:w}))})();return n().createElement(s.p,{value:{navigateTo:(...e)=>{k(e[0])},navigateToAsync:k,currentPage:h,currentUrl:v,params:w,csrfToken:l,onNavigate:d,isNavigating:b}},u?n().createElement(u,null,A):n().createElement(n().Fragment,null,A))}},226:(e,t,r)=>{r.d(t,{A:()=>c});var a=r(15),n=r.n(a),o=r(854),s=r(168);const c=({data:e,title:t,children:r})=>n().createElement(o.N.Provider,{value:e},t&&n().createElement(s.A,null,n().createElement("title",null,t)),r)},252:e=>{e.exports=require("express")},287:(e,t,r)=>{r.d(t,{A:()=>c});var a=r(507),n=r(168),o=r(703),s=r(226);function c({url:e}){return React.createElement(s.A,null,React.createElement(n.A,null,React.createElement("title",null,"404 - Page Not Found"),React.createElement("meta",{name:"description",content:"The page you're looking for doesn't exist"})),React.createElement(a.A,null,React.createElement("div",{className:"relative min-h-screen overflow-hidden bg-black text-white flex flex-col justify-center items-center px-4 font-sans"},React.createElement("div",{className:"fixed inset-0 z-0 overflow-hidden pointer-events-none"},React.createElement("div",{className:"absolute inset-0 grid-pattern opacity-30"}),React.createElement("div",{className:"absolute top-1/4 left-1/4 w-96 h-96 bg-orange-500 rounded-full opacity-20 blur-3xl animate-glow"}),React.createElement("div",{className:"absolute bottom-1/4 right-1/4 w-96 h-96 bg-purple-500 rounded-full opacity-10 blur-3xl animate-glow",style:{animationDelay:"2s"}}),React.createElement("div",{className:"absolute inset-0 hero-gradient"})),React.createElement("div",{className:"relative z-10 max-w-lg w-full text-center animate-scale-in"},React.createElement("div",{className:"glass-card rounded-3xl p-12 border border-white/10 shadow-2xl"},React.createElement("div",{className:"mb-8"},React.createElement("h1",{className:"text-9xl font-bold text-transparent bg-clip-text bg-gradient-to-br from-white to-gray-500 mb-4 animate-float"},"404"),React.createElement("h2",{className:"text-3xl font-bold text-white mb-4"},"Page Not Found"),React.createElement("p",{className:"text-gray-400 text-lg leading-relaxed"},e?React.createElement(React.Fragment,null,"The page ",React.createElement("span",{className:"text-orange-400"},'"',e,'"')," ","you're looking for doesn't exist."):"The page you're looking for doesn't exist.")),React.createElement("div",{className:"flex flex-col sm:flex-row gap-4 justify-center"},React.createElement(o.A,{href:"/",className:"btn-primary px-8 py-3.5 text-white font-semibold rounded-xl inline-flex items-center justify-center gap-2 w-full sm:w-auto"},React.createElement("svg",{className:"w-5 h-5",fill:"none",stroke:"currentColor",viewBox:"0 0 24 24"},React.createElement("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M3 12l2-2m0 0l7-7 7 7M5 10v10a1 1 0 001 1h3m10-11l2 2m-2-2v10a1 1 0 01-1 1h-3m-6 0a1 1 0 001-1v-4a1 1 0 011-1h2a1 1 0 011 1v4a1 1 0 001 1m-6 0h6"})),"Go Home"),React.createElement("button",{onClick:()=>window.history.back(),className:"btn-secondary px-8 py-3.5 text-white font-semibold rounded-xl inline-flex items-center justify-center gap-2 w-full sm:w-auto"},React.createElement("svg",{className:"w-5 h-5",fill:"none",stroke:"currentColor",viewBox:"0 0 24 24"},React.createElement("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M10 19l-7-7m0 0l7-7m-7 7h18"})),"Go Back"))),React.createElement("div",{className:"mt-8 text-gray-500 text-sm"},"If you believe this is an error, please"," ",React.createElement(o.A,{href:"/contact",className:"text-orange-400 hover:text-orange-300 underline transition-colors"},"contact support"),".")))))}},322:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{__webpack_require__.d(__webpack_exports__,{A:()=>__WEBPACK_DEFAULT_EXPORT__});var compression__WEBPACK_IMPORTED_MODULE_0__=__webpack_require__(174),compression__WEBPACK_IMPORTED_MODULE_0___default=__webpack_require__.n(compression__WEBPACK_IMPORTED_MODULE_0__),cookie_parser__WEBPACK_IMPORTED_MODULE_1__=__webpack_require__(898),cookie_parser__WEBPACK_IMPORTED_MODULE_1___default=__webpack_require__.n(cookie_parser__WEBPACK_IMPORTED_MODULE_1__),express__WEBPACK_IMPORTED_MODULE_2__=__webpack_require__(252),express__WEBPACK_IMPORTED_MODULE_2___default=__webpack_require__.n(express__WEBPACK_IMPORTED_MODULE_2__),fs__WEBPACK_IMPORTED_MODULE_3__=__webpack_require__(896),fs__WEBPACK_IMPORTED_MODULE_3___default=__webpack_require__.n(fs__WEBPACK_IMPORTED_MODULE_3__),helmet__WEBPACK_IMPORTED_MODULE_4__=__webpack_require__(525),helmet__WEBPACK_IMPORTED_MODULE_4___default=__webpack_require__.n(helmet__WEBPACK_IMPORTED_MODULE_4__),path__WEBPACK_IMPORTED_MODULE_5__=__webpack_require__(928),path__WEBPACK_IMPORTED_MODULE_5___default=__webpack_require__.n(path__WEBPACK_IMPORTED_MODULE_5__),_shared_views_ErrorPage__WEBPACK_IMPORTED_MODULE_6__=__webpack_require__(944),_shared_views_NotFoundPage__WEBPACK_IMPORTED_MODULE_7__=__webpack_require__(287),_ArcanaJSMiddleware__WEBPACK_IMPORTED_MODULE_8__=__webpack_require__(47),_CsrfMiddleware__WEBPACK_IMPORTED_MODULE_9__=__webpack_require__(570),_DynamicRouter__WEBPACK_IMPORTED_MODULE_10__=__webpack_require__(38),_ResponseHandlerMiddleware__WEBPACK_IMPORTED_MODULE_11__=__webpack_require__(615);class ArcanaJSServer{constructor(e){this.config=e,this.app=express__WEBPACK_IMPORTED_MODULE_2___default()(),this.initialize()}normalizeDb(e){if(!e)return e;if("function"==typeof e.close)return e;if("function"==typeof e.disconnect)return{client:e,close:async()=>{await e.disconnect()}};if(e.client&&e.db){const t=e.client;return{client:t,db:e.db,close:async()=>{if(t&&"function"==typeof t.close)await t.close();else{if(!t||"function"!=typeof t.disconnect)throw new Error("No close method on client");await t.disconnect()}}}}return e&&"function"==typeof e.close&&e.connect?{client:e,close:async()=>{await e.close()}}:"function"==typeof e.end||"function"==typeof e.query?{client:e,close:async()=>{if("function"==typeof e.end)await e.end();else{if("function"!=typeof e.close)throw new Error("No close/end method on SQL client");await e.close()}}}:e.s&&e.s.client&&"function"==typeof e.s.client.close?{client:e.s.client,db:e,close:async()=>{await e.s.client.close()}}:{client:e,close:async()=>{throw new Error("No known close method on DB client")}}}initialize(){const{staticDir:e="public",distDir:t="dist/public",indexFile:r="dist/public/index.html",views:a,viewsContext:n,routes:o,layout:s,apiRoutes:c,apiBase:i="/api"}=this.config,l=process.cwd();let _=a;!_&&n&&(_=this.loadViewsFromContext(n)),_||(_=this.loadViewsFromAlias()),_||(_=this.discoverViews()),_&&0!==Object.keys(_).length||(console.warn("No views found. Please check your views directory."),_={}),_.NotFoundPage=_.NotFoundPage||_shared_views_NotFoundPage__WEBPACK_IMPORTED_MODULE_7__.A,_.ErrorPage=_.ErrorPage||_shared_views_ErrorPage__WEBPACK_IMPORTED_MODULE_6__.A,this.app.use(helmet__WEBPACK_IMPORTED_MODULE_4___default()({contentSecurityPolicy:!1})),this.app.use(cookie_parser__WEBPACK_IMPORTED_MODULE_1___default()()),this.app.use((0,_CsrfMiddleware__WEBPACK_IMPORTED_MODULE_9__.V)()),this.app.use(_ResponseHandlerMiddleware__WEBPACK_IMPORTED_MODULE_11__.s),this.app.use((e,t,r)=>{e.db=this.app.locals.db,r()});const u={index:!1,maxAge:"production"===process.env.NODE_ENV?"1y":"0"},d=[path__WEBPACK_IMPORTED_MODULE_5___default().resolve(l,t),path__WEBPACK_IMPORTED_MODULE_5___default().resolve(l,e)].filter((e,t,r)=>r.indexOf(e)===t);for(const e of d)this.app.use(express__WEBPACK_IMPORTED_MODULE_2___default().static(e,u));if(this.app.use(compression__WEBPACK_IMPORTED_MODULE_0___default()()),this.app.use((0,_ArcanaJSMiddleware__WEBPACK_IMPORTED_MODULE_8__.C)({views:_,indexFile:path__WEBPACK_IMPORTED_MODULE_5___default().resolve(l,r),layout:s})),this.config.dbConnect)try{const e=this.config.dbConnect(),t=e=>{try{this.app.locals.db=this.normalizeDb(e)||e,console.log("Database connection attached to app.locals.db")}catch(t){this.app.locals.db=e,console.warn("DB connection attached without full normalization",t)}};e&&e.then&&"function"==typeof e.then?e.then(t).catch(e=>console.error("Error establishing DB connection:",e)):t(e)}catch(e){console.error("Error calling dbConnect:",e)}const p=(e,t)=>{if(!e)return;const r=Array.isArray(e)?e:[e];for(const e of r)e&&("function"==typeof e.getRouter?this.app.use(t||"/",e.getRouter()):this.app.use(t||"/",e))};try{p(c,i),c&&console.log(`API routes mounted at ${i}`)}catch(e){console.error("Error mounting apiRoutes:",e)}try{p(o)}catch(e){console.error("Error mounting routes:",e)}this.app.use((0,_DynamicRouter__WEBPACK_IMPORTED_MODULE_10__.p)(_)),this.app.use((e,t)=>{e.get("X-ArcanaJS-Request")||"json"===e.query.format?t.status(404).json({page:"NotFoundPage",data:{},params:{},csrfToken:t.locals.csrfToken}):t.status(404).renderPage("NotFoundPage")}),this.app.use((e,t,r,a)=>{console.error(e);const n="production"===process.env.NODE_ENV?"Internal Server Error":e.message;t.get("X-ArcanaJS-Request")||"json"===t.query.format?r.status(500).json({page:"ErrorPage",data:{message:n},params:{},csrfToken:r.locals.csrfToken}):r.status(500).renderPage("ErrorPage",{message:n})})}loadViewsFromContext(e){const t={};return e.keys().forEach(r=>{const a=r.replace(/^\.\/(.*)\.tsx$/,"$1");t[a]=e(r).default}),t}loadViewsFromAlias(){try{const e=__webpack_require__(369);if(e)return this.loadViewsFromContext(e)}catch(e){}}discoverViews(){const views={},viewsDir=this.config.viewsDir?path__WEBPACK_IMPORTED_MODULE_5___default().resolve(process.cwd(),this.config.viewsDir):path__WEBPACK_IMPORTED_MODULE_5___default().resolve(process.cwd(),"src/views");if(!fs__WEBPACK_IMPORTED_MODULE_3___default().existsSync(viewsDir))return views;const traverse=dir=>{const files=fs__WEBPACK_IMPORTED_MODULE_3___default().readdirSync(dir);files.forEach(file=>{const fullPath=path__WEBPACK_IMPORTED_MODULE_5___default().join(dir,file),stat=fs__WEBPACK_IMPORTED_MODULE_3___default().statSync(fullPath);if(stat.isDirectory())traverse(fullPath);else if(file.endsWith(".tsx")||file.endsWith(".jsx")){const relativePath=path__WEBPACK_IMPORTED_MODULE_5___default().relative(viewsDir,fullPath),viewName=relativePath.replace(/\.(tsx|jsx)$/,"");try{const requireFunc="undefined"!=typeof require?require:eval("require");if(file.endsWith(".tsx")||file.endsWith(".ts"))try{requireFunc("ts-node/register")}catch(e){}const pageModule=requireFunc(fullPath);views[viewName]=pageModule.default||pageModule}catch(e){console.error(`Failed to load view ${viewName}:`,e)}}})};return traverse(viewsDir),views}start(){const e=this.config.port||process.env.PORT||3e3;if(this.serverInstance=this.app.listen(e,()=>{console.log(`Server is running on http://localhost:${e}`)}),!1!==this.config.autoHandleSignals){const e=async()=>{try{await this.stop(),process.exit(0)}catch(e){console.error("Error during shutdown:",e),process.exit(1)}};this._sigintHandler=e,this._sigtermHandler=e,process.on("SIGINT",this._sigintHandler),process.on("SIGTERM",this._sigtermHandler)}}async stop(){this.serverInstance&&(await new Promise((e,t)=>{this.serverInstance.close(r=>{if(r)return t(r);e()})}),this.serverInstance=void 0,console.log("HTTP server stopped"));const e=this.app.locals.db;if(e){let t=!1;try{"function"==typeof e.disconnect&&(await e.disconnect(),t=!0,console.log("Database connection closed via disconnect()."))}catch(e){console.error("Error calling disconnect() on DB client:",e)}if(!t)try{"function"==typeof e.close&&(await e.close(),t=!0,console.log("Database connection closed via close()."))}catch(e){console.error("Error calling close() on DB client:",e)}if(!t)try{"function"==typeof e.end&&(await e.end(),t=!0,console.log("Database connection closed via end()."))}catch(e){console.error("Error calling end() on DB client:",e)}if(!t)try{const r=e.client&&e.client.close;r&&"function"==typeof r&&(await e.client.close(),t=!0,console.log("Database connection closed via db.client.close()."))}catch(e){console.error("Error calling db.client.close() on DB client:",e)}if(!t)try{const r=e.s&&e.s.client&&e.s.client.close;r&&"function"==typeof r&&(await e.s.client.close(),t=!0,console.log("Database connection closed via db.s.client.close()."))}catch(e){console.error("Error calling db.s.client.close() on DB client:",e)}t||console.warn("Could not find a supported close method on the DB client; connection may remain open.")}try{this._sigintHandler&&(process.removeListener("SIGINT",this._sigintHandler),this._sigintHandler=void 0),this._sigtermHandler&&(process.removeListener("SIGTERM",this._sigtermHandler),this._sigtermHandler=void 0)}catch(e){}}}const __WEBPACK_DEFAULT_EXPORT__=ArcanaJSServer},369:e=>{e.exports=require("arcana-views")},507:(e,t,r)=>{r.d(t,{A:()=>o});var a=r(15),n=r.n(a);const o=({children:e})=>n().createElement(n().Fragment,null,e)},525:e=>{e.exports=require("helmet")},570:(e,t,r)=>{r.d(t,{V:()=>s});const a=require("crypto");var n=r.n(a);const o="_csrf",s=()=>(e,t,r)=>{let a=e.cookies[o];a||(a=n().randomBytes(32).toString("hex"),t.cookie(o,a,{httpOnly:!0,secure:"production"===process.env.NODE_ENV,sameSite:"strict"})),t.locals.csrfToken=a;const s=e.method.toUpperCase();if(["POST","PUT","DELETE","PATCH"].includes(s)){const r=e.headers["x-csrf-token"];if(!r||r!==a)return t.status(403).json({error:"Invalid CSRF Token"})}r()}},615:(e,t,r)=>{r.d(t,{s:()=>a});const a=(e,t,r)=>{t.success=(e={},r="Success",a=200)=>t.status(a).json({success:!0,message:r,data:e,error:null}),t.error=(e="Error",r=500,a=null,n=null)=>{const o=a?"object"==typeof a&&null!==a?a instanceof Error?a.toString():a:a.toString():null;return t.status(r).json({success:!1,message:e,data:n,error:o})},r()}},680:(e,t,r)=>{r.d(t,{p:()=>s,z:()=>o});var a=r(15),n=r.n(a);const o=(0,r(100).$)("RouterContext",null),s=({value:e,children:t})=>n().createElement(o.Provider,{value:e},t)},703:(e,t,r)=>{r.d(t,{A:()=>c});var a=r(15),n=r.n(a),o=r(981);function s(){return s=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var a in r)({}).hasOwnProperty.call(r,a)&&(e[a]=r[a])}return e},s.apply(null,arguments)}const c=({href:e,children:t,prefetch:r=!1,...a})=>{const{navigateTo:c,navigateToAsync:i}=(0,o.A)(),l=/^https?:\/\//.test(e);return n().createElement("a",s({href:e,onClick:async t=>{t.preventDefault(),l?window.open(e,"_blank","noopener,noreferrer"):i?await i(e):c(e)},onMouseEnter:()=>{r&&!l&&fetch(e,{method:"HEAD"}).catch(()=>{})},target:l?"_blank":void 0,rel:l?"noopener noreferrer":void 0},a),t)}},854:(e,t,r)=>{r.d(t,{N:()=>a});const a=(0,r(100).$)("PageContext",null)},896:e=>{e.exports=require("fs")},898:e=>{e.exports=require("cookie-parser")},928:e=>{e.exports=require("path")},944:(e,t,r)=>{r.d(t,{A:()=>c});var a=r(507),n=r(168),o=r(703),s=r(226);function c({message:e="Something went wrong",statusCode:t=500,stack:r}){const c="development"===process.env.NODE_ENV;return React.createElement(s.A,null,React.createElement(n.A,null,React.createElement("title",null,t," - Server Error"),React.createElement("meta",{name:"description",content:"An error occurred on the server"})),React.createElement(a.A,null,React.createElement("div",{className:"relative min-h-screen overflow-hidden bg-black text-white flex flex-col justify-center items-center px-4 font-sans"},React.createElement("div",{className:"fixed inset-0 z-0 overflow-hidden pointer-events-none"},React.createElement("div",{className:"absolute inset-0 grid-pattern opacity-30"}),React.createElement("div",{className:"absolute top-1/4 right-1/4 w-96 h-96 bg-red-600 rounded-full opacity-20 blur-3xl animate-glow"}),React.createElement("div",{className:"absolute bottom-1/4 left-1/4 w-96 h-96 bg-orange-600 rounded-full opacity-10 blur-3xl animate-glow",style:{animationDelay:"2s"}}),React.createElement("div",{className:"absolute inset-0 hero-gradient"})),React.createElement("div",{className:"relative z-10 max-w-2xl w-full text-center animate-scale-in"},React.createElement("div",{className:"glass-card rounded-3xl p-12 border border-white/10 shadow-2xl"},React.createElement("div",{className:"mb-8"},React.createElement("div",{className:"text-6xl mb-6 animate-float"},React.createElement("span",{className:"text-red-500 drop-shadow-lg filter"},"⚠️")),React.createElement("h1",{className:"text-8xl font-bold text-transparent bg-clip-text bg-gradient-to-br from-red-500 to-orange-500 mb-4"},t),React.createElement("h2",{className:"text-3xl font-bold text-white mb-4"},"Server Error"),React.createElement("p",{className:"text-gray-400 text-lg leading-relaxed"},e)),React.createElement("div",{className:"flex flex-col sm:flex-row gap-4 justify-center mb-8"},React.createElement(o.A,{href:"/",className:"btn-primary px-8 py-3.5 text-white font-semibold rounded-xl inline-flex items-center justify-center gap-2 w-full sm:w-auto bg-gradient-to-r from-red-600 to-orange-600 hover:from-red-500 hover:to-orange-500 border-none shadow-red-900/20"},React.createElement("svg",{className:"w-5 h-5",fill:"none",stroke:"currentColor",viewBox:"0 0 24 24"},React.createElement("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M3 12l2-2m0 0l7-7 7 7M5 10v10a1 1 0 001 1h3m10-11l2 2m-2-2v10a1 1 0 01-1 1h-3m-6 0a1 1 0 001-1v-4a1 1 0 011-1h2a1 1 0 011 1v4a1 1 0 001 1m-6 0h6"})),"Go Home"),React.createElement("button",{onClick:()=>window.location.reload(),className:"btn-secondary px-8 py-3.5 text-white font-semibold rounded-xl inline-flex items-center justify-center gap-2 w-full sm:w-auto"},React.createElement("svg",{className:"w-5 h-5",fill:"none",stroke:"currentColor",viewBox:"0 0 24 24"},React.createElement("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M4 4v5h.582m15.356 2A8.001 8.001 0 004.582 9m0 0H9m11 11v-5h-.581m0 0a8.003 8.003 0 01-15.357-2m15.357 2H15"})),"Try Again")),c&&r&&React.createElement("div",{className:"mt-8 text-left animate-slide-up"},React.createElement("details",{className:"bg-black/40 border border-white/10 rounded-xl overflow-hidden group"},React.createElement("summary",{className:"cursor-pointer font-medium text-gray-300 p-4 hover:bg-white/5 transition-colors flex items-center justify-between select-none"},React.createElement("span",null,"Stack Trace (Development Only)"),React.createElement("svg",{className:"w-5 h-5 text-gray-500 group-open:rotate-180 transition-transform",fill:"none",stroke:"currentColor",viewBox:"0 0 24 24"},React.createElement("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M19 9l-7 7-7-7"}))),React.createElement("pre",{className:"text-xs text-red-300/80 p-4 overflow-x-auto whitespace-pre-wrap font-mono border-t border-white/5 bg-black/20"},r)))),React.createElement("div",{className:"mt-8 text-gray-500 text-sm"},"If this problem persists, please"," ",React.createElement(o.A,{href:"/contact",className:"text-red-400 hover:text-red-300 underline transition-colors"},"contact support"),".")))))}},981:(e,t,r)=>{r.d(t,{A:()=>o});var a=r(15),n=r(680);const o=()=>{const e=(0,a.useContext)(n.z);if(!e)throw new Error("useRouter must be used within an ArcanaJSApp");return e}}},__webpack_module_cache__={};function __webpack_require__(e){var t=__webpack_module_cache__[e];if(void 0!==t)return t.exports;var r=__webpack_module_cache__[e]={exports:{}};return __webpack_modules__[e](r,r.exports,__webpack_require__),r.exports}__webpack_require__.n=e=>{var t=e&&e.__esModule?()=>e.default:()=>e;return __webpack_require__.d(t,{a:t}),t},__webpack_require__.d=(e,t)=>{for(var r in t)__webpack_require__.o(t,r)&&!__webpack_require__.o(e,r)&&Object.defineProperty(e,r,{enumerable:!0,get:t[r]})},__webpack_require__.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),__webpack_require__.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})};var __webpack_exports__={};__webpack_require__.r(__webpack_exports__),__webpack_require__.d(__webpack_exports__,{ArcanaJSServer:()=>ArcanaJSServer.A,Body:()=>Body.A,Express:()=>external_express_.Express,Head:()=>Head.A,Link:()=>Link.A,NavLink:()=>components_NavLink,NextFunction:()=>external_express_.NextFunction,Page:()=>Page.A,Request:()=>external_express_.Request,Response:()=>external_express_.Response,Route:()=>server_Router,createArcanaServer:()=>createArcanaServer,hydrateArcanaJS:()=>client,useLocation:()=>hooks_useLocation,usePage:()=>hooks_usePage,useParams:()=>hooks_useParams,useQuery:()=>hooks_useQuery,useRouter:()=>useRouter.A});var ArcanaJSServer=__webpack_require__(322),Body=__webpack_require__(507),Head=__webpack_require__(168),Link=__webpack_require__(703),external_react_=__webpack_require__(15),external_react_default=__webpack_require__.n(external_react_),useRouter=__webpack_require__(981);function _extends(){return _extends=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var a in r)({}).hasOwnProperty.call(r,a)&&(e[a]=r[a])}return e},_extends.apply(null,arguments)}const NavLink=({href:e,activeClassName:t="active",className:r="",exact:a=!1,prefetch:n=!1,children:o,...s})=>{const{currentUrl:c}=(0,useRouter.A)(),i=`${r} ${(a?c===e:c.startsWith(e))?t:""}`.trim();return external_react_default().createElement(Link.A,_extends({href:e,className:i,prefetch:n},s),o)},components_NavLink=NavLink;var Page=__webpack_require__(226);const client_namespaceObject=require("react-dom/client");var HeadContext=__webpack_require__(3),ArcanaJSApp=__webpack_require__(178),ErrorPage=__webpack_require__(944),NotFoundPage=__webpack_require__(287);const hydrateArcanaJS=(e,t,r)=>{let a={};e.keys&&"function"==typeof e.keys?e.keys().forEach(t=>{const r=t.replace(/^\.\/(.*)\.tsx$/,"$1");a[r]=e(t).default}):a=e,a.NotFoundPage||(a.NotFoundPage=NotFoundPage.A),a.ErrorPage||(a.ErrorPage=ErrorPage.A);const n=document.getElementById("root"),o=document.getElementById("__ARCANAJS_DATA__"),s={tags:[],push:()=>{}};if(n&&o)try{const{page:e,data:c,params:i,csrfToken:l}=JSON.parse(o.textContent||"{}");(0,client_namespaceObject.hydrateRoot)(n,external_react_default().createElement(HeadContext.g.Provider,{value:s},external_react_default().createElement(ArcanaJSApp.l,{initialPage:e,initialData:c,initialParams:i,csrfToken:l,views:a,layout:t,onNavigate:(null==r?void 0:r.onNavigate)||(()=>{})})))}catch(e){console.error("Failed to parse initial data",e)}},client=hydrateArcanaJS,useLocation=()=>{const{currentUrl:e}=(0,useRouter.A)();return{pathname:e,search:"undefined"!=typeof window?window.location.search:"",hash:"undefined"!=typeof window?window.location.hash:""}},hooks_useLocation=useLocation;var PageContext=__webpack_require__(854);const usePage=()=>(0,external_react_.useContext)(PageContext.N),hooks_usePage=usePage;var RouterContext=__webpack_require__(680);const useParams=()=>{const e=(0,external_react_.useContext)(RouterContext.z);if(!e)throw new Error("useParams must be used within an ArcanaJSApp");return e.params},hooks_useParams=useParams,useQuery=()=>{const{search:e}=hooks_useLocation();return new URLSearchParams(e)},hooks_useQuery=useQuery;var external_express_=__webpack_require__(252),external_express_default=__webpack_require__.n(external_express_);class ControllerBinder{static handle(e,t){let r;try{r=new e}catch(t){console.warn(`Failed to instantiate controller ${e.name}`,t),r=e}return async(a,n,o)=>{try{if("function"!=typeof r[t])throw new Error(`Method ${t} not found on controller ${e.name}`);await r[t](a,n,o)}catch(e){o(e)}}}}class Router{constructor(){this.router=external_express_default().Router(),this.middlewareStack=[],this.prefixStack=[]}static create(){return new Router}middleware(...e){const t=this._clone();return t.middlewareStack=[...this.middlewareStack,...e],t}prefix(e){const t=this._clone();return t.prefixStack=[...this.prefixStack,e.replace(/^\/|\/$/g,"")],t}group(e){return e(this),this}get(e,...t){const r=t.pop(),a=t;return this._addRoute("get",e,r,a)}post(e,...t){const r=t.pop(),a=t;return this._addRoute("post",e,r,a)}put(e,...t){const r=t.pop(),a=t;return this._addRoute("put",e,r,a)}delete(e,...t){const r=t.pop(),a=t;return this._addRoute("delete",e,r,a)}patch(e,...t){const r=t.pop(),a=t;return this._addRoute("patch",e,r,a)}options(e,...t){const r=t.pop(),a=t;return this._addRoute("options",e,r,a)}getRouter(){return this.router}mount(e,t="/"){e.use(t,this.router)}_clone(){const e=new Router;return e.router=this.router,e.middlewareStack=[...this.middlewareStack],e.prefixStack=[...this.prefixStack],e}_addRoute(e,t,r,a=[]){const n=this._buildPath(t),o=this._buildHandler(r),s=a.flat(1/0),c=[...this.middlewareStack,...s,o];return this.router[e](n,...c),this}_buildPath(e){const t=e.replace(/^\//,""),r=this.prefixStack.filter(e=>""!==e);return 0===r.length?`/${t}`:`/${r.join("/")}/${t}`.replace(/\/+/g,"/")}_buildHandler(e){if("function"==typeof e)return e;if(Array.isArray(e)&&2===e.length){const[t,r]=e;return ControllerBinder.handle(t,r)}throw new Error('Action must be a function or array [Controller, "method"]')}}class Route{static _router=new Router;static create(){return Router.create()}static middleware(...e){return this._router.middleware(...e)}static prefix(e){return this._router.prefix(e)}static group(e){return this._router.group(e)}static get(e,...t){return this._router.get(e,...t)}static post(e,...t){return this._router.post(e,...t)}static put(e,...t){return this._router.put(e,...t)}static delete(e,...t){return this._router.delete(e,...t)}static patch(e,...t){return this._router.patch(e,...t)}static options(e,...t){return this._router.options(e,...t)}static getRouter(){return this._router.getRouter()}static mount(e,t="/"){return this._router.mount(e,t)}static reset(){this._router=new Router}}const server_Router=Route;function createArcanaServer(e,t){return new ArcanaJSServer.A({...t})}var __webpack_export_target__=exports;for(var __webpack_i__ in __webpack_exports__)__webpack_export_target__[__webpack_i__]=__webpack_exports__[__webpack_i__];__webpack_exports__.__esModule&&Object.defineProperty(__webpack_export_target__,"__esModule",{value:!0})})();
1
+ /*! For license information please see arcanajs.js.LICENSE.txt */
2
+ (()=>{var __webpack_modules__={14:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";__webpack_require__.d(__webpack_exports__,{dynamicRequire:()=>dynamicRequire});const dynamicRequire=id=>"undefined"!=typeof require?require(id):eval("require")(id)},369:e=>{"use strict";e.exports=require("arcana-views")},590:(e,t,r)=>{},630:()=>{var e;!function(e){!function(){var t="object"==typeof globalThis?globalThis:"object"==typeof global?global:"object"==typeof self?self:"object"==typeof this?this:function(){try{return Function("return this;")()}catch(e){}}()||function(){try{return(0,eval)("(function() { return this; })()")}catch(e){}}(),r=n(e);function n(e,t){return function(r,n){Object.defineProperty(e,r,{configurable:!0,writable:!0,value:n}),t&&t(r,n)}}void 0!==t.Reflect&&(r=n(t.Reflect,r)),function(e,t){var r=Object.prototype.hasOwnProperty,n="function"==typeof Symbol,s=n&&void 0!==Symbol.toPrimitive?Symbol.toPrimitive:"@@toPrimitive",i=n&&void 0!==Symbol.iterator?Symbol.iterator:"@@iterator",a="function"==typeof Object.create,o={__proto__:[]}instanceof Array,c=!a&&!o,u={create:a?function(){return V(Object.create(null))}:o?function(){return V({__proto__:null})}:function(){return V({})},has:c?function(e,t){return r.call(e,t)}:function(e,t){return t in e},get:c?function(e,t){return r.call(e,t)?e[t]:void 0}:function(e,t){return e[t]}},l=Object.getPrototypeOf(Function),h="function"==typeof Map&&"function"==typeof Map.prototype.entries?Map:function(){var e={},t=[],r=function(){function e(e,t,r){this._index=0,this._keys=e,this._values=t,this._selector=r}return e.prototype["@@iterator"]=function(){return this},e.prototype[i]=function(){return this},e.prototype.next=function(){var e=this._index;if(e>=0&&e<this._keys.length){var r=this._selector(this._keys[e],this._values[e]);return e+1>=this._keys.length?(this._index=-1,this._keys=t,this._values=t):this._index++,{value:r,done:!1}}return{value:void 0,done:!0}},e.prototype.throw=function(e){throw this._index>=0&&(this._index=-1,this._keys=t,this._values=t),e},e.prototype.return=function(e){return this._index>=0&&(this._index=-1,this._keys=t,this._values=t),{value:e,done:!0}},e}();return function(){function t(){this._keys=[],this._values=[],this._cacheKey=e,this._cacheIndex=-2}return Object.defineProperty(t.prototype,"size",{get:function(){return this._keys.length},enumerable:!0,configurable:!0}),t.prototype.has=function(e){return this._find(e,!1)>=0},t.prototype.get=function(e){var t=this._find(e,!1);return t>=0?this._values[t]:void 0},t.prototype.set=function(e,t){var r=this._find(e,!0);return this._values[r]=t,this},t.prototype.delete=function(t){var r=this._find(t,!1);if(r>=0){for(var n=this._keys.length,s=r+1;s<n;s++)this._keys[s-1]=this._keys[s],this._values[s-1]=this._values[s];return this._keys.length--,this._values.length--,q(t,this._cacheKey)&&(this._cacheKey=e,this._cacheIndex=-2),!0}return!1},t.prototype.clear=function(){this._keys.length=0,this._values.length=0,this._cacheKey=e,this._cacheIndex=-2},t.prototype.keys=function(){return new r(this._keys,this._values,n)},t.prototype.values=function(){return new r(this._keys,this._values,s)},t.prototype.entries=function(){return new r(this._keys,this._values,a)},t.prototype["@@iterator"]=function(){return this.entries()},t.prototype[i]=function(){return this.entries()},t.prototype._find=function(e,t){if(!q(this._cacheKey,e)){this._cacheIndex=-1;for(var r=0;r<this._keys.length;r++)if(q(this._keys[r],e)){this._cacheIndex=r;break}}return this._cacheIndex<0&&t&&(this._cacheIndex=this._keys.length,this._keys.push(e),this._values.push(void 0)),this._cacheIndex},t}();function n(e,t){return e}function s(e,t){return t}function a(e,t){return[e,t]}}(),d="function"==typeof Set&&"function"==typeof Set.prototype.entries?Set:function(){function e(){this._map=new h}return Object.defineProperty(e.prototype,"size",{get:function(){return this._map.size},enumerable:!0,configurable:!0}),e.prototype.has=function(e){return this._map.has(e)},e.prototype.add=function(e){return this._map.set(e,e),this},e.prototype.delete=function(e){return this._map.delete(e)},e.prototype.clear=function(){this._map.clear()},e.prototype.keys=function(){return this._map.keys()},e.prototype.values=function(){return this._map.keys()},e.prototype.entries=function(){return this._map.entries()},e.prototype["@@iterator"]=function(){return this.keys()},e.prototype[i]=function(){return this.keys()},e}(),p="function"==typeof WeakMap?WeakMap:function(){var e=u.create(),t=n();return function(){function e(){this._key=n()}return e.prototype.has=function(e){var t=s(e,!1);return void 0!==t&&u.has(t,this._key)},e.prototype.get=function(e){var t=s(e,!1);return void 0!==t?u.get(t,this._key):void 0},e.prototype.set=function(e,t){return s(e,!0)[this._key]=t,this},e.prototype.delete=function(e){var t=s(e,!1);return void 0!==t&&delete t[this._key]},e.prototype.clear=function(){this._key=n()},e}();function n(){var t;do{t="@@WeakMap@@"+a()}while(u.has(e,t));return e[t]=!0,t}function s(e,n){if(!r.call(e,t)){if(!n)return;Object.defineProperty(e,t,{value:u.create()})}return e[t]}function i(e,t){for(var r=0;r<t;++r)e[r]=255*Math.random()|0;return e}function a(){var e=function(e){if("function"==typeof Uint8Array){var t=new Uint8Array(e);return"undefined"!=typeof crypto?crypto.getRandomValues(t):"undefined"!=typeof msCrypto?msCrypto.getRandomValues(t):i(t,e),t}return i(new Array(e),e)}(16);e[6]=79&e[6]|64,e[8]=191&e[8]|128;for(var t="",r=0;r<16;++r){var n=e[r];4!==r&&6!==r&&8!==r||(t+="-"),n<16&&(t+="0"),t+=n.toString(16).toLowerCase()}return t}}(),f=n?Symbol.for("@reflect-metadata:registry"):void 0,m=function(){var e;return!R(f)&&N(t.Reflect)&&Object.isExtensible(t.Reflect)&&(e=t.Reflect[f]),R(e)&&(e=function(){var e,r,n,s;R(f)||void 0===t.Reflect||f in t.Reflect||"function"!=typeof t.Reflect.defineMetadata||(e=function(e){var t=e.defineMetadata,r=e.hasOwnMetadata,n=e.getOwnMetadata,s=e.getOwnMetadataKeys,i=e.deleteMetadata,a=new p;return{isProviderFor:function(e,t){var r=a.get(e);return!(R(r)||!r.has(t))||!!s(e,t).length&&(R(r)&&(r=new d,a.set(e,r)),r.add(t),!0)},OrdinaryDefineOwnMetadata:t,OrdinaryHasOwnMetadata:r,OrdinaryGetOwnMetadata:n,OrdinaryOwnMetadataKeys:s,OrdinaryDeleteMetadata:i}}(t.Reflect));var i=new p,a={registerProvider:o,getProvider:u,setProvider:m};return a;function o(t){if(!Object.isExtensible(a))throw new Error("Cannot add provider to a frozen registry.");switch(!0){case e===t:break;case R(r):r=t;break;case r===t:break;case R(n):n=t;break;case n===t:break;default:void 0===s&&(s=new d),s.add(t)}}function c(t,i){if(!R(r)){if(r.isProviderFor(t,i))return r;if(!R(n)){if(n.isProviderFor(t,i))return r;if(!R(s))for(var a=$(s);;){var o=K(a);if(!o)return;var c=M(o);if(c.isProviderFor(t,i))return I(a),c}}}if(!R(e)&&e.isProviderFor(t,i))return e}function u(e,t){var r,n=i.get(e);return R(n)||(r=n.get(t)),R(r)?(R(r=c(e,t))||(R(n)&&(n=new h,i.set(e,n)),n.set(t,r)),r):r}function l(e){if(R(e))throw new TypeError;return r===e||n===e||!R(s)&&s.has(e)}function m(e,t,r){if(!l(r))throw new Error("Metadata provider not registered.");var n=u(e,t);if(n!==r){if(!R(n))return!1;var s=i.get(e);R(s)&&(s=new h,i.set(e,s)),s.set(t,r)}return!0}}()),!R(f)&&N(t.Reflect)&&Object.isExtensible(t.Reflect)&&Object.defineProperty(t.Reflect,f,{enumerable:!1,configurable:!1,writable:!1,value:e}),e}(),y=function(e){var t=new p,r={isProviderFor:function(e,r){var n=t.get(e);return!R(n)&&n.has(r)},OrdinaryDefineOwnMetadata:function(e,t,r,s){n(r,s,!0).set(e,t)},OrdinaryHasOwnMetadata:function(e,t,r){var s=n(t,r,!1);return!R(s)&&O(s.has(e))},OrdinaryGetOwnMetadata:function(e,t,r){var s=n(t,r,!1);if(!R(s))return s.get(e)},OrdinaryOwnMetadataKeys:function(e,t){var r=[],s=n(e,t,!1);if(R(s))return r;for(var i=$(s.keys()),a=0;;){var o=K(i);if(!o)return r.length=a,r;var c=M(o);try{r[a]=c}catch(e){try{I(i)}finally{throw e}}a++}},OrdinaryDeleteMetadata:function(e,r,s){var i=n(r,s,!1);if(R(i))return!1;if(!i.delete(e))return!1;if(0===i.size){var a=t.get(r);R(a)||(a.delete(s),0===a.size&&t.delete(a))}return!0}};return m.registerProvider(r),r;function n(n,s,i){var a=t.get(n),o=!1;if(R(a)){if(!i)return;a=new h,t.set(n,a),o=!0}var c=a.get(s);if(R(c)){if(!i)return;if(c=new h,a.set(s,c),!e.setProvider(n,s,r))throw a.delete(s),o&&t.delete(n),new Error("Wrong provider for target.")}return c}}(m);function w(e,t,r){if(g(e,t,r))return!0;var n=F(t);return!A(n)&&w(e,n,r)}function g(e,t,r){var n=L(t,r,!1);return!R(n)&&O(n.OrdinaryHasOwnMetadata(e,t,r))}function _(e,t,r){if(g(e,t,r))return b(e,t,r);var n=F(t);return A(n)?void 0:_(e,n,r)}function b(e,t,r){var n=L(t,r,!1);if(!R(n))return n.OrdinaryGetOwnMetadata(e,t,r)}function v(e,t,r,n){L(r,n,!0).OrdinaryDefineOwnMetadata(e,t,r,n)}function E(e,t){var r=x(e,t),n=F(e);if(null===n)return r;var s=E(n,t);if(s.length<=0)return r;if(r.length<=0)return s;for(var i=new d,a=[],o=0,c=r;o<c.length;o++){var u=c[o];i.has(u)||(i.add(u),a.push(u))}for(var l=0,h=s;l<h.length;l++)u=h[l],i.has(u)||(i.add(u),a.push(u));return a}function x(e,t){var r=L(e,t,!1);return r?r.OrdinaryOwnMetadataKeys(e,t):[]}function k(e){if(null===e)return 1;switch(typeof e){case"undefined":return 0;case"boolean":return 2;case"string":return 3;case"symbol":return 4;case"number":return 5;case"object":return null===e?1:6;default:return 6}}function R(e){return void 0===e}function A(e){return null===e}function N(e){return"object"==typeof e?null!==e:"function"==typeof e}function C(e,t){switch(k(e)){case 0:case 1:case 2:case 3:case 4:case 5:return e}var r=3===t?"string":5===t?"number":"default",n=D(e,s);if(void 0!==n){var i=n.call(e,r);if(N(i))throw new TypeError;return i}return function(e,t){if("string"===t){var r=e.toString;if(j(r)&&!N(s=r.call(e)))return s;if(j(n=e.valueOf)&&!N(s=n.call(e)))return s}else{var n;if(j(n=e.valueOf)&&!N(s=n.call(e)))return s;var s,i=e.toString;if(j(i)&&!N(s=i.call(e)))return s}throw new TypeError}(e,"default"===r?"number":r)}function O(e){return!!e}function T(e){var t=C(e,3);return"symbol"==typeof t?t:function(e){return""+e}(t)}function S(e){return Array.isArray?Array.isArray(e):e instanceof Object?e instanceof Array:"[object Array]"===Object.prototype.toString.call(e)}function j(e){return"function"==typeof e}function P(e){return"function"==typeof e}function q(e,t){return e===t||e!=e&&t!=t}function D(e,t){var r=e[t];if(null!=r){if(!j(r))throw new TypeError;return r}}function $(e){var t=D(e,i);if(!j(t))throw new TypeError;var r=t.call(e);if(!N(r))throw new TypeError;return r}function M(e){return e.value}function K(e){var t=e.next();return!t.done&&t}function I(e){var t=e.return;t&&t.call(e)}function F(e){var t=Object.getPrototypeOf(e);if("function"!=typeof e||e===l)return t;if(t!==l)return t;var r=e.prototype,n=r&&Object.getPrototypeOf(r);if(null==n||n===Object.prototype)return t;var s=n.constructor;return"function"!=typeof s||s===e?t:s}function L(e,t,r){var n=m.getProvider(e,t);if(!R(n))return n;if(r){if(m.setProvider(e,t,y))return y;throw new Error("Illegal state.")}}function V(e){return e.__=void 0,delete e.__,e}e("decorate",function(e,t,r,n){if(R(r)){if(!S(e))throw new TypeError;if(!P(t))throw new TypeError;return function(e,t){for(var r=e.length-1;r>=0;--r){var n=(0,e[r])(t);if(!R(n)&&!A(n)){if(!P(n))throw new TypeError;t=n}}return t}(e,t)}if(!S(e))throw new TypeError;if(!N(t))throw new TypeError;if(!N(n)&&!R(n)&&!A(n))throw new TypeError;return A(n)&&(n=void 0),function(e,t,r,n){for(var s=e.length-1;s>=0;--s){var i=(0,e[s])(t,r,n);if(!R(i)&&!A(i)){if(!N(i))throw new TypeError;n=i}}return n}(e,t,r=T(r),n)}),e("metadata",function(e,t){return function(r,n){if(!N(r))throw new TypeError;if(!R(n)&&!function(e){switch(k(e)){case 3:case 4:return!0;default:return!1}}(n))throw new TypeError;v(e,t,r,n)}}),e("defineMetadata",function(e,t,r,n){if(!N(r))throw new TypeError;return R(n)||(n=T(n)),v(e,t,r,n)}),e("hasMetadata",function(e,t,r){if(!N(t))throw new TypeError;return R(r)||(r=T(r)),w(e,t,r)}),e("hasOwnMetadata",function(e,t,r){if(!N(t))throw new TypeError;return R(r)||(r=T(r)),g(e,t,r)}),e("getMetadata",function(e,t,r){if(!N(t))throw new TypeError;return R(r)||(r=T(r)),_(e,t,r)}),e("getOwnMetadata",function(e,t,r){if(!N(t))throw new TypeError;return R(r)||(r=T(r)),b(e,t,r)}),e("getMetadataKeys",function(e,t){if(!N(e))throw new TypeError;return R(t)||(t=T(t)),E(e,t)}),e("getOwnMetadataKeys",function(e,t){if(!N(e))throw new TypeError;return R(t)||(t=T(t)),x(e,t)}),e("deleteMetadata",function(e,t,r){if(!N(t))throw new TypeError;if(R(r)||(r=T(r)),!N(t))throw new TypeError;R(r)||(r=T(r));var n=L(t,r,!1);return!R(n)&&n.OrdinaryDeleteMetadata(e,t,r)})}(r,t),void 0===t.Reflect&&(t.Reflect=e)}()}(e||(e={}))},697:(e,t,r)=>{},707:(e,t,r)=>{}},__webpack_module_cache__={};function __webpack_require__(e){var t=__webpack_module_cache__[e];if(void 0!==t)return t.exports;var r=__webpack_module_cache__[e]={exports:{}};return __webpack_modules__[e](r,r.exports,__webpack_require__),r.exports}__webpack_require__.n=e=>{var t=e&&e.__esModule?()=>e.default:()=>e;return __webpack_require__.d(t,{a:t}),t},__webpack_require__.d=(e,t)=>{for(var r in t)__webpack_require__.o(t,r)&&!__webpack_require__.o(e,r)&&Object.defineProperty(e,r,{enumerable:!0,get:t[r]})},__webpack_require__.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),__webpack_require__.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})};var __webpack_exports__={};(()=>{"use strict";__webpack_require__.r(__webpack_exports__),__webpack_require__.d(__webpack_exports__,{ArcanaJSServer:()=>G,Container:()=>B,Express:()=>s.Express,FormRequest:()=>Y,JsonResource:()=>Z,NextFunction:()=>s.NextFunction,Request:()=>s.Request,Response:()=>s.Response,Route:()=>ie,ServiceProvider:()=>ae,ValidationException:()=>Q,Validator:()=>X,createArcanaServer:()=>oe});const e=require("compression");var t=__webpack_require__.n(e);const r=require("cookie-parser");var n=__webpack_require__.n(r);const s=require("express");var i=__webpack_require__.n(s);const a=require("fs");var o=__webpack_require__.n(a);const c=require("helmet");var u=__webpack_require__.n(c);const l=require("path");var h=__webpack_require__.n(l);const d=require("react");var p=__webpack_require__.n(d);const f=({children:e})=>p().createElement(p().Fragment,null,e);function m(e,t){const r=global,n=Symbol.for(`ARCANAJS_CONTEXT_${e}`);return r[n]||(r[n]=(0,d.createContext)(t)),r[n]}const y=m("HeadContext",null),w=({children:e})=>{const t=(0,d.useContext)(y);return"undefined"==typeof window&&t&&p().Children.forEach(e,e=>{p().isValidElement(e)&&t.push(p().cloneElement(e,{"data-arcanajs-head":"true"}))}),(0,d.useEffect)(()=>{const t=[];return p().Children.forEach(e,e=>{if(p().isValidElement(e)){const r=e;if("title"===r.type)document.title=r.props.children;else if("meta"===r.type){const e=r.props;let n="meta";if(e.name&&(n+=`[name="${e.name}"]`),e.property&&(n+=`[property="${e.property}"]`),e.name||e.property){let r=document.querySelector(n+'[data-arcanajs-head="true"]')||document.querySelector(n);if(r)r.setAttribute("content",e.content),r.setAttribute("data-arcanajs-head","true"),t.push(r);else{const r=document.createElement("meta");Object.keys(e).forEach(t=>{r.setAttribute(t,e[t])}),r.setAttribute("data-arcanajs-head","true"),document.head.appendChild(r),t.push(r)}}}else if("link"===r.type){const e=r.props;let n="link";e.rel&&(n+=`[rel="${e.rel}"]`),e.href&&(n+=`[href="${e.href}"]`);let s=document.querySelector(n+'[data-arcanajs-head="true"]')||document.querySelector(n);if(s)s.setAttribute("data-arcanajs-head","true"),t.push(s);else{const r=document.createElement("link");Object.keys(e).forEach(t=>{r.setAttribute(t,e[t])}),r.setAttribute("data-arcanajs-head","true"),document.head.appendChild(r),t.push(r)}}}}),()=>{t.forEach(e=>{e.remove()})}},[e]),null},g=m("RouterContext",null),_=({value:e,children:t})=>p().createElement(g.Provider,{value:e},t);function b(){return b=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var n in r)({}).hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e},b.apply(null,arguments)}const v=({href:e,children:t,prefetch:r=!1,...n})=>{const{navigateTo:s,navigateToAsync:i}=(()=>{const e=(0,d.useContext)(g);if(!e)throw new Error("useRouter must be used within an ArcanaJSApp");return e})(),a=/^https?:\/\//.test(e);return p().createElement("a",b({href:e,onClick:async t=>{t.preventDefault(),a?window.open(e,"_blank","noopener,noreferrer"):i?await i(e):s(e)},onMouseEnter:()=>{r&&!a&&fetch(e,{method:"HEAD"}).catch(()=>{})},target:a?"_blank":void 0,rel:a?"noopener noreferrer":void 0},n),t)},E=m("PageContext",null),x=({data:e,title:t,children:r})=>p().createElement(E.Provider,{value:e},t&&p().createElement(w,null,p().createElement("title",null,t)),r);function k({message:e="Something went wrong",statusCode:t=500,stack:r}){const n="development"===process.env.NODE_ENV;return React.createElement(x,null,React.createElement(w,null,React.createElement("title",null,t," - Server Error"),React.createElement("meta",{name:"description",content:"An error occurred on the server"})),React.createElement(f,null,React.createElement("div",{className:"relative min-h-screen overflow-hidden bg-black text-white flex flex-col justify-center items-center px-4 font-sans"},React.createElement("div",{className:"fixed inset-0 z-0 overflow-hidden pointer-events-none"},React.createElement("div",{className:"absolute inset-0 grid-pattern opacity-30"}),React.createElement("div",{className:"absolute top-1/4 right-1/4 w-96 h-96 bg-red-600 rounded-full opacity-20 blur-3xl animate-glow"}),React.createElement("div",{className:"absolute bottom-1/4 left-1/4 w-96 h-96 bg-orange-600 rounded-full opacity-10 blur-3xl animate-glow",style:{animationDelay:"2s"}}),React.createElement("div",{className:"absolute inset-0 hero-gradient"})),React.createElement("div",{className:"relative z-10 max-w-2xl w-full text-center animate-scale-in"},React.createElement("div",{className:"glass-card rounded-3xl p-12 border border-white/10 shadow-2xl"},React.createElement("div",{className:"mb-8"},React.createElement("div",{className:"text-6xl mb-6 animate-float"},React.createElement("span",{className:"text-red-500 drop-shadow-lg filter"},"⚠️")),React.createElement("h1",{className:"text-8xl font-bold text-transparent bg-clip-text bg-gradient-to-br from-red-500 to-orange-500 mb-4"},t),React.createElement("h2",{className:"text-3xl font-bold text-white mb-4"},"Server Error"),React.createElement("p",{className:"text-gray-400 text-lg leading-relaxed"},e)),React.createElement("div",{className:"flex flex-col sm:flex-row gap-4 justify-center mb-8"},React.createElement(v,{href:"/",className:"btn-primary px-8 py-3.5 text-white font-semibold rounded-xl inline-flex items-center justify-center gap-2 w-full sm:w-auto bg-gradient-to-r from-red-600 to-orange-600 hover:from-red-500 hover:to-orange-500 border-none shadow-red-900/20"},React.createElement("svg",{className:"w-5 h-5",fill:"none",stroke:"currentColor",viewBox:"0 0 24 24"},React.createElement("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M3 12l2-2m0 0l7-7 7 7M5 10v10a1 1 0 001 1h3m10-11l2 2m-2-2v10a1 1 0 01-1 1h-3m-6 0a1 1 0 001-1v-4a1 1 0 011-1h2a1 1 0 011 1v4a1 1 0 001 1m-6 0h6"})),"Go Home"),React.createElement("button",{onClick:()=>window.location.reload(),className:"btn-secondary px-8 py-3.5 text-white font-semibold rounded-xl inline-flex items-center justify-center gap-2 w-full sm:w-auto"},React.createElement("svg",{className:"w-5 h-5",fill:"none",stroke:"currentColor",viewBox:"0 0 24 24"},React.createElement("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M4 4v5h.582m15.356 2A8.001 8.001 0 004.582 9m0 0H9m11 11v-5h-.581m0 0a8.003 8.003 0 01-15.357-2m15.357 2H15"})),"Try Again")),n&&r&&React.createElement("div",{className:"mt-8 text-left animate-slide-up"},React.createElement("details",{className:"bg-black/40 border border-white/10 rounded-xl overflow-hidden group"},React.createElement("summary",{className:"cursor-pointer font-medium text-gray-300 p-4 hover:bg-white/5 transition-colors flex items-center justify-between select-none"},React.createElement("span",null,"Stack Trace (Development Only)"),React.createElement("svg",{className:"w-5 h-5 text-gray-500 group-open:rotate-180 transition-transform",fill:"none",stroke:"currentColor",viewBox:"0 0 24 24"},React.createElement("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M19 9l-7 7-7-7"}))),React.createElement("pre",{className:"text-xs text-red-300/80 p-4 overflow-x-auto whitespace-pre-wrap font-mono border-t border-white/5 bg-black/20"},r)))),React.createElement("div",{className:"mt-8 text-gray-500 text-sm"},"If this problem persists, please"," ",React.createElement(v,{href:"/contact",className:"text-red-400 hover:text-red-300 underline transition-colors"},"contact support"),".")))))}function R({url:e}){return React.createElement(x,null,React.createElement(w,null,React.createElement("title",null,"404 - Page Not Found"),React.createElement("meta",{name:"description",content:"The page you're looking for doesn't exist"})),React.createElement(f,null,React.createElement("div",{className:"relative min-h-screen overflow-hidden bg-black text-white flex flex-col justify-center items-center px-4 font-sans"},React.createElement("div",{className:"fixed inset-0 z-0 overflow-hidden pointer-events-none"},React.createElement("div",{className:"absolute inset-0 grid-pattern opacity-30"}),React.createElement("div",{className:"absolute top-1/4 left-1/4 w-96 h-96 bg-orange-500 rounded-full opacity-20 blur-3xl animate-glow"}),React.createElement("div",{className:"absolute bottom-1/4 right-1/4 w-96 h-96 bg-purple-500 rounded-full opacity-10 blur-3xl animate-glow",style:{animationDelay:"2s"}}),React.createElement("div",{className:"absolute inset-0 hero-gradient"})),React.createElement("div",{className:"relative z-10 max-w-lg w-full text-center animate-scale-in"},React.createElement("div",{className:"glass-card rounded-3xl p-12 border border-white/10 shadow-2xl"},React.createElement("div",{className:"mb-8"},React.createElement("h1",{className:"text-9xl font-bold text-transparent bg-clip-text bg-gradient-to-br from-white to-gray-500 mb-4 animate-float"},"404"),React.createElement("h2",{className:"text-3xl font-bold text-white mb-4"},"Page Not Found"),React.createElement("p",{className:"text-gray-400 text-lg leading-relaxed"},e?React.createElement(React.Fragment,null,"The page ",React.createElement("span",{className:"text-orange-400"},'"',e,'"')," ","you're looking for doesn't exist."):"The page you're looking for doesn't exist.")),React.createElement("div",{className:"flex flex-col sm:flex-row gap-4 justify-center"},React.createElement(v,{href:"/",className:"btn-primary px-8 py-3.5 text-white font-semibold rounded-xl inline-flex items-center justify-center gap-2 w-full sm:w-auto"},React.createElement("svg",{className:"w-5 h-5",fill:"none",stroke:"currentColor",viewBox:"0 0 24 24"},React.createElement("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M3 12l2-2m0 0l7-7 7 7M5 10v10a1 1 0 001 1h3m10-11l2 2m-2-2v10a1 1 0 01-1 1h-3m-6 0a1 1 0 001-1v-4a1 1 0 011-1h2a1 1 0 011 1v4a1 1 0 001 1m-6 0h6"})),"Go Home"),React.createElement("button",{onClick:()=>window.history.back(),className:"btn-secondary px-8 py-3.5 text-white font-semibold rounded-xl inline-flex items-center justify-center gap-2 w-full sm:w-auto"},React.createElement("svg",{className:"w-5 h-5",fill:"none",stroke:"currentColor",viewBox:"0 0 24 24"},React.createElement("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M10 19l-7-7m0 0l7-7m-7 7h18"})),"Go Back"))),React.createElement("div",{className:"mt-8 text-gray-500 text-sm"},"If you believe this is an error, please"," ",React.createElement(v,{href:"/contact",className:"text-orange-400 hover:text-orange-300 underline transition-colors"},"contact support"),".")))))}const A=require("react-dom/server"),N=e=>{const{initialPage:t,initialData:r,initialParams:n={},initialUrl:s,csrfToken:i,views:a,layout:o,onNavigate:c,cacheLimit:u=50}=e,[l,h]=(0,d.useState)(t),[f,m]=(0,d.useState)(r),[y,w]=(0,d.useState)(n),[g,b]=(0,d.useState)(s||("undefined"!=typeof window?window.location.pathname:"/")),[v,E]=(0,d.useState)(!1),k=p().useRef(new Map),R=p().useRef(null);(0,d.useEffect)(()=>{"undefined"==typeof window||window.history.state||window.history.replaceState({page:t,data:r,params:n},"",window.location.href);const e=e=>{if(e.state)h(e.state.page),m(e.state.data),w(e.state.params||{}),b(window.location.pathname);else{const e=window.location.pathname;A(e).catch(()=>{window.location.reload()})}};return window.addEventListener("popstate",e),()=>{var t;window.removeEventListener("popstate",e),null===(t=R.current)||void 0===t||t.abort()}},[]);const A=async e=>{var t;const r=k.current;if(r.has(e)){const t=r.get(e);if(h(t.page),m(t.data),w(t.params||{}),b(e),window.history.pushState(t,"",e),"undefined"!=typeof window)try{window.scrollTo({top:0,behavior:"smooth"})}catch{}return void(c&&c(e))}E(!0),null===(t=R.current)||void 0===t||t.abort();const n=new AbortController;R.current=n;try{const t=await fetch(e,{headers:{"X-ArcanaJS-Request":"true"},cache:"no-store",signal:n.signal});if(!t.ok){if(404===t.status)return h("NotFoundPage"),b(e),void window.history.pushState({page:"NotFoundPage",data:{}},"",e);throw new Error(`Navigation failed: ${t.status} ${t.statusText}`)}if(!(t.headers.get("content-type")||"").includes("application/json"))return void(window.location.href=e);const r=await t.json(),s={page:r.page,data:r.data,params:r.params||{}};if(((e,t)=>{const r=k.current;if(r.has(e)&&r.delete(e),r.set(e,t),r.size>u){const e=r.keys().next().value;void 0!==e&&r.delete(e)}})(e,s),window.history.pushState({page:s.page,data:s.data,params:s.params},"",e),h(s.page),m(s.data),w(s.params||{}),b(e),"undefined"!=typeof window)try{window.scrollTo({top:0,behavior:"smooth"})}catch{}c&&c(e)}catch(e){if("AbortError"===(null==e?void 0:e.name))return;throw console.error("Navigation failed",e),e}finally{R.current===n&&(R.current=null),E(!1)}},N=(()=>{const e=a[l]||a.NotFoundPage||(()=>p().createElement("div",null,"404 Not Found"));return p().createElement(x,{data:f},p().createElement(e,{data:f,navigateTo:A,params:y}))})();return p().createElement(_,{value:{navigateTo:(...e)=>{A(e[0])},navigateToAsync:A,currentPage:l,currentUrl:g,params:y,csrfToken:i,onNavigate:c,isNavigating:v}},o?p().createElement(o,null,N):p().createElement(p().Fragment,null,N))},C='<!DOCTYPE html>\n<html lang="en">\n <head>\n <meta charset="UTF-8" />\n <meta name="viewport" content="width=device-width, initial-scale=1.0" />\n \x3c!--HEAD_CONTENT--\x3e\n </head>\n <body>\n <div id="root">\x3c!--APP_CONTENT--\x3e</div>\n \x3c!--ARCANAJS_DATA_SCRIPT--\x3e\n </body>\n</html>',O=require("crypto");var T=__webpack_require__.n(O);const S="_csrf",j=(e,t,r)=>{t.success=(e={},r="Success",n=200)=>t.status(n).json({success:!0,message:r,data:e,error:null}),t.error=(e="Error",r=500,n=null,s=null)=>{const i=n?"object"==typeof n&&null!==n?n instanceof Error?n.toString():n:n.toString():null;return t.status(r).json({success:!1,message:e,data:s,error:i})},r()};var P=__webpack_require__(14);class q{static macros={};static macro(e,t){this.macros[e]=t,this.prototype[e]=t}static mixin(e){Object.keys(e).forEach(t=>{this.macro(t,e[t])})}static hasMacro(e){return!!this.macros[e]}}class D extends q{selectColumns=["*"];whereClauses=[];orderByClauses=[];joinClauses=[];constructor(e,t){super(),this.tableName=e,this.adapter=t}select(...e){return this.selectColumns=e,this}where(e,t,r){return void 0===r&&(r=t,t="="),this.whereClauses.push({column:e,operator:t,value:r,boolean:"AND"}),this}orWhere(e,t,r){return void 0===r&&(r=t,t="="),this.whereClauses.push({column:e,operator:t,value:r,boolean:"OR"}),this}whereIn(e,t){return this.whereClauses.push({column:e,operator:"IN",value:t,boolean:"AND"}),this}whereNotIn(e,t){return this.whereClauses.push({column:e,operator:"NOT IN",value:t,boolean:"AND"}),this}whereBetween(e,t){return this.whereClauses.push({column:e,operator:"BETWEEN",value:t,boolean:"AND"}),this}whereNull(e){return this.whereClauses.push({column:e,operator:"IS NULL",value:null,boolean:"AND"}),this}whereNotNull(e){return this.whereClauses.push({column:e,operator:"IS NOT NULL",value:null,boolean:"AND"}),this}orderBy(e,t="ASC"){return this.orderByClauses.push({column:e,direction:t.toUpperCase()}),this}limit(e){return this.limitValue=e,this}offset(e){return this.offsetValue=e,this}join(e,t,r,n,s="INNER"){return this.joinClauses.push({type:s,table:e,first:t,operator:r,second:n}),this}leftJoin(e,t,r,n){return this.join(e,t,r,n,"LEFT")}rightJoin(e,t,r,n){return this.join(e,t,r,n,"RIGHT")}eagerLoads=[];setModel(e){return this.model=e,this}with(e){return Array.isArray(e)?this.eagerLoads.push(...e):this.eagerLoads.push(e),this}async get(){const e={columns:this.selectColumns,where:this.whereClauses,orderBy:this.orderByClauses,limit:this.limitValue,offset:this.offsetValue,joins:this.joinClauses},t=await this.adapter.select(this.tableName,e);return this.eagerLoads.length>0&&this.model?await this.eagerLoadRelations(t):t}async eagerLoadRelations(e){if(0===e.length)return e;const t=e.map(e=>this.model.hydrate(e));for(const e of this.eagerLoads){const r=new this.model;if("function"!=typeof r[e])throw new Error(`Relation ${e} does not exist on ${this.model.name}`);const n=r[e]();n.addEagerConstraints(t);const s=await n.get();n.match(t,s,e)}return t}async first(){return this.limit(1),(await this.get())[0]||null}async find(e){return this.where("id",e).first()}async count(){this.selectColumns=["COUNT(*) as count"];const e=await this.first();return e?e.count:0}async pluck(e){return this.select(e),(await this.get()).map(t=>t[e])}async sum(e){this.selectColumns=[`SUM(${e}) as sum`];const t=await this.first();return t&&t.sum||0}async avg(e){this.selectColumns=[`AVG(${e}) as avg`];const t=await this.first();return t&&t.avg||0}async min(e){this.selectColumns=[`MIN(${e}) as min`];const t=await this.first();return t?t.min:null}async max(e){this.selectColumns=[`MAX(${e}) as max`];const t=await this.first();return t?t.max:null}async exists(){return await this.count()>0}async paginate(e=1,t=15){const r=await this.count(),n=(e-1)*t;return this.limit(t).offset(n),{data:await this.get(),total:r,perPage:t,currentPage:e,lastPage:Math.ceil(r/t)}}clone(){const e=new D(this.tableName,this.adapter);return e.selectColumns=[...this.selectColumns],e.whereClauses=[...this.whereClauses],e.orderByClauses=[...this.orderByClauses],e.joinClauses=[...this.joinClauses],e.limitValue=this.limitValue,e.offsetValue=this.offsetValue,e}}class ${constructor(e,t){this.query=e,this.parent=t,this.related=e.model,this.addConstraints()}getQuery(){return this.query}async get(){return this.query.get()}async first(){return this.query.first()}}class M extends ${constructor(e,t,r,n){super(e,t),this.foreignKey=r,this.ownerKey=n}addConstraints(){const e=this.parent.getAttribute(this.foreignKey);this.query.where(this.ownerKey,"=",e)}addEagerConstraints(e){const t=e.map(e=>e.getAttribute(this.foreignKey)).filter(e=>null!==e);this.query.whereIn(this.ownerKey,t)}match(e,t,r){const n={};return t.forEach(e=>{const t=e.getAttribute(this.ownerKey);n[t]=e}),e.forEach(e=>{const t=e.getAttribute(this.foreignKey);n[t]&&e.setRelation(r,n[t])}),e}}class K extends ${constructor(e,t,r,n,s,i,a){super(e,t),this.table=r,this.foreignPivotKey=n,this.relatedPivotKey=s,this.parentKey=i,this.relatedKey=a}addConstraints(){this.performJoin(),this.query.where(`${this.table}.${this.foreignPivotKey}`,"=",this.parent.getAttribute(this.parentKey))}performJoin(e){const t=e||this.query,r=this.related.prototype.getTable();return t.join(this.table,`${r}.${this.relatedKey}`,"=",`${this.table}.${this.relatedPivotKey}`),this}addEagerConstraints(e){this.performJoin();const t=e.map(e=>e.getAttribute(this.parentKey)).filter(e=>null!==e);this.query.whereIn(`${this.table}.${this.foreignPivotKey}`,t)}match(e,t,r){return e}}class I extends ${constructor(e,t,r,n){super(e,t),this.foreignKey=r,this.localKey=n}addConstraints(){const e=this.parent.getAttribute(this.localKey);this.query.where(this.foreignKey,"=",e)}addEagerConstraints(e){const t=e.map(e=>e.getAttribute(this.localKey)).filter(e=>null!==e);this.query.whereIn(this.foreignKey,t)}match(e,t,r){const n={};return t.forEach(e=>{const t=e.getAttribute(this.foreignKey);n[t]||(n[t]=[]),n[t].push(e)}),e.forEach(e=>{const t=e.getAttribute(this.localKey);n[t]?e.setRelation(r,n[t]):e.setRelation(r,[])}),e}}class F extends ${constructor(e,t,r,n){super(e,t),this.foreignKey=r,this.localKey=n}addConstraints(){const e=this.parent.getAttribute(this.localKey);this.query.where(this.foreignKey,"=",e)}addEagerConstraints(e){const t=e.map(e=>e.getAttribute(this.localKey)).filter(e=>null!==e);this.query.whereIn(this.foreignKey,t)}match(e,t,r){const n={};return t.forEach(e=>{const t=e.getAttribute(this.foreignKey);n[t]=e}),e.forEach(e=>{const t=e.getAttribute(this.localKey);n[t]&&e.setRelation(r,n[t])}),e}}class L extends q{static primaryKey="id";static connection="default";attributes={};original={};relations={};exists=!1;fillable=[];guarded=["id"];hidden=[];visible=[];casts={};dates=[];timestamps=!0;createdAt="created_at";updatedAt="updated_at";softDeletes=!1;deletedAt="deleted_at";static setAdapter(e){this.adapter=e}static getTable(){if(this.tableName)return this.tableName;const e=this.name;return this.pluralize(this.snakeCase(e))}static query(){return new D(this.getTable(),this.adapter)}static async all(){return(await this.query().get()).map(e=>this.hydrate(e))}static async find(e){const t=await this.query().where(this.primaryKey,e).first();return t?this.hydrate(t):null}static async findOrFail(e){const t=await this.find(e);if(!t)throw new Error(`Model not found with ${this.primaryKey}: ${e}`);return t}static where(e,t,r){return this.query().where(e,t,r)}static async create(e){const t=new this;if(t.fill(e),t.timestamps){const e=new Date;t.attributes[t.createdAt]=e,t.attributes[t.updatedAt]=e}const r=await this.adapter.insert(this.getTable(),t.attributes),n=r[this.primaryKey]||r.id||r.insertId;return t.attributes[this.primaryKey]=n,"id"!==this.primaryKey&&(t.attributes.id=n),t.exists=!0,t.syncOriginal(),t}static async update(e,t){const r=await this.findOrFail(e);return await r.update(t),r}static async destroy(e){const t=await this.find(e);return!!t&&await t.delete()}static async firstOrCreate(e,t={}){const r=this.query();for(const[t,n]of Object.entries(e))r.where(t,n);const n=await r.first();return n?this.hydrate(n):await this.create({...e,...t})}static async updateOrCreate(e,t={}){const r=this.query();for(const[t,n]of Object.entries(e))r.where(t,n);const n=await r.first();if(n){const e=this.hydrate(n);return await e.update(t),e}return await this.create({...e,...t})}static hydrate(e){const t=new this;return t.attributes={...e},t.original={...e},t.exists=!0,t}fill(e){for(const[t,r]of Object.entries(e))this.isFillable(t)&&this.setAttribute(t,r);return this}isFillable(e){return this.fillable.length>0?this.fillable.includes(e):!this.guarded.includes(e)}setAttribute(e,t){const r=`set${this.studly(e)}Attribute`;"function"==typeof this[r]&&(t=this[r](t)),this.attributes[e]=this.castAttribute(e,t)}getAttribute(e){const t=`get${this.studly(e)}Attribute`;if("function"==typeof this[t])return this[t]();const r=this.attributes[e];return this.castAttribute(e,r,!0)}castAttribute(e,t,r=!1){if(null==t)return t;const n=this.casts[e];if(!n)return t;if(r)switch(n){case"int":case"integer":return parseInt(t);case"float":case"double":return parseFloat(t);case"string":return String(t);case"bool":case"boolean":return Boolean(t);case"array":case"json":return"string"==typeof t?JSON.parse(t):t;case"date":case"datetime":return t instanceof Date?t:new Date(t);default:return t}else switch(n){case"array":case"json":return"object"==typeof t?JSON.stringify(t):t;case"date":case"datetime":return t instanceof Date?t:new Date(t);default:return t}}async save(){const e=this.constructor;if(this.timestamps){const e=new Date;this.exists||(this.attributes[this.createdAt]=e),this.attributes[this.updatedAt]=e}if(this.exists){const t=this.attributes[e.primaryKey];await e.adapter.update(e.getTable(),t,this.attributes)}else{const t=await e.adapter.insert(e.getTable(),this.attributes),r=t[e.primaryKey]||t.id||t.insertId;this.attributes[e.primaryKey]=r,"id"!==e.primaryKey&&(this.attributes.id=r),this.exists=!0}return this.syncOriginal(),this}async update(e){return this.fill(e),await this.save()}async delete(){const e=this.constructor;if(this.softDeletes)return this.attributes[this.deletedAt]=new Date,await this.save(),!0;const t=this.attributes[e.primaryKey];return await e.adapter.delete(e.getTable(),t)}async forceDelete(){const e=this.constructor,t=this.attributes[e.primaryKey];return await e.adapter.delete(e.getTable(),t)}async restore(){return this.softDeletes&&(this.attributes[this.deletedAt]=null,await this.save()),this}syncOriginal(){this.original={...this.attributes}}getDirty(){const e={};for(const[t,r]of Object.entries(this.attributes))this.original[t]!==r&&(e[t]=r);return e}isDirty(){return Object.keys(this.getDirty()).length>0}constructor(e={}){super(),this.fill(e)}toJSON(){const e={};for(const[t,r]of Object.entries(this.attributes))this.hidden.includes(t)||this.visible.length>0&&!this.visible.includes(t)||(e[t]=this.getAttribute(t));for(const[t,r]of Object.entries(this.relations))e[t]=r;return e}hasOne(e,t,r){const n=new e,s=t||`${this.constructor.name.toLowerCase()}_id`,i=r||"id";return new F(n.newQuery(),this,s,i)}hasMany(e,t,r){const n=new e,s=t||`${this.constructor.name.toLowerCase()}_id`,i=r||"id";return new I(n.newQuery(),this,s,i)}belongsTo(e,t,r){const n=new e,s=t||`${n.constructor.name.toLowerCase()}_id`,i=r||"id";return new M(n.newQuery(),this,s,i)}belongsToMany(e,t,r,n,s,i){const a=new e,o=t||this.guessPivotTable(a),c=r||`${this.constructor.name.toLowerCase()}_id`,u=n||`${a.constructor.name.toLowerCase()}_id`,l=s||"id",h=i||"id";return new K(a.newQuery(),this,o,c,u,l,h)}guessPivotTable(e){const t=[this.constructor.name.toLowerCase(),e.constructor.name.toLowerCase()];return t.sort(),t.join("_")}static with(e){return this.query().with(e)}setRelation(e,t){return this.relations[e]=t,this}getRelation(e){return this.relations[e]}relationLoaded(e){return void 0!==this.relations[e]}newQuery(){return this.constructor.query()}static snakeCase(e){return e.replace(/([A-Z])/g,"_$1").toLowerCase().replace(/^_/,"")}static pluralize(e){return e.endsWith("y")?e.slice(0,-1)+"ies":e.endsWith("s")?e+"es":e+"s"}studly(e){return e.replace(/(^|_)(\w)/g,(e,t,r)=>r.toUpperCase())}}class V{constructor(e,t,r){this.definition={name:e,type:t,length:r,nullable:!1}}nullable(){return this.definition.nullable=!0,this}default(e){return this.definition.default=e,this}unique(){return this.definition.unique=!0,this}primary(){return this.definition.primary=!0,this}autoIncrement(){return this.definition.autoIncrement=!0,this}unsigned(){return this.definition.unsigned=!0,this}getDefinition(){return this.definition}}class H{constructor(e){this.column=e}references(e){return this.referencedColumn=e,this}on(e){return this.referencedTable=e,this}onDelete(e){return this.onDeleteAction=e,this}onUpdate(e){return this.onUpdateAction=e,this}toSQL(){if(!this.referencedTable||!this.referencedColumn)throw new Error("Foreign key must reference a table and column");let e=`FOREIGN KEY (${this.column}) REFERENCES ${this.referencedTable}(${this.referencedColumn})`;return this.onDeleteAction&&(e+=` ON DELETE ${this.onDeleteAction}`),this.onUpdateAction&&(e+=` ON UPDATE ${this.onUpdateAction}`),e}}class J{columns=[];indexes=[];foreignKeys=[];primaryKeys=[];constructor(e){this.tableName=e}id(e="id"){const t=new V(e,"bigInteger");return t.primary().autoIncrement().unsigned(),this.columns.push(t.getDefinition()),t}uuid(e="id"){const t=new V(e,"uuid");return this.columns.push(t.getDefinition()),t}string(e,t=255){const r=new V(e,"string",t);return this.columns.push(r.getDefinition()),r}text(e){const t=new V(e,"text");return this.columns.push(t.getDefinition()),t}integer(e){const t=new V(e,"integer");return this.columns.push(t.getDefinition()),t}bigInteger(e){const t=new V(e,"bigInteger");return this.columns.push(t.getDefinition()),t}decimal(e,t=10,r=2){const n=new V(e,"decimal");return this.columns.push(n.getDefinition()),n}float(e){const t=new V(e,"float");return this.columns.push(t.getDefinition()),t}double(e){const t=new V(e,"double");return this.columns.push(t.getDefinition()),t}boolean(e){const t=new V(e,"boolean");return this.columns.push(t.getDefinition()),t}date(e){const t=new V(e,"date");return this.columns.push(t.getDefinition()),t}datetime(e){const t=new V(e,"datetime");return this.columns.push(t.getDefinition()),t}timestamp(e){const t=new V(e,"timestamp");return this.columns.push(t.getDefinition()),t}timestamps(){this.timestamp("created_at").nullable(),this.timestamp("updated_at").nullable()}softDeletes(e="deleted_at"){return this.timestamp(e).nullable()}json(e){const t=new V(e,"json");return this.columns.push(t.getDefinition()),t}enum(e,t){const r=new V(e,"enum");return this.columns.push(r.getDefinition()),r}foreign(e){const t=new H(e);return this.foreignKeys.push(t),t}index(e,t){const r=Array.isArray(e)?e:[e];this.indexes.push({columns:r,unique:!1,name:t})}unique(e,t){const r=Array.isArray(e)?e:[e];this.indexes.push({columns:r,unique:!0,name:t})}primary(e){this.primaryKeys=Array.isArray(e)?e:[e]}getColumns(){return this.columns}getTableName(){return this.tableName}getIndexes(){return this.indexes}getForeignKeys(){return this.foreignKeys}}class W{static setAdapter(e){this.adapter=e}static async create(e,t){const r=new J(e);t(r),await this.adapter.createTable(e,r.getColumns())}static async table(e,t){t(new J(e)),console.warn("Schema.table() is not fully implemented yet. Use migrations for complex alterations.")}static async drop(e){await this.adapter.dropTable(e)}static async dropIfExists(e){await this.hasTable(e)&&await this.drop(e)}static async rename(e,t){throw new Error("Schema.rename() not yet implemented")}static async hasTable(e){return await this.adapter.hasTable(e)}static async hasColumn(e,t){return await this.adapter.hasColumn(e,t)}static async getTables(){throw new Error("Schema.getTables() not yet implemented")}static async getColumns(e){throw new Error("Schema.getColumns() not yet implemented")}}class U{static async register(e){let t;try{const e=`${process.cwd()}/database/config`;t=(0,P.dynamicRequire)(e).default||(0,P.dynamicRequire)(e)}catch(e){return void console.warn("No database config found. Skipping database setup.")}const r=(()=>{switch(t.type){case"mysql":return new(__webpack_require__(707).default);case"mongodb":return new(__webpack_require__(697).default);case"postgres":return new(__webpack_require__(590).default);default:throw new Error(`Unsupported DB type ${t.type}`)}})();e.singleton("DatabaseAdapter",()=>r),e.singleton("DBConnection",async()=>{const e=await r.connect(t);return L.setAdapter(r),W.setAdapter(r),console.log(`Connected to ${t.type} database: ${t.database}`),e})}static async close(e){try{const t=await e.make("DatabaseAdapter");await t.disconnect(),console.log("Database connection closed.")}catch(e){}}}__webpack_require__(630);class B{bindings=new Map;singletons=new Map;constructor(){B.instance||(B.instance=this)}static getInstance(){return B.instance||(B.instance=new B),B.instance}bind(e,t){this.isConstructor(t)?this.bindings.set(e,()=>this.build(t)):this.bindings.set(e,t)}singleton(e,t){const r=this.isConstructor(t)?()=>this.build(t):t;this.bindings.set(e,()=>(this.singletons.has(e)||this.singletons.set(e,r(this)),this.singletons.get(e)))}make(e){if(this.bindings.has(e))return this.bindings.get(e)(this);if(this.isConstructor(e))return this.build(e);throw new Error(`Service not found: ${e.toString()}`)}build(e){return new e(...(Reflect.getMetadata("design:paramtypes",e)||[]).map(e=>this.make(e)))}isConstructor(e){return!!e.prototype&&!!e.prototype.constructor.name}}const z=B.getInstance(),G=class{providers=[];constructor(e){this.config=e,this.app=i()(),this.container=B.getInstance(),U.register(this.container).catch(e=>{console.error("Failed to register DatabaseProvider:",e)}),this.initialize(),this.registerProviders(),this.bootProviders()}registerProviders(){this.config.providers&&this.config.providers.forEach(e=>{const t=new e(this);t.register(),this.providers.push(t)})}bootProviders(){this.providers.forEach(e=>{e.boot()})}initialize(){const{staticDir:e="public",distDir:r="dist/public",indexFile:s="dist/public/index.html",views:a,viewsContext:c,routes:l,layout:d,apiRoutes:f,apiBase:m="/api"}=this.config,w=process.cwd();let g=a;!g&&c&&(g=this.loadViewsFromContext(c)),g||(g=this.loadViewsFromAlias()),g||(g=this.discoverViews()),g&&0!==Object.keys(g).length||(console.warn("No views found. Please check your views directory."),g={}),g.NotFoundPage=g.NotFoundPage||R,g.ErrorPage=g.ErrorPage||k,this.app.use(u()({contentSecurityPolicy:!1})),this.app.use(n()()),this.app.use((e,t,r)=>{let n=e.cookies[S];n||(n=T().randomBytes(32).toString("hex"),t.cookie(S,n,{httpOnly:!0,secure:"production"===process.env.NODE_ENV,sameSite:"strict"})),t.locals.csrfToken=n;const s=e.method.toUpperCase();if(["POST","PUT","DELETE","PATCH"].includes(s)){const r=e.headers["x-csrf-token"];if(!r||r!==n)return t.status(403).json({error:"Invalid CSRF Token"})}r()}),this.app.use(j);const _={index:!1,maxAge:"production"===process.env.NODE_ENV?"1y":"0"},b=[h().resolve(w,r),h().resolve(w,e)].filter((e,t,r)=>r.indexOf(e)===t);for(const e of b)this.app.use(i().static(e,_));this.app.use(t()()),this.app.use((e=>{const{views:t,indexFile:r,layout:n}=e;let s=null;return(e,i,a)=>{i.renderPage=(a,c={},u={})=>{const l=i.locals.csrfToken;if(e.get("X-ArcanaJS-Request")||"json"===e.query.format)return i.json({page:a,data:c,params:u,csrfToken:l});try{const h=[],d={tags:h,push:e=>h.push(e)},f=(0,A.renderToString)(p().createElement(y.Provider,{value:d},p().createElement(N,{initialPage:a,initialData:c,initialParams:u,initialUrl:e.path,csrfToken:l,views:t,layout:n}))),m=(0,A.renderToString)(p().createElement(p().Fragment,null,...h));(e=>{if("production"===process.env.NODE_ENV&&s)return e(null,s);r&&o().existsSync(r)?o().readFile(r,"utf8",(t,r)=>{t||"production"!==process.env.NODE_ENV||(s=r),e(t,r)}):("production"===process.env.NODE_ENV&&(s=C),e(null,C))})((e,t)=>{if(e)return console.error("Error reading index.html",e),i.status(500).send("Server Error");var r;const n=`<script id="__ARCANAJS_DATA__" type="application/json">${r={page:a,data:c,params:u,csrfToken:l},JSON.stringify(r).replace(/</g,"\\u003c")}<\/script>`,s=process.env.ARCANA_HMR_PORT?`\n <script>\n (function() {\n const socket = new WebSocket("ws://localhost:${process.env.ARCANA_HMR_PORT}");\n socket.onmessage = function(event) {\n const data = JSON.parse(event.data);\n if (data.type === "reload") {\n window.location.reload();\n }\n };\n })();\n <\/script>`:"",o=t.replace("\x3c!--HEAD_CONTENT--\x3e",m).replace("\x3c!--APP_CONTENT--\x3e",f).replace("\x3c!--ARCANAJS_DATA_SCRIPT--\x3e",n+s);i.send(o)})}catch(e){return console.error("SSR Error:",e),i.status(500).send("Internal Server Error")}return i},a()}})({views:g,indexFile:h().resolve(w,s),layout:d}));const v=(e,t)=>{if(!e)return;const r=Array.isArray(e)?e:[e];for(const e of r)e&&("function"==typeof e.getRouter?this.app.use(t||"/",e.getRouter()):this.app.use(t||"/",e))};try{v(f,m),f&&console.log(`API routes mounted at ${m}`)}catch(e){console.error("Error mounting apiRoutes:",e)}try{v(l)}catch(e){console.error("Error mounting routes:",e)}this.app.use((e=>(t,r,n)=>{let s=t.path.substring(1);if(""===s&&(s="index"),e[s])return r.renderPage(s,{});for(const t of Object.keys(e)){if(!t.includes("["))continue;const e=t.split("/"),n=s.split("/");if(e.length!==n.length)continue;let i=!0;const a={};for(let t=0;t<e.length;t++){const r=e[t],s=n[t];if(r.startsWith("[")&&r.endsWith("]"))a[r.slice(1,-1)]=s;else if(r!==s){i=!1;break}}if(i)return r.renderPage(t,{},a)}n()})(g)),this.app.use((e,t)=>{e.get("X-ArcanaJS-Request")||"json"===e.query.format?t.status(404).json({page:"NotFoundPage",data:{},params:{},csrfToken:t.locals.csrfToken}):t.status(404).renderPage("NotFoundPage")}),this.app.use((e,t,r,n)=>{console.error(e);const s="production"===process.env.NODE_ENV?"Internal Server Error":e.message;t.get("X-ArcanaJS-Request")||"json"===t.query.format?r.status(500).json({page:"ErrorPage",data:{message:s},params:{},csrfToken:r.locals.csrfToken}):r.status(500).renderPage("ErrorPage",{message:s})})}loadViewsFromContext(e){const t={};return e.keys().forEach(r=>{const n=r.replace(/^\.\/(.*)\.tsx$/,"$1");t[n]=e(r).default}),t}loadViewsFromAlias(){try{const e=__webpack_require__(369);if(e)return this.loadViewsFromContext(e)}catch(e){}}discoverViews(){const e={},t=this.config.viewsDir?h().resolve(process.cwd(),this.config.viewsDir):h().resolve(process.cwd(),"src/views");if(!o().existsSync(t))return e;const r=n=>{o().readdirSync(n).forEach(s=>{const i=h().join(n,s);if(o().statSync(i).isDirectory())r(i);else if(s.endsWith(".tsx")||s.endsWith(".jsx")){const r=h().relative(t,i).replace(/\.(tsx|jsx)$/,"");try{if(s.endsWith(".tsx")||s.endsWith(".ts"))try{(0,P.dynamicRequire)("ts-node/register")}catch(e){}const t=(0,P.dynamicRequire)(i);e[r]=t.default||t}catch(e){console.error(`Failed to load view ${r}:`,e)}}})};return r(t),e}start(){const e=this.config.port||process.env.PORT||3e3;if(this.serverInstance=this.app.listen(e,()=>{console.log(`Server is running on http://localhost:${e}`)}),!1!==this.config.autoHandleSignals){const e=async()=>{try{await this.stop(),process.exit(0)}catch(e){console.error("Error during shutdown:",e),process.exit(1)}};this._sigintHandler=e,this._sigtermHandler=e,process.on("SIGINT",this._sigintHandler),process.on("SIGTERM",this._sigtermHandler)}}async stop(){this.serverInstance&&(await new Promise((e,t)=>{this.serverInstance.close(r=>{if(r)return t(r);e()})}),this.serverInstance=void 0,console.log("HTTP server stopped"));try{await U.close(this.container)}catch(e){console.error("Error closing database connection:",e)}try{this._sigintHandler&&(process.removeListener("SIGINT",this._sigintHandler),this._sigintHandler=void 0),this._sigtermHandler&&(process.removeListener("SIGTERM",this._sigtermHandler),this._sigtermHandler=void 0)}catch(e){}}};class Q extends Error{constructor(e){super("The given data was invalid."),this.name="ValidationException",this.errors=e,this.status=422}}class X{errors={};constructor(e,t){this.data=e,this.rules=t}static make(e,t){return new X(e,t)}fails(){return this.validate(),Object.keys(this.errors).length>0}passes(){return!this.fails()}errors_(){return this.errors}validate(){this.errors={};const e={};for(const[t,r]of Object.entries(this.rules)){const n=r.split("|"),s=this.data[t];for(const e of n)if("required"===e)null!=s&&""!==s||this.addError(t,`${t} is required.`);else if("string"===e)void 0!==s&&"string"!=typeof s&&this.addError(t,`${t} must be a string.`);else if("numeric"===e)void 0!==s&&isNaN(Number(s))&&this.addError(t,`${t} must be a number.`);else if("email"===e)void 0===s||/^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(String(s))||this.addError(t,`${t} must be a valid email address.`);else if(e.startsWith("min:")){const r=parseInt(e.split(":")[1]);"string"==typeof s&&s.length<r?this.addError(t,`${t} must be at least ${r} characters.`):"number"==typeof s&&s<r&&this.addError(t,`${t} must be at least ${r}.`)}else if(e.startsWith("max:")){const r=parseInt(e.split(":")[1]);"string"==typeof s&&s.length>r?this.addError(t,`${t} must not be greater than ${r} characters.`):"number"==typeof s&&s>r&&this.addError(t,`${t} must not be greater than ${r}.`)}void 0!==s&&(e[t]=s)}if(Object.keys(this.errors).length>0)throw new Q(this.errors);return e}addError(e,t){this.errors[e]||(this.errors[e]=[]),this.errors[e].push(t)}}class Y{constructor(e){this.req=e}authorize(){return!0}async validate(){if(!this.authorize())throw new Error("This action is unauthorized.");return X.make(this.req.body,this.rules()).validate()}input(e,t=null){return this.req.body[e]||t}all(){return this.req.body}}class Z{constructor(e){this.resource=e}static make(e){return new this(e)}static collection(e){return new ee(e,this)}resolve(e){return null===this.resource?null:Array.isArray(this.resource)?this.resource.map(t=>new this.constructor(t).toArray(e)):this.toArray(e)}toArray(e){return this.resource&&"function"==typeof this.resource.toJSON?this.resource.toJSON():this.resource}}class ee extends Z{constructor(e,t){super(e),this.collects=t}resolve(e){return this.resource.map(t=>new this.collects(t).resolve(e))}}class te{static handle(e,t){let r;try{r=z.make(e)}catch(t){console.warn(`Failed to instantiate controller ${e.name}`,t),r=e}return async(n,s,i)=>{try{if("function"!=typeof r[t])throw new Error(`Method ${t} not found on controller ${e.name}`);await r[t](n,s,i)}catch(e){i(e)}}}}class re{static handle(e,t="handle"){let r;try{r=z.make(e)}catch(t){r=e}return async(n,s,i)=>{try{if("function"!=typeof r[t])throw new Error(`Method ${t} not found on middleware ${e.name}`);await r[t](n,s,i)}catch(e){i(e)}}}}class ne{constructor(){this.router=i().Router(),this.middlewareStack=[],this.prefixStack=[]}static create(){return new ne}middleware(...e){const t=this._clone(),r=e.map(e=>this._resolveMiddleware(e));return t.middlewareStack=[...this.middlewareStack,...r],t}prefix(e){const t=this._clone();return t.prefixStack=[...this.prefixStack,e.replace(/^\/|\/$/g,"")],t}group(e){return e(this),this}get(e,...t){const r=t.pop(),n=t;return this._addRoute("get",e,r,n)}post(e,...t){const r=t.pop(),n=t;return this._addRoute("post",e,r,n)}put(e,...t){const r=t.pop(),n=t;return this._addRoute("put",e,r,n)}delete(e,...t){const r=t.pop(),n=t;return this._addRoute("delete",e,r,n)}patch(e,...t){const r=t.pop(),n=t;return this._addRoute("patch",e,r,n)}options(e,...t){const r=t.pop(),n=t;return this._addRoute("options",e,r,n)}resource(e,t){return this.get(e,t,"index"),this.get(`${e}/create`,t,"create"),this.post(e,t,"store"),this.get(`${e}/:id`,t,"show"),this.get(`${e}/:id/edit`,t,"edit"),this.put(`${e}/:id`,t,"update"),this.patch(`${e}/:id`,t,"update"),this.delete(`${e}/:id`,t,"destroy"),this}getRouter(){return this.router}mount(e,t="/"){e.use(t,this.router)}_clone(){const e=new ne;return e.router=this.router,e.middlewareStack=[...this.middlewareStack],e.prefixStack=[...this.prefixStack],e}_addRoute(e,t,r,n=[]){const s=this._buildPath(t),i=this._buildHandler(r),a=n.flat(1/0).map(e=>this._resolveMiddleware(e)),o=[...this.middlewareStack,...a,i];return this.router[e](s,...o),this}_resolveMiddleware(e){var t;if("function"==typeof e&&(null===(t=e.prototype)||void 0===t||!t.handle))return e;if(Array.isArray(e)&&2===e.length){const[t,r]=e;return re.handle(t,r)}if("function"==typeof e||"object"==typeof e&&null!==e)return re.handle(e,"handle");throw new Error("Invalid middleware. Must be a function, [Class, 'method'], or Class.")}_buildPath(e){const t=e.replace(/^\//,""),r=this.prefixStack.filter(e=>""!==e);return 0===r.length?`/${t}`:`/${r.join("/")}/${t}`.replace(/\/+/g,"/")}_buildHandler(e){if("function"==typeof e)return e;if(Array.isArray(e)&&2===e.length){const[t,r]=e;return te.handle(t,r)}throw new Error('Action must be a function or array [Controller, "method"]')}}class se{static _router=new ne;static create(){return ne.create()}static middleware(...e){return this._router.middleware(...e)}static prefix(e){return this._router.prefix(e)}static group(e){return this._router.group(e)}static get(e,...t){return this._router.get(e,...t)}static post(e,...t){return this._router.post(e,...t)}static put(e,...t){return this._router.put(e,...t)}static delete(e,...t){return this._router.delete(e,...t)}static patch(e,...t){return this._router.patch(e,...t)}static options(e,...t){return this._router.options(e,...t)}static getRouter(){return this._router.getRouter()}static mount(e,t="/"){return this._router.mount(e,t)}static reset(){this._router=new ne}}const ie=se;class ae{constructor(e){this.app=e}register(){}boot(){}}function oe(e,t){return new G({...t})}})();var __webpack_export_target__=exports;for(var __webpack_i__ in __webpack_exports__)__webpack_export_target__[__webpack_i__]=__webpack_exports__[__webpack_i__];__webpack_exports__.__esModule&&Object.defineProperty(__webpack_export_target__,"__esModule",{value:!0})})();
2
3
  //# sourceMappingURL=arcanajs.js.map
@@ -0,0 +1,14 @@
1
+ /*! *****************************************************************************
2
+ Copyright (C) Microsoft. All rights reserved.
3
+ Licensed under the Apache License, Version 2.0 (the "License"); you may not use
4
+ this file except in compliance with the License. You may obtain a copy of the
5
+ License at http://www.apache.org/licenses/LICENSE-2.0
6
+
7
+ THIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
8
+ KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED
9
+ WARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE,
10
+ MERCHANTABLITY OR NON-INFRINGEMENT.
11
+
12
+ See the Apache Version 2.0 License for specific language governing permissions
13
+ and limitations under the License.
14
+ ***************************************************************************** */