@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.
- package/LICENSE +21 -0
- package/README.md +9 -0
- package/dist/es/component/blackboard/index.css +33 -0
- package/dist/es/component/blackboard/index.mjs +278 -0
- package/dist/es/component/config-selector/index.mjs +104 -0
- package/dist/es/component/context-preview/index.mjs +38 -0
- package/dist/es/component/env-config/index.mjs +112 -0
- package/dist/es/component/env-config-reminder/index.css +22 -0
- package/dist/es/component/env-config-reminder/index.mjs +28 -0
- package/dist/es/component/form-field/index.mjs +163 -0
- package/dist/es/component/history-selector/index.css +135 -0
- package/dist/es/component/history-selector/index.mjs +170 -0
- package/dist/es/component/index.mjs +1 -0
- package/dist/es/component/logo/index.css +13 -0
- package/dist/es/component/logo/index.mjs +20 -0
- package/dist/es/component/misc/index.mjs +94 -0
- package/dist/es/component/nav-actions/index.mjs +32 -0
- package/dist/es/component/nav-actions/style.css +35 -0
- package/dist/es/component/player/index.css +185 -0
- package/dist/es/component/player/index.mjs +856 -0
- package/dist/es/component/playground/index.css +431 -0
- package/dist/es/component/playground/index.mjs +8 -0
- package/dist/es/component/playground/playground-demo-ui-context.json +290 -0
- package/dist/es/component/playground-result/index.css +34 -0
- package/dist/es/component/playground-result/index.mjs +62 -0
- package/dist/es/component/prompt-input/index.css +391 -0
- package/dist/es/component/prompt-input/index.mjs +730 -0
- package/dist/es/component/service-mode-control/index.mjs +105 -0
- package/dist/es/component/shiny-text/index.css +75 -0
- package/dist/es/component/shiny-text/index.mjs +15 -0
- package/dist/es/component/universal-playground/index.css +341 -0
- package/dist/es/component/universal-playground/index.mjs +302 -0
- package/dist/es/component/universal-playground/providers/context-provider.mjs +52 -0
- package/dist/es/component/universal-playground/providers/indexeddb-storage-provider.mjs +207 -0
- package/dist/es/component/universal-playground/providers/storage-provider.mjs +210 -0
- package/dist/es/hooks/usePlaygroundExecution.mjs +180 -0
- package/dist/es/hooks/usePlaygroundState.mjs +203 -0
- package/dist/es/hooks/useSafeOverrideAIConfig.mjs +24 -0
- package/dist/es/hooks/useServerValid.mjs +30 -0
- package/dist/es/icons/avatar.mjs +28 -0
- package/dist/es/icons/close.mjs +19 -0
- package/dist/es/icons/global-perspective.mjs +16 -0
- package/dist/es/icons/history.mjs +30 -0
- package/dist/es/icons/magnifying-glass.mjs +39 -0
- package/dist/es/icons/player-setting.mjs +26 -0
- package/dist/es/icons/setting.mjs +20 -0
- package/dist/es/icons/show-marker.mjs +16 -0
- package/dist/es/index.mjs +25 -0
- package/dist/es/store/history.mjs +89 -0
- package/dist/es/store/store.mjs +186 -0
- package/dist/es/types.mjs +70 -0
- package/dist/es/utils/color.mjs +35 -0
- package/dist/es/utils/constants.mjs +99 -0
- package/dist/es/utils/index.mjs +10 -0
- package/dist/es/utils/pixi-loader.mjs +16 -0
- package/dist/es/utils/playground-utils.mjs +67 -0
- package/dist/es/utils/replay-scripts.mjs +312 -0
- package/dist/lib/component/blackboard/index.css +33 -0
- package/dist/lib/component/blackboard/index.js +321 -0
- package/dist/lib/component/config-selector/index.js +148 -0
- package/dist/lib/component/context-preview/index.js +83 -0
- package/dist/lib/component/env-config/index.js +146 -0
- package/dist/lib/component/env-config-reminder/index.css +22 -0
- package/dist/lib/component/env-config-reminder/index.js +62 -0
- package/dist/lib/component/form-field/index.js +209 -0
- package/dist/lib/component/history-selector/index.css +135 -0
- package/dist/lib/component/history-selector/index.js +216 -0
- package/dist/lib/component/index.js +60 -0
- package/dist/lib/component/logo/index.css +13 -0
- package/dist/lib/component/logo/index.js +57 -0
- package/dist/lib/component/misc/index.js +150 -0
- package/dist/lib/component/nav-actions/index.js +66 -0
- package/dist/lib/component/nav-actions/style.css +35 -0
- package/dist/lib/component/player/index.css +185 -0
- package/dist/lib/component/player/index.js +902 -0
- package/dist/lib/component/playground/index.css +431 -0
- package/dist/lib/component/playground/index.js +113 -0
- package/dist/lib/component/playground/playground-demo-ui-context.json +290 -0
- package/dist/lib/component/playground-result/index.css +34 -0
- package/dist/lib/component/playground-result/index.js +106 -0
- package/dist/lib/component/prompt-input/index.css +391 -0
- package/dist/lib/component/prompt-input/index.js +774 -0
- package/dist/lib/component/service-mode-control/index.js +139 -0
- package/dist/lib/component/shiny-text/index.css +75 -0
- package/dist/lib/component/shiny-text/index.js +49 -0
- package/dist/lib/component/universal-playground/index.css +341 -0
- package/dist/lib/component/universal-playground/index.js +350 -0
- package/dist/lib/component/universal-playground/providers/context-provider.js +95 -0
- package/dist/lib/component/universal-playground/providers/indexeddb-storage-provider.js +247 -0
- package/dist/lib/component/universal-playground/providers/storage-provider.js +268 -0
- package/dist/lib/hooks/usePlaygroundExecution.js +214 -0
- package/dist/lib/hooks/usePlaygroundState.js +237 -0
- package/dist/lib/hooks/useSafeOverrideAIConfig.js +61 -0
- package/dist/lib/hooks/useServerValid.js +64 -0
- package/dist/lib/icons/avatar.js +62 -0
- package/dist/lib/icons/close.js +53 -0
- package/dist/lib/icons/global-perspective.js +50 -0
- package/dist/lib/icons/history.js +64 -0
- package/dist/lib/icons/magnifying-glass.js +73 -0
- package/dist/lib/icons/player-setting.js +60 -0
- package/dist/lib/icons/setting.js +54 -0
- package/dist/lib/icons/show-marker.js +50 -0
- package/dist/lib/index.js +187 -0
- package/dist/lib/store/history.js +96 -0
- package/dist/lib/store/store.js +196 -0
- package/dist/lib/types.js +116 -0
- package/dist/lib/utils/color.js +75 -0
- package/dist/lib/utils/constants.js +154 -0
- package/dist/lib/utils/index.js +63 -0
- package/dist/lib/utils/pixi-loader.js +56 -0
- package/dist/lib/utils/playground-utils.js +110 -0
- package/dist/lib/utils/replay-scripts.js +355 -0
- package/dist/types/component/blackboard/index.d.ts +15 -0
- package/dist/types/component/config-selector/index.d.ts +9 -0
- package/dist/types/component/context-preview/index.d.ts +9 -0
- package/dist/types/component/env-config/index.d.ts +6 -0
- package/dist/types/component/env-config-reminder/index.d.ts +6 -0
- package/dist/types/component/form-field/index.d.ts +17 -0
- package/dist/types/component/history-selector/index.d.ts +10 -0
- package/dist/types/component/index.d.ts +1 -0
- package/dist/types/component/logo/index.d.ts +5 -0
- package/dist/types/component/misc/index.d.ts +6 -0
- package/dist/types/component/nav-actions/index.d.ts +10 -0
- package/dist/types/component/player/index.d.ts +13 -0
- package/dist/types/component/playground/index.d.ts +7 -0
- package/dist/types/component/playground-result/index.d.ts +20 -0
- package/dist/types/component/prompt-input/index.d.ts +22 -0
- package/dist/types/component/service-mode-control/index.d.ts +6 -0
- package/dist/types/component/shiny-text/index.d.ts +12 -0
- package/dist/types/component/universal-playground/index.d.ts +4 -0
- package/dist/types/component/universal-playground/providers/context-provider.d.ts +37 -0
- package/dist/types/component/universal-playground/providers/indexeddb-storage-provider.d.ts +71 -0
- package/dist/types/component/universal-playground/providers/storage-provider.d.ts +58 -0
- package/dist/types/hooks/usePlaygroundExecution.d.ts +10 -0
- package/dist/types/hooks/usePlaygroundState.d.ts +26 -0
- package/dist/types/hooks/useSafeOverrideAIConfig.d.ts +16 -0
- package/dist/types/hooks/useServerValid.d.ts +1 -0
- package/dist/types/index.d.ts +27 -0
- package/dist/types/store/history.d.ts +16 -0
- package/dist/types/store/store.d.ts +36 -0
- package/dist/types/types.d.ts +161 -0
- package/dist/types/utils/color.d.ts +4 -0
- package/dist/types/utils/constants.d.ts +74 -0
- package/dist/types/utils/index.d.ts +4 -0
- package/dist/types/utils/pixi-loader.d.ts +5 -0
- package/dist/types/utils/playground-utils.d.ts +6 -0
- package/dist/types/utils/replay-scripts.d.ts +34 -0
- 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 {};
|