commit: f5382ec08504a06c005e8f40738596c5c5c837de
parent: 407073d7a2557bb0da42472b822c664863bcc7fc
Author: Yamagishi Kazutoshi <ykzts@desire.sh>
Date: Tue, 18 Jul 2017 22:20:38 +0900
Exclude self toots from regular expression filter (#4245)
* Exclude self toots from regular expression filter
* refactor
Diffstat:
1 file changed, 24 insertions(+), 19 deletions(-)
diff --git a/app/javascript/mastodon/features/ui/containers/status_list_container.js b/app/javascript/mastodon/features/ui/containers/status_list_container.js
@@ -10,31 +10,36 @@ const makeGetStatusIds = () => createSelector([
(state, { type }) => state.getIn(['timelines', type, 'items'], ImmutableList()),
(state) => state.get('statuses'),
(state) => state.getIn(['meta', 'me']),
-], (columnSettings, statusIds, statuses, me) => statusIds.filter(id => {
- const statusForId = statuses.get(id);
- let showStatus = true;
+], (columnSettings, statusIds, statuses, me) => {
+ const rawRegex = columnSettings.getIn(['regex', 'body'], '').trim();
+ let regex = null;
- if (columnSettings.getIn(['shows', 'reblog']) === false) {
- showStatus = showStatus && statusForId.get('reblog') === null;
+ try {
+ regex = rawRegex && new RegExp(rawRegex, 'i');
+ } catch (e) {
+ // Bad regex, don't affect filters
}
- if (columnSettings.getIn(['shows', 'reply']) === false) {
- showStatus = showStatus && (statusForId.get('in_reply_to_id') === null || statusForId.get('in_reply_to_account_id') === me);
- }
+ return statusIds.filter(id => {
+ const statusForId = statuses.get(id);
+ let showStatus = true;
- if (columnSettings.getIn(['regex', 'body'], '').trim().length > 0) {
- try {
- if (showStatus) {
- const regex = new RegExp(columnSettings.getIn(['regex', 'body']).trim(), 'i');
- showStatus = !regex.test(statusForId.get('reblog') ? statuses.getIn([statusForId.get('reblog'), 'search_index']) : statusForId.get('search_index'));
- }
- } catch(e) {
- // Bad regex, don't affect filters
+ if (columnSettings.getIn(['shows', 'reblog']) === false) {
+ showStatus = showStatus && statusForId.get('reblog') === null;
+ }
+
+ if (columnSettings.getIn(['shows', 'reply']) === false) {
+ showStatus = showStatus && (statusForId.get('in_reply_to_id') === null || statusForId.get('in_reply_to_account_id') === me);
}
- }
- return showStatus;
-}));
+ if (showStatus && regex && statusForId.get('account') !== me) {
+ const searchIndex = statusForId.get('reblog') ? statuses.getIn([statusForId.get('reblog'), 'search_index']) : statusForId.get('search_index');
+ showStatus = !regex.test(searchIndex);
+ }
+
+ return showStatus;
+ });
+});
const makeMapStateToProps = () => {
const getStatusIds = makeGetStatusIds();