one
Version:
One is a new React Framework that makes Vite serve both native and web.
158 lines (156 loc) • 8.51 kB
JavaScript
;
var __create = Object.create;
var __defProp = Object.defineProperty;
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
var __getOwnPropNames = Object.getOwnPropertyNames;
var __getProtoOf = Object.getPrototypeOf,
__hasOwnProp = Object.prototype.hasOwnProperty;
var __export = (target, all) => {
for (var name in all) __defProp(target, name, {
get: all[name],
enumerable: !0
});
},
__copyProps = (to, from, except, desc) => {
if (from && typeof from == "object" || typeof from == "function") for (let key of __getOwnPropNames(from)) !__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: !0
}) : target, mod)),
__toCommonJS = mod => __copyProps(__defProp({}, "__esModule", {
value: !0
}), mod);
var getViteMetroPluginOptions_exports = {};
__export(getViteMetroPluginOptions_exports, {
getViteMetroPluginOptions: () => getViteMetroPluginOptions
});
module.exports = __toCommonJS(getViteMetroPluginOptions_exports);
var import_module = __toESM(require("module"), 1),
import_path = __toESM(require("path"), 1),
import_micromatch = __toESM(require("micromatch"), 1),
import_tsconfig_paths = __toESM(require("tsconfig-paths"), 1),
import_glob_patterns = require("../router/glob-patterns.native.js");
function getViteMetroPluginOptions(param) {
var {
projectRoot,
relativeRouterRoot,
ignoredRouteFiles,
userDefaultConfigOverrides,
setupFile
} = param,
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),
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 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)],
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 console.warn(`[one/metro] *.css files are ignored for now, resolving ${moduleName} to empty module.`), {
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: 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) {
var nativeSetupFile = typeof setupFile == "string" ? setupFile : setupFile.native || setupFile.ios || setupFile.android;
if (nativeSetupFile) return import_path.default.relative(import_path.default.dirname(metroEntryPath), import_path.default.join(projectRoot, nativeSetupFile));
}
}()
}]]
}
};
}
//# sourceMappingURL=getViteMetroPluginOptions.native.js.map