@squide/firefly 4.0.1 → 4.0.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/CHANGELOG.md CHANGED
@@ -1,5 +1,14 @@
1
1
  # @squide/firefly
2
2
 
3
+ ## 4.0.2
4
+
5
+ ### Patch Changes
6
+
7
+ - [#135](https://github.com/gsoft-inc/wl-squide/pull/135) [`8e73083`](https://github.com/gsoft-inc/wl-squide/commit/8e73083bb90a6f23495ac6a8dca0245862ee2c9a) Thanks [@patricklafrance](https://github.com/patricklafrance)! - Fixing a remaining issue with deferred registrations that depends on protected data.
8
+
9
+ - Updated dependencies [[`8e73083`](https://github.com/gsoft-inc/wl-squide/commit/8e73083bb90a6f23495ac6a8dca0245862ee2c9a)]:
10
+ - @squide/react-router@4.0.2
11
+
3
12
  ## 4.0.1
4
13
 
5
14
  ### Patch Changes
package/dist/AppRouter.js CHANGED
@@ -1 +1 @@
1
- export { AppRouter, BootstrappingRoute } from './chunk-72TYI5MX.js';
1
+ export { AppRouter, BootstrappingRoute } from './chunk-M533VVCI.js';
@@ -0,0 +1,6 @@
1
+ import * as react_jsx_runtime from 'react/jsx-runtime';
2
+
3
+ declare function NoMatchRouteFallback(): react_jsx_runtime.JSX.Element;
4
+ declare const Component: typeof NoMatchRouteFallback;
5
+
6
+ export { Component, NoMatchRouteFallback };
@@ -0,0 +1 @@
1
+ export { Component, NoMatchRouteFallback } from './chunk-MCU5TIOP.js';
@@ -1,6 +1,6 @@
1
1
  import { useLogOnceLogger, isNil } from '@squide/core';
2
2
  import { useIsMswStarted } from '@squide/msw';
3
- import { useIsRouteMatchProtected, useRoutes } from '@squide/react-router';
3
+ import { useRouteMatch, useIsRouteProtected, useRoutes } from '@squide/react-router';
4
4
  import { useAreModulesRegistered, useAreModulesReady } from '@squide/webpack-module-federation';
5
5
  import { useEffect, useCallback, cloneElement, useMemo } from 'react';
6
6
  import { ErrorBoundary, useErrorBoundary } from 'react-error-boundary';
@@ -94,7 +94,8 @@ function BootstrappingRoute(props) {
94
94
  }
95
95
  }, [logger, areModulesRegistered, areModulesReady, isMswStarted, waitForMsw]);
96
96
  useLoadPublicData(areModulesRegistered, areModulesReady, isMswStarted, isPublicDataLoaded, onLoadPublicData);
97
- const isActiveRouteProtected = useIsRouteMatchProtected(location2, { throwWhenThereIsNoMatch: areModulesReady });
97
+ const activeRoute = useRouteMatch(location2, { throwWhenThereIsNoMatch: areModulesReady });
98
+ const isActiveRouteProtected = useIsRouteProtected(activeRoute);
98
99
  useLoadProtectedData(areModulesRegistered, areModulesReady, isMswStarted, isActiveRouteProtected, isProtectedDataLoaded, onLoadProtectedData);
99
100
  useEffect(() => {
100
101
  if (onCompleteRegistrations) {
@@ -105,7 +106,7 @@ function BootstrappingRoute(props) {
105
106
  }
106
107
  }
107
108
  }, [areModulesRegistered, areModulesReady, isMswStarted, isPublicDataLoaded, isProtectedDataLoaded, isActiveRouteProtected, onCompleteRegistrations]);
108
- if (!areModulesReady || !isMswStarted || !isPublicDataLoaded || isActiveRouteProtected && !isProtectedDataLoaded) {
109
+ if (!areModulesReady || !isMswStarted || !activeRoute || !isPublicDataLoaded || isActiveRouteProtected && !isProtectedDataLoaded) {
109
110
  return fallbackElement;
110
111
  }
111
112
  return /* @__PURE__ */ jsx(Outlet, {});
@@ -131,6 +132,12 @@ function AppRouter(props) {
131
132
  });
132
133
  }, [errorElement]);
133
134
  return useMemo(() => {
135
+ if (!routes.some((x) => x.path === "*")) {
136
+ routes.push({
137
+ path: "*",
138
+ lazy: () => import('./NoMatchRouteFallback.js')
139
+ });
140
+ }
134
141
  return renderRouterProvider([
135
142
  {
136
143
  element: /* @__PURE__ */ jsx(ErrorBoundary, { fallbackRender: errorRenderer, children: /* @__PURE__ */ jsx(
@@ -0,0 +1,27 @@
1
+ import { jsxs, jsx } from 'react/jsx-runtime';
2
+
3
+ // src/NoMatchRouteFallback.tsx
4
+ function NoMatchRouteFallback() {
5
+ return /* @__PURE__ */ jsxs("div", { children: [
6
+ /* @__PURE__ */ jsx("h1", { children: "404 not found" }),
7
+ /* @__PURE__ */ jsxs("p", { children: [
8
+ "This page has been dynamically added by Squide to fix an issue with the ",
9
+ /* @__PURE__ */ jsx("code", { children: "AppRouter" }),
10
+ " component. ",
11
+ /* @__PURE__ */ jsxs("strong", { children: [
12
+ "Please replace this page in your application by a ",
13
+ /* @__PURE__ */ jsx("a", { href: "https://reactrouter.com/en/main/start/tutorial#handling-not-found-errors", children: "custom match page" }),
14
+ "."
15
+ ] })
16
+ ] }),
17
+ /* @__PURE__ */ jsx("p", { children: "The code should be like the following:" }),
18
+ /* @__PURE__ */ jsx("pre", { style: { backgroundColor: "rgb(243, 245, 249)", color: "rgb(21, 25, 40)", padding: "4px 10px", border: "1px solid rgb(225, 229, 239)" }, children: `runtime.registerRoute({
19
+ $visibility: "public",
20
+ path: "*",
21
+ lazy: import("./NoMatchPage.tsx")
22
+ });` })
23
+ ] });
24
+ }
25
+ var Component = NoMatchRouteFallback;
26
+
27
+ export { Component, NoMatchRouteFallback };
package/dist/index.d.ts CHANGED
@@ -3,6 +3,7 @@ export * from '@squide/msw';
3
3
  export * from '@squide/react-router';
4
4
  export * from '@squide/webpack-module-federation';
5
5
  export { AppRouter, AppRouterProps, BootstrappingRoute, OnCompleteRegistrationsFunction, OnLoadProtectedDataFunction, OnLoadPublicDataFunction, RenderRouterProviderFunction } from './AppRouter.js';
6
+ export { Component, NoMatchRouteFallback } from './NoMatchRouteFallback.js';
6
7
  export { FireflyRuntime } from './fireflyRuntime.js';
7
8
  import 'react';
8
9
  import 'react/jsx-runtime';
package/dist/index.js CHANGED
@@ -1,4 +1,5 @@
1
- export { AppRouter, BootstrappingRoute } from './chunk-72TYI5MX.js';
1
+ export { AppRouter, BootstrappingRoute } from './chunk-M533VVCI.js';
2
+ export { Component, NoMatchRouteFallback } from './chunk-MCU5TIOP.js';
2
3
  export { FireflyRuntime } from './chunk-6R4K3V6F.js';
3
4
  export * from '@squide/core';
4
5
  export * from '@squide/msw';
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@squide/firefly",
3
3
  "author": "Workleap",
4
- "version": "4.0.1",
4
+ "version": "4.0.2",
5
5
  "description": "Helpers to facilitate the creation of a shell package with Squide firefly technology stack.",
6
6
  "license": "Apache-2.0",
7
7
  "repository": {
@@ -92,9 +92,9 @@
92
92
  },
93
93
  "dependencies": {
94
94
  "@squide/core": "3.2.1",
95
- "@squide/msw": "2.0.9",
96
- "@squide/react-router": "4.0.1",
97
- "@squide/webpack-module-federation": "3.0.4"
95
+ "@squide/react-router": "4.0.2",
96
+ "@squide/webpack-module-federation": "3.0.4",
97
+ "@squide/msw": "2.0.9"
98
98
  },
99
99
  "sideEffects": false,
100
100
  "engines": {