UNPKG

@builder.io/dev-tools

Version:

Builder.io Visual CMS Devtools

62 lines (61 loc) 1.96 kB
import { createRequire } from 'module'; const require = createRequire(import.meta.url); import * as remixBuild from "@remix-run/dev/server-build"; import * as React from "react"; const assets = remixBuild.assets; const assetsBuildDirectory = remixBuild.assetsBuildDirectory; const entry = remixBuild.entry; const remixRoutes = remixBuild.routes; const future = remixBuild.future; const publicPath = remixBuild.publicPath; const RemixRootApp = remixRoutes.root.module.default; const devToolsServerUrl = typeof process !== "undefined" && process.env.BUILDER_REMIX_DEVTOOLS_URL ? process.env.BUILDER_REMIX_DEVTOOLS_URL : `http://localhost:5273/`; const BuilderDevToolsScript = process.env.NODE_ENV !== "development" ? () => null : function BuilderDevToolsScript2() { const url = new URL(`/~builder-dev-tools.js`, devToolsServerUrl); let c = `/* Builder Devtools (Remix) */ `; c += `if (typeof document !== "undefined" && typeof window !== "undefined" && !window.__builderDevTools) { `; c += ` window.__builderDevTools = true; `; c += ` import(${JSON.stringify(url)}).catch(e => console.error(e)); `; c += `} `; return React.createElement("script", { suppressHydrationWarning: true, type: "module", dangerouslySetInnerHTML: { __html: c } }); }; const BuilderRootApp = () => { const remixRoot = RemixRootApp(); const remixRootProps = remixRoot.props; const remixRootChildren = Array.isArray(remixRootProps.children) ? remixRootProps.children : [remixRootProps.children]; return { ...remixRoot, props: { ...remixRootProps, children: [...remixRootChildren, BuilderDevToolsScript()] } }; }; const routes = process.env.NODE_ENV !== "development" ? remixRoutes : { ...remixRoutes, root: { ...remixRoutes.root, module: { ...remixRoutes.root.module, default: BuilderRootApp } } }; export { assets, assetsBuildDirectory, entry, future, publicPath, routes };