2018-01-26 10:19:43 +00:00
|
|
|
// @flow
|
2018-06-20 20:19:53 +00:00
|
|
|
import { toState } from '../base/redux';
|
2018-01-26 10:19:43 +00:00
|
|
|
import { parseStandardURIString } from '../base/util';
|
2018-06-20 20:19:53 +00:00
|
|
|
import { i18next, DEFAULT_LANGUAGE, LANGUAGES } from '../base/i18n';
|
2019-05-30 21:10:40 +00:00
|
|
|
import {
|
|
|
|
getLocalParticipant,
|
|
|
|
isLocalParticipantModerator
|
|
|
|
} from '../base/participants';
|
2018-01-26 10:19:43 +00:00
|
|
|
|
2018-04-28 01:43:11 +00:00
|
|
|
declare var interfaceConfig: Object;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Used for web. Indicates if the setting section is enabled.
|
|
|
|
*
|
|
|
|
* @param {string} settingName - The name of the setting section as defined in
|
|
|
|
* interface_config.js and SettingsMenu.js.
|
|
|
|
* @returns {boolean} True to indicate that the given setting section
|
|
|
|
* is enabled, false otherwise.
|
|
|
|
*/
|
|
|
|
export function isSettingEnabled(settingName: string) {
|
|
|
|
return interfaceConfig.SETTINGS_SECTIONS.includes(settingName);
|
|
|
|
}
|
|
|
|
|
2018-01-26 10:19:43 +00:00
|
|
|
/**
|
|
|
|
* Normalizes a URL entered by the user.
|
|
|
|
* FIXME: Consider adding this to base/util/uri.
|
|
|
|
*
|
|
|
|
* @param {string} url - The URL to validate.
|
|
|
|
* @returns {string|null} - The normalized URL, or null if the URL is invalid.
|
|
|
|
*/
|
|
|
|
export function normalizeUserInputURL(url: string) {
|
|
|
|
/* eslint-disable no-param-reassign */
|
|
|
|
|
|
|
|
if (url) {
|
|
|
|
url = url.replace(/\s/g, '').toLowerCase();
|
2018-02-26 16:14:46 +00:00
|
|
|
|
2018-01-26 10:19:43 +00:00
|
|
|
const urlRegExp = new RegExp('^(\\w+://)?(.+)$');
|
|
|
|
const urlComponents = urlRegExp.exec(url);
|
|
|
|
|
2018-10-03 09:29:19 +00:00
|
|
|
if (urlComponents && (!urlComponents[1]
|
|
|
|
|| !urlComponents[1].startsWith('http'))) {
|
2018-01-26 10:19:43 +00:00
|
|
|
url = `https://${urlComponents[2]}`;
|
|
|
|
}
|
|
|
|
|
2018-02-26 16:14:46 +00:00
|
|
|
const parsedURI = parseStandardURIString(url);
|
2018-01-26 10:19:43 +00:00
|
|
|
|
|
|
|
if (!parsedURI.host) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
return parsedURI.toString();
|
|
|
|
}
|
|
|
|
|
|
|
|
return url;
|
|
|
|
|
|
|
|
/* eslint-enable no-param-reassign */
|
|
|
|
}
|
2018-04-28 01:43:11 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Used for web. Returns whether or not only Device Selection is configured to
|
|
|
|
* display as a setting.
|
|
|
|
*
|
|
|
|
* @returns {boolean}
|
|
|
|
*/
|
|
|
|
export function shouldShowOnlyDeviceSelection() {
|
|
|
|
return interfaceConfig.SETTINGS_SECTIONS.length === 1
|
|
|
|
&& isSettingEnabled('devices');
|
|
|
|
}
|
2018-06-20 20:19:53 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the properties for the "More" tab from settings dialog from Redux
|
|
|
|
* state.
|
|
|
|
*
|
|
|
|
* @param {(Function|Object)} stateful -The (whole) redux state, or redux's
|
|
|
|
* {@code getState} function to be used to retrieve the state.
|
|
|
|
* @returns {Object} - The properties for the "More" tab from settings dialog.
|
|
|
|
*/
|
|
|
|
export function getMoreTabProps(stateful: Object | Function) {
|
|
|
|
const state = toState(stateful);
|
|
|
|
const language = i18next.language || DEFAULT_LANGUAGE;
|
2018-08-06 15:24:59 +00:00
|
|
|
const {
|
|
|
|
conference,
|
|
|
|
followMeEnabled,
|
|
|
|
startAudioMutedPolicy,
|
|
|
|
startVideoMutedPolicy
|
|
|
|
} = state['features/base/conference'];
|
2019-04-26 18:11:53 +00:00
|
|
|
const followMeActive = Boolean(state['features/follow-me'].moderator);
|
2018-06-20 20:19:53 +00:00
|
|
|
const configuredTabs = interfaceConfig.SETTINGS_SECTIONS || [];
|
|
|
|
|
|
|
|
// The settings sections to display.
|
2018-08-06 15:24:59 +00:00
|
|
|
const showModeratorSettings = Boolean(
|
|
|
|
conference
|
|
|
|
&& configuredTabs.includes('moderator')
|
2019-05-30 21:10:40 +00:00
|
|
|
&& isLocalParticipantModerator(state));
|
2018-06-20 20:19:53 +00:00
|
|
|
|
|
|
|
return {
|
|
|
|
currentLanguage: language,
|
2019-04-26 18:11:53 +00:00
|
|
|
followMeActive: Boolean(conference && followMeActive),
|
2018-08-06 15:24:59 +00:00
|
|
|
followMeEnabled: Boolean(conference && followMeEnabled),
|
2018-06-20 20:19:53 +00:00
|
|
|
languages: LANGUAGES,
|
|
|
|
showLanguageSettings: configuredTabs.includes('language'),
|
|
|
|
showModeratorSettings,
|
2018-08-06 15:24:59 +00:00
|
|
|
startAudioMuted: Boolean(conference && startAudioMutedPolicy),
|
|
|
|
startVideoMuted: Boolean(conference && startVideoMutedPolicy)
|
2018-06-20 20:19:53 +00:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the properties for the "Profile" tab from settings dialog from Redux
|
|
|
|
* state.
|
|
|
|
*
|
|
|
|
* @param {(Function|Object)} stateful -The (whole) redux state, or redux's
|
|
|
|
* {@code getState} function to be used to retrieve the state.
|
|
|
|
* @returns {Object} - The properties for the "Profile" tab from settings
|
|
|
|
* dialog.
|
|
|
|
*/
|
|
|
|
export function getProfileTabProps(stateful: Object | Function) {
|
|
|
|
const state = toState(stateful);
|
2018-08-06 15:24:59 +00:00
|
|
|
const {
|
|
|
|
authEnabled,
|
|
|
|
authLogin,
|
|
|
|
conference
|
|
|
|
} = state['features/base/conference'];
|
2018-06-20 20:19:53 +00:00
|
|
|
const localParticipant = getLocalParticipant(state);
|
|
|
|
|
|
|
|
return {
|
2018-08-06 15:24:59 +00:00
|
|
|
authEnabled: Boolean(conference && authEnabled),
|
2019-03-19 20:44:37 +00:00
|
|
|
authLogin,
|
2018-06-20 20:19:53 +00:00
|
|
|
displayName: localParticipant.name,
|
|
|
|
email: localParticipant.email
|
|
|
|
};
|
|
|
|
}
|