@xiuchang-midscene/shared 2.0.2 → 2.0.3

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 (166) hide show
  1. package/dist/es/oss/index.mjs +1 -1
  2. package/dist/lib/oss/index.js +1 -1
  3. package/package.json +1 -1
  4. package/src/oss/index.ts +1 -1
  5. package/dist/es/baseDB.mjs.bak +0 -109
  6. package/dist/es/build/copy-static.mjs.bak +0 -31
  7. package/dist/es/build/rspack-config.mjs.bak +0 -4
  8. package/dist/es/cli/cli-runner.mjs.bak +0 -140
  9. package/dist/es/cli/index.mjs.bak +0 -2
  10. package/dist/es/common.mjs.bak +0 -37
  11. package/dist/es/constants/example-code.mjs.bak +0 -223
  12. package/dist/es/constants/index.mjs.bak +0 -23
  13. package/dist/es/env/basic.mjs.bak +0 -6
  14. package/dist/es/env/constants.mjs.bak +0 -70
  15. package/dist/es/env/global-config-manager.mjs.bak +0 -94
  16. package/dist/es/env/helper.mjs.bak +0 -43
  17. package/dist/es/env/index.mjs.bak +0 -5
  18. package/dist/es/env/init-debug.mjs.bak +0 -18
  19. package/dist/es/env/model-config-manager.mjs.bak +0 -79
  20. package/dist/es/env/parse-model-config.mjs.bak +0 -132
  21. package/dist/es/env/types.mjs.bak +0 -220
  22. package/dist/es/env/utils.mjs.bak +0 -26
  23. package/dist/es/extractor/constants.mjs.bak +0 -2
  24. package/dist/es/extractor/debug.mjs.bak +0 -6
  25. package/dist/es/extractor/dom-util.mjs.bak +0 -92
  26. package/dist/es/extractor/index.mjs.bak +0 -5
  27. package/dist/es/extractor/locator.mjs.bak +0 -250
  28. package/dist/es/extractor/tree.mjs.bak +0 -78
  29. package/dist/es/extractor/util.mjs.bak +0 -245
  30. package/dist/es/extractor/web-extractor.mjs.bak +0 -303
  31. package/dist/es/img/box-select.mjs.bak +0 -824
  32. package/dist/es/img/canvas-fallback.mjs.bak +0 -238
  33. package/dist/es/img/get-photon.mjs.bak +0 -45
  34. package/dist/es/img/get-sharp.mjs.bak +0 -11
  35. package/dist/es/img/index.mjs.bak +0 -4
  36. package/dist/es/img/info.mjs.bak +0 -29
  37. package/dist/es/img/transform.mjs.bak +0 -295
  38. package/dist/es/index.mjs.bak +0 -4
  39. package/dist/es/logger.mjs.bak +0 -64
  40. package/dist/es/mcp/base-server.mjs.bak +0 -281
  41. package/dist/es/mcp/base-tools.mjs.bak +0 -91
  42. package/dist/es/mcp/chrome-path.mjs.bak +0 -35
  43. package/dist/es/mcp/index.mjs.bak +0 -7
  44. package/dist/es/mcp/inject-report-html-plugin.mjs.bak +0 -53
  45. package/dist/es/mcp/launcher-helper.mjs.bak +0 -52
  46. package/dist/es/mcp/tool-generator.mjs.bak +0 -297
  47. package/dist/es/mcp/types.mjs.bak +0 -3
  48. package/dist/es/node/fs.mjs.bak +0 -44
  49. package/dist/es/node/index.mjs.bak +0 -2
  50. package/dist/es/node/port.mjs.bak +0 -24
  51. package/dist/es/oss/demo.mjs.bak +0 -30
  52. package/dist/es/oss/index.mjs.bak +0 -90
  53. package/dist/es/polyfills/async-hooks.mjs.bak +0 -2
  54. package/dist/es/polyfills/index.mjs.bak +0 -1
  55. package/dist/es/types/index.mjs.bak +0 -3
  56. package/dist/es/us-keyboard-layout.mjs.bak +0 -1414
  57. package/dist/es/utils.mjs.bak +0 -72
  58. package/dist/es/zod-schema-utils.mjs.bak +0 -54
  59. package/dist/lib/baseDB.js.bak +0 -149
  60. package/dist/lib/build/copy-static.js.bak +0 -79
  61. package/dist/lib/build/rspack-config.js.bak +0 -38
  62. package/dist/lib/cli/cli-runner.js.bak +0 -196
  63. package/dist/lib/cli/index.js.bak +0 -48
  64. package/dist/lib/common.js.bak +0 -93
  65. package/dist/lib/constants/example-code.js.bak +0 -260
  66. package/dist/lib/constants/index.js.bak +0 -96
  67. package/dist/lib/env/basic.js.bak +0 -40
  68. package/dist/lib/env/constants.js.bak +0 -113
  69. package/dist/lib/env/global-config-manager.js.bak +0 -128
  70. package/dist/lib/env/helper.js.bak +0 -80
  71. package/dist/lib/env/index.js.bak +0 -90
  72. package/dist/lib/env/init-debug.js.bak +0 -52
  73. package/dist/lib/env/model-config-manager.js.bak +0 -113
  74. package/dist/lib/env/parse-model-config.js.bak +0 -178
  75. package/dist/lib/env/types.js.bak +0 -554
  76. package/dist/lib/env/utils.js.bak +0 -72
  77. package/dist/lib/extractor/constants.js.bak +0 -42
  78. package/dist/lib/extractor/debug.js.bak +0 -12
  79. package/dist/lib/extractor/dom-util.js.bak +0 -153
  80. package/dist/lib/extractor/index.js.bak +0 -81
  81. package/dist/lib/extractor/locator.js.bak +0 -296
  82. package/dist/lib/extractor/tree.js.bak +0 -124
  83. package/dist/lib/extractor/util.js.bak +0 -336
  84. package/dist/lib/extractor/web-extractor.js.bak +0 -349
  85. package/dist/lib/img/box-select.js.bak +0 -875
  86. package/dist/lib/img/canvas-fallback.js.bak +0 -305
  87. package/dist/lib/img/get-photon.js.bak +0 -82
  88. package/dist/lib/img/get-sharp.js.bak +0 -45
  89. package/dist/lib/img/index.js.bak +0 -95
  90. package/dist/lib/img/info.js.bak +0 -83
  91. package/dist/lib/img/transform.js.bak +0 -387
  92. package/dist/lib/index.js.bak +0 -47
  93. package/dist/lib/logger.js.bak +0 -114
  94. package/dist/lib/mcp/base-server.js.bak +0 -331
  95. package/dist/lib/mcp/base-tools.js.bak +0 -125
  96. package/dist/lib/mcp/chrome-path.js.bak +0 -72
  97. package/dist/lib/mcp/index.js.bak +0 -100
  98. package/dist/lib/mcp/inject-report-html-plugin.js.bak +0 -98
  99. package/dist/lib/mcp/launcher-helper.js.bak +0 -86
  100. package/dist/lib/mcp/tool-generator.js.bak +0 -334
  101. package/dist/lib/mcp/types.js.bak +0 -40
  102. package/dist/lib/node/fs.js.bak +0 -97
  103. package/dist/lib/node/index.js.bak +0 -65
  104. package/dist/lib/node/port.js.bak +0 -61
  105. package/dist/lib/oss/demo.js.bak +0 -36
  106. package/dist/lib/oss/index.js.bak +0 -138
  107. package/dist/lib/polyfills/async-hooks.js.bak +0 -36
  108. package/dist/lib/polyfills/index.js.bak +0 -58
  109. package/dist/lib/types/index.js.bak +0 -37
  110. package/dist/lib/us-keyboard-layout.js.bak +0 -1457
  111. package/dist/lib/utils.js.bak +0 -148
  112. package/dist/lib/zod-schema-utils.js.bak +0 -97
  113. package/dist/types/baseDB.d.ts.bak +0 -25
  114. package/dist/types/build/copy-static.d.ts.bak +0 -31
  115. package/dist/types/build/rspack-config.d.ts.bak +0 -8
  116. package/dist/types/cli/cli-runner.d.ts.bak +0 -14
  117. package/dist/types/cli/index.d.ts.bak +0 -2
  118. package/dist/types/common.d.ts.bak +0 -12
  119. package/dist/types/constants/example-code.d.ts.bak +0 -2
  120. package/dist/types/constants/index.d.ts.bak +0 -21
  121. package/dist/types/env/basic.d.ts.bak +0 -6
  122. package/dist/types/env/constants.d.ts.bak +0 -40
  123. package/dist/types/env/global-config-manager.d.ts.bak +0 -32
  124. package/dist/types/env/helper.d.ts.bak +0 -4
  125. package/dist/types/env/index.d.ts.bak +0 -4
  126. package/dist/types/env/init-debug.d.ts.bak +0 -1
  127. package/dist/types/env/model-config-manager.d.ts.bak +0 -25
  128. package/dist/types/env/parse-model-config.d.ts.bak +0 -31
  129. package/dist/types/env/types.d.ts.bak +0 -318
  130. package/dist/types/env/utils.d.ts.bak +0 -38
  131. package/dist/types/extractor/constants.d.ts.bak +0 -1
  132. package/dist/types/extractor/debug.d.ts.bak +0 -1
  133. package/dist/types/extractor/dom-util.d.ts.bak +0 -56
  134. package/dist/types/extractor/index.d.ts.bak +0 -32
  135. package/dist/types/extractor/locator.d.ts.bak +0 -9
  136. package/dist/types/extractor/tree.d.ts.bak +0 -6
  137. package/dist/types/extractor/util.d.ts.bak +0 -47
  138. package/dist/types/extractor/web-extractor.d.ts.bak +0 -19
  139. package/dist/types/img/box-select.d.ts.bak +0 -26
  140. package/dist/types/img/canvas-fallback.d.ts.bak +0 -105
  141. package/dist/types/img/get-photon.d.ts.bak +0 -19
  142. package/dist/types/img/get-sharp.d.ts.bak +0 -3
  143. package/dist/types/img/index.d.ts.bak +0 -3
  144. package/dist/types/img/info.d.ts.bak +0 -29
  145. package/dist/types/img/transform.d.ts.bak +0 -107
  146. package/dist/types/index.d.ts.bak +0 -4
  147. package/dist/types/logger.d.ts.bak +0 -5
  148. package/dist/types/mcp/base-server.d.ts.bak +0 -93
  149. package/dist/types/mcp/base-tools.d.ts.bak +0 -79
  150. package/dist/types/mcp/chrome-path.d.ts.bak +0 -2
  151. package/dist/types/mcp/index.d.ts.bak +0 -7
  152. package/dist/types/mcp/inject-report-html-plugin.d.ts.bak +0 -18
  153. package/dist/types/mcp/launcher-helper.d.ts.bak +0 -94
  154. package/dist/types/mcp/tool-generator.d.ts.bak +0 -10
  155. package/dist/types/mcp/types.d.ts.bak +0 -103
  156. package/dist/types/node/fs.d.ts.bak +0 -15
  157. package/dist/types/node/index.d.ts.bak +0 -2
  158. package/dist/types/node/port.d.ts.bak +0 -8
  159. package/dist/types/oss/demo.d.ts.bak +0 -1
  160. package/dist/types/oss/index.d.ts.bak +0 -34
  161. package/dist/types/polyfills/async-hooks.d.ts.bak +0 -6
  162. package/dist/types/polyfills/index.d.ts.bak +0 -4
  163. package/dist/types/types/index.d.ts.bak +0 -34
  164. package/dist/types/us-keyboard-layout.d.ts.bak +0 -32
  165. package/dist/types/utils.d.ts.bak +0 -34
  166. package/dist/types/zod-schema-utils.d.ts.bak +0 -23
@@ -1,245 +0,0 @@
1
- import { generateHashId } from "../utils.mjs";
2
- import { extractTextWithPosition } from "./web-extractor.mjs";
3
- const MAX_VALUE_LENGTH = 300;
4
- let debugMode = false;
5
- function setDebugMode(mode) {
6
- debugMode = mode;
7
- }
8
- function getDebugMode() {
9
- return debugMode;
10
- }
11
- function logger(..._msg) {
12
- if (!debugMode) return;
13
- console.log(..._msg);
14
- }
15
- function isElementPartiallyInViewport(rect, currentWindow, currentDocument, visibleAreaRatio = 2 / 3) {
16
- const elementHeight = rect.height;
17
- const elementWidth = rect.width;
18
- const viewportRect = {
19
- left: 0,
20
- top: 0,
21
- width: currentWindow.innerWidth || currentDocument.documentElement.clientWidth,
22
- height: currentWindow.innerHeight || currentDocument.documentElement.clientHeight,
23
- right: currentWindow.innerWidth || currentDocument.documentElement.clientWidth,
24
- bottom: currentWindow.innerHeight || currentDocument.documentElement.clientHeight,
25
- x: 0,
26
- y: 0,
27
- zoom: 1
28
- };
29
- const overlapRect = overlappedRect(rect, viewportRect);
30
- if (!overlapRect) return false;
31
- const visibleArea = overlapRect.width * overlapRect.height;
32
- const totalArea = elementHeight * elementWidth;
33
- return visibleArea / totalArea >= visibleAreaRatio;
34
- }
35
- function getPseudoElementContent(element, currentWindow) {
36
- if (!(element instanceof currentWindow.HTMLElement)) return {
37
- before: '',
38
- after: ''
39
- };
40
- const beforeContent = currentWindow.getComputedStyle(element, '::before').getPropertyValue('content');
41
- const afterContent = currentWindow.getComputedStyle(element, '::after').getPropertyValue('content');
42
- return {
43
- before: 'none' === beforeContent ? '' : beforeContent.replace(/"/g, ''),
44
- after: 'none' === afterContent ? '' : afterContent.replace(/"/g, '')
45
- };
46
- }
47
- function hasOverflowY(element, currentWindow) {
48
- const style = currentWindow.getComputedStyle(element);
49
- return 'scroll' === style.overflowY || 'auto' === style.overflowY || 'hidden' === style.overflowY;
50
- }
51
- function overlappedRect(rect1, rect2) {
52
- const left = Math.max(rect1.left, rect2.left);
53
- const top = Math.max(rect1.top, rect2.top);
54
- const right = Math.min(rect1.right, rect2.right);
55
- const bottom = Math.min(rect1.bottom, rect2.bottom);
56
- if (left < right && top < bottom) return {
57
- left,
58
- top,
59
- right,
60
- bottom,
61
- width: right - left,
62
- height: bottom - top,
63
- x: left,
64
- y: top,
65
- zoom: 1
66
- };
67
- return null;
68
- }
69
- function getRect(el, baseZoom, currentWindow) {
70
- let originalRect;
71
- let newZoom = 1;
72
- const hasGetBoundingClientRect = el instanceof Element;
73
- if (hasGetBoundingClientRect) {
74
- originalRect = el.getBoundingClientRect();
75
- if (el instanceof currentWindow.HTMLElement && !('currentCSSZoom' in el)) newZoom = Number.parseFloat(currentWindow.getComputedStyle(el).zoom) || 1;
76
- } else {
77
- const range = currentWindow.document.createRange();
78
- range.selectNodeContents(el);
79
- originalRect = range.getBoundingClientRect();
80
- }
81
- const zoom = newZoom * baseZoom;
82
- return {
83
- width: originalRect.width * zoom,
84
- height: originalRect.height * zoom,
85
- left: originalRect.left * zoom,
86
- top: originalRect.top * zoom,
87
- right: originalRect.right * zoom,
88
- bottom: originalRect.bottom * zoom,
89
- x: originalRect.x * zoom,
90
- y: originalRect.y * zoom,
91
- zoom
92
- };
93
- }
94
- const isElementCovered = (el, rect, currentWindow)=>{
95
- const x = rect.left + rect.width / 2;
96
- const y = rect.top + rect.height / 2;
97
- const topElement = currentWindow.document.elementFromPoint(x, y);
98
- if (!topElement) return false;
99
- if (topElement === el) return false;
100
- if (el?.contains(topElement)) return false;
101
- if (topElement?.contains(el)) return false;
102
- const rectOfTopElement = getRect(topElement, 1, currentWindow);
103
- const overlapRect = overlappedRect(rect, rectOfTopElement);
104
- if (!overlapRect) return false;
105
- logger(el, 'Element is covered by another element', {
106
- topElement,
107
- el,
108
- rect,
109
- x,
110
- y
111
- });
112
- return true;
113
- };
114
- function elementRect(el, currentWindow, currentDocument, baseZoom = 1) {
115
- if (!el) {
116
- logger(el, 'Element is not in the DOM hierarchy');
117
- return false;
118
- }
119
- if (!(el instanceof currentWindow.HTMLElement) && el.nodeType !== Node.TEXT_NODE && 'svg' !== el.nodeName.toLowerCase()) {
120
- logger(el, 'Element is not in the DOM hierarchy');
121
- return false;
122
- }
123
- if (el instanceof currentWindow.HTMLElement) {
124
- const style = currentWindow.getComputedStyle(el);
125
- if ('none' === style.display || 'hidden' === style.visibility || '0' === style.opacity && 'INPUT' !== el.tagName) {
126
- logger(el, 'Element is hidden');
127
- return false;
128
- }
129
- }
130
- const rect = getRect(el, baseZoom, currentWindow);
131
- if (0 === rect.width && 0 === rect.height) {
132
- logger(el, 'Element has no size');
133
- return false;
134
- }
135
- if (1 === baseZoom && isElementCovered(el, rect, currentWindow)) return false;
136
- const isVisible = isElementPartiallyInViewport(rect, currentWindow, currentDocument);
137
- let parent = el;
138
- const parentUntilNonStatic = (currentNode)=>{
139
- let parent = currentNode?.parentElement;
140
- while(parent){
141
- const style = currentWindow.getComputedStyle(parent);
142
- if ('static' !== style.position) return parent;
143
- parent = parent.parentElement;
144
- }
145
- return null;
146
- };
147
- while(parent && parent !== currentDocument.body){
148
- if (!(parent instanceof currentWindow.HTMLElement)) {
149
- parent = parent.parentElement;
150
- continue;
151
- }
152
- const parentStyle = currentWindow.getComputedStyle(parent);
153
- if ('hidden' === parentStyle.overflow) {
154
- const parentRect = getRect(parent, 1, currentWindow);
155
- const tolerance = 10;
156
- if (rect.right < parentRect.left - tolerance || rect.left > parentRect.right + tolerance || rect.bottom < parentRect.top - tolerance || rect.top > parentRect.bottom + tolerance) {
157
- logger(el, 'element is partially or totally hidden by an ancestor', {
158
- rect,
159
- parentRect
160
- });
161
- return false;
162
- }
163
- }
164
- if ('fixed' === parentStyle.position || 'sticky' === parentStyle.position) break;
165
- parent = 'absolute' === parentStyle.position ? parentUntilNonStatic(parent) : parent.parentElement;
166
- }
167
- return {
168
- left: Math.round(rect.left),
169
- top: Math.round(rect.top),
170
- width: Math.round(rect.width),
171
- height: Math.round(rect.height),
172
- zoom: rect.zoom,
173
- isVisible
174
- };
175
- }
176
- function validTextNodeContent(node) {
177
- if (!node) return false;
178
- if (node.nodeType !== Node.ELEMENT_NODE && node.nodeType !== Node.TEXT_NODE && '#text' !== node.nodeName) return false;
179
- const content = node.textContent || node.innerText;
180
- if (content && !/^\s*$/.test(content)) return content.trim();
181
- return false;
182
- }
183
- function getNodeAttributes(node, currentWindow) {
184
- if (!node || !(node instanceof currentWindow.HTMLElement) || !node.attributes) return {};
185
- const attributesList = Array.from(node.attributes).map((attr)=>{
186
- if ('class' === attr.name) return [
187
- attr.name,
188
- `.${attr.value.split(' ').join('.')}`
189
- ];
190
- let value = attr.value;
191
- if (value.startsWith('data:image')) value = 'image';
192
- if (value.length > MAX_VALUE_LENGTH) value = `${value.slice(0, MAX_VALUE_LENGTH)}...`;
193
- return [
194
- attr.name,
195
- value
196
- ];
197
- });
198
- return Object.fromEntries(attributesList);
199
- }
200
- const NODE_CACHE_MAX_SIZE = 2000;
201
- function setNodeHashCacheListOnWindow() {
202
- if ('undefined' != typeof window) window.midsceneNodeHashCache = new Map();
203
- }
204
- function getNodeCacheMap() {
205
- if ('undefined' == typeof window) return;
206
- return window.midsceneNodeHashCache;
207
- }
208
- function setNodeToCacheList(node, id) {
209
- const cache = getNodeCacheMap();
210
- if (!cache) return;
211
- if (cache.has(id)) return;
212
- if (cache.size >= NODE_CACHE_MAX_SIZE) {
213
- const firstKey = cache.keys().next().value;
214
- if (void 0 !== firstKey) cache.delete(firstKey);
215
- }
216
- cache.set(id, node);
217
- }
218
- function getNodeFromCacheList(id) {
219
- return getNodeCacheMap()?.get(id);
220
- }
221
- function midsceneGenerateHash(node, content, rect) {
222
- const slicedHash = generateHashId(rect, content);
223
- if (node) {
224
- if ('undefined' != typeof window && !getNodeCacheMap()) setNodeHashCacheListOnWindow();
225
- setNodeToCacheList(node, slicedHash);
226
- }
227
- return slicedHash;
228
- }
229
- function generateId(numberId) {
230
- return `${numberId}`;
231
- }
232
- function setGenerateHashOnWindow() {
233
- if ('undefined' != typeof window) window.midsceneGenerateHash = midsceneGenerateHash;
234
- }
235
- function setMidsceneVisibleRectOnWindow() {
236
- if ('undefined' != typeof window) window.midsceneVisibleRect = elementRect;
237
- }
238
- function setExtractTextWithPositionOnWindow() {
239
- if ('undefined' != typeof window) window.extractTextWithPosition = extractTextWithPosition;
240
- }
241
- function getTopDocument() {
242
- const container = document.body || document;
243
- return container;
244
- }
245
- export { elementRect, generateId, getDebugMode, getNodeAttributes, getNodeFromCacheList, getPseudoElementContent, getRect, getTopDocument, hasOverflowY, isElementPartiallyInViewport, logger, midsceneGenerateHash, overlappedRect, setDebugMode, setExtractTextWithPositionOnWindow, setGenerateHashOnWindow, setMidsceneVisibleRectOnWindow, setNodeHashCacheListOnWindow, setNodeToCacheList, validTextNodeContent };
@@ -1,303 +0,0 @@
1
- import { CONTAINER_MINI_HEIGHT, CONTAINER_MINI_WIDTH, NodeType } from "../constants/index.mjs";
2
- import { isAElement, isButtonElement, isContainerElement, isFormElement, isImgElement, isTextElement } from "./dom-util.mjs";
3
- import { descriptionOfTree } from "./tree.mjs";
4
- import { elementRect, getNodeAttributes, getPseudoElementContent, getRect, getTopDocument, logger, midsceneGenerateHash, setDebugMode } from "./util.mjs";
5
- let indexId = 0;
6
- function tagNameOfNode(node) {
7
- let tagName = '';
8
- if (node instanceof HTMLElement) tagName = node.tagName?.toLowerCase();
9
- else {
10
- const parentElement = node.parentElement;
11
- if (parentElement && parentElement instanceof HTMLElement) tagName = parentElement.tagName?.toLowerCase();
12
- }
13
- return tagName ? `<${tagName}>` : '';
14
- }
15
- function collectElementInfo(node, currentWindow, currentDocument, baseZoom = 1, basePoint = {
16
- left: 0,
17
- top: 0
18
- }, isContainer = false) {
19
- const rect = elementRect(node, currentWindow, currentDocument, baseZoom);
20
- if (!rect) return null;
21
- if (rect.width < CONTAINER_MINI_WIDTH || rect.height < CONTAINER_MINI_HEIGHT) return null;
22
- if (0 !== basePoint.left || 0 !== basePoint.top) {
23
- rect.left += basePoint.left;
24
- rect.top += basePoint.top;
25
- }
26
- if (rect.height >= window.innerHeight && rect.width >= window.innerWidth) return null;
27
- if (isFormElement(node)) {
28
- const attributes = getNodeAttributes(node, currentWindow);
29
- let valueContent = attributes.value || attributes.placeholder || node.textContent || '';
30
- const nodeHashId = midsceneGenerateHash(node, valueContent, rect);
31
- const tagName = node.tagName.toLowerCase();
32
- if ('select' === node.tagName.toLowerCase()) {
33
- const selectedOption = node.options[node.selectedIndex];
34
- valueContent = selectedOption?.textContent || '';
35
- }
36
- if (('input' === node.tagName.toLowerCase() || 'textarea' === node.tagName.toLowerCase()) && node.value) valueContent = node.value;
37
- const elementInfo = {
38
- id: nodeHashId,
39
- nodeHashId,
40
- nodeType: NodeType.FORM_ITEM,
41
- indexId: indexId++,
42
- attributes: {
43
- ...attributes,
44
- htmlTagName: `<${tagName}>`,
45
- nodeType: NodeType.FORM_ITEM
46
- },
47
- content: valueContent.trim(),
48
- rect,
49
- center: [
50
- Math.round(rect.left + rect.width / 2),
51
- Math.round(rect.top + rect.height / 2)
52
- ],
53
- zoom: rect.zoom,
54
- isVisible: rect.isVisible
55
- };
56
- return elementInfo;
57
- }
58
- if (isButtonElement(node)) {
59
- const rect = mergeElementAndChildrenRects(node, currentWindow, currentDocument, baseZoom);
60
- if (!rect) return null;
61
- const attributes = getNodeAttributes(node, currentWindow);
62
- const pseudo = getPseudoElementContent(node, currentWindow);
63
- const content = node.innerText || pseudo.before || pseudo.after || '';
64
- const nodeHashId = midsceneGenerateHash(node, content, rect);
65
- const elementInfo = {
66
- id: nodeHashId,
67
- indexId: indexId++,
68
- nodeHashId,
69
- nodeType: NodeType.BUTTON,
70
- attributes: {
71
- ...attributes,
72
- htmlTagName: tagNameOfNode(node),
73
- nodeType: NodeType.BUTTON
74
- },
75
- content,
76
- rect,
77
- center: [
78
- Math.round(rect.left + rect.width / 2),
79
- Math.round(rect.top + rect.height / 2)
80
- ],
81
- zoom: rect.zoom,
82
- isVisible: rect.isVisible
83
- };
84
- return elementInfo;
85
- }
86
- if (isImgElement(node)) {
87
- const attributes = getNodeAttributes(node, currentWindow);
88
- const nodeHashId = midsceneGenerateHash(node, '', rect);
89
- const elementInfo = {
90
- id: nodeHashId,
91
- indexId: indexId++,
92
- nodeHashId,
93
- attributes: {
94
- ...attributes,
95
- ...node.nodeName?.toLowerCase() === 'svg' ? {
96
- svgContent: 'true'
97
- } : {},
98
- nodeType: NodeType.IMG,
99
- htmlTagName: tagNameOfNode(node)
100
- },
101
- nodeType: NodeType.IMG,
102
- content: '',
103
- rect,
104
- center: [
105
- Math.round(rect.left + rect.width / 2),
106
- Math.round(rect.top + rect.height / 2)
107
- ],
108
- zoom: rect.zoom,
109
- isVisible: rect.isVisible
110
- };
111
- return elementInfo;
112
- }
113
- if (isTextElement(node)) {
114
- const text = node.textContent?.trim().replace(/\n+/g, ' ');
115
- if (!text) return null;
116
- const attributes = getNodeAttributes(node, currentWindow);
117
- const attributeKeys = Object.keys(attributes);
118
- if (!text.trim() && 0 === attributeKeys.length) return null;
119
- const nodeHashId = midsceneGenerateHash(node, text, rect);
120
- const elementInfo = {
121
- id: nodeHashId,
122
- indexId: indexId++,
123
- nodeHashId,
124
- nodeType: NodeType.TEXT,
125
- attributes: {
126
- ...attributes,
127
- nodeType: NodeType.TEXT,
128
- htmlTagName: tagNameOfNode(node)
129
- },
130
- center: [
131
- Math.round(rect.left + rect.width / 2),
132
- Math.round(rect.top + rect.height / 2)
133
- ],
134
- content: text,
135
- rect,
136
- zoom: rect.zoom,
137
- isVisible: rect.isVisible
138
- };
139
- return elementInfo;
140
- }
141
- if (isAElement(node)) {
142
- const attributes = getNodeAttributes(node, currentWindow);
143
- const pseudo = getPseudoElementContent(node, currentWindow);
144
- const content = node.innerText || pseudo.before || pseudo.after || '';
145
- const nodeHashId = midsceneGenerateHash(node, content, rect);
146
- const elementInfo = {
147
- id: nodeHashId,
148
- indexId: indexId++,
149
- nodeHashId,
150
- nodeType: NodeType.A,
151
- attributes: {
152
- ...attributes,
153
- htmlTagName: tagNameOfNode(node),
154
- nodeType: NodeType.A
155
- },
156
- content,
157
- rect,
158
- center: [
159
- Math.round(rect.left + rect.width / 2),
160
- Math.round(rect.top + rect.height / 2)
161
- ],
162
- zoom: rect.zoom,
163
- isVisible: rect.isVisible
164
- };
165
- return elementInfo;
166
- }
167
- if (isContainerElement(node) || isContainer) {
168
- const attributes = getNodeAttributes(node, currentWindow);
169
- const nodeHashId = midsceneGenerateHash(node, '', rect);
170
- const elementInfo = {
171
- id: nodeHashId,
172
- nodeHashId,
173
- indexId: indexId++,
174
- nodeType: NodeType.CONTAINER,
175
- attributes: {
176
- ...attributes,
177
- nodeType: NodeType.CONTAINER,
178
- htmlTagName: tagNameOfNode(node)
179
- },
180
- content: '',
181
- rect,
182
- center: [
183
- Math.round(rect.left + rect.width / 2),
184
- Math.round(rect.top + rect.height / 2)
185
- ],
186
- zoom: rect.zoom,
187
- isVisible: rect.isVisible
188
- };
189
- return elementInfo;
190
- }
191
- return null;
192
- }
193
- function extractTextWithPosition(initNode, debugMode = false) {
194
- const elementNode = extractTreeNode(initNode, debugMode);
195
- const elementInfoArray = [];
196
- function dfsTopChildren(node) {
197
- if (node.node) elementInfoArray.push(node.node);
198
- for(let i = 0; i < node.children.length; i++)dfsTopChildren(node.children[i]);
199
- }
200
- dfsTopChildren({
201
- children: elementNode.children,
202
- node: elementNode.node
203
- });
204
- return elementInfoArray;
205
- }
206
- function extractTreeNodeAsString(initNode, visibleOnly = false, debugMode = false) {
207
- const elementNode = extractTreeNode(initNode, debugMode);
208
- return descriptionOfTree(elementNode, void 0, false, visibleOnly);
209
- }
210
- function extractTreeNode(initNode, debugMode = false) {
211
- setDebugMode(debugMode);
212
- indexId = 0;
213
- const topDocument = getTopDocument();
214
- const startNode = initNode || topDocument;
215
- const topChildren = [];
216
- function dfs(node, currentWindow, currentDocument, baseZoom = 1, basePoint = {
217
- left: 0,
218
- top: 0
219
- }) {
220
- if (!node) return null;
221
- if (node.nodeType && 10 === node.nodeType) return null;
222
- const elementInfo = collectElementInfo(node, currentWindow, currentDocument, baseZoom, basePoint);
223
- if (node instanceof currentWindow.HTMLIFrameElement) {
224
- if (node.contentWindow && node.contentWindow) return null;
225
- }
226
- const nodeInfo = {
227
- node: elementInfo,
228
- children: []
229
- };
230
- if (elementInfo?.nodeType === NodeType.BUTTON || elementInfo?.nodeType === NodeType.IMG || elementInfo?.nodeType === NodeType.TEXT || elementInfo?.nodeType === NodeType.FORM_ITEM || elementInfo?.nodeType === NodeType.CONTAINER) return nodeInfo;
231
- const rect = getRect(node, baseZoom, currentWindow);
232
- for(let i = 0; i < node.childNodes.length; i++){
233
- logger('will dfs', node.childNodes[i]);
234
- const childNodeInfo = dfs(node.childNodes[i], currentWindow, currentDocument, rect.zoom, basePoint);
235
- if (Array.isArray(childNodeInfo)) nodeInfo.children.push(...childNodeInfo);
236
- else if (childNodeInfo) nodeInfo.children.push(childNodeInfo);
237
- }
238
- if (null === nodeInfo.node) {
239
- if (0 === nodeInfo.children.length) return null;
240
- return nodeInfo.children;
241
- }
242
- return nodeInfo;
243
- }
244
- const rootNodeInfo = dfs(startNode, window, document, 1, {
245
- left: 0,
246
- top: 0
247
- });
248
- if (Array.isArray(rootNodeInfo)) topChildren.push(...rootNodeInfo);
249
- else if (rootNodeInfo) topChildren.push(rootNodeInfo);
250
- if (startNode === topDocument) {
251
- const iframes = document.querySelectorAll('iframe');
252
- for(let i = 0; i < iframes.length; i++){
253
- const iframe = iframes[i];
254
- if (iframe.contentDocument && iframe.contentWindow) {
255
- const iframeInfo = collectElementInfo(iframe, window, document, 1);
256
- if (iframeInfo) {
257
- const iframeChildren = dfs(iframe.contentDocument.body, iframe.contentWindow, iframe.contentDocument, 1, {
258
- left: iframeInfo.rect.left,
259
- top: iframeInfo.rect.top
260
- });
261
- if (Array.isArray(iframeChildren)) topChildren.push(...iframeChildren);
262
- else if (iframeChildren) topChildren.push(iframeChildren);
263
- }
264
- }
265
- }
266
- }
267
- return {
268
- node: null,
269
- children: topChildren
270
- };
271
- }
272
- function mergeElementAndChildrenRects(node, currentWindow, currentDocument, baseZoom = 1) {
273
- const selfRect = elementRect(node, currentWindow, currentDocument, baseZoom);
274
- if (!selfRect) return null;
275
- let minLeft = selfRect.left;
276
- let minTop = selfRect.top;
277
- let maxRight = selfRect.left + selfRect.width;
278
- let maxBottom = selfRect.top + selfRect.height;
279
- function traverse(child) {
280
- for(let i = 0; i < child.childNodes.length; i++){
281
- const sub = child.childNodes[i];
282
- if (1 === sub.nodeType) {
283
- const rect = elementRect(sub, currentWindow, currentDocument, baseZoom);
284
- if (rect) {
285
- minLeft = Math.min(minLeft, rect.left);
286
- minTop = Math.min(minTop, rect.top);
287
- maxRight = Math.max(maxRight, rect.left + rect.width);
288
- maxBottom = Math.max(maxBottom, rect.top + rect.height);
289
- }
290
- traverse(sub);
291
- }
292
- }
293
- }
294
- traverse(node);
295
- return {
296
- ...selfRect,
297
- left: minLeft,
298
- top: minTop,
299
- width: maxRight - minLeft,
300
- height: maxBottom - minTop
301
- };
302
- }
303
- export { collectElementInfo, extractTextWithPosition, extractTreeNode, extractTreeNodeAsString, mergeElementAndChildrenRects };