Browse Source

Minor optimization regarding regexp filtering in timelines

closed-social-glitch-2
Thibaut Girka 5 years ago
committed by ThibG
parent
commit
9d6b46fe34
1 changed files with 15 additions and 8 deletions
  1. +15
    -8
      app/javascript/flavours/glitch/features/ui/containers/status_list_container.js

+ 15
- 8
app/javascript/flavours/glitch/features/ui/containers/status_list_container.js View File

@ -6,19 +6,26 @@ import { createSelector } from 'reselect';
import { debounce } from 'lodash';
import { me } from 'flavours/glitch/util/initial_state';
const makeGetStatusIds = () => createSelector([
(state, { type }) => state.getIn(['settings', type], ImmutableMap()),
(state, { type }) => state.getIn(['timelines', type, 'items'], ImmutableList()),
(state) => state.get('statuses'),
], (columnSettings, statusIds, statuses) => {
const rawRegex = columnSettings.getIn(['regex', 'body'], '').trim();
let regex = null;
const getRegex = createSelector([
(state, { type }) => state.getIn(['settings', type, 'regex', 'body']),
], (rawRegex) => {
let regex = null;
try {
regex = rawRegex && new RegExp(rawRegex, 'i');
regex = rawRegex && new RegExp(rawRegex.trim(), 'i');
} catch (e) {
// Bad regex, don't affect filters
}
return regex;
});
const makeGetStatusIds = () => createSelector([
(state, { type }) => state.getIn(['settings', type], ImmutableMap()),
(state, { type }) => state.getIn(['timelines', type, 'items'], ImmutableList()),
(state) => state.get('statuses'),
getRegex,
], (columnSettings, statusIds, statuses, regex) => {
const rawRegex = columnSettings.getIn(['regex', 'body'], '').trim();
return statusIds.filter(id => {
if (id === null) return true;

Loading…
Cancel
Save