@alepha/react 0.13.1 → 0.13.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/auth/index.browser.js +5 -5
- package/dist/auth/index.browser.js.map +1 -1
- package/dist/auth/index.d.ts +330 -330
- package/dist/auth/index.js +7 -7
- package/dist/auth/index.js.map +1 -1
- package/dist/core/index.browser.js +19 -18
- package/dist/core/index.browser.js.map +1 -1
- package/dist/core/index.d.ts +352 -344
- package/dist/core/index.js +25 -24
- package/dist/core/index.js.map +1 -1
- package/dist/core/index.native.js +381 -0
- package/dist/core/index.native.js.map +1 -0
- package/dist/form/index.d.ts +2 -2
- package/dist/head/index.browser.js +7 -7
- package/dist/head/index.browser.js.map +1 -1
- package/dist/head/index.d.ts +265 -265
- package/dist/head/index.js +7 -7
- package/dist/head/index.js.map +1 -1
- package/dist/i18n/index.d.ts +20 -20
- package/dist/i18n/index.js +12 -12
- package/dist/i18n/index.js.map +1 -1
- package/dist/websocket/index.d.ts +7 -7
- package/dist/websocket/index.js.map +1 -1
- package/package.json +18 -9
- package/src/auth/index.ts +1 -1
- package/src/auth/providers/ReactAuthProvider.ts +1 -1
- package/src/auth/services/ReactAuth.ts +5 -5
- package/src/core/components/NestedView.tsx +1 -1
- package/src/core/hooks/useStore.ts +4 -4
- package/src/core/index.browser.ts +2 -2
- package/src/core/index.native.ts +1 -1
- package/src/core/index.shared-router.ts +1 -1
- package/src/core/index.ts +3 -3
- package/src/core/{descriptors → primitives}/$page.ts +20 -20
- package/src/core/providers/ReactBrowserProvider.ts +2 -2
- package/src/core/providers/ReactBrowserRouterProvider.ts +2 -2
- package/src/core/providers/ReactPageProvider.ts +25 -11
- package/src/core/providers/ReactServerProvider.ts +12 -12
- package/src/core/services/ReactPageServerService.ts +6 -6
- package/src/core/services/ReactPageService.ts +6 -6
- package/src/core/services/ReactRouter.ts +3 -3
- package/src/head/index.browser.ts +3 -3
- package/src/head/index.ts +4 -4
- package/src/head/{descriptors → primitives}/$head.ts +6 -6
- package/src/i18n/hooks/useI18n.ts +2 -2
- package/src/i18n/index.ts +3 -3
- package/src/i18n/{descriptors → primitives}/$dictionary.ts +8 -8
- package/src/i18n/providers/I18nProvider.ts +5 -5
- package/src/websocket/hooks/useRoom.tsx +3 -3
package/dist/auth/index.js
CHANGED
|
@@ -13,7 +13,7 @@ var ReactAuthProvider = class {
|
|
|
13
13
|
handler: async ({ request, state }) => {
|
|
14
14
|
if (request?.user) {
|
|
15
15
|
const { token, realm, ...user } = request.user;
|
|
16
|
-
this.alepha.
|
|
16
|
+
this.alepha.store.set("alepha.server.request.user", user);
|
|
17
17
|
state.user = user;
|
|
18
18
|
}
|
|
19
19
|
}
|
|
@@ -47,12 +47,12 @@ var ReactAuth = class {
|
|
|
47
47
|
* Alias for `alepha.state.get("user")`
|
|
48
48
|
*/
|
|
49
49
|
get user() {
|
|
50
|
-
return this.alepha.
|
|
50
|
+
return this.alepha.store.get("alepha.server.request.user");
|
|
51
51
|
}
|
|
52
52
|
async ping() {
|
|
53
53
|
const { data } = await this.httpClient.fetch(alephaServerAuthRoutes.userinfo, { schema: { response: userinfoResponseSchema } });
|
|
54
|
-
this.alepha.
|
|
55
|
-
this.alepha.
|
|
54
|
+
this.alepha.store.set("alepha.server.request.apiLinks", data.api);
|
|
55
|
+
this.alepha.store.set("alepha.server.request.user", data.user);
|
|
56
56
|
return data.user;
|
|
57
57
|
}
|
|
58
58
|
async login(provider, options) {
|
|
@@ -66,8 +66,8 @@ var ReactAuth = class {
|
|
|
66
66
|
}),
|
|
67
67
|
schema: { response: tokenResponseSchema }
|
|
68
68
|
});
|
|
69
|
-
this.alepha.
|
|
70
|
-
this.alepha.
|
|
69
|
+
this.alepha.store.set("alepha.server.request.apiLinks", data.api);
|
|
70
|
+
this.alepha.store.set("alepha.server.request.user", data.user);
|
|
71
71
|
return data;
|
|
72
72
|
}
|
|
73
73
|
if (this.alepha.isBrowser()) {
|
|
@@ -116,7 +116,7 @@ const useAuth = () => {
|
|
|
116
116
|
*/
|
|
117
117
|
const AlephaReactAuth = $module({
|
|
118
118
|
name: "alepha.react.auth",
|
|
119
|
-
|
|
119
|
+
primitives: [$auth],
|
|
120
120
|
services: [
|
|
121
121
|
AlephaReact,
|
|
122
122
|
AlephaServerLinks,
|
package/dist/auth/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","names":[],"sources":["../../src/auth/providers/ReactAuthProvider.ts","../../src/auth/services/ReactAuth.ts","../../src/auth/hooks/useAuth.ts","../../src/auth/index.ts"],"sourcesContent":["import { $hook, $inject, Alepha } from \"alepha\";\n\nexport class ReactAuthProvider {\n protected readonly alepha = $inject(Alepha);\n\n public readonly onRender = $hook({\n on: \"react:server:render:begin\",\n handler: async ({ request, state }) => {\n if (request?.user) {\n const { token, realm, ...user } = request.user; // do not send token and realm to the client\n this.alepha.
|
|
1
|
+
{"version":3,"file":"index.js","names":[],"sources":["../../src/auth/providers/ReactAuthProvider.ts","../../src/auth/services/ReactAuth.ts","../../src/auth/hooks/useAuth.ts","../../src/auth/index.ts"],"sourcesContent":["import { $hook, $inject, Alepha } from \"alepha\";\n\nexport class ReactAuthProvider {\n protected readonly alepha = $inject(Alepha);\n\n public readonly onRender = $hook({\n on: \"react:server:render:begin\",\n handler: async ({ request, state }) => {\n if (request?.user) {\n const { token, realm, ...user } = request.user; // do not send token and realm to the client\n this.alepha.store.set(\"alepha.server.request.user\", user); // for hydration, browser, etc...\n state.user = user;\n }\n },\n });\n}\n","import { ReactBrowserProvider, Redirection } from \"@alepha/react\";\nimport { $hook, $inject, Alepha } from \"alepha\";\nimport { $logger } from \"alepha/logger\";\nimport type { UserAccountToken } from \"alepha/security\";\nimport { HttpClient } from \"alepha/server\";\nimport { alephaServerAuthRoutes, tokenResponseSchema, type Tokens, userinfoResponseSchema } from \"alepha/server/auth\";\n\n/**\n * Browser, SSR friendly, service to handle authentication.\n */\nexport class ReactAuth {\n protected readonly log = $logger();\n protected readonly alepha = $inject(Alepha);\n protected readonly httpClient = $inject(HttpClient);\n\n protected readonly onBeginTransition = $hook({\n on: \"react:transition:begin\",\n handler: async (event) => {\n if (this.alepha.isBrowser()) {\n Object.defineProperty(event.state, \"user\", {\n get: () => this.user,\n });\n }\n },\n });\n\n protected readonly onFetchRequest = $hook({\n on: \"client:onRequest\",\n handler: async ({ request }) => {\n if (this.alepha.isBrowser() && this.user) {\n // ensure cookies are sent with requests and refresh-able\n request.credentials ??= \"include\";\n }\n },\n });\n\n /**\n * Get the current authenticated user.\n *\n * Alias for `alepha.state.get(\"user\")`\n */\n public get user(): UserAccountToken | undefined {\n return this.alepha.store.get(\"alepha.server.request.user\");\n }\n\n public async ping() {\n const { data } = await this.httpClient.fetch(alephaServerAuthRoutes.userinfo, {\n schema: { response: userinfoResponseSchema },\n });\n\n this.alepha.store.set(\"alepha.server.request.apiLinks\", data.api);\n this.alepha.store.set(\"alepha.server.request.user\", data.user);\n\n return data.user;\n }\n\n public async login(\n provider: string,\n options: {\n hostname?: string;\n username?: string;\n password?: string;\n redirect?: string;\n [extra: string]: any;\n },\n ): Promise<Tokens> {\n if (options.username || options.password) {\n const { data } = await this.httpClient.fetch(\n `${options.hostname || \"\"}${alephaServerAuthRoutes.token}?provider=${provider}`,\n {\n method: \"POST\",\n body: JSON.stringify({\n username: options.username,\n password: options.password,\n ...options,\n }),\n schema: { response: tokenResponseSchema },\n },\n );\n\n this.alepha.store.set(\"alepha.server.request.apiLinks\", data.api);\n this.alepha.store.set(\"alepha.server.request.user\", data.user);\n\n return data;\n }\n\n if (this.alepha.isBrowser()) {\n const browser = this.alepha.inject(ReactBrowserProvider);\n const redirect =\n options.redirect ||\n (browser.transitioning\n ? window.location.origin + browser.transitioning.to\n : window.location.href);\n\n const href = `${window.location.origin}${alephaServerAuthRoutes.login}?provider=${provider}&redirect_uri=${encodeURIComponent(redirect)}`;\n\n if (browser.transitioning) {\n throw new Redirection(href);\n } else {\n window.location.href = href;\n return {} as Tokens;\n }\n }\n\n throw new Redirection(\n `${alephaServerAuthRoutes.login}?provider=${provider}&redirect_uri=${options.redirect || \"/\"}`,\n );\n }\n\n public logout() {\n window.location.href = `${alephaServerAuthRoutes.logout}?post_logout_redirect_uri=${encodeURIComponent(window.location.origin)}`;\n }\n}\n","import { useAlepha, useStore } from \"@alepha/react\";\nimport { type HttpVirtualClient, LinkProvider } from \"alepha/server/links\";\nimport { ReactAuth } from \"../services/ReactAuth.ts\";\n\nexport const useAuth = <T extends object = any>() => {\n const alepha = useAlepha();\n const [user] = useStore(\"alepha.server.request.user\");\n\n return {\n user,\n logout: () => {\n alepha.inject(ReactAuth).logout();\n },\n login: async (\n provider: keyof T,\n options: {\n username?: string;\n password?: string;\n redirect?: string;\n [extra: string]: any;\n } = {},\n ) => {\n await alepha.inject(ReactAuth).login(provider as string, options);\n },\n can: <Api extends object = any>(\n name: keyof HttpVirtualClient<Api>,\n ): boolean => {\n return alepha.inject(LinkProvider).can(name as string);\n },\n };\n};\n","import { AlephaReact } from \"@alepha/react\";\nimport { $module } from \"alepha\";\nimport type { UserAccount } from \"alepha/security\";\nimport { ReactAuthProvider } from \"./providers/ReactAuthProvider.ts\";\nimport { ReactAuth } from \"./services/ReactAuth.ts\";\nimport { $auth, AlephaServerAuth } from \"alepha/server/auth\";\nimport { AlephaServerLinks } from \"alepha/server/links\";\n\n// ---------------------------------------------------------------------------------------------------------------------\n\nexport * from \"./index.shared.ts\";\nexport * from \"./providers/ReactAuthProvider.ts\";\n\n// ---------------------------------------------------------------------------------------------------------------------\n\ndeclare module \"@alepha/react\" {\n interface ReactRouterState {\n user?: UserAccount;\n }\n}\n\n// ---------------------------------------------------------------------------------------------------------------------\n\n/**\n * The ReactAuthModule provides authentication services for React applications.\n *\n * @see {@link ReactAuthProvider}\n * @module alepha.react.auth\n */\nexport const AlephaReactAuth = $module({\n name: \"alepha.react.auth\",\n primitives: [$auth],\n services: [AlephaReact, AlephaServerLinks, AlephaServerAuth, ReactAuthProvider, ReactAuth],\n});\n"],"mappings":";;;;;;;;AAEA,IAAa,oBAAb,MAA+B;CAC7B,AAAmB,SAAS,QAAQ,OAAO;CAE3C,AAAgB,WAAW,MAAM;EAC/B,IAAI;EACJ,SAAS,OAAO,EAAE,SAAS,YAAY;AACrC,OAAI,SAAS,MAAM;IACjB,MAAM,EAAE,OAAO,OAAO,GAAG,SAAS,QAAQ;AAC1C,SAAK,OAAO,MAAM,IAAI,8BAA8B,KAAK;AACzD,UAAM,OAAO;;;EAGlB,CAAC;;;;;;;;ACJJ,IAAa,YAAb,MAAuB;CACrB,AAAmB,MAAM,SAAS;CAClC,AAAmB,SAAS,QAAQ,OAAO;CAC3C,AAAmB,aAAa,QAAQ,WAAW;CAEnD,AAAmB,oBAAoB,MAAM;EAC3C,IAAI;EACJ,SAAS,OAAO,UAAU;AACxB,OAAI,KAAK,OAAO,WAAW,CACzB,QAAO,eAAe,MAAM,OAAO,QAAQ,EACzC,WAAW,KAAK,MACjB,CAAC;;EAGP,CAAC;CAEF,AAAmB,iBAAiB,MAAM;EACxC,IAAI;EACJ,SAAS,OAAO,EAAE,cAAc;AAC9B,OAAI,KAAK,OAAO,WAAW,IAAI,KAAK,KAElC,SAAQ,gBAAgB;;EAG7B,CAAC;;;;;;CAOF,IAAW,OAAqC;AAC9C,SAAO,KAAK,OAAO,MAAM,IAAI,6BAA6B;;CAG5D,MAAa,OAAO;EAClB,MAAM,EAAE,SAAS,MAAM,KAAK,WAAW,MAAM,uBAAuB,UAAU,EAC5E,QAAQ,EAAE,UAAU,wBAAwB,EAC7C,CAAC;AAEF,OAAK,OAAO,MAAM,IAAI,kCAAkC,KAAK,IAAI;AACjE,OAAK,OAAO,MAAM,IAAI,8BAA8B,KAAK,KAAK;AAE9D,SAAO,KAAK;;CAGd,MAAa,MACX,UACA,SAOiB;AACjB,MAAI,QAAQ,YAAY,QAAQ,UAAU;GACxC,MAAM,EAAE,SAAS,MAAM,KAAK,WAAW,MACrC,GAAG,QAAQ,YAAY,KAAK,uBAAuB,MAAM,YAAY,YACrE;IACE,QAAQ;IACR,MAAM,KAAK,UAAU;KACnB,UAAU,QAAQ;KAClB,UAAU,QAAQ;KAClB,GAAG;KACJ,CAAC;IACF,QAAQ,EAAE,UAAU,qBAAqB;IAC1C,CACF;AAED,QAAK,OAAO,MAAM,IAAI,kCAAkC,KAAK,IAAI;AACjE,QAAK,OAAO,MAAM,IAAI,8BAA8B,KAAK,KAAK;AAE9D,UAAO;;AAGT,MAAI,KAAK,OAAO,WAAW,EAAE;GAC3B,MAAM,UAAU,KAAK,OAAO,OAAO,qBAAqB;GACxD,MAAM,WACJ,QAAQ,aACP,QAAQ,gBACL,OAAO,SAAS,SAAS,QAAQ,cAAc,KAC/C,OAAO,SAAS;GAEtB,MAAM,OAAO,GAAG,OAAO,SAAS,SAAS,uBAAuB,MAAM,YAAY,SAAS,gBAAgB,mBAAmB,SAAS;AAEvI,OAAI,QAAQ,cACV,OAAM,IAAI,YAAY,KAAK;QACtB;AACL,WAAO,SAAS,OAAO;AACvB,WAAO,EAAE;;;AAIb,QAAM,IAAI,YACR,GAAG,uBAAuB,MAAM,YAAY,SAAS,gBAAgB,QAAQ,YAAY,MAC1F;;CAGH,AAAO,SAAS;AACd,SAAO,SAAS,OAAO,GAAG,uBAAuB,OAAO,4BAA4B,mBAAmB,OAAO,SAAS,OAAO;;;;;;AC1GlI,MAAa,gBAAwC;CACnD,MAAM,SAAS,WAAW;CAC1B,MAAM,CAAC,QAAQ,SAAS,6BAA6B;AAErD,QAAO;EACL;EACA,cAAc;AACZ,UAAO,OAAO,UAAU,CAAC,QAAQ;;EAEnC,OAAO,OACL,UACA,UAKI,EAAE,KACH;AACH,SAAM,OAAO,OAAO,UAAU,CAAC,MAAM,UAAoB,QAAQ;;EAEnE,MACE,SACY;AACZ,UAAO,OAAO,OAAO,aAAa,CAAC,IAAI,KAAe;;EAEzD;;;;;;;;;;;ACAH,MAAa,kBAAkB,QAAQ;CACrC,MAAM;CACN,YAAY,CAAC,MAAM;CACnB,UAAU;EAAC;EAAa;EAAmB;EAAkB;EAAmB;EAAU;CAC3F,CAAC"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { $atom, $env, $hook, $inject, $module, $use, Alepha, AlephaError, Atom,
|
|
1
|
+
import { $atom, $env, $hook, $inject, $module, $use, Alepha, AlephaError, Atom, KIND, Primitive, createPrimitive, t } from "alepha";
|
|
2
2
|
import { AlephaDateTime, DateTimeProvider } from "alepha/datetime";
|
|
3
3
|
import { AlephaServer, HttpClient } from "alepha/server";
|
|
4
4
|
import { AlephaServerLinks, LinkProvider } from "alepha/server/links";
|
|
@@ -19,11 +19,11 @@ var ReactPageService = class {
|
|
|
19
19
|
};
|
|
20
20
|
|
|
21
21
|
//#endregion
|
|
22
|
-
//#region src/core/
|
|
22
|
+
//#region src/core/primitives/$page.ts
|
|
23
23
|
/**
|
|
24
|
-
* Main
|
|
24
|
+
* Main primitive for defining a React route in the application.
|
|
25
25
|
*
|
|
26
|
-
* The $page
|
|
26
|
+
* The $page primitive is the core building block for creating type-safe, SSR-enabled React routes.
|
|
27
27
|
* It provides a declarative way to define pages with powerful features:
|
|
28
28
|
*
|
|
29
29
|
* **Routing & Navigation**
|
|
@@ -109,9 +109,9 @@ var ReactPageService = class {
|
|
|
109
109
|
* ```
|
|
110
110
|
*/
|
|
111
111
|
const $page = (options) => {
|
|
112
|
-
return
|
|
112
|
+
return createPrimitive(PagePrimitive, options);
|
|
113
113
|
};
|
|
114
|
-
var
|
|
114
|
+
var PagePrimitive = class extends Primitive {
|
|
115
115
|
reactPageService = $inject(ReactPageService);
|
|
116
116
|
onInit() {
|
|
117
117
|
if (this.options.static) this.options.cache ??= { store: {
|
|
@@ -141,7 +141,7 @@ var PageDescriptor = class extends Descriptor {
|
|
|
141
141
|
return this.options.path || "";
|
|
142
142
|
}
|
|
143
143
|
};
|
|
144
|
-
$page[KIND] =
|
|
144
|
+
$page[KIND] = PagePrimitive;
|
|
145
145
|
|
|
146
146
|
//#endregion
|
|
147
147
|
//#region src/core/components/NotFound.tsx
|
|
@@ -421,9 +421,9 @@ const useEvents = (opts, deps) => {
|
|
|
421
421
|
function useStore(target, defaultValue) {
|
|
422
422
|
const alepha = useAlepha();
|
|
423
423
|
useMemo(() => {
|
|
424
|
-
if (defaultValue != null && alepha.
|
|
424
|
+
if (defaultValue != null && alepha.store.get(target) == null) alepha.store.set(target, defaultValue);
|
|
425
425
|
}, [defaultValue]);
|
|
426
|
-
const [state, setState] = useState(alepha.
|
|
426
|
+
const [state, setState] = useState(alepha.store.get(target));
|
|
427
427
|
useEffect(() => {
|
|
428
428
|
if (!alepha.isBrowser()) return;
|
|
429
429
|
const key = target instanceof Atom ? target.key : target;
|
|
@@ -432,7 +432,7 @@ function useStore(target, defaultValue) {
|
|
|
432
432
|
});
|
|
433
433
|
}, []);
|
|
434
434
|
return [state, (value) => {
|
|
435
|
-
alepha.
|
|
435
|
+
alepha.store.set(target, value);
|
|
436
436
|
}];
|
|
437
437
|
}
|
|
438
438
|
|
|
@@ -622,6 +622,7 @@ var ReactPageProvider = class {
|
|
|
622
622
|
if (!path.includes(":") && !path.includes("*")) pages.push({
|
|
623
623
|
...page,
|
|
624
624
|
name: params[Object.keys(params)[0]],
|
|
625
|
+
staticName: page.name,
|
|
625
626
|
path,
|
|
626
627
|
...entry
|
|
627
628
|
});
|
|
@@ -852,7 +853,7 @@ var ReactPageProvider = class {
|
|
|
852
853
|
on: "configure",
|
|
853
854
|
handler: () => {
|
|
854
855
|
let hasNotFoundHandler = false;
|
|
855
|
-
const pages = this.alepha.
|
|
856
|
+
const pages = this.alepha.primitives($page);
|
|
856
857
|
const hasParent = (it) => {
|
|
857
858
|
if (it.options.parent) return true;
|
|
858
859
|
for (const page of pages) if ((page.options.children ? Array.isArray(page.options.children) ? page.options.children : page.options.children() : []).includes(it)) return true;
|
|
@@ -950,7 +951,7 @@ var ReactBrowserRouterProvider = class extends RouterProvider {
|
|
|
950
951
|
};
|
|
951
952
|
await this.alepha.events.emit("react:action:begin", { type: "transition" });
|
|
952
953
|
await this.alepha.events.emit("react:transition:begin", {
|
|
953
|
-
previous: this.alepha.
|
|
954
|
+
previous: this.alepha.store.get("alepha.react.router.state"),
|
|
954
955
|
state
|
|
955
956
|
});
|
|
956
957
|
try {
|
|
@@ -992,7 +993,7 @@ var ReactBrowserRouterProvider = class extends RouterProvider {
|
|
|
992
993
|
const layer = previous[i];
|
|
993
994
|
if (state.layers[i]?.name !== layer.name) this.pageApi.page(layer.name)?.onLeave?.();
|
|
994
995
|
}
|
|
995
|
-
this.alepha.
|
|
996
|
+
this.alepha.store.set("alepha.react.router.state", state);
|
|
996
997
|
await this.alepha.events.emit("react:action:end", { type: "transition" });
|
|
997
998
|
await this.alepha.events.emit("react:transition:end", { state });
|
|
998
999
|
}
|
|
@@ -1030,7 +1031,7 @@ var ReactBrowserProvider = class {
|
|
|
1030
1031
|
}
|
|
1031
1032
|
transitioning;
|
|
1032
1033
|
get state() {
|
|
1033
|
-
return this.alepha.
|
|
1034
|
+
return this.alepha.store.get("alepha.react.router.state");
|
|
1034
1035
|
}
|
|
1035
1036
|
/**
|
|
1036
1037
|
* Accessor for Document DOM API.
|
|
@@ -1147,7 +1148,7 @@ var ReactBrowserProvider = class {
|
|
|
1147
1148
|
const hydration = this.getHydrationState();
|
|
1148
1149
|
const previous = hydration?.layers ?? [];
|
|
1149
1150
|
if (hydration) {
|
|
1150
|
-
for (const [key, value] of Object.entries(hydration)) if (key !== "layers") this.alepha.
|
|
1151
|
+
for (const [key, value] of Object.entries(hydration)) if (key !== "layers") this.alepha.store.set(key, value);
|
|
1151
1152
|
}
|
|
1152
1153
|
await this.render({ previous });
|
|
1153
1154
|
const element = this.router.root(this.state);
|
|
@@ -1192,7 +1193,7 @@ var ReactRouter = class {
|
|
|
1192
1193
|
alepha = $inject(Alepha);
|
|
1193
1194
|
pageApi = $inject(ReactPageProvider);
|
|
1194
1195
|
get state() {
|
|
1195
|
-
return this.alepha.
|
|
1196
|
+
return this.alepha.store.get("alepha.react.router.state");
|
|
1196
1197
|
}
|
|
1197
1198
|
get pages() {
|
|
1198
1199
|
return this.pageApi.getPages();
|
|
@@ -1686,7 +1687,7 @@ const decode = (alepha, schema, data) => {
|
|
|
1686
1687
|
//#region src/core/index.browser.ts
|
|
1687
1688
|
const AlephaReact = $module({
|
|
1688
1689
|
name: "alepha.react",
|
|
1689
|
-
|
|
1690
|
+
primitives: [$page],
|
|
1690
1691
|
services: [
|
|
1691
1692
|
ReactPageProvider,
|
|
1692
1693
|
ReactBrowserRouterProvider,
|
|
@@ -1699,5 +1700,5 @@ const AlephaReact = $module({
|
|
|
1699
1700
|
});
|
|
1700
1701
|
|
|
1701
1702
|
//#endregion
|
|
1702
|
-
export { $page, AlephaContext, AlephaReact, ClientOnly_default as ClientOnly, ErrorBoundary_default as ErrorBoundary, ErrorViewer_default as ErrorViewer, Link_default as Link, NestedView_default as NestedView, NotFoundPage as NotFound,
|
|
1703
|
+
export { $page, AlephaContext, AlephaReact, ClientOnly_default as ClientOnly, ErrorBoundary_default as ErrorBoundary, ErrorViewer_default as ErrorViewer, Link_default as Link, NestedView_default as NestedView, NotFoundPage as NotFound, PagePrimitive, ReactBrowserProvider, ReactBrowserRouterProvider, ReactPageProvider, ReactRouter, Redirection, RouterLayerContext, isPageRoute, reactBrowserOptions, ssrSchemaLoading, useAction, useActive, useAlepha, useClient, useEvents, useInject, useQueryParams, useRouter, useRouterState, useSchema, useStore };
|
|
1703
1704
|
//# sourceMappingURL=index.browser.js.map
|