1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162 |
- // @flow
-
- import { parseStandardURIString } from '../base/util';
-
- 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);
- }
-
- /**
- * 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();
-
- const urlRegExp = new RegExp('^(\\w+://)?(.+)$');
- const urlComponents = urlRegExp.exec(url);
-
- if (!urlComponents[1] || !urlComponents[1].startsWith('http')) {
- url = `https://${urlComponents[2]}`;
- }
-
- const parsedURI = parseStandardURIString(url);
-
- if (!parsedURI.host) {
- return null;
- }
-
- return parsedURI.toString();
- }
-
- return url;
-
- /* eslint-enable no-param-reassign */
- }
-
- /**
- * 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');
- }
|