@base44-preview/vite-plugin 0.2.26-pr.43.e9195be → 0.2.27-pr.41.77be9cb

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.
Files changed (168) hide show
  1. package/dist/capabilities/inline-edit/controller.d.ts +3 -0
  2. package/dist/capabilities/inline-edit/controller.d.ts.map +1 -0
  3. package/dist/capabilities/inline-edit/controller.js +194 -0
  4. package/dist/capabilities/inline-edit/controller.js.map +1 -0
  5. package/dist/capabilities/inline-edit/dom-utils.d.ts +6 -0
  6. package/dist/capabilities/inline-edit/dom-utils.d.ts.map +1 -0
  7. package/dist/capabilities/inline-edit/dom-utils.js +49 -0
  8. package/dist/capabilities/inline-edit/dom-utils.js.map +1 -0
  9. package/dist/capabilities/inline-edit/index.d.ts +3 -0
  10. package/dist/capabilities/inline-edit/index.d.ts.map +1 -0
  11. package/dist/capabilities/inline-edit/index.js +2 -0
  12. package/dist/capabilities/inline-edit/index.js.map +1 -0
  13. package/dist/capabilities/inline-edit/types.d.ts +25 -0
  14. package/dist/capabilities/inline-edit/types.d.ts.map +1 -0
  15. package/dist/capabilities/inline-edit/types.js.map +1 -0
  16. package/dist/injections/visual-edit-agent/capabilities/inline-editing/core.d.ts +25 -0
  17. package/dist/injections/visual-edit-agent/capabilities/inline-editing/core.d.ts.map +1 -0
  18. package/dist/injections/visual-edit-agent/capabilities/inline-editing/core.js +95 -0
  19. package/dist/injections/visual-edit-agent/capabilities/inline-editing/core.js.map +1 -0
  20. package/dist/injections/visual-edit-agent/capabilities/inline-editing/index.d.ts +4 -0
  21. package/dist/injections/visual-edit-agent/capabilities/inline-editing/index.d.ts.map +1 -0
  22. package/dist/injections/visual-edit-agent/capabilities/inline-editing/index.js +4 -0
  23. package/dist/injections/visual-edit-agent/capabilities/inline-editing/index.js.map +1 -0
  24. package/dist/injections/visual-edit-agent/capabilities/inline-editing/styles.d.ts +9 -0
  25. package/dist/injections/visual-edit-agent/capabilities/inline-editing/styles.d.ts.map +1 -0
  26. package/dist/injections/visual-edit-agent/capabilities/inline-editing/styles.js +26 -0
  27. package/dist/injections/visual-edit-agent/capabilities/inline-editing/styles.js.map +1 -0
  28. package/dist/injections/visual-edit-agent/capabilities/inline-editing/validation.d.ts +17 -0
  29. package/dist/injections/visual-edit-agent/capabilities/inline-editing/validation.d.ts.map +1 -0
  30. package/dist/injections/visual-edit-agent/capabilities/inline-editing/validation.js +76 -0
  31. package/dist/injections/visual-edit-agent/capabilities/inline-editing/validation.js.map +1 -0
  32. package/dist/injections/visual-edit-agent/constants.d.ts +10 -0
  33. package/dist/injections/visual-edit-agent/constants.d.ts.map +1 -0
  34. package/dist/injections/visual-edit-agent/constants.js +10 -0
  35. package/dist/injections/visual-edit-agent/constants.js.map +1 -0
  36. package/dist/injections/visual-edit-agent/handlers/click-handlers.d.ts +10 -0
  37. package/dist/injections/visual-edit-agent/handlers/click-handlers.d.ts.map +1 -0
  38. package/dist/injections/visual-edit-agent/handlers/click-handlers.js +117 -0
  39. package/dist/injections/visual-edit-agent/handlers/click-handlers.js.map +1 -0
  40. package/dist/injections/visual-edit-agent/handlers/hover-handlers.d.ts +14 -0
  41. package/dist/injections/visual-edit-agent/handlers/hover-handlers.d.ts.map +1 -0
  42. package/dist/injections/visual-edit-agent/handlers/hover-handlers.js +64 -0
  43. package/dist/injections/visual-edit-agent/handlers/hover-handlers.js.map +1 -0
  44. package/dist/injections/visual-edit-agent/handlers/inline-edit-handlers.d.ts +14 -0
  45. package/dist/injections/visual-edit-agent/handlers/inline-edit-handlers.d.ts.map +1 -0
  46. package/dist/injections/visual-edit-agent/handlers/inline-edit-handlers.js +114 -0
  47. package/dist/injections/visual-edit-agent/handlers/inline-edit-handlers.js.map +1 -0
  48. package/dist/injections/visual-edit-agent/handlers/message-handlers.d.ts +26 -0
  49. package/dist/injections/visual-edit-agent/handlers/message-handlers.d.ts.map +1 -0
  50. package/dist/injections/visual-edit-agent/handlers/message-handlers.js +148 -0
  51. package/dist/injections/visual-edit-agent/handlers/message-handlers.js.map +1 -0
  52. package/dist/injections/visual-edit-agent/handlers/messages/toggle-inline-edit-mode.d.ts +7 -0
  53. package/dist/injections/visual-edit-agent/handlers/messages/toggle-inline-edit-mode.d.ts.map +1 -0
  54. package/dist/injections/visual-edit-agent/handlers/messages/toggle-inline-edit-mode.js +54 -0
  55. package/dist/injections/visual-edit-agent/handlers/messages/toggle-inline-edit-mode.js.map +1 -0
  56. package/dist/injections/visual-edit-agent/handlers/messages/toggle-visual-edit-mode.d.ts +11 -0
  57. package/dist/injections/visual-edit-agent/handlers/messages/toggle-visual-edit-mode.d.ts.map +1 -0
  58. package/dist/injections/visual-edit-agent/handlers/messages/toggle-visual-edit-mode.js +32 -0
  59. package/dist/injections/visual-edit-agent/handlers/messages/toggle-visual-edit-mode.js.map +1 -0
  60. package/dist/injections/visual-edit-agent/handlers/messages/types.d.ts +105 -0
  61. package/dist/injections/visual-edit-agent/handlers/messages/types.d.ts.map +1 -0
  62. package/dist/injections/visual-edit-agent/handlers/messages/types.js +28 -0
  63. package/dist/injections/visual-edit-agent/handlers/messages/types.js.map +1 -0
  64. package/dist/injections/visual-edit-agent/index.d.ts +6 -0
  65. package/dist/injections/visual-edit-agent/index.d.ts.map +1 -0
  66. package/dist/injections/visual-edit-agent/index.js +109 -0
  67. package/dist/injections/visual-edit-agent/index.js.map +1 -0
  68. package/dist/injections/visual-edit-agent/state/agent-state.d.ts +17 -0
  69. package/dist/injections/visual-edit-agent/state/agent-state.d.ts.map +1 -0
  70. package/dist/injections/visual-edit-agent/state/agent-state.js +18 -0
  71. package/dist/injections/visual-edit-agent/state/agent-state.js.map +1 -0
  72. package/dist/injections/visual-edit-agent/ui/overlay.d.ts +26 -0
  73. package/dist/injections/visual-edit-agent/ui/overlay.d.ts.map +1 -0
  74. package/dist/injections/visual-edit-agent/ui/overlay.js +104 -0
  75. package/dist/injections/visual-edit-agent/ui/overlay.js.map +1 -0
  76. package/dist/injections/visual-edit-agent/utils/dom-utils.d.ts +14 -0
  77. package/dist/injections/visual-edit-agent/utils/dom-utils.d.ts.map +1 -0
  78. package/dist/injections/visual-edit-agent/utils/dom-utils.js +34 -0
  79. package/dist/injections/visual-edit-agent/utils/dom-utils.js.map +1 -0
  80. package/dist/injections/visual-edit-agent.d.ts +1 -1
  81. package/dist/injections/visual-edit-agent.d.ts.map +1 -1
  82. package/dist/injections/visual-edit-agent.js +1 -506
  83. package/dist/injections/visual-edit-agent.js.map +1 -1
  84. package/dist/jsx-processor.d.ts +1 -4
  85. package/dist/jsx-processor.d.ts.map +1 -1
  86. package/dist/jsx-processor.js +6 -33
  87. package/dist/jsx-processor.js.map +1 -1
  88. package/dist/jsx-utils.d.ts +0 -9
  89. package/dist/jsx-utils.d.ts.map +1 -1
  90. package/dist/jsx-utils.js +0 -86
  91. package/dist/jsx-utils.js.map +1 -1
  92. package/dist/processors/shared-utils.d.ts +0 -64
  93. package/dist/processors/shared-utils.d.ts.map +1 -1
  94. package/dist/processors/shared-utils.js +0 -468
  95. package/dist/processors/shared-utils.js.map +1 -1
  96. package/dist/processors/static-array-processor.d.ts +3 -2
  97. package/dist/processors/static-array-processor.d.ts.map +1 -1
  98. package/dist/processors/static-array-processor.js +3 -2
  99. package/dist/processors/static-array-processor.js.map +1 -1
  100. package/dist/statics/index.mjs +5 -1
  101. package/dist/statics/index.mjs.map +1 -1
  102. package/dist/visual-edit-plugin.d.ts +1 -0
  103. package/dist/visual-edit-plugin.d.ts.map +1 -1
  104. package/dist/visual-edit-plugin.js +178 -29
  105. package/dist/visual-edit-plugin.js.map +1 -1
  106. package/package.json +1 -1
  107. package/src/capabilities/inline-edit/controller.ts +245 -0
  108. package/src/capabilities/inline-edit/dom-utils.ts +48 -0
  109. package/src/capabilities/inline-edit/index.ts +2 -0
  110. package/src/capabilities/inline-edit/types.ts +30 -0
  111. package/src/injections/visual-edit-agent/README.md +222 -0
  112. package/src/injections/visual-edit-agent/capabilities/inline-editing/core.ts +120 -0
  113. package/src/injections/visual-edit-agent/capabilities/inline-editing/index.ts +10 -0
  114. package/src/injections/visual-edit-agent/capabilities/inline-editing/styles.ts +26 -0
  115. package/src/injections/visual-edit-agent/capabilities/inline-editing/validation.ts +87 -0
  116. package/src/injections/visual-edit-agent/constants.ts +9 -0
  117. package/src/injections/visual-edit-agent/handlers/click-handlers.ts +146 -0
  118. package/src/injections/visual-edit-agent/handlers/hover-handlers.ts +78 -0
  119. package/src/injections/visual-edit-agent/handlers/inline-edit-handlers.ts +146 -0
  120. package/src/injections/visual-edit-agent/handlers/message-handlers.ts +201 -0
  121. package/src/injections/visual-edit-agent/handlers/messages/toggle-inline-edit-mode.ts +65 -0
  122. package/src/injections/visual-edit-agent/handlers/messages/toggle-visual-edit-mode.ts +40 -0
  123. package/src/injections/visual-edit-agent/handlers/messages/types.ts +134 -0
  124. package/src/injections/visual-edit-agent/index.ts +121 -0
  125. package/src/injections/visual-edit-agent/state/agent-state.ts +31 -0
  126. package/src/injections/visual-edit-agent/ui/overlay.ts +126 -0
  127. package/src/injections/visual-edit-agent/utils/dom-utils.ts +39 -0
  128. package/src/injections/visual-edit-agent.ts +1 -625
  129. package/src/jsx-processor.ts +14 -41
  130. package/src/jsx-utils.ts +0 -116
  131. package/src/processors/shared-utils.ts +0 -596
  132. package/src/processors/static-array-processor.ts +3 -6
  133. package/src/visual-edit-plugin.ts +215 -34
  134. package/dist/consts.d.ts +0 -12
  135. package/dist/consts.d.ts.map +0 -1
  136. package/dist/consts.js +0 -12
  137. package/dist/consts.js.map +0 -1
  138. package/dist/processors/collection-id-processor.d.ts +0 -20
  139. package/dist/processors/collection-id-processor.d.ts.map +0 -1
  140. package/dist/processors/collection-id-processor.js +0 -182
  141. package/dist/processors/collection-id-processor.js.map +0 -1
  142. package/dist/processors/collection-item-field-processor.d.ts +0 -33
  143. package/dist/processors/collection-item-field-processor.d.ts.map +0 -1
  144. package/dist/processors/collection-item-field-processor.js +0 -275
  145. package/dist/processors/collection-item-field-processor.js.map +0 -1
  146. package/dist/processors/collection-item-id-processor.d.ts +0 -12
  147. package/dist/processors/collection-item-id-processor.d.ts.map +0 -1
  148. package/dist/processors/collection-item-id-processor.js +0 -50
  149. package/dist/processors/collection-item-id-processor.js.map +0 -1
  150. package/dist/processors/collection-reference-field-processor.d.ts +0 -31
  151. package/dist/processors/collection-reference-field-processor.d.ts.map +0 -1
  152. package/dist/processors/collection-reference-field-processor.js +0 -174
  153. package/dist/processors/collection-reference-field-processor.js.map +0 -1
  154. package/dist/processors/collection-tracing-utils.d.ts +0 -31
  155. package/dist/processors/collection-tracing-utils.d.ts.map +0 -1
  156. package/dist/processors/collection-tracing-utils.js +0 -326
  157. package/dist/processors/collection-tracing-utils.js.map +0 -1
  158. package/dist/types.d.ts +0 -5
  159. package/dist/types.d.ts.map +0 -1
  160. package/dist/types.js.map +0 -1
  161. package/src/consts.ts +0 -12
  162. package/src/processors/collection-id-processor.ts +0 -261
  163. package/src/processors/collection-item-field-processor.ts +0 -410
  164. package/src/processors/collection-item-id-processor.ts +0 -69
  165. package/src/processors/collection-reference-field-processor.ts +0 -225
  166. package/src/processors/collection-tracing-utils.ts +0 -436
  167. package/src/types.ts +0 -4
  168. /package/dist/{types.js → capabilities/inline-edit/types.js} +0 -0
@@ -1,436 +0,0 @@
1
- import type { NodePath } from "@babel/traverse";
2
- import type * as t from "@babel/types";
3
- import type { CollectionInfo } from "../types.js";
4
- import {
5
- ExpressionAnalysisUtils,
6
- BindingUtils,
7
- CallExpressionUtils,
8
- } from "./shared-utils.js";
9
-
10
- export class CollectionTracingUtils {
11
- private expressionUtils: ExpressionAnalysisUtils;
12
- private bindingUtils: BindingUtils;
13
- private callUtils: CallExpressionUtils;
14
- private visitedSetters = new Set<string>();
15
- private visitedGetByIdSetters = new Set<string>();
16
-
17
- constructor(private types: typeof t) {
18
- this.expressionUtils = new ExpressionAnalysisUtils(types);
19
- this.bindingUtils = new BindingUtils(types);
20
- this.callUtils = new CallExpressionUtils(types);
21
- }
22
-
23
- resetVisited(): void {
24
- this.visitedSetters.clear();
25
- this.visitedGetByIdSetters.clear();
26
- }
27
-
28
- traceCollectionSource(
29
- path: NodePath<t.Expression>
30
- ): CollectionInfo | null {
31
- this.resetVisited();
32
- return this.traceExpression(path);
33
- }
34
-
35
- private traceExpression(
36
- path: NodePath<t.Expression>
37
- ): CollectionInfo | null {
38
- if (path.isIdentifier()) {
39
- return this.traceIdentifierToCollection(path);
40
- }
41
-
42
- if (path.isMemberExpression()) {
43
- return this.traceMemberExpression(path);
44
- }
45
-
46
- if (path.isCallExpression()) {
47
- return this.traceCallExpression(path);
48
- }
49
-
50
- if (path.isAwaitExpression()) {
51
- const argument = path.get("argument");
52
- if (argument.isExpression()) {
53
- return this.traceExpression(argument);
54
- }
55
- }
56
-
57
- if (path.isArrayExpression()) {
58
- return this.traceArrayExpression(path);
59
- }
60
-
61
- return null;
62
- }
63
-
64
- private traceIdentifierToCollection(
65
- path: NodePath<t.Identifier>
66
- ): CollectionInfo | null {
67
- const name = path.node.name;
68
- const binding = path.scope.getBinding(name);
69
- if (!binding) return null;
70
-
71
- if (binding.path.isVariableDeclarator()) {
72
- return this.traceVariableDeclarator(binding.path, name);
73
- }
74
-
75
- if (this.bindingUtils.isFunctionParameter(name, path)) {
76
- return this.traceParameterToCollection(name, path);
77
- }
78
-
79
- return null;
80
- }
81
-
82
- private traceVariableDeclarator(
83
- declaratorPath: NodePath<t.VariableDeclarator>,
84
- variableName: string
85
- ): CollectionInfo | null {
86
- const init = declaratorPath.get("init");
87
-
88
- if (init.isCallExpression()) {
89
- const directResult = this.checkDirectServiceCall(init);
90
- if (directResult) return directResult;
91
-
92
- const useStateInfo = this.bindingUtils.isUseStateCall(init);
93
- if (useStateInfo?.setterName) {
94
- return this.traceUseStateSetter(useStateInfo.setterName, declaratorPath);
95
- }
96
- }
97
-
98
- if (init.isAwaitExpression()) {
99
- const awaitArg = init.get("argument");
100
- if (awaitArg.isCallExpression()) {
101
- const directResult = this.checkDirectServiceCall(awaitArg);
102
- if (directResult) return directResult;
103
- }
104
- return this.traceExpression(init);
105
- }
106
-
107
- if (init.isMemberExpression()) {
108
- return this.traceExpression(init);
109
- }
110
-
111
- if (init.isIdentifier()) {
112
- return this.traceExpression(init);
113
- }
114
-
115
- if (init.isCallExpression()) {
116
- return this.traceExpression(init);
117
- }
118
-
119
- const id = declaratorPath.get("id");
120
-
121
- if (id.isArrayPattern()) {
122
- return this.traceArrayDestructuring(declaratorPath, id, variableName);
123
- }
124
-
125
- if (id.isObjectPattern()) {
126
- return this.traceObjectDestructuring(declaratorPath, id, variableName);
127
- }
128
-
129
- return null;
130
- }
131
-
132
- private traceUseStateSetter(
133
- setterName: string,
134
- declaratorPath: NodePath<t.VariableDeclarator>
135
- ): CollectionInfo | null {
136
- if (this.visitedSetters.has(setterName)) return null;
137
- this.visitedSetters.add(setterName);
138
-
139
- const functionScope = declaratorPath.getFunctionParent() ?? declaratorPath.scope.path;
140
- const setterCall = this.bindingUtils.findSetterCallInScope(
141
- setterName,
142
- functionScope
143
- );
144
-
145
- if (!setterCall) return null;
146
-
147
- const args = setterCall.get("arguments");
148
- const firstArg = args[0];
149
- if (!firstArg || !firstArg.isExpression()) return null;
150
-
151
- return this.traceExpression(firstArg);
152
- }
153
-
154
- private traceMemberExpression(
155
- path: NodePath<t.MemberExpression>
156
- ): CollectionInfo | null {
157
- const property = path.get("property");
158
- const object = path.get("object");
159
-
160
- if (
161
- property.isIdentifier() &&
162
- property.node.name === "items"
163
- ) {
164
- if (object.isExpression()) {
165
- return this.traceExpression(object);
166
- }
167
- }
168
-
169
- if (object.isIdentifier()) {
170
- const objResult = this.traceIdentifierToCollection(object);
171
- if (objResult && property.isIdentifier()) {
172
- if (objResult.references.includes(property.node.name)) {
173
- return { id: property.node.name, references: [] };
174
- }
175
- }
176
- return objResult;
177
- }
178
-
179
- if (object.isExpression()) {
180
- return this.traceExpression(object);
181
- }
182
-
183
- return null;
184
- }
185
-
186
- private traceCallExpression(
187
- path: NodePath<t.CallExpression>
188
- ): CollectionInfo | null {
189
- const directResult = this.checkDirectServiceCall(path);
190
- if (directResult) return directResult;
191
-
192
- if (this.callUtils.isChainedArrayMethod(path.node)) {
193
- const callee = path.get("callee");
194
- if (callee.isMemberExpression()) {
195
- const obj = callee.get("object") as NodePath<t.Expression>;
196
- return this.traceExpression(obj);
197
- }
198
- }
199
-
200
- return null;
201
- }
202
-
203
- private checkDirectServiceCall(
204
- path: NodePath<t.CallExpression>
205
- ): CollectionInfo | null {
206
- const getAllInfo = this.callUtils.isGetAllCall(path.node);
207
- if (getAllInfo) {
208
- return {
209
- id: getAllInfo.collectionName,
210
- references: getAllInfo.references,
211
- };
212
- }
213
-
214
- const getByIdInfo = this.callUtils.isGetByIdCall(path.node);
215
- if (getByIdInfo) {
216
- return {
217
- id: getByIdInfo.collectionName,
218
- references: getByIdInfo.multiRefFields,
219
- };
220
- }
221
-
222
- return null;
223
- }
224
-
225
- private traceArrayDestructuring(
226
- declaratorPath: NodePath<t.VariableDeclarator>,
227
- pattern: NodePath<t.ArrayPattern>,
228
- variableName: string
229
- ): CollectionInfo | null {
230
- const elements = pattern.get("elements");
231
- const index = elements.findIndex(
232
- (el) => el.isIdentifier() && el.node.name === variableName
233
- );
234
-
235
- if (index === -1) return null;
236
-
237
- const init = declaratorPath.get("init");
238
-
239
- if (init.hasNode() && this.bindingUtils.isPromiseAllCall(init as NodePath<t.Node>)) {
240
- return this.tracePromiseAllElement(init as NodePath<t.Node>, index);
241
- }
242
-
243
- if (init.isCallExpression()) {
244
- const useStateInfo = this.bindingUtils.isUseStateCall(init);
245
- if (useStateInfo && index === 0 && useStateInfo.setterName) {
246
- return this.traceUseStateSetter(useStateInfo.setterName, declaratorPath);
247
- }
248
- }
249
-
250
- return null;
251
- }
252
-
253
- private traceObjectDestructuring(
254
- declaratorPath: NodePath<t.VariableDeclarator>,
255
- pattern: NodePath<t.ObjectPattern>,
256
- variableName: string
257
- ): CollectionInfo | null {
258
- const init = declaratorPath.get("init");
259
- if (!init.isExpression()) return null;
260
-
261
- const prop = pattern.node.properties.find(
262
- (p) =>
263
- this.types.isObjectProperty(p) &&
264
- this.types.isIdentifier(p.value) &&
265
- p.value.name === variableName
266
- );
267
-
268
- if (!prop || !this.types.isObjectProperty(prop)) return null;
269
-
270
- const key = prop.key;
271
- const propertyName = this.types.isIdentifier(key)
272
- ? key.name
273
- : this.types.isStringLiteral(key)
274
- ? key.value
275
- : null;
276
-
277
- if (propertyName === "items") {
278
- return this.traceExpression(init);
279
- }
280
-
281
- return this.traceExpression(init);
282
- }
283
-
284
- private tracePromiseAllElement(
285
- init: NodePath<t.Node>,
286
- index: number
287
- ): CollectionInfo | null {
288
- let callExpr: NodePath<t.CallExpression>;
289
-
290
- if (init.isAwaitExpression()) {
291
- const arg = init.get("argument");
292
- if (!arg.isCallExpression()) return null;
293
- callExpr = arg;
294
- } else if (init.isCallExpression()) {
295
- callExpr = init;
296
- } else {
297
- return null;
298
- }
299
-
300
- const args = callExpr.get("arguments");
301
- const firstArg = args[0];
302
- if (!firstArg?.isArrayExpression()) return null;
303
-
304
- const elements = firstArg.get("elements");
305
- const targetElement = elements[index];
306
- if (!targetElement || !targetElement.isExpression()) return null;
307
-
308
- return this.traceExpression(targetElement);
309
- }
310
-
311
- private traceParameterToCollection(
312
- paramName: string,
313
- path: NodePath
314
- ): CollectionInfo | null {
315
- const fn = path.getFunctionParent();
316
- if (!fn) return null;
317
-
318
- const fnName = this.getFunctionName(fn);
319
- if (!fnName) return null;
320
-
321
- const programPath = fn.findParent((p) => p.isProgram());
322
- if (!programPath) return null;
323
-
324
- let result: CollectionInfo | null = null;
325
-
326
- programPath.traverse({
327
- JSXOpeningElement: (jsxPath: NodePath<t.JSXOpeningElement>) => {
328
- if (result) return;
329
-
330
- const elementName = this.getJSXElementName(jsxPath.node);
331
- if (elementName !== fnName) return;
332
-
333
- for (const attr of jsxPath.node.attributes) {
334
- if (!this.types.isJSXAttribute(attr)) continue;
335
- if (!this.types.isJSXIdentifier(attr.name)) continue;
336
- if (attr.name.name !== paramName) continue;
337
-
338
- if (
339
- attr.value &&
340
- this.types.isJSXExpressionContainer(attr.value) &&
341
- this.types.isExpression(attr.value.expression)
342
- ) {
343
- const exprPath = jsxPath
344
- .get("attributes")
345
- .find(
346
- (a) =>
347
- a.isJSXAttribute() &&
348
- this.types.isJSXIdentifier(a.node.name) &&
349
- a.node.name.name === paramName
350
- );
351
-
352
- if (exprPath && exprPath.isJSXAttribute()) {
353
- const valPath = exprPath.get("value");
354
- if (
355
- valPath.isJSXExpressionContainer()
356
- ) {
357
- const expr = valPath.get("expression");
358
- if (expr.isExpression()) {
359
- result = this.traceExpression(expr);
360
- }
361
- }
362
- }
363
- }
364
- }
365
- },
366
- });
367
-
368
- return result;
369
- }
370
-
371
- private traceArrayExpression(
372
- path: NodePath<t.ArrayExpression>
373
- ): CollectionInfo | null {
374
- const elements = path.get("elements");
375
- for (const el of elements) {
376
- if (el.isSpreadElement()) {
377
- const arg = el.get("argument");
378
- if (arg.isExpression()) {
379
- const result = this.traceExpression(arg);
380
- if (result) return result;
381
- }
382
- }
383
- }
384
- return null;
385
- }
386
-
387
- private getFunctionName(fn: NodePath<t.Function>): string | null {
388
- if (fn.isFunctionDeclaration() && fn.node.id) {
389
- return fn.node.id.name;
390
- }
391
-
392
- const parent = fn.parentPath;
393
- if (parent?.isVariableDeclarator()) {
394
- const id = parent.get("id");
395
- if (id.isIdentifier()) return id.node.name;
396
- }
397
-
398
- return null;
399
- }
400
-
401
- private getJSXElementName(node: t.JSXOpeningElement): string | null {
402
- if (this.types.isJSXIdentifier(node.name)) {
403
- return node.name.name;
404
- }
405
- return null;
406
- }
407
-
408
- traceGetByIdSource(
409
- path: NodePath
410
- ): CollectionInfo | null {
411
- this.visitedGetByIdSetters.clear();
412
- return this.findGetByIdInScope(path);
413
- }
414
-
415
- private findGetByIdInScope(
416
- path: NodePath
417
- ): CollectionInfo | null {
418
- const fn = path.getFunctionParent() ?? path.scope.path;
419
- let result: CollectionInfo | null = null;
420
-
421
- fn.traverse({
422
- CallExpression: (callPath: NodePath<t.CallExpression>) => {
423
- if (result) return;
424
- const info = this.callUtils.isGetByIdCall(callPath.node);
425
- if (info) {
426
- result = {
427
- id: info.collectionName,
428
- references: info.multiRefFields,
429
- };
430
- }
431
- },
432
- });
433
-
434
- return result;
435
- }
436
- }
package/src/types.ts DELETED
@@ -1,4 +0,0 @@
1
- export interface CollectionInfo {
2
- id: string;
3
- references: string[];
4
- }