@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.
Files changed (123) hide show
  1. package/dist/es/component/blackboard/index.css +8 -0
  2. package/dist/es/component/blackboard/index.mjs +137 -68
  3. package/dist/es/component/config-selector/index.mjs +102 -4
  4. package/dist/es/component/context-preview/index.mjs +1 -2
  5. package/dist/es/component/env-config/index.mjs +1 -2
  6. package/dist/es/component/env-config-reminder/index.css +8 -0
  7. package/dist/es/component/env-config-reminder/index.mjs +1 -2
  8. package/dist/es/component/form-field/index.mjs +5 -10
  9. package/dist/es/component/history-selector/index.css +38 -1
  10. package/dist/es/component/history-selector/index.mjs +1 -2
  11. package/dist/es/component/logo/index.mjs +7 -3
  12. package/dist/es/component/misc/index.mjs +1 -4
  13. package/dist/es/component/nav-actions/index.mjs +1 -2
  14. package/dist/es/component/nav-actions/style.css +1 -1
  15. package/dist/es/component/player/index.css +26 -0
  16. package/dist/es/component/player/index.mjs +376 -364
  17. package/dist/es/component/playground/index.css +291 -31
  18. package/dist/es/component/playground-result/index.css +10 -0
  19. package/dist/es/component/playground-result/index.mjs +129 -10
  20. package/dist/es/component/prompt-input/index.css +281 -31
  21. package/dist/es/component/prompt-input/index.mjs +83 -25
  22. package/dist/es/component/screenshot-viewer/index.css +214 -0
  23. package/dist/es/component/screenshot-viewer/index.mjs +282 -0
  24. package/dist/es/component/service-mode-control/index.mjs +1 -2
  25. package/dist/es/component/shiny-text/index.css +35 -3
  26. package/dist/es/component/shiny-text/index.mjs +3 -3
  27. package/dist/es/component/universal-playground/index.css +61 -1
  28. package/dist/es/component/universal-playground/index.mjs +106 -83
  29. package/dist/es/component/universal-playground/providers/context-provider.mjs +56 -18
  30. package/dist/es/component/universal-playground/providers/indexeddb-storage-provider.mjs +213 -139
  31. package/dist/es/component/universal-playground/providers/storage-provider.mjs +199 -121
  32. package/dist/es/hooks/usePlaygroundExecution.mjs +297 -146
  33. package/dist/es/hooks/usePlaygroundState.mjs +141 -75
  34. package/dist/es/hooks/useSafeOverrideAIConfig.mjs +2 -6
  35. package/dist/es/hooks/useServerValid.mjs +37 -12
  36. package/dist/es/hooks/useTheme.mjs +25 -0
  37. package/dist/es/icons/avatar.mjs +46 -4
  38. package/dist/es/icons/close.mjs +46 -4
  39. package/dist/es/icons/global-perspective.mjs +47 -5
  40. package/dist/es/icons/history.mjs +48 -6
  41. package/dist/es/icons/magnifying-glass.mjs +47 -5
  42. package/dist/es/icons/player-setting.mjs +48 -6
  43. package/dist/es/icons/setting.mjs +47 -5
  44. package/dist/es/icons/show-marker.mjs +47 -5
  45. package/dist/es/index.mjs +4 -4
  46. package/dist/es/store/history.mjs +46 -7
  47. package/dist/es/store/store.mjs +68 -2
  48. package/dist/es/types.mjs +1 -1
  49. package/dist/es/utils/constants.mjs +7 -3
  50. package/dist/es/utils/index.mjs +4 -1
  51. package/dist/es/utils/pixi-loader.mjs +37 -11
  52. package/dist/es/utils/replay-scripts.mjs +160 -111
  53. package/dist/lib/component/blackboard/index.css +8 -0
  54. package/dist/lib/component/blackboard/index.js +139 -70
  55. package/dist/lib/component/config-selector/index.js +103 -5
  56. package/dist/lib/component/context-preview/index.js +3 -4
  57. package/dist/lib/component/env-config/index.js +3 -4
  58. package/dist/lib/component/env-config-reminder/index.css +8 -0
  59. package/dist/lib/component/env-config-reminder/index.js +3 -4
  60. package/dist/lib/component/form-field/index.js +10 -15
  61. package/dist/lib/component/history-selector/index.css +38 -1
  62. package/dist/lib/component/history-selector/index.js +3 -4
  63. package/dist/lib/component/index.js +6 -8
  64. package/dist/lib/component/logo/index.js +9 -5
  65. package/dist/lib/component/misc/index.js +6 -9
  66. package/dist/lib/component/nav-actions/index.js +3 -4
  67. package/dist/lib/component/nav-actions/style.css +1 -1
  68. package/dist/lib/component/player/index.css +26 -0
  69. package/dist/lib/component/player/index.js +376 -365
  70. package/dist/lib/component/playground/index.css +291 -31
  71. package/dist/lib/component/playground/index.js +31 -33
  72. package/dist/lib/component/playground-result/index.css +10 -0
  73. package/dist/lib/component/playground-result/index.js +131 -12
  74. package/dist/lib/component/prompt-input/index.css +281 -31
  75. package/dist/lib/component/prompt-input/index.js +84 -26
  76. package/dist/lib/component/screenshot-viewer/index.css +214 -0
  77. package/dist/lib/component/screenshot-viewer/index.js +316 -0
  78. package/dist/lib/component/service-mode-control/index.js +3 -4
  79. package/dist/lib/component/shiny-text/index.css +35 -3
  80. package/dist/lib/component/shiny-text/index.js +5 -5
  81. package/dist/lib/component/universal-playground/index.css +61 -1
  82. package/dist/lib/component/universal-playground/index.js +108 -84
  83. package/dist/lib/component/universal-playground/providers/context-provider.js +58 -20
  84. package/dist/lib/component/universal-playground/providers/indexeddb-storage-provider.js +217 -143
  85. package/dist/lib/component/universal-playground/providers/storage-provider.js +207 -129
  86. package/dist/lib/hooks/usePlaygroundExecution.js +299 -148
  87. package/dist/lib/hooks/usePlaygroundState.js +143 -77
  88. package/dist/lib/hooks/useSafeOverrideAIConfig.js +4 -8
  89. package/dist/lib/hooks/useServerValid.js +39 -14
  90. package/dist/lib/hooks/useTheme.js +59 -0
  91. package/dist/lib/icons/avatar.js +48 -6
  92. package/dist/lib/icons/close.js +48 -6
  93. package/dist/lib/icons/global-perspective.js +49 -7
  94. package/dist/lib/icons/history.js +50 -8
  95. package/dist/lib/icons/magnifying-glass.js +49 -7
  96. package/dist/lib/icons/player-setting.js +50 -8
  97. package/dist/lib/icons/setting.js +49 -7
  98. package/dist/lib/icons/show-marker.js +49 -7
  99. package/dist/lib/index.js +44 -34
  100. package/dist/lib/store/history.js +48 -9
  101. package/dist/lib/store/store.js +74 -8
  102. package/dist/lib/types.js +3 -3
  103. package/dist/lib/utils/color.js +2 -2
  104. package/dist/lib/utils/constants.js +20 -4
  105. package/dist/lib/utils/index.js +10 -4
  106. package/dist/lib/utils/pixi-loader.js +41 -15
  107. package/dist/lib/utils/playground-utils.js +4 -4
  108. package/dist/lib/utils/replay-scripts.js +164 -115
  109. package/dist/types/component/config-selector/index.d.ts +2 -0
  110. package/dist/types/component/player/index.d.ts +0 -1
  111. package/dist/types/component/playground-result/index.d.ts +1 -0
  112. package/dist/types/component/prompt-input/index.d.ts +2 -1
  113. package/dist/types/component/screenshot-viewer/index.d.ts +15 -0
  114. package/dist/types/hooks/usePlaygroundExecution.d.ts +1 -1
  115. package/dist/types/hooks/usePlaygroundState.d.ts +3 -3
  116. package/dist/types/hooks/useTheme.d.ts +7 -0
  117. package/dist/types/index.d.ts +3 -3
  118. package/dist/types/store/store.d.ts +18 -1
  119. package/dist/types/types.d.ts +14 -4
  120. package/dist/types/utils/constants.d.ts +5 -1
  121. package/dist/types/utils/index.d.ts +1 -0
  122. package/dist/types/utils/replay-scripts.d.ts +1 -1
  123. package/package.json +12 -22
@@ -1,15 +1,57 @@
1
1
  import { jsx, jsxs } from "react/jsx-runtime";
2
2
  import "react";
3
- const SvgMagnifyingGlass = (props)=>/*#__PURE__*/ jsxs("svg", {
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
- ...props,
50
+ viewBox: "0 0 19 19"
51
+ }, props), {
10
52
  children: [
11
53
  /*#__PURE__*/ jsxs("g", {
12
- stroke: "#000",
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
- const SvgPlayerSetting = (props)=>/*#__PURE__*/ jsxs("svg", {
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
- ...props,
50
+ viewBox: "0 0 16 16"
51
+ }, props), {
10
52
  children: [
11
53
  /*#__PURE__*/ jsx("path", {
12
- stroke: "#333",
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: "#333",
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
- const SvgSetting = (props)=>/*#__PURE__*/ jsx("svg", {
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
- ...props,
50
+ viewBox: "0 0 27 27"
51
+ }, props), {
10
52
  children: /*#__PURE__*/ jsx("path", {
11
- stroke: "#000",
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
- const SvgShowMarker = (props)=>/*#__PURE__*/ jsx("svg", {
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
- ...props,
50
+ viewBox: "0 0 16 16"
51
+ }, props), {
10
52
  children: /*#__PURE__*/ jsx("path", {
11
- fill: "#333",
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) || 'aiAction';
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
  });
@@ -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 useBlackboardPreference = store_create((set)=>{
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 { useBlackboardPreference, useEnvConfig };
252
+ export { useEnvConfig, useGlobalPreference };
package/dist/es/types.mjs CHANGED
@@ -13,7 +13,7 @@ const VALIDATION_CONSTANTS = {
13
13
  LOCATION: 'midscene_location_field_flag'
14
14
  },
15
15
  DEFAULT_VALUES: {
16
- ACTION_TYPE: 'aiAction',
16
+ ACTION_TYPE: 'aiAct',
17
17
  TIMEOUT_MS: 15000,
18
18
  CHECK_INTERVAL_MS: 3000
19
19
  }
@@ -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
- aiAction: {
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
- 'aiAction',
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 };
@@ -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 };