create-expo-stack 2.5.0-next.cfc261a → 2.5.0
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/README.md +209 -7
- package/build/commands/create-expo-stack.js +51 -53
- package/build/templates/base/components/Container.tsx.ejs +13 -0
- package/build/templates/base/package.json.ejs +1 -1
- package/build/templates/packages/expo-router/drawer/app/(drawer)/(tabs)/index.tsx.ejs +3 -10
- package/build/templates/packages/expo-router/drawer/app/(drawer)/(tabs)/two.tsx.ejs +4 -11
- package/build/templates/packages/expo-router/drawer/app/(drawer)/index.tsx.ejs +4 -10
- package/build/templates/packages/expo-router/drawer/app/+not-found.tsx.ejs +17 -22
- package/build/templates/packages/expo-router/drawer/app/modal.tsx.ejs +2 -1
- package/build/templates/packages/expo-router/stack/app/+not-found.tsx.ejs +13 -18
- package/build/templates/packages/expo-router/stack/app/details.tsx.ejs +6 -12
- package/build/templates/packages/expo-router/stack/app/index.tsx.ejs +5 -13
- package/build/templates/packages/expo-router/tabs/app/modal.tsx.ejs +2 -1
- package/build/templates/packages/nativewind/components/Button.tsx.ejs +2 -2
- package/build/templates/packages/nativewind/components/Container.tsx.ejs +9 -0
- package/build/templates/packages/nativewind/tailwind.config.js.ejs +1 -1
- package/build/templates/packages/restyle/components/Button.tsx.ejs +3 -2
- package/build/templates/packages/restyle/components/Container.tsx.ejs +6 -0
- package/build/templates/packages/tamagui/components/Button.tsx.ejs +1 -1
- package/build/templates/packages/tamagui/components/Container.tsx.ejs +6 -0
- package/build/templates/packages/unistyles/components/Button.tsx.ejs +1 -1
- package/build/templates/packages/unistyles/components/Container.tsx.ejs +9 -0
- package/build/templates/packages/unistyles/theme.ts.ejs +2 -1
- package/build/types/utilities/getPackageManager.d.ts +1 -0
- package/build/types/utilities/validateProjectName.d.ts +1 -1
- package/build/utilities/configureProjectFiles.js +10 -2
- package/build/utilities/getPackageManager.js +9 -2
- package/build/utilities/printOutput.js +4 -2
- package/build/utilities/renderTitle.js +8 -1
- package/build/utilities/runCLI.js +114 -40
- package/build/utilities/validateProjectName.js +14 -8
- package/package.json +66 -66
|
@@ -38,13 +38,15 @@ var __generator = (this && this.__generator) || function (thisArg, body) {
|
|
|
38
38
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
39
39
|
exports.runCLI = void 0;
|
|
40
40
|
var constants_1 = require("../constants");
|
|
41
|
+
var getPackageManager_1 = require("./getPackageManager");
|
|
42
|
+
var recommendedBunVersion = '1.0.14';
|
|
41
43
|
function runCLI(toolbox, projectName) {
|
|
42
44
|
return __awaiter(this, void 0, void 0, function () {
|
|
43
|
-
var options, success, prompt, cliResults, useTypescript, askNavigation, askNavigationType, navigationSelect, navigationTypeSelect, askStyling, stylingSelect, askAuthentication, authenticationSelect, askInternalization, internalizationSelect
|
|
44
|
-
return __generator(this, function (
|
|
45
|
-
switch (
|
|
45
|
+
var options, _a, info, success, warning, highlight, prompt, cliResults, useTypescript, defaultPackageManagerVersion, shouldUseDefaultPackageManager, askPackageManager, packageManagerSelect, askPackageManager, packageManagerSelect, askNavigation, askNavigationType, navigationSelect, navigationTypeSelect, shouldContinue, shouldContinue, baseStylePackageNames, askStyling, stylingSelect, askAuthentication, authenticationSelect, askInternalization, internalizationSelect;
|
|
46
|
+
return __generator(this, function (_b) {
|
|
47
|
+
switch (_b.label) {
|
|
46
48
|
case 0:
|
|
47
|
-
options = toolbox.parameters.options,
|
|
49
|
+
options = toolbox.parameters.options, _a = toolbox.print, info = _a.info, success = _a.success, warning = _a.warning, highlight = _a.highlight, prompt = toolbox.prompt;
|
|
48
50
|
cliResults = constants_1.defaultOptions;
|
|
49
51
|
// Project name already validated, just set cliResults
|
|
50
52
|
cliResults.projectName = projectName;
|
|
@@ -53,13 +55,53 @@ function runCLI(toolbox, projectName) {
|
|
|
53
55
|
cliResults.packages = [];
|
|
54
56
|
return [4 /*yield*/, prompt.confirm('Would you like to use TypeScript with this project?', true)];
|
|
55
57
|
case 1:
|
|
56
|
-
useTypescript =
|
|
58
|
+
useTypescript = _b.sent();
|
|
57
59
|
if (useTypescript) {
|
|
58
60
|
success('Good call, now using TypeScript! 🚀');
|
|
59
61
|
}
|
|
60
62
|
else {
|
|
61
63
|
success("Wrong answer, we're gonna use Typescript.");
|
|
62
64
|
}
|
|
65
|
+
defaultPackageManagerVersion = (0, getPackageManager_1.getDefaultPackageManagerVersion)();
|
|
66
|
+
if (!cliResults.flags.packageManager) return [3 /*break*/, 6];
|
|
67
|
+
if (!(options.bun || options.pnpm || options.npm || options.yarn)) return [3 /*break*/, 2];
|
|
68
|
+
cliResults.flags.packageManager = options.bun ? 'bun' : options.pnpm ? 'pnpm' : options.npm ? 'npm' : 'yarn';
|
|
69
|
+
return [3 /*break*/, 5];
|
|
70
|
+
case 2:
|
|
71
|
+
highlight("\nWe've detected ".concat(cliResults.flags.packageManager, " ").concat(defaultPackageManagerVersion ? "v".concat(defaultPackageManagerVersion) : '', " as your preferred package manager."));
|
|
72
|
+
return [4 /*yield*/, prompt.confirm("Would you like to continue using it?", true)];
|
|
73
|
+
case 3:
|
|
74
|
+
shouldUseDefaultPackageManager = _b.sent();
|
|
75
|
+
if (!!shouldUseDefaultPackageManager) return [3 /*break*/, 5];
|
|
76
|
+
askPackageManager = {
|
|
77
|
+
type: 'select',
|
|
78
|
+
name: 'packageManagerSelect',
|
|
79
|
+
message: 'Which package manager would you like to use?',
|
|
80
|
+
choices: ['npm', 'yarn', 'pnpm', 'bun']
|
|
81
|
+
};
|
|
82
|
+
return [4 /*yield*/, prompt.ask(askPackageManager)];
|
|
83
|
+
case 4:
|
|
84
|
+
packageManagerSelect = (_b.sent()).packageManagerSelect;
|
|
85
|
+
cliResults.flags.packageManager = packageManagerSelect;
|
|
86
|
+
_b.label = 5;
|
|
87
|
+
case 5: return [3 /*break*/, 9];
|
|
88
|
+
case 6:
|
|
89
|
+
if (!(options.bun || options.pnpm || options.npm || options.yarn)) return [3 /*break*/, 7];
|
|
90
|
+
cliResults.flags.packageManager = options.bun ? 'bun' : options.pnpm ? 'pnpm' : options.npm ? 'npm' : 'yarn';
|
|
91
|
+
return [3 /*break*/, 9];
|
|
92
|
+
case 7:
|
|
93
|
+
askPackageManager = {
|
|
94
|
+
type: 'select',
|
|
95
|
+
name: 'packageManagerSelect',
|
|
96
|
+
message: 'Which package manager would you like to use?',
|
|
97
|
+
choices: ['npm', 'yarn', 'pnpm', 'bun']
|
|
98
|
+
};
|
|
99
|
+
return [4 /*yield*/, prompt.ask(askPackageManager)];
|
|
100
|
+
case 8:
|
|
101
|
+
packageManagerSelect = (_b.sent()).packageManagerSelect;
|
|
102
|
+
cliResults.flags.packageManager = packageManagerSelect;
|
|
103
|
+
_b.label = 9;
|
|
104
|
+
case 9:
|
|
63
105
|
askNavigation = {
|
|
64
106
|
type: 'select',
|
|
65
107
|
name: 'navigationSelect',
|
|
@@ -73,12 +115,12 @@ function runCLI(toolbox, projectName) {
|
|
|
73
115
|
choices: ['Stack', 'Tabs', 'Drawer + Tabs']
|
|
74
116
|
};
|
|
75
117
|
return [4 /*yield*/, prompt.ask(askNavigation)];
|
|
76
|
-
case
|
|
77
|
-
navigationSelect = (
|
|
78
|
-
if (!(navigationSelect !== 'None')) return [3 /*break*/,
|
|
118
|
+
case 10:
|
|
119
|
+
navigationSelect = (_b.sent()).navigationSelect;
|
|
120
|
+
if (!(navigationSelect !== 'None')) return [3 /*break*/, 16];
|
|
79
121
|
return [4 /*yield*/, prompt.ask(askNavigationType)];
|
|
80
|
-
case
|
|
81
|
-
navigationTypeSelect = (
|
|
122
|
+
case 11:
|
|
123
|
+
navigationTypeSelect = (_b.sent()).navigationTypeSelect;
|
|
82
124
|
if (navigationSelect === 'React Navigation') {
|
|
83
125
|
cliResults.packages.push({
|
|
84
126
|
name: 'react-navigation',
|
|
@@ -97,21 +139,68 @@ function runCLI(toolbox, projectName) {
|
|
|
97
139
|
}
|
|
98
140
|
});
|
|
99
141
|
}
|
|
142
|
+
if (!(cliResults.flags.packageManager === 'bun' &&
|
|
143
|
+
defaultPackageManagerVersion &&
|
|
144
|
+
defaultPackageManagerVersion !== recommendedBunVersion)) return [3 /*break*/, 13];
|
|
145
|
+
warning('⚠️' + ' ' + " We've detected you're using Bun v".concat(defaultPackageManagerVersion, "."));
|
|
146
|
+
info('');
|
|
147
|
+
warning("Some packages may not work correctly if you continue. We recommend using Bun v".concat(recommendedBunVersion, " until peerDependencies are properly resolved with bun install."));
|
|
148
|
+
warning("For more information, visit https://github.com/oven-sh/bun/issues/4946");
|
|
149
|
+
info('');
|
|
150
|
+
warning("To switch to Bun v".concat(recommendedBunVersion, ", run:"));
|
|
151
|
+
info('');
|
|
152
|
+
warning("\tcurl -fsSL https://bun.sh/install | bash -s \"bun-v".concat(recommendedBunVersion, "\""));
|
|
153
|
+
info('');
|
|
154
|
+
warning("or visit bun.sh/docs/installation for other installation methods (e.g. via Homebrew, npm, etc).");
|
|
155
|
+
info('');
|
|
156
|
+
return [4 /*yield*/, prompt.confirm("Would you like to continue without switching to Bun v".concat(recommendedBunVersion, "?"), true)];
|
|
157
|
+
case 12:
|
|
158
|
+
shouldContinue = _b.sent();
|
|
159
|
+
if (!shouldContinue) {
|
|
160
|
+
throw new Error("User cancelled to install recommended version of Bun.");
|
|
161
|
+
}
|
|
162
|
+
return [3 /*break*/, 15];
|
|
163
|
+
case 13:
|
|
164
|
+
if (!(cliResults.flags.packageManager === 'bun' && !defaultPackageManagerVersion)) return [3 /*break*/, 15];
|
|
165
|
+
warning('⚠️' + ' ' + " We've detected you're using Bun but we are unable to determine which version you are using.");
|
|
166
|
+
info('');
|
|
167
|
+
warning("We recommend using Bun v".concat(recommendedBunVersion, " until peerDependencies are properly resolved with bun install. If you continue with a version that is not v").concat(recommendedBunVersion, ", some packages may not work correctly."));
|
|
168
|
+
warning("For more information, visit https://github.com/oven-sh/bun/issues/4946");
|
|
169
|
+
info('');
|
|
170
|
+
warning("To check your version of Bun, run:");
|
|
171
|
+
info('');
|
|
172
|
+
warning("\tbun -version");
|
|
173
|
+
info('');
|
|
174
|
+
warning("To switch to Bun v".concat(recommendedBunVersion, ", run:"));
|
|
175
|
+
info('');
|
|
176
|
+
warning("\tcurl -fsSL https://bun.sh/install | bash -s \"bun-v".concat(recommendedBunVersion, "\""));
|
|
177
|
+
info('');
|
|
178
|
+
warning("or visit bun.sh/docs/installation for other installation methods (e.g. via Homebrew, npm, etc).");
|
|
179
|
+
info('');
|
|
180
|
+
return [4 /*yield*/, prompt.confirm('Would you like to continue with your current version of Bun?', true)];
|
|
181
|
+
case 14:
|
|
182
|
+
shouldContinue = _b.sent();
|
|
183
|
+
if (!shouldContinue) {
|
|
184
|
+
throw new Error('User cancelled to install recommended version of Bun.');
|
|
185
|
+
}
|
|
186
|
+
_b.label = 15;
|
|
187
|
+
case 15:
|
|
100
188
|
success("Great, we'll use ".concat(navigationSelect, "!"));
|
|
101
|
-
return [3 /*break*/,
|
|
102
|
-
case
|
|
189
|
+
return [3 /*break*/, 17];
|
|
190
|
+
case 16:
|
|
103
191
|
success("No problem, skipping navigation for now.");
|
|
104
|
-
|
|
105
|
-
case
|
|
192
|
+
_b.label = 17;
|
|
193
|
+
case 17:
|
|
194
|
+
baseStylePackageNames = ['Nativewind', 'Restyle', 'Stylesheet', 'Tamagui (experimental)', 'Unistyles'];
|
|
106
195
|
askStyling = {
|
|
107
196
|
type: 'select',
|
|
108
197
|
name: 'stylingSelect',
|
|
109
198
|
message: 'What would you like to use for styling?',
|
|
110
|
-
choices:
|
|
199
|
+
choices: baseStylePackageNames
|
|
111
200
|
};
|
|
112
201
|
return [4 /*yield*/, prompt.ask(askStyling)];
|
|
113
|
-
case
|
|
114
|
-
stylingSelect = (
|
|
202
|
+
case 18:
|
|
203
|
+
stylingSelect = (_b.sent()).stylingSelect;
|
|
115
204
|
if (stylingSelect === 'Nativewind') {
|
|
116
205
|
cliResults.packages.push({ name: 'nativewind', type: 'styling' });
|
|
117
206
|
success("You'll be styling with ease using Tailwind.");
|
|
@@ -139,8 +228,8 @@ function runCLI(toolbox, projectName) {
|
|
|
139
228
|
choices: ['None', 'Supabase', 'Firebase']
|
|
140
229
|
};
|
|
141
230
|
return [4 /*yield*/, prompt.ask(askAuthentication)];
|
|
142
|
-
case
|
|
143
|
-
authenticationSelect = (
|
|
231
|
+
case 19:
|
|
232
|
+
authenticationSelect = (_b.sent()).authenticationSelect;
|
|
144
233
|
if (authenticationSelect === 'Supabase') {
|
|
145
234
|
cliResults.packages.push({ name: 'supabase', type: 'authentication' });
|
|
146
235
|
success("You'll be using Supabase for authentication.");
|
|
@@ -155,12 +244,12 @@ function runCLI(toolbox, projectName) {
|
|
|
155
244
|
askInternalization = {
|
|
156
245
|
type: 'select',
|
|
157
246
|
name: 'internalizationSelect',
|
|
158
|
-
message: 'What would you like to
|
|
159
|
-
choices: ['
|
|
247
|
+
message: 'What would you like to support internationalization?',
|
|
248
|
+
choices: ['None', 'i18next']
|
|
160
249
|
};
|
|
161
250
|
return [4 /*yield*/, prompt.ask(askInternalization)];
|
|
162
|
-
case
|
|
163
|
-
internalizationSelect = (
|
|
251
|
+
case 20:
|
|
252
|
+
internalizationSelect = (_b.sent()).internalizationSelect;
|
|
164
253
|
if (internalizationSelect === 'i18next') {
|
|
165
254
|
cliResults.packages.push({ name: 'i18next', type: 'internationalization' });
|
|
166
255
|
success("You'll be using i18next for internationalization.");
|
|
@@ -168,25 +257,10 @@ function runCLI(toolbox, projectName) {
|
|
|
168
257
|
else {
|
|
169
258
|
success("No problem, skipping internationalization for now.");
|
|
170
259
|
}
|
|
171
|
-
|
|
172
|
-
askPackageManager = {
|
|
173
|
-
type: 'select',
|
|
174
|
-
name: 'packageManagerSelect',
|
|
175
|
-
message: 'Which package manager would you like to use?',
|
|
176
|
-
choices: ['npm', 'yarn', 'pnpm', 'bun']
|
|
177
|
-
};
|
|
178
|
-
return [4 /*yield*/, prompt.ask(askPackageManager)];
|
|
179
|
-
case 9:
|
|
180
|
-
packageManagerSelect = (_a.sent()).packageManagerSelect;
|
|
181
|
-
cliResults.flags.packageManager = packageManagerSelect;
|
|
182
|
-
return [3 /*break*/, 11];
|
|
183
|
-
case 10:
|
|
184
|
-
cliResults.flags.packageManager = 'npm';
|
|
185
|
-
_a.label = 11;
|
|
186
|
-
case 11: return [2 /*return*/, cliResults];
|
|
260
|
+
return [2 /*return*/, cliResults];
|
|
187
261
|
}
|
|
188
262
|
});
|
|
189
263
|
});
|
|
190
264
|
}
|
|
191
265
|
exports.runCLI = runCLI;
|
|
192
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
266
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"runCLI.js","sourceRoot":"","sources":["../../src/utilities/runCLI.ts"],"names":[],"mappings":"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"}
|
|
@@ -37,7 +37,7 @@ var __generator = (this && this.__generator) || function (thisArg, body) {
|
|
|
37
37
|
};
|
|
38
38
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
39
39
|
exports.validateProjectName = void 0;
|
|
40
|
-
function validateProjectName(exists, removeAsync, prompt, projectName) {
|
|
40
|
+
function validateProjectName(exists, removeAsync, prompt, projectName, success, overwrite) {
|
|
41
41
|
return __awaiter(this, void 0, void 0, function () {
|
|
42
42
|
var confirmDelete;
|
|
43
43
|
return __generator(this, function (_a) {
|
|
@@ -46,7 +46,13 @@ function validateProjectName(exists, removeAsync, prompt, projectName) {
|
|
|
46
46
|
if (!exists(projectName)) {
|
|
47
47
|
return [2 /*return*/];
|
|
48
48
|
}
|
|
49
|
-
if (!(
|
|
49
|
+
if (!(overwrite || (exists(projectName) === 'dir' && !prompt))) return [3 /*break*/, 2];
|
|
50
|
+
return [4 /*yield*/, removeAsync(projectName)];
|
|
51
|
+
case 1:
|
|
52
|
+
_a.sent();
|
|
53
|
+
return [2 /*return*/];
|
|
54
|
+
case 2:
|
|
55
|
+
if (!(prompt != null)) return [3 /*break*/, 5];
|
|
50
56
|
return [4 /*yield*/, prompt.ask([
|
|
51
57
|
{
|
|
52
58
|
type: 'confirm',
|
|
@@ -54,17 +60,17 @@ function validateProjectName(exists, removeAsync, prompt, projectName) {
|
|
|
54
60
|
message: "A folder with the name '".concat(projectName, "' already exists. Do you want to delete it?")
|
|
55
61
|
}
|
|
56
62
|
])];
|
|
57
|
-
case
|
|
63
|
+
case 3:
|
|
58
64
|
confirmDelete = _a.sent();
|
|
59
|
-
if (!confirmDelete.delete) return [3 /*break*/,
|
|
65
|
+
if (!confirmDelete.delete) return [3 /*break*/, 5];
|
|
60
66
|
return [4 /*yield*/, removeAsync(projectName)];
|
|
61
|
-
case
|
|
67
|
+
case 4:
|
|
62
68
|
_a.sent();
|
|
63
|
-
return [2 /*return*/, void
|
|
64
|
-
case
|
|
69
|
+
return [2 /*return*/, void success("Deleted existing directory: ".concat(projectName))];
|
|
70
|
+
case 5: throw new Error("A project with the name '".concat(projectName, "' already exists."));
|
|
65
71
|
}
|
|
66
72
|
});
|
|
67
73
|
});
|
|
68
74
|
}
|
|
69
75
|
exports.validateProjectName = validateProjectName;
|
|
70
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
76
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFsaWRhdGVQcm9qZWN0TmFtZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlsaXRpZXMvdmFsaWRhdGVQcm9qZWN0TmFtZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFHQSxTQUFzQixtQkFBbUIsQ0FDdkMsTUFBc0MsRUFDdEMsV0FBNkMsRUFDN0MsTUFBNEIsRUFDNUIsV0FBbUIsRUFDbkIsT0FBa0MsRUFDbEMsU0FBa0I7Ozs7OztvQkFFbEIsSUFBSSxDQUFDLE1BQU0sQ0FBQyxXQUFXLENBQUMsRUFBRSxDQUFDO3dCQUN6QixzQkFBTztvQkFDVCxDQUFDO3lCQUVHLENBQUEsU0FBUyxJQUFJLENBQUMsTUFBTSxDQUFDLFdBQVcsQ0FBQyxLQUFLLEtBQUssSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFBLEVBQXZELHdCQUF1RDtvQkFDekQscUJBQU0sV0FBVyxDQUFDLFdBQVcsQ0FBQyxFQUFBOztvQkFBOUIsU0FBOEIsQ0FBQztvQkFDL0Isc0JBQU87O3lCQUdMLENBQUEsTUFBTSxJQUFJLElBQUksQ0FBQSxFQUFkLHdCQUFjO29CQUNNLHFCQUFNLE1BQU0sQ0FBQyxHQUFHLENBQUM7NEJBQ3JDO2dDQUNFLElBQUksRUFBRSxTQUFTO2dDQUNmLElBQUksRUFBRSxRQUFRO2dDQUNkLE9BQU8sRUFBRSxrQ0FBMkIsV0FBVyxnREFBNkM7NkJBQzdGO3lCQUNGLENBQUMsRUFBQTs7b0JBTkksYUFBYSxHQUFHLFNBTXBCO3lCQUVFLGFBQWEsQ0FBQyxNQUFNLEVBQXBCLHdCQUFvQjtvQkFDdEIscUJBQU0sV0FBVyxDQUFDLFdBQVcsQ0FBQyxFQUFBOztvQkFBOUIsU0FBOEIsQ0FBQztvQkFDL0Isc0JBQU8sS0FBSyxPQUFPLENBQUMsc0NBQStCLFdBQVcsQ0FBRSxDQUFDLEVBQUM7d0JBSXRFLE1BQU0sSUFBSSxLQUFLLENBQUMsbUNBQTRCLFdBQVcsc0JBQW1CLENBQUMsQ0FBQzs7OztDQUM3RTtBQWpDRCxrREFpQ0MifQ==
|
package/package.json
CHANGED
|
@@ -1,68 +1,68 @@
|
|
|
1
1
|
{
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
2
|
+
"name": "create-expo-stack",
|
|
3
|
+
"version": "2.5.0",
|
|
4
|
+
"description": "CLI tool to initialize a React Native application with Expo",
|
|
5
|
+
"repository": {
|
|
6
|
+
"type": "git",
|
|
7
|
+
"url": "https://github.com/danstepanov/create-expo-stack.git",
|
|
8
|
+
"directory": "cli"
|
|
9
|
+
},
|
|
10
|
+
"homepage": "https://createexpostack.com",
|
|
11
|
+
"license": "MIT",
|
|
12
|
+
"types": "build/types/types.d.ts",
|
|
13
|
+
"bin": {
|
|
14
|
+
"create-expo-stack": "bin/create-expo-stack.js"
|
|
15
|
+
},
|
|
16
|
+
"files": [
|
|
17
|
+
"build",
|
|
18
|
+
"LICENSE",
|
|
19
|
+
"readme.md",
|
|
20
|
+
"docs",
|
|
21
|
+
"bin"
|
|
22
|
+
],
|
|
23
|
+
"scripts": {
|
|
24
|
+
"build": "bun run clean-build && bun run compile && bun run copy-templates && bun run lint-templates",
|
|
25
|
+
"bump": "bun run ./src/utilities/bumpVersion.ts",
|
|
26
|
+
"clean-build": "rm -rf ./build",
|
|
27
|
+
"compile": "tsc -p .",
|
|
28
|
+
"copy-templates": "bun run copyfiles -u 2 -a \"./src/templates/**/*\" ./build/templates",
|
|
29
|
+
"format": "eslint \"**/*.{js,jsx,ts,tsx}\" --fix --resolve-plugins-relative-to . && prettier \"**/*.{js,jsx,ts,tsx,json}\" --write",
|
|
30
|
+
"lint-templates": "bun run ejslint ./src/templates",
|
|
31
|
+
"prepublishOnly": "bun run build",
|
|
32
|
+
"publishPublic": "bun run build && npm publish --access public",
|
|
33
|
+
"snapupdate": "jest --updateSnapshot",
|
|
34
|
+
"test:watch": "bun test --watch",
|
|
35
|
+
"test": "bun test --timeout 30000"
|
|
36
|
+
},
|
|
37
|
+
"prettier": {
|
|
38
|
+
"arrowParens": "always",
|
|
39
|
+
"bracketSameLine": false,
|
|
40
|
+
"bracketSpacing": true,
|
|
41
|
+
"printWidth": 120,
|
|
42
|
+
"semi": true,
|
|
43
|
+
"singleQuote": true,
|
|
44
|
+
"tabWidth": 2,
|
|
45
|
+
"trailingComma": "none",
|
|
46
|
+
"useTabs": false
|
|
47
|
+
},
|
|
48
|
+
"dependencies": {
|
|
49
|
+
"ejs-lint": "^2.0.0",
|
|
50
|
+
"figlet": "^1.6.0",
|
|
51
|
+
"gluegun": "latest",
|
|
52
|
+
"gradient-string": "^2.0.2"
|
|
53
|
+
},
|
|
54
|
+
"devDependencies": {
|
|
55
|
+
"@types/gradient-string": "^1.1.2",
|
|
56
|
+
"@typescript-eslint/eslint-plugin": "^6.9.1",
|
|
57
|
+
"@typescript-eslint/parser": "^6.9.1",
|
|
58
|
+
"copyfiles": "^2.4.1",
|
|
59
|
+
"eslint": "^8.53.0",
|
|
60
|
+
"eslint-config-prettier": "^9.0.0",
|
|
61
|
+
"eslint-plugin-prettier": "^5.0.1",
|
|
62
|
+
"husky": "^5.1.3",
|
|
63
|
+
"prettier": "^3.1.0"
|
|
64
|
+
},
|
|
65
|
+
"publishConfig": {
|
|
66
|
+
"provenance": false
|
|
67
|
+
}
|
|
68
68
|
}
|