arcanajs 2.6.0 → 3.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +7 -22
- package/bin/arcanajs.js +1 -1
- package/dist/arcanajs.client.js +2 -0
- package/dist/arcanajs.client.js.map +1 -0
- package/dist/arcanajs.js +2 -0
- package/dist/arcanajs.js.map +1 -0
- package/dist/cli/index.js +2 -0
- package/dist/cli/index.js.map +1 -0
- package/{framework → dist}/lib/client/index.d.ts +6 -26
- package/{framework → dist}/lib/global.d.ts +6 -10
- package/dist/lib/index.client.d.ts +11 -0
- package/dist/lib/index.d.ts +38 -0
- package/{framework → dist}/lib/server/ArcanaJSServer.d.ts +4 -4
- package/dist/lib/server/DefaultTemplate.d.ts +1 -0
- package/{framework → dist}/lib/shared/components/Body.d.ts +2 -2
- package/{framework → dist}/lib/shared/components/Head.d.ts +2 -1
- package/{framework → dist}/lib/shared/components/Link.d.ts +2 -2
- package/{framework → dist}/lib/shared/components/NavLink.d.ts +2 -2
- package/{framework → dist}/lib/shared/components/Page.d.ts +2 -1
- package/{framework → dist}/lib/shared/hooks/useLocation.d.ts +2 -1
- package/dist/lib/shared/hooks/usePage.d.ts +2 -0
- package/dist/lib/shared/hooks/useParams.d.ts +2 -0
- package/dist/lib/shared/hooks/useQuery.d.ts +2 -0
- package/dist/lib/shared/hooks/useRouter.d.ts +2 -0
- package/package.json +26 -23
- package/framework/cli/index.js +0 -204
- package/framework/cli/templates.d.ts +0 -6
- package/framework/cli/templates.js +0 -62
- package/framework/cli/webpack.config.js +0 -310
- package/framework/lib/client/index.js +0 -97
- package/framework/lib/config/index.d.ts +0 -46
- package/framework/lib/config/index.js +0 -115
- package/framework/lib/index.d.ts +0 -19
- package/framework/lib/index.js +0 -59
- package/framework/lib/server/ArcanaJSMiddleware.js +0 -114
- package/framework/lib/server/ArcanaJSServer.js +0 -441
- package/framework/lib/server/ControllerBinder.js +0 -32
- package/framework/lib/server/CsrfMiddleware.js +0 -34
- package/framework/lib/server/DynamicRouter.js +0 -50
- package/framework/lib/server/ResponseHandlerMiddleware.js +0 -30
- package/framework/lib/server/Router.js +0 -203
- package/framework/lib/server/default-index.html +0 -12
- package/framework/lib/server.d.ts +0 -33
- package/framework/lib/server.js +0 -69
- package/framework/lib/shared/components/Body.js +0 -8
- package/framework/lib/shared/components/Head.js +0 -125
- package/framework/lib/shared/components/Link.js +0 -30
- package/framework/lib/shared/components/NavLink.js +0 -13
- package/framework/lib/shared/components/Page.js +0 -10
- package/framework/lib/shared/context/HeadContext.js +0 -5
- package/framework/lib/shared/context/PageContext.js +0 -6
- package/framework/lib/shared/context/RouterContext.js +0 -10
- package/framework/lib/shared/core/ArcanaJSApp.js +0 -194
- package/framework/lib/shared/hooks/useHead.js +0 -7
- package/framework/lib/shared/hooks/useLocation.js +0 -13
- package/framework/lib/shared/hooks/usePage.d.ts +0 -1
- package/framework/lib/shared/hooks/usePage.js +0 -7
- package/framework/lib/shared/hooks/useParams.d.ts +0 -1
- package/framework/lib/shared/hooks/useParams.js +0 -13
- package/framework/lib/shared/hooks/useQuery.d.ts +0 -1
- package/framework/lib/shared/hooks/useQuery.js +0 -9
- package/framework/lib/shared/hooks/useRouter.d.ts +0 -1
- package/framework/lib/shared/hooks/useRouter.js +0 -13
- package/framework/lib/shared/utils/createSingletonContext.js +0 -21
- package/framework/lib/shared/views/ErrorPage.js +0 -12
- package/framework/lib/shared/views/NotFoundPage.js +0 -11
- package/framework/lib/types.d.ts +0 -174
- package/framework/lib/types.js +0 -8
- package/framework/templates/arcanajs.config.ts +0 -44
- package/framework/templates/package.json +0 -15
- package/framework/templates/postcss.config.js +0 -6
- package/framework/templates/public/arcanajs.png +0 -0
- package/framework/templates/public/arcanajs.svg +0 -12
- package/framework/templates/public/favicon.ico +0 -0
- package/framework/templates/src/arcanajs.d.ts +0 -8
- package/framework/templates/src/client/globals.css +0 -199
- package/framework/templates/src/client/index.tsx +0 -7
- package/framework/templates/src/db/mongo.ts +0 -10
- package/framework/templates/src/db/mongoose.ts +0 -12
- package/framework/templates/src/db/mysql.ts +0 -15
- package/framework/templates/src/db/postgres.ts +0 -8
- package/framework/templates/src/server/controllers/HomeController.ts +0 -19
- package/framework/templates/src/server/controllers/UsersController.ts +0 -37
- package/framework/templates/src/server/index.ts +0 -38
- package/framework/templates/src/server/routes/api.ts +0 -6
- package/framework/templates/src/server/routes/web.ts +0 -7
- package/framework/templates/src/types/HomePageData.ts +0 -11
- package/framework/templates/src/views/ErrorPage.tsx +0 -136
- package/framework/templates/src/views/HomePage.tsx +0 -369
- package/framework/templates/src/views/NotFoundPage.tsx +0 -108
- package/framework/templates/tsconfig.json +0 -27
- /package/{framework → dist}/cli/index.d.ts +0 -0
- /package/{framework → dist}/cli/webpack.config.d.ts +0 -0
- /package/{framework → dist}/lib/server/ArcanaJSMiddleware.d.ts +0 -0
- /package/{framework → dist}/lib/server/ControllerBinder.d.ts +0 -0
- /package/{framework → dist}/lib/server/CsrfMiddleware.d.ts +0 -0
- /package/{framework → dist}/lib/server/DynamicRouter.d.ts +0 -0
- /package/{framework → dist}/lib/server/ResponseHandlerMiddleware.d.ts +0 -0
- /package/{framework → dist}/lib/server/Router.d.ts +0 -0
- /package/{framework → dist}/lib/shared/context/HeadContext.d.ts +0 -0
- /package/{framework → dist}/lib/shared/context/PageContext.d.ts +0 -0
- /package/{framework → dist}/lib/shared/context/RouterContext.d.ts +0 -0
- /package/{framework → dist}/lib/shared/core/ArcanaJSApp.d.ts +0 -0
- /package/{framework → dist}/lib/shared/hooks/useHead.d.ts +0 -0
- /package/{framework → dist}/lib/shared/utils/createSingletonContext.d.ts +0 -0
- /package/{framework → dist}/lib/shared/views/ErrorPage.d.ts +0 -0
- /package/{framework → dist}/lib/shared/views/NotFoundPage.d.ts +0 -0
package/README.md
CHANGED
|
@@ -13,40 +13,25 @@ ArcanaJS is a modern React framework for building server-side rendered (SSR) app
|
|
|
13
13
|
|
|
14
14
|
## Quick Start
|
|
15
15
|
|
|
16
|
-
### Create a new folder
|
|
17
|
-
|
|
18
|
-
```bash
|
|
19
|
-
mkdir my-app
|
|
20
|
-
cd my-app
|
|
21
|
-
```
|
|
22
|
-
|
|
23
16
|
### Initialize a New Project
|
|
24
17
|
|
|
25
|
-
|
|
26
|
-
npx arcanajs
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
### Development
|
|
30
|
-
|
|
31
|
-
Install dependencies:
|
|
32
|
-
|
|
33
|
-
```bash
|
|
34
|
-
npm install
|
|
35
|
-
```
|
|
18
|
+
````bash
|
|
19
|
+
npx create-arcanajs-app
|
|
20
|
+
````
|
|
36
21
|
|
|
37
22
|
Start the development server:
|
|
38
23
|
|
|
39
|
-
|
|
24
|
+
````bash
|
|
40
25
|
npm run dev
|
|
41
|
-
|
|
26
|
+
````
|
|
42
27
|
|
|
43
28
|
Visit `http://localhost:3000` to see your application.
|
|
44
29
|
|
|
45
30
|
### Build for Production
|
|
46
31
|
|
|
47
|
-
|
|
32
|
+
````bash
|
|
48
33
|
npm run build
|
|
49
|
-
|
|
34
|
+
````
|
|
50
35
|
|
|
51
36
|
### Start Production Server
|
|
52
37
|
|
package/bin/arcanajs.js
CHANGED
|
@@ -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":"mBACA,IAAIA,EAAsB,CCA1BA,EAAyBC,IACxB,IAAIC,EAASD,GAAUA,EAAOE,WAC7B,IAAOF,EAAiB,QACxB,IAAM,EAEP,OADAD,EAAoBI,EAAEF,EAAQ,CAAEG,IACzBH,GCLRF,EAAwB,CAACM,EAASC,KACjC,IAAI,IAAIC,KAAOD,EACXP,EAAoBS,EAAEF,EAAYC,KAASR,EAAoBS,EAAEH,EAASE,IAC5EE,OAAOC,eAAeL,EAASE,EAAK,CAAEI,YAAY,EAAMC,IAAKN,EAAWC,MCJ3ER,EAAwB,CAACc,EAAKC,IAAUL,OAAOM,UAAUC,eAAeC,KAAKJ,EAAKC,GCClFf,EAAyBM,IACH,oBAAXa,QAA0BA,OAAOC,aAC1CV,OAAOC,eAAeL,EAASa,OAAOC,YAAa,CAAEC,MAAO,WAE7DX,OAAOC,eAAeL,EAAS,aAAc,CAAEe,OAAO,M,oLCLvD,MAAM,EAA+BC,QAAQ,S,aCM7C,MAGA,EAHkCC,EAAGC,cAC5BC,IAAAA,cAAAA,IAAAA,SAAA,KAAGD,GCIL,SAASE,EACdlB,EACAmB,GAEA,MAAMC,EAAYC,OACZC,EAAYX,OAAOY,IAAI,oBAAoBvB,KAMjD,OAJKoB,EAAUE,KACbF,EAAUE,IAAaE,EAAAA,EAAAA,eAAiBL,IAGnCC,EAAUE,EACnB,CCfO,MAAMG,EAAcP,EACzB,cACA,MCsFF,EA7FsDQ,EAAGV,eACvD,MAAMW,GCDqBC,EAAAA,EAAAA,YAAWH,GD2FtC,MAvFsB,oBAAXI,QAA0BF,GACnCV,IAAAA,SAAea,QAAQd,EAAWe,IAC5Bd,IAAAA,eAAqBc,IACvBJ,EAAYK,KACVf,IAAAA,aAAmBc,EAAkC,CACnD,qBAAsB,aAQhCE,EAAAA,EAAAA,WAAU,KACR,MAAMC,EAAiC,GA+DvC,OA7DAjB,IAAAA,SAAea,QAAQd,EAAWe,IAChC,GAAId,IAAAA,eAAqBc,GAAQ,CAC/B,MAAMI,EAAeJ,EACrB,GAA0B,UAAtBI,EAAaC,KACfC,SAASC,MAAQH,EAAaI,MAAMvB,cAC/B,GAA0B,SAAtBmB,EAAaC,KAAiB,CACvC,MAAMG,EAAQJ,EAAaI,MAE3B,IAAIC,EAAW,OAKf,GAJID,EAAME,OAAMD,GAAY,UAAUD,EAAME,UACxCF,EAAMG,WAAUF,GAAY,cAAcD,EAAMG,cAGhDH,EAAME,MAAQF,EAAMG,SAAU,CAChC,IAAIC,EACFN,SAASO,cACPJ,EAAW,gCACRH,SAASO,cAAcJ,GAE9B,GAAIG,EAEFA,EAAQE,aAAa,UAAWN,EAAMO,SACtCH,EAAQE,aAAa,qBAAsB,QAC3CX,EAAgBF,KAAKW,OAChB,CAEL,MAAMI,EAAUV,SAASW,cAAc,QACvC9C,OAAO+C,KAAKV,GAAOT,QAAS9B,IAC1B+C,EAAQF,aAAa7C,EAAKuC,EAAMvC,MAElC+C,EAAQF,aAAa,qBAAsB,QAC3CR,SAASa,KAAKC,YAAYJ,GAC1Bb,EAAgBF,KAAKe,EACvB,CACF,CACF,MAAO,GAA0B,SAAtBZ,EAAaC,KAAiB,CACvC,MAAMG,EAAQJ,EAAaI,MAC3B,IAAIC,EAAW,OACXD,EAAMa,MAAKZ,GAAY,SAASD,EAAMa,SACtCb,EAAMc,OAAMb,GAAY,UAAUD,EAAMc,UAE5C,IAAIV,EACFN,SAASO,cAAcJ,EAAW,gCAClCH,SAASO,cAAcJ,GAEzB,GAAIG,EACFA,EAAQE,aAAa,qBAAsB,QAC3CX,EAAgBF,KAAKW,OAChB,CACL,MAAMW,EAAUjB,SAASW,cAAc,QACvC9C,OAAO+C,KAAKV,GAAOT,QAAS9B,IAC1BsD,EAAQT,aAAa7C,EAAKuC,EAAMvC,MAElCsD,EAAQT,aAAa,qBAAsB,QAC3CR,SAASa,KAAKC,YAAYG,GAC1BpB,EAAgBF,KAAKsB,EACvB,CACF,CACF,IAGK,KAELpB,EAAgBJ,QAASyB,IAGvBA,EAAGC,aAGN,CAACxC,IAEG,ME/EIyC,EAAgBvC,EAC3B,gBACA,MAGWwC,EAGRA,EAAG7C,QAAOG,cAEXC,IAAAA,cAACwC,EAAcE,SAAQ,CAAC9C,MAAOA,GAAQG,GCf3C,EAPkB4C,KAChB,MAAMC,GAAUjC,EAAAA,EAAAA,YAAW6B,GAC3B,IAAKI,EACH,MAAM,IAAIC,MAAM,gDAElB,OAAOD,G,wNCAT,MA0CA,EA1CkCE,EAChCV,OACArC,WACAgD,YAAW,KACRzB,MAEH,MAAM,WAAE0B,EAAU,gBAAEC,GAAoBN,IAElCO,EAAa,eAAeC,KAAKf,GAqBvC,OACEpC,IAAAA,cAAA,IAAAoD,EAAA,CACEhB,KAAMA,EACNiB,QAtBgBC,UAClBC,EAAEC,iBACEN,EAEFtC,OAAO6C,KAAKrB,EAAM,SAAU,uBACnBa,QACHA,EAAgBb,GAEtBY,EAAWZ,IAeXsB,aAXqBC,KACnBZ,IAAaG,GAEfU,MAAMxB,EAAM,CAAEyB,OAAQ,SAAUC,MAAM,SAStCC,OAAQb,EAAa,cAAWc,EAChC7B,IAAKe,EAAa,2BAAwBc,GACtC1C,GAEHvB,I,wNCnCP,MA4BA,EA5BwCkE,EACtC7B,OACA8B,kBAAkB,SAClBC,YAAY,GACZC,SAAQ,EACRrB,YAAW,EACXhD,cACGuB,MAEH,MAAM,WAAE+C,GAAe1B,IAIjB2B,EAAoB,GAAGH,MAFZC,EAAQC,IAAejC,EAAOiC,EAAWE,WAAWnC,IAGxD8B,EAAkB,KAC5BM,OAEH,OACExE,IAAAA,cAAC8C,EAAIM,EAAA,CACHhB,KAAMA,EACN+B,UAAWG,EACXvB,SAAUA,GACNzB,GAEHvB,IChCM0E,EAAcxE,EACzB,cACA,MCmBF,EApBayE,EACXC,OACAtD,QACAtB,cAOEC,IAAAA,cAACyE,EAAY/B,SAAQ,CAAC9C,MAAO+E,GAC1BtD,GACCrB,IAAAA,cAACS,EAAI,KACHT,IAAAA,cAAA,aAAQqB,IAGXtB,GCpBD,EAA+BF,QAAQ,oBC2BhC+E,EAIXtD,IAEA,MAAM,YACJuD,EAAW,YACXC,EAAW,cACXC,EAAgB,CAAC,EAAY,WAC7BC,EAAU,UACVC,EAAS,MACTC,EACAC,OAAQC,EAAM,WACdC,EAAU,WACVC,EAAa,IACXhE,GAEGiE,EAAMC,IAAWC,EAAAA,EAAAA,UAAiBZ,IAClCF,EAAMe,IAAWD,EAAAA,EAAAA,UAAgBX,IACjCa,EAAQC,IAAaH,EAAAA,EAAAA,UAAkBV,IACvCc,EAAKC,IAAUL,EAAAA,EAAAA,UACpBT,IACqB,oBAAXpE,OAAyBA,OAAOmF,SAASC,SAAW,OAEzDC,EAAcC,IAAmBT,EAAAA,EAAAA,WAAS,GAG3CU,EAAkBnG,IAAAA,OACtB,IAAIoG,KAIAC,EAAerG,IAAAA,OAAqC,OAE1DgB,EAAAA,EAAAA,WAAU,KACc,oBAAXJ,QAA2BA,OAAO0F,QAAQC,OACnD3F,OAAO0F,QAAQE,aACb,CAAEjB,KAAMV,EAAaF,KAAMG,EAAaa,OAAQZ,GAChD,GACAnE,OAAOmF,SAAS3D,MAIpB,MAAMqE,EAAkBC,IACtB,GAAIA,EAAMH,MACRf,EAAQkB,EAAMH,MAAMhB,MACpBG,EAAQgB,EAAMH,MAAM5B,MACpBiB,EAAUc,EAAMH,MAAMZ,QAAW,CAAC,GAClCG,EAAOlF,OAAOmF,SAASC,cAClB,CAEL,MAAMW,EAAO/F,OAAOmF,SAASC,SACxBhD,EAAW2D,GAAM7C,MAAM,KAC1BlD,OAAOmF,SAASa,UAEpB,GAIF,OADAhG,OAAOiG,iBAAiB,WAAYJ,GAC7B,KAAM,IAAAK,EACXlG,OAAOmG,oBAAoB,WAAYN,GACnB,QAApBK,EAAAT,EAAaW,eAAO,IAAAF,GAApBA,EAAsBG,UAEvB,IAEH,MAaMjE,EAAaM,UAAyC,IAAA4D,EAE1D,MAAMC,EAAMhB,EAAgBa,QAC5B,GAAIG,EAAIC,IAAIC,GAAS,CACnB,MAAMC,EAASH,EAAI/H,IAAIiI,GAOvB,GANA7B,EAAQ8B,EAAO/B,MACfG,EAAQ4B,EAAO3C,MACfiB,EAAU0B,EAAO3B,QAAW,CAAC,GAC7BG,EAAOuB,GACPzG,OAAO0F,QAAQiB,UAAUD,EAAQ,GAAID,GAEf,oBAAXzG,OACT,IACEA,OAAO4G,SAAS,CAAEC,IAAK,EAAGC,SAAU,UACtC,CAAE,MACA,CAKJ,YADIrC,GAAYA,EAAWgC,GAE7B,CAEAnB,GAAgB,GAGI,QAApBgB,EAAAb,EAAaW,eAAO,IAAAE,GAApBA,EAAsBD,QACtB,MAAMU,EAAa,IAAIC,gBACvBvB,EAAaW,QAAUW,EAEvB,IACE,MAAME,QAAiBjE,MAAMyD,EAAQ,CACnCS,QAAS,CAAE,qBAAsB,QACjCC,MAAO,WACPC,OAAQL,EAAWK,SAGrB,IAAKH,EAASI,GAAI,CAChB,GAAwB,MAApBJ,EAASK,OAQX,OAPA1C,EAAQ,gBACRM,EAAOuB,QACPzG,OAAO0F,QAAQiB,UACb,CAAEhC,KAAM,eAAgBZ,KAAM,CAAC,GAC/B,GACA0C,GAIJ,MAAM,IAAIxE,MACR,sBAAsBgF,EAASK,UAAUL,EAASM,aAEtD,CAGA,KADoBN,EAASC,QAAQ1I,IAAI,iBAAmB,IAC3CgJ,SAAS,oBAExB,YADAxH,OAAOmF,SAAS3D,KAAOiF,GAIzB,MAAMgB,QAAaR,EAASQ,OAEtBC,EAAU,CACd/C,KAAM8C,EAAK9C,KACXZ,KAAM0D,EAAK1D,KACXgB,OAAS0C,EAAK1C,QAAU,CAAC,GAe3B,GA5Fa4C,EACfxJ,EACAa,KAEA,MAAMuH,EAAMhB,EAAgBa,QAG5B,GAFIG,EAAIC,IAAIrI,IAAMoI,EAAIqB,OAAOzJ,GAC7BoI,EAAIsB,IAAI1J,EAAKa,GACTuH,EAAIuB,KAAOpD,EAAY,CACzB,MAAMqD,EAAWxB,EAAInF,OAAO4G,OAAOhJ,WAClBoE,IAAb2E,GAAwBxB,EAAIqB,OAAOG,EACzC,GAqEEJ,CAASlB,EAAQiB,GAEjB1H,OAAO0F,QAAQiB,UACb,CAAEhC,KAAM+C,EAAQ/C,KAAMZ,KAAM2D,EAAQ3D,KAAMgB,OAAQ2C,EAAQ3C,QAC1D,GACA0B,GAGF7B,EAAQ8C,EAAQ/C,MAChBG,EAAQ4C,EAAQ3D,MAChBiB,EAAU0C,EAAQ3C,QAAW,CAAC,GAC9BG,EAAOuB,GAEe,oBAAXzG,OACT,IACEA,OAAO4G,SAAS,CAAEC,IAAK,EAAGC,SAAU,UACtC,CAAE,MACA,CAIArC,GAAYA,EAAWgC,EAC7B,CAAE,MAAOwB,GACP,GAAkB,gBAAdA,aAAG,EAAHA,EAAKrH,MAAuB,OAEhC,MADAsH,QAAQC,MAAM,oBAAqBF,GAC7BA,CACR,CAAE,QAEIxC,EAAaW,UAAYW,IAAYtB,EAAaW,QAAU,MAChEd,GAAgB,EAClB,GAmBIrE,EAhBamH,MACjB,MAAMC,EAAa/D,EAAMK,IACvBL,EAAoB,cAAC,KACdlF,IAAAA,cAAA,WAAK,kBAMd,OACEA,IAAAA,cAAC0E,EAAI,CAACC,KAAMA,GACV3E,IAAAA,cAACiJ,EAAS,CAACtE,KAAMA,EAAM3B,WAAYA,EAAY2C,OAAQA,MAK7CqD,GAEhB,OACEhJ,IAAAA,cAACyC,EAAc,CACb7C,MAAO,CAELoD,WAAYA,IAAIkG,KACTlG,EAAWkG,EAAK,KAGvBjG,gBAAiBD,EACjBmG,YAAa5D,EACblB,WAAYwB,EACZF,SACAV,YACAI,aACAY,iBAGDb,EAASpF,IAAAA,cAACoF,EAAM,KAAEvD,GAAoB7B,IAAAA,cAAAA,IAAAA,SAAA,KAAG6B,KCtOjC,SAASuH,GAAU,QAChCC,EAAU,uBAAsB,WAChCC,EAAa,IAAG,MAChBC,IAEA,MAAMC,EAAyC,gBAAzBC,QAAQC,IAAIC,SAElC,OACE3J,MAAA+B,cAAC2C,EAAI,KACH1E,MAAA+B,cAACtB,EAAI,KACHT,MAAA+B,cAAA,aAAQuH,EAAW,mBACnBtJ,MAAA+B,cAAA,QAAMP,KAAK,cAAcK,QAAQ,qCAEnC7B,MAAA+B,cAACjC,EAAI,KACHE,MAAA+B,cAAA,OAAKoC,UAAU,sHAEbnE,MAAA+B,cAAA,OAAKoC,UAAU,yDACbnE,MAAA+B,cAAA,OAAKoC,UAAU,6CACfnE,MAAA+B,cAAA,OAAKoC,UAAU,kGACfnE,MAAA+B,cAAA,OACEoC,UAAU,qGACVyF,MAAO,CAAEC,eAAgB,QAE3B7J,MAAA+B,cAAA,OAAKoC,UAAU,oCAGjBnE,MAAA+B,cAAA,OAAKoC,UAAU,+DACbnE,MAAA+B,cAAA,OAAKoC,UAAU,iEACbnE,MAAA+B,cAAA,OAAKoC,UAAU,QACbnE,MAAA+B,cAAA,OAAKoC,UAAU,+BACbnE,MAAA+B,cAAA,QAAMoC,UAAU,sCAAqC,OAEvDnE,MAAA+B,cAAA,MAAIoC,UAAU,sGACXmF,GAEHtJ,MAAA+B,cAAA,MAAIoC,UAAU,sCAAqC,gBAGnDnE,MAAA+B,cAAA,KAAGoC,UAAU,yCACVkF,IAILrJ,MAAA+B,cAAA,OAAKoC,UAAU,uDACbnE,MAAA+B,cAACe,EAAI,CACHV,KAAK,IACL+B,UAAU,+OAEVnE,MAAA+B,cAAA,OACEoC,UAAU,UACV2F,KAAK,OACLC,OAAO,eACPC,QAAQ,aAERhK,MAAA+B,cAAA,QACEkI,cAAc,QACdC,eAAe,QACfC,YAAa,EACbxL,EAAE,sJAEA,WAIRqB,MAAA+B,cAAA,UACEsB,QAASA,IAAMzC,OAAOmF,SAASa,SAC/BzC,UAAU,gIAEVnE,MAAA+B,cAAA,OACEoC,UAAU,UACV2F,KAAK,OACLC,OAAO,eACPC,QAAQ,aAERhK,MAAA+B,cAAA,QACEkI,cAAc,QACdC,eAAe,QACfC,YAAa,EACbxL,EAAE,iHAEA,cAKT6K,GAAiBD,GAChBvJ,MAAA+B,cAAA,OAAKoC,UAAU,mCACbnE,MAAA+B,cAAA,WAASoC,UAAU,uEACjBnE,MAAA+B,cAAA,WAASoC,UAAU,iIACjBnE,MAAA+B,cAAA,YAAM,kCACN/B,MAAA+B,cAAA,OACEoC,UAAU,mEACV2F,KAAK,OACLC,OAAO,eACPC,QAAQ,aAERhK,MAAA+B,cAAA,QACEkI,cAAc,QACdC,eAAe,QACfC,YAAa,EACbxL,EAAE,qBAIRqB,MAAA+B,cAAA,OAAKoC,UAAU,iHACZoF,MAOXvJ,MAAA+B,cAAA,OAAKoC,UAAU,8BAA6B,mCACT,IACjCnE,MAAA+B,cAACe,EAAI,CACHV,KAAK,WACL+B,UAAU,+DACX,mBAEM,QAQrB,CCjIe,SAASiG,GAAa,IAAEvE,IACrC,OACE7F,MAAA+B,cAAC2C,EAAI,KACH1E,MAAA+B,cAACtB,EAAI,KACHT,MAAA+B,cAAA,aAAO,wBACP/B,MAAA+B,cAAA,QACEP,KAAK,cACLK,QAAQ,+CAGZ7B,MAAA+B,cAACjC,EAAI,KACHE,MAAA+B,cAAA,OAAKoC,UAAU,sHAEbnE,MAAA+B,cAAA,OAAKoC,UAAU,yDACbnE,MAAA+B,cAAA,OAAKoC,UAAU,6CACfnE,MAAA+B,cAAA,OAAKoC,UAAU,oGACfnE,MAAA+B,cAAA,OACEoC,UAAU,sGACVyF,MAAO,CAAEC,eAAgB,QAE3B7J,MAAA+B,cAAA,OAAKoC,UAAU,oCAGjBnE,MAAA+B,cAAA,OAAKoC,UAAU,8DACbnE,MAAA+B,cAAA,OAAKoC,UAAU,iEACbnE,MAAA+B,cAAA,OAAKoC,UAAU,QACbnE,MAAA+B,cAAA,MAAIoC,UAAU,gHAA+G,OAG7HnE,MAAA+B,cAAA,MAAIoC,UAAU,sCAAqC,kBAGnDnE,MAAA+B,cAAA,KAAGoC,UAAU,yCACV0B,EACC7F,MAAA+B,cAAA/B,MAAAqK,SAAA,KAAE,YACSrK,MAAA+B,cAAA,QAAMoC,UAAU,mBAAkB,IAAE0B,EAAI,KAAS,IAAI,qCAIhE,+CAKN7F,MAAA+B,cAAA,OAAKoC,UAAU,kDACbnE,MAAA+B,cAACe,EAAI,CACHV,KAAK,IACL+B,UAAU,8HAEVnE,MAAA+B,cAAA,OACEoC,UAAU,UACV2F,KAAK,OACLC,OAAO,eACPC,QAAQ,aAERhK,MAAA+B,cAAA,QACEkI,cAAc,QACdC,eAAe,QACfC,YAAa,EACbxL,EAAE,sJAEA,WAIRqB,MAAA+B,cAAA,UACEsB,QAASA,IAAMzC,OAAO0F,QAAQgE,OAC9BnG,UAAU,gIAEVnE,MAAA+B,cAAA,OACEoC,UAAU,UACV2F,KAAK,OACLC,OAAO,eACPC,QAAQ,aAERhK,MAAA+B,cAAA,QACEkI,cAAc,QACdC,eAAe,QACfC,YAAa,EACbxL,EAAE,iCAEA,aAKZqB,MAAA+B,cAAA,OAAKoC,UAAU,8BAA6B,0CACF,IACxCnE,MAAA+B,cAACe,EAAI,CACHV,KAAK,WACL+B,UAAU,qEACX,mBAEM,QAQrB,CC7DA,MAyDA,EAzDwBoG,CACtBC,EACArF,EACAsF,KAEA,IAAIvF,EAAuC,CAAC,EAExCsF,EAAexI,MAAuC,mBAAxBwI,EAAexI,KAC/CwI,EAAexI,OAAOnB,QAAS9B,IAC7B,MAAM2L,EAAW3L,EAAI4L,QAAQ,kBAAmB,MAChDzF,EAAMwF,GAAYF,EAAezL,GAAK6L,UAGxC1F,EAAQsF,EAILtF,EAAoB,eACvBA,EAAoB,aAAIkF,GAErBlF,EAAiB,YACpBA,EAAiB,UAAIkE,GAGvB,MAAMyB,EAAYzJ,SAAS0J,eAAe,QACpCC,EAAa3J,SAAS0J,eAAe,qBAGrCpK,EAA2B,CAC/BsK,KAAM,GACNjK,KAAMA,QAGR,GAAI8J,GAAaE,EACf,IACE,MAAM,KAAExF,EAAI,KAAEZ,EAAI,OAAEgB,EAAM,UAAEV,GAAcgG,KAAKC,MAC7CH,EAAWI,aAAe,OAE5BC,EAAAA,EAAAA,aACEP,EACA7K,IAAAA,cAACQ,EAAYkC,SAAQ,CAAC9C,MAAOc,GAC3BV,IAAAA,cAAC4E,EAAW,CACVC,YAAaU,EACbT,YAAaH,EACbI,cAAeY,EACfV,UAAWA,EACXC,MAAOA,EACPC,OAAQA,EACRE,YAAYoF,aAAO,EAAPA,EAASpF,aAAU,MAAa,MAIpD,CAAE,MAAO9B,GACPuF,QAAQC,MAAM,+BAAgCxF,EAChD,GC5FJ,EARoB8H,KAClB,MAAM,WAAEhH,GAAe1B,IACvB,MAAO,CACLqD,SAAU3B,EACViH,OAA0B,oBAAX1K,OAAyBA,OAAOmF,SAASuF,OAAS,GACjEC,KAAwB,oBAAX3K,OAAyBA,OAAOmF,SAASwF,KAAO,KCHjE,EADgBC,KAAkB7K,EAAAA,EAAAA,YAAW8D,GCO7C,EAPkBgH,KAChB,MAAM7I,GAAUjC,EAAAA,EAAAA,YAAW6B,GAC3B,IAAKI,EACH,MAAM,IAAIC,MAAM,gDAElB,OAAOD,EAAQ+C,QCFjB,EAJiB+F,KACf,MAAM,OAAEJ,GAAWD,IACnB,OAAO,IAAIM,gBAAgBL,I","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
ADDED
|
@@ -0,0 +1,2 @@
|
|
|
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]}},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(509);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(509),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)},509:(e,t,r)=>{r.d(t,{A:()=>s});var a=r(15),n=r.n(a),o=r(554);const s=({children:e})=>{const t=(0,o.o)();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}},525:e=>{e.exports=require("helmet")},554:(e,t,r)=>{r.d(t,{o:()=>o});var a=r(15),n=r(3);const o=()=>(0,a.useContext)(n.g)},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(509),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__(509),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})})();
|
|
2
|
+
//# sourceMappingURL=arcanajs.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"arcanajs.js","mappings":"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","sources":["webpack://arcanajs/./src/lib/shared/context/HeadContext.tsx","webpack://arcanajs/external commonjs \"react\"","webpack://arcanajs/./src/lib/server/DynamicRouter.ts","webpack://arcanajs/external commonjs \"react-dom/server\"","webpack://arcanajs/./src/lib/server/DefaultTemplate.ts","webpack://arcanajs/./src/lib/server/ArcanaJSMiddleware.ts","webpack://arcanajs/./src/lib/shared/utils/createSingletonContext.ts","webpack://arcanajs/external commonjs \"compression\"","webpack://arcanajs/./src/lib/shared/core/ArcanaJSApp.tsx","webpack://arcanajs/./src/lib/shared/components/Page.tsx","webpack://arcanajs/external commonjs \"express\"","webpack://arcanajs/./src/lib/shared/views/NotFoundPage.tsx","webpack://arcanajs/./src/lib/server/ArcanaJSServer.ts","webpack://arcanajs/external commonjs \"arcana-views\"","webpack://arcanajs/./src/lib/shared/components/Body.tsx","webpack://arcanajs/./src/lib/shared/components/Head.tsx","webpack://arcanajs/external commonjs \"helmet\"","webpack://arcanajs/./src/lib/shared/hooks/useHead.ts","webpack://arcanajs/external node-commonjs \"crypto\"","webpack://arcanajs/./src/lib/server/CsrfMiddleware.ts","webpack://arcanajs/./src/lib/server/ResponseHandlerMiddleware.ts","webpack://arcanajs/./src/lib/shared/context/RouterContext.tsx","webpack://arcanajs/./src/lib/shared/components/Link.tsx","webpack://arcanajs/./src/lib/shared/context/PageContext.tsx","webpack://arcanajs/external node-commonjs \"fs\"","webpack://arcanajs/external commonjs \"cookie-parser\"","webpack://arcanajs/external node-commonjs \"path\"","webpack://arcanajs/./src/lib/shared/views/ErrorPage.tsx","webpack://arcanajs/./src/lib/shared/hooks/useRouter.ts","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/./src/lib/shared/components/NavLink.tsx","webpack://arcanajs/external commonjs \"react-dom/client\"","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","webpack://arcanajs/./src/lib/server/ControllerBinder.ts","webpack://arcanajs/./src/lib/server/Router.ts","webpack://arcanajs/./src/lib/index.ts"],"sourcesContent":["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","module.exports = require(\"react\");","import { NextFunction, Request, Response } from \"express\";\n\nexport const createDynamicRouter = (views: Record<string, any>) => {\n return (req: Request, res: Response, next: NextFunction) => {\n // Remove leading slash\n let path = req.path.substring(1);\n\n // Handle root path mapping to \"index\" if not handled elsewhere\n if (path === \"\") {\n path = \"index\";\n }\n\n // 1. Exact match\n if (views[path]) {\n return res.renderPage(path, {});\n }\n\n // 2. Dynamic match\n for (const viewName of Object.keys(views)) {\n if (!viewName.includes(\"[\")) continue;\n\n // Convert view path to regex\n // e.g., \"users/[id]\" -> \"^users/([^/]+)$\"\n // We need to escape special regex characters first, but keep [ and ] for our logic\n // Actually, simpler: split by '/' and match segments\n\n const pageParts = viewName.split(\"/\");\n const pathParts = path.split(\"/\");\n\n if (pageParts.length !== pathParts.length) continue;\n\n let match = true;\n const params: Record<string, string> = {};\n\n for (let i = 0; i < pageParts.length; i++) {\n const pagePart = pageParts[i];\n const pathPart = pathParts[i];\n\n if (pagePart.startsWith(\"[\") && pagePart.endsWith(\"]\")) {\n const paramName = pagePart.slice(1, -1);\n params[paramName] = pathPart;\n } else if (pagePart !== pathPart) {\n match = false;\n break;\n }\n }\n\n if (match) {\n return res.renderPage(viewName, {}, params);\n }\n }\n\n // If not found, pass to the next middleware (usually 404 handler)\n next();\n };\n};\n","const __WEBPACK_NAMESPACE_OBJECT__ = require(\"react-dom/server\");","export const defaultHtmlTemplate = `<!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 <!--HEAD_CONTENT-->\n </head>\n <body>\n <div id=\"root\"><!--APP_CONTENT--></div>\n <!--ARCANAJS_DATA_SCRIPT-->\n </body>\n</html>`;\n","import { NextFunction, Request, Response } from \"express\";\nimport fs from \"fs\";\nimport React from \"react\";\nimport { renderToString } from \"react-dom/server\";\nimport { HeadContext, HeadManager } from \"../shared/context/HeadContext\";\nimport { ArcanaJSApp } from \"../shared/core/ArcanaJSApp\";\nimport { defaultHtmlTemplate } from \"./DefaultTemplate\";\n\nconst DEFAULT_HTML_TEMPLATE = defaultHtmlTemplate;\n\n// Extend Express Response interface\ndeclare global {\n namespace Express {\n interface Response {\n /**\n * Renders a React page using ArcanaJS SSR.\n *\n * @param page - The name of the page component to render.\n * @param data - Initial data to pass to the page component (default: {}).\n * @param params - Route parameters (default: {}).\n * @returns The Express Response object.\n */\n renderPage(\n page: string,\n data?: any,\n params?: Record<string, string>\n ): Response;\n }\n }\n}\n\ninterface ArcanaJSOptions {\n views: Record<string, React.FC<any>>;\n indexFile?: string;\n layout?: React.FC<any>;\n}\n\n// Helper to prevent XSS in initial data\nconst safeStringify = (obj: any) => {\n return JSON.stringify(obj).replace(/</g, \"\\\\u003c\");\n};\n\nexport const createArcanaJSMiddleware = (options: ArcanaJSOptions) => {\n const { views, indexFile, layout } = options;\n let cachedIndexHtml: string | null = null;\n\n const getIndexHtml = (\n callback: (err: NodeJS.ErrnoException | null, data: string) => void\n ) => {\n if (process.env.NODE_ENV === \"production\" && cachedIndexHtml) {\n return callback(null, cachedIndexHtml);\n }\n\n if (indexFile && fs.existsSync(indexFile)) {\n fs.readFile(indexFile, \"utf8\", (err, htmlData) => {\n if (!err && process.env.NODE_ENV === \"production\") {\n cachedIndexHtml = htmlData;\n }\n callback(err, htmlData);\n });\n } else {\n if (process.env.NODE_ENV === \"production\") {\n cachedIndexHtml = DEFAULT_HTML_TEMPLATE;\n }\n callback(null, DEFAULT_HTML_TEMPLATE);\n }\n };\n\n return (req: Request, res: Response, next: NextFunction) => {\n res.renderPage = (\n page: string,\n data: any = {},\n params: Record<string, string> = {}\n ) => {\n const csrfToken = res.locals.csrfToken;\n\n if (req.get(\"X-ArcanaJS-Request\") || req.query.format === \"json\") {\n return res.json({ page, data, params, csrfToken });\n }\n try {\n const headTags: React.ReactNode[] = [];\n const headManager: HeadManager = {\n tags: headTags,\n push: (nodes) => headTags.push(nodes),\n };\n\n const appHtml = renderToString(\n React.createElement(\n HeadContext.Provider,\n { value: headManager },\n React.createElement(ArcanaJSApp, {\n initialPage: page,\n initialData: data,\n initialParams: params,\n initialUrl: req.path,\n csrfToken: csrfToken,\n views: views,\n layout: layout,\n })\n )\n );\n\n const headHtml = renderToString(\n React.createElement(React.Fragment, null, ...headTags)\n );\n\n getIndexHtml((err, htmlData) => {\n if (err) {\n console.error(\"Error reading index.html\", err);\n return res.status(500).send(\"Server Error\");\n }\n\n const scriptContent = safeStringify({\n page,\n data,\n params,\n csrfToken,\n });\n const scriptTag = `<script id=\"__ARCANAJS_DATA__\" type=\"application/json\">${scriptContent}</script>`;\n\n const hmrScript = process.env.ARCANA_HMR_PORT\n ? `\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>`\n : \"\";\n\n const html = htmlData\n .replace(\"<!--HEAD_CONTENT-->\", headHtml)\n .replace(\"<!--APP_CONTENT-->\", appHtml)\n .replace(\"<!--ARCANAJS_DATA_SCRIPT-->\", scriptTag + hmrScript);\n\n res.send(html);\n });\n } catch (error) {\n console.error(\"SSR Error:\", error);\n return res.status(500).send(\"Internal Server Error\");\n }\n return res;\n };\n next();\n };\n};\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","module.exports = require(\"compression\");","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 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","module.exports = require(\"express\");","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 compression from \"compression\";\nimport cookieParser from \"cookie-parser\";\nimport express, { Express, RequestHandler } from \"express\";\nimport fs from \"fs\";\nimport helmet from \"helmet\";\nimport path from \"path\";\nimport React from \"react\";\nimport ErrorPage from \"../shared/views/ErrorPage\";\nimport NotFoundPage from \"../shared/views/NotFoundPage\";\nimport { createArcanaJSMiddleware } from \"./ArcanaJSMiddleware\";\nimport { createCsrfMiddleware } from \"./CsrfMiddleware\";\nimport { createDynamicRouter } from \"./DynamicRouter\";\nimport { responseHandler } from \"./ResponseHandlerMiddleware\";\n\nexport interface ArcanaJSConfig<TDb = any> {\n port?: number | string;\n views?: Record<string, React.FC<any>>;\n viewsDir?: string;\n viewsContext?: any;\n routes?: RequestHandler | RequestHandler[];\n /** API routes can be provided separately from web routes */\n apiRoutes?: RequestHandler | RequestHandler[];\n /** Base path under which API routes will be mounted (default: '/api') */\n apiBase?: string;\n staticDir?: string;\n distDir?: string;\n indexFile?: string;\n layout?: React.FC<any>;\n /** Optional function to establish a DB connection. Should return a Promise resolving to the DB client/connection. */\n dbConnect?: () => Promise<TDb> | TDb;\n /** Automatically register SIGINT/SIGTERM handlers to call stop(). Default: true */\n autoHandleSignals?: boolean;\n}\n\ndeclare global {\n namespace Express {\n interface Request {\n /**\n * Normalized DB object optionally attached to the request by ArcanaJSServer.\n * It may be either the raw client, or an object like `{ client, db, close }`.\n */\n db?: any;\n }\n }\n}\n\nclass ArcanaJSServer<TDb = any> {\n public app: Express;\n private config: ArcanaJSConfig<TDb>;\n private serverInstance?: import(\"http\").Server;\n private _sigintHandler?: () => void;\n private _sigtermHandler?: () => void;\n\n constructor(config: ArcanaJSConfig<TDb>) {\n this.config = config;\n this.app = express();\n this.initialize();\n }\n\n /**\n * Normalize different DB client shapes into a single object exposing:\n * { client?: any, db?: any, close: async () => void }\n */\n private normalizeDb(obj: any): any {\n if (!obj) return obj;\n\n // If already normalized (has close function), return as-is\n if (typeof obj.close === \"function\") {\n return obj;\n }\n\n // Mongoose instance\n if (typeof obj.disconnect === \"function\") {\n return {\n client: obj,\n close: async () => {\n await obj.disconnect();\n },\n };\n }\n\n // If object contains { client, db }\n if (obj.client && obj.db) {\n const client = obj.client;\n return {\n client,\n db: obj.db,\n close: async () => {\n if (client && typeof client.close === \"function\") {\n await client.close();\n } else if (client && typeof client.disconnect === \"function\") {\n await client.disconnect();\n } else {\n throw new Error(\"No close method on client\");\n }\n },\n };\n }\n\n // Native MongoClient instance\n if (obj && typeof obj.close === \"function\" && obj.connect) {\n return {\n client: obj,\n close: async () => {\n await obj.close();\n },\n };\n }\n\n // Pg/mysql client with end()/query()\n if (typeof obj.end === \"function\" || typeof obj.query === \"function\") {\n return {\n client: obj,\n close: async () => {\n if (typeof obj.end === \"function\") {\n await obj.end();\n } else if (typeof obj.close === \"function\") {\n await obj.close();\n } else {\n throw new Error(\"No close/end method on SQL client\");\n }\n },\n };\n }\n\n // Try internal mongo client path { s: { client } }\n if (obj.s && obj.s.client && typeof obj.s.client.close === \"function\") {\n return {\n client: obj.s.client,\n db: obj,\n close: async () => {\n await obj.s.client.close();\n },\n };\n }\n\n // Fallback: wrap with a close that throws to surface the issue\n return {\n client: obj,\n close: async () => {\n throw new Error(\"No known close method on DB client\");\n },\n };\n }\n\n private initialize() {\n const {\n staticDir = \"public\",\n distDir = \"dist/public\",\n indexFile = \"dist/public/index.html\",\n views,\n viewsContext,\n routes,\n layout,\n apiRoutes,\n apiBase = \"/api\",\n } = this.config;\n\n const root = process.cwd();\n\n // 1. Resolve views once and in priority order\n let resolvedViews = views;\n if (!resolvedViews && viewsContext)\n resolvedViews = this.loadViewsFromContext(viewsContext);\n if (!resolvedViews) resolvedViews = this.loadViewsFromAlias();\n if (!resolvedViews) resolvedViews = this.discoverViews();\n if (!resolvedViews || Object.keys(resolvedViews).length === 0) {\n console.warn(\"No views found. Please check your views directory.\");\n resolvedViews = {} as Record<string, React.FC<any>>;\n }\n resolvedViews.NotFoundPage = resolvedViews.NotFoundPage || NotFoundPage;\n resolvedViews.ErrorPage = resolvedViews.ErrorPage || ErrorPage;\n\n // Security headers\n this.app.use(helmet({ contentSecurityPolicy: false }));\n this.app.use(cookieParser());\n this.app.use(createCsrfMiddleware());\n this.app.use(responseHandler);\n\n // Expose `req.db` for convenience\n this.app.use(\n (\n req: express.Request,\n _res: express.Response,\n next: express.NextFunction\n ) => {\n req.db = this.app.locals.db;\n next();\n }\n );\n\n // Static files: resolve and dedupe paths, serve before compression to avoid recompressing static files\n const isProduction = process.env.NODE_ENV === \"production\";\n const staticOptions = { index: false, maxAge: isProduction ? \"1y\" : \"0\" };\n const staticPaths = [\n path.resolve(root, distDir),\n path.resolve(root, staticDir),\n ].filter((p, i, a) => a.indexOf(p) === i);\n for (const p of staticPaths) {\n this.app.use(express.static(p, staticOptions));\n }\n\n // Compression for dynamic responses (after static middleware)\n this.app.use(compression());\n\n // ArcanaJS Middleware\n this.app.use(\n createArcanaJSMiddleware({\n views: resolvedViews,\n indexFile: path.resolve(root, indexFile),\n layout,\n })\n );\n\n // Establish DB connection if provided (normalize eagerly where possible)\n if (this.config.dbConnect) {\n try {\n const maybe = this.config.dbConnect();\n const handleDb = (db: any) => {\n try {\n this.app.locals.db = this.normalizeDb(db) || db;\n console.log(\"Database connection attached to app.locals.db\");\n } catch (e) {\n this.app.locals.db = db;\n console.warn(\n \"DB connection attached without full normalization\",\n e\n );\n }\n };\n\n if (\n maybe &&\n (maybe as any).then &&\n typeof (maybe as any).then === \"function\"\n ) {\n (maybe as Promise<any>)\n .then(handleDb)\n .catch((err: any) =>\n console.error(\"Error establishing DB connection:\", err)\n );\n } else {\n handleDb(maybe);\n }\n } catch (err) {\n console.error(\"Error calling dbConnect:\", err);\n }\n }\n\n // Helper to mount arrays or single route objects\n const mount = (target: any, base?: string) => {\n if (!target) return;\n const items = Array.isArray(target) ? target : [target];\n for (const r of items) {\n if (!r) continue;\n if (typeof r.getRouter === \"function\") {\n this.app.use(base || \"/\", r.getRouter());\n } else {\n this.app.use(base || \"/\", r as RequestHandler);\n }\n }\n };\n\n try {\n mount(apiRoutes, apiBase);\n if (apiRoutes) console.log(`API routes mounted at ${apiBase}`);\n } catch (err) {\n console.error(\"Error mounting apiRoutes:\", err);\n }\n\n try {\n mount(routes);\n } catch (err) {\n console.error(\"Error mounting routes:\", err);\n }\n\n // Dynamic Router\n this.app.use(createDynamicRouter(resolvedViews));\n\n // 404 and error handlers\n this.app.use((req, res) => {\n if (req.get(\"X-ArcanaJS-Request\") || req.query.format === \"json\") {\n res.status(404).json({\n page: \"NotFoundPage\",\n data: {},\n params: {},\n csrfToken: res.locals.csrfToken,\n });\n } else {\n res.status(404).renderPage(\"NotFoundPage\");\n }\n });\n\n this.app.use(\n (\n err: any,\n req: express.Request,\n res: express.Response,\n next: express.NextFunction\n ) => {\n console.error(err);\n const message =\n process.env.NODE_ENV === \"production\"\n ? \"Internal Server Error\"\n : err.message;\n if (req.get(\"X-ArcanaJS-Request\") || req.query.format === \"json\") {\n res.status(500).json({\n page: \"ErrorPage\",\n data: { message },\n params: {},\n csrfToken: res.locals.csrfToken,\n });\n } else {\n res.status(500).renderPage(\"ErrorPage\", { message });\n }\n }\n );\n }\n\n private loadViewsFromContext(context: any): Record<string, React.FC<any>> {\n const views: Record<string, React.FC<any>> = {};\n context.keys().forEach((key: string) => {\n const viewName = key.replace(/^\\.\\/(.*)\\.tsx$/, \"$1\");\n views[viewName] = context(key).default;\n });\n return views;\n }\n\n private loadViewsFromAlias(): Record<string, React.FC<any>> | undefined {\n try {\n // @ts-ignore - This alias is injected by Webpack\n const injectedViews = require(\"arcana-views\");\n if (injectedViews) {\n return this.loadViewsFromContext(injectedViews);\n }\n } catch (e) {\n // Ignore\n }\n return undefined;\n }\n\n private discoverViews(): Record<string, React.FC<any>> {\n const views: Record<string, React.FC<any>> = {};\n const viewsDir = this.config.viewsDir\n ? path.resolve(process.cwd(), this.config.viewsDir)\n : path.resolve(process.cwd(), \"src/views\");\n\n if (!fs.existsSync(viewsDir)) return views;\n\n const traverse = (dir: string) => {\n const files = fs.readdirSync(dir);\n files.forEach((file) => {\n const fullPath = path.join(dir, file);\n const stat = fs.statSync(fullPath);\n\n if (stat.isDirectory()) {\n traverse(fullPath);\n } else if (file.endsWith(\".tsx\") || file.endsWith(\".jsx\")) {\n const relativePath = path.relative(viewsDir, fullPath);\n const viewName = relativePath.replace(/\\.(tsx|jsx)$/, \"\");\n try {\n // Use __non_webpack_require__ if available to avoid Webpack bundling issues\n // or standard require if running in Node directly\n const requireFunc =\n typeof __non_webpack_require__ !== \"undefined\"\n ? __non_webpack_require__\n : eval(\"require\");\n\n // Register ts-node if needed\n if (file.endsWith(\".tsx\") || file.endsWith(\".ts\")) {\n try {\n requireFunc(\"ts-node/register\");\n } catch (e) {\n // Ignore\n }\n }\n\n const pageModule = requireFunc(fullPath);\n views[viewName] = pageModule.default || pageModule;\n } catch (error) {\n console.error(`Failed to load view ${viewName}:`, error);\n }\n }\n });\n };\n\n traverse(viewsDir);\n return views;\n }\n\n public start() {\n const PORT = this.config.port || process.env.PORT || 3000;\n this.serverInstance = this.app.listen(PORT, () => {\n console.log(`Server is running on http://localhost:${PORT}`);\n });\n\n // Optionally register process signal handlers per-instance to gracefully shutdown\n const autoHandle = this.config.autoHandleSignals !== false;\n if (autoHandle) {\n const shutdown = async () => {\n try {\n await this.stop();\n process.exit(0);\n } catch (err) {\n console.error(\"Error during shutdown:\", err);\n process.exit(1);\n }\n };\n this._sigintHandler = shutdown;\n this._sigtermHandler = shutdown;\n process.on(\"SIGINT\", this._sigintHandler);\n process.on(\"SIGTERM\", this._sigtermHandler);\n }\n }\n\n /**\n * Stop the HTTP server and close DB connection if present.\n */\n public async stop(): Promise<void> {\n // Close HTTP server\n if (this.serverInstance) {\n await new Promise<void>((resolve, reject) => {\n this.serverInstance!.close((err) => {\n if (err) return reject(err);\n resolve();\n });\n });\n this.serverInstance = undefined;\n console.log(\"HTTP server stopped\");\n }\n\n // Close DB connection if attached to app.locals.db\n const db = this.app.locals.db as TDb | undefined;\n if (db) {\n let closed = false;\n // Try mongoose.disconnect()\n try {\n if (typeof (db as any).disconnect === \"function\") {\n await (db as any).disconnect();\n closed = true;\n console.log(\"Database connection closed via disconnect().\");\n }\n } catch (err) {\n console.error(\"Error calling disconnect() on DB client:\", err);\n }\n\n // Try db.close()\n if (!closed) {\n try {\n if (typeof (db as any).close === \"function\") {\n await (db as any).close();\n closed = true;\n console.log(\"Database connection closed via close().\");\n }\n } catch (err) {\n console.error(\"Error calling close() on DB client:\", err);\n }\n }\n\n // Try db.end()\n if (!closed) {\n try {\n if (typeof (db as any).end === \"function\") {\n await (db as any).end();\n closed = true;\n console.log(\"Database connection closed via end().\");\n }\n } catch (err) {\n console.error(\"Error calling end() on DB client:\", err);\n }\n }\n\n // Try db.client?.close()\n if (!closed) {\n try {\n const clientClose = (db as any).client && (db as any).client.close;\n if (clientClose && typeof clientClose === \"function\") {\n await (db as any).client.close();\n closed = true;\n console.log(\"Database connection closed via db.client.close().\");\n }\n } catch (err) {\n console.error(\"Error calling db.client.close() on DB client:\", err);\n }\n }\n\n // Try db.s?.client?.close() (internal Mongo client path)\n if (!closed) {\n try {\n const maybeInternal =\n (db as any).s && (db as any).s.client && (db as any).s.client.close;\n if (maybeInternal && typeof maybeInternal === \"function\") {\n await (db as any).s.client.close();\n closed = true;\n console.log(\"Database connection closed via db.s.client.close().\");\n }\n } catch (err) {\n console.error(\"Error calling db.s.client.close() on DB client:\", err);\n }\n }\n\n if (!closed) {\n console.warn(\n \"Could not find a supported close method on the DB client; connection may remain open.\"\n );\n }\n }\n\n // Remove signal handlers registered by this instance\n try {\n if (this._sigintHandler) {\n process.removeListener(\"SIGINT\", this._sigintHandler);\n this._sigintHandler = undefined;\n }\n if (this._sigtermHandler) {\n process.removeListener(\"SIGTERM\", this._sigtermHandler);\n this._sigtermHandler = undefined;\n }\n } catch (err) {\n // ignore errors while removing listeners\n }\n }\n}\nexport default ArcanaJSServer;","module.exports = require(\"arcana-views\");","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, { 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","module.exports = require(\"helmet\");","import { useContext } from \"react\";\nimport { HeadContext } from \"../context/HeadContext\";\n\nexport const useHead = () => useContext(HeadContext);\n","const __WEBPACK_NAMESPACE_OBJECT__ = require(\"crypto\");","import crypto from \"crypto\";\nimport { NextFunction, Request, Response } from \"express\";\n\nconst CSRF_COOKIE_NAME = \"_csrf\";\n\nexport const createCsrfMiddleware = () => {\n return (req: Request, res: Response, next: NextFunction) => {\n // 1. Generate or retrieve token\n let token = req.cookies[CSRF_COOKIE_NAME];\n\n if (!token) {\n token = crypto.randomBytes(32).toString(\"hex\");\n res.cookie(CSRF_COOKIE_NAME, token, {\n httpOnly: true,\n secure: process.env.NODE_ENV === \"production\",\n sameSite: \"strict\",\n });\n }\n\n // 2. Expose token to the response locals (for injection into the view)\n res.locals.csrfToken = token;\n\n // 3. Verify token on state-changing methods\n const method = req.method.toUpperCase();\n if ([\"POST\", \"PUT\", \"DELETE\", \"PATCH\"].includes(method)) {\n const headerToken = req.headers[\"x-csrf-token\"];\n\n if (!headerToken || headerToken !== token) {\n return res.status(403).json({ error: \"Invalid CSRF Token\" });\n }\n }\n\n next();\n };\n};\n","import type { NextFunction, Request, Response } from \"express\";\n\ndeclare global {\n namespace Express {\n interface Response {\n /**\n * Sends a success response with a standard format.\n *\n * @param data - The data payload to include in the response (default: {}).\n * @param message - A descriptive message for the success (default: \"Success\").\n * @param status - The HTTP status code to return (default: 200).\n * @returns The Express Response object.\n */\n success: (\n data?: string | object | null,\n message?: string,\n status?: number\n ) => Response;\n\n /**\n * Sends an error response with a standard format.\n *\n * @param message - A descriptive message for the error (default: \"Error\").\n * @param status - The HTTP status code to return (default: 500).\n * @param error - Additional error details or object (default: null).\n * @param data - Optional data payload to include in the error response (default: null).\n * @returns The Express Response object.\n */\n error: (\n message?: string,\n status?: number,\n error?: string | object | null,\n data?: string | object | null\n ) => Response;\n }\n }\n}\n\nexport const responseHandler = (\n req: Request,\n res: Response,\n next: NextFunction\n) => {\n res.success = (\n data: string | object | null = {},\n message: string = \"Success\",\n status: number = 200\n ) => {\n return res.status(status).json({\n success: true,\n message,\n data,\n error: null,\n });\n };\n\n res.error = (\n message: string = \"Error\",\n status: number = 500,\n error: string | object | null = null,\n data: string | object | null = null\n ) => {\n const errorResponse: string | object | null = error\n ? typeof error === \"object\" && error !== null\n ? error instanceof Error\n ? error.toString()\n : error\n : error.toString()\n : null;\n\n return res.status(status).json({\n success: false,\n message,\n data,\n error: errorResponse,\n });\n };\n\n next();\n};\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 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 { 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","module.exports = require(\"fs\");","module.exports = require(\"cookie-parser\");","module.exports = require(\"path\");","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 { 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","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\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};","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","const __WEBPACK_NAMESPACE_OBJECT__ = require(\"react-dom/client\");","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","import { NextFunction, Request, Response } from \"express\";\n\nexport default class ControllerBinder {\n static handle(controller: any, method: string) {\n // Instantiate the controller once (Singleton pattern) for performance\n // This assumes controllers are stateless, which is best practice.\n let instance: any;\n try {\n instance = new controller();\n } catch (e) {\n // Fallback if controller is not a class or fails to instantiate\n console.warn(`Failed to instantiate controller ${controller.name}`, e);\n instance = controller;\n }\n\n return async (req: Request, res: Response, next: NextFunction) => {\n try {\n // Call the method\n if (typeof instance[method] === \"function\") {\n await instance[method](req, res, next);\n } else {\n throw new Error(\n `Method ${method} not found on controller ${controller.name}`\n );\n }\n } catch (error) {\n next(error);\n }\n };\n }\n}\n","import express, { Router as ExpressRouter, RequestHandler } from \"express\";\nimport ControllerBinder from \"./ControllerBinder\";\n\n/**\n * Provides Routing syntax for defining routes with prefixes, middlewares, and groups\n */\nexport class Router {\n private router: ExpressRouter;\n private middlewareStack: RequestHandler[];\n private prefixStack: string[];\n\n constructor() {\n this.router = express.Router();\n this.middlewareStack = [];\n this.prefixStack = [];\n }\n\n /**\n * Create a new router instance\n */\n static create(): Router {\n return new Router();\n }\n\n /**\n * Add middleware to the current stack\n */\n middleware(...middleware: RequestHandler[]): Router {\n const newRouter = this._clone();\n newRouter.middlewareStack = [...this.middlewareStack, ...middleware];\n return newRouter;\n }\n\n /**\n * Add prefix to the current stack\n */\n prefix(prefix: string): Router {\n const newRouter = this._clone();\n newRouter.prefixStack = [\n ...this.prefixStack,\n prefix.replace(/^\\/|\\/$/g, \"\"),\n ];\n return newRouter;\n }\n\n /**\n * Create a route group\n */\n group(callback: (router: Router) => void): Router {\n callback(this);\n return this;\n }\n\n /**\n * Define a GET route\n */\n get(path: string, ...args: any[]): Router {\n const action = args.pop();\n const middlewares = args;\n return this._addRoute(\"get\", path, action, middlewares);\n }\n\n /**\n * Define a POST route\n */\n post(path: string, ...args: any[]): Router {\n const action = args.pop();\n const middlewares = args;\n return this._addRoute(\"post\", path, action, middlewares);\n }\n\n /**\n * Define a PUT route\n */\n put(path: string, ...args: any[]): Router {\n const action = args.pop();\n const middlewares = args;\n return this._addRoute(\"put\", path, action, middlewares);\n }\n\n /**\n * Define a DELETE route\n */\n delete(path: string, ...args: any[]): Router {\n const action = args.pop();\n const middlewares = args;\n return this._addRoute(\"delete\", path, action, middlewares);\n }\n\n /**\n * Define a PATCH route\n */\n patch(path: string, ...args: any[]): Router {\n const action = args.pop();\n const middlewares = args;\n return this._addRoute(\"patch\", path, action, middlewares);\n }\n\n /**\n * Define an OPTIONS route\n */\n options(path: string, ...args: any[]): Router {\n const action = args.pop();\n const middlewares = args;\n return this._addRoute(\"options\", path, action, middlewares);\n }\n\n /**\n * Get the underlying Express router\n */\n getRouter(): ExpressRouter {\n return this.router;\n }\n\n /**\n * Mount this router to an Express app or router\n */\n mount(app: express.Application | ExpressRouter, basePath = \"/\"): void {\n (app as any).use(basePath, this.router);\n }\n\n /**\n * Clone the current router instance\n */\n private _clone(): Router {\n const newRouter = new Router();\n newRouter.router = this.router;\n newRouter.middlewareStack = [...this.middlewareStack];\n newRouter.prefixStack = [...this.prefixStack];\n return newRouter;\n }\n\n /**\n * Add a route to the router\n */\n private _addRoute(\n method: \"get\" | \"post\" | \"put\" | \"delete\" | \"patch\" | \"options\",\n path: string,\n action: any,\n routeMiddlewares: any[] = []\n ): Router {\n const fullPath = this._buildPath(path);\n const handler = this._buildHandler(action);\n const flatMiddlewares = routeMiddlewares.flat(Infinity) as RequestHandler[];\n const middlewares = [...this.middlewareStack, ...flatMiddlewares, handler];\n\n this.router[method](fullPath, ...middlewares);\n return this;\n }\n\n /**\n * Build the full path with prefixes\n */\n private _buildPath(path: string): string {\n const cleanPath = path.replace(/^\\//, \"\");\n const prefixes = this.prefixStack.filter((p) => p !== \"\");\n\n if (prefixes.length === 0) {\n return `/${cleanPath}`;\n }\n\n return `/${prefixes.join(\"/\")}/${cleanPath}`.replace(/\\/+/g, \"/\");\n }\n\n /**\n * Build the route handler\n */\n private _buildHandler(action: any): RequestHandler {\n if (typeof action === \"function\") {\n return action;\n }\n\n if (Array.isArray(action) && action.length === 2) {\n const [controller, method] = action;\n return ControllerBinder.handle(controller, method);\n }\n\n throw new Error(\n 'Action must be a function or array [Controller, \"method\"]'\n );\n }\n}\n\n/**\n * Static Route class for ArcanaJS Routing\n */\nexport class Route {\n private static _router = new Router();\n\n static create(): Router {\n return Router.create();\n }\n\n static middleware(...middleware: RequestHandler[]): Router {\n return this._router.middleware(...middleware);\n }\n\n static prefix(prefix: string): Router {\n return this._router.prefix(prefix);\n }\n\n static group(callback: (router: Router) => void): Router {\n return this._router.group(callback);\n }\n\n static get(path: string, ...args: any[]): Router {\n return this._router.get(path, ...args);\n }\n\n static post(path: string, ...args: any[]): Router {\n return this._router.post(path, ...args);\n }\n\n static put(path: string, ...args: any[]): Router {\n return this._router.put(path, ...args);\n }\n\n static delete(path: string, ...args: any[]): Router {\n return this._router.delete(path, ...args);\n }\n\n static patch(path: string, ...args: any[]): Router {\n return this._router.patch(path, ...args);\n }\n\n static options(path: string, ...args: any[]): Router {\n return this._router.options(path, ...args);\n }\n\n static getRouter(): ExpressRouter {\n return this._router.getRouter();\n }\n\n static mount(app: express.Application, basePath = \"/\"): void {\n return this._router.mount(app, basePath);\n }\n\n static reset(): void {\n this._router = new Router();\n }\n}\n\nexport default Route;\n","import { Express } from \"express\";\nimport ArcanaJSServer, { ArcanaJSConfig } from \"./server/ArcanaJSServer\";\n\n// ============================================================================\n// Component Exports\n// ============================================================================\n\nexport { default as Body } from \"./shared/components/Body\";\nexport { default as Head } from \"./shared/components/Head\";\nexport { default as Link } from \"./shared/components/Link\";\nexport { default as NavLink } from \"./shared/components/NavLink\";\nexport { default as Page } from \"./shared/components/Page\";\n\n// ============================================================================\n// Client Exports\n// ============================================================================\n\nexport { default as hydrateArcanaJS } from \"./client/index\";\n\n// ============================================================================\n// Hook Exports\n// ============================================================================\n\nexport { default as useLocation } from \"./shared/hooks/useLocation\";\nexport { default as usePage } from \"./shared/hooks/usePage\";\nexport { default as useParams } from \"./shared/hooks/useParams\";\nexport { default as useQuery } from \"./shared/hooks/useQuery\";\nexport { default as useRouter } from \"./shared/hooks/useRouter\";\n\n// ============================================================================\n// Server Core Exports\n// ============================================================================\n\nexport { default as ArcanaJSServer } from \"./server/ArcanaJSServer\";\n\nexport { Express, NextFunction, Request, Response } from \"express\";\n\n// ============================================================================\n// Routing Exports\n// ============================================================================\n\nexport { default as Route } from \"./server/Router\";\n\n// ============================================================================\n// Server Factory Function\n// ============================================================================\n\n/**\n * Create an ArcanaJS server with the given Express app\n *\n * @param app - Express application instance\n * @param config - Optional ArcanaJS configuration\n * @returns ArcanaJSServer instance\n *\n * @example\n * ```typescript\n * import express from 'express';\n * import { createArcanaServer } from 'arcanajs/server';\n *\n * const app = express();\n * const server = createArcanaServer(app, {\n * port: 3000,\n * viewsDir: 'src/views',\n * });\n *\n * server.start();\n * ```\n */\nexport function createArcanaServer(\n app: Express,\n config?: Partial<ArcanaJSConfig>\n): ArcanaJSServer {\n const server = new ArcanaJSServer({ ...config });\n return server;\n}\n"],"names":["HeadContext","createSingletonContext","module","exports","require","createDynamicRouter","views","req","res","next","path","substring","renderPage","viewName","Object","keys","includes","pageParts","split","pathParts","length","match","params","i","pagePart","pathPart","startsWith","endsWith","slice","DEFAULT_HTML_TEMPLATE","createArcanaJSMiddleware","options","indexFile","layout","cachedIndexHtml","page","data","csrfToken","locals","get","query","format","json","headTags","headManager","tags","push","nodes","appHtml","renderToString","React","Provider","value","ArcanaJSApp","initialPage","initialData","initialParams","initialUrl","headHtml","callback","process","env","NODE_ENV","fs","err","htmlData","getIndexHtml","console","error","status","send","obj","scriptTag","JSON","stringify","replace","hmrScript","ARCANA_HMR_PORT","html","key","defaultValue","globalAny","global","symbolKey","Symbol","for","createContext","props","Layout","onNavigate","cacheLimit","setPage","useState","setData","setParams","url","setUrl","window","location","pathname","isNavigating","setIsNavigating","navigationCache","Map","currentAbort","useEffect","history","state","replaceState","href","handlePopState","event","navigateTo","catch","reload","addEventListener","_currentAbort$current","removeEventListener","current","abort","async","_currentAbort$current2","map","has","newUrl","cached","pushState","scrollTo","top","behavior","controller","AbortController","response","fetch","headers","cache","signal","ok","Error","statusText","payload","setCache","delete","set","size","firstKey","undefined","name","content","Component","Page","RouterProvider","args","navigateToAsync","currentPage","currentUrl","title","children","PageContext","Head","NotFoundPage","createElement","Body","className","style","animationDelay","Fragment","Link","fill","stroke","viewBox","strokeLinecap","strokeLinejoin","strokeWidth","d","onClick","back","ArcanaJSServer","constructor","config","this","app","express","initialize","normalizeDb","close","disconnect","client","db","connect","end","s","staticDir","distDir","viewsContext","routes","apiRoutes","apiBase","root","cwd","resolvedViews","loadViewsFromContext","loadViewsFromAlias","discoverViews","warn","ErrorPage","use","helmet","contentSecurityPolicy","cookieParser","createCsrfMiddleware","responseHandler","_res","staticOptions","index","maxAge","staticPaths","filter","p","a","indexOf","compression","dbConnect","maybe","handleDb","log","e","then","mount","target","base","items","Array","isArray","r","getRouter","message","context","forEach","default","injectedViews","viewsDir","traverse","dir","files","file","fullPath","stat","isDirectory","relativePath","requireFunc","__non_webpack_require__","eval","pageModule","start","PORT","port","serverInstance","listen","autoHandleSignals","shutdown","stop","exit","_sigintHandler","_sigtermHandler","on","Promise","resolve","reject","closed","clientClose","maybeInternal","removeListener","useHead","child","managedElements","reactElement","type","document","selector","property","element","querySelector","setAttribute","newMeta","head","appendChild","rel","newLink","el","remove","useContext","CSRF_COOKIE_NAME","token","cookies","crypto","toString","cookie","httpOnly","secure","sameSite","method","toUpperCase","headerToken","success","errorResponse","RouterContext","prefetch","useRouter","isExternal","test","_extends","preventDefault","open","onMouseEnter","handleMouseEnter","statusCode","stack","isDevelopment","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","__webpack_modules__","n","getter","__esModule","definition","o","defineProperty","enumerable","prop","prototype","hasOwnProperty","call","toStringTag","NavLink","activeClassName","exact","combinedClassName","trim","hydrateArcanaJS","viewsOrContext","container","getElementById","dataScript","parse","textContent","hydrateRoot","useLocation","search","hash","usePage","useParams","useQuery","URLSearchParams","ControllerBinder","handle","instance","Router","router","middlewareStack","prefixStack","create","middleware","newRouter","_clone","prefix","group","action","pop","middlewares","_addRoute","post","put","patch","basePath","routeMiddlewares","_buildPath","handler","_buildHandler","flatMiddlewares","flat","Infinity","cleanPath","prefixes","join","Route","_router","reset","createArcanaServer"],"ignoreList":[],"sourceRoot":""}
|