| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162 |
- import { IReduxState } from '../../app/types';
-
- import { IConfig } from './configType';
- import { TOOLBAR_BUTTONS } from './constants';
-
- export * from './functions.any';
-
- /**
- * Removes all analytics related options from the given configuration, in case of a libre build.
- *
- * @param {*} config - The configuration which needs to be cleaned up.
- * @returns {void}
- */
- export function _cleanupConfig(config: IConfig) { // eslint-disable-line @typescript-eslint/no-unused-vars
- }
-
- /**
- * Returns the replaceParticipant config.
- *
- * @param {Object} state - The state of the app.
- * @returns {boolean}
- */
- export function getReplaceParticipant(state: IReduxState): string | undefined {
- return state['features/base/config'].replaceParticipant;
- }
-
- /**
- * Returns the list of enabled toolbar buttons.
- *
- * @param {Object} state - The redux state.
- * @returns {Array<string>} - The list of enabled toolbar buttons.
- */
- export function getToolbarButtons(state: IReduxState): Array<string> {
- const { toolbarButtons } = state['features/base/config'];
-
- return Array.isArray(toolbarButtons) ? toolbarButtons : TOOLBAR_BUTTONS;
- }
-
- /**
- * Checks if the specified button is enabled.
- *
- * @param {string} buttonName - The name of the button.
- * {@link interfaceConfig}.
- * @param {Object|Array<string>} state - The redux state or the array with the enabled buttons.
- * @returns {boolean} - True if the button is enabled and false otherwise.
- */
- export function isToolbarButtonEnabled(buttonName: string, state: IReduxState | Array<string>) {
- const buttons = Array.isArray(state) ? state : getToolbarButtons(state);
-
- return buttons.includes(buttonName);
- }
-
- /**
- * Returns whether audio level measurement is enabled or not.
- *
- * @param {Object} state - The state of the app.
- * @returns {boolean}
- */
- export function areAudioLevelsEnabled(state: IReduxState): boolean {
- // Default to false for React Native as audio levels are of no interest to the mobile app.
- return navigator.product !== 'ReactNative' && !state['features/base/config'].disableAudioLevels;
- }
|