[Glitch] Feature: Direct message from Statuses
Port 904a2479dd2085dfc94f33746ad6f7a755e72609 to glitch-soc
This commit is contained in:
		
							parent
							
								
									fb6de5310d
								
							
						
					
					
						commit
						97c69de416
					
				@ -32,6 +32,8 @@ export default class Status extends ImmutablePureComponent {
 | 
			
		||||
    onFavourite: PropTypes.func,
 | 
			
		||||
    onReblog: PropTypes.func,
 | 
			
		||||
    onDelete: PropTypes.func,
 | 
			
		||||
    onDirect: PropTypes.func,
 | 
			
		||||
    onMention: PropTypes.func,
 | 
			
		||||
    onPin: PropTypes.func,
 | 
			
		||||
    onOpenMedia: PropTypes.func,
 | 
			
		||||
    onOpenVideo: PropTypes.func,
 | 
			
		||||
 | 
			
		||||
@ -10,6 +10,7 @@ import RelativeTimestamp from './relative_timestamp';
 | 
			
		||||
 | 
			
		||||
const messages = defineMessages({
 | 
			
		||||
  delete: { id: 'status.delete', defaultMessage: 'Delete' },
 | 
			
		||||
  direct: { id: 'status.direct', defaultMessage: 'Direct message @{name}' },
 | 
			
		||||
  mention: { id: 'status.mention', defaultMessage: 'Mention @{name}' },
 | 
			
		||||
  mute: { id: 'account.mute', defaultMessage: 'Mute @{name}' },
 | 
			
		||||
  block: { id: 'account.block', defaultMessage: 'Block @{name}' },
 | 
			
		||||
@ -44,6 +45,7 @@ export default class StatusActionBar extends ImmutablePureComponent {
 | 
			
		||||
    onFavourite: PropTypes.func,
 | 
			
		||||
    onReblog: PropTypes.func,
 | 
			
		||||
    onDelete: PropTypes.func,
 | 
			
		||||
    onDirect: PropTypes.func,
 | 
			
		||||
    onMention: PropTypes.func,
 | 
			
		||||
    onMute: PropTypes.func,
 | 
			
		||||
    onBlock: PropTypes.func,
 | 
			
		||||
@ -98,6 +100,10 @@ export default class StatusActionBar extends ImmutablePureComponent {
 | 
			
		||||
    this.props.onMention(this.props.status.get('account'), this.context.router.history);
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  handleDirectClick = () => {
 | 
			
		||||
    this.props.onDirect(this.props.status.get('account'), this.context.router.history);
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  handleMuteClick = () => {
 | 
			
		||||
    this.props.onMute(this.props.status.get('account'));
 | 
			
		||||
  }
 | 
			
		||||
@ -157,6 +163,7 @@ export default class StatusActionBar extends ImmutablePureComponent {
 | 
			
		||||
      menu.push({ text: intl.formatMessage(messages.delete), action: this.handleDeleteClick });
 | 
			
		||||
    } else {
 | 
			
		||||
      menu.push({ text: intl.formatMessage(messages.mention, { name: status.getIn(['account', 'username']) }), action: this.handleMentionClick });
 | 
			
		||||
      menu.push({ text: intl.formatMessage(messages.direct, { name: status.getIn(['account', 'username']) }), action: this.handleDirectClick });
 | 
			
		||||
      menu.push(null);
 | 
			
		||||
      menu.push({ text: intl.formatMessage(messages.mute, { name: status.getIn(['account', 'username']) }), action: this.handleMuteClick });
 | 
			
		||||
      menu.push({ text: intl.formatMessage(messages.block, { name: status.getIn(['account', 'username']) }), action: this.handleBlockClick });
 | 
			
		||||
 | 
			
		||||
@ -5,6 +5,7 @@ import { makeGetStatus } from 'flavours/glitch/selectors';
 | 
			
		||||
import {
 | 
			
		||||
  replyCompose,
 | 
			
		||||
  mentionCompose,
 | 
			
		||||
  directCompose,
 | 
			
		||||
} from 'flavours/glitch/actions/compose';
 | 
			
		||||
import {
 | 
			
		||||
  reblog,
 | 
			
		||||
@ -131,6 +132,10 @@ const mapDispatchToProps = (dispatch, { intl }) => ({
 | 
			
		||||
    }
 | 
			
		||||
  },
 | 
			
		||||
 | 
			
		||||
  onDirect (account, router) {
 | 
			
		||||
    dispatch(directCompose(account, router));
 | 
			
		||||
  },
 | 
			
		||||
 | 
			
		||||
  onMention (account, router) {
 | 
			
		||||
    dispatch(mentionCompose(account, router));
 | 
			
		||||
  },
 | 
			
		||||
 | 
			
		||||
@ -8,6 +8,7 @@ import { me } from 'flavours/glitch/util/initial_state';
 | 
			
		||||
 | 
			
		||||
const messages = defineMessages({
 | 
			
		||||
  delete: { id: 'status.delete', defaultMessage: 'Delete' },
 | 
			
		||||
  direct: { id: 'status.direct', defaultMessage: 'Direct message @{name}' },
 | 
			
		||||
  mention: { id: 'status.mention', defaultMessage: 'Mention @{name}' },
 | 
			
		||||
  reply: { id: 'status.reply', defaultMessage: 'Reply' },
 | 
			
		||||
  reblog: { id: 'status.reblog', defaultMessage: 'Boost' },
 | 
			
		||||
@ -43,6 +44,7 @@ export default class ActionBar extends React.PureComponent {
 | 
			
		||||
    onMuteConversation: PropTypes.func,
 | 
			
		||||
    onBlock: PropTypes.func,
 | 
			
		||||
    onDelete: PropTypes.func.isRequired,
 | 
			
		||||
    onDirect: PropTypes.func.isRequired,
 | 
			
		||||
    onMention: PropTypes.func.isRequired,
 | 
			
		||||
    onReport: PropTypes.func,
 | 
			
		||||
    onPin: PropTypes.func,
 | 
			
		||||
@ -70,6 +72,10 @@ export default class ActionBar extends React.PureComponent {
 | 
			
		||||
    this.props.onDelete(this.props.status);
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  handleDirectClick = () => {
 | 
			
		||||
    this.props.onDirect(this.props.status.get('account'), this.context.router.history);
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  handleMentionClick = () => {
 | 
			
		||||
    this.props.onMention(this.props.status.get('account'), this.context.router.history);
 | 
			
		||||
  }
 | 
			
		||||
@ -115,6 +121,7 @@ export default class ActionBar extends React.PureComponent {
 | 
			
		||||
 | 
			
		||||
    if (publicStatus) {
 | 
			
		||||
      menu.push({ text: intl.formatMessage(messages.embed), action: this.handleEmbed });
 | 
			
		||||
      menu.push(null);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    if (me === status.getIn(['account', 'id'])) {
 | 
			
		||||
@ -128,6 +135,7 @@ export default class ActionBar extends React.PureComponent {
 | 
			
		||||
      menu.push({ text: intl.formatMessage(messages.delete), action: this.handleDeleteClick });
 | 
			
		||||
    } else {
 | 
			
		||||
      menu.push({ text: intl.formatMessage(messages.mention, { name: status.getIn(['account', 'username']) }), action: this.handleMentionClick });
 | 
			
		||||
      menu.push({ text: intl.formatMessage(messages.direct, { name: status.getIn(['account', 'username']) }), action: this.handleDirectClick });
 | 
			
		||||
      menu.push(null);
 | 
			
		||||
      menu.push({ text: intl.formatMessage(messages.mute, { name: status.getIn(['account', 'username']) }), action: this.handleMuteClick });
 | 
			
		||||
      menu.push({ text: intl.formatMessage(messages.block, { name: status.getIn(['account', 'username']) }), action: this.handleBlockClick });
 | 
			
		||||
 | 
			
		||||
@ -21,6 +21,7 @@ import {
 | 
			
		||||
import {
 | 
			
		||||
  replyCompose,
 | 
			
		||||
  mentionCompose,
 | 
			
		||||
  directCompose,
 | 
			
		||||
} from 'flavours/glitch/actions/compose';
 | 
			
		||||
import { blockAccount } from 'flavours/glitch/actions/accounts';
 | 
			
		||||
import { muteStatus, unmuteStatus, deleteStatus } from 'flavours/glitch/actions/statuses';
 | 
			
		||||
@ -170,6 +171,10 @@ export default class Status extends ImmutablePureComponent {
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  handleDirectClick = (account, router) => {
 | 
			
		||||
    this.props.dispatch(directCompose(account, router));
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  handleMentionClick = (account, router) => {
 | 
			
		||||
    this.props.dispatch(mentionCompose(account, router));
 | 
			
		||||
  }
 | 
			
		||||
@ -399,6 +404,7 @@ export default class Status extends ImmutablePureComponent {
 | 
			
		||||
                  onReblog={this.handleReblogClick}
 | 
			
		||||
                  onBookmark={this.handleBookmarkClick}
 | 
			
		||||
                  onDelete={this.handleDeleteClick}
 | 
			
		||||
                  onDirect={this.handleDirectClick}
 | 
			
		||||
                  onMention={this.handleMentionClick}
 | 
			
		||||
                  onMute={this.handleMuteClick}
 | 
			
		||||
                  onMuteConversation={this.handleConversationMuteClick}
 | 
			
		||||
 | 
			
		||||
@ -322,16 +322,18 @@ export default function compose(state = initialState, action) {
 | 
			
		||||
  case COMPOSE_UPLOAD_PROGRESS:
 | 
			
		||||
    return state.set('progress', Math.round((action.loaded / action.total) * 100));
 | 
			
		||||
  case COMPOSE_MENTION:
 | 
			
		||||
    return state
 | 
			
		||||
      .update('text', text => `${text}@${action.account.get('acct')} `)
 | 
			
		||||
      .set('focusDate', new Date())
 | 
			
		||||
      .set('idempotencyKey', uuid());
 | 
			
		||||
    return state.withMutations(map => {
 | 
			
		||||
      map.update('text', text => [text.trim(), `@${action.account.get('acct')} `].filter((str) => str.length !== 0).join(' '));
 | 
			
		||||
      map.set('focusDate', new Date());
 | 
			
		||||
      map.set('idempotencyKey', uuid());
 | 
			
		||||
    });
 | 
			
		||||
  case COMPOSE_DIRECT:
 | 
			
		||||
    return state
 | 
			
		||||
      .update('text', text => `@${action.account.get('acct')} `)
 | 
			
		||||
      .set('privacy', 'direct')
 | 
			
		||||
      .set('focusDate', new Date())
 | 
			
		||||
      .set('idempotencyKey', uuid());
 | 
			
		||||
    return state.withMutations(map => {
 | 
			
		||||
      map.update('text', text => [text.trim(), `@${action.account.get('acct')} `].filter((str) => str.length !== 0).join(' '));
 | 
			
		||||
      map.set('privacy', 'direct');
 | 
			
		||||
      map.set('focusDate', new Date());
 | 
			
		||||
      map.set('idempotencyKey', uuid());
 | 
			
		||||
    });
 | 
			
		||||
  case COMPOSE_SUGGESTIONS_CLEAR:
 | 
			
		||||
    return state.update('suggestions', ImmutableList(), list => list.clear()).set('suggestion_token', null);
 | 
			
		||||
  case COMPOSE_SUGGESTIONS_READY:
 | 
			
		||||
 | 
			
		||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user