@netless/window-manager 0.3.10 → 0.3.12

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-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-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.10",
3
+ "version": "0.3.12",
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.22",
26
26
  "@netless/app-media-player": "0.1.0-beta.5",
27
- "@netless/telebox-insider": "0.2.7",
27
+ "@netless/telebox-insider": "0.2.9",
28
28
  "emittery": "^0.9.2",
29
29
  "lodash": "^4.17.21",
30
30
  "p-retry": "^4.6.1",
package/src/AppManager.ts CHANGED
@@ -25,7 +25,7 @@ import { onObjectRemoved, safeListenPropsUpdated } from "./Utils/Reactive";
25
25
  import { ReconnectRefresher } from "./ReconnectRefresher";
26
26
  import { ViewManager } from "./ViewManager";
27
27
  import type { Displayer, DisplayerState, Room } from "white-web-sdk";
28
- import type { CreateCollectorConfig } from "./BoxManager";
28
+ import type { CreateTeleBoxManagerConfig } from "./BoxManager";
29
29
  import type {
30
30
  AddAppParams,
31
31
  BaseInsertParams,
@@ -47,7 +47,7 @@ export class AppManager {
47
47
 
48
48
  private appListeners: AppListeners;
49
49
 
50
- constructor(public windowManger: WindowManager, options: CreateCollectorConfig) {
50
+ constructor(public windowManger: WindowManager, options: CreateTeleBoxManagerConfig) {
51
51
  this.displayer = windowManger.displayer;
52
52
  this.cameraStore = new CameraStore();
53
53
  this.mainViewProxy = new MainViewProxy(this);
package/src/BoxManager.ts CHANGED
@@ -1,23 +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
9
  } from "@netless/telebox-insider";
10
+ import type { AddAppOptions, AppInitState } from "./index";
16
11
  import type {
17
12
  TeleBoxManagerUpdateConfig,
18
13
  TeleBoxManagerCreateConfig,
19
14
  ReadonlyTeleBox,
20
15
  TeleBoxManagerConfig,
16
+ TeleBoxColorScheme,
21
17
  } from "@netless/telebox-insider";
22
18
  import type Emittery from "emittery";
23
19
  import type { AppManager } from "./AppManager";
@@ -45,9 +41,10 @@ type SetBoxMinSizeParams = AppId & { minWidth: number; minHeight: number };
45
41
 
46
42
  type SetBoxTitleParams = AppId & { title: string };
47
43
 
48
- export type CreateCollectorConfig = {
44
+ export type CreateTeleBoxManagerConfig = {
49
45
  collectorContainer?: HTMLElement;
50
46
  collectorStyles?: Partial<CSSStyleDeclaration>;
47
+ prefersColorScheme?: TeleBoxColorScheme;
51
48
  };
52
49
 
53
50
  export class BoxManager {
@@ -57,9 +54,9 @@ export class BoxManager {
57
54
 
58
55
  constructor(
59
56
  private manager: AppManager,
60
- collectorConfig?: CreateCollectorConfig
57
+ createTeleBoxManagerConfig?: CreateTeleBoxManagerConfig
61
58
  ) {
62
- this.teleBoxManager = this.setupBoxManager(collectorConfig);
59
+ this.teleBoxManager = this.setupBoxManager(createTeleBoxManagerConfig);
63
60
  this.teleBoxManager.events.on(TELE_BOX_MANAGER_EVENT.State, state => {
64
61
  if (state) {
65
62
  callbacks.emit("boxStateChange", state);
@@ -69,7 +66,7 @@ export class BoxManager {
69
66
  this.teleBoxManager.events.on("minimized", minimized => {
70
67
  this.manager.safeSetAttributes({ minimized });
71
68
  });
72
- this.teleBoxManager.events.on("maximized", maximized => {
69
+ this.teleBoxManager.events.on("maximized", maximized => {
73
70
  this.manager.safeSetAttributes({ maximized });
74
71
  });
75
72
  this.teleBoxManager.events.on("removed", boxes => {
@@ -86,7 +83,11 @@ export class BoxManager {
86
83
  this.teleBoxManager.events.on(
87
84
  "intrinsic_resize",
88
85
  debounce((box: ReadonlyTeleBox): void => {
89
- 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
+ });
90
91
  }, 200)
91
92
  );
92
93
  this.teleBoxManager.events.on("focused", box => {
@@ -100,6 +101,12 @@ export class BoxManager {
100
101
  this.blurFocusBox();
101
102
  }
102
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
+ });
103
110
  }
104
111
 
105
112
  public get boxState() {
@@ -114,6 +121,14 @@ export class BoxManager {
114
121
  return this.teleBoxManager.minimized;
115
122
  }
116
123
 
124
+ public get darkMode() {
125
+ return this.teleBoxManager.darkMode;
126
+ }
127
+
128
+ public get prefersColorScheme(): TeleBoxColorScheme {
129
+ return this.teleBoxManager.prefersColorScheme;
130
+ }
131
+
117
132
  public createBox(params: CreateBoxParams): void {
118
133
  if (!this.teleBoxManager) return;
119
134
  let { minwidth = MIN_WIDTH, minheight = MIN_HEIGHT } = params.app.config ?? {};
@@ -156,7 +171,9 @@ export class BoxManager {
156
171
  }
157
172
  }
158
173
 
159
- public setupBoxManager(collectorConfig?: CreateCollectorConfig): TeleBoxManager {
174
+ public setupBoxManager(
175
+ createTeleBoxManagerConfig?: CreateTeleBoxManagerConfig
176
+ ): TeleBoxManager {
160
177
  const root = WindowManager.wrapper ? WindowManager.wrapper : document.body;
161
178
  const rect = root.getBoundingClientRect();
162
179
  const initManagerState: TeleBoxManagerConfig = {
@@ -168,9 +185,13 @@ export class BoxManager {
168
185
  height: rect.height,
169
186
  },
170
187
  fence: false,
188
+ prefersColorScheme: createTeleBoxManagerConfig?.prefersColorScheme,
189
+ };
190
+ const container = createTeleBoxManagerConfig?.collectorContainer || WindowManager.wrapper;
191
+ const styles = {
192
+ ...DEFAULT_COLLECTOR_STYLE,
193
+ ...createTeleBoxManagerConfig?.collectorStyles,
171
194
  };
172
- const container = collectorConfig?.collectorContainer || WindowManager.wrapper;
173
- const styles = { ...DEFAULT_COLLECTOR_STYLE, ...collectorConfig?.collectorStyles };
174
195
  const teleBoxCollector = new TeleBoxCollector({
175
196
  styles: styles,
176
197
  // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
@@ -224,7 +245,7 @@ export class BoxManager {
224
245
  if (state.maximized != null) {
225
246
  this.teleBoxManager.setMaximized(Boolean(state.maximized), true);
226
247
  this.teleBoxManager.setMinimized(Boolean(state.minimized), true);
227
- }
248
+ }
228
249
  setTimeout(() => {
229
250
  if (state.focus) {
230
251
  this.teleBoxManager.update(box.id, { focus: true }, true);
@@ -298,6 +319,10 @@ export class BoxManager {
298
319
  this.teleBoxManager.setReadonly(readonly);
299
320
  }
300
321
 
322
+ public setPrefersColorScheme(colorScheme: TeleBoxColorScheme) {
323
+ this.teleBoxManager.setPrefersColorScheme(colorScheme);
324
+ }
325
+
301
326
  public destroy() {
302
327
  this.teleBoxManager.destroy();
303
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 {
@@ -33,6 +33,9 @@ export const replaceRoomFunction = (room: Room, manager: AppManager) => {
33
33
  room.moveCameraToContain = (...args) => manager.mainView.moveCameraToContain(...args);
34
34
  room.convertToPointInWorld = (...args) => manager.mainView.convertToPointInWorld(...args);
35
35
  room.setCameraBound = (...args) => manager.mainView.setCameraBound(...args);
36
+ room.scenePreview = (...args) => manager.mainView.scenePreview(...args);
37
+ room.fillSceneSnapshot = (...args) => manager.mainView.fillSceneSnapshot(...args);
38
+ room.generateScreenshot = (...args) => manager.mainView.generateScreenshot(...args);
36
39
  }
37
40
 
38
41
  };
package/src/index.ts CHANGED
@@ -51,10 +51,11 @@ 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";
57
- import type { TeleBoxState } from "@netless/telebox-insider";
58
+ import type { TeleBoxColorScheme, TeleBoxState } from "@netless/telebox-insider";
58
59
  import type { AppProxy } from "./AppProxy";
59
60
 
60
61
  const ResizeObserver = window.ResizeObserver || ResizeObserverPolyfill;
@@ -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 = {
@@ -156,6 +160,7 @@ export type MountParams = {
156
160
  cursor?: boolean;
157
161
  debug?: boolean;
158
162
  disableCameraTransform?: boolean;
163
+ prefersColorScheme?: TeleBoxColorScheme;
159
164
  };
160
165
 
161
166
  export const callbacks: Emittery<PublicEvent> = new Emittery();
@@ -170,7 +175,7 @@ export class WindowManager extends InvisiblePlugin<WindowMangerAttributes> {
170
175
  public static containerSizeRatio = DEFAULT_CONTAINER_RATIO;
171
176
  private static isCreated = false;
172
177
 
173
- public version = "0.3.10";
178
+ public version = "0.3.12";
174
179
 
175
180
  public appListeners?: AppListeners;
176
181
 
@@ -225,6 +230,7 @@ export class WindowManager extends InvisiblePlugin<WindowMangerAttributes> {
225
230
  let overwriteStyles: string | undefined;
226
231
  let cursor: boolean | undefined;
227
232
  let disableCameraTransform = false;
233
+ let prefersColorScheme: TeleBoxColorScheme | undefined = "light";
228
234
  if ("room" in params) {
229
235
  room = params.room;
230
236
  container = params.container;
@@ -238,6 +244,7 @@ export class WindowManager extends InvisiblePlugin<WindowMangerAttributes> {
238
244
  overwriteStyles = params.overwriteStyles;
239
245
  cursor = params.cursor;
240
246
  disableCameraTransform = Boolean(params?.disableCameraTransform);
247
+ prefersColorScheme = params.prefersColorScheme;
241
248
  } else {
242
249
  room = params;
243
250
  containerSizeRatio = options?.containerSizeRatio;
@@ -303,6 +310,7 @@ export class WindowManager extends InvisiblePlugin<WindowMangerAttributes> {
303
310
  manager.appManager = new AppManager(manager, {
304
311
  collectorContainer: collectorContainer,
305
312
  collectorStyles: collectorStyles,
313
+ prefersColorScheme: prefersColorScheme,
306
314
  });
307
315
  manager.observePlaygroundSize(playground, sizer, wrapper);
308
316
  if (cursor) {
@@ -509,6 +517,14 @@ export class WindowManager extends InvisiblePlugin<WindowMangerAttributes> {
509
517
  }
510
518
  }
511
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
+
512
528
  public get apps(): Apps | undefined {
513
529
  return this.appManager?.store.apps();
514
530
  }
@@ -521,6 +537,18 @@ export class WindowManager extends InvisiblePlugin<WindowMangerAttributes> {
521
537
  }
522
538
  }
523
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
+
524
552
  /**
525
553
  * 查询所有的 App
526
554
  */
@@ -620,6 +648,10 @@ export class WindowManager extends InvisiblePlugin<WindowMangerAttributes> {
620
648
  }
621
649
  }
622
650
 
651
+ public setPrefersColorScheme(scheme: TeleBoxColorScheme): void {
652
+ this.appManager?.boxManager.setPrefersColorScheme(scheme);
653
+ }
654
+
623
655
  private isDynamicPPT(scenes: SceneDefinition[]) {
624
656
  const sceneSrc = scenes[0]?.ppt?.src;
625
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 {