commit: 0bd4608ad1b29328f04fcad6e7a20ef61668d239
parent: 693383234c68397c22bb94d1d93cb33c6a8ae939
Author: Eugen Rochko <eugen@zeonfederated.com>
Date: Mon, 26 Sep 2016 15:49:28 +0200
Fix #55 - Filter self from pre-filled mentions
Diffstat:
1 file changed, 18 insertions(+), 7 deletions(-)
diff --git a/app/assets/javascripts/components/reducers/compose.jsx b/app/assets/javascripts/components/reducers/compose.jsx
@@ -10,9 +10,10 @@ import {
COMPOSE_UPLOAD_FAIL,
COMPOSE_UPLOAD_UNDO,
COMPOSE_UPLOAD_PROGRESS
-} from '../actions/compose';
-import { TIMELINE_DELETE } from '../actions/timelines';
-import Immutable from 'immutable';
+} from '../actions/compose';
+import { TIMELINE_DELETE } from '../actions/timelines';
+import { ACCOUNT_SET_SELF } from '../actions/accounts';
+import Immutable from 'immutable';
const initialState = Immutable.Map({
text: '',
@@ -20,11 +21,19 @@ const initialState = Immutable.Map({
is_submitting: false,
is_uploading: false,
progress: 0,
- media_attachments: Immutable.List([])
+ media_attachments: Immutable.List([]),
+ me: null
});
-function statusToTextMentions(status) {
- return Immutable.OrderedSet([`@${status.getIn(['account', 'acct'])} `]).union(status.get('mentions').map(mention => `@${mention.get('acct')} `)).join('');
+function statusToTextMentions(state, status) {
+ let set = Immutable.OrderedSet([]);
+ let me = state.get('me');
+
+ if (status.getIn(['account', 'id']) !== me) {
+ set = set.add(`@${status.getIn(['account', 'acct'])} `);
+ }
+
+ return set.union(status.get('mentions').filterNot(mention => mention.get('id') === me).map(mention => `@${mention.get('acct')} `)).join('');
};
function clearAll(state) {
@@ -60,7 +69,7 @@ export default function compose(state = initialState, action) {
case COMPOSE_REPLY:
return state.withMutations(map => {
map.set('in_reply_to', action.status.get('id'));
- map.set('text', statusToTextMentions(action.status));
+ map.set('text', statusToTextMentions(state, action.status));
});
case COMPOSE_REPLY_CANCEL:
return state.withMutations(map => {
@@ -89,6 +98,8 @@ export default function compose(state = initialState, action) {
} else {
return state;
}
+ case ACCOUNT_SET_SELF:
+ return state.set('me', action.account.id);
default:
return state;
}