one
Version:
One is a new React Framework that makes Vite serve both native and web.
75 lines (74 loc) • 3.87 kB
JavaScript
import module from "node:module";
import path from "node:path";
import tsconfigPaths from "tsconfig-paths";
function getViteMetroPluginOptions(param) {
var {
projectRoot,
relativeRouterRoot
} = 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]
});
return {
defaultConfigOverrides: function (defaultConfig) {
var _defaultConfig_resolver, _defaultConfig_resolver1, _defaultConfig_resolver2;
return {
...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
...Object.fromEntries(Object.entries(tsconfigPathsConfigLoadResult.paths).map(function (param2) {
var [k, v] = param2,
_v_;
if (k.endsWith("/*") && !((_v_ = v[0]) === null || _v_ === void 0) && _v_.endsWith("/*")) {
var key = k.replace(/\/\*$/, ""),
value = v[0].replace(/\/\*$/, "");
return value = path.join(tsconfigPathsConfigLoadResult.absoluteBaseUrl, value), [key, value];
}
}).filter(function (i) {
return !!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
};
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;
}
}
};
},
babelConfig: {
plugins: [["babel-plugin-module-resolver", {
alias: {
...Object.fromEntries(Object.entries(tsconfigPathsConfigLoadResult.paths).map(function (param2) {
var [k, v] = param2,
key = k.replace(/\/\*$/, ""),
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
}]]
}
};
}
export { getViteMetroPluginOptions };
//# sourceMappingURL=getViteMetroPluginOptions.native.js.map