@atlaskit/codemod-cli 0.25.2 → 0.26.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.
package/CHANGELOG.md CHANGED
@@ -1,5 +1,21 @@
1
1
  # @atlaskit/codemod-cli
2
2
 
3
+ ## 0.26.1
4
+
5
+ ### Patch Changes
6
+
7
+ - [#136464](https://stash.atlassian.com/projects/CONFCLOUD/repos/confluence-frontend/pull-requests/136464)
8
+ [`4f11a637eccad`](https://stash.atlassian.com/projects/CONFCLOUD/repos/confluence-frontend/commits/4f11a637eccad) -
9
+ Fixed the import path checking in remove-gemini-dark-options transformer.
10
+
11
+ ## 0.26.0
12
+
13
+ ### Minor Changes
14
+
15
+ - [#135958](https://stash.atlassian.com/projects/CONFCLOUD/repos/confluence-frontend/pull-requests/135958)
16
+ [`61059e42a3aa2`](https://stash.atlassian.com/projects/CONFCLOUD/repos/confluence-frontend/commits/61059e42a3aa2) -
17
+ Added a new preset and codemod for removing dark options from Gemini VR tests.
18
+
3
19
  ## 0.25.2
4
20
 
5
21
  ### Patch Changes
package/dist/cjs/main.js CHANGED
@@ -305,7 +305,7 @@ function _main() {
305
305
  case 4:
306
306
  _yield$parseArgs = _context5.sent;
307
307
  packages = _yield$parseArgs.packages;
308
- _process$env$_PACKAGE = "0.25.2", _PACKAGE_VERSION_ = _process$env$_PACKAGE === void 0 ? '0.0.0-dev' : _process$env$_PACKAGE;
308
+ _process$env$_PACKAGE = "0.26.1", _PACKAGE_VERSION_ = _process$env$_PACKAGE === void 0 ? '0.0.0-dev' : _process$env$_PACKAGE;
309
309
  logger.log(_chalk.default.bgBlue(_chalk.default.black("\uD83D\uDCDA Atlassian-Frontend codemod library @ ".concat(_PACKAGE_VERSION_, " \uD83D\uDCDA"))));
310
310
  if (packages && packages.length > 0) {
311
311
  logger.log(_chalk.default.gray("Searching for codemods for newer versions of the following packages: ".concat(packages.map(function (pkg) {
@@ -10,12 +10,13 @@ require("./styled-to-emotion/styled-to-emotion");
10
10
  require("./theme-remove-deprecated-mixins/theme-remove-deprecated-mixins");
11
11
  require("./migrate-to-new-buttons/migrate-to-new-buttons");
12
12
  require("./upgrade-pragmatic-drag-and-drop-to-stable/upgrade-pragmatic-drag-and-drop-to-stable");
13
+ require("./remove-dark-theme-vr-options/remove-dark-theme-vr-options");
13
14
  /**
14
15
  * Manually import presets to make sure typescript includes them
15
16
  * in the final bundle.
16
17
  */
17
18
 
18
- var presets = ['styled-to-emotion', 'theme-remove-deprecated-mixins', 'migrate-to-new-buttons', 'upgrade-pragmatic-drag-and-drop-to-stable'].map(function (preset) {
19
+ var presets = ['styled-to-emotion', 'theme-remove-deprecated-mixins', 'migrate-to-new-buttons', 'upgrade-pragmatic-drag-and-drop-to-stable', 'remove-dark-theme-vr-options'].map(function (preset) {
19
20
  return _path.default.join(__dirname, preset, "".concat(preset, ".@(ts|js|tsx)"));
20
21
  });
21
22
  var _default = exports.default = presets;
@@ -0,0 +1,42 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = void 0;
7
+ var _utils = require("@hypermod/utils");
8
+ var PRINT_SETTINGS = {
9
+ quote: 'single'
10
+ };
11
+ function transformer(file, api) {
12
+ var j = api.jscodeshift;
13
+ var source = j(file.source);
14
+
15
+ // check if import from @af/visual-regression or @atlassian/jira-vr-testing
16
+ var platformImports = (0, _utils.getImportDeclaration)(j, source, '@af/visual-regression');
17
+ var jiraImports = (0, _utils.getImportDeclaration)(j, source, '@atlassian/jira-vr-testing');
18
+ if (!platformImports.length && !jiraImports.length) {
19
+ return file.source;
20
+ }
21
+
22
+ // find ObjectProperty that has a "environment" property
23
+ // and then a "colorScheme" property inside the "environment" property
24
+ // and value is "dark" inside the "colorScheme" property
25
+ source.find(j.ObjectExpression).filter(function (path) {
26
+ var environmentProperty = path.node.properties.find(function (prop) {
27
+ return prop.type === 'ObjectProperty' && prop.key.type === 'Identifier' && prop.key.name === 'environment';
28
+ });
29
+ if (!environmentProperty) {
30
+ return false;
31
+ }
32
+ var colorSchemeProperty = environmentProperty.type === 'ObjectProperty' && environmentProperty.value.type === 'ObjectExpression' && environmentProperty.value.properties.find(function (path) {
33
+ return path.type === 'ObjectProperty' && path.key.type === 'Identifier' && path.key.name === 'colorScheme';
34
+ });
35
+ if (!colorSchemeProperty) {
36
+ return false;
37
+ }
38
+ return colorSchemeProperty.type === 'ObjectProperty' && colorSchemeProperty.value.type === 'StringLiteral' && colorSchemeProperty.value.value === 'dark';
39
+ }).remove();
40
+ return source.toSource(PRINT_SETTINGS);
41
+ }
42
+ var _default = exports.default = transformer;
@@ -0,0 +1,44 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.default = transformer;
8
+ var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
9
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
10
+ var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
11
+ var _removeGeminiDarkOptionsTransformer = _interopRequireDefault(require("./codemods/remove-gemini-dark-options-transformer"));
12
+ function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
13
+ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2.default)(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
14
+ function transformer(_x, _x2) {
15
+ return _transformer.apply(this, arguments);
16
+ }
17
+ function _transformer() {
18
+ _transformer = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee(file, api) {
19
+ var transformers, src;
20
+ return _regenerator.default.wrap(function _callee$(_context) {
21
+ while (1) switch (_context.prev = _context.next) {
22
+ case 0:
23
+ transformers = [_removeGeminiDarkOptionsTransformer.default];
24
+ src = file.source;
25
+ transformers.forEach(function (transformer) {
26
+ if (typeof src === 'undefined') {
27
+ return;
28
+ }
29
+ var nextSrc = transformer(_objectSpread(_objectSpread({}, file), {}, {
30
+ source: src
31
+ }), api);
32
+ if (nextSrc) {
33
+ src = nextSrc;
34
+ }
35
+ });
36
+ return _context.abrupt("return", src);
37
+ case 4:
38
+ case "end":
39
+ return _context.stop();
40
+ }
41
+ }, _callee);
42
+ }));
43
+ return _transformer.apply(this, arguments);
44
+ }
@@ -8,5 +8,6 @@ import './styled-to-emotion/styled-to-emotion';
8
8
  import './theme-remove-deprecated-mixins/theme-remove-deprecated-mixins';
9
9
  import './migrate-to-new-buttons/migrate-to-new-buttons';
10
10
  import './upgrade-pragmatic-drag-and-drop-to-stable/upgrade-pragmatic-drag-and-drop-to-stable';
11
- const presets = ['styled-to-emotion', 'theme-remove-deprecated-mixins', 'migrate-to-new-buttons', 'upgrade-pragmatic-drag-and-drop-to-stable'].map(preset => path.join(__dirname, preset, `${preset}.@(ts|js|tsx)`));
11
+ import './remove-dark-theme-vr-options/remove-dark-theme-vr-options';
12
+ const presets = ['styled-to-emotion', 'theme-remove-deprecated-mixins', 'migrate-to-new-buttons', 'upgrade-pragmatic-drag-and-drop-to-stable', 'remove-dark-theme-vr-options'].map(preset => path.join(__dirname, preset, `${preset}.@(ts|js|tsx)`));
12
13
  export default presets;
@@ -0,0 +1,32 @@
1
+ import { getImportDeclaration } from '@hypermod/utils';
2
+ const PRINT_SETTINGS = {
3
+ quote: 'single'
4
+ };
5
+ function transformer(file, api) {
6
+ const j = api.jscodeshift;
7
+ const source = j(file.source);
8
+
9
+ // check if import from @af/visual-regression or @atlassian/jira-vr-testing
10
+ const platformImports = getImportDeclaration(j, source, '@af/visual-regression');
11
+ const jiraImports = getImportDeclaration(j, source, '@atlassian/jira-vr-testing');
12
+ if (!platformImports.length && !jiraImports.length) {
13
+ return file.source;
14
+ }
15
+
16
+ // find ObjectProperty that has a "environment" property
17
+ // and then a "colorScheme" property inside the "environment" property
18
+ // and value is "dark" inside the "colorScheme" property
19
+ source.find(j.ObjectExpression).filter(path => {
20
+ const environmentProperty = path.node.properties.find(prop => prop.type === 'ObjectProperty' && prop.key.type === 'Identifier' && prop.key.name === 'environment');
21
+ if (!environmentProperty) {
22
+ return false;
23
+ }
24
+ const colorSchemeProperty = environmentProperty.type === 'ObjectProperty' && environmentProperty.value.type === 'ObjectExpression' && environmentProperty.value.properties.find(path => path.type === 'ObjectProperty' && path.key.type === 'Identifier' && path.key.name === 'colorScheme');
25
+ if (!colorSchemeProperty) {
26
+ return false;
27
+ }
28
+ return colorSchemeProperty.type === 'ObjectProperty' && colorSchemeProperty.value.type === 'StringLiteral' && colorSchemeProperty.value.value === 'dark';
29
+ }).remove();
30
+ return source.toSource(PRINT_SETTINGS);
31
+ }
32
+ export default transformer;
@@ -0,0 +1,18 @@
1
+ import removeGeminiDarkOptionTransformer from './codemods/remove-gemini-dark-options-transformer';
2
+ export default async function transformer(file, api) {
3
+ const transformers = [removeGeminiDarkOptionTransformer];
4
+ let src = file.source;
5
+ transformers.forEach(transformer => {
6
+ if (typeof src === 'undefined') {
7
+ return;
8
+ }
9
+ const nextSrc = transformer({
10
+ ...file,
11
+ source: src
12
+ }, api);
13
+ if (nextSrc) {
14
+ src = nextSrc;
15
+ }
16
+ });
17
+ return src;
18
+ }
package/dist/esm/main.js CHANGED
@@ -298,7 +298,7 @@ function _main() {
298
298
  case 4:
299
299
  _yield$parseArgs = _context5.sent;
300
300
  packages = _yield$parseArgs.packages;
301
- _process$env$_PACKAGE = "0.25.2", _PACKAGE_VERSION_ = _process$env$_PACKAGE === void 0 ? '0.0.0-dev' : _process$env$_PACKAGE;
301
+ _process$env$_PACKAGE = "0.26.1", _PACKAGE_VERSION_ = _process$env$_PACKAGE === void 0 ? '0.0.0-dev' : _process$env$_PACKAGE;
302
302
  logger.log(chalk.bgBlue(chalk.black("\uD83D\uDCDA Atlassian-Frontend codemod library @ ".concat(_PACKAGE_VERSION_, " \uD83D\uDCDA"))));
303
303
  if (packages && packages.length > 0) {
304
304
  logger.log(chalk.gray("Searching for codemods for newer versions of the following packages: ".concat(packages.map(function (pkg) {
@@ -8,7 +8,8 @@ import './styled-to-emotion/styled-to-emotion';
8
8
  import './theme-remove-deprecated-mixins/theme-remove-deprecated-mixins';
9
9
  import './migrate-to-new-buttons/migrate-to-new-buttons';
10
10
  import './upgrade-pragmatic-drag-and-drop-to-stable/upgrade-pragmatic-drag-and-drop-to-stable';
11
- var presets = ['styled-to-emotion', 'theme-remove-deprecated-mixins', 'migrate-to-new-buttons', 'upgrade-pragmatic-drag-and-drop-to-stable'].map(function (preset) {
11
+ import './remove-dark-theme-vr-options/remove-dark-theme-vr-options';
12
+ var presets = ['styled-to-emotion', 'theme-remove-deprecated-mixins', 'migrate-to-new-buttons', 'upgrade-pragmatic-drag-and-drop-to-stable', 'remove-dark-theme-vr-options'].map(function (preset) {
12
13
  return path.join(__dirname, preset, "".concat(preset, ".@(ts|js|tsx)"));
13
14
  });
14
15
  export default presets;
@@ -0,0 +1,36 @@
1
+ import { getImportDeclaration } from '@hypermod/utils';
2
+ var PRINT_SETTINGS = {
3
+ quote: 'single'
4
+ };
5
+ function transformer(file, api) {
6
+ var j = api.jscodeshift;
7
+ var source = j(file.source);
8
+
9
+ // check if import from @af/visual-regression or @atlassian/jira-vr-testing
10
+ var platformImports = getImportDeclaration(j, source, '@af/visual-regression');
11
+ var jiraImports = getImportDeclaration(j, source, '@atlassian/jira-vr-testing');
12
+ if (!platformImports.length && !jiraImports.length) {
13
+ return file.source;
14
+ }
15
+
16
+ // find ObjectProperty that has a "environment" property
17
+ // and then a "colorScheme" property inside the "environment" property
18
+ // and value is "dark" inside the "colorScheme" property
19
+ source.find(j.ObjectExpression).filter(function (path) {
20
+ var environmentProperty = path.node.properties.find(function (prop) {
21
+ return prop.type === 'ObjectProperty' && prop.key.type === 'Identifier' && prop.key.name === 'environment';
22
+ });
23
+ if (!environmentProperty) {
24
+ return false;
25
+ }
26
+ var colorSchemeProperty = environmentProperty.type === 'ObjectProperty' && environmentProperty.value.type === 'ObjectExpression' && environmentProperty.value.properties.find(function (path) {
27
+ return path.type === 'ObjectProperty' && path.key.type === 'Identifier' && path.key.name === 'colorScheme';
28
+ });
29
+ if (!colorSchemeProperty) {
30
+ return false;
31
+ }
32
+ return colorSchemeProperty.type === 'ObjectProperty' && colorSchemeProperty.value.type === 'StringLiteral' && colorSchemeProperty.value.value === 'dark';
33
+ }).remove();
34
+ return source.toSource(PRINT_SETTINGS);
35
+ }
36
+ export default transformer;
@@ -0,0 +1,37 @@
1
+ import _defineProperty from "@babel/runtime/helpers/defineProperty";
2
+ import _asyncToGenerator from "@babel/runtime/helpers/asyncToGenerator";
3
+ import _regeneratorRuntime from "@babel/runtime/regenerator";
4
+ function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
5
+ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
6
+ import removeGeminiDarkOptionTransformer from './codemods/remove-gemini-dark-options-transformer';
7
+ export default function transformer(_x, _x2) {
8
+ return _transformer.apply(this, arguments);
9
+ }
10
+ function _transformer() {
11
+ _transformer = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee(file, api) {
12
+ var transformers, src;
13
+ return _regeneratorRuntime.wrap(function _callee$(_context) {
14
+ while (1) switch (_context.prev = _context.next) {
15
+ case 0:
16
+ transformers = [removeGeminiDarkOptionTransformer];
17
+ src = file.source;
18
+ transformers.forEach(function (transformer) {
19
+ if (typeof src === 'undefined') {
20
+ return;
21
+ }
22
+ var nextSrc = transformer(_objectSpread(_objectSpread({}, file), {}, {
23
+ source: src
24
+ }), api);
25
+ if (nextSrc) {
26
+ src = nextSrc;
27
+ }
28
+ });
29
+ return _context.abrupt("return", src);
30
+ case 4:
31
+ case "end":
32
+ return _context.stop();
33
+ }
34
+ }, _callee);
35
+ }));
36
+ return _transformer.apply(this, arguments);
37
+ }
@@ -1,3 +1,4 @@
1
+ /// <reference types="node" />
1
2
  import { type Flags, type Default } from './types';
2
3
  declare const defaultFlags: {
3
4
  parser: "babel";
@@ -6,5 +6,6 @@ import './styled-to-emotion/styled-to-emotion';
6
6
  import './theme-remove-deprecated-mixins/theme-remove-deprecated-mixins';
7
7
  import './migrate-to-new-buttons/migrate-to-new-buttons';
8
8
  import './upgrade-pragmatic-drag-and-drop-to-stable/upgrade-pragmatic-drag-and-drop-to-stable';
9
+ import './remove-dark-theme-vr-options/remove-dark-theme-vr-options';
9
10
  declare const presets: string[];
10
11
  export default presets;
@@ -0,0 +1,3 @@
1
+ import { type API, type FileInfo } from 'jscodeshift';
2
+ declare function transformer(file: FileInfo, api: API): string;
3
+ export default transformer;
@@ -0,0 +1,2 @@
1
+ import type { API, FileInfo } from 'jscodeshift';
2
+ export default function transformer(file: FileInfo, api: API): Promise<string>;
@@ -1,3 +1,4 @@
1
+ /// <reference types="node" />
1
2
  import { type Flags, type Default } from './types';
2
3
  declare const defaultFlags: {
3
4
  parser: "babel";
@@ -6,5 +6,6 @@ import './styled-to-emotion/styled-to-emotion';
6
6
  import './theme-remove-deprecated-mixins/theme-remove-deprecated-mixins';
7
7
  import './migrate-to-new-buttons/migrate-to-new-buttons';
8
8
  import './upgrade-pragmatic-drag-and-drop-to-stable/upgrade-pragmatic-drag-and-drop-to-stable';
9
+ import './remove-dark-theme-vr-options/remove-dark-theme-vr-options';
9
10
  declare const presets: string[];
10
11
  export default presets;
@@ -0,0 +1,3 @@
1
+ import { type API, type FileInfo } from 'jscodeshift';
2
+ declare function transformer(file: FileInfo, api: API): string;
3
+ export default transformer;
@@ -0,0 +1,2 @@
1
+ import type { API, FileInfo } from 'jscodeshift';
2
+ export default function transformer(file: FileInfo, api: API): Promise<string>;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@atlaskit/codemod-cli",
3
- "version": "0.25.2",
3
+ "version": "0.26.1",
4
4
  "description": "A cli for distributing codemods for atlassian-frontend components and services",
5
5
  "publishConfig": {
6
6
  "registry": "https://registry.npmjs.org/"
@@ -30,8 +30,7 @@
30
30
  "./utils": "./src/utils.ts"
31
31
  },
32
32
  "atlassian": {
33
- "team": "Design System Team",
34
- "releaseModel": "continuous"
33
+ "team": "Design System Team"
35
34
  },
36
35
  "scripts": {
37
36
  "prestart": "cd ../../ && yarn build @atlaskit/codemod-utils tokens",
@@ -40,7 +39,7 @@
40
39
  "bin": "./bin/codemod-cli.js",
41
40
  "dependencies": {
42
41
  "@atlaskit/codemod-utils": "^4.2.0",
43
- "@atlaskit/tokens": "^1.56.0",
42
+ "@atlaskit/tokens": "^1.59.0",
44
43
  "@babel/runtime": "^7.0.0",
45
44
  "@codeshift/utils": "^0.2.4",
46
45
  "@hypermod/utils": "^0.4.2",