@alignable/bifrost 0.0.7 → 0.0.9

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.d.ts CHANGED
@@ -1,11 +1,11 @@
1
- import { Config } from "vite-plugin-ssr/types";
1
+ import { Config, ConfigNonHeaderFile } from "vite-plugin-ssr/types";
2
2
  import { DocumentProps, Layout, LayoutMap } from "./types/internal";
3
3
  import ProxyLibConfig from "./proxy/pages/+config.js";
4
4
  import bifrostLibConfig from "./renderer/+config.js";
5
5
  import { Turbolinks } from "./lib/turbolinks.js";
6
6
  export { usePageContext } from "./renderer/usePageContext.js";
7
7
  export { LayoutMap, DocumentProps };
8
- type ConfigConstructor<LibConfig extends Config, T extends {
8
+ type ConfigConstructor<LibConfig extends ConfigNonHeaderFile, T extends {
9
9
  [K in keyof LibConfig["meta"]]?: any;
10
10
  }> = Config & Partial<T>;
11
11
  export type ProxyConfig<LayoutProps> = ConfigConstructor<typeof ProxyLibConfig, {
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAC/C,OAAO,EAAE,aAAa,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AACpE,OAAO,cAAc,MAAM,0BAA0B,CAAC;AACtD,OAAO,gBAAgB,MAAM,uBAAuB,CAAC;AACrD,OAAO,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AACjD,OAAO,EAAE,cAAc,EAAE,MAAM,8BAA8B,CAAC;AAI9D,OAAO,EAAE,SAAS,EAAE,aAAa,EAAE,CAAC;AAGpC,KAAK,iBAAiB,CACpB,SAAS,SAAS,MAAM,EACxB,CAAC,SAAS;KAAG,CAAC,IAAI,MAAM,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,GAAG;CAAE,IAChD,MAAM,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;AAExB,MAAM,MAAM,WAAW,CAAC,WAAW,IAAI,iBAAiB,CACtD,OAAO,cAAc,EACrB;IACE,SAAS,EAAE,SAAS,CAAC,WAAW,CAAC,CAAC;CACnC,CACF,CAAC;AAEF,MAAM,MAAM,aAAa,CAAC,WAAW,IAAI,iBAAiB,CACxD,OAAO,gBAAgB,EACvB;IACE,MAAM,EAAE,MAAM,CAAC,WAAW,CAAC,CAAC;IAC5B,WAAW,EAAE,WAAW,CAAC;IACzB,aAAa,EAAE,aAAa,CAAC;CAC9B,CACF,CAAC;AAEF,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,MAAM;QACd,UAAU,EAAE,OAAO,UAAU,CAAC;KAC/B;CACF"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AACpE,OAAO,EAAE,aAAa,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AACpE,OAAO,cAAc,MAAM,0BAA0B,CAAC;AACtD,OAAO,gBAAgB,MAAM,uBAAuB,CAAC;AACrD,OAAO,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AACjD,OAAO,EAAE,cAAc,EAAE,MAAM,8BAA8B,CAAC;AAI9D,OAAO,EAAE,SAAS,EAAE,aAAa,EAAE,CAAC;AAGpC,KAAK,iBAAiB,CACpB,SAAS,SAAS,mBAAmB,EACrC,CAAC,SAAS;KAAG,CAAC,IAAI,MAAM,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,GAAG;CAAE,IAChD,MAAM,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;AAExB,MAAM,MAAM,WAAW,CAAC,WAAW,IAAI,iBAAiB,CACtD,OAAO,cAAc,EACrB;IACE,SAAS,EAAE,SAAS,CAAC,WAAW,CAAC,CAAC;CACnC,CACF,CAAC;AAEF,MAAM,MAAM,aAAa,CAAC,WAAW,IAAI,iBAAiB,CACxD,OAAO,gBAAgB,EACvB;IACE,MAAM,EAAE,MAAM,CAAC,WAAW,CAAC,CAAC;IAC5B,WAAW,EAAE,WAAW,CAAC;IACzB,aAAa,EAAE,aAAa,CAAC;CAC9B,CACF,CAAC;AAEF,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,MAAM;QACd,UAAU,EAAE,OAAO,UAAU,CAAC;KAC/B;CACF"}
@@ -0,0 +1,5 @@
1
+ export declare function getGlobalObject<T extends Record<string, unknown> = never>(key: `${string}.ts`, defaultValue: T): T;
2
+ declare global {
3
+ var __vite_plugin_ssr: undefined | Record<string, Record<string, unknown>>;
4
+ }
5
+ //# sourceMappingURL=getGlobalObject.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getGlobalObject.d.ts","sourceRoot":"","sources":["../../lib/getGlobalObject.ts"],"names":[],"mappings":"AAAA,wBAAgB,eAAe,CAAC,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,KAAK,EAEvE,GAAG,EAAE,GAAG,MAAM,KAAK,EACnB,YAAY,EAAE,CAAC,GACd,CAAC,CAIH;AACD,OAAO,CAAC,MAAM,CAAC;IACb,IAAI,iBAAiB,EAAE,SAAS,GAAG,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,CAAA;CAC3E"}
@@ -0,0 +1,7 @@
1
+ export function getGlobalObject(
2
+ // We use the filename as key; each `getGlobalObject()` call should live in a unique filename.
3
+ key, defaultValue) {
4
+ const allGlobalObjects = (globalThis.__vite_plugin_ssr = globalThis.__vite_plugin_ssr || {});
5
+ const globalObject = (allGlobalObjects[key] = allGlobalObjects[key] || defaultValue);
6
+ return globalObject;
7
+ }
@@ -1,9 +1,9 @@
1
1
  declare const _default: {
2
2
  route: string;
3
- onBeforeRenderPath: string;
4
- onRenderClientPath: string;
5
- onRenderHtmlPath: string;
6
- PagePath: string;
3
+ onBeforeRender: "import:@alignable/bifrost/proxy/pages/onBeforeRender";
4
+ onRenderClient: "import:@alignable/bifrost/proxy/pages/onRenderClient";
5
+ onRenderHtml: "import:@alignable/bifrost/proxy/pages/onRenderHtml";
6
+ Page: string;
7
7
  passToClient: string[];
8
8
  clientRouting: true;
9
9
  hydrationCanBeAborted: true;
@@ -1,9 +1,9 @@
1
1
  export default {
2
2
  route: "/*",
3
- onBeforeRenderPath: "@alignable/bifrost/proxy/pages/onBeforeRender",
4
- onRenderClientPath: "@alignable/bifrost/proxy/pages/onRenderClient",
5
- onRenderHtmlPath: "@alignable/bifrost/proxy/pages/onRenderHtml",
6
- PagePath: "@alignable/bifrost/proxy/pages/Page",
3
+ onBeforeRender: "import:@alignable/bifrost/proxy/pages/onBeforeRender",
4
+ onRenderClient: "import:@alignable/bifrost/proxy/pages/onRenderClient",
5
+ onRenderHtml: "import:@alignable/bifrost/proxy/pages/onRenderHtml",
6
+ Page: "import:@alignable/bifrost/proxy/pages/Page",
7
7
  passToClient: ["proxySendClient", "layout", "layoutProps", "redirectTo"],
8
8
  clientRouting: true,
9
9
  hydrationCanBeAborted: true,
@@ -0,0 +1,3 @@
1
+ import { PageContextBuiltInClientWithClientRouting } from "vite-plugin-ssr/types";
2
+ export default function onPageTransitionEnd(pageContext: PageContextBuiltInClientWithClientRouting): void;
3
+ //# sourceMappingURL=onPageTransitionEnd.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"onPageTransitionEnd.d.ts","sourceRoot":"","sources":["../../../proxy/pages/onPageTransitionEnd.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,yCAAyC,EAAE,MAAM,uBAAuB,CAAC;AAGlF,MAAM,CAAC,OAAO,UAAU,mBAAmB,CACzC,WAAW,EAAE,yCAAyC,QAGvD"}
@@ -0,0 +1,3 @@
1
+ export default function onPageTransitionEnd(pageContext) {
2
+ // TODO: We're just guessing with the request. handle failed and failedwithstatuscode
3
+ }
@@ -0,0 +1,3 @@
1
+ import { PageContextBuiltInClientWithClientRouting } from "vite-plugin-ssr/types";
2
+ export default function onPageTransitionStart(pageContext: PageContextBuiltInClientWithClientRouting): void;
3
+ //# sourceMappingURL=onPageTransitionStart.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"onPageTransitionStart.d.ts","sourceRoot":"","sources":["../../../proxy/pages/onPageTransitionStart.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,yCAAyC,EAAE,MAAM,uBAAuB,CAAC;AAIlF,MAAM,CAAC,OAAO,UAAU,qBAAqB,CAC3C,WAAW,EAAE,yCAAyC,QAQvD"}
@@ -0,0 +1,9 @@
1
+ import { Visit, getAdapter } from "../../lib/turbolinks";
2
+ export default function onPageTransitionStart(pageContext) {
3
+ const v = new Visit();
4
+ window.Turbolinks.controller.restorationIdentifier = v.restorationIdentifier;
5
+ window.Turbolinks.controller.currentVisit = v;
6
+ console.log(v.identifier);
7
+ getAdapter()?.visitStarted(v);
8
+ getAdapter()?.visitRequestStarted(v);
9
+ }
@@ -1,6 +1,6 @@
1
1
  declare const _default: {
2
- routePath: string;
3
- PagePath: string;
2
+ route: string;
3
+ Page: string;
4
4
  meta: {
5
5
  onBeforeRender: {
6
6
  env: "server-and-client";
@@ -1,6 +1,6 @@
1
1
  export default {
2
- routePath: "@alignable/bifrost/proxy/pages/restorationVisit/route",
3
- PagePath: "@alignable/bifrost/proxy/pages/Page",
2
+ route: "import:@alignable/bifrost/proxy/pages/restorationVisit/route",
3
+ Page: "import:@alignable/bifrost/proxy/pages/Page",
4
4
  meta: {
5
5
  onBeforeRender: {
6
6
  // We tell vite-plugin-ssr to load and execute onBeforeRender()
@@ -1,8 +1,8 @@
1
1
  declare const _default: {
2
2
  passToClient: string[];
3
- onRenderClientPath: string;
4
- onRenderHtmlPath: string;
5
- onBeforeRoutePath: string;
3
+ onRenderClient: "import:@alignable/bifrost/renderer/onRenderClient";
4
+ onRenderHtml: "import:@alignable/bifrost/renderer/onRenderHtml";
5
+ onBeforeRoute: "import:@alignable/bifrost/renderer/onBeforeRoute";
6
6
  clientRouting: true;
7
7
  hydrationCanBeAborted: true;
8
8
  meta: {
@@ -1,8 +1,8 @@
1
1
  export default {
2
2
  passToClient: ["layoutProps", "pageProps", "redirectTo", "documentProps"],
3
- onRenderClientPath: "@alignable/bifrost/renderer/onRenderClient",
4
- onRenderHtmlPath: "@alignable/bifrost/renderer/onRenderHtml",
5
- onBeforeRoutePath: "@alignable/bifrost/renderer/onBeforeRoute",
3
+ onRenderClient: "import:@alignable/bifrost/renderer/onRenderClient",
4
+ onRenderHtml: "import:@alignable/bifrost/renderer/onRenderHtml",
5
+ onBeforeRoute: "import:@alignable/bifrost/renderer/onBeforeRoute",
6
6
  clientRouting: true,
7
7
  hydrationCanBeAborted: true,
8
8
  meta: {
@@ -1,9 +1,9 @@
1
1
  export default function onBeforeRoute(_pageContext: any): {
2
2
  pageContext: {
3
3
  _pageId: string;
4
- layoutProps: Record<string, unknown>;
5
4
  proxySendClient?: import("../types/internal.js").Proxy | undefined;
6
5
  layout: string;
6
+ layoutProps: Record<string, unknown>;
7
7
  };
8
8
  } | undefined;
9
9
  //# sourceMappingURL=onBeforeRoute.d.ts.map
@@ -6,5 +6,6 @@ declare function PageContextProvider({ pageContext, children }: {
6
6
  pageContext: PageContext;
7
7
  children: React.ReactNode;
8
8
  }): JSX.Element;
9
+ /** Access the pageContext from any React component */
9
10
  declare function usePageContext(): PageContext;
10
11
  //# sourceMappingURL=usePageContext.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"usePageContext.d.ts","sourceRoot":"","sources":["../../renderer/usePageContext.tsx"],"names":[],"mappings":"AAGA,OAAO,KAAqB,MAAM,OAAO,CAAA;AACzC,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAEnD,OAAO,EAAE,mBAAmB,EAAE,CAAA;AAC9B,OAAO,EAAE,cAAc,EAAE,CAAA;AAIzB,iBAAS,mBAAmB,CAAC,EAAE,WAAW,EAAE,QAAQ,EAAE,EAAE;IAAE,WAAW,EAAE,WAAW,CAAC;IAAC,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAA;CAAE,eAE9G;AAED,iBAAS,cAAc,gBAGtB"}
1
+ {"version":3,"file":"usePageContext.d.ts","sourceRoot":"","sources":["../../renderer/usePageContext.tsx"],"names":[],"mappings":"AAGA,OAAO,KAAqB,MAAM,OAAO,CAAA;AACzC,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAGnD,OAAO,EAAE,mBAAmB,EAAE,CAAA;AAC9B,OAAO,EAAE,cAAc,EAAE,CAAA;AAMzB,iBAAS,mBAAmB,CAAC,EAAE,WAAW,EAAE,QAAQ,EAAE,EAAE;IAAE,WAAW,EAAE,WAAW,CAAC;IAAC,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAA;CAAE,eAG9G;AAED,sDAAsD;AACtD,iBAAS,cAAc,gBAItB"}
@@ -1,13 +1,21 @@
1
1
  // `usePageContext` allows us to access `pageContext` in any React component.
2
2
  // See https://vite-plugin-ssr.com/pageContext-anywhere
3
3
  import React, { useContext } from 'react';
4
+ import { getGlobalObject } from './utils/getGlobalObject.js';
4
5
  export { PageContextProvider };
5
6
  export { usePageContext };
6
- const Context = React.createContext(undefined);
7
+ const { Context } = getGlobalObject('PageContextProvider.ts', {
8
+ Context: React.createContext(undefined)
9
+ });
7
10
  function PageContextProvider({ pageContext, children }) {
11
+ if (!pageContext)
12
+ throw new Error('Argument pageContext missing');
8
13
  return React.createElement(Context.Provider, { value: pageContext }, children);
9
14
  }
15
+ /** Access the pageContext from any React component */
10
16
  function usePageContext() {
11
17
  const pageContext = useContext(Context);
18
+ if (!pageContext)
19
+ throw new Error('<PageContextProvider> is needed for being able to use usePageContext()');
12
20
  return pageContext;
13
21
  }
@@ -0,0 +1,5 @@
1
+ export declare function getGlobalObject<T extends Record<string, unknown> = never>(key: `${string}.ts`, defaultValue: T): T;
2
+ declare global {
3
+ var __vite_plugin_ssr: undefined | Record<string, Record<string, unknown>>;
4
+ }
5
+ //# sourceMappingURL=getGlobalObject.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getGlobalObject.d.ts","sourceRoot":"","sources":["../../../renderer/utils/getGlobalObject.ts"],"names":[],"mappings":"AAEA,wBAAgB,eAAe,CAAC,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,KAAK,EAEvE,GAAG,EAAE,GAAG,MAAM,KAAK,EACnB,YAAY,EAAE,CAAC,GACd,CAAC,CAIH;AACD,OAAO,CAAC,MAAM,CAAC;IACb,IAAI,iBAAiB,EAAE,SAAS,GAAG,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,CAAA;CAC3E"}
@@ -0,0 +1,8 @@
1
+ // https://github.com/brillout/vike-react/blob/main/vike-react/renderer/utils/getGlobalObject.ts
2
+ export function getGlobalObject(
3
+ // We use the filename as key; each `getGlobalObject()` call should live in a unique filename.
4
+ key, defaultValue) {
5
+ const allGlobalObjects = (globalThis.__vite_plugin_ssr = globalThis.__vite_plugin_ssr || {});
6
+ const globalObject = (allGlobalObjects[key] = allGlobalObjects[key] || defaultValue);
7
+ return globalObject;
8
+ }
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@alignable/bifrost",
3
3
  "repository": "https://github.com/Alignable/bifrost.git",
4
- "version": "0.0.7",
4
+ "version": "0.0.9",
5
5
  "type": "module",
6
6
  "types": "./dist/index.d.ts",
7
7
  "exports": {
@@ -58,8 +58,8 @@
58
58
  "typesVersions": {
59
59
  "*": {
60
60
  "*": [
61
- "./dist/index.d.ts",
62
- "./dist/*"
61
+ "./dist/*",
62
+ "./dist/index.d.ts"
63
63
  ]
64
64
  }
65
65
  },
@@ -76,12 +76,12 @@
76
76
  "react": "^18.x.x",
77
77
  "react-dom": "^18.x.x",
78
78
  "uuid": "^9.0.0",
79
- "vite-plugin-ssr": "0.4.127"
79
+ "vite-plugin-ssr": "0.4.130"
80
80
  },
81
81
  "peerDependencies": {
82
82
  "react": "^18.x.x",
83
83
  "react-dom": "^18.x.x",
84
- "vite-plugin-ssr": "0.4.127",
84
+ "vite-plugin-ssr": "0.4.130",
85
85
  "typescript": ">=4.7"
86
86
  },
87
87
  "devDependencies": {