import SideContainerToggler from '../../../modules/UI/side_pannels/SideContainerToggler'; import defaultToolbarButtons from './defaultToolbarButtons'; type MapOfAttributes = { [key: string]: * }; declare var $: Function; declare var AJS: Object; declare var interfaceConfig: Object; export { abstractMapStateToProps } from './functions.native'; /* eslint-disable flowtype/space-before-type-colon */ /** * Takes toolbar button props and maps them to HTML attributes to set. * * @param {Object} props - Props set to the React component. * @returns {MapOfAttributes} */ export function getButtonAttributesByProps(props: Object = {}) : MapOfAttributes { let classNames = props.classNames; if (classNames) { // XXX Make sure to not modify props.classNames because that'd be bad // practice. classNames = [ ...classNames ]; } props.toggled && classNames.push('toggled'); props.unclickable && classNames.push('unclickable'); const result: MapOfAttributes = { className: classNames.join(' '), 'data-container': 'body', 'data-placement': 'bottom', id: props.id }; if (!props.enabled) { result.disabled = 'disabled'; } if (props.hidden) { result.style = { display: 'none' }; } return result; } /* eslint-enable flowtype/space-before-type-colon */ /** * Returns an object which contains the default buttons for the primary and * secondary toolbars. * * @returns {Object} */ export function getDefaultToolboxButtons(): Object { let toolbarButtons = { primaryToolbarButtons: new Map(), secondaryToolbarButtons: new Map() }; if (typeof interfaceConfig !== 'undefined' && interfaceConfig.TOOLBAR_BUTTONS) { const { filmStripOnly } = interfaceConfig; toolbarButtons = interfaceConfig.TOOLBAR_BUTTONS.reduce( (acc, buttonName) => { const button = defaultToolbarButtons[buttonName]; if (button) { const place = _getToolbarButtonPlace(buttonName); button.buttonName = buttonName; // In filmstrip-only mode we only add a button if it's // filmstrip-only enabled. if (!filmStripOnly || button.filmstripOnlyEnabled) { acc[place].set(buttonName, button); } } return acc; }, toolbarButtons); } return toolbarButtons; } /** * Get place for toolbar button. Now it can be in the primary Toolbar or in the * secondary Toolbar. * * @param {string} btn - Button name. * @private * @returns {string} */ function _getToolbarButtonPlace(btn) { return ( interfaceConfig.MAIN_TOOLBAR_BUTTONS.includes(btn) ? 'primaryToolbarButtons' : 'secondaryToolbarButtons'); } /** * Returns toolbar class names to add while rendering. * * @param {Object} props - Props object pass to React component. * @returns {Object} * @private */ export function getToolbarClassNames(props: Object) { const primaryToolbarClassNames = [ interfaceConfig.filmStripOnly ? 'toolbar_filmstrip-only' : 'toolbar_primary' ]; const secondaryToolbarClassNames = [ 'toolbar_secondary' ]; if (props._visible) { const slideInAnimation = SideContainerToggler.isVisible ? 'slideInExtX' : 'slideInX'; primaryToolbarClassNames.push('fadeIn'); secondaryToolbarClassNames.push(slideInAnimation); } else { const slideOutAnimation = SideContainerToggler.isVisible ? 'slideOutExtX' : 'slideOutX'; primaryToolbarClassNames.push('fadeOut'); secondaryToolbarClassNames.push(slideOutAnimation); } return { primaryToolbarClassName: primaryToolbarClassNames.join(' '), secondaryToolbarClassName: secondaryToolbarClassNames.join(' ') }; } /** * Show custom popup/tooltip for a specified button. * * @param {string} popupSelectorID - The selector id of the popup to show. * @param {boolean} show - True or false/show or hide the popup. * @param {number} timeout - The time to show the popup. * @returns {void} */ export function showCustomToolbarPopup( popupSelectorID: string, show: boolean, timeout: number) { AJS.$(popupSelectorID).tooltip({ gravity: $(popupSelectorID).attr('data-popup'), html: true, title: 'title', trigger: 'manual' }); if (show) { AJS.$(popupSelectorID).tooltip('show'); setTimeout( () => { // hide the tooltip AJS.$(popupSelectorID).tooltip('hide'); }, timeout); } else { AJS.$(popupSelectorID).tooltip('hide'); } }