* 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
42 lines
876 B
JavaScript
42 lines
876 B
JavaScript
// @flow
|
|
import { observable, action } from 'mobx';
|
|
import invariant from 'invariant';
|
|
import { client } from 'utils/ApiClient';
|
|
import type { User } from 'types';
|
|
|
|
type View = {
|
|
user: User,
|
|
count: number,
|
|
};
|
|
|
|
class DocumentViewersStore {
|
|
documentId: string;
|
|
@observable viewers: Array<View>;
|
|
@observable isFetching: boolean;
|
|
|
|
@action fetchViewers = async () => {
|
|
this.isFetching = true;
|
|
|
|
try {
|
|
const res = await client.get(
|
|
'/views.list',
|
|
{
|
|
id: this.documentId,
|
|
},
|
|
{ cache: true }
|
|
);
|
|
invariant(res && res.data, 'Data should be available');
|
|
this.viewers = res.data.users;
|
|
} catch (e) {
|
|
console.error('Something went wrong');
|
|
}
|
|
this.isFetching = false;
|
|
};
|
|
|
|
constructor(documentId: string) {
|
|
this.documentId = documentId;
|
|
}
|
|
}
|
|
|
|
export default DocumentViewersStore;
|