@mui/x-codemod 7.0.0-beta.0 → 7.0.0-beta.7

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/README.md CHANGED
@@ -221,6 +221,8 @@ The list includes these transformers
221
221
  - [`rename-use-tree-item`](#rename-use-tree-item)
222
222
  - [`rename-expansion-props`](#rename-expansion-props)
223
223
  - [`rename-selection-props`](#rename-selection-props)
224
+ - [`replace-transition-props-by-slot`](#replace-transition-props-by-slot)
225
+ - [`rename-focus-callback`](#rename-focus-callback)
224
226
 
225
227
  #### `rename-tree-view-simple-tree-view`
226
228
 
@@ -273,13 +275,13 @@ Rename the expansion props
273
275
  ```diff
274
276
  <TreeView
275
277
  - onNodeToggle={handleExpansionChange}
276
- + onExpandedNodesChange={handleExpansionChange}
278
+ + onExpandedItemsChange={handleExpansionChange}
277
279
 
278
- - expanded={expandedNodes}
279
- + expandedNodes={expandedNodes}
280
+ - expanded={expandedItems}
281
+ + expandedItems={expandedItems}
280
282
 
281
- - defaultExpanded={defaultExpandedNodes}
282
- + defaultExpandedNodes={defaultExpandedNodes}
283
+ - defaultExpanded={defaultExpandedItems}
284
+ + defaultExpandedItems={defaultExpandedItems}
283
285
  />
284
286
  ```
285
287
 
@@ -290,13 +292,38 @@ Rename the selection props
290
292
  ```diff
291
293
  <TreeView
292
294
  - onNodeSelect={handleSelectionChange}
293
- + onSelectedNodesChange={handleSelectionChange}
295
+ + onSelectedItemsChange={handleSelectionChange}
294
296
 
295
- - selected={selectedNodes}
296
- + selectedNodes={selectedNodes}
297
+ - selected={selectedItems}
298
+ + selectedItems={selectedItems}
297
299
 
298
- - defaultSelected={defaultSelectedNodes}
299
- + defaultSelectedNodes={defaultSelectedNodes}
300
+ - defaultSelected={defaultSelectedItems}
301
+ + defaultSelectedItems={defaultSelectedItems}
302
+ />
303
+ ```
304
+
305
+ #### `replace-transition-props-by-slot`
306
+
307
+ Replace the `TransitionComponent` and `TransitionProps` components with the `groupTransition` slot:
308
+
309
+ ```diff
310
+ <TreeItem
311
+ - TransitionComponent={Fade}
312
+ + slots={{ groupTransition: Fade }}
313
+
314
+ - TransitionProps={{ timeout: 600 }}
315
+ + slotProps={{ groupTransition: { timeout: 600 } }}
316
+ />
317
+ ```
318
+
319
+ #### `rename-focus-callback`
320
+
321
+ Replace the `onNodeFocus` callback with `onItemFocus`:
322
+
323
+ ```diff
324
+ <TreeView
325
+ - onNodeFocus={onNodeFocus}
326
+ + onItemFocus={onItemFocus}
300
327
  />
301
328
  ```
302
329
 
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@mui/x-codemod",
3
- "version": "7.0.0-beta.0",
3
+ "version": "7.0.0-beta.7",
4
4
  "bin": "./codemod.js",
5
5
  "private": false,
6
6
  "author": "MUI Team",
@@ -32,9 +32,9 @@
32
32
  "url": "https://opencollective.com/mui-org"
33
33
  },
34
34
  "dependencies": {
35
- "@babel/core": "^7.23.7",
36
- "@babel/runtime": "^7.23.8",
37
- "@babel/traverse": "^7.23.7",
35
+ "@babel/core": "^7.24.0",
36
+ "@babel/runtime": "^7.24.0",
37
+ "@babel/traverse": "^7.24.0",
38
38
  "jscodeshift": "0.13.1",
39
39
  "jscodeshift-add-imports": "^1.0.10",
40
40
  "yargs": "^17.7.2"
@@ -7,11 +7,15 @@ Object.defineProperty(exports, "__esModule", {
7
7
  exports.default = transformer;
8
8
  var _renameExpansionProps = _interopRequireDefault(require("../rename-expansion-props"));
9
9
  var _renameSelectionProps = _interopRequireDefault(require("../rename-selection-props"));
10
+ var _renameFocusCallback = _interopRequireDefault(require("../rename-focus-callback"));
11
+ var _replaceTransitionPropsBySlot = _interopRequireDefault(require("../replace-transition-props-by-slot"));
10
12
  var _renameUseTreeItem = _interopRequireDefault(require("../rename-use-tree-item"));
11
13
  var _renameTreeViewSimpleTreeView = _interopRequireDefault(require("../rename-tree-view-simple-tree-view"));
12
14
  function transformer(file, api, options) {
13
15
  file.source = (0, _renameExpansionProps.default)(file, api, options);
14
16
  file.source = (0, _renameSelectionProps.default)(file, api, options);
17
+ file.source = (0, _renameFocusCallback.default)(file, api, options);
18
+ file.source = (0, _replaceTransitionPropsBySlot.default)(file, api, options);
15
19
  file.source = (0, _renameUseTreeItem.default)(file, api, options);
16
20
  file.source = (0, _renameTreeViewSimpleTreeView.default)(file, api, options);
17
21
  return file.source;
@@ -14,9 +14,9 @@ function transformer(file, api, options) {
14
14
  root,
15
15
  componentNames: ['TreeView', 'SimpleTreeView'],
16
16
  props: {
17
- expanded: 'expandedNodes',
18
- defaultExpanded: 'defaultExpandedNodes',
19
- onNodeToggle: 'onExpandedNodesChange'
17
+ expanded: 'expandedItems',
18
+ defaultExpanded: 'defaultExpandedItems',
19
+ onNodeToggle: 'onExpandedItemsChange'
20
20
  },
21
21
  j
22
22
  }).toSource(printOptions);
@@ -0,0 +1,21 @@
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 _renameProps = _interopRequireDefault(require("../../../util/renameProps"));
9
+ function transformer(file, api, options) {
10
+ const j = api.jscodeshift;
11
+ const root = j(file.source);
12
+ const printOptions = options.printOptions;
13
+ return (0, _renameProps.default)({
14
+ root,
15
+ componentNames: ['TreeView', 'SimpleTreeView'],
16
+ props: {
17
+ onNodeFocus: 'onItemFocus'
18
+ },
19
+ j
20
+ }).toSource(printOptions);
21
+ }
@@ -14,9 +14,9 @@ function transformer(file, api, options) {
14
14
  root,
15
15
  componentNames: ['TreeView', 'SimpleTreeView'],
16
16
  props: {
17
- selected: 'selectedNodes',
18
- defaultSelected: 'defaultSelectedNodes',
19
- onNodeSelect: 'onSelectedNodesChange'
17
+ selected: 'selectedItems',
18
+ defaultSelected: 'defaultSelectedItems',
19
+ onNodeSelect: 'onSelectedItemsChange'
20
20
  },
21
21
  j
22
22
  }).toSource(printOptions);
@@ -0,0 +1,54 @@
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 _addComponentsSlots = require("../../../util/addComponentsSlots");
9
+ var _removeProps = _interopRequireDefault(require("../../../util/removeProps"));
10
+ const propsToSlots = {
11
+ TransitionComponent: {
12
+ prop: 'slots',
13
+ path: 'groupTransition'
14
+ },
15
+ TransitionProps: {
16
+ prop: 'slotProps',
17
+ path: 'groupTransition'
18
+ }
19
+ };
20
+ function transformer(file, api, options) {
21
+ const j = api.jscodeshift;
22
+ const root = j(file.source);
23
+ const printOptions = options.printOptions || {
24
+ quote: 'single',
25
+ trailingComma: true
26
+ };
27
+ root.find(j.JSXElement).filter(path => path.value.openingElement.name.name === 'TreeItem').forEach(path => {
28
+ const attributesToTransform = j(path).find(j.JSXAttribute).filter(attribute => Object.keys(propsToSlots).includes(attribute.value.name.name));
29
+ attributesToTransform.forEach(attribute => {
30
+ const attributeName = attribute.value.name.name;
31
+
32
+ // Get the value in case it's:
33
+ // - prop={value}
34
+ // - prop="value"
35
+ // - prop (which means true)
36
+ let value = attribute.value.value?.type === 'JSXExpressionContainer' ? attribute.value.value.expression : attribute.value.value || j.booleanLiteral(true);
37
+ if (attributeName === 'showToolbar') {
38
+ if (value.type === 'BooleanLiteral' || value.type === 'Literal' && typeof value.value === 'boolean') {
39
+ value.value = !value.value;
40
+ } else {
41
+ value = j.unaryExpression('!', value);
42
+ }
43
+ }
44
+ (0, _addComponentsSlots.transformNestedProp)(path, propsToSlots[attributeName].prop, propsToSlots[attributeName].path, value, j);
45
+ });
46
+ });
47
+ (0, _removeProps.default)({
48
+ root,
49
+ componentNames: ['TreeItem'],
50
+ props: Object.keys(propsToSlots),
51
+ j
52
+ });
53
+ return root.toSource(printOptions);
54
+ }