@shopify/cli-hydrogen 0.0.0-nightly-20230110194301

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.
Files changed (86) hide show
  1. package/LICENSE +8 -0
  2. package/README.md +63 -0
  3. package/dist/cli/commands/hydrogen/add/eslint.d.ts +11 -0
  4. package/dist/cli/commands/hydrogen/add/eslint.js +26 -0
  5. package/dist/cli/commands/hydrogen/add/eslint.js.map +1 -0
  6. package/dist/cli/commands/hydrogen/add/tailwind.d.ts +11 -0
  7. package/dist/cli/commands/hydrogen/add/tailwind.js +26 -0
  8. package/dist/cli/commands/hydrogen/add/tailwind.js.map +1 -0
  9. package/dist/cli/commands/hydrogen/build.d.ts +14 -0
  10. package/dist/cli/commands/hydrogen/build.js +49 -0
  11. package/dist/cli/commands/hydrogen/build.js.map +1 -0
  12. package/dist/cli/commands/hydrogen/deploy.d.ts +19 -0
  13. package/dist/cli/commands/hydrogen/deploy.js +58 -0
  14. package/dist/cli/commands/hydrogen/deploy.js.map +1 -0
  15. package/dist/cli/commands/hydrogen/dev.d.ts +13 -0
  16. package/dist/cli/commands/hydrogen/dev.js +31 -0
  17. package/dist/cli/commands/hydrogen/dev.js.map +1 -0
  18. package/dist/cli/commands/hydrogen/info.d.ts +12 -0
  19. package/dist/cli/commands/hydrogen/info.js +28 -0
  20. package/dist/cli/commands/hydrogen/info.js.map +1 -0
  21. package/dist/cli/commands/hydrogen/preview.d.ts +13 -0
  22. package/dist/cli/commands/hydrogen/preview.js +46 -0
  23. package/dist/cli/commands/hydrogen/preview.js.map +1 -0
  24. package/dist/cli/constants.d.ts +15 -0
  25. package/dist/cli/constants.js +16 -0
  26. package/dist/cli/constants.js.map +1 -0
  27. package/dist/cli/flags.d.ts +4 -0
  28. package/dist/cli/flags.js +16 -0
  29. package/dist/cli/flags.js.map +1 -0
  30. package/dist/cli/models/hydrogen.d.ts +22 -0
  31. package/dist/cli/models/hydrogen.js +82 -0
  32. package/dist/cli/models/hydrogen.js.map +1 -0
  33. package/dist/cli/prompts/git-init.d.ts +1 -0
  34. package/dist/cli/prompts/git-init.js +16 -0
  35. package/dist/cli/prompts/git-init.js.map +1 -0
  36. package/dist/cli/services/build/check-lockfile.d.ts +3 -0
  37. package/dist/cli/services/build/check-lockfile.js +80 -0
  38. package/dist/cli/services/build/check-lockfile.js.map +1 -0
  39. package/dist/cli/services/build.d.ts +14 -0
  40. package/dist/cli/services/build.js +44 -0
  41. package/dist/cli/services/build.js.map +1 -0
  42. package/dist/cli/services/deploy/config.d.ts +4 -0
  43. package/dist/cli/services/deploy/config.js +49 -0
  44. package/dist/cli/services/deploy/config.js.map +1 -0
  45. package/dist/cli/services/deploy/error.d.ts +4 -0
  46. package/dist/cli/services/deploy/error.js +11 -0
  47. package/dist/cli/services/deploy/error.js.map +1 -0
  48. package/dist/cli/services/deploy/graphql/create_deployment.d.ts +10 -0
  49. package/dist/cli/services/deploy/graphql/create_deployment.js +15 -0
  50. package/dist/cli/services/deploy/graphql/create_deployment.js.map +1 -0
  51. package/dist/cli/services/deploy/graphql/upload_deployment.d.ts +1 -0
  52. package/dist/cli/services/deploy/graphql/upload_deployment.js +16 -0
  53. package/dist/cli/services/deploy/graphql/upload_deployment.js.map +1 -0
  54. package/dist/cli/services/deploy/types.d.ts +37 -0
  55. package/dist/cli/services/deploy/types.js +2 -0
  56. package/dist/cli/services/deploy/types.js.map +1 -0
  57. package/dist/cli/services/deploy/upload.d.ts +5 -0
  58. package/dist/cli/services/deploy/upload.js +81 -0
  59. package/dist/cli/services/deploy/upload.js.map +1 -0
  60. package/dist/cli/services/deploy.d.ts +2 -0
  61. package/dist/cli/services/deploy.js +103 -0
  62. package/dist/cli/services/deploy.js.map +1 -0
  63. package/dist/cli/services/dev/check-version.d.ts +1 -0
  64. package/dist/cli/services/dev/check-version.js +30 -0
  65. package/dist/cli/services/dev/check-version.js.map +1 -0
  66. package/dist/cli/services/dev.d.ts +10 -0
  67. package/dist/cli/services/dev.js +37 -0
  68. package/dist/cli/services/dev.js.map +1 -0
  69. package/dist/cli/services/eslint.d.ts +8 -0
  70. package/dist/cli/services/eslint.js +74 -0
  71. package/dist/cli/services/eslint.js.map +1 -0
  72. package/dist/cli/services/info.d.ts +7 -0
  73. package/dist/cli/services/info.js +132 -0
  74. package/dist/cli/services/info.js.map +1 -0
  75. package/dist/cli/services/preview.d.ts +12 -0
  76. package/dist/cli/services/preview.js +63 -0
  77. package/dist/cli/services/preview.js.map +1 -0
  78. package/dist/cli/services/tailwind.d.ts +9 -0
  79. package/dist/cli/services/tailwind.js +103 -0
  80. package/dist/cli/services/tailwind.js.map +1 -0
  81. package/dist/cli/utilities/load-config.d.ts +5 -0
  82. package/dist/cli/utilities/load-config.js +6 -0
  83. package/dist/cli/utilities/load-config.js.map +1 -0
  84. package/dist/tsconfig.tsbuildinfo +1 -0
  85. package/oclif.manifest.json +1 -0
  86. package/package.json +78 -0
package/LICENSE ADDED
@@ -0,0 +1,8 @@
1
+ Copyright 2019-present, Shopify Inc.
2
+
3
+ ​​
4
+ Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
5
+
6
+ The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
7
+
8
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
package/README.md ADDED
@@ -0,0 +1,63 @@
1
+ <img src="https://github.com/Shopify/cli/blob/main/assets/logo.png?raw=true" width="150"/>
2
+
3
+ # Shopify CLI
4
+ <a href="http://twitter.com/ShopifyDevs"><img src="https://img.shields.io/twitter/follow/ShopifyDevs?style=flat-square" alt="Twitter Followers"></a>
5
+ <img src="https://img.shields.io/badge/License-MIT-green.svg" alt="License">
6
+ <a href="https://github.com/Shopify/cli/actions/workflows/shopify-cli.yml">![badge](https://github.com/Shopify/cli/actions/workflows/shopify-cli.yml/badge.svg)</a>
7
+
8
+ With the Shopify command line interface (Shopify CLI 3.0), you can:
9
+ - build custom storefronts and manage their hosting
10
+ - initialize, build, dev, and deploy Shopify apps — and generate app extensions
11
+
12
+ <p>&nbsp;</p>
13
+
14
+ ### Before you begin ###
15
+
16
+ Install the latest version of [Node.js](https://nodejs.org/en/download/) and [npm](https://docs.npmjs.com/getting-started) (or another package manager of your choice).
17
+
18
+ <p>&nbsp;</p>
19
+
20
+ ## Developing apps with Shopify CLI
21
+
22
+ When you’re building a Shopify app, you can initialize your project using your preferred package manager. A single command will install all the dependencies you need — including Shopify CLI itself.
23
+
24
+ Initialize your project using one of the following commands:
25
+ - `npm init @shopify/app@latest` (installed by default with Node)
26
+ - `pnpm create @shopify/create-app@latest`
27
+ - `yarn create @shopify/app`
28
+
29
+ Learn more in the docs: [Create an app](https://shopify.dev/apps/getting-started/create)
30
+
31
+ <p>&nbsp;</p>
32
+
33
+ ## Developing Hydrogen custom storefronts with Shopify CLI ##
34
+
35
+ When you’re building a custom storefront, use Hydrogen, Shopify’s React-based framework optimized for headless commerce. Initialize a new Hydrogen app with a fully-featured Demo Store template, or start from scratch with the minimal Hello World template. Shopify Plus stores can deploy their Hydrogen apps to Oxygen, Shopify’s global hosting solution, at no extra cost.
36
+
37
+ Get started using one of the following commands:
38
+ - `npm init @shopify/hydrogen@latest`
39
+ - `npx @shopify/create-hydrogen@latest`
40
+ - `pnpm create @shopify/create-hydrogen@latest`
41
+ - `yarn create @shopify/hydrogen`
42
+
43
+ <p>&nbsp;</p>
44
+
45
+ ## Help 🖐
46
+
47
+ If you encounter issues using the CLI or have feedback you'd like to share with us, below are some options:
48
+
49
+ - [Open a GitHub issue](https://github.com/Shopify/cli/issues) - To report bugs or request new features, open an issue in the Shopify CLI repository.
50
+ - [Shopify Community Forums](https://community.shopify.com/) - Visit our forums to connect with the community and learn more about Shopify CLI development.
51
+ - [CLI Documentation - Apps](https://shopify.dev/apps/tools/cli) - To view CLI documentation for app development
52
+ - [CLI Documentation - Themes](https://shopify.dev/themes/tools/cli) - To view CLI documentation for theme development
53
+ - [CLI Documentation - Hydrogen](https://shopify.dev/custom-storefronts/tools/cli) - To view CLI documentation for Hydrogen (custom storefront) development
54
+
55
+ ## Contribute 👩🏽‍💻
56
+
57
+ If you'd like to contribute to the project, check out the [contributors docs](/docs) and the [steps to get started](/docs/cli/get-started.md).
58
+
59
+ <p>&nbsp;</p>
60
+
61
+ ## References
62
+
63
+ - [oclif](https://oclif.io/)
@@ -0,0 +1,11 @@
1
+ import Command from '@shopify/cli-kit/node/base-command';
2
+ export default class AddESLint extends Command {
3
+ static flags: {
4
+ force: import("@oclif/core/lib/interfaces/parser.js").BooleanFlag<boolean>;
5
+ path: import("@oclif/core/lib/interfaces/parser.js").OptionFlag<string | undefined>;
6
+ install: import("@oclif/core/lib/interfaces/parser.js").BooleanFlag<boolean>;
7
+ preset: import("@oclif/core/lib/interfaces/parser.js").OptionFlag<string | undefined>;
8
+ verbose: import("@oclif/core/lib/interfaces/parser.js").BooleanFlag<boolean>;
9
+ };
10
+ run(): Promise<void>;
11
+ }
@@ -0,0 +1,26 @@
1
+ import { hydrogenFlags } from '../../../flags.js';
2
+ import { addESLint } from '../../../services/eslint.js';
3
+ import { load as loadApp } from '../../../models/hydrogen.js';
4
+ import { Flags } from '@oclif/core';
5
+ import { cli, path } from '@shopify/cli-kit';
6
+ import Command from '@shopify/cli-kit/node/base-command';
7
+ export default class AddESLint extends Command {
8
+ async run() {
9
+ const { flags: { path: pathFlag, install, force }, } = await this.parse(AddESLint);
10
+ const directory = pathFlag ? path.resolve(pathFlag) : process.cwd();
11
+ const app = await loadApp(directory);
12
+ await addESLint({ app, install, force });
13
+ }
14
+ }
15
+ AddESLint.flags = {
16
+ ...cli.globalFlags,
17
+ ...hydrogenFlags,
18
+ force: Flags.boolean({
19
+ hidden: false,
20
+ char: 'f',
21
+ description: 'Overwrite existing configuration',
22
+ default: false,
23
+ env: 'SHOPIFY_FLAG_FORCE',
24
+ }),
25
+ };
26
+ //# sourceMappingURL=eslint.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"eslint.js","sourceRoot":"","sources":["../../../../../src/cli/commands/hydrogen/add/eslint.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,aAAa,EAAC,MAAM,mBAAmB,CAAA;AAC/C,OAAO,EAAC,SAAS,EAAC,MAAM,6BAA6B,CAAA;AACrD,OAAO,EAAC,IAAI,IAAI,OAAO,EAAc,MAAM,6BAA6B,CAAA;AACxE,OAAO,EAAC,KAAK,EAAC,MAAM,aAAa,CAAA;AACjC,OAAO,EAAC,GAAG,EAAE,IAAI,EAAC,MAAM,kBAAkB,CAAA;AAC1C,OAAO,OAAO,MAAM,oCAAoC,CAAA;AAExD,MAAM,CAAC,OAAO,OAAO,SAAU,SAAQ,OAAO;IAarC,KAAK,CAAC,GAAG;QACd,MAAM,EACJ,KAAK,EAAE,EAAC,IAAI,EAAE,QAAQ,EAAE,OAAO,EAAE,KAAK,EAAC,GACxC,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAA;QAC/B,MAAM,SAAS,GAAG,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,GAAG,EAAE,CAAA;QAEnE,MAAM,GAAG,GAAgB,MAAM,OAAO,CAAC,SAAS,CAAC,CAAA;QAEjD,MAAM,SAAS,CAAC,EAAC,GAAG,EAAE,OAAO,EAAE,KAAK,EAAC,CAAC,CAAA;IACxC,CAAC;;AArBM,eAAK,GAAG;IACb,GAAG,GAAG,CAAC,WAAW;IAClB,GAAG,aAAa;IAChB,KAAK,EAAE,KAAK,CAAC,OAAO,CAAC;QACnB,MAAM,EAAE,KAAK;QACb,IAAI,EAAE,GAAG;QACT,WAAW,EAAE,kCAAkC;QAC/C,OAAO,EAAE,KAAK;QACd,GAAG,EAAE,oBAAoB;KAC1B,CAAC;CACH,CAAA","sourcesContent":["import {hydrogenFlags} from '../../../flags.js'\nimport {addESLint} from '../../../services/eslint.js'\nimport {load as loadApp, HydrogenApp} from '../../../models/hydrogen.js'\nimport {Flags} from '@oclif/core'\nimport {cli, path} from '@shopify/cli-kit'\nimport Command from '@shopify/cli-kit/node/base-command'\n\nexport default class AddESLint extends Command {\n static flags = {\n ...cli.globalFlags,\n ...hydrogenFlags,\n force: Flags.boolean({\n hidden: false,\n char: 'f',\n description: 'Overwrite existing configuration',\n default: false,\n env: 'SHOPIFY_FLAG_FORCE',\n }),\n }\n\n public async run(): Promise<void> {\n const {\n flags: {path: pathFlag, install, force},\n } = await this.parse(AddESLint)\n const directory = pathFlag ? path.resolve(pathFlag) : process.cwd()\n\n const app: HydrogenApp = await loadApp(directory)\n\n await addESLint({app, install, force})\n }\n}\n"]}
@@ -0,0 +1,11 @@
1
+ import Command from '@shopify/cli-kit/node/base-command';
2
+ export default class AddTailwind extends Command {
3
+ static flags: {
4
+ force: import("@oclif/core/lib/interfaces/parser.js").BooleanFlag<boolean>;
5
+ path: import("@oclif/core/lib/interfaces/parser.js").OptionFlag<string | undefined>;
6
+ install: import("@oclif/core/lib/interfaces/parser.js").BooleanFlag<boolean>;
7
+ preset: import("@oclif/core/lib/interfaces/parser.js").OptionFlag<string | undefined>;
8
+ verbose: import("@oclif/core/lib/interfaces/parser.js").BooleanFlag<boolean>;
9
+ };
10
+ run(): Promise<void>;
11
+ }
@@ -0,0 +1,26 @@
1
+ import { hydrogenFlags } from '../../../flags.js';
2
+ import { addTailwind } from '../../../services/tailwind.js';
3
+ import { load as loadApp } from '../../../models/hydrogen.js';
4
+ import { Flags } from '@oclif/core';
5
+ import { path, cli } from '@shopify/cli-kit';
6
+ import Command from '@shopify/cli-kit/node/base-command';
7
+ export default class AddTailwind extends Command {
8
+ async run() {
9
+ const { flags: { path: pathFlag, install, force }, } = await this.parse(AddTailwind);
10
+ const directory = pathFlag ? path.resolve(pathFlag) : process.cwd();
11
+ const app = await loadApp(directory);
12
+ await addTailwind({ app, directory, install, force });
13
+ }
14
+ }
15
+ AddTailwind.flags = {
16
+ ...cli.globalFlags,
17
+ ...hydrogenFlags,
18
+ force: Flags.boolean({
19
+ hidden: false,
20
+ char: 'f',
21
+ description: 'overwrite existing configuration',
22
+ default: false,
23
+ env: 'SHOPIFY_FLAG_FORCE',
24
+ }),
25
+ };
26
+ //# sourceMappingURL=tailwind.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tailwind.js","sourceRoot":"","sources":["../../../../../src/cli/commands/hydrogen/add/tailwind.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,aAAa,EAAC,MAAM,mBAAmB,CAAA;AAC/C,OAAO,EAAC,WAAW,EAAC,MAAM,+BAA+B,CAAA;AACzD,OAAO,EAAC,IAAI,IAAI,OAAO,EAAc,MAAM,6BAA6B,CAAA;AACxE,OAAO,EAAC,KAAK,EAAC,MAAM,aAAa,CAAA;AACjC,OAAO,EAAC,IAAI,EAAE,GAAG,EAAC,MAAM,kBAAkB,CAAA;AAC1C,OAAO,OAAO,MAAM,oCAAoC,CAAA;AAExD,MAAM,CAAC,OAAO,OAAO,WAAY,SAAQ,OAAO;IAavC,KAAK,CAAC,GAAG;QACd,MAAM,EACJ,KAAK,EAAE,EAAC,IAAI,EAAE,QAAQ,EAAE,OAAO,EAAE,KAAK,EAAC,GACxC,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,CAAA;QACjC,MAAM,SAAS,GAAG,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,GAAG,EAAE,CAAA;QAEnE,MAAM,GAAG,GAAgB,MAAM,OAAO,CAAC,SAAS,CAAC,CAAA;QAEjD,MAAM,WAAW,CAAC,EAAC,GAAG,EAAE,SAAS,EAAE,OAAO,EAAE,KAAK,EAAC,CAAC,CAAA;IACrD,CAAC;;AArBM,iBAAK,GAAG;IACb,GAAG,GAAG,CAAC,WAAW;IAClB,GAAG,aAAa;IAChB,KAAK,EAAE,KAAK,CAAC,OAAO,CAAC;QACnB,MAAM,EAAE,KAAK;QACb,IAAI,EAAE,GAAG;QACT,WAAW,EAAE,kCAAkC;QAC/C,OAAO,EAAE,KAAK;QACd,GAAG,EAAE,oBAAoB;KAC1B,CAAC;CACH,CAAA","sourcesContent":["import {hydrogenFlags} from '../../../flags.js'\nimport {addTailwind} from '../../../services/tailwind.js'\nimport {load as loadApp, HydrogenApp} from '../../../models/hydrogen.js'\nimport {Flags} from '@oclif/core'\nimport {path, cli} from '@shopify/cli-kit'\nimport Command from '@shopify/cli-kit/node/base-command'\n\nexport default class AddTailwind extends Command {\n static flags = {\n ...cli.globalFlags,\n ...hydrogenFlags,\n force: Flags.boolean({\n hidden: false,\n char: 'f',\n description: 'overwrite existing configuration',\n default: false,\n env: 'SHOPIFY_FLAG_FORCE',\n }),\n }\n\n public async run(): Promise<void> {\n const {\n flags: {path: pathFlag, install, force},\n } = await this.parse(AddTailwind)\n const directory = pathFlag ? path.resolve(pathFlag) : process.cwd()\n\n const app: HydrogenApp = await loadApp(directory)\n\n await addTailwind({app, directory, install, force})\n }\n}\n"]}
@@ -0,0 +1,14 @@
1
+ import Command from '@shopify/cli-kit/node/base-command';
2
+ export default class Build extends Command {
3
+ static description: string;
4
+ static flags: {
5
+ path: import("@oclif/core/lib/interfaces/parser.js").OptionFlag<string | undefined>;
6
+ base: import("@oclif/core/lib/interfaces/parser.js").OptionFlag<string | undefined>;
7
+ client: import("@oclif/core/lib/interfaces/parser.js").BooleanFlag<boolean>;
8
+ target: import("@oclif/core/lib/interfaces/parser.js").OptionFlag<string>;
9
+ entry: import("@oclif/core/lib/interfaces/parser.js").OptionFlag<string | undefined>;
10
+ preset: import("@oclif/core/lib/interfaces/parser.js").OptionFlag<string | undefined>;
11
+ verbose: import("@oclif/core/lib/interfaces/parser.js").BooleanFlag<boolean>;
12
+ };
13
+ run(): Promise<void>;
14
+ }
@@ -0,0 +1,49 @@
1
+ import { build } from '../../services/build.js';
2
+ import { hydrogenFlags } from '../../flags.js';
3
+ import { Flags } from '@oclif/core';
4
+ import { path, cli } from '@shopify/cli-kit';
5
+ import Command from '@shopify/cli-kit/node/base-command';
6
+ const PLATFORM_ENTRIES = {
7
+ node: `@shopify/hydrogen/platforms/node`,
8
+ worker: `@shopify/hydrogen/platforms/worker`,
9
+ };
10
+ export default class Build extends Command {
11
+ async run() {
12
+ const { flags } = await this.parse(Build);
13
+ const directory = flags.path ? path.resolve(flags.path) : process.cwd();
14
+ const entry = flags.entry || PLATFORM_ENTRIES[flags.target];
15
+ const targets = {
16
+ client: flags.client,
17
+ worker: flags.target === 'worker' ? entry : false,
18
+ node: flags.target === 'node' ? entry : false,
19
+ };
20
+ await build({ ...flags, directory, targets });
21
+ }
22
+ }
23
+ Build.description = 'Builds a Hydrogen storefront for production';
24
+ Build.flags = {
25
+ ...cli.globalFlags,
26
+ path: hydrogenFlags.path,
27
+ base: Flags.string({
28
+ description: ' the public path when served in production',
29
+ env: 'SHOPIFY_FLAG_BUILD_BASE',
30
+ }),
31
+ client: Flags.boolean({
32
+ description: 'build the client code',
33
+ env: 'SHOPIFY_FLAG_BUILD_CLIENT',
34
+ allowNo: true,
35
+ default: true,
36
+ }),
37
+ target: Flags.string({
38
+ char: 't',
39
+ description: 'the target platform to build for (worker or node)',
40
+ options: ['node', 'worker'],
41
+ default: 'worker',
42
+ env: 'SHOPIFY_FLAG_BUILD_TARGET',
43
+ }),
44
+ entry: Flags.string({
45
+ description: 'produce Server Side Rendering (SSR) build for node environments',
46
+ env: 'SHOPIFY_FLAG_BUILD_SSR_ENTRY',
47
+ }),
48
+ };
49
+ //# sourceMappingURL=build.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"build.js","sourceRoot":"","sources":["../../../../src/cli/commands/hydrogen/build.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,KAAK,EAAC,MAAM,yBAAyB,CAAA;AAC7C,OAAO,EAAC,aAAa,EAAC,MAAM,gBAAgB,CAAA;AAC5C,OAAO,EAAC,KAAK,EAAC,MAAM,aAAa,CAAA;AACjC,OAAO,EAAC,IAAI,EAAE,GAAG,EAAC,MAAM,kBAAkB,CAAA;AAC1C,OAAO,OAAO,MAAM,oCAAoC,CAAA;AAExD,MAAM,gBAAgB,GAAG;IACvB,IAAI,EAAE,kCAAkC;IACxC,MAAM,EAAE,oCAAoC;CAC7C,CAAA;AAED,MAAM,CAAC,OAAO,OAAO,KAAM,SAAQ,OAAO;IA4BxC,KAAK,CAAC,GAAG;QACP,MAAM,EAAC,KAAK,EAAC,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAA;QACvC,MAAM,SAAS,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,GAAG,EAAE,CAAA;QAEvE,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,IAAI,gBAAgB,CAAC,KAAK,CAAC,MAA2B,CAAC,CAAA;QAEhF,MAAM,OAAO,GAAG;YACd,MAAM,EAAE,KAAK,CAAC,MAAM;YACpB,MAAM,EAAE,KAAK,CAAC,MAAM,KAAK,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK;YACjD,IAAI,EAAE,KAAK,CAAC,MAAM,KAAK,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK;SAC9C,CAAA;QAED,MAAM,KAAK,CAAC,EAAC,GAAG,KAAK,EAAE,SAAS,EAAE,OAAO,EAAC,CAAC,CAAA;IAC7C,CAAC;;AAxCM,iBAAW,GAAG,6CAA6C,CAAA;AAC3D,WAAK,GAAG;IACb,GAAG,GAAG,CAAC,WAAW;IAClB,IAAI,EAAE,aAAa,CAAC,IAAI;IACxB,IAAI,EAAE,KAAK,CAAC,MAAM,CAAC;QACjB,WAAW,EAAE,4CAA4C;QACzD,GAAG,EAAE,yBAAyB;KAC/B,CAAC;IACF,MAAM,EAAE,KAAK,CAAC,OAAO,CAAC;QACpB,WAAW,EAAE,uBAAuB;QACpC,GAAG,EAAE,2BAA2B;QAChC,OAAO,EAAE,IAAI;QACb,OAAO,EAAE,IAAI;KACd,CAAC;IACF,MAAM,EAAE,KAAK,CAAC,MAAM,CAAC;QACnB,IAAI,EAAE,GAAG;QACT,WAAW,EAAE,mDAAmD;QAChE,OAAO,EAAE,CAAC,MAAM,EAAE,QAAQ,CAAC;QAC3B,OAAO,EAAE,QAAQ;QACjB,GAAG,EAAE,2BAA2B;KACjC,CAAC;IACF,KAAK,EAAE,KAAK,CAAC,MAAM,CAAC;QAClB,WAAW,EAAE,iEAAiE;QAC9E,GAAG,EAAE,8BAA8B;KACpC,CAAC;CACH,CAAA","sourcesContent":["import {build} from '../../services/build.js'\nimport {hydrogenFlags} from '../../flags.js'\nimport {Flags} from '@oclif/core'\nimport {path, cli} from '@shopify/cli-kit'\nimport Command from '@shopify/cli-kit/node/base-command'\n\nconst PLATFORM_ENTRIES = {\n node: `@shopify/hydrogen/platforms/node`,\n worker: `@shopify/hydrogen/platforms/worker`,\n}\n\nexport default class Build extends Command {\n static description = 'Builds a Hydrogen storefront for production'\n static flags = {\n ...cli.globalFlags,\n path: hydrogenFlags.path,\n base: Flags.string({\n description: ' the public path when served in production',\n env: 'SHOPIFY_FLAG_BUILD_BASE',\n }),\n client: Flags.boolean({\n description: 'build the client code',\n env: 'SHOPIFY_FLAG_BUILD_CLIENT',\n allowNo: true,\n default: true,\n }),\n target: Flags.string({\n char: 't',\n description: 'the target platform to build for (worker or node)',\n options: ['node', 'worker'],\n default: 'worker',\n env: 'SHOPIFY_FLAG_BUILD_TARGET',\n }),\n entry: Flags.string({\n description: 'produce Server Side Rendering (SSR) build for node environments',\n env: 'SHOPIFY_FLAG_BUILD_SSR_ENTRY',\n }),\n }\n\n async run(): Promise<void> {\n const {flags} = await this.parse(Build)\n const directory = flags.path ? path.resolve(flags.path) : process.cwd()\n\n const entry = flags.entry || PLATFORM_ENTRIES[flags.target as 'node' | 'worker']\n\n const targets = {\n client: flags.client,\n worker: flags.target === 'worker' ? entry : false,\n node: flags.target === 'node' ? entry : false,\n }\n\n await build({...flags, directory, targets})\n }\n}\n"]}
@@ -0,0 +1,19 @@
1
+ import Command from '@shopify/cli-kit/node/base-command';
2
+ export default class Deploy extends Command {
3
+ static description: string;
4
+ static hidden: boolean;
5
+ static flags: {
6
+ deploymentToken: import("@oclif/core/lib/interfaces/parser.js").OptionFlag<string>;
7
+ commitMessage: import("@oclif/core/lib/interfaces/parser.js").OptionFlag<string | undefined>;
8
+ commitAuthor: import("@oclif/core/lib/interfaces/parser.js").OptionFlag<string | undefined>;
9
+ pathToBuild: import("@oclif/core/lib/interfaces/parser.js").OptionFlag<string | undefined>;
10
+ healthCheck: import("@oclif/core/lib/interfaces/parser.js").BooleanFlag<boolean>;
11
+ assumeYes: import("@oclif/core/lib/interfaces/parser.js").BooleanFlag<boolean>;
12
+ oxygenAddress: import("@oclif/core/lib/interfaces/parser.js").OptionFlag<string>;
13
+ path: import("@oclif/core/lib/interfaces/parser.js").OptionFlag<string | undefined>;
14
+ install: import("@oclif/core/lib/interfaces/parser.js").BooleanFlag<boolean>;
15
+ preset: import("@oclif/core/lib/interfaces/parser.js").OptionFlag<string | undefined>;
16
+ verbose: import("@oclif/core/lib/interfaces/parser.js").BooleanFlag<boolean>;
17
+ };
18
+ run(): Promise<void>;
19
+ }
@@ -0,0 +1,58 @@
1
+ import { hydrogenFlags } from '../../flags.js';
2
+ import { deployToOxygen } from '../../services/deploy.js';
3
+ import { output, cli, environment, path } from '@shopify/cli-kit';
4
+ import Command from '@shopify/cli-kit/node/base-command';
5
+ import { Flags } from '@oclif/core';
6
+ export default class Deploy extends Command {
7
+ async run() {
8
+ const isShopify = await environment.local.isShopify();
9
+ if (!isShopify) {
10
+ output.warn('Command coming soon...');
11
+ return;
12
+ }
13
+ const { flags } = await this.parse(Deploy);
14
+ const dir = flags.path ? path.resolve(flags.path) : process.cwd();
15
+ await deployToOxygen({ ...flags, path: dir });
16
+ }
17
+ }
18
+ Deploy.description = 'Deploy your Hydrogen app to Oxygen hosting';
19
+ Deploy.hidden = true;
20
+ Deploy.flags = {
21
+ ...cli.globalFlags,
22
+ ...hydrogenFlags,
23
+ deploymentToken: Flags.string({
24
+ required: true,
25
+ env: 'SHOPIFY_HYDROGEN_FLAG_DEPLOYMENT_TOKEN',
26
+ description: 'Specify your Oxygen deployment token.',
27
+ }),
28
+ commitMessage: Flags.string({
29
+ env: 'SHOPIFY_HYDROGEN_FLAG_COMMIT_MESSAGE',
30
+ description: 'Override the default Git commit message.',
31
+ }),
32
+ commitAuthor: Flags.string({
33
+ env: 'SHOPIFY_HYDROGEN_FLAG_COMMIT_AUTHOR',
34
+ description: 'Override the default Git commit author.',
35
+ }),
36
+ pathToBuild: Flags.string({
37
+ hidden: true,
38
+ env: 'SHOPIFY_HYDROGEN_FLAG_PATH_TO_BUILD',
39
+ description: 'Skip build process and use provided value as build',
40
+ }),
41
+ healthCheck: Flags.boolean({
42
+ env: 'SHOPIFY_HYDROGEN_FLAG_HEALTH_CHECK',
43
+ default: true,
44
+ description: 'Require a health check before the deployment succeeds.',
45
+ }),
46
+ assumeYes: Flags.boolean({
47
+ char: 'y',
48
+ env: 'SHOPIFY_HYDROGEN_FLAG_ASSUME_YES',
49
+ default: false,
50
+ description: 'Automatic yes to prompts. Assume "yes" as answer to all prompts and run non-interactively.',
51
+ }),
52
+ oxygenAddress: Flags.string({
53
+ hidden: true,
54
+ env: 'SHOPIFY_HYDROGEN_FLAG_OXYGEN_ADDRESS',
55
+ default: 'oxygen-dms.shopifycloud.com',
56
+ }),
57
+ };
58
+ //# sourceMappingURL=deploy.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"deploy.js","sourceRoot":"","sources":["../../../../src/cli/commands/hydrogen/deploy.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,aAAa,EAAC,MAAM,gBAAgB,CAAA;AAC5C,OAAO,EAAC,cAAc,EAAC,MAAM,0BAA0B,CAAA;AACvD,OAAO,EAAC,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,IAAI,EAAC,MAAM,kBAAkB,CAAA;AAC/D,OAAO,OAAO,MAAM,oCAAoC,CAAA;AACxD,OAAO,EAAC,KAAK,EAAC,MAAM,aAAa,CAAA;AAEjC,MAAM,CAAC,OAAO,OAAO,MAAO,SAAQ,OAAO;IA2ClC,KAAK,CAAC,GAAG;QACd,MAAM,SAAS,GAAG,MAAM,WAAW,CAAC,KAAK,CAAC,SAAS,EAAE,CAAA;QACrD,IAAI,CAAC,SAAS,EAAE;YACd,MAAM,CAAC,IAAI,CAAC,wBAAwB,CAAC,CAAA;YACrC,OAAM;SACP;QAED,MAAM,EAAC,KAAK,EAAC,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAA;QACxC,MAAM,GAAG,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,GAAG,EAAE,CAAA;QAEjE,MAAM,cAAc,CAAC,EAAC,GAAG,KAAK,EAAE,IAAI,EAAE,GAAG,EAAC,CAAC,CAAA;IAC7C,CAAC;;AArDM,kBAAW,GAAG,4CAA4C,CAAA;AAC1D,aAAM,GAAG,IAAI,CAAA;AAEb,YAAK,GAAG;IACb,GAAG,GAAG,CAAC,WAAW;IAClB,GAAG,aAAa;IAChB,eAAe,EAAE,KAAK,CAAC,MAAM,CAAC;QAC5B,QAAQ,EAAE,IAAI;QACd,GAAG,EAAE,wCAAwC;QAC7C,WAAW,EAAE,uCAAuC;KACrD,CAAC;IACF,aAAa,EAAE,KAAK,CAAC,MAAM,CAAC;QAC1B,GAAG,EAAE,sCAAsC;QAC3C,WAAW,EAAE,0CAA0C;KACxD,CAAC;IACF,YAAY,EAAE,KAAK,CAAC,MAAM,CAAC;QACzB,GAAG,EAAE,qCAAqC;QAC1C,WAAW,EAAE,yCAAyC;KACvD,CAAC;IACF,WAAW,EAAE,KAAK,CAAC,MAAM,CAAC;QACxB,MAAM,EAAE,IAAI;QACZ,GAAG,EAAE,qCAAqC;QAC1C,WAAW,EAAE,oDAAoD;KAClE,CAAC;IACF,WAAW,EAAE,KAAK,CAAC,OAAO,CAAC;QACzB,GAAG,EAAE,oCAAoC;QACzC,OAAO,EAAE,IAAI;QACb,WAAW,EAAE,wDAAwD;KACtE,CAAC;IACF,SAAS,EAAE,KAAK,CAAC,OAAO,CAAC;QACvB,IAAI,EAAE,GAAG;QACT,GAAG,EAAE,kCAAkC;QACvC,OAAO,EAAE,KAAK;QACd,WAAW,EAAE,4FAA4F;KAC1G,CAAC;IACF,aAAa,EAAE,KAAK,CAAC,MAAM,CAAC;QAC1B,MAAM,EAAE,IAAI;QACZ,GAAG,EAAE,sCAAsC;QAC3C,OAAO,EAAE,6BAA6B;KACvC,CAAC;CACH,CAAA","sourcesContent":["import {hydrogenFlags} from '../../flags.js'\nimport {deployToOxygen} from '../../services/deploy.js'\nimport {output, cli, environment, path} from '@shopify/cli-kit'\nimport Command from '@shopify/cli-kit/node/base-command'\nimport {Flags} from '@oclif/core'\n\nexport default class Deploy extends Command {\n static description = 'Deploy your Hydrogen app to Oxygen hosting'\n static hidden = true\n\n static flags = {\n ...cli.globalFlags,\n ...hydrogenFlags,\n deploymentToken: Flags.string({\n required: true,\n env: 'SHOPIFY_HYDROGEN_FLAG_DEPLOYMENT_TOKEN',\n description: 'Specify your Oxygen deployment token.',\n }),\n commitMessage: Flags.string({\n env: 'SHOPIFY_HYDROGEN_FLAG_COMMIT_MESSAGE',\n description: 'Override the default Git commit message.',\n }),\n commitAuthor: Flags.string({\n env: 'SHOPIFY_HYDROGEN_FLAG_COMMIT_AUTHOR',\n description: 'Override the default Git commit author.',\n }),\n pathToBuild: Flags.string({\n hidden: true,\n env: 'SHOPIFY_HYDROGEN_FLAG_PATH_TO_BUILD',\n description: 'Skip build process and use provided value as build',\n }),\n healthCheck: Flags.boolean({\n env: 'SHOPIFY_HYDROGEN_FLAG_HEALTH_CHECK',\n default: true,\n description: 'Require a health check before the deployment succeeds.',\n }),\n assumeYes: Flags.boolean({\n char: 'y',\n env: 'SHOPIFY_HYDROGEN_FLAG_ASSUME_YES',\n default: false,\n description: 'Automatic yes to prompts. Assume \"yes\" as answer to all prompts and run non-interactively.',\n }),\n oxygenAddress: Flags.string({\n hidden: true,\n env: 'SHOPIFY_HYDROGEN_FLAG_OXYGEN_ADDRESS',\n default: 'oxygen-dms.shopifycloud.com',\n }),\n }\n\n public async run(): Promise<void> {\n const isShopify = await environment.local.isShopify()\n if (!isShopify) {\n output.warn('Command coming soon...')\n return\n }\n\n const {flags} = await this.parse(Deploy)\n const dir = flags.path ? path.resolve(flags.path) : process.cwd()\n\n await deployToOxygen({...flags, path: dir})\n }\n}\n"]}
@@ -0,0 +1,13 @@
1
+ import Command from '@shopify/cli-kit/node/base-command';
2
+ export default class Dev extends Command {
3
+ static description: string;
4
+ static flags: {
5
+ path: import("@oclif/core/lib/interfaces/parser.js").OptionFlag<string | undefined>;
6
+ force: import("@oclif/core/lib/interfaces/parser.js").BooleanFlag<boolean>;
7
+ host: import("@oclif/core/lib/interfaces/parser.js").BooleanFlag<boolean>;
8
+ open: import("@oclif/core/lib/interfaces/parser.js").BooleanFlag<boolean>;
9
+ preset: import("@oclif/core/lib/interfaces/parser.js").OptionFlag<string | undefined>;
10
+ verbose: import("@oclif/core/lib/interfaces/parser.js").BooleanFlag<boolean>;
11
+ };
12
+ run(): Promise<void>;
13
+ }
@@ -0,0 +1,31 @@
1
+ import devService from '../../services/dev.js';
2
+ import { hydrogenFlags } from '../../flags.js';
3
+ import { path, cli } from '@shopify/cli-kit';
4
+ import { Flags } from '@oclif/core';
5
+ import Command from '@shopify/cli-kit/node/base-command';
6
+ export default class Dev extends Command {
7
+ async run() {
8
+ const { flags } = await this.parse(Dev);
9
+ const directory = flags.path ? path.resolve(flags.path) : process.cwd();
10
+ await devService({ directory, ...flags, commandConfig: this.config });
11
+ }
12
+ }
13
+ Dev.description = 'Run a Hydrogen storefront locally for development';
14
+ Dev.flags = {
15
+ ...cli.globalFlags,
16
+ path: hydrogenFlags.path,
17
+ force: Flags.boolean({
18
+ description: 'force dependency pre-bundling.',
19
+ env: 'SHOPIFY_FLAG_DEV_FORCE',
20
+ }),
21
+ host: Flags.boolean({
22
+ description: 'listen on all addresses, including LAN and public addresses.',
23
+ env: 'SHOPIFY_FLAG_DEV_HOST',
24
+ }),
25
+ open: Flags.boolean({
26
+ description: 'automatically open the app in the browser',
27
+ env: 'SHOPIFY_FLAG_DEV_OPEN',
28
+ default: false,
29
+ }),
30
+ };
31
+ //# sourceMappingURL=dev.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dev.js","sourceRoot":"","sources":["../../../../src/cli/commands/hydrogen/dev.ts"],"names":[],"mappings":"AAAA,OAAO,UAAU,MAAM,uBAAuB,CAAA;AAC9C,OAAO,EAAC,aAAa,EAAC,MAAM,gBAAgB,CAAA;AAC5C,OAAO,EAAC,IAAI,EAAE,GAAG,EAAC,MAAM,kBAAkB,CAAA;AAC1C,OAAO,EAAC,KAAK,EAAC,MAAM,aAAa,CAAA;AACjC,OAAO,OAAO,MAAM,oCAAoC,CAAA;AAExD,MAAM,CAAC,OAAO,OAAO,GAAI,SAAQ,OAAO;IAoBtC,KAAK,CAAC,GAAG;QACP,MAAM,EAAC,KAAK,EAAC,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;QACrC,MAAM,SAAS,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,GAAG,EAAE,CAAA;QAEvE,MAAM,UAAU,CAAC,EAAC,SAAS,EAAE,GAAG,KAAK,EAAE,aAAa,EAAE,IAAI,CAAC,MAAM,EAAC,CAAC,CAAA;IACrE,CAAC;;AAxBM,eAAW,GAAG,mDAAmD,CAAA;AACjE,SAAK,GAAG;IACb,GAAG,GAAG,CAAC,WAAW;IAClB,IAAI,EAAE,aAAa,CAAC,IAAI;IACxB,KAAK,EAAE,KAAK,CAAC,OAAO,CAAC;QACnB,WAAW,EAAE,gCAAgC;QAC7C,GAAG,EAAE,wBAAwB;KAC9B,CAAC;IACF,IAAI,EAAE,KAAK,CAAC,OAAO,CAAC;QAClB,WAAW,EAAE,8DAA8D;QAC3E,GAAG,EAAE,uBAAuB;KAC7B,CAAC;IACF,IAAI,EAAE,KAAK,CAAC,OAAO,CAAC;QAClB,WAAW,EAAE,2CAA2C;QACxD,GAAG,EAAE,uBAAuB;QAC5B,OAAO,EAAE,KAAK;KACf,CAAC;CACH,CAAA","sourcesContent":["import devService from '../../services/dev.js'\nimport {hydrogenFlags} from '../../flags.js'\nimport {path, cli} from '@shopify/cli-kit'\nimport {Flags} from '@oclif/core'\nimport Command from '@shopify/cli-kit/node/base-command'\n\nexport default class Dev extends Command {\n static description = 'Run a Hydrogen storefront locally for development'\n static flags = {\n ...cli.globalFlags,\n path: hydrogenFlags.path,\n force: Flags.boolean({\n description: 'force dependency pre-bundling.',\n env: 'SHOPIFY_FLAG_DEV_FORCE',\n }),\n host: Flags.boolean({\n description: 'listen on all addresses, including LAN and public addresses.',\n env: 'SHOPIFY_FLAG_DEV_HOST',\n }),\n open: Flags.boolean({\n description: 'automatically open the app in the browser',\n env: 'SHOPIFY_FLAG_DEV_OPEN',\n default: false,\n }),\n }\n\n async run(): Promise<void> {\n const {flags} = await this.parse(Dev)\n const directory = flags.path ? path.resolve(flags.path) : process.cwd()\n\n await devService({directory, ...flags, commandConfig: this.config})\n }\n}\n"]}
@@ -0,0 +1,12 @@
1
+ import Command from '@shopify/cli-kit/node/base-command';
2
+ export default class Info extends Command {
3
+ static description: string;
4
+ static flags: {
5
+ showToken: import("@oclif/core/lib/interfaces/parser.js").BooleanFlag<boolean>;
6
+ path: import("@oclif/core/lib/interfaces/parser.js").OptionFlag<string | undefined>;
7
+ install: import("@oclif/core/lib/interfaces/parser.js").BooleanFlag<boolean>;
8
+ preset: import("@oclif/core/lib/interfaces/parser.js").OptionFlag<string | undefined>;
9
+ verbose: import("@oclif/core/lib/interfaces/parser.js").BooleanFlag<boolean>;
10
+ };
11
+ run(): Promise<void>;
12
+ }
@@ -0,0 +1,28 @@
1
+ import { info } from '../../services/info.js';
2
+ import { load as loadApp } from '../../models/hydrogen.js';
3
+ import { hydrogenFlags } from '../../flags.js';
4
+ import { Flags } from '@oclif/core';
5
+ import { output, path, cli } from '@shopify/cli-kit';
6
+ import Command from '@shopify/cli-kit/node/base-command';
7
+ export default class Info extends Command {
8
+ async run() {
9
+ const { flags } = await this.parse(Info);
10
+ const directory = flags.path ? path.resolve(flags.path) : process.cwd();
11
+ const app = await loadApp(directory);
12
+ output.info(info(app, { showPrivateData: flags.showToken }));
13
+ if (app.errors)
14
+ process.exit(2);
15
+ }
16
+ }
17
+ Info.description = 'Print basic information about your hydrogen app';
18
+ Info.flags = {
19
+ ...cli.globalFlags,
20
+ ...hydrogenFlags,
21
+ showToken: Flags.boolean({
22
+ hidden: false,
23
+ description: 'Show storefront API token',
24
+ default: false,
25
+ env: 'SHOPIFY_HYDROGEN_FLAG_SHOW_TOKEN',
26
+ }),
27
+ };
28
+ //# sourceMappingURL=info.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"info.js","sourceRoot":"","sources":["../../../../src/cli/commands/hydrogen/info.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,IAAI,EAAC,MAAM,wBAAwB,CAAA;AAC3C,OAAO,EAAC,IAAI,IAAI,OAAO,EAAc,MAAM,0BAA0B,CAAA;AACrE,OAAO,EAAC,aAAa,EAAC,MAAM,gBAAgB,CAAA;AAC5C,OAAO,EAAC,KAAK,EAAC,MAAM,aAAa,CAAA;AACjC,OAAO,EAAC,MAAM,EAAE,IAAI,EAAE,GAAG,EAAC,MAAM,kBAAkB,CAAA;AAClD,OAAO,OAAO,MAAM,oCAAoC,CAAA;AAExD,MAAM,CAAC,OAAO,OAAO,IAAK,SAAQ,OAAO;IAchC,KAAK,CAAC,GAAG;QACd,MAAM,EAAC,KAAK,EAAC,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAA;QACtC,MAAM,SAAS,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,GAAG,EAAE,CAAA;QACvE,MAAM,GAAG,GAAgB,MAAM,OAAO,CAAC,SAAS,CAAC,CAAA;QAEjD,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,EAAC,eAAe,EAAE,KAAK,CAAC,SAAS,EAAC,CAAC,CAAC,CAAA;QAC1D,IAAI,GAAG,CAAC,MAAM;YAAE,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;IACjC,CAAC;;AApBM,gBAAW,GAAG,iDAAiD,CAAA;AAE/D,UAAK,GAAG;IACb,GAAG,GAAG,CAAC,WAAW;IAClB,GAAG,aAAa;IAChB,SAAS,EAAE,KAAK,CAAC,OAAO,CAAC;QACvB,MAAM,EAAE,KAAK;QACb,WAAW,EAAE,2BAA2B;QACxC,OAAO,EAAE,KAAK;QACd,GAAG,EAAE,kCAAkC;KACxC,CAAC;CACH,CAAA","sourcesContent":["import {info} from '../../services/info.js'\nimport {load as loadApp, HydrogenApp} from '../../models/hydrogen.js'\nimport {hydrogenFlags} from '../../flags.js'\nimport {Flags} from '@oclif/core'\nimport {output, path, cli} from '@shopify/cli-kit'\nimport Command from '@shopify/cli-kit/node/base-command'\n\nexport default class Info extends Command {\n static description = 'Print basic information about your hydrogen app'\n\n static flags = {\n ...cli.globalFlags,\n ...hydrogenFlags,\n showToken: Flags.boolean({\n hidden: false,\n description: 'Show storefront API token',\n default: false,\n env: 'SHOPIFY_HYDROGEN_FLAG_SHOW_TOKEN',\n }),\n }\n\n public async run(): Promise<void> {\n const {flags} = await this.parse(Info)\n const directory = flags.path ? path.resolve(flags.path) : process.cwd()\n const app: HydrogenApp = await loadApp(directory)\n\n output.info(info(app, {showPrivateData: flags.showToken}))\n if (app.errors) process.exit(2)\n }\n}\n"]}
@@ -0,0 +1,13 @@
1
+ import Command from '@shopify/cli-kit/node/base-command';
2
+ export default class Preview extends Command {
3
+ static description: string;
4
+ static flags: {
5
+ path: import("@oclif/core/lib/interfaces/parser.js").OptionFlag<string | undefined>;
6
+ port: import("@oclif/core/lib/interfaces/parser.js").OptionFlag<string>;
7
+ env: import("@oclif/core/lib/interfaces/parser.js").OptionFlag<string | undefined>;
8
+ target: import("@oclif/core/lib/interfaces/parser.js").OptionFlag<string>;
9
+ preset: import("@oclif/core/lib/interfaces/parser.js").OptionFlag<string | undefined>;
10
+ verbose: import("@oclif/core/lib/interfaces/parser.js").BooleanFlag<boolean>;
11
+ };
12
+ run(): Promise<void>;
13
+ }
@@ -0,0 +1,46 @@
1
+ import { previewInWorker, previewInNode } from '../../services/preview.js';
2
+ import { hydrogenFlags } from '../../flags.js';
3
+ import { path, cli } from '@shopify/cli-kit';
4
+ import { Flags } from '@oclif/core';
5
+ import Command from '@shopify/cli-kit/node/base-command';
6
+ export default class Preview extends Command {
7
+ async run() {
8
+ const { flags } = await this.parse(Preview);
9
+ const directory = flags.path ? path.resolve(flags.path) : process.cwd();
10
+ const port = parseInt(flags.port, 10);
11
+ const envPath = flags.env;
12
+ if (flags.target === 'worker') {
13
+ await previewInWorker({ directory, port, envPath });
14
+ }
15
+ else if (flags.target === 'node') {
16
+ await previewInNode({ directory, port });
17
+ }
18
+ }
19
+ }
20
+ Preview.description = 'Run a Hydrogen storefront locally in a worker environment';
21
+ Preview.flags = {
22
+ ...cli.globalFlags,
23
+ path: hydrogenFlags.path,
24
+ port: Flags.string({
25
+ char: 'p',
26
+ hidden: true,
27
+ description: 'the port to run the preview server on',
28
+ default: '3000',
29
+ env: 'SHOPIFY_FLAG_PORT',
30
+ }),
31
+ env: Flags.string({
32
+ char: 'e',
33
+ description: 'the file path to your .env',
34
+ default: undefined,
35
+ parse: (input, _) => Promise.resolve(path.resolve(input)),
36
+ env: 'SHOPIFY_FLAG_ENV_PATH',
37
+ }),
38
+ target: Flags.string({
39
+ char: 't',
40
+ description: 'the target environment (worker or node)',
41
+ options: ['node', 'worker'],
42
+ default: 'worker',
43
+ env: 'SHOPIFY_FLAG_PREVIEW_TARGET',
44
+ }),
45
+ };
46
+ //# sourceMappingURL=preview.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"preview.js","sourceRoot":"","sources":["../../../../src/cli/commands/hydrogen/preview.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,eAAe,EAAE,aAAa,EAAC,MAAM,2BAA2B,CAAA;AACxE,OAAO,EAAC,aAAa,EAAC,MAAM,gBAAgB,CAAA;AAC5C,OAAO,EAAC,IAAI,EAAE,GAAG,EAAC,MAAM,kBAAkB,CAAA;AAC1C,OAAO,EAAC,KAAK,EAAC,MAAM,aAAa,CAAA;AACjC,OAAO,OAAO,MAAM,oCAAoC,CAAA;AAExD,MAAM,CAAC,OAAO,OAAO,OAAQ,SAAQ,OAAO;IA4B1C,KAAK,CAAC,GAAG;QACP,MAAM,EAAC,KAAK,EAAC,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAA;QACzC,MAAM,SAAS,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,GAAG,EAAE,CAAA;QACvE,MAAM,IAAI,GAAG,QAAQ,CAAC,KAAK,CAAC,IAAI,EAAE,EAAE,CAAC,CAAA;QACrC,MAAM,OAAO,GAAG,KAAK,CAAC,GAAG,CAAA;QAEzB,IAAI,KAAK,CAAC,MAAM,KAAK,QAAQ,EAAE;YAC7B,MAAM,eAAe,CAAC,EAAC,SAAS,EAAE,IAAI,EAAE,OAAO,EAAC,CAAC,CAAA;SAClD;aAAM,IAAI,KAAK,CAAC,MAAM,KAAK,MAAM,EAAE;YAClC,MAAM,aAAa,CAAC,EAAC,SAAS,EAAE,IAAI,EAAC,CAAC,CAAA;SACvC;IACH,CAAC;;AAtCM,mBAAW,GAAG,2DAA2D,CAAA;AACzE,aAAK,GAAG;IACb,GAAG,GAAG,CAAC,WAAW;IAClB,IAAI,EAAE,aAAa,CAAC,IAAI;IACxB,IAAI,EAAE,KAAK,CAAC,MAAM,CAAC;QACjB,IAAI,EAAE,GAAG;QACT,MAAM,EAAE,IAAI;QACZ,WAAW,EAAE,uCAAuC;QACpD,OAAO,EAAE,MAAM;QACf,GAAG,EAAE,mBAAmB;KACzB,CAAC;IACF,GAAG,EAAE,KAAK,CAAC,MAAM,CAAC;QAChB,IAAI,EAAE,GAAG;QACT,WAAW,EAAE,4BAA4B;QACzC,OAAO,EAAE,SAAS;QAClB,KAAK,EAAE,CAAC,KAAK,EAAE,CAAC,EAAE,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QACzD,GAAG,EAAE,uBAAuB;KAC7B,CAAC;IACF,MAAM,EAAE,KAAK,CAAC,MAAM,CAAC;QACnB,IAAI,EAAE,GAAG;QACT,WAAW,EAAE,yCAAyC;QACtD,OAAO,EAAE,CAAC,MAAM,EAAE,QAAQ,CAAC;QAC3B,OAAO,EAAE,QAAQ;QACjB,GAAG,EAAE,6BAA6B;KACnC,CAAC;CACH,CAAA","sourcesContent":["import {previewInWorker, previewInNode} from '../../services/preview.js'\nimport {hydrogenFlags} from '../../flags.js'\nimport {path, cli} from '@shopify/cli-kit'\nimport {Flags} from '@oclif/core'\nimport Command from '@shopify/cli-kit/node/base-command'\n\nexport default class Preview extends Command {\n static description = 'Run a Hydrogen storefront locally in a worker environment'\n static flags = {\n ...cli.globalFlags,\n path: hydrogenFlags.path,\n port: Flags.string({\n char: 'p',\n hidden: true,\n description: 'the port to run the preview server on',\n default: '3000',\n env: 'SHOPIFY_FLAG_PORT',\n }),\n env: Flags.string({\n char: 'e',\n description: 'the file path to your .env',\n default: undefined,\n parse: (input, _) => Promise.resolve(path.resolve(input)),\n env: 'SHOPIFY_FLAG_ENV_PATH',\n }),\n target: Flags.string({\n char: 't',\n description: 'the target environment (worker or node)',\n options: ['node', 'worker'],\n default: 'worker',\n env: 'SHOPIFY_FLAG_PREVIEW_TARGET',\n }),\n }\n\n async run(): Promise<void> {\n const {flags} = await this.parse(Preview)\n const directory = flags.path ? path.resolve(flags.path) : process.cwd()\n const port = parseInt(flags.port, 10)\n const envPath = flags.env\n\n if (flags.target === 'worker') {\n await previewInWorker({directory, port, envPath})\n } else if (flags.target === 'node') {\n await previewInNode({directory, port})\n }\n }\n}\n"]}
@@ -0,0 +1,15 @@
1
+ export declare const configurationFileNames: {
2
+ readonly hydrogen: "hydrogen.config";
3
+ };
4
+ export declare const supportedConfigExtensions: string[];
5
+ export declare const dotEnvFileNames: {
6
+ production: string;
7
+ };
8
+ export declare const genericConfigurationFileNames: {
9
+ readonly tailwind: "tailwind.config";
10
+ readonly postCSS: "postcss.config";
11
+ readonly eslint: ".eslintrc.js";
12
+ readonly typescript: {
13
+ readonly config: "tsconfig.json";
14
+ };
15
+ };
@@ -0,0 +1,16 @@
1
+ export const configurationFileNames = {
2
+ hydrogen: 'hydrogen.config',
3
+ };
4
+ export const supportedConfigExtensions = ['ts', 'js', 'mjs', 'cjs', 'json'];
5
+ export const dotEnvFileNames = {
6
+ production: '.env',
7
+ };
8
+ export const genericConfigurationFileNames = {
9
+ tailwind: 'tailwind.config',
10
+ postCSS: 'postcss.config',
11
+ eslint: '.eslintrc.js',
12
+ typescript: {
13
+ config: 'tsconfig.json',
14
+ },
15
+ };
16
+ //# sourceMappingURL=constants.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"constants.js","sourceRoot":"","sources":["../../src/cli/constants.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,sBAAsB,GAAG;IACpC,QAAQ,EAAE,iBAAiB;CACnB,CAAA;AAEV,MAAM,CAAC,MAAM,yBAAyB,GAAG,CAAC,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,CAAC,CAAA;AAE3E,MAAM,CAAC,MAAM,eAAe,GAAG;IAC7B,UAAU,EAAE,MAAM;CACnB,CAAA;AAED,MAAM,CAAC,MAAM,6BAA6B,GAAG;IAC3C,QAAQ,EAAE,iBAAiB;IAC3B,OAAO,EAAE,gBAAgB;IACzB,MAAM,EAAE,cAAc;IACtB,UAAU,EAAE;QACV,MAAM,EAAE,eAAe;KACxB;CACO,CAAA","sourcesContent":["export const configurationFileNames = {\n hydrogen: 'hydrogen.config',\n} as const\n\nexport const supportedConfigExtensions = ['ts', 'js', 'mjs', 'cjs', 'json']\n\nexport const dotEnvFileNames = {\n production: '.env',\n}\n\nexport const genericConfigurationFileNames = {\n tailwind: 'tailwind.config',\n postCSS: 'postcss.config',\n eslint: '.eslintrc.js',\n typescript: {\n config: 'tsconfig.json',\n },\n} as const\n"]}
@@ -0,0 +1,4 @@
1
+ export declare const hydrogenFlags: {
2
+ path: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined>;
3
+ install: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
4
+ };
@@ -0,0 +1,16 @@
1
+ import { Flags } from '@oclif/core';
2
+ export const hydrogenFlags = {
3
+ path: Flags.string({
4
+ hidden: true,
5
+ description: 'the path to your hydrogen storefront',
6
+ env: 'SHOPIFY_HYDROGEN_FLAG_PATH',
7
+ }),
8
+ install: Flags.boolean({
9
+ hidden: true,
10
+ default: true,
11
+ description: 'should install packages',
12
+ env: 'SHOPIFY_HYDROGEN_FLAG_INSTALL',
13
+ allowNo: true,
14
+ }),
15
+ };
16
+ //# sourceMappingURL=flags.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"flags.js","sourceRoot":"","sources":["../../src/cli/flags.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,KAAK,EAAC,MAAM,aAAa,CAAA;AAEjC,MAAM,CAAC,MAAM,aAAa,GAAG;IAC3B,IAAI,EAAE,KAAK,CAAC,MAAM,CAAC;QACjB,MAAM,EAAE,IAAI;QACZ,WAAW,EAAE,sCAAsC;QACnD,GAAG,EAAE,4BAA4B;KAClC,CAAC;IACF,OAAO,EAAE,KAAK,CAAC,OAAO,CAAC;QACrB,MAAM,EAAE,IAAI;QACZ,OAAO,EAAE,IAAI;QACb,WAAW,EAAE,yBAAyB;QACtC,GAAG,EAAE,+BAA+B;QACpC,OAAO,EAAE,IAAI;KACd,CAAC;CACH,CAAA","sourcesContent":["import {Flags} from '@oclif/core'\n\nexport const hydrogenFlags = {\n path: Flags.string({\n hidden: true,\n description: 'the path to your hydrogen storefront',\n env: 'SHOPIFY_HYDROGEN_FLAG_PATH',\n }),\n install: Flags.boolean({\n hidden: true,\n default: true,\n description: 'should install packages',\n env: 'SHOPIFY_HYDROGEN_FLAG_INSTALL',\n allowNo: true,\n }),\n}\n"]}
@@ -0,0 +1,22 @@
1
+ import { PackageManager } from '@shopify/cli-kit/node/node-package-manager';
2
+ import type { HydrogenConfig } from '@shopify/hydrogen/config';
3
+ export interface HydrogenApp {
4
+ name: string;
5
+ directory: string;
6
+ packageManager: PackageManager;
7
+ configuration: HydrogenConfig;
8
+ nodeDependencies: {
9
+ [key: string]: string;
10
+ };
11
+ language: 'JavaScript' | 'TypeScript';
12
+ errors?: AppErrors;
13
+ }
14
+ declare class AppErrors {
15
+ private errors;
16
+ addError(path: string, message: string): void;
17
+ getError(path: string): string | undefined;
18
+ isEmpty(): boolean;
19
+ toJSON(): string[];
20
+ }
21
+ export declare function load(directory: string): Promise<HydrogenApp>;
22
+ export {};