1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192 |
- // @flow
-
- import React from 'react';
-
- import { translate } from '../../../base/i18n';
- import { Icon, IconCheckSolid, IconExclamation } from '../../../base/icons';
- import { connect } from '../../../base/redux';
- import {
- getDeviceStatusType,
- getDeviceStatusText,
- getRawError
- } from '../../functions';
-
- export type Props = {
-
- /**
- * The text to be displayed in relation to the status of the audio/video devices.
- */
- deviceStatusText: string,
-
- /**
- * The type of status for current devices, controlling the background color of the text.
- * Can be `ok` or `warning`.
- */
- deviceStatusType: string,
-
- /**
- * The error coming from device configuration.
- */
- rawError: string,
-
- /**
- * Used for translation.
- */
- t: Function
- };
-
- const iconMap = {
- warning: {
- src: IconExclamation,
- className: 'device-icon--warning'
- },
- ok: {
- src: IconCheckSolid,
- className: 'device-icon--ok'
- }
- };
-
- /**
- * Strip showing the current status of the devices.
- * User is informed if there are missing or malfunctioning devices.
- *
- * @returns {ReactElement}
- */
- function DeviceStatus({ deviceStatusType, deviceStatusText, rawError, t }: Props) {
- const { src, className } = iconMap[deviceStatusType];
-
- return (
- <div
- className = 'device-status'
- role = 'alert'
- tabIndex = { -1 }>
- <Icon
- className = { `device-icon ${className}` }
- size = { 16 }
- src = { src } />
- <span
- role = 'heading'>
- {t(deviceStatusText)}
- </span>
- { rawError && <span>
- { rawError }
- </span> }
- </div>
- );
- }
-
- /**
- * Maps (parts of) the redux state to the React {@code Component} props.
- *
- * @param {Object} state - The redux state.
- * @returns {{ deviceStatusText: string, deviceStatusText: string }}
- */
- function mapStateToProps(state) {
- return {
- deviceStatusText: getDeviceStatusText(state),
- deviceStatusType: getDeviceStatusType(state),
- rawError: getRawError(state)
- };
- }
-
- export default translate(connect(mapStateToProps)(DeviceStatus));
|