@techsee/techsee-media-service-client 999.2.2-bundle-release → 999.2.4-sap
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/lib/assets/img/avatar.png +0 -0
- package/lib/assets/img/camera-button.png +0 -0
- package/lib/assets/img/exclamation-mark.png +0 -0
- package/lib/assets/img/media-rejected/chrome1.png +0 -0
- package/lib/assets/img/media-rejected/chrome2.png +0 -0
- package/lib/assets/img/media-rejected/chrome3.png +0 -0
- package/lib/assets/img/media-rejected/chrome4.png +0 -0
- package/lib/assets/img/media-rejected/close_button.png +0 -0
- package/lib/assets/img/media-rejected/ios1.png +0 -0
- package/lib/assets/img/media-rejected/ios2.png +0 -0
- package/lib/components/Avatar/Avatar.d.ts +8 -0
- package/lib/components/Avatar/Avatar.d.ts.map +1 -0
- package/lib/components/Avatar/Avatar.js +26 -0
- package/lib/components/Avatar/Avatar.js.map +1 -0
- package/lib/components/Avatar/Avatar.scss +45 -0
- package/lib/components/ButtonPanels/EndMeetingButtonPanel/EndMeetingButtonPanel.d.ts +7 -0
- package/lib/components/ButtonPanels/EndMeetingButtonPanel/EndMeetingButtonPanel.d.ts.map +1 -0
- package/lib/components/ButtonPanels/EndMeetingButtonPanel/EndMeetingButtonPanel.js +15 -0
- package/lib/components/ButtonPanels/EndMeetingButtonPanel/EndMeetingButtonPanel.js.map +1 -0
- package/lib/components/ButtonPanels/MediaButtonsPanel/MediaButtonsPanel.d.ts +24 -0
- package/lib/components/ButtonPanels/MediaButtonsPanel/MediaButtonsPanel.d.ts.map +1 -0
- package/lib/components/ButtonPanels/MediaButtonsPanel/MediaButtonsPanel.js +58 -0
- package/lib/components/ButtonPanels/MediaButtonsPanel/MediaButtonsPanel.js.map +1 -0
- package/lib/components/ButtonPanels/MediaButtonsPanel/MediaButtonsPanel.scss +47 -0
- package/lib/components/ButtonPanels/MultipartyButton/MultipartyButton.d.ts +18 -0
- package/lib/components/ButtonPanels/MultipartyButton/MultipartyButton.d.ts.map +1 -0
- package/lib/components/ButtonPanels/MultipartyButton/MultipartyButton.js +35 -0
- package/lib/components/ButtonPanels/MultipartyButton/MultipartyButton.js.map +1 -0
- package/lib/components/ButtonPanels/PinButtonPanel/PinButtonPanel.d.ts +10 -0
- package/lib/components/ButtonPanels/PinButtonPanel/PinButtonPanel.d.ts.map +1 -0
- package/lib/components/ButtonPanels/PinButtonPanel/PinButtonPanel.js +22 -0
- package/lib/components/ButtonPanels/PinButtonPanel/PinButtonPanel.js.map +1 -0
- package/lib/components/ButtonPanels/SnapshotButtonPanel/SnapshotButtonPanel.d.ts +9 -0
- package/lib/components/ButtonPanels/SnapshotButtonPanel/SnapshotButtonPanel.d.ts.map +1 -0
- package/lib/components/ButtonPanels/SnapshotButtonPanel/SnapshotButtonPanel.js +15 -0
- package/lib/components/ButtonPanels/SnapshotButtonPanel/SnapshotButtonPanel.js.map +1 -0
- package/lib/components/ButtonPanels/SnapshotButtonPanel/SnapshotButtonPanel.scss +6 -0
- package/lib/components/ButtonPanels/index.d.ts +6 -0
- package/lib/components/ButtonPanels/index.d.ts.map +1 -0
- package/lib/components/ButtonPanels/index.js +14 -0
- package/lib/components/ButtonPanels/index.js.map +1 -0
- package/lib/components/LoaderSpinner/LoaderSpinner.d.ts +8 -0
- package/lib/components/LoaderSpinner/LoaderSpinner.d.ts.map +1 -0
- package/lib/components/LoaderSpinner/LoaderSpinner.js +22 -0
- package/lib/components/LoaderSpinner/LoaderSpinner.js.map +1 -0
- package/lib/components/LoaderSpinner/LoaderSpinner.scss +69 -0
- package/lib/components/MagicMarker/MagicMarker.scss +18 -0
- package/lib/components/MagicMarker/MagicMarkerComponent.d.ts +36 -0
- package/lib/components/MagicMarker/MagicMarkerComponent.d.ts.map +1 -0
- package/lib/components/MagicMarker/MagicMarkerComponent.js +111 -0
- package/lib/components/MagicMarker/MagicMarkerComponent.js.map +1 -0
- package/lib/components/MagicMarker/index.d.ts +2 -0
- package/lib/components/MagicMarker/index.d.ts.map +1 -0
- package/lib/components/MagicMarker/index.js +6 -0
- package/lib/components/MagicMarker/index.js.map +1 -0
- package/lib/components/MediaRejectedModal/MediaRejectedModal.d.ts +24 -0
- package/lib/components/MediaRejectedModal/MediaRejectedModal.d.ts.map +1 -0
- package/lib/components/MediaRejectedModal/MediaRejectedModal.js +45 -0
- package/lib/components/MediaRejectedModal/MediaRejectedModal.js.map +1 -0
- package/lib/components/MediaRejectedModal/MediaRejectedModal.scss +75 -0
- package/lib/components/Multiparty.d.ts +23 -6
- package/lib/components/Multiparty.d.ts.map +1 -0
- package/lib/components/Multiparty.js +210 -0
- package/lib/components/Multiparty.js.map +1 -0
- package/lib/components/Multiparty.scss +8 -0
- package/lib/components/Multiparty.types.d.ts +11 -0
- package/lib/components/Multiparty.types.d.ts.map +1 -0
- package/lib/components/Multiparty.types.js +9 -0
- package/lib/components/Multiparty.types.js.map +1 -0
- package/lib/components/Video/Video.d.ts +23 -0
- package/lib/components/Video/Video.d.ts.map +1 -0
- package/lib/components/Video/Video.js +23 -0
- package/lib/components/Video/Video.js.map +1 -0
- package/lib/components/Video/Video.scss +10 -0
- package/lib/components/Video/VideoPlaceholder.d.ts +23 -0
- package/lib/components/Video/VideoPlaceholder.d.ts.map +1 -0
- package/lib/components/Video/VideoPlaceholder.js +30 -0
- package/lib/components/Video/VideoPlaceholder.js.map +1 -0
- package/lib/components/VideoLayouts/AgentPinnedLayout/AgentPinnedLayout.d.ts +23 -0
- package/lib/components/VideoLayouts/AgentPinnedLayout/AgentPinnedLayout.d.ts.map +1 -0
- package/lib/components/VideoLayouts/AgentPinnedLayout/AgentPinnedLayout.js +35 -0
- package/lib/components/VideoLayouts/AgentPinnedLayout/AgentPinnedLayout.js.map +1 -0
- package/lib/components/VideoLayouts/AgentPinnedLayout/AgentPinnedLayout.scss +49 -0
- package/lib/components/VideoLayouts/BigMainVideoLayout/BigAreaLandscapeLayout.d.ts +13 -0
- package/lib/components/VideoLayouts/BigMainVideoLayout/BigAreaLandscapeLayout.d.ts.map +1 -0
- package/lib/components/VideoLayouts/BigMainVideoLayout/BigAreaLandscapeLayout.js +63 -0
- package/lib/components/VideoLayouts/BigMainVideoLayout/BigAreaLandscapeLayout.js.map +1 -0
- package/lib/components/VideoLayouts/BigMainVideoLayout/BigAreaLandscapeLayout.scss +46 -0
- package/lib/components/VideoLayouts/BigMainVideoLayout/BigAreaLayout.d.ts +55 -0
- package/lib/components/VideoLayouts/BigMainVideoLayout/BigAreaLayout.d.ts.map +1 -0
- package/lib/components/VideoLayouts/BigMainVideoLayout/BigAreaLayout.js +41 -0
- package/lib/components/VideoLayouts/BigMainVideoLayout/BigAreaLayout.js.map +1 -0
- package/lib/components/VideoLayouts/BigMainVideoLayout/BigAreaLayout.scss +94 -0
- package/lib/components/VideoLayouts/BigMainVideoLayout/BigAreaLayoutPortrait.d.ts +12 -0
- package/lib/components/VideoLayouts/BigMainVideoLayout/BigAreaLayoutPortrait.d.ts.map +1 -0
- package/lib/components/VideoLayouts/BigMainVideoLayout/BigAreaLayoutPortrait.js +62 -0
- package/lib/components/VideoLayouts/BigMainVideoLayout/BigAreaLayoutPortrait.js.map +1 -0
- package/lib/components/VideoLayouts/BigMainVideoLayout/BigAreaPortraitLayout.scss +72 -0
- package/lib/components/VideoLayouts/VideoLayoutManager.d.ts +36 -0
- package/lib/components/VideoLayouts/VideoLayoutManager.d.ts.map +1 -0
- package/lib/components/VideoLayouts/VideoLayoutManager.js +40 -0
- package/lib/components/VideoLayouts/VideoLayoutManager.js.map +1 -0
- package/lib/components/VideoLayouts/index.d.ts +2 -0
- package/lib/components/VideoLayouts/index.d.ts.map +1 -0
- package/lib/components/VideoLayouts/index.js +6 -0
- package/lib/components/VideoLayouts/index.js.map +1 -0
- package/lib/components/VideoPlaceholders/BigAreaMediaPermissionDeniedPlaceholder.d.ts +12 -0
- package/lib/components/VideoPlaceholders/BigAreaMediaPermissionDeniedPlaceholder.d.ts.map +1 -0
- package/lib/components/VideoPlaceholders/BigAreaMediaPermissionDeniedPlaceholder.js +36 -0
- package/lib/components/VideoPlaceholders/BigAreaMediaPermissionDeniedPlaceholder.js.map +1 -0
- package/lib/components/VideoPlaceholders/BigAreaMediaPermissionDeniedPlaceholder.scss +34 -0
- package/lib/components/VideoPlaceholders/CameraOffButton.d.ts +4 -0
- package/lib/components/VideoPlaceholders/CameraOffButton.d.ts.map +1 -0
- package/lib/components/VideoPlaceholders/CameraOffButton.js +9 -0
- package/lib/components/VideoPlaceholders/CameraOffButton.js.map +1 -0
- package/lib/components/VideoPlaceholders/SmallAreaMediaPermissionDeniedPlaceholder.d.ts +12 -0
- package/lib/components/VideoPlaceholders/SmallAreaMediaPermissionDeniedPlaceholder.d.ts.map +1 -0
- package/lib/components/VideoPlaceholders/SmallAreaMediaPermissionDeniedPlaceholder.js +40 -0
- package/lib/components/VideoPlaceholders/SmallAreaMediaPermissionDeniedPlaceholder.js.map +1 -0
- package/lib/components/VideoPlaceholders/SmallAreaMediaPermissionDeniedPlaceholder.scss +15 -0
- package/lib/components/VideoPlaceholders/Tooltip.scss +65 -0
- package/lib/index.d.ts +6 -1
- package/lib/index.d.ts.map +1 -0
- package/lib/index.js +26 -0
- package/lib/index.js.map +1 -0
- package/lib/services/ConnectionManager.d.ts +42 -0
- package/lib/services/ConnectionManager.d.ts.map +1 -0
- package/lib/services/ConnectionManager.js +199 -0
- package/lib/services/ConnectionManager.js.map +1 -0
- package/lib/services/MediaStateService.d.ts +25 -0
- package/lib/services/MediaStateService.d.ts.map +1 -0
- package/lib/services/MediaStateService.js +84 -0
- package/lib/services/MediaStateService.js.map +1 -0
- package/lib/services/MultipartyController.d.ts +33 -0
- package/lib/services/MultipartyController.d.ts.map +1 -0
- package/lib/services/MultipartyController.js +384 -0
- package/lib/services/MultipartyController.js.map +1 -0
- package/lib/services/MultipartyEventTypes.d.ts +92 -0
- package/lib/services/MultipartyEventTypes.d.ts.map +1 -0
- package/lib/services/MultipartyEventTypes.js +19 -0
- package/lib/services/MultipartyEventTypes.js.map +1 -0
- package/lib/services/trafficLogManager.d.ts +21 -0
- package/lib/services/trafficLogManager.d.ts.map +1 -0
- package/lib/services/trafficLogManager.js +130 -0
- package/lib/services/trafficLogManager.js.map +1 -0
- package/lib/services/types.d.ts +51 -0
- package/lib/services/types.d.ts.map +1 -0
- package/lib/services/types.js +47 -0
- package/lib/services/types.js.map +1 -0
- package/lib/utils/ClientConstants.d.ts +5 -0
- package/lib/utils/ClientConstants.d.ts.map +1 -0
- package/lib/utils/ClientConstants.js +8 -0
- package/lib/utils/ClientConstants.js.map +1 -0
- package/lib/utils/MergingStore.d.ts +11 -0
- package/lib/utils/MergingStore.d.ts.map +1 -0
- package/lib/utils/MergingStore.js +98 -0
- package/lib/utils/MergingStore.js.map +1 -0
- package/lib/utils/detectOsType.d.ts +8 -0
- package/lib/utils/detectOsType.d.ts.map +1 -0
- package/lib/utils/detectOsType.js +23 -0
- package/lib/utils/detectOsType.js.map +1 -0
- package/lib/utils/index.d.ts +5 -0
- package/lib/utils/index.d.ts.map +1 -0
- package/lib/utils/index.js +14 -0
- package/lib/utils/index.js.map +1 -0
- package/lib/utils/useEvent.d.ts +4 -0
- package/lib/utils/useEvent.d.ts.map +1 -0
- package/lib/utils/useEvent.js +20 -0
- package/lib/utils/useEvent.js.map +1 -0
- package/package.json +87 -58
- package/lib/bundle.js +0 -3
- package/lib/bundle.js.LICENSE.txt +0 -57
- package/lib/services/WebRTCClient.d.ts +0 -22
- package/lib/stories/Multiparty.stories.d.ts +0 -4
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Avatar.d.ts","sourceRoot":"","sources":["../../../src/components/Avatar/Avatar.tsx"],"names":[],"mappings":";AACA,OAAO,eAAe,CAAC;AAEvB,MAAM,WAAW,WAAW;IACxB,IAAI,CAAC,EAAE,MAAM,GAAG,KAAK,CAAC;IACtB,OAAO,CAAC,EAAE,MAAM,IAAI,CAAC;CACxB;AAED,eAAO,MAAM,MAAM,EAAE,KAAK,CAAC,EAAE,CAAC,WAAW,CAWxC,CAAC"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __assign = (this && this.__assign) || function () {
|
|
3
|
+
__assign = Object.assign || function(t) {
|
|
4
|
+
for (var s, i = 1, n = arguments.length; i < n; i++) {
|
|
5
|
+
s = arguments[i];
|
|
6
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
|
|
7
|
+
t[p] = s[p];
|
|
8
|
+
}
|
|
9
|
+
return t;
|
|
10
|
+
};
|
|
11
|
+
return __assign.apply(this, arguments);
|
|
12
|
+
};
|
|
13
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
14
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
exports.Avatar = void 0;
|
|
18
|
+
var jsx_runtime_1 = require("react/jsx-runtime");
|
|
19
|
+
var avatar_png_1 = __importDefault(require("../../assets/img/avatar.png"));
|
|
20
|
+
require("./Avatar.scss");
|
|
21
|
+
var Avatar = function (_a) {
|
|
22
|
+
var text = _a.text, onClick = _a.onClick;
|
|
23
|
+
return (jsx_runtime_1.jsx("div", __assign({ className: 'avatar-container' }, { children: jsx_runtime_1.jsxs("div", __assign({ className: 'avatar-box' }, { children: [jsx_runtime_1.jsx("img", { src: avatar_png_1.default, className: 'avatar-img' }, void 0), text && (jsx_runtime_1.jsx("div", __assign({ className: 'avatar-toast', onClick: onClick }, { children: jsx_runtime_1.jsx("span", __assign({ className: 'avatar-toast-text' }, { children: text }), void 0) }), void 0))] }), void 0) }), void 0));
|
|
24
|
+
};
|
|
25
|
+
exports.Avatar = Avatar;
|
|
26
|
+
//# sourceMappingURL=Avatar.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Avatar.js","sourceRoot":"","sources":["../../../src/components/Avatar/Avatar.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;AAAA,2EAA2D;AAC3D,yBAAuB;AAOhB,IAAM,MAAM,GAA0B,UAAC,EAAe;QAAd,IAAI,UAAA,EAAE,OAAO,aAAA;IAAM,OAAA,CAC9D,oCAAK,SAAS,EAAC,kBAAkB,gBAC7B,qCAAK,SAAS,EAAC,YAAY,iBACvB,2BAAK,GAAG,EAAE,oBAAgB,EAAE,SAAS,EAAC,YAAY,WAAG,EACpD,IAAI,IAAI,CACL,oCAAK,SAAS,EAAC,cAAc,EAAC,OAAO,EAAE,OAAO,gBAC1C,qCAAM,SAAS,EAAC,mBAAmB,gBAAE,IAAI,YAAQ,YAC/C,CACT,aACC,YACJ,CACT;AAXiE,CAWjE,CAAC;AAXW,QAAA,MAAM,UAWjB"}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
.avatar-container {
|
|
2
|
+
position: absolute;
|
|
3
|
+
z-index: 2;
|
|
4
|
+
background: #3a3a3a;
|
|
5
|
+
width: 100%;
|
|
6
|
+
height: 100%;
|
|
7
|
+
border-radius: inherit;
|
|
8
|
+
|
|
9
|
+
display: flex;
|
|
10
|
+
flex-direction: column;
|
|
11
|
+
align-items: center;
|
|
12
|
+
justify-content: center;
|
|
13
|
+
|
|
14
|
+
.avatar-box {
|
|
15
|
+
position: relative;
|
|
16
|
+
width: 100%;
|
|
17
|
+
text-align: center;
|
|
18
|
+
|
|
19
|
+
.avatar-toast {
|
|
20
|
+
background-color: rgba(255, 255, 255, 0.2);
|
|
21
|
+
padding: 10px;
|
|
22
|
+
z-index: 3;
|
|
23
|
+
|
|
24
|
+
position: absolute;
|
|
25
|
+
bottom: -15px;
|
|
26
|
+
left: 50%;
|
|
27
|
+
|
|
28
|
+
transform: translate(-50%, 100%);
|
|
29
|
+
|
|
30
|
+
border-radius: 4px;
|
|
31
|
+
|
|
32
|
+
.avatar-toast-text {
|
|
33
|
+
color: #ffffff;
|
|
34
|
+
font-style: normal;
|
|
35
|
+
font-weight: 700;
|
|
36
|
+
font-size: 16px;
|
|
37
|
+
line-height: 22px;
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
&:hover {
|
|
41
|
+
cursor: pointer;
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"EndMeetingButtonPanel.d.ts","sourceRoot":"","sources":["../../../../src/components/ButtonPanels/EndMeetingButtonPanel/EndMeetingButtonPanel.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAG1B,aAAK,KAAK,GAAG;IACT,qBAAqB,CAAC,EAAE,MAAM,IAAI,CAAC;CACtC,CAAC;AAWF,eAAO,MAAM,qBAAqB,EAAE,KAAK,CAAC,EAAE,CAAC,KAAK,CAAqC,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.EndMeetingButtonPanel = void 0;
|
|
7
|
+
var jsx_runtime_1 = require("react/jsx-runtime");
|
|
8
|
+
var react_1 = __importDefault(require("react"));
|
|
9
|
+
var MultipartyButton_1 = require("../MultipartyButton/MultipartyButton");
|
|
10
|
+
var endMeetingButtonPanel = function (_a) {
|
|
11
|
+
var onEndMeetingRequested = _a.onEndMeetingRequested;
|
|
12
|
+
return (jsx_runtime_1.jsx(MultipartyButton_1.MultipartyButton, { type: MultipartyButton_1.MultipartyButtonType.Mobile, onClick: onEndMeetingRequested, iconName: 'slim-x', isBackgroundVisible: true }, void 0));
|
|
13
|
+
};
|
|
14
|
+
exports.EndMeetingButtonPanel = react_1.default.memo(endMeetingButtonPanel);
|
|
15
|
+
//# sourceMappingURL=EndMeetingButtonPanel.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"EndMeetingButtonPanel.js","sourceRoot":"","sources":["../../../../src/components/ButtonPanels/EndMeetingButtonPanel/EndMeetingButtonPanel.tsx"],"names":[],"mappings":";;;;;;;AAAA,gDAA0B;AAC1B,yEAA4F;AAM5F,IAAM,qBAAqB,GAAG,UAAC,EAA8B;QAA7B,qBAAqB,2BAAA;IAA0B,OAAA,CAC3E,kBAAC,mCAAgB,IACb,IAAI,EAAE,uCAAoB,CAAC,MAAM,EACjC,OAAO,EAAE,qBAAqB,EAC9B,QAAQ,EAAC,QAAQ,EACjB,mBAAmB,iBACrB,CACL;AAP8E,CAO9E,CAAC;AAEW,QAAA,qBAAqB,GAAoB,eAAK,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { MultipartyButtonType } from '../MultipartyButton/MultipartyButton';
|
|
3
|
+
import './MediaButtonsPanel.scss';
|
|
4
|
+
interface Props {
|
|
5
|
+
buttonsType: MultipartyButtonType;
|
|
6
|
+
isMuted: boolean;
|
|
7
|
+
isVideoTurnedOff: boolean;
|
|
8
|
+
isBackgroundVisible?: boolean;
|
|
9
|
+
isIconTransparencyEnabled?: boolean;
|
|
10
|
+
isSharingScreen?: boolean;
|
|
11
|
+
disabledDesktopSharingButton?: boolean;
|
|
12
|
+
buttonsSpacing?: ButtonsSpacing;
|
|
13
|
+
onToggleMute?: () => void;
|
|
14
|
+
onToggleVideo?: () => void;
|
|
15
|
+
onSwitchCamera?: () => void;
|
|
16
|
+
toggleScreenShare?: () => void;
|
|
17
|
+
}
|
|
18
|
+
export declare enum ButtonsSpacing {
|
|
19
|
+
Dense = 0,
|
|
20
|
+
Sparse = 1
|
|
21
|
+
}
|
|
22
|
+
export declare const MediaButtonsPanel: React.FC<Props>;
|
|
23
|
+
export {};
|
|
24
|
+
//# sourceMappingURL=MediaButtonsPanel.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MediaButtonsPanel.d.ts","sourceRoot":"","sources":["../../../../src/components/ButtonPanels/MediaButtonsPanel/MediaButtonsPanel.tsx"],"names":[],"mappings":"AAAA,OAAO,KAA0C,MAAM,OAAO,CAAC;AAE/D,OAAO,EAAmB,oBAAoB,EAAC,MAAM,sCAAsC,CAAC;AAE5F,OAAO,0BAA0B,CAAC;AAElC,UAAU,KAAK;IACX,WAAW,EAAE,oBAAoB,CAAC;IAClC,OAAO,EAAE,OAAO,CAAC;IACjB,gBAAgB,EAAE,OAAO,CAAC;IAC1B,mBAAmB,CAAC,EAAE,OAAO,CAAC;IAC9B,yBAAyB,CAAC,EAAE,OAAO,CAAC;IACpC,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,4BAA4B,CAAC,EAAE,OAAO,CAAC;IACvC,cAAc,CAAC,EAAE,cAAc,CAAC;IAChC,YAAY,CAAC,EAAE,MAAM,IAAI,CAAC;IAC1B,aAAa,CAAC,EAAE,MAAM,IAAI,CAAC;IAC3B,cAAc,CAAC,EAAE,MAAM,IAAI,CAAC;IAC5B,iBAAiB,CAAC,EAAE,MAAM,IAAI,CAAC;CAClC;AAED,oBAAY,cAAc;IACtB,KAAK,IAAA;IACL,MAAM,IAAA;CACT;AAED,eAAO,MAAM,iBAAiB,EAAE,KAAK,CAAC,EAAE,CAAC,KAAK,CAmG7C,CAAC"}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __assign = (this && this.__assign) || function () {
|
|
3
|
+
__assign = Object.assign || function(t) {
|
|
4
|
+
for (var s, i = 1, n = arguments.length; i < n; i++) {
|
|
5
|
+
s = arguments[i];
|
|
6
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
|
|
7
|
+
t[p] = s[p];
|
|
8
|
+
}
|
|
9
|
+
return t;
|
|
10
|
+
};
|
|
11
|
+
return __assign.apply(this, arguments);
|
|
12
|
+
};
|
|
13
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
14
|
+
exports.MediaButtonsPanel = exports.ButtonsSpacing = void 0;
|
|
15
|
+
var jsx_runtime_1 = require("react/jsx-runtime");
|
|
16
|
+
var react_1 = require("react");
|
|
17
|
+
var simple_icon_1 = require("@techsee/techsee-ui-common/lib/icons/simple-icon");
|
|
18
|
+
var MultipartyButton_1 = require("../MultipartyButton/MultipartyButton");
|
|
19
|
+
require("./MediaButtonsPanel.scss");
|
|
20
|
+
var ButtonsSpacing;
|
|
21
|
+
(function (ButtonsSpacing) {
|
|
22
|
+
ButtonsSpacing[ButtonsSpacing["Dense"] = 0] = "Dense";
|
|
23
|
+
ButtonsSpacing[ButtonsSpacing["Sparse"] = 1] = "Sparse";
|
|
24
|
+
})(ButtonsSpacing = exports.ButtonsSpacing || (exports.ButtonsSpacing = {}));
|
|
25
|
+
var MediaButtonsPanel = function (_a) {
|
|
26
|
+
var buttonsType = _a.buttonsType, isMuted = _a.isMuted, isVideoTurnedOff = _a.isVideoTurnedOff, _b = _a.isBackgroundVisible, isBackgroundVisible = _b === void 0 ? true : _b, _c = _a.isIconTransparencyEnabled, isIconTransparencyEnabled = _c === void 0 ? true : _c, _d = _a.buttonsSpacing, buttonsSpacing = _d === void 0 ? ButtonsSpacing.Sparse : _d, onToggleMute = _a.onToggleMute, onToggleVideo = _a.onToggleVideo, onSwitchCamera = _a.onSwitchCamera, isSharingScreen = _a.isSharingScreen, toggleScreenShare = _a.toggleScreenShare, disabledDesktopSharingButton = _a.disabledDesktopSharingButton;
|
|
27
|
+
var platformClass = 'mobile';
|
|
28
|
+
if (buttonsType === MultipartyButton_1.MultipartyButtonType.Desktop)
|
|
29
|
+
platformClass = 'desktop';
|
|
30
|
+
else if (buttonsType === MultipartyButton_1.MultipartyButtonType.DesktopObsolete)
|
|
31
|
+
platformClass = 'desktop-obsolete';
|
|
32
|
+
platformClass += ' ' + (buttonsSpacing === ButtonsSpacing.Dense ? 'dense' : 'sparse');
|
|
33
|
+
var _e = react_1.useState(false), displayStopSharingButton = _e[0], setDisplayStopSharingButton = _e[1];
|
|
34
|
+
var onClickScreenShare = react_1.useCallback(function () {
|
|
35
|
+
if (isSharingScreen && !displayStopSharingButton) {
|
|
36
|
+
setDisplayStopSharingButton(true);
|
|
37
|
+
}
|
|
38
|
+
if (isSharingScreen && displayStopSharingButton) {
|
|
39
|
+
setDisplayStopSharingButton(false);
|
|
40
|
+
}
|
|
41
|
+
if (!isSharingScreen && toggleScreenShare) {
|
|
42
|
+
toggleScreenShare();
|
|
43
|
+
}
|
|
44
|
+
}, [toggleScreenShare, isSharingScreen, displayStopSharingButton]);
|
|
45
|
+
var onClickStopSharingButton = react_1.useCallback(function () {
|
|
46
|
+
setDisplayStopSharingButton(false);
|
|
47
|
+
if (toggleScreenShare) {
|
|
48
|
+
toggleScreenShare();
|
|
49
|
+
}
|
|
50
|
+
}, [toggleScreenShare, setDisplayStopSharingButton]);
|
|
51
|
+
var onCloseStopSharingButton = function (event) {
|
|
52
|
+
event.stopPropagation();
|
|
53
|
+
setDisplayStopSharingButton(false);
|
|
54
|
+
};
|
|
55
|
+
return (jsx_runtime_1.jsxs("div", __assign({ className: "media-buttons-panel " + platformClass }, { children: [toggleScreenShare && (jsx_runtime_1.jsxs(jsx_runtime_1.Fragment, { children: [jsx_runtime_1.jsx(MultipartyButton_1.MultipartyButton, { type: buttonsType, onClick: onClickScreenShare, iconName: 'Screen-Share', isBackgroundVisible: isBackgroundVisible, disabled: disabledDesktopSharingButton }, void 0), displayStopSharingButton && (jsx_runtime_1.jsxs("div", __assign({ className: 'stop-desktop-sharing', onClick: onClickStopSharingButton }, { children: [jsx_runtime_1.jsx("button", __assign({ type: 'button', onClick: onCloseStopSharingButton }, { children: jsx_runtime_1.jsx(simple_icon_1.Icon, { iconName: 'close' }, void 0) }), void 0), jsx_runtime_1.jsx("span", { children: "Stop Sharing" }, void 0)] }), void 0))] }, void 0)), onToggleMute && (jsx_runtime_1.jsx(MultipartyButton_1.MultipartyButton, { type: buttonsType, onClick: onToggleMute, iconName: isMuted ? 'mic-off' : 'mic-on', isSwitchedOn: !isIconTransparencyEnabled || !isMuted, isBackgroundVisible: isBackgroundVisible }, void 0)), onToggleVideo && (jsx_runtime_1.jsx(MultipartyButton_1.MultipartyButton, { type: buttonsType, onClick: onToggleVideo, iconName: isVideoTurnedOff ? 'camera-off' : 'camera-on', isSwitchedOn: !isIconTransparencyEnabled || !isVideoTurnedOff, isBackgroundVisible: isBackgroundVisible }, void 0)), onSwitchCamera && (jsx_runtime_1.jsx(MultipartyButton_1.MultipartyButton, { type: buttonsType, onClick: onSwitchCamera, iconName: 'switch-camera', isBackgroundVisible: isBackgroundVisible, disabled: isVideoTurnedOff }, void 0))] }), void 0));
|
|
56
|
+
};
|
|
57
|
+
exports.MediaButtonsPanel = MediaButtonsPanel;
|
|
58
|
+
//# sourceMappingURL=MediaButtonsPanel.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MediaButtonsPanel.js","sourceRoot":"","sources":["../../../../src/components/ButtonPanels/MediaButtonsPanel/MediaButtonsPanel.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
.media-buttons-panel {
|
|
2
|
+
display: flex;
|
|
3
|
+
|
|
4
|
+
&.mobile > * {
|
|
5
|
+
margin: 15px 15px 15px 0;
|
|
6
|
+
}
|
|
7
|
+
|
|
8
|
+
&.desktop.sparse > * {
|
|
9
|
+
margin: 10px 10px 10px 0;
|
|
10
|
+
|
|
11
|
+
&:last-child {
|
|
12
|
+
margin-right: 0;
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
&.desktop.dense > * {
|
|
17
|
+
margin: 10px 3px 10px 0;
|
|
18
|
+
|
|
19
|
+
&:last-child {
|
|
20
|
+
margin-right: 0;
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
&.button-desktop-obsolete > * {
|
|
25
|
+
margin: 10px 5px 10px 0;
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
& > *:last-child {
|
|
29
|
+
margin-right: 0;
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
&.mobile {
|
|
33
|
+
.stop-desktop-sharing {
|
|
34
|
+
display: flex;
|
|
35
|
+
flex-direction: row;
|
|
36
|
+
align-items: center;
|
|
37
|
+
padding: 4px;
|
|
38
|
+
position: absolute;
|
|
39
|
+
width: 161px;
|
|
40
|
+
height: 56px;
|
|
41
|
+
top: 50px;
|
|
42
|
+
background: #f9fafb;
|
|
43
|
+
//box-shadow: 0px 0px 70px rgb(0 0 0 / 45%);
|
|
44
|
+
border-radius: 10px;
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
export declare enum MultipartyButtonType {
|
|
3
|
+
Mobile = "mobile",
|
|
4
|
+
Desktop = "desktop",
|
|
5
|
+
DesktopObsolete = "desktop-obsolete",
|
|
6
|
+
MobileObsolete = "mobile-obsolete"
|
|
7
|
+
}
|
|
8
|
+
interface Props {
|
|
9
|
+
type: MultipartyButtonType;
|
|
10
|
+
iconName: string;
|
|
11
|
+
isSwitchedOn?: boolean;
|
|
12
|
+
disabled?: boolean;
|
|
13
|
+
isBackgroundVisible?: boolean;
|
|
14
|
+
onClick?: () => void;
|
|
15
|
+
}
|
|
16
|
+
export declare const MultipartyButton: React.FC<Props>;
|
|
17
|
+
export {};
|
|
18
|
+
//# sourceMappingURL=MultipartyButton.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MultipartyButton.d.ts","sourceRoot":"","sources":["../../../../src/components/ButtonPanels/MultipartyButton/MultipartyButton.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAU1B,oBAAY,oBAAoB;IAC5B,MAAM,WAAW;IACjB,OAAO,YAAY;IACnB,eAAe,qBAAqB;IACpC,cAAc,oBAAoB;CACrC;AAeD,UAAU,KAAK;IACX,IAAI,EAAE,oBAAoB,CAAC;IAC3B,QAAQ,EAAE,MAAM,CAAC;IACjB,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,mBAAmB,CAAC,EAAE,OAAO,CAAC;IAC9B,OAAO,CAAC,EAAE,MAAM,IAAI,CAAC;CACxB;AAED,eAAO,MAAM,gBAAgB,EAAE,KAAK,CAAC,EAAE,CAAC,KAAK,CA0B5C,CAAC"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.MultipartyButton = exports.MultipartyButtonType = void 0;
|
|
4
|
+
var jsx_runtime_1 = require("react/jsx-runtime");
|
|
5
|
+
var border_rounded_icon_1 = require("@techsee/techsee-ui-common/lib/forms/buttons/border-rounded-icon");
|
|
6
|
+
var square_rounded_icon_1 = require("@techsee/techsee-ui-common/lib/forms/buttons/square-rounded-icon");
|
|
7
|
+
var large_rounded_icon_1 = require("@techsee/techsee-ui-common/lib/icons/large-rounded-icon");
|
|
8
|
+
var MultipartyButtonType;
|
|
9
|
+
(function (MultipartyButtonType) {
|
|
10
|
+
MultipartyButtonType["Mobile"] = "mobile";
|
|
11
|
+
MultipartyButtonType["Desktop"] = "desktop";
|
|
12
|
+
MultipartyButtonType["DesktopObsolete"] = "desktop-obsolete";
|
|
13
|
+
MultipartyButtonType["MobileObsolete"] = "mobile-obsolete";
|
|
14
|
+
})(MultipartyButtonType = exports.MultipartyButtonType || (exports.MultipartyButtonType = {}));
|
|
15
|
+
function buttonTypeToIconSize(buttonType) {
|
|
16
|
+
switch (buttonType) {
|
|
17
|
+
case MultipartyButtonType.DesktopObsolete:
|
|
18
|
+
return large_rounded_icon_1.IconSizes.LargeObsolete;
|
|
19
|
+
case MultipartyButtonType.Mobile:
|
|
20
|
+
return large_rounded_icon_1.IconSizes.MobileLarge;
|
|
21
|
+
case MultipartyButtonType.MobileObsolete:
|
|
22
|
+
return large_rounded_icon_1.IconSizes.MobileLargeObsolete;
|
|
23
|
+
default:
|
|
24
|
+
return large_rounded_icon_1.IconSizes.Large;
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
var MultipartyButton = function (_a) {
|
|
28
|
+
var type = _a.type, iconName = _a.iconName, _b = _a.isSwitchedOn, isSwitchedOn = _b === void 0 ? true : _b, _c = _a.isBackgroundVisible, isBackgroundVisible = _c === void 0 ? true : _c, _d = _a.disabled, disabled = _d === void 0 ? false : _d, onClick = _a.onClick;
|
|
29
|
+
var IconButton = type === MultipartyButtonType.Mobile ? border_rounded_icon_1.BorderRoundedIconButton : square_rounded_icon_1.SquareRoundedIconButton;
|
|
30
|
+
var backgroundTransparency = isBackgroundVisible ? large_rounded_icon_1.BackgroundTransparencies.HALF : large_rounded_icon_1.BackgroundTransparencies.FULL;
|
|
31
|
+
var iconTransparency = isSwitchedOn || isBackgroundVisible ? large_rounded_icon_1.IconTransparencies.NONE : large_rounded_icon_1.IconTransparencies.HALF;
|
|
32
|
+
return (jsx_runtime_1.jsx(IconButton, { onClick: onClick, sizeName: buttonTypeToIconSize(type), colorName: large_rounded_icon_1.IconColors.Black, iconName: iconName, iconTransparency: iconTransparency, noBorder: true, reverseColor: true, disabled: disabled, backgroundTransparency: backgroundTransparency }, void 0));
|
|
33
|
+
};
|
|
34
|
+
exports.MultipartyButton = MultipartyButton;
|
|
35
|
+
//# sourceMappingURL=MultipartyButton.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MultipartyButton.js","sourceRoot":"","sources":["../../../../src/components/ButtonPanels/MultipartyButton/MultipartyButton.tsx"],"names":[],"mappings":";;;;AACA,wGAAyG;AACzG,wGAAyG;AACzG,8FAKiE;AAEjE,IAAY,oBAKX;AALD,WAAY,oBAAoB;IAC5B,yCAAiB,CAAA;IACjB,2CAAmB,CAAA;IACnB,4DAAoC,CAAA;IACpC,0DAAkC,CAAA;AACtC,CAAC,EALW,oBAAoB,GAApB,4BAAoB,KAApB,4BAAoB,QAK/B;AAED,SAAS,oBAAoB,CAAC,UAAgC;IAC1D,QAAQ,UAAU,EAAE;QAChB,KAAK,oBAAoB,CAAC,eAAe;YACrC,OAAO,8BAAS,CAAC,aAAa,CAAC;QACnC,KAAK,oBAAoB,CAAC,MAAM;YAC5B,OAAO,8BAAS,CAAC,WAAW,CAAC;QACjC,KAAK,oBAAoB,CAAC,cAAc;YACpC,OAAO,8BAAS,CAAC,mBAAmB,CAAC;QACzC;YACI,OAAO,8BAAS,CAAC,KAAK,CAAC;KAC9B;AACL,CAAC;AAWM,IAAM,gBAAgB,GAAoB,UAAC,EAOjD;QANG,IAAI,UAAA,EACJ,QAAQ,cAAA,EACR,oBAAmB,EAAnB,YAAY,mBAAG,IAAI,KAAA,EACnB,2BAA0B,EAA1B,mBAAmB,mBAAG,IAAI,KAAA,EAC1B,gBAAgB,EAAhB,QAAQ,mBAAG,KAAK,KAAA,EAChB,OAAO,aAAA;IAEP,IAAM,UAAU,GAAG,IAAI,KAAK,oBAAoB,CAAC,MAAM,CAAC,CAAC,CAAC,6CAAuB,CAAC,CAAC,CAAC,6CAAuB,CAAC;IAE5G,IAAM,sBAAsB,GAAG,mBAAmB,CAAC,CAAC,CAAC,6CAAwB,CAAC,IAAI,CAAC,CAAC,CAAC,6CAAwB,CAAC,IAAI,CAAC;IACnH,IAAM,gBAAgB,GAAG,YAAY,IAAI,mBAAmB,CAAC,CAAC,CAAC,uCAAkB,CAAC,IAAI,CAAC,CAAC,CAAC,uCAAkB,CAAC,IAAI,CAAC;IAEjH,OAAO,CACH,kBAAC,UAAU,IACP,OAAO,EAAE,OAAO,EAChB,QAAQ,EAAE,oBAAoB,CAAC,IAAI,CAAC,EACpC,SAAS,EAAE,+BAAU,CAAC,KAAK,EAC3B,QAAQ,EAAE,QAAQ,EAClB,gBAAgB,EAAE,gBAAgB,EAClC,QAAQ,QACR,YAAY,QACZ,QAAQ,EAAE,QAAQ,EAClB,sBAAsB,EAAE,sBAAsB,WAChD,CACL,CAAC;AACN,CAAC,CAAC;AA1BW,QAAA,gBAAgB,oBA0B3B"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
declare type PinCallback = (() => void) | false;
|
|
3
|
+
declare type Props = {
|
|
4
|
+
isPinned: boolean;
|
|
5
|
+
isVideoHover: boolean;
|
|
6
|
+
onTogglePin?: PinCallback;
|
|
7
|
+
};
|
|
8
|
+
export declare const PinButtonPanel: React.FC<Props>;
|
|
9
|
+
export {};
|
|
10
|
+
//# sourceMappingURL=PinButtonPanel.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PinButtonPanel.d.ts","sourceRoot":"","sources":["../../../../src/components/ButtonPanels/PinButtonPanel/PinButtonPanel.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAG1B,aAAK,WAAW,GAAG,CAAC,MAAM,IAAI,CAAC,GAAG,KAAK,CAAC;AACxC,aAAK,KAAK,GAAG;IACT,QAAQ,EAAE,OAAO,CAAC;IAClB,YAAY,EAAE,OAAO,CAAC;IACtB,WAAW,CAAC,EAAE,WAAW,CAAC;CAC7B,CAAC;AAEF,eAAO,MAAM,cAAc,EAAE,KAAK,CAAC,EAAE,CAAC,KAAK,CAY1C,CAAC"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __assign = (this && this.__assign) || function () {
|
|
3
|
+
__assign = Object.assign || function(t) {
|
|
4
|
+
for (var s, i = 1, n = arguments.length; i < n; i++) {
|
|
5
|
+
s = arguments[i];
|
|
6
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
|
|
7
|
+
t[p] = s[p];
|
|
8
|
+
}
|
|
9
|
+
return t;
|
|
10
|
+
};
|
|
11
|
+
return __assign.apply(this, arguments);
|
|
12
|
+
};
|
|
13
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
14
|
+
exports.PinButtonPanel = void 0;
|
|
15
|
+
var jsx_runtime_1 = require("react/jsx-runtime");
|
|
16
|
+
var MultipartyButton_1 = require("../MultipartyButton/MultipartyButton");
|
|
17
|
+
var PinButtonPanel = function (_a) {
|
|
18
|
+
var onTogglePin = _a.onTogglePin, isPinned = _a.isPinned, isVideoHover = _a.isVideoHover;
|
|
19
|
+
return (jsx_runtime_1.jsx("div", __assign({ className: 'pin-buttons-panel' }, { children: onTogglePin && (jsx_runtime_1.jsx(MultipartyButton_1.MultipartyButton, { type: MultipartyButton_1.MultipartyButtonType.Desktop, onClick: onTogglePin, iconName: 'pin', isSwitchedOn: isPinned, isBackgroundVisible: isVideoHover }, void 0)) }), void 0));
|
|
20
|
+
};
|
|
21
|
+
exports.PinButtonPanel = PinButtonPanel;
|
|
22
|
+
//# sourceMappingURL=PinButtonPanel.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PinButtonPanel.js","sourceRoot":"","sources":["../../../../src/components/ButtonPanels/PinButtonPanel/PinButtonPanel.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;AACA,yEAA4F;AASrF,IAAM,cAAc,GAAoB,UAAC,EAAqC;QAApC,WAAW,iBAAA,EAAE,QAAQ,cAAA,EAAE,YAAY,kBAAA;IAAmB,OAAA,CACnG,oCAAK,SAAS,EAAC,mBAAmB,gBAC7B,WAAW,IAAI,CACZ,kBAAC,mCAAgB,IACb,IAAI,EAAE,uCAAoB,CAAC,OAAO,EAClC,OAAO,EAAE,WAAW,EACpB,QAAQ,EAAC,KAAK,EACd,YAAY,EAAE,QAAQ,EACtB,mBAAmB,EAAE,YAAY,WACnC,CACL,YACC,CACT;AAZsG,CAYtG,CAAC;AAZW,QAAA,cAAc,kBAYzB"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import './SnapshotButtonPanel.scss';
|
|
3
|
+
declare type SnapshotCallback = () => void;
|
|
4
|
+
declare type Props = {
|
|
5
|
+
onSnapshot?: SnapshotCallback;
|
|
6
|
+
};
|
|
7
|
+
export declare const SnapshotButtonPanel: React.FC<Props>;
|
|
8
|
+
export {};
|
|
9
|
+
//# sourceMappingURL=SnapshotButtonPanel.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SnapshotButtonPanel.d.ts","sourceRoot":"","sources":["../../../../src/components/ButtonPanels/SnapshotButtonPanel/SnapshotButtonPanel.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,4BAA4B,CAAC;AAEpC,aAAK,gBAAgB,GAAG,MAAM,IAAI,CAAC;AACnC,aAAK,KAAK,GAAG;IACT,UAAU,CAAC,EAAE,gBAAgB,CAAC;CACjC,CAAC;AAEF,eAAO,MAAM,mBAAmB,EAAE,KAAK,CAAC,EAAE,CAAC,KAAK,CAE/C,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.SnapshotButtonPanel = void 0;
|
|
7
|
+
var jsx_runtime_1 = require("react/jsx-runtime");
|
|
8
|
+
var camera_button_png_1 = __importDefault(require("../../../assets/img/camera-button.png"));
|
|
9
|
+
require("./SnapshotButtonPanel.scss");
|
|
10
|
+
var SnapshotButtonPanel = function (_a) {
|
|
11
|
+
var onSnapshot = _a.onSnapshot;
|
|
12
|
+
return (jsx_runtime_1.jsx("img", { src: camera_button_png_1.default, onClick: onSnapshot, className: 'snapshot-button-panel-img' }, void 0));
|
|
13
|
+
};
|
|
14
|
+
exports.SnapshotButtonPanel = SnapshotButtonPanel;
|
|
15
|
+
//# sourceMappingURL=SnapshotButtonPanel.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SnapshotButtonPanel.js","sourceRoot":"","sources":["../../../../src/components/ButtonPanels/SnapshotButtonPanel/SnapshotButtonPanel.tsx"],"names":[],"mappings":";;;;;;;AACA,4FAA8D;AAC9D,sCAAoC;AAO7B,IAAM,mBAAmB,GAAoB,UAAC,EAAY;QAAX,UAAU,gBAAA;IAAmB,OAAA,CAC/E,2BAAK,GAAG,EAAE,2BAAS,EAAE,OAAO,EAAE,UAAU,EAAE,SAAS,EAAC,2BAA2B,WAAG,CACrF;AAFkF,CAElF,CAAC;AAFW,QAAA,mBAAmB,uBAE9B"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export { PinButtonPanel } from './PinButtonPanel/PinButtonPanel';
|
|
2
|
+
export { MediaButtonsPanel } from './MediaButtonsPanel/MediaButtonsPanel';
|
|
3
|
+
export { MultipartyButtonType } from './MultipartyButton/MultipartyButton';
|
|
4
|
+
export { SnapshotButtonPanel } from './SnapshotButtonPanel/SnapshotButtonPanel';
|
|
5
|
+
export { EndMeetingButtonPanel } from './EndMeetingButtonPanel/EndMeetingButtonPanel';
|
|
6
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/ButtonPanels/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,cAAc,EAAC,MAAM,iCAAiC,CAAC;AAC/D,OAAO,EAAC,iBAAiB,EAAC,MAAM,uCAAuC,CAAC;AACxE,OAAO,EAAC,oBAAoB,EAAC,MAAM,qCAAqC,CAAC;AACzE,OAAO,EAAC,mBAAmB,EAAC,MAAM,2CAA2C,CAAC;AAC9E,OAAO,EAAC,qBAAqB,EAAC,MAAM,+CAA+C,CAAC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.EndMeetingButtonPanel = exports.SnapshotButtonPanel = exports.MultipartyButtonType = exports.MediaButtonsPanel = exports.PinButtonPanel = void 0;
|
|
4
|
+
var PinButtonPanel_1 = require("./PinButtonPanel/PinButtonPanel");
|
|
5
|
+
Object.defineProperty(exports, "PinButtonPanel", { enumerable: true, get: function () { return PinButtonPanel_1.PinButtonPanel; } });
|
|
6
|
+
var MediaButtonsPanel_1 = require("./MediaButtonsPanel/MediaButtonsPanel");
|
|
7
|
+
Object.defineProperty(exports, "MediaButtonsPanel", { enumerable: true, get: function () { return MediaButtonsPanel_1.MediaButtonsPanel; } });
|
|
8
|
+
var MultipartyButton_1 = require("./MultipartyButton/MultipartyButton");
|
|
9
|
+
Object.defineProperty(exports, "MultipartyButtonType", { enumerable: true, get: function () { return MultipartyButton_1.MultipartyButtonType; } });
|
|
10
|
+
var SnapshotButtonPanel_1 = require("./SnapshotButtonPanel/SnapshotButtonPanel");
|
|
11
|
+
Object.defineProperty(exports, "SnapshotButtonPanel", { enumerable: true, get: function () { return SnapshotButtonPanel_1.SnapshotButtonPanel; } });
|
|
12
|
+
var EndMeetingButtonPanel_1 = require("./EndMeetingButtonPanel/EndMeetingButtonPanel");
|
|
13
|
+
Object.defineProperty(exports, "EndMeetingButtonPanel", { enumerable: true, get: function () { return EndMeetingButtonPanel_1.EndMeetingButtonPanel; } });
|
|
14
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/ButtonPanels/index.ts"],"names":[],"mappings":";;;AAAA,kEAA+D;AAAvD,gHAAA,cAAc,OAAA;AACtB,2EAAwE;AAAhE,sHAAA,iBAAiB,OAAA;AACzB,wEAAyE;AAAjE,wHAAA,oBAAoB,OAAA;AAC5B,iFAA8E;AAAtE,0HAAA,mBAAmB,OAAA;AAC3B,uFAAoF;AAA5E,8HAAA,qBAAqB,OAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"LoaderSpinner.d.ts","sourceRoot":"","sources":["../../../src/components/LoaderSpinner/LoaderSpinner.tsx"],"names":[],"mappings":";AAAA,OAAO,sBAAsB,CAAC;AAE9B,aAAK,kBAAkB,GAAG;IACtB,OAAO,EAAE,MAAM,CAAC;CACnB,CAAC;AAEF,eAAO,MAAM,aAAa,EAAE,KAAK,CAAC,EAAE,CAAC,kBAAkB,CAiEtD,CAAC"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __assign = (this && this.__assign) || function () {
|
|
3
|
+
__assign = Object.assign || function(t) {
|
|
4
|
+
for (var s, i = 1, n = arguments.length; i < n; i++) {
|
|
5
|
+
s = arguments[i];
|
|
6
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
|
|
7
|
+
t[p] = s[p];
|
|
8
|
+
}
|
|
9
|
+
return t;
|
|
10
|
+
};
|
|
11
|
+
return __assign.apply(this, arguments);
|
|
12
|
+
};
|
|
13
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
14
|
+
exports.LoaderSpinner = void 0;
|
|
15
|
+
var jsx_runtime_1 = require("react/jsx-runtime");
|
|
16
|
+
require("./LoaderSpinner.scss");
|
|
17
|
+
var LoaderSpinner = function (_a) {
|
|
18
|
+
var caption = _a.caption;
|
|
19
|
+
return (jsx_runtime_1.jsxs("div", __assign({ className: 'loader-spinner-container' }, { children: [jsx_runtime_1.jsxs("svg", __assign({ className: 'spinner', width: '118', height: '118', viewBox: '0 0 118 118', fill: 'none', xmlns: 'http://www.w3.org/2000/svg' }, { children: [jsx_runtime_1.jsx("circle", { cx: '59', cy: '59', r: '59', fill: 'white', fillOpacity: '0.1' }, void 0), jsx_runtime_1.jsxs("g", __assign({ clipPath: 'url(#clip0)' }, { children: [jsx_runtime_1.jsx("path", { className: 'circle circle-1', d: 'M59.5 41C63.6421 41 67 37.6421 67 33.5C67 29.3579 63.6421 26 59.5 26C55.3579 26 52 29.3579 52 33.5C52 37.6421 55.3579 41 59.5 41Z', fill: 'white' }, void 0), jsx_runtime_1.jsx("path", { className: 'circle circle-2', d: 'M72.1901 45.5985C75.3572 48.256 80.0754 47.8472 82.7285 44.6854C85.3815 41.5236 84.9648 36.8061 81.7977 34.1486C78.6306 31.4911 73.9124 31.8999 71.2593 35.0617C68.6063 38.2235 69.023 42.941 72.1901 45.5985Z', fill: 'white' }, void 0), jsx_runtime_1.jsx("path", { className: 'circle circle-3', d: 'M79.0856 57.4596C79.7997 61.5093 83.6914 64.2081 87.7779 63.4875C91.8644 62.7669 94.5983 58.8999 93.8843 54.8502C93.1702 50.8005 89.2785 48.1017 85.192 48.8223C81.1055 49.5428 78.3716 53.4099 79.0856 57.4596Z', fill: 'white' }, void 0), jsx_runtime_1.jsx("path", { className: 'circle circle-4', d: 'M76.6956 70.9205C74.6351 74.4894 75.8718 79.0609 79.4579 81.1313C83.044 83.2017 87.6214 81.987 89.6819 78.4182C91.7424 74.8493 90.5056 70.2778 86.9196 68.2074C83.3335 66.137 78.756 67.3517 76.6956 70.9205Z', fill: 'white' }, void 0), jsx_runtime_1.jsx("path", { className: 'circle circle-5', d: 'M66.0989 79.7512C62.2028 81.1693 60.1855 85.454 61.5931 89.3214C63.0007 93.1889 67.3003 95.1745 71.1963 93.7564C75.0924 92.3384 77.1097 88.0536 75.7021 84.1862C74.2945 80.3188 69.9949 78.3331 66.0989 79.7512Z', fill: 'white' }, void 0), jsx_runtime_1.jsx("path", { className: 'circle circle-6', d: 'M52.2142 79.7512C48.3181 78.3331 44.0186 80.3188 42.611 84.1862C41.2034 88.0536 43.2207 92.3384 47.1167 93.7564C51.0128 95.1745 55.3123 93.1889 56.72 89.3214C58.1276 85.454 56.1103 81.1693 52.2142 79.7512Z', fill: 'white' }, void 0), jsx_runtime_1.jsx("path", { className: 'circle circle-7', d: 'M41.6175 70.9205C39.557 67.3517 34.9796 66.137 31.3935 68.2074C27.8074 70.2778 26.5707 74.8493 28.6312 78.4182C30.6916 81.987 35.2691 83.2017 38.8552 81.1313C42.4412 79.0609 43.678 74.4894 41.6175 70.9205Z', fill: 'white' }, void 0), jsx_runtime_1.jsx("path", { className: 'circle circle-8', d: 'M39.2274 57.4596C39.9415 53.4099 37.2076 49.5428 33.1211 48.8223C29.0345 48.1017 25.1429 50.8005 24.4288 54.8502C23.7147 58.8999 26.4487 62.7669 30.5352 63.4875C34.6217 64.2081 38.5134 61.5093 39.2274 57.4596Z', fill: 'white' }, void 0), jsx_runtime_1.jsx("path", { className: 'circle circle-9', d: 'M46.123 45.5985C49.2901 42.941 49.7068 38.2235 47.0537 35.0617C44.4007 31.8999 39.6825 31.4911 36.5154 34.1486C33.3483 36.8061 32.9316 41.5236 35.5846 44.6854C38.2377 47.8472 42.9559 48.256 46.123 45.5985Z', fill: 'white' }, void 0)] }), void 0), jsx_runtime_1.jsx("defs", { children: jsx_runtime_1.jsx("clipPath", __assign({ id: 'clip0' }, { children: jsx_runtime_1.jsx("rect", { width: '70', height: '69', fill: 'white', transform: 'translate(24 26)' }, void 0) }), void 0) }, void 0)] }), void 0), jsx_runtime_1.jsx("div", __assign({ className: 'loader-spinner-caption' }, { children: caption }), void 0)] }), void 0));
|
|
20
|
+
};
|
|
21
|
+
exports.LoaderSpinner = LoaderSpinner;
|
|
22
|
+
//# sourceMappingURL=LoaderSpinner.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"LoaderSpinner.js","sourceRoot":"","sources":["../../../src/components/LoaderSpinner/LoaderSpinner.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,gCAA8B;AAMvB,IAAM,aAAa,GAAiC,UAAC,EAAS;QAAR,OAAO,aAAA;IAAM,OAAA,CACtE,qCAAK,SAAS,EAAC,0BAA0B,iBACrC,qCACI,SAAS,EAAC,SAAS,EACnB,KAAK,EAAC,KAAK,EACX,MAAM,EAAC,KAAK,EACZ,OAAO,EAAC,aAAa,EACrB,IAAI,EAAC,MAAM,EACX,KAAK,EAAC,4BAA4B,iBAClC,8BAAQ,EAAE,EAAC,IAAI,EAAC,EAAE,EAAC,IAAI,EAAC,CAAC,EAAC,IAAI,EAAC,IAAI,EAAC,OAAO,EAAC,WAAW,EAAC,KAAK,WAAG,EAChE,mCAAG,QAAQ,EAAC,aAAa,iBACrB,4BACI,SAAS,EAAC,iBAAiB,EAC3B,CAAC,EAAC,mIAAmI,EACrI,IAAI,EAAC,OAAO,WACd,EACF,4BACI,SAAS,EAAC,iBAAiB,EAC3B,CAAC,EAAC,gNAAgN,EAClN,IAAI,EAAC,OAAO,WACd,EACF,4BACI,SAAS,EAAC,iBAAiB,EAC3B,CAAC,EAAC,kNAAkN,EACpN,IAAI,EAAC,OAAO,WACd,EACF,4BACI,SAAS,EAAC,iBAAiB,EAC3B,CAAC,EAAC,+MAA+M,EACjN,IAAI,EAAC,OAAO,WACd,EACF,4BACI,SAAS,EAAC,iBAAiB,EAC3B,CAAC,EAAC,kNAAkN,EACpN,IAAI,EAAC,OAAO,WACd,EACF,4BACI,SAAS,EAAC,iBAAiB,EAC3B,CAAC,EAAC,+MAA+M,EACjN,IAAI,EAAC,OAAO,WACd,EACF,4BACI,SAAS,EAAC,iBAAiB,EAC3B,CAAC,EAAC,+MAA+M,EACjN,IAAI,EAAC,OAAO,WACd,EACF,4BACI,SAAS,EAAC,iBAAiB,EAC3B,CAAC,EAAC,mNAAmN,EACrN,IAAI,EAAC,OAAO,WACd,EACF,4BACI,SAAS,EAAC,iBAAiB,EAC3B,CAAC,EAAC,+MAA+M,EACjN,IAAI,EAAC,OAAO,WACd,aACF,EACJ,sCACI,yCAAU,EAAE,EAAC,OAAO,gBAChB,4BAAM,KAAK,EAAC,IAAI,EAAC,MAAM,EAAC,IAAI,EAAC,IAAI,EAAC,OAAO,EAAC,SAAS,EAAC,kBAAkB,WAAG,YAClE,WACR,aACL,EACN,oCAAK,SAAS,EAAC,wBAAwB,gBAAE,OAAO,YAAO,aACrD,CACT;AAjEyE,CAiEzE,CAAC;AAjEW,QAAA,aAAa,iBAiExB"}
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
.loader-spinner-container {
|
|
2
|
+
position: absolute;
|
|
3
|
+
z-index: 2;
|
|
4
|
+
background: #3a3a3a;
|
|
5
|
+
width: 100%;
|
|
6
|
+
height: 100%;
|
|
7
|
+
border-radius: inherit;
|
|
8
|
+
|
|
9
|
+
display: flex;
|
|
10
|
+
flex-direction: column;
|
|
11
|
+
align-items: center;
|
|
12
|
+
justify-content: center;
|
|
13
|
+
|
|
14
|
+
.loader-spinner-caption {
|
|
15
|
+
font-family: 'Open Sans';
|
|
16
|
+
font-size: 14px;
|
|
17
|
+
color: white;
|
|
18
|
+
|
|
19
|
+
text-align: center;
|
|
20
|
+
padding-top: 20px;
|
|
21
|
+
margin: 0px 15px;
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
.circle {
|
|
25
|
+
animation: loading-spinner 1.8s infinite;
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
.circle-2 {
|
|
29
|
+
animation-delay: 0.2s;
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
.circle-3 {
|
|
33
|
+
animation-delay: 0.4s;
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
.circle-4 {
|
|
37
|
+
animation-delay: 0.6s;
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
.circle-5 {
|
|
41
|
+
animation-delay: 0.8s;
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
.circle-6 {
|
|
45
|
+
animation-delay: 1s;
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
.circle-7 {
|
|
49
|
+
animation-delay: 1.2s;
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
.circle-8 {
|
|
53
|
+
animation-delay: 1.4s;
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
.circle-9 {
|
|
57
|
+
animation-delay: 1.6s;
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
@keyframes loading-spinner {
|
|
61
|
+
0%,
|
|
62
|
+
100% {
|
|
63
|
+
opacity: 100%;
|
|
64
|
+
}
|
|
65
|
+
50% {
|
|
66
|
+
opacity: 0%;
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
.magic-marker {
|
|
2
|
+
position: relative;
|
|
3
|
+
width: 100%;
|
|
4
|
+
height: 100%;
|
|
5
|
+
|
|
6
|
+
> canvas {
|
|
7
|
+
position: absolute;
|
|
8
|
+
top: 0;
|
|
9
|
+
left: 0;
|
|
10
|
+
|
|
11
|
+
width: 100%;
|
|
12
|
+
height: 100%;
|
|
13
|
+
object-fit: contain;
|
|
14
|
+
|
|
15
|
+
touch-action: none;
|
|
16
|
+
overscroll-behavior: contain;
|
|
17
|
+
}
|
|
18
|
+
}
|