@commercetools-frontend/mc-scripts 25.1.0 → 25.2.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.
Files changed (56) hide show
  1. package/cli/dist/commercetools-frontend-mc-scripts-cli.cjs.dev.js +20 -7
  2. package/cli/dist/commercetools-frontend-mc-scripts-cli.cjs.prod.js +20 -7
  3. package/cli/dist/commercetools-frontend-mc-scripts-cli.esm.js +20 -7
  4. package/dist/{build-ec10df64.cjs.prod.js → build-182a099c.cjs.prod.js} +3 -3
  5. package/dist/{build-dbcd0936.esm.js → build-220a1658.esm.js} +3 -3
  6. package/dist/{build-0a5986d1.cjs.dev.js → build-519d246d.cjs.dev.js} +3 -3
  7. package/dist/{build-vite-16b1a575.cjs.dev.js → build-vite-837e7c94.cjs.dev.js} +56 -34
  8. package/dist/{build-vite-59e1f185.esm.js → build-vite-8cae71a0.esm.js} +53 -15
  9. package/dist/{build-vite-5d317720.cjs.prod.js → build-vite-b007241b.cjs.prod.js} +56 -34
  10. package/dist/commercetools-frontend-mc-scripts.cjs.dev.js +1 -1
  11. package/dist/commercetools-frontend-mc-scripts.cjs.prod.js +1 -1
  12. package/dist/commercetools-frontend-mc-scripts.esm.js +1 -1
  13. package/dist/config-sync-0b96d430.esm.js +255 -0
  14. package/dist/config-sync-b3072939.cjs.prod.js +265 -0
  15. package/dist/config-sync-ci-4a09aa00.cjs.prod.js +305 -0
  16. package/dist/config-sync-ci-85e3fec2.esm.js +294 -0
  17. package/dist/config-sync-ci-eadb8bfc.cjs.dev.js +305 -0
  18. package/dist/config-sync-f8fca39f.cjs.dev.js +265 -0
  19. package/dist/{config-sync-ce05c66c.cjs.prod.js → config-sync-helpers-11fc328f.cjs.prod.js} +162 -287
  20. package/dist/{config-sync-dbb43993.cjs.dev.js → config-sync-helpers-dab59ed9.cjs.dev.js} +162 -287
  21. package/dist/{config-sync-e7f53a98.esm.js → config-sync-helpers-fe6ea729.esm.js} +154 -283
  22. package/dist/{create-postcss-config-91c09596.cjs.prod.js → create-postcss-config-56b74a34.cjs.prod.js} +1 -1
  23. package/dist/{create-postcss-config-381b636b.cjs.dev.js → create-postcss-config-78879a12.cjs.dev.js} +1 -1
  24. package/dist/{create-postcss-config-0a86560d.esm.js → create-postcss-config-95f9bf62.esm.js} +1 -1
  25. package/dist/{create-webpack-config-for-development-37677a49.cjs.prod.js → create-webpack-config-for-development-3eb1b365.cjs.prod.js} +2 -2
  26. package/dist/{create-webpack-config-for-development-488742b2.cjs.dev.js → create-webpack-config-for-development-62b89920.cjs.dev.js} +2 -2
  27. package/dist/{create-webpack-config-for-development-df3f7f7f.esm.js → create-webpack-config-for-development-a28736fa.esm.js} +2 -2
  28. package/dist/{create-webpack-config-for-production-e22f78d2.esm.js → create-webpack-config-for-production-21ea561f.esm.js} +2 -2
  29. package/dist/{create-webpack-config-for-production-aad64e2a.cjs.prod.js → create-webpack-config-for-production-3b6599db.cjs.prod.js} +2 -2
  30. package/dist/{create-webpack-config-for-production-46d817cc.cjs.dev.js → create-webpack-config-for-production-e5ed8805.cjs.dev.js} +2 -2
  31. package/dist/{credentials-storage-0b89aa0e.cjs.prod.js → credentials-storage-6d592cd6.cjs.prod.js} +20 -2
  32. package/dist/{credentials-storage-cbb5c559.cjs.dev.js → credentials-storage-c4c5980e.cjs.dev.js} +20 -2
  33. package/dist/{credentials-storage-4464313c.esm.js → credentials-storage-fcc77fb6.esm.js} +20 -2
  34. package/dist/declarations/src/types.d.ts +4 -0
  35. package/dist/{deployment-previews-set-bbef95d2.esm.js → deployment-previews-set-7d49e7df.esm.js} +3 -3
  36. package/dist/{deployment-previews-set-4edd48db.cjs.dev.js → deployment-previews-set-8d6a1e99.cjs.dev.js} +3 -3
  37. package/dist/{deployment-previews-set-636fb1a3.cjs.prod.js → deployment-previews-set-f8ce3db7.cjs.prod.js} +3 -3
  38. package/dist/{graphql-requests-0a6eeb3a.cjs.prod.js → graphql-requests-b57fca4c.cjs.prod.js} +2 -2
  39. package/dist/{graphql-requests-14074b2b.esm.js → graphql-requests-d2fa2ca7.esm.js} +3 -3
  40. package/dist/{graphql-requests-23f7ddb1.cjs.dev.js → graphql-requests-da194989.cjs.dev.js} +2 -2
  41. package/dist/{login-54ebae96.cjs.prod.js → login-9774c9cc.cjs.prod.js} +130 -11
  42. package/dist/{login-1b222f33.esm.js → login-abb38213.esm.js} +127 -10
  43. package/dist/{login-a6fd5fbf.cjs.dev.js → login-f4550251.cjs.dev.js} +130 -11
  44. package/dist/{package-e1f7242c.cjs.prod.js → package-0eebca1b.cjs.dev.js} +20 -10
  45. package/dist/{package-a34835d9.esm.js → package-9e6910b8.esm.js} +20 -10
  46. package/dist/{package-d8b1f4c0.cjs.dev.js → package-b9298ce3.cjs.prod.js} +20 -10
  47. package/dist/{start-890895df.esm.js → start-109f9462.esm.js} +3 -3
  48. package/dist/{start-37ec4a7e.cjs.dev.js → start-7765f44c.cjs.dev.js} +3 -3
  49. package/dist/{start-0be8a294.cjs.prod.js → start-e014127c.cjs.prod.js} +3 -3
  50. package/package.json +20 -10
  51. package/postcss/dist/commercetools-frontend-mc-scripts-postcss.cjs.dev.js +2 -2
  52. package/postcss/dist/commercetools-frontend-mc-scripts-postcss.cjs.prod.js +2 -2
  53. package/postcss/dist/commercetools-frontend-mc-scripts-postcss.esm.js +2 -2
  54. package/webpack/dist/commercetools-frontend-mc-scripts-webpack.cjs.dev.js +4 -4
  55. package/webpack/dist/commercetools-frontend-mc-scripts-webpack.cjs.prod.js +4 -4
  56. package/webpack/dist/commercetools-frontend-mc-scripts-webpack.esm.js +4 -4
@@ -0,0 +1,265 @@
1
+ 'use strict';
2
+
3
+ var _slicedToArray = require('@babel/runtime-corejs3/helpers/slicedToArray');
4
+ var _mapInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/map');
5
+ var _findInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/find');
6
+ var _filterInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/filter');
7
+ var chalk = require('chalk');
8
+ var prompts = require('prompts');
9
+ var applicationConfig = require('@commercetools-frontend/application-config');
10
+ var configSyncHelpers = require('./config-sync-helpers-dab59ed9.cjs.dev.js');
11
+ var credentialsStorage$1 = require('./credentials-storage-c4c5980e.cjs.dev.js');
12
+ var graphqlRequests = require('./graphql-requests-da194989.cjs.dev.js');
13
+ require('@babel/runtime-corejs3/core-js-stable/json/stringify');
14
+ require('lodash/omit');
15
+ require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-symbols');
16
+ require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptor');
17
+ require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptors');
18
+ require('@babel/runtime-corejs3/core-js-stable/object/define-properties');
19
+ require('@babel/runtime-corejs3/core-js-stable/object/define-property');
20
+ require('@babel/runtime-corejs3/helpers/defineProperty');
21
+ require('@babel/runtime-corejs3/core-js-stable/instance/repeat');
22
+ require('@babel/runtime-corejs3/core-js-stable/set');
23
+ require('@babel/runtime-corejs3/core-js-stable/instance/for-each');
24
+ require('@babel/runtime-corejs3/core-js-stable/instance/bind');
25
+ require('@babel/runtime-corejs3/core-js-stable/instance/reduce');
26
+ require('@babel/runtime-corejs3/core-js-stable/object/keys');
27
+ require('@babel/runtime-corejs3/helpers/classCallCheck');
28
+ require('@babel/runtime-corejs3/helpers/createClass');
29
+ require('@babel/runtime-corejs3/core-js-stable/date/now');
30
+ require('node:fs');
31
+ require('node:os');
32
+ require('node:path');
33
+ require('./does-file-exist-eb86baca.cjs.dev.js');
34
+ require('@babel/runtime-corejs3/core-js-stable/instance/some');
35
+ require('graphql');
36
+ require('graphql-request');
37
+ require('@commercetools-frontend/constants');
38
+ require('@commercetools/http-user-agent');
39
+ require('./package-0eebca1b.cjs.dev.js');
40
+
41
+ function _interopDefault (e) { return e && e.__esModule ? e : { 'default': e }; }
42
+
43
+ var _mapInstanceProperty__default = /*#__PURE__*/_interopDefault(_mapInstanceProperty);
44
+ var _findInstanceProperty__default = /*#__PURE__*/_interopDefault(_findInstanceProperty);
45
+ var _filterInstanceProperty__default = /*#__PURE__*/_interopDefault(_filterInstanceProperty);
46
+ var chalk__default = /*#__PURE__*/_interopDefault(chalk);
47
+ var prompts__default = /*#__PURE__*/_interopDefault(prompts);
48
+
49
+ const credentialsStorage = new credentialsStorage$1.CredentialsStorage();
50
+ async function promptForOrganization(_ref) {
51
+ var _context;
52
+ let mcApiUrl = _ref.mcApiUrl,
53
+ applicationIdentifier = _ref.applicationIdentifier,
54
+ customViewId = _ref.customViewId,
55
+ entityType = _ref.entityType;
56
+ const userOrganizations = await graphqlRequests.fetchUserOrganizations({
57
+ mcApiUrl,
58
+ applicationIdentifier,
59
+ customViewId
60
+ });
61
+ if (userOrganizations.total === 0) {
62
+ throw new Error(`It seems you are not an admin of any Organization. Please make sure to be part of the Administrators team of the Organization you want the ${entityType} to be configured to.`);
63
+ }
64
+ if (userOrganizations.total === 1) {
65
+ const _userOrganizations$re = _slicedToArray(userOrganizations.results, 1),
66
+ organization = _userOrganizations$re[0];
67
+ return {
68
+ id: organization.id,
69
+ name: organization.name
70
+ };
71
+ }
72
+ const organizationChoices = _mapInstanceProperty__default["default"](_context = userOrganizations.results).call(_context, organization => ({
73
+ title: organization.name,
74
+ value: organization.id
75
+ }));
76
+ const _await$prompts = await prompts__default["default"]({
77
+ type: 'select',
78
+ name: 'organizationId',
79
+ message: 'Select an Organization',
80
+ choices: organizationChoices,
81
+ initial: 0
82
+ }),
83
+ selectedOrganizationId = _await$prompts.organizationId;
84
+ if (!selectedOrganizationId) {
85
+ throw new Error(`No Organization selected, aborting.`);
86
+ }
87
+ const organizationName = _findInstanceProperty__default["default"](organizationChoices).call(organizationChoices, _ref2 => {
88
+ let value = _ref2.value;
89
+ return value === selectedOrganizationId;
90
+ }).title;
91
+ return {
92
+ id: selectedOrganizationId,
93
+ name: organizationName
94
+ };
95
+ }
96
+ async function confirmAction(_ref3) {
97
+ var _context2;
98
+ let message = _ref3.message,
99
+ dryRun = _ref3.dryRun,
100
+ dryRunMessage = _ref3.dryRunMessage;
101
+ const _await$prompts2 = await prompts__default["default"]({
102
+ type: 'text',
103
+ name: 'confirmation',
104
+ message: _filterInstanceProperty__default["default"](_context2 = [message, dryRun && chalk__default["default"].gray(dryRunMessage)]).call(_context2, Boolean).join('\n'),
105
+ initial: 'yes'
106
+ }),
107
+ confirmation = _await$prompts2.confirmation;
108
+ if (!confirmation || confirmation.toLowerCase().charAt(0) !== 'y') {
109
+ console.log(chalk__default["default"].red('Aborted.'));
110
+ return false;
111
+ }
112
+ return true;
113
+ }
114
+ async function createOrUpdateCustomApplication(_ref4) {
115
+ let mcApiUrl = _ref4.mcApiUrl,
116
+ localCustomEntityData = _ref4.localCustomEntityData,
117
+ applicationIdentifier = _ref4.applicationIdentifier,
118
+ options = _ref4.options;
119
+ const status = await configSyncHelpers.checkCustomApplicationStatus({
120
+ mcApiUrl,
121
+ entryPointUriPath: localCustomEntityData.entryPointUriPath,
122
+ applicationIdentifier,
123
+ localCustomEntityData
124
+ });
125
+ if (!status.exists) {
126
+ // Create new Custom Application
127
+ const organization = await promptForOrganization({
128
+ mcApiUrl,
129
+ applicationIdentifier,
130
+ entityType: 'Custom Application'
131
+ });
132
+ const confirmed = await confirmAction({
133
+ message: `You are about to create a new Custom Application in the "${chalk__default["default"].green(organization.name)}" organization. Are you sure you want to proceed?`,
134
+ dryRun: options.dryRun,
135
+ dryRunMessage: 'Using "--dry-run", no data will be created.'
136
+ });
137
+ if (!confirmed) return;
138
+ await configSyncHelpers.performCreateCustomApplication({
139
+ mcApiUrl,
140
+ organizationId: organization.id,
141
+ organizationName: organization.name,
142
+ localCustomEntityData,
143
+ applicationIdentifier,
144
+ dryRun: options.dryRun
145
+ });
146
+ return;
147
+ }
148
+
149
+ // Check for changes
150
+ if (!status.configDiff) {
151
+ console.log(chalk__default["default"].green(`Custom Application up-to-date.`));
152
+ console.log(`You can inspect the Custom Application data in the Merchant Center at "${chalk__default["default"].gray(status.link)}".`);
153
+ return;
154
+ }
155
+ console.log('Changes detected:');
156
+ console.log(status.configDiff);
157
+ console.log();
158
+ const confirmed = await confirmAction({
159
+ message: `You are about to update the Custom Application "${chalk__default["default"].green(localCustomEntityData.entryPointUriPath)}" with the changes above. Are you sure you want to proceed?`,
160
+ dryRun: options.dryRun,
161
+ dryRunMessage: 'Using "--dry-run", no data will be updated.'
162
+ });
163
+ if (!confirmed) return;
164
+ await configSyncHelpers.performUpdateCustomApplication({
165
+ mcApiUrl,
166
+ organizationId: status.organizationId,
167
+ applicationId: status.applicationId,
168
+ localCustomEntityData,
169
+ applicationIdentifier,
170
+ dryRun: options.dryRun
171
+ });
172
+ }
173
+ async function createOrUpdateCustomView(_ref5) {
174
+ let mcApiUrl = _ref5.mcApiUrl,
175
+ localCustomEntityData = _ref5.localCustomEntityData,
176
+ customViewId = _ref5.customViewId,
177
+ options = _ref5.options,
178
+ applicationIdentifier = _ref5.applicationIdentifier;
179
+ const status = await configSyncHelpers.checkCustomViewStatus({
180
+ mcApiUrl,
181
+ customViewId,
182
+ applicationIdentifier,
183
+ localCustomEntityData
184
+ });
185
+ if (!status.exists) {
186
+ // Create new Custom View
187
+ const organization = await promptForOrganization({
188
+ mcApiUrl,
189
+ applicationIdentifier,
190
+ customViewId,
191
+ entityType: 'Custom View'
192
+ });
193
+ const confirmed = await confirmAction({
194
+ message: `You are about to create a new Custom View in the "${chalk__default["default"].green(organization.name)}" organization. Are you sure you want to proceed?`,
195
+ dryRun: options.dryRun,
196
+ dryRunMessage: 'Using "--dry-run", no data will be created.'
197
+ });
198
+ if (!confirmed) return;
199
+ await configSyncHelpers.performCreateCustomView({
200
+ mcApiUrl,
201
+ organizationId: organization.id,
202
+ organizationName: organization.name,
203
+ localCustomEntityData,
204
+ applicationIdentifier,
205
+ dryRun: options.dryRun
206
+ });
207
+ return;
208
+ }
209
+
210
+ // Check for changes
211
+ if (!status.configDiff) {
212
+ console.log(chalk__default["default"].green(`Custom View up-to-date.`));
213
+ console.log(`You can inspect the Custom View data in the Merchant Center at "${chalk__default["default"].gray(status.link)}".`);
214
+ return;
215
+ }
216
+ console.log('Changes detected:');
217
+ console.log(status.configDiff);
218
+ console.log();
219
+ const confirmed = await confirmAction({
220
+ message: `You are about to update the Custom View "${chalk__default["default"].green(localCustomEntityData.defaultLabel)}" with the changes above. Are you sure you want to proceed?`,
221
+ dryRun: options.dryRun,
222
+ dryRunMessage: 'Using "--dry-run", no data will be updated.'
223
+ });
224
+ if (!confirmed) return;
225
+ await configSyncHelpers.performUpdateCustomView({
226
+ mcApiUrl,
227
+ organizationId: status.organizationId,
228
+ customViewId: status.customViewId,
229
+ localCustomEntityData,
230
+ applicationIdentifier,
231
+ dryRun: options.dryRun
232
+ });
233
+ }
234
+ async function run(options) {
235
+ const applicationConfig$1 = await applicationConfig.processConfig();
236
+ const localCustomEntityData = applicationConfig$1.data;
237
+ const _applicationConfig$en = applicationConfig$1.env,
238
+ mcApiUrl = _applicationConfig$en.mcApiUrl,
239
+ applicationIdentifier = _applicationConfig$en.applicationIdentifier,
240
+ customViewId = _applicationConfig$en.customViewId;
241
+ console.log(`Using Merchant Center environment "${chalk__default["default"].green(mcApiUrl)}".`);
242
+ console.log();
243
+ const isSessionValid = credentialsStorage.isSessionValid(mcApiUrl);
244
+ if (!isSessionValid) {
245
+ throw new Error(`You don't have a valid session. Please, run the "mc-scripts login" command to authenticate yourself.`);
246
+ }
247
+ if (configSyncHelpers.isCustomViewData(localCustomEntityData)) {
248
+ await createOrUpdateCustomView({
249
+ mcApiUrl,
250
+ localCustomEntityData,
251
+ applicationIdentifier,
252
+ customViewId: customViewId || localCustomEntityData.id,
253
+ options
254
+ });
255
+ } else {
256
+ await createOrUpdateCustomApplication({
257
+ mcApiUrl,
258
+ localCustomEntityData,
259
+ applicationIdentifier,
260
+ options
261
+ });
262
+ }
263
+ }
264
+
265
+ exports["default"] = run;