@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,163 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
9
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
10
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
11
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
12
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
13
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
14
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
15
|
+
});
|
|
16
|
+
};
|
|
17
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
|
+
exports.FindLegacyContextAPI = void 0;
|
|
19
|
+
const rewrite_1 = require("@openrewrite/rewrite");
|
|
20
|
+
const javascript_1 = require("@openrewrite/rewrite/javascript");
|
|
21
|
+
const java_1 = require("@openrewrite/rewrite/java");
|
|
22
|
+
class LegacyContextRow {
|
|
23
|
+
}
|
|
24
|
+
__decorate([
|
|
25
|
+
(0, rewrite_1.Column)({ displayName: "File path", description: "The file path where the legacy context API is used" })
|
|
26
|
+
], LegacyContextRow.prototype, "filePath", void 0);
|
|
27
|
+
__decorate([
|
|
28
|
+
(0, rewrite_1.Column)({ displayName: "API type", description: "The type of legacy context API: contextTypes, childContextTypes, or getChildContext" })
|
|
29
|
+
], LegacyContextRow.prototype, "apiType", void 0);
|
|
30
|
+
__decorate([
|
|
31
|
+
(0, rewrite_1.Column)({ displayName: "Component name", description: "The name of the component using the legacy context API" })
|
|
32
|
+
], LegacyContextRow.prototype, "componentName", void 0);
|
|
33
|
+
class FindLegacyContextAPI extends rewrite_1.Recipe {
|
|
34
|
+
constructor() {
|
|
35
|
+
super(...arguments);
|
|
36
|
+
this.name = "org.openrewrite.react.19.find-legacy-context-api";
|
|
37
|
+
this.displayName = "Find legacy Context API usage";
|
|
38
|
+
this.description = "Finds usage of the legacy Context API (`contextTypes`, `childContextTypes`, `getChildContext`) that was removed in React 19. These must be migrated to `React.createContext()`.";
|
|
39
|
+
this.dataTable = new rewrite_1.DataTable("org.openrewrite.react.19.LegacyContextAPITable", "Legacy Context API usages", "Table of all legacy Context API usages found in the codebase.", LegacyContextRow);
|
|
40
|
+
}
|
|
41
|
+
editor() {
|
|
42
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
43
|
+
const dataTable = this.dataTable;
|
|
44
|
+
const LEGACY_CONTEXT_PROPS = new Set(['contextTypes', 'childContextTypes']);
|
|
45
|
+
return new class extends javascript_1.JavaScriptVisitor {
|
|
46
|
+
constructor() {
|
|
47
|
+
super(...arguments);
|
|
48
|
+
this.filePath = "";
|
|
49
|
+
this.classStack = [];
|
|
50
|
+
}
|
|
51
|
+
visitJsCompilationUnit(cu, ctx) {
|
|
52
|
+
const _super = Object.create(null, {
|
|
53
|
+
visitJsCompilationUnit: { get: () => super.visitJsCompilationUnit }
|
|
54
|
+
});
|
|
55
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
56
|
+
var _a;
|
|
57
|
+
this.filePath = (_a = cu.sourcePath) !== null && _a !== void 0 ? _a : "";
|
|
58
|
+
this.classStack = [];
|
|
59
|
+
let result = yield _super.visitJsCompilationUnit.call(this, cu, ctx);
|
|
60
|
+
for (const paddedStmt of result.statements) {
|
|
61
|
+
const stmt = paddedStmt.element;
|
|
62
|
+
if (!stmt)
|
|
63
|
+
continue;
|
|
64
|
+
let assignment;
|
|
65
|
+
if (stmt.kind === javascript_1.JS.Kind.ExpressionStatement) {
|
|
66
|
+
const exprStmt = stmt;
|
|
67
|
+
if (exprStmt.expression.kind === java_1.J.Kind.Assignment) {
|
|
68
|
+
assignment = exprStmt.expression;
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
else if (stmt.kind === java_1.J.Kind.Assignment) {
|
|
72
|
+
assignment = stmt;
|
|
73
|
+
}
|
|
74
|
+
if (!assignment)
|
|
75
|
+
continue;
|
|
76
|
+
if (assignment.variable.kind !== java_1.J.Kind.FieldAccess)
|
|
77
|
+
continue;
|
|
78
|
+
const fa = assignment.variable;
|
|
79
|
+
const propName = fa.name.element.simpleName;
|
|
80
|
+
if (!LEGACY_CONTEXT_PROPS.has(propName))
|
|
81
|
+
continue;
|
|
82
|
+
if (!(0, java_1.isIdentifier)(fa.target))
|
|
83
|
+
continue;
|
|
84
|
+
const componentName = fa.target.simpleName;
|
|
85
|
+
dataTable.insertRow(ctx, {
|
|
86
|
+
filePath: this.filePath,
|
|
87
|
+
apiType: propName,
|
|
88
|
+
componentName
|
|
89
|
+
});
|
|
90
|
+
result = Object.assign(Object.assign({}, result), { statements: result.statements.map(s => {
|
|
91
|
+
if (s === paddedStmt) {
|
|
92
|
+
return Object.assign(Object.assign({}, s), { element: (0, rewrite_1.foundSearchResult)(stmt, `Legacy Context API: ${propName}`) });
|
|
93
|
+
}
|
|
94
|
+
return s;
|
|
95
|
+
}) });
|
|
96
|
+
}
|
|
97
|
+
return result;
|
|
98
|
+
});
|
|
99
|
+
}
|
|
100
|
+
visitClassDeclaration(classDecl, ctx) {
|
|
101
|
+
const _super = Object.create(null, {
|
|
102
|
+
visitClassDeclaration: { get: () => super.visitClassDeclaration }
|
|
103
|
+
});
|
|
104
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
105
|
+
var _a, _b;
|
|
106
|
+
const name = (_b = (_a = classDecl.name) === null || _a === void 0 ? void 0 : _a.simpleName) !== null && _b !== void 0 ? _b : "<anonymous>";
|
|
107
|
+
this.classStack.push(name);
|
|
108
|
+
const result = yield _super.visitClassDeclaration.call(this, classDecl, ctx);
|
|
109
|
+
this.classStack.pop();
|
|
110
|
+
return result;
|
|
111
|
+
});
|
|
112
|
+
}
|
|
113
|
+
visitVariableDeclarations(vd, ctx) {
|
|
114
|
+
const _super = Object.create(null, {
|
|
115
|
+
visitVariableDeclarations: { get: () => super.visitVariableDeclarations }
|
|
116
|
+
});
|
|
117
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
118
|
+
var _a, _b, _c;
|
|
119
|
+
const result = yield _super.visitVariableDeclarations.call(this, vd, ctx);
|
|
120
|
+
if (this.classStack.length === 0)
|
|
121
|
+
return result;
|
|
122
|
+
const namedVar = (_b = (_a = vd.variables) === null || _a === void 0 ? void 0 : _a[0]) === null || _b === void 0 ? void 0 : _b.element;
|
|
123
|
+
if (!namedVar)
|
|
124
|
+
return result;
|
|
125
|
+
const varName = (_c = namedVar.name) === null || _c === void 0 ? void 0 : _c.simpleName;
|
|
126
|
+
if (!varName || !LEGACY_CONTEXT_PROPS.has(varName))
|
|
127
|
+
return result;
|
|
128
|
+
const componentName = this.classStack[this.classStack.length - 1];
|
|
129
|
+
dataTable.insertRow(ctx, {
|
|
130
|
+
filePath: this.filePath,
|
|
131
|
+
apiType: varName,
|
|
132
|
+
componentName
|
|
133
|
+
});
|
|
134
|
+
return (0, rewrite_1.foundSearchResult)(result, `Legacy Context API: ${varName}`);
|
|
135
|
+
});
|
|
136
|
+
}
|
|
137
|
+
visitMethodDeclaration(method, ctx) {
|
|
138
|
+
const _super = Object.create(null, {
|
|
139
|
+
visitMethodDeclaration: { get: () => super.visitMethodDeclaration }
|
|
140
|
+
});
|
|
141
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
142
|
+
var _a;
|
|
143
|
+
const result = yield _super.visitMethodDeclaration.call(this, method, ctx);
|
|
144
|
+
if (this.classStack.length === 0)
|
|
145
|
+
return result;
|
|
146
|
+
const methodName = (_a = method.name) === null || _a === void 0 ? void 0 : _a.simpleName;
|
|
147
|
+
if (methodName !== 'getChildContext')
|
|
148
|
+
return result;
|
|
149
|
+
const componentName = this.classStack[this.classStack.length - 1];
|
|
150
|
+
dataTable.insertRow(ctx, {
|
|
151
|
+
filePath: this.filePath,
|
|
152
|
+
apiType: 'getChildContext',
|
|
153
|
+
componentName
|
|
154
|
+
});
|
|
155
|
+
return (0, rewrite_1.foundSearchResult)(result, "Legacy Context API: getChildContext");
|
|
156
|
+
});
|
|
157
|
+
}
|
|
158
|
+
}();
|
|
159
|
+
});
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
exports.FindLegacyContextAPI = FindLegacyContextAPI;
|
|
163
|
+
//# sourceMappingURL=find-legacy-context-api.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"find-legacy-context-api.js","sourceRoot":"","sources":["../../src/react19/find-legacy-context-api.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { ExecutionContext, Recipe, TreeVisitor } from "@openrewrite/rewrite";
|
|
2
|
+
export declare class NoImplicitRefCallbackReturn extends Recipe {
|
|
3
|
+
readonly name = "org.openrewrite.react.19.no-implicit-ref-callback-return";
|
|
4
|
+
readonly displayName: string;
|
|
5
|
+
readonly description: string;
|
|
6
|
+
editor(): Promise<TreeVisitor<any, ExecutionContext>>;
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=no-implicit-ref-callback-return.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"no-implicit-ref-callback-return.d.ts","sourceRoot":"","sources":["../../src/react19/no-implicit-ref-callback-return.ts"],"names":[],"mappings":"AAAA,OAAO,EAAe,gBAAgB,EAAqB,MAAM,EAAE,WAAW,EAAC,MAAM,sBAAsB,CAAC;AA2B5G,qBAAa,2BAA4B,SAAQ,MAAM;IACnD,QAAQ,CAAC,IAAI,8DAA8D;IAC3E,QAAQ,CAAC,WAAW,EAAE,MAAM,CAA0C;IACtE,QAAQ,CAAC,WAAW,EAAE,MAAM,CAAyN;IAE/O,MAAM,IAAI,OAAO,CAAC,WAAW,CAAC,GAAG,EAAE,gBAAgB,CAAC,CAAC;CA0F9D"}
|
|
@@ -0,0 +1,107 @@
|
|
|
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.NoImplicitRefCallbackReturn = 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
|
+
const emptySpace = { kind: 'org.openrewrite.java.tree.Space', whitespace: '', comments: [] };
|
|
18
|
+
const singleSpace = { kind: 'org.openrewrite.java.tree.Space', whitespace: ' ', comments: [] };
|
|
19
|
+
class NoImplicitRefCallbackReturn extends rewrite_1.Recipe {
|
|
20
|
+
constructor() {
|
|
21
|
+
super(...arguments);
|
|
22
|
+
this.name = "org.openrewrite.react.19.no-implicit-ref-callback-return";
|
|
23
|
+
this.displayName = "Remove implicit ref callback returns";
|
|
24
|
+
this.description = "In React 19, ref callbacks can return cleanup functions. Arrow functions with expression bodies implicitly return values, which React would interpret as cleanup functions. This recipe wraps them in block bodies.";
|
|
25
|
+
}
|
|
26
|
+
editor() {
|
|
27
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
28
|
+
return new class extends javascript_1.JavaScriptVisitor {
|
|
29
|
+
visitJsxAttribute(attribute, ctx) {
|
|
30
|
+
const _super = Object.create(null, {
|
|
31
|
+
visitJsxAttribute: { get: () => super.visitJsxAttribute }
|
|
32
|
+
});
|
|
33
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
34
|
+
var _a;
|
|
35
|
+
let attr = yield _super.visitJsxAttribute.call(this, attribute, ctx);
|
|
36
|
+
if (attr.key.kind !== java_1.J.Kind.Identifier) {
|
|
37
|
+
return attr;
|
|
38
|
+
}
|
|
39
|
+
if (attr.key.simpleName !== 'ref') {
|
|
40
|
+
return attr;
|
|
41
|
+
}
|
|
42
|
+
if (!attr.value) {
|
|
43
|
+
return attr;
|
|
44
|
+
}
|
|
45
|
+
const valueExpr = attr.value.element;
|
|
46
|
+
if (valueExpr.kind !== javascript_1.JS.Kind.JsxEmbeddedExpression) {
|
|
47
|
+
return attr;
|
|
48
|
+
}
|
|
49
|
+
const embedded = valueExpr;
|
|
50
|
+
const innerExpr = (_a = embedded.expression.element) !== null && _a !== void 0 ? _a : embedded.expression;
|
|
51
|
+
if (innerExpr.kind !== javascript_1.JS.Kind.ArrowFunction) {
|
|
52
|
+
return attr;
|
|
53
|
+
}
|
|
54
|
+
const arrowFn = innerExpr;
|
|
55
|
+
const lambda = arrowFn.lambda;
|
|
56
|
+
if (!lambda.body || lambda.body.kind === java_1.J.Kind.Block) {
|
|
57
|
+
return attr;
|
|
58
|
+
}
|
|
59
|
+
let stmtExpr = lambda.body;
|
|
60
|
+
if (stmtExpr.kind === java_1.J.Kind.Parentheses) {
|
|
61
|
+
stmtExpr = stmtExpr.tree.element;
|
|
62
|
+
}
|
|
63
|
+
stmtExpr = Object.assign(Object.assign({}, stmtExpr), { prefix: emptySpace });
|
|
64
|
+
const semicolonMarkers = (0, rewrite_1.markers)({
|
|
65
|
+
kind: java_1.J.Markers.Semicolon,
|
|
66
|
+
id: (0, rewrite_1.randomId)()
|
|
67
|
+
});
|
|
68
|
+
const exprStatement = {
|
|
69
|
+
kind: javascript_1.JS.Kind.ExpressionStatement,
|
|
70
|
+
id: (0, rewrite_1.randomId)(),
|
|
71
|
+
prefix: singleSpace,
|
|
72
|
+
markers: rewrite_1.emptyMarkers,
|
|
73
|
+
expression: stmtExpr
|
|
74
|
+
};
|
|
75
|
+
const block = {
|
|
76
|
+
kind: java_1.J.Kind.Block,
|
|
77
|
+
id: (0, rewrite_1.randomId)(),
|
|
78
|
+
prefix: lambda.body.prefix,
|
|
79
|
+
markers: rewrite_1.emptyMarkers,
|
|
80
|
+
static: {
|
|
81
|
+
kind: java_1.J.Kind.RightPadded,
|
|
82
|
+
element: false,
|
|
83
|
+
after: emptySpace,
|
|
84
|
+
markers: rewrite_1.emptyMarkers
|
|
85
|
+
},
|
|
86
|
+
statements: [{
|
|
87
|
+
kind: java_1.J.Kind.RightPadded,
|
|
88
|
+
element: exprStatement,
|
|
89
|
+
after: emptySpace,
|
|
90
|
+
markers: semicolonMarkers
|
|
91
|
+
}],
|
|
92
|
+
end: singleSpace
|
|
93
|
+
};
|
|
94
|
+
return (0, mutative_1.create)(attr, draft => {
|
|
95
|
+
var _a;
|
|
96
|
+
const embeddedDraft = draft.value.element;
|
|
97
|
+
const innerDraft = (_a = embeddedDraft.expression.element) !== null && _a !== void 0 ? _a : embeddedDraft.expression;
|
|
98
|
+
innerDraft.lambda.body = block;
|
|
99
|
+
});
|
|
100
|
+
});
|
|
101
|
+
}
|
|
102
|
+
}();
|
|
103
|
+
});
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
exports.NoImplicitRefCallbackReturn = NoImplicitRefCallbackReturn;
|
|
107
|
+
//# sourceMappingURL=no-implicit-ref-callback-return.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"no-implicit-ref-callback-return.js","sourceRoot":"","sources":["../../src/react19/no-implicit-ref-callback-return.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { ExecutionContext, Recipe, TreeVisitor } from "@openrewrite/rewrite";
|
|
2
|
+
export declare class RemoveContextProvider extends Recipe {
|
|
3
|
+
readonly name = "org.openrewrite.react.19.remove-context-provider";
|
|
4
|
+
readonly displayName: string;
|
|
5
|
+
readonly description: string;
|
|
6
|
+
editor(): Promise<TreeVisitor<any, ExecutionContext>>;
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=remove-context-provider.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"remove-context-provider.d.ts","sourceRoot":"","sources":["../../src/react19/remove-context-provider.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,gBAAgB,EAAE,MAAM,EAAE,WAAW,EAAC,MAAM,sBAAsB,CAAC;AA2B3E,qBAAa,qBAAsB,SAAQ,MAAM;IAC7C,QAAQ,CAAC,IAAI,sDAAsD;IACnE,QAAQ,CAAC,WAAW,EAAE,MAAM,CAAuC;IACnE,QAAQ,CAAC,WAAW,EAAE,MAAM,CAAyG;IAE/H,MAAM,IAAI,OAAO,CAAC,WAAW,CAAC,GAAG,EAAE,gBAAgB,CAAC,CAAC;CAsD9D"}
|
|
@@ -0,0 +1,59 @@
|
|
|
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.RemoveContextProvider = 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 RemoveContextProvider extends rewrite_1.Recipe {
|
|
17
|
+
constructor() {
|
|
18
|
+
super(...arguments);
|
|
19
|
+
this.name = "org.openrewrite.react.19.remove-context-provider";
|
|
20
|
+
this.displayName = "Remove `Context.Provider` wrapper";
|
|
21
|
+
this.description = "In React 19, `<Context.Provider>` is deprecated. Render `<Context>` directly as a provider instead.";
|
|
22
|
+
}
|
|
23
|
+
editor() {
|
|
24
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
25
|
+
return new class extends javascript_1.JavaScriptVisitor {
|
|
26
|
+
visitJsxTag(tag, ctx) {
|
|
27
|
+
const _super = Object.create(null, {
|
|
28
|
+
visitJsxTag: { get: () => super.visitJsxTag }
|
|
29
|
+
});
|
|
30
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
31
|
+
let t = yield _super.visitJsxTag.call(this, tag, ctx);
|
|
32
|
+
const openName = t.openName.element;
|
|
33
|
+
if (openName.kind !== java_1.J.Kind.FieldAccess) {
|
|
34
|
+
return t;
|
|
35
|
+
}
|
|
36
|
+
const fieldAccess = openName;
|
|
37
|
+
const propertyName = fieldAccess.name.element.simpleName;
|
|
38
|
+
if (propertyName !== 'Provider') {
|
|
39
|
+
return t;
|
|
40
|
+
}
|
|
41
|
+
const target = fieldAccess.target;
|
|
42
|
+
const newName = Object.assign(Object.assign({}, target), { prefix: openName.prefix });
|
|
43
|
+
const result = Object.assign(Object.assign({}, t), { openName: Object.assign(Object.assign({}, t.openName), { element: newName }) });
|
|
44
|
+
if (t.closingName) {
|
|
45
|
+
const closingElement = t.closingName.element;
|
|
46
|
+
if (closingElement.kind === java_1.J.Kind.FieldAccess) {
|
|
47
|
+
const closingTarget = closingElement.target;
|
|
48
|
+
result.closingName = Object.assign(Object.assign({}, t.closingName), { element: Object.assign(Object.assign({}, closingTarget), { prefix: closingElement.prefix }) });
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
return result;
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
}();
|
|
55
|
+
});
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
exports.RemoveContextProvider = RemoveContextProvider;
|
|
59
|
+
//# sourceMappingURL=remove-context-provider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"remove-context-provider.js","sourceRoot":"","sources":["../../src/react19/remove-context-provider.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,kDAA2E;AAC3E,gEAAkE;AAClE,oDAA4C;AAyB5C,MAAa,qBAAsB,SAAQ,gBAAM;IAAjD;;QACa,SAAI,GAAG,kDAAkD,CAAC;QAC1D,gBAAW,GAAW,mCAAmC,CAAC;QAC1D,gBAAW,GAAW,qGAAqG,CAAC;IAwDzI,CAAC;IAtDS,MAAM;;YACR,OAAO,IAAI,KAAM,SAAQ,8BAAmC;gBACzC,WAAW,CAAC,GAAY,EAAE,GAAqB;;;;;wBAC1D,IAAI,CAAC,GAAG,MAAM,OAAM,WAAW,YAAC,GAAG,EAAE,GAAG,CAAY,CAAC;wBAErD,MAAM,QAAQ,GAAG,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC;wBAGpC,IAAI,QAAQ,CAAC,IAAI,KAAK,QAAC,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;4BACvC,OAAO,CAAC,CAAC;wBACb,CAAC;wBAED,MAAM,WAAW,GAAG,QAAyB,CAAC;wBAC9C,MAAM,YAAY,GAAG,WAAW,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC;wBAEzD,IAAI,YAAY,KAAK,UAAU,EAAE,CAAC;4BAC9B,OAAO,CAAC,CAAC;wBACb,CAAC;wBAGD,MAAM,MAAM,GAAG,WAAW,CAAC,MAAsB,CAAC;wBAClD,MAAM,OAAO,mCACN,MAAM,KACT,MAAM,EAAE,QAAQ,CAAC,MAAM,GAC1B,CAAC;wBAGF,MAAM,MAAM,GAAG,gCACR,CAAC,KACJ,QAAQ,kCACD,CAAC,CAAC,QAAQ,KACb,OAAO,EAAE,OAAO,MAEhB,CAAC;wBAGT,IAAI,CAAC,CAAC,WAAW,EAAE,CAAC;4BAChB,MAAM,cAAc,GAAG,CAAC,CAAC,WAAW,CAAC,OAAO,CAAC;4BAC7C,IAAI,cAAc,CAAC,IAAI,KAAK,QAAC,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;gCAC7C,MAAM,aAAa,GAAI,cAAgC,CAAC,MAAsB,CAAC;gCAC/E,MAAM,CAAC,WAAW,mCACX,CAAC,CAAC,WAAW,KAChB,OAAO,kCACA,aAAa,KAChB,MAAM,EAAE,cAAc,CAAC,MAAM,MAEpC,CAAC;4BACN,CAAC;wBACL,CAAC;wBAED,OAAO,MAAiB,CAAC;oBAC7B,CAAC;iBAAA;aACJ,EAAE,CAAC;QACR,CAAC;KAAA;CACJ;AA3DD,sDA2DC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { ExecutionContext, Recipe, TreeVisitor } from "@openrewrite/rewrite";
|
|
2
|
+
export declare class RemoveForwardRef extends Recipe {
|
|
3
|
+
readonly name = "org.openrewrite.react.19.remove-forward-ref";
|
|
4
|
+
readonly displayName: string;
|
|
5
|
+
readonly description: string;
|
|
6
|
+
editor(): Promise<TreeVisitor<any, ExecutionContext>>;
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=remove-forward-ref.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"remove-forward-ref.d.ts","sourceRoot":"","sources":["../../src/react19/remove-forward-ref.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,gBAAgB,EAAE,MAAM,EAAE,WAAW,EAAC,MAAM,sBAAsB,CAAC;AAa3E,qBAAa,gBAAiB,SAAQ,MAAM;IACxC,QAAQ,CAAC,IAAI,iDAAiD;IAC9D,QAAQ,CAAC,WAAW,EAAE,MAAM,CAAuC;IACnE,QAAQ,CAAC,WAAW,EAAE,MAAM,CAA4J;IAElL,MAAM,IAAI,OAAO,CAAC,WAAW,CAAC,GAAG,EAAE,gBAAgB,CAAC,CAAC;CAkD9D"}
|
|
@@ -0,0 +1,73 @@
|
|
|
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.RemoveForwardRef = void 0;
|
|
13
|
+
const rewrite_1 = require("@openrewrite/rewrite");
|
|
14
|
+
const javascript_1 = require("@openrewrite/rewrite/javascript");
|
|
15
|
+
const simplify_object_pattern_property_1 = require("../simplify-object-pattern-property");
|
|
16
|
+
class RemoveForwardRef extends rewrite_1.Recipe {
|
|
17
|
+
constructor() {
|
|
18
|
+
super(...arguments);
|
|
19
|
+
this.name = "org.openrewrite.react.19.remove-forward-ref";
|
|
20
|
+
this.displayName = "Remove `React.forwardRef` wrapper";
|
|
21
|
+
this.description = "`React.forwardRef` is deprecated for Function Components in React 19. This recipe removes the `forwardRef` wrapper and converts ref to a regular prop.";
|
|
22
|
+
}
|
|
23
|
+
editor() {
|
|
24
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
25
|
+
const reactOptions = {
|
|
26
|
+
context: ['import { forwardRef } from "react";'],
|
|
27
|
+
dependencies: { '@types/react': '^19.0.0' }
|
|
28
|
+
};
|
|
29
|
+
const { props, ref, body, name, refType, propsType } = {
|
|
30
|
+
props: (0, javascript_1.capture)({ variadic: true }),
|
|
31
|
+
ref: (0, javascript_1.capture)(),
|
|
32
|
+
body: (0, javascript_1.capture)({ variadic: true }),
|
|
33
|
+
name: (0, javascript_1.capture)(),
|
|
34
|
+
refType: (0, javascript_1.capture)(),
|
|
35
|
+
propsType: (0, javascript_1.capture)()
|
|
36
|
+
};
|
|
37
|
+
const rule = (0, javascript_1.rewrite)(() => ({
|
|
38
|
+
before: (0, javascript_1.pattern) `forwardRef<${refType}, ${propsType}>((${props}, ${ref}) => ${body})`.configure(reactOptions),
|
|
39
|
+
after: (0, javascript_1.template) `({ ref: ${ref}, ...${props} }: ${propsType} & { ref?: React.Ref<${refType}> }) => ${body}`
|
|
40
|
+
})).orElse((0, javascript_1.rewrite)(() => ({
|
|
41
|
+
before: (0, javascript_1.pattern) `forwardRef((${props}, ${ref}) => ${body})`.configure(reactOptions),
|
|
42
|
+
after: (0, javascript_1.template) `({ ref: ${ref}, ...${props} }) => ${body}`
|
|
43
|
+
}))).orElse((0, javascript_1.rewrite)(() => ({
|
|
44
|
+
before: (0, javascript_1.pattern) `forwardRef(function ${name}({${props}}, ${ref}) {${body}})`.configure(reactOptions),
|
|
45
|
+
after: (0, javascript_1.template) `function ${name}({ ref: ${ref}, ${props} }) {${body}}`
|
|
46
|
+
}))).orElse((0, javascript_1.rewrite)(() => ({
|
|
47
|
+
before: (0, javascript_1.pattern) `forwardRef(function ${name}(${props}, ${ref}) {${body}})`.configure(reactOptions),
|
|
48
|
+
after: (0, javascript_1.template) `function ${name}({ ref: ${ref}, ...${props} }) {${body}}`
|
|
49
|
+
})));
|
|
50
|
+
return new class extends javascript_1.JavaScriptVisitor {
|
|
51
|
+
visitMethodInvocation(method, p) {
|
|
52
|
+
const _super = Object.create(null, {
|
|
53
|
+
visitMethodInvocation: { get: () => super.visitMethodInvocation }
|
|
54
|
+
});
|
|
55
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
56
|
+
let m = yield _super.visitMethodInvocation.call(this, method, p);
|
|
57
|
+
let result = yield rule
|
|
58
|
+
.andThen((0, javascript_1.fromRecipe)(new simplify_object_pattern_property_1.SimplifyObjectPatternProperty(), p))
|
|
59
|
+
.tryOn(this.cursor, m);
|
|
60
|
+
if (result) {
|
|
61
|
+
(0, javascript_1.maybeRemoveImport)(this, "react", "default");
|
|
62
|
+
(0, javascript_1.maybeRemoveImport)(this, "react", "forwardRef");
|
|
63
|
+
return result;
|
|
64
|
+
}
|
|
65
|
+
return m;
|
|
66
|
+
});
|
|
67
|
+
}
|
|
68
|
+
}();
|
|
69
|
+
});
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
exports.RemoveForwardRef = RemoveForwardRef;
|
|
73
|
+
//# sourceMappingURL=remove-forward-ref.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"remove-forward-ref.js","sourceRoot":"","sources":["../../src/react19/remove-forward-ref.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { ExecutionContext, Recipe, TreeVisitor } from "@openrewrite/rewrite";
|
|
2
|
+
export declare class RemovePropTypes extends Recipe {
|
|
3
|
+
readonly name = "org.openrewrite.react.19.remove-prop-types";
|
|
4
|
+
readonly displayName: string;
|
|
5
|
+
readonly description: string;
|
|
6
|
+
editor(): Promise<TreeVisitor<any, ExecutionContext>>;
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=remove-prop-types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"remove-prop-types.d.ts","sourceRoot":"","sources":["../../src/react19/remove-prop-types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,gBAAgB,EAAE,MAAM,EAAE,WAAW,EAAC,MAAM,sBAAsB,CAAC;AAgC3E,qBAAa,eAAgB,SAAQ,MAAM;IACvC,QAAQ,CAAC,IAAI,gDAAgD;IAC7D,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;CAgD9D"}
|
|
@@ -0,0 +1,76 @@
|
|
|
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.RemovePropTypes = 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 RemovePropTypes extends rewrite_1.Recipe {
|
|
18
|
+
constructor() {
|
|
19
|
+
super(...arguments);
|
|
20
|
+
this.name = "org.openrewrite.react.19.remove-prop-types";
|
|
21
|
+
this.displayName = "Remove `propTypes` assignments";
|
|
22
|
+
this.description = "Removes `Component.propTypes = {...}` assignments. PropTypes are silently ignored in React 19.";
|
|
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
|
+
let assignment;
|
|
39
|
+
if (s.kind === javascript_1.JS.Kind.ExpressionStatement) {
|
|
40
|
+
const exprStmt = s;
|
|
41
|
+
const expr = exprStmt.expression;
|
|
42
|
+
if (expr.kind === java_1.J.Kind.Assignment) {
|
|
43
|
+
assignment = expr;
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
else if (s.kind === java_1.J.Kind.Assignment) {
|
|
47
|
+
assignment = s;
|
|
48
|
+
}
|
|
49
|
+
if (!assignment)
|
|
50
|
+
continue;
|
|
51
|
+
if (assignment.variable.kind !== java_1.J.Kind.FieldAccess)
|
|
52
|
+
continue;
|
|
53
|
+
const fa = assignment.variable;
|
|
54
|
+
if (fa.name.element.simpleName !== 'propTypes')
|
|
55
|
+
continue;
|
|
56
|
+
if (!(0, java_1.isIdentifier)(fa.target))
|
|
57
|
+
continue;
|
|
58
|
+
statementsToRemove.add(s.id);
|
|
59
|
+
}
|
|
60
|
+
if (statementsToRemove.size === 0)
|
|
61
|
+
return result;
|
|
62
|
+
const filteredStatements = result.statements.filter(stmt => {
|
|
63
|
+
const s = stmt.element;
|
|
64
|
+
return !s || !statementsToRemove.has(s.id);
|
|
65
|
+
});
|
|
66
|
+
return (0, mutative_1.create)(result, draft => {
|
|
67
|
+
draft.statements = filteredStatements;
|
|
68
|
+
});
|
|
69
|
+
});
|
|
70
|
+
}
|
|
71
|
+
}();
|
|
72
|
+
});
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
exports.RemovePropTypes = RemovePropTypes;
|
|
76
|
+
//# sourceMappingURL=remove-prop-types.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"remove-prop-types.js","sourceRoot":"","sources":["../../src/react19/remove-prop-types.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,kDAA2E;AAC3E,gEAAsE;AACtE,oDAA0D;AAC1D,uCAAgC;AA6BhC,MAAa,eAAgB,SAAQ,gBAAM;IAA3C;;QACa,SAAI,GAAG,4CAA4C,CAAC;QACpD,gBAAW,GAAW,gCAAgC,CAAC;QACvD,gBAAW,GAAW,gGAAgG,CAAC;IAkDpI,CAAC;IAhDS,MAAM;;YACR,OAAO,IAAI,KAAM,SAAQ,8BAAmC;gBACzC,sBAAsB,CAAC,EAAsB,EAAE,GAAqB;;;;;wBAC/E,IAAI,MAAM,GAAG,MAAM,OAAM,sBAAsB,YAAC,EAAE,EAAE,GAAG,CAAuB,CAAC;wBAG/E,MAAM,kBAAkB,GAAG,IAAI,GAAG,EAAU,CAAC;wBAE7C,KAAK,MAAM,IAAI,IAAI,MAAM,CAAC,UAAU,EAAE,CAAC;4BACnC,MAAM,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC;4BACvB,IAAI,CAAC,CAAC;gCAAE,SAAS;4BAEjB,IAAI,UAAoC,CAAC;4BAEzC,IAAI,CAAC,CAAC,IAAI,KAAK,eAAE,CAAC,IAAI,CAAC,mBAAmB,EAAE,CAAC;gCACzC,MAAM,QAAQ,GAAG,CAA2B,CAAC;gCAC7C,MAAM,IAAI,GAAG,QAAQ,CAAC,UAAU,CAAC;gCACjC,IAAI,IAAI,CAAC,IAAI,KAAK,QAAC,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC;oCAClC,UAAU,GAAG,IAAoB,CAAC;gCACtC,CAAC;4BACL,CAAC;iCAAM,IAAI,CAAC,CAAC,IAAI,KAAK,QAAC,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC;gCACtC,UAAU,GAAG,CAAiB,CAAC;4BACnC,CAAC;4BAED,IAAI,CAAC,UAAU;gCAAE,SAAS;4BAG1B,IAAI,UAAU,CAAC,QAAQ,CAAC,IAAI,KAAK,QAAC,CAAC,IAAI,CAAC,WAAW;gCAAE,SAAS;4BAC9D,MAAM,EAAE,GAAG,UAAU,CAAC,QAAyB,CAAC;4BAChD,IAAI,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,KAAK,WAAW;gCAAE,SAAS;4BACzD,IAAI,CAAC,IAAA,mBAAY,EAAC,EAAE,CAAC,MAAM,CAAC;gCAAE,SAAS;4BAEvC,kBAAkB,CAAC,GAAG,CAAE,CAAS,CAAC,EAAE,CAAC,CAAC;wBAC1C,CAAC;wBAED,IAAI,kBAAkB,CAAC,IAAI,KAAK,CAAC;4BAAE,OAAO,MAAM,CAAC;wBAEjD,MAAM,kBAAkB,GAAG,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE;4BACvD,MAAM,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC;4BACvB,OAAO,CAAC,CAAC,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAE,CAAS,CAAC,EAAE,CAAC,CAAC;wBACxD,CAAC,CAAC,CAAC;wBAEH,OAAO,IAAA,iBAAM,EAAC,MAAM,EAAE,KAAK,CAAC,EAAE;4BAC1B,KAAK,CAAC,UAAU,GAAG,kBAAyB,CAAC;wBACjD,CAAC,CAAC,CAAC;oBACP,CAAC;iBAAA;aACJ,EAAE,CAAC;QACR,CAAC;KAAA;CACJ;AArDD,0CAqDC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { ExecutionContext, Recipe, TreeVisitor } from "@openrewrite/rewrite";
|
|
2
|
+
export declare class RemoveReactFC extends Recipe {
|
|
3
|
+
readonly name = "org.openrewrite.react.19.remove-react-fc";
|
|
4
|
+
readonly displayName: string;
|
|
5
|
+
readonly description: string;
|
|
6
|
+
editor(): Promise<TreeVisitor<any, ExecutionContext>>;
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=remove-react-fc.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"remove-react-fc.d.ts","sourceRoot":"","sources":["../../src/react19/remove-react-fc.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,gBAAgB,EAAE,MAAM,EAAE,WAAW,EAAC,MAAM,sBAAsB,CAAC;AA0B3E,qBAAa,aAAc,SAAQ,MAAM;IACrC,QAAQ,CAAC,IAAI,8CAA8C;IAC3D,QAAQ,CAAC,WAAW,EAAE,MAAM,CAAuC;IACnE,QAAQ,CAAC,WAAW,EAAE,MAAM,CAAuI;IAE7J,MAAM,IAAI,OAAO,CAAC,WAAW,CAAC,GAAG,EAAE,gBAAgB,CAAC,CAAC;CAuN9D"}
|