8558b92cae
* Collection edit modal * Add icon * 💚 * Oh look, some specs * Delete collection * Remove from collection * Handle error responses Protect against deleting last collection * Fix key * 💚 * Keyboard navigate documents list * Add missing database constraints
121 lines
3.0 KiB
JavaScript
121 lines
3.0 KiB
JavaScript
// @flow
|
|
import {
|
|
observable,
|
|
computed,
|
|
action,
|
|
runInAction,
|
|
ObservableArray,
|
|
autorunAsync,
|
|
} from 'mobx';
|
|
import ApiClient, { client } from 'utils/ApiClient';
|
|
import _ from 'lodash';
|
|
import invariant from 'invariant';
|
|
|
|
import stores from 'stores';
|
|
import Collection from 'models/Collection';
|
|
import ErrorsStore from 'stores/ErrorsStore';
|
|
import CacheStore from 'stores/CacheStore';
|
|
import UiStore from 'stores/UiStore';
|
|
|
|
const COLLECTION_CACHE_KEY = 'COLLECTION_CACHE_KEY';
|
|
|
|
type Options = {
|
|
teamId: string,
|
|
cache: CacheStore,
|
|
ui: UiStore,
|
|
};
|
|
|
|
class CollectionsStore {
|
|
@observable data: ObservableArray<Collection> = observable.array([]);
|
|
@observable isLoaded: boolean = false;
|
|
|
|
client: ApiClient;
|
|
teamId: string;
|
|
errors: ErrorsStore;
|
|
cache: CacheStore;
|
|
ui: UiStore;
|
|
|
|
@computed get active(): ?Collection {
|
|
return this.ui.activeCollectionId
|
|
? this.getById(this.ui.activeCollectionId)
|
|
: undefined;
|
|
}
|
|
|
|
/* Actions */
|
|
|
|
@action fetchAll = async (): Promise<*> => {
|
|
try {
|
|
const res = await this.client.post('/collections.list', {
|
|
id: this.teamId,
|
|
});
|
|
invariant(res && res.data, 'Collection list not available');
|
|
const { data } = res;
|
|
runInAction('CollectionsStore#fetch', () => {
|
|
this.data.replace(data.map(collection => new Collection(collection)));
|
|
this.isLoaded = true;
|
|
});
|
|
} catch (e) {
|
|
this.errors.add('Failed to load collections');
|
|
}
|
|
};
|
|
|
|
@action fetchById = async (id: string): Promise<?Collection> => {
|
|
let collection = this.getById(id);
|
|
if (!collection) {
|
|
try {
|
|
const res = await this.client.post('/collections.info', {
|
|
id,
|
|
});
|
|
invariant(res && res.data, 'Collection not available');
|
|
const { data } = res;
|
|
runInAction('CollectionsStore#getById', () => {
|
|
collection = new Collection(data);
|
|
this.add(collection);
|
|
});
|
|
} catch (e) {
|
|
Bugsnag.notify(e);
|
|
this.errors.add('Something went wrong');
|
|
}
|
|
}
|
|
|
|
return collection;
|
|
};
|
|
|
|
@action add = (collection: Collection): void => {
|
|
this.data.push(collection);
|
|
};
|
|
|
|
@action remove = (id: string): void => {
|
|
this.data.splice(this.data.indexOf(id), 1);
|
|
};
|
|
|
|
getById = (id: string): ?Collection => {
|
|
return _.find(this.data, { id });
|
|
};
|
|
|
|
constructor(options: Options) {
|
|
this.client = client;
|
|
this.errors = stores.errors;
|
|
this.teamId = options.teamId;
|
|
this.cache = options.cache;
|
|
this.ui = options.ui;
|
|
//
|
|
// this.cache.getItem(COLLECTION_CACHE_KEY).then(data => {
|
|
// if (data) {
|
|
// this.data.replace(data.map(collection => new Collection(collection)));
|
|
// this.isLoaded = true;
|
|
// }
|
|
// });
|
|
|
|
autorunAsync('CollectionsStore.persists', () => {
|
|
if (this.data.length > 0)
|
|
this.cache.setItem(
|
|
COLLECTION_CACHE_KEY,
|
|
this.data.map(collection => collection.data)
|
|
);
|
|
});
|
|
}
|
|
}
|
|
|
|
export default CollectionsStore;
|