Skip to content
Extraits de code Groupes Projets
reply_indicator.js 2,05 ko
Newer Older
  • Learn to ignore specific revisions
  • import React from 'react';
    
    import ImmutablePropTypes from 'react-immutable-proptypes';
    
    import PropTypes from 'prop-types';
    
    import Avatar from '../../../components/avatar';
    import IconButton from '../../../components/icon_button';
    import DisplayName from '../../../components/display_name';
    
    import { defineMessages, injectIntl } from 'react-intl';
    
    import ImmutablePureComponent from 'react-immutable-pure-component';
    
    import { isRtl } from '../../../rtl';
    
    
    const messages = defineMessages({
    
      cancel: { id: 'reply_indicator.cancel', defaultMessage: 'Cancel' },
    
    @injectIntl
    export default class ReplyIndicator extends ImmutablePureComponent {
    
      static contextTypes = {
    
        router: PropTypes.object,
    
      };
    
      static propTypes = {
        status: ImmutablePropTypes.map,
        onCancel: PropTypes.func.isRequired,
    
        intl: PropTypes.object.isRequired,
    
        this.props.onCancel();
    
      handleAccountClick = (e) => {
    
        if (e.button === 0) {
          e.preventDefault();
    
          this.context.router.history.push(`/accounts/${this.props.status.getIn(['account', 'id'])}`);
    
      render () {
    
        const { status, intl } = this.props;
    
        if (!status) {
          return null;
        }
    
    
        const content = { __html: status.get('contentHtml') };
        const style   = {
          direction: isRtl(status.get('search_index')) ? 'rtl' : 'ltr',
        };
    
    
        return (
    
          <div className='reply-indicator'>
    
            <div className='reply-indicator__header'>
    
              <div className='reply-indicator__cancel'><IconButton title={intl.formatMessage(messages.cancel)} icon='times' onClick={this.handleClick} inverted /></div>
    
              <a href={status.getIn(['account', 'url'])} onClick={this.handleAccountClick} className='reply-indicator__display-name'>
    
                <div className='reply-indicator__display-avatar'><Avatar account={status.get('account')} size={24} /></div>
    
                <DisplayName account={status.get('account')} />
    
              </a>
            </div>
    
    
            <div className='reply-indicator__content' style={style} dangerouslySetInnerHTML={content} />