@shopify/create-app 3.35.0 → 3.36.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/dist/commands/init.d.ts +2 -0
- package/dist/commands/init.js +6 -3
- package/dist/commands/init.js.map +1 -1
- package/dist/prompts/init.js +5 -2
- package/dist/prompts/init.js.map +1 -1
- package/dist/services/init.js +58 -92
- package/dist/services/init.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/dist/utils/template/cleanup.js +9 -9
- package/dist/utils/template/cleanup.js.map +1 -1
- package/dist/utils/template/npm.d.ts +6 -7
- package/dist/utils/template/npm.js +20 -32
- package/dist/utils/template/npm.js.map +1 -1
- package/dist/utils/versions.js +7 -6
- package/dist/utils/versions.js.map +1 -1
- package/oclif.manifest.json +1 -1
- package/package.json +2 -2
package/dist/commands/init.d.ts
CHANGED
package/dist/commands/init.js
CHANGED
|
@@ -2,12 +2,15 @@ import initPrompt, { templateURLMap } from '../prompts/init.js';
|
|
|
2
2
|
import initService from '../services/init.js';
|
|
3
3
|
import { Flags } from '@oclif/core';
|
|
4
4
|
import { globalFlags } from '@shopify/cli-kit/node/cli';
|
|
5
|
-
import {
|
|
5
|
+
import { error, output } from '@shopify/cli-kit';
|
|
6
6
|
import Command from '@shopify/cli-kit/node/base-command';
|
|
7
|
+
import { resolvePath } from '@shopify/cli-kit/node/path';
|
|
8
|
+
// eslint-disable-next-line node/prefer-global/url
|
|
9
|
+
import { URL } from 'url';
|
|
7
10
|
export default class Init extends Command {
|
|
8
11
|
async run() {
|
|
9
12
|
const { flags } = await this.parse(Init);
|
|
10
|
-
const directory = flags.path ?
|
|
13
|
+
const directory = flags.path ? resolvePath(flags.path) : process.cwd();
|
|
11
14
|
this.validateTemplateValue(flags.template);
|
|
12
15
|
const promptAnswers = await initPrompt({
|
|
13
16
|
name: flags.name,
|
|
@@ -56,7 +59,7 @@ Init.flags = {
|
|
|
56
59
|
path: Flags.string({
|
|
57
60
|
char: 'p',
|
|
58
61
|
env: 'SHOPIFY_FLAG_PATH',
|
|
59
|
-
parse: (input, _) => Promise.resolve(
|
|
62
|
+
parse: (input, _) => Promise.resolve(resolvePath(input)),
|
|
60
63
|
hidden: false,
|
|
61
64
|
}),
|
|
62
65
|
template: Flags.string({
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"init.js","sourceRoot":"","sources":["../../src/commands/init.ts"],"names":[],"mappings":"AAAA,OAAO,UAAU,EAAE,EAAC,cAAc,EAAC,MAAM,oBAAoB,CAAA;AAC7D,OAAO,WAAW,MAAM,qBAAqB,CAAA;AAC7C,OAAO,EAAC,KAAK,EAAC,MAAM,aAAa,CAAA;AACjC,OAAO,EAAC,WAAW,EAAC,MAAM,2BAA2B,CAAA;AACrD,OAAO,EAAC,
|
|
1
|
+
{"version":3,"file":"init.js","sourceRoot":"","sources":["../../src/commands/init.ts"],"names":[],"mappings":"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","sourcesContent":["import initPrompt, {templateURLMap} from '../prompts/init.js'\nimport initService from '../services/init.js'\nimport {Flags} from '@oclif/core'\nimport {globalFlags} from '@shopify/cli-kit/node/cli'\nimport {error, output} from '@shopify/cli-kit'\nimport Command from '@shopify/cli-kit/node/base-command'\nimport {resolvePath} from '@shopify/cli-kit/node/path'\n// eslint-disable-next-line node/prefer-global/url\nimport {URL} from 'url'\n\nexport default class Init extends Command {\n static aliases = ['create-app']\n\n static flags = {\n ...globalFlags,\n name: Flags.string({\n char: 'n',\n env: 'SHOPIFY_FLAG_NAME',\n hidden: false,\n }),\n path: Flags.string({\n char: 'p',\n env: 'SHOPIFY_FLAG_PATH',\n parse: (input, _) => Promise.resolve(resolvePath(input)),\n hidden: false,\n }),\n template: Flags.string({\n description: `The app template. Accepts one of the following:\n - <${Object.keys(templateURLMap).join('|')}>\n - Any GitHub repo with optional branch and subpath, e.g., https://github.com/Shopify/<repository>/[subpath]#[branch]`,\n env: 'SHOPIFY_FLAG_TEMPLATE',\n }),\n 'package-manager': Flags.string({\n char: 'd',\n env: 'SHOPIFY_FLAG_PACKAGE_MANAGER',\n hidden: false,\n options: ['npm', 'yarn', 'pnpm'],\n }),\n local: Flags.boolean({\n char: 'l',\n env: 'SHOPIFY_FLAG_LOCAL',\n default: false,\n hidden: true,\n }),\n }\n\n async run(): Promise<void> {\n const {flags} = await this.parse(Init)\n const directory = flags.path ? resolvePath(flags.path) : process.cwd()\n\n this.validateTemplateValue(flags.template)\n\n const promptAnswers = await initPrompt({\n name: flags.name,\n template: flags.template,\n directory,\n })\n\n await initService({\n name: promptAnswers.name,\n packageManager: flags['package-manager'],\n template: promptAnswers.template,\n local: flags.local,\n directory,\n })\n }\n\n validateTemplateValue(template: string | undefined) {\n if (!template) {\n return\n }\n\n const url = this.parseURL(template)\n if (url && url.origin !== 'https://github.com')\n throw new error.Abort(\n 'Only GitHub repository references are supported, ' +\n 'e.g., https://github.com/Shopify/<repository>/[subpath]#[branch]',\n )\n if (!url && !Object.keys(templateURLMap).includes(template))\n throw new error.Abort(\n output.content`Only ${Object.keys(templateURLMap)\n .map((alias) => output.content`${output.token.yellow(alias)}`.value)\n .join(', ')} template aliases are supported`,\n )\n }\n\n parseURL(url: string): URL | undefined {\n try {\n return new URL(url)\n // eslint-disable-next-line no-catch-all/no-catch-all\n } catch (error) {\n return undefined\n }\n }\n}\n"]}
|
package/dist/prompts/init.js
CHANGED
|
@@ -17,7 +17,7 @@ const init = async (options, prompt = ui.prompt) => {
|
|
|
17
17
|
questions.push({
|
|
18
18
|
type: 'input',
|
|
19
19
|
name: 'name',
|
|
20
|
-
preface: '\nWelcome. Let’s get started by naming your app. You can change it later
|
|
20
|
+
preface: '\nWelcome. Let’s get started by naming your app. You can change it later.\n',
|
|
21
21
|
message: "Your app's name?",
|
|
22
22
|
default: defaults.name,
|
|
23
23
|
validate: (value) => {
|
|
@@ -27,6 +27,9 @@ const init = async (options, prompt = ui.prompt) => {
|
|
|
27
27
|
if (value.length > 30) {
|
|
28
28
|
return 'Enter a shorter name (30 character max.)';
|
|
29
29
|
}
|
|
30
|
+
if (value.toLowerCase().includes('shopify')) {
|
|
31
|
+
return "App Name can't include the word 'shopify'";
|
|
32
|
+
}
|
|
30
33
|
return true;
|
|
31
34
|
},
|
|
32
35
|
});
|
|
@@ -43,7 +46,7 @@ const init = async (options, prompt = ui.prompt) => {
|
|
|
43
46
|
name: 'template',
|
|
44
47
|
choices: templateList,
|
|
45
48
|
message: 'Which template would you like to use?',
|
|
46
|
-
default: defaults.template,
|
|
49
|
+
default: Object.keys(templateURLMap).find((key) => templateURLMap[key] === defaults.template),
|
|
47
50
|
});
|
|
48
51
|
}
|
|
49
52
|
const promptOutput = await prompt(questions);
|
package/dist/prompts/init.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"init.js","sourceRoot":"","sources":["../../src/prompts/init.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,EAAE,EAAC,MAAM,kBAAkB,CAAA;AACnC,OAAO,EAAC,iCAAiC,EAAC,MAAM,0BAA0B,CAAA;AAa1E,8DAA8D;AAC9D,wEAAwE;AACxE,MAAM,CAAC,MAAM,cAAc,GAAG;IAC5B,IAAI,EAAE,sDAAsD;IAC5D,GAAG,EAAE,qDAAqD;IAC1D,IAAI,EAAE,sDAAsD;CACpD,CAAA;AAEV,MAAM,IAAI,GAAG,KAAK,EAAE,OAAoB,EAAE,MAAM,GAAG,EAAE,CAAC,MAAM,EAAuB,EAAE;IACnF,MAAM,QAAQ,GAAG;QACf,IAAI,EAAE,MAAM,iCAAiC,CAAC,EAAC,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,OAAO,CAAC,SAAS,EAAC,CAAC;QAC5F,QAAQ,EAAE,cAAc,CAAC,IAAI;KACrB,CAAA;IAEV,MAAM,SAAS,GAAuC,EAAE,CAAA;IACxD,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE;QACjB,SAAS,CAAC,IAAI,CAAC;YACb,IAAI,EAAE,OAAO;YACb,IAAI,EAAE,MAAM;YACZ,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"init.js","sourceRoot":"","sources":["../../src/prompts/init.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,EAAE,EAAC,MAAM,kBAAkB,CAAA;AACnC,OAAO,EAAC,iCAAiC,EAAC,MAAM,0BAA0B,CAAA;AAa1E,8DAA8D;AAC9D,wEAAwE;AACxE,MAAM,CAAC,MAAM,cAAc,GAAG;IAC5B,IAAI,EAAE,sDAAsD;IAC5D,GAAG,EAAE,qDAAqD;IAC1D,IAAI,EAAE,sDAAsD;CACpD,CAAA;AAEV,MAAM,IAAI,GAAG,KAAK,EAAE,OAAoB,EAAE,MAAM,GAAG,EAAE,CAAC,MAAM,EAAuB,EAAE;IACnF,MAAM,QAAQ,GAAG;QACf,IAAI,EAAE,MAAM,iCAAiC,CAAC,EAAC,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,OAAO,CAAC,SAAS,EAAC,CAAC;QAC5F,QAAQ,EAAE,cAAc,CAAC,IAAI;KACrB,CAAA;IAEV,MAAM,SAAS,GAAuC,EAAE,CAAA;IACxD,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE;QACjB,SAAS,CAAC,IAAI,CAAC;YACb,IAAI,EAAE,OAAO;YACb,IAAI,EAAE,MAAM;YACZ,OAAO,EAAE,6EAA6E;YACtF,OAAO,EAAE,kBAAkB;YAC3B,OAAO,EAAE,QAAQ,CAAC,IAAI;YACtB,QAAQ,EAAE,CAAC,KAAK,EAAE,EAAE;gBAClB,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE;oBACtB,OAAO,yBAAyB,CAAA;iBACjC;gBACD,IAAI,KAAK,CAAC,MAAM,GAAG,EAAE,EAAE;oBACrB,OAAO,0CAA0C,CAAA;iBAClD;gBACD,IAAI,KAAK,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,SAAS,CAAC,EAAE;oBAC3C,OAAO,2CAA2C,CAAA;iBACnD;gBACD,OAAO,IAAI,CAAA;YACb,CAAC;SACF,CAAC,CAAA;KACH;IAED,IAAI,CAAC,OAAO,CAAC,QAAQ,IAAI,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE;QAC/D,MAAM,YAAY,GAAG,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE;YAC3D,OAAO;gBACL,IAAI,EAAE,GAAG;gBACT,KAAK,EAAE,GAAG;aACX,CAAA;QACH,CAAC,CAAC,CAAA;QACF,SAAS,CAAC,IAAI,CAAC;YACb,IAAI,EAAE,QAAQ;YACd,IAAI,EAAE,UAAU;YAChB,OAAO,EAAE,YAAY;YACrB,OAAO,EAAE,uCAAuC;YAChD,OAAO,EAAE,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,IAAI,CACvC,CAAC,GAAG,EAAE,EAAE,CAAC,cAAc,CAAC,GAA8B,CAAC,KAAK,QAAQ,CAAC,QAAQ,CAC9E;SACF,CAAC,CAAA;KACH;IAED,MAAM,YAAY,GAAe,MAAM,MAAM,CAAC,SAAS,CAAC,CAAA;IACxD,MAAM,OAAO,GAAG;QACd,GAAG,OAAO;QACV,GAAG,YAAY;KAChB,CAAA;IAED,MAAM,WAAW,GAAG,cAAc,CAAC,OAAO,CAAC,QAAuC,CAAC,CAAA;IACnF,OAAO,CAAC,QAAQ,GAAG,WAAW,IAAI,OAAO,CAAC,QAAQ,IAAI,QAAQ,CAAC,QAAQ,CAAA;IAEvE,OAAO,OAAO,CAAA;AAChB,CAAC,CAAA;AAED,eAAe,IAAI,CAAA","sourcesContent":["import {ui} from '@shopify/cli-kit'\nimport {generateRandomNameForSubdirectory} from '@shopify/cli-kit/node/fs'\n\ninterface InitOptions {\n name?: string\n template?: string\n directory: string\n}\n\ninterface InitOutput {\n name: string\n template: string\n}\n\n// Eventually this list should be taken from a remote location\n// That way we don't have to update the CLI every time we add a template\nexport const templateURLMap = {\n node: 'https://github.com/Shopify/shopify-app-template-node',\n php: 'https://github.com/Shopify/shopify-app-template-php',\n ruby: 'https://github.com/Shopify/shopify-app-template-ruby',\n} as const\n\nconst init = async (options: InitOptions, prompt = ui.prompt): Promise<InitOutput> => {\n const defaults = {\n name: await generateRandomNameForSubdirectory({suffix: 'app', directory: options.directory}),\n template: templateURLMap.node,\n } as const\n\n const questions: ui.Question<'name' | 'template'>[] = []\n if (!options.name) {\n questions.push({\n type: 'input',\n name: 'name',\n preface: '\\nWelcome. Let’s get started by naming your app. You can change it later.\\n',\n message: \"Your app's name?\",\n default: defaults.name,\n validate: (value) => {\n if (value.length === 0) {\n return \"App Name can't be empty\"\n }\n if (value.length > 30) {\n return 'Enter a shorter name (30 character max.)'\n }\n if (value.toLowerCase().includes('shopify')) {\n return \"App Name can't include the word 'shopify'\"\n }\n return true\n },\n })\n }\n\n if (!options.template && Object.keys(templateURLMap).length > 1) {\n const templateList = Object.keys(templateURLMap).map((key) => {\n return {\n name: key,\n value: key,\n }\n })\n questions.push({\n type: 'select',\n name: 'template',\n choices: templateList,\n message: 'Which template would you like to use?',\n default: Object.keys(templateURLMap).find(\n (key) => templateURLMap[key as 'node' | 'php' | 'ruby'] === defaults.template,\n ),\n })\n }\n\n const promptOutput: InitOutput = await prompt(questions)\n const answers = {\n ...options,\n ...promptOutput,\n }\n\n const templateURL = templateURLMap[answers.template as keyof typeof templateURLMap]\n answers.template = templateURL || answers.template || defaults.template\n\n return answers\n}\n\nexport default init\n"]}
|
package/dist/services/init.js
CHANGED
|
@@ -1,127 +1,93 @@
|
|
|
1
1
|
import { getDeepInstallNPMTasks, updateCLIDependencies } from '../utils/template/npm.js';
|
|
2
2
|
import cleanup from '../utils/template/cleanup.js';
|
|
3
|
-
import {
|
|
4
|
-
import { packageManager, packageManagerUsedForCreating } from '@shopify/cli-kit/node/node-package-manager';
|
|
5
|
-
import { renderSuccess } from '@shopify/cli-kit/node/ui';
|
|
3
|
+
import { error, output } from '@shopify/cli-kit';
|
|
4
|
+
import { findUpAndReadPackageJson, packageManager, packageManagerUsedForCreating, writePackageJSON, } from '@shopify/cli-kit/node/node-package-manager';
|
|
5
|
+
import { renderSuccess, renderTasks } from '@shopify/cli-kit/node/ui';
|
|
6
6
|
import { parseGitHubRepositoryReference } from '@shopify/cli-kit/node/github';
|
|
7
7
|
import { hyphenate } from '@shopify/cli-kit/common/string';
|
|
8
8
|
import { recursiveLiquidTemplateCopy } from '@shopify/cli-kit/node/liquid';
|
|
9
|
-
import { isShopify
|
|
9
|
+
import { isShopify } from '@shopify/cli-kit/node/environment/local';
|
|
10
10
|
import { downloadGitRepository, initializeGitRepository } from '@shopify/cli-kit/node/git';
|
|
11
11
|
import { appendFile, fileExists, inTemporaryDirectory, mkdir, moveFile } from '@shopify/cli-kit/node/fs';
|
|
12
|
+
import { joinPath } from '@shopify/cli-kit/node/path';
|
|
13
|
+
import { username } from '@shopify/cli-kit/node/os';
|
|
12
14
|
async function init(options) {
|
|
13
15
|
const packageManager = inferPackageManager(options.packageManager);
|
|
14
16
|
const hyphenizedName = hyphenate(options.name);
|
|
15
|
-
const outputDirectory =
|
|
17
|
+
const outputDirectory = joinPath(options.directory, hyphenizedName);
|
|
16
18
|
const githubRepo = parseGitHubRepositoryReference(options.template);
|
|
17
19
|
await ensureAppDirectoryIsAvailable(outputDirectory, hyphenizedName);
|
|
18
20
|
await inTemporaryDirectory(async (tmpDir) => {
|
|
19
|
-
const templateDownloadDir =
|
|
21
|
+
const templateDownloadDir = joinPath(tmpDir, 'download');
|
|
20
22
|
const templatePathDir = githubRepo.filePath
|
|
21
|
-
?
|
|
23
|
+
? joinPath(templateDownloadDir, githubRepo.filePath)
|
|
22
24
|
: templateDownloadDir;
|
|
23
|
-
const templateScaffoldDir =
|
|
25
|
+
const templateScaffoldDir = joinPath(tmpDir, 'app');
|
|
24
26
|
const repoUrl = githubRepo.branch ? `${githubRepo.baseURL}#${githubRepo.branch}` : githubRepo.baseURL;
|
|
25
27
|
await mkdir(templateDownloadDir);
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
28
|
+
const tasks = [
|
|
29
|
+
{
|
|
30
|
+
title: `Downloading template from ${repoUrl}`,
|
|
31
|
+
task: async () => {
|
|
32
|
+
await downloadGitRepository({
|
|
33
|
+
repoUrl,
|
|
34
|
+
destination: templateDownloadDir,
|
|
35
|
+
shallow: true,
|
|
36
|
+
});
|
|
37
|
+
},
|
|
38
|
+
},
|
|
39
|
+
];
|
|
40
|
+
tasks.push({
|
|
41
|
+
title: 'Parsing liquid',
|
|
29
42
|
task: async () => {
|
|
30
|
-
await
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
shallow: true,
|
|
43
|
+
await recursiveLiquidTemplateCopy(templatePathDir, templateScaffoldDir, {
|
|
44
|
+
dependency_manager: packageManager,
|
|
45
|
+
app_name: options.name,
|
|
34
46
|
});
|
|
35
|
-
return { successMessage: `Downloaded template from ${repoUrl}` };
|
|
36
47
|
},
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
{
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
app_name: options.name,
|
|
51
|
-
});
|
|
52
|
-
task.title = 'Liquid parsed';
|
|
53
|
-
},
|
|
54
|
-
},
|
|
55
|
-
{
|
|
56
|
-
title: 'Update package.json',
|
|
57
|
-
task: async (_, task) => {
|
|
58
|
-
task.title = 'Updating package.json';
|
|
59
|
-
const packageJSON = await npm.readPackageJSON(templateScaffoldDir);
|
|
60
|
-
await npm.updateAppData(packageJSON, hyphenizedName);
|
|
61
|
-
await updateCLIDependencies({ packageJSON, local: options.local, directory: templateScaffoldDir });
|
|
62
|
-
await npm.writePackageJSON(templateScaffoldDir, packageJSON);
|
|
63
|
-
// Ensure that the installation of dependencies doesn't fail when using
|
|
64
|
-
// pnpm due to missing peerDependencies.
|
|
65
|
-
if (packageManager === 'pnpm') {
|
|
66
|
-
await appendFile(path.join(templateScaffoldDir, '.npmrc'), `auto-install-peers=true\n`);
|
|
67
|
-
}
|
|
68
|
-
task.title = 'Updated package.json';
|
|
69
|
-
parentTask.title = 'App initialized';
|
|
70
|
-
},
|
|
71
|
-
},
|
|
72
|
-
]);
|
|
73
|
-
},
|
|
48
|
+
}, {
|
|
49
|
+
title: 'Updating package.json',
|
|
50
|
+
task: async () => {
|
|
51
|
+
const packageJSON = (await findUpAndReadPackageJson(templateScaffoldDir)).content;
|
|
52
|
+
packageJSON.name = hyphenizedName;
|
|
53
|
+
packageJSON.author = (await username()) ?? '';
|
|
54
|
+
await updateCLIDependencies({ packageJSON, local: options.local, directory: templateScaffoldDir });
|
|
55
|
+
await writePackageJSON(templateScaffoldDir, packageJSON);
|
|
56
|
+
// Ensure that the installation of dependencies doesn't fail when using
|
|
57
|
+
// pnpm due to missing peerDependencies.
|
|
58
|
+
if (packageManager === 'pnpm') {
|
|
59
|
+
await appendFile(joinPath(templateScaffoldDir, '.npmrc'), `auto-install-peers=true\n`);
|
|
60
|
+
}
|
|
74
61
|
},
|
|
75
|
-
|
|
62
|
+
});
|
|
76
63
|
if (await isShopify()) {
|
|
77
64
|
tasks.push({
|
|
78
|
-
title: "[Shopifolks-only]
|
|
79
|
-
task: async (
|
|
80
|
-
|
|
81
|
-
const npmrcPath = path.join(templateScaffoldDir, '.npmrc');
|
|
65
|
+
title: "[Shopifolks-only] Configuring the project's NPM registry",
|
|
66
|
+
task: async () => {
|
|
67
|
+
const npmrcPath = joinPath(templateScaffoldDir, '.npmrc');
|
|
82
68
|
const npmrcContent = `@shopify:registry=https://registry.npmjs.org\n`;
|
|
83
69
|
await appendFile(npmrcPath, npmrcContent);
|
|
84
|
-
task.title = "[Shopifolks-only] Project's NPM registry configured.";
|
|
85
70
|
},
|
|
86
71
|
});
|
|
87
72
|
}
|
|
88
|
-
tasks
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
function didInstallEverything() {
|
|
94
|
-
parentTask.title = `Dependencies installed with ${packageManager}`;
|
|
95
|
-
}
|
|
96
|
-
return parentTask.newListr(await getDeepInstallNPMTasks({
|
|
97
|
-
from: templateScaffoldDir,
|
|
98
|
-
packageManager,
|
|
99
|
-
didInstallEverything,
|
|
100
|
-
}), { concurrent: false });
|
|
101
|
-
},
|
|
73
|
+
tasks.push({
|
|
74
|
+
title: 'Installing dependencies',
|
|
75
|
+
task: async () => {
|
|
76
|
+
const subtasks = await getDeepInstallNPMTasks({ from: templateScaffoldDir, packageManager });
|
|
77
|
+
return subtasks;
|
|
102
78
|
},
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
await cleanup(templateScaffoldDir);
|
|
108
|
-
task.title = 'Completed clean up';
|
|
109
|
-
},
|
|
79
|
+
}, {
|
|
80
|
+
title: 'Cleaning up',
|
|
81
|
+
task: async () => {
|
|
82
|
+
await cleanup(templateScaffoldDir);
|
|
110
83
|
},
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
task.title = 'Git repository initialized';
|
|
116
|
-
},
|
|
84
|
+
}, {
|
|
85
|
+
title: 'Initializing a Git repository...',
|
|
86
|
+
task: async () => {
|
|
87
|
+
await initializeGitRepository(templateScaffoldDir);
|
|
117
88
|
},
|
|
118
|
-
]);
|
|
119
|
-
const list = ui.newListr(tasks, {
|
|
120
|
-
concurrent: false,
|
|
121
|
-
rendererOptions: { collapse: false },
|
|
122
|
-
rendererSilent: isUnitTest(),
|
|
123
89
|
});
|
|
124
|
-
await
|
|
90
|
+
await renderTasks(tasks);
|
|
125
91
|
await moveFile(templateScaffoldDir, outputDirectory);
|
|
126
92
|
});
|
|
127
93
|
renderSuccess({
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"init.js","sourceRoot":"","sources":["../../src/services/init.ts"],"names":[],"mappings":"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","sourcesContent":["import {getDeepInstallNPMTasks, updateCLIDependencies} from '../utils/template/npm.js'\nimport cleanup from '../utils/template/cleanup.js'\n\nimport {path, ui, npm, error, output} from '@shopify/cli-kit'\nimport {packageManager, PackageManager, packageManagerUsedForCreating} from '@shopify/cli-kit/node/node-package-manager'\nimport {renderSuccess} from '@shopify/cli-kit/node/ui'\nimport {parseGitHubRepositoryReference} from '@shopify/cli-kit/node/github'\nimport {hyphenate} from '@shopify/cli-kit/common/string'\nimport {recursiveLiquidTemplateCopy} from '@shopify/cli-kit/node/liquid'\nimport {isShopify, isUnitTest} from '@shopify/cli-kit/node/environment/local'\nimport {downloadGitRepository, initializeGitRepository} from '@shopify/cli-kit/node/git'\nimport {appendFile, fileExists, inTemporaryDirectory, mkdir, moveFile} from '@shopify/cli-kit/node/fs'\n\ninterface InitOptions {\n name: string\n directory: string\n template: string\n packageManager: string | undefined\n local: boolean\n}\n\nasync function init(options: InitOptions) {\n const packageManager: PackageManager = inferPackageManager(options.packageManager)\n const hyphenizedName = hyphenate(options.name)\n const outputDirectory = path.join(options.directory, hyphenizedName)\n const githubRepo = parseGitHubRepositoryReference(options.template)\n\n await ensureAppDirectoryIsAvailable(outputDirectory, hyphenizedName)\n\n await inTemporaryDirectory(async (tmpDir) => {\n const templateDownloadDir = path.join(tmpDir, 'download')\n const templatePathDir = githubRepo.filePath\n ? path.join(templateDownloadDir, githubRepo.filePath)\n : templateDownloadDir\n const templateScaffoldDir = path.join(tmpDir, 'app')\n const repoUrl = githubRepo.branch ? `${githubRepo.baseURL}#${githubRepo.branch}` : githubRepo.baseURL\n\n await mkdir(templateDownloadDir)\n let tasks: ui.ListrTasks = []\n\n await ui.task({\n title: `Downloading template from ${repoUrl}`,\n task: async () => {\n await downloadGitRepository({\n repoUrl,\n destination: templateDownloadDir,\n shallow: true,\n })\n return {successMessage: `Downloaded template from ${repoUrl}`}\n },\n })\n\n tasks = tasks.concat([\n {\n title: `Initialize your app ${hyphenizedName}`,\n task: async (_, parentTask) => {\n parentTask.title = `Initializing your app ${hyphenizedName}`\n return parentTask.newListr([\n {\n title: 'Parse liquid',\n task: async (_, task) => {\n task.title = 'Parsing liquid'\n await recursiveLiquidTemplateCopy(templatePathDir, templateScaffoldDir, {\n dependency_manager: packageManager,\n app_name: options.name,\n })\n\n task.title = 'Liquid parsed'\n },\n },\n {\n title: 'Update package.json',\n task: async (_, task) => {\n task.title = 'Updating package.json'\n const packageJSON = await npm.readPackageJSON(templateScaffoldDir)\n\n await npm.updateAppData(packageJSON, hyphenizedName)\n await updateCLIDependencies({packageJSON, local: options.local, directory: templateScaffoldDir})\n\n await npm.writePackageJSON(templateScaffoldDir, packageJSON)\n\n // Ensure that the installation of dependencies doesn't fail when using\n // pnpm due to missing peerDependencies.\n if (packageManager === 'pnpm') {\n await appendFile(path.join(templateScaffoldDir, '.npmrc'), `auto-install-peers=true\\n`)\n }\n\n task.title = 'Updated package.json'\n parentTask.title = 'App initialized'\n },\n },\n ])\n },\n },\n ])\n\n if (await isShopify()) {\n tasks.push({\n title: \"[Shopifolks-only] Configure the project's NPM registry\",\n task: async (_, task) => {\n task.title = \"[Shopifolks-only] Configuring the project's NPM registry\"\n const npmrcPath = path.join(templateScaffoldDir, '.npmrc')\n const npmrcContent = `@shopify:registry=https://registry.npmjs.org\\n`\n await appendFile(npmrcPath, npmrcContent)\n task.title = \"[Shopifolks-only] Project's NPM registry configured.\"\n },\n })\n }\n\n tasks = tasks.concat([\n {\n title: `Install dependencies with ${packageManager}`,\n task: async (_, parentTask) => {\n parentTask.title = `Installing dependencies with ${packageManager}`\n function didInstallEverything() {\n parentTask.title = `Dependencies installed with ${packageManager}`\n }\n\n return parentTask.newListr(\n await getDeepInstallNPMTasks({\n from: templateScaffoldDir,\n packageManager,\n didInstallEverything,\n }),\n {concurrent: false},\n )\n },\n },\n {\n title: 'Clean up',\n task: async (_, task) => {\n task.title = 'Cleaning up'\n await cleanup(templateScaffoldDir)\n task.title = 'Completed clean up'\n },\n },\n {\n title: 'Initializing a Git repository...',\n task: async (_, task) => {\n await initializeGitRepository(templateScaffoldDir)\n task.title = 'Git repository initialized'\n },\n },\n ])\n\n const list = ui.newListr(tasks, {\n concurrent: false,\n rendererOptions: {collapse: false},\n rendererSilent: isUnitTest(),\n })\n await list.run()\n\n await moveFile(templateScaffoldDir, outputDirectory)\n })\n\n renderSuccess({\n headline: [{userInput: hyphenizedName}, 'is ready for you to build!'],\n nextSteps: [\n ['Run', {command: `cd ${hyphenizedName}`}],\n ['For extensions, run', {command: output.formatPackageManagerCommand(packageManager, 'generate extension')}],\n ['To see your app, run', {command: output.formatPackageManagerCommand(packageManager, 'dev')}],\n ],\n reference: [\n {link: {label: 'Shopify docs', url: 'https://shopify.dev'}},\n [\n 'For an overview of commands, run',\n {command: `${output.formatPackageManagerCommand(packageManager, 'shopify app', '--help')}`},\n ],\n ],\n })\n}\n\nfunction inferPackageManager(optionsPackageManager: string | undefined): PackageManager {\n if (optionsPackageManager && packageManager.includes(optionsPackageManager as PackageManager)) {\n return optionsPackageManager as PackageManager\n }\n const usedPackageManager = packageManagerUsedForCreating()\n return usedPackageManager === 'unknown' ? 'npm' : usedPackageManager\n}\n\nasync function ensureAppDirectoryIsAvailable(directory: string, name: string): Promise<void> {\n const exists = await fileExists(directory)\n if (exists)\n throw new error.Abort(`\\nA directory with this name (${name}) already exists.\\nChoose a new name for your app.`)\n}\n\nexport default init\n"]}
|
|
1
|
+
{"version":3,"file":"init.js","sourceRoot":"","sources":["../../src/services/init.ts"],"names":[],"mappings":"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","sourcesContent":["import {getDeepInstallNPMTasks, updateCLIDependencies} from '../utils/template/npm.js'\nimport cleanup from '../utils/template/cleanup.js'\n\nimport {error, output} from '@shopify/cli-kit'\nimport {\n findUpAndReadPackageJson,\n packageManager,\n PackageManager,\n packageManagerUsedForCreating,\n writePackageJSON,\n} from '@shopify/cli-kit/node/node-package-manager'\nimport {renderSuccess, renderTasks} from '@shopify/cli-kit/node/ui'\nimport {parseGitHubRepositoryReference} from '@shopify/cli-kit/node/github'\nimport {hyphenate} from '@shopify/cli-kit/common/string'\nimport {recursiveLiquidTemplateCopy} from '@shopify/cli-kit/node/liquid'\nimport {Task} from '@shopify/cli-kit/src/private/node/ui/components/Tasks.js'\nimport {isShopify} from '@shopify/cli-kit/node/environment/local'\nimport {downloadGitRepository, initializeGitRepository} from '@shopify/cli-kit/node/git'\nimport {appendFile, fileExists, inTemporaryDirectory, mkdir, moveFile} from '@shopify/cli-kit/node/fs'\nimport {joinPath} from '@shopify/cli-kit/node/path'\nimport {username} from '@shopify/cli-kit/node/os'\n\ninterface InitOptions {\n name: string\n directory: string\n template: string\n packageManager: string | undefined\n local: boolean\n}\n\nasync function init(options: InitOptions) {\n const packageManager: PackageManager = inferPackageManager(options.packageManager)\n const hyphenizedName = hyphenate(options.name)\n const outputDirectory = joinPath(options.directory, hyphenizedName)\n const githubRepo = parseGitHubRepositoryReference(options.template)\n\n await ensureAppDirectoryIsAvailable(outputDirectory, hyphenizedName)\n\n await inTemporaryDirectory(async (tmpDir) => {\n const templateDownloadDir = joinPath(tmpDir, 'download')\n const templatePathDir = githubRepo.filePath\n ? joinPath(templateDownloadDir, githubRepo.filePath)\n : templateDownloadDir\n const templateScaffoldDir = joinPath(tmpDir, 'app')\n const repoUrl = githubRepo.branch ? `${githubRepo.baseURL}#${githubRepo.branch}` : githubRepo.baseURL\n\n await mkdir(templateDownloadDir)\n const tasks: Task<unknown>[] = [\n {\n title: `Downloading template from ${repoUrl}`,\n task: async () => {\n await downloadGitRepository({\n repoUrl,\n destination: templateDownloadDir,\n shallow: true,\n })\n },\n },\n ]\n\n tasks.push(\n {\n title: 'Parsing liquid',\n task: async () => {\n await recursiveLiquidTemplateCopy(templatePathDir, templateScaffoldDir, {\n dependency_manager: packageManager,\n app_name: options.name,\n })\n },\n },\n {\n title: 'Updating package.json',\n task: async () => {\n const packageJSON = (await findUpAndReadPackageJson(templateScaffoldDir)).content\n packageJSON.name = hyphenizedName\n packageJSON.author = (await username()) ?? ''\n await updateCLIDependencies({packageJSON, local: options.local, directory: templateScaffoldDir})\n\n await writePackageJSON(templateScaffoldDir, packageJSON)\n\n // Ensure that the installation of dependencies doesn't fail when using\n // pnpm due to missing peerDependencies.\n if (packageManager === 'pnpm') {\n await appendFile(joinPath(templateScaffoldDir, '.npmrc'), `auto-install-peers=true\\n`)\n }\n },\n },\n )\n\n if (await isShopify()) {\n tasks.push({\n title: \"[Shopifolks-only] Configuring the project's NPM registry\",\n task: async () => {\n const npmrcPath = joinPath(templateScaffoldDir, '.npmrc')\n const npmrcContent = `@shopify:registry=https://registry.npmjs.org\\n`\n await appendFile(npmrcPath, npmrcContent)\n },\n })\n }\n\n tasks.push(\n {\n title: 'Installing dependencies',\n task: async () => {\n const subtasks = await getDeepInstallNPMTasks({from: templateScaffoldDir, packageManager})\n return subtasks\n },\n },\n {\n title: 'Cleaning up',\n task: async () => {\n await cleanup(templateScaffoldDir)\n },\n },\n {\n title: 'Initializing a Git repository...',\n task: async () => {\n await initializeGitRepository(templateScaffoldDir)\n },\n },\n )\n\n await renderTasks(tasks)\n\n await moveFile(templateScaffoldDir, outputDirectory)\n })\n\n renderSuccess({\n headline: [{userInput: hyphenizedName}, 'is ready for you to build!'],\n nextSteps: [\n ['Run', {command: `cd ${hyphenizedName}`}],\n ['For extensions, run', {command: output.formatPackageManagerCommand(packageManager, 'generate extension')}],\n ['To see your app, run', {command: output.formatPackageManagerCommand(packageManager, 'dev')}],\n ],\n reference: [\n {link: {label: 'Shopify docs', url: 'https://shopify.dev'}},\n [\n 'For an overview of commands, run',\n {command: `${output.formatPackageManagerCommand(packageManager, 'shopify app', '--help')}`},\n ],\n ],\n })\n}\n\nfunction inferPackageManager(optionsPackageManager: string | undefined): PackageManager {\n if (optionsPackageManager && packageManager.includes(optionsPackageManager as PackageManager)) {\n return optionsPackageManager as PackageManager\n }\n const usedPackageManager = packageManagerUsedForCreating()\n return usedPackageManager === 'unknown' ? 'npm' : usedPackageManager\n}\n\nasync function ensureAppDirectoryIsAvailable(directory: string, name: string): Promise<void> {\n const exists = await fileExists(directory)\n if (exists)\n throw new error.Abort(`\\nA directory with this name (${name}) already exists.\\nChoose a new name for your app.`)\n}\n\nexport default init\n"]}
|