UNPKG

one

Version:

One is a new React Framework that makes Vite serve both native and web.

204 lines (202 loc) 10.2 kB
"use strict"; var __create = Object.create; var __defProp = Object.defineProperty; var __getOwnPropDesc = Object.getOwnPropertyDescriptor; var __getOwnPropNames = Object.getOwnPropertyNames; var __getProtoOf = Object.getPrototypeOf; var __hasOwnProp = Object.prototype.hasOwnProperty; var __export = (target, all) => { for (var name in all) __defProp(target, name, { get: all[name], enumerable: true }); }; var __copyProps = (to, from, except, desc) => { if (from && typeof from === "object" || typeof from === "function") { for (let key of __getOwnPropNames(from)) if (!__hasOwnProp.call(to, key) && key !== except) __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable }); } return to; }; var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps( // If the importer is in node compatibility mode or this is not an ESM // file that has been converted to a CommonJS file using a Babel- // compatible transform (i.e. "__esModule" has not been set), then set // "default" to the CommonJS "module.exports" for node compatibility. isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target, mod)); var __toCommonJS = mod => __copyProps(__defProp({}, "__esModule", { value: true }), mod); var getViteMetroPluginOptions_exports = {}; __export(getViteMetroPluginOptions_exports, { getViteMetroPluginOptions: () => getViteMetroPluginOptions }); module.exports = __toCommonJS(getViteMetroPluginOptions_exports); var import_module = __toESM(require("module"), 1); var import_path = __toESM(require("path"), 1); var import_micromatch = __toESM(require("micromatch"), 1); var import_tsconfig_paths = __toESM(require("tsconfig-paths"), 1); var import_glob_patterns = require("../router/glob-patterns.native.js"); function getViteMetroPluginOptions(param) { var { projectRoot, relativeRouterRoot, ignoredRouteFiles, userDefaultConfigOverrides, setupFile } = param; var tsconfigPathsConfigLoadResult = import_tsconfig_paths.default.loadConfig(projectRoot); if (tsconfigPathsConfigLoadResult.resultType === "failed") { throw new Error("tsconfigPathsConfigLoadResult.resultType is not success"); } var require2 = import_module.default.createRequire(projectRoot); var emptyPath = require2.resolve("@vxrn/vite-plugin-metro/empty", { paths: [projectRoot] }); var metroEntryPath = require2.resolve("one/metro-entry", { paths: [projectRoot] }); var routerRequireContextRegexString = function () { var excludeRes = [...(ignoredRouteFiles || []).map(function (pattern) { return import_micromatch.default.makeRe(pattern); }), ...import_glob_patterns.ROUTE_NATIVE_EXCLUSION_GLOB_PATTERNS.map(function (pattern) { return import_micromatch.default.makeRe(pattern); }), import_micromatch.default.makeRe(import_glob_patterns.API_ROUTE_GLOB_PATTERN)]; var supportedRegexMustStartWith = String.raw`^(?:(?:^|\/|(?:(?:(?!(?:^|\/)\.).)*?)\/)(?!\.)(?=.)[^/]*?`; var supportedRegexMustEndWith = String.raw`)$`; var negativeLookaheadGroups = excludeRes.map(function (re, i) { var reSource = re.source; if (!(reSource.startsWith(supportedRegexMustStartWith) && reSource.endsWith(supportedRegexMustEndWith))) { var ignoredRouteFile = ignoredRouteFiles === null || ignoredRouteFiles === void 0 ? void 0 : ignoredRouteFiles[i]; if (ignoredRouteFile) { throw new Error(`[one/metro] ignoredRouteFile pattern "${ignoredRouteFile}" is not supported. We cannot process the corresponding regex "${reSource}" for now.`); } throw new Error(`Unsupported regex "${reSource}" in "ignoredRouteFiles".`); } var rePart = reSource.slice(supportedRegexMustStartWith.length, reSource.length - supportedRegexMustEndWith.length); return String.raw`(?:.*${rePart})`; }); return String.raw`^(?:\.\/)(?!${negativeLookaheadGroups.join("|")}$).*\.tsx?$`; }(); return { defaultConfigOverrides: function (defaultConfig) { var _defaultConfig_resolver, _defaultConfig_resolver1, _defaultConfig_resolver2; var config = { ...defaultConfig, resolver: { ...(defaultConfig === null || defaultConfig === void 0 ? void 0 : defaultConfig.resolver), extraNodeModules: { ...(defaultConfig === null || defaultConfig === void 0 ? void 0 : (_defaultConfig_resolver = defaultConfig.resolver) === null || _defaultConfig_resolver === void 0 ? void 0 : _defaultConfig_resolver.extraNodeModules) }, // "vite-tsconfig-paths" for Metro // Commenting out since we are using babel-plugin-module-resolver alias instead // ...Object.fromEntries( // Object.entries(tsconfigPathsConfigLoadResult.paths) // .map(([k, v]) => { // if (k.endsWith('/*') && v[0]?.endsWith('/*')) { // const key = k.replace(/\/\*$/, '') // let value = v[0].replace(/\/\*$/, '') // value = path.join(tsconfigPathsConfigLoadResult.absoluteBaseUrl, value) // return [key, value] // } // }) // .filter((i): i is NonNullable<typeof i> => !!i) // ), nodeModulesPaths: tsconfigPathsConfigLoadResult.absoluteBaseUrl ? [ // "vite-tsconfig-paths" for Metro tsconfigPathsConfigLoadResult.absoluteBaseUrl, ...((defaultConfig === null || defaultConfig === void 0 ? void 0 : (_defaultConfig_resolver1 = defaultConfig.resolver) === null || _defaultConfig_resolver1 === void 0 ? void 0 : _defaultConfig_resolver1.nodeModulesPaths) || [])] : defaultConfig === null || defaultConfig === void 0 ? void 0 : (_defaultConfig_resolver2 = defaultConfig.resolver) === null || _defaultConfig_resolver2 === void 0 ? void 0 : _defaultConfig_resolver2.nodeModulesPaths, resolveRequest: function (context, moduleName, platform) { var _defaultConfig_resolver3; if (moduleName.endsWith(".css")) { return { type: "sourceFile", filePath: emptyPath }; } if (/_middleware.tsx?$/.test(moduleName)) { return { type: "sourceFile", filePath: emptyPath }; } if (/\.server(\.[jt]sx?)?$/.test(moduleName)) { return { type: "sourceFile", filePath: emptyPath }; } if (moduleName === "react-native-svg") { var _defaultConfig_resolver12; var defaultResolveRequest = (defaultConfig === null || defaultConfig === void 0 ? void 0 : (_defaultConfig_resolver12 = defaultConfig.resolver) === null || _defaultConfig_resolver12 === void 0 ? void 0 : _defaultConfig_resolver12.resolveRequest) || context.resolveRequest; var res = defaultResolveRequest(context, moduleName, platform); if (res && "filePath" in res && res.filePath.includes("/src/index.ts")) { return { ...res, filePath: res.filePath.replace("/src/index.ts", "/lib/commonjs/index.js") }; } return res; } var defaultResolveRequest1 = (defaultConfig === null || defaultConfig === void 0 ? void 0 : (_defaultConfig_resolver3 = defaultConfig.resolver) === null || _defaultConfig_resolver3 === void 0 ? void 0 : _defaultConfig_resolver3.resolveRequest) || context.resolveRequest; var res1 = defaultResolveRequest1(context, moduleName, platform); if (res1 && "filePath" in res1 && /\.server\.[jt]sx?$/.test(res1.filePath)) { return { type: "sourceFile", filePath: emptyPath }; } return res1; } } }; if (typeof userDefaultConfigOverrides === "function") { config = userDefaultConfigOverrides(config); } return config; }, babelConfig: { plugins: [ // enforce environment guard imports (server-only, client-only, etc.) "one/babel-plugin-environment-guard", // Remove server-only code (loader, generateStaticParams) from route files // This must run early to prevent server-only imports from being bundled ["one/babel-plugin-remove-server-code", { routerRoot: relativeRouterRoot }], ["babel-plugin-module-resolver", { // "vite-tsconfig-paths" for Metro alias: Object.fromEntries(Object.entries(tsconfigPathsConfigLoadResult.paths).map(function (param2) { var [k, v] = param2; var key = function () { if (k.endsWith("/*")) { return k.replace(/\/\*$/, ""); } return `${k}$`; }(); var value = v[0].replace(/\/\*$/, ""); if (!value.startsWith("./")) { value = `./${value}`; } return [key, value]; })) }], ["one/babel-plugin-one-router-metro", { ONE_ROUTER_APP_ROOT_RELATIVE_TO_ENTRY: import_path.default.relative(import_path.default.dirname(metroEntryPath), import_path.default.join(projectRoot, relativeRouterRoot)), ONE_ROUTER_ROOT_FOLDER_NAME: relativeRouterRoot, ONE_ROUTER_REQUIRE_CONTEXT_REGEX_STRING: routerRequireContextRegexString, ONE_SETUP_FILE_NATIVE: function () { if (!setupFile) return void 0; var nativeSetupFile = typeof setupFile === "string" ? setupFile : setupFile.native || setupFile.ios || setupFile.android; if (!nativeSetupFile) return void 0; return import_path.default.relative(import_path.default.dirname(metroEntryPath), import_path.default.join(projectRoot, nativeSetupFile)); }() }], // inline ONE_SERVER_URL so native prod bundles know where to fetch loaders "one/babel-plugin-inline-one-server-url"] } }; } //# sourceMappingURL=getViteMetroPluginOptions.native.js.map