* Recording document views * Add 'views' to document response * Basic displaying of document views, probably want it more sublte than this? But hey, lets get it in there * Bigly improves. RESTful > RPC * Display of who's viewed doc * Add Popover, add Scrollable, move views store * Working server tests 💁 * Document Stars (#81) * Added: Starred documents * UI is dumb but functionality works * Star now displayed inline in title * Optimistic rendering * Documents Endpoints (#85) * More seeds, documents.list endpoint * Upgrade deprecated middleware * document.viewers, specs * Add documents.starred Add request specs for star / unstar endpoints * Basic /starred page * Remove comment * Fixed double layout
30 lines
769 B
JavaScript
30 lines
769 B
JavaScript
// @flow
|
|
import { observable, action, runInAction } from 'mobx';
|
|
import invariant from 'invariant';
|
|
import { client } from 'utils/ApiClient';
|
|
import type { Document } from 'types';
|
|
|
|
class StarredDocumentsStore {
|
|
@observable documents: Array<Document> = [];
|
|
@observable isFetching = false;
|
|
|
|
@action fetchDocuments = async () => {
|
|
this.isFetching = true;
|
|
|
|
try {
|
|
const res = await client.get('/documents.starred');
|
|
invariant(res && res.data, 'res or res.data missing');
|
|
const { data } = res;
|
|
runInAction('update state after fetching data', () => {
|
|
this.documents = data;
|
|
});
|
|
} catch (e) {
|
|
console.error('Something went wrong');
|
|
}
|
|
|
|
this.isFetching = false;
|
|
};
|
|
}
|
|
|
|
export default StarredDocumentsStore;
|