| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178 | // @flow
import React, { PureComponent } from 'react';
import { SafeAreaView, View } from 'react-native';
import { WebView } from 'react-native-webview';
import type { Dispatch } from 'redux';
import { ColorSchemeRegistry } from '../../../base/color-scheme';
import { translate } from '../../../base/i18n';
import { HeaderWithNavigation, LoadingIndicator, SlidingView } from '../../../base/react';
import { connect } from '../../../base/redux';
import { toggleDocument } from '../../actions';
import { getSharedDocumentUrl } from '../../functions';
import styles, { INDICATOR_COLOR } from './styles';
/**
 * The type of the React {@code Component} props of {@code ShareDocument}.
 */
type Props = {
    /**
     * URL for the shared document.
     */
    _documentUrl: string,
    /**
     * Color schemed style of the header component.
     */
    _headerStyles: Object,
    /**
     * True if the chat window should be rendered.
     */
    _isOpen: boolean,
    /**
     * The Redux dispatch function.
     */
    dispatch: Dispatch<any>,
    /**
     * Function to be used to translate i18n labels.
     */
    t: Function
};
/**
 * Implements a React native component that renders the shared document window.
 */
class SharedDocument extends PureComponent<Props> {
    /**
     * Instantiates a new instance.
     *
     * @inheritdoc
     */
    constructor(props: Props) {
        super(props);
        this._onClose = this._onClose.bind(this);
        this._onError = this._onError.bind(this);
        this._renderLoading = this._renderLoading.bind(this);
    }
    /**
     * Implements React's {@link Component#render()}.
     *
     * @inheritdoc
     */
    render() {
        const { _documentUrl, _isOpen } = this.props;
        const webViewStyles = this._getWebViewStyles();
        return (
            <SlidingView
                onHide = { this._onClose }
                position = 'bottom'
                show = { _isOpen } >
                <View style = { styles.webViewWrapper }>
                    <HeaderWithNavigation
                        headerLabelKey = 'documentSharing.title'
                        onPressBack = { this._onClose } />
                    <SafeAreaView style = { webViewStyles }>
                        <WebView
                            onError = { this._onError }
                            renderLoading = { this._renderLoading }
                            source = {{ uri: _documentUrl }}
                            startInLoadingState = { true } />
                    </SafeAreaView>
                </View>
            </SlidingView>
        );
    }
    /**
     * Computes the styles required for the WebView component.
     *
     * @returns {Object}
     */
    _getWebViewStyles() {
        return {
            ...styles.webView,
            backgroundColor: this.props._headerStyles.screenHeader.backgroundColor
        };
    }
    _onClose: () => boolean
    /**
     * Closes the window.
     *
     * @returns {boolean}
     */
    _onClose() {
        const { _isOpen, dispatch } = this.props;
        if (_isOpen) {
            dispatch(toggleDocument());
            return true;
        }
        return false;
    }
    _onError: () => void;
    /**
     * Callback to handle the error if the page fails to load.
     *
     * @returns {void}
     */
    _onError() {
        const { _isOpen, dispatch } = this.props;
        if (_isOpen) {
            dispatch(toggleDocument());
        }
    }
    _renderLoading: () => React$Component<any>;
    /**
     * Renders the loading indicator.
     *
     * @returns {React$Component<any>}
     */
    _renderLoading() {
        return (
            <View style = { styles.indicatorWrapper }>
                <LoadingIndicator
                    color = { INDICATOR_COLOR }
                    size = 'large' />
            </View>
        );
    }
}
/**
 * Maps (parts of) the redux state to {@link SharedDocument} React {@code Component} props.
 *
 * @param {Object} state - The redux store/state.
 * @private
 * @returns {Object}
 */
export function _mapStateToProps(state: Object) {
    const { editing } = state['features/etherpad'];
    const documentUrl = getSharedDocumentUrl(state);
    return {
        _documentUrl: documentUrl,
        _headerStyles: ColorSchemeRegistry.get(state, 'Header'),
        _isOpen: editing
    };
}
export default translate(connect(_mapStateToProps)(SharedDocument));
 |