ref: TS Improvements (#12358)
Remove unnecessary ts-ignores Remove unnecessary eslint-disable Fix type errors Change Dispatch type to IStore['dispatch']
This commit is contained in:
parent
6365b699c1
commit
6c3206e4d4
|
@ -16,6 +16,7 @@ declare global {
|
||||||
config: IConfig;
|
config: IConfig;
|
||||||
JITSI_MEET_LITE_SDK?: boolean;
|
JITSI_MEET_LITE_SDK?: boolean;
|
||||||
interfaceConfig?: any;
|
interfaceConfig?: any;
|
||||||
|
JitsiMeetJS?: any;
|
||||||
}
|
}
|
||||||
|
|
||||||
const config: IConfig;
|
const config: IConfig;
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
import { IState } from '../app/types';
|
import { IState } from '../app/types';
|
||||||
import {
|
import {
|
||||||
CONFERENCE_JOINED,
|
CONFERENCE_JOINED,
|
||||||
|
|
|
@ -1,11 +1,10 @@
|
||||||
/* eslint-disable lines-around-comment */
|
/* eslint-disable lines-around-comment */
|
||||||
import React, { Component } from 'react';
|
import React, { Component } from 'react';
|
||||||
import { WithTranslation } from 'react-i18next';
|
import { WithTranslation } from 'react-i18next';
|
||||||
import type { Dispatch } from 'redux';
|
|
||||||
|
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import { connect } from '../../../../../connection';
|
import { connect } from '../../../../../connection';
|
||||||
import { IState } from '../../../app/types';
|
import { IState, IStore } from '../../../app/types';
|
||||||
import { IConfig } from '../../../base/config/configType';
|
import { IConfig } from '../../../base/config/configType';
|
||||||
import { toJid } from '../../../base/connection/functions';
|
import { toJid } from '../../../base/connection/functions';
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
|
@ -55,7 +54,7 @@ interface Props extends WithTranslation {
|
||||||
/**
|
/**
|
||||||
* Redux store dispatch method.
|
* Redux store dispatch method.
|
||||||
*/
|
*/
|
||||||
dispatch: Dispatch<any>;
|
dispatch: IStore['dispatch'];
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Invoked when username and password are submitted.
|
* Invoked when username and password are submitted.
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
import { batch } from 'react-redux';
|
import { batch } from 'react-redux';
|
||||||
|
|
||||||
import { APP_WILL_MOUNT, APP_WILL_UNMOUNT } from '../base/app/actionTypes';
|
import { APP_WILL_MOUNT, APP_WILL_UNMOUNT } from '../base/app/actionTypes';
|
||||||
|
@ -19,6 +18,7 @@ import StateListenerRegistry from '../base/redux/StateListenerRegistry';
|
||||||
import { playSound, registerSound, unregisterSound } from '../base/sounds/actions';
|
import { playSound, registerSound, unregisterSound } from '../base/sounds/actions';
|
||||||
import { hideNotification, showNotification } from '../notifications/actions';
|
import { hideNotification, showNotification } from '../notifications/actions';
|
||||||
import { NOTIFICATION_TIMEOUT_TYPE } from '../notifications/constants';
|
import { NOTIFICATION_TIMEOUT_TYPE } from '../notifications/constants';
|
||||||
|
// eslint-disable-next-line lines-around-comment
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import { muteLocal } from '../video-menu/actions.any';
|
import { muteLocal } from '../video-menu/actions.any';
|
||||||
|
|
||||||
|
|
|
@ -1,10 +1,8 @@
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
import type { Dispatch } from 'redux';
|
|
||||||
|
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import UIEvents from '../../../../service/UI/UIEvents';
|
import UIEvents from '../../../../service/UI/UIEvents';
|
||||||
import { createAudioOnlyChangedEvent } from '../../analytics/AnalyticsEvents';
|
import { createAudioOnlyChangedEvent } from '../../analytics/AnalyticsEvents';
|
||||||
import { sendAnalytics } from '../../analytics/functions';
|
import { sendAnalytics } from '../../analytics/functions';
|
||||||
|
import { IStore } from '../../app/types';
|
||||||
|
|
||||||
import { SET_AUDIO_ONLY } from './actionTypes';
|
import { SET_AUDIO_ONLY } from './actionTypes';
|
||||||
import logger from './logger';
|
import logger from './logger';
|
||||||
|
@ -22,7 +20,7 @@ declare let APP: any;
|
||||||
* }}
|
* }}
|
||||||
*/
|
*/
|
||||||
export function setAudioOnly(audioOnly: boolean) {
|
export function setAudioOnly(audioOnly: boolean) {
|
||||||
return (dispatch: Dispatch<any>, getState: Function) => {
|
return (dispatch: IStore['dispatch'], getState: IStore['getState']) => {
|
||||||
const { enabled: oldValue } = getState()['features/base/audio-only'];
|
const { enabled: oldValue } = getState()['features/base/audio-only'];
|
||||||
|
|
||||||
if (oldValue !== audioOnly) {
|
if (oldValue !== audioOnly) {
|
||||||
|
@ -49,7 +47,7 @@ export function setAudioOnly(audioOnly: boolean) {
|
||||||
* @returns {Function}
|
* @returns {Function}
|
||||||
*/
|
*/
|
||||||
export function toggleAudioOnly() {
|
export function toggleAudioOnly() {
|
||||||
return (dispatch: Dispatch<any>, getState: Function) => {
|
return (dispatch: IStore['dispatch'], getState: IStore['getState']) => {
|
||||||
const { enabled } = getState()['features/base/audio-only'];
|
const { enabled } = getState()['features/base/audio-only'];
|
||||||
|
|
||||||
return dispatch(setAudioOnly(!enabled));
|
return dispatch(setAudioOnly(!enabled));
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
import { LOCKED_LOCALLY, LOCKED_REMOTELY } from '../../room-lock/constants';
|
import { LOCKED_LOCALLY, LOCKED_REMOTELY } from '../../room-lock/constants';
|
||||||
import { CONNECTION_WILL_CONNECT, SET_LOCATION_URL } from '../connection/actionTypes';
|
import { CONNECTION_WILL_CONNECT, SET_LOCATION_URL } from '../connection/actionTypes';
|
||||||
import { JitsiConferenceErrors } from '../lib-jitsi-meet';
|
import { JitsiConferenceErrors } from '../lib-jitsi-meet';
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import { jitsiLocalStorage } from '@jitsi/js-utils';
|
import { jitsiLocalStorage } from '@jitsi/js-utils';
|
||||||
import { Dispatch } from 'redux';
|
|
||||||
|
|
||||||
|
import { IStore } from '../../app/types';
|
||||||
import { addKnownDomains } from '../known-domains/actions';
|
import { addKnownDomains } from '../known-domains/actions';
|
||||||
import { parseURIString } from '../util/uri';
|
import { parseURIString } from '../util/uri';
|
||||||
|
|
||||||
|
@ -99,7 +99,7 @@ export function overwriteConfig(config: Object) {
|
||||||
* @returns {Function}
|
* @returns {Function}
|
||||||
*/
|
*/
|
||||||
export function setConfig(config: Object = {}) {
|
export function setConfig(config: Object = {}) {
|
||||||
return (dispatch: Dispatch<any>, getState: Function) => {
|
return (dispatch: IStore['dispatch'], getState: IStore['getState']) => {
|
||||||
const { locationURL } = getState()['features/base/connection'];
|
const { locationURL } = getState()['features/base/connection'];
|
||||||
|
|
||||||
// Now that the loading of the config was successful override the values
|
// Now that the loading of the config was successful override the values
|
||||||
|
@ -135,7 +135,7 @@ export function setConfig(config: Object = {}) {
|
||||||
* @returns {Function}
|
* @returns {Function}
|
||||||
*/
|
*/
|
||||||
export function storeConfig(baseURL: string, config: Object) {
|
export function storeConfig(baseURL: string, config: Object) {
|
||||||
return (dispatch: Dispatch<any>) => {
|
return (dispatch: IStore['dispatch']) => {
|
||||||
// Try to store the configuration in localStorage. If the deployment
|
// Try to store the configuration in localStorage. If the deployment
|
||||||
// specified 'getroom' as a function, for example, it does not make
|
// specified 'getroom' as a function, for example, it does not make
|
||||||
// sense to and it will not be stored.
|
// sense to and it will not be stored.
|
||||||
|
|
|
@ -1,6 +1,5 @@
|
||||||
/* eslint-disable lines-around-comment */
|
import { IStore } from '../../app/types';
|
||||||
import { Dispatch } from 'redux';
|
// eslint-disable-next-line lines-around-comment
|
||||||
|
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import { conferenceLeft, conferenceWillLeave } from '../conference/actions';
|
import { conferenceLeft, conferenceWillLeave } from '../conference/actions';
|
||||||
import { getCurrentConference } from '../conference/functions';
|
import { getCurrentConference } from '../conference/functions';
|
||||||
|
@ -74,7 +73,7 @@ export type ConnectionFailedError = {
|
||||||
* @returns {Function}
|
* @returns {Function}
|
||||||
*/
|
*/
|
||||||
export function connect(id?: string, password?: string) {
|
export function connect(id?: string, password?: string) {
|
||||||
return (dispatch: Dispatch<any>, getState: Function) => {
|
return (dispatch: IStore['dispatch'], getState: IStore['getState']) => {
|
||||||
const state = getState();
|
const state = getState();
|
||||||
const options = constructOptions(state);
|
const options = constructOptions(state);
|
||||||
const { locationURL } = state['features/base/connection'];
|
const { locationURL } = state['features/base/connection'];
|
||||||
|
@ -266,7 +265,7 @@ function _connectionWillConnect(connection: Object) {
|
||||||
* @returns {Function}
|
* @returns {Function}
|
||||||
*/
|
*/
|
||||||
export function disconnect() {
|
export function disconnect() {
|
||||||
return (dispatch: Dispatch<any>, getState: Function): Promise<void> => {
|
return (dispatch: IStore['dispatch'], getState: IStore['getState']): Promise<void> => {
|
||||||
const state = getState();
|
const state = getState();
|
||||||
|
|
||||||
// The conference we have already joined or are joining.
|
// The conference we have already joined or are joining.
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
import { SET_ROOM } from '../conference/actionTypes';
|
import { SET_ROOM } from '../conference/actionTypes';
|
||||||
import { JitsiConnectionErrors } from '../lib-jitsi-meet';
|
import { JitsiConnectionErrors } from '../lib-jitsi-meet';
|
||||||
import ReducerRegistry from '../redux/ReducerRegistry';
|
import ReducerRegistry from '../redux/ReducerRegistry';
|
||||||
|
@ -15,8 +14,9 @@ import {
|
||||||
import { ConnectionFailedError } from './actions.native';
|
import { ConnectionFailedError } from './actions.native';
|
||||||
|
|
||||||
export interface IConnectionState {
|
export interface IConnectionState {
|
||||||
connecting?: Object;
|
connecting?: any;
|
||||||
connection?: {
|
connection?: {
|
||||||
|
disconnect: Function;
|
||||||
getJid: () => string;
|
getJid: () => string;
|
||||||
getLogs: () => Object;
|
getLogs: () => Object;
|
||||||
};
|
};
|
||||||
|
|
|
@ -1,15 +1,14 @@
|
||||||
import { AnyAction } from 'redux';
|
import { AnyAction } from 'redux';
|
||||||
|
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import UIEvents from '../../../../service/UI/UIEvents';
|
import UIEvents from '../../../../service/UI/UIEvents';
|
||||||
import { IStore } from '../../app/types';
|
import { IStore } from '../../app/types';
|
||||||
import { processExternalDeviceRequest } from '../../device-selection/functions';
|
import { processExternalDeviceRequest } from '../../device-selection/functions';
|
||||||
import { showNotification, showWarningNotification } from '../../notifications/actions';
|
import { showNotification, showWarningNotification } from '../../notifications/actions';
|
||||||
import { NOTIFICATION_TIMEOUT_TYPE } from '../../notifications/constants';
|
import { NOTIFICATION_TIMEOUT_TYPE } from '../../notifications/constants';
|
||||||
|
// eslint-disable-next-line lines-around-comment
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import { replaceAudioTrackById, replaceVideoTrackById, setDeviceStatusWarning } from '../../prejoin/actions';
|
import { replaceAudioTrackById, replaceVideoTrackById, setDeviceStatusWarning } from '../../prejoin/actions';
|
||||||
// @ts-ignore
|
|
||||||
import { isPrejoinPageVisible } from '../../prejoin/functions';
|
import { isPrejoinPageVisible } from '../../prejoin/functions';
|
||||||
import { APP_WILL_MOUNT, APP_WILL_UNMOUNT } from '../app/actionTypes';
|
import { APP_WILL_MOUNT, APP_WILL_UNMOUNT } from '../app/actionTypes';
|
||||||
import JitsiMeetJS, { JitsiMediaDevicesEvents, JitsiTrackErrors } from '../lib-jitsi-meet';
|
import JitsiMeetJS, { JitsiMediaDevicesEvents, JitsiTrackErrors } from '../lib-jitsi-meet';
|
||||||
|
|
|
@ -1,5 +1,4 @@
|
||||||
// @ts-ignore
|
import { getAppProp } from '../app/functions';
|
||||||
import { getAppProp } from '../app';
|
|
||||||
import { IStateful } from '../app/types';
|
import { IStateful } from '../app/types';
|
||||||
import { toState } from '../redux/functions';
|
import { toState } from '../redux/functions';
|
||||||
|
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
import {
|
import {
|
||||||
SET_CONFIG
|
SET_CONFIG
|
||||||
} from '../config/actionTypes';
|
} from '../config/actionTypes';
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import { jitsiLocalStorage } from '@jitsi/js-utils';
|
import { jitsiLocalStorage } from '@jitsi/js-utils';
|
||||||
|
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import Logger from '@jitsi/logger';
|
import Logger from '@jitsi/logger';
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,4 @@
|
||||||
import { Dispatch } from 'redux';
|
import { IStore } from '../../app/types';
|
||||||
|
|
||||||
import { showModeratedNotification } from '../../av-moderation/actions';
|
import { showModeratedNotification } from '../../av-moderation/actions';
|
||||||
import { shouldShowModeratedNotification } from '../../av-moderation/functions';
|
import { shouldShowModeratedNotification } from '../../av-moderation/functions';
|
||||||
import { isModerationNotificationDisplayed } from '../../notifications/functions';
|
import { isModerationNotificationDisplayed } from '../../notifications/functions';
|
||||||
|
@ -106,7 +105,7 @@ export function setScreenshareMuted(
|
||||||
mediaType: MediaType = MEDIA_TYPE.SCREENSHARE,
|
mediaType: MediaType = MEDIA_TYPE.SCREENSHARE,
|
||||||
authority: number = SCREENSHARE_MUTISM_AUTHORITY.USER,
|
authority: number = SCREENSHARE_MUTISM_AUTHORITY.USER,
|
||||||
ensureTrack = false) {
|
ensureTrack = false) {
|
||||||
return (dispatch: Dispatch<any>, getState: Function) => {
|
return (dispatch: IStore['dispatch'], getState: IStore['getState']) => {
|
||||||
const state = getState();
|
const state = getState();
|
||||||
|
|
||||||
// check for A/V Moderation when trying to unmute
|
// check for A/V Moderation when trying to unmute
|
||||||
|
@ -167,7 +166,7 @@ export function setVideoMuted(
|
||||||
mediaType: string = MEDIA_TYPE.VIDEO,
|
mediaType: string = MEDIA_TYPE.VIDEO,
|
||||||
authority: number = VIDEO_MUTISM_AUTHORITY.USER,
|
authority: number = VIDEO_MUTISM_AUTHORITY.USER,
|
||||||
ensureTrack = false) {
|
ensureTrack = false) {
|
||||||
return (dispatch: Dispatch<any>, getState: Function) => {
|
return (dispatch: IStore['dispatch'], getState: IStore['getState']) => {
|
||||||
const state = getState();
|
const state = getState();
|
||||||
|
|
||||||
// check for A/V Moderation when trying to unmute
|
// check for A/V Moderation when trying to unmute
|
||||||
|
|
|
@ -1,14 +1,13 @@
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
import './middleware.any.js';
|
import './middleware.any.js';
|
||||||
|
|
||||||
import { IStore } from '../../app/types';
|
import { IStore } from '../../app/types';
|
||||||
import { showNotification } from '../../notifications/actions';
|
import { showNotification } from '../../notifications/actions';
|
||||||
import { NOTIFICATION_TIMEOUT_TYPE } from '../../notifications/constants';
|
import { NOTIFICATION_TIMEOUT_TYPE } from '../../notifications/constants';
|
||||||
import LocalRecordingManager from '../../recording/components/Recording/LocalRecordingManager.web';
|
import LocalRecordingManager from '../../recording/components/Recording/LocalRecordingManager.web';
|
||||||
|
// eslint-disable-next-line lines-around-comment
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import StopRecordingDialog from '../../recording/components/Recording/web/StopRecordingDialog';
|
import StopRecordingDialog from '../../recording/components/Recording/web/StopRecordingDialog';
|
||||||
// @ts-ignore
|
import { openDialog } from '../dialog/actions';
|
||||||
import { openDialog } from '../dialog';
|
|
||||||
import MiddlewareRegistry from '../redux/MiddlewareRegistry';
|
import MiddlewareRegistry from '../redux/MiddlewareRegistry';
|
||||||
|
|
||||||
import { SET_VIDEO_MUTED } from './actionTypes';
|
import { SET_VIDEO_MUTED } from './actionTypes';
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
import {
|
import {
|
||||||
SCREEN_SHARE_REMOTE_PARTICIPANTS_UPDATED
|
SCREEN_SHARE_REMOTE_PARTICIPANTS_UPDATED
|
||||||
} from '../../video-layout/actionTypes';
|
} from '../../video-layout/actionTypes';
|
||||||
|
@ -311,6 +310,7 @@ ReducerRegistry.register<IParticipantsState>('features/base/participants',
|
||||||
|
|
||||||
state.sortedRemoteVirtualScreenshareParticipants = new Map(sortedRemoteVirtualScreenshareParticipants);
|
state.sortedRemoteVirtualScreenshareParticipants = new Map(sortedRemoteVirtualScreenshareParticipants);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Exclude the screenshare participant from the fake participant count to avoid duplicates.
|
// Exclude the screenshare participant from the fake participant count to avoid duplicates.
|
||||||
if (fakeParticipant && !isScreenShareParticipant(participant)) {
|
if (fakeParticipant && !isScreenShareParticipant(participant)) {
|
||||||
state.fakeParticipants.set(id, participant);
|
state.fakeParticipants.set(id, participant);
|
||||||
|
@ -402,6 +402,7 @@ ReducerRegistry.register<IParticipantsState>('features/base/participants',
|
||||||
|
|
||||||
// Keep the remote screen share list sorted alphabetically.
|
// Keep the remote screen share list sorted alphabetically.
|
||||||
sortedSharesList.length && sortedSharesList.sort((a, b) => a[1].localeCompare(b[1]));
|
sortedSharesList.length && sortedSharesList.sort((a, b) => a[1].localeCompare(b[1]));
|
||||||
|
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
state.sortedRemoteScreenshares = new Map(sortedSharesList);
|
state.sortedRemoteScreenshares = new Map(sortedSharesList);
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,3 @@
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
|
|
||||||
import { Theme } from '@mui/material';
|
import { Theme } from '@mui/material';
|
||||||
import React, { useCallback, useState } from 'react';
|
import React, { useCallback, useState } from 'react';
|
||||||
import { WithTranslation } from 'react-i18next';
|
import { WithTranslation } from 'react-i18next';
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import { TouchableRipple } from 'react-native-paper';
|
import { TouchableRipple } from 'react-native-paper';
|
||||||
|
|
||||||
|
@ -50,6 +49,7 @@ const IconButton: React.FC<IconButtonProps> = ({
|
||||||
<TouchableRipple
|
<TouchableRipple
|
||||||
accessibilityLabel = { accessibilityLabel }
|
accessibilityLabel = { accessibilityLabel }
|
||||||
disabled = { disabled }
|
disabled = { disabled }
|
||||||
|
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
onPress = { onPress }
|
onPress = { onPress }
|
||||||
rippleColor = { rippleColor }
|
rippleColor = { rippleColor }
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import { jitsiLocalStorage } from '@jitsi/js-utils';
|
import { jitsiLocalStorage } from '@jitsi/js-utils';
|
||||||
import _ from 'lodash';
|
import _ from 'lodash';
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import type { AudioElement } from '../media';
|
import type { AudioElement } from '../media';
|
||||||
import ReducerRegistry from '../redux/ReducerRegistry';
|
import ReducerRegistry from '../redux/ReducerRegistry';
|
||||||
|
|
|
@ -2,9 +2,7 @@ import { IState, IStore } from '../../app/types';
|
||||||
import { getMultipleVideoSupportFeatureFlag } from '../config/functions.any';
|
import { getMultipleVideoSupportFeatureFlag } from '../config/functions.any';
|
||||||
import { MEDIA_TYPE, VIDEO_TYPE } from '../media/constants';
|
import { MEDIA_TYPE, VIDEO_TYPE } from '../media/constants';
|
||||||
import { getParticipantById, isScreenShareParticipant } from '../participants/functions';
|
import { getParticipantById, isScreenShareParticipant } from '../participants/functions';
|
||||||
// eslint-disable-next-line lines-around-comment
|
import { getTrackByMediaTypeAndParticipant, getVirtualScreenshareParticipantTrack } from '../tracks/functions';
|
||||||
// @ts-ignore
|
|
||||||
import { getTrackByMediaTypeAndParticipant, getVirtualScreenshareParticipantTrack } from '../tracks';
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Indicates whether the test mode is enabled. When it's enabled
|
* Indicates whether the test mode is enabled. When it's enabled
|
||||||
|
@ -46,7 +44,7 @@ export function getRemoteVideoType({ getState }: IStore, id: string) {
|
||||||
*/
|
*/
|
||||||
export function isLargeVideoReceived({ getState }: IStore): boolean {
|
export function isLargeVideoReceived({ getState }: IStore): boolean {
|
||||||
const state = getState();
|
const state = getState();
|
||||||
const largeVideoParticipantId = state['features/large-video'].participantId;
|
const largeVideoParticipantId = state['features/large-video'].participantId ?? '';
|
||||||
const largeVideoParticipant = getParticipantById(state, largeVideoParticipantId ?? '');
|
const largeVideoParticipant = getParticipantById(state, largeVideoParticipantId ?? '');
|
||||||
const tracks = state['features/base/tracks'];
|
const tracks = state['features/base/tracks'];
|
||||||
let videoTrack;
|
let videoTrack;
|
||||||
|
@ -59,7 +57,8 @@ export function isLargeVideoReceived({ getState }: IStore): boolean {
|
||||||
|
|
||||||
const lastMediaEvent = state['features/large-video']?.lastMediaEvent;
|
const lastMediaEvent = state['features/large-video']?.lastMediaEvent;
|
||||||
|
|
||||||
return videoTrack && !videoTrack.muted && (lastMediaEvent === 'playing' || lastMediaEvent === 'canplaythrough');
|
return Boolean(videoTrack && !videoTrack.muted
|
||||||
|
&& (lastMediaEvent === 'playing' || lastMediaEvent === 'canplaythrough'));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -82,5 +81,6 @@ export function isRemoteVideoReceived({ getState }: IStore, id: string): boolean
|
||||||
}
|
}
|
||||||
const lastMediaEvent = videoTrack?.lastMediaEvent;
|
const lastMediaEvent = videoTrack?.lastMediaEvent;
|
||||||
|
|
||||||
return videoTrack && !videoTrack.muted && (lastMediaEvent === 'playing' || lastMediaEvent === 'canplaythrough');
|
return Boolean(videoTrack && !videoTrack.muted
|
||||||
|
&& (lastMediaEvent === 'playing' || lastMediaEvent === 'canplaythrough'));
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import { useTranslation } from 'react-i18next';
|
import { useTranslation } from 'react-i18next';
|
||||||
import {
|
import {
|
||||||
|
@ -95,6 +94,7 @@ const Button: React.FC<IButtonProps> = ({
|
||||||
contentStyle
|
contentStyle
|
||||||
] }
|
] }
|
||||||
disabled = { disabled }
|
disabled = { disabled }
|
||||||
|
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
icon = { icon }
|
icon = { icon }
|
||||||
labelStyle = { [
|
labelStyle = { [
|
||||||
|
|
|
@ -1,14 +1,12 @@
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
|
|
||||||
import { Theme } from '@mui/material';
|
import { Theme } from '@mui/material';
|
||||||
import React, { ReactNode, useEffect, useLayoutEffect, useRef, useState } from 'react';
|
import React, { ReactNode, useEffect, useLayoutEffect, useRef, useState } from 'react';
|
||||||
import { useSelector } from 'react-redux';
|
import { useSelector } from 'react-redux';
|
||||||
import { makeStyles } from 'tss-react/mui';
|
import { makeStyles } from 'tss-react/mui';
|
||||||
|
|
||||||
import { getComputedOuterHeight } from '../../../../participants-pane/functions';
|
import { getComputedOuterHeight } from '../../../../participants-pane/functions';
|
||||||
|
// eslint-disable-next-line lines-around-comment
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import { Drawer, JitsiPortal } from '../../../../toolbox/components/web';
|
import { Drawer, JitsiPortal } from '../../../../toolbox/components/web';
|
||||||
// @ts-ignore
|
|
||||||
import { showOverflowDrawer } from '../../../../toolbox/functions.web';
|
import { showOverflowDrawer } from '../../../../toolbox/functions.web';
|
||||||
import participantsPaneTheme from '../../../components/themes/participantsPaneTheme.json';
|
import participantsPaneTheme from '../../../components/themes/participantsPaneTheme.json';
|
||||||
import { withPixelLineHeight } from '../../../styles/functions.web';
|
import { withPixelLineHeight } from '../../../styles/functions.web';
|
||||||
|
|
|
@ -3,7 +3,6 @@ import React, { ReactNode } from 'react';
|
||||||
import { useSelector } from 'react-redux';
|
import { useSelector } from 'react-redux';
|
||||||
import { makeStyles } from 'tss-react/mui';
|
import { makeStyles } from 'tss-react/mui';
|
||||||
|
|
||||||
// @ts-ignore
|
|
||||||
import { showOverflowDrawer } from '../../../../toolbox/functions.web';
|
import { showOverflowDrawer } from '../../../../toolbox/functions.web';
|
||||||
import Icon from '../../../icons/components/Icon';
|
import Icon from '../../../icons/components/Icon';
|
||||||
import { withPixelLineHeight } from '../../../styles/functions.web';
|
import { withPixelLineHeight } from '../../../styles/functions.web';
|
||||||
|
|
|
@ -84,19 +84,14 @@ export function getBaseUrl(w: Window = window) {
|
||||||
* NOTE: After React-ifying everything this should be the only global.
|
* NOTE: After React-ifying everything this should be the only global.
|
||||||
*/
|
*/
|
||||||
export function getJitsiMeetGlobalNS() {
|
export function getJitsiMeetGlobalNS() {
|
||||||
// @ts-ignore
|
|
||||||
if (!window.JitsiMeetJS) {
|
if (!window.JitsiMeetJS) {
|
||||||
// @ts-ignore
|
|
||||||
window.JitsiMeetJS = {};
|
window.JitsiMeetJS = {};
|
||||||
}
|
}
|
||||||
|
|
||||||
// @ts-ignore
|
|
||||||
if (!window.JitsiMeetJS.app) {
|
if (!window.JitsiMeetJS.app) {
|
||||||
// @ts-ignore
|
|
||||||
window.JitsiMeetJS.app = {};
|
window.JitsiMeetJS.app = {};
|
||||||
}
|
}
|
||||||
|
|
||||||
// @ts-ignore
|
|
||||||
return window.JitsiMeetJS.app;
|
return window.JitsiMeetJS.app;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,5 @@
|
||||||
import { Linking } from 'react-native';
|
import { Linking } from 'react-native';
|
||||||
|
|
||||||
// @ts-ignore
|
|
||||||
import logger from './logger';
|
import logger from './logger';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -8,16 +8,12 @@ import { IStore } from '../app/types';
|
||||||
import {
|
import {
|
||||||
conferenceLeft,
|
conferenceLeft,
|
||||||
conferenceWillLeave,
|
conferenceWillLeave,
|
||||||
createConference,
|
createConference
|
||||||
getCurrentConference
|
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
} from '../base/conference';
|
} from '../base/conference/actions';
|
||||||
import { CONFERENCE_LEAVE_REASONS } from '../base/conference/constants';
|
import { CONFERENCE_LEAVE_REASONS } from '../base/conference/constants';
|
||||||
import {
|
import { getCurrentConference } from '../base/conference/functions';
|
||||||
setAudioMuted,
|
import { setAudioMuted, setVideoMuted } from '../base/media/actions';
|
||||||
setVideoMuted
|
|
||||||
// @ts-ignore
|
|
||||||
} from '../base/media';
|
|
||||||
import { MEDIA_TYPE } from '../base/media/constants';
|
import { MEDIA_TYPE } from '../base/media/constants';
|
||||||
import { getRemoteParticipants } from '../base/participants/functions';
|
import { getRemoteParticipants } from '../base/participants/functions';
|
||||||
import {
|
import {
|
||||||
|
@ -230,7 +226,7 @@ export function moveToRoom(roomId?: string) {
|
||||||
// dispatch(setRoom(_roomId));
|
// dispatch(setRoom(_roomId));
|
||||||
dispatch(createConference(_roomId));
|
dispatch(createConference(_roomId));
|
||||||
dispatch(setAudioMuted(audio.muted));
|
dispatch(setAudioMuted(audio.muted));
|
||||||
dispatch(setVideoMuted(video.muted));
|
dispatch(setVideoMuted(Boolean(video.muted)));
|
||||||
dispatch(createDesiredLocalTracks());
|
dispatch(createDesiredLocalTracks());
|
||||||
} else {
|
} else {
|
||||||
const localTracks = getLocalTracks(getState()['features/base/tracks']);
|
const localTracks = getLocalTracks(getState()['features/base/tracks']);
|
||||||
|
|
|
@ -1,9 +1,7 @@
|
||||||
import _ from 'lodash';
|
import _ from 'lodash';
|
||||||
|
|
||||||
import { IStateful } from '../base/app/types';
|
import { IStateful } from '../base/app/types';
|
||||||
// eslint-disable-next-line lines-around-comment
|
import { getCurrentConference } from '../base/conference/functions';
|
||||||
// @ts-ignore
|
|
||||||
import { getCurrentConference } from '../base/conference';
|
|
||||||
import { getParticipantById, getParticipantCount, isLocalParticipantModerator } from '../base/participants/functions';
|
import { getParticipantById, getParticipantCount, isLocalParticipantModerator } from '../base/participants/functions';
|
||||||
import { toState } from '../base/redux/functions';
|
import { toState } from '../base/redux/functions';
|
||||||
|
|
||||||
|
|
|
@ -2,9 +2,7 @@ import { JitsiConferenceEvents } from '../base/lib-jitsi-meet';
|
||||||
import { getParticipantById } from '../base/participants/functions';
|
import { getParticipantById } from '../base/participants/functions';
|
||||||
import MiddlewareRegistry from '../base/redux/MiddlewareRegistry';
|
import MiddlewareRegistry from '../base/redux/MiddlewareRegistry';
|
||||||
import StateListenerRegistry from '../base/redux/StateListenerRegistry';
|
import StateListenerRegistry from '../base/redux/StateListenerRegistry';
|
||||||
// eslint-disable-next-line lines-around-comment
|
import { editMessage } from '../chat/actions.any';
|
||||||
// @ts-ignore
|
|
||||||
import { editMessage } from '../chat';
|
|
||||||
import { MESSAGE_TYPE_REMOTE } from '../chat/constants';
|
import { MESSAGE_TYPE_REMOTE } from '../chat/constants';
|
||||||
|
|
||||||
import { UPDATE_BREAKOUT_ROOMS } from './actionTypes';
|
import { UPDATE_BREAKOUT_ROOMS } from './actionTypes';
|
||||||
|
|
|
@ -1,16 +1,13 @@
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
import React, { Component, RefObject } from 'react';
|
import React, { Component, RefObject } from 'react';
|
||||||
import { WithTranslation } from 'react-i18next';
|
import { WithTranslation } from 'react-i18next';
|
||||||
import type { Dispatch } from 'redux';
|
|
||||||
|
|
||||||
import { IState } from '../../../app/types';
|
import { IState, IStore } from '../../../app/types';
|
||||||
import { isMobileBrowser } from '../../../base/environment/utils';
|
import { isMobileBrowser } from '../../../base/environment/utils';
|
||||||
import { translate } from '../../../base/i18n/functions';
|
import { translate } from '../../../base/i18n/functions';
|
||||||
import { IconPlane, IconSmile } from '../../../base/icons/svg';
|
import { IconPlane, IconSmile } from '../../../base/icons/svg';
|
||||||
import { connect } from '../../../base/redux/functions';
|
import { connect } from '../../../base/redux/functions';
|
||||||
import Button from '../../../base/ui/components/web/Button';
|
import Button from '../../../base/ui/components/web/Button';
|
||||||
import Input from '../../../base/ui/components/web/Input';
|
import Input from '../../../base/ui/components/web/Input';
|
||||||
// @ts-ignore
|
|
||||||
import { areSmileysDisabled } from '../../functions';
|
import { areSmileysDisabled } from '../../functions';
|
||||||
|
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
|
@ -29,7 +26,7 @@ interface Props extends WithTranslation {
|
||||||
/**
|
/**
|
||||||
* Invoked to send chat messages.
|
* Invoked to send chat messages.
|
||||||
*/
|
*/
|
||||||
dispatch: Dispatch<any>;
|
dispatch: IStore['dispatch'];
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Callback to invoke on message send.
|
* Callback to invoke on message send.
|
||||||
|
|
|
@ -1,12 +1,10 @@
|
||||||
import React, { Component } from 'react';
|
import React, { Component } from 'react';
|
||||||
import { WithTranslation } from 'react-i18next';
|
import { WithTranslation } from 'react-i18next';
|
||||||
import type { Dispatch } from 'redux';
|
|
||||||
|
|
||||||
|
import { IStore } from '../../../app/types';
|
||||||
import { translate } from '../../../base/i18n/functions';
|
import { translate } from '../../../base/i18n/functions';
|
||||||
import { connect } from '../../../base/redux/functions';
|
import { connect } from '../../../base/redux/functions';
|
||||||
// eslint-disable-next-line lines-around-comment
|
import { updateSettings } from '../../../base/settings/actions';
|
||||||
// @ts-ignore
|
|
||||||
import { updateSettings } from '../../../base/settings';
|
|
||||||
import { Button } from '../../../base/ui/components/web';
|
import { Button } from '../../../base/ui/components/web';
|
||||||
import Input from '../../../base/ui/components/web/Input';
|
import Input from '../../../base/ui/components/web/Input';
|
||||||
|
|
||||||
|
@ -21,7 +19,7 @@ interface Props extends WithTranslation {
|
||||||
/**
|
/**
|
||||||
* Invoked to set the local participant display name.
|
* Invoked to set the local participant display name.
|
||||||
*/
|
*/
|
||||||
dispatch: Dispatch<any>;
|
dispatch: IStore['dispatch'];
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Whether the polls feature is enabled or not.
|
* Whether the polls feature is enabled or not.
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
import throttle from 'lodash/throttle';
|
import throttle from 'lodash/throttle';
|
||||||
import React, { RefObject } from 'react';
|
import React, { RefObject } from 'react';
|
||||||
import { scrollIntoView } from 'seamless-scroll-polyfill';
|
import { scrollIntoView } from 'seamless-scroll-polyfill';
|
||||||
|
@ -11,14 +10,17 @@ import ChatMessageGroup from './ChatMessageGroup';
|
||||||
import NewMessagesButton from './NewMessagesButton';
|
import NewMessagesButton from './NewMessagesButton';
|
||||||
|
|
||||||
interface State {
|
interface State {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Whether or not message container has received new messages.
|
* Whether or not message container has received new messages.
|
||||||
*/
|
*/
|
||||||
hasNewMessages: boolean;
|
hasNewMessages: boolean;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Whether or not scroll position is at the bottom of container.
|
* Whether or not scroll position is at the bottom of container.
|
||||||
*/
|
*/
|
||||||
isScrolledToBottom: boolean;
|
isScrolledToBottom: boolean;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The id of the last read message.
|
* The id of the last read message.
|
||||||
*/
|
*/
|
||||||
|
@ -275,6 +277,7 @@ export default class MessageContainer extends AbstractMessageContainer<Props, St
|
||||||
*/
|
*/
|
||||||
_findFirstUnreadMessage() {
|
_findFirstUnreadMessage() {
|
||||||
const messagesNodeList = document.querySelectorAll('.chatmessage-wrapper');
|
const messagesNodeList = document.querySelectorAll('.chatmessage-wrapper');
|
||||||
|
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
const messagesToArray = [ ...messagesNodeList ];
|
const messagesToArray = [ ...messagesNodeList ];
|
||||||
|
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
|
|
||||||
import Icon from '../../../../base/icons/components/Icon';
|
import Icon from '../../../../base/icons/components/Icon';
|
||||||
|
|
|
@ -1,10 +1,10 @@
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import { useTranslation } from 'react-i18next';
|
import { useTranslation } from 'react-i18next';
|
||||||
import { Text, View } from 'react-native';
|
import { Text, View } from 'react-native';
|
||||||
|
|
||||||
import EndMeetingButton from './EndMeetingButton';
|
import EndMeetingButton from './EndMeetingButton';
|
||||||
import SoundDeviceButton from './SoundDeviceButton';
|
import SoundDeviceButton from './SoundDeviceButton';
|
||||||
|
// eslint-disable-next-line lines-around-comment
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import styles from './styles';
|
import styles from './styles';
|
||||||
|
|
||||||
|
|
|
@ -10,14 +10,12 @@ import {
|
||||||
} from '../../../../analytics/AnalyticsEvents';
|
} from '../../../../analytics/AnalyticsEvents';
|
||||||
import { sendAnalytics } from '../../../../analytics/functions';
|
import { sendAnalytics } from '../../../../analytics/functions';
|
||||||
import { IState } from '../../../../app/types';
|
import { IState } from '../../../../app/types';
|
||||||
// @ts-ignore
|
import { AUDIO_MUTE_BUTTON_ENABLED } from '../../../../base/flags/constants';
|
||||||
import { AUDIO_MUTE_BUTTON_ENABLED, getFeatureFlag } from '../../../../base/flags';
|
import { getFeatureFlag } from '../../../../base/flags/functions';
|
||||||
import Icon from '../../../../base/icons/components/Icon';
|
import Icon from '../../../../base/icons/components/Icon';
|
||||||
import { IconMicrophone, IconMicrophoneEmptySlash } from '../../../../base/icons/svg';
|
import { IconMicrophone, IconMicrophoneEmptySlash } from '../../../../base/icons/svg';
|
||||||
import { MEDIA_TYPE } from '../../../../base/media/constants';
|
import { MEDIA_TYPE } from '../../../../base/media/constants';
|
||||||
// @ts-ignore
|
import { isLocalTrackMuted } from '../../../../base/tracks/functions';
|
||||||
import { isLocalTrackMuted } from '../../../../base/tracks';
|
|
||||||
// @ts-ignore
|
|
||||||
import { isAudioMuteButtonDisabled } from '../../../../toolbox/functions.any';
|
import { isAudioMuteButtonDisabled } from '../../../../toolbox/functions.any';
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import { muteLocal } from '../../../../video-menu/actions';
|
import { muteLocal } from '../../../../video-menu/actions';
|
||||||
|
@ -37,7 +35,7 @@ const MicrophoneButton = (): JSX.Element | null => {
|
||||||
const audioMuted = useSelector((state: IState) => isLocalTrackMuted(state['features/base/tracks'],
|
const audioMuted = useSelector((state: IState) => isLocalTrackMuted(state['features/base/tracks'],
|
||||||
MEDIA_TYPE.AUDIO));
|
MEDIA_TYPE.AUDIO));
|
||||||
const disabled = useSelector(isAudioMuteButtonDisabled);
|
const disabled = useSelector(isAudioMuteButtonDisabled);
|
||||||
const enabledFlag = useSelector(state => getFeatureFlag(state, AUDIO_MUTE_BUTTON_ENABLED, true));
|
const enabledFlag = useSelector((state: IState) => getFeatureFlag(state, AUDIO_MUTE_BUTTON_ENABLED, true));
|
||||||
const [ longPress, setLongPress ] = useState(false);
|
const [ longPress, setLongPress ] = useState(false);
|
||||||
|
|
||||||
if (!enabledFlag) {
|
if (!enabledFlag) {
|
||||||
|
|
|
@ -2,7 +2,6 @@
|
||||||
import React, { useCallback } from 'react';
|
import React, { useCallback } from 'react';
|
||||||
import { useDispatch } from 'react-redux';
|
import { useDispatch } from 'react-redux';
|
||||||
|
|
||||||
// @ts-ignore
|
|
||||||
import { openSheet } from '../../../../base/dialog/actions';
|
import { openSheet } from '../../../../base/dialog/actions';
|
||||||
import Button from '../../../../base/ui/components/native/Button';
|
import Button from '../../../../base/ui/components/native/Button';
|
||||||
import { BUTTON_TYPES } from '../../../../base/ui/constants';
|
import { BUTTON_TYPES } from '../../../../base/ui/constants';
|
||||||
|
|
|
@ -4,11 +4,9 @@ import { StyleProp, Text, View, ViewStyle } from 'react-native';
|
||||||
import { useSelector } from 'react-redux';
|
import { useSelector } from 'react-redux';
|
||||||
|
|
||||||
import { IState } from '../../../../app/types';
|
import { IState } from '../../../../app/types';
|
||||||
// @ts-ignore
|
|
||||||
import { getConferenceName } from '../../../../base/conference/functions';
|
import { getConferenceName } from '../../../../base/conference/functions';
|
||||||
// @ts-ignore
|
import { MEETING_NAME_ENABLED } from '../../../../base/flags/constants';
|
||||||
import { MEETING_NAME_ENABLED, getFeatureFlag } from '../../../../base/flags';
|
import { getFeatureFlag } from '../../../../base/flags/functions';
|
||||||
// @ts-ignore
|
|
||||||
import { JitsiRecordingConstants } from '../../../../base/lib-jitsi-meet';
|
import { JitsiRecordingConstants } from '../../../../base/lib-jitsi-meet';
|
||||||
import { getLocalParticipant } from '../../../../base/participants/functions';
|
import { getLocalParticipant } from '../../../../base/participants/functions';
|
||||||
import { connect } from '../../../../base/redux/functions';
|
import { connect } from '../../../../base/redux/functions';
|
||||||
|
|
|
@ -5,8 +5,7 @@ import { useDispatch, useSelector } from 'react-redux';
|
||||||
|
|
||||||
import { IState } from '../../../app/types';
|
import { IState } from '../../../app/types';
|
||||||
import { IconMenuDown } from '../../../base/icons/svg/index';
|
import { IconMenuDown } from '../../../base/icons/svg/index';
|
||||||
// @ts-ignore
|
import Label from '../../../base/label/components/web/Label';
|
||||||
import { Label } from '../../../base/label';
|
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import { Tooltip } from '../../../base/tooltip';
|
import { Tooltip } from '../../../base/tooltip';
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
|
|
|
@ -6,11 +6,9 @@ import clsx from 'clsx';
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import { WithTranslation } from 'react-i18next';
|
import { WithTranslation } from 'react-i18next';
|
||||||
import { connect } from 'react-redux';
|
import { connect } from 'react-redux';
|
||||||
import type { Dispatch } from 'redux';
|
|
||||||
|
|
||||||
import { IState } from '../../../app/types';
|
import { IState, IStore } from '../../../app/types';
|
||||||
// @ts-ignore
|
import { getSourceNameSignalingFeatureFlag } from '../../../base/config/functions.any';
|
||||||
import { getSourceNameSignalingFeatureFlag } from '../../../base/config';
|
|
||||||
import { translate } from '../../../base/i18n/functions';
|
import { translate } from '../../../base/i18n/functions';
|
||||||
import { MEDIA_TYPE } from '../../../base/media/constants';
|
import { MEDIA_TYPE } from '../../../base/media/constants';
|
||||||
import {
|
import {
|
||||||
|
@ -24,8 +22,7 @@ import {
|
||||||
getSourceNameByParticipantId,
|
getSourceNameByParticipantId,
|
||||||
getTrackByMediaTypeAndParticipant,
|
getTrackByMediaTypeAndParticipant,
|
||||||
getVirtualScreenshareParticipantTrack
|
getVirtualScreenshareParticipantTrack
|
||||||
// @ts-ignore
|
} from '../../../base/tracks/functions';
|
||||||
} from '../../../base/tracks';
|
|
||||||
import {
|
import {
|
||||||
isParticipantConnectionStatusInactive,
|
isParticipantConnectionStatusInactive,
|
||||||
isParticipantConnectionStatusInterrupted,
|
isParticipantConnectionStatusInterrupted,
|
||||||
|
@ -131,7 +128,7 @@ type Props = AbstractProps & WithTranslation & {
|
||||||
/**
|
/**
|
||||||
* The Redux dispatch function.
|
* The Redux dispatch function.
|
||||||
*/
|
*/
|
||||||
dispatch: Dispatch<any>;
|
dispatch: IStore['dispatch'];
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Whether or not clicking the indicator should display a popover for more
|
* Whether or not clicking the indicator should display a popover for more
|
||||||
|
|
|
@ -20,7 +20,7 @@ export function isTrackStreamingStatusActive(videoTrack: ITrack) {
|
||||||
* @param {Object} videoTrack - Track reference.
|
* @param {Object} videoTrack - Track reference.
|
||||||
* @returns {boolean} - Is streaming status inactive.
|
* @returns {boolean} - Is streaming status inactive.
|
||||||
*/
|
*/
|
||||||
export function isTrackStreamingStatusInactive(videoTrack: ITrack) {
|
export function isTrackStreamingStatusInactive(videoTrack?: ITrack) {
|
||||||
const streamingStatus = videoTrack?.streamingStatus;
|
const streamingStatus = videoTrack?.streamingStatus;
|
||||||
|
|
||||||
return streamingStatus === JitsiTrackStreamingStatus.INACTIVE;
|
return streamingStatus === JitsiTrackStreamingStatus.INACTIVE;
|
||||||
|
@ -32,7 +32,7 @@ export function isTrackStreamingStatusInactive(videoTrack: ITrack) {
|
||||||
* @param {Object} videoTrack - Track reference.
|
* @param {Object} videoTrack - Track reference.
|
||||||
* @returns {boolean} - Is streaming status interrupted.
|
* @returns {boolean} - Is streaming status interrupted.
|
||||||
*/
|
*/
|
||||||
export function isTrackStreamingStatusInterrupted(videoTrack: ITrack) {
|
export function isTrackStreamingStatusInterrupted(videoTrack?: ITrack) {
|
||||||
const streamingStatus = videoTrack?.streamingStatus;
|
const streamingStatus = videoTrack?.streamingStatus;
|
||||||
|
|
||||||
return streamingStatus === JitsiTrackStreamingStatus.INTERRUPTED;
|
return streamingStatus === JitsiTrackStreamingStatus.INTERRUPTED;
|
||||||
|
|
|
@ -1,9 +1,8 @@
|
||||||
import { Component } from 'react';
|
import { Component } from 'react';
|
||||||
import { WithTranslation } from 'react-i18next';
|
import { WithTranslation } from 'react-i18next';
|
||||||
import type { Dispatch } from 'redux';
|
|
||||||
|
|
||||||
// @ts-ignore
|
import { IStore } from '../../app/types';
|
||||||
import { updateSettings } from '../../base/settings';
|
import { updateSettings } from '../../base/settings/actions';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The type of the React {@code Component} props of
|
* The type of the React {@code Component} props of
|
||||||
|
@ -14,7 +13,7 @@ export interface Props extends WithTranslation {
|
||||||
/**
|
/**
|
||||||
* Invoked to update the local participant's display name.
|
* Invoked to update the local participant's display name.
|
||||||
*/
|
*/
|
||||||
dispatch: Dispatch<any>;
|
dispatch: IStore['dispatch'];
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Function to be invoked after a successful display name change.
|
* Function to be invoked after a successful display name change.
|
||||||
|
|
|
@ -4,16 +4,14 @@ import { withStyles } from '@mui/styles';
|
||||||
import React, { Component } from 'react';
|
import React, { Component } from 'react';
|
||||||
import { WithTranslation } from 'react-i18next';
|
import { WithTranslation } from 'react-i18next';
|
||||||
import { connect } from 'react-redux';
|
import { connect } from 'react-redux';
|
||||||
import type { Dispatch } from 'redux';
|
|
||||||
|
|
||||||
import { IState } from '../../../app/types';
|
import { IState, IStore } from '../../../app/types';
|
||||||
import { translate } from '../../../base/i18n/functions';
|
import { translate } from '../../../base/i18n/functions';
|
||||||
import {
|
import {
|
||||||
getParticipantById,
|
getParticipantById,
|
||||||
getParticipantDisplayName
|
getParticipantDisplayName
|
||||||
} from '../../../base/participants/functions';
|
} from '../../../base/participants/functions';
|
||||||
// @ts-ignore
|
import { updateSettings } from '../../../base/settings/actions';
|
||||||
import { updateSettings } from '../../../base/settings';
|
|
||||||
import { withPixelLineHeight } from '../../../base/styles/functions.web';
|
import { withPixelLineHeight } from '../../../base/styles/functions.web';
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import { Tooltip } from '../../../base/tooltip';
|
import { Tooltip } from '../../../base/tooltip';
|
||||||
|
@ -50,7 +48,7 @@ interface Props extends WithTranslation {
|
||||||
/**
|
/**
|
||||||
* Invoked to update the participant's display name.
|
* Invoked to update the participant's display name.
|
||||||
*/
|
*/
|
||||||
dispatch: Dispatch<any>;
|
dispatch: IStore['dispatch'];
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A string to append to the displayName, if provided.
|
* A string to append to the displayName, if provided.
|
||||||
|
|
|
@ -6,7 +6,6 @@ import { useSelector } from 'react-redux';
|
||||||
import { makeStyles } from 'tss-react/mui';
|
import { makeStyles } from 'tss-react/mui';
|
||||||
|
|
||||||
import { IState } from '../../../app/types';
|
import { IState } from '../../../app/types';
|
||||||
// @ts-ignore
|
|
||||||
import { isDisplayNameVisible } from '../../../base/config/functions.any';
|
import { isDisplayNameVisible } from '../../../base/config/functions.any';
|
||||||
import {
|
import {
|
||||||
getLocalParticipant,
|
getLocalParticipant,
|
||||||
|
@ -17,7 +16,6 @@ import { Participant } from '../../../base/participants/types';
|
||||||
import { withPixelLineHeight } from '../../../base/styles/functions.web';
|
import { withPixelLineHeight } from '../../../base/styles/functions.web';
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import { getLargeVideoParticipant } from '../../../large-video/functions';
|
import { getLargeVideoParticipant } from '../../../large-video/functions';
|
||||||
// @ts-ignore
|
|
||||||
import { isToolboxVisible } from '../../../toolbox/functions.web';
|
import { isToolboxVisible } from '../../../toolbox/functions.web';
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import { isLayoutTileView } from '../../../video-layout';
|
import { isLayoutTileView } from '../../../video-layout';
|
||||||
|
|
|
@ -1,18 +1,14 @@
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
import React, { Component } from 'react';
|
import React, { Component } from 'react';
|
||||||
import { WithTranslation } from 'react-i18next';
|
import { WithTranslation } from 'react-i18next';
|
||||||
import type { Dispatch } from 'redux';
|
|
||||||
|
|
||||||
import { createE2EEEvent } from '../../analytics/AnalyticsEvents';
|
import { createE2EEEvent } from '../../analytics/AnalyticsEvents';
|
||||||
import { sendAnalytics } from '../../analytics/functions';
|
import { sendAnalytics } from '../../analytics/functions';
|
||||||
import { IState } from '../../app/types';
|
import { IState, IStore } from '../../app/types';
|
||||||
import { translate } from '../../base/i18n/functions';
|
import { translate } from '../../base/i18n/functions';
|
||||||
import { connect } from '../../base/redux/functions';
|
import { connect } from '../../base/redux/functions';
|
||||||
import Switch from '../../base/ui/components/web/Switch';
|
import Switch from '../../base/ui/components/web/Switch';
|
||||||
// @ts-ignore
|
|
||||||
import { toggleE2EE } from '../actions';
|
import { toggleE2EE } from '../actions';
|
||||||
import { MAX_MODE } from '../constants';
|
import { MAX_MODE } from '../constants';
|
||||||
// @ts-ignore
|
|
||||||
import { doesEveryoneSupportE2EE } from '../functions';
|
import { doesEveryoneSupportE2EE } from '../functions';
|
||||||
|
|
||||||
interface Props extends WithTranslation {
|
interface Props extends WithTranslation {
|
||||||
|
@ -45,7 +41,7 @@ interface Props extends WithTranslation {
|
||||||
/**
|
/**
|
||||||
* The redux {@code dispatch} function.
|
* The redux {@code dispatch} function.
|
||||||
*/
|
*/
|
||||||
dispatch: Dispatch<any>;
|
dispatch: IStore['dispatch'];
|
||||||
}
|
}
|
||||||
|
|
||||||
type State = {
|
type State = {
|
||||||
|
|
|
@ -1,8 +1,6 @@
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
import 'image-capture';
|
import 'image-capture';
|
||||||
import './createImageBitmap';
|
import './createImageBitmap';
|
||||||
import { IStore } from '../app/types';
|
import { IStore } from '../app/types';
|
||||||
// @ts-ignore
|
|
||||||
import { getLocalVideoTrack } from '../base/tracks/functions';
|
import { getLocalVideoTrack } from '../base/tracks/functions';
|
||||||
import { getBaseUrl } from '../base/util/helpers';
|
import { getBaseUrl } from '../base/util/helpers';
|
||||||
|
|
||||||
|
@ -98,6 +96,7 @@ class FaceLandmarksDetector {
|
||||||
|
|
||||||
const baseUrl = `${getBaseUrl()}libs/`;
|
const baseUrl = `${getBaseUrl()}libs/`;
|
||||||
let workerUrl = `${baseUrl}face-landmarks-worker.min.js`;
|
let workerUrl = `${baseUrl}face-landmarks-worker.min.js`;
|
||||||
|
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
const workerBlob = new Blob([ `importScripts("${workerUrl}");` ], { type: 'application/javascript' });
|
const workerBlob = new Blob([ `importScripts("${workerUrl}");` ], { type: 'application/javascript' });
|
||||||
|
|
||||||
|
|
|
@ -1,7 +1,5 @@
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
import { IState } from '../app/types';
|
import { IState } from '../app/types';
|
||||||
import { getLocalParticipant } from '../base/participants/functions';
|
import { getLocalParticipant } from '../base/participants/functions';
|
||||||
// @ts-ignore
|
|
||||||
import { extractFqnFromPath } from '../dynamic-branding/functions.any';
|
import { extractFqnFromPath } from '../dynamic-branding/functions.any';
|
||||||
|
|
||||||
import { DETECT_FACE, FACE_BOX_EVENT_TYPE, SEND_IMAGE_INTERVAL_MS } from './constants';
|
import { DETECT_FACE, FACE_BOX_EVENT_TYPE, SEND_IMAGE_INTERVAL_MS } from './constants';
|
||||||
|
|
|
@ -1,10 +1,8 @@
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
import { IStore } from '../app/types';
|
import { IStore } from '../app/types';
|
||||||
import {
|
import {
|
||||||
CONFERENCE_JOINED,
|
CONFERENCE_JOINED,
|
||||||
CONFERENCE_WILL_LEAVE
|
CONFERENCE_WILL_LEAVE
|
||||||
} from '../base/conference/actionTypes';
|
} from '../base/conference/actionTypes';
|
||||||
// @ts-ignore
|
|
||||||
import { getCurrentConference } from '../base/conference/functions';
|
import { getCurrentConference } from '../base/conference/functions';
|
||||||
import { JitsiConferenceEvents } from '../base/lib-jitsi-meet';
|
import { JitsiConferenceEvents } from '../base/lib-jitsi-meet';
|
||||||
import { getLocalParticipant, getParticipantCount } from '../base/participants/functions';
|
import { getLocalParticipant, getParticipantCount } from '../base/participants/functions';
|
||||||
|
|
|
@ -5,24 +5,20 @@ import _ from 'lodash';
|
||||||
import React, { PureComponent } from 'react';
|
import React, { PureComponent } from 'react';
|
||||||
import { WithTranslation } from 'react-i18next';
|
import { WithTranslation } from 'react-i18next';
|
||||||
import { FixedSizeGrid, FixedSizeList } from 'react-window';
|
import { FixedSizeGrid, FixedSizeList } from 'react-window';
|
||||||
import type { Dispatch } from 'redux';
|
|
||||||
|
|
||||||
import { ACTION_SHORTCUT_TRIGGERED, createShortcutEvent, createToolbarEvent } from '../../../analytics/AnalyticsEvents';
|
import { ACTION_SHORTCUT_TRIGGERED, createShortcutEvent, createToolbarEvent } from '../../../analytics/AnalyticsEvents';
|
||||||
import { sendAnalytics } from '../../../analytics/functions';
|
import { sendAnalytics } from '../../../analytics/functions';
|
||||||
import { IState } from '../../../app/types';
|
import { IState, IStore } from '../../../app/types';
|
||||||
// @ts-ignore
|
import { getSourceNameSignalingFeatureFlag, getToolbarButtons } from '../../../base/config/functions.web';
|
||||||
import { getSourceNameSignalingFeatureFlag, getToolbarButtons } from '../../../base/config';
|
|
||||||
import { isMobileBrowser } from '../../../base/environment/utils';
|
import { isMobileBrowser } from '../../../base/environment/utils';
|
||||||
import { translate } from '../../../base/i18n/functions';
|
import { translate } from '../../../base/i18n/functions';
|
||||||
import Icon from '../../../base/icons/components/Icon';
|
import Icon from '../../../base/icons/components/Icon';
|
||||||
import { IconMenuDown, IconMenuUp } from '../../../base/icons/svg';
|
import { IconMenuDown, IconMenuUp } from '../../../base/icons/svg';
|
||||||
import { Participant } from '../../../base/participants/types';
|
import { Participant } from '../../../base/participants/types';
|
||||||
import { connect } from '../../../base/redux/functions';
|
import { connect } from '../../../base/redux/functions';
|
||||||
// @ts-ignore
|
|
||||||
import { shouldHideSelfView } from '../../../base/settings/functions.any';
|
import { shouldHideSelfView } from '../../../base/settings/functions.any';
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import { showToolbox } from '../../../toolbox/actions.web';
|
import { showToolbox } from '../../../toolbox/actions.web';
|
||||||
// @ts-ignore
|
|
||||||
import { isButtonEnabled, isToolboxVisible } from '../../../toolbox/functions.web';
|
import { isButtonEnabled, isToolboxVisible } from '../../../toolbox/functions.web';
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import { getCurrentLayout } from '../../../video-layout';
|
import { getCurrentLayout } from '../../../video-layout';
|
||||||
|
@ -232,7 +228,7 @@ interface Props extends WithTranslation {
|
||||||
/**
|
/**
|
||||||
* The redux {@code dispatch} function.
|
* The redux {@code dispatch} function.
|
||||||
*/
|
*/
|
||||||
dispatch: Dispatch<any>;
|
dispatch: IStore['dispatch'];
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The type of filmstrip to be displayed.
|
* The type of filmstrip to be displayed.
|
||||||
|
|
|
@ -11,8 +11,10 @@ import { sendAnalytics } from '../../../analytics/functions';
|
||||||
import { IState } from '../../../app/types';
|
import { IState } from '../../../app/types';
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import { Avatar } from '../../../base/avatar';
|
import { Avatar } from '../../../base/avatar';
|
||||||
// @ts-ignore
|
import {
|
||||||
import { getMultipleVideoSupportFeatureFlag, getSourceNameSignalingFeatureFlag } from '../../../base/config';
|
getMultipleVideoSupportFeatureFlag,
|
||||||
|
getSourceNameSignalingFeatureFlag
|
||||||
|
} from '../../../base/config/functions.web';
|
||||||
import { isMobileBrowser } from '../../../base/environment/utils';
|
import { isMobileBrowser } from '../../../base/environment/utils';
|
||||||
import { JitsiTrackEvents } from '../../../base/lib-jitsi-meet';
|
import { JitsiTrackEvents } from '../../../base/lib-jitsi-meet';
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
|
@ -29,21 +31,16 @@ import {
|
||||||
} from '../../../base/participants/functions';
|
} from '../../../base/participants/functions';
|
||||||
import { Participant } from '../../../base/participants/types';
|
import { Participant } from '../../../base/participants/types';
|
||||||
import { ASPECT_RATIO_NARROW } from '../../../base/responsive-ui/constants';
|
import { ASPECT_RATIO_NARROW } from '../../../base/responsive-ui/constants';
|
||||||
// @ts-ignore
|
import { isTestModeEnabled } from '../../../base/testing/functions';
|
||||||
import { isTestModeEnabled } from '../../../base/testing';
|
import { trackStreamingStatusChanged, updateLastTrackVideoMediaEvent } from '../../../base/tracks/actions';
|
||||||
import {
|
import {
|
||||||
getLocalAudioTrack,
|
getLocalAudioTrack,
|
||||||
getLocalVideoTrack,
|
getLocalVideoTrack,
|
||||||
getTrackByMediaTypeAndParticipant,
|
getTrackByMediaTypeAndParticipant,
|
||||||
getVirtualScreenshareParticipantTrack,
|
getVirtualScreenshareParticipantTrack
|
||||||
trackStreamingStatusChanged,
|
} from '../../../base/tracks/functions';
|
||||||
updateLastTrackVideoMediaEvent
|
|
||||||
// @ts-ignore
|
|
||||||
} from '../../../base/tracks';
|
|
||||||
import { getVideoObjectPosition } from '../../../face-landmarks/functions';
|
import { getVideoObjectPosition } from '../../../face-landmarks/functions';
|
||||||
// @ts-ignore
|
|
||||||
import { hideGif, showGif } from '../../../gifs/actions';
|
import { hideGif, showGif } from '../../../gifs/actions';
|
||||||
// @ts-ignore
|
|
||||||
import { getGifDisplayMode, getGifForParticipant } from '../../../gifs/functions';
|
import { getGifDisplayMode, getGifForParticipant } from '../../../gifs/functions';
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import { PresenceLabel } from '../../../presence-status';
|
import { PresenceLabel } from '../../../presence-status';
|
||||||
|
@ -1178,7 +1175,7 @@ function _mapStateToProps(state: IState, ownProps: any): Object {
|
||||||
const { participantID, filmstripType = FILMSTRIP_TYPE.MAIN } = ownProps;
|
const { participantID, filmstripType = FILMSTRIP_TYPE.MAIN } = ownProps;
|
||||||
|
|
||||||
const participant = getParticipantByIdOrUndefined(state, participantID);
|
const participant = getParticipantByIdOrUndefined(state, participantID);
|
||||||
const id = participant?.id;
|
const id = participant?.id ?? '';
|
||||||
const isLocal = participant?.local ?? true;
|
const isLocal = participant?.local ?? true;
|
||||||
const multipleVideoSupportEnabled = getMultipleVideoSupportFeatureFlag(state);
|
const multipleVideoSupportEnabled = getMultipleVideoSupportFeatureFlag(state);
|
||||||
const sourceNameSignalingEnabled = getSourceNameSignalingFeatureFlag(state);
|
const sourceNameSignalingEnabled = getSourceNameSignalingFeatureFlag(state);
|
||||||
|
|
|
@ -9,7 +9,6 @@ import {
|
||||||
getMultipleVideoSupportFeatureFlag,
|
getMultipleVideoSupportFeatureFlag,
|
||||||
isDisplayNameVisible,
|
isDisplayNameVisible,
|
||||||
isNameReadOnly
|
isNameReadOnly
|
||||||
// @ts-ignore
|
|
||||||
} from '../../../base/config/functions.any';
|
} from '../../../base/config/functions.any';
|
||||||
import { isScreenShareParticipantById } from '../../../base/participants/functions';
|
import { isScreenShareParticipantById } from '../../../base/participants/functions';
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
|
|
|
@ -5,8 +5,7 @@ import { useSelector } from 'react-redux';
|
||||||
import { makeStyles } from 'tss-react/mui';
|
import { makeStyles } from 'tss-react/mui';
|
||||||
|
|
||||||
import { IState } from '../../../app/types';
|
import { IState } from '../../../app/types';
|
||||||
// @ts-ignore
|
import { getMultipleVideoSupportFeatureFlag } from '../../../base/config/functions.any';
|
||||||
import { getMultipleVideoSupportFeatureFlag } from '../../../base/config';
|
|
||||||
import { isMobileBrowser } from '../../../base/environment/utils';
|
import { isMobileBrowser } from '../../../base/environment/utils';
|
||||||
import { isScreenShareParticipantById } from '../../../base/participants/functions';
|
import { isScreenShareParticipantById } from '../../../base/participants/functions';
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
|
|
|
@ -45,7 +45,7 @@ type Props = {
|
||||||
const VideoMenuTriggerButton = ({
|
const VideoMenuTriggerButton = ({
|
||||||
hidePopover,
|
hidePopover,
|
||||||
local,
|
local,
|
||||||
participantId,
|
participantId = '',
|
||||||
popoverVisible,
|
popoverVisible,
|
||||||
showPopover,
|
showPopover,
|
||||||
thumbnailType,
|
thumbnailType,
|
||||||
|
|
|
@ -11,7 +11,6 @@ import { createGifSentEvent } from '../../../analytics/AnalyticsEvents';
|
||||||
import { sendAnalytics } from '../../../analytics/functions';
|
import { sendAnalytics } from '../../../analytics/functions';
|
||||||
import { IState } from '../../../app/types';
|
import { IState } from '../../../app/types';
|
||||||
import Input from '../../../base/ui/components/web/Input';
|
import Input from '../../../base/ui/components/web/Input';
|
||||||
// @ts-ignore
|
|
||||||
import { sendMessage } from '../../../chat/actions.any';
|
import { sendMessage } from '../../../chat/actions.any';
|
||||||
import { SCROLL_SIZE } from '../../../filmstrip/constants';
|
import { SCROLL_SIZE } from '../../../filmstrip/constants';
|
||||||
import { toggleReactionsMenuVisibility } from '../../../reactions/actions.web';
|
import { toggleReactionsMenuVisibility } from '../../../reactions/actions.web';
|
||||||
|
@ -19,11 +18,8 @@ import { toggleReactionsMenuVisibility } from '../../../reactions/actions.web';
|
||||||
import { setOverflowMenuVisible } from '../../../toolbox/actions.web';
|
import { setOverflowMenuVisible } from '../../../toolbox/actions.web';
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import { Drawer, JitsiPortal } from '../../../toolbox/components/web';
|
import { Drawer, JitsiPortal } from '../../../toolbox/components/web';
|
||||||
// @ts-ignore
|
|
||||||
import { showOverflowDrawer } from '../../../toolbox/functions.web';
|
import { showOverflowDrawer } from '../../../toolbox/functions.web';
|
||||||
// @ts-ignore
|
|
||||||
import { setGifDrawerVisibility } from '../../actions';
|
import { setGifDrawerVisibility } from '../../actions';
|
||||||
// @ts-ignore
|
|
||||||
import { formatGifUrlMessage, getGifAPIKey, getGifUrl } from '../../functions';
|
import { formatGifUrlMessage, getGifAPIKey, getGifUrl } from '../../functions';
|
||||||
|
|
||||||
const OVERFLOW_DRAWER_PADDING = 16;
|
const OVERFLOW_DRAWER_PADDING = 16;
|
||||||
|
|
|
@ -10,11 +10,9 @@ import { translate } from '../../../../base/i18n/functions';
|
||||||
import { JitsiRecordingConstants } from '../../../../base/lib-jitsi-meet';
|
import { JitsiRecordingConstants } from '../../../../base/lib-jitsi-meet';
|
||||||
import { connect } from '../../../../base/redux/functions';
|
import { connect } from '../../../../base/redux/functions';
|
||||||
import Dialog from '../../../../base/ui/components/web/Dialog';
|
import Dialog from '../../../../base/ui/components/web/Dialog';
|
||||||
// @ts-ignore
|
|
||||||
import { isDynamicBrandingDataLoaded } from '../../../../dynamic-branding/functions.any';
|
import { isDynamicBrandingDataLoaded } from '../../../../dynamic-branding/functions.any';
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import EmbedMeetingTrigger from '../../../../embed-meeting/components/EmbedMeetingTrigger';
|
import EmbedMeetingTrigger from '../../../../embed-meeting/components/EmbedMeetingTrigger';
|
||||||
// @ts-ignore
|
|
||||||
import { isVpaasMeeting } from '../../../../jaas/functions';
|
import { isVpaasMeeting } from '../../../../jaas/functions';
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import { getActiveSession } from '../../../../recording';
|
import { getActiveSession } from '../../../../recording';
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
import { Theme } from '@mui/material';
|
import { Theme } from '@mui/material';
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import { WithTranslation } from 'react-i18next';
|
import { WithTranslation } from 'react-i18next';
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
import { Theme } from '@mui/material';
|
import { Theme } from '@mui/material';
|
||||||
import React, { useCallback } from 'react';
|
import React, { useCallback } from 'react';
|
||||||
import { WithTranslation } from 'react-i18next';
|
import { WithTranslation } from 'react-i18next';
|
||||||
|
@ -6,6 +5,7 @@ import { useStore } from 'react-redux';
|
||||||
import { makeStyles } from 'tss-react/mui';
|
import { makeStyles } from 'tss-react/mui';
|
||||||
|
|
||||||
import { translate } from '../../base/i18n/functions';
|
import { translate } from '../../base/i18n/functions';
|
||||||
|
// eslint-disable-next-line lines-around-comment
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import { setSeeWhatIsBeingShared } from '../actions.web';
|
import { setSeeWhatIsBeingShared } from '../actions.web';
|
||||||
|
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
import React, { PureComponent } from 'react';
|
import React, { PureComponent } from 'react';
|
||||||
import { WithTranslation } from 'react-i18next';
|
import { WithTranslation } from 'react-i18next';
|
||||||
|
|
||||||
|
@ -7,8 +6,8 @@ import { translate } from '../../../base/i18n/functions';
|
||||||
import { isLocalParticipantModerator } from '../../../base/participants/functions';
|
import { isLocalParticipantModerator } from '../../../base/participants/functions';
|
||||||
import { connect } from '../../../base/redux/functions';
|
import { connect } from '../../../base/redux/functions';
|
||||||
import Switch from '../../../base/ui/components/web/Switch';
|
import Switch from '../../../base/ui/components/web/Switch';
|
||||||
// @ts-ignore
|
|
||||||
import { isInBreakoutRoom } from '../../../breakout-rooms/functions';
|
import { isInBreakoutRoom } from '../../../breakout-rooms/functions';
|
||||||
|
// eslint-disable-next-line lines-around-comment
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import { toggleLobbyMode } from '../../actions';
|
import { toggleLobbyMode } from '../../actions';
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,4 @@
|
||||||
// @ts-ignore
|
import { CONFERENCE_JOINED, CONFERENCE_LEFT, SET_PASSWORD } from '../base/conference/actionTypes';
|
||||||
import { CONFERENCE_JOINED, CONFERENCE_LEFT, SET_PASSWORD } from '../base/conference';
|
|
||||||
import { Participant } from '../base/participants/types';
|
import { Participant } from '../base/participants/types';
|
||||||
import ReducerRegistry from '../base/redux/ReducerRegistry';
|
import ReducerRegistry from '../base/redux/ReducerRegistry';
|
||||||
|
|
||||||
|
|
|
@ -1,10 +1,6 @@
|
||||||
/* eslint-disable lines-around-comment */
|
import { IStore } from '../app/types';
|
||||||
import { Dispatch } from 'redux';
|
import { getLocalJitsiAudioTrack } from '../base/tracks/functions';
|
||||||
|
import { showErrorNotification } from '../notifications/actions';
|
||||||
// @ts-ignore
|
|
||||||
import { getLocalJitsiAudioTrack } from '../base/tracks';
|
|
||||||
// @ts-ignore
|
|
||||||
import { showErrorNotification } from '../notifications';
|
|
||||||
import { NOTIFICATION_TIMEOUT_TYPE } from '../notifications/constants';
|
import { NOTIFICATION_TIMEOUT_TYPE } from '../notifications/constants';
|
||||||
import { NoiseSuppressionEffect } from '../stream-effects/noise-suppression/NoiseSuppressionEffect';
|
import { NoiseSuppressionEffect } from '../stream-effects/noise-suppression/NoiseSuppressionEffect';
|
||||||
|
|
||||||
|
@ -34,7 +30,7 @@ export function setNoiseSuppressionEnabledState(enabled: boolean): any {
|
||||||
* @returns {Function}
|
* @returns {Function}
|
||||||
*/
|
*/
|
||||||
export function toggleNoiseSuppression(): any {
|
export function toggleNoiseSuppression(): any {
|
||||||
return (dispatch: Dispatch, getState: Function) => {
|
return (dispatch: IStore['dispatch'], getState: IStore['getState']) => {
|
||||||
if (isNoiseSuppressionEnabled(getState())) {
|
if (isNoiseSuppressionEnabled(getState())) {
|
||||||
dispatch(setNoiseSuppressionEnabled(false));
|
dispatch(setNoiseSuppressionEnabled(false));
|
||||||
} else {
|
} else {
|
||||||
|
@ -51,7 +47,7 @@ export function toggleNoiseSuppression(): any {
|
||||||
* @returns {Function}
|
* @returns {Function}
|
||||||
*/
|
*/
|
||||||
export function setNoiseSuppressionEnabled(enabled: boolean): any {
|
export function setNoiseSuppressionEnabled(enabled: boolean): any {
|
||||||
return async (dispatch: Dispatch, getState: Function) => {
|
return async (dispatch: IStore['dispatch'], getState: IStore['getState']) => {
|
||||||
const state = getState();
|
const state = getState();
|
||||||
|
|
||||||
const localAudio = getLocalJitsiAudioTrack(state);
|
const localAudio = getLocalJitsiAudioTrack(state);
|
||||||
|
@ -82,6 +78,7 @@ export function setNoiseSuppressionEnabled(enabled: boolean): any {
|
||||||
error
|
error
|
||||||
);
|
);
|
||||||
|
|
||||||
|
// @ts-ignore
|
||||||
dispatch(showErrorNotification({
|
dispatch(showErrorNotification({
|
||||||
titleKey: 'notify.noiseSuppressionFailedTitle'
|
titleKey: 'notify.noiseSuppressionFailedTitle'
|
||||||
}, NOTIFICATION_TIMEOUT_TYPE.MEDIUM));
|
}, NOTIFICATION_TIMEOUT_TYPE.MEDIUM));
|
||||||
|
|
|
@ -1,10 +1,7 @@
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
import { IState } from '../app/types';
|
import { IState } from '../app/types';
|
||||||
// @ts-ignore
|
import { showWarningNotification } from '../notifications/actions';
|
||||||
import { showWarningNotification } from '../notifications';
|
|
||||||
import { NOTIFICATION_TIMEOUT_TYPE } from '../notifications/constants';
|
import { NOTIFICATION_TIMEOUT_TYPE } from '../notifications/constants';
|
||||||
// @ts-ignore
|
import { isScreenAudioShared } from '../screen-share/functions';
|
||||||
import { isScreenAudioShared } from '../screen-share';
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Is noise suppression currently enabled.
|
* Is noise suppression currently enabled.
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
import { FlagGroupContext } from '@atlaskit/flag/flag-group';
|
import { FlagGroupContext } from '@atlaskit/flag/flag-group';
|
||||||
import { AtlasKitThemeProvider } from '@atlaskit/theme';
|
import { AtlasKitThemeProvider } from '@atlaskit/theme';
|
||||||
import { Theme } from '@mui/material';
|
import { Theme } from '@mui/material';
|
||||||
|
@ -11,9 +10,7 @@ import { CSSTransition, TransitionGroup } from 'react-transition-group';
|
||||||
import { IState } from '../../../app/types';
|
import { IState } from '../../../app/types';
|
||||||
import { translate } from '../../../base/i18n/functions';
|
import { translate } from '../../../base/i18n/functions';
|
||||||
import { connect } from '../../../base/redux/functions';
|
import { connect } from '../../../base/redux/functions';
|
||||||
// @ts-ignore
|
|
||||||
import { hideNotification } from '../../actions';
|
import { hideNotification } from '../../actions';
|
||||||
// @ts-ignore
|
|
||||||
import { areThereNotifications } from '../../functions';
|
import { areThereNotifications } from '../../functions';
|
||||||
|
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
|
|
|
@ -1,10 +1,8 @@
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
import React, { useCallback } from 'react';
|
import React, { useCallback } from 'react';
|
||||||
import { useDispatch } from 'react-redux';
|
import { useDispatch } from 'react-redux';
|
||||||
|
|
||||||
import Button from '../../../../../base/ui/components/native/Button';
|
import Button from '../../../../../base/ui/components/native/Button';
|
||||||
import { BUTTON_TYPES } from '../../../../../base/ui/constants';
|
import { BUTTON_TYPES } from '../../../../../base/ui/constants';
|
||||||
// @ts-ignore
|
|
||||||
import { createBreakoutRoom } from '../../../../../breakout-rooms/actions';
|
import { createBreakoutRoom } from '../../../../../breakout-rooms/actions';
|
||||||
|
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
|
|
|
@ -1,10 +1,8 @@
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
import React, { useCallback } from 'react';
|
import React, { useCallback } from 'react';
|
||||||
import { useDispatch } from 'react-redux';
|
import { useDispatch } from 'react-redux';
|
||||||
|
|
||||||
import Button from '../../../../../base/ui/components/native/Button';
|
import Button from '../../../../../base/ui/components/native/Button';
|
||||||
import { BUTTON_TYPES } from '../../../../../base/ui/constants';
|
import { BUTTON_TYPES } from '../../../../../base/ui/constants';
|
||||||
// @ts-ignore
|
|
||||||
import { autoAssignToBreakoutRooms } from '../../../../../breakout-rooms/actions';
|
import { autoAssignToBreakoutRooms } from '../../../../../breakout-rooms/actions';
|
||||||
|
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
|
|
|
@ -6,7 +6,6 @@ import { createBreakoutRoomsEvent } from '../../../../../analytics/AnalyticsEven
|
||||||
import { sendAnalytics } from '../../../../../analytics/functions';
|
import { sendAnalytics } from '../../../../../analytics/functions';
|
||||||
import Button from '../../../../../base/ui/components/native/Button';
|
import Button from '../../../../../base/ui/components/native/Button';
|
||||||
import { BUTTON_TYPES } from '../../../../../base/ui/constants';
|
import { BUTTON_TYPES } from '../../../../../base/ui/constants';
|
||||||
// @ts-ignore
|
|
||||||
import { moveToRoom } from '../../../../../breakout-rooms/actions';
|
import { moveToRoom } from '../../../../../breakout-rooms/actions';
|
||||||
|
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
|
|
|
@ -1,11 +1,9 @@
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
import React, { useCallback } from 'react';
|
import React, { useCallback } from 'react';
|
||||||
import { useTranslation } from 'react-i18next';
|
import { useTranslation } from 'react-i18next';
|
||||||
import { useDispatch } from 'react-redux';
|
import { useDispatch } from 'react-redux';
|
||||||
|
|
||||||
import Button from '../../../../../base/ui/components/web/Button';
|
import Button from '../../../../../base/ui/components/web/Button';
|
||||||
import { BUTTON_TYPES } from '../../../../../base/ui/constants';
|
import { BUTTON_TYPES } from '../../../../../base/ui/constants';
|
||||||
// @ts-ignore
|
|
||||||
import { createBreakoutRoom } from '../../../../../breakout-rooms/actions';
|
import { createBreakoutRoom } from '../../../../../breakout-rooms/actions';
|
||||||
|
|
||||||
export const AddBreakoutRoomButton = () => {
|
export const AddBreakoutRoomButton = () => {
|
||||||
|
|
|
@ -1,11 +1,9 @@
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
import React, { useCallback } from 'react';
|
import React, { useCallback } from 'react';
|
||||||
import { useTranslation } from 'react-i18next';
|
import { useTranslation } from 'react-i18next';
|
||||||
import { useDispatch } from 'react-redux';
|
import { useDispatch } from 'react-redux';
|
||||||
|
|
||||||
import Button from '../../../../../base/ui/components/web/Button';
|
import Button from '../../../../../base/ui/components/web/Button';
|
||||||
import { BUTTON_TYPES } from '../../../../../base/ui/constants';
|
import { BUTTON_TYPES } from '../../../../../base/ui/constants';
|
||||||
// @ts-ignore
|
|
||||||
import { autoAssignToBreakoutRooms } from '../../../../../breakout-rooms/actions';
|
import { autoAssignToBreakoutRooms } from '../../../../../breakout-rooms/actions';
|
||||||
|
|
||||||
export const AutoAssignButton = () => {
|
export const AutoAssignButton = () => {
|
||||||
|
|
|
@ -1,5 +1,3 @@
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
|
|
||||||
import { Theme } from '@mui/material';
|
import { Theme } from '@mui/material';
|
||||||
import React, { ReactElement, useCallback, useState } from 'react';
|
import React, { ReactElement, useCallback, useState } from 'react';
|
||||||
import { useTranslation } from 'react-i18next';
|
import { useTranslation } from 'react-i18next';
|
||||||
|
@ -12,7 +10,6 @@ import Icon from '../../../../../base/icons/components/Icon';
|
||||||
import { IconArrowDown, IconArrowUp } from '../../../../../base/icons/svg';
|
import { IconArrowDown, IconArrowUp } from '../../../../../base/icons/svg';
|
||||||
import { isLocalParticipantModerator } from '../../../../../base/participants/functions';
|
import { isLocalParticipantModerator } from '../../../../../base/participants/functions';
|
||||||
import { withPixelLineHeight } from '../../../../../base/styles/functions.web';
|
import { withPixelLineHeight } from '../../../../../base/styles/functions.web';
|
||||||
// @ts-ignore
|
|
||||||
import { showOverflowDrawer } from '../../../../../toolbox/functions.web';
|
import { showOverflowDrawer } from '../../../../../toolbox/functions.web';
|
||||||
import { ACTION_TRIGGER } from '../../../../constants';
|
import { ACTION_TRIGGER } from '../../../../constants';
|
||||||
import { participantMatchesSearch } from '../../../../functions';
|
import { participantMatchesSearch } from '../../../../functions';
|
||||||
|
|
|
@ -1,5 +1,3 @@
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
|
|
||||||
import { Theme } from '@mui/material';
|
import { Theme } from '@mui/material';
|
||||||
import React, { useCallback } from 'react';
|
import React, { useCallback } from 'react';
|
||||||
import { useTranslation } from 'react-i18next';
|
import { useTranslation } from 'react-i18next';
|
||||||
|
@ -9,7 +7,6 @@ import { makeStyles } from 'tss-react/mui';
|
||||||
import { createBreakoutRoomsEvent } from '../../../../../analytics/AnalyticsEvents';
|
import { createBreakoutRoomsEvent } from '../../../../../analytics/AnalyticsEvents';
|
||||||
import { sendAnalytics } from '../../../../../analytics/functions';
|
import { sendAnalytics } from '../../../../../analytics/functions';
|
||||||
import Button from '../../../../../base/ui/components/web/Button';
|
import Button from '../../../../../base/ui/components/web/Button';
|
||||||
// @ts-ignore
|
|
||||||
import { moveToRoom } from '../../../../../breakout-rooms/actions';
|
import { moveToRoom } from '../../../../../breakout-rooms/actions';
|
||||||
|
|
||||||
type Props = {
|
type Props = {
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
import React, { useCallback } from 'react';
|
import React, { useCallback } from 'react';
|
||||||
import { useTranslation } from 'react-i18next';
|
import { useTranslation } from 'react-i18next';
|
||||||
import { useDispatch } from 'react-redux';
|
import { useDispatch } from 'react-redux';
|
||||||
|
@ -7,7 +6,6 @@ import { createBreakoutRoomsEvent } from '../../../../../analytics/AnalyticsEven
|
||||||
import { sendAnalytics } from '../../../../../analytics/functions';
|
import { sendAnalytics } from '../../../../../analytics/functions';
|
||||||
import Button from '../../../../../base/ui/components/web/Button';
|
import Button from '../../../../../base/ui/components/web/Button';
|
||||||
import { BUTTON_TYPES } from '../../../../../base/ui/constants';
|
import { BUTTON_TYPES } from '../../../../../base/ui/constants';
|
||||||
// @ts-ignore
|
|
||||||
import { moveToRoom } from '../../../../../breakout-rooms/actions';
|
import { moveToRoom } from '../../../../../breakout-rooms/actions';
|
||||||
|
|
||||||
export const LeaveButton = () => {
|
export const LeaveButton = () => {
|
||||||
|
|
|
@ -10,9 +10,7 @@ import { Avatar } from '../../../../../base/avatar';
|
||||||
import { isLocalParticipantModerator } from '../../../../../base/participants/functions';
|
import { isLocalParticipantModerator } from '../../../../../base/participants/functions';
|
||||||
import ContextMenu from '../../../../../base/ui/components/web/ContextMenu';
|
import ContextMenu from '../../../../../base/ui/components/web/ContextMenu';
|
||||||
import ContextMenuItemGroup from '../../../../../base/ui/components/web/ContextMenuItemGroup';
|
import ContextMenuItemGroup from '../../../../../base/ui/components/web/ContextMenuItemGroup';
|
||||||
// @ts-ignore
|
|
||||||
import { getBreakoutRooms } from '../../../../../breakout-rooms/functions';
|
import { getBreakoutRooms } from '../../../../../breakout-rooms/functions';
|
||||||
// @ts-ignore
|
|
||||||
import { showOverflowDrawer } from '../../../../../toolbox/functions.web';
|
import { showOverflowDrawer } from '../../../../../toolbox/functions.web';
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import SendToRoomButton from '../../../../../video-menu/components/web/SendToRoomButton';
|
import SendToRoomButton from '../../../../../video-menu/components/web/SendToRoomButton';
|
||||||
|
|
|
@ -3,8 +3,7 @@ import React, { useCallback } from 'react';
|
||||||
import { View } from 'react-native';
|
import { View } from 'react-native';
|
||||||
import { useDispatch, useSelector } from 'react-redux';
|
import { useDispatch, useSelector } from 'react-redux';
|
||||||
|
|
||||||
// @ts-ignore
|
import { openDialog, openSheet } from '../../../base/dialog/actions';
|
||||||
import { openDialog, openSheet } from '../../../base/dialog';
|
|
||||||
import { IconHorizontalPoints } from '../../../base/icons/svg';
|
import { IconHorizontalPoints } from '../../../base/icons/svg';
|
||||||
import IconButton from '../../../base/react/components/native/IconButton';
|
import IconButton from '../../../base/react/components/native/IconButton';
|
||||||
import Button from '../../../base/ui/components/native/Button';
|
import Button from '../../../base/ui/components/native/Button';
|
||||||
|
@ -12,7 +11,6 @@ import { BUTTON_TYPES } from '../../../base/ui/constants';
|
||||||
import MuteEveryoneDialog
|
import MuteEveryoneDialog
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
from '../../../video-menu/components/native/MuteEveryoneDialog';
|
from '../../../video-menu/components/native/MuteEveryoneDialog';
|
||||||
// @ts-ignore
|
|
||||||
import { isMoreActionsVisible, isMuteAllVisible } from '../../functions';
|
import { isMoreActionsVisible, isMuteAllVisible } from '../../functions';
|
||||||
|
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
|
|
|
@ -12,7 +12,6 @@ import { BottomSheet, hideSheet } from '../../../base/dialog';
|
||||||
import { bottomSheetStyles } from '../../../base/dialog/components/native/styles';
|
import { bottomSheetStyles } from '../../../base/dialog/components/native/styles';
|
||||||
import { translate } from '../../../base/i18n/functions';
|
import { translate } from '../../../base/i18n/functions';
|
||||||
import { connect } from '../../../base/redux/functions';
|
import { connect } from '../../../base/redux/functions';
|
||||||
// @ts-ignore
|
|
||||||
import { getBreakoutRooms } from '../../../breakout-rooms/functions';
|
import { getBreakoutRooms } from '../../../breakout-rooms/functions';
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import SendToBreakoutRoom from '../../../video-menu/components/native/SendToBreakoutRoom';
|
import SendToBreakoutRoom from '../../../video-menu/components/native/SendToBreakoutRoom';
|
||||||
|
|
|
@ -10,15 +10,12 @@ import {
|
||||||
requestDisableVideoModeration,
|
requestDisableVideoModeration,
|
||||||
requestEnableAudioModeration,
|
requestEnableAudioModeration,
|
||||||
requestEnableVideoModeration
|
requestEnableVideoModeration
|
||||||
// @ts-ignore
|
|
||||||
} from '../../../av-moderation/actions';
|
} from '../../../av-moderation/actions';
|
||||||
import {
|
import {
|
||||||
isEnabled as isAvModerationEnabled,
|
isEnabled as isAvModerationEnabled,
|
||||||
isSupported as isAvModerationSupported
|
isSupported as isAvModerationSupported
|
||||||
// @ts-ignore
|
|
||||||
} from '../../../av-moderation/functions';
|
} from '../../../av-moderation/functions';
|
||||||
// @ts-ignore
|
import { openDialog } from '../../../base/dialog/actions';
|
||||||
import { openDialog } from '../../../base/dialog';
|
|
||||||
import {
|
import {
|
||||||
IconCheck,
|
IconCheck,
|
||||||
IconHorizontalPoints,
|
IconHorizontalPoints,
|
||||||
|
@ -31,7 +28,6 @@ import {
|
||||||
} from '../../../base/participants/functions';
|
} from '../../../base/participants/functions';
|
||||||
import ContextMenu from '../../../base/ui/components/web/ContextMenu';
|
import ContextMenu from '../../../base/ui/components/web/ContextMenu';
|
||||||
import ContextMenuItemGroup from '../../../base/ui/components/web/ContextMenuItemGroup';
|
import ContextMenuItemGroup from '../../../base/ui/components/web/ContextMenuItemGroup';
|
||||||
// @ts-ignore
|
|
||||||
import { isInBreakoutRoom } from '../../../breakout-rooms/functions';
|
import { isInBreakoutRoom } from '../../../breakout-rooms/functions';
|
||||||
import {
|
import {
|
||||||
openSettingsDialog,
|
openSettingsDialog,
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
import React, { useCallback } from 'react';
|
import React, { useCallback } from 'react';
|
||||||
import { useTranslation } from 'react-i18next';
|
import { useTranslation } from 'react-i18next';
|
||||||
import { useDispatch } from 'react-redux';
|
import { useDispatch } from 'react-redux';
|
||||||
|
@ -8,6 +7,7 @@ import { sendAnalytics } from '../../../analytics/functions';
|
||||||
import { IconInviteMore } from '../../../base/icons/svg';
|
import { IconInviteMore } from '../../../base/icons/svg';
|
||||||
import Button from '../../../base/ui/components/web/Button';
|
import Button from '../../../base/ui/components/web/Button';
|
||||||
import { BUTTON_TYPES } from '../../../base/ui/constants';
|
import { BUTTON_TYPES } from '../../../base/ui/constants';
|
||||||
|
// eslint-disable-next-line lines-around-comment
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import { beginAddPeople } from '../../../invite';
|
import { beginAddPeople } from '../../../invite';
|
||||||
|
|
||||||
|
|
|
@ -16,8 +16,7 @@ import { admitMultiple } from '../../../lobby/actions.web';
|
||||||
import { getKnockingParticipants, getLobbyEnabled } from '../../../lobby/functions';
|
import { getKnockingParticipants, getLobbyEnabled } from '../../../lobby/functions';
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import { Drawer, JitsiPortal } from '../../../toolbox/components/web';
|
import { Drawer, JitsiPortal } from '../../../toolbox/components/web';
|
||||||
// @ts-ignore
|
import { showOverflowDrawer } from '../../../toolbox/functions.web';
|
||||||
import { showOverflowDrawer } from '../../../toolbox/functions';
|
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import { useLobbyActions, useParticipantDrawer } from '../../hooks';
|
import { useLobbyActions, useParticipantDrawer } from '../../hooks';
|
||||||
|
|
||||||
|
|
|
@ -7,10 +7,8 @@ import { useDispatch, useSelector } from 'react-redux';
|
||||||
import { makeStyles } from 'tss-react/mui';
|
import { makeStyles } from 'tss-react/mui';
|
||||||
|
|
||||||
import { IState } from '../../../app/types';
|
import { IState } from '../../../app/types';
|
||||||
// @ts-ignore
|
|
||||||
import { rejectParticipantAudio } from '../../../av-moderation/actions';
|
import { rejectParticipantAudio } from '../../../av-moderation/actions';
|
||||||
import participantsPaneTheme from '../../../base/components/themes/participantsPaneTheme.json';
|
import participantsPaneTheme from '../../../base/components/themes/participantsPaneTheme.json';
|
||||||
// @ts-ignore
|
|
||||||
import { isToolbarButtonEnabled } from '../../../base/config/functions.web';
|
import { isToolbarButtonEnabled } from '../../../base/config/functions.web';
|
||||||
import { MEDIA_TYPE } from '../../../base/media/constants';
|
import { MEDIA_TYPE } from '../../../base/media/constants';
|
||||||
import { getParticipantById, isScreenShareParticipant } from '../../../base/participants/functions';
|
import { getParticipantById, isScreenShareParticipant } from '../../../base/participants/functions';
|
||||||
|
@ -19,13 +17,10 @@ import { withPixelLineHeight } from '../../../base/styles/functions.web';
|
||||||
import Input from '../../../base/ui/components/web/Input';
|
import Input from '../../../base/ui/components/web/Input';
|
||||||
import useContextMenu from '../../../base/ui/hooks/useContextMenu';
|
import useContextMenu from '../../../base/ui/hooks/useContextMenu';
|
||||||
import { normalizeAccents } from '../../../base/util/strings.web';
|
import { normalizeAccents } from '../../../base/util/strings.web';
|
||||||
// @ts-ignore
|
|
||||||
import { getBreakoutRooms, getCurrentRoomId, isInBreakoutRoom } from '../../../breakout-rooms/functions';
|
import { getBreakoutRooms, getCurrentRoomId, isInBreakoutRoom } from '../../../breakout-rooms/functions';
|
||||||
// @ts-ignore
|
import { showOverflowDrawer } from '../../../toolbox/functions.web';
|
||||||
import { showOverflowDrawer } from '../../../toolbox/functions';
|
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import { muteRemote } from '../../../video-menu/actions.any';
|
import { muteRemote } from '../../../video-menu/actions.any';
|
||||||
// @ts-ignore
|
|
||||||
import { getSortedParticipantIds, shouldRenderInviteButton } from '../../functions';
|
import { getSortedParticipantIds, shouldRenderInviteButton } from '../../functions';
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import { useParticipantDrawer } from '../../hooks';
|
import { useParticipantDrawer } from '../../hooks';
|
||||||
|
|
|
@ -1,5 +1,3 @@
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
|
|
||||||
import { Theme } from '@mui/material';
|
import { Theme } from '@mui/material';
|
||||||
import React, { ReactElement, useCallback } from 'react';
|
import React, { ReactElement, useCallback } from 'react';
|
||||||
import { WithTranslation } from 'react-i18next';
|
import { WithTranslation } from 'react-i18next';
|
||||||
|
|
|
@ -1,15 +1,11 @@
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
|
|
||||||
import { Theme } from '@mui/material';
|
import { Theme } from '@mui/material';
|
||||||
import React, { useCallback } from 'react';
|
import React, { useCallback } from 'react';
|
||||||
import { useTranslation } from 'react-i18next';
|
import { useTranslation } from 'react-i18next';
|
||||||
import { useDispatch } from 'react-redux';
|
import { useDispatch } from 'react-redux';
|
||||||
import { makeStyles } from 'tss-react/mui';
|
import { makeStyles } from 'tss-react/mui';
|
||||||
|
|
||||||
// @ts-ignore
|
|
||||||
import { approveParticipant } from '../../../av-moderation/actions';
|
import { approveParticipant } from '../../../av-moderation/actions';
|
||||||
import Button from '../../../base/ui/components/web/Button';
|
import Button from '../../../base/ui/components/web/Button';
|
||||||
// @ts-ignore
|
|
||||||
import { QUICK_ACTION_BUTTON } from '../../constants';
|
import { QUICK_ACTION_BUTTON } from '../../constants';
|
||||||
|
|
||||||
type Props = {
|
type Props = {
|
||||||
|
|
|
@ -6,17 +6,14 @@ import { WithTranslation } from 'react-i18next';
|
||||||
|
|
||||||
import { IState } from '../../../app/types';
|
import { IState } from '../../../app/types';
|
||||||
import participantsPaneTheme from '../../../base/components/themes/participantsPaneTheme.json';
|
import participantsPaneTheme from '../../../base/components/themes/participantsPaneTheme.json';
|
||||||
// @ts-ignore
|
import { openDialog } from '../../../base/dialog/actions';
|
||||||
import { openDialog } from '../../../base/dialog';
|
|
||||||
import { translate } from '../../../base/i18n/functions';
|
import { translate } from '../../../base/i18n/functions';
|
||||||
import { IconClose, IconHorizontalPoints } from '../../../base/icons/svg';
|
import { IconClose, IconHorizontalPoints } from '../../../base/icons/svg';
|
||||||
// @ts-ignore
|
|
||||||
import { isLocalParticipantModerator } from '../../../base/participants/functions';
|
import { isLocalParticipantModerator } from '../../../base/participants/functions';
|
||||||
import { connect } from '../../../base/redux/functions';
|
import { connect } from '../../../base/redux/functions';
|
||||||
import Button from '../../../base/ui/components/web/Button';
|
import Button from '../../../base/ui/components/web/Button';
|
||||||
import ClickableIcon from '../../../base/ui/components/web/ClickableIcon';
|
import ClickableIcon from '../../../base/ui/components/web/ClickableIcon';
|
||||||
import { BUTTON_TYPES } from '../../../base/ui/constants';
|
import { BUTTON_TYPES } from '../../../base/ui/constants';
|
||||||
// @ts-ignore
|
|
||||||
import { isAddBreakoutRoomButtonVisible } from '../../../breakout-rooms/functions';
|
import { isAddBreakoutRoomButtonVisible } from '../../../breakout-rooms/functions';
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import { MuteEveryoneDialog } from '../../../video-menu/components/';
|
import { MuteEveryoneDialog } from '../../../video-menu/components/';
|
||||||
|
@ -27,7 +24,6 @@ import {
|
||||||
getParticipantsPaneOpen,
|
getParticipantsPaneOpen,
|
||||||
isMoreActionsVisible,
|
isMoreActionsVisible,
|
||||||
isMuteAllVisible
|
isMuteAllVisible
|
||||||
// @ts-ignore
|
|
||||||
} from '../../functions';
|
} from '../../functions';
|
||||||
import { AddBreakoutRoomButton } from '../breakout-rooms/components/web/AddBreakoutRoomButton';
|
import { AddBreakoutRoomButton } from '../breakout-rooms/components/web/AddBreakoutRoomButton';
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
import { IState } from '../app/types';
|
import { IState } from '../app/types';
|
||||||
import {
|
import {
|
||||||
isEnabledFromState,
|
isEnabledFromState,
|
||||||
|
@ -7,8 +6,8 @@ import {
|
||||||
isSupported
|
isSupported
|
||||||
} from '../av-moderation/functions';
|
} from '../av-moderation/functions';
|
||||||
import { IStateful } from '../base/app/types';
|
import { IStateful } from '../base/app/types';
|
||||||
// @ts-ignore
|
import { INVITE_ENABLED } from '../base/flags/constants';
|
||||||
import { INVITE_ENABLED, getFeatureFlag } from '../base/flags';
|
import { getFeatureFlag } from '../base/flags/functions';
|
||||||
import { MEDIA_TYPE, type MediaType } from '../base/media/constants';
|
import { MEDIA_TYPE, type MediaType } from '../base/media/constants';
|
||||||
import {
|
import {
|
||||||
getDominantSpeakerParticipant,
|
getDominantSpeakerParticipant,
|
||||||
|
@ -20,6 +19,7 @@ import {
|
||||||
} from '../base/participants/functions';
|
} from '../base/participants/functions';
|
||||||
import { Participant } from '../base/participants/types';
|
import { Participant } from '../base/participants/types';
|
||||||
import { toState } from '../base/redux/functions';
|
import { toState } from '../base/redux/functions';
|
||||||
|
// eslint-disable-next-line lines-around-comment
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import { normalizeAccents } from '../base/util/strings';
|
import { normalizeAccents } from '../base/util/strings';
|
||||||
import { isInBreakoutRoom } from '../breakout-rooms/functions';
|
import { isInBreakoutRoom } from '../breakout-rooms/functions';
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
import React, { ComponentType, useCallback, useState } from 'react';
|
import React, { ComponentType, useCallback, useState } from 'react';
|
||||||
import { useTranslation } from 'react-i18next';
|
import { useTranslation } from 'react-i18next';
|
||||||
import { useDispatch, useSelector } from 'react-redux';
|
import { useDispatch, useSelector } from 'react-redux';
|
||||||
|
@ -8,7 +7,6 @@ import { sendAnalytics } from '../../analytics/functions';
|
||||||
import { IState } from '../../app/types';
|
import { IState } from '../../app/types';
|
||||||
import { getLocalParticipant, getParticipantById } from '../../base/participants/functions';
|
import { getLocalParticipant, getParticipantById } from '../../base/participants/functions';
|
||||||
import { useBoundSelector } from '../../base/util/hooks';
|
import { useBoundSelector } from '../../base/util/hooks';
|
||||||
// @ts-ignore
|
|
||||||
import { registerVote, setVoteChanging } from '../actions';
|
import { registerVote, setVoteChanging } from '../actions';
|
||||||
import { COMMAND_ANSWER_POLL } from '../constants';
|
import { COMMAND_ANSWER_POLL } from '../constants';
|
||||||
import { Poll } from '../types';
|
import { Poll } from '../types';
|
||||||
|
|
|
@ -7,7 +7,6 @@ import { getLocalParticipant } from '../../../base/participants/functions';
|
||||||
import Button from '../../../base/ui/components/native/Button';
|
import Button from '../../../base/ui/components/native/Button';
|
||||||
import Switch from '../../../base/ui/components/native/Switch';
|
import Switch from '../../../base/ui/components/native/Switch';
|
||||||
import { BUTTON_TYPES } from '../../../base/ui/constants';
|
import { BUTTON_TYPES } from '../../../base/ui/constants';
|
||||||
// @ts-ignore
|
|
||||||
import { isSubmitAnswerDisabled } from '../../functions';
|
import { isSubmitAnswerDisabled } from '../../functions';
|
||||||
import AbstractPollAnswer, { AbstractProps } from '../AbstractPollAnswer';
|
import AbstractPollAnswer, { AbstractProps } from '../AbstractPollAnswer';
|
||||||
|
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
import { Theme } from '@mui/material';
|
import { Theme } from '@mui/material';
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import { makeStyles } from 'tss-react/mui';
|
import { makeStyles } from 'tss-react/mui';
|
||||||
|
@ -7,7 +6,6 @@ import { makeStyles } from 'tss-react/mui';
|
||||||
import Button from '../../../base/ui/components/web/Button';
|
import Button from '../../../base/ui/components/web/Button';
|
||||||
import Checkbox from '../../../base/ui/components/web/Checkbox';
|
import Checkbox from '../../../base/ui/components/web/Checkbox';
|
||||||
import { BUTTON_TYPES } from '../../../base/ui/constants';
|
import { BUTTON_TYPES } from '../../../base/ui/constants';
|
||||||
// @ts-ignore
|
|
||||||
import { isSubmitAnswerDisabled } from '../../functions';
|
import { isSubmitAnswerDisabled } from '../../functions';
|
||||||
import AbstractPollAnswer, { AbstractProps } from '../AbstractPollAnswer';
|
import AbstractPollAnswer, { AbstractProps } from '../AbstractPollAnswer';
|
||||||
|
|
||||||
|
|
|
@ -17,9 +17,7 @@ import { useDispatch, useSelector } from 'react-redux';
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import { appNavigate } from '../../app/actions.native';
|
import { appNavigate } from '../../app/actions.native';
|
||||||
import { IState } from '../../app/types';
|
import { IState } from '../../app/types';
|
||||||
// @ts-ignore
|
|
||||||
import { setAudioOnly } from '../../base/audio-only/actions';
|
import { setAudioOnly } from '../../base/audio-only/actions';
|
||||||
// @ts-ignore
|
|
||||||
import { getConferenceName } from '../../base/conference/functions';
|
import { getConferenceName } from '../../base/conference/functions';
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import { connect } from '../../base/connection/actions.native';
|
import { connect } from '../../base/connection/actions.native';
|
||||||
|
@ -30,8 +28,7 @@ import { getLocalParticipant } from '../../base/participants/functions';
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import { getFieldValue } from '../../base/react';
|
import { getFieldValue } from '../../base/react';
|
||||||
import { ASPECT_RATIO_NARROW } from '../../base/responsive-ui/constants';
|
import { ASPECT_RATIO_NARROW } from '../../base/responsive-ui/constants';
|
||||||
// @ts-ignore
|
import { updateSettings } from '../../base/settings/actions';
|
||||||
import { updateSettings } from '../../base/settings';
|
|
||||||
import BaseTheme from '../../base/ui/components/BaseTheme.native';
|
import BaseTheme from '../../base/ui/components/BaseTheme.native';
|
||||||
import Button from '../../base/ui/components/native/Button';
|
import Button from '../../base/ui/components/native/Button';
|
||||||
import { BUTTON_TYPES } from '../../base/ui/constants';
|
import { BUTTON_TYPES } from '../../base/ui/constants';
|
||||||
|
@ -48,7 +45,6 @@ import { screen } from '../../mobile/navigation/routes';
|
||||||
import AudioMuteButton from '../../toolbox/components/AudioMuteButton';
|
import AudioMuteButton from '../../toolbox/components/AudioMuteButton';
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import VideoMuteButton from '../../toolbox/components/VideoMuteButton';
|
import VideoMuteButton from '../../toolbox/components/VideoMuteButton';
|
||||||
// @ts-ignore
|
|
||||||
import { isDisplayNameRequired } from '../functions';
|
import { isDisplayNameRequired } from '../functions';
|
||||||
import { PrejoinProps } from '../types';
|
import { PrejoinProps } from '../types';
|
||||||
|
|
||||||
|
|
|
@ -11,8 +11,6 @@ import { connect } from '../../../base/redux/functions';
|
||||||
import {
|
import {
|
||||||
getDeviceStatusText,
|
getDeviceStatusText,
|
||||||
getDeviceStatusType
|
getDeviceStatusType
|
||||||
|
|
||||||
// @ts-ignore
|
|
||||||
} from '../../functions';
|
} from '../../functions';
|
||||||
|
|
||||||
export interface Props extends WithTranslation {
|
export interface Props extends WithTranslation {
|
||||||
|
|
|
@ -16,7 +16,6 @@ import { getLocalParticipant, hasRaisedHand } from '../../../base/participants/f
|
||||||
import GifsMenu from '../../../gifs/components/web/GifsMenu';
|
import GifsMenu from '../../../gifs/components/web/GifsMenu';
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import GifsMenuButton from '../../../gifs/components/web/GifsMenuButton';
|
import GifsMenuButton from '../../../gifs/components/web/GifsMenuButton';
|
||||||
// @ts-ignore
|
|
||||||
import { isGifEnabled, isGifsMenuOpen } from '../../../gifs/functions';
|
import { isGifEnabled, isGifsMenuOpen } from '../../../gifs/functions';
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import { dockToolbox } from '../../../toolbox/actions.web';
|
import { dockToolbox } from '../../../toolbox/actions.web';
|
||||||
|
|
|
@ -1,11 +1,9 @@
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
import { v4 as uuidv4 } from 'uuid';
|
import { v4 as uuidv4 } from 'uuid';
|
||||||
|
|
||||||
import { IState } from '../app/types';
|
import { IState } from '../app/types';
|
||||||
// @ts-ignore
|
import { REACTIONS_ENABLED } from '../base/flags/constants';
|
||||||
import { REACTIONS_ENABLED, getFeatureFlag } from '../base/flags';
|
import { getFeatureFlag } from '../base/flags/functions';
|
||||||
import { getLocalParticipant } from '../base/participants/functions';
|
import { getLocalParticipant } from '../base/participants/functions';
|
||||||
// @ts-ignore
|
|
||||||
import { extractFqnFromPath } from '../dynamic-branding/functions.any';
|
import { extractFqnFromPath } from '../dynamic-branding/functions.any';
|
||||||
|
|
||||||
import { REACTIONS, ReactionEmojiProps, ReactionThreshold, SOUNDS_THRESHOLDS } from './constants';
|
import { REACTIONS, ReactionEmojiProps, ReactionThreshold, SOUNDS_THRESHOLDS } from './constants';
|
||||||
|
|
|
@ -1,16 +1,13 @@
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
import { batch } from 'react-redux';
|
import { batch } from 'react-redux';
|
||||||
|
|
||||||
import { createReactionSoundsDisabledEvent } from '../analytics/AnalyticsEvents';
|
import { createReactionSoundsDisabledEvent } from '../analytics/AnalyticsEvents';
|
||||||
import { sendAnalytics } from '../analytics/functions';
|
import { sendAnalytics } from '../analytics/functions';
|
||||||
import { IStore } from '../app/types';
|
import { IStore } from '../app/types';
|
||||||
import { APP_WILL_MOUNT, APP_WILL_UNMOUNT } from '../base/app/actionTypes';
|
import { APP_WILL_MOUNT, APP_WILL_UNMOUNT } from '../base/app/actionTypes';
|
||||||
import {
|
import { CONFERENCE_JOIN_IN_PROGRESS, SET_START_REACTIONS_MUTED } from '../base/conference/actionTypes';
|
||||||
CONFERENCE_JOIN_IN_PROGRESS,
|
// eslint-disable-next-line lines-around-comment
|
||||||
SET_START_REACTIONS_MUTED,
|
// @ts-ignore
|
||||||
setStartReactionsMuted
|
import { setStartReactionsMuted } from '../base/conference/actions';
|
||||||
// @ts-ignore
|
|
||||||
} from '../base/conference';
|
|
||||||
import {
|
import {
|
||||||
getParticipantById,
|
getParticipantById,
|
||||||
getParticipantCount,
|
getParticipantCount,
|
||||||
|
@ -18,14 +15,11 @@ import {
|
||||||
} from '../base/participants/functions';
|
} from '../base/participants/functions';
|
||||||
import MiddlewareRegistry from '../base/redux/MiddlewareRegistry';
|
import MiddlewareRegistry from '../base/redux/MiddlewareRegistry';
|
||||||
import { SETTINGS_UPDATED } from '../base/settings/actionTypes';
|
import { SETTINGS_UPDATED } from '../base/settings/actionTypes';
|
||||||
// @ts-ignore
|
|
||||||
import { updateSettings } from '../base/settings/actions';
|
import { updateSettings } from '../base/settings/actions';
|
||||||
// @ts-ignore
|
import { playSound, registerSound, unregisterSound } from '../base/sounds/actions';
|
||||||
import { playSound, registerSound, unregisterSound } from '../base/sounds';
|
|
||||||
// @ts-ignore
|
|
||||||
import { getDisabledSounds } from '../base/sounds/functions.any';
|
import { getDisabledSounds } from '../base/sounds/functions.any';
|
||||||
// @ts-ignore
|
import { showNotification } from '../notifications/actions';
|
||||||
import { NOTIFICATION_TIMEOUT_TYPE, showNotification } from '../notifications';
|
import { NOTIFICATION_TIMEOUT_TYPE } from '../notifications/constants';
|
||||||
|
|
||||||
import {
|
import {
|
||||||
ADD_REACTION_BUFFER,
|
ADD_REACTION_BUFFER,
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
import { getURLWithoutParamsNormalized } from '../base/connection/utils';
|
import { getURLWithoutParamsNormalized } from '../base/connection/utils';
|
||||||
import PersistenceRegistry from '../base/redux/PersistenceRegistry';
|
import PersistenceRegistry from '../base/redux/PersistenceRegistry';
|
||||||
import ReducerRegistry from '../base/redux/ReducerRegistry';
|
import ReducerRegistry from '../base/redux/ReducerRegistry';
|
||||||
|
@ -8,6 +7,7 @@ import {
|
||||||
_STORE_CURRENT_CONFERENCE,
|
_STORE_CURRENT_CONFERENCE,
|
||||||
_UPDATE_CONFERENCE_DURATION
|
_UPDATE_CONFERENCE_DURATION
|
||||||
} from './actionTypes';
|
} from './actionTypes';
|
||||||
|
// eslint-disable-next-line lines-around-comment
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import { isRecentListEnabled } from './functions';
|
import { isRecentListEnabled } from './functions';
|
||||||
|
|
||||||
|
|
|
@ -16,7 +16,6 @@ import {
|
||||||
import { StyleType } from '../../../base/styles';
|
import { StyleType } from '../../../base/styles';
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import { authorizeDropbox, updateDropboxToken } from '../../../dropbox';
|
import { authorizeDropbox, updateDropboxToken } from '../../../dropbox';
|
||||||
// @ts-ignore
|
|
||||||
import { isVpaasMeeting } from '../../../jaas/functions';
|
import { isVpaasMeeting } from '../../../jaas/functions';
|
||||||
import { RECORDING_TYPES } from '../../constants';
|
import { RECORDING_TYPES } from '../../constants';
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
import i18next from 'i18next';
|
import i18next from 'i18next';
|
||||||
import { v4 as uuidV4 } from 'uuid';
|
import { v4 as uuidV4 } from 'uuid';
|
||||||
import fixWebmDuration from 'webm-duration-fix';
|
import fixWebmDuration from 'webm-duration-fix';
|
||||||
|
@ -8,6 +7,7 @@ import { getRoomName } from '../../../base/conference/functions';
|
||||||
import { MEDIA_TYPE } from '../../../base/media/constants';
|
import { MEDIA_TYPE } from '../../../base/media/constants';
|
||||||
import { getLocalTrack, getTrackState } from '../../../base/tracks/functions';
|
import { getLocalTrack, getTrackState } from '../../../base/tracks/functions';
|
||||||
import { inIframe } from '../../../base/util/iframeUtils';
|
import { inIframe } from '../../../base/util/iframeUtils';
|
||||||
|
// eslint-disable-next-line lines-around-comment
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import { stopLocalVideoRecording } from '../../actions.any';
|
import { stopLocalVideoRecording } from '../../actions.any';
|
||||||
|
|
||||||
|
@ -223,6 +223,7 @@ const LocalRecordingManager: ILocalRecordingManager = {
|
||||||
const currentTitle = document.title;
|
const currentTitle = document.title;
|
||||||
|
|
||||||
document.title = i18next.t('localRecording.selectTabTitle');
|
document.title = i18next.t('localRecording.selectTabTitle');
|
||||||
|
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
gdmStream = await navigator.mediaDevices.getDisplayMedia({
|
gdmStream = await navigator.mediaDevices.getDisplayMedia({
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
|
|
|
@ -5,8 +5,7 @@ import React from 'react';
|
||||||
|
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import { StartRecordingDialog } from '../..';
|
import { StartRecordingDialog } from '../..';
|
||||||
// @ts-ignore
|
import { openDialog } from '../../../../base/dialog/actions';
|
||||||
import { openDialog } from '../../../../base/dialog';
|
|
||||||
import { translate } from '../../../../base/i18n/functions';
|
import { translate } from '../../../../base/i18n/functions';
|
||||||
import { IconHighlight } from '../../../../base/icons/svg';
|
import { IconHighlight } from '../../../../base/icons/svg';
|
||||||
import { MEET_FEATURES } from '../../../../base/jwt/constants';
|
import { MEET_FEATURES } from '../../../../base/jwt/constants';
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
import { Theme } from '@mui/material';
|
import { Theme } from '@mui/material';
|
||||||
import { withStyles } from '@mui/styles';
|
import { withStyles } from '@mui/styles';
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
|
@ -9,6 +8,7 @@ import { JitsiRecordingConstants } from '../../../base/lib-jitsi-meet';
|
||||||
import { connect } from '../../../base/redux/functions';
|
import { connect } from '../../../base/redux/functions';
|
||||||
import AbstractRecordingLabel, {
|
import AbstractRecordingLabel, {
|
||||||
_mapStateToProps
|
_mapStateToProps
|
||||||
|
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
} from '../AbstractRecordingLabel';
|
} from '../AbstractRecordingLabel';
|
||||||
|
|
||||||
|
@ -57,6 +57,7 @@ class RecordingLabel extends AbstractRecordingLabel {
|
||||||
<div>
|
<div>
|
||||||
<Label
|
<Label
|
||||||
className = { classes?.[mode] }
|
className = { classes?.[mode] }
|
||||||
|
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
text = { t(this._getLabelKey()) } />
|
text = { t(this._getLabelKey()) } />
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -1,7 +1,6 @@
|
||||||
/* eslint-disable import/order */
|
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import rtcstatsInit from '@jitsi/rtcstats/rtcstats';
|
import rtcstatsInit from '@jitsi/rtcstats/rtcstats';
|
||||||
|
// eslint-disable-next-line lines-around-comment
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import traceInit from '@jitsi/rtcstats/trace-ws';
|
import traceInit from '@jitsi/rtcstats/trace-ws';
|
||||||
|
|
||||||
|
|
|
@ -1,24 +1,15 @@
|
||||||
/* eslint-disable import/order */
|
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import { jitsiLocalStorage } from '@jitsi/js-utils';
|
import { jitsiLocalStorage } from '@jitsi/js-utils';
|
||||||
|
|
||||||
import { getAmplitudeIdentity } from '../analytics/functions';
|
import { getAmplitudeIdentity } from '../analytics/functions';
|
||||||
import {
|
import { IStore } from '../app/types';
|
||||||
getAnalyticsRoomName,
|
import { IStateful } from '../base/app/types';
|
||||||
getConferenceOptions
|
import { getAnalyticsRoomName, getConferenceOptions } from '../base/conference/functions';
|
||||||
|
import { getLocalParticipant } from '../base/participants/functions';
|
||||||
// @ts-ignore
|
|
||||||
} from '../base/conference';
|
|
||||||
|
|
||||||
// @ts-ignore
|
|
||||||
import { getLocalParticipant } from '../base/participants';
|
|
||||||
|
|
||||||
import { toState } from '../base/redux/functions';
|
import { toState } from '../base/redux/functions';
|
||||||
|
|
||||||
import RTCStats from './RTCStats';
|
import RTCStats from './RTCStats';
|
||||||
import logger from './logger';
|
import logger from './logger';
|
||||||
import { IStateful } from '../base/app/types';
|
|
||||||
import { IStore } from '../app/types';
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Checks whether rtcstats is enabled or not.
|
* Checks whether rtcstats is enabled or not.
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
// @ts-ignore
|
|
||||||
import { getLogger } from '../base/logging/functions';
|
import { getLogger } from '../base/logging/functions';
|
||||||
|
|
||||||
export default getLogger('features/rtcstats');
|
export default getLogger('features/rtcstats');
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
/* eslint-disable lines-around-comment */
|
|
||||||
import { AnyAction } from 'redux';
|
import { AnyAction } from 'redux';
|
||||||
|
|
||||||
import { IStore } from '../app/types';
|
import { IStore } from '../app/types';
|
||||||
|
@ -8,14 +7,12 @@ import {
|
||||||
CONFERENCE_UNIQUE_ID_SET,
|
CONFERENCE_UNIQUE_ID_SET,
|
||||||
CONFERENCE_WILL_LEAVE,
|
CONFERENCE_WILL_LEAVE,
|
||||||
E2E_RTT_CHANGED
|
E2E_RTT_CHANGED
|
||||||
// @ts-ignore
|
} from '../base/conference/actionTypes';
|
||||||
} from '../base/conference';
|
|
||||||
import { LIB_WILL_INIT } from '../base/lib-jitsi-meet/actionTypes';
|
import { LIB_WILL_INIT } from '../base/lib-jitsi-meet/actionTypes';
|
||||||
import { DOMINANT_SPEAKER_CHANGED } from '../base/participants/actionTypes';
|
import { DOMINANT_SPEAKER_CHANGED } from '../base/participants/actionTypes';
|
||||||
import MiddlewareRegistry from '../base/redux/MiddlewareRegistry';
|
import MiddlewareRegistry from '../base/redux/MiddlewareRegistry';
|
||||||
import { TRACK_ADDED, TRACK_UPDATED } from '../base/tracks/actionTypes';
|
import { TRACK_ADDED, TRACK_UPDATED } from '../base/tracks/actionTypes';
|
||||||
import { getCurrentRoomId, isInBreakoutRoom } from '../breakout-rooms/functions';
|
import { getCurrentRoomId, isInBreakoutRoom } from '../breakout-rooms/functions';
|
||||||
// @ts-ignore
|
|
||||||
import { extractFqnFromPath } from '../dynamic-branding/functions.any';
|
import { extractFqnFromPath } from '../dynamic-branding/functions.any';
|
||||||
import { ADD_FACE_EXPRESSION, FACE_LANDMARK_DETECTION_STOPPED } from '../face-landmarks/actionTypes';
|
import { ADD_FACE_EXPRESSION, FACE_LANDMARK_DETECTION_STOPPED } from '../face-landmarks/actionTypes';
|
||||||
|
|
||||||
|
|
|
@ -7,7 +7,8 @@ import { useDispatch } from 'react-redux';
|
||||||
import { makeStyles } from 'tss-react/mui';
|
import { makeStyles } from 'tss-react/mui';
|
||||||
|
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import { Dialog, hideDialog } from '../../../base/dialog';
|
import { Dialog } from '../../../base/dialog';
|
||||||
|
import { hideDialog } from '../../../base/dialog/actions';
|
||||||
import Icon from '../../../base/icons/components/Icon';
|
import Icon from '../../../base/icons/components/Icon';
|
||||||
import { IconSearch } from '../../../base/icons/svg';
|
import { IconSearch } from '../../../base/icons/svg';
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
|
|
|
@ -1,8 +1,7 @@
|
||||||
import React, { Component } from 'react';
|
import React, { Component } from 'react';
|
||||||
import { WithTranslation } from 'react-i18next';
|
import { WithTranslation } from 'react-i18next';
|
||||||
import type { Dispatch } from 'redux';
|
|
||||||
|
|
||||||
import { IState } from '../../app/types';
|
import { IState, IStore } from '../../app/types';
|
||||||
import { translate } from '../../base/i18n/functions';
|
import { translate } from '../../base/i18n/functions';
|
||||||
import { connect } from '../../base/redux/functions';
|
import { connect } from '../../base/redux/functions';
|
||||||
import { updateSettings } from '../../base/settings/actions';
|
import { updateSettings } from '../../base/settings/actions';
|
||||||
|
@ -24,7 +23,7 @@ export interface Props extends WithTranslation {
|
||||||
/**
|
/**
|
||||||
* The redux {@code dispatch} function.
|
* The redux {@code dispatch} function.
|
||||||
*/
|
*/
|
||||||
dispatch: Dispatch<any>;
|
dispatch: IStore['dispatch'];
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue