UNPKG

matrix-react-sdk

Version:
86 lines (84 loc) 13.8 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties")); var _react = _interopRequireWildcard(require("react")); var _MediaDeviceHandler = _interopRequireWildcard(require("../../../MediaDeviceHandler")); var _IconizedContextMenu = _interopRequireWildcard(require("./IconizedContextMenu")); var _languageHandler = require("../../../languageHandler"); const _excluded = ["deviceKinds"]; /* Copyright 2024 New Vector Ltd. Copyright 2021 Šimon Brandner <simon.bra.ag@gmail.com> SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only Please see LICENSE files in the repository root for full details. */ function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); } 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; } const SECTION_NAMES = { [_MediaDeviceHandler.MediaDeviceKindEnum.AudioInput]: (0, _languageHandler._td)("voip|input_devices"), [_MediaDeviceHandler.MediaDeviceKindEnum.AudioOutput]: (0, _languageHandler._td)("voip|output_devices"), [_MediaDeviceHandler.MediaDeviceKindEnum.VideoInput]: (0, _languageHandler._td)("common|cameras") }; const DeviceContextMenuDevice = ({ label, selected, onClick }) => { return /*#__PURE__*/_react.default.createElement(_IconizedContextMenu.IconizedContextMenuRadio, { iconClassName: "mx_DeviceContextMenu_device_icon", label: label, active: selected, onClick: onClick }); }; const DeviceContextMenuSection = ({ deviceKind }) => { const [devices, setDevices] = (0, _react.useState)([]); const [selectedDevice, setSelectedDevice] = (0, _react.useState)(_MediaDeviceHandler.default.getDevice(deviceKind)); (0, _react.useEffect)(() => { const getDevices = async () => { return setDevices((await _MediaDeviceHandler.default.getDevices())?.[deviceKind] ?? []); }; getDevices(); }, [deviceKind]); const onDeviceClick = deviceId => { _MediaDeviceHandler.default.instance.setDevice(deviceId, deviceKind); setSelectedDevice(deviceId); }; return /*#__PURE__*/_react.default.createElement(_IconizedContextMenu.IconizedContextMenuOptionList, { label: (0, _languageHandler._t)(SECTION_NAMES[deviceKind]) }, devices.map(({ label, deviceId }) => { return /*#__PURE__*/_react.default.createElement(DeviceContextMenuDevice, { key: deviceId, label: label, selected: selectedDevice === deviceId, onClick: () => onDeviceClick(deviceId) }); })); }; const DeviceContextMenu = _ref => { let { deviceKinds } = _ref, props = (0, _objectWithoutProperties2.default)(_ref, _excluded); return /*#__PURE__*/_react.default.createElement(_IconizedContextMenu.default, (0, _extends2.default)({ compact: true, className: "mx_DeviceContextMenu" }, props), deviceKinds.map(kind => { return /*#__PURE__*/_react.default.createElement(DeviceContextMenuSection, { key: kind, deviceKind: kind }); })); }; var _default = exports.default = DeviceContextMenu; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_MediaDeviceHandler","_IconizedContextMenu","_languageHandler","_excluded","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","SECTION_NAMES","MediaDeviceKindEnum","AudioInput","_td","AudioOutput","VideoInput","DeviceContextMenuDevice","label","selected","onClick","createElement","IconizedContextMenuRadio","iconClassName","active","DeviceContextMenuSection","deviceKind","devices","setDevices","useState","selectedDevice","setSelectedDevice","MediaDeviceHandler","getDevice","useEffect","getDevices","onDeviceClick","deviceId","instance","setDevice","IconizedContextMenuOptionList","_t","map","key","DeviceContextMenu","_ref","deviceKinds","props","_objectWithoutProperties2","_extends2","compact","className","kind","_default","exports"],"sources":["../../../../src/components/views/context_menus/DeviceContextMenu.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2021 Šimon Brandner <simon.bra.ag@gmail.com>\n\nSPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only\nPlease see LICENSE files in the repository root for full details.\n*/\n\nimport React, { useEffect, useState } from \"react\";\n\nimport MediaDeviceHandler, { MediaDeviceKindEnum } from \"../../../MediaDeviceHandler\";\nimport IconizedContextMenu, { IconizedContextMenuOptionList, IconizedContextMenuRadio } from \"./IconizedContextMenu\";\nimport { IProps as IContextMenuProps } from \"../../structures/ContextMenu\";\nimport { _t, _td, TranslationKey } from \"../../../languageHandler\";\n\nconst SECTION_NAMES: Record<MediaDeviceKindEnum, TranslationKey> = {\n    [MediaDeviceKindEnum.AudioInput]: _td(\"voip|input_devices\"),\n    [MediaDeviceKindEnum.AudioOutput]: _td(\"voip|output_devices\"),\n    [MediaDeviceKindEnum.VideoInput]: _td(\"common|cameras\"),\n};\n\ninterface IDeviceContextMenuDeviceProps {\n    label: string;\n    selected: boolean;\n    onClick: () => void;\n}\n\nconst DeviceContextMenuDevice: React.FC<IDeviceContextMenuDeviceProps> = ({ label, selected, onClick }) => {\n    return (\n        <IconizedContextMenuRadio\n            iconClassName=\"mx_DeviceContextMenu_device_icon\"\n            label={label}\n            active={selected}\n            onClick={onClick}\n        />\n    );\n};\n\ninterface IDeviceContextMenuSectionProps {\n    deviceKind: MediaDeviceKindEnum;\n}\n\nconst DeviceContextMenuSection: React.FC<IDeviceContextMenuSectionProps> = ({ deviceKind }) => {\n    const [devices, setDevices] = useState<MediaDeviceInfo[]>([]);\n    const [selectedDevice, setSelectedDevice] = useState(MediaDeviceHandler.getDevice(deviceKind));\n\n    useEffect(() => {\n        const getDevices = async (): Promise<void> => {\n            return setDevices((await MediaDeviceHandler.getDevices())?.[deviceKind] ?? []);\n        };\n        getDevices();\n    }, [deviceKind]);\n\n    const onDeviceClick = (deviceId: string): void => {\n        MediaDeviceHandler.instance.setDevice(deviceId, deviceKind);\n        setSelectedDevice(deviceId);\n    };\n\n    return (\n        <IconizedContextMenuOptionList label={_t(SECTION_NAMES[deviceKind])}>\n            {devices.map(({ label, deviceId }) => {\n                return (\n                    <DeviceContextMenuDevice\n                        key={deviceId}\n                        label={label}\n                        selected={selectedDevice === deviceId}\n                        onClick={() => onDeviceClick(deviceId)}\n                    />\n                );\n            })}\n        </IconizedContextMenuOptionList>\n    );\n};\n\ninterface IProps extends IContextMenuProps {\n    deviceKinds: MediaDeviceKind[];\n}\n\nconst DeviceContextMenu: React.FC<IProps> = ({ deviceKinds, ...props }) => {\n    return (\n        <IconizedContextMenu compact className=\"mx_DeviceContextMenu\" {...props}>\n            {deviceKinds.map((kind) => {\n                return <DeviceContextMenuSection key={kind} deviceKind={kind as MediaDeviceKindEnum} />;\n            })}\n        </IconizedContextMenu>\n    );\n};\n\nexport default DeviceContextMenu;\n"],"mappings":"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","ignoreList":[]}