Adding responsive to jitsi logo, buttons and hiding some part of the interface (#7380)

* Adding responsive to jitsi logo, buttons and hiding some part of the interface
* moving media types thresholds to variables and apply only to screen
* hide chrome extension banner on very small view
* Hide filmstrip only on desktop narrow windows
This commit is contained in:
Jesús Espino 2020-07-31 13:53:19 +02:00 committed by GitHub
parent b0650b8448
commit 400c86ad5e
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 104 additions and 6 deletions

70
css/_responsive.scss Normal file
View File

@ -0,0 +1,70 @@
@media only screen and (max-width: $smallScreen) {
.watermark {
width: 20%;
height: 20%;
}
.new-toolbox {
.toolbox-content {
.button-group-center, .button-group-left, .button-group-right {
.toolbox-button {
.toolbox-icon {
width: 28px;
height: 28px;
svg {
width: 18px;
height: 18px;
}
}
&:nth-child(2) {
.toolbox-icon {
width: 30px;
height: 30px;
}
}
}
}
}
}
}
@media only screen and (max-width: $verySmallScreen) {
#videoResolutionLabel {
display: none;
}
.desktop-browser {
.vertical-filmstrip .filmstrip {
display: none;
}
}
.new-toolbox {
.toolbox-content {
.button-group-center, .button-group-left, .button-group-right {
.settings-button-small-icon {
display: none;
}
.toolbox-button {
.toolbox-icon {
width: 18px;
height: 18px;
svg {
width: 12px;
height: 12px;
}
}
&:nth-child(2) {
.toolbox-icon {
width: 20px;
height: 20px;
}
}
}
}
}
}
.chrome-extension-banner {
display: none;
}
}

View File

@ -269,3 +269,9 @@ $chromeExtensionBannerTop: 80px;
$chromeExtensionBannerRight: 16px; $chromeExtensionBannerRight: 16px;
$chromeExtensionBannerTopInMeeting: 10px; $chromeExtensionBannerTopInMeeting: 10px;
$chromeExtensionBannerRightInMeeeting: 10px; $chromeExtensionBannerRightInMeeeting: 10px;
/**
* media type thresholds
*/
$smallScreen: 700px;
$verySmallScreen: 500px;

View File

@ -101,5 +101,6 @@ $flagsImagePath: "../images/";
@import 'modals/security/security'; @import 'modals/security/security';
@import 'premeeting-screens'; @import 'premeeting-screens';
@import 'e2ee'; @import 'e2ee';
@import 'responsive';
/* Modules END */ /* Modules END */

View File

@ -6,6 +6,7 @@ const UI = {};
import EventEmitter from 'events'; import EventEmitter from 'events';
import Logger from 'jitsi-meet-logger'; import Logger from 'jitsi-meet-logger';
import { isMobileBrowser } from '../../react/features/base/environment/utils';
import { getLocalParticipant } from '../../react/features/base/participants'; import { getLocalParticipant } from '../../react/features/base/participants';
import { toggleChat } from '../../react/features/chat'; import { toggleChat } from '../../react/features/chat';
import { setDocumentUrl } from '../../react/features/etherpad'; import { setDocumentUrl } from '../../react/features/etherpad';
@ -154,6 +155,12 @@ UI.start = function() {
sharedVideoManager = new SharedVideoManager(eventEmitter); sharedVideoManager = new SharedVideoManager(eventEmitter);
if (isMobileBrowser()) {
$('body').addClass('mobile-browser');
} else {
$('body').addClass('desktop-browser');
}
if (interfaceConfig.filmStripOnly) { if (interfaceConfig.filmStripOnly) {
$('body').addClass('filmstrip-only'); $('body').addClass('filmstrip-only');
APP.store.dispatch(setNotificationsEnabled(false)); APP.store.dispatch(setNotificationsEnabled(false));

View File

@ -1209,13 +1209,27 @@ class Toolbox extends Component<Props, State> {
const buttonsLeft = []; const buttonsLeft = [];
const buttonsRight = []; const buttonsRight = [];
const smallThreshold = 700;
const verySmallThreshold = 500;
let minSpaceBetweenButtons = 48;
let widthPlusPaddingOfButton = 56;
if (this.state.windowWidth <= verySmallThreshold) {
minSpaceBetweenButtons = 26;
widthPlusPaddingOfButton = 28;
} else if (this.state.windowWidth <= smallThreshold) {
minSpaceBetweenButtons = 36;
widthPlusPaddingOfButton = 40;
}
const maxNumberOfButtonsPerGroup = Math.floor( const maxNumberOfButtonsPerGroup = Math.floor(
( (
this.state.windowWidth this.state.windowWidth
- 168 // the width of the central group by design - 168 // the width of the central group by design
- 48 // the minimum space between the button groups - minSpaceBetweenButtons // the minimum space between the button groups
) )
/ 56 // the width + padding of a button / widthPlusPaddingOfButton // the width + padding of a button
/ 2 // divide by the number of groups(left and right group) / 2 // divide by the number of groups(left and right group)
); );
@ -1232,7 +1246,7 @@ class Toolbox extends Component<Props, State> {
if (this._shouldShowButton('closedcaptions')) { if (this._shouldShowButton('closedcaptions')) {
buttonsLeft.push('closedcaptions'); buttonsLeft.push('closedcaptions');
} }
if (overflowHasItems) { if (overflowHasItems && this.state.windowWidth >= verySmallThreshold) {
buttonsRight.push('overflowmenu'); buttonsRight.push('overflowmenu');
} }
if (this._shouldShowButton('invite')) { if (this._shouldShowButton('invite')) {
@ -1255,13 +1269,13 @@ class Toolbox extends Component<Props, State> {
movedButtons.push(...buttonsLeft.splice( movedButtons.push(...buttonsLeft.splice(
maxNumberOfButtonsPerGroup, maxNumberOfButtonsPerGroup,
buttonsLeft.length - maxNumberOfButtonsPerGroup)); buttonsLeft.length - maxNumberOfButtonsPerGroup));
if (buttonsRight.indexOf('overflowmenu') === -1) { if (buttonsRight.indexOf('overflowmenu') === -1 && this.state.windowWidth >= verySmallThreshold) {
buttonsRight.unshift('overflowmenu'); buttonsRight.unshift('overflowmenu');
} }
} }
if (buttonsRight.length > maxNumberOfButtonsPerGroup) { if (buttonsRight.length > maxNumberOfButtonsPerGroup) {
if (buttonsRight.indexOf('overflowmenu') === -1) { if (buttonsRight.indexOf('overflowmenu') === -1 && this.state.windowWidth >= verySmallThreshold) {
buttonsRight.unshift('overflowmenu'); buttonsRight.unshift('overflowmenu');
} }
@ -1332,7 +1346,7 @@ class Toolbox extends Component<Props, State> {
tooltip = { t('toolbar.invite') } /> } tooltip = { t('toolbar.invite') } /> }
{ buttonsRight.indexOf('security') !== -1 { buttonsRight.indexOf('security') !== -1
&& <SecurityDialogButton customClass = 'security-toolbar-button' /> } && <SecurityDialogButton customClass = 'security-toolbar-button' /> }
{ buttonsRight.indexOf('overflowmenu') !== -1 { buttonsRight.indexOf('overflowmenu') !== -1 && this.state.windowWidth >= verySmallThreshold
&& <OverflowMenuButton && <OverflowMenuButton
isOpen = { _overflowMenuVisible } isOpen = { _overflowMenuVisible }
onVisibilityChange = { this._onSetOverflowVisible }> onVisibilityChange = { this._onSetOverflowVisible }>