Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@module-federation/bridge-react

Package Overview
Dependencies
Maintainers
0
Versions
365
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@module-federation/bridge-react - npm Package Compare versions

Comparing version 0.0.0-next-20240718061842 to 0.0.0-next-20240718063946

dist/router-v5.cjs.js

5

CHANGELOG.md
# @module-federation/bridge-react
## 0.0.0-next-20240718061842
## 0.0.0-next-20240718063946
### Patch Changes
- @module-federation/bridge-shared@0.0.0-next-20240718061842
- chore: bump next
- @module-federation/bridge-shared@0.0.0-next-20240718063946

@@ -9,0 +10,0 @@ ## 0.2.6

56

dist/index.cjs.js

@@ -310,28 +310,46 @@ "use strict";

const RawComponent = (info) => {
const { appInfo, propsInfo } = info;
const { appInfo, propsInfo, ...restProps } = info;
const { name, memoryRoute, basename = "/" } = appInfo;
return /* @__PURE__ */ React__namespace.createElement(context.RouterContext.Provider, { value: { name, basename, memoryRoute } }, /* @__PURE__ */ React__namespace.createElement(bridgeInfo.rootComponent, { ...propsInfo, basename }));
return /* @__PURE__ */ React__namespace.createElement(context.RouterContext.Provider, { value: { name, basename, memoryRoute } }, /* @__PURE__ */ React__namespace.createElement(bridgeInfo.rootComponent, { ...propsInfo, basename, ...restProps }));
};
return {
render(info) {
async render(info) {
context.LoggerInstance.log(`createBridgeComponent render Info`, info);
const { name, basename, memoryRoute, ...propsInfo } = info;
if (context.atLeastReact18(React__namespace)) {
const root = client.createRoot(info.dom);
rootMap.set(info.dom, root);
root.render(
/* @__PURE__ */ React__namespace.createElement(
RawComponent,
{
propsInfo,
appInfo: {
name,
basename,
memoryRoute
if (bridgeInfo == null ? void 0 : bridgeInfo.render) {
Promise.resolve(bridgeInfo == null ? void 0 : bridgeInfo.render(
/* @__PURE__ */ React__namespace.createElement(
RawComponent,
{
propsInfo,
appInfo: {
name,
basename,
memoryRoute
}
}
}
)
);
),
info.dom
)).then((root) => rootMap.set(info.dom, root));
} else {
const root = client.createRoot(info.dom);
root.render(
/* @__PURE__ */ React__namespace.createElement(
RawComponent,
{
propsInfo,
appInfo: {
name,
basename,
memoryRoute
}
}
)
);
rootMap.set(info.dom, root);
}
} else {
ReactDOM.render(
const renderFunc = (bridgeInfo == null ? void 0 : bridgeInfo.render) || ReactDOM.render;
renderFunc(
/* @__PURE__ */ React__namespace.createElement(

@@ -352,3 +370,3 @@ RawComponent,

},
destroy(info) {
async destroy(info) {
context.LoggerInstance.log(`createBridgeComponent destroy Info`, {

@@ -355,0 +373,0 @@ dom: info.dom

import { ComponentType } from 'react';
import { default as default_2 } from 'react';
import { default as default_3 } from 'react-dom/client';
import { ErrorInfo } from 'react';

@@ -8,6 +9,6 @@ import { PropsWithChildren } from 'react';

export declare function createBridgeComponent<T>(bridgeInfo: ProviderFnParams<T>): () => {
render(info: RenderFnParams & any): void;
render(info: RenderFnParams & any): Promise<void>;
destroy(info: {
dom: HTMLElement;
}): void;
}): Promise<void>;
rawComponent: React_2.ComponentType<T>;

@@ -23,4 +24,4 @@ __BRIDGE_FN__: (_args: T) => void;

}): (props: {
basename?: ProviderParams['basename'];
memoryRoute?: ProviderParams['memoryRoute'];
basename?: ProviderParams["basename"];
memoryRoute?: ProviderParams["memoryRoute"];
} & ("__BRIDGE_FN__" extends keyof (T[E] extends (...args: any) => any ? ReturnType<T[E]> : never) ? (T[E] extends (...args: any) => any ? ReturnType<T[E]> : never)["__BRIDGE_FN__"] extends (...args: any) => any ? Parameters<(T[E] extends (...args: any) => any ? ReturnType<T[E]> : never)["__BRIDGE_FN__"]>[0] : {} : {})) => default_2.JSX.Element;

@@ -54,2 +55,3 @@

rootComponent: React_2.ComponentType<T>;
render?: (App: React_2.ReactElement, id?: HTMLElement | string) => RootType | Promise<RootType>;
};

@@ -69,2 +71,4 @@

declare type RootType = HTMLElement | default_3.Root;
export { }

@@ -291,28 +291,46 @@ import * as React from "react";

const RawComponent = (info) => {
const { appInfo, propsInfo } = info;
const { appInfo, propsInfo, ...restProps } = info;
const { name, memoryRoute, basename = "/" } = appInfo;
return /* @__PURE__ */ React.createElement(RouterContext.Provider, { value: { name, basename, memoryRoute } }, /* @__PURE__ */ React.createElement(bridgeInfo.rootComponent, { ...propsInfo, basename }));
return /* @__PURE__ */ React.createElement(RouterContext.Provider, { value: { name, basename, memoryRoute } }, /* @__PURE__ */ React.createElement(bridgeInfo.rootComponent, { ...propsInfo, basename, ...restProps }));
};
return {
render(info) {
async render(info) {
LoggerInstance.log(`createBridgeComponent render Info`, info);
const { name, basename, memoryRoute, ...propsInfo } = info;
if (atLeastReact18(React)) {
const root = client.createRoot(info.dom);
rootMap.set(info.dom, root);
root.render(
/* @__PURE__ */ React.createElement(
RawComponent,
{
propsInfo,
appInfo: {
name,
basename,
memoryRoute
if (bridgeInfo == null ? void 0 : bridgeInfo.render) {
Promise.resolve(bridgeInfo == null ? void 0 : bridgeInfo.render(
/* @__PURE__ */ React.createElement(
RawComponent,
{
propsInfo,
appInfo: {
name,
basename,
memoryRoute
}
}
}
)
);
),
info.dom
)).then((root) => rootMap.set(info.dom, root));
} else {
const root = client.createRoot(info.dom);
root.render(
/* @__PURE__ */ React.createElement(
RawComponent,
{
propsInfo,
appInfo: {
name,
basename,
memoryRoute
}
}
)
);
rootMap.set(info.dom, root);
}
} else {
ReactDOM.render(
const renderFunc = (bridgeInfo == null ? void 0 : bridgeInfo.render) || ReactDOM.render;
renderFunc(
/* @__PURE__ */ React.createElement(

@@ -333,3 +351,3 @@ RawComponent,

},
destroy(info) {
async destroy(info) {
LoggerInstance.log(`createBridgeComponent destroy Info`, {

@@ -336,0 +354,0 @@ dom: info.dom

@@ -63,4 +63,6 @@ "use strict";

const createBrowserRouter = ReactRouterDom__namespace["createBrowserRouter"];
console.log("=======resolve to v5!!");
if (!routerContextProps)
return /* @__PURE__ */ React.createElement(RouterProvider, { ...props });
console.log("=======resolve to v6!!");
if (routerContextProps.memoryRoute) {

@@ -72,2 +74,7 @@ const MemeoryRouterInstance = createMemoryRouter(routers, {

} else {
console.log("=======createBrowserRouter routers", routers);
console.log(
"=======createBrowserRouter routerContextProps.basename",
routerContextProps.basename
);
const BrowserRouterInstance = createBrowserRouter(routers, {

@@ -74,0 +81,0 @@ basename: routerContextProps.basename,

@@ -45,4 +45,6 @@ import React__default, { useContext } from "react";

const createBrowserRouter = ReactRouterDom["createBrowserRouter"];
console.log("=======resolve to v5!!");
if (!routerContextProps)
return /* @__PURE__ */ React__default.createElement(RouterProvider, { ...props });
console.log("=======resolve to v6!!");
if (routerContextProps.memoryRoute) {

@@ -54,2 +56,7 @@ const MemeoryRouterInstance = createMemoryRouter(routers, {

} else {
console.log("=======createBrowserRouter routers", routers);
console.log(
"=======createBrowserRouter routerContextProps.basename",
routerContextProps.basename
);
const BrowserRouterInstance = createBrowserRouter(routers, {

@@ -56,0 +63,0 @@ basename: routerContextProps.basename,

{
"name": "@module-federation/bridge-react",
"version": "0.0.0-next-20240718061842",
"version": "0.0.0-next-20240718063946",
"publishConfig": {

@@ -23,2 +23,12 @@ "access": "public"

},
"./router-v5": {
"types": "./dist/router-v5.d.ts",
"import": "./dist/router-v5.es.js",
"require": "./dist/router-v5.cjs.js"
},
"./router-v6": {
"types": "./dist/router-v6.d.ts",
"import": "./dist/router-v6.es.js",
"require": "./dist/router-v6.cjs.js"
},
"./*": "./*"

@@ -29,3 +39,3 @@ },

"react-error-boundary": "^4.0.13",
"@module-federation/bridge-shared": "0.0.0-next-20240718061842"
"@module-federation/bridge-shared": "0.0.0-next-20240718063946"
},

@@ -32,0 +42,0 @@ "peerDependencies": {

@@ -25,2 +25,4 @@ import { defineConfig } from 'vite';

router: path.resolve(__dirname, 'src/router.tsx'),
'router-v5': path.resolve(__dirname, 'src/router-v5.tsx'),
'router-v6': path.resolve(__dirname, 'src/router-v6.tsx'),
},

@@ -36,2 +38,4 @@ formats: ['cjs', 'es'],

'react-router-dom/',
'react-router-dom/index.js',
'react-router-dom/dist/index.js',
],

@@ -38,0 +42,0 @@ },

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc