@netless/window-manager 0.3.12-canary.0 → 0.3.15

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/style.css CHANGED
@@ -1 +1 @@
1
- .netless-window-manager-playground{width:100%;height:100%;position:relative;z-index:1;overflow:hidden}.netless-window-manager-sizer{position:absolute;top:0;left:0;width:100%;height:100%;z-index:1;overflow:hidden;display:flex}.netless-window-manager-sizer-horizontal{flex-direction:column}.netless-window-manager-sizer:before,.netless-window-manager-sizer:after{flex:1;content:"";display:block}.netless-window-manager-chess-sizer:before,.netless-window-manager-chess-sizer:after{background-image:linear-gradient(45deg,#b0b0b0 25%,transparent 25%),linear-gradient(-45deg,#b0b0b0 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#b0b0b0 75%),linear-gradient(-45deg,transparent 75%,#b0b0b0 75%);background-color:#fff;background-size:20px 20px;background-position:0 0,0 10px,10px -10px,-10px 0px}.netless-window-manager-wrapper{position:relative;z-index:1;width:100%;height:100%;overflow:hidden}.netless-window-manager-main-view{width:100%;height:100%}.netless-window-manager-cursor-pencil-image{width:26px;height:26px}.netless-window-manager-cursor-eraser-image{width:26px;height:26px}.netless-window-manager-cursor-selector-image{width:24px;height:24px}.netless-window-manager-cursor-selector-avatar{border-radius:50%;border-style:solid;border-width:2px;border-color:#fff;margin-bottom:2px}.netless-window-manager-cursor-selector-avatar img{width:12px}.netless-window-manager-cursor-inner{border-radius:4px;display:flex;align-items:center;justify-content:center;flex-direction:row;padding-left:4px;padding-right:4px;font-size:12px}.netless-window-manager-cursor-inner-mellow{height:32px;border-radius:16px;display:flex;align-items:center;justify-content:center;flex-direction:row;padding-left:16px;padding-right:16px}.netless-window-manager-cursor-tag-name{font-size:12px;margin-left:4px;padding:2px 8px;border-radius:4px}.netless-window-manager-cursor-mid{display:flex;flex-direction:column;align-items:center;justify-content:center;position:fixed;width:26px;height:26px;z-index:2147483647;left:0;top:0;will-change:transform;transition:transform .05s;transform-origin:0 0;user-select:none}.netless-window-manager-cursor-pencil-offset{margin-left:-20px}.netless-window-manager-cursor-selector-offset{margin-left:-22px;margin-top:56px}.netless-window-manager-cursor-text-offset{margin-left:-30px;margin-top:18px}.netless-window-manager-cursor-shape-offset{display:flex;flex-direction:column;align-items:center;justify-content:center;position:absolute;width:180px;height:64px;margin-left:-30px;margin-top:12px}.netless-window-manager-cursor-name{width:100%;height:48px;display:flex;align-items:center;justify-content:center;position:absolute;top:-40px}.cursor-image-wrapper{display:flex;justify-content:center}.tele-fancy-scrollbar{overscroll-behavior:contain;overflow:auto;overflow-y:scroll;overflow-y:overlay;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar;scrollbar-width:auto}.tele-fancy-scrollbar::-webkit-scrollbar{height:8px;width:8px}.tele-fancy-scrollbar::-webkit-scrollbar-track{background-color:transparent}.tele-fancy-scrollbar::-webkit-scrollbar-thumb{background-color:#444e601a;background-color:transparent;border-radius:4px;transition:background-color .4s}.tele-fancy-scrollbar:hover::-webkit-scrollbar-thumb{background-color:#444e601a}.tele-fancy-scrollbar::-webkit-scrollbar-thumb:hover{background-color:#444e6033}.tele-fancy-scrollbar::-webkit-scrollbar-thumb:active{background-color:#444e6033}.tele-fancy-scrollbar::-webkit-scrollbar-thumb:vertical{min-height:50px}.tele-fancy-scrollbar::-webkit-scrollbar-thumb:horizontal{min-width:50px}.telebox-box{position:absolute;top:0;left:0;z-index:100;will-change:transform;transition:width .4s cubic-bezier(.4,.9,.71,1.02),height .4s cubic-bezier(.55,.82,.63,.95),opacity .6s cubic-bezier(.7,0,.84,0),transform .4s ease}.telebox-box-main{position:relative;width:100%;height:100%;display:flex;flex-direction:column;overflow:hidden;background:#f9f9fc;box-shadow:0 4px 10px #2f419226;border-radius:6px;border:1px solid #e3e3ec}.telebox-titlebar-wrap{flex-shrink:0;position:relative;z-index:1}.telebox-content-wrap{flex:1;width:100%;overflow:hidden;display:flex;justify-content:center;align-items:center}.telebox-content{width:100%;height:100%;position:relative}.telebox-footer-wrap{flex-shrink:0;display:flex;flex-direction:column}.telebox-footer-wrap:before{content:"";display:block;flex:1}.telebox-resize-handle{position:absolute;z-index:2147483647}.telebox-n{width:100%;height:5px;left:0;top:-5px;cursor:n-resize}.telebox-s{width:100%;height:5px;left:0;bottom:-5px;cursor:s-resize}.telebox-w{width:5px;height:100%;left:-5px;top:0;cursor:w-resize}.telebox-e{width:5px;height:100%;right:-5px;top:0;cursor:e-resize}.telebox-nw{width:15px;height:15px;top:-5px;left:-5px;cursor:nw-resize}.telebox-ne{width:15px;height:15px;top:-5px;right:-5px;cursor:ne-resize}.telebox-se{width:15px;height:15px;bottom:-5px;right:-5px;cursor:se-resize}.telebox-sw{width:15px;height:15px;bottom:-5px;left:-5px;cursor:sw-resize}.telebox-track-mask{position:fixed;top:0;left:0;z-index:2147483647;width:100%;height:100%;background:rgba(0,0,0,.0001);cursor:move}.telebox-cursor-n{cursor:n-resize}.telebox-cursor-s{cursor:s-resize}.telebox-cursor-w{cursor:w-resize}.telebox-cursor-e{cursor:e-resize}.telebox-cursor-nw{cursor:nw-resize}.telebox-cursor-ne{cursor:ne-resize}.telebox-cursor-se{cursor:se-resize}.telebox-cursor-sw{cursor:sw-resize}.telebox-maximized .telebox-resize-handles,.telebox-no-resize .telebox-resize-handles{display:none}.telebox-maximized{box-shadow:none;transition:none}.telebox-minimized{will-change:transform;transition:width 50ms cubic-bezier(.4,.9,.71,1.02),height 50ms cubic-bezier(.55,.82,.63,.95),opacity .6s cubic-bezier(.7,0,.84,0),transform .6s ease;opacity:0;pointer-events:none;user-select:none}.telebox-transforming{will-change:transform;transition:opacity .6s cubic-bezier(.7,0,.84,0)}.telebox-readonly .telebox-resize-handle{cursor:initial!important;pointer-events:none!important}.telebox-color-scheme-dark .telebox-box-main{color:#e9e9e9;background:#212126;border-color:#43434d}.telebox-titlebar{box-sizing:border-box;height:26px;display:flex;align-items:center;padding:0 16px;background:#fff;user-select:none;border-bottom:1px solid #eeeef7}.telebox-title{overflow:hidden;margin:0 24px 0 0;padding:0;font-size:14px;font-weight:400;font-family:PingFangSC-Regular,PingFang SC;white-space:nowrap;word-break:keep-all;text-overflow:ellipsis;color:#191919}.telebox-titlebar-btns{white-space:nowrap;word-break:keep-all;margin-left:auto;font-size:0}.telebox-titlebar-btn{width:22px;height:22px;padding:0;outline:0;border:none;background:0 0;cursor:pointer}.telebox-titlebar-btn~.telebox-titlebar-btn{margin-left:10px}.telebox-titlebar-btn-icon{width:22px;height:22px}.telebox-readonly .telebox-titlebar-btn{cursor:not-allowed}.telebox-titlebar-icon-minimize{background:center/cover no-repeat url()}.telebox-titlebar-icon-maximize{background:center/cover no-repeat url()}.telebox-titlebar-icon-maximize.is-active{background-image:url()}.telebox-titlebar-icon-close{background:center/cover no-repeat url()}.telebox-color-scheme-dark .telebox-title{color:#e9e9e9}.telebox-color-scheme-dark .telebox-titlebar{color:#e9e9e9;background:#43434d;border-bottom:none}.telebox-collector{visibility:hidden;display:block;position:absolute;z-index:200;width:40px;height:40px;margin:0;padding:0;border:none;outline:0;font-size:0;border-radius:50%;background:#fff;box-shadow:0 2px 6px #2f419226;cursor:pointer;user-select:none;pointer-events:none}.telebox-collector-icon{width:18px;height:16px}.telebox-collector-visible{visibility:visible;pointer-events:initial}.telebox-collector-readonly{cursor:not-allowed}.telebox-max-titlebar{display:none;position:absolute;top:0;left:0;z-index:50000;user-select:none}.telebox-max-titlebar-maximized{display:flex}.telebox-titles{flex:1;height:100%;margin:0 16px 0 -16px;overflow-y:hidden;overflow-x:scroll;overflow-x:overlay;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar;scrollbar-width:auto}.telebox-titles::-webkit-scrollbar{height:8px;width:8px}.telebox-titles::-webkit-scrollbar-track{background-color:transparent}.telebox-titles::-webkit-scrollbar-thumb{background-color:#eeeef7cc;background-color:transparent;border-radius:4px;transition:background-color .4s}.telebox-titles:hover::-webkit-scrollbar-thumb{background-color:#eeeef7cc}.telebox-titles::-webkit-scrollbar-thumb:hover{background-color:#eeeef7}.telebox-titles::-webkit-scrollbar-thumb:active{background-color:#eeeef7}.telebox-titles::-webkit-scrollbar-thumb:vertical{min-height:50px}.telebox-titles::-webkit-scrollbar-thumb:horizontal{min-width:50px}.telebox-titles-content{height:100%;display:flex;flex-wrap:nowrap;align-items:center;padding:0}.telebox-titles-tab{overflow:hidden;max-width:182px;min-width:50px;padding:0 26px 0 16px;outline:0;font-size:13px;font-family:PingFangSC-Regular,PingFang SC;font-weight:400;text-overflow:ellipsis;white-space:nowrap;word-break:keep-all;border:none;border-right:1px solid #e5e5f0;color:#7b88a0;background:0 0;cursor:pointer}.telebox-titles-tab~.telebox-titles-tab{margin-left:2px}.telebox-titles-tab-focus{color:#357bf6}.telebox-readonly .telebox-titles-tab{cursor:not-allowed}
1
+ .netless-window-manager-playground{width:100%;height:100%;position:relative;z-index:1;overflow:hidden;user-select:none}.netless-window-manager-sizer{position:absolute;top:0;left:0;width:100%;height:100%;z-index:1;overflow:hidden;display:flex}.netless-window-manager-sizer-horizontal{flex-direction:column}.netless-window-manager-sizer:before,.netless-window-manager-sizer:after{flex:1;content:"";display:block}.netless-window-manager-chess-sizer:before,.netless-window-manager-chess-sizer:after{background-image:linear-gradient(45deg,#b0b0b0 25%,transparent 25%),linear-gradient(-45deg,#b0b0b0 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#b0b0b0 75%),linear-gradient(-45deg,transparent 75%,#b0b0b0 75%);background-color:#fff;background-size:20px 20px;background-position:0 0,0 10px,10px -10px,-10px 0px}.netless-window-manager-wrapper{position:relative;z-index:1;width:100%;height:100%;overflow:hidden}.netless-window-manager-main-view{width:100%;height:100%}.netless-window-manager-cursor-pencil-image{width:26px;height:26px}.netless-window-manager-cursor-eraser-image{width:26px;height:26px}.netless-window-manager-cursor-selector-image{width:24px;height:24px}.netless-window-manager-cursor-selector-avatar{border-radius:50%;border-style:solid;border-width:2px;border-color:#fff;margin-bottom:2px}.netless-window-manager-cursor-selector-avatar img{width:12px}.netless-window-manager-cursor-inner{border-radius:4px;display:flex;align-items:center;justify-content:center;flex-direction:row;padding-left:4px;padding-right:4px;font-size:12px}.netless-window-manager-cursor-inner-mellow{height:32px;border-radius:16px;display:flex;align-items:center;justify-content:center;flex-direction:row;padding-left:16px;padding-right:16px}.netless-window-manager-cursor-tag-name{font-size:12px;margin-left:4px;padding:2px 8px;border-radius:4px}.netless-window-manager-cursor-mid{display:flex;flex-direction:column;align-items:center;justify-content:center;position:fixed;width:26px;height:26px;z-index:2147483647;left:0;top:0;will-change:transform;transition:transform .05s;transform-origin:0 0;user-select:none}.netless-window-manager-cursor-pencil-offset{margin-left:-20px}.netless-window-manager-cursor-selector-offset{margin-left:-22px;margin-top:56px}.netless-window-manager-cursor-text-offset{margin-left:-30px;margin-top:18px}.netless-window-manager-cursor-shape-offset{display:flex;flex-direction:column;align-items:center;justify-content:center;position:absolute;width:180px;height:64px;margin-left:-30px;margin-top:12px}.netless-window-manager-cursor-name{width:100%;height:48px;display:flex;align-items:center;justify-content:center;position:absolute;top:-40px}.cursor-image-wrapper{display:flex;justify-content:center}.tele-fancy-scrollbar{overscroll-behavior:contain;overflow:auto;overflow-y:scroll;overflow-y:overlay;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar;scrollbar-width:auto}.tele-fancy-scrollbar::-webkit-scrollbar{height:8px;width:8px}.tele-fancy-scrollbar::-webkit-scrollbar-track{background-color:transparent}.tele-fancy-scrollbar::-webkit-scrollbar-thumb{background-color:#444e601a;background-color:transparent;border-radius:4px;transition:background-color .4s}.tele-fancy-scrollbar:hover::-webkit-scrollbar-thumb{background-color:#444e601a}.tele-fancy-scrollbar::-webkit-scrollbar-thumb:hover{background-color:#444e6033}.tele-fancy-scrollbar::-webkit-scrollbar-thumb:active{background-color:#444e6033}.tele-fancy-scrollbar::-webkit-scrollbar-thumb:vertical{min-height:50px}.tele-fancy-scrollbar::-webkit-scrollbar-thumb:horizontal{min-width:50px}.telebox-box{position:absolute;top:0;left:0;z-index:100;will-change:transform;transition:width .4s cubic-bezier(.4,.9,.71,1.02),height .4s cubic-bezier(.55,.82,.63,.95),opacity .6s cubic-bezier(.7,0,.84,0),transform .4s ease}.telebox-box-main{position:relative;width:100%;height:100%;display:flex;flex-direction:column;overflow:hidden;background:#f9f9fc;box-shadow:0 4px 10px #2f419226;border-radius:6px;border:1px solid #e3e3ec}.telebox-titlebar-wrap{flex-shrink:0;position:relative;z-index:1}.telebox-content-wrap{flex:1;width:100%;overflow:hidden;display:flex;justify-content:center;align-items:center}.telebox-content{width:100%;height:100%;position:relative}.telebox-footer-wrap{flex-shrink:0;display:flex;flex-direction:column}.telebox-footer-wrap:before{content:"";display:block;flex:1}.telebox-resize-handle{position:absolute;z-index:2147483647}.telebox-n{width:100%;height:5px;left:0;top:-5px;cursor:n-resize}.telebox-s{width:100%;height:5px;left:0;bottom:-5px;cursor:s-resize}.telebox-w{width:5px;height:100%;left:-5px;top:0;cursor:w-resize}.telebox-e{width:5px;height:100%;right:-5px;top:0;cursor:e-resize}.telebox-nw{width:15px;height:15px;top:-5px;left:-5px;cursor:nw-resize}.telebox-ne{width:15px;height:15px;top:-5px;right:-5px;cursor:ne-resize}.telebox-se{width:15px;height:15px;bottom:-5px;right:-5px;cursor:se-resize}.telebox-sw{width:15px;height:15px;bottom:-5px;left:-5px;cursor:sw-resize}.telebox-track-mask{position:fixed;top:0;left:0;z-index:2147483647;width:100%;height:100%;background:rgba(0,0,0,.0001);cursor:move}.telebox-cursor-n{cursor:n-resize}.telebox-cursor-s{cursor:s-resize}.telebox-cursor-w{cursor:w-resize}.telebox-cursor-e{cursor:e-resize}.telebox-cursor-nw{cursor:nw-resize}.telebox-cursor-ne{cursor:ne-resize}.telebox-cursor-se{cursor:se-resize}.telebox-cursor-sw{cursor:sw-resize}.telebox-maximized .telebox-resize-handles,.telebox-no-resize .telebox-resize-handles{display:none}.telebox-maximized{box-shadow:none;transition:none}.telebox-minimized{will-change:transform;transition:width 50ms cubic-bezier(.4,.9,.71,1.02),height 50ms cubic-bezier(.55,.82,.63,.95),opacity .6s cubic-bezier(.7,0,.84,0),transform .6s ease;opacity:0;pointer-events:none;user-select:none}.telebox-transforming{will-change:transform;transition:opacity .6s cubic-bezier(.7,0,.84,0)}.telebox-readonly .telebox-resize-handle{cursor:initial!important;pointer-events:none!important}.telebox-color-scheme-dark .telebox-box-main{color:#e9e9e9;background:#212126;border-color:#43434d}.telebox-titlebar{box-sizing:border-box;height:26px;display:flex;align-items:center;padding:0 16px;background:#fff;user-select:none;border-bottom:1px solid #eeeef7}.telebox-title{overflow:hidden;margin:0 24px 0 0;padding:0;font-size:14px;font-weight:400;font-family:PingFangSC-Regular,PingFang SC;white-space:nowrap;word-break:keep-all;text-overflow:ellipsis;color:#191919}.telebox-titlebar-btns{white-space:nowrap;word-break:keep-all;margin-left:auto;font-size:0}.telebox-titlebar-btn{width:22px;height:22px;padding:0;outline:0;border:none;background:0 0;cursor:pointer}.telebox-titlebar-btn~.telebox-titlebar-btn{margin-left:10px}.telebox-titlebar-btn-icon{width:22px;height:22px}.telebox-readonly .telebox-titlebar-btn{cursor:not-allowed}.telebox-titlebar-icon-minimize{background:center/cover no-repeat url()}.telebox-titlebar-icon-maximize{background:center/cover no-repeat url()}.telebox-titlebar-icon-maximize.is-active{background-image:url()}.telebox-titlebar-icon-close{background:center/cover no-repeat url()}.telebox-color-scheme-dark .telebox-titlebar{color:#e9e9e9;background:#43434d;border-bottom:none}.telebox-collector{visibility:hidden;display:block;position:absolute;z-index:200;width:40px;height:40px;margin:0;padding:0;border:none;outline:0;font-size:0;border-radius:50%;background:#fff;box-shadow:0 2px 6px #2f419226;cursor:pointer;user-select:none;pointer-events:none;background-repeat:no-repeat;background-size:18px 16px;background-position:center}.telebox-collector-visible{visibility:visible;pointer-events:initial}.telebox-collector-readonly{cursor:not-allowed}.telebox-color-scheme-dark.telebox-collector{background-color:#43434d}.telebox-max-titlebar{display:none;position:absolute;top:0;left:0;z-index:50000;user-select:none}.telebox-max-titlebar-maximized{display:flex}.telebox-titles{flex:1;height:100%;margin:0 16px 0 -16px;overflow-y:hidden;overflow-x:scroll;overflow-x:overlay;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar;scrollbar-width:auto}.telebox-titles::-webkit-scrollbar{height:8px;width:8px}.telebox-titles::-webkit-scrollbar-track{background-color:transparent}.telebox-titles::-webkit-scrollbar-thumb{background-color:#eeeef7cc;background-color:transparent;border-radius:4px;transition:background-color .4s}.telebox-titles:hover::-webkit-scrollbar-thumb{background-color:#eeeef7cc}.telebox-titles::-webkit-scrollbar-thumb:hover{background-color:#eeeef7}.telebox-titles::-webkit-scrollbar-thumb:active{background-color:#eeeef7}.telebox-titles::-webkit-scrollbar-thumb:vertical{min-height:50px}.telebox-titles::-webkit-scrollbar-thumb:horizontal{min-width:50px}.telebox-titles-content{height:100%;display:flex;flex-wrap:nowrap;align-items:center;padding:0}.telebox-titles-tab{overflow:hidden;max-width:182px;min-width:50px;padding:0 26px 0 16px;outline:0;font-size:13px;font-family:PingFangSC-Regular,PingFang SC;font-weight:400;text-overflow:ellipsis;white-space:nowrap;word-break:keep-all;border:none;border-right:1px solid #e5e5f0;color:#7b88a0;background:0 0;cursor:pointer}.telebox-titles-tab~.telebox-titles-tab{margin-left:2px}.telebox-titles-tab-focus{color:#357bf6}.telebox-readonly .telebox-titles-tab{cursor:not-allowed}.telebox-color-scheme-dark{color-scheme:dark}.telebox-color-scheme-dark.telebox-titlebar{color:#e9e9e9;background:#43434d;border-bottom:none}.telebox-color-scheme-dark .telebox-titles-tab{border-right-color:#7b88a0}.telebox-color-scheme-dark .telebox-title{color:#e9e9e9}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@netless/window-manager",
3
- "version": "0.3.12-canary.0",
3
+ "version": "0.3.15",
4
4
  "description": "",
5
5
  "main": "dist/index.es.js",
6
6
  "module": "dist/index.es.js",
@@ -22,9 +22,9 @@
22
22
  },
23
23
  "dependencies": {
24
24
  "@juggle/resize-observer": "^3.3.1",
25
- "@netless/app-docs-viewer": "^0.1.21",
25
+ "@netless/app-docs-viewer": "0.1.24",
26
26
  "@netless/app-media-player": "0.1.0-beta.5",
27
- "@netless/telebox-insider": "0.2.8",
27
+ "@netless/telebox-insider": "0.2.10",
28
28
  "emittery": "^0.9.2",
29
29
  "lodash": "^4.17.21",
30
30
  "p-retry": "^4.6.1",
package/src/BoxManager.ts CHANGED
@@ -1,24 +1,19 @@
1
1
  import { callbacks, emitter, WindowManager } from "./index";
2
2
  import { debounce, maxBy } from "lodash";
3
- import {
4
- DEFAULT_COLLECTOR_STYLE,
5
- Events,
6
- MIN_HEIGHT,
7
- MIN_WIDTH
8
- } from "./constants";
9
- import type { AddAppOptions, AppInitState } from "./index";
3
+ import { DEFAULT_COLLECTOR_STYLE, Events, MIN_HEIGHT, MIN_WIDTH } from "./constants";
10
4
  import {
11
5
  TELE_BOX_MANAGER_EVENT,
12
6
  TELE_BOX_STATE,
13
7
  TeleBoxCollector,
14
8
  TeleBoxManager,
15
- TeleBoxColorScheme
16
9
  } from "@netless/telebox-insider";
10
+ import type { AddAppOptions, AppInitState } from "./index";
17
11
  import type {
18
12
  TeleBoxManagerUpdateConfig,
19
13
  TeleBoxManagerCreateConfig,
20
14
  ReadonlyTeleBox,
21
15
  TeleBoxManagerConfig,
16
+ TeleBoxColorScheme,
22
17
  } from "@netless/telebox-insider";
23
18
  import type Emittery from "emittery";
24
19
  import type { AppManager } from "./AppManager";
@@ -59,7 +54,7 @@ export class BoxManager {
59
54
 
60
55
  constructor(
61
56
  private manager: AppManager,
62
- createTeleBoxManagerConfig?: CreateTeleBoxManagerConfig,
57
+ createTeleBoxManagerConfig?: CreateTeleBoxManagerConfig
63
58
  ) {
64
59
  this.teleBoxManager = this.setupBoxManager(createTeleBoxManagerConfig);
65
60
  this.teleBoxManager.events.on(TELE_BOX_MANAGER_EVENT.State, state => {
@@ -71,7 +66,7 @@ export class BoxManager {
71
66
  this.teleBoxManager.events.on("minimized", minimized => {
72
67
  this.manager.safeSetAttributes({ minimized });
73
68
  });
74
- this.teleBoxManager.events.on("maximized", maximized => {
69
+ this.teleBoxManager.events.on("maximized", maximized => {
75
70
  this.manager.safeSetAttributes({ maximized });
76
71
  });
77
72
  this.teleBoxManager.events.on("removed", boxes => {
@@ -88,7 +83,11 @@ export class BoxManager {
88
83
  this.teleBoxManager.events.on(
89
84
  "intrinsic_resize",
90
85
  debounce((box: ReadonlyTeleBox): void => {
91
- emitter.emit("resize", { appId: box.id, width: box.intrinsicWidth, height: box.intrinsicHeight });
86
+ emitter.emit("resize", {
87
+ appId: box.id,
88
+ width: box.intrinsicWidth,
89
+ height: box.intrinsicHeight,
90
+ });
92
91
  }, 200)
93
92
  );
94
93
  this.teleBoxManager.events.on("focused", box => {
@@ -102,6 +101,12 @@ export class BoxManager {
102
101
  this.blurFocusBox();
103
102
  }
104
103
  });
104
+ this.teleBoxManager.events.on("dark_mode", darkMode => {
105
+ callbacks.emit("darkModeChange", darkMode);
106
+ });
107
+ this.teleBoxManager.events.on("prefers_color_scheme", colorScheme => {
108
+ callbacks.emit("prefersColorSchemeChange", colorScheme);
109
+ });
105
110
  }
106
111
 
107
112
  public get boxState() {
@@ -116,6 +121,14 @@ export class BoxManager {
116
121
  return this.teleBoxManager.minimized;
117
122
  }
118
123
 
124
+ public get darkMode() {
125
+ return this.teleBoxManager.darkMode;
126
+ }
127
+
128
+ public get prefersColorScheme(): TeleBoxColorScheme {
129
+ return this.teleBoxManager.prefersColorScheme;
130
+ }
131
+
119
132
  public createBox(params: CreateBoxParams): void {
120
133
  if (!this.teleBoxManager) return;
121
134
  let { minwidth = MIN_WIDTH, minheight = MIN_HEIGHT } = params.app.config ?? {};
@@ -158,7 +171,9 @@ export class BoxManager {
158
171
  }
159
172
  }
160
173
 
161
- public setupBoxManager(createTeleBoxManagerConfig?: CreateTeleBoxManagerConfig): TeleBoxManager {
174
+ public setupBoxManager(
175
+ createTeleBoxManagerConfig?: CreateTeleBoxManagerConfig
176
+ ): TeleBoxManager {
162
177
  const root = WindowManager.wrapper ? WindowManager.wrapper : document.body;
163
178
  const rect = root.getBoundingClientRect();
164
179
  const initManagerState: TeleBoxManagerConfig = {
@@ -173,7 +188,10 @@ export class BoxManager {
173
188
  prefersColorScheme: createTeleBoxManagerConfig?.prefersColorScheme,
174
189
  };
175
190
  const container = createTeleBoxManagerConfig?.collectorContainer || WindowManager.wrapper;
176
- const styles = { ...DEFAULT_COLLECTOR_STYLE, ...createTeleBoxManagerConfig?.collectorStyles };
191
+ const styles = {
192
+ ...DEFAULT_COLLECTOR_STYLE,
193
+ ...createTeleBoxManagerConfig?.collectorStyles,
194
+ };
177
195
  const teleBoxCollector = new TeleBoxCollector({
178
196
  styles: styles,
179
197
  // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
@@ -227,7 +245,7 @@ export class BoxManager {
227
245
  if (state.maximized != null) {
228
246
  this.teleBoxManager.setMaximized(Boolean(state.maximized), true);
229
247
  this.teleBoxManager.setMinimized(Boolean(state.minimized), true);
230
- }
248
+ }
231
249
  setTimeout(() => {
232
250
  if (state.focus) {
233
251
  this.teleBoxManager.update(box.id, { focus: true }, true);
@@ -301,6 +319,10 @@ export class BoxManager {
301
319
  this.teleBoxManager.setReadonly(readonly);
302
320
  }
303
321
 
322
+ public setPrefersColorScheme(colorScheme: TeleBoxColorScheme) {
323
+ this.teleBoxManager.setPrefersColorScheme(colorScheme);
324
+ }
325
+
304
326
  public destroy() {
305
327
  this.teleBoxManager.destroy();
306
328
  }
package/src/MainView.ts CHANGED
@@ -88,6 +88,10 @@ export class MainViewProxy extends Base {
88
88
  return this.mainView;
89
89
  }
90
90
 
91
+ public get cameraState() {
92
+ return { ...this.view.camera, ...this.view.size };
93
+ }
94
+
91
95
  public createMainView(): View {
92
96
  const mainView = createView(this.manager.displayer);
93
97
  mainView.callbacks.on("onSizeUpdated", () => {
@@ -139,6 +143,7 @@ export class MainViewProxy extends Base {
139
143
 
140
144
  private sizeListener = (size: Size) => {
141
145
  this.setMainViewSize(size);
146
+ callbacks.emit("cameraStateChange", this.cameraState);
142
147
  };
143
148
 
144
149
  public setMainViewSize = debounce(size => {
@@ -147,10 +152,16 @@ export class MainViewProxy extends Base {
147
152
 
148
153
  private addCameraListener() {
149
154
  this.view.callbacks.on("onCameraUpdatedByDevice", this.cameraListener);
155
+ this.view.callbacks.on("onCameraUpdated", this.cameraStateChangeListener);
150
156
  }
151
157
 
152
158
  private removeCameraListener() {
153
159
  this.view.callbacks.off("onCameraUpdatedByDevice", this.cameraListener);
160
+ this.view.callbacks.off("onCameraUpdated", this.cameraStateChangeListener)
161
+ }
162
+
163
+ private cameraStateChangeListener = () => {
164
+ callbacks.emit("cameraStateChange", this.cameraState);
154
165
  }
155
166
 
156
167
  public switchViewModeToWriter(): void {
package/src/index.ts CHANGED
@@ -51,6 +51,7 @@ import type {
51
51
  Point,
52
52
  Rectangle,
53
53
  ViewVisionMode,
54
+ CameraState,
54
55
  } from "white-web-sdk";
55
56
  import type { AppListeners } from "./AppListener";
56
57
  import type { NetlessApp, RegisterParams } from "./typings";
@@ -141,6 +142,9 @@ export const emitter: Emittery<EmitterEvent> = new Emittery();
141
142
  export type PublicEvent = {
142
143
  mainViewModeChange: ViewVisionMode;
143
144
  boxStateChange: `${TELE_BOX_STATE}`;
145
+ darkModeChange: boolean;
146
+ prefersColorSchemeChange: TeleBoxColorScheme;
147
+ cameraStateChange: CameraState;
144
148
  };
145
149
 
146
150
  export type MountParams = {
@@ -171,7 +175,7 @@ export class WindowManager extends InvisiblePlugin<WindowMangerAttributes> {
171
175
  public static containerSizeRatio = DEFAULT_CONTAINER_RATIO;
172
176
  private static isCreated = false;
173
177
 
174
- public version = "0.3.12-canary.0";
178
+ public version = "0.3.15";
175
179
 
176
180
  public appListeners?: AppListeners;
177
181
 
@@ -306,7 +310,7 @@ export class WindowManager extends InvisiblePlugin<WindowMangerAttributes> {
306
310
  manager.appManager = new AppManager(manager, {
307
311
  collectorContainer: collectorContainer,
308
312
  collectorStyles: collectorStyles,
309
- prefersColorScheme: prefersColorScheme
313
+ prefersColorScheme: prefersColorScheme,
310
314
  });
311
315
  manager.observePlaygroundSize(playground, sizer, wrapper);
312
316
  if (cursor) {
@@ -513,6 +517,14 @@ export class WindowManager extends InvisiblePlugin<WindowMangerAttributes> {
513
517
  }
514
518
  }
515
519
 
520
+ public get cameraState(): CameraState {
521
+ if (this.appManager) {
522
+ return this.appManager.mainViewProxy.cameraState;
523
+ } else {
524
+ throw new AppManagerNotInitError();
525
+ }
526
+ }
527
+
516
528
  public get apps(): Apps | undefined {
517
529
  return this.appManager?.store.apps();
518
530
  }
@@ -525,6 +537,18 @@ export class WindowManager extends InvisiblePlugin<WindowMangerAttributes> {
525
537
  }
526
538
  }
527
539
 
540
+ public get darkMode(): boolean {
541
+ return Boolean(this.appManager?.boxManager.darkMode);
542
+ }
543
+
544
+ public get prefersColorScheme(): TeleBoxColorScheme {
545
+ if (this.appManager) {
546
+ return this.appManager.boxManager.prefersColorScheme;
547
+ } else {
548
+ throw new AppManagerNotInitError();
549
+ }
550
+ }
551
+
528
552
  /**
529
553
  * 查询所有的 App
530
554
  */
@@ -624,6 +648,10 @@ export class WindowManager extends InvisiblePlugin<WindowMangerAttributes> {
624
648
  }
625
649
  }
626
650
 
651
+ public setPrefersColorScheme(scheme: TeleBoxColorScheme): void {
652
+ this.appManager?.boxManager.setPrefersColorScheme(scheme);
653
+ }
654
+
627
655
  private isDynamicPPT(scenes: SceneDefinition[]) {
628
656
  const sceneSrc = scenes[0]?.ppt?.src;
629
657
  return sceneSrc?.startsWith("pptx://");
package/src/style.css CHANGED
@@ -4,6 +4,7 @@
4
4
  position: relative;
5
5
  z-index: 1;
6
6
  overflow: hidden;
7
+ user-select: none;
7
8
  }
8
9
 
9
10
  .netless-window-manager-sizer {