UNPKG

one

Version:

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

121 lines (120 loc) 6.54 kB
import module from "module"; import path from "path"; import mm from "micromatch"; import tsconfigPaths from "tsconfig-paths"; import { API_ROUTE_GLOB_PATTERN, ROUTE_NATIVE_EXCLUSION_GLOB_PATTERNS } from "../router/glob-patterns.native.js"; function getViteMetroPluginOptions(param) { var { projectRoot, relativeRouterRoot, ignoredRouteFiles, userDefaultConfigOverrides, setupFile } = param, tsconfigPathsConfigLoadResult = tsconfigPaths.loadConfig(projectRoot); if (tsconfigPathsConfigLoadResult.resultType === "failed") throw new Error("tsconfigPathsConfigLoadResult.resultType is not success"); var require2 = module.createRequire(projectRoot), emptyPath = require2.resolve("@vxrn/vite-plugin-metro/empty", { paths: [projectRoot] }), metroEntryPath = require2.resolve("one/metro-entry", { paths: [projectRoot] }), routerRequireContextRegexString = function () { var excludeRes = [...(ignoredRouteFiles || []).map(function (pattern) { return mm.makeRe(pattern); }), ...ROUTE_NATIVE_EXCLUSION_GLOB_PATTERNS.map(function (pattern) { return mm.makeRe(pattern); }), mm.makeRe(API_ROUTE_GLOB_PATTERN)], supportedRegexMustStartWith = String.raw`^(?:(?:^|\/|(?:(?:(?!(?:^|\/)\.).)*?)\/)(?!\.)(?=.)[^/]*?`, supportedRegexMustEndWith = String.raw`)$`, negativeLookaheadGroups = excludeRes.map(function (re, i) { var reSource = re.source; if (!(reSource.startsWith(supportedRegexMustStartWith) && reSource.endsWith(supportedRegexMustEndWith))) { var ignoredRouteFile = ignoredRouteFiles?.[i]; throw ignoredRouteFile ? new Error(`[one/metro] ignoredRouteFile pattern "${ignoredRouteFile}" is not supported. We cannot process the corresponding regex "${reSource}" for now.`) : 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, config = { ...defaultConfig, resolver: { ...defaultConfig?.resolver, extraNodeModules: { ...(defaultConfig == null || (_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_resolver1 = defaultConfig.resolver) === null || _defaultConfig_resolver1 === void 0 ? void 0 : _defaultConfig_resolver1.nodeModulesPaths) || [])] : defaultConfig == null || (_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 }; var defaultResolveRequest = (defaultConfig == null || (_defaultConfig_resolver3 = defaultConfig.resolver) === null || _defaultConfig_resolver3 === void 0 ? void 0 : _defaultConfig_resolver3.resolveRequest) || context.resolveRequest, res = defaultResolveRequest(context, moduleName, platform); return res; } } }; return typeof userDefaultConfigOverrides == "function" && (config = userDefaultConfigOverrides(config)), config; }, babelConfig: { plugins: [ // 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, key = function () { return k.endsWith("/*") ? k.replace(/\/\*$/, "") : `${k}$`; }(), value = v[0].replace(/\/\*$/, ""); return value.startsWith("./") || (value = `./${value}`), [key, value]; })) }], ["one/babel-plugin-one-router-metro", { ONE_ROUTER_APP_ROOT_RELATIVE_TO_ENTRY: path.relative(path.dirname(metroEntryPath), path.join(projectRoot, relativeRouterRoot)), ONE_ROUTER_ROOT_FOLDER_NAME: relativeRouterRoot, ONE_ROUTER_REQUIRE_CONTEXT_REGEX_STRING: routerRequireContextRegexString, ONE_SETUP_FILE_NATIVE: function () { if (setupFile) { var nativeSetupFile = typeof setupFile == "string" ? setupFile : setupFile.native || setupFile.ios || setupFile.android; if (nativeSetupFile) return path.relative(path.dirname(metroEntryPath), path.join(projectRoot, nativeSetupFile)); } }() }]] } }; } export { getViteMetroPluginOptions }; //# sourceMappingURL=getViteMetroPluginOptions.native.js.map