@midscene/visualizer 0.30.10 → 0.30.11-beta-20251218071621.0
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/dist/es/component/blackboard/index.css +8 -0
- package/dist/es/component/blackboard/index.mjs +137 -68
- package/dist/es/component/config-selector/index.mjs +102 -4
- package/dist/es/component/context-preview/index.mjs +1 -2
- package/dist/es/component/env-config/index.mjs +1 -2
- package/dist/es/component/env-config-reminder/index.css +8 -0
- package/dist/es/component/env-config-reminder/index.mjs +1 -2
- package/dist/es/component/form-field/index.mjs +5 -10
- package/dist/es/component/history-selector/index.css +38 -1
- package/dist/es/component/history-selector/index.mjs +1 -2
- package/dist/es/component/logo/index.mjs +7 -3
- package/dist/es/component/misc/index.mjs +1 -4
- package/dist/es/component/nav-actions/index.mjs +1 -2
- package/dist/es/component/nav-actions/style.css +1 -1
- package/dist/es/component/player/index.css +26 -0
- package/dist/es/component/player/index.mjs +376 -364
- package/dist/es/component/playground/index.css +291 -31
- package/dist/es/component/playground-result/index.css +10 -0
- package/dist/es/component/playground-result/index.mjs +129 -10
- package/dist/es/component/prompt-input/index.css +281 -31
- package/dist/es/component/prompt-input/index.mjs +83 -25
- package/dist/es/component/screenshot-viewer/index.css +214 -0
- package/dist/es/component/screenshot-viewer/index.mjs +282 -0
- package/dist/es/component/service-mode-control/index.mjs +1 -2
- package/dist/es/component/shiny-text/index.css +35 -3
- package/dist/es/component/shiny-text/index.mjs +3 -3
- package/dist/es/component/universal-playground/index.css +61 -1
- package/dist/es/component/universal-playground/index.mjs +106 -83
- package/dist/es/component/universal-playground/providers/context-provider.mjs +56 -18
- package/dist/es/component/universal-playground/providers/indexeddb-storage-provider.mjs +213 -139
- package/dist/es/component/universal-playground/providers/storage-provider.mjs +199 -121
- package/dist/es/hooks/usePlaygroundExecution.mjs +297 -146
- package/dist/es/hooks/usePlaygroundState.mjs +141 -75
- package/dist/es/hooks/useSafeOverrideAIConfig.mjs +2 -6
- package/dist/es/hooks/useServerValid.mjs +37 -12
- package/dist/es/hooks/useTheme.mjs +25 -0
- package/dist/es/icons/avatar.mjs +46 -4
- package/dist/es/icons/close.mjs +46 -4
- package/dist/es/icons/global-perspective.mjs +47 -5
- package/dist/es/icons/history.mjs +48 -6
- package/dist/es/icons/magnifying-glass.mjs +47 -5
- package/dist/es/icons/player-setting.mjs +48 -6
- package/dist/es/icons/setting.mjs +47 -5
- package/dist/es/icons/show-marker.mjs +47 -5
- package/dist/es/index.mjs +4 -4
- package/dist/es/store/history.mjs +46 -7
- package/dist/es/store/store.mjs +68 -2
- package/dist/es/types.mjs +1 -1
- package/dist/es/utils/constants.mjs +7 -3
- package/dist/es/utils/index.mjs +4 -1
- package/dist/es/utils/pixi-loader.mjs +37 -11
- package/dist/es/utils/replay-scripts.mjs +160 -111
- package/dist/lib/component/blackboard/index.css +8 -0
- package/dist/lib/component/blackboard/index.js +139 -70
- package/dist/lib/component/config-selector/index.js +103 -5
- package/dist/lib/component/context-preview/index.js +3 -4
- package/dist/lib/component/env-config/index.js +3 -4
- package/dist/lib/component/env-config-reminder/index.css +8 -0
- package/dist/lib/component/env-config-reminder/index.js +3 -4
- package/dist/lib/component/form-field/index.js +10 -15
- package/dist/lib/component/history-selector/index.css +38 -1
- package/dist/lib/component/history-selector/index.js +3 -4
- package/dist/lib/component/index.js +6 -8
- package/dist/lib/component/logo/index.js +9 -5
- package/dist/lib/component/misc/index.js +6 -9
- package/dist/lib/component/nav-actions/index.js +3 -4
- package/dist/lib/component/nav-actions/style.css +1 -1
- package/dist/lib/component/player/index.css +26 -0
- package/dist/lib/component/player/index.js +376 -365
- package/dist/lib/component/playground/index.css +291 -31
- package/dist/lib/component/playground/index.js +31 -33
- package/dist/lib/component/playground-result/index.css +10 -0
- package/dist/lib/component/playground-result/index.js +131 -12
- package/dist/lib/component/prompt-input/index.css +281 -31
- package/dist/lib/component/prompt-input/index.js +84 -26
- package/dist/lib/component/screenshot-viewer/index.css +214 -0
- package/dist/lib/component/screenshot-viewer/index.js +316 -0
- package/dist/lib/component/service-mode-control/index.js +3 -4
- package/dist/lib/component/shiny-text/index.css +35 -3
- package/dist/lib/component/shiny-text/index.js +5 -5
- package/dist/lib/component/universal-playground/index.css +61 -1
- package/dist/lib/component/universal-playground/index.js +108 -84
- package/dist/lib/component/universal-playground/providers/context-provider.js +58 -20
- package/dist/lib/component/universal-playground/providers/indexeddb-storage-provider.js +217 -143
- package/dist/lib/component/universal-playground/providers/storage-provider.js +207 -129
- package/dist/lib/hooks/usePlaygroundExecution.js +299 -148
- package/dist/lib/hooks/usePlaygroundState.js +143 -77
- package/dist/lib/hooks/useSafeOverrideAIConfig.js +4 -8
- package/dist/lib/hooks/useServerValid.js +39 -14
- package/dist/lib/hooks/useTheme.js +59 -0
- package/dist/lib/icons/avatar.js +48 -6
- package/dist/lib/icons/close.js +48 -6
- package/dist/lib/icons/global-perspective.js +49 -7
- package/dist/lib/icons/history.js +50 -8
- package/dist/lib/icons/magnifying-glass.js +49 -7
- package/dist/lib/icons/player-setting.js +50 -8
- package/dist/lib/icons/setting.js +49 -7
- package/dist/lib/icons/show-marker.js +49 -7
- package/dist/lib/index.js +44 -34
- package/dist/lib/store/history.js +48 -9
- package/dist/lib/store/store.js +74 -8
- package/dist/lib/types.js +3 -3
- package/dist/lib/utils/color.js +2 -2
- package/dist/lib/utils/constants.js +20 -4
- package/dist/lib/utils/index.js +10 -4
- package/dist/lib/utils/pixi-loader.js +41 -15
- package/dist/lib/utils/playground-utils.js +4 -4
- package/dist/lib/utils/replay-scripts.js +164 -115
- package/dist/types/component/config-selector/index.d.ts +2 -0
- package/dist/types/component/player/index.d.ts +0 -1
- package/dist/types/component/playground-result/index.d.ts +1 -0
- package/dist/types/component/prompt-input/index.d.ts +2 -1
- package/dist/types/component/screenshot-viewer/index.d.ts +15 -0
- package/dist/types/hooks/usePlaygroundExecution.d.ts +1 -1
- package/dist/types/hooks/usePlaygroundState.d.ts +3 -3
- package/dist/types/hooks/useTheme.d.ts +7 -0
- package/dist/types/index.d.ts +3 -3
- package/dist/types/store/store.d.ts +18 -1
- package/dist/types/types.d.ts +14 -4
- package/dist/types/utils/constants.d.ts +5 -1
- package/dist/types/utils/index.d.ts +1 -0
- package/dist/types/utils/replay-scripts.d.ts +1 -1
- package/package.json +12 -22
|
@@ -1,15 +1,57 @@
|
|
|
1
1
|
import { jsx, jsxs } from "react/jsx-runtime";
|
|
2
2
|
import "react";
|
|
3
|
-
|
|
3
|
+
function _define_property(obj, key, value) {
|
|
4
|
+
if (key in obj) Object.defineProperty(obj, key, {
|
|
5
|
+
value: value,
|
|
6
|
+
enumerable: true,
|
|
7
|
+
configurable: true,
|
|
8
|
+
writable: true
|
|
9
|
+
});
|
|
10
|
+
else obj[key] = value;
|
|
11
|
+
return obj;
|
|
12
|
+
}
|
|
13
|
+
function _object_spread(target) {
|
|
14
|
+
for(var i = 1; i < arguments.length; i++){
|
|
15
|
+
var source = null != arguments[i] ? arguments[i] : {};
|
|
16
|
+
var ownKeys = Object.keys(source);
|
|
17
|
+
if ("function" == typeof Object.getOwnPropertySymbols) ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {
|
|
18
|
+
return Object.getOwnPropertyDescriptor(source, sym).enumerable;
|
|
19
|
+
}));
|
|
20
|
+
ownKeys.forEach(function(key) {
|
|
21
|
+
_define_property(target, key, source[key]);
|
|
22
|
+
});
|
|
23
|
+
}
|
|
24
|
+
return target;
|
|
25
|
+
}
|
|
26
|
+
function magnifying_glass_ownKeys(object, enumerableOnly) {
|
|
27
|
+
var keys = Object.keys(object);
|
|
28
|
+
if (Object.getOwnPropertySymbols) {
|
|
29
|
+
var symbols = Object.getOwnPropertySymbols(object);
|
|
30
|
+
if (enumerableOnly) symbols = symbols.filter(function(sym) {
|
|
31
|
+
return Object.getOwnPropertyDescriptor(object, sym).enumerable;
|
|
32
|
+
});
|
|
33
|
+
keys.push.apply(keys, symbols);
|
|
34
|
+
}
|
|
35
|
+
return keys;
|
|
36
|
+
}
|
|
37
|
+
function _object_spread_props(target, source) {
|
|
38
|
+
source = null != source ? source : {};
|
|
39
|
+
if (Object.getOwnPropertyDescriptors) Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));
|
|
40
|
+
else magnifying_glass_ownKeys(Object(source)).forEach(function(key) {
|
|
41
|
+
Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
|
|
42
|
+
});
|
|
43
|
+
return target;
|
|
44
|
+
}
|
|
45
|
+
const SvgMagnifyingGlass = (props)=>/*#__PURE__*/ jsxs("svg", _object_spread_props(_object_spread({
|
|
4
46
|
xmlns: "http://www.w3.org/2000/svg",
|
|
5
47
|
width: 19,
|
|
6
48
|
height: 19,
|
|
7
49
|
fill: "none",
|
|
8
|
-
viewBox: "0 0 19 19"
|
|
9
|
-
|
|
50
|
+
viewBox: "0 0 19 19"
|
|
51
|
+
}, props), {
|
|
10
52
|
children: [
|
|
11
53
|
/*#__PURE__*/ jsxs("g", {
|
|
12
|
-
stroke: "
|
|
54
|
+
stroke: "currentColor",
|
|
13
55
|
strokeLinejoin: "round",
|
|
14
56
|
strokeOpacity: 0.65,
|
|
15
57
|
strokeWidth: 1.5,
|
|
@@ -34,6 +76,6 @@ const SvgMagnifyingGlass = (props)=>/*#__PURE__*/ jsxs("svg", {
|
|
|
34
76
|
})
|
|
35
77
|
})
|
|
36
78
|
]
|
|
37
|
-
});
|
|
79
|
+
}));
|
|
38
80
|
const magnifying_glass = SvgMagnifyingGlass;
|
|
39
81
|
export { magnifying_glass as default };
|
|
@@ -1,26 +1,68 @@
|
|
|
1
1
|
import { jsx, jsxs } from "react/jsx-runtime";
|
|
2
2
|
import "react";
|
|
3
|
-
|
|
3
|
+
function _define_property(obj, key, value) {
|
|
4
|
+
if (key in obj) Object.defineProperty(obj, key, {
|
|
5
|
+
value: value,
|
|
6
|
+
enumerable: true,
|
|
7
|
+
configurable: true,
|
|
8
|
+
writable: true
|
|
9
|
+
});
|
|
10
|
+
else obj[key] = value;
|
|
11
|
+
return obj;
|
|
12
|
+
}
|
|
13
|
+
function _object_spread(target) {
|
|
14
|
+
for(var i = 1; i < arguments.length; i++){
|
|
15
|
+
var source = null != arguments[i] ? arguments[i] : {};
|
|
16
|
+
var ownKeys = Object.keys(source);
|
|
17
|
+
if ("function" == typeof Object.getOwnPropertySymbols) ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {
|
|
18
|
+
return Object.getOwnPropertyDescriptor(source, sym).enumerable;
|
|
19
|
+
}));
|
|
20
|
+
ownKeys.forEach(function(key) {
|
|
21
|
+
_define_property(target, key, source[key]);
|
|
22
|
+
});
|
|
23
|
+
}
|
|
24
|
+
return target;
|
|
25
|
+
}
|
|
26
|
+
function player_setting_ownKeys(object, enumerableOnly) {
|
|
27
|
+
var keys = Object.keys(object);
|
|
28
|
+
if (Object.getOwnPropertySymbols) {
|
|
29
|
+
var symbols = Object.getOwnPropertySymbols(object);
|
|
30
|
+
if (enumerableOnly) symbols = symbols.filter(function(sym) {
|
|
31
|
+
return Object.getOwnPropertyDescriptor(object, sym).enumerable;
|
|
32
|
+
});
|
|
33
|
+
keys.push.apply(keys, symbols);
|
|
34
|
+
}
|
|
35
|
+
return keys;
|
|
36
|
+
}
|
|
37
|
+
function _object_spread_props(target, source) {
|
|
38
|
+
source = null != source ? source : {};
|
|
39
|
+
if (Object.getOwnPropertyDescriptors) Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));
|
|
40
|
+
else player_setting_ownKeys(Object(source)).forEach(function(key) {
|
|
41
|
+
Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
|
|
42
|
+
});
|
|
43
|
+
return target;
|
|
44
|
+
}
|
|
45
|
+
const SvgPlayerSetting = (props)=>/*#__PURE__*/ jsxs("svg", _object_spread_props(_object_spread({
|
|
4
46
|
xmlns: "http://www.w3.org/2000/svg",
|
|
5
47
|
width: 16,
|
|
6
48
|
height: 16,
|
|
7
49
|
fill: "none",
|
|
8
|
-
viewBox: "0 0 16 16"
|
|
9
|
-
|
|
50
|
+
viewBox: "0 0 16 16"
|
|
51
|
+
}, props), {
|
|
10
52
|
children: [
|
|
11
53
|
/*#__PURE__*/ jsx("path", {
|
|
12
|
-
stroke: "
|
|
54
|
+
stroke: "currentColor",
|
|
13
55
|
strokeLinejoin: "round",
|
|
14
56
|
strokeWidth: 1.333,
|
|
15
57
|
d: "M11.333 13.667 14.667 8l-3.334-5.667H4.667L1.333 8l3.334 5.667z"
|
|
16
58
|
}),
|
|
17
59
|
/*#__PURE__*/ jsx("path", {
|
|
18
|
-
stroke: "
|
|
60
|
+
stroke: "currentColor",
|
|
19
61
|
strokeLinejoin: "round",
|
|
20
62
|
strokeWidth: 1.333,
|
|
21
63
|
d: "M8 9.667a1.667 1.667 0 1 0 0-3.334 1.667 1.667 0 0 0 0 3.334Z"
|
|
22
64
|
})
|
|
23
65
|
]
|
|
24
|
-
});
|
|
66
|
+
}));
|
|
25
67
|
const player_setting = SvgPlayerSetting;
|
|
26
68
|
export { player_setting as default };
|
|
@@ -1,20 +1,62 @@
|
|
|
1
1
|
import { jsx } from "react/jsx-runtime";
|
|
2
2
|
import "react";
|
|
3
|
-
|
|
3
|
+
function _define_property(obj, key, value) {
|
|
4
|
+
if (key in obj) Object.defineProperty(obj, key, {
|
|
5
|
+
value: value,
|
|
6
|
+
enumerable: true,
|
|
7
|
+
configurable: true,
|
|
8
|
+
writable: true
|
|
9
|
+
});
|
|
10
|
+
else obj[key] = value;
|
|
11
|
+
return obj;
|
|
12
|
+
}
|
|
13
|
+
function _object_spread(target) {
|
|
14
|
+
for(var i = 1; i < arguments.length; i++){
|
|
15
|
+
var source = null != arguments[i] ? arguments[i] : {};
|
|
16
|
+
var ownKeys = Object.keys(source);
|
|
17
|
+
if ("function" == typeof Object.getOwnPropertySymbols) ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {
|
|
18
|
+
return Object.getOwnPropertyDescriptor(source, sym).enumerable;
|
|
19
|
+
}));
|
|
20
|
+
ownKeys.forEach(function(key) {
|
|
21
|
+
_define_property(target, key, source[key]);
|
|
22
|
+
});
|
|
23
|
+
}
|
|
24
|
+
return target;
|
|
25
|
+
}
|
|
26
|
+
function setting_ownKeys(object, enumerableOnly) {
|
|
27
|
+
var keys = Object.keys(object);
|
|
28
|
+
if (Object.getOwnPropertySymbols) {
|
|
29
|
+
var symbols = Object.getOwnPropertySymbols(object);
|
|
30
|
+
if (enumerableOnly) symbols = symbols.filter(function(sym) {
|
|
31
|
+
return Object.getOwnPropertyDescriptor(object, sym).enumerable;
|
|
32
|
+
});
|
|
33
|
+
keys.push.apply(keys, symbols);
|
|
34
|
+
}
|
|
35
|
+
return keys;
|
|
36
|
+
}
|
|
37
|
+
function _object_spread_props(target, source) {
|
|
38
|
+
source = null != source ? source : {};
|
|
39
|
+
if (Object.getOwnPropertyDescriptors) Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));
|
|
40
|
+
else setting_ownKeys(Object(source)).forEach(function(key) {
|
|
41
|
+
Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
|
|
42
|
+
});
|
|
43
|
+
return target;
|
|
44
|
+
}
|
|
45
|
+
const SvgSetting = (props)=>/*#__PURE__*/ jsx("svg", _object_spread_props(_object_spread({
|
|
4
46
|
xmlns: "http://www.w3.org/2000/svg",
|
|
5
47
|
width: 27,
|
|
6
48
|
height: 27,
|
|
7
49
|
fill: "none",
|
|
8
|
-
viewBox: "0 0 27 27"
|
|
9
|
-
|
|
50
|
+
viewBox: "0 0 27 27"
|
|
51
|
+
}, props), {
|
|
10
52
|
children: /*#__PURE__*/ jsx("path", {
|
|
11
|
-
stroke: "
|
|
53
|
+
stroke: "currentColor",
|
|
12
54
|
strokeLinecap: "round",
|
|
13
55
|
strokeLinejoin: "round",
|
|
14
56
|
strokeOpacity: 0.85,
|
|
15
57
|
strokeWidth: 1.333,
|
|
16
58
|
d: "M19.527 8.855h-2M14.86 7.522v2.667M14.86 8.855H7.527M10.194 13.522H7.527M12.86 12.189v2.666M20.193 13.522H12.86M19.527 18.189h-2M14.86 16.855v2.667M14.86 18.189H7.527"
|
|
17
59
|
})
|
|
18
|
-
});
|
|
60
|
+
}));
|
|
19
61
|
const setting = SvgSetting;
|
|
20
62
|
export { setting as default };
|
|
@@ -1,16 +1,58 @@
|
|
|
1
1
|
import { jsx } from "react/jsx-runtime";
|
|
2
2
|
import "react";
|
|
3
|
-
|
|
3
|
+
function _define_property(obj, key, value) {
|
|
4
|
+
if (key in obj) Object.defineProperty(obj, key, {
|
|
5
|
+
value: value,
|
|
6
|
+
enumerable: true,
|
|
7
|
+
configurable: true,
|
|
8
|
+
writable: true
|
|
9
|
+
});
|
|
10
|
+
else obj[key] = value;
|
|
11
|
+
return obj;
|
|
12
|
+
}
|
|
13
|
+
function _object_spread(target) {
|
|
14
|
+
for(var i = 1; i < arguments.length; i++){
|
|
15
|
+
var source = null != arguments[i] ? arguments[i] : {};
|
|
16
|
+
var ownKeys = Object.keys(source);
|
|
17
|
+
if ("function" == typeof Object.getOwnPropertySymbols) ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {
|
|
18
|
+
return Object.getOwnPropertyDescriptor(source, sym).enumerable;
|
|
19
|
+
}));
|
|
20
|
+
ownKeys.forEach(function(key) {
|
|
21
|
+
_define_property(target, key, source[key]);
|
|
22
|
+
});
|
|
23
|
+
}
|
|
24
|
+
return target;
|
|
25
|
+
}
|
|
26
|
+
function show_marker_ownKeys(object, enumerableOnly) {
|
|
27
|
+
var keys = Object.keys(object);
|
|
28
|
+
if (Object.getOwnPropertySymbols) {
|
|
29
|
+
var symbols = Object.getOwnPropertySymbols(object);
|
|
30
|
+
if (enumerableOnly) symbols = symbols.filter(function(sym) {
|
|
31
|
+
return Object.getOwnPropertyDescriptor(object, sym).enumerable;
|
|
32
|
+
});
|
|
33
|
+
keys.push.apply(keys, symbols);
|
|
34
|
+
}
|
|
35
|
+
return keys;
|
|
36
|
+
}
|
|
37
|
+
function _object_spread_props(target, source) {
|
|
38
|
+
source = null != source ? source : {};
|
|
39
|
+
if (Object.getOwnPropertyDescriptors) Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));
|
|
40
|
+
else show_marker_ownKeys(Object(source)).forEach(function(key) {
|
|
41
|
+
Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
|
|
42
|
+
});
|
|
43
|
+
return target;
|
|
44
|
+
}
|
|
45
|
+
const SvgShowMarker = (props)=>/*#__PURE__*/ jsx("svg", _object_spread_props(_object_spread({
|
|
4
46
|
xmlns: "http://www.w3.org/2000/svg",
|
|
5
47
|
width: 16,
|
|
6
48
|
height: 16,
|
|
7
49
|
fill: "none",
|
|
8
|
-
viewBox: "0 0 16 16"
|
|
9
|
-
|
|
50
|
+
viewBox: "0 0 16 16"
|
|
51
|
+
}, props), {
|
|
10
52
|
children: /*#__PURE__*/ jsx("path", {
|
|
11
|
-
fill: "
|
|
53
|
+
fill: "currentColor",
|
|
12
54
|
d: "M13 1.835a2.165 2.165 0 0 1 .665 4.225v3.88a2.166 2.166 0 1 1-2.725 2.725H5.06a2.165 2.165 0 1 1-2.725-2.726V6.06A2.165 2.165 0 1 1 5.06 3.336h5.88c.281-.87 1.097-1.5 2.06-1.5m-10 9.33a.835.835 0 1 0 0 1.67.835.835 0 0 0 0-1.67m10 0a.835.835 0 1 0 0 1.67.835.835 0 0 0 0-1.67m-7.94-6.5A2.17 2.17 0 0 1 3.665 6.06v3.88c.66.213 1.181.734 1.395 1.395h5.88a2.17 2.17 0 0 1 1.395-1.396V6.06a2.17 2.17 0 0 1-1.395-1.394zM3 3.165a.835.835 0 1 0 0 1.67.835.835 0 0 0 0-1.67m10 0a.835.835 0 1 0 0 1.67.835.835 0 0 0 0-1.67"
|
|
13
55
|
})
|
|
14
|
-
});
|
|
56
|
+
}));
|
|
15
57
|
const show_marker = SvgShowMarker;
|
|
16
58
|
export { show_marker as default };
|
package/dist/es/index.mjs
CHANGED
|
@@ -1,13 +1,12 @@
|
|
|
1
|
-
import "./component/playground/index.css";
|
|
2
|
-
import "./component/universal-playground/index.css";
|
|
3
1
|
import { allScriptsFromDump, generateAnimationScripts } from "./utils/replay-scripts.mjs";
|
|
4
|
-
import { useEnvConfig } from "./store/store.mjs";
|
|
2
|
+
import { useEnvConfig, useGlobalPreference } from "./store/store.mjs";
|
|
5
3
|
import { colorForName, globalThemeConfig, highlightColorForType } from "./utils/color.mjs";
|
|
6
4
|
import { EnvConfig } from "./component/env-config/index.mjs";
|
|
7
5
|
import { EnvConfigReminder } from "./component/env-config-reminder/index.mjs";
|
|
8
6
|
import { NavActions } from "./component/nav-actions/index.mjs";
|
|
9
7
|
import { Logo } from "./component/logo/index.mjs";
|
|
10
8
|
import { iconForStatus, timeCostStrElement } from "./component/misc/index.mjs";
|
|
9
|
+
import { useTheme } from "./hooks/useTheme.mjs";
|
|
11
10
|
import { useServerValid } from "./hooks/useServerValid.mjs";
|
|
12
11
|
import { safeOverrideAIConfig, useSafeOverrideAIConfig } from "./hooks/useSafeOverrideAIConfig.mjs";
|
|
13
12
|
import { PlaygroundResultView } from "./component/playground-result/index.mjs";
|
|
@@ -16,10 +15,11 @@ import { ContextPreview } from "./component/context-preview/index.mjs";
|
|
|
16
15
|
import { PromptInput } from "./component/prompt-input/index.mjs";
|
|
17
16
|
import { Player } from "./component/player/index.mjs";
|
|
18
17
|
import { Blackboard } from "./component/blackboard/index.mjs";
|
|
18
|
+
import screenshot_viewer from "./component/screenshot-viewer/index.mjs";
|
|
19
19
|
import { actionNameForType, getPlaceholderForType, staticAgentFromContext } from "./utils/playground-utils.mjs";
|
|
20
20
|
import { filterBase64Value, timeStr } from "./utils/index.mjs";
|
|
21
21
|
import shiny_text from "./component/shiny-text/index.mjs";
|
|
22
22
|
import universal_playground, { UniversalPlayground } from "./component/universal-playground/index.mjs";
|
|
23
23
|
import { IndexedDBStorageProvider, LocalStorageProvider, MemoryStorageProvider, NoOpStorageProvider, StorageType, createStorageProvider, detectBestStorageType } from "./component/universal-playground/providers/storage-provider.mjs";
|
|
24
24
|
import { AgentContextProvider, BaseContextProvider, NoOpContextProvider, StaticContextProvider } from "./component/universal-playground/providers/context-provider.mjs";
|
|
25
|
-
export { AgentContextProvider, BaseContextProvider, Blackboard, ContextPreview, EnvConfig, EnvConfigReminder, IndexedDBStorageProvider, LocalStorageProvider, Logo, MemoryStorageProvider, NavActions, NoOpContextProvider, NoOpStorageProvider, Player, PlaygroundResultView, PromptInput, ServiceModeControl, shiny_text as ShinyText, StaticContextProvider, StorageType, UniversalPlayground, universal_playground as UniversalPlaygroundDefault, actionNameForType, allScriptsFromDump, colorForName, createStorageProvider, detectBestStorageType, filterBase64Value, generateAnimationScripts, getPlaceholderForType, globalThemeConfig, highlightColorForType, iconForStatus, safeOverrideAIConfig, staticAgentFromContext, timeCostStrElement, timeStr, useEnvConfig, useSafeOverrideAIConfig, useServerValid };
|
|
25
|
+
export { AgentContextProvider, BaseContextProvider, Blackboard, ContextPreview, EnvConfig, EnvConfigReminder, IndexedDBStorageProvider, LocalStorageProvider, Logo, MemoryStorageProvider, NavActions, NoOpContextProvider, NoOpStorageProvider, Player, PlaygroundResultView, PromptInput, screenshot_viewer as ScreenshotViewer, ServiceModeControl, shiny_text as ShinyText, StaticContextProvider, StorageType, UniversalPlayground, universal_playground as UniversalPlaygroundDefault, actionNameForType, allScriptsFromDump, colorForName, createStorageProvider, detectBestStorageType, filterBase64Value, generateAnimationScripts, getPlaceholderForType, globalThemeConfig, highlightColorForType, iconForStatus, safeOverrideAIConfig, staticAgentFromContext, timeCostStrElement, timeStr, useEnvConfig, useGlobalPreference, useSafeOverrideAIConfig, useServerValid, useTheme };
|
|
@@ -26,6 +26,48 @@ __webpack_require__.r(external_zustand_namespaceObject);
|
|
|
26
26
|
__webpack_require__.d(external_zustand_namespaceObject, {
|
|
27
27
|
create: ()=>create
|
|
28
28
|
});
|
|
29
|
+
function _define_property(obj, key, value) {
|
|
30
|
+
if (key in obj) Object.defineProperty(obj, key, {
|
|
31
|
+
value: value,
|
|
32
|
+
enumerable: true,
|
|
33
|
+
configurable: true,
|
|
34
|
+
writable: true
|
|
35
|
+
});
|
|
36
|
+
else obj[key] = value;
|
|
37
|
+
return obj;
|
|
38
|
+
}
|
|
39
|
+
function _object_spread(target) {
|
|
40
|
+
for(var i = 1; i < arguments.length; i++){
|
|
41
|
+
var source = null != arguments[i] ? arguments[i] : {};
|
|
42
|
+
var ownKeys = Object.keys(source);
|
|
43
|
+
if ("function" == typeof Object.getOwnPropertySymbols) ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {
|
|
44
|
+
return Object.getOwnPropertyDescriptor(source, sym).enumerable;
|
|
45
|
+
}));
|
|
46
|
+
ownKeys.forEach(function(key) {
|
|
47
|
+
_define_property(target, key, source[key]);
|
|
48
|
+
});
|
|
49
|
+
}
|
|
50
|
+
return target;
|
|
51
|
+
}
|
|
52
|
+
function history_ownKeys(object, enumerableOnly) {
|
|
53
|
+
var keys = Object.keys(object);
|
|
54
|
+
if (Object.getOwnPropertySymbols) {
|
|
55
|
+
var symbols = Object.getOwnPropertySymbols(object);
|
|
56
|
+
if (enumerableOnly) symbols = symbols.filter(function(sym) {
|
|
57
|
+
return Object.getOwnPropertyDescriptor(object, sym).enumerable;
|
|
58
|
+
});
|
|
59
|
+
keys.push.apply(keys, symbols);
|
|
60
|
+
}
|
|
61
|
+
return keys;
|
|
62
|
+
}
|
|
63
|
+
function _object_spread_props(target, source) {
|
|
64
|
+
source = null != source ? source : {};
|
|
65
|
+
if (Object.getOwnPropertyDescriptors) Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));
|
|
66
|
+
else history_ownKeys(Object(source)).forEach(function(key) {
|
|
67
|
+
Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
|
|
68
|
+
});
|
|
69
|
+
return target;
|
|
70
|
+
}
|
|
29
71
|
const { create: history_create } = external_zustand_namespaceObject;
|
|
30
72
|
const HISTORY_KEY = 'midscene-prompt-history-v2';
|
|
31
73
|
const LAST_SELECTED_TYPE_KEY = 'midscene-last-selected-type';
|
|
@@ -33,7 +75,7 @@ const getHistoryFromLocalStorage = ()=>{
|
|
|
33
75
|
const historyString = localStorage.getItem(HISTORY_KEY);
|
|
34
76
|
return historyString ? JSON.parse(historyString) : {};
|
|
35
77
|
};
|
|
36
|
-
const getLastSelectedType = ()=>localStorage.getItem(LAST_SELECTED_TYPE_KEY) || '
|
|
78
|
+
const getLastSelectedType = ()=>localStorage.getItem(LAST_SELECTED_TYPE_KEY) || 'aiAct';
|
|
37
79
|
const setLastSelectedType = (type)=>{
|
|
38
80
|
localStorage.setItem(LAST_SELECTED_TYPE_KEY, type);
|
|
39
81
|
};
|
|
@@ -41,9 +83,7 @@ const useHistoryStore = history_create((set, get)=>({
|
|
|
41
83
|
history: getHistoryFromLocalStorage(),
|
|
42
84
|
lastSelectedType: getLastSelectedType(),
|
|
43
85
|
clearHistory: (type)=>{
|
|
44
|
-
const newHistory = {
|
|
45
|
-
...get().history
|
|
46
|
-
};
|
|
86
|
+
const newHistory = _object_spread({}, get().history);
|
|
47
87
|
delete newHistory[type];
|
|
48
88
|
set({
|
|
49
89
|
history: newHistory
|
|
@@ -69,10 +109,9 @@ const useHistoryStore = history_create((set, get)=>({
|
|
|
69
109
|
})
|
|
70
110
|
];
|
|
71
111
|
if (newTypeHistory.length > 10) newTypeHistory.length = 10;
|
|
72
|
-
const newHistory = {
|
|
73
|
-
...currentHistory,
|
|
112
|
+
const newHistory = _object_spread_props(_object_spread({}, currentHistory), {
|
|
74
113
|
[type]: newTypeHistory
|
|
75
|
-
};
|
|
114
|
+
});
|
|
76
115
|
set({
|
|
77
116
|
history: newHistory
|
|
78
117
|
});
|
package/dist/es/store/store.mjs
CHANGED
|
@@ -30,6 +30,8 @@ const { create: store_create } = external_zustand_namespaceObject;
|
|
|
30
30
|
const AUTO_ZOOM_KEY = 'midscene-auto-zoom';
|
|
31
31
|
const BACKGROUND_VISIBLE_KEY = 'midscene-background-visible';
|
|
32
32
|
const ELEMENTS_VISIBLE_KEY = 'midscene-elements-visible';
|
|
33
|
+
const MODEL_CALL_DETAILS_KEY = 'midscene-model-call-details';
|
|
34
|
+
const DARK_MODE_KEY = 'midscene-dark-mode';
|
|
33
35
|
const parseBooleanParam = (value)=>{
|
|
34
36
|
if (null === value) return;
|
|
35
37
|
const normalized = value.trim().toLowerCase();
|
|
@@ -51,16 +53,23 @@ const getQueryPreference = (paramName)=>{
|
|
|
51
53
|
const searchParams = new URLSearchParams(window.location.search);
|
|
52
54
|
return parseBooleanParam(searchParams.get(paramName));
|
|
53
55
|
};
|
|
54
|
-
const
|
|
56
|
+
const useGlobalPreference = store_create((set)=>{
|
|
55
57
|
const savedAutoZoom = 'false' !== localStorage.getItem(AUTO_ZOOM_KEY);
|
|
56
58
|
const savedBackgroundVisible = 'false' !== localStorage.getItem(BACKGROUND_VISIBLE_KEY);
|
|
57
59
|
const savedElementsVisible = 'false' !== localStorage.getItem(ELEMENTS_VISIBLE_KEY);
|
|
60
|
+
const savedModelCallDetails = 'true' === localStorage.getItem(MODEL_CALL_DETAILS_KEY);
|
|
61
|
+
const savedDarkMode = 'true' === localStorage.getItem(DARK_MODE_KEY);
|
|
58
62
|
const autoZoomFromQuery = getQueryPreference('focusOnCursor');
|
|
59
63
|
const elementsVisibleFromQuery = getQueryPreference('showElementMarkers');
|
|
64
|
+
const darkModeFromQuery = getQueryPreference('darkMode');
|
|
65
|
+
const initialDarkMode = void 0 === darkModeFromQuery ? savedDarkMode : darkModeFromQuery;
|
|
66
|
+
if (void 0 !== darkModeFromQuery) localStorage.setItem(DARK_MODE_KEY, initialDarkMode.toString());
|
|
60
67
|
return {
|
|
61
68
|
backgroundVisible: savedBackgroundVisible,
|
|
62
69
|
elementsVisible: void 0 === elementsVisibleFromQuery ? savedElementsVisible : elementsVisibleFromQuery,
|
|
63
70
|
autoZoom: void 0 === autoZoomFromQuery ? savedAutoZoom : autoZoomFromQuery,
|
|
71
|
+
modelCallDetailsEnabled: savedModelCallDetails,
|
|
72
|
+
darkModeEnabled: initialDarkMode,
|
|
64
73
|
setBackgroundVisible: (visible)=>{
|
|
65
74
|
set({
|
|
66
75
|
backgroundVisible: visible
|
|
@@ -78,6 +87,18 @@ const useBlackboardPreference = store_create((set)=>{
|
|
|
78
87
|
autoZoom: enabled
|
|
79
88
|
});
|
|
80
89
|
localStorage.setItem(AUTO_ZOOM_KEY, enabled.toString());
|
|
90
|
+
},
|
|
91
|
+
setModelCallDetailsEnabled: (enabled)=>{
|
|
92
|
+
set({
|
|
93
|
+
modelCallDetailsEnabled: enabled
|
|
94
|
+
});
|
|
95
|
+
localStorage.setItem(MODEL_CALL_DETAILS_KEY, enabled.toString());
|
|
96
|
+
},
|
|
97
|
+
setDarkModeEnabled: (enabled)=>{
|
|
98
|
+
set({
|
|
99
|
+
darkModeEnabled: enabled
|
|
100
|
+
});
|
|
101
|
+
localStorage.setItem(DARK_MODE_KEY, enabled.toString());
|
|
81
102
|
}
|
|
82
103
|
};
|
|
83
104
|
});
|
|
@@ -87,6 +108,11 @@ const TRACKING_ACTIVE_TAB_KEY = 'midscene-tracking-active-tab';
|
|
|
87
108
|
const DEEP_THINK_KEY = 'midscene-deep-think';
|
|
88
109
|
const SCREENSHOT_INCLUDED_KEY = 'midscene-screenshot-included';
|
|
89
110
|
const DOM_INCLUDED_KEY = 'midscene-dom-included';
|
|
111
|
+
const PLANNING_STRATEGY_KEY = 'midscene-planning-strategy';
|
|
112
|
+
const IME_STRATEGY_KEY = 'midscene-ime-strategy';
|
|
113
|
+
const AUTO_DISMISS_KEYBOARD_KEY = 'midscene-auto-dismiss-keyboard';
|
|
114
|
+
const KEYBOARD_DISMISS_STRATEGY_KEY = 'midscene-keyboard-dismiss-strategy';
|
|
115
|
+
const ALWAYS_REFRESH_SCREEN_INFO_KEY = 'midscene-always-refresh-screen-info';
|
|
90
116
|
const getConfigStringFromLocalStorage = ()=>{
|
|
91
117
|
const configString = localStorage.getItem(CONFIG_KEY);
|
|
92
118
|
return configString || '';
|
|
@@ -117,6 +143,11 @@ const useEnvConfig = store_create((set, get)=>{
|
|
|
117
143
|
const savedDeepThink = 'true' === localStorage.getItem(DEEP_THINK_KEY);
|
|
118
144
|
const savedScreenshotIncluded = 'false' !== localStorage.getItem(SCREENSHOT_INCLUDED_KEY);
|
|
119
145
|
const savedDomIncluded = localStorage.getItem(DOM_INCLUDED_KEY) || 'false';
|
|
146
|
+
const savedImeStrategy = localStorage.getItem(IME_STRATEGY_KEY) || 'yadb-for-non-ascii';
|
|
147
|
+
const savedAutoDismissKeyboard = 'false' !== localStorage.getItem(AUTO_DISMISS_KEYBOARD_KEY);
|
|
148
|
+
const savedKeyboardDismissStrategy = localStorage.getItem(KEYBOARD_DISMISS_STRATEGY_KEY) || 'esc-first';
|
|
149
|
+
const savedAlwaysRefreshScreenInfo = 'true' === localStorage.getItem(ALWAYS_REFRESH_SCREEN_INFO_KEY);
|
|
150
|
+
const savedPlanningStrategy = localStorage.getItem(PLANNING_STRATEGY_KEY) || 'standard';
|
|
120
151
|
return {
|
|
121
152
|
serviceMode: ifInExtension ? 'In-Browser-Extension' : savedServiceMode || 'Server',
|
|
122
153
|
setServiceMode: (serviceMode)=>{
|
|
@@ -175,12 +206,47 @@ const useEnvConfig = store_create((set, get)=>{
|
|
|
175
206
|
});
|
|
176
207
|
localStorage.setItem(DOM_INCLUDED_KEY, domIncluded.toString());
|
|
177
208
|
},
|
|
209
|
+
planningStrategy: savedPlanningStrategy,
|
|
210
|
+
setPlanningStrategy: (planningStrategy)=>{
|
|
211
|
+
set({
|
|
212
|
+
planningStrategy
|
|
213
|
+
});
|
|
214
|
+
localStorage.setItem(PLANNING_STRATEGY_KEY, planningStrategy);
|
|
215
|
+
},
|
|
178
216
|
popupTab: 'playground',
|
|
179
217
|
setPopupTab: (tab)=>{
|
|
180
218
|
set({
|
|
181
219
|
popupTab: tab
|
|
182
220
|
});
|
|
221
|
+
},
|
|
222
|
+
imeStrategy: savedImeStrategy,
|
|
223
|
+
setImeStrategy: (imeStrategy)=>{
|
|
224
|
+
set({
|
|
225
|
+
imeStrategy
|
|
226
|
+
});
|
|
227
|
+
localStorage.setItem(IME_STRATEGY_KEY, imeStrategy);
|
|
228
|
+
},
|
|
229
|
+
autoDismissKeyboard: savedAutoDismissKeyboard,
|
|
230
|
+
setAutoDismissKeyboard: (autoDismissKeyboard)=>{
|
|
231
|
+
set({
|
|
232
|
+
autoDismissKeyboard
|
|
233
|
+
});
|
|
234
|
+
localStorage.setItem(AUTO_DISMISS_KEYBOARD_KEY, autoDismissKeyboard.toString());
|
|
235
|
+
},
|
|
236
|
+
keyboardDismissStrategy: savedKeyboardDismissStrategy,
|
|
237
|
+
setKeyboardDismissStrategy: (keyboardDismissStrategy)=>{
|
|
238
|
+
set({
|
|
239
|
+
keyboardDismissStrategy
|
|
240
|
+
});
|
|
241
|
+
localStorage.setItem(KEYBOARD_DISMISS_STRATEGY_KEY, keyboardDismissStrategy);
|
|
242
|
+
},
|
|
243
|
+
alwaysRefreshScreenInfo: savedAlwaysRefreshScreenInfo,
|
|
244
|
+
setAlwaysRefreshScreenInfo: (alwaysRefreshScreenInfo)=>{
|
|
245
|
+
set({
|
|
246
|
+
alwaysRefreshScreenInfo
|
|
247
|
+
});
|
|
248
|
+
localStorage.setItem(ALWAYS_REFRESH_SCREEN_INFO_KEY, alwaysRefreshScreenInfo.toString());
|
|
183
249
|
}
|
|
184
250
|
};
|
|
185
251
|
});
|
|
186
|
-
export {
|
|
252
|
+
export { useEnvConfig, useGlobalPreference };
|
package/dist/es/types.mjs
CHANGED
|
@@ -2,8 +2,12 @@ const trackingTip = 'limit popup to current tab';
|
|
|
2
2
|
const deepThinkTip = 'deep think';
|
|
3
3
|
const screenshotIncludedTip = 'include screenshot in request';
|
|
4
4
|
const domIncludedTip = 'include DOM info in request';
|
|
5
|
+
const imeStrategyTip = 'IME strategy';
|
|
6
|
+
const autoDismissKeyboardTip = 'Auto dismiss keyboard';
|
|
7
|
+
const keyboardDismissStrategyTip = 'Keyboard dismiss strategy';
|
|
8
|
+
const alwaysRefreshScreenInfoTip = 'Always refresh screen info';
|
|
5
9
|
const apiMetadata = {
|
|
6
|
-
|
|
10
|
+
aiAct: {
|
|
7
11
|
group: 'interaction',
|
|
8
12
|
title: 'Auto Planning: plan the steps and execute'
|
|
9
13
|
},
|
|
@@ -69,7 +73,7 @@ const apiMetadata = {
|
|
|
69
73
|
}
|
|
70
74
|
};
|
|
71
75
|
const defaultMainButtons = [
|
|
72
|
-
'
|
|
76
|
+
'aiAct',
|
|
73
77
|
'aiTap',
|
|
74
78
|
'aiQuery',
|
|
75
79
|
'aiAssert'
|
|
@@ -96,4 +100,4 @@ const BLANK_RESULT = {
|
|
|
96
100
|
reportHTML: null,
|
|
97
101
|
error: null
|
|
98
102
|
};
|
|
99
|
-
export { BLANK_RESULT, WELCOME_MESSAGE_TEMPLATE, apiMetadata, deepThinkTip, defaultMainButtons, domIncludedTip, screenshotIncludedTip, trackingTip };
|
|
103
|
+
export { BLANK_RESULT, WELCOME_MESSAGE_TEMPLATE, alwaysRefreshScreenInfoTip, apiMetadata, autoDismissKeyboardTip, deepThinkTip, defaultMainButtons, domIncludedTip, imeStrategyTip, keyboardDismissStrategyTip, screenshotIncludedTip, trackingTip };
|
package/dist/es/utils/index.mjs
CHANGED
|
@@ -2,9 +2,12 @@ import dayjs from "dayjs";
|
|
|
2
2
|
function timeStr(timestamp) {
|
|
3
3
|
return timestamp ? dayjs(timestamp).format('YYYY-MM-DD HH:mm:ss') : '-';
|
|
4
4
|
}
|
|
5
|
+
function fullTimeStrWithMilliseconds(timestamp) {
|
|
6
|
+
return timestamp ? dayjs(timestamp).format('YYYY-MM-DD HH:mm:ss.SSS') : '-';
|
|
7
|
+
}
|
|
5
8
|
function filterBase64Value(input) {
|
|
6
9
|
return input.replace(/data:image\/[^"]+"/g, 'data:image..."');
|
|
7
10
|
}
|
|
8
11
|
const mousePointer = '';
|
|
9
12
|
const mouseLoading = '';
|
|
10
|
-
export { filterBase64Value, mouseLoading, mousePointer, timeStr };
|
|
13
|
+
export { filterBase64Value, fullTimeStrWithMilliseconds, mouseLoading, mousePointer, timeStr };
|