| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970 | /* @flow */
import React, { Component } from 'react';
/**
 * The type of the React {@code Component} props of {@link DialogContainer}.
 */
type Props = {
    /**
     * The component to render.
     */
    _component: Function,
    /**
     * The props to pass to the component that will be rendered.
     */
    _componentProps: Object,
    /**
     * True if the UI is in a compact state where we don't show dialogs.
     */
    _reducedUI: boolean
};
/**
 * Implements a DialogContainer responsible for showing all dialogs.
 */
export default class AbstractDialogContainer extends Component<Props> {
    /**
     * Returns the dialog to be displayed.
     *
     * @private
     * @returns {ReactElement|null}
     */
    _renderDialogContent() {
        const {
            _component: component,
            _reducedUI: reducedUI
        } = this.props;
        return (
            component && !reducedUI
                ? React.createElement(component, this.props._componentProps)
                : null);
    }
}
/**
 * Maps (parts of) the redux state to the associated
 * {@code AbstractDialogContainer}'s props.
 *
 * @param {Object} state - The redux state.
 * @private
 * @returns {{
 *     _component: React.Component,
 *     _componentProps: Object,
 *     _reducedUI: boolean
 * }}
 */
export function abstractMapStateToProps(state: Object) {
    const stateFeaturesBaseDialog = state['features/base/dialog'];
    const { reducedUI } = state['features/base/responsive-ui'];
    return {
        _component: stateFeaturesBaseDialog.component,
        _componentProps: stateFeaturesBaseDialog.componentProps,
        _reducedUI: reducedUI
    };
}
 |