summaryrefslogtreecommitdiffstats
path: root/webapp/components/webrtc/components/webrtc_header.jsx
blob: a5f679da0233acc362ad8baf5d3f23aba825dd65 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
// Copyright (c) 2016-present Mattermost, Inc. All Rights Reserved.
// See License.txt for license information.

import Constants from 'utils/constants.jsx';

import {Tooltip, OverlayTrigger} from 'react-bootstrap';
import {FormattedMessage} from 'react-intl';

import PropTypes from 'prop-types';

import React from 'react';

export default function WebrtcHeader(props) {
    const title = (
        <FormattedMessage
            id='webrtc.header'
            defaultMessage='Call with {username}'
            values={{
                username: props.username
            }}
        />
    );

    const closeSidebarTooltip = (
        <Tooltip id='closeSidebarTooltip'>
            <FormattedMessage
                id='rhs_header.closeTooltip'
                defaultMessage='Close Sidebar'
            />
        </Tooltip>
    );

    const expandSidebarTooltip = (
        <Tooltip id='expandSidebarTooltip'>
            <FormattedMessage
                id='rhs_header.expandTooltip'
                defaultMessage='Expand Sidebar'
            />
        </Tooltip>
    );

    const shrinkSidebarTooltip = (
        <Tooltip id='shrinkSidebarTooltip'>
            <FormattedMessage
                id='rhs_header.expandTooltip'
                defaultMessage='Shrink Sidebar'
            />
        </Tooltip>
    );

    return (
        <div className='sidebar--right__header'>
            <span className='sidebar--right__title'>{title}</span>
            <div className='pull-right'>
                <button
                    type='button'
                    className='sidebar--right__expand'
                    aria-label='Expand'
                    onClick={props.toggleSize}
                >
                    <OverlayTrigger
                        trigger={['hover', 'focus']}
                        delayShow={Constants.OVERLAY_TIME_DELAY}
                        placement='top'
                        overlay={expandSidebarTooltip}
                    >
                        <i className='fa fa-expand'/>
                    </OverlayTrigger>
                    <OverlayTrigger
                        trigger={['hover', 'focus']}
                        delayShow={Constants.OVERLAY_TIME_DELAY}
                        placement='top'
                        overlay={shrinkSidebarTooltip}
                    >
                        <i className='fa fa-compress'/>
                    </OverlayTrigger>
                </button>
                <button
                    type='button'
                    className='sidebar--right__close'
                    aria-label='Close'
                    title='Close'
                    onClick={props.onClose}
                >
                    <OverlayTrigger
                        delayShow={Constants.OVERLAY_TIME_DELAY}
                        placement='top'
                        overlay={closeSidebarTooltip}
                    >
                        <i className='fa fa-sign-out'/>
                    </OverlayTrigger>
                </button>
            </div>
        </div>
    );
}

WebrtcHeader.propTypes = {
    username: PropTypes.string.isRequired,
    onClose: PropTypes.func.isRequired,
    toggleSize: PropTypes.func
};