@openrewrite/recipes-react 0.2.9
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/dist/index.d.ts +4 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +130 -0
- package/dist/index.js.map +1 -0
- package/dist/migration/change-component-prop-value.d.ts +20 -0
- package/dist/migration/change-component-prop-value.d.ts.map +1 -0
- package/dist/migration/change-component-prop-value.js +217 -0
- package/dist/migration/change-component-prop-value.js.map +1 -0
- package/dist/react-native/view-prop-types.d.ts +8 -0
- package/dist/react-native/view-prop-types.d.ts.map +1 -0
- package/dist/react-native/view-prop-types.js +65 -0
- package/dist/react-native/view-prop-types.js.map +1 -0
- package/dist/react16/error-boundaries.d.ts +8 -0
- package/dist/react16/error-boundaries.d.ts.map +1 -0
- package/dist/react16/error-boundaries.js +42 -0
- package/dist/react16/error-boundaries.js.map +1 -0
- package/dist/react16/find-dom-node.d.ts +8 -0
- package/dist/react16/find-dom-node.d.ts.map +1 -0
- package/dist/react16/find-dom-node.js +48 -0
- package/dist/react16/find-dom-node.js.map +1 -0
- package/dist/react16/react-dom-factories.d.ts +8 -0
- package/dist/react16/react-dom-factories.d.ts.map +1 -0
- package/dist/react16/react-dom-factories.js +72 -0
- package/dist/react16/react-dom-factories.js.map +1 -0
- package/dist/react16/react-prop-types.d.ts +8 -0
- package/dist/react16/react-prop-types.d.ts.map +1 -0
- package/dist/react16/react-prop-types.js +69 -0
- package/dist/react16/react-prop-types.js.map +1 -0
- package/dist/react16/react-to-react-dom.d.ts +8 -0
- package/dist/react16/react-to-react-dom.d.ts.map +1 -0
- package/dist/react16/react-to-react-dom.js +97 -0
- package/dist/react16/react-to-react-dom.js.map +1 -0
- package/dist/react16/replace-create-factory.d.ts +8 -0
- package/dist/react16/replace-create-factory.d.ts.map +1 -0
- package/dist/react16/replace-create-factory.js +69 -0
- package/dist/react16/replace-create-factory.js.map +1 -0
- package/dist/react16/upgrade-to-react-16.d.ts +8 -0
- package/dist/react16/upgrade-to-react-16.d.ts.map +1 -0
- package/dist/react16/upgrade-to-react-16.js +41 -0
- package/dist/react16/upgrade-to-react-16.js.map +1 -0
- package/dist/react17/remove-event-persist.d.ts +8 -0
- package/dist/react17/remove-event-persist.d.ts.map +1 -0
- package/dist/react17/remove-event-persist.js +114 -0
- package/dist/react17/remove-event-persist.js.map +1 -0
- package/dist/react17/rename-unsafe-lifecycles.d.ts +8 -0
- package/dist/react17/rename-unsafe-lifecycles.d.ts.map +1 -0
- package/dist/react17/rename-unsafe-lifecycles.js +48 -0
- package/dist/react17/rename-unsafe-lifecycles.js.map +1 -0
- package/dist/react17/update-react-imports.d.ts +8 -0
- package/dist/react17/update-react-imports.d.ts.map +1 -0
- package/dist/react17/update-react-imports.js +40 -0
- package/dist/react17/update-react-imports.js.map +1 -0
- package/dist/react17/upgrade-to-react-17.d.ts +8 -0
- package/dist/react17/upgrade-to-react-17.d.ts.map +1 -0
- package/dist/react17/upgrade-to-react-17.js +37 -0
- package/dist/react17/upgrade-to-react-17.js.map +1 -0
- package/dist/react18/remove-unstable-batched-updates.d.ts +8 -0
- package/dist/react18/remove-unstable-batched-updates.d.ts.map +1 -0
- package/dist/react18/remove-unstable-batched-updates.js +170 -0
- package/dist/react18/remove-unstable-batched-updates.js.map +1 -0
- package/dist/react18/replace-reactdom-render.d.ts +8 -0
- package/dist/react18/replace-reactdom-render.d.ts.map +1 -0
- package/dist/react18/replace-reactdom-render.js +55 -0
- package/dist/react18/replace-reactdom-render.js.map +1 -0
- package/dist/react18/replace-render-callback.d.ts +8 -0
- package/dist/react18/replace-render-callback.d.ts.map +1 -0
- package/dist/react18/replace-render-callback.js +60 -0
- package/dist/react18/replace-render-callback.js.map +1 -0
- package/dist/react18/replace-unmount-component-at-node.d.ts +8 -0
- package/dist/react18/replace-unmount-component-at-node.d.ts.map +1 -0
- package/dist/react18/replace-unmount-component-at-node.js +54 -0
- package/dist/react18/replace-unmount-component-at-node.js.map +1 -0
- package/dist/react18/upgrade-to-react-18.d.ts +8 -0
- package/dist/react18/upgrade-to-react-18.d.ts.map +1 -0
- package/dist/react18/upgrade-to-react-18.js +39 -0
- package/dist/react18/upgrade-to-react-18.js.map +1 -0
- package/dist/react19/deprecated-react-types.d.ts +8 -0
- package/dist/react19/deprecated-react-types.d.ts.map +1 -0
- package/dist/react19/deprecated-react-types.js +135 -0
- package/dist/react19/deprecated-react-types.js.map +1 -0
- package/dist/react19/find-context-consumer.d.ts +9 -0
- package/dist/react19/find-context-consumer.d.ts.map +1 -0
- package/dist/react19/find-context-consumer.js +128 -0
- package/dist/react19/find-context-consumer.js.map +1 -0
- package/dist/react19/find-deprecated-reactdom-apis.d.ts +9 -0
- package/dist/react19/find-deprecated-reactdom-apis.d.ts.map +1 -0
- package/dist/react19/find-deprecated-reactdom-apis.js +132 -0
- package/dist/react19/find-deprecated-reactdom-apis.js.map +1 -0
- package/dist/react19/find-element-ref.d.ts +9 -0
- package/dist/react19/find-element-ref.d.ts.map +1 -0
- package/dist/react19/find-element-ref.js +88 -0
- package/dist/react19/find-element-ref.js.map +1 -0
- package/dist/react19/find-legacy-context-api.d.ts +9 -0
- package/dist/react19/find-legacy-context-api.d.ts.map +1 -0
- package/dist/react19/find-legacy-context-api.js +163 -0
- package/dist/react19/find-legacy-context-api.js.map +1 -0
- package/dist/react19/no-implicit-ref-callback-return.d.ts +8 -0
- package/dist/react19/no-implicit-ref-callback-return.d.ts.map +1 -0
- package/dist/react19/no-implicit-ref-callback-return.js +107 -0
- package/dist/react19/no-implicit-ref-callback-return.js.map +1 -0
- package/dist/react19/remove-context-provider.d.ts +8 -0
- package/dist/react19/remove-context-provider.d.ts.map +1 -0
- package/dist/react19/remove-context-provider.js +59 -0
- package/dist/react19/remove-context-provider.js.map +1 -0
- package/dist/react19/remove-forward-ref.d.ts +8 -0
- package/dist/react19/remove-forward-ref.d.ts.map +1 -0
- package/dist/react19/remove-forward-ref.js +73 -0
- package/dist/react19/remove-forward-ref.js.map +1 -0
- package/dist/react19/remove-prop-types.d.ts +8 -0
- package/dist/react19/remove-prop-types.d.ts.map +1 -0
- package/dist/react19/remove-prop-types.js +76 -0
- package/dist/react19/remove-prop-types.js.map +1 -0
- package/dist/react19/remove-react-fc.d.ts +8 -0
- package/dist/react19/remove-react-fc.d.ts.map +1 -0
- package/dist/react19/remove-react-fc.js +149 -0
- package/dist/react19/remove-react-fc.js.map +1 -0
- package/dist/react19/replace-act-import.d.ts +9 -0
- package/dist/react19/replace-act-import.d.ts.map +1 -0
- package/dist/react19/replace-act-import.js +34 -0
- package/dist/react19/replace-act-import.js.map +1 -0
- package/dist/react19/replace-default-props.d.ts +8 -0
- package/dist/react19/replace-default-props.d.ts.map +1 -0
- package/dist/react19/replace-default-props.js +195 -0
- package/dist/react19/replace-default-props.js.map +1 -0
- package/dist/react19/replace-react-shallow-renderer.d.ts +8 -0
- package/dist/react19/replace-react-shallow-renderer.d.ts.map +1 -0
- package/dist/react19/replace-react-shallow-renderer.js +69 -0
- package/dist/react19/replace-react-shallow-renderer.js.map +1 -0
- package/dist/react19/replace-reactdom-hydrate.d.ts +8 -0
- package/dist/react19/replace-reactdom-hydrate.d.ts.map +1 -0
- package/dist/react19/replace-reactdom-hydrate.js +55 -0
- package/dist/react19/replace-reactdom-hydrate.js.map +1 -0
- package/dist/react19/replace-string-ref.d.ts +8 -0
- package/dist/react19/replace-string-ref.d.ts.map +1 -0
- package/dist/react19/replace-string-ref.js +75 -0
- package/dist/react19/replace-string-ref.js.map +1 -0
- package/dist/react19/replace-use-form-state.d.ts +8 -0
- package/dist/react19/replace-use-form-state.d.ts.map +1 -0
- package/dist/react19/replace-use-form-state.js +54 -0
- package/dist/react19/replace-use-form-state.js.map +1 -0
- package/dist/react19/upgrade-to-react-19.d.ts +8 -0
- package/dist/react19/upgrade-to-react-19.d.ts.map +1 -0
- package/dist/react19/upgrade-to-react-19.js +59 -0
- package/dist/react19/upgrade-to-react-19.js.map +1 -0
- package/dist/react19/use-context-hook.d.ts +8 -0
- package/dist/react19/use-context-hook.d.ts.map +1 -0
- package/dist/react19/use-context-hook.js +54 -0
- package/dist/react19/use-context-hook.js.map +1 -0
- package/dist/react19/use-ref-required-initial.d.ts +8 -0
- package/dist/react19/use-ref-required-initial.d.ts.map +1 -0
- package/dist/react19/use-ref-required-initial.js +74 -0
- package/dist/react19/use-ref-required-initial.js.map +1 -0
- package/dist/refactoring/class-to-functional.d.ts +8 -0
- package/dist/refactoring/class-to-functional.d.ts.map +1 -0
- package/dist/refactoring/class-to-functional.js +205 -0
- package/dist/refactoring/class-to-functional.js.map +1 -0
- package/dist/refactoring/create-class-to-es6.d.ts +8 -0
- package/dist/refactoring/create-class-to-es6.d.ts.map +1 -0
- package/dist/refactoring/create-class-to-es6.js +289 -0
- package/dist/refactoring/create-class-to-es6.js.map +1 -0
- package/dist/refactoring/create-element-to-jsx.d.ts +8 -0
- package/dist/refactoring/create-element-to-jsx.d.ts.map +1 -0
- package/dist/refactoring/create-element-to-jsx.js +167 -0
- package/dist/refactoring/create-element-to-jsx.js.map +1 -0
- package/dist/refactoring/manual-bind-to-arrow.d.ts +8 -0
- package/dist/refactoring/manual-bind-to-arrow.d.ts.map +1 -0
- package/dist/refactoring/manual-bind-to-arrow.js +134 -0
- package/dist/refactoring/manual-bind-to-arrow.js.map +1 -0
- package/dist/refactoring/pure-render-mixin.d.ts +8 -0
- package/dist/refactoring/pure-render-mixin.d.ts.map +1 -0
- package/dist/refactoring/pure-render-mixin.js +253 -0
- package/dist/refactoring/pure-render-mixin.js.map +1 -0
- package/dist/refactoring/sort-comp.d.ts +8 -0
- package/dist/refactoring/sort-comp.d.ts.map +1 -0
- package/dist/refactoring/sort-comp.js +128 -0
- package/dist/refactoring/sort-comp.js.map +1 -0
- package/dist/search/find-hook-usage.d.ts +9 -0
- package/dist/search/find-hook-usage.d.ts.map +1 -0
- package/dist/search/find-hook-usage.js +262 -0
- package/dist/search/find-hook-usage.js.map +1 -0
- package/dist/search/find-prop-usage.d.ts +15 -0
- package/dist/search/find-prop-usage.d.ts.map +1 -0
- package/dist/search/find-prop-usage.js +177 -0
- package/dist/search/find-prop-usage.js.map +1 -0
- package/dist/search/find-react-component.d.ts +15 -0
- package/dist/search/find-react-component.d.ts.map +1 -0
- package/dist/search/find-react-component.js +260 -0
- package/dist/search/find-react-component.js.map +1 -0
- package/dist/search/find-server-rendering-usage.d.ts +9 -0
- package/dist/search/find-server-rendering-usage.d.ts.map +1 -0
- package/dist/search/find-server-rendering-usage.js +131 -0
- package/dist/search/find-server-rendering-usage.js.map +1 -0
- package/dist/simplify-object-pattern-property.d.ts +8 -0
- package/dist/simplify-object-pattern-property.d.ts.map +1 -0
- package/dist/simplify-object-pattern-property.js +59 -0
- package/dist/simplify-object-pattern-property.js.map +1 -0
- package/dist/simplify-react-imports.d.ts +8 -0
- package/dist/simplify-react-imports.d.ts.map +1 -0
- package/dist/simplify-react-imports.js +199 -0
- package/dist/simplify-react-imports.js.map +1 -0
- package/package.json +39 -0
- package/src/index.ts +149 -0
- package/src/migration/change-component-prop-value.ts +268 -0
- package/src/react-native/view-prop-types.ts +63 -0
- package/src/react16/error-boundaries.ts +46 -0
- package/src/react16/find-dom-node.ts +55 -0
- package/src/react16/react-dom-factories.ts +99 -0
- package/src/react16/react-prop-types.ts +71 -0
- package/src/react16/react-to-react-dom.ts +104 -0
- package/src/react16/replace-create-factory.ts +96 -0
- package/src/react16/upgrade-to-react-16.ts +37 -0
- package/src/react17/remove-event-persist.ts +121 -0
- package/src/react17/rename-unsafe-lifecycles.ts +57 -0
- package/src/react17/update-react-imports.ts +50 -0
- package/src/react17/upgrade-to-react-17.ts +30 -0
- package/src/react18/remove-unstable-batched-updates.ts +192 -0
- package/src/react18/replace-reactdom-render.ts +68 -0
- package/src/react18/replace-render-callback.ts +66 -0
- package/src/react18/replace-unmount-component-at-node.ts +66 -0
- package/src/react18/upgrade-to-react-18.ts +33 -0
- package/src/react19/deprecated-react-types.ts +120 -0
- package/src/react19/find-context-consumer.ts +127 -0
- package/src/react19/find-deprecated-reactdom-apis.ts +125 -0
- package/src/react19/find-element-ref.ts +86 -0
- package/src/react19/find-legacy-context-api.ts +157 -0
- package/src/react19/no-implicit-ref-callback-return.ts +123 -0
- package/src/react19/remove-context-provider.ts +87 -0
- package/src/react19/remove-forward-ref.ts +69 -0
- package/src/react19/remove-prop-types.ts +86 -0
- package/src/react19/remove-react-fc.ts +247 -0
- package/src/react19/replace-act-import.ts +36 -0
- package/src/react19/replace-default-props.ts +220 -0
- package/src/react19/replace-react-shallow-renderer.ts +75 -0
- package/src/react19/replace-reactdom-hydrate.ts +67 -0
- package/src/react19/replace-string-ref.ts +89 -0
- package/src/react19/replace-use-form-state.ts +66 -0
- package/src/react19/upgrade-to-react-19.ts +66 -0
- package/src/react19/use-context-hook.ts +67 -0
- package/src/react19/use-ref-required-initial.ts +75 -0
- package/src/refactoring/class-to-functional.ts +229 -0
- package/src/refactoring/create-class-to-es6.ts +309 -0
- package/src/refactoring/create-element-to-jsx.ts +200 -0
- package/src/refactoring/manual-bind-to-arrow.ts +139 -0
- package/src/refactoring/pure-render-mixin.ts +346 -0
- package/src/refactoring/sort-comp.ts +135 -0
- package/src/search/find-hook-usage.ts +226 -0
- package/src/search/find-prop-usage.ts +176 -0
- package/src/search/find-react-component.ts +254 -0
- package/src/search/find-server-rendering-usage.ts +120 -0
- package/src/simplify-object-pattern-property.ts +71 -0
- package/src/simplify-react-imports.ts +241 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"react-dom-factories.d.ts","sourceRoot":"","sources":["../../src/react16/react-dom-factories.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,gBAAgB,EAAE,MAAM,EAAE,WAAW,EAAC,MAAM,sBAAsB,CAAC;AAyB3E,qBAAa,iBAAkB,SAAQ,MAAM;IACzC,QAAQ,CAAC,IAAI,kDAAkD;IAC/D,QAAQ,CAAC,WAAW,EAAE,MAAM,CAAwD;IACpF,QAAQ,CAAC,WAAW,EAAE,MAAM,CAA+F;IAErH,MAAM,IAAI,OAAO,CAAC,WAAW,CAAC,GAAG,EAAE,gBAAgB,CAAC,CAAC;CAoE9D"}
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.ReactDomFactories = void 0;
|
|
13
|
+
const rewrite_1 = require("@openrewrite/rewrite");
|
|
14
|
+
const javascript_1 = require("@openrewrite/rewrite/javascript");
|
|
15
|
+
const java_1 = require("@openrewrite/rewrite/java");
|
|
16
|
+
class ReactDomFactories extends rewrite_1.Recipe {
|
|
17
|
+
constructor() {
|
|
18
|
+
super(...arguments);
|
|
19
|
+
this.name = "org.openrewrite.react.16.react-dom-factories";
|
|
20
|
+
this.displayName = "Replace `React.DOM` factories with `createElement`";
|
|
21
|
+
this.description = "Converts deprecated `React.DOM.xxx()` factory calls to `React.createElement('xxx', ...)`.";
|
|
22
|
+
}
|
|
23
|
+
editor() {
|
|
24
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
25
|
+
return new class extends javascript_1.JavaScriptVisitor {
|
|
26
|
+
visitMethodInvocation(method, p) {
|
|
27
|
+
const _super = Object.create(null, {
|
|
28
|
+
visitMethodInvocation: { get: () => super.visitMethodInvocation }
|
|
29
|
+
});
|
|
30
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
31
|
+
var _a, _b, _c, _d;
|
|
32
|
+
let m = yield _super.visitMethodInvocation.call(this, method, p);
|
|
33
|
+
if (!m.select)
|
|
34
|
+
return m;
|
|
35
|
+
const select = (_a = m.select.element) !== null && _a !== void 0 ? _a : m.select;
|
|
36
|
+
if (select.kind !== java_1.J.Kind.FieldAccess)
|
|
37
|
+
return m;
|
|
38
|
+
const domAccess = select;
|
|
39
|
+
if (domAccess.name.element.simpleName !== 'DOM')
|
|
40
|
+
return m;
|
|
41
|
+
if (domAccess.target.kind !== java_1.J.Kind.Identifier)
|
|
42
|
+
return m;
|
|
43
|
+
if (domAccess.target.simpleName !== 'React')
|
|
44
|
+
return m;
|
|
45
|
+
const elementName = m.name.simpleName;
|
|
46
|
+
const elementLiteral = {
|
|
47
|
+
kind: java_1.J.Kind.Literal,
|
|
48
|
+
id: m.name.id,
|
|
49
|
+
prefix: (_d = (_c = (_b = m.arguments.elements[0]) === null || _b === void 0 ? void 0 : _b.element) === null || _c === void 0 ? void 0 : _c.prefix) !== null && _d !== void 0 ? _d : { whitespace: '', comments: [] },
|
|
50
|
+
markers: m.name.markers,
|
|
51
|
+
value: elementName,
|
|
52
|
+
valueSource: `'${elementName}'`
|
|
53
|
+
};
|
|
54
|
+
const originalElements = m.arguments.elements.map((el, i) => {
|
|
55
|
+
if (i === 0 && el.element) {
|
|
56
|
+
return Object.assign(Object.assign({}, el), { element: Object.assign(Object.assign({}, el.element), { prefix: { whitespace: ' ', comments: [] } }) });
|
|
57
|
+
}
|
|
58
|
+
return el;
|
|
59
|
+
});
|
|
60
|
+
const newArgs = [
|
|
61
|
+
{ element: elementLiteral, after: { whitespace: '', comments: [] } },
|
|
62
|
+
...originalElements
|
|
63
|
+
];
|
|
64
|
+
return Object.assign(Object.assign({}, m), { select: Object.assign(Object.assign({}, m.select), { element: domAccess.target }), name: Object.assign(Object.assign({}, m.name), { simpleName: 'createElement' }), arguments: Object.assign(Object.assign({}, m.arguments), { elements: newArgs }) });
|
|
65
|
+
});
|
|
66
|
+
}
|
|
67
|
+
}();
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
exports.ReactDomFactories = ReactDomFactories;
|
|
72
|
+
//# sourceMappingURL=react-dom-factories.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"react-dom-factories.js","sourceRoot":"","sources":["../../src/react16/react-dom-factories.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,kDAA2E;AAC3E,gEAMyC;AACzC,oDAAwD;AAiBxD,MAAa,iBAAkB,SAAQ,gBAAM;IAA7C;;QACa,SAAI,GAAG,8CAA8C,CAAC;QACtD,gBAAW,GAAW,oDAAoD,CAAC;QAC3E,gBAAW,GAAW,2FAA2F,CAAC;IAsE/H,CAAC;IApES,MAAM;;YACR,OAAO,IAAI,KAAM,SAAQ,8BAAmC;gBACzC,qBAAqB,CAAC,MAA0B,EAAE,CAAmB;;;;;;wBAChF,IAAI,CAAC,GAAG,MAAM,OAAM,qBAAqB,YAAC,MAAM,EAAE,CAAC,CAAuB,CAAC;wBAG3E,IAAI,CAAC,CAAC,CAAC,MAAM;4BAAE,OAAO,CAAC,CAAC;wBACxB,MAAM,MAAM,GAAG,MAAC,CAAC,CAAC,MAAc,CAAC,OAAO,mCAAI,CAAC,CAAC,MAAM,CAAC;wBACrD,IAAI,MAAM,CAAC,IAAI,KAAK,QAAC,CAAC,IAAI,CAAC,WAAW;4BAAE,OAAO,CAAC,CAAC;wBAEjD,MAAM,SAAS,GAAG,MAAuB,CAAC;wBAC1C,IAAI,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,KAAK,KAAK;4BAAE,OAAO,CAAC,CAAC;wBAC1D,IAAI,SAAS,CAAC,MAAM,CAAC,IAAI,KAAK,QAAC,CAAC,IAAI,CAAC,UAAU;4BAAE,OAAO,CAAC,CAAC;wBAC1D,IAAK,SAAS,CAAC,MAAuB,CAAC,UAAU,KAAK,OAAO;4BAAE,OAAO,CAAC,CAAC;wBAGxE,MAAM,WAAW,GAAG,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC;wBAMtC,MAAM,cAAc,GAAc;4BAC9B,IAAI,EAAE,QAAC,CAAC,IAAI,CAAC,OAAO;4BACpB,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,EAAE;4BACb,MAAM,EAAE,MAAA,MAAA,MAAA,CAAC,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC,0CAAE,OAAO,0CAAE,MAAM,mCAAI,EAAC,UAAU,EAAE,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAC;4BAClF,OAAO,EAAE,CAAC,CAAC,IAAI,CAAC,OAAO;4BACvB,KAAK,EAAE,WAAW;4BAClB,WAAW,EAAE,IAAI,WAAW,GAAG;yBAClC,CAAC;wBAGF,MAAM,gBAAgB,GAAG,CAAC,CAAC,SAAS,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,EAAO,EAAE,CAAS,EAAE,EAAE;4BACrE,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC,OAAO,EAAE,CAAC;gCACxB,uCACO,EAAE,KACL,OAAO,kCACA,EAAE,CAAC,OAAO,KACb,MAAM,EAAE,EAAC,UAAU,EAAE,GAAG,EAAE,QAAQ,EAAE,EAAE,EAAC,OAE7C;4BACN,CAAC;4BACD,OAAO,EAAE,CAAC;wBACd,CAAC,CAAC,CAAC;wBAEH,MAAM,OAAO,GAAG;4BACZ,EAAC,OAAO,EAAE,cAAc,EAAE,KAAK,EAAE,EAAC,UAAU,EAAE,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAC,EAAC;4BAChE,GAAG,gBAAgB;yBACtB,CAAC;wBAEF,OAAO,gCACA,CAAC,KACJ,MAAM,kCACE,CAAC,CAAC,MAAc,KACpB,OAAO,EAAE,SAAS,CAAC,MAAM,KAE7B,IAAI,kCACG,CAAC,CAAC,IAAI,KACT,UAAU,EAAE,eAAe,KAE/B,SAAS,kCACF,CAAC,CAAC,SAAS,KACd,QAAQ,EAAE,OAAO,MAEK,CAAC;oBACnC,CAAC;iBAAA;aACJ,EAAE,CAAC;QACR,CAAC;KAAA;CACJ;AAzED,8CAyEC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { ExecutionContext, Recipe, TreeVisitor } from "@openrewrite/rewrite";
|
|
2
|
+
export declare class ReactPropTypes extends Recipe {
|
|
3
|
+
readonly name = "org.openrewrite.react.16.react-prop-types";
|
|
4
|
+
readonly displayName: string;
|
|
5
|
+
readonly description: string;
|
|
6
|
+
editor(): Promise<TreeVisitor<any, ExecutionContext>>;
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=react-prop-types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"react-prop-types.d.ts","sourceRoot":"","sources":["../../src/react16/react-prop-types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,gBAAgB,EAAE,MAAM,EAAE,WAAW,EAAC,MAAM,sBAAsB,CAAC;AA0B3E,qBAAa,cAAe,SAAQ,MAAM;IACtC,QAAQ,CAAC,IAAI,+CAA+C;IAC5D,QAAQ,CAAC,WAAW,EAAE,MAAM,CAAoD;IAChF,QAAQ,CAAC,WAAW,EAAE,MAAM,CAAsH;IAE5I,MAAM,IAAI,OAAO,CAAC,WAAW,CAAC,GAAG,EAAE,gBAAgB,CAAC,CAAC;CAuC9D"}
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.ReactPropTypes = void 0;
|
|
13
|
+
const rewrite_1 = require("@openrewrite/rewrite");
|
|
14
|
+
const javascript_1 = require("@openrewrite/rewrite/javascript");
|
|
15
|
+
const java_1 = require("@openrewrite/rewrite/java");
|
|
16
|
+
class ReactPropTypes extends rewrite_1.Recipe {
|
|
17
|
+
constructor() {
|
|
18
|
+
super(...arguments);
|
|
19
|
+
this.name = "org.openrewrite.react.16.react-prop-types";
|
|
20
|
+
this.displayName = "Move `React.PropTypes` to `prop-types` package";
|
|
21
|
+
this.description = "Extracts PropTypes usage from the React namespace to the separate `prop-types` package introduced in React 15.5.";
|
|
22
|
+
}
|
|
23
|
+
editor() {
|
|
24
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
25
|
+
return new class extends javascript_1.JavaScriptVisitor {
|
|
26
|
+
constructor() {
|
|
27
|
+
super(...arguments);
|
|
28
|
+
this.transformed = false;
|
|
29
|
+
}
|
|
30
|
+
visitFieldAccess(fieldAccess, ctx) {
|
|
31
|
+
const _super = Object.create(null, {
|
|
32
|
+
visitFieldAccess: { get: () => super.visitFieldAccess }
|
|
33
|
+
});
|
|
34
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
35
|
+
let fa = yield _super.visitFieldAccess.call(this, fieldAccess, ctx);
|
|
36
|
+
if (fa.target.kind !== java_1.J.Kind.Identifier) {
|
|
37
|
+
return fa;
|
|
38
|
+
}
|
|
39
|
+
const target = fa.target;
|
|
40
|
+
if (target.simpleName !== 'React') {
|
|
41
|
+
return fa;
|
|
42
|
+
}
|
|
43
|
+
if (fa.name.element.simpleName !== 'PropTypes') {
|
|
44
|
+
return fa;
|
|
45
|
+
}
|
|
46
|
+
this.transformed = true;
|
|
47
|
+
return Object.assign(Object.assign({}, fa.name.element), { prefix: fa.prefix });
|
|
48
|
+
});
|
|
49
|
+
}
|
|
50
|
+
visitJsCompilationUnit(cu, ctx) {
|
|
51
|
+
const _super = Object.create(null, {
|
|
52
|
+
visitJsCompilationUnit: { get: () => super.visitJsCompilationUnit }
|
|
53
|
+
});
|
|
54
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
55
|
+
this.transformed = false;
|
|
56
|
+
let result = yield _super.visitJsCompilationUnit.call(this, cu, ctx);
|
|
57
|
+
if (this.transformed) {
|
|
58
|
+
(0, javascript_1.maybeAddImport)(this, { module: "prop-types", member: "default", alias: "PropTypes", onlyIfReferenced: false });
|
|
59
|
+
(0, javascript_1.maybeRemoveImport)(this, "react", "PropTypes");
|
|
60
|
+
}
|
|
61
|
+
return result;
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
}();
|
|
65
|
+
});
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
exports.ReactPropTypes = ReactPropTypes;
|
|
69
|
+
//# sourceMappingURL=react-prop-types.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"react-prop-types.js","sourceRoot":"","sources":["../../src/react16/react-prop-types.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,kDAA2E;AAC3E,gEAAqG;AACrG,oDAA4C;AAwB5C,MAAa,cAAe,SAAQ,gBAAM;IAA1C;;QACa,SAAI,GAAG,2CAA2C,CAAC;QACnD,gBAAW,GAAW,gDAAgD,CAAC;QACvE,gBAAW,GAAW,kHAAkH,CAAC;IAyCtJ,CAAC;IAvCS,MAAM;;YACR,OAAO,IAAI,KAAM,SAAQ,8BAAmC;gBAAjD;;oBACC,gBAAW,GAAG,KAAK,CAAC;gBAmChC,CAAC;gBAjCkB,gBAAgB,CAAC,WAA0B,EAAE,GAAqB;;;;;wBAC7E,IAAI,EAAE,GAAG,MAAM,OAAM,gBAAgB,YAAC,WAAW,EAAE,GAAG,CAAkB,CAAC;wBAGzE,IAAI,EAAE,CAAC,MAAM,CAAC,IAAI,KAAK,QAAC,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC;4BACvC,OAAO,EAAE,CAAC;wBACd,CAAC;wBACD,MAAM,MAAM,GAAG,EAAE,CAAC,MAAsB,CAAC;wBACzC,IAAI,MAAM,CAAC,UAAU,KAAK,OAAO,EAAE,CAAC;4BAChC,OAAO,EAAE,CAAC;wBACd,CAAC;wBACD,IAAI,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,KAAK,WAAW,EAAE,CAAC;4BAC7C,OAAO,EAAE,CAAC;wBACd,CAAC;wBAED,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;wBAGxB,OAAO,gCACA,EAAE,CAAC,IAAI,CAAC,OAAO,KAClB,MAAM,EAAE,EAAE,CAAC,MAAM,GACJ,CAAC;oBACtB,CAAC;iBAAA;gBAEc,sBAAsB,CAAC,EAAO,EAAE,GAAqB;;;;;wBAChE,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;wBACzB,IAAI,MAAM,GAAG,MAAM,OAAM,sBAAsB,YAAC,EAAE,EAAE,GAAG,CAAC,CAAC;wBACzD,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;4BACnB,IAAA,2BAAc,EAAC,IAAI,EAAE,EAAC,MAAM,EAAE,YAAY,EAAE,MAAM,EAAE,SAAS,EAAE,KAAK,EAAE,WAAW,EAAE,gBAAgB,EAAE,KAAK,EAAC,CAAC,CAAC;4BAC7G,IAAA,8BAAiB,EAAC,IAAI,EAAE,OAAO,EAAE,WAAW,CAAC,CAAC;wBAClD,CAAC;wBACD,OAAO,MAAM,CAAC;oBAClB,CAAC;iBAAA;aACJ,EAAE,CAAC;QACR,CAAC;KAAA;CACJ;AA5CD,wCA4CC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { ExecutionContext, Recipe, TreeVisitor } from "@openrewrite/rewrite";
|
|
2
|
+
export declare class ReactToReactDom extends Recipe {
|
|
3
|
+
readonly name = "org.openrewrite.react.16.react-to-react-dom";
|
|
4
|
+
readonly displayName: string;
|
|
5
|
+
readonly description: string;
|
|
6
|
+
editor(): Promise<TreeVisitor<any, ExecutionContext>>;
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=react-to-react-dom.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"react-to-react-dom.d.ts","sourceRoot":"","sources":["../../src/react16/react-to-react-dom.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,gBAAgB,EAAE,MAAM,EAAE,WAAW,EAAC,MAAM,sBAAsB,CAAC;AA+B3E,qBAAa,eAAgB,SAAQ,MAAM;IACvC,QAAQ,CAAC,IAAI,iDAAiD;IAC9D,QAAQ,CAAC,WAAW,EAAE,MAAM,CAA6C;IACzE,QAAQ,CAAC,WAAW,EAAE,MAAM,CAA4H;IAElJ,MAAM,IAAI,OAAO,CAAC,WAAW,CAAC,GAAG,EAAE,gBAAgB,CAAC,CAAC;CAmE9D"}
|
|
@@ -0,0 +1,97 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.ReactToReactDom = void 0;
|
|
13
|
+
const rewrite_1 = require("@openrewrite/rewrite");
|
|
14
|
+
const javascript_1 = require("@openrewrite/rewrite/javascript");
|
|
15
|
+
const java_1 = require("@openrewrite/rewrite/java");
|
|
16
|
+
const DOM_METHODS = new Set([
|
|
17
|
+
'render',
|
|
18
|
+
'findDOMNode',
|
|
19
|
+
'unmountComponentAtNode',
|
|
20
|
+
'unstable_batchedUpdates',
|
|
21
|
+
'unstable_renderSubtreeIntoContainer',
|
|
22
|
+
]);
|
|
23
|
+
class ReactToReactDom extends rewrite_1.Recipe {
|
|
24
|
+
constructor() {
|
|
25
|
+
super(...arguments);
|
|
26
|
+
this.name = "org.openrewrite.react.16.react-to-react-dom";
|
|
27
|
+
this.displayName = "Split `React` DOM methods to `ReactDOM`";
|
|
28
|
+
this.description = "Moves DOM-specific methods like `React.render()` and `React.findDOMNode()` to `ReactDOM` from the `react-dom` package.";
|
|
29
|
+
}
|
|
30
|
+
editor() {
|
|
31
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
32
|
+
return new class extends javascript_1.JavaScriptVisitor {
|
|
33
|
+
constructor() {
|
|
34
|
+
super(...arguments);
|
|
35
|
+
this.needsReactDOM = false;
|
|
36
|
+
}
|
|
37
|
+
visitJsCompilationUnit(cu, ctx) {
|
|
38
|
+
const _super = Object.create(null, {
|
|
39
|
+
visitJsCompilationUnit: { get: () => super.visitJsCompilationUnit }
|
|
40
|
+
});
|
|
41
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
42
|
+
this.needsReactDOM = false;
|
|
43
|
+
let result = yield _super.visitJsCompilationUnit.call(this, cu, ctx);
|
|
44
|
+
if (this.needsReactDOM) {
|
|
45
|
+
(0, javascript_1.maybeAddImport)(this, { module: "react-dom", member: "default", alias: "ReactDOM", onlyIfReferenced: false });
|
|
46
|
+
}
|
|
47
|
+
return result;
|
|
48
|
+
});
|
|
49
|
+
}
|
|
50
|
+
visitFieldAccess(fieldAccess, ctx) {
|
|
51
|
+
const _super = Object.create(null, {
|
|
52
|
+
visitFieldAccess: { get: () => super.visitFieldAccess }
|
|
53
|
+
});
|
|
54
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
55
|
+
let fa = yield _super.visitFieldAccess.call(this, fieldAccess, ctx);
|
|
56
|
+
if (fa.target.kind !== java_1.J.Kind.Identifier) {
|
|
57
|
+
return fa;
|
|
58
|
+
}
|
|
59
|
+
const target = fa.target;
|
|
60
|
+
if (target.simpleName !== 'React') {
|
|
61
|
+
return fa;
|
|
62
|
+
}
|
|
63
|
+
const methodName = fa.name.element.simpleName;
|
|
64
|
+
if (!DOM_METHODS.has(methodName)) {
|
|
65
|
+
return fa;
|
|
66
|
+
}
|
|
67
|
+
this.needsReactDOM = true;
|
|
68
|
+
return Object.assign(Object.assign({}, fa), { target: Object.assign(Object.assign({}, target), { simpleName: 'ReactDOM' }) });
|
|
69
|
+
});
|
|
70
|
+
}
|
|
71
|
+
visitMethodInvocation(method, p) {
|
|
72
|
+
const _super = Object.create(null, {
|
|
73
|
+
visitMethodInvocation: { get: () => super.visitMethodInvocation }
|
|
74
|
+
});
|
|
75
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
76
|
+
var _a;
|
|
77
|
+
let m = yield _super.visitMethodInvocation.call(this, method, p);
|
|
78
|
+
if (!m.select)
|
|
79
|
+
return m;
|
|
80
|
+
const select = (_a = m.select.element) !== null && _a !== void 0 ? _a : m.select;
|
|
81
|
+
if (select.kind !== java_1.J.Kind.Identifier)
|
|
82
|
+
return m;
|
|
83
|
+
if (select.simpleName !== 'React')
|
|
84
|
+
return m;
|
|
85
|
+
const methodName = m.name.simpleName;
|
|
86
|
+
if (!DOM_METHODS.has(methodName))
|
|
87
|
+
return m;
|
|
88
|
+
this.needsReactDOM = true;
|
|
89
|
+
return Object.assign(Object.assign({}, m), { select: Object.assign(Object.assign({}, m.select), { element: Object.assign(Object.assign({}, select), { simpleName: 'ReactDOM' }) }) });
|
|
90
|
+
});
|
|
91
|
+
}
|
|
92
|
+
}();
|
|
93
|
+
});
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
exports.ReactToReactDom = ReactToReactDom;
|
|
97
|
+
//# sourceMappingURL=react-to-react-dom.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"react-to-react-dom.js","sourceRoot":"","sources":["../../src/react16/react-to-react-dom.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { ExecutionContext, Recipe, TreeVisitor } from "@openrewrite/rewrite";
|
|
2
|
+
export declare class ReplaceCreateFactory extends Recipe {
|
|
3
|
+
readonly name = "org.openrewrite.react.16.replace-create-factory";
|
|
4
|
+
readonly displayName: string;
|
|
5
|
+
readonly description: string;
|
|
6
|
+
editor(): Promise<TreeVisitor<any, ExecutionContext>>;
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=replace-create-factory.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"replace-create-factory.d.ts","sourceRoot":"","sources":["../../src/react16/replace-create-factory.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,gBAAgB,EAAE,MAAM,EAAE,WAAW,EAAC,MAAM,sBAAsB,CAAC;AAsB3E,qBAAa,oBAAqB,SAAQ,MAAM;IAC5C,QAAQ,CAAC,IAAI,qDAAqD;IAClE,QAAQ,CAAC,WAAW,EAAE,MAAM,CAA8D;IAC1F,QAAQ,CAAC,WAAW,EAAE,MAAM,CAAwL;IAE9M,MAAM,IAAI,OAAO,CAAC,WAAW,CAAC,GAAG,EAAE,gBAAgB,CAAC,CAAC;CAoE9D"}
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.ReplaceCreateFactory = void 0;
|
|
13
|
+
const rewrite_1 = require("@openrewrite/rewrite");
|
|
14
|
+
const javascript_1 = require("@openrewrite/rewrite/javascript");
|
|
15
|
+
const java_1 = require("@openrewrite/rewrite/java");
|
|
16
|
+
class ReplaceCreateFactory extends rewrite_1.Recipe {
|
|
17
|
+
constructor() {
|
|
18
|
+
super(...arguments);
|
|
19
|
+
this.name = "org.openrewrite.react.16.replace-create-factory";
|
|
20
|
+
this.displayName = "Replace `React.createFactory` with `React.createElement`";
|
|
21
|
+
this.description = "Replaces `React.createFactory(type)(props, children)` with `React.createElement(type, props, children)`. React.createFactory was deprecated in React 15.6 and removed in React 16.";
|
|
22
|
+
}
|
|
23
|
+
editor() {
|
|
24
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
25
|
+
return new class extends javascript_1.JavaScriptVisitor {
|
|
26
|
+
visitFunctionCall(functionCall, p) {
|
|
27
|
+
const _super = Object.create(null, {
|
|
28
|
+
visitFunctionCall: { get: () => super.visitFunctionCall }
|
|
29
|
+
});
|
|
30
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
31
|
+
var _a, _b;
|
|
32
|
+
let fc = yield _super.visitFunctionCall.call(this, functionCall, p);
|
|
33
|
+
if (!fc.function)
|
|
34
|
+
return fc;
|
|
35
|
+
const callee = (_a = fc.function.element) !== null && _a !== void 0 ? _a : fc.function;
|
|
36
|
+
if (callee.kind !== java_1.J.Kind.MethodInvocation)
|
|
37
|
+
return fc;
|
|
38
|
+
const innerCall = callee;
|
|
39
|
+
if (innerCall.name.simpleName !== 'createFactory')
|
|
40
|
+
return fc;
|
|
41
|
+
if (!innerCall.select)
|
|
42
|
+
return fc;
|
|
43
|
+
const innerArgs = (_b = innerCall.arguments) === null || _b === void 0 ? void 0 : _b.elements;
|
|
44
|
+
if (!innerArgs || innerArgs.length !== 1)
|
|
45
|
+
return fc;
|
|
46
|
+
const typeArg = innerArgs[0];
|
|
47
|
+
const outerArgs = fc.arguments.elements.filter((el) => {
|
|
48
|
+
var _a;
|
|
49
|
+
const element = (_a = el.element) !== null && _a !== void 0 ? _a : el;
|
|
50
|
+
return element.kind !== java_1.J.Kind.Empty;
|
|
51
|
+
});
|
|
52
|
+
const newOuterArgs = outerArgs.map((el, i) => {
|
|
53
|
+
if (i === 0 && el.element) {
|
|
54
|
+
return Object.assign(Object.assign({}, el), { element: Object.assign(Object.assign({}, el.element), { prefix: { whitespace: ' ', comments: [] } }) });
|
|
55
|
+
}
|
|
56
|
+
return el;
|
|
57
|
+
});
|
|
58
|
+
const newArgs = outerArgs.length > 0
|
|
59
|
+
? [typeArg, ...newOuterArgs]
|
|
60
|
+
: [typeArg];
|
|
61
|
+
return Object.assign(Object.assign({}, innerCall), { prefix: fc.prefix, select: innerCall.select, name: Object.assign(Object.assign({}, innerCall.name), { simpleName: 'createElement' }), arguments: Object.assign(Object.assign({}, fc.arguments), { elements: newArgs }) });
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
}();
|
|
65
|
+
});
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
exports.ReplaceCreateFactory = ReplaceCreateFactory;
|
|
69
|
+
//# sourceMappingURL=replace-create-factory.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"replace-create-factory.js","sourceRoot":"","sources":["../../src/react16/replace-create-factory.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,kDAA2E;AAC3E,gEAAsE;AACtE,oDAA4C;AAoB5C,MAAa,oBAAqB,SAAQ,gBAAM;IAAhD;;QACa,SAAI,GAAG,iDAAiD,CAAC;QACzD,gBAAW,GAAW,0DAA0D,CAAC;QACjF,gBAAW,GAAW,oLAAoL,CAAC;IAsExN,CAAC;IApES,MAAM;;YACR,OAAO,IAAI,KAAM,SAAQ,8BAAmC;gBACzC,iBAAiB,CAAC,YAA6B,EAAE,CAAmB;;;;;;wBAC/E,IAAI,EAAE,GAAG,MAAM,OAAM,iBAAiB,YAAC,YAAY,EAAE,CAAC,CAAoB,CAAC;wBAG3E,IAAI,CAAC,EAAE,CAAC,QAAQ;4BAAE,OAAO,EAAE,CAAC;wBAC5B,MAAM,MAAM,GAAG,MAAC,EAAE,CAAC,QAAgB,CAAC,OAAO,mCAAI,EAAE,CAAC,QAAQ,CAAC;wBAG3D,IAAI,MAAM,CAAC,IAAI,KAAK,QAAC,CAAC,IAAI,CAAC,gBAAgB;4BAAE,OAAO,EAAE,CAAC;wBACvD,MAAM,SAAS,GAAG,MAA4B,CAAC;wBAG/C,IAAI,SAAS,CAAC,IAAI,CAAC,UAAU,KAAK,eAAe;4BAAE,OAAO,EAAE,CAAC;wBAG7D,IAAI,CAAC,SAAS,CAAC,MAAM;4BAAE,OAAO,EAAE,CAAC;wBAGjC,MAAM,SAAS,GAAG,MAAA,SAAS,CAAC,SAAS,0CAAE,QAAQ,CAAC;wBAChD,IAAI,CAAC,SAAS,IAAI,SAAS,CAAC,MAAM,KAAK,CAAC;4BAAE,OAAO,EAAE,CAAC;wBAEpD,MAAM,OAAO,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC;wBAI7B,MAAM,SAAS,GAAG,EAAE,CAAC,SAAS,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,EAAO,EAAE,EAAE;;4BACvD,MAAM,OAAO,GAAG,MAAA,EAAE,CAAC,OAAO,mCAAI,EAAE,CAAC;4BACjC,OAAO,OAAO,CAAC,IAAI,KAAK,QAAC,CAAC,IAAI,CAAC,KAAK,CAAC;wBACzC,CAAC,CAAC,CAAC;wBAGH,MAAM,YAAY,GAAG,SAAS,CAAC,GAAG,CAAC,CAAC,EAAO,EAAE,CAAS,EAAE,EAAE;4BACtD,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC,OAAO,EAAE,CAAC;gCACxB,uCACO,EAAE,KACL,OAAO,kCACA,EAAE,CAAC,OAAO,KACb,MAAM,EAAE,EAAC,UAAU,EAAE,GAAG,EAAE,QAAQ,EAAE,EAAE,EAAC,OAE7C;4BACN,CAAC;4BACD,OAAO,EAAE,CAAC;wBACd,CAAC,CAAC,CAAC;wBAEH,MAAM,OAAO,GAAG,SAAS,CAAC,MAAM,GAAG,CAAC;4BAChC,CAAC,CAAC,CAAC,OAAO,EAAE,GAAG,YAAY,CAAC;4BAC5B,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC;wBAIhB,OAAO,gCACA,SAAS,KACZ,MAAM,EAAG,EAAU,CAAC,MAAM,EAC1B,MAAM,EAAE,SAAS,CAAC,MAAM,EACxB,IAAI,kCACG,SAAS,CAAC,IAAI,KACjB,UAAU,EAAE,eAAe,KAE/B,SAAS,kCACF,EAAE,CAAC,SAAS,KACf,QAAQ,EAAE,OAAO,MAEK,CAAC;oBACnC,CAAC;iBAAA;aACJ,EAAE,CAAC;QACR,CAAC;KAAA;CACJ;AAzED,oDAyEC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { Recipe } from "@openrewrite/rewrite";
|
|
2
|
+
export declare class UpgradeToReact16 extends Recipe {
|
|
3
|
+
readonly name = "org.openrewrite.react.migrate.upgrade-to-react-16";
|
|
4
|
+
readonly displayName = "Upgrade to React 16";
|
|
5
|
+
readonly description = "Migrate deprecated APIs for React 16 compatibility. Includes PropTypes extraction, ReactDOM split, DOM factory replacement, createFactory replacement, and error boundary API updates.";
|
|
6
|
+
recipeList(): Promise<Recipe[]>;
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=upgrade-to-react-16.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"upgrade-to-react-16.d.ts","sourceRoot":"","sources":["../../src/react16/upgrade-to-react-16.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,MAAM,EAAC,MAAM,sBAAsB,CAAC;AAqB5C,qBAAa,gBAAiB,SAAQ,MAAM;IACxC,QAAQ,CAAC,IAAI,uDAAuD;IACpE,QAAQ,CAAC,WAAW,yBAAyB;IAC7C,QAAQ,CAAC,WAAW,4LAA4L;IAE1M,UAAU,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;CAUxC"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.UpgradeToReact16 = void 0;
|
|
13
|
+
const rewrite_1 = require("@openrewrite/rewrite");
|
|
14
|
+
const error_boundaries_1 = require("./error-boundaries");
|
|
15
|
+
const find_dom_node_1 = require("./find-dom-node");
|
|
16
|
+
const react_prop_types_1 = require("./react-prop-types");
|
|
17
|
+
const react_dom_factories_1 = require("./react-dom-factories");
|
|
18
|
+
const react_to_react_dom_1 = require("./react-to-react-dom");
|
|
19
|
+
const replace_create_factory_1 = require("./replace-create-factory");
|
|
20
|
+
class UpgradeToReact16 extends rewrite_1.Recipe {
|
|
21
|
+
constructor() {
|
|
22
|
+
super(...arguments);
|
|
23
|
+
this.name = "org.openrewrite.react.migrate.upgrade-to-react-16";
|
|
24
|
+
this.displayName = "Upgrade to React 16";
|
|
25
|
+
this.description = "Migrate deprecated APIs for React 16 compatibility. Includes PropTypes extraction, ReactDOM split, DOM factory replacement, createFactory replacement, and error boundary API updates.";
|
|
26
|
+
}
|
|
27
|
+
recipeList() {
|
|
28
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
29
|
+
return [
|
|
30
|
+
new react_prop_types_1.ReactPropTypes(),
|
|
31
|
+
new react_dom_factories_1.ReactDomFactories(),
|
|
32
|
+
new react_to_react_dom_1.ReactToReactDom(),
|
|
33
|
+
new find_dom_node_1.FindDomNode(),
|
|
34
|
+
new error_boundaries_1.ErrorBoundaries(),
|
|
35
|
+
new replace_create_factory_1.ReplaceCreateFactory(),
|
|
36
|
+
];
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
exports.UpgradeToReact16 = UpgradeToReact16;
|
|
41
|
+
//# sourceMappingURL=upgrade-to-react-16.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"upgrade-to-react-16.js","sourceRoot":"","sources":["../../src/react16/upgrade-to-react-16.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,kDAA4C;AAC5C,yDAAmD;AACnD,mDAA4C;AAC5C,yDAAkD;AAClD,+DAAwD;AACxD,6DAAqD;AACrD,qEAA8D;AAe9D,MAAa,gBAAiB,SAAQ,gBAAM;IAA5C;;QACa,SAAI,GAAG,mDAAmD,CAAC;QAC3D,gBAAW,GAAG,qBAAqB,CAAC;QACpC,gBAAW,GAAG,wLAAwL,CAAC;IAYpN,CAAC;IAVS,UAAU;;YACZ,OAAO;gBACH,IAAI,iCAAc,EAAE;gBACpB,IAAI,uCAAiB,EAAE;gBACvB,IAAI,oCAAe,EAAE;gBACrB,IAAI,2BAAW,EAAE;gBACjB,IAAI,kCAAe,EAAE;gBACrB,IAAI,6CAAoB,EAAE;aAC7B,CAAC;QACN,CAAC;KAAA;CACJ;AAfD,4CAeC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { ExecutionContext, Recipe, TreeVisitor } from "@openrewrite/rewrite";
|
|
2
|
+
export declare class RemoveEventPersist extends Recipe {
|
|
3
|
+
readonly name = "org.openrewrite.react.17.remove-event-persist";
|
|
4
|
+
readonly displayName: string;
|
|
5
|
+
readonly description: string;
|
|
6
|
+
editor(): Promise<TreeVisitor<any, ExecutionContext>>;
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=remove-event-persist.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"remove-event-persist.d.ts","sourceRoot":"","sources":["../../src/react17/remove-event-persist.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,gBAAgB,EAAE,MAAM,EAAE,WAAW,EAAC,MAAM,sBAAsB,CAAC;AA4B3E,qBAAa,kBAAmB,SAAQ,MAAM;IAC1C,QAAQ,CAAC,IAAI,mDAAmD;IAChE,QAAQ,CAAC,WAAW,EAAE,MAAM,CAAoC;IAChE,QAAQ,CAAC,WAAW,EAAE,MAAM,CAAoG;IAE1H,MAAM,IAAI,OAAO,CAAC,WAAW,CAAC,GAAG,EAAE,gBAAgB,CAAC,CAAC;CAuF9D"}
|
|
@@ -0,0 +1,114 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.RemoveEventPersist = void 0;
|
|
13
|
+
const rewrite_1 = require("@openrewrite/rewrite");
|
|
14
|
+
const javascript_1 = require("@openrewrite/rewrite/javascript");
|
|
15
|
+
const java_1 = require("@openrewrite/rewrite/java");
|
|
16
|
+
const mutative_1 = require("mutative");
|
|
17
|
+
class RemoveEventPersist extends rewrite_1.Recipe {
|
|
18
|
+
constructor() {
|
|
19
|
+
super(...arguments);
|
|
20
|
+
this.name = "org.openrewrite.react.17.remove-event-persist";
|
|
21
|
+
this.displayName = "Remove `event.persist()` calls";
|
|
22
|
+
this.description = "Removes `event.persist()` calls. React 17 removed event pooling, making persist() unnecessary.";
|
|
23
|
+
}
|
|
24
|
+
editor() {
|
|
25
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
26
|
+
return new class extends javascript_1.JavaScriptVisitor {
|
|
27
|
+
visitJsCompilationUnit(cu, ctx) {
|
|
28
|
+
const _super = Object.create(null, {
|
|
29
|
+
visitJsCompilationUnit: { get: () => super.visitJsCompilationUnit }
|
|
30
|
+
});
|
|
31
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
32
|
+
let result = yield _super.visitJsCompilationUnit.call(this, cu, ctx);
|
|
33
|
+
const statementsToRemove = new Set();
|
|
34
|
+
for (const stmt of result.statements) {
|
|
35
|
+
const s = stmt.element;
|
|
36
|
+
if (!s)
|
|
37
|
+
continue;
|
|
38
|
+
if (this.isPersistCall(s)) {
|
|
39
|
+
statementsToRemove.add(s.id);
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
if (statementsToRemove.size === 0)
|
|
43
|
+
return result;
|
|
44
|
+
const filteredStatements = result.statements.filter(stmt => {
|
|
45
|
+
const s = stmt.element;
|
|
46
|
+
return !s || !statementsToRemove.has(s.id);
|
|
47
|
+
});
|
|
48
|
+
return (0, mutative_1.create)(result, draft => {
|
|
49
|
+
draft.statements = filteredStatements;
|
|
50
|
+
});
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
visitBlock(block, ctx) {
|
|
54
|
+
const _super = Object.create(null, {
|
|
55
|
+
visitBlock: { get: () => super.visitBlock }
|
|
56
|
+
});
|
|
57
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
58
|
+
let b = yield _super.visitBlock.call(this, block, ctx);
|
|
59
|
+
const statementsToRemove = new Set();
|
|
60
|
+
for (const stmt of b.statements) {
|
|
61
|
+
const s = stmt.element;
|
|
62
|
+
if (!s)
|
|
63
|
+
continue;
|
|
64
|
+
if (this.isPersistCall(s)) {
|
|
65
|
+
statementsToRemove.add(s.id);
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
if (statementsToRemove.size === 0)
|
|
69
|
+
return b;
|
|
70
|
+
const filteredStatements = b.statements.filter(stmt => {
|
|
71
|
+
const s = stmt.element;
|
|
72
|
+
return !s || !statementsToRemove.has(s.id);
|
|
73
|
+
});
|
|
74
|
+
return (0, mutative_1.create)(b, draft => {
|
|
75
|
+
draft.statements = filteredStatements;
|
|
76
|
+
});
|
|
77
|
+
});
|
|
78
|
+
}
|
|
79
|
+
isPersistCall(stmt) {
|
|
80
|
+
let expr;
|
|
81
|
+
if (stmt.kind === javascript_1.JS.Kind.ExpressionStatement) {
|
|
82
|
+
expr = stmt.expression;
|
|
83
|
+
}
|
|
84
|
+
else if (stmt.kind === java_1.J.Kind.MethodInvocation) {
|
|
85
|
+
expr = stmt;
|
|
86
|
+
}
|
|
87
|
+
else {
|
|
88
|
+
return false;
|
|
89
|
+
}
|
|
90
|
+
if (!expr || expr.kind !== java_1.J.Kind.MethodInvocation)
|
|
91
|
+
return false;
|
|
92
|
+
const method = expr;
|
|
93
|
+
if (!method.select)
|
|
94
|
+
return false;
|
|
95
|
+
if (method.name.simpleName !== 'persist')
|
|
96
|
+
return false;
|
|
97
|
+
if (method.arguments) {
|
|
98
|
+
const args = method.arguments.elements;
|
|
99
|
+
const hasRealArgs = args.some((el) => {
|
|
100
|
+
var _a;
|
|
101
|
+
const element = (_a = el.element) !== null && _a !== void 0 ? _a : el;
|
|
102
|
+
return element.kind !== java_1.J.Kind.Empty;
|
|
103
|
+
});
|
|
104
|
+
if (hasRealArgs)
|
|
105
|
+
return false;
|
|
106
|
+
}
|
|
107
|
+
return true;
|
|
108
|
+
}
|
|
109
|
+
}();
|
|
110
|
+
});
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
exports.RemoveEventPersist = RemoveEventPersist;
|
|
114
|
+
//# sourceMappingURL=remove-event-persist.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"remove-event-persist.js","sourceRoot":"","sources":["../../src/react17/remove-event-persist.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { ExecutionContext, Recipe, TreeVisitor } from "@openrewrite/rewrite";
|
|
2
|
+
export declare class RenameUnsafeLifecycles extends Recipe {
|
|
3
|
+
readonly name = "org.openrewrite.react.17.rename-unsafe-lifecycles";
|
|
4
|
+
readonly displayName: string;
|
|
5
|
+
readonly description: string;
|
|
6
|
+
editor(): Promise<TreeVisitor<any, ExecutionContext>>;
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=rename-unsafe-lifecycles.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rename-unsafe-lifecycles.d.ts","sourceRoot":"","sources":["../../src/react17/rename-unsafe-lifecycles.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,gBAAgB,EAAE,MAAM,EAAE,WAAW,EAAC,MAAM,sBAAsB,CAAC;AAkC3E,qBAAa,sBAAuB,SAAQ,MAAM;IAC9C,QAAQ,CAAC,IAAI,uDAAuD;IACpE,QAAQ,CAAC,WAAW,EAAE,MAAM,CAA0D;IACtF,QAAQ,CAAC,WAAW,EAAE,MAAM,CAA8H;IAEpJ,MAAM,IAAI,OAAO,CAAC,WAAW,CAAC,GAAG,EAAE,gBAAgB,CAAC,CAAC;CAiB9D"}
|