phanpy/src/utils/filters.jsx

51 lines
1.6 KiB
React
Raw Normal View History

import mem from './mem';
2023-03-21 16:09:36 +00:00
import store from './store';
function _isFiltered(filtered, filterContext) {
if (!filtered?.length) return false;
2023-03-21 16:09:36 +00:00
const appliedFilters = filtered.filter((f) => {
const { filter } = f;
const hasContext = filter.context.includes(filterContext);
if (!hasContext) return false;
if (!filter.expiresAt) return hasContext;
return new Date(filter.expiresAt) > new Date();
});
if (!appliedFilters.length) return false;
2023-03-21 16:09:36 +00:00
const isHidden = appliedFilters.some((f) => f.filter.filterAction === 'hide');
if (isHidden)
return {
action: 'hide',
};
2023-03-23 13:49:09 +00:00
const isWarn = appliedFilters.some((f) => f.filter.filterAction === 'warn');
if (isWarn) {
2023-03-21 16:09:36 +00:00
const filterTitles = appliedFilters.map((f) => f.filter.title);
return {
action: 'warn',
2023-03-21 16:09:36 +00:00
titles: filterTitles,
titlesStr: filterTitles.join(' • '),
};
}
return false;
}
export const isFiltered = mem(_isFiltered);
export function filteredItem(item, filterContext, currentAccountID) {
const { filtered } = item;
if (!filtered?.length) return true;
const isSelf = currentAccountID && item.account?.id === currentAccountID;
if (isSelf) return true;
const filterState = isFiltered(filtered, filterContext);
if (!filterState) return true;
if (filterState.action === 'hide') return false;
// item._filtered = filterState;
return true;
2023-03-21 16:09:36 +00:00
}
export function filteredItems(items, filterContext) {
if (!items?.length) return [];
if (!filterContext) return items;
const currentAccountID = store.session.get('currentAccount');
return items.filter((item) =>
filteredItem(item, filterContext, currentAccountID),
);
}