Change layout of posts in web UI (#19423)
This commit is contained in:
		
							parent
							
								
									fcca781aae
								
							
						
					
					
						commit
						0ca29eaa3f
					
				
					 13 changed files with 195 additions and 357 deletions
				
			
		| 
						 | 
				
			
			@ -41,7 +41,7 @@ class FeaturedTags extends ImmutablePureComponent {
 | 
			
		|||
            name={featuredTag.get('name')}
 | 
			
		||||
            href={featuredTag.get('url')}
 | 
			
		||||
            to={`/@${account.get('acct')}/tagged/${featuredTag.get('name')}`}
 | 
			
		||||
            uses={featuredTag.get('statuses_count')}
 | 
			
		||||
            uses={featuredTag.get('statuses_count') * 1}
 | 
			
		||||
            withGraph={false}
 | 
			
		||||
            description={((featuredTag.get('statuses_count') * 1) > 0) ? intl.formatMessage(messages.lastStatusAt, { date: intl.formatDate(featuredTag.get('last_status_at'), { month: 'short', day: '2-digit' }) }) : intl.formatMessage(messages.empty)}
 | 
			
		||||
          />
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -326,25 +326,26 @@ class Header extends ImmutablePureComponent {
 | 
			
		|||
          {!(suspended || hidden) && (
 | 
			
		||||
            <div className='account__header__extra'>
 | 
			
		||||
              <div className='account__header__bio'>
 | 
			
		||||
                {fields.size > 0 && (
 | 
			
		||||
                  <div className='account__header__fields'>
 | 
			
		||||
                    {fields.map((pair, i) => (
 | 
			
		||||
                      <dl key={i}>
 | 
			
		||||
                        <dt dangerouslySetInnerHTML={{ __html: pair.get('name_emojified') }} title={pair.get('name')} className='translate' />
 | 
			
		||||
 | 
			
		||||
                        <dd className={`${pair.get('verified_at') ? 'verified' : ''} translate`} title={pair.get('value_plain')}>
 | 
			
		||||
                          {pair.get('verified_at') && <span title={intl.formatMessage(messages.linkVerifiedOn, { date: intl.formatDate(pair.get('verified_at'), dateFormatOptions) })}><Icon id='check' className='verified__mark' /></span>} <span dangerouslySetInnerHTML={{ __html: pair.get('value_emojified') }} />
 | 
			
		||||
                        </dd>
 | 
			
		||||
                      </dl>
 | 
			
		||||
                    ))}
 | 
			
		||||
                  </div>
 | 
			
		||||
                )}
 | 
			
		||||
 | 
			
		||||
                {(account.get('id') !== me && signedIn) && <AccountNoteContainer account={account} />}
 | 
			
		||||
 | 
			
		||||
                {account.get('note').length > 0 && account.get('note') !== '<p></p>' && <div className='account__header__content translate' dangerouslySetInnerHTML={content} />}
 | 
			
		||||
 | 
			
		||||
                <div className='account__header__joined'><FormattedMessage id='account.joined' defaultMessage='Joined {date}' values={{ date: intl.formatDate(account.get('created_at'), { year: 'numeric', month: 'short', day: '2-digit' }) }} /></div>
 | 
			
		||||
                <div className='account__header__fields'>
 | 
			
		||||
                  <dl>
 | 
			
		||||
                    <dt><FormattedMessage id='account.joined_short' defaultMessage='Joined' /></dt>
 | 
			
		||||
                    <dd>{intl.formatDate(account.get('created_at'), { year: 'numeric', month: 'short', day: '2-digit' })}</dd>
 | 
			
		||||
                  </dl>
 | 
			
		||||
 | 
			
		||||
                  {fields.map((pair, i) => (
 | 
			
		||||
                    <dl key={i}>
 | 
			
		||||
                      <dt dangerouslySetInnerHTML={{ __html: pair.get('name_emojified') }} title={pair.get('name')} className='translate' />
 | 
			
		||||
 | 
			
		||||
                      <dd className={`${pair.get('verified_at') ? 'verified' : ''} translate`} title={pair.get('value_plain')}>
 | 
			
		||||
                        {pair.get('verified_at') && <span title={intl.formatMessage(messages.linkVerifiedOn, { date: intl.formatDate(pair.get('verified_at'), dateFormatOptions) })}><Icon id='check' className='verified__mark' /></span>} <span dangerouslySetInnerHTML={{ __html: pair.get('value_emojified') }} />
 | 
			
		||||
                      </dd>
 | 
			
		||||
                    </dl>
 | 
			
		||||
                  ))}
 | 
			
		||||
                </div>
 | 
			
		||||
              </div>
 | 
			
		||||
 | 
			
		||||
              <div className='account__header__extra__links'>
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -56,7 +56,7 @@ class ActionBar extends React.PureComponent {
 | 
			
		|||
    return (
 | 
			
		||||
      <div className='compose__action-bar'>
 | 
			
		||||
        <div className='compose__action-bar-dropdown'>
 | 
			
		||||
          <DropdownMenuContainer items={menu} icon='chevron-down' size={16} direction='right' />
 | 
			
		||||
          <DropdownMenuContainer items={menu} icon='ellipsis-v' size={18} direction='right' />
 | 
			
		||||
        </div>
 | 
			
		||||
      </div>
 | 
			
		||||
    );
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -21,7 +21,7 @@ export default class NavigationBar extends ImmutablePureComponent {
 | 
			
		|||
      <div className='navigation-bar'>
 | 
			
		||||
        <Permalink href={this.props.account.get('url')} to={`/@${this.props.account.get('acct')}`}>
 | 
			
		||||
          <span style={{ display: 'none' }}>{this.props.account.get('acct')}</span>
 | 
			
		||||
          <Avatar account={this.props.account} size={48} />
 | 
			
		||||
          <Avatar account={this.props.account} size={46} />
 | 
			
		||||
        </Permalink>
 | 
			
		||||
 | 
			
		||||
        <div className='navigation-bar__profile'>
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -287,9 +287,10 @@ class ActionBar extends React.PureComponent {
 | 
			
		|||
        <div className='detailed-status__button'><IconButton title={intl.formatMessage(messages.reply)} icon={status.get('in_reply_to_account_id') === status.getIn(['account', 'id']) ? 'reply' : replyIcon} onClick={this.handleReplyClick} /></div>
 | 
			
		||||
        <div className='detailed-status__button' ><IconButton className={classNames({ reblogPrivate })} disabled={!publicStatus && !reblogPrivate} active={status.get('reblogged')} title={reblogTitle} icon='retweet' onClick={this.handleReblogClick} /></div>
 | 
			
		||||
        <div className='detailed-status__button'><IconButton className='star-icon' animate active={status.get('favourited')} title={intl.formatMessage(messages.favourite)} icon='star' onClick={this.handleFavouriteClick} /></div>
 | 
			
		||||
        {shareButton}
 | 
			
		||||
        <div className='detailed-status__button'><IconButton className='bookmark-icon' disabled={!signedIn} active={status.get('bookmarked')} title={intl.formatMessage(messages.bookmark)} icon='bookmark' onClick={this.handleBookmarkClick} /></div>
 | 
			
		||||
 | 
			
		||||
        {shareButton}
 | 
			
		||||
 | 
			
		||||
        <div className='detailed-status__action-bar-dropdown'>
 | 
			
		||||
          <DropdownMenuContainer size={18} icon='ellipsis-h' disabled={!signedIn} status={status} items={menu} direction='left' title={intl.formatMessage(messages.more)} />
 | 
			
		||||
        </div>
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -262,7 +262,7 @@ class DetailedStatus extends ImmutablePureComponent {
 | 
			
		|||
      <div style={outerStyle}>
 | 
			
		||||
        <div ref={this.setRef} className={classNames('detailed-status', `detailed-status-${status.get('visibility')}`, { compact })}>
 | 
			
		||||
          <a href={status.getIn(['account', 'url'])} onClick={this.handleAccountClick} className='detailed-status__display-name'>
 | 
			
		||||
            <div className='detailed-status__display-avatar'><Avatar account={status.get('account')} size={48} /></div>
 | 
			
		||||
            <div className='detailed-status__display-avatar'><Avatar account={status.get('account')} size={46} /></div>
 | 
			
		||||
            <DisplayName account={status.get('account')} localDomain={this.props.domain} />
 | 
			
		||||
          </a>
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -2,10 +2,6 @@ import React from 'react';
 | 
			
		|||
import PropTypes from 'prop-types';
 | 
			
		||||
import ImmutablePropTypes from 'react-immutable-proptypes';
 | 
			
		||||
import ImmutablePureComponent from 'react-immutable-pure-component';
 | 
			
		||||
import StatusContent from '../../../components/status_content';
 | 
			
		||||
import Avatar from '../../../components/avatar';
 | 
			
		||||
import RelativeTimestamp from '../../../components/relative_timestamp';
 | 
			
		||||
import DisplayName from '../../../components/display_name';
 | 
			
		||||
import IconButton from '../../../components/icon_button';
 | 
			
		||||
import classNames from 'classnames';
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -38,32 +34,8 @@ export default class ActionsModal extends ImmutablePureComponent {
 | 
			
		|||
  }
 | 
			
		||||
 | 
			
		||||
  render () {
 | 
			
		||||
    const status = this.props.status && (
 | 
			
		||||
      <div className='status light'>
 | 
			
		||||
        <div className='boost-modal__status-header'>
 | 
			
		||||
          <div className='boost-modal__status-time'>
 | 
			
		||||
            <a href={this.props.status.get('url')} className='status__relative-time' target='_blank' rel='noopener noreferrer'>
 | 
			
		||||
              <RelativeTimestamp timestamp={this.props.status.get('created_at')} />
 | 
			
		||||
            </a>
 | 
			
		||||
          </div>
 | 
			
		||||
 | 
			
		||||
          <a href={this.props.status.getIn(['account', 'url'])} className='status__display-name'>
 | 
			
		||||
            <div className='status__avatar'>
 | 
			
		||||
              <Avatar account={this.props.status.get('account')} size={48} />
 | 
			
		||||
            </div>
 | 
			
		||||
 | 
			
		||||
            <DisplayName account={this.props.status.get('account')} />
 | 
			
		||||
          </a>
 | 
			
		||||
        </div>
 | 
			
		||||
 | 
			
		||||
        <StatusContent status={this.props.status} />
 | 
			
		||||
      </div>
 | 
			
		||||
    );
 | 
			
		||||
 | 
			
		||||
    return (
 | 
			
		||||
      <div className='modal-root__modal actions-modal'>
 | 
			
		||||
        {status}
 | 
			
		||||
 | 
			
		||||
        <ul className={classNames({ 'with-status': !!status })}>
 | 
			
		||||
          {this.props.actions.map(this.renderAction)}
 | 
			
		||||
        </ul>
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -97,12 +97,11 @@ class BoostModal extends ImmutablePureComponent {
 | 
			
		|||
      <div className='modal-root__modal boost-modal'>
 | 
			
		||||
        <div className='boost-modal__container'>
 | 
			
		||||
          <div className={classNames('status', `status-${status.get('visibility')}`, 'light')}>
 | 
			
		||||
            <div className='boost-modal__status-header'>
 | 
			
		||||
              <div className='boost-modal__status-time'>
 | 
			
		||||
                <a href={status.get('url')} className='status__relative-time' target='_blank' rel='noopener noreferrer'>
 | 
			
		||||
                  <span className='status__visibility-icon'><Icon id={visibilityIcon.icon} title={visibilityIcon.text} /></span>
 | 
			
		||||
                  <RelativeTimestamp timestamp={status.get('created_at')} /></a>
 | 
			
		||||
              </div>
 | 
			
		||||
            <div className='status__info'>
 | 
			
		||||
              <a href={status.get('url')} className='status__relative-time' target='_blank' rel='noopener noreferrer'>
 | 
			
		||||
                <span className='status__visibility-icon'><Icon id={visibilityIcon.icon} title={visibilityIcon.text} /></span>
 | 
			
		||||
                <RelativeTimestamp timestamp={status.get('created_at')} />
 | 
			
		||||
              </a>
 | 
			
		||||
 | 
			
		||||
              <a onClick={this.handleAccountClick} href={status.getIn(['account', 'url'])} className='status__display-name'>
 | 
			
		||||
                <div className='status__avatar'>
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Reference in a new issue