fcr-ui-scene 3.4.2 → 3.4.4

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.
Files changed (215) hide show
  1. package/lib/common/device-store.d.ts +23 -14
  2. package/lib/common/device-store.js +361 -252
  3. package/lib/common/device-stream-store.d.ts +8 -14
  4. package/lib/common/device-stream-store.js +254 -116
  5. package/lib/common/event-store.d.ts +35 -10
  6. package/lib/common/event-store.js +64 -13
  7. package/lib/common/security-store.d.ts +47 -39
  8. package/lib/common/security-store.js +335 -379
  9. package/lib/electron/app.js +1 -0
  10. package/lib/modules/action-bar/action-bar-collapes-items.d.ts +4 -1
  11. package/lib/modules/action-bar/action-bar-collapes-items.js +38 -21
  12. package/lib/modules/action-bar/components/apps/useWidgetList.d.ts +7 -0
  13. package/lib/modules/action-bar/components/apps/useWidgetList.js +43 -0
  14. package/lib/modules/action-bar/components/leave/assign-host.d.ts +8 -1
  15. package/lib/modules/action-bar/components/leave/assign-host.js +1 -1
  16. package/lib/modules/action-bar/components/leave/leave-meeting.d.ts +16 -1
  17. package/lib/modules/action-bar/smaller.js +5 -5
  18. package/lib/modules/chat/chat-bar/index.css +6 -0
  19. package/lib/modules/chat/chat-bar/index.d.ts +3 -3
  20. package/lib/modules/chat/chat-bar/index.js +51 -39
  21. package/lib/modules/chat/chat-select/index.css +27 -7
  22. package/lib/modules/chat/chat-select/index.d.ts +1 -1
  23. package/lib/modules/chat/chat-select/index.js +18 -4
  24. package/lib/modules/chat/chat.d.ts +1 -2
  25. package/lib/modules/chat/chat.js +196 -128
  26. package/lib/modules/chat/components/chat-select/select-input/index.d.ts +7 -0
  27. package/lib/modules/chat/components/chat-select/select-input/index.js +35 -0
  28. package/lib/modules/chat/components/chat-select/select-item/index.d.ts +12 -0
  29. package/lib/modules/chat/components/chat-select/select-item/index.js +153 -0
  30. package/lib/modules/chat/components/chat-tabs/index.d.ts +2 -0
  31. package/lib/modules/chat/components/chat-tabs/index.js +61 -0
  32. package/lib/modules/chat/components/message-list/chat-empty/index.d.ts +2 -0
  33. package/lib/modules/chat/components/message-list/chat-empty/index.js +26 -0
  34. package/lib/modules/chat/components/message-list/history-unread-message-button/index.d.ts +7 -0
  35. package/lib/modules/chat/components/message-list/history-unread-message-button/index.js +55 -0
  36. package/lib/modules/chat/components/message-list/message-item/index.d.ts +15 -0
  37. package/lib/modules/chat/components/message-list/message-item/index.js +279 -0
  38. package/lib/modules/chat/components/message-list/scroll-bottom-button/index.d.ts +9 -0
  39. package/lib/modules/chat/components/message-list/scroll-bottom-button/index.js +67 -0
  40. package/lib/modules/chat/message-list.js +68 -51
  41. package/lib/modules/components/dialog-container/component/body.js +1 -2
  42. package/lib/modules/components/dialog-container/index.d.ts +2 -2
  43. package/lib/modules/components/member-window/components/member-actions/components/audio-control.d.ts +6 -0
  44. package/lib/modules/components/member-window/components/member-actions/components/audio-control.js +36 -0
  45. package/lib/modules/components/member-window/components/member-actions/components/icon-buttons/index.d.ts +40 -0
  46. package/lib/modules/components/member-window/components/member-actions/components/icon-buttons/index.js +170 -0
  47. package/lib/modules/components/member-window/components/member-actions/components/icon-status.d.ts +11 -0
  48. package/lib/modules/components/member-window/components/member-actions/components/icon-status.js +105 -0
  49. package/lib/modules/components/member-window/components/member-actions/components/layout/index.d.ts +9 -0
  50. package/lib/modules/components/member-window/components/member-actions/components/layout/index.js +42 -0
  51. package/lib/modules/components/member-window/components/member-actions/components/more-actions.d.ts +11 -0
  52. package/lib/modules/components/member-window/components/member-actions/components/more-actions.js +159 -0
  53. package/lib/modules/components/member-window/components/member-actions/components/share-status.d.ts +2 -0
  54. package/lib/modules/components/member-window/components/member-actions/components/share-status.js +32 -0
  55. package/lib/modules/components/member-window/components/member-actions/components/user-info.d.ts +16 -0
  56. package/lib/modules/components/member-window/components/member-actions/components/user-info.js +130 -0
  57. package/lib/modules/components/member-window/components/member-actions/components/user-tag.d.ts +12 -0
  58. package/lib/modules/components/member-window/components/member-actions/components/user-tag.js +57 -0
  59. package/lib/modules/components/member-window/components/member-actions/index.d.ts +3 -0
  60. package/lib/modules/components/member-window/components/member-actions/index.js +122 -0
  61. package/lib/modules/components/member-window/components/member-actions/libs/index.d.ts +2 -0
  62. package/lib/modules/components/member-window/components/member-actions/libs/index.js +24 -0
  63. package/lib/modules/components/member-window/components/member-actions/provider.d.ts +21 -0
  64. package/lib/modules/components/member-window/components/member-actions/provider.js +77 -0
  65. package/lib/modules/components/member-window/components/member-actions/store.d.ts +48 -0
  66. package/lib/modules/components/member-window/components/member-actions/store.js +306 -0
  67. package/lib/modules/components/member-window/components/member-board.d.ts +2 -0
  68. package/lib/modules/components/member-window/components/member-board.js +63 -0
  69. package/lib/modules/components/member-window/components/mic-volume.d.ts +2 -0
  70. package/lib/modules/components/member-window/components/mic-volume.js +23 -0
  71. package/lib/modules/components/member-window/components/video-player/components/local-video-player.d.ts +4 -0
  72. package/lib/modules/components/member-window/components/video-player/components/local-video-player.js +40 -0
  73. package/lib/modules/components/member-window/components/video-player/components/remote-video-player.d.ts +8 -0
  74. package/lib/modules/components/member-window/components/video-player/components/remote-video-player.js +62 -0
  75. package/lib/modules/components/member-window/components/video-player/index.d.ts +9 -0
  76. package/lib/modules/components/member-window/components/video-player/index.js +38 -0
  77. package/lib/modules/components/member-window/types.d.ts +78 -0
  78. package/lib/modules/components/member-window/types.js +6 -0
  79. package/lib/modules/connection-gateway/components/tabs/index.js +2 -1
  80. package/lib/modules/control-bar/components/meeting-details/index.js +7 -15
  81. package/lib/modules/control-bar/components/more-actions/index.js +5 -15
  82. package/lib/modules/dialog/components/system-preference/assets/bg1.png +0 -0
  83. package/lib/modules/dialog/components/system-preference/assets/bg2.png +0 -0
  84. package/lib/modules/dialog/components/system-preference/assets/fcr_png_host.png +0 -0
  85. package/lib/modules/dialog/components/widget/electron.d.ts +5 -0
  86. package/lib/modules/dialog/components/widget/electron.js +41 -0
  87. package/lib/modules/dialog/components/widget/index.d.ts +6 -0
  88. package/lib/modules/dialog/components/widget/index.js +41 -0
  89. package/lib/modules/dialog/type.d.ts +84 -0
  90. package/lib/modules/dialog/type.js +6 -0
  91. package/lib/modules/invite/components/pstn-invite.js +4 -13
  92. package/lib/modules/invite/pstn-invite.js +7 -9
  93. package/lib/modules/invite/store.d.ts +2 -0
  94. package/lib/modules/invite/store.js +6 -0
  95. package/lib/modules/invite/voip-invite.js +5 -6
  96. package/lib/modules/layout/member-window/index.css +116 -18
  97. package/lib/modules/layout/member-window/index.d.ts +10 -3
  98. package/lib/modules/layout/member-window/index.js +227 -115
  99. package/lib/modules/participant/attendee/index.css +0 -51
  100. package/lib/modules/participant/attendee/index.d.ts +8 -5
  101. package/lib/modules/participant/attendee/index.js +61 -15
  102. package/lib/modules/participant/components/attendee/components/interpreter-tag/index.d.ts +3 -0
  103. package/lib/modules/participant/components/attendee/components/interpreter-tag/index.js +48 -0
  104. package/lib/modules/participant/components/confirm-input/index.d.ts +6 -0
  105. package/lib/modules/participant/components/confirm-input/index.js +49 -0
  106. package/lib/modules/participant/components/drop-menu/util.d.ts +5 -0
  107. package/lib/modules/participant/components/drop-menu/util.js +28 -0
  108. package/lib/modules/participant/components/participants/components/footer/components/buttons.d.ts +6 -0
  109. package/lib/modules/participant/components/participants/components/footer/components/buttons.js +52 -0
  110. package/lib/modules/participant/components/participants/components/footer/components/drop-menu/index.css +60 -0
  111. package/lib/modules/participant/components/participants/components/footer/components/drop-menu/index.d.ts +2 -0
  112. package/lib/modules/participant/components/participants/components/footer/components/drop-menu/index.js +166 -0
  113. package/lib/modules/participant/components/participants/components/footer/components/drop-menu/util.d.ts +5 -0
  114. package/lib/modules/participant/components/participants/components/footer/components/drop-menu/util.js +28 -0
  115. package/lib/modules/participant/components/participants/components/footer/components/footer/index.css +13 -0
  116. package/lib/modules/participant/components/participants/components/footer/components/footer/index.d.ts +5 -0
  117. package/lib/modules/participant/components/participants/components/footer/components/footer/index.js +242 -0
  118. package/lib/modules/participant/components/participants/components/footer/index.d.ts +5 -0
  119. package/lib/modules/participant/components/participants/components/footer/index.js +47 -0
  120. package/lib/modules/participant/components/participants/components/merge/index.d.ts +11 -0
  121. package/lib/modules/participant/components/participants/components/merge/index.js +49 -0
  122. package/lib/modules/participant/components/participants/components/participants/components/attendee/index.css +191 -0
  123. package/lib/modules/participant/components/participants/components/participants/components/attendee/index.d.ts +4 -0
  124. package/lib/modules/participant/components/participants/components/participants/components/attendee/index.js +204 -0
  125. package/lib/modules/participant/components/participants/components/participants/components/participants-more/index.css +49 -0
  126. package/lib/modules/participant/components/participants/components/participants/components/participants-more/index.d.ts +5 -0
  127. package/lib/modules/participant/components/participants/components/participants/components/participants-more/index.js +219 -0
  128. package/lib/modules/participant/components/participants/components/participants/components/user-row/index.d.ts +5 -0
  129. package/lib/modules/participant/components/participants/components/participants/components/user-row/index.js +70 -0
  130. package/lib/modules/participant/components/participants/components/participants/index.css +104 -0
  131. package/lib/modules/participant/components/participants/components/participants/index.d.ts +3 -0
  132. package/lib/modules/participant/components/participants/components/participants/index.js +110 -0
  133. package/lib/modules/participant/components/participants/components/render-tab/index.d.ts +2 -0
  134. package/lib/modules/participant/components/participants/components/render-tab/index.js +49 -0
  135. package/lib/modules/participant/components/participants/components/render-user/components/attendee/components/interpreter-tag/index.d.ts +3 -0
  136. package/lib/modules/participant/components/participants/components/render-user/components/attendee/components/interpreter-tag/index.js +48 -0
  137. package/lib/modules/participant/components/participants/components/render-user/components/attendee/components/microphone-indicator/index.d.ts +6 -0
  138. package/lib/modules/participant/components/participants/components/render-user/components/attendee/components/microphone-indicator/index.js +28 -0
  139. package/lib/modules/participant/components/participants/components/render-user/components/attendee/components/user-avatar/index.d.ts +7 -0
  140. package/lib/modules/participant/components/participants/components/render-user/components/attendee/components/user-avatar/index.js +39 -0
  141. package/lib/modules/participant/components/participants/components/render-user/components/attendee/index.css +69 -0
  142. package/lib/modules/participant/components/participants/components/render-user/components/attendee/index.d.ts +5 -0
  143. package/lib/modules/participant/components/participants/components/render-user/components/attendee/index.js +135 -0
  144. package/lib/modules/participant/components/participants/components/render-user/components/user-action/components/audio-button/index.d.ts +7 -0
  145. package/lib/modules/participant/components/participants/components/render-user/components/user-action/components/audio-button/index.js +31 -0
  146. package/lib/modules/participant/components/participants/components/render-user/components/user-action/components/move-actions-popover/index.d.ts +12 -0
  147. package/lib/modules/participant/components/participants/components/render-user/components/user-action/components/move-actions-popover/index.js +82 -0
  148. package/lib/modules/participant/components/participants/components/render-user/components/user-action/components/move-to-mainroom-button/index.d.ts +4 -0
  149. package/lib/modules/participant/components/participants/components/render-user/components/user-action/components/move-to-mainroom-button/index.js +26 -0
  150. package/lib/modules/participant/components/participants/components/render-user/components/user-action/index.d.ts +2 -0
  151. package/lib/modules/participant/components/participants/components/render-user/components/user-action/index.js +75 -0
  152. package/lib/modules/participant/components/participants/components/render-user/index.d.ts +5 -0
  153. package/lib/modules/participant/components/participants/components/render-user/index.js +21 -0
  154. package/lib/modules/participant/components/participants/render-tab/index.d.ts +2 -0
  155. package/lib/modules/participant/components/participants/render-tab/index.js +49 -0
  156. package/lib/modules/participant/components/participants/render-user/index.d.ts +5 -0
  157. package/lib/modules/participant/components/participants/render-user/index.js +21 -0
  158. package/lib/modules/participant/components/participants/types.d.ts +96 -0
  159. package/lib/modules/participant/components/participants/types.js +37 -0
  160. package/lib/modules/participant/components/user-action/audio-button/index.d.ts +7 -0
  161. package/lib/modules/participant/components/user-action/audio-button/index.js +31 -0
  162. package/lib/modules/participant/components/user-action/move-actions-popover/index.d.ts +12 -0
  163. package/lib/modules/participant/components/user-action/move-actions-popover/index.js +82 -0
  164. package/lib/modules/participant/components/user-action/move-to-mainroom-button/index.d.ts +4 -0
  165. package/lib/modules/participant/components/user-action/move-to-mainroom-button/index.js +26 -0
  166. package/lib/modules/share-screen/selection/index.css +4 -0
  167. package/lib/modules/share-screen/selection/index.js +126 -129
  168. package/lib/modules/share-screen/share-state-bar/index.js +1 -1
  169. package/lib/modules/state-bar/meeting-details.js +29 -34
  170. package/lib/modules/video-window/components/deviceState/index.d.ts +7 -0
  171. package/lib/modules/video-window/components/deviceState/index.js +75 -0
  172. package/lib/modules/video-window/components/members/index.css +51 -0
  173. package/lib/modules/video-window/components/members/index.d.ts +2 -0
  174. package/lib/modules/video-window/components/members/index.js +130 -0
  175. package/lib/modules/video-window/components/speaking/index.css +86 -0
  176. package/lib/modules/video-window/components/speaking/index.d.ts +3 -0
  177. package/lib/modules/video-window/components/speaking/index.js +48 -0
  178. package/lib/modules/video-window/components/topControl/index.css +35 -0
  179. package/lib/modules/video-window/components/topControl/index.d.ts +3 -0
  180. package/lib/modules/video-window/components/topControl/index.js +79 -0
  181. package/lib/modules/widget/index.css +17 -0
  182. package/lib/modules/widget/index.d.ts +10 -0
  183. package/lib/modules/widget/index.js +114 -0
  184. package/lib/modules/widget/sdk.d.ts +30 -0
  185. package/lib/modules/widget/sdk.js +221 -0
  186. package/lib/modules/widget/store.d.ts +14 -0
  187. package/lib/modules/widget/store.js +28 -0
  188. package/lib/modules/widget/type.d.ts +155 -0
  189. package/lib/modules/widget/type.js +6 -0
  190. package/lib/modules/widget/view.d.ts +2 -0
  191. package/lib/modules/widget/view.js +47 -0
  192. package/lib/modules/widget/web-widget.d.ts +29 -0
  193. package/lib/modules/widget/web-widget.js +234 -0
  194. package/lib/providers/ability-provider.d.ts +24 -0
  195. package/lib/providers/ability-provider.js +36 -0
  196. package/lib/providers/widget-provider.d.ts +44 -0
  197. package/lib/providers/widget-provider.js +167 -0
  198. package/lib/schema.d.ts +114 -0
  199. package/lib/schema.js +77 -0
  200. package/lib/shared-data-source/member-data.d.ts +126 -0
  201. package/lib/shared-data-source/member-data.js +465 -0
  202. package/lib/translations/enUS.d.ts +5 -0
  203. package/lib/translations/enUS.js +9 -3
  204. package/lib/translations/zhCN.d.ts +5 -0
  205. package/lib/translations/zhCN.js +13 -7
  206. package/lib/utilities/extract.d.ts +1 -1
  207. package/lib/utilities/logger.d.ts +8 -0
  208. package/lib/utilities/logger.js +42 -0
  209. package/lib/utilities/meeting-detail.d.ts +2 -0
  210. package/lib/utilities/meeting-detail.js +56 -0
  211. package/lib/utilities/validate-params.d.ts +2 -0
  212. package/lib/utilities/validate-params.js +16 -0
  213. package/lib/widget-sdk.d.ts +2 -0
  214. package/lib/widget-sdk.js +13 -0
  215. package/package.json +5 -5
@@ -0,0 +1,204 @@
1
+ "use strict";
2
+
3
+ require("core-js/modules/es.symbol.js");
4
+ require("core-js/modules/es.array.filter.js");
5
+ require("core-js/modules/es.array.for-each.js");
6
+ require("core-js/modules/es.array.push.js");
7
+ require("core-js/modules/es.object.define-properties.js");
8
+ require("core-js/modules/es.object.define-property.js");
9
+ require("core-js/modules/es.object.get-own-property-descriptor.js");
10
+ require("core-js/modules/es.object.get-own-property-descriptors.js");
11
+ require("core-js/modules/es.object.keys.js");
12
+ require("core-js/modules/es.object.to-string.js");
13
+ require("core-js/modules/esnext.async-iterator.filter.js");
14
+ require("core-js/modules/esnext.async-iterator.for-each.js");
15
+ require("core-js/modules/esnext.iterator.constructor.js");
16
+ require("core-js/modules/esnext.iterator.filter.js");
17
+ require("core-js/modules/esnext.iterator.for-each.js");
18
+ require("core-js/modules/web.dom-collections.for-each.js");
19
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
20
+ Object.defineProperty(exports, "__esModule", {
21
+ value: true
22
+ });
23
+ exports.FcrParticipant = void 0;
24
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
25
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
26
+ var _react = require("react");
27
+ var _participantsMore = require("../participants-more");
28
+ require("./index.css");
29
+ var _classnames = _interopRequireDefault(require("classnames"));
30
+ var _action = require("agora-ui-foundation/lib/components/button/action");
31
+ var _i18n = require("agora-ui-foundation/lib/i18n");
32
+ var _popover = require("agora-ui-foundation/lib/components/popover");
33
+ var _type = require("agora-ui-foundation/lib/components/icon/type");
34
+ var _icon = require("agora-ui-foundation/lib/components/icon");
35
+ var _avatar = require("agora-ui-foundation/lib/components/avatar");
36
+ var _microphoneState = require("agora-ui-foundation/lib/components/room-screen-share-state-bar/microphone-state");
37
+ var _cameraState = require("agora-ui-foundation/lib/components/room-screen-share-state-bar/camera-state");
38
+ var _types = require("../../../../types");
39
+ var _jsxRuntime = require("react/jsx-runtime");
40
+ function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
41
+ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
42
+ var FcrParticipant = exports.FcrParticipant = function FcrParticipant(props) {
43
+ var user = props.user,
44
+ hasPinnedStream = props.hasPinnedStream,
45
+ _props$onParticipants = props.onParticipantsButtonClick,
46
+ onParticipantsButtonClick = _props$onParticipants === void 0 ? function () {} : _props$onParticipants,
47
+ _props$hideActions = props.hideActions,
48
+ hideActions = _props$hideActions === void 0 ? [] : _props$hideActions;
49
+ var userId = user.userId,
50
+ _user$userName = user.userName,
51
+ userName = _user$userName === void 0 ? '' : _user$userName,
52
+ hasAudio = user.hasAudio,
53
+ hasVideo = user.hasVideo,
54
+ isHost = user.isHost,
55
+ _user$isMe = user.isMe,
56
+ isMe = _user$isMe === void 0 ? false : _user$isMe,
57
+ _user$isScreenSharing = user.isScreenSharing,
58
+ isScreenSharing = _user$isScreenSharing === void 0 ? false : _user$isScreenSharing,
59
+ userType = user.userType,
60
+ videoDeviceType = user.videoDeviceType,
61
+ audioDeviceType = user.audioDeviceType;
62
+ var t = (0, _i18n.useI18n)();
63
+ var _useState = (0, _react.useState)(false),
64
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
65
+ isShowDropMenu = _useState2[0],
66
+ setIsShowDropMenu = _useState2[1];
67
+ var _useState3 = (0, _react.useState)(false),
68
+ _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
69
+ disableHover = _useState4[0],
70
+ setDisableHover = _useState4[1];
71
+ (0, _react.useEffect)(function () {
72
+ setDisableHover(userType !== 'normal');
73
+ }, [userType]);
74
+ var userActions = function userActions() {
75
+ return /*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
76
+ className: "attendee__user-action attendee__user-action-host ".concat(isShowDropMenu ? 'attendee__user-action-hovered' : ''),
77
+ children: [isMe && isHost ? /*#__PURE__*/(0, _jsxRuntime.jsx)(_action.FcrActionButton, {
78
+ size: "small",
79
+ onClick: function onClick() {
80
+ onParticipantsButtonClick(hasAudio ? _types.ParticipantActionType.MUTE_AUDIO : _types.ParticipantActionType.UNMUTE_AUDIO, userId);
81
+ },
82
+ children: /*#__PURE__*/(0, _jsxRuntime.jsx)("span", {
83
+ className: hasAudio ? 'attendee__danger-operate' : 'attendee__normal-operate',
84
+ children: hasAudio ? t('fmt_device_label_audio_mute') : isMe ? t('fmt_device_label_audio_unmute') : t('fmt_sip_button_unmute')
85
+ })
86
+ }) : /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
87
+ children: isMe ? /*#__PURE__*/(0, _jsxRuntime.jsx)(_action.FcrActionButton, {
88
+ size: "small",
89
+ onClick: function onClick() {
90
+ return onParticipantsButtonClick(hasAudio ? _types.ParticipantActionType.MUTE_AUDIO : _types.ParticipantActionType.UNMUTE_AUDIO, userId);
91
+ },
92
+ children: hasAudio ? t('fmt_device_label_audio_mute') : t('fmt_device_label_audio_unmute')
93
+ }) : /*#__PURE__*/(0, _jsxRuntime.jsx)(_action.FcrActionButton, {
94
+ size: "small",
95
+ onClick: function onClick() {
96
+ return onParticipantsButtonClick(_types.ParticipantActionType.PRIVATE_CHAT, userId);
97
+ },
98
+ children: t('fmt_chats_label_privatechat')
99
+ })
100
+ }), /*#__PURE__*/(0, _jsxRuntime.jsx)(_popover.FcrPopover, {
101
+ visible: isShowDropMenu,
102
+ overlayInnerStyle: {
103
+ border: 0,
104
+ boxShadow: 'var(--fcr_web_light_dropup_m)',
105
+ borderRadius: 'var(--fcr_cornerradius_l)'
106
+ },
107
+ overlayClassName: "attendee__more-actions",
108
+ mouseEnterDelay: 0,
109
+ content: /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
110
+ onMouseEnter: function onMouseEnter() {
111
+ return setIsShowDropMenu(true);
112
+ },
113
+ onMouseLeave: function onMouseLeave() {
114
+ return setIsShowDropMenu(false);
115
+ },
116
+ children: /*#__PURE__*/(0, _jsxRuntime.jsx)(_participantsMore.FcrParticipantsMoreActions, {
117
+ hideActions: hideActions,
118
+ hasPinnedStream: hasPinnedStream,
119
+ onParticipantsButtonClick: onParticipantsButtonClick,
120
+ user: user
121
+ })
122
+ }),
123
+ placement: "bottomRight",
124
+ children: /*#__PURE__*/(0, _jsxRuntime.jsx)(_action.FcrActionButton, {
125
+ onClick: function onClick() {
126
+ return setIsShowDropMenu(true);
127
+ },
128
+ iconType: _type.FcrIconType.FCR_DROPDOWN,
129
+ children: t('fmt_participants_member_button_more')
130
+ })
131
+ })]
132
+ });
133
+ };
134
+ var userAvatar = function userAvatar() {
135
+ if (userType === 'meeting-system') {
136
+ return {
137
+ icon: /*#__PURE__*/(0, _jsxRuntime.jsx)(_icon.FcrIcon, {
138
+ type: _type.FcrIconType.FCR_SIPDEVICE,
139
+ colors: {
140
+ iconPrimary: 'var(--fcr_ui_scene_white10)',
141
+ iconSecondary: 'var(--fcr_ui_scene_ramp_green6)'
142
+ }
143
+ }),
144
+ backgroundColor: 'var(--fcr_ui_scene_ramp_purple7)'
145
+ };
146
+ }
147
+ if (userType === 'phone') {
148
+ return {
149
+ icon: /*#__PURE__*/(0, _jsxRuntime.jsx)(_icon.FcrIcon, {
150
+ type: _type.FcrIconType.FCR_PHONECALL3
151
+ }),
152
+ backgroundColor: 'var(--fcr_ui_scene_ramp_green6)'
153
+ };
154
+ }
155
+ return {
156
+ icon: null,
157
+ backgroundColor: ''
158
+ };
159
+ };
160
+ return /*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
161
+ className: (0, _classnames["default"])('attendee', {
162
+ 'attendee-active': isShowDropMenu && !disableHover
163
+ }),
164
+ onMouseLeave: function onMouseLeave() {
165
+ return setIsShowDropMenu(false);
166
+ },
167
+ children: [/*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
168
+ className: "attendee__user-info",
169
+ children: [/*#__PURE__*/(0, _jsxRuntime.jsx)(_avatar.FcrAvatar, _objectSpread({
170
+ size: 24,
171
+ nickName: userName,
172
+ textSize: 12
173
+ }, userAvatar())), /*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
174
+ className: "attendee__user-info-identity",
175
+ children: [/*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
176
+ className: "attendee__name",
177
+ children: [userName, isMe && /*#__PURE__*/(0, _jsxRuntime.jsxs)("span", {
178
+ className: "attendee__me-badge",
179
+ children: ["(", t('fmt_participant_label_Me'), ")"]
180
+ })]
181
+ }), isHost && /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
182
+ className: "attendee__host-badge",
183
+ children: t('fmt_role_host')
184
+ })]
185
+ })]
186
+ }), /*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
187
+ className: "attendee__user-media",
188
+ children: [isScreenSharing && /*#__PURE__*/(0, _jsxRuntime.jsx)(_icon.FcrIcon, {
189
+ type: _type.FcrIconType.FCR_SCREENSHARING_1,
190
+ size: 28,
191
+ colors: {
192
+ iconPrimary: 'var(--fcr_ui_scene_ramp_green6)'
193
+ }
194
+ }), audioDeviceType !== 'none' && /*#__PURE__*/(0, _jsxRuntime.jsx)(_microphoneState.MicrophoneState, {
195
+ isMicrophoneMuted: !hasAudio,
196
+ size: 28,
197
+ isPhoneMic: audioDeviceType === 'phone-mic'
198
+ }), videoDeviceType !== 'none' && /*#__PURE__*/(0, _jsxRuntime.jsx)(_cameraState.CameraState, {
199
+ isCameraMuted: !hasVideo,
200
+ size: 28
201
+ })]
202
+ }), userActions()]
203
+ }, userId);
204
+ };
@@ -0,0 +1,49 @@
1
+ /* .fcr-drop-menu-option-with-under-line{
2
+ position: relative;
3
+ padding: 8px
4
+ }
5
+ .fcr-drop-menu-option-with-under-line::after {
6
+ content: "";
7
+ position: absolute;
8
+ left: 0;
9
+ right: -30px;
10
+ bottom: -10px;
11
+ border-top: 1px solid var(--fcr_ui_scene_line1);
12
+ margin: 8px 10px;
13
+ } */
14
+ .fcr-drop-menu-option-with-under-line:last-child:after {
15
+ border: 0;
16
+ }
17
+
18
+ .fcr-participants-more-dropmenu {
19
+ max-width: 300px;
20
+ padding: 15px 10px 15px 10px;
21
+ }
22
+
23
+ .fcr-participants-more-dropmenu .fcr-drop-menu-title {
24
+ height: 32px;
25
+ line-height: 32px;
26
+ padding-left: 8px;
27
+ text-align: left;
28
+ }
29
+
30
+ .fcr-participants-more-dropmenu .fcr-drop-menu-options {
31
+ gap: 0;
32
+ }
33
+
34
+ .fcr-participants-more-dropmenu .fcr-drop-menu-option {
35
+ min-height: 32px;
36
+ height: auto;
37
+ padding: 5px 10px 5px 5px;
38
+ align-items: start;
39
+ }
40
+
41
+ .fcr-participants-more-dropmenu .fcr-drop-menu-group {
42
+ font-size: 12px;
43
+ line-height: 32px;
44
+ padding: 8px 0 0 5px;
45
+ color: var(--fcr_ui_scene_icontext2);
46
+ margin: 8px -10px 0 5px;
47
+ border-top: 1px solid var(--fcr_ui_scene_line1);
48
+ text-align: left;
49
+ }
@@ -0,0 +1,5 @@
1
+ import { FC } from 'react';
2
+ import './index.css';
3
+ import { ParticipantsMoreActionsProps } from '../../../../types';
4
+ declare const FcrParticipantsMoreActions: FC<ParticipantsMoreActionsProps>;
5
+ export { FcrParticipantsMoreActions };
@@ -0,0 +1,219 @@
1
+ "use strict";
2
+
3
+ require("core-js/modules/es.object.define-property.js");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.FcrParticipantsMoreActions = void 0;
8
+ require("core-js/modules/es.array.filter.js");
9
+ require("core-js/modules/es.array.includes.js");
10
+ require("core-js/modules/es.array.is-array.js");
11
+ require("core-js/modules/es.array.some.js");
12
+ require("core-js/modules/es.object.to-string.js");
13
+ require("core-js/modules/es.string.includes.js");
14
+ require("core-js/modules/esnext.array.group.js");
15
+ require("core-js/modules/esnext.async-iterator.filter.js");
16
+ require("core-js/modules/esnext.async-iterator.some.js");
17
+ require("core-js/modules/esnext.iterator.constructor.js");
18
+ require("core-js/modules/esnext.iterator.filter.js");
19
+ require("core-js/modules/esnext.iterator.some.js");
20
+ require("./index.css");
21
+ var _i18next = require("i18next");
22
+ var _icon = require("agora-ui-foundation/lib/components/icon");
23
+ var _type = require("agora-ui-foundation/lib/components/icon/type");
24
+ var _cameraState = require("agora-ui-foundation/lib/components/room-screen-share-state-bar/camera-state");
25
+ var _dropMenu = require("agora-ui-foundation/lib/components/drop-menu");
26
+ var _types = require("../../../../types");
27
+ var _jsxRuntime = require("react/jsx-runtime");
28
+ // 提取常量
29
+ var ICON_SIZE = 20;
30
+ var ICON_PRIMARY_COLOR = 'var(--fcr_ui_scene_icontext5)';
31
+ var RAMP_RED_COLOR = 'var(--fcr_ui_scene_ramp_red6)';
32
+
33
+ // 封装图标创建函数
34
+ var createIcon = function createIcon(type) {
35
+ var size = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : ICON_SIZE;
36
+ var colors = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {
37
+ iconPrimary: ICON_PRIMARY_COLOR
38
+ };
39
+ return /*#__PURE__*/(0, _jsxRuntime.jsx)(_icon.FcrIcon, {
40
+ type: type,
41
+ size: size,
42
+ colors: colors
43
+ });
44
+ };
45
+
46
+ // 封装按钮点击处理函数
47
+ var handleButtonClick = function handleButtonClick(actionType, userId, onParticipantsButtonClick) {
48
+ return function () {
49
+ onParticipantsButtonClick(actionType, userId);
50
+ };
51
+ };
52
+ var FcrParticipantsMoreActions = exports.FcrParticipantsMoreActions = function FcrParticipantsMoreActions(props) {
53
+ var onParticipantsButtonClick = props.onParticipantsButtonClick,
54
+ hasPinnedStream = props.hasPinnedStream,
55
+ hideActions = props.hideActions,
56
+ user = props.user;
57
+ var isMe = user.isMe,
58
+ userId = user.userId,
59
+ hasVideo = user.hasVideo,
60
+ userName = user.userName,
61
+ userRole = user.userRole,
62
+ isPin = user.isPin,
63
+ userType = user.userType,
64
+ allowedOperations = user.allowedOperations;
65
+ var cameraStateType = !hasVideo ? 'primary' : 'danger';
66
+
67
+ // 定义所有操作菜单
68
+ var allOperationMenu = [{
69
+ icon: /*#__PURE__*/(0, _jsxRuntime.jsx)(_cameraState.CameraState, {
70
+ ignoreColor: true,
71
+ isCameraMuted: true,
72
+ renderMode: "forward-state"
73
+ }),
74
+ title: (0, _i18next.t)('fmt_device_label_video_start'),
75
+ key: 'start_video',
76
+ type: cameraStateType,
77
+ canOperation: !hasVideo && userType !== 'phone',
78
+ onButtonClick: handleButtonClick(_types.ParticipantActionType.UNMUTE_VIDEO, userId, onParticipantsButtonClick)
79
+ }, {
80
+ icon: /*#__PURE__*/(0, _jsxRuntime.jsx)(_cameraState.CameraState, {
81
+ ignoreColor: true,
82
+ isCameraMuted: true,
83
+ renderMode: "forward-state"
84
+ }),
85
+ title: (0, _i18next.t)('fmt_sip_button_opencamera'),
86
+ key: 'request_start_video',
87
+ type: 'primary',
88
+ canOperation: !hasVideo && !isMe && userType !== 'phone',
89
+ onButtonClick: handleButtonClick(_types.ParticipantActionType.UNMUTE_VIDEO, userId, onParticipantsButtonClick)
90
+ }, {
91
+ icon: /*#__PURE__*/(0, _jsxRuntime.jsx)(_cameraState.CameraState, {
92
+ isCameraMuted: false,
93
+ renderMode: "forward-state"
94
+ }),
95
+ title: /*#__PURE__*/(0, _jsxRuntime.jsx)("span", {
96
+ children: (0, _i18next.t)('fmt_device_label_video_stop')
97
+ }),
98
+ key: 'stop_video',
99
+ type: cameraStateType,
100
+ canOperation: hasVideo && userType !== 'phone',
101
+ onButtonClick: handleButtonClick(_types.ParticipantActionType.MUTE_VIDEO, userId, onParticipantsButtonClick)
102
+ }, {
103
+ icon: createIcon(_type.FcrIconType.FCR_MOBILE_CHAT3),
104
+ title: (0, _i18next.t)('fmt_attendies_label_privatechat'),
105
+ key: 'private_chat',
106
+ type: 'primary',
107
+ canOperation: !isMe && userType !== 'phone',
108
+ onButtonClick: handleButtonClick(_types.ParticipantActionType.PRIVATE_CHAT, userId, onParticipantsButtonClick)
109
+ }, {
110
+ type: 'group',
111
+ title: (0, _i18next.t)('fmt_additional_label_meet_view_own'),
112
+ key: 'own_view'
113
+ }, {
114
+ icon: isPin ? createIcon(_type.FcrIconType.FCR_UNPIN) : createIcon(_type.FcrIconType.FCR_PINPAGE),
115
+ title: isPin ? /*#__PURE__*/(0, _jsxRuntime.jsx)("span", {
116
+ children: (0, _i18next.t)('fmt_attendies_options_cancelfixed')
117
+ }) : hasPinnedStream ? (0, _i18next.t)('fmt_attendies_options_replacefixed') : (0, _i18next.t)('fmt_attendies_options_fixfirst'),
118
+ key: 'pin',
119
+ type: isPin ? 'danger' : 'primary',
120
+ canOperation: userType === 'normal' || userType === 'meeting-system' && hasVideo,
121
+ onButtonClick: handleButtonClick(isPin ? _types.ParticipantActionType.REMOVE_PIN : _types.ParticipantActionType.ADD_PIN, userId, onParticipantsButtonClick),
122
+ group: 'own_view'
123
+ }, {
124
+ type: 'group',
125
+ title: (0, _i18next.t)('fmt_additional_label_attendee_permission'),
126
+ key: 'permission'
127
+ }, {
128
+ title: (0, _i18next.t)('fmt_attendies_options_sethost'),
129
+ icon: createIcon(_type.FcrIconType.FCR_HOST2),
130
+ key: 'set_as_host',
131
+ canOperation: userRole !== _types.FcrUserRole.HOST && userType === 'normal',
132
+ onButtonClick: handleButtonClick(_types.ParticipantActionType.SET_AS_HOST, userId, onParticipantsButtonClick),
133
+ group: 'permission'
134
+ }, {
135
+ title: (0, _i18next.t)('fmt_attendies_options_setcohost'),
136
+ icon: createIcon(_type.FcrIconType.FCR_COHOST2),
137
+ key: 'set_as_co_host',
138
+ type: 'primary',
139
+ canOperation: userRole !== _types.FcrUserRole.COHOST && userType === 'normal',
140
+ onButtonClick: handleButtonClick(_types.ParticipantActionType.SET_AS_CO_HOST, userId, onParticipantsButtonClick),
141
+ group: 'permission'
142
+ }, {
143
+ title: (0, _i18next.t)('fmt_attendies_options_revokecohost'),
144
+ icon: createIcon(_type.FcrIconType.FCR_PINPAGE),
145
+ key: 'revoke_co_host',
146
+ type: 'danger',
147
+ canOperation: userRole === _types.FcrUserRole.COHOST && userType === 'normal',
148
+ onButtonClick: handleButtonClick(_types.ParticipantActionType.SET_AS_ATTENDEE, userId, onParticipantsButtonClick),
149
+ group: 'permission'
150
+ }, {
151
+ title: (0, _i18next.t)('fmt_additional_option_rename_in_meeting'),
152
+ icon: createIcon(_type.FcrIconType.FCR_RENAME2),
153
+ key: 'change_name',
154
+ type: 'primary',
155
+ canOperation: true,
156
+ onButtonClick: handleButtonClick(_types.ParticipantActionType.RENAME_IN_MEETING, userId, onParticipantsButtonClick),
157
+ group: 'permission'
158
+ }, {
159
+ title: (0, _i18next.t)('fmt_modules_tips_mergevideo'),
160
+ icon: createIcon(_type.FcrIconType.FCR_MOBILE_CAMERA2),
161
+ key: 'merge_video',
162
+ type: 'primary',
163
+ canOperation: userType === 'phone',
164
+ onButtonClick: handleButtonClick(_types.ParticipantActionType.MERGE_VIDEO, userId, onParticipantsButtonClick),
165
+ group: 'permission'
166
+ }, {
167
+ type: 'group',
168
+ title: (0, _i18next.t)('fmt_screenshare_controlbar_button_security'),
169
+ key: 'security'
170
+ }, {
171
+ title: (0, _i18next.t)('fmt_attendies_options_putinwaitingroom'),
172
+ icon: createIcon(_type.FcrIconType.FCR_PUT_WAITING_ROOM, ICON_SIZE, {
173
+ iconPrimary: RAMP_RED_COLOR
174
+ }),
175
+ key: 'put_into_waiting_room',
176
+ type: 'danger',
177
+ canOperation: true,
178
+ onButtonClick: handleButtonClick(_types.ParticipantActionType.PUT_IN_WAITING_ROOM, userId, onParticipantsButtonClick),
179
+ group: 'security'
180
+ }, {
181
+ title: (0, _i18next.t)('fmt_attendies_button_remove'),
182
+ icon: createIcon(_type.FcrIconType.FCR_SETTING_NONE, ICON_SIZE, {
183
+ iconPrimary: RAMP_RED_COLOR
184
+ }),
185
+ key: 'kick_out',
186
+ type: 'danger',
187
+ canOperation: true,
188
+ onButtonClick: handleButtonClick(_types.ParticipantActionType.KICK_OUT, userId, onParticipantsButtonClick),
189
+ group: 'security'
190
+ }];
191
+
192
+ // 过滤允许的操作
193
+ var filterAllowedOperations = function filterAllowedOperations(menuItems) {
194
+ if (Array.isArray(allowedOperations) && allowedOperations.length > 0) {
195
+ return menuItems.filter(function (item) {
196
+ return allowedOperations.includes(item.key) && item.canOperation || item.type === 'group';
197
+ }).filter(function (item) {
198
+ if (hideActions && hideActions.length) {
199
+ return !hideActions.includes(item.key);
200
+ }
201
+ return true;
202
+ });
203
+ }
204
+ return menuItems;
205
+ };
206
+ var currentActions = filterAllowedOperations(allOperationMenu);
207
+
208
+ // 过滤有分组的项
209
+ var hasGroupItem = currentActions.filter(function (item) {
210
+ return item.type === 'group' && currentActions.some(function (action) {
211
+ return action.group === item.key;
212
+ }) || item.type !== 'group';
213
+ });
214
+ return /*#__PURE__*/(0, _jsxRuntime.jsx)(_dropMenu.FcrDropMenu, {
215
+ className: "fcr-participants-more-dropmenu",
216
+ title: userName,
217
+ options: hasGroupItem
218
+ });
219
+ };
@@ -0,0 +1,5 @@
1
+ import { ListRowProps } from 'react-virtualized';
2
+ import { CellMeasurerCache } from 'react-virtualized/dist/es/CellMeasurer';
3
+ import { ParticipantActionType, User } from '../../../../types';
4
+ export declare const cache: CellMeasurerCache;
5
+ export declare const userRowRenderer: (userList: User[], userRenderer: ((user: User) => React.ReactNode) | undefined, hasPinnedStream: boolean, toggleParticipantAction: ((action: ParticipantActionType, userId: string) => void) | undefined) => (renderProps: ListRowProps) => import("react/jsx-runtime").JSX.Element;
@@ -0,0 +1,70 @@
1
+ "use strict";
2
+
3
+ require("core-js/modules/es.symbol.js");
4
+ require("core-js/modules/es.array.filter.js");
5
+ require("core-js/modules/es.array.for-each.js");
6
+ require("core-js/modules/es.array.iterator.js");
7
+ require("core-js/modules/es.array.push.js");
8
+ require("core-js/modules/es.object.define-properties.js");
9
+ require("core-js/modules/es.object.define-property.js");
10
+ require("core-js/modules/es.object.get-own-property-descriptor.js");
11
+ require("core-js/modules/es.object.get-own-property-descriptors.js");
12
+ require("core-js/modules/es.object.keys.js");
13
+ require("core-js/modules/es.object.to-string.js");
14
+ require("core-js/modules/es.string.iterator.js");
15
+ require("core-js/modules/es.weak-map.js");
16
+ require("core-js/modules/esnext.async-iterator.filter.js");
17
+ require("core-js/modules/esnext.async-iterator.for-each.js");
18
+ require("core-js/modules/esnext.iterator.constructor.js");
19
+ require("core-js/modules/esnext.iterator.filter.js");
20
+ require("core-js/modules/esnext.iterator.for-each.js");
21
+ require("core-js/modules/esnext.weak-map.delete-all.js");
22
+ require("core-js/modules/esnext.weak-map.emplace.js");
23
+ require("core-js/modules/web.dom-collections.for-each.js");
24
+ require("core-js/modules/web.dom-collections.iterator.js");
25
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
26
+ var _typeof = require("@babel/runtime/helpers/typeof");
27
+ Object.defineProperty(exports, "__esModule", {
28
+ value: true
29
+ });
30
+ exports.userRowRenderer = exports.cache = void 0;
31
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
32
+ var _CellMeasurer = _interopRequireWildcard(require("react-virtualized/dist/es/CellMeasurer"));
33
+ var _attendee = require("../attendee");
34
+ var _jsxRuntime = require("react/jsx-runtime");
35
+ function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
36
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
37
+ function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
38
+ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
39
+ var cache = exports.cache = new _CellMeasurer.CellMeasurerCache({
40
+ fixedWidth: true,
41
+ defaultHeight: 52
42
+ });
43
+ var userRowRenderer = exports.userRowRenderer = function userRowRenderer(userList, userRenderer, hasPinnedStream, toggleParticipantAction) {
44
+ return function (renderProps) {
45
+ var key = renderProps.key,
46
+ parent = renderProps.parent,
47
+ index = renderProps.index,
48
+ style = renderProps.style;
49
+ return /*#__PURE__*/(0, _jsxRuntime.jsx)(_CellMeasurer["default"], {
50
+ cache: cache,
51
+ parent: parent,
52
+ columnIndex: 0,
53
+ rowIndex: index,
54
+ children: function children(_ref) {
55
+ var measure = _ref.measure;
56
+ return /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
57
+ style: _objectSpread(_objectSpread({}, style), {}, {
58
+ pointerEvents: 'all'
59
+ }),
60
+ onLoad: measure,
61
+ children: userRenderer ? userRenderer(userList[index]) : /*#__PURE__*/(0, _jsxRuntime.jsx)(_attendee.FcrParticipant, {
62
+ hasPinnedStream: hasPinnedStream,
63
+ user: userList[index],
64
+ onParticipantsButtonClick: toggleParticipantAction
65
+ })
66
+ });
67
+ }
68
+ }, key);
69
+ };
70
+ };
@@ -0,0 +1,104 @@
1
+ .fcr-participant {
2
+ display: flex;
3
+ flex-direction: column;
4
+ width: 100%;
5
+ height: 100%;
6
+ min-width: 320px;
7
+ min-height: 560px;
8
+ }
9
+
10
+ .fcr-participant__search-and-invite {
11
+ display: flex;
12
+ align-items: center;
13
+ /* margin-bottom: 15px; */
14
+ gap: 8px;
15
+ width: 100%;
16
+ padding: 5px 15px;
17
+ }
18
+
19
+ .fcr-participant__search-and-invite .fcr-input {
20
+ height: 32px;
21
+ flex: 1;
22
+ }
23
+
24
+ .fcr-participant__search-and-invite .fcr-button-secondary {
25
+ border: 0.5px solid var(--fcr_web_ui_scene_line4);
26
+ color: var(--fcr_ui_scene_icontext1);
27
+ }
28
+
29
+ .fcr-participant__list {
30
+ flex: 1;
31
+ }
32
+
33
+ .fcr-participant__list div:focus {
34
+ outline: none;
35
+ }
36
+ .fcr-participant__footer {
37
+ display: flex;
38
+ justify-content: space-between;
39
+ padding: 4px 15px 10px 15px;
40
+ gap: 8px;
41
+ width: 100%;
42
+ background-color: var(--fcr_mobile_ui_scene_color_popup_fill2);
43
+ }
44
+
45
+ .fcr-participant__footer button {
46
+ border-radius: var(--fcr_cornerradius_s);
47
+ }
48
+
49
+ .fcr-participant__footer .fcr-button-posticon {
50
+ width: 16px;
51
+ }
52
+
53
+ .fcr-participant__footer .fcr-button-posticon path {
54
+ fill: var(--fcr_ui_scene_icontext1);
55
+ }
56
+
57
+ .fcr-participant__footer .fcr-button:hover {
58
+ /* border-color: var(--fcr_ui_scene_ramp_brand6); */
59
+ }
60
+ .fcr-participant__footer .fcr-button:hover path {
61
+ fill: var(--fcr_web_ui_scene_mainicon2);
62
+ }
63
+
64
+ .fcr-participant__search-and-invite input {
65
+ border-radius: var(--fcr_cornerradius_s);
66
+ }
67
+
68
+ .attendee__more-actions,
69
+ .attendee__footer-more-actions {
70
+ border: 0;
71
+ box-shadow: var(--fcr_web_light_dropup_m);
72
+ border-radius: var(--fcr_cornerradius_l);
73
+ max-width: fit-content;
74
+ }
75
+
76
+ .attendee__footer-more-actions .fcr-tooltip-inner {
77
+ max-width: 364px;
78
+ min-width: 302px;
79
+ width: auto !important;
80
+ }
81
+
82
+ .attendee__more-actions .fcr-checkbox-input-wrapper,
83
+ .attendee__footer-more-actions .fcr-checkbox-input-wrapper {
84
+ border: 0;
85
+ }
86
+
87
+ .attendee__more-actions .fcr-checkbox-input-wrapper .fcr-btn-click-effect,
88
+ .attendee__footer-more-actions .fcr-checkbox-input-wrapper .fcr-btn-click-effect {
89
+ height: 24px;
90
+ width: 24px;
91
+ background: transparent;
92
+ }
93
+
94
+ .attendee__footer-more-actions .fcr-checkbox {
95
+ width: 100%;
96
+ }
97
+
98
+ .attendee__footer-more-actions .fcr-drop-menu-option {
99
+ width: auto;
100
+ }
101
+
102
+ .fcr_participants_button_invite {
103
+ min-width: 70px !important;
104
+ }
@@ -0,0 +1,3 @@
1
+ import { ParticipantProps } from '../../types';
2
+ import './index.css';
3
+ export declare const FcrParticipants: (props: ParticipantProps) => import("react/jsx-runtime").JSX.Element;