111 lines
3.5 KiB
JavaScript
111 lines
3.5 KiB
JavaScript
import { Fragment } from 'react'
|
|
import { defineMessages, injectIntl, FormattedMessage } from 'react-intl'
|
|
import ImmutablePureComponent from 'react-immutable-pure-component'
|
|
import ImmutablePropTypes from 'react-immutable-proptypes'
|
|
import { openModal } from '../../actions/modal'
|
|
import { MODAL_GROUP_MEMBERS } from '../../constants'
|
|
import { shortNumberFormat } from '../../utils/numbers'
|
|
import PanelLayout from './panel_layout'
|
|
import Button from '../button'
|
|
import Divider from '../divider'
|
|
import Dummy from '../dummy'
|
|
import Icon from '../icon'
|
|
import Text from '../text'
|
|
import RelativeTimestamp from '../relative_timestamp'
|
|
|
|
const messages = defineMessages({
|
|
title: { id: 'about', defaultMessage: 'About' },
|
|
members: { id: 'members', defaultMessage: 'Members' },
|
|
})
|
|
|
|
const mapDispatchToProps = (dispatch) => ({
|
|
onOpenGroupMembersModal(groupId) {
|
|
dispatch(openModal(MODAL_GROUP_MEMBERS, { groupId }))
|
|
},
|
|
})
|
|
|
|
export default
|
|
@injectIntl
|
|
@connect(null, mapDispatchToProps)
|
|
class GroupInfoPanel extends ImmutablePureComponent {
|
|
|
|
static propTypes = {
|
|
group: ImmutablePropTypes.map.isRequired,
|
|
intl: PropTypes.object.isRequired,
|
|
onOpenGroupMembersModal: PropTypes.func.isRequired,
|
|
noPanel: PropTypes.bool,
|
|
}
|
|
|
|
handleOnOpenGroupMembersModal = () => {
|
|
this.props.onOpenGroupMembersModal(this.props.group.get('id'))
|
|
}
|
|
|
|
render() {
|
|
const { intl, group, noPanel } = this.props
|
|
|
|
const Wrapper = noPanel ? Dummy : PanelLayout
|
|
|
|
return (
|
|
<Wrapper title={intl.formatMessage(messages.title)}>
|
|
{
|
|
!!group &&
|
|
<Fragment>
|
|
|
|
<div className={[_s.default, _s.flexRow, _s.alignItemsCenter].join(' ')}>
|
|
<Text weight='medium'>
|
|
{group.get('title')}
|
|
</Text>
|
|
</div>
|
|
|
|
<Divider isSmall />
|
|
|
|
<div className={[_s.default, _s.flexRow, _s.justifyContentCenter].join(' ')}>
|
|
<div className={[_s.default, _s.flexRow, _s.alignItemsCenter].join(' ')}>
|
|
<Icon id='group' size='14px' className={_s.fillPrimary} />
|
|
<Text size='small' className={_s.ml5}>
|
|
{intl.formatMessage(messages.members)}
|
|
</Text>
|
|
</div>
|
|
<Button
|
|
isText
|
|
color='brand'
|
|
backgroundColor='none'
|
|
className={_s.mlAuto}
|
|
onClick={this.handleOnOpenGroupMembersModal}
|
|
>
|
|
<Text color='inherit' weight='medium' size='normal' className={_s.underline_onHover}>
|
|
{shortNumberFormat(group.get('member_count'))}
|
|
|
|
{intl.formatMessage(messages.members)}
|
|
</Text>
|
|
</Button>
|
|
</div>
|
|
|
|
<Divider isSmall />
|
|
|
|
<div className={[_s.default, _s.flexRow, _s.alignItemsCenter].join(' ')}>
|
|
<Icon id='calendar' size='12px' className={_s.fillSecondary} />
|
|
<Text
|
|
size='small'
|
|
color='secondary'
|
|
className={_s.ml5}
|
|
>
|
|
{
|
|
<FormattedMessage id='lists.panel_created' defaultMessage='Created: {date}' values={{
|
|
date: <RelativeTimestamp timestamp={group.get('created_at')} />,
|
|
}} />
|
|
}
|
|
</Text>
|
|
</div>
|
|
|
|
<Divider isSmall />
|
|
|
|
<Text>
|
|
{group.get('description')}
|
|
</Text>
|
|
</Fragment>
|
|
}
|
|
</Wrapper>
|
|
)
|
|
}
|
|
} |