@sqaitech/visualizer 0.30.10

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 (148) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +9 -0
  3. package/dist/es/component/blackboard/index.css +33 -0
  4. package/dist/es/component/blackboard/index.mjs +278 -0
  5. package/dist/es/component/config-selector/index.mjs +104 -0
  6. package/dist/es/component/context-preview/index.mjs +38 -0
  7. package/dist/es/component/env-config/index.mjs +112 -0
  8. package/dist/es/component/env-config-reminder/index.css +22 -0
  9. package/dist/es/component/env-config-reminder/index.mjs +28 -0
  10. package/dist/es/component/form-field/index.mjs +163 -0
  11. package/dist/es/component/history-selector/index.css +135 -0
  12. package/dist/es/component/history-selector/index.mjs +170 -0
  13. package/dist/es/component/index.mjs +1 -0
  14. package/dist/es/component/logo/index.css +13 -0
  15. package/dist/es/component/logo/index.mjs +20 -0
  16. package/dist/es/component/misc/index.mjs +94 -0
  17. package/dist/es/component/nav-actions/index.mjs +32 -0
  18. package/dist/es/component/nav-actions/style.css +35 -0
  19. package/dist/es/component/player/index.css +185 -0
  20. package/dist/es/component/player/index.mjs +856 -0
  21. package/dist/es/component/playground/index.css +431 -0
  22. package/dist/es/component/playground/index.mjs +8 -0
  23. package/dist/es/component/playground/playground-demo-ui-context.json +290 -0
  24. package/dist/es/component/playground-result/index.css +34 -0
  25. package/dist/es/component/playground-result/index.mjs +62 -0
  26. package/dist/es/component/prompt-input/index.css +391 -0
  27. package/dist/es/component/prompt-input/index.mjs +730 -0
  28. package/dist/es/component/service-mode-control/index.mjs +105 -0
  29. package/dist/es/component/shiny-text/index.css +75 -0
  30. package/dist/es/component/shiny-text/index.mjs +15 -0
  31. package/dist/es/component/universal-playground/index.css +341 -0
  32. package/dist/es/component/universal-playground/index.mjs +302 -0
  33. package/dist/es/component/universal-playground/providers/context-provider.mjs +52 -0
  34. package/dist/es/component/universal-playground/providers/indexeddb-storage-provider.mjs +207 -0
  35. package/dist/es/component/universal-playground/providers/storage-provider.mjs +210 -0
  36. package/dist/es/hooks/usePlaygroundExecution.mjs +180 -0
  37. package/dist/es/hooks/usePlaygroundState.mjs +203 -0
  38. package/dist/es/hooks/useSafeOverrideAIConfig.mjs +24 -0
  39. package/dist/es/hooks/useServerValid.mjs +30 -0
  40. package/dist/es/icons/avatar.mjs +28 -0
  41. package/dist/es/icons/close.mjs +19 -0
  42. package/dist/es/icons/global-perspective.mjs +16 -0
  43. package/dist/es/icons/history.mjs +30 -0
  44. package/dist/es/icons/magnifying-glass.mjs +39 -0
  45. package/dist/es/icons/player-setting.mjs +26 -0
  46. package/dist/es/icons/setting.mjs +20 -0
  47. package/dist/es/icons/show-marker.mjs +16 -0
  48. package/dist/es/index.mjs +25 -0
  49. package/dist/es/store/history.mjs +89 -0
  50. package/dist/es/store/store.mjs +186 -0
  51. package/dist/es/types.mjs +70 -0
  52. package/dist/es/utils/color.mjs +35 -0
  53. package/dist/es/utils/constants.mjs +99 -0
  54. package/dist/es/utils/index.mjs +10 -0
  55. package/dist/es/utils/pixi-loader.mjs +16 -0
  56. package/dist/es/utils/playground-utils.mjs +67 -0
  57. package/dist/es/utils/replay-scripts.mjs +312 -0
  58. package/dist/lib/component/blackboard/index.css +33 -0
  59. package/dist/lib/component/blackboard/index.js +321 -0
  60. package/dist/lib/component/config-selector/index.js +148 -0
  61. package/dist/lib/component/context-preview/index.js +83 -0
  62. package/dist/lib/component/env-config/index.js +146 -0
  63. package/dist/lib/component/env-config-reminder/index.css +22 -0
  64. package/dist/lib/component/env-config-reminder/index.js +62 -0
  65. package/dist/lib/component/form-field/index.js +209 -0
  66. package/dist/lib/component/history-selector/index.css +135 -0
  67. package/dist/lib/component/history-selector/index.js +216 -0
  68. package/dist/lib/component/index.js +60 -0
  69. package/dist/lib/component/logo/index.css +13 -0
  70. package/dist/lib/component/logo/index.js +57 -0
  71. package/dist/lib/component/misc/index.js +150 -0
  72. package/dist/lib/component/nav-actions/index.js +66 -0
  73. package/dist/lib/component/nav-actions/style.css +35 -0
  74. package/dist/lib/component/player/index.css +185 -0
  75. package/dist/lib/component/player/index.js +902 -0
  76. package/dist/lib/component/playground/index.css +431 -0
  77. package/dist/lib/component/playground/index.js +113 -0
  78. package/dist/lib/component/playground/playground-demo-ui-context.json +290 -0
  79. package/dist/lib/component/playground-result/index.css +34 -0
  80. package/dist/lib/component/playground-result/index.js +106 -0
  81. package/dist/lib/component/prompt-input/index.css +391 -0
  82. package/dist/lib/component/prompt-input/index.js +774 -0
  83. package/dist/lib/component/service-mode-control/index.js +139 -0
  84. package/dist/lib/component/shiny-text/index.css +75 -0
  85. package/dist/lib/component/shiny-text/index.js +49 -0
  86. package/dist/lib/component/universal-playground/index.css +341 -0
  87. package/dist/lib/component/universal-playground/index.js +350 -0
  88. package/dist/lib/component/universal-playground/providers/context-provider.js +95 -0
  89. package/dist/lib/component/universal-playground/providers/indexeddb-storage-provider.js +247 -0
  90. package/dist/lib/component/universal-playground/providers/storage-provider.js +268 -0
  91. package/dist/lib/hooks/usePlaygroundExecution.js +214 -0
  92. package/dist/lib/hooks/usePlaygroundState.js +237 -0
  93. package/dist/lib/hooks/useSafeOverrideAIConfig.js +61 -0
  94. package/dist/lib/hooks/useServerValid.js +64 -0
  95. package/dist/lib/icons/avatar.js +62 -0
  96. package/dist/lib/icons/close.js +53 -0
  97. package/dist/lib/icons/global-perspective.js +50 -0
  98. package/dist/lib/icons/history.js +64 -0
  99. package/dist/lib/icons/magnifying-glass.js +73 -0
  100. package/dist/lib/icons/player-setting.js +60 -0
  101. package/dist/lib/icons/setting.js +54 -0
  102. package/dist/lib/icons/show-marker.js +50 -0
  103. package/dist/lib/index.js +187 -0
  104. package/dist/lib/store/history.js +96 -0
  105. package/dist/lib/store/store.js +196 -0
  106. package/dist/lib/types.js +116 -0
  107. package/dist/lib/utils/color.js +75 -0
  108. package/dist/lib/utils/constants.js +154 -0
  109. package/dist/lib/utils/index.js +63 -0
  110. package/dist/lib/utils/pixi-loader.js +56 -0
  111. package/dist/lib/utils/playground-utils.js +110 -0
  112. package/dist/lib/utils/replay-scripts.js +355 -0
  113. package/dist/types/component/blackboard/index.d.ts +15 -0
  114. package/dist/types/component/config-selector/index.d.ts +9 -0
  115. package/dist/types/component/context-preview/index.d.ts +9 -0
  116. package/dist/types/component/env-config/index.d.ts +6 -0
  117. package/dist/types/component/env-config-reminder/index.d.ts +6 -0
  118. package/dist/types/component/form-field/index.d.ts +17 -0
  119. package/dist/types/component/history-selector/index.d.ts +10 -0
  120. package/dist/types/component/index.d.ts +1 -0
  121. package/dist/types/component/logo/index.d.ts +5 -0
  122. package/dist/types/component/misc/index.d.ts +6 -0
  123. package/dist/types/component/nav-actions/index.d.ts +10 -0
  124. package/dist/types/component/player/index.d.ts +13 -0
  125. package/dist/types/component/playground/index.d.ts +7 -0
  126. package/dist/types/component/playground-result/index.d.ts +20 -0
  127. package/dist/types/component/prompt-input/index.d.ts +22 -0
  128. package/dist/types/component/service-mode-control/index.d.ts +6 -0
  129. package/dist/types/component/shiny-text/index.d.ts +12 -0
  130. package/dist/types/component/universal-playground/index.d.ts +4 -0
  131. package/dist/types/component/universal-playground/providers/context-provider.d.ts +37 -0
  132. package/dist/types/component/universal-playground/providers/indexeddb-storage-provider.d.ts +71 -0
  133. package/dist/types/component/universal-playground/providers/storage-provider.d.ts +58 -0
  134. package/dist/types/hooks/usePlaygroundExecution.d.ts +10 -0
  135. package/dist/types/hooks/usePlaygroundState.d.ts +26 -0
  136. package/dist/types/hooks/useSafeOverrideAIConfig.d.ts +16 -0
  137. package/dist/types/hooks/useServerValid.d.ts +1 -0
  138. package/dist/types/index.d.ts +27 -0
  139. package/dist/types/store/history.d.ts +16 -0
  140. package/dist/types/store/store.d.ts +36 -0
  141. package/dist/types/types.d.ts +161 -0
  142. package/dist/types/utils/color.d.ts +4 -0
  143. package/dist/types/utils/constants.d.ts +74 -0
  144. package/dist/types/utils/index.d.ts +4 -0
  145. package/dist/types/utils/pixi-loader.d.ts +5 -0
  146. package/dist/types/utils/playground-utils.d.ts +6 -0
  147. package/dist/types/utils/replay-scripts.d.ts +34 -0
  148. package/package.json +85 -0
@@ -0,0 +1,63 @@
1
+ "use strict";
2
+ var __webpack_require__ = {};
3
+ (()=>{
4
+ __webpack_require__.n = (module)=>{
5
+ var getter = module && module.__esModule ? ()=>module['default'] : ()=>module;
6
+ __webpack_require__.d(getter, {
7
+ a: getter
8
+ });
9
+ return getter;
10
+ };
11
+ })();
12
+ (()=>{
13
+ __webpack_require__.d = (exports1, definition)=>{
14
+ for(var key in definition)if (__webpack_require__.o(definition, key) && !__webpack_require__.o(exports1, key)) Object.defineProperty(exports1, key, {
15
+ enumerable: true,
16
+ get: definition[key]
17
+ });
18
+ };
19
+ })();
20
+ (()=>{
21
+ __webpack_require__.o = (obj, prop)=>Object.prototype.hasOwnProperty.call(obj, prop);
22
+ })();
23
+ (()=>{
24
+ __webpack_require__.r = (exports1)=>{
25
+ if ('undefined' != typeof Symbol && Symbol.toStringTag) Object.defineProperty(exports1, Symbol.toStringTag, {
26
+ value: 'Module'
27
+ });
28
+ Object.defineProperty(exports1, '__esModule', {
29
+ value: true
30
+ });
31
+ };
32
+ })();
33
+ var __webpack_exports__ = {};
34
+ __webpack_require__.r(__webpack_exports__);
35
+ __webpack_require__.d(__webpack_exports__, {
36
+ filterBase64Value: ()=>filterBase64Value,
37
+ mouseLoading: ()=>mouseLoading,
38
+ timeStr: ()=>timeStr,
39
+ mousePointer: ()=>mousePointer
40
+ });
41
+ const external_dayjs_namespaceObject = require("dayjs");
42
+ var external_dayjs_default = /*#__PURE__*/ __webpack_require__.n(external_dayjs_namespaceObject);
43
+ function timeStr(timestamp) {
44
+ return timestamp ? external_dayjs_default()(timestamp).format('YYYY-MM-DD HH:mm:ss') : '-';
45
+ }
46
+ function filterBase64Value(input) {
47
+ return input.replace(/data:image\/[^"]+"/g, 'data:image..."');
48
+ }
49
+ const mousePointer = '';
50
+ const mouseLoading = '';
51
+ exports.filterBase64Value = __webpack_exports__.filterBase64Value;
52
+ exports.mouseLoading = __webpack_exports__.mouseLoading;
53
+ exports.mousePointer = __webpack_exports__.mousePointer;
54
+ exports.timeStr = __webpack_exports__.timeStr;
55
+ for(var __webpack_i__ in __webpack_exports__)if (-1 === [
56
+ "filterBase64Value",
57
+ "mouseLoading",
58
+ "mousePointer",
59
+ "timeStr"
60
+ ].indexOf(__webpack_i__)) exports[__webpack_i__] = __webpack_exports__[__webpack_i__];
61
+ Object.defineProperty(exports, '__esModule', {
62
+ value: true
63
+ });
@@ -0,0 +1,56 @@
1
+ "use strict";
2
+ var __webpack_require__ = {};
3
+ (()=>{
4
+ __webpack_require__.d = (exports1, definition)=>{
5
+ for(var key in definition)if (__webpack_require__.o(definition, key) && !__webpack_require__.o(exports1, key)) Object.defineProperty(exports1, key, {
6
+ enumerable: true,
7
+ get: definition[key]
8
+ });
9
+ };
10
+ })();
11
+ (()=>{
12
+ __webpack_require__.o = (obj, prop)=>Object.prototype.hasOwnProperty.call(obj, prop);
13
+ })();
14
+ (()=>{
15
+ __webpack_require__.r = (exports1)=>{
16
+ if ('undefined' != typeof Symbol && Symbol.toStringTag) Object.defineProperty(exports1, Symbol.toStringTag, {
17
+ value: 'Module'
18
+ });
19
+ Object.defineProperty(exports1, '__esModule', {
20
+ value: true
21
+ });
22
+ };
23
+ })();
24
+ var __webpack_exports__ = {};
25
+ __webpack_require__.r(__webpack_exports__);
26
+ __webpack_require__.d(__webpack_exports__, {
27
+ getTexture: ()=>getTexture,
28
+ getTextureFromCache: ()=>getTextureFromCache,
29
+ loadTexture: ()=>loadTexture
30
+ });
31
+ require("pixi.js/unsafe-eval");
32
+ const external_pixi_js_namespaceObject = require("pixi.js");
33
+ const globalTextureMap = new Map();
34
+ const loadTexture = async (img)=>{
35
+ if (globalTextureMap.has(img)) return;
36
+ return external_pixi_js_namespaceObject.Assets.load(img).then((texture)=>{
37
+ globalTextureMap.set(img, texture);
38
+ });
39
+ };
40
+ const getTextureFromCache = (name)=>globalTextureMap.get(name);
41
+ const getTexture = async (name)=>{
42
+ if (globalTextureMap.has(name)) return globalTextureMap.get(name);
43
+ await loadTexture(name);
44
+ return globalTextureMap.get(name);
45
+ };
46
+ exports.getTexture = __webpack_exports__.getTexture;
47
+ exports.getTextureFromCache = __webpack_exports__.getTextureFromCache;
48
+ exports.loadTexture = __webpack_exports__.loadTexture;
49
+ for(var __webpack_i__ in __webpack_exports__)if (-1 === [
50
+ "getTexture",
51
+ "getTextureFromCache",
52
+ "loadTexture"
53
+ ].indexOf(__webpack_i__)) exports[__webpack_i__] = __webpack_exports__[__webpack_i__];
54
+ Object.defineProperty(exports, '__esModule', {
55
+ value: true
56
+ });
@@ -0,0 +1,110 @@
1
+ "use strict";
2
+ var __webpack_require__ = {};
3
+ (()=>{
4
+ __webpack_require__.d = (exports1, definition)=>{
5
+ for(var key in definition)if (__webpack_require__.o(definition, key) && !__webpack_require__.o(exports1, key)) Object.defineProperty(exports1, key, {
6
+ enumerable: true,
7
+ get: definition[key]
8
+ });
9
+ };
10
+ })();
11
+ (()=>{
12
+ __webpack_require__.o = (obj, prop)=>Object.prototype.hasOwnProperty.call(obj, prop);
13
+ })();
14
+ (()=>{
15
+ __webpack_require__.r = (exports1)=>{
16
+ if ('undefined' != typeof Symbol && Symbol.toStringTag) Object.defineProperty(exports1, Symbol.toStringTag, {
17
+ value: 'Module'
18
+ });
19
+ Object.defineProperty(exports1, '__esModule', {
20
+ value: true
21
+ });
22
+ };
23
+ })();
24
+ var __webpack_exports__ = {};
25
+ __webpack_require__.r(__webpack_exports__);
26
+ __webpack_require__.d(__webpack_exports__, {
27
+ staticAgentFromContext: ()=>staticAgentFromContext,
28
+ actionNameForType: ()=>actionNameForType,
29
+ isRunButtonEnabled: ()=>isRunButtonEnabled,
30
+ getPlaceholderForType: ()=>getPlaceholderForType
31
+ });
32
+ const static_namespaceObject = require("@sqaitech/web/static");
33
+ const external_types_js_namespaceObject = require("../types.js");
34
+ const actionNameForType = (type)=>{
35
+ const typeWithoutAi = type.startsWith('ai') ? type.slice(2) : type;
36
+ if (typeWithoutAi.startsWith('IOS')) return typeWithoutAi.substring(3).replace(/([A-Z])/g, ' $1').replace(/^/, 'IOS').trim();
37
+ const fullName = typeWithoutAi.replace(/([A-Z])/g, ' $1').trim();
38
+ const words = fullName.split(' ');
39
+ if (words.length > 3) return words.slice(-3).join(' ');
40
+ return fullName;
41
+ };
42
+ const staticAgentFromContext = (context)=>{
43
+ const page = new static_namespaceObject.StaticPage(context);
44
+ return new static_namespaceObject.StaticPageAgent(page);
45
+ };
46
+ const getPlaceholderForType = (type)=>{
47
+ if ('aiQuery' === type) return 'What do you want to query?';
48
+ if ('aiAssert' === type) return 'What do you want to assert?';
49
+ if ('aiTap' === type) return 'What element do you want to tap?';
50
+ if ('aiDoubleClick' === type) return 'What element do you want to double-click?';
51
+ if ('aiHover' === type) return 'What element do you want to hover over?';
52
+ if ('aiInput' === type) return 'Format: <value> | <element>\nExample: hello world | search box';
53
+ if ('aiRightClick' === type) return 'What element do you want to right-click?';
54
+ if ('aiKeyboardPress' === type) return 'Format: <key> | <element (optional)>\nExample: Enter | text field';
55
+ if ('aiScroll' === type) return 'Format: <direction> <amount> | <element (optional)>\nExample: down 500 | main content';
56
+ if ('aiLocate' === type) return 'What element do you want to locate?';
57
+ if ('aiBoolean' === type) return 'What do you want to check (returns true/false)?';
58
+ if ('aiNumber' === type) return 'What number do you want to extract?';
59
+ if ('aiString' === type) return 'What text do you want to extract?';
60
+ if ('aiAsk' === type) return 'What do you want to ask?';
61
+ if ('aiWaitFor' === type) return 'What condition do you want to wait for?';
62
+ return 'What do you want to do?';
63
+ };
64
+ const isRunButtonEnabled = (runButtonEnabled, needsStructuredParams, params, actionSpace, selectedType, promptValue)=>{
65
+ if (!runButtonEnabled) return false;
66
+ const needsAnyInput = (()=>{
67
+ if (actionSpace) {
68
+ const action = actionSpace.find((a)=>a.interfaceAlias === selectedType || a.name === selectedType);
69
+ if (action) {
70
+ if (!action.paramSchema) return false;
71
+ if ('object' == typeof action.paramSchema && 'shape' in action.paramSchema) {
72
+ const shape = action.paramSchema.shape || {};
73
+ const shapeKeys = Object.keys(shape);
74
+ return shapeKeys.length > 0;
75
+ }
76
+ }
77
+ }
78
+ return true;
79
+ })();
80
+ if (!needsAnyInput) return true;
81
+ if (needsStructuredParams) {
82
+ const currentParams = params || {};
83
+ const action = null == actionSpace ? void 0 : actionSpace.find((a)=>a.interfaceAlias === selectedType || a.name === selectedType);
84
+ if ((null == action ? void 0 : action.paramSchema) && (0, external_types_js_namespaceObject.isZodObjectSchema)(action.paramSchema)) {
85
+ const schema = action.paramSchema;
86
+ const shape = schema.shape || {};
87
+ return Object.keys(shape).every((key)=>{
88
+ const field = shape[key];
89
+ const { isOptional } = (0, external_types_js_namespaceObject.unwrapZodType)(field);
90
+ const value = currentParams[key];
91
+ return isOptional || void 0 !== value && '' !== value && null !== value;
92
+ });
93
+ }
94
+ return true;
95
+ }
96
+ return promptValue.trim().length > 0;
97
+ };
98
+ exports.actionNameForType = __webpack_exports__.actionNameForType;
99
+ exports.getPlaceholderForType = __webpack_exports__.getPlaceholderForType;
100
+ exports.isRunButtonEnabled = __webpack_exports__.isRunButtonEnabled;
101
+ exports.staticAgentFromContext = __webpack_exports__.staticAgentFromContext;
102
+ for(var __webpack_i__ in __webpack_exports__)if (-1 === [
103
+ "actionNameForType",
104
+ "getPlaceholderForType",
105
+ "isRunButtonEnabled",
106
+ "staticAgentFromContext"
107
+ ].indexOf(__webpack_i__)) exports[__webpack_i__] = __webpack_exports__[__webpack_i__];
108
+ Object.defineProperty(exports, '__esModule', {
109
+ value: true
110
+ });
@@ -0,0 +1,355 @@
1
+ 'use client';
2
+ "use strict";
3
+ var __webpack_require__ = {};
4
+ (()=>{
5
+ __webpack_require__.d = (exports1, definition)=>{
6
+ for(var key in definition)if (__webpack_require__.o(definition, key) && !__webpack_require__.o(exports1, key)) Object.defineProperty(exports1, key, {
7
+ enumerable: true,
8
+ get: definition[key]
9
+ });
10
+ };
11
+ })();
12
+ (()=>{
13
+ __webpack_require__.o = (obj, prop)=>Object.prototype.hasOwnProperty.call(obj, prop);
14
+ })();
15
+ (()=>{
16
+ __webpack_require__.r = (exports1)=>{
17
+ if ('undefined' != typeof Symbol && Symbol.toStringTag) Object.defineProperty(exports1, Symbol.toStringTag, {
18
+ value: 'Module'
19
+ });
20
+ Object.defineProperty(exports1, '__esModule', {
21
+ value: true
22
+ });
23
+ };
24
+ })();
25
+ var __webpack_exports__ = {};
26
+ __webpack_require__.r(__webpack_exports__);
27
+ __webpack_require__.d(__webpack_exports__, {
28
+ cameraStateForRect: ()=>cameraStateForRect,
29
+ mergeTwoCameraState: ()=>mergeTwoCameraState,
30
+ generateAnimationScripts: ()=>generateAnimationScripts,
31
+ allScriptsFromDump: ()=>allScriptsFromDump
32
+ });
33
+ const external_index_js_namespaceObject = require("./index.js");
34
+ const agent_namespaceObject = require("@sqaitech/core/agent");
35
+ const extractor_namespaceObject = require("@sqaitech/shared/extractor");
36
+ const stillDuration = 900;
37
+ const actionSpinningPointerDuration = 300;
38
+ const stillAfterInsightDuration = 300;
39
+ const locateDuration = 800;
40
+ const actionDuration = 1000;
41
+ const clearInsightDuration = 200;
42
+ const cameraStateForRect = (rect, imageWidth, imageHeight)=>{
43
+ const canvasRatio = imageWidth / imageHeight;
44
+ const rectRatio = rect.width / rect.height;
45
+ let rectWidthOnPage;
46
+ rectWidthOnPage = rectRatio >= canvasRatio ? rect.width : rect.height / imageHeight * imageWidth;
47
+ const cameraPaddingRatio = rectWidthOnPage > 400 ? 0.1 : rectWidthOnPage > 50 ? 0.2 : 0.3;
48
+ const cameraWidth = Math.min(imageWidth, rectWidthOnPage + imageWidth * cameraPaddingRatio * 2);
49
+ const cameraHeight = imageHeight / imageWidth * cameraWidth;
50
+ let left = Math.min(rect.left - imageWidth * cameraPaddingRatio, imageWidth - cameraWidth);
51
+ left = Math.max(left, 0);
52
+ let top = Math.min(rect.top - imageHeight * cameraPaddingRatio, imageHeight - cameraHeight);
53
+ top = Math.max(top, 0);
54
+ return {
55
+ left: Math.round(left),
56
+ top: Math.round(top),
57
+ width: Math.round(cameraWidth)
58
+ };
59
+ };
60
+ const mergeTwoCameraState = (cameraState1, cameraState2)=>{
61
+ const newLeft = Math.min(cameraState1.left, cameraState2.left);
62
+ const newTop = Math.min(cameraState1.top, cameraState2.top);
63
+ const newRight = Math.max(cameraState1.left + cameraState1.width, cameraState2.left + cameraState2.width);
64
+ const newWidth = newRight - newLeft;
65
+ return {
66
+ left: newLeft,
67
+ top: newTop,
68
+ width: newWidth
69
+ };
70
+ };
71
+ const capitalizeFirstLetter = (str)=>{
72
+ if ('string' != typeof str || 0 === str.length) return str;
73
+ return str.charAt(0).toUpperCase() + str.slice(1);
74
+ };
75
+ const allScriptsFromDump = (dump)=>{
76
+ const dimensionsSet = new Set();
77
+ let firstWidth;
78
+ let firstHeight;
79
+ const sdkVersion = dump.sdkVersion;
80
+ const modelBriefsSet = new Set();
81
+ dump.executions.forEach((execution)=>{
82
+ execution.tasks.forEach((task)=>{
83
+ var _task_uiContext_size, _task_uiContext;
84
+ if (null == (_task_uiContext = task.uiContext) ? void 0 : null == (_task_uiContext_size = _task_uiContext.size) ? void 0 : _task_uiContext_size.width) {
85
+ const w = task.uiContext.size.width;
86
+ const h = task.uiContext.size.height;
87
+ if (!firstWidth) {
88
+ firstWidth = w;
89
+ firstHeight = h;
90
+ }
91
+ dimensionsSet.add(`${w}x${h}`);
92
+ }
93
+ });
94
+ });
95
+ if (!firstWidth || !firstHeight) {
96
+ console.warn('width or height is missing in dump file');
97
+ return {
98
+ scripts: [],
99
+ sdkVersion,
100
+ modelBriefs: []
101
+ };
102
+ }
103
+ const allScripts = [];
104
+ dump.executions.forEach((execution)=>{
105
+ const scripts = generateAnimationScripts(execution, -1, firstWidth, firstHeight);
106
+ if (scripts) allScripts.push(...scripts);
107
+ execution.tasks.forEach((task)=>{
108
+ if (task.usage) {
109
+ const { model_name, model_description, intent } = task.usage;
110
+ if (intent && model_name) modelBriefsSet.add(model_description ? `${capitalizeFirstLetter(intent)}/${model_name}(${model_description})` : model_name);
111
+ }
112
+ });
113
+ });
114
+ const allScriptsWithoutIntermediateDoneFrame = allScripts.filter((script, index)=>{
115
+ if (index !== allScripts.length - 1 && 'Done' === script.title) return false;
116
+ return true;
117
+ });
118
+ const modelBriefs = (()=>{
119
+ var _list_;
120
+ const list = [
121
+ ...modelBriefsSet
122
+ ];
123
+ if (!list.length) return list;
124
+ const firstOneInfo = null == (_list_ = list[0]) ? void 0 : _list_.split('/', 2)[1];
125
+ if (firstOneInfo && list.slice(1).every((item)=>(null == item ? void 0 : item.split('/', 2)[1]) === firstOneInfo)) return [
126
+ firstOneInfo
127
+ ];
128
+ return list;
129
+ })();
130
+ return {
131
+ scripts: allScriptsWithoutIntermediateDoneFrame,
132
+ width: firstWidth,
133
+ height: firstHeight,
134
+ sdkVersion,
135
+ modelBriefs
136
+ };
137
+ };
138
+ const generateAnimationScripts = (execution, task, imageWidth, imageHeight)=>{
139
+ if (!execution || !execution.tasks.length) return null;
140
+ if (0 === imageWidth || 0 === imageHeight) return null;
141
+ let tasksIncluded = [];
142
+ if (-1 === task) tasksIncluded = execution.tasks;
143
+ else {
144
+ const startIndex = execution.tasks.findIndex((t)=>t === task);
145
+ if (-1 === startIndex) {
146
+ console.error("task not found, cannot generate animation scripts");
147
+ return null;
148
+ }
149
+ if (startIndex === execution.tasks.length - 1) return null;
150
+ for(let i = startIndex; i < execution.tasks.length; i++){
151
+ if (i > startIndex && 'Planning' === execution.tasks[i].type) break;
152
+ tasksIncluded.push(execution.tasks[i]);
153
+ }
154
+ }
155
+ if (0 === tasksIncluded.length) return null;
156
+ const fullPageCameraState = cameraStateForRect({
157
+ left: 0,
158
+ top: 0,
159
+ width: imageWidth,
160
+ height: imageHeight
161
+ }, imageWidth, imageHeight);
162
+ const pointerScript = (img, title, subTitle)=>({
163
+ type: 'pointer',
164
+ img,
165
+ duration: 0,
166
+ title,
167
+ subTitle
168
+ });
169
+ const scripts = [];
170
+ let insightCameraState;
171
+ let currentCameraState = fullPageCameraState;
172
+ let insightOnTop = false;
173
+ const taskCount = tasksIncluded.length;
174
+ let initSubTitle = '';
175
+ let errorStateFlag = false;
176
+ tasksIncluded.forEach((task, index)=>{
177
+ if (errorStateFlag) return;
178
+ if (0 === index) initSubTitle = (0, agent_namespaceObject.paramStr)(task);
179
+ if ('Planning' === task.type) {
180
+ const planningTask = task;
181
+ if (planningTask.recorder && planningTask.recorder.length > 0) {
182
+ var _planningTask_recorder_, _planningTask_recorder, _task_uiContext_size, _task_uiContext, _task_uiContext_size1, _task_uiContext1;
183
+ scripts.push({
184
+ type: 'img',
185
+ img: null == (_planningTask_recorder = planningTask.recorder) ? void 0 : null == (_planningTask_recorder_ = _planningTask_recorder[0]) ? void 0 : _planningTask_recorder_.screenshot,
186
+ camera: 0 === index ? fullPageCameraState : void 0,
187
+ duration: stillDuration,
188
+ title: (0, agent_namespaceObject.typeStr)(task),
189
+ subTitle: (0, agent_namespaceObject.paramStr)(task),
190
+ imageWidth: (null == (_task_uiContext = task.uiContext) ? void 0 : null == (_task_uiContext_size = _task_uiContext.size) ? void 0 : _task_uiContext_size.width) || imageWidth,
191
+ imageHeight: (null == (_task_uiContext1 = task.uiContext) ? void 0 : null == (_task_uiContext_size1 = _task_uiContext1.size) ? void 0 : _task_uiContext_size1.height) || imageHeight
192
+ });
193
+ }
194
+ } else if ('Insight' === task.type && 'Locate' === task.subType) {
195
+ var _insightTask_output;
196
+ const insightTask = task;
197
+ const resultElement = null == (_insightTask_output = insightTask.output) ? void 0 : _insightTask_output.element;
198
+ const title = (0, agent_namespaceObject.typeStr)(task);
199
+ const subTitle = (0, agent_namespaceObject.paramStr)(task);
200
+ if (null == resultElement ? void 0 : resultElement.rect) insightCameraState = {
201
+ ...cameraStateForRect(resultElement.rect, imageWidth, imageHeight),
202
+ pointerLeft: resultElement.center[0],
203
+ pointerTop: resultElement.center[1]
204
+ };
205
+ const context = insightTask.uiContext;
206
+ if (null == context ? void 0 : context.screenshotBase64) {
207
+ var _insightTask_output1, _insightDump_taskInfo, _context_size, _context_size1;
208
+ const insightDump = insightTask.log;
209
+ const insightContentLength = context.tree ? (0, extractor_namespaceObject.treeToList)(context.tree).length : 0;
210
+ if (context.screenshotBase64) {
211
+ var _context_size2, _context_size3;
212
+ scripts.push({
213
+ type: 'img',
214
+ img: context.screenshotBase64,
215
+ duration: stillAfterInsightDuration,
216
+ title,
217
+ subTitle,
218
+ imageWidth: (null == (_context_size2 = context.size) ? void 0 : _context_size2.width) || imageWidth,
219
+ imageHeight: (null == (_context_size3 = context.size) ? void 0 : _context_size3.height) || imageHeight
220
+ });
221
+ }
222
+ let cameraState;
223
+ cameraState = currentCameraState === fullPageCameraState ? void 0 : insightCameraState ? mergeTwoCameraState(currentCameraState, insightCameraState) : void 0;
224
+ scripts.push({
225
+ type: 'insight',
226
+ img: context.screenshotBase64,
227
+ context: context,
228
+ camera: cameraState,
229
+ highlightElement: (null == (_insightTask_output1 = insightTask.output) ? void 0 : _insightTask_output1.element) || void 0,
230
+ searchArea: null == insightDump ? void 0 : null == (_insightDump_taskInfo = insightDump.taskInfo) ? void 0 : _insightDump_taskInfo.searchArea,
231
+ duration: insightContentLength > 20 ? locateDuration : 0.5 * locateDuration,
232
+ insightCameraDuration: locateDuration,
233
+ title,
234
+ subTitle,
235
+ imageWidth: (null == (_context_size = context.size) ? void 0 : _context_size.width) || imageWidth,
236
+ imageHeight: (null == (_context_size1 = context.size) ? void 0 : _context_size1.height) || imageHeight
237
+ });
238
+ scripts.push({
239
+ type: 'sleep',
240
+ duration: stillAfterInsightDuration,
241
+ title,
242
+ subTitle
243
+ });
244
+ insightOnTop = true;
245
+ }
246
+ } else if ('Action' === task.type && 'FalsyConditionStatement' !== task.subType) {
247
+ var _task_recorder_, _task_recorder, _task_uiContext_size2, _task_uiContext2, _task_uiContext_size3, _task_uiContext3, _task_recorder_1, _task_recorder1;
248
+ const title = (0, agent_namespaceObject.typeStr)(task);
249
+ const subTitle = (0, agent_namespaceObject.paramStr)(task);
250
+ scripts.push(pointerScript(external_index_js_namespaceObject.mousePointer, title, subTitle));
251
+ currentCameraState = null != insightCameraState ? insightCameraState : fullPageCameraState;
252
+ scripts.push({
253
+ type: 'img',
254
+ img: null == (_task_recorder = task.recorder) ? void 0 : null == (_task_recorder_ = _task_recorder[0]) ? void 0 : _task_recorder_.screenshot,
255
+ duration: actionDuration,
256
+ camera: 'Sleep' === task.subType ? fullPageCameraState : insightCameraState,
257
+ title,
258
+ subTitle,
259
+ imageWidth: (null == (_task_uiContext2 = task.uiContext) ? void 0 : null == (_task_uiContext_size2 = _task_uiContext2.size) ? void 0 : _task_uiContext_size2.width) || imageWidth,
260
+ imageHeight: (null == (_task_uiContext3 = task.uiContext) ? void 0 : null == (_task_uiContext_size3 = _task_uiContext3.size) ? void 0 : _task_uiContext_size3.height) || imageHeight
261
+ });
262
+ if (insightOnTop) {
263
+ scripts.push({
264
+ type: 'clear-insight',
265
+ duration: clearInsightDuration,
266
+ title,
267
+ subTitle
268
+ });
269
+ insightOnTop = false;
270
+ }
271
+ const imgStillDuration = index < taskCount - 1 ? stillDuration : 0;
272
+ if (null == (_task_recorder1 = task.recorder) ? void 0 : null == (_task_recorder_1 = _task_recorder1[1]) ? void 0 : _task_recorder_1.screenshot) {
273
+ var _task_recorder_2, _task_recorder2, _task_uiContext_size4, _task_uiContext4, _task_uiContext_size5, _task_uiContext5;
274
+ scripts.push({
275
+ type: 'spinning-pointer',
276
+ duration: actionSpinningPointerDuration,
277
+ title,
278
+ subTitle
279
+ });
280
+ scripts.push(pointerScript(external_index_js_namespaceObject.mousePointer, title, subTitle));
281
+ scripts.push({
282
+ type: 'img',
283
+ img: null == (_task_recorder2 = task.recorder) ? void 0 : null == (_task_recorder_2 = _task_recorder2[1]) ? void 0 : _task_recorder_2.screenshot,
284
+ duration: imgStillDuration,
285
+ title,
286
+ subTitle,
287
+ imageWidth: (null == (_task_uiContext4 = task.uiContext) ? void 0 : null == (_task_uiContext_size4 = _task_uiContext4.size) ? void 0 : _task_uiContext_size4.width) || imageWidth,
288
+ imageHeight: (null == (_task_uiContext5 = task.uiContext) ? void 0 : null == (_task_uiContext_size5 = _task_uiContext5.size) ? void 0 : _task_uiContext_size5.height) || imageHeight
289
+ });
290
+ } else scripts.push({
291
+ type: 'sleep',
292
+ duration: imgStillDuration,
293
+ title,
294
+ subTitle
295
+ });
296
+ } else {
297
+ var _task_recorder_3, _task_recorder3;
298
+ const title = (0, agent_namespaceObject.typeStr)(task);
299
+ const subTitle = (0, agent_namespaceObject.paramStr)(task);
300
+ const screenshot = null == (_task_recorder3 = task.recorder) ? void 0 : null == (_task_recorder_3 = _task_recorder3[task.recorder.length - 1]) ? void 0 : _task_recorder_3.screenshot;
301
+ if (screenshot) {
302
+ var _task_uiContext_size6, _task_uiContext6, _task_uiContext_size7, _task_uiContext7;
303
+ scripts.push({
304
+ type: 'img',
305
+ img: screenshot,
306
+ duration: stillDuration,
307
+ camera: fullPageCameraState,
308
+ title,
309
+ subTitle,
310
+ imageWidth: (null == (_task_uiContext6 = task.uiContext) ? void 0 : null == (_task_uiContext_size6 = _task_uiContext6.size) ? void 0 : _task_uiContext_size6.width) || imageWidth,
311
+ imageHeight: (null == (_task_uiContext7 = task.uiContext) ? void 0 : null == (_task_uiContext_size7 = _task_uiContext7.size) ? void 0 : _task_uiContext_size7.height) || imageHeight
312
+ });
313
+ }
314
+ }
315
+ if ('finished' !== task.status) {
316
+ var _task_uiContext_size8, _task_uiContext8, _task_uiContext_size9, _task_uiContext9;
317
+ errorStateFlag = true;
318
+ const errorTitle = (0, agent_namespaceObject.typeStr)(task);
319
+ const errorMsg = task.errorMessage || 'unknown error';
320
+ const errorSubTitle = errorMsg.indexOf('NOT_IMPLEMENTED_AS_DESIGNED') > 0 ? 'Further actions cannot be performed in the current environment' : errorMsg;
321
+ scripts.push({
322
+ type: 'img',
323
+ img: task.recorder && task.recorder.length > 0 ? task.recorder[task.recorder.length - 1].screenshot : '',
324
+ camera: fullPageCameraState,
325
+ duration: stillDuration,
326
+ title: errorTitle,
327
+ subTitle: errorSubTitle,
328
+ imageWidth: (null == (_task_uiContext8 = task.uiContext) ? void 0 : null == (_task_uiContext_size8 = _task_uiContext8.size) ? void 0 : _task_uiContext_size8.width) || imageWidth,
329
+ imageHeight: (null == (_task_uiContext9 = task.uiContext) ? void 0 : null == (_task_uiContext_size9 = _task_uiContext9.size) ? void 0 : _task_uiContext_size9.height) || imageHeight
330
+ });
331
+ return;
332
+ }
333
+ });
334
+ if (!errorStateFlag) scripts.push({
335
+ title: 'Done',
336
+ subTitle: initSubTitle,
337
+ type: 'img',
338
+ duration: stillDuration,
339
+ camera: fullPageCameraState
340
+ });
341
+ return scripts;
342
+ };
343
+ exports.allScriptsFromDump = __webpack_exports__.allScriptsFromDump;
344
+ exports.cameraStateForRect = __webpack_exports__.cameraStateForRect;
345
+ exports.generateAnimationScripts = __webpack_exports__.generateAnimationScripts;
346
+ exports.mergeTwoCameraState = __webpack_exports__.mergeTwoCameraState;
347
+ for(var __webpack_i__ in __webpack_exports__)if (-1 === [
348
+ "allScriptsFromDump",
349
+ "cameraStateForRect",
350
+ "generateAnimationScripts",
351
+ "mergeTwoCameraState"
352
+ ].indexOf(__webpack_i__)) exports[__webpack_i__] = __webpack_exports__[__webpack_i__];
353
+ Object.defineProperty(exports, '__esModule', {
354
+ value: true
355
+ });
@@ -0,0 +1,15 @@
1
+ import 'pixi.js/unsafe-eval';
2
+ import type { BaseElement, Rect, UIContext } from '@sqaitech/core';
3
+ import * as PIXI from 'pixi.js';
4
+ import './index.less';
5
+ export declare const pointMarkForItem: (point: [number, number], type: "highlightPoint") => PIXI.Graphics;
6
+ export declare const rectMarkForItem: (rect: Rect, name: string, type: "element" | "searchArea" | "highlight") => (PIXI.Graphics | PIXI.Text)[];
7
+ export declare const Blackboard: (props: {
8
+ uiContext: UIContext;
9
+ highlightElements?: BaseElement[];
10
+ highlightRect?: Rect;
11
+ highlightPoints?: [number, number][];
12
+ hideController?: boolean;
13
+ onCanvasClick?: (position: [number, number]) => void;
14
+ }) => import("react").JSX.Element;
15
+ export default Blackboard;
@@ -0,0 +1,9 @@
1
+ import type React from 'react';
2
+ interface ConfigSelectorProps {
3
+ showDeepThinkOption: boolean;
4
+ enableTracking: boolean;
5
+ showDataExtractionOptions: boolean;
6
+ hideDomAndScreenshotOptions?: boolean;
7
+ }
8
+ export declare const ConfigSelector: React.FC<ConfigSelectorProps>;
9
+ export {};
@@ -0,0 +1,9 @@
1
+ import type { UIContext } from '@sqaitech/core';
2
+ import type React from 'react';
3
+ interface ContextPreviewProps {
4
+ uiContextPreview: UIContext | undefined;
5
+ setUiContextPreview: (context: UIContext) => void;
6
+ showContextPreview: boolean;
7
+ }
8
+ export declare const ContextPreview: React.FC<ContextPreviewProps>;
9
+ export {};