@netless/fastboard-react 0.2.5 → 0.2.6

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.mjs CHANGED
@@ -377,12 +377,7 @@ function RedoUndo({ theme, undoIcon, undoIconDisable, redoIcon, redoIconDisable
377
377
  // src/components/ZoomControl/hooks.ts
378
378
  import { useCallback as useCallback3 } from "react";
379
379
  var ScalePoints = [
380
- 0.10737418240000011,
381
- 0.13421772800000012,
382
- 0.16777216000000014,
383
- 0.20971520000000016,
384
- 0.26214400000000015,
385
- 0.3276800000000002,
380
+ 0.3,
386
381
  0.4096000000000002,
387
382
  0.5120000000000001,
388
383
  0.6400000000000001,
@@ -392,12 +387,7 @@ var ScalePoints = [
392
387
  1.5876000000000001,
393
388
  2.000376,
394
389
  2.5204737600000002,
395
- 3.1757969376000004,
396
- 4.001504141376,
397
- 5.041895218133761,
398
- 6.352787974848539,
399
- 8.00451284830916,
400
- 10
390
+ 3
401
391
  ];
402
392
  function nextScale(scale, delta) {
403
393
  const { length } = ScalePoints;
@@ -740,59 +730,10 @@ function PageControl({
740
730
  }
741
731
 
742
732
  // src/components/Toolbar/hooks.ts
743
- import { useCallback as useCallback5 } from "react";
744
- function useRoomState() {
745
- return useFastboardValue(useFastboardApp().memberState);
746
- }
747
- function useToolbar() {
748
- const app = useFastboardApp();
749
- const writable = useWritable();
750
- const memberState = useRoomState();
751
- const cleanCurrentScene = useCallback5(() => {
752
- app.cleanCurrentScene();
753
- }, [app]);
754
- const setAppliance = useCallback5((appliance, shape) => {
755
- app.setAppliance(appliance, shape);
756
- }, [app]);
757
- const setStrokeWidth = useCallback5((strokeWidth) => {
758
- app.setStrokeWidth(strokeWidth);
759
- }, [app]);
760
- const setStrokeColor = useCallback5((strokeColor) => {
761
- app.setStrokeColor(strokeColor);
762
- }, [app]);
763
- return {
764
- writable,
765
- memberState,
766
- cleanCurrentScene,
767
- setAppliance,
768
- setStrokeWidth,
769
- setStrokeColor
770
- };
771
- }
772
- var EmptyToolbarHook = {
773
- writable: false,
774
- memberState: void 0,
775
- cleanCurrentScene: noop,
776
- setAppliance: noop,
777
- setStrokeWidth: noop,
778
- setStrokeColor: noop
779
- };
733
+ import { useCallback as useCallback5, useState as useState3 } from "react";
780
734
 
781
- // src/components/Toolbar/Toolbar.tsx
782
- import clsx9 from "clsx";
783
- import { AnimatePresence, motion } from "framer-motion";
784
- import React43, { createContext as createContext3, useState as useState4 } from "react";
785
-
786
- // src/components/Toolbar/components/assets/expanded.png
787
- var expanded_default = "";
788
-
789
- // src/components/Toolbar/Content.tsx
790
- import clsx8 from "clsx";
791
- import React42, { useCallback as useCallback10, useContext as useContext13, useEffect as useEffect3, useRef as useRef2, useState as useState3 } from "react";
792
-
793
- // src/components/Toolbar/components/ApplianceButtons.tsx
794
- import React33, { useCallback as useCallback6, useContext as useContext4 } from "react";
795
- import { ApplianceNames } from "white-web-sdk";
735
+ // src/components/Toolbar/const.ts
736
+ import { ApplianceNames, ShapeType } from "white-web-sdk";
796
737
 
797
738
  // src/components/Toolbar/icons/index.ts
798
739
  import { memo } from "react";
@@ -1069,6 +1010,96 @@ var Icons = {
1069
1010
  Down: memo(Down)
1070
1011
  };
1071
1012
 
1013
+ // src/components/Toolbar/const.ts
1014
+ var ShapesMap = {
1015
+ [ApplianceNames.rectangle]: Icons.Rectangle,
1016
+ [ApplianceNames.ellipse]: Icons.Circle,
1017
+ [ApplianceNames.straight]: Icons.Line,
1018
+ [ApplianceNames.arrow]: Icons.Arrow,
1019
+ [ShapeType.Pentagram]: Icons.Star,
1020
+ [ShapeType.Rhombus]: Icons.Diamond,
1021
+ [ShapeType.Triangle]: Icons.Triangle,
1022
+ [ShapeType.SpeechBalloon]: Icons.SpeechBalloon
1023
+ };
1024
+ var ApplianceShapes = [
1025
+ ApplianceNames.rectangle,
1026
+ ApplianceNames.ellipse,
1027
+ ApplianceNames.straight,
1028
+ ApplianceNames.arrow
1029
+ ];
1030
+ var Shapes = [
1031
+ ShapeType.Pentagram,
1032
+ ShapeType.Rhombus,
1033
+ ShapeType.Triangle,
1034
+ ShapeType.SpeechBalloon
1035
+ ];
1036
+ var ItemHeight = 32 + 4;
1037
+ var ItemsCount = 8;
1038
+ var MaxHeight = ItemHeight * ItemsCount - 4;
1039
+ var MinHeight = ItemHeight * 2 - 4;
1040
+
1041
+ // src/components/Toolbar/hooks.ts
1042
+ function useRoomState() {
1043
+ return useFastboardValue(useFastboardApp().memberState);
1044
+ }
1045
+ function useToolbar() {
1046
+ const app = useFastboardApp();
1047
+ const writable = useWritable();
1048
+ const memberState = useRoomState();
1049
+ const [lastShape, setLastShape] = useState3("rectangle");
1050
+ const cleanCurrentScene = useCallback5(() => {
1051
+ app.cleanCurrentScene();
1052
+ }, [app]);
1053
+ const setAppliance = useCallback5((appliance, shape) => {
1054
+ app.setAppliance(appliance, shape);
1055
+ if (shape) {
1056
+ setLastShape(shape);
1057
+ } else if (appliance in ShapesMap) {
1058
+ setLastShape(appliance);
1059
+ }
1060
+ }, [app]);
1061
+ const setStrokeWidth = useCallback5((strokeWidth) => {
1062
+ app.setStrokeWidth(strokeWidth);
1063
+ }, [app]);
1064
+ const setStrokeColor = useCallback5((strokeColor) => {
1065
+ app.setStrokeColor(strokeColor);
1066
+ }, [app]);
1067
+ return {
1068
+ writable,
1069
+ memberState,
1070
+ lastShape,
1071
+ cleanCurrentScene,
1072
+ setAppliance,
1073
+ setStrokeWidth,
1074
+ setStrokeColor
1075
+ };
1076
+ }
1077
+ var EmptyToolbarHook = {
1078
+ writable: false,
1079
+ memberState: void 0,
1080
+ lastShape: "rectangle",
1081
+ cleanCurrentScene: noop,
1082
+ setAppliance: noop,
1083
+ setStrokeWidth: noop,
1084
+ setStrokeColor: noop
1085
+ };
1086
+
1087
+ // src/components/Toolbar/Toolbar.tsx
1088
+ import clsx9 from "clsx";
1089
+ import { AnimatePresence, motion } from "framer-motion";
1090
+ import React43, { createContext as createContext3, useState as useState5 } from "react";
1091
+
1092
+ // src/components/Toolbar/components/assets/expanded.png
1093
+ var expanded_default = "";
1094
+
1095
+ // src/components/Toolbar/Content.tsx
1096
+ import clsx8 from "clsx";
1097
+ import React42, { useCallback as useCallback10, useContext as useContext13, useEffect as useEffect3, useRef as useRef2, useState as useState4 } from "react";
1098
+
1099
+ // src/components/Toolbar/components/ApplianceButtons.tsx
1100
+ import React33, { useCallback as useCallback6, useContext as useContext4 } from "react";
1101
+ import { ApplianceNames as ApplianceNames2 } from "white-web-sdk";
1102
+
1072
1103
  // src/components/Toolbar/components/Button.tsx
1073
1104
  import clsx4 from "clsx";
1074
1105
  import React32, { forwardRef, useContext as useContext3 } from "react";
@@ -1109,10 +1140,10 @@ function ClickerButton() {
1109
1140
  const app = useFastboardApp();
1110
1141
  const { t } = useTranslation();
1111
1142
  const { theme, icons, writable, setAppliance, memberState } = useContext4(ToolbarContext);
1112
- const changeAppliance = useCallback6(() => setAppliance(ApplianceNames.clicker), [setAppliance]);
1143
+ const changeAppliance = useCallback6(() => setAppliance(ApplianceNames2.clicker), [setAppliance]);
1113
1144
  const shortcut = (_a = app.hotKeys) == null ? void 0 : _a.changeToClick;
1114
1145
  const appliance = memberState == null ? void 0 : memberState.currentApplianceName;
1115
- const active = appliance === ApplianceNames.clicker;
1146
+ const active = appliance === ApplianceNames2.clicker;
1116
1147
  const disabled = !writable;
1117
1148
  return /* @__PURE__ */ React33.createElement(Button, {
1118
1149
  content: renderToolTip(t("clicker"), shortcut),
@@ -1131,9 +1162,9 @@ function SelectorButton() {
1131
1162
  const app = useFastboardApp();
1132
1163
  const { t } = useTranslation();
1133
1164
  const { theme, icons, writable, setAppliance, memberState } = useContext4(ToolbarContext);
1134
- const changeAppliance = useCallback6(() => setAppliance(ApplianceNames.selector), [setAppliance]);
1165
+ const changeAppliance = useCallback6(() => setAppliance(ApplianceNames2.selector), [setAppliance]);
1135
1166
  const appliance = memberState == null ? void 0 : memberState.currentApplianceName;
1136
- const active = appliance === ApplianceNames.selector;
1167
+ const active = appliance === ApplianceNames2.selector;
1137
1168
  const disabled = !writable;
1138
1169
  const shortcut = (app.hotKeys || defaultHotKeys).changeToSelector;
1139
1170
  return /* @__PURE__ */ React33.createElement(Button, {
@@ -1153,9 +1184,9 @@ function EraserButton() {
1153
1184
  const app = useFastboardApp();
1154
1185
  const { t } = useTranslation();
1155
1186
  const { theme, icons, writable, setAppliance, memberState } = useContext4(ToolbarContext);
1156
- const changeAppliance = useCallback6(() => setAppliance(ApplianceNames.eraser), [setAppliance]);
1187
+ const changeAppliance = useCallback6(() => setAppliance(ApplianceNames2.eraser), [setAppliance]);
1157
1188
  const appliance = memberState == null ? void 0 : memberState.currentApplianceName;
1158
- const active = appliance === ApplianceNames.eraser;
1189
+ const active = appliance === ApplianceNames2.eraser;
1159
1190
  const disabled = !writable;
1160
1191
  const shortcut = ((app == null ? void 0 : app.hotKeys) || defaultHotKeys).changeToEraser;
1161
1192
  return /* @__PURE__ */ React33.createElement(Button, {
@@ -1272,7 +1303,7 @@ function AppIcon({ title, src, alt, onClick }) {
1272
1303
  // src/components/Toolbar/components/PencilButton.tsx
1273
1304
  import Tippy6 from "@tippyjs/react";
1274
1305
  import React38, { useCallback as useCallback7, useContext as useContext9 } from "react";
1275
- import { ApplianceNames as ApplianceNames2 } from "white-web-sdk";
1306
+ import { ApplianceNames as ApplianceNames3 } from "white-web-sdk";
1276
1307
 
1277
1308
  // src/components/Toolbar/components/ColorBox.tsx
1278
1309
  import clsx5 from "clsx";
@@ -1349,10 +1380,10 @@ function PencilButton() {
1349
1380
  const { t } = useTranslation();
1350
1381
  const { theme, icons, writable, setAppliance, memberState } = useContext9(ToolbarContext);
1351
1382
  const changeAppliance = useCallback7(() => {
1352
- setAppliance(ApplianceNames2.pencil);
1383
+ setAppliance(ApplianceNames3.pencil);
1353
1384
  }, [setAppliance]);
1354
1385
  const appliance = memberState == null ? void 0 : memberState.currentApplianceName;
1355
- const active = appliance === ApplianceNames2.pencil;
1386
+ const active = appliance === ApplianceNames3.pencil;
1356
1387
  const disabled = !writable;
1357
1388
  const shortcut = ((app == null ? void 0 : app.hotKeys) || defaultHotKeys).changeToPencil;
1358
1389
  return /* @__PURE__ */ React38.createElement("span", {
@@ -1391,46 +1422,15 @@ function renderPencilButtonContent() {
1391
1422
  import Tippy7 from "@tippyjs/react";
1392
1423
  import React39, { useContext as useContext10 } from "react";
1393
1424
  import { ApplianceNames as ApplianceNames4 } from "white-web-sdk";
1394
-
1395
- // src/components/Toolbar/const.ts
1396
- import { ApplianceNames as ApplianceNames3, ShapeType } from "white-web-sdk";
1397
- var ShapesMap = {
1398
- [ApplianceNames3.rectangle]: Icons.Rectangle,
1399
- [ApplianceNames3.ellipse]: Icons.Circle,
1400
- [ApplianceNames3.straight]: Icons.Line,
1401
- [ApplianceNames3.arrow]: Icons.Arrow,
1402
- [ShapeType.Pentagram]: Icons.Star,
1403
- [ShapeType.Rhombus]: Icons.Diamond,
1404
- [ShapeType.Triangle]: Icons.Triangle,
1405
- [ShapeType.SpeechBalloon]: Icons.SpeechBalloon
1406
- };
1407
- var ApplianceShapes = [
1408
- ApplianceNames3.rectangle,
1409
- ApplianceNames3.ellipse,
1410
- ApplianceNames3.straight,
1411
- ApplianceNames3.arrow
1412
- ];
1413
- var Shapes = [
1414
- ShapeType.Pentagram,
1415
- ShapeType.Rhombus,
1416
- ShapeType.Triangle,
1417
- ShapeType.SpeechBalloon
1418
- ];
1419
- var ItemHeight = 32 + 4;
1420
- var ItemsCount = 8;
1421
- var MaxHeight = ItemHeight * ItemsCount - 4;
1422
- var MinHeight = ItemHeight * 2 - 4;
1423
-
1424
- // src/components/Toolbar/components/ShapesButton.tsx
1425
1425
  var ShapeTypes = /* @__PURE__ */ new Set([...ApplianceShapes, ...Shapes]);
1426
1426
  function ShapesButton() {
1427
1427
  const { t } = useTranslation();
1428
- const { theme, memberState } = useContext10(ToolbarContext);
1428
+ const { theme, memberState, lastShape } = useContext10(ToolbarContext);
1429
1429
  const appliance = memberState == null ? void 0 : memberState.currentApplianceName;
1430
1430
  const shape = memberState == null ? void 0 : memberState.shapeType;
1431
1431
  const key = appliance === ApplianceNames4.shape ? shape : appliance;
1432
1432
  const active = ShapeTypes.has(key);
1433
- const CurrentIcon = ShapesMap[key] || Icons.Rectangle;
1433
+ const CurrentIcon = ShapesMap[lastShape];
1434
1434
  return /* @__PURE__ */ React39.createElement("span", {
1435
1435
  className: "fastboard-toolbar-btn-interactive"
1436
1436
  }, /* @__PURE__ */ React39.createElement(Tippy7, {
@@ -1590,8 +1590,8 @@ var collapsed_default = "
1590
1590
  function Content({ onCollapse }) {
1591
1591
  const { theme, icons, writable } = useContext13(ToolbarContext);
1592
1592
  const ref = useRef2(null);
1593
- const [scrollTop, setScrollTop] = useState3(0);
1594
- const [parentHeight, setParentHeight] = useState3(0);
1593
+ const [scrollTop, setScrollTop] = useState4(0);
1594
+ const [parentHeight, setParentHeight] = useState4(0);
1595
1595
  const disabled = !writable;
1596
1596
  const needScroll = parentHeight < ItemHeight * ItemsCount + 48;
1597
1597
  const sectionHeight = clamp(parentHeight - 48 * (needScroll ? 3 : 1), MinHeight, MaxHeight);
@@ -1653,8 +1653,8 @@ var name4 = "fastboard-toolbar";
1653
1653
  function Toolbar({ theme, icons }) {
1654
1654
  theme = useTheme(theme);
1655
1655
  const hook = useToolbar();
1656
- const [expanded, setExpanded] = useState4(true);
1657
- const [pointerEvents, setPointerEvents] = useState4("auto");
1656
+ const [expanded, setExpanded] = useState5(true);
1657
+ const [pointerEvents, setPointerEvents] = useState5("auto");
1658
1658
  const disabled = !hook.writable;
1659
1659
  return /* @__PURE__ */ React43.createElement(ToolbarContext.Provider, {
1660
1660
  value: __spreadValues({ theme, icons }, hook)
@@ -1686,11 +1686,11 @@ function Toolbar({ theme, icons }) {
1686
1686
  }
1687
1687
 
1688
1688
  // src/components/PlayerControl/hooks.ts
1689
- import { useCallback as useCallback11, useEffect as useEffect4, useState as useState5 } from "react";
1689
+ import { useCallback as useCallback11, useEffect as useEffect4, useState as useState6 } from "react";
1690
1690
  import { PlayerPhase } from "white-web-sdk";
1691
1691
  var EMPTY_ARRAY = [];
1692
1692
  function useForceUpdate2() {
1693
- const [, forceUpdate_] = useState5({});
1693
+ const [, forceUpdate_] = useState6({});
1694
1694
  return useCallback11(() => forceUpdate_({}), EMPTY_ARRAY);
1695
1695
  }
1696
1696
  function usePlayerControl(player) {
@@ -1757,7 +1757,7 @@ function usePlayerControl(player) {
1757
1757
  import Tippy10 from "@tippyjs/react";
1758
1758
  import clsx11 from "clsx";
1759
1759
  import RcSlider2 from "rc-slider";
1760
- import React48, { useEffect as useEffect5, useState as useState6 } from "react";
1760
+ import React48, { useEffect as useEffect5, useState as useState7 } from "react";
1761
1761
  import { PlayerPhase as PlayerPhase2 } from "white-web-sdk";
1762
1762
 
1763
1763
  // src/components/PlayerControl/components/Button.tsx
@@ -1836,7 +1836,7 @@ function PlayerControl(_a) {
1836
1836
  var _b = _a, { theme, autoHide = false, player: player_ } = _b, icons = __objRest(_b, ["theme", "autoHide", "player"]);
1837
1837
  theme = useTheme(theme);
1838
1838
  const { t } = useTranslation();
1839
- const [currentTime, setCurrentTime] = useState6(0);
1839
+ const [currentTime, setCurrentTime] = useState7(0);
1840
1840
  const player = usePlayerControl(player_);
1841
1841
  useEffect5(() => {
1842
1842
  setCurrentTime(player.currentTime);