| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879 | import React, { Component } from 'react';
import DesktopSourcePreview from './DesktopSourcePreview';
/**
 * React component for showing a grid of DesktopSourcePreviews.
 *
 * @extends Component
 */
class DesktopPickerPane extends Component {
    /**
     * DesktopPickerPane component's property types.
     *
     * @static
     */
    static propTypes = {
        /**
         * The handler to be invoked when a DesktopSourcePreview is clicked.
         */
        onClick: React.PropTypes.func,
        /**
         * The handler to be invoked when a DesktopSourcePreview is double
         * clicked.
         */
        onDoubleClick: React.PropTypes.func,
        /**
         * The id of the DesktopCapturerSource that is currently selected.
         */
        selectedSourceId: React.PropTypes.string,
        /**
         * An array of DesktopCapturerSources.
         */
        sources: React.PropTypes.array,
        /**
         * The source type of the DesktopCapturerSources to display.
         */
        type: React.PropTypes.string
    }
    /**
     * Implements React's {@link Component#render()}.
     *
     * @inheritdoc
     * @returns {ReactElement}
     */
    render() {
        const {
            onClick,
            onDoubleClick,
            selectedSourceId,
            sources,
            type
        } = this.props;
        const classNames
            = `desktop-picker-pane default-scrollbar source-type-${type}`;
        const previews
            = sources.map(
                source =>
                    <DesktopSourcePreview
                        key = { source.id }
                        onClick = { onClick }
                        onDoubleClick = { onDoubleClick }
                        selected = { source.id === selectedSourceId }
                        source = { source } />);
        return (
            <div className = { classNames }>
                { previews }
            </div>
        );
    }
}
export default DesktopPickerPane;
 |