62 lines
1.5 KiB
JavaScript
62 lines
1.5 KiB
JavaScript
// @flow
|
|
import { observable, action, runInAction, ObservableArray } 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';
|
|
|
|
type Options = {
|
|
teamId: string,
|
|
};
|
|
|
|
class CollectionsStore {
|
|
@observable data: ObservableArray<Collection> = observable.array([]);
|
|
@observable isLoaded: boolean = false;
|
|
|
|
client: ApiClient;
|
|
teamId: string;
|
|
errors: ErrorsStore;
|
|
|
|
/* Actions */
|
|
|
|
@action fetch = 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,
|
|
errors: this.errors,
|
|
})
|
|
)
|
|
);
|
|
this.isLoaded = true;
|
|
});
|
|
} catch (e) {
|
|
this.errors.add('Failed to load collections');
|
|
}
|
|
};
|
|
|
|
@action getById = async (id: string): Promise<Collection> => {
|
|
if (!this.isLoaded) await this.fetch();
|
|
return _.find(this.data, { id });
|
|
};
|
|
|
|
constructor(options: Options) {
|
|
this.client = client;
|
|
this.errors = stores.errors;
|
|
this.teamId = options.teamId;
|
|
}
|
|
}
|
|
|
|
export default CollectionsStore;
|