pleroma/app/soapbox/entity-store/utils.ts

55 lines
1.3 KiB
TypeScript
Raw Normal View History

2023-03-14 12:13:49 -07:00
import type { Entity, EntityStore, EntityList, EntityCache, EntityListState } from './types';
2022-12-04 14:58:13 -08:00
/** Insert the entities into the store. */
const updateStore = (store: EntityStore, entities: Entity[]): EntityStore => {
return entities.reduce<EntityStore>((store, entity) => {
store[entity.id] = entity;
return store;
}, { ...store });
2022-12-04 14:58:13 -08:00
};
/** Update the list with new entity IDs. */
const updateList = (list: EntityList, entities: Entity[]): EntityList => {
const newIds = entities.map(entity => entity.id);
const ids = new Set([...Array.from(list.ids), ...newIds]);
const sizeDiff = ids.size - list.ids.size;
list.state.totalCount += sizeDiff;
2022-12-04 14:58:13 -08:00
return {
...list,
ids,
2022-12-04 14:58:13 -08:00
};
};
/** Create an empty entity cache. */
const createCache = (): EntityCache => ({
store: {},
lists: {},
2022-12-04 14:58:13 -08:00
});
/** Create an empty entity list. */
const createList = (): EntityList => ({
ids: new Set(),
2023-03-14 12:13:49 -07:00
state: createListState(),
});
/** Create an empty entity list state. */
const createListState = (): EntityListState => ({
next: undefined,
prev: undefined,
totalCount: 0,
2023-03-14 12:13:49 -07:00
error: null,
fetched: false,
fetching: false,
2023-03-14 12:13:49 -07:00
lastFetchedAt: undefined,
invalid: false,
2022-12-04 14:58:13 -08:00
});
export {
updateStore,
updateList,
createCache,
createList,
2023-03-14 12:13:49 -07:00
createListState,
2022-12-04 14:58:13 -08:00
};