* first pass at updating all Time components each second * fix a couple date variable typos * use class style state management instead of hooks * wip: Separate title from body * address feedback * test: Remove unused test * feat: You in publishing info language fix: Removal of secondary headings * After much deliberation… a migration is needed for this to be reliable * fix: Export to work with new title structure * fix: Untitled * fix: Consistent spacing of first editor node * fix: Emoji in title handling * fix: Time component not updating for new props * chore: Add createdAt case * fix: Conflict after merging new TOC * PR feedback * lint * fix: Heading level adjustment Co-authored-by: Taylor Lapeyre <taylorlapeyre@gmail.com>
36 lines
900 B
JavaScript
36 lines
900 B
JavaScript
// @flow
|
|
import { reduce, filter, find, orderBy } from 'lodash';
|
|
import BaseStore from './BaseStore';
|
|
import RootStore from './RootStore';
|
|
import View from 'models/View';
|
|
|
|
export default class ViewsStore extends BaseStore<View> {
|
|
actions = ['list', 'create'];
|
|
|
|
constructor(rootStore: RootStore) {
|
|
super(rootStore, View);
|
|
}
|
|
|
|
inDocument(documentId: string): View[] {
|
|
return orderBy(
|
|
filter(this.orderedData, view => view.documentId === documentId),
|
|
'lastViewedAt',
|
|
'desc'
|
|
);
|
|
}
|
|
|
|
countForDocument(documentId: string): number {
|
|
const views = this.inDocument(documentId);
|
|
return reduce(views, (memo, view) => memo + view.count, 0);
|
|
}
|
|
|
|
touch(documentId: string, userId: string) {
|
|
const view = find(
|
|
this.orderedData,
|
|
view => view.documentId === documentId && view.user.id === userId
|
|
);
|
|
if (!view) return;
|
|
view.touch();
|
|
}
|
|
}
|