one
Version:
One is a new React Framework that makes Vite serve both native and web.
165 lines (164 loc) • 8.34 kB
JavaScript
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;
var tsconfigPathsConfigLoadResult = tsconfigPaths.loadConfig(projectRoot);
if (tsconfigPathsConfigLoadResult.resultType === "failed") {
throw new Error("tsconfigPathsConfigLoadResult.resultType is not success");
}
var require2 = module.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 mm.makeRe(pattern);
}), ...ROUTE_NATIVE_EXCLUSION_GLOB_PATTERNS.map(function (pattern) {
return mm.makeRe(pattern);
}), mm.makeRe(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: 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) return void 0;
var nativeSetupFile = typeof setupFile === "string" ? setupFile : setupFile.native || setupFile.ios || setupFile.android;
if (!nativeSetupFile) return void 0;
return path.relative(path.dirname(metroEntryPath), path.join(projectRoot, nativeSetupFile));
}()
}],
// inline ONE_SERVER_URL so native prod bundles know where to fetch loaders
"one/babel-plugin-inline-one-server-url"]
}
};
}
export { getViteMetroPluginOptions };
//# sourceMappingURL=getViteMetroPluginOptions.native.js.map