@netless/window-manager 0.4.30 → 0.4.33

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/index.d.ts CHANGED
@@ -9,7 +9,7 @@ import type { TELE_BOX_STATE } from "./BoxManager";
9
9
  import type { Apps, Position } from "./AttributesDelegate";
10
10
  import type { Displayer, SceneDefinition, View, Room, InvisiblePluginContext, Camera, AnimationMode, CameraBound, Point, Rectangle, CameraState, Player, ImageInformation, SceneState } from "white-web-sdk";
11
11
  import type { AppListeners } from "./AppListener";
12
- import type { NetlessApp, RegisterParams } from "./typings";
12
+ import type { ApplianceIcons, NetlessApp, RegisterParams } from "./typings";
13
13
  import type { TeleBoxColorScheme, TeleBoxState } from "@netless/telebox-insider";
14
14
  import type { AppProxy } from "./App";
15
15
  import type { PublicEvent } from "./callback";
@@ -87,6 +87,7 @@ export declare type MountParams = {
87
87
  debug?: boolean;
88
88
  disableCameraTransform?: boolean;
89
89
  prefersColorScheme?: TeleBoxColorScheme;
90
+ applianceIcons?: ApplianceIcons;
90
91
  };
91
92
  export declare const reconnectRefresher: ReconnectRefresher;
92
93
  export declare class WindowManager extends InvisiblePlugin<WindowMangerAttributes> implements PageController {
package/dist/index.es.js CHANGED
@@ -1271,6 +1271,7 @@ const calculateNextIndex = (index, pageState) => {
1271
1271
  }
1272
1272
  return nextIndex;
1273
1273
  };
1274
+ const boxEmitter = new Emittery();
1274
1275
  class AppProxy {
1275
1276
  constructor(params, manager, appId, isAddApp) {
1276
1277
  var _a;
@@ -1581,7 +1582,7 @@ class AppProxy {
1581
1582
  }
1582
1583
  case "focus": {
1583
1584
  (_d = this.boxManager) == null ? void 0 : _d.focusBox({ appId: this.id });
1584
- emitter.emit("focus", { appId: this.id });
1585
+ boxEmitter.emit("focus", { appId: this.id });
1585
1586
  break;
1586
1587
  }
1587
1588
  }
@@ -2142,6 +2143,34 @@ class AppManager {
2142
2143
  };
2143
2144
  callbacks$1.emit("sceneStateChange", this.sceneState);
2144
2145
  };
2146
+ this.onBoxMove = (payload) => {
2147
+ this.dispatchInternalEvent(Events.AppMove, payload);
2148
+ this.store.updateAppState(payload.appId, AppAttributes.Position, {
2149
+ x: payload.x,
2150
+ y: payload.y
2151
+ });
2152
+ };
2153
+ this.onBoxResize = (payload) => {
2154
+ if (payload.width && payload.height) {
2155
+ this.dispatchInternalEvent(Events.AppResize, payload);
2156
+ this.store.updateAppState(payload.appId, AppAttributes.Size, {
2157
+ width: payload.width,
2158
+ height: payload.height
2159
+ });
2160
+ }
2161
+ };
2162
+ this.onBoxFocus = (payload) => {
2163
+ this.windowManger.safeSetAttributes({ focus: payload.appId });
2164
+ };
2165
+ this.onBoxClose = (payload) => {
2166
+ const appProxy = this.appProxies.get(payload.appId);
2167
+ if (appProxy) {
2168
+ appProxy.destroy(false, true, true, payload.error);
2169
+ }
2170
+ };
2171
+ this.onBoxStateChange = (payload) => {
2172
+ this.dispatchInternalEvent(Events.AppBoxStateChange, payload);
2173
+ };
2145
2174
  this.addAppsChangeListener = () => {
2146
2175
  var _a;
2147
2176
  (_a = this.refresher) == null ? void 0 : _a.add("apps", () => {
@@ -2274,43 +2303,6 @@ class AppManager {
2274
2303
  }
2275
2304
  }
2276
2305
  };
2277
- this.boxEventListener = (eventName, payload) => {
2278
- switch (eventName) {
2279
- case "move": {
2280
- this.dispatchInternalEvent(Events.AppMove, payload);
2281
- this.store.updateAppState(payload.appId, AppAttributes.Position, {
2282
- x: payload.x,
2283
- y: payload.y
2284
- });
2285
- break;
2286
- }
2287
- case "focus": {
2288
- this.windowManger.safeSetAttributes({ focus: payload.appId });
2289
- break;
2290
- }
2291
- case "resize": {
2292
- if (payload.width && payload.height) {
2293
- this.dispatchInternalEvent(Events.AppResize, payload);
2294
- this.store.updateAppState(payload.appId, AppAttributes.Size, {
2295
- width: payload.width,
2296
- height: payload.height
2297
- });
2298
- }
2299
- break;
2300
- }
2301
- case "close": {
2302
- const appProxy = this.appProxies.get(payload.appId);
2303
- if (appProxy) {
2304
- appProxy.destroy(false, true, payload.error);
2305
- }
2306
- break;
2307
- }
2308
- case "boxStateChange": {
2309
- this.dispatchInternalEvent(Events.AppBoxStateChange, payload);
2310
- break;
2311
- }
2312
- }
2313
- };
2314
2306
  this.updateRootDirRemoving = (removing) => {
2315
2307
  this.rootDirRemoving = removing;
2316
2308
  };
@@ -2400,7 +2392,11 @@ class AppManager {
2400
2392
  var _a, _b, _c, _d, _e2, _f;
2401
2393
  await this.attributesUpdateCallback(this.attributes.apps);
2402
2394
  emitter.emit("updateManagerRect");
2403
- emitter.onAny(this.boxEventListener);
2395
+ boxEmitter.on("move", this.onBoxMove);
2396
+ boxEmitter.on("resize", this.onBoxResize);
2397
+ boxEmitter.on("focus", this.onBoxFocus);
2398
+ boxEmitter.on("close", this.onBoxClose);
2399
+ boxEmitter.on("boxStateChange", this.onBoxStateChange);
2404
2400
  this.addAppsChangeListener();
2405
2401
  this.addAppCloseListener();
2406
2402
  (_a = this.refresher) == null ? void 0 : _a.add("maximized", () => {
@@ -2549,7 +2545,7 @@ class AppManager {
2549
2545
  var _a, _b;
2550
2546
  if (appProxy && appProxy.box) {
2551
2547
  const box = appProxy.box;
2552
- emitter.emit("move", {
2548
+ boxEmitter.emit("move", {
2553
2549
  appId: appProxy.id,
2554
2550
  x: box == null ? void 0 : box.intrinsicX,
2555
2551
  y: box == null ? void 0 : box.intrinsicY
@@ -2682,7 +2678,7 @@ class AppManager {
2682
2678
  this.displayer.callbacks.off(this.eventName, this.displayerStateListener);
2683
2679
  this.displayer.callbacks.off("onEnableWriteNowChanged", this.displayerWritableListener);
2684
2680
  this.appListeners.removeListeners();
2685
- emitter.offAny(this.boxEventListener);
2681
+ boxEmitter.clearListeners();
2686
2682
  emitter.clearListeners();
2687
2683
  if (this.appProxies.size) {
2688
2684
  this.appProxies.forEach((appProxy) => {
@@ -2724,6 +2720,19 @@ const findMemberByUid = (room, uid) => {
2724
2720
  return ((_a = member.payload) == null ? void 0 : _a.uid) === uid;
2725
2721
  });
2726
2722
  };
2723
+ const createInvisiblePlugin = async (room) => {
2724
+ try {
2725
+ const manager = await room.createInvisiblePlugin(WindowManager, {});
2726
+ return manager;
2727
+ } catch (error) {
2728
+ if (error.message === `invisible plugin "WindowManager" exits`) {
2729
+ await wait(200);
2730
+ return room.getInvisiblePlugin(WindowManager.kind);
2731
+ } else {
2732
+ log("createInvisiblePlugin failed", error);
2733
+ }
2734
+ }
2735
+ };
2727
2736
  const ResizeObserver$2 = window.ResizeObserver || ResizeObserver$3;
2728
2737
  class ContainerResizeObserver {
2729
2738
  constructor(emitter2) {
@@ -4535,7 +4544,7 @@ class Bt {
4535
4544
  return typeof e2 == "string" ? this.boxes.find((t2) => t2.id === e2) : e2;
4536
4545
  }
4537
4546
  }
4538
- const createBoxManager = (manager, callbacks2, emitter2, options) => {
4547
+ const createBoxManager = (manager, callbacks2, emitter2, boxEmitter2, options) => {
4539
4548
  return new BoxManager({
4540
4549
  safeSetAttributes: (attributes) => manager.safeSetAttributes(attributes),
4541
4550
  getMainView: () => manager.mainView,
@@ -4557,14 +4566,15 @@ const createBoxManager = (manager, callbacks2, emitter2, options) => {
4557
4566
  return (_a = manager.appManager) == null ? void 0 : _a.store.setAppFocus(appId, true);
4558
4567
  },
4559
4568
  callbacks: callbacks2,
4560
- emitter: emitter2
4569
+ emitter: emitter2,
4570
+ boxEmitter: boxEmitter2
4561
4571
  }, options);
4562
4572
  };
4563
4573
  class BoxManager {
4564
4574
  constructor(context, createTeleBoxManagerConfig) {
4565
4575
  this.context = context;
4566
4576
  this.createTeleBoxManagerConfig = createTeleBoxManagerConfig;
4567
- const { emitter: emitter2, callbacks: callbacks2 } = context;
4577
+ const { emitter: emitter2, callbacks: callbacks2, boxEmitter: boxEmitter2 } = context;
4568
4578
  this.teleBoxManager = this.setupBoxManager(createTeleBoxManagerConfig);
4569
4579
  this.teleBoxManager._state$.reaction((state) => {
4570
4580
  callbacks2.emit("boxStateChange", state);
@@ -4594,14 +4604,14 @@ class BoxManager {
4594
4604
  });
4595
4605
  this.teleBoxManager.events.on("removed", (boxes) => {
4596
4606
  boxes.forEach((box) => {
4597
- emitter2.emit("close", { appId: box.id });
4607
+ boxEmitter2.emit("close", { appId: box.id });
4598
4608
  });
4599
4609
  });
4600
4610
  this.teleBoxManager.events.on("intrinsic_move", debounce((box) => {
4601
- emitter2.emit("move", { appId: box.id, x: box.intrinsicX, y: box.intrinsicY });
4611
+ boxEmitter2.emit("move", { appId: box.id, x: box.intrinsicX, y: box.intrinsicY });
4602
4612
  }, 50));
4603
4613
  this.teleBoxManager.events.on("intrinsic_resize", debounce((box) => {
4604
- emitter2.emit("resize", {
4614
+ boxEmitter2.emit("resize", {
4605
4615
  appId: box.id,
4606
4616
  width: box.intrinsicWidth,
4607
4617
  height: box.intrinsicHeight
@@ -4610,7 +4620,7 @@ class BoxManager {
4610
4620
  this.teleBoxManager.events.on("focused", (box) => {
4611
4621
  if (box) {
4612
4622
  if (this.canOperate) {
4613
- emitter2.emit("focus", { appId: box.id });
4623
+ boxEmitter2.emit("focus", { appId: box.id });
4614
4624
  } else {
4615
4625
  this.teleBoxManager.blurBox(box.id);
4616
4626
  }
@@ -4675,7 +4685,7 @@ class BoxManager {
4675
4685
  const box = this.teleBoxManager.queryOne({ id: appId });
4676
4686
  if (box) {
4677
4687
  if (box.state === Ke$1.Maximized) {
4678
- this.context.emitter.emit("resize", {
4688
+ this.context.boxEmitter.emit("resize", {
4679
4689
  appId,
4680
4690
  x: box.x,
4681
4691
  y: box.y,
@@ -5400,20 +5410,6 @@ class Cursor$1 extends SvelteComponent {
5400
5410
  });
5401
5411
  }
5402
5412
  }
5403
- var pencil = "";
5404
- var selector = "";
5405
- var eraser = "";
5406
- var shape = "";
5407
- var text = "";
5408
- var laser = "";
5409
- const ApplianceMap = {
5410
- [ApplianceNames.pencil]: pencil,
5411
- [ApplianceNames.selector]: selector,
5412
- [ApplianceNames.eraser]: eraser,
5413
- [ApplianceNames.shape]: shape,
5414
- [ApplianceNames.text]: text,
5415
- [ApplianceNames.laserPointer]: laser
5416
- };
5417
5413
  class Cursor {
5418
5414
  constructor(manager, memberId, cursorManager, wrapper) {
5419
5415
  this.manager = manager;
@@ -5549,8 +5545,9 @@ class Cursor {
5549
5545
  }
5550
5546
  getIcon() {
5551
5547
  if (this.member) {
5552
- const applianceSrc = ApplianceMap[this.memberApplianceName || ApplianceNames.shape];
5553
- return applianceSrc || ApplianceMap[ApplianceNames.shape];
5548
+ const icons = this.cursorManager.applianceIcons;
5549
+ const applianceSrc = icons[this.memberApplianceName || ApplianceNames.shape];
5550
+ return applianceSrc || icons[ApplianceNames.shape];
5554
5551
  }
5555
5552
  }
5556
5553
  updateMember() {
@@ -5578,14 +5575,29 @@ class Cursor {
5578
5575
  }
5579
5576
  }
5580
5577
  }
5578
+ var pencil = "";
5579
+ var selector = "";
5580
+ var eraser = "";
5581
+ var shape = "";
5582
+ var text = "";
5583
+ var laser = "";
5584
+ const ApplianceMap = {
5585
+ [ApplianceNames.pencil]: pencil,
5586
+ [ApplianceNames.selector]: selector,
5587
+ [ApplianceNames.eraser]: eraser,
5588
+ [ApplianceNames.shape]: shape,
5589
+ [ApplianceNames.text]: text,
5590
+ [ApplianceNames.laserPointer]: laser
5591
+ };
5581
5592
  class CursorManager {
5582
- constructor(manager, enableCursor) {
5593
+ constructor(manager, enableCursor, applianceIcons) {
5583
5594
  var _a;
5584
5595
  this.manager = manager;
5585
5596
  this.enableCursor = enableCursor;
5586
5597
  this.cursorInstances = /* @__PURE__ */ new Map();
5587
5598
  this.sideEffectManager = new SideEffectManager();
5588
5599
  this.store = this.manager.store;
5600
+ this.applianceIcons = ApplianceMap;
5589
5601
  this.onCursorMove = (payload) => {
5590
5602
  const cursorInstance = this.initCursorInstance(payload.uid);
5591
5603
  if (payload.state === CursorState.Leave) {
@@ -5653,6 +5665,9 @@ class CursorManager {
5653
5665
  this.sideEffectManager.add(() => {
5654
5666
  return emitter.on("playgroundSizeChange", () => this.updateContainerRect());
5655
5667
  });
5668
+ if (applianceIcons) {
5669
+ this.applianceIcons = __spreadValues(__spreadValues({}, ApplianceMap), applianceIcons);
5670
+ }
5656
5671
  }
5657
5672
  canMoveCursor(member) {
5658
5673
  const isLaserPointer = (member == null ? void 0 : member.memberState.currentApplianceName) === ApplianceNames.laserPointer;
@@ -5753,19 +5768,24 @@ class ReconnectRefresher {
5753
5768
  this.ctx = ctx;
5754
5769
  this.reactors = /* @__PURE__ */ new Map();
5755
5770
  this.disposers = /* @__PURE__ */ new Map();
5756
- this.onPhaseChanged = (phase) => {
5757
- var _a;
5771
+ this.onPhaseChanged = async (phase) => {
5772
+ var _a, _b;
5758
5773
  if (phase === RoomPhase.Reconnecting) {
5759
5774
  this.ctx.emitter.emit("startReconnect");
5760
5775
  }
5761
5776
  if (phase === RoomPhase.Connected && this.phase === RoomPhase.Reconnecting) {
5762
- (_a = this.room) == null ? void 0 : _a.dispatchMagixEvent(EnsureReconnectEvent, {});
5777
+ if ((_a = this.room) == null ? void 0 : _a.isWritable) {
5778
+ (_b = this.room) == null ? void 0 : _b.dispatchMagixEvent(EnsureReconnectEvent, {});
5779
+ } else {
5780
+ await wait(500);
5781
+ this.onReconnected();
5782
+ }
5763
5783
  }
5764
5784
  this.phase = phase;
5765
5785
  };
5766
5786
  this.onReconnected = debounce(() => {
5767
5787
  this._onReconnected();
5768
- }, 3e3);
5788
+ }, 1e3);
5769
5789
  this._onReconnected = () => {
5770
5790
  log("onReconnected refresh reactors");
5771
5791
  this.releaseDisposers();
@@ -15077,14 +15097,14 @@ const reconnectRefresher = new ReconnectRefresher({ emitter });
15077
15097
  const _WindowManager = class extends InvisiblePlugin {
15078
15098
  constructor(context) {
15079
15099
  super(context);
15080
- this.version = "0.4.30";
15081
- this.dependencies = { "dependencies": { "@juggle/resize-observer": "^3.3.1", "@netless/telebox-insider": "0.2.26", "emittery": "^0.9.2", "lodash": "^4.17.21", "p-retry": "^4.6.1", "side-effect-manager": "^0.1.5", "uuid": "^7.0.3", "video.js": ">=7" }, "peerDependencies": { "white-web-sdk": "^2.16.0" }, "devDependencies": { "@netless/app-docs-viewer": "^0.2.9", "@netless/app-media-player": "0.1.0-beta.5", "@rollup/plugin-commonjs": "^20.0.0", "@rollup/plugin-node-resolve": "^13.0.4", "@rollup/plugin-url": "^6.1.0", "@sveltejs/vite-plugin-svelte": "^1.0.0-next.22", "@tsconfig/svelte": "^2.0.1", "@types/debug": "^4.1.7", "@types/lodash": "^4.14.182", "@types/lodash-es": "^4.17.4", "@types/uuid": "^8.3.1", "@typescript-eslint/eslint-plugin": "^4.30.0", "@typescript-eslint/parser": "^4.30.0", "cypress": "^8.7.0", "dotenv": "^10.0.0", "eslint": "^7.32.0", "eslint-config-prettier": "^8.3.0", "eslint-plugin-svelte3": "^3.2.0", "jsdom": "^19.0.0", "less": "^4.1.1", "prettier": "^2.3.2", "prettier-plugin-svelte": "^2.4.0", "rollup-plugin-analyzer": "^4.0.0", "rollup-plugin-styles": "^3.14.1", "svelte": "^3.42.4", "typescript": "^4.5.5", "vite": "^2.5.3", "vitest": "^0.12.4", "white-web-sdk": "2.16.10" } };
15100
+ this.version = "0.4.33";
15101
+ this.dependencies = { "dependencies": { "@juggle/resize-observer": "^3.3.1", "@netless/telebox-insider": "0.2.26", "emittery": "^0.9.2", "lodash": "^4.17.21", "p-retry": "^4.6.1", "side-effect-manager": "^0.1.5", "uuid": "^7.0.3", "video.js": ">=7" }, "peerDependencies": { "white-web-sdk": "^2.16.0" }, "devDependencies": { "@netless/app-docs-viewer": "^0.2.9", "@netless/app-media-player": "0.1.0-beta.5", "@rollup/plugin-commonjs": "^20.0.0", "@rollup/plugin-node-resolve": "^13.0.4", "@rollup/plugin-url": "^6.1.0", "@sveltejs/vite-plugin-svelte": "^1.0.0-next.22", "@tsconfig/svelte": "^2.0.1", "@types/debug": "^4.1.7", "@types/lodash": "^4.14.182", "@types/lodash-es": "^4.17.4", "@types/uuid": "^8.3.1", "@typescript-eslint/eslint-plugin": "^4.30.0", "@typescript-eslint/parser": "^4.30.0", "@vitest/ui": "^0.14.1", "cypress": "^8.7.0", "dotenv": "^10.0.0", "eslint": "^7.32.0", "eslint-config-prettier": "^8.3.0", "eslint-plugin-svelte3": "^3.2.0", "jsdom": "^19.0.0", "less": "^4.1.1", "prettier": "^2.3.2", "prettier-plugin-svelte": "^2.4.0", "rollup-plugin-analyzer": "^4.0.0", "rollup-plugin-styles": "^3.14.1", "svelte": "^3.42.4", "typescript": "^4.5.5", "vite": "^2.5.3", "vitest": "^0.14.1", "white-web-sdk": "2.16.10" } };
15082
15102
  this.emitter = callbacks$1;
15083
15103
  this.viewMode = ViewMode.Broadcaster;
15084
15104
  this.isReplay = isPlayer(this.displayer);
15085
15105
  this.containerSizeRatio = _WindowManager.containerSizeRatio;
15086
15106
  _WindowManager.displayer = context.displayer;
15087
- window.NETLESS_DEPS = { "dependencies": { "@juggle/resize-observer": "^3.3.1", "@netless/telebox-insider": "0.2.26", "emittery": "^0.9.2", "lodash": "^4.17.21", "p-retry": "^4.6.1", "side-effect-manager": "^0.1.5", "uuid": "^7.0.3", "video.js": ">=7" }, "peerDependencies": { "white-web-sdk": "^2.16.0" }, "devDependencies": { "@netless/app-docs-viewer": "^0.2.9", "@netless/app-media-player": "0.1.0-beta.5", "@rollup/plugin-commonjs": "^20.0.0", "@rollup/plugin-node-resolve": "^13.0.4", "@rollup/plugin-url": "^6.1.0", "@sveltejs/vite-plugin-svelte": "^1.0.0-next.22", "@tsconfig/svelte": "^2.0.1", "@types/debug": "^4.1.7", "@types/lodash": "^4.14.182", "@types/lodash-es": "^4.17.4", "@types/uuid": "^8.3.1", "@typescript-eslint/eslint-plugin": "^4.30.0", "@typescript-eslint/parser": "^4.30.0", "cypress": "^8.7.0", "dotenv": "^10.0.0", "eslint": "^7.32.0", "eslint-config-prettier": "^8.3.0", "eslint-plugin-svelte3": "^3.2.0", "jsdom": "^19.0.0", "less": "^4.1.1", "prettier": "^2.3.2", "prettier-plugin-svelte": "^2.4.0", "rollup-plugin-analyzer": "^4.0.0", "rollup-plugin-styles": "^3.14.1", "svelte": "^3.42.4", "typescript": "^4.5.5", "vite": "^2.5.3", "vitest": "^0.12.4", "white-web-sdk": "2.16.10" } };
15107
+ window.NETLESS_DEPS = { "dependencies": { "@juggle/resize-observer": "^3.3.1", "@netless/telebox-insider": "0.2.26", "emittery": "^0.9.2", "lodash": "^4.17.21", "p-retry": "^4.6.1", "side-effect-manager": "^0.1.5", "uuid": "^7.0.3", "video.js": ">=7" }, "peerDependencies": { "white-web-sdk": "^2.16.0" }, "devDependencies": { "@netless/app-docs-viewer": "^0.2.9", "@netless/app-media-player": "0.1.0-beta.5", "@rollup/plugin-commonjs": "^20.0.0", "@rollup/plugin-node-resolve": "^13.0.4", "@rollup/plugin-url": "^6.1.0", "@sveltejs/vite-plugin-svelte": "^1.0.0-next.22", "@tsconfig/svelte": "^2.0.1", "@types/debug": "^4.1.7", "@types/lodash": "^4.14.182", "@types/lodash-es": "^4.17.4", "@types/uuid": "^8.3.1", "@typescript-eslint/eslint-plugin": "^4.30.0", "@typescript-eslint/parser": "^4.30.0", "@vitest/ui": "^0.14.1", "cypress": "^8.7.0", "dotenv": "^10.0.0", "eslint": "^7.32.0", "eslint-config-prettier": "^8.3.0", "eslint-plugin-svelte3": "^3.2.0", "jsdom": "^19.0.0", "less": "^4.1.1", "prettier": "^2.3.2", "prettier-plugin-svelte": "^2.4.0", "rollup-plugin-analyzer": "^4.0.0", "rollup-plugin-styles": "^3.14.1", "svelte": "^3.42.4", "typescript": "^4.5.5", "vite": "^2.5.3", "vitest": "^0.14.1", "white-web-sdk": "2.16.10" } };
15088
15108
  }
15089
15109
  static async mount(params) {
15090
15110
  const room = params.room;
@@ -15132,7 +15152,7 @@ const _WindowManager = class extends InvisiblePlugin {
15132
15152
  await manager.ensureAttributes();
15133
15153
  manager.appManager = new AppManager(manager);
15134
15154
  manager._pageState = new PageStateImpl(manager.appManager);
15135
- manager.cursorManager = new CursorManager(manager.appManager, Boolean(cursor));
15155
+ manager.cursorManager = new CursorManager(manager.appManager, Boolean(cursor), params.applianceIcons);
15136
15156
  if (containerSizeRatio) {
15137
15157
  manager.containerSizeRatio = containerSizeRatio;
15138
15158
  }
@@ -15160,12 +15180,12 @@ const _WindowManager = class extends InvisiblePlugin {
15160
15180
  } catch (error) {
15161
15181
  throw new Error("[WindowManger]: room must be switched to be writable");
15162
15182
  }
15163
- manager = await room.createInvisiblePlugin(_WindowManager, {});
15164
- manager.ensureAttributes();
15183
+ manager = await createInvisiblePlugin(room);
15184
+ manager == null ? void 0 : manager.ensureAttributes();
15165
15185
  await wait(500);
15166
15186
  await room.setWritable(false);
15167
15187
  } else {
15168
- manager = await room.createInvisiblePlugin(_WindowManager, {});
15188
+ manager = await createInvisiblePlugin(room);
15169
15189
  }
15170
15190
  }
15171
15191
  }
@@ -15194,7 +15214,7 @@ const _WindowManager = class extends InvisiblePlugin {
15194
15214
  }
15195
15215
  bindContainer(container) {
15196
15216
  var _a, _b, _c, _d, _e2, _f;
15197
- if (this.room.phase !== RoomPhase.Connected) {
15217
+ if (isRoom(this.displayer) && this.room.phase !== RoomPhase.Connected) {
15198
15218
  throw new BindContainerRoomPhaseInvalidError();
15199
15219
  }
15200
15220
  if (_WindowManager.isCreated && _WindowManager.container) {
@@ -15208,7 +15228,7 @@ const _WindowManager = class extends InvisiblePlugin {
15208
15228
  if (this.boxManager) {
15209
15229
  this.boxManager.destroy();
15210
15230
  }
15211
- const boxManager = createBoxManager(this, callbacks$1, emitter, {
15231
+ const boxManager = createBoxManager(this, callbacks$1, emitter, boxEmitter, {
15212
15232
  collectorContainer: params.collectorContainer,
15213
15233
  collectorStyles: params.collectorStyles,
15214
15234
  prefersColorScheme: params.prefersColorScheme