2017-05-23 07:45:15 +00:00
|
|
|
// @flow
|
2019-01-05 21:37:33 +00:00
|
|
|
import invariant from 'invariant';
|
|
|
|
import { map, without, pick, filter } from 'lodash';
|
|
|
|
import { action, computed, observable } from 'mobx';
|
2017-08-03 13:48:07 +00:00
|
|
|
import BaseModel from 'models/BaseModel';
|
2018-05-08 05:08:47 +00:00
|
|
|
import Document from 'models/Document';
|
2019-01-05 21:37:33 +00:00
|
|
|
import User from 'models/User';
|
2017-07-09 17:27:29 +00:00
|
|
|
import { client } from 'utils/ApiClient';
|
2017-05-23 07:45:15 +00:00
|
|
|
import type { NavigationNode } from 'types';
|
|
|
|
|
2018-12-05 06:24:30 +00:00
|
|
|
export default class Collection extends BaseModel {
|
2019-01-05 21:37:33 +00:00
|
|
|
@observable isSaving: boolean;
|
|
|
|
@observable isLoadingUsers: boolean;
|
|
|
|
@observable userIds: string[] = [];
|
2017-07-09 17:27:29 +00:00
|
|
|
|
2017-05-23 07:45:15 +00:00
|
|
|
id: string;
|
|
|
|
name: string;
|
2018-12-05 06:24:30 +00:00
|
|
|
description: string;
|
2017-10-30 06:22:46 +00:00
|
|
|
color: string;
|
2019-01-05 21:37:33 +00:00
|
|
|
private: boolean;
|
2017-05-23 07:45:15 +00:00
|
|
|
type: 'atlas' | 'journal';
|
2018-05-08 05:08:47 +00:00
|
|
|
documents: NavigationNode[];
|
2018-12-05 06:24:30 +00:00
|
|
|
createdAt: ?string;
|
|
|
|
updatedAt: ?string;
|
2017-05-23 07:45:15 +00:00
|
|
|
url: string;
|
|
|
|
|
2017-11-20 04:16:49 +00:00
|
|
|
@computed
|
|
|
|
get isEmpty(): boolean {
|
|
|
|
return this.documents.length === 0;
|
|
|
|
}
|
|
|
|
|
2017-11-28 16:55:15 +00:00
|
|
|
@computed
|
|
|
|
get documentIds(): string[] {
|
|
|
|
const results = [];
|
|
|
|
const travelDocuments = (documentList, path) =>
|
|
|
|
documentList.forEach(document => {
|
|
|
|
results.push(document.id);
|
|
|
|
travelDocuments(document.children);
|
|
|
|
});
|
|
|
|
|
|
|
|
travelDocuments(this.documents);
|
|
|
|
return results;
|
|
|
|
}
|
|
|
|
|
2019-01-05 21:37:33 +00:00
|
|
|
@computed
|
|
|
|
get users(): User[] {
|
|
|
|
return filter(this.store.rootStore.users.active, user =>
|
|
|
|
this.userIds.includes(user.id)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
@action
|
|
|
|
async fetchUsers() {
|
|
|
|
this.isLoadingUsers = true;
|
|
|
|
|
|
|
|
try {
|
|
|
|
const res = await client.post('/collections.users', { id: this.id });
|
|
|
|
invariant(res && res.data, 'User data should be available');
|
|
|
|
this.userIds = map(res.data, user => user.id);
|
|
|
|
res.data.forEach(this.store.rootStore.users.add);
|
|
|
|
} finally {
|
|
|
|
this.isLoadingUsers = false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@action
|
|
|
|
async addUser(user: User) {
|
|
|
|
await client.post('/collections.add_user', {
|
|
|
|
id: this.id,
|
|
|
|
userId: user.id,
|
|
|
|
});
|
|
|
|
this.userIds = this.userIds.concat(user.id);
|
|
|
|
}
|
|
|
|
|
|
|
|
@action
|
|
|
|
async removeUser(user: User) {
|
|
|
|
await client.post('/collections.remove_user', {
|
|
|
|
id: this.id,
|
|
|
|
userId: user.id,
|
|
|
|
});
|
|
|
|
this.userIds = without(this.userIds, user.id);
|
|
|
|
}
|
|
|
|
|
2018-05-08 05:08:47 +00:00
|
|
|
@action
|
|
|
|
updateDocument(document: Document) {
|
|
|
|
const travelDocuments = (documentList, path) =>
|
|
|
|
documentList.forEach(d => {
|
|
|
|
if (d.id === document.id) {
|
|
|
|
d.title = document.title;
|
|
|
|
d.url = document.url;
|
|
|
|
} else {
|
|
|
|
travelDocuments(d.children);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
travelDocuments(this.documents);
|
|
|
|
}
|
|
|
|
|
2018-12-05 06:24:30 +00:00
|
|
|
toJS = () => {
|
2019-01-05 21:37:33 +00:00
|
|
|
return pick(this, ['id', 'name', 'color', 'description', 'private']);
|
2017-05-23 07:45:15 +00:00
|
|
|
};
|
|
|
|
|
2018-12-05 06:24:30 +00:00
|
|
|
export = () => {
|
|
|
|
return client.post('/collections.export', { id: this.id });
|
2018-06-21 04:33:21 +00:00
|
|
|
};
|
2017-05-23 07:45:15 +00:00
|
|
|
}
|