one
Version:
One is a new React Framework that makes Vite serve both native and web.
93 lines • 4.46 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_node_module = __toESM(require("node:module"), 1),
import_node_path = __toESM(require("node:path"), 1),
import_tsconfig_paths = __toESM(require("tsconfig-paths"), 1);
function getViteMetroPluginOptions({
projectRoot,
relativeRouterRoot
}) {
const tsconfigPathsConfigLoadResult = import_tsconfig_paths.default.loadConfig(projectRoot);
if (tsconfigPathsConfigLoadResult.resultType === "failed") throw new Error("tsconfigPathsConfigLoadResult.resultType is not success");
const require2 = import_node_module.default.createRequire(projectRoot),
emptyPath = require2.resolve("@vxrn/vite-plugin-metro/empty", {
paths: [projectRoot]
}),
metroEntryPath = require2.resolve("one/metro-entry", {
paths: [projectRoot]
});
return {
defaultConfigOverrides: defaultConfig => ({
...defaultConfig,
resolver: {
...defaultConfig?.resolver,
extraNodeModules: {
...defaultConfig?.resolver?.extraNodeModules,
// "vite-tsconfig-paths" for Metro
...Object.fromEntries(Object.entries(tsconfigPathsConfigLoadResult.paths).map(([k, v]) => {
if (k.endsWith("/*") && v[0]?.endsWith("/*")) {
const key = k.replace(/\/\*$/, "");
let value = v[0].replace(/\/\*$/, "");
return value = import_node_path.default.join(tsconfigPathsConfigLoadResult.absoluteBaseUrl, value), [key, value];
}
}).filter(i => !!i))
},
nodeModulesPaths: tsconfigPathsConfigLoadResult.absoluteBaseUrl ? [
// "vite-tsconfig-paths" for Metro
tsconfigPathsConfigLoadResult.absoluteBaseUrl, ...(defaultConfig?.resolver?.nodeModulesPaths || [])] : defaultConfig?.resolver?.nodeModulesPaths,
resolveRequest: (context, moduleName, platform) => moduleName.endsWith(".css") ? (console.warn(`[one/metro] *.css files are ignored for now, resolving ${moduleName} to empty module.`), {
type: "sourceFile",
filePath: emptyPath
}) : (defaultConfig?.resolver?.resolveRequest || context.resolveRequest)(context, moduleName, platform)
}
}),
babelConfig: {
plugins: [["babel-plugin-module-resolver", {
alias: {
...Object.fromEntries(Object.entries(tsconfigPathsConfigLoadResult.paths).map(([k, v]) => {
const key = k.replace(/\/\*$/, "");
let 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_node_path.default.relative(import_node_path.default.dirname(metroEntryPath), import_node_path.default.join(projectRoot, relativeRouterRoot)),
ONE_ROUTER_ROOT_FOLDER_NAME: relativeRouterRoot
}]]
}
};
}