@atlaskit/codemod-cli 0.11.5 → 0.12.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (51) hide show
  1. package/CHANGELOG.md +16 -0
  2. package/dist/cjs/cli.js +75 -68
  3. package/dist/cjs/filepath.js +29 -69
  4. package/dist/cjs/index.js +3 -3
  5. package/dist/cjs/main.js +167 -337
  6. package/dist/cjs/presets/css-to-design-tokens/css-to-design-tokens.js +31 -73
  7. package/dist/cjs/presets/css-to-design-tokens/utils/legacy-colors.js +3 -3
  8. package/dist/cjs/presets/css-to-design-tokens/utils/meta.js +6 -19
  9. package/dist/cjs/presets/index.js +1 -3
  10. package/dist/cjs/presets/styled-to-emotion/styled-to-emotion.js +12 -19
  11. package/dist/cjs/presets/theme-to-design-tokens/theme-to-design-tokens.js +32 -61
  12. package/dist/cjs/presets/theme-to-design-tokens/utils/ast-meta.js +13 -26
  13. package/dist/cjs/presets/theme-to-design-tokens/utils/color.js +7 -11
  14. package/dist/cjs/presets/theme-to-design-tokens/utils/fuzzy-search.js +6 -10
  15. package/dist/cjs/presets/theme-to-design-tokens/utils/legacy-colors.js +3 -3
  16. package/dist/cjs/presets/theme-to-design-tokens/utils/named-colors.js +1 -1
  17. package/dist/cjs/presets/theme-to-design-tokens/utils/tokens.js +2 -16
  18. package/dist/cjs/sinceRef.js +35 -70
  19. package/dist/cjs/transforms.js +26 -44
  20. package/dist/cjs/types.js +3 -27
  21. package/dist/cjs/utils.js +6 -6
  22. package/dist/cjs/version.json +1 -1
  23. package/dist/es2019/version.json +1 -1
  24. package/dist/esm/cli.js +53 -55
  25. package/dist/esm/filepath.js +50 -54
  26. package/dist/esm/main.js +220 -230
  27. package/dist/esm/presets/css-to-design-tokens/css-to-design-tokens.js +11 -13
  28. package/dist/esm/sinceRef.js +48 -50
  29. package/dist/esm/version.json +1 -1
  30. package/dist/types-ts4.0/cli.d.ts +1 -0
  31. package/dist/types-ts4.0/filepath.d.ts +2 -0
  32. package/dist/types-ts4.0/index.d.ts +4 -0
  33. package/dist/types-ts4.0/main.d.ts +19 -0
  34. package/dist/types-ts4.0/presets/css-to-design-tokens/css-to-design-tokens.d.ts +2 -0
  35. package/dist/types-ts4.0/presets/css-to-design-tokens/utils/legacy-colors.d.ts +3 -0
  36. package/dist/types-ts4.0/presets/css-to-design-tokens/utils/meta.d.ts +1 -0
  37. package/dist/types-ts4.0/presets/index.d.ts +9 -0
  38. package/dist/types-ts4.0/presets/styled-to-emotion/styled-to-emotion.d.ts +6 -0
  39. package/dist/types-ts4.0/presets/theme-to-design-tokens/theme-to-design-tokens.d.ts +2 -0
  40. package/dist/types-ts4.0/presets/theme-to-design-tokens/utils/ast-meta.d.ts +3 -0
  41. package/dist/types-ts4.0/presets/theme-to-design-tokens/utils/ast.d.ts +3 -0
  42. package/dist/types-ts4.0/presets/theme-to-design-tokens/utils/color.d.ts +4 -0
  43. package/dist/types-ts4.0/presets/theme-to-design-tokens/utils/fuzzy-search.d.ts +5 -0
  44. package/dist/types-ts4.0/presets/theme-to-design-tokens/utils/legacy-colors.d.ts +3 -0
  45. package/dist/types-ts4.0/presets/theme-to-design-tokens/utils/named-colors.d.ts +1 -0
  46. package/dist/types-ts4.0/presets/theme-to-design-tokens/utils/tokens.d.ts +2 -0
  47. package/dist/types-ts4.0/sinceRef.d.ts +5 -0
  48. package/dist/types-ts4.0/transforms.d.ts +10 -0
  49. package/dist/types-ts4.0/types.d.ts +59 -0
  50. package/dist/types-ts4.0/utils.d.ts +1 -0
  51. package/package.json +2 -2
package/dist/cjs/main.js CHANGED
@@ -5,10 +5,6 @@ Object.defineProperty(exports, "__esModule", {
5
5
  value: true
6
6
  });
7
7
  exports.default = main;
8
- var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
9
- var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
10
- var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
11
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
12
8
  var _chalk = _interopRequireDefault(require("chalk"));
13
9
  var _fs = _interopRequireDefault(require("fs"));
14
10
  var _projectorSpawn = _interopRequireDefault(require("projector-spawn"));
@@ -19,374 +15,208 @@ var _transforms = require("./transforms");
19
15
  var _types = require("./types");
20
16
  var _sinceRef = require("./sinceRef");
21
17
  var _filepath = require("./filepath");
22
- function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; }
23
- function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
24
- function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
25
- function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
26
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
27
- var jscodeshift = require.resolve('.bin/jscodeshift');
28
- var applyTransformMeta = function applyTransformMeta(transforms) {
29
- return transforms.map(function (transform) {
30
- var moduleMatch = transform.dir.match(/\/@atlaskit\/[^\/]+\//);
31
- if (moduleMatch) {
32
- var moduleName = moduleMatch[0].substring(1, moduleMatch[0].length - 1);
33
- var transformName = transform.name === 'index' ? transform.dir.slice(transform.dir.lastIndexOf('/') + 1) : transform.name;
34
- return _objectSpread(_objectSpread({}, transform), {}, {
35
- id: "".concat(moduleName, ": ").concat(transformName)
36
- });
18
+ const jscodeshift = require.resolve('.bin/jscodeshift');
19
+ const applyTransformMeta = transforms => transforms.map(transform => {
20
+ const moduleMatch = transform.dir.match(/\/@atlaskit\/[^\/]+\//);
21
+ if (moduleMatch) {
22
+ const moduleName = moduleMatch[0].substring(1, moduleMatch[0].length - 1);
23
+ const transformName = transform.name === 'index' ? transform.dir.slice(transform.dir.lastIndexOf('/') + 1) : transform.name;
24
+ return {
25
+ ...transform,
26
+ id: `${moduleName}: ${transformName}`
27
+ };
28
+ }
29
+ const presetMatch = transform.dir.match(/\/codemod-cli\/.+\/presets/);
30
+ if (presetMatch) {
31
+ const transformName = transform.name === 'index' ? transform.dir.slice(transform.dir.lastIndexOf('/') + 1) : transform.name;
32
+ return {
33
+ ...transform,
34
+ id: `@atlaskit/codemod-cli: ${transformName}`
35
+ };
36
+ }
37
+ return {
38
+ ...transform,
39
+ id: `${transform.dir}/${transform.name}`
40
+ };
41
+ });
42
+ const getTransformPrompt = async transforms => {
43
+ const transformMeta = applyTransformMeta(transforms);
44
+ return await new _enquirer.AutoComplete({
45
+ message: 'Select which transform would you like to run? 🤔',
46
+ limit: 18,
47
+ choices: transformMeta.map(({
48
+ id,
49
+ name,
50
+ dir
51
+ }) => id ? id : `${dir}/${name}`),
52
+ result: choice => transformMeta.find(({
53
+ id,
54
+ dir
55
+ }) => id === choice || dir === choice)
56
+ }).run();
57
+ };
58
+ const resolveTransform = async (flags, transforms) => {
59
+ if (flags.preset) {
60
+ const transform = transforms.find(({
61
+ name
62
+ }) => name === flags.preset);
63
+ if (!transform) {
64
+ console.warn(`No preset found for: ${_chalk.default.bgRed(flags.preset)}`);
65
+ } else {
66
+ return transform; // Return only if transform found.
37
67
  }
38
- var presetMatch = transform.dir.match(/\/codemod-cli\/.+\/presets/);
39
- if (presetMatch) {
40
- var _transformName = transform.name === 'index' ? transform.dir.slice(transform.dir.lastIndexOf('/') + 1) : transform.name;
41
- return _objectSpread(_objectSpread({}, transform), {}, {
42
- id: "@atlaskit/codemod-cli: ".concat(_transformName)
43
- });
68
+ }
69
+
70
+ if (flags.transform && (0, _transforms.hasTransform)(flags.transform)) {
71
+ return (0, _transforms.parseTransformPath)(flags.transform);
72
+ }
73
+ if (flags.transform && !(0, _transforms.hasTransform)(flags.transform)) {
74
+ console.warn(`No available transform found for: ${_chalk.default.bgRed(flags.transform)}`);
75
+ }
76
+ return await getTransformPrompt(transforms);
77
+ };
78
+ const runTransform = async (filePaths, transform, flags) => {
79
+ const {
80
+ logger
81
+ } = flags;
82
+ logger.log(_chalk.default.green(`Running transform '${_chalk.default.bold(transform.name)}' over ${_chalk.default.bold(filePaths.join(', '))}...`));
83
+ let codemodDirs = filePaths;
84
+ if (flags.filterPaths) {
85
+ logger.log(_chalk.default.green(`Running filtering logic for module ${transform.module}...`));
86
+ codemodDirs = await (0, _filepath.findDependentPackagePaths)(filePaths, transform.module);
87
+ if (codemodDirs.length === 0) {
88
+ // Fallback to non-filter logic if filtering returns no directories
89
+ logger.log(_chalk.default.yellow(`Could not filter source paths for ${transform.module}, falling back to running over all specified paths. (See --no-filter-paths flag)`));
90
+ codemodDirs = filePaths;
91
+ } else {
92
+ logger.log(_chalk.default.green(`Running transform '${_chalk.default.bold(transform.name)}' over filtered dirs ${_chalk.default.bold(codemodDirs.join(', '))}...`));
44
93
  }
45
- return _objectSpread(_objectSpread({}, transform), {}, {
46
- id: "".concat(transform.dir, "/").concat(transform.name)
47
- });
94
+ }
95
+ logger.log(_chalk.default.green(`Transforming files matching these extensions '${_chalk.default.bold(flags.extensions)}'...`));
96
+ const transformPath = (0, _transforms.getTransformPath)(transform);
97
+
98
+ // Limit CPUs to 8 to prevent issues when running on CI with a large amount of cpus
99
+ const args = [`--transform=${transformPath}`, `--ignore-pattern=${flags.ignorePattern}`, `--parser=${flags.parser}`, `--extensions=${flags.extensions}`, '--cpus=8', ...codemodDirs];
100
+ if (flags.failOnError) {
101
+ args.unshift('--fail-on-error');
102
+ }
103
+
104
+ // To avoid https://github.com/facebook/jscodeshift/issues/424 where the jscodeshift.js file is `CRLF` ending.
105
+ // The workaround to use only the `node_modules` indicated in this ticket will not work as we run this code as CLI in products repository
106
+ // that may not have jscodeshift installed.
107
+ const jscodeshiftContent = _fs.default.readFileSync(jscodeshift, 'utf8');
108
+ const jscodeshiftContentNew = (0, _utils.fixLineEnding)(jscodeshiftContent, 'LF');
109
+ _fs.default.writeFileSync(jscodeshift, jscodeshiftContentNew);
110
+ await (0, _projectorSpawn.default)(jscodeshift, args, {
111
+ stdio: 'inherit'
48
112
  });
49
113
  };
50
- var getTransformPrompt = /*#__PURE__*/function () {
51
- var _ref = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee(transforms) {
52
- var transformMeta;
53
- return _regenerator.default.wrap(function _callee$(_context) {
54
- while (1) {
55
- switch (_context.prev = _context.next) {
56
- case 0:
57
- transformMeta = applyTransformMeta(transforms);
58
- _context.next = 3;
59
- return new _enquirer.AutoComplete({
60
- message: 'Select which transform would you like to run? 🤔',
61
- limit: 18,
62
- choices: transformMeta.map(function (_ref2) {
63
- var id = _ref2.id,
64
- name = _ref2.name,
65
- dir = _ref2.dir;
66
- return id ? id : "".concat(dir, "/").concat(name);
67
- }),
68
- result: function result(choice) {
69
- return transformMeta.find(function (_ref3) {
70
- var id = _ref3.id,
71
- dir = _ref3.dir;
72
- return id === choice || dir === choice;
73
- });
74
- }
75
- }).run();
76
- case 3:
77
- return _context.abrupt("return", _context.sent);
78
- case 4:
79
- case "end":
80
- return _context.stop();
81
- }
82
- }
83
- }, _callee);
84
- }));
85
- return function getTransformPrompt(_x) {
86
- return _ref.apply(this, arguments);
87
- };
88
- }();
89
- var resolveTransform = /*#__PURE__*/function () {
90
- var _ref4 = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee2(flags, transforms) {
91
- var transform;
92
- return _regenerator.default.wrap(function _callee2$(_context2) {
93
- while (1) {
94
- switch (_context2.prev = _context2.next) {
95
- case 0:
96
- if (!flags.preset) {
97
- _context2.next = 7;
98
- break;
99
- }
100
- transform = transforms.find(function (_ref5) {
101
- var name = _ref5.name;
102
- return name === flags.preset;
103
- });
104
- if (transform) {
105
- _context2.next = 6;
106
- break;
107
- }
108
- console.warn("No preset found for: ".concat(_chalk.default.bgRed(flags.preset)));
109
- _context2.next = 7;
110
- break;
111
- case 6:
112
- return _context2.abrupt("return", transform);
113
- case 7:
114
- if (!(flags.transform && (0, _transforms.hasTransform)(flags.transform))) {
115
- _context2.next = 9;
116
- break;
117
- }
118
- return _context2.abrupt("return", (0, _transforms.parseTransformPath)(flags.transform));
119
- case 9:
120
- if (flags.transform && !(0, _transforms.hasTransform)(flags.transform)) {
121
- console.warn("No available transform found for: ".concat(_chalk.default.bgRed(flags.transform)));
122
- }
123
- _context2.next = 12;
124
- return getTransformPrompt(transforms);
125
- case 12:
126
- return _context2.abrupt("return", _context2.sent);
127
- case 13:
128
- case "end":
129
- return _context2.stop();
130
- }
131
- }
132
- }, _callee2);
133
- }));
134
- return function resolveTransform(_x2, _x3) {
135
- return _ref4.apply(this, arguments);
136
- };
137
- }();
138
- var runTransform = /*#__PURE__*/function () {
139
- var _ref6 = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee3(filePaths, transform, flags) {
140
- var logger, codemodDirs, transformPath, args, jscodeshiftContent, jscodeshiftContentNew;
141
- return _regenerator.default.wrap(function _callee3$(_context3) {
142
- while (1) {
143
- switch (_context3.prev = _context3.next) {
144
- case 0:
145
- logger = flags.logger;
146
- logger.log(_chalk.default.green("Running transform '".concat(_chalk.default.bold(transform.name), "' over ").concat(_chalk.default.bold(filePaths.join(', ')), "...")));
147
- codemodDirs = filePaths;
148
- if (!flags.filterPaths) {
149
- _context3.next = 9;
150
- break;
151
- }
152
- logger.log(_chalk.default.green("Running filtering logic for module ".concat(transform.module, "...")));
153
- _context3.next = 7;
154
- return (0, _filepath.findDependentPackagePaths)(filePaths, transform.module);
155
- case 7:
156
- codemodDirs = _context3.sent;
157
- if (codemodDirs.length === 0) {
158
- // Fallback to non-filter logic if filtering returns no directories
159
- logger.log(_chalk.default.yellow("Could not filter source paths for ".concat(transform.module, ", falling back to running over all specified paths. (See --no-filter-paths flag)")));
160
- codemodDirs = filePaths;
161
- } else {
162
- logger.log(_chalk.default.green("Running transform '".concat(_chalk.default.bold(transform.name), "' over filtered dirs ").concat(_chalk.default.bold(codemodDirs.join(', ')), "...")));
163
- }
164
- case 9:
165
- logger.log(_chalk.default.green("Transforming files matching these extensions '".concat(_chalk.default.bold(flags.extensions), "'...")));
166
- transformPath = (0, _transforms.getTransformPath)(transform); // Limit CPUs to 8 to prevent issues when running on CI with a large amount of cpus
167
- args = ["--transform=".concat(transformPath), "--ignore-pattern=".concat(flags.ignorePattern), "--parser=".concat(flags.parser), "--extensions=".concat(flags.extensions), '--cpus=8'].concat((0, _toConsumableArray2.default)(codemodDirs));
168
- if (flags.failOnError) {
169
- args.unshift('--fail-on-error');
170
- }
171
-
172
- // To avoid https://github.com/facebook/jscodeshift/issues/424 where the jscodeshift.js file is `CRLF` ending.
173
- // The workaround to use only the `node_modules` indicated in this ticket will not work as we run this code as CLI in products repository
174
- // that may not have jscodeshift installed.
175
- jscodeshiftContent = _fs.default.readFileSync(jscodeshift, 'utf8');
176
- jscodeshiftContentNew = (0, _utils.fixLineEnding)(jscodeshiftContent, 'LF');
177
- _fs.default.writeFileSync(jscodeshift, jscodeshiftContentNew);
178
- _context3.next = 18;
179
- return (0, _projectorSpawn.default)(jscodeshift, args, {
180
- stdio: 'inherit'
181
- });
182
- case 18:
183
- case "end":
184
- return _context3.stop();
185
- }
186
- }
187
- }, _callee3);
188
- }));
189
- return function runTransform(_x4, _x5, _x6) {
190
- return _ref6.apply(this, arguments);
191
- };
192
- }();
193
- var parsePkg = function parsePkg(pkg) {
114
+ const parsePkg = pkg => {
194
115
  if (!pkg.startsWith('@')) {
195
116
  throw new _types.ValidationError('Package names must be fully qualified and begin with "@"');
196
117
  }
197
- var name = pkg;
198
- var version = null;
199
- var parts = pkg.split('@');
118
+ let name = pkg;
119
+ let version = null;
120
+ const parts = pkg.split('@');
200
121
  if (parts.length > 2) {
201
- name = "@".concat(parts[1]);
122
+ name = `@${parts[1]}`;
202
123
  version = parts[parts.length - 1];
203
124
  }
204
125
  return {
205
- name: name,
206
- version: version
126
+ name,
127
+ version
207
128
  };
208
129
  };
209
- var parsePackagesFlag = function parsePackagesFlag(packages) {
130
+ const parsePackagesFlag = packages => {
210
131
  return packages.split(',').map(parsePkg);
211
132
  };
212
- var validatePackages = function validatePackages(packages, errorCallback) {
133
+ const validatePackages = (packages, errorCallback) => {
213
134
  if (!packages) {
214
135
  return;
215
136
  }
216
- var errors = [];
217
- var transformedPackages = packages.map(function (pkg) {
218
- var version = null;
137
+ const errors = [];
138
+ const transformedPackages = packages.map(pkg => {
139
+ let version = null;
219
140
  if (pkg.version != null) {
220
141
  if (_semver.default.validRange(pkg.version)) {
221
142
  version = _semver.default.valid(_semver.default.minVersion(pkg.version));
222
143
  } else {
223
- errors.push("Invalid version \"".concat(pkg.version, "\" for package \"").concat(pkg.name, "\""));
144
+ errors.push(`Invalid version "${pkg.version}" for package "${pkg.name}"`);
224
145
  }
225
146
  }
226
- return _objectSpread(_objectSpread({}, pkg), {}, {
227
- version: version
228
- });
147
+ return {
148
+ ...pkg,
149
+ version
150
+ };
229
151
  });
230
152
  if (errors.length > 0) {
231
153
  errorCallback && errorCallback(errors);
232
154
  }
233
155
  return transformedPackages;
234
156
  };
235
- var parseArgs = /*#__PURE__*/function () {
236
- var _ref7 = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee4(input, flags) {
237
- var packages, unvalidatedPackages, _unvalidatedPackages;
238
- return _regenerator.default.wrap(function _callee4$(_context4) {
239
- while (1) {
240
- switch (_context4.prev = _context4.next) {
241
- case 0:
242
- if (input[0]) {
243
- _context4.next = 2;
244
- break;
245
- }
246
- throw new _types.ValidationError('Please supply a path to the source files you wish to modify');
247
- case 2:
248
- if (!flags.packages) {
249
- _context4.next = 7;
250
- break;
251
- }
252
- unvalidatedPackages = parsePackagesFlag(flags.packages);
253
- packages = validatePackages(unvalidatedPackages, function (errors) {
254
- throw new _types.ValidationError(errors.join('\n'));
255
- });
256
- _context4.next = 12;
257
- break;
258
- case 7:
259
- if (!flags.sinceRef) {
260
- _context4.next = 12;
261
- break;
262
- }
263
- _context4.next = 10;
264
- return (0, _sinceRef.getPackagesSinceRef)(flags.sinceRef);
265
- case 10:
266
- _unvalidatedPackages = _context4.sent;
267
- packages = validatePackages(_unvalidatedPackages, function (errors) {
268
- throw new Error("Detected invalid previous versions of packages upgraded since \"".concat(flags.sinceRef, "\". Previous versions must be valid semver.\n").concat(errors.join('\n')));
269
- });
270
- case 12:
271
- return _context4.abrupt("return", {
272
- packages: packages
273
- });
274
- case 13:
275
- case "end":
276
- return _context4.stop();
277
- }
278
- }
279
- }, _callee4);
280
- }));
281
- return function parseArgs(_x7, _x8) {
282
- return _ref7.apply(this, arguments);
157
+ const parseArgs = async (input, flags) => {
158
+ let packages;
159
+ if (!input[0]) {
160
+ throw new _types.ValidationError('Please supply a path to the source files you wish to modify');
161
+ }
162
+ if (flags.packages) {
163
+ const unvalidatedPackages = parsePackagesFlag(flags.packages);
164
+ packages = validatePackages(unvalidatedPackages, errors => {
165
+ throw new _types.ValidationError(errors.join('\n'));
166
+ });
167
+ } else if (flags.sinceRef) {
168
+ const unvalidatedPackages = await (0, _sinceRef.getPackagesSinceRef)(flags.sinceRef);
169
+ packages = validatePackages(unvalidatedPackages, errors => {
170
+ throw new Error(`Detected invalid previous versions of packages upgraded since "${flags.sinceRef}". Previous versions must be valid semver.\n${errors.join('\n')}`);
171
+ });
172
+ }
173
+ return {
174
+ packages
283
175
  };
284
- }();
285
- var defaultFlags = {
176
+ };
177
+ const defaultFlags = {
286
178
  parser: 'babel',
287
179
  extensions: 'js',
288
180
  ignorePattern: 'node_modules',
289
181
  logger: console
290
182
  };
291
- function main(_x9, _x10) {
292
- return _main.apply(this, arguments);
293
- }
294
- function _main() {
295
- _main = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee5(input, userFlags) {
296
- var flags, logger, _yield$parseArgs, packages, _process$env$_PACKAGE, _PACKAGE_VERSION_, shouldHavePackages, availableTransforms, transforms, transformsWithModule, _iterator, _step, transform;
297
- return _regenerator.default.wrap(function _callee5$(_context5) {
298
- while (1) {
299
- switch (_context5.prev = _context5.next) {
300
- case 0:
301
- flags = _objectSpread(_objectSpread({}, defaultFlags), userFlags);
302
- logger = flags.logger;
303
- _context5.next = 4;
304
- return parseArgs(input, flags);
305
- case 4:
306
- _yield$parseArgs = _context5.sent;
307
- packages = _yield$parseArgs.packages;
308
- _process$env$_PACKAGE = "0.11.5", _PACKAGE_VERSION_ = _process$env$_PACKAGE === void 0 ? '0.0.0-dev' : _process$env$_PACKAGE;
309
- logger.log(_chalk.default.bgBlue(_chalk.default.black("\uD83D\uDCDA Atlassian-Frontend codemod library @ ".concat(_PACKAGE_VERSION_, " \uD83D\uDCDA"))));
310
- if (packages && packages.length > 0) {
311
- logger.log(_chalk.default.gray("Searching for codemods for newer versions of the following packages: ".concat(packages.map(function (pkg) {
312
- return "".concat(pkg.name).concat(pkg.version ? '@' + pkg.version : '');
313
- }))));
314
- }
315
- shouldHavePackages = flags.sinceRef || flags.packages && flags.packages.length > 0;
316
- if (!(shouldHavePackages && (packages === null || packages === void 0 ? void 0 : packages.length) === 0)) {
317
- _context5.next = 13;
318
- break;
319
- }
320
- logger.log(_chalk.default.gray("Did not find updated packages, exiting"));
321
- return _context5.abrupt("return", {
322
- transforms: []
323
- });
324
- case 13:
325
- availableTransforms = (0, _transforms.getTransforms)(packages);
326
- if (!(availableTransforms.length === 0)) {
327
- _context5.next = 16;
328
- break;
329
- }
330
- throw new _types.NoTransformsExistError('No codemods available. Please make sure you have the latest version of the packages you are trying to upgrade before running the codemod');
331
- case 16:
332
- if (!packages) {
333
- _context5.next = 20;
334
- break;
335
- }
336
- _context5.t0 = availableTransforms;
337
- _context5.next = 24;
338
- break;
339
- case 20:
340
- _context5.next = 22;
341
- return resolveTransform(flags, availableTransforms);
342
- case 22:
343
- _context5.t1 = _context5.sent;
344
- _context5.t0 = [_context5.t1];
345
- case 24:
346
- transforms = _context5.t0;
347
- transformsWithModule = transforms.map(function (transform) {
348
- return _objectSpread(_objectSpread({}, transform), {}, {
349
- module: (0, _transforms.getTransformModule)(transform)
350
- });
351
- });
352
- logger.log(_chalk.default.cyan("Running the following transforms \n".concat(_chalk.default.bold(transformsWithModule.map(function (transform) {
353
- return "".concat(transform.module, ": ").concat(transform.name);
354
- }).join('\n')))));
355
- _iterator = _createForOfIteratorHelper(transformsWithModule);
356
- _context5.prev = 28;
357
- _iterator.s();
358
- case 30:
359
- if ((_step = _iterator.n()).done) {
360
- _context5.next = 36;
361
- break;
362
- }
363
- transform = _step.value;
364
- _context5.next = 34;
365
- return runTransform(input, transform, flags);
366
- case 34:
367
- _context5.next = 30;
368
- break;
369
- case 36:
370
- _context5.next = 41;
371
- break;
372
- case 38:
373
- _context5.prev = 38;
374
- _context5.t2 = _context5["catch"](28);
375
- _iterator.e(_context5.t2);
376
- case 41:
377
- _context5.prev = 41;
378
- _iterator.f();
379
- return _context5.finish(41);
380
- case 44:
381
- return _context5.abrupt("return", {
382
- transforms: transformsWithModule
383
- });
384
- case 45:
385
- case "end":
386
- return _context5.stop();
387
- }
388
- }
389
- }, _callee5, null, [[28, 38, 41, 44]]);
183
+ async function main(input, userFlags) {
184
+ const flags = {
185
+ ...defaultFlags,
186
+ ...userFlags
187
+ };
188
+ const logger = flags.logger;
189
+ const {
190
+ packages
191
+ } = await parseArgs(input, flags);
192
+ const {
193
+ _PACKAGE_VERSION_ = '0.0.0-dev'
194
+ } = process.env;
195
+ logger.log(_chalk.default.bgBlue(_chalk.default.black(`📚 Atlassian-Frontend codemod library @ ${_PACKAGE_VERSION_} 📚`)));
196
+ if (packages && packages.length > 0) {
197
+ logger.log(_chalk.default.gray(`Searching for codemods for newer versions of the following packages: ${packages.map(pkg => `${pkg.name}${pkg.version ? '@' + pkg.version : ''}`)}`));
198
+ }
199
+ const shouldHavePackages = flags.sinceRef || flags.packages && flags.packages.length > 0;
200
+ if (shouldHavePackages && (packages === null || packages === void 0 ? void 0 : packages.length) === 0) {
201
+ logger.log(_chalk.default.gray(`Did not find updated packages, exiting`));
202
+ return {
203
+ transforms: []
204
+ };
205
+ }
206
+ const availableTransforms = (0, _transforms.getTransforms)(packages);
207
+ if (availableTransforms.length === 0) {
208
+ throw new _types.NoTransformsExistError('No codemods available. Please make sure you have the latest version of the packages you are trying to upgrade before running the codemod');
209
+ }
210
+ const transforms = packages ? availableTransforms : [await resolveTransform(flags, availableTransforms)];
211
+ const transformsWithModule = transforms.map(transform => ({
212
+ ...transform,
213
+ module: (0, _transforms.getTransformModule)(transform)
390
214
  }));
391
- return _main.apply(this, arguments);
215
+ logger.log(_chalk.default.cyan(`Running the following transforms \n${_chalk.default.bold(transformsWithModule.map(transform => `${transform.module}: ${transform.name}`).join('\n'))}`));
216
+ for (const transform of transformsWithModule) {
217
+ await runTransform(input, transform, flags);
218
+ }
219
+ return {
220
+ transforms: transformsWithModule
221
+ };
392
222
  }