one
Version:
One is a new React Framework that makes Vite serve both native and web.
99 lines (95 loc) • 3.9 kB
JavaScript
import fs from "fs";
import path from "path";
import { loadUserOneOptions } from "../vite/loadConfig.native.js";
import { getRouterRootFromOneOptions } from "../utils/getRouterRootFromOneOptions.native.js";
function _type_of(obj) {
"@swc/helpers - typeof";
return obj && typeof Symbol < "u" && obj.constructor === Symbol ? "symbol" : typeof obj;
}
var GENERATED_COMMENT = `// auto-generated by "one eas-prebuild" - do not edit manually
// regenerate with: npx one eas-prebuild
`;
async function run() {
var _oneOptions_react,
root = process.cwd();
console.info("one eas-prebuild: generating EAS build configs..."), process.env.IS_VXRN_CLI = "true";
var {
oneOptions
} = await loadUserOneOptions("build", !0),
routerRoot = getRouterRootFromOneOptions(oneOptions),
setupFile = oneOptions.setupFile,
reactCompiler = (_oneOptions_react = oneOptions.react) === null || _oneOptions_react === void 0 ? void 0 : _oneOptions_react.compiler,
useReactCompiler = reactCompiler === !0 || reactCompiler === "native" || (typeof reactCompiler > "u" ? "undefined" : _type_of(reactCompiler)) === "object",
hasReanimated = checkDependency(root, "react-native-reanimated"),
babelConfig = generateBabelConfig({
routerRoot,
setupFile,
useReactCompiler,
hasReanimated
}),
babelPath = path.join(root, "babel.config.cjs");
fs.writeFileSync(babelPath, babelConfig), console.info(` \u2713 wrote ${path.relative(root, babelPath)}`);
var metroConfig = generateMetroConfig(),
metroPath = path.join(root, "metro.config.cjs");
fs.writeFileSync(metroPath, metroConfig), console.info(` \u2713 wrote ${path.relative(root, metroPath)}`), console.info("one eas-prebuild: done");
}
function checkDependency(root, pkg) {
try {
var _pkgJson_dependencies,
_pkgJson_devDependencies,
pkgJsonPath = path.join(root, "package.json"),
pkgJson = JSON.parse(fs.readFileSync(pkgJsonPath, "utf-8"));
return !!(!((_pkgJson_dependencies = pkgJson.dependencies) === null || _pkgJson_dependencies === void 0) && _pkgJson_dependencies[pkg] || !((_pkgJson_devDependencies = pkgJson.devDependencies) === null || _pkgJson_devDependencies === void 0) && _pkgJson_devDependencies[pkg]);
} catch {
return !1;
}
}
function generateBabelConfig(param) {
var {
routerRoot,
setupFile,
useReactCompiler,
hasReanimated
} = param,
setupFileArg = setupFile ? typeof setupFile == "string" ? `'${setupFile}'` : `{ ${Object.entries(setupFile).filter(function (param2) {
var [, v] = param2;
return v;
}).map(function (param2) {
var [k, v] = param2;
return `${k}: '${v}'`;
}).join(", ")} }` : "undefined",
prePlugins = [],
postPlugins = [];
useReactCompiler && prePlugins.push("'babel-plugin-react-compiler'"), hasReanimated && postPlugins.push("'react-native-reanimated/plugin'");
var pluginsCode = function () {
if (!prePlugins.length && !postPlugins.length) return "options.babelConfig?.plugins || []";
var parts = [];
return prePlugins.length && parts.push(...prePlugins), parts.push("...(options.babelConfig?.plugins || [])"), postPlugins.length && parts.push(...postPlugins), `[
${parts.join(`,
`)},
]`;
}();
return `${GENERATED_COMMENT}
const { getViteMetroPluginOptions } = require('one/getViteMetroPluginOptions')
const options = getViteMetroPluginOptions({
projectRoot: __dirname,
relativeRouterRoot: '${routerRoot}',
setupFile: ${setupFileArg},
})
module.exports = function (api) {
api.cache(true)
return {
presets: ['babel-preset-expo'],
plugins: ${pluginsCode},
}
}
`;
}
function generateMetroConfig() {
return `${GENERATED_COMMENT}
const { getDefaultConfig } = require('one/metro-eas')
module.exports = getDefaultConfig(__dirname)
`;
}
export { run };
//# sourceMappingURL=easPrebuild.native.js.map