@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 +37 -10
- package/package.json +4 -4
- package/v7.0.0/tree-view/preset-safe/index.js +4 -0
- package/v7.0.0/tree-view/rename-expansion-props/index.js +3 -3
- package/v7.0.0/tree-view/rename-focus-callback/index.js +21 -0
- package/v7.0.0/tree-view/rename-selection-props/index.js +3 -3
- package/v7.0.0/tree-view/replace-transition-props-by-slot/index.js +54 -0
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
|
-
+
|
|
278
|
+
+ onExpandedItemsChange={handleExpansionChange}
|
|
277
279
|
|
|
278
|
-
- expanded={
|
|
279
|
-
+
|
|
280
|
+
- expanded={expandedItems}
|
|
281
|
+
+ expandedItems={expandedItems}
|
|
280
282
|
|
|
281
|
-
- defaultExpanded={
|
|
282
|
-
+
|
|
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
|
-
+
|
|
295
|
+
+ onSelectedItemsChange={handleSelectionChange}
|
|
294
296
|
|
|
295
|
-
- selected={
|
|
296
|
-
+
|
|
297
|
+
- selected={selectedItems}
|
|
298
|
+
+ selectedItems={selectedItems}
|
|
297
299
|
|
|
298
|
-
- defaultSelected={
|
|
299
|
-
+
|
|
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.
|
|
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.
|
|
36
|
-
"@babel/runtime": "^7.
|
|
37
|
-
"@babel/traverse": "^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: '
|
|
18
|
-
defaultExpanded: '
|
|
19
|
-
onNodeToggle: '
|
|
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: '
|
|
18
|
-
defaultSelected: '
|
|
19
|
-
onNodeSelect: '
|
|
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
|
+
}
|