@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,74 @@
1
+ import type { InfoListItem, PlaygroundResult } from '../types';
2
+ export declare const trackingTip = "limit popup to current tab";
3
+ export declare const deepThinkTip = "deep think";
4
+ export declare const screenshotIncludedTip = "include screenshot in request";
5
+ export declare const domIncludedTip = "include DOM info in request";
6
+ export declare const apiMetadata: {
7
+ aiAction: {
8
+ group: string;
9
+ title: string;
10
+ };
11
+ aiTap: {
12
+ group: string;
13
+ title: string;
14
+ };
15
+ aiDoubleClick: {
16
+ group: string;
17
+ title: string;
18
+ };
19
+ aiHover: {
20
+ group: string;
21
+ title: string;
22
+ };
23
+ aiInput: {
24
+ group: string;
25
+ title: string;
26
+ };
27
+ aiRightClick: {
28
+ group: string;
29
+ title: string;
30
+ };
31
+ aiKeyboardPress: {
32
+ group: string;
33
+ title: string;
34
+ };
35
+ aiScroll: {
36
+ group: string;
37
+ title: string;
38
+ };
39
+ aiLocate: {
40
+ group: string;
41
+ title: string;
42
+ };
43
+ aiQuery: {
44
+ group: string;
45
+ title: string;
46
+ };
47
+ aiBoolean: {
48
+ group: string;
49
+ title: string;
50
+ };
51
+ aiNumber: {
52
+ group: string;
53
+ title: string;
54
+ };
55
+ aiString: {
56
+ group: string;
57
+ title: string;
58
+ };
59
+ aiAsk: {
60
+ group: string;
61
+ title: string;
62
+ };
63
+ aiAssert: {
64
+ group: string;
65
+ title: string;
66
+ };
67
+ aiWaitFor: {
68
+ group: string;
69
+ title: string;
70
+ };
71
+ };
72
+ export declare const defaultMainButtons: string[];
73
+ export declare const WELCOME_MESSAGE_TEMPLATE: Omit<InfoListItem, 'id' | 'timestamp'>;
74
+ export declare const BLANK_RESULT: PlaygroundResult;
@@ -0,0 +1,4 @@
1
+ export declare function timeStr(timestamp?: number): string;
2
+ export declare function filterBase64Value(input: string): string;
3
+ export declare const mousePointer = "";
4
+ export declare const mouseLoading = "";
@@ -0,0 +1,5 @@
1
+ import 'pixi.js/unsafe-eval';
2
+ import * as PIXI from 'pixi.js';
3
+ export declare const loadTexture: (img: string) => Promise<void>;
4
+ export declare const getTextureFromCache: (name: string) => PIXI.Texture | undefined;
5
+ export declare const getTexture: (name: string) => Promise<PIXI.Texture | undefined>;
@@ -0,0 +1,6 @@
1
+ import type { WebUIContext } from '@sqaitech/core';
2
+ import { StaticPageAgent } from '@sqaitech/web/static';
3
+ export declare const actionNameForType: (type: string) => string;
4
+ export declare const staticAgentFromContext: (context: WebUIContext) => StaticPageAgent;
5
+ export declare const getPlaceholderForType: (type: string) => string;
6
+ export declare const isRunButtonEnabled: (runButtonEnabled: boolean, needsStructuredParams: boolean, params: any, actionSpace: any[] | undefined, selectedType: string, promptValue: string) => boolean;
@@ -0,0 +1,34 @@
1
+ import type { ExecutionDump, ExecutionTask, GroupedActionDump, LocateResultElement, Rect, UIContext } from '@sqaitech/core';
2
+ export interface CameraState {
3
+ left: number;
4
+ top: number;
5
+ width: number;
6
+ pointerLeft: number;
7
+ pointerTop: number;
8
+ }
9
+ export type TargetCameraState = Omit<CameraState, 'pointerLeft' | 'pointerTop'> & Partial<Pick<CameraState, 'pointerLeft' | 'pointerTop'>>;
10
+ export interface AnimationScript {
11
+ type: 'img' | 'insight' | 'clear-insight' | 'pointer' | 'spinning-pointer' | 'sleep';
12
+ img?: string;
13
+ camera?: TargetCameraState;
14
+ context?: UIContext;
15
+ highlightElement?: LocateResultElement;
16
+ searchArea?: Rect;
17
+ duration: number;
18
+ insightCameraDuration?: number;
19
+ title?: string;
20
+ subTitle?: string;
21
+ imageWidth?: number;
22
+ imageHeight?: number;
23
+ }
24
+ export declare const cameraStateForRect: (rect: Rect, imageWidth: number, imageHeight: number) => TargetCameraState;
25
+ export declare const mergeTwoCameraState: (cameraState1: TargetCameraState, cameraState2: TargetCameraState) => TargetCameraState;
26
+ export interface ReplayScriptsInfo {
27
+ scripts: AnimationScript[];
28
+ width?: number;
29
+ height?: number;
30
+ sdkVersion?: string;
31
+ modelBriefs: string[];
32
+ }
33
+ export declare const allScriptsFromDump: (dump: GroupedActionDump) => ReplayScriptsInfo | null;
34
+ export declare const generateAnimationScripts: (execution: ExecutionDump | null, task: ExecutionTask | number, imageWidth: number, imageHeight: number) => AnimationScript[] | null;
package/package.json ADDED
@@ -0,0 +1,85 @@
1
+ {
2
+ "name": "@sqaitech/visualizer",
3
+ "version": "0.30.10",
4
+ "repository": "https://github.com/qa-nparekh/midscene",
5
+ "homepage": "https://sqai.tech/",
6
+ "types": "./dist/types/index.d.ts",
7
+ "main": "./dist/lib/index.js",
8
+ "module": "./dist/es/index.mjs",
9
+ "exports": {
10
+ ".": {
11
+ "types": "./dist/types/index.d.ts",
12
+ "import": "./dist/es/index.mjs",
13
+ "require": "./dist/es/index.js"
14
+ }
15
+ },
16
+ "files": [
17
+ "dist",
18
+ "html",
19
+ "README.md"
20
+ ],
21
+ "watch": {
22
+ "build": {
23
+ "patterns": [
24
+ "src"
25
+ ],
26
+ "extensions": "tsx,less,scss,css,js,jsx,ts",
27
+ "quiet": false
28
+ }
29
+ },
30
+ "peerDependencies": {
31
+ "react": "18.3.1",
32
+ "react-dom": ">=19.1.0"
33
+ },
34
+ "devDependencies": {
35
+ "@pixi/unsafe-eval": "7.4.2",
36
+ "@rsbuild/plugin-less": "^1.2.4",
37
+ "@rsbuild/plugin-node-polyfill": "1.3.0",
38
+ "@rsbuild/plugin-react": "^1.3.1",
39
+ "@rsbuild/plugin-svgr": "^1.1.1",
40
+ "@rslib/core": "^0.11.2",
41
+ "@types/chrome": "0.0.279",
42
+ "@types/node": "^18.0.0",
43
+ "@types/react": "^18.3.1",
44
+ "@types/react-dom": "^18.3.1",
45
+ "execa": "9.3.0",
46
+ "http-server": "14.1.1",
47
+ "npm-watch": "0.13.0",
48
+ "pixi-filters": "6.0.5",
49
+ "pixi.js": "8.1.1",
50
+ "query-string": "9.1.1",
51
+ "react": "18.3.1",
52
+ "react-dom": "18.3.1",
53
+ "react-resizable-panels": "2.0.22",
54
+ "rimraf": "~3.0.2",
55
+ "tsx": "^4.19.2",
56
+ "typescript": "^5.8.3",
57
+ "zustand": "4.5.2"
58
+ },
59
+ "sideEffects": [
60
+ "**/*.css",
61
+ "**/*.less",
62
+ "**/*.sass",
63
+ "**/*.scss"
64
+ ],
65
+ "publishConfig": {
66
+ "access": "public"
67
+ },
68
+ "dependencies": {
69
+ "@ant-design/icons": "^5.3.1",
70
+ "antd": "^5.21.6",
71
+ "buffer": "6.0.3",
72
+ "dayjs": "^1.11.11",
73
+ "@sqaitech/playground": "0.30.10",
74
+ "@sqaitech/core": "0.30.10",
75
+ "@sqaitech/shared": "0.30.10",
76
+ "@sqaitech/web": "0.30.10"
77
+ },
78
+ "license": "MIT",
79
+ "scripts": {
80
+ "dev": "npm run build && npx npm-watch",
81
+ "build": "rslib build",
82
+ "build:watch": "rslib build --watch",
83
+ "serve": "http-server ./dist/ -p 3000"
84
+ }
85
+ }