@netless/window-manager 0.4.43 → 0.4.45

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
@@ -207,6 +207,10 @@ export declare class WindowManager extends InvisiblePlugin<WindowMangerAttribute
207
207
  * 关闭 APP
208
208
  */
209
209
  closeApp(appId: string): Promise<void>;
210
+ /**
211
+ * 切换 focus 到指定的 app, 并且把这个 app 放到最前面
212
+ */
213
+ focusApp(appId: string): void;
210
214
  moveCamera(camera: Partial<Camera> & {
211
215
  animationMode?: AnimationMode | undefined;
212
216
  }): void;
package/dist/index.es.js CHANGED
@@ -20,7 +20,7 @@ var __spreadProps = (a2, b2) => __defProps(a2, __getOwnPropDescs(b2));
20
20
  import pRetry from "p-retry";
21
21
  import Emittery from "emittery";
22
22
  import { debounce, isEqual, omit, isObject, has, get, size as size$1, mapValues, noop as noop$2, pick, isEmpty, isInteger, orderBy, isFunction, throttle, isNumber, isNull } from "lodash";
23
- import { ScenePathType, UpdateEventKind, listenUpdated, unlistenUpdated, reaction, autorun, toJS, listenDisposed, unlistenDisposed, AnimationMode, isPlayer, isRoom, WhiteVersion, ApplianceNames, RoomPhase, InvisiblePlugin, ViewMode } from "white-web-sdk";
23
+ import { ScenePathType, UpdateEventKind, listenUpdated, unlistenUpdated, reaction, autorun, toJS, listenDisposed, unlistenDisposed, ViewMode, AnimationMode, isPlayer, isRoom, WhiteVersion, ApplianceNames, RoomPhase, InvisiblePlugin } from "white-web-sdk";
24
24
  import { v4 } from "uuid";
25
25
  import { genUID, SideEffectManager } from "side-effect-manager";
26
26
  import { ResizeObserver as ResizeObserver$3 } from "@juggle/resize-observer";
@@ -1753,6 +1753,7 @@ class MainViewProxy {
1753
1753
  this.started = false;
1754
1754
  this.mainViewIsAddListener = false;
1755
1755
  this.store = this.manager.store;
1756
+ this.viewMode = this.manager.windowManger.viewMode;
1756
1757
  this.sideEffectManager = new SideEffectManager();
1757
1758
  this.startListenWritableChange = () => {
1758
1759
  this.sideEffectManager.add(() => {
@@ -1776,7 +1777,7 @@ class MainViewProxy {
1776
1777
  }, { fireImmediately: true });
1777
1778
  };
1778
1779
  this.sizeChangeHandler = debounce((size2) => {
1779
- if (size2) {
1780
+ if (size2 && this.viewMode === ViewMode.Broadcaster) {
1780
1781
  this.moveCameraToContian(size2);
1781
1782
  this.moveCamera(this.mainViewCamera);
1782
1783
  }
@@ -1786,6 +1787,8 @@ class MainViewProxy {
1786
1787
  this.sizeChangeHandler(size2);
1787
1788
  };
1788
1789
  this.onCameraUpdatedByDevice = (camera) => {
1790
+ if (this.viewMode === ViewMode.Follower)
1791
+ return;
1789
1792
  this.store.setMainViewCamera(__spreadProps(__spreadValues({}, camera), { id: this.manager.uid }));
1790
1793
  if (!isEqual(this.mainViewSize, __spreadProps(__spreadValues({}, this.mainView.size), { id: this.manager.uid }))) {
1791
1794
  this.setMainViewSize(this.view.size);
@@ -1800,6 +1803,9 @@ class MainViewProxy {
1800
1803
  this.onCameraOrSizeUpdated = () => {
1801
1804
  callbacks$1.emit("cameraStateChange", this.cameraState);
1802
1805
  };
1806
+ this.setViewMode = (mode) => {
1807
+ this.viewMode = mode;
1808
+ };
1803
1809
  this.mainView = this.createMainView();
1804
1810
  this.moveCameraSizeByAttributes();
1805
1811
  emitter.once("mainViewMounted").then(() => {
@@ -1826,6 +1832,8 @@ class MainViewProxy {
1826
1832
  });
1827
1833
  }
1828
1834
  ensureCameraAndSize() {
1835
+ if (this.viewMode !== ViewMode.Broadcaster)
1836
+ return;
1829
1837
  if (!this.mainViewCamera || !this.mainViewSize) {
1830
1838
  this.manager.dispatchInternalEvent(Events.InitMainViewCamera);
1831
1839
  this.setCameraAndSize();
@@ -6676,8 +6684,9 @@ function create_if_block(ctx) {
6676
6684
  let span;
6677
6685
  let t1;
6678
6686
  let t2;
6679
- let if_block0 = ctx[14] && create_if_block_2(ctx);
6680
- let if_block1 = ctx[15] && create_if_block_1(ctx);
6687
+ let div1_class_value;
6688
+ let if_block0 = ctx[16] && create_if_block_2(ctx);
6689
+ let if_block1 = ctx[17] && create_if_block_1(ctx);
6681
6690
  return {
6682
6691
  c() {
6683
6692
  div1 = element("div");
@@ -6698,7 +6707,7 @@ function create_if_block(ctx) {
6698
6707
  set_style(div0, "background-color", ctx[2]);
6699
6708
  set_style(div0, "color", ctx[9]);
6700
6709
  set_style(div0, "opacity", ctx[11]);
6701
- attr(div1, "class", "netless-window-manager-cursor-name");
6710
+ attr(div1, "class", div1_class_value = "netless-window-manager-cursor-name " + ctx[14] + " " + ctx[13]);
6702
6711
  },
6703
6712
  m(target, anchor) {
6704
6713
  insert(target, div1, anchor);
@@ -6713,7 +6722,7 @@ function create_if_block(ctx) {
6713
6722
  if_block1.m(div0, null);
6714
6723
  },
6715
6724
  p(ctx2, dirty) {
6716
- if (ctx2[14]) {
6725
+ if (ctx2[16]) {
6717
6726
  if (if_block0) {
6718
6727
  if_block0.p(ctx2, dirty);
6719
6728
  } else {
@@ -6727,7 +6736,7 @@ function create_if_block(ctx) {
6727
6736
  }
6728
6737
  if (dirty & 1)
6729
6738
  set_data(t1, ctx2[0]);
6730
- if (ctx2[15]) {
6739
+ if (ctx2[17]) {
6731
6740
  if (if_block1) {
6732
6741
  if_block1.p(ctx2, dirty);
6733
6742
  } else {
@@ -6751,6 +6760,9 @@ function create_if_block(ctx) {
6751
6760
  if (dirty & 2048) {
6752
6761
  set_style(div0, "opacity", ctx2[11]);
6753
6762
  }
6763
+ if (dirty & 24576 && div1_class_value !== (div1_class_value = "netless-window-manager-cursor-name " + ctx2[14] + " " + ctx2[13])) {
6764
+ attr(div1, "class", div1_class_value);
6765
+ }
6754
6766
  },
6755
6767
  d(detaching) {
6756
6768
  if (detaching)
@@ -6769,7 +6781,7 @@ function create_if_block_2(ctx) {
6769
6781
  c() {
6770
6782
  img = element("img");
6771
6783
  attr(img, "class", "netless-window-manager-cursor-selector-avatar");
6772
- attr(img, "style", ctx[16]());
6784
+ attr(img, "style", ctx[18]());
6773
6785
  if (!src_url_equal(img.src, img_src_value = ctx[7]))
6774
6786
  attr(img, "src", img_src_value);
6775
6787
  attr(img, "alt", "avatar");
@@ -6831,14 +6843,14 @@ function create_fragment(ctx) {
6831
6843
  t2 = space();
6832
6844
  div0 = element("div");
6833
6845
  img = element("img");
6834
- attr(img, "class", img_class_value = "netless-window-manager-cursor-" + ctx[3] + "-image");
6846
+ attr(img, "class", img_class_value = "netless-window-manager-cursor-" + ctx[3] + "-image " + ctx[13]);
6835
6847
  if (!src_url_equal(img.src, img_src_value = ctx[6]))
6836
6848
  attr(img, "src", img_src_value);
6837
6849
  attr(img, "alt", ctx[3]);
6838
6850
  attr(div0, "class", "cursor-image-wrapper");
6839
6851
  attr(div1, "class", "netless-window-manager-cursor-mid");
6840
6852
  set_style(div1, "transform", "translateX(" + ctx[4] + "px) translateY(" + ctx[5] + "px)");
6841
- set_style(div1, "display", ctx[13]);
6853
+ set_style(div1, "display", ctx[15]);
6842
6854
  },
6843
6855
  m(target, anchor) {
6844
6856
  insert(target, div1, anchor);
@@ -6861,7 +6873,7 @@ function create_fragment(ctx) {
6861
6873
  if_block.d(1);
6862
6874
  if_block = null;
6863
6875
  }
6864
- if (dirty & 8 && img_class_value !== (img_class_value = "netless-window-manager-cursor-" + ctx2[3] + "-image")) {
6876
+ if (dirty & 8200 && img_class_value !== (img_class_value = "netless-window-manager-cursor-" + ctx2[3] + "-image " + ctx2[13])) {
6865
6877
  attr(img, "class", img_class_value);
6866
6878
  }
6867
6879
  if (dirty & 64 && !src_url_equal(img.src, img_src_value = ctx2[6])) {
@@ -6873,8 +6885,8 @@ function create_fragment(ctx) {
6873
6885
  if (dirty & 48) {
6874
6886
  set_style(div1, "transform", "translateX(" + ctx2[4] + "px) translateY(" + ctx2[5] + "px)");
6875
6887
  }
6876
- if (dirty & 8192) {
6877
- set_style(div1, "display", ctx2[13]);
6888
+ if (dirty & 32768) {
6889
+ set_style(div1, "display", ctx2[15]);
6878
6890
  }
6879
6891
  },
6880
6892
  i: noop,
@@ -6893,6 +6905,9 @@ function instance($$self, $$props, $$invalidate) {
6893
6905
  let hasAvatar;
6894
6906
  let display;
6895
6907
  let isLaserPointer;
6908
+ let isLaserPointerPencilEraser;
6909
+ let offset;
6910
+ let pencilEraserSize3ImageOffset;
6896
6911
  let { cursorName } = $$props;
6897
6912
  let { tagName } = $$props;
6898
6913
  let { backgroundColor } = $$props;
@@ -6906,6 +6921,7 @@ function instance($$self, $$props, $$invalidate) {
6906
6921
  let { color: color2 } = $$props;
6907
6922
  let { cursorTagBackgroundColor } = $$props;
6908
6923
  let { opacity } = $$props;
6924
+ let { pencilEraserSize } = $$props;
6909
6925
  const computedAvatarStyle = () => {
6910
6926
  return Object.entries({
6911
6927
  width: (hasName ? 19 : 28) + "px",
@@ -6931,7 +6947,7 @@ function instance($$self, $$props, $$invalidate) {
6931
6947
  if ("src" in $$props2)
6932
6948
  $$invalidate(6, src = $$props2.src);
6933
6949
  if ("visible" in $$props2)
6934
- $$invalidate(17, visible = $$props2.visible);
6950
+ $$invalidate(19, visible = $$props2.visible);
6935
6951
  if ("avatar" in $$props2)
6936
6952
  $$invalidate(7, avatar = $$props2.avatar);
6937
6953
  if ("theme" in $$props2)
@@ -6942,23 +6958,34 @@ function instance($$self, $$props, $$invalidate) {
6942
6958
  $$invalidate(10, cursorTagBackgroundColor = $$props2.cursorTagBackgroundColor);
6943
6959
  if ("opacity" in $$props2)
6944
6960
  $$invalidate(11, opacity = $$props2.opacity);
6961
+ if ("pencilEraserSize" in $$props2)
6962
+ $$invalidate(20, pencilEraserSize = $$props2.pencilEraserSize);
6945
6963
  };
6946
6964
  $$self.$$.update = () => {
6947
6965
  if ($$self.$$.dirty & 1) {
6948
6966
  hasName = !isEmpty(cursorName);
6949
6967
  }
6950
6968
  if ($$self.$$.dirty & 2) {
6951
- $$invalidate(15, hasTagName = !isEmpty(tagName));
6969
+ $$invalidate(17, hasTagName = !isEmpty(tagName));
6952
6970
  }
6953
6971
  if ($$self.$$.dirty & 128) {
6954
- $$invalidate(14, hasAvatar = !isEmpty(avatar));
6972
+ $$invalidate(16, hasAvatar = !isEmpty(avatar));
6955
6973
  }
6956
- if ($$self.$$.dirty & 131072) {
6957
- $$invalidate(13, display = visible ? "initial" : "none");
6974
+ if ($$self.$$.dirty & 524288) {
6975
+ $$invalidate(15, display = visible ? "initial" : "none");
6958
6976
  }
6959
6977
  if ($$self.$$.dirty & 8) {
6960
6978
  $$invalidate(12, isLaserPointer = appliance === ApplianceNames.laserPointer);
6961
6979
  }
6980
+ if ($$self.$$.dirty & 4104) {
6981
+ $$invalidate(21, isLaserPointerPencilEraser = isLaserPointer || appliance === ApplianceNames.pencilEraser);
6982
+ }
6983
+ if ($$self.$$.dirty & 2097152) {
6984
+ $$invalidate(14, offset = isLaserPointerPencilEraser ? "netless-window-manager-laserPointer-pencilEraser-offset" : "");
6985
+ }
6986
+ if ($$self.$$.dirty & 1048576) {
6987
+ $$invalidate(13, pencilEraserSize3ImageOffset = pencilEraserSize === 3 ? "netless-window-manager-pencilEraser-3-offset" : "");
6988
+ }
6962
6989
  };
6963
6990
  return [
6964
6991
  cursorName,
@@ -6974,11 +7001,15 @@ function instance($$self, $$props, $$invalidate) {
6974
7001
  cursorTagBackgroundColor,
6975
7002
  opacity,
6976
7003
  isLaserPointer,
7004
+ pencilEraserSize3ImageOffset,
7005
+ offset,
6977
7006
  display,
6978
7007
  hasAvatar,
6979
7008
  hasTagName,
6980
7009
  computedAvatarStyle,
6981
- visible
7010
+ visible,
7011
+ pencilEraserSize,
7012
+ isLaserPointerPencilEraser
6982
7013
  ];
6983
7014
  }
6984
7015
  class Cursor$1 extends SvelteComponent {
@@ -6992,12 +7023,13 @@ class Cursor$1 extends SvelteComponent {
6992
7023
  x: 4,
6993
7024
  y: 5,
6994
7025
  src: 6,
6995
- visible: 17,
7026
+ visible: 19,
6996
7027
  avatar: 7,
6997
7028
  theme: 8,
6998
7029
  color: 9,
6999
7030
  cursorTagBackgroundColor: 10,
7000
- opacity: 11
7031
+ opacity: 11,
7032
+ pencilEraserSize: 20
7001
7033
  });
7002
7034
  }
7003
7035
  }
@@ -7118,6 +7150,7 @@ class Cursor {
7118
7150
  }
7119
7151
  }
7120
7152
  initProps() {
7153
+ var _a;
7121
7154
  return {
7122
7155
  x: 0,
7123
7156
  y: 0,
@@ -7131,14 +7164,22 @@ class Cursor {
7131
7164
  color: this.memberCursorTextColor,
7132
7165
  cursorTagBackgroundColor: this.memberCursorTagBackgroundColor,
7133
7166
  opacity: this.memberOpacity,
7134
- tagName: this.memberTagName
7167
+ tagName: this.memberTagName,
7168
+ pencilEraserSize: (_a = this.member) == null ? void 0 : _a.memberState.pencilEraserSize
7135
7169
  };
7136
7170
  }
7137
7171
  getIcon() {
7172
+ var _a;
7138
7173
  if (this.member) {
7139
7174
  const icons = this.cursorManager.applianceIcons;
7140
- const applianceSrc = icons[this.memberApplianceName || ApplianceNames.shape];
7141
- return applianceSrc || icons[ApplianceNames.shape];
7175
+ let applianceSrc = icons[ApplianceNames.shape];
7176
+ if (this.memberApplianceName === ApplianceNames.pencilEraser) {
7177
+ const size2 = ((_a = this.member) == null ? void 0 : _a.memberState.pencilEraserSize) || 1;
7178
+ applianceSrc = icons[`${this.memberApplianceName}${size2}`];
7179
+ } else {
7180
+ applianceSrc = icons[this.memberApplianceName || ApplianceNames.shape];
7181
+ }
7182
+ return applianceSrc;
7142
7183
  }
7143
7184
  }
7144
7185
  updateMember() {
@@ -7172,13 +7213,19 @@ var eraser = "
7172
7213
  var shape = "";
7173
7214
  var text = "";
7174
7215
  var laser = "";
7216
+ var pencilEraser1 = "";
7217
+ var pencilEraser2 = "";
7218
+ var pencilEraser3 = "";
7175
7219
  const ApplianceMap = {
7176
7220
  [ApplianceNames.pencil]: pencil,
7177
7221
  [ApplianceNames.selector]: selector,
7178
7222
  [ApplianceNames.eraser]: eraser,
7179
7223
  [ApplianceNames.shape]: shape,
7180
7224
  [ApplianceNames.text]: text,
7181
- [ApplianceNames.laserPointer]: laser
7225
+ [ApplianceNames.laserPointer]: laser,
7226
+ ["pencilEraser1"]: pencilEraser1,
7227
+ ["pencilEraser2"]: pencilEraser2,
7228
+ ["pencilEraser3"]: pencilEraser3
7182
7229
  };
7183
7230
  class CursorManager {
7184
7231
  constructor(manager, enableCursor, applianceIcons) {
@@ -16688,7 +16735,7 @@ const reconnectRefresher = new ReconnectRefresher({ emitter });
16688
16735
  const _WindowManager = class extends InvisiblePlugin {
16689
16736
  constructor(context) {
16690
16737
  super(context);
16691
- this.version = "0.4.43";
16738
+ this.version = "0.4.45";
16692
16739
  this.dependencies = { "dependencies": { "@juggle/resize-observer": "^3.3.1", "@netless/telebox-insider": "0.2.27", "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.33" } };
16693
16740
  this.emitter = callbacks$1;
16694
16741
  this.viewMode = ViewMode.Broadcaster;
@@ -17026,7 +17073,7 @@ const _WindowManager = class extends InvisiblePlugin {
17026
17073
  addEmitterOnceListener(`destroy-${kind2}`, listener);
17027
17074
  }
17028
17075
  setViewMode(mode) {
17029
- var _a, _b, _c;
17076
+ var _a, _b, _c, _d;
17030
17077
  if (mode === ViewMode.Broadcaster) {
17031
17078
  if (this.canOperate) {
17032
17079
  (_a = this.appManager) == null ? void 0 : _a.mainViewProxy.setCameraAndSize();
@@ -17037,6 +17084,7 @@ const _WindowManager = class extends InvisiblePlugin {
17037
17084
  (_c = this.appManager) == null ? void 0 : _c.mainViewProxy.stop();
17038
17085
  }
17039
17086
  this.viewMode = mode;
17087
+ (_d = this.appManager) == null ? void 0 : _d.mainViewProxy.setViewMode(mode);
17040
17088
  }
17041
17089
  setBoxState(boxState) {
17042
17090
  if (!this.canOperate)
@@ -17173,6 +17221,14 @@ const _WindowManager = class extends InvisiblePlugin {
17173
17221
  var _a;
17174
17222
  return (_a = this.appManager) == null ? void 0 : _a.closeApp(appId);
17175
17223
  }
17224
+ focusApp(appId) {
17225
+ var _a, _b, _c;
17226
+ const box = (_a = this.boxManager) == null ? void 0 : _a.getBox(appId);
17227
+ if (box) {
17228
+ (_b = this.boxManager) == null ? void 0 : _b.focusBox({ appId }, false);
17229
+ ((_c = this.boxManager) == null ? void 0 : _c.teleBoxManager).makeBoxTop(box, false);
17230
+ }
17231
+ }
17176
17232
  moveCamera(camera) {
17177
17233
  var _a;
17178
17234
  const pureCamera = omit(camera, ["animationMode"]);