create-react-native-library 0.62.0 → 0.62.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bin/create-react-native-library +1 -1
- package/lib/package.json +69 -0
- package/lib/src/constants.d.ts +5 -0
- package/lib/src/constants.js +6 -0
- package/lib/src/constants.js.map +1 -0
- package/lib/src/exampleApp/dependencies.d.ts +8 -0
- package/lib/src/exampleApp/dependencies.js +34 -0
- package/lib/src/exampleApp/dependencies.js.map +1 -0
- package/lib/src/exampleApp/generateExampleApp.d.ts +6 -0
- package/lib/src/exampleApp/generateExampleApp.js +309 -0
- package/lib/src/exampleApp/generateExampleApp.js.map +1 -0
- package/lib/src/index.d.ts +1 -0
- package/lib/src/index.js +134 -0
- package/lib/src/index.js.map +1 -0
- package/lib/src/inform.d.ts +10 -0
- package/lib/src/inform.js +56 -0
- package/lib/src/inform.js.map +1 -0
- package/lib/src/prompt.d.ts +125 -0
- package/lib/src/prompt.js +325 -0
- package/lib/src/prompt.js.map +1 -0
- package/lib/src/template.d.ts +44 -0
- package/lib/src/template.js +258 -0
- package/lib/src/template.js.map +1 -0
- package/lib/src/utils/assert.d.ts +1 -0
- package/lib/src/utils/assert.js +17 -0
- package/lib/src/utils/assert.js.map +1 -0
- package/lib/src/utils/configureTools.d.ts +43 -0
- package/lib/src/utils/configureTools.js +122 -0
- package/lib/src/utils/configureTools.js.map +1 -0
- package/lib/src/utils/createMetadata.d.ts +4 -0
- package/lib/src/utils/createMetadata.js +23 -0
- package/lib/src/utils/createMetadata.js.map +1 -0
- package/lib/src/utils/initialCommit.d.ts +1 -0
- package/lib/src/utils/initialCommit.js +24 -0
- package/lib/src/utils/initialCommit.js.map +1 -0
- package/lib/src/utils/local.d.ts +5 -0
- package/lib/src/utils/local.js +49 -0
- package/lib/src/utils/local.js.map +1 -0
- package/lib/src/utils/packageManager.d.ts +1 -0
- package/lib/src/utils/packageManager.js +8 -0
- package/lib/src/utils/packageManager.js.map +1 -0
- package/lib/src/utils/resolveNpmPackageVersion.d.ts +1 -0
- package/lib/src/utils/resolveNpmPackageVersion.js +20 -0
- package/lib/src/utils/resolveNpmPackageVersion.js.map +1 -0
- package/lib/src/utils/sortObjectKeys.d.ts +1 -0
- package/lib/src/utils/sortObjectKeys.js +9 -0
- package/lib/src/utils/sortObjectKeys.js.map +1 -0
- package/lib/src/utils/spawn.d.ts +2 -0
- package/lib/src/utils/spawn.js +26 -0
- package/lib/src/utils/spawn.js.map +1 -0
- package/package.json +12 -10
- package/templates/common/$package.json +1 -1
- package/templates/common/tsconfig.json +0 -2
- package/templates/tools/eslint/~package.json +3 -3
- package/templates/tools/jest/~package.json +2 -2
- package/templates/tools/lefthook/~package.json +3 -3
- package/templates/tools/release-it/~package.json +2 -2
- package/templates/tools/turborepo/~package.json +1 -1
- package/templates/tools/vite/example/~package.json +1 -1
- package/templates/tools/vite/~package.json +1 -1
- package/lib/constants.js +0 -12
- package/lib/constants.js.map +0 -1
- package/lib/exampleApp/dependencies.js +0 -34
- package/lib/exampleApp/dependencies.js.map +0 -1
- package/lib/exampleApp/generateExampleApp.js +0 -249
- package/lib/exampleApp/generateExampleApp.js.map +0 -1
- package/lib/index.js +0 -130
- package/lib/index.js.map +0 -1
- package/lib/inform.js +0 -72
- package/lib/inform.js.map +0 -1
- package/lib/prompt.js +0 -305
- package/lib/prompt.js.map +0 -1
- package/lib/template.js +0 -258
- package/lib/template.js.map +0 -1
- package/lib/utils/assert.js +0 -22
- package/lib/utils/assert.js.map +0 -1
- package/lib/utils/configureTools.js +0 -137
- package/lib/utils/configureTools.js.map +0 -1
- package/lib/utils/createMetadata.js +0 -17
- package/lib/utils/createMetadata.js.map +0 -1
- package/lib/utils/initialCommit.js +0 -37
- package/lib/utils/initialCommit.js.map +0 -1
- package/lib/utils/local.js +0 -55
- package/lib/utils/local.js.map +0 -1
- package/lib/utils/packageManager.js +0 -13
- package/lib/utils/packageManager.js.map +0 -1
- package/lib/utils/resolveNpmPackageVersion.js +0 -22
- package/lib/utils/resolveNpmPackageVersion.js.map +0 -1
- package/lib/utils/sortObjectKeys.js +0 -15
- package/lib/utils/sortObjectKeys.js.map +0 -1
- package/lib/utils/spawn.js +0 -33
- package/lib/utils/spawn.js.map +0 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"resolveNpmPackageVersion.js","sourceRoot":"","sources":["../../../src/utils/resolveNpmPackageVersion.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAC;AAEnC,MAAM,CAAC,KAAK,UAAU,wBAAwB,CAC5C,IAAY,EACZ,QAAgB,EAChB,UAAkB,IAAI;IAEtB,IAAI,MAAc,CAAC;IAEnB,IAAI,CAAC;QACH,MAAM,OAAO,GAAG,KAAK,CAAC,KAAK,EAAE,CAAC,MAAM,EAAE,IAAI,EAAE,kBAAkB,CAAC,CAAC,CAAC;QAEjE,MAAM,GAAG,MAAM,OAAO,CAAC,IAAI,CAAC;YAC1B,IAAI,OAAO,CAAS,CAAC,OAAO,EAAE,EAAE;gBAC9B,UAAU,CAAC,GAAG,EAAE;oBACd,OAAO,CAAC,QAAQ,CAAC,CAAC;gBACpB,CAAC,EAAE,OAAO,CAAC,CAAC;YACd,CAAC,CAAC;YACF,OAAO;SACR,CAAC,CAAC;IACL,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;QACX,MAAM,GAAG,QAAQ,CAAC;IACpB,CAAC;IAED,OAAO,MAAM,CAAC;AAChB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export default function sortObjectKeys<T extends Record<string, unknown>>(obj: T): T;
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export default function sortObjectKeys(obj) {
|
|
2
|
+
// eslint-disable-next-line @typescript-eslint/require-array-sort-compare
|
|
3
|
+
return Object.keys(obj).sort().reduce((acc, key) => {
|
|
4
|
+
acc[key] = obj[key];
|
|
5
|
+
return acc;
|
|
6
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-type-assertion
|
|
7
|
+
}, {});
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=sortObjectKeys.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sortObjectKeys.js","sourceRoot":"","sources":["../../../src/utils/sortObjectKeys.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,OAAO,UAAU,cAAc,CACpC,GAAM;IAEN,yEAAyE;IACzE,OAAQ,MAAM,CAAC,IAAI,CAAC,GAAG,CAAiB,CAAC,IAAI,EAAE,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE;QAClE,GAAG,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC;QACpB,OAAO,GAAG,CAAC;QACX,uEAAuE;IACzE,CAAC,EAAE,EAAO,CAAC,CAAC;AACd,CAAC"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import crossSpawn from 'cross-spawn';
|
|
2
|
+
export const spawn = async (...args) => {
|
|
3
|
+
return new Promise((resolve, reject) => {
|
|
4
|
+
const child = crossSpawn(...args);
|
|
5
|
+
let stdout = '';
|
|
6
|
+
let stderr = '';
|
|
7
|
+
child.stdout?.setEncoding('utf8');
|
|
8
|
+
child.stdout?.on('data', (data) => {
|
|
9
|
+
stdout += data;
|
|
10
|
+
});
|
|
11
|
+
child.stderr?.setEncoding('utf8');
|
|
12
|
+
child.stderr?.on('data', (data) => {
|
|
13
|
+
stderr += data;
|
|
14
|
+
});
|
|
15
|
+
child.once('error', reject);
|
|
16
|
+
child.once('close', (code) => {
|
|
17
|
+
if (code === 0) {
|
|
18
|
+
resolve(stdout.trim());
|
|
19
|
+
}
|
|
20
|
+
else {
|
|
21
|
+
reject(new Error(stderr.trim()));
|
|
22
|
+
}
|
|
23
|
+
});
|
|
24
|
+
});
|
|
25
|
+
};
|
|
26
|
+
//# sourceMappingURL=spawn.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"spawn.js","sourceRoot":"","sources":["../../../src/utils/spawn.ts"],"names":[],"mappings":"AAAA,OAAO,UAAU,MAAM,aAAa,CAAC;AAErC,MAAM,CAAC,MAAM,KAAK,GAAG,KAAK,EAAE,GAAG,IAAmC,EAAE,EAAE;IACpE,OAAO,IAAI,OAAO,CAAS,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;QAC7C,MAAM,KAAK,GAAG,UAAU,CAAC,GAAG,IAAI,CAAC,CAAC;QAElC,IAAI,MAAM,GAAG,EAAE,CAAC;QAChB,IAAI,MAAM,GAAG,EAAE,CAAC;QAEhB,KAAK,CAAC,MAAM,EAAE,WAAW,CAAC,MAAM,CAAC,CAAC;QAClC,KAAK,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,EAAE,CAAC,IAAY,EAAE,EAAE;YACxC,MAAM,IAAI,IAAI,CAAC;QACjB,CAAC,CAAC,CAAC;QAEH,KAAK,CAAC,MAAM,EAAE,WAAW,CAAC,MAAM,CAAC,CAAC;QAClC,KAAK,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,EAAE,CAAC,IAAY,EAAE,EAAE;YACxC,MAAM,IAAI,IAAI,CAAC;QACjB,CAAC,CAAC,CAAC;QAEH,KAAK,CAAC,IAAI,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;QAC5B,KAAK,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,IAAI,EAAE,EAAE;YAC3B,IAAI,IAAI,KAAK,CAAC,EAAE,CAAC;gBACf,OAAO,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC,CAAC;YACzB,CAAC;iBAAM,CAAC;gBACN,MAAM,CAAC,IAAI,KAAK,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;YACnC,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "create-react-native-library",
|
|
3
|
-
"version": "0.62.
|
|
3
|
+
"version": "0.62.1",
|
|
4
4
|
"description": "CLI to scaffold React Native libraries",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"react-native",
|
|
@@ -23,7 +23,10 @@
|
|
|
23
23
|
"url": "https://github.com/callstack/react-native-builder-bob/issues"
|
|
24
24
|
},
|
|
25
25
|
"homepage": "https://oss.callstack.com/react-native-builder-bob/create",
|
|
26
|
-
"
|
|
26
|
+
"type": "module",
|
|
27
|
+
"exports": {
|
|
28
|
+
".": "./lib/src/index.js"
|
|
29
|
+
},
|
|
27
30
|
"bin": "bin/create-react-native-library",
|
|
28
31
|
"files": [
|
|
29
32
|
"lib",
|
|
@@ -37,7 +40,7 @@
|
|
|
37
40
|
"registry": "https://registry.npmjs.org/"
|
|
38
41
|
},
|
|
39
42
|
"scripts": {
|
|
40
|
-
"prepare": "
|
|
43
|
+
"prepare": "del-cli lib .tsbuildinfo && tsc"
|
|
41
44
|
},
|
|
42
45
|
"dependencies": {
|
|
43
46
|
"cross-spawn": "^7.0.6",
|
|
@@ -48,20 +51,19 @@
|
|
|
48
51
|
"github-username": "^9.0.0",
|
|
49
52
|
"kleur": "^4.1.5",
|
|
50
53
|
"ora": "^9.3.0",
|
|
51
|
-
"pigment": "^0.4.
|
|
54
|
+
"pigment": "^0.4.4",
|
|
55
|
+
"typescript": "^6.0.3",
|
|
52
56
|
"validate-npm-package-name": "^7.0.2"
|
|
53
57
|
},
|
|
54
58
|
"devDependencies": {
|
|
55
|
-
"@babel/cli": "^7.28.6",
|
|
56
|
-
"@babel/core": "^7.29.0",
|
|
57
|
-
"@babel/preset-env": "^7.29.2",
|
|
58
|
-
"@babel/preset-typescript": "^7.28.5",
|
|
59
59
|
"@commitlint/config-conventional": "^20.5.0",
|
|
60
60
|
"@types/cross-spawn": "^6.0.6",
|
|
61
61
|
"@types/dedent": "^0.7.2",
|
|
62
62
|
"@types/ejs": "^3.1.5",
|
|
63
63
|
"@types/fs-extra": "^11.0.4",
|
|
64
|
-
"@types/
|
|
64
|
+
"@types/node": "^20.19.39",
|
|
65
|
+
"@types/validate-npm-package-name": "^4.0.2",
|
|
66
|
+
"del-cli": "^7.0.0"
|
|
65
67
|
},
|
|
66
|
-
"gitHead": "
|
|
68
|
+
"gitHead": "d4370e22e9e2976b464096fbd2b5738c740266e0"
|
|
67
69
|
}
|
|
@@ -84,7 +84,7 @@
|
|
|
84
84
|
<% if (project.moduleConfig === 'nitro-modules' || project.viewConfig === 'nitro-view') { -%>
|
|
85
85
|
"react-native-nitro-modules": "^<%- versions.nitro %>",
|
|
86
86
|
<% } -%>
|
|
87
|
-
"typescript": "^6.0.
|
|
87
|
+
"typescript": "^6.0.3"
|
|
88
88
|
},
|
|
89
89
|
"peerDependencies": {
|
|
90
90
|
"react": "*",
|
|
@@ -10,14 +10,14 @@
|
|
|
10
10
|
"useTabs": false
|
|
11
11
|
},
|
|
12
12
|
"devDependencies": {
|
|
13
|
-
"@eslint/compat": "^2.0
|
|
13
|
+
"@eslint/compat": "^2.1.0",
|
|
14
14
|
"@eslint/eslintrc": "^3.3.5",
|
|
15
15
|
"@eslint/js": "^10.0.1",
|
|
16
16
|
"@react-native/eslint-config": "0.85.0",
|
|
17
17
|
"eslint": "^9.39.4",
|
|
18
18
|
"eslint-config-prettier": "^10.1.8",
|
|
19
19
|
"eslint-plugin-ft-flow": "^3.0.11",
|
|
20
|
-
"eslint-plugin-prettier": "^5.5.
|
|
21
|
-
"prettier": "^3.8.
|
|
20
|
+
"eslint-plugin-prettier": "^5.5.6",
|
|
21
|
+
"prettier": "^3.8.3"
|
|
22
22
|
}
|
|
23
23
|
}
|
|
@@ -3,8 +3,8 @@
|
|
|
3
3
|
"extends": ["@commitlint/config-conventional"]
|
|
4
4
|
},
|
|
5
5
|
"devDependencies": {
|
|
6
|
-
"@commitlint/config-conventional": "^
|
|
7
|
-
"commitlint": "^
|
|
8
|
-
"lefthook": "^2.1.
|
|
6
|
+
"@commitlint/config-conventional": "^21.0.2",
|
|
7
|
+
"commitlint": "^21.0.2",
|
|
8
|
+
"lefthook": "^2.1.9"
|
|
9
9
|
}
|
|
10
10
|
}
|
package/lib/constants.js
DELETED
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.SUPPORTED_REACT_NATIVE_VERSION = exports.SUPPORTED_MONOREPO_CONFIG_VERSION = exports.SUPPORTED_EXPO_SDK_VERSION = exports.FALLBACK_NITRO_MODULES_VERSION = exports.FALLBACK_BOB_VERSION = void 0;
|
|
7
|
-
const FALLBACK_BOB_VERSION = exports.FALLBACK_BOB_VERSION = '0.41.0';
|
|
8
|
-
const FALLBACK_NITRO_MODULES_VERSION = exports.FALLBACK_NITRO_MODULES_VERSION = '0.35.3';
|
|
9
|
-
const SUPPORTED_MONOREPO_CONFIG_VERSION = exports.SUPPORTED_MONOREPO_CONFIG_VERSION = '0.3.3';
|
|
10
|
-
const SUPPORTED_REACT_NATIVE_VERSION = exports.SUPPORTED_REACT_NATIVE_VERSION = '0.85.0';
|
|
11
|
-
const SUPPORTED_EXPO_SDK_VERSION = exports.SUPPORTED_EXPO_SDK_VERSION = '55';
|
|
12
|
-
//# sourceMappingURL=constants.js.map
|
package/lib/constants.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"constants.js","names":["FALLBACK_BOB_VERSION","exports","FALLBACK_NITRO_MODULES_VERSION","SUPPORTED_MONOREPO_CONFIG_VERSION","SUPPORTED_REACT_NATIVE_VERSION","SUPPORTED_EXPO_SDK_VERSION"],"sources":["../src/constants.ts"],"sourcesContent":["export const FALLBACK_BOB_VERSION = '0.41.0';\nexport const FALLBACK_NITRO_MODULES_VERSION = '0.35.3';\nexport const SUPPORTED_MONOREPO_CONFIG_VERSION = '0.3.3';\nexport const SUPPORTED_REACT_NATIVE_VERSION = '0.85.0';\nexport const SUPPORTED_EXPO_SDK_VERSION = '55';\n"],"mappings":";;;;;;AAAO,MAAMA,oBAAoB,GAAAC,OAAA,CAAAD,oBAAA,GAAG,QAAQ;AACrC,MAAME,8BAA8B,GAAAD,OAAA,CAAAC,8BAAA,GAAG,QAAQ;AAC/C,MAAMC,iCAAiC,GAAAF,OAAA,CAAAE,iCAAA,GAAG,OAAO;AACjD,MAAMC,8BAA8B,GAAAH,OAAA,CAAAG,8BAAA,GAAG,QAAQ;AAC/C,MAAMC,0BAA0B,GAAAJ,OAAA,CAAAI,0BAAA,GAAG,IAAI","ignoreList":[]}
|
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.alignDependencyVersionsWithExampleApp = alignDependencyVersionsWithExampleApp;
|
|
7
|
-
var _path = _interopRequireDefault(require("path"));
|
|
8
|
-
var _fsExtra = _interopRequireDefault(require("fs-extra"));
|
|
9
|
-
var _sortObjectKeys = _interopRequireDefault(require("../utils/sortObjectKeys"));
|
|
10
|
-
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
11
|
-
async function alignDependencyVersionsWithExampleApp(pkg, folder) {
|
|
12
|
-
const examplePackageJson = await _fsExtra.default.readJSON(_path.default.join(folder, 'example', 'package.json'));
|
|
13
|
-
const PACKAGES_TO_COPY = ['react', 'react-native', '@types/react', '@react-native/babel-preset'];
|
|
14
|
-
const usesCodegen = pkg['react-native-builder-bob']?.targets?.some(target => Array.isArray(target) ? target[0] === 'codegen' : target === 'codegen') ?? false;
|
|
15
|
-
if (usesCodegen) {
|
|
16
|
-
PACKAGES_TO_COPY.push('@react-native-community/cli');
|
|
17
|
-
}
|
|
18
|
-
const devDependencies = {};
|
|
19
|
-
PACKAGES_TO_COPY.forEach(name => {
|
|
20
|
-
if (name) {
|
|
21
|
-
const version = examplePackageJson.dependencies?.[name] ?? examplePackageJson.devDependencies?.[name];
|
|
22
|
-
if (version != null) {
|
|
23
|
-
devDependencies[name] = version;
|
|
24
|
-
} else if (pkg.devDependencies?.[name] == null) {
|
|
25
|
-
throw new Error(`Couldn't find the package "${name}" in the example app.`);
|
|
26
|
-
}
|
|
27
|
-
}
|
|
28
|
-
});
|
|
29
|
-
pkg['devDependencies'] = (0, _sortObjectKeys.default)({
|
|
30
|
-
...pkg['devDependencies'],
|
|
31
|
-
...devDependencies
|
|
32
|
-
});
|
|
33
|
-
}
|
|
34
|
-
//# sourceMappingURL=dependencies.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"dependencies.js","names":["_path","_interopRequireDefault","require","_fsExtra","_sortObjectKeys","e","__esModule","default","alignDependencyVersionsWithExampleApp","pkg","folder","examplePackageJson","fs","readJSON","path","join","PACKAGES_TO_COPY","usesCodegen","targets","some","target","Array","isArray","push","devDependencies","forEach","name","version","dependencies","Error","sortObjectKeys"],"sources":["../../src/exampleApp/dependencies.ts"],"sourcesContent":["import path from 'path';\nimport fs from 'fs-extra';\nimport sortObjectKeys from '../utils/sortObjectKeys';\n\ntype PackageJson = {\n devDependencies?: Record<string, string>;\n 'react-native-builder-bob'?: {\n targets?: (string | [string, unknown])[];\n };\n};\n\nexport async function alignDependencyVersionsWithExampleApp(\n pkg: PackageJson,\n folder: string\n) {\n const examplePackageJson = await fs.readJSON(\n path.join(folder, 'example', 'package.json')\n );\n\n const PACKAGES_TO_COPY = [\n 'react',\n 'react-native',\n '@types/react',\n '@react-native/babel-preset',\n ];\n\n const usesCodegen =\n pkg['react-native-builder-bob']?.targets?.some((target) =>\n Array.isArray(target) ? target[0] === 'codegen' : target === 'codegen'\n ) ?? false;\n\n if (usesCodegen) {\n PACKAGES_TO_COPY.push('@react-native-community/cli');\n }\n\n const devDependencies: Record<string, string> = {};\n\n PACKAGES_TO_COPY.forEach((name) => {\n if (name) {\n const version =\n examplePackageJson.dependencies?.[name] ??\n examplePackageJson.devDependencies?.[name];\n\n if (version != null) {\n devDependencies[name] = version;\n } else if (pkg.devDependencies?.[name] == null) {\n throw new Error(\n `Couldn't find the package \"${name}\" in the example app.`\n );\n }\n }\n });\n\n pkg['devDependencies'] = sortObjectKeys({\n ...pkg['devDependencies'],\n ...devDependencies,\n });\n}\n"],"mappings":";;;;;;AAAA,IAAAA,KAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,QAAA,GAAAF,sBAAA,CAAAC,OAAA;AACA,IAAAE,eAAA,GAAAH,sBAAA,CAAAC,OAAA;AAAqD,SAAAD,uBAAAI,CAAA,WAAAA,CAAA,IAAAA,CAAA,CAAAC,UAAA,GAAAD,CAAA,KAAAE,OAAA,EAAAF,CAAA;AAS9C,eAAeG,qCAAqCA,CACzDC,GAAgB,EAChBC,MAAc,EACd;EACA,MAAMC,kBAAkB,GAAG,MAAMC,gBAAE,CAACC,QAAQ,CAC1CC,aAAI,CAACC,IAAI,CAACL,MAAM,EAAE,SAAS,EAAE,cAAc,CAC7C,CAAC;EAED,MAAMM,gBAAgB,GAAG,CACvB,OAAO,EACP,cAAc,EACd,cAAc,EACd,4BAA4B,CAC7B;EAED,MAAMC,WAAW,GACfR,GAAG,CAAC,0BAA0B,CAAC,EAAES,OAAO,EAAEC,IAAI,CAAEC,MAAM,IACpDC,KAAK,CAACC,OAAO,CAACF,MAAM,CAAC,GAAGA,MAAM,CAAC,CAAC,CAAC,KAAK,SAAS,GAAGA,MAAM,KAAK,SAC/D,CAAC,IAAI,KAAK;EAEZ,IAAIH,WAAW,EAAE;IACfD,gBAAgB,CAACO,IAAI,CAAC,6BAA6B,CAAC;EACtD;EAEA,MAAMC,eAAuC,GAAG,CAAC,CAAC;EAElDR,gBAAgB,CAACS,OAAO,CAAEC,IAAI,IAAK;IACjC,IAAIA,IAAI,EAAE;MACR,MAAMC,OAAO,GACXhB,kBAAkB,CAACiB,YAAY,GAAGF,IAAI,CAAC,IACvCf,kBAAkB,CAACa,eAAe,GAAGE,IAAI,CAAC;MAE5C,IAAIC,OAAO,IAAI,IAAI,EAAE;QACnBH,eAAe,CAACE,IAAI,CAAC,GAAGC,OAAO;MACjC,CAAC,MAAM,IAAIlB,GAAG,CAACe,eAAe,GAAGE,IAAI,CAAC,IAAI,IAAI,EAAE;QAC9C,MAAM,IAAIG,KAAK,CACb,8BAA8BH,IAAI,uBACpC,CAAC;MACH;IACF;EACF,CAAC,CAAC;EAEFjB,GAAG,CAAC,iBAAiB,CAAC,GAAG,IAAAqB,uBAAc,EAAC;IACtC,GAAGrB,GAAG,CAAC,iBAAiB,CAAC;IACzB,GAAGe;EACL,CAAC,CAAC;AACJ","ignoreList":[]}
|
|
@@ -1,249 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.default = generateExampleApp;
|
|
7
|
-
var _dedent = _interopRequireDefault(require("dedent"));
|
|
8
|
-
var _fsExtra = _interopRequireDefault(require("fs-extra"));
|
|
9
|
-
var _getLatestVersion = require("get-latest-version");
|
|
10
|
-
var _kleur = _interopRequireDefault(require("kleur"));
|
|
11
|
-
var _path = _interopRequireDefault(require("path"));
|
|
12
|
-
var _constants = require("../constants");
|
|
13
|
-
var _sortObjectKeys = _interopRequireDefault(require("../utils/sortObjectKeys"));
|
|
14
|
-
var _spawn = require("../utils/spawn");
|
|
15
|
-
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
16
|
-
const FILES_TO_DELETE = ['__tests__', '.buckconfig', '.eslintrc.js', '.flowconfig', '.git', '.gitignore', '.prettierrc.js', 'App.js', 'App.tsx', 'index.js', 'tsconfig.json'];
|
|
17
|
-
const PACKAGES_TO_REMOVE = ['@react-native/eslint-config', '@react-native/new-app-screen', '@tsconfig/react-native', '@types/jest', '@types/react-test-renderer', '@typescript-eslint/eslint-plugin', '@typescript-eslint/parser', 'babel-jest', 'eslint', 'jest', 'prettier', 'react-test-renderer', 'typescript', 'react-native-safe-area-context'];
|
|
18
|
-
const PACKAGES_TO_ADD_EXPO_WEB = {
|
|
19
|
-
'@expo/metro-runtime': '~5.0.4',
|
|
20
|
-
'react-native-web': '~0.21.1'
|
|
21
|
-
};
|
|
22
|
-
const PACKAGES_TO_ADD_DEV_EXPO_NATIVE = {
|
|
23
|
-
'expo-dev-client': '~5.0.3'
|
|
24
|
-
};
|
|
25
|
-
async function fetchReactNativeVersion(version) {
|
|
26
|
-
const matchedReactNativeVersion = /(\d+\.\d+[-.0-9a-z]*)/.test(version) ? version : await (0, _getLatestVersion.getLatestVersion)('react-native', {
|
|
27
|
-
range: version
|
|
28
|
-
});
|
|
29
|
-
if (!matchedReactNativeVersion) {
|
|
30
|
-
throw new Error(`Could not find a matching version for react-native: ${version}`);
|
|
31
|
-
}
|
|
32
|
-
return matchedReactNativeVersion;
|
|
33
|
-
}
|
|
34
|
-
async function fetchCompatibleExpoSDK(reactNativeVersion) {
|
|
35
|
-
const matchedReactNativeVersion = await fetchReactNativeVersion(reactNativeVersion);
|
|
36
|
-
const res = await fetch('https://api.expo.dev/v2/versions/latest');
|
|
37
|
-
if (!res.ok) {
|
|
38
|
-
throw new Error(`Failed to fetch Expo SDK versions: ${String(res.status)} ${res.statusText}`);
|
|
39
|
-
}
|
|
40
|
-
const result = await res.json();
|
|
41
|
-
const sdkVersion = Object.entries(result.data.sdkVersions).find(([, sdkVersionInfo]) => {
|
|
42
|
-
if (typeof sdkVersionInfo === 'object' && sdkVersionInfo != null && 'facebookReactNativeVersion' in sdkVersionInfo && typeof sdkVersionInfo.facebookReactNativeVersion === 'string') {
|
|
43
|
-
const requested = matchedReactNativeVersion.split('.');
|
|
44
|
-
const supported = sdkVersionInfo.facebookReactNativeVersion.split('.');
|
|
45
|
-
return requested[0] === supported[0] && requested[1] === supported[1] && (requested[2] ? requested[2] === supported[2] : true);
|
|
46
|
-
}
|
|
47
|
-
return false;
|
|
48
|
-
})?.[0]
|
|
49
|
-
// Get major SDK version (e.g. "55" from "55.0.0")
|
|
50
|
-
.split('.')[0];
|
|
51
|
-
if (sdkVersion == null) {
|
|
52
|
-
throw new Error(`Couldn't find a compatible Expo SDK for react-native@${reactNativeVersion}`);
|
|
53
|
-
}
|
|
54
|
-
return {
|
|
55
|
-
sdkVersion,
|
|
56
|
-
reactNativeVersion: matchedReactNativeVersion
|
|
57
|
-
};
|
|
58
|
-
}
|
|
59
|
-
async function generateExampleApp({
|
|
60
|
-
config,
|
|
61
|
-
root,
|
|
62
|
-
reactNativeVersion
|
|
63
|
-
}) {
|
|
64
|
-
const directory = _path.default.join(root, 'example');
|
|
65
|
-
let args = [];
|
|
66
|
-
switch (config.example) {
|
|
67
|
-
case 'vanilla':
|
|
68
|
-
if (reactNativeVersion != null && reactNativeVersion !== _constants.SUPPORTED_REACT_NATIVE_VERSION) {
|
|
69
|
-
console.log(`${_kleur.default.blue('ℹ')} Using untested ${_kleur.default.cyan(`react-native@${reactNativeVersion}`)} for the example`);
|
|
70
|
-
}
|
|
71
|
-
|
|
72
|
-
// `npx @react-native-community/cli init <projectName> --directory example --skip-install`
|
|
73
|
-
args = [`@react-native-community/cli`, 'init', `${config.project.name}Example`, '--package-name', `${config.project.package}.example`, '--directory', directory, '--version', reactNativeVersion || _constants.SUPPORTED_REACT_NATIVE_VERSION, '--skip-install', '--skip-git-init', '--pm', 'npm'];
|
|
74
|
-
break;
|
|
75
|
-
case 'test-app':
|
|
76
|
-
{
|
|
77
|
-
// Test App doesn't support a semver range for the version
|
|
78
|
-
const matchedReactNativeVersion = reactNativeVersion ? await fetchReactNativeVersion(reactNativeVersion) : _constants.SUPPORTED_REACT_NATIVE_VERSION;
|
|
79
|
-
if (reactNativeVersion != null && reactNativeVersion !== _constants.SUPPORTED_REACT_NATIVE_VERSION) {
|
|
80
|
-
console.log(`${_kleur.default.blue('ℹ')} Using untested ${_kleur.default.cyan(`react-native@${matchedReactNativeVersion}`)} for the example`);
|
|
81
|
-
}
|
|
82
|
-
|
|
83
|
-
// `npx --package react-native-test-app@latest init --name ${projectName}Example --destination example --version ${reactNativeVersion}`
|
|
84
|
-
args = ['--package', `react-native-test-app@latest`, 'init', '--name', `${config.project.name}Example`, `--destination`, directory, '--version', matchedReactNativeVersion, '--platform', 'ios', '--platform', 'android'];
|
|
85
|
-
}
|
|
86
|
-
break;
|
|
87
|
-
case 'expo':
|
|
88
|
-
{
|
|
89
|
-
// `npx create-expo-app example --no-install --template blank`
|
|
90
|
-
const {
|
|
91
|
-
sdkVersion,
|
|
92
|
-
reactNativeVersion: matchedReactNativeVersion
|
|
93
|
-
} = reactNativeVersion ? await fetchCompatibleExpoSDK(reactNativeVersion) : {
|
|
94
|
-
sdkVersion: _constants.SUPPORTED_EXPO_SDK_VERSION,
|
|
95
|
-
reactNativeVersion: null
|
|
96
|
-
};
|
|
97
|
-
if (sdkVersion !== _constants.SUPPORTED_EXPO_SDK_VERSION && matchedReactNativeVersion) {
|
|
98
|
-
console.log(`${_kleur.default.blue('ℹ')} Using untested ${_kleur.default.cyan(`expo@${sdkVersion}`)} with ${_kleur.default.cyan(`react-native@${matchedReactNativeVersion}`)} for the example`);
|
|
99
|
-
}
|
|
100
|
-
args = ['create-expo-app@latest', directory, '--no-install', '--template', `blank@sdk-${sdkVersion}`];
|
|
101
|
-
break;
|
|
102
|
-
}
|
|
103
|
-
case undefined:
|
|
104
|
-
case null:
|
|
105
|
-
{
|
|
106
|
-
// Do nothing
|
|
107
|
-
}
|
|
108
|
-
}
|
|
109
|
-
await (0, _spawn.spawn)('npx', args, {
|
|
110
|
-
env: {
|
|
111
|
-
...process.env,
|
|
112
|
-
npm_config_yes: 'true'
|
|
113
|
-
}
|
|
114
|
-
});
|
|
115
|
-
|
|
116
|
-
// Remove unnecessary files and folders
|
|
117
|
-
for (const file of FILES_TO_DELETE) {
|
|
118
|
-
await _fsExtra.default.remove(_path.default.join(directory, file));
|
|
119
|
-
}
|
|
120
|
-
|
|
121
|
-
// Patch the example app's package.json
|
|
122
|
-
const pkg = await _fsExtra.default.readJSON(_path.default.join(directory, 'package.json'));
|
|
123
|
-
pkg.name = `${config.project.slug}-example`;
|
|
124
|
-
|
|
125
|
-
// Remove Jest config for now
|
|
126
|
-
delete pkg.jest;
|
|
127
|
-
|
|
128
|
-
// Make sure we have at least empty objects
|
|
129
|
-
// Otherwise generation will fails if package doesn't contain these fields
|
|
130
|
-
pkg.scripts = pkg.scripts || {};
|
|
131
|
-
pkg.dependencies = pkg.dependencies || {};
|
|
132
|
-
pkg.devDependencies = pkg.devDependencies || {};
|
|
133
|
-
const {
|
|
134
|
-
scripts,
|
|
135
|
-
dependencies,
|
|
136
|
-
devDependencies
|
|
137
|
-
} = pkg;
|
|
138
|
-
delete scripts.test;
|
|
139
|
-
delete scripts.lint;
|
|
140
|
-
const SCRIPTS_TO_ADD = config.example === 'expo' ? {
|
|
141
|
-
'build:ios': `xcodebuild ONLY_ACTIVE_ARCH=YES -workspace ios/${config.project.name}Example.xcworkspace -UseNewBuildSystem=YES -scheme ${config.project.name}Example -configuration Debug -sdk iphonesimulator -derivedDataPath ios/build -quiet`,
|
|
142
|
-
'build:android': 'cd android && ./gradlew assembleDebug -DtestBuildType=debug -Dorg.gradle.jvmargs=-Xmx4g'
|
|
143
|
-
} : {
|
|
144
|
-
'build:android': 'react-native build-android --extra-params "--no-daemon --console=plain -PreactNativeArchitectures=arm64-v8a"',
|
|
145
|
-
'build:ios': `react-native build-ios --mode Debug`
|
|
146
|
-
};
|
|
147
|
-
if (config.example != null) {
|
|
148
|
-
Object.assign(scripts, SCRIPTS_TO_ADD);
|
|
149
|
-
}
|
|
150
|
-
if (config.example === 'test-app') {
|
|
151
|
-
// `react-native-test-app` doesn't bundle application by default in 'Release' mode and also `bundle` command doesn't create a directory.
|
|
152
|
-
// `mkdist` script should be removed after stable React Native major contains this fix: https://github.com/facebook/react-native/pull/45182.
|
|
153
|
-
|
|
154
|
-
const androidBuild = ['npm run mkdist', 'react-native bundle --entry-file index.js --platform android --dev true --bundle-output dist/main.android.jsbundle --assets-dest dist', SCRIPTS_TO_ADD['build:android']].join(' && ');
|
|
155
|
-
const iosBuild = ['npm run mkdist', 'react-native bundle --entry-file index.js --platform ios --dev true --bundle-output dist/main.ios.jsbundle --assets-dest dist', SCRIPTS_TO_ADD['build:ios']].join(' && ');
|
|
156
|
-
Object.assign(scripts, {
|
|
157
|
-
'build:android': androidBuild,
|
|
158
|
-
'build:ios': iosBuild
|
|
159
|
-
});
|
|
160
|
-
const app = await _fsExtra.default.readJSON(_path.default.join(directory, 'app.json'));
|
|
161
|
-
app.android = app.android || {};
|
|
162
|
-
app.android.package = `${config.project.package}.example`;
|
|
163
|
-
app.ios = app.ios || {};
|
|
164
|
-
app.ios.bundleIdentifier = `${config.project.package}.example`;
|
|
165
|
-
await _fsExtra.default.writeJSON(_path.default.join(directory, 'app.json'), app, {
|
|
166
|
-
spaces: 2
|
|
167
|
-
});
|
|
168
|
-
}
|
|
169
|
-
PACKAGES_TO_REMOVE.forEach(name => {
|
|
170
|
-
// eslint-disable-next-line @typescript-eslint/no-dynamic-delete
|
|
171
|
-
delete devDependencies[name];
|
|
172
|
-
// eslint-disable-next-line @typescript-eslint/no-dynamic-delete
|
|
173
|
-
delete dependencies[name];
|
|
174
|
-
});
|
|
175
|
-
const PACKAGES_TO_ADD_DEV = {
|
|
176
|
-
'react-native-builder-bob': `^${config.versions.bob}`,
|
|
177
|
-
'react-native-monorepo-config': `^${_constants.SUPPORTED_MONOREPO_CONFIG_VERSION}`
|
|
178
|
-
};
|
|
179
|
-
if (config.project.moduleConfig === 'nitro-modules' || config.project.viewConfig === 'nitro-view') {
|
|
180
|
-
const packagesToAddNitro = {
|
|
181
|
-
'react-native-nitro-modules': `^${config.versions.nitro || 'latest'}`
|
|
182
|
-
};
|
|
183
|
-
Object.assign(dependencies, packagesToAddNitro);
|
|
184
|
-
}
|
|
185
|
-
Object.assign(devDependencies, PACKAGES_TO_ADD_DEV);
|
|
186
|
-
if (config.example === 'expo') {
|
|
187
|
-
const sdkVersion = dependencies.expo.split('.')[0].replace(/[^\d]/, '');
|
|
188
|
-
let bundledNativeModules;
|
|
189
|
-
try {
|
|
190
|
-
const res = await fetch(`https://raw.githubusercontent.com/expo/expo/sdk-${sdkVersion}/packages/expo/bundledNativeModules.json`);
|
|
191
|
-
if (!res.ok) {
|
|
192
|
-
throw new Error(`Failed to fetch bundled native modules for Expo SDK ${sdkVersion}: ${String(res.status)} ${res.statusText}`);
|
|
193
|
-
}
|
|
194
|
-
bundledNativeModules = await res.json();
|
|
195
|
-
} catch (e) {
|
|
196
|
-
console.warn(`${_kleur.default.yellow('⚠')} Failed to fetch compatibility data for Expo SDK ${sdkVersion}: ${_kleur.default.cyan(config.example)}`);
|
|
197
|
-
bundledNativeModules = {};
|
|
198
|
-
}
|
|
199
|
-
if (config.project.native) {
|
|
200
|
-
Object.entries(PACKAGES_TO_ADD_DEV_EXPO_NATIVE).forEach(([name, version]) => {
|
|
201
|
-
devDependencies[name] = bundledNativeModules[name] || version;
|
|
202
|
-
});
|
|
203
|
-
scripts.start = 'expo start --dev-client';
|
|
204
|
-
scripts.android = 'expo run:android';
|
|
205
|
-
scripts.ios = 'expo run:ios';
|
|
206
|
-
await _fsExtra.default.writeFile(_path.default.join(directory, '.gitignore'), (0, _dedent.default)`
|
|
207
|
-
# These folders are generated with prebuild (CNG)
|
|
208
|
-
android/
|
|
209
|
-
ios/
|
|
210
|
-
`);
|
|
211
|
-
}
|
|
212
|
-
const reactVersion = dependencies.react ?? devDependencies.react;
|
|
213
|
-
if (typeof reactVersion !== 'string') {
|
|
214
|
-
throw new Error("Couldn't find the package 'react' in the example app.");
|
|
215
|
-
}
|
|
216
|
-
Object.entries(PACKAGES_TO_ADD_EXPO_WEB).forEach(([name, version]) => {
|
|
217
|
-
dependencies[name] = bundledNativeModules[name] || version;
|
|
218
|
-
});
|
|
219
|
-
dependencies['react-dom'] = reactVersion;
|
|
220
|
-
scripts.web = 'expo start --web';
|
|
221
|
-
scripts['build:web'] = 'expo export --platform web';
|
|
222
|
-
const app = await _fsExtra.default.readJSON(_path.default.join(directory, 'app.json'));
|
|
223
|
-
app.expo.name = `${config.project.name} Example`;
|
|
224
|
-
app.expo.slug = `${config.project.slug}-example`;
|
|
225
|
-
app.expo.android = app.expo.android || {};
|
|
226
|
-
app.expo.android.package = `${config.project.package}.example`;
|
|
227
|
-
app.expo.ios = app.expo.ios || {};
|
|
228
|
-
app.expo.ios.bundleIdentifier = `${config.project.package}.example`;
|
|
229
|
-
await _fsExtra.default.writeJSON(_path.default.join(directory, 'app.json'), app, {
|
|
230
|
-
spaces: 2
|
|
231
|
-
});
|
|
232
|
-
}
|
|
233
|
-
|
|
234
|
-
// Sort the deps by name to match behavior of package managers
|
|
235
|
-
// This way the package.json doesn't get updated when installing deps
|
|
236
|
-
for (const field of ['dependencies', 'devDependencies']) {
|
|
237
|
-
if (pkg[field]) {
|
|
238
|
-
pkg[field] = (0, _sortObjectKeys.default)(pkg[field]);
|
|
239
|
-
}
|
|
240
|
-
}
|
|
241
|
-
await _fsExtra.default.writeJSON(_path.default.join(directory, 'package.json'), pkg, {
|
|
242
|
-
spaces: 2
|
|
243
|
-
});
|
|
244
|
-
if (config.example === 'vanilla' && config.project.cpp) {
|
|
245
|
-
const podfile = await _fsExtra.default.readFile(_path.default.join(directory, 'ios', 'Podfile'), 'utf8');
|
|
246
|
-
await _fsExtra.default.writeFile(_path.default.join(directory, 'ios', 'Podfile'), "ENV['RCT_USE_RN_DEP'] = '1' # Needed to make iOS build work for C++ module\n\n" + podfile);
|
|
247
|
-
}
|
|
248
|
-
}
|
|
249
|
-
//# sourceMappingURL=generateExampleApp.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"generateExampleApp.js","names":["_dedent","_interopRequireDefault","require","_fsExtra","_getLatestVersion","_kleur","_path","_constants","_sortObjectKeys","_spawn","e","__esModule","default","FILES_TO_DELETE","PACKAGES_TO_REMOVE","PACKAGES_TO_ADD_EXPO_WEB","PACKAGES_TO_ADD_DEV_EXPO_NATIVE","fetchReactNativeVersion","version","matchedReactNativeVersion","test","getLatestVersion","range","Error","fetchCompatibleExpoSDK","reactNativeVersion","res","fetch","ok","String","status","statusText","result","json","sdkVersion","Object","entries","data","sdkVersions","find","sdkVersionInfo","facebookReactNativeVersion","requested","split","supported","generateExampleApp","config","root","directory","path","join","args","example","SUPPORTED_REACT_NATIVE_VERSION","console","log","kleur","blue","cyan","project","name","package","SUPPORTED_EXPO_SDK_VERSION","undefined","spawn","env","process","npm_config_yes","file","fs","remove","pkg","readJSON","slug","jest","scripts","dependencies","devDependencies","lint","SCRIPTS_TO_ADD","assign","androidBuild","iosBuild","app","android","ios","bundleIdentifier","writeJSON","spaces","forEach","PACKAGES_TO_ADD_DEV","versions","bob","SUPPORTED_MONOREPO_CONFIG_VERSION","moduleConfig","viewConfig","packagesToAddNitro","nitro","expo","replace","bundledNativeModules","warn","yellow","native","start","writeFile","dedent","reactVersion","react","web","field","sortObjectKeys","cpp","podfile","readFile"],"sources":["../../src/exampleApp/generateExampleApp.ts"],"sourcesContent":["import dedent from 'dedent';\nimport fs from 'fs-extra';\nimport { getLatestVersion } from 'get-latest-version';\nimport kleur from 'kleur';\nimport path from 'path';\nimport {\n SUPPORTED_EXPO_SDK_VERSION,\n SUPPORTED_MONOREPO_CONFIG_VERSION,\n SUPPORTED_REACT_NATIVE_VERSION,\n} from '../constants';\nimport type { TemplateConfiguration } from '../template';\nimport sortObjectKeys from '../utils/sortObjectKeys';\nimport { spawn } from '../utils/spawn';\n\nconst FILES_TO_DELETE = [\n '__tests__',\n '.buckconfig',\n '.eslintrc.js',\n '.flowconfig',\n '.git',\n '.gitignore',\n '.prettierrc.js',\n 'App.js',\n 'App.tsx',\n 'index.js',\n 'tsconfig.json',\n];\n\nconst PACKAGES_TO_REMOVE = [\n '@react-native/eslint-config',\n '@react-native/new-app-screen',\n '@tsconfig/react-native',\n '@types/jest',\n '@types/react-test-renderer',\n '@typescript-eslint/eslint-plugin',\n '@typescript-eslint/parser',\n 'babel-jest',\n 'eslint',\n 'jest',\n 'prettier',\n 'react-test-renderer',\n 'typescript',\n 'react-native-safe-area-context',\n];\n\nconst PACKAGES_TO_ADD_EXPO_WEB = {\n '@expo/metro-runtime': '~5.0.4',\n 'react-native-web': '~0.21.1',\n};\n\nconst PACKAGES_TO_ADD_DEV_EXPO_NATIVE = {\n 'expo-dev-client': '~5.0.3',\n};\n\nasync function fetchReactNativeVersion(version: string) {\n const matchedReactNativeVersion = /(\\d+\\.\\d+[-.0-9a-z]*)/.test(version)\n ? version\n : await getLatestVersion('react-native', {\n range: version,\n });\n\n if (!matchedReactNativeVersion) {\n throw new Error(\n `Could not find a matching version for react-native: ${version}`\n );\n }\n\n return matchedReactNativeVersion;\n}\n\nasync function fetchCompatibleExpoSDK(reactNativeVersion: string) {\n const matchedReactNativeVersion =\n await fetchReactNativeVersion(reactNativeVersion);\n\n const res = await fetch('https://api.expo.dev/v2/versions/latest');\n\n if (!res.ok) {\n throw new Error(\n `Failed to fetch Expo SDK versions: ${String(res.status)} ${res.statusText}`\n );\n }\n\n const result = await res.json();\n\n const sdkVersion = Object.entries(result.data.sdkVersions)\n .find(([, sdkVersionInfo]) => {\n if (\n typeof sdkVersionInfo === 'object' &&\n sdkVersionInfo != null &&\n 'facebookReactNativeVersion' in sdkVersionInfo &&\n typeof sdkVersionInfo.facebookReactNativeVersion === 'string'\n ) {\n const requested = matchedReactNativeVersion.split('.');\n const supported = sdkVersionInfo.facebookReactNativeVersion.split('.');\n\n return (\n requested[0] === supported[0] &&\n requested[1] === supported[1] &&\n (requested[2] ? requested[2] === supported[2] : true)\n );\n }\n\n return false;\n })?.[0]\n // Get major SDK version (e.g. \"55\" from \"55.0.0\")\n .split('.')[0];\n\n if (sdkVersion == null) {\n throw new Error(\n `Couldn't find a compatible Expo SDK for react-native@${reactNativeVersion}`\n );\n }\n\n return {\n sdkVersion,\n reactNativeVersion: matchedReactNativeVersion,\n };\n}\n\nexport default async function generateExampleApp({\n config,\n root,\n reactNativeVersion,\n}: {\n config: TemplateConfiguration;\n root: string;\n reactNativeVersion: string | undefined;\n}) {\n const directory = path.join(root, 'example');\n\n let args: string[] = [];\n\n switch (config.example) {\n case 'vanilla':\n if (\n reactNativeVersion != null &&\n reactNativeVersion !== SUPPORTED_REACT_NATIVE_VERSION\n ) {\n console.log(\n `${kleur.blue('ℹ')} Using untested ${kleur.cyan(\n `react-native@${reactNativeVersion}`\n )} for the example`\n );\n }\n\n // `npx @react-native-community/cli init <projectName> --directory example --skip-install`\n args = [\n `@react-native-community/cli`,\n 'init',\n `${config.project.name}Example`,\n '--package-name',\n `${config.project.package}.example`,\n '--directory',\n directory,\n '--version',\n reactNativeVersion || SUPPORTED_REACT_NATIVE_VERSION,\n '--skip-install',\n '--skip-git-init',\n '--pm',\n 'npm',\n ];\n break;\n case 'test-app':\n {\n // Test App doesn't support a semver range for the version\n const matchedReactNativeVersion = reactNativeVersion\n ? await fetchReactNativeVersion(reactNativeVersion)\n : SUPPORTED_REACT_NATIVE_VERSION;\n\n if (\n reactNativeVersion != null &&\n reactNativeVersion !== SUPPORTED_REACT_NATIVE_VERSION\n ) {\n console.log(\n `${kleur.blue('ℹ')} Using untested ${kleur.cyan(\n `react-native@${matchedReactNativeVersion}`\n )} for the example`\n );\n }\n\n // `npx --package react-native-test-app@latest init --name ${projectName}Example --destination example --version ${reactNativeVersion}`\n args = [\n '--package',\n `react-native-test-app@latest`,\n 'init',\n '--name',\n `${config.project.name}Example`,\n `--destination`,\n directory,\n '--version',\n matchedReactNativeVersion,\n '--platform',\n 'ios',\n '--platform',\n 'android',\n ];\n }\n break;\n case 'expo': {\n // `npx create-expo-app example --no-install --template blank`\n const { sdkVersion, reactNativeVersion: matchedReactNativeVersion } =\n reactNativeVersion\n ? await fetchCompatibleExpoSDK(reactNativeVersion)\n : {\n sdkVersion: SUPPORTED_EXPO_SDK_VERSION,\n reactNativeVersion: null,\n };\n\n if (\n sdkVersion !== SUPPORTED_EXPO_SDK_VERSION &&\n matchedReactNativeVersion\n ) {\n console.log(\n `${kleur.blue('ℹ')} Using untested ${kleur.cyan(\n `expo@${sdkVersion}`\n )} with ${kleur.cyan(`react-native@${matchedReactNativeVersion}`)} for the example`\n );\n }\n\n args = [\n 'create-expo-app@latest',\n directory,\n '--no-install',\n '--template',\n `blank@sdk-${sdkVersion}`,\n ];\n break;\n }\n case undefined:\n case null: {\n // Do nothing\n }\n }\n\n await spawn('npx', args, {\n env: { ...process.env, npm_config_yes: 'true' },\n });\n\n // Remove unnecessary files and folders\n for (const file of FILES_TO_DELETE) {\n await fs.remove(path.join(directory, file));\n }\n\n // Patch the example app's package.json\n const pkg = await fs.readJSON(path.join(directory, 'package.json'));\n\n pkg.name = `${config.project.slug}-example`;\n\n // Remove Jest config for now\n delete pkg.jest;\n\n // Make sure we have at least empty objects\n // Otherwise generation will fails if package doesn't contain these fields\n pkg.scripts = pkg.scripts || {};\n pkg.dependencies = pkg.dependencies || {};\n pkg.devDependencies = pkg.devDependencies || {};\n\n const { scripts, dependencies, devDependencies } = pkg;\n\n delete scripts.test;\n delete scripts.lint;\n\n const SCRIPTS_TO_ADD =\n config.example === 'expo'\n ? {\n 'build:ios': `xcodebuild ONLY_ACTIVE_ARCH=YES -workspace ios/${config.project.name}Example.xcworkspace -UseNewBuildSystem=YES -scheme ${config.project.name}Example -configuration Debug -sdk iphonesimulator -derivedDataPath ios/build -quiet`,\n 'build:android':\n 'cd android && ./gradlew assembleDebug -DtestBuildType=debug -Dorg.gradle.jvmargs=-Xmx4g',\n }\n : {\n 'build:android':\n 'react-native build-android --extra-params \"--no-daemon --console=plain -PreactNativeArchitectures=arm64-v8a\"',\n 'build:ios': `react-native build-ios --mode Debug`,\n };\n\n if (config.example != null) {\n Object.assign(scripts, SCRIPTS_TO_ADD);\n }\n\n if (config.example === 'test-app') {\n // `react-native-test-app` doesn't bundle application by default in 'Release' mode and also `bundle` command doesn't create a directory.\n // `mkdist` script should be removed after stable React Native major contains this fix: https://github.com/facebook/react-native/pull/45182.\n\n const androidBuild = [\n 'npm run mkdist',\n 'react-native bundle --entry-file index.js --platform android --dev true --bundle-output dist/main.android.jsbundle --assets-dest dist',\n SCRIPTS_TO_ADD['build:android'],\n ].join(' && ');\n\n const iosBuild = [\n 'npm run mkdist',\n 'react-native bundle --entry-file index.js --platform ios --dev true --bundle-output dist/main.ios.jsbundle --assets-dest dist',\n SCRIPTS_TO_ADD['build:ios'],\n ].join(' && ');\n\n Object.assign(scripts, {\n 'build:android': androidBuild,\n 'build:ios': iosBuild,\n });\n\n const app = await fs.readJSON(path.join(directory, 'app.json'));\n\n app.android = app.android || {};\n app.android.package = `${config.project.package}.example`;\n app.ios = app.ios || {};\n app.ios.bundleIdentifier = `${config.project.package}.example`;\n\n await fs.writeJSON(path.join(directory, 'app.json'), app, {\n spaces: 2,\n });\n }\n\n PACKAGES_TO_REMOVE.forEach((name) => {\n // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n delete devDependencies[name];\n // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n delete dependencies[name];\n });\n\n const PACKAGES_TO_ADD_DEV = {\n 'react-native-builder-bob': `^${config.versions.bob}`,\n 'react-native-monorepo-config': `^${SUPPORTED_MONOREPO_CONFIG_VERSION}`,\n };\n\n if (\n config.project.moduleConfig === 'nitro-modules' ||\n config.project.viewConfig === 'nitro-view'\n ) {\n const packagesToAddNitro = {\n 'react-native-nitro-modules': `^${config.versions.nitro || 'latest'}`,\n };\n\n Object.assign(dependencies, packagesToAddNitro);\n }\n\n Object.assign(devDependencies, PACKAGES_TO_ADD_DEV);\n\n if (config.example === 'expo') {\n const sdkVersion: string = dependencies.expo\n .split('.')[0]\n .replace(/[^\\d]/, '');\n\n let bundledNativeModules: Record<string, string>;\n\n try {\n const res = await fetch(\n `https://raw.githubusercontent.com/expo/expo/sdk-${sdkVersion}/packages/expo/bundledNativeModules.json`\n );\n\n if (!res.ok) {\n throw new Error(\n `Failed to fetch bundled native modules for Expo SDK ${sdkVersion}: ${String(res.status)} ${res.statusText}`\n );\n }\n\n bundledNativeModules = await res.json();\n } catch (e) {\n console.warn(\n `${kleur.yellow(\n '⚠'\n )} Failed to fetch compatibility data for Expo SDK ${sdkVersion}: ${kleur.cyan(\n config.example\n )}`\n );\n\n bundledNativeModules = {};\n }\n\n if (config.project.native) {\n Object.entries(PACKAGES_TO_ADD_DEV_EXPO_NATIVE).forEach(\n ([name, version]) => {\n devDependencies[name] = bundledNativeModules[name] || version;\n }\n );\n\n scripts.start = 'expo start --dev-client';\n scripts.android = 'expo run:android';\n scripts.ios = 'expo run:ios';\n\n await fs.writeFile(\n path.join(directory, '.gitignore'),\n dedent`\n # These folders are generated with prebuild (CNG)\n android/\n ios/\n `\n );\n }\n\n const reactVersion = dependencies.react ?? devDependencies.react;\n\n if (typeof reactVersion !== 'string') {\n throw new Error(\"Couldn't find the package 'react' in the example app.\");\n }\n\n Object.entries(PACKAGES_TO_ADD_EXPO_WEB).forEach(([name, version]) => {\n dependencies[name] = bundledNativeModules[name] || version;\n });\n\n dependencies['react-dom'] = reactVersion;\n scripts.web = 'expo start --web';\n scripts['build:web'] = 'expo export --platform web';\n\n const app = await fs.readJSON(path.join(directory, 'app.json'));\n\n app.expo.name = `${config.project.name} Example`;\n app.expo.slug = `${config.project.slug}-example`;\n app.expo.android = app.expo.android || {};\n app.expo.android.package = `${config.project.package}.example`;\n app.expo.ios = app.expo.ios || {};\n app.expo.ios.bundleIdentifier = `${config.project.package}.example`;\n\n await fs.writeJSON(path.join(directory, 'app.json'), app, {\n spaces: 2,\n });\n }\n\n // Sort the deps by name to match behavior of package managers\n // This way the package.json doesn't get updated when installing deps\n for (const field of ['dependencies', 'devDependencies']) {\n if (pkg[field]) {\n pkg[field] = sortObjectKeys(pkg[field]);\n }\n }\n\n await fs.writeJSON(path.join(directory, 'package.json'), pkg, {\n spaces: 2,\n });\n\n if (config.example === 'vanilla' && config.project.cpp) {\n const podfile = await fs.readFile(\n path.join(directory, 'ios', 'Podfile'),\n 'utf8'\n );\n\n await fs.writeFile(\n path.join(directory, 'ios', 'Podfile'),\n \"ENV['RCT_USE_RN_DEP'] = '1' # Needed to make iOS build work for C++ module\\n\\n\" +\n podfile\n );\n }\n}\n"],"mappings":"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","ignoreList":[]}
|