fix(Safari): Fix mobile double tapping for toolbar and overflow.
* Create generic tooltip wrapper for mobile usability. * Change overflow menu icon/font/padding sizes. * Change overflow drawer expand icon.
This commit is contained in:
parent
d2568b874b
commit
b69e93a900
|
@ -7,7 +7,7 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
.drawer-menu {
|
.drawer-menu {
|
||||||
padding: 12px 16px;
|
padding: 0 16px;
|
||||||
max-height: 50vh;
|
max-height: 50vh;
|
||||||
background: #242528;
|
background: #242528;
|
||||||
border-radius: 16px 16px 0 0;
|
border-radius: 16px 16px 0 0;
|
||||||
|
@ -24,12 +24,14 @@
|
||||||
height: 44px;
|
height: 44px;
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
|
|
||||||
&:hover {
|
@media (hover: hover) and (pointer: fine) {
|
||||||
background-color: $overflowMenuItemHoverBG;
|
&:hover {
|
||||||
|
background-color: $overflowMenuItemHoverBG;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
svg, path {
|
svg {
|
||||||
fill: #b8c7e0;
|
fill: none;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -57,7 +59,7 @@
|
||||||
color: $overflowMenuItemColor;
|
color: $overflowMenuItemColor;
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
display: flex;
|
display: flex;
|
||||||
font-size: 14px;
|
font-size: 16px;
|
||||||
|
|
||||||
div {
|
div {
|
||||||
display: flex;
|
display: flex;
|
||||||
|
@ -65,16 +67,20 @@
|
||||||
align-items: center;
|
align-items: center;
|
||||||
}
|
}
|
||||||
|
|
||||||
&:hover {
|
@media (hover: hover) and (pointer: fine) {
|
||||||
background-color: $overflowMenuItemHoverBG;
|
&:hover {
|
||||||
color: $overflowMenuItemHoverColor;
|
background-color: $overflowMenuItemHoverBG;
|
||||||
|
color: $overflowMenuItemHoverColor;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
&.unclickable {
|
&.unclickable {
|
||||||
cursor: default;
|
cursor: default;
|
||||||
}
|
}
|
||||||
&.unclickable:hover {
|
@media (hover: hover) and (pointer: fine) {
|
||||||
background: inherit;
|
&.unclickable:hover {
|
||||||
|
background: inherit;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
&.disabled {
|
&.disabled {
|
||||||
cursor: initial;
|
cursor: initial;
|
||||||
|
@ -93,15 +99,17 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
.overflow-menu-item-icon {
|
.overflow-menu-item-icon {
|
||||||
margin-right: 10px;
|
margin-right: 16px;
|
||||||
|
|
||||||
i {
|
i {
|
||||||
display: inline;
|
display: inline;
|
||||||
font-size: 24px;
|
font-size: 24px;
|
||||||
}
|
}
|
||||||
|
|
||||||
i:hover {
|
@media (hover: hover) and (pointer: fine) {
|
||||||
background-color: initial;
|
i:hover {
|
||||||
|
background-color: initial;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
img {
|
img {
|
||||||
|
@ -111,11 +119,13 @@
|
||||||
|
|
||||||
svg {
|
svg {
|
||||||
fill: #B8C7E0 !important;
|
fill: #B8C7E0 !important;
|
||||||
|
height: 20px;
|
||||||
|
width: 20px;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.profile-text {
|
.profile-text {
|
||||||
max-width: 150px;
|
max-width: 100%;
|
||||||
text-overflow: ellipsis;
|
text-overflow: ellipsis;
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
white-space: nowrap;
|
white-space: nowrap;
|
||||||
|
|
|
@ -91,9 +91,11 @@
|
||||||
width: 38px;
|
width: 38px;
|
||||||
height: 38px;
|
height: 38px;
|
||||||
|
|
||||||
&:hover {
|
@media (hover: hover) and (pointer: fine) {
|
||||||
background-color: #daebfa;
|
&:hover {
|
||||||
border: 1px solid #daebfa;
|
background-color: #daebfa;
|
||||||
|
border: 1px solid #daebfa;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
&.toggled {
|
&.toggled {
|
||||||
|
@ -104,8 +106,10 @@
|
||||||
fill: #fff;
|
fill: #fff;
|
||||||
}
|
}
|
||||||
|
|
||||||
&:hover {
|
@media (hover: hover) and (pointer: fine) {
|
||||||
background-color: #5e6d7a;
|
&:hover {
|
||||||
|
background-color: #5e6d7a;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -127,8 +131,10 @@
|
||||||
width: 40px;
|
width: 40px;
|
||||||
height: 40px;
|
height: 40px;
|
||||||
|
|
||||||
&:hover {
|
@media (hover: hover) and (pointer: fine) {
|
||||||
background-color: $hangupColor;
|
&:hover {
|
||||||
|
background-color: $hangupColor;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
svg {
|
svg {
|
||||||
|
@ -159,8 +165,9 @@
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
display: flex;
|
display: flex;
|
||||||
font-size: 14px;
|
font-size: 14px;
|
||||||
height: 22px;
|
height: 40px;
|
||||||
padding: 5px 12px;
|
padding: 5px 12px;
|
||||||
|
box-sizing: border-box;
|
||||||
|
|
||||||
div {
|
div {
|
||||||
display: flex;
|
display: flex;
|
||||||
|
@ -168,16 +175,20 @@
|
||||||
align-items: center;
|
align-items: center;
|
||||||
}
|
}
|
||||||
|
|
||||||
&:hover {
|
@media (hover: hover) and (pointer: fine) {
|
||||||
background-color: $overflowMenuItemHoverBG;
|
&:hover {
|
||||||
color: $overflowMenuItemHoverColor;
|
background-color: $overflowMenuItemHoverBG;
|
||||||
|
color: $overflowMenuItemHoverColor;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
&.unclickable {
|
&.unclickable {
|
||||||
cursor: default;
|
cursor: default;
|
||||||
}
|
}
|
||||||
&.unclickable:hover {
|
@media (hover: hover) and (pointer: fine) {
|
||||||
background: inherit;
|
&.unclickable:hover {
|
||||||
|
background: inherit;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
&.disabled {
|
&.disabled {
|
||||||
cursor: initial;
|
cursor: initial;
|
||||||
|
@ -196,15 +207,17 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
.overflow-menu-item-icon {
|
.overflow-menu-item-icon {
|
||||||
margin-right: 10px;
|
margin-right: 16px;
|
||||||
|
|
||||||
i {
|
i {
|
||||||
display: inline;
|
display: inline;
|
||||||
font-size: 24px;
|
font-size: 24px;
|
||||||
}
|
}
|
||||||
|
|
||||||
i:hover {
|
@media (hover: hover) and (pointer: fine) {
|
||||||
background-color: initial;
|
i:hover {
|
||||||
|
background-color: initial;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
img {
|
img {
|
||||||
|
@ -214,6 +227,8 @@
|
||||||
|
|
||||||
svg {
|
svg {
|
||||||
fill: #B8C7E0 !important;
|
fill: #B8C7E0 !important;
|
||||||
|
height: 20px;
|
||||||
|
width: 20px;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -261,7 +276,13 @@
|
||||||
justify-content: center;
|
justify-content: center;
|
||||||
width: $newToolbarSize;
|
width: $newToolbarSize;
|
||||||
|
|
||||||
&:hover, &.toggled {
|
@media (hover: hover) and (pointer: fine) {
|
||||||
|
&:hover {
|
||||||
|
background: $newToolbarButtonHoverColor;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
&.toggled {
|
||||||
background: $newToolbarButtonHoverColor;
|
background: $newToolbarButtonHoverColor;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -32,8 +32,10 @@
|
||||||
line-height: 24px;
|
line-height: 24px;
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
|
|
||||||
&:hover {
|
@media (hover: hover) and (pointer: fine) {
|
||||||
background: #278ADF;
|
&:hover {
|
||||||
|
background: #278ADF;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
&-text {
|
&-text {
|
||||||
|
|
|
@ -0,0 +1,3 @@
|
||||||
|
<svg width="29" height="12" viewBox="0 0 29 12" fill="none" xmlns="http://www.w3.org/2000/svg">
|
||||||
|
<path d="M2.5 2L14.2616 10L26.5 2" stroke="#929292" stroke-width="3.5" stroke-linecap="round" stroke-linejoin="round"/>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 223 B |
|
@ -0,0 +1,3 @@
|
||||||
|
<svg width="29" height="12" viewBox="0 0 29 12" fill="none" xmlns="http://www.w3.org/2000/svg">
|
||||||
|
<path d="M2.5 10L14.2616 2L26.5 10" stroke="#929292" stroke-width="3.5" stroke-linecap="round" stroke-linejoin="round"/>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 224 B |
|
@ -6,8 +6,10 @@ export { default as IconArrowBack } from './arrow_back.svg';
|
||||||
export { default as IconArrowDown } from './arrow_down.svg';
|
export { default as IconArrowDown } from './arrow_down.svg';
|
||||||
export { default as IconArrowDownLarge } from './arrow_down_large.svg';
|
export { default as IconArrowDownLarge } from './arrow_down_large.svg';
|
||||||
export { default as IconArrowDownSmall } from './arrow-down-small.svg';
|
export { default as IconArrowDownSmall } from './arrow-down-small.svg';
|
||||||
|
export { default as IconArrowDownWide } from './icon-arrow-down-wide.svg';
|
||||||
export { default as IconArrowUp } from './arrow_up.svg';
|
export { default as IconArrowUp } from './arrow_up.svg';
|
||||||
export { default as IconArrowUpLarge } from './arrow_up_large.svg';
|
export { default as IconArrowUpLarge } from './arrow_up_large.svg';
|
||||||
|
export { default as IconArrowUpWide } from './icon-arrow-up-wide.svg';
|
||||||
export { default as IconArrowLeft } from './arrow-left.svg';
|
export { default as IconArrowLeft } from './arrow-left.svg';
|
||||||
export { default as IconAudioOnly } from './visibility.svg';
|
export { default as IconAudioOnly } from './visibility.svg';
|
||||||
export { default as IconAudioOnlyOff } from './visibility-off.svg';
|
export { default as IconAudioOnlyOff } from './visibility-off.svg';
|
||||||
|
|
|
@ -1,10 +1,10 @@
|
||||||
/* @flow */
|
/* @flow */
|
||||||
|
|
||||||
import Tooltip from '@atlaskit/tooltip';
|
|
||||||
import React, { Component } from 'react';
|
import React, { Component } from 'react';
|
||||||
|
|
||||||
import { translate } from '../../../i18n';
|
import { translate } from '../../../i18n';
|
||||||
import { Icon } from '../../../icons';
|
import { Icon } from '../../../icons';
|
||||||
|
import { Tooltip } from '../../../tooltip';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The type of the React {@code Component} props of {@link BaseIndicator}.
|
* The type of the React {@code Component} props of {@link BaseIndicator}.
|
||||||
|
|
|
@ -1,9 +1,9 @@
|
||||||
// @flow
|
// @flow
|
||||||
|
|
||||||
import Tooltip from '@atlaskit/tooltip';
|
|
||||||
import React, { Component } from 'react';
|
import React, { Component } from 'react';
|
||||||
|
|
||||||
import { Icon } from '../../icons';
|
import { Icon } from '../../icons';
|
||||||
|
import { Tooltip } from '../../tooltip';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The type of the React {@code Component} props of {@link OverflowMenuItem}.
|
* The type of the React {@code Component} props of {@link OverflowMenuItem}.
|
||||||
|
|
|
@ -1,9 +1,9 @@
|
||||||
// @flow
|
// @flow
|
||||||
|
|
||||||
import Tooltip from '@atlaskit/tooltip';
|
|
||||||
import React, { Fragment } from 'react';
|
import React, { Fragment } from 'react';
|
||||||
|
|
||||||
import { Icon } from '../../icons';
|
import { Icon } from '../../icons';
|
||||||
|
import { Tooltip } from '../../tooltip';
|
||||||
|
|
||||||
import AbstractToolboxItem from './AbstractToolboxItem';
|
import AbstractToolboxItem from './AbstractToolboxItem';
|
||||||
import type { Props } from './AbstractToolboxItem';
|
import type { Props } from './AbstractToolboxItem';
|
||||||
|
|
|
@ -0,0 +1,50 @@
|
||||||
|
// @flow
|
||||||
|
|
||||||
|
import Tooltip from '@atlaskit/tooltip';
|
||||||
|
import React from 'react';
|
||||||
|
|
||||||
|
import { isMobileBrowser } from '../../environment/utils';
|
||||||
|
|
||||||
|
type Props = {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Children of the component.
|
||||||
|
*/
|
||||||
|
children: React$Node,
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The text to be displayed in the tooltip.
|
||||||
|
*/
|
||||||
|
content?: string | null,
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The position of the tooltip relative to the element it contains.
|
||||||
|
*/
|
||||||
|
position?: string
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Wrapper of AtlasKit Tooltip that doesn't render the actual tooltip in mobile browsers.
|
||||||
|
*
|
||||||
|
* @returns {ReactElement}
|
||||||
|
*/
|
||||||
|
function TooltipWrapper({
|
||||||
|
children,
|
||||||
|
content,
|
||||||
|
position
|
||||||
|
}: Props) {
|
||||||
|
if (isMobileBrowser()) {
|
||||||
|
return children;
|
||||||
|
}
|
||||||
|
|
||||||
|
return (
|
||||||
|
<Tooltip
|
||||||
|
content = { content }
|
||||||
|
position = { position }>
|
||||||
|
{children}
|
||||||
|
</Tooltip>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
export default TooltipWrapper;
|
|
@ -0,0 +1,3 @@
|
||||||
|
// @flow
|
||||||
|
|
||||||
|
export { default as Tooltip } from './TooltipWrapper';
|
|
@ -0,0 +1,3 @@
|
||||||
|
// @flow
|
||||||
|
|
||||||
|
export * from './components';
|
|
@ -1,6 +1,5 @@
|
||||||
// @flow
|
// @flow
|
||||||
|
|
||||||
import Tooltip from '@atlaskit/tooltip';
|
|
||||||
import React, { Component } from 'react';
|
import React, { Component } from 'react';
|
||||||
import type { Dispatch } from 'redux';
|
import type { Dispatch } from 'redux';
|
||||||
|
|
||||||
|
@ -11,6 +10,7 @@ import {
|
||||||
import { translate } from '../../base/i18n';
|
import { translate } from '../../base/i18n';
|
||||||
import { Icon, IconAdd } from '../../base/icons';
|
import { Icon, IconAdd } from '../../base/icons';
|
||||||
import { connect } from '../../base/redux';
|
import { connect } from '../../base/redux';
|
||||||
|
import { Tooltip } from '../../base/tooltip';
|
||||||
import { updateCalendarEvent } from '../actions';
|
import { updateCalendarEvent } from '../actions';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -1,10 +1,10 @@
|
||||||
// @flow
|
// @flow
|
||||||
|
|
||||||
import Tooltip from '@atlaskit/tooltip';
|
|
||||||
import React, { Component } from 'react';
|
import React, { Component } from 'react';
|
||||||
|
|
||||||
import { translate } from '../../base/i18n';
|
import { translate } from '../../base/i18n';
|
||||||
import { Icon, IconAdd } from '../../base/icons';
|
import { Icon, IconAdd } from '../../base/icons';
|
||||||
|
import { Tooltip } from '../../base/tooltip';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The type of the React {@code Component} props of {@link JoinButton}.
|
* The type of the React {@code Component} props of {@link JoinButton}.
|
||||||
|
|
|
@ -1,12 +1,12 @@
|
||||||
// @flow
|
// @flow
|
||||||
|
|
||||||
import Tooltip from '@atlaskit/tooltip';
|
|
||||||
import React, { Component } from 'react';
|
import React, { Component } from 'react';
|
||||||
|
|
||||||
import { translate } from '../../base/i18n';
|
import { translate } from '../../base/i18n';
|
||||||
import { IconE2EE } from '../../base/icons';
|
import { IconE2EE } from '../../base/icons';
|
||||||
import { CircularLabel } from '../../base/label';
|
import { CircularLabel } from '../../base/label';
|
||||||
import { connect } from '../../base/redux';
|
import { connect } from '../../base/redux';
|
||||||
|
import { Tooltip } from '../../base/tooltip';
|
||||||
|
|
||||||
import { _mapStateToProps, type Props } from './AbstractE2EELabel';
|
import { _mapStateToProps, type Props } from './AbstractE2EELabel';
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,5 @@
|
||||||
// @flow
|
// @flow
|
||||||
|
|
||||||
import Tooltip from '@atlaskit/tooltip';
|
|
||||||
import React, { useState } from 'react';
|
import React, { useState } from 'react';
|
||||||
|
|
||||||
import { translate } from '../../../../base/i18n';
|
import { translate } from '../../../../base/i18n';
|
||||||
|
@ -13,6 +12,7 @@ import {
|
||||||
IconOutlook,
|
IconOutlook,
|
||||||
IconYahoo
|
IconYahoo
|
||||||
} from '../../../../base/icons';
|
} from '../../../../base/icons';
|
||||||
|
import { Tooltip } from '../../../../base/tooltip';
|
||||||
import { copyText, openURLInBrowser } from '../../../../base/util';
|
import { copyText, openURLInBrowser } from '../../../../base/util';
|
||||||
|
|
||||||
type Props = {
|
type Props = {
|
||||||
|
|
|
@ -1,11 +1,11 @@
|
||||||
// @flow
|
// @flow
|
||||||
|
|
||||||
import Tooltip from '@atlaskit/tooltip';
|
|
||||||
import React, { Component } from 'react';
|
import React, { Component } from 'react';
|
||||||
|
|
||||||
import { translate } from '../../base/i18n/index';
|
import { translate } from '../../base/i18n/index';
|
||||||
import { CircularLabel } from '../../base/label/index';
|
import { CircularLabel } from '../../base/label/index';
|
||||||
import { connect } from '../../base/redux';
|
import { connect } from '../../base/redux';
|
||||||
|
import { Tooltip } from '../../base/tooltip';
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
|
|
||||||
import React, { useEffect, useRef, useState } from 'react';
|
import React, { useEffect, useRef, useState } from 'react';
|
||||||
|
|
||||||
import { Icon, IconArrowUp, IconArrowDown } from '../../../base/icons';
|
import { Icon, IconArrowUpWide, IconArrowDownWide } from '../../../base/icons';
|
||||||
|
|
||||||
type Props = {
|
type Props = {
|
||||||
|
|
||||||
|
@ -78,7 +78,7 @@ function Drawer({
|
||||||
<div
|
<div
|
||||||
className = 'drawer-toggle'
|
className = 'drawer-toggle'
|
||||||
onClick = { toggleExpanded }>
|
onClick = { toggleExpanded }>
|
||||||
<Icon src = { expanded ? IconArrowDown : IconArrowUp } />
|
<Icon src = { expanded ? IconArrowDownWide : IconArrowUpWide } />
|
||||||
</div>
|
</div>
|
||||||
)}
|
)}
|
||||||
{children}
|
{children}
|
||||||
|
|
|
@ -83,7 +83,7 @@ class OverflowMenuProfileItem extends Component<Props> {
|
||||||
<span className = 'overflow-menu-item-icon'>
|
<span className = 'overflow-menu-item-icon'>
|
||||||
<Avatar
|
<Avatar
|
||||||
participantId = { _localParticipant.id }
|
participantId = { _localParticipant.id }
|
||||||
size = { 24 } />
|
size = { 20 } />
|
||||||
</span>
|
</span>
|
||||||
<span className = 'profile-text'>
|
<span className = 'profile-text'>
|
||||||
{ displayName }
|
{ displayName }
|
||||||
|
|
|
@ -1,9 +1,9 @@
|
||||||
/* @flow */
|
/* @flow */
|
||||||
|
|
||||||
import Tooltip from '@atlaskit/tooltip';
|
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
|
|
||||||
import { Icon } from '../../../base/icons';
|
import { Icon } from '../../../base/icons';
|
||||||
|
import { Tooltip } from '../../../base/tooltip';
|
||||||
import AbstractToolbarButton from '../AbstractToolbarButton';
|
import AbstractToolbarButton from '../AbstractToolbarButton';
|
||||||
import type { Props as AbstractToolbarButtonProps }
|
import type { Props as AbstractToolbarButtonProps }
|
||||||
from '../AbstractToolbarButton';
|
from '../AbstractToolbarButton';
|
||||||
|
|
|
@ -1,11 +1,11 @@
|
||||||
// @flow
|
// @flow
|
||||||
|
|
||||||
import Tooltip from '@atlaskit/tooltip';
|
|
||||||
import React, { Component } from 'react';
|
import React, { Component } from 'react';
|
||||||
|
|
||||||
import { translate } from '../../base/i18n';
|
import { translate } from '../../base/i18n';
|
||||||
import { CircularLabel } from '../../base/label';
|
import { CircularLabel } from '../../base/label';
|
||||||
import { connect } from '../../base/redux';
|
import { connect } from '../../base/redux';
|
||||||
|
import { Tooltip } from '../../base/tooltip';
|
||||||
|
|
||||||
import { _mapStateToProps, type Props } from './AbstractTranscribingLabel';
|
import { _mapStateToProps, type Props } from './AbstractTranscribingLabel';
|
||||||
|
|
||||||
|
|
|
@ -1,12 +1,12 @@
|
||||||
// @flow
|
// @flow
|
||||||
|
|
||||||
import Tooltip from '@atlaskit/tooltip';
|
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
|
|
||||||
import { translate } from '../../base/i18n';
|
import { translate } from '../../base/i18n';
|
||||||
import { CircularLabel } from '../../base/label';
|
import { CircularLabel } from '../../base/label';
|
||||||
import { MEDIA_TYPE } from '../../base/media';
|
import { MEDIA_TYPE } from '../../base/media';
|
||||||
import { connect } from '../../base/redux';
|
import { connect } from '../../base/redux';
|
||||||
|
import { Tooltip } from '../../base/tooltip';
|
||||||
import { getTrackByMediaTypeAndParticipant } from '../../base/tracks';
|
import { getTrackByMediaTypeAndParticipant } from '../../base/tracks';
|
||||||
|
|
||||||
import AbstractVideoQualityLabel, {
|
import AbstractVideoQualityLabel, {
|
||||||
|
|
Loading…
Reference in New Issue