@nx/react-native
Version:
213 lines (212 loc) • 8.64 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.reactNativeLibraryGenerator = reactNativeLibraryGenerator;
exports.reactNativeLibraryGeneratorInternal = reactNativeLibraryGeneratorInternal;
const devkit_1 = require("@nx/devkit");
const js_1 = require("@nx/js");
const init_1 = require("../init/init");
const add_linting_1 = require("../../utils/add-linting");
const add_jest_1 = require("../../utils/add-jest");
const component_1 = require("../component/component");
const normalize_options_1 = require("./lib/normalize-options");
const ensure_dependencies_1 = require("../../utils/ensure-dependencies");
const log_show_project_command_1 = require("@nx/devkit/src/utils/log-show-project-command");
const ts_solution_setup_1 = require("@nx/js/src/utils/typescript/ts-solution-setup");
const sort_fields_1 = require("@nx/js/src/utils/package-json/sort-fields");
const add_rollup_build_target_1 = require("@nx/react/src/generators/library/lib/add-rollup-build-target");
const artifact_name_and_directory_utils_1 = require("@nx/devkit/src/generators/artifact-name-and-directory-utils");
const path_1 = require("path");
const versions_1 = require("../../utils/versions");
async function reactNativeLibraryGenerator(host, schema) {
return await reactNativeLibraryGeneratorInternal(host, {
addPlugin: false,
useProjectJson: true,
...schema,
});
}
async function reactNativeLibraryGeneratorInternal(host, schema) {
const tasks = [];
const jsInitTask = await (0, js_1.initGenerator)(host, {
...schema,
skipFormat: true,
});
tasks.push(jsInitTask);
const options = await (0, normalize_options_1.normalizeOptions)(host, schema);
if (options.publishable === true && !schema.importPath) {
throw new Error(`For publishable libs you have to provide a proper "--importPath" which needs to be a valid npm package name (e.g. my-awesome-lib or @myorg/my-lib)`);
}
const initTask = await (0, init_1.default)(host, { ...options, skipFormat: true });
tasks.push(initTask);
if (!options.skipPackageJson) {
tasks.push((0, ensure_dependencies_1.ensureDependencies)(host));
}
createFiles(host, options);
if (options.isUsingTsSolutionConfig) {
await (0, ts_solution_setup_1.addProjectToTsSolutionWorkspace)(host, options.projectRoot);
}
const addProjectTask = await addProject(host, options);
if (addProjectTask) {
tasks.push(addProjectTask);
}
const lintTask = await (0, add_linting_1.addLinting)(host, {
...options,
projectName: options.name,
tsConfigPaths: [
(0, devkit_1.joinPathFragments)(options.projectRoot, 'tsconfig.lib.json'),
],
});
tasks.push(lintTask);
const jestTask = await (0, add_jest_1.addJest)(host, options.unitTestRunner, options.name, options.projectRoot, options.js, options.skipPackageJson, options.addPlugin, 'tsconfig.lib.json');
tasks.push(jestTask);
const relativeCwd = (0, artifact_name_and_directory_utils_1.getRelativeCwd)();
const path = (0, devkit_1.joinPathFragments)(options.projectRoot, 'src/lib', options.fileName);
const componentTask = await (0, component_1.default)(host, {
path: relativeCwd ? (0, path_1.relative)(relativeCwd, path) : path,
skipTests: options.unitTestRunner === 'none',
export: true,
skipFormat: true,
js: options.js,
});
tasks.push(() => componentTask);
if (!options.skipTsConfig && !options.isUsingTsSolutionConfig) {
(0, js_1.addTsConfigPath)(host, options.importPath, [
(0, devkit_1.joinPathFragments)(options.projectRoot, './src', 'index.' + (options.js ? 'js' : 'ts')),
]);
}
(0, ts_solution_setup_1.updateTsconfigFiles)(host, options.projectRoot, 'tsconfig.lib.json', {
jsx: 'react-jsx',
module: 'esnext',
moduleResolution: 'bundler',
}, options.linter === 'eslint'
? ['eslint.config.js', 'eslint.config.cjs', 'eslint.config.mjs']
: undefined);
(0, sort_fields_1.sortPackageJsonFields)(host, options.projectRoot);
if (!options.skipFormat) {
await (0, devkit_1.formatFiles)(host);
}
// Always run install to link packages.
if (options.isUsingTsSolutionConfig) {
tasks.push(() => (0, devkit_1.installPackagesTask)(host, true));
}
tasks.push(() => {
(0, log_show_project_command_1.logShowProjectCommand)(options.name);
});
return (0, devkit_1.runTasksInSerial)(...tasks);
}
async function addProject(host, options) {
const project = {
root: options.projectRoot,
sourceRoot: (0, devkit_1.joinPathFragments)(options.projectRoot, 'src'),
projectType: 'library',
tags: options.parsedTags,
targets: {},
};
let packageJson = {
name: options.importPath,
version: '0.0.1',
};
if (!options.useProjectJson) {
packageJson = {
...packageJson,
...determineEntryFields(options),
files: options.publishable ? ['dist', '!**/*.tsbuildinfo'] : undefined,
peerDependencies: {
react: versions_1.reactVersion,
'react-native': versions_1.reactNativeVersion,
},
};
if (options.name !== options.importPath) {
packageJson.nx = { name: options.name };
}
if (options.parsedTags?.length) {
packageJson.nx ??= {};
packageJson.nx.tags = options.parsedTags;
}
}
else {
(0, devkit_1.addProjectConfiguration)(host, options.name, project);
}
if (!options.useProjectJson ||
options.isUsingTsSolutionConfig ||
options.publishable ||
options.buildable) {
(0, devkit_1.writeJson)(host, (0, devkit_1.joinPathFragments)(options.projectRoot, 'package.json'), packageJson);
}
if (options.publishable || options.buildable) {
const external = new Set([
'react/jsx-runtime',
'react-native',
'react',
'react-dom',
]);
const rollupTask = await (0, add_rollup_build_target_1.addRollupBuildTarget)(host, {
...options,
format: ['cjs', 'esm'],
style: 'none',
js: options.js,
skipFormat: true,
}, external);
(0, devkit_1.updateJson)(host, `${options.projectRoot}/package.json`, (json) => {
json.peerDependencies = {
...json.peerDependencies,
react: versions_1.reactVersion,
'react-native': versions_1.reactNativeVersion,
};
return json;
});
return rollupTask;
}
return () => { };
}
function updateTsConfig(tree, options) {
if (options.isUsingTsSolutionConfig) {
return;
}
(0, devkit_1.updateJson)(tree, (0, devkit_1.joinPathFragments)(options.projectRoot, 'tsconfig.json'), (json) => {
if (options.strict) {
json.compilerOptions = {
...json.compilerOptions,
forceConsistentCasingInFileNames: true,
strict: true,
noImplicitReturns: true,
noFallthroughCasesInSwitch: true,
};
}
return json;
});
}
function createFiles(host, options) {
(0, devkit_1.generateFiles)(host, (0, devkit_1.joinPathFragments)(__dirname, './files/lib'), options.projectRoot, {
...options,
...(0, devkit_1.names)(options.name),
offsetFromRoot: (0, devkit_1.offsetFromRoot)(options.projectRoot),
rootTsConfigPath: (0, js_1.getRelativePathToRootTsConfig)(host, options.projectRoot),
});
if (options.js) {
(0, devkit_1.toJS)(host);
}
updateTsConfig(host, options);
}
function determineEntryFields(options) {
if (options.buildable ||
options.publishable ||
!options.isUsingTsSolutionConfig) {
// For buildable libraries, the entries are configured by the bundler (i.e. Rollup).
return undefined;
}
return {
main: options.js ? './src/index.js' : './src/index.ts',
types: options.js ? './src/index.js' : './src/index.ts',
exports: {
'.': options.js
? './src/index.js'
: {
types: './src/index.ts',
import: './src/index.ts',
default: './src/index.ts',
},
'./package.json': './package.json',
},
};
}
exports.default = reactNativeLibraryGenerator;