9142d975df
* Mostly there * Fix up specs * Working scope, updated tests * Don't record view on draft * PR feedback * Highlight drafts nav item * Bugaboos * Styling * Refactoring, gradually addressing Jori feedback * Show collection in drafts list Flow fixes * Ensure menu actions are hidden when draft
85 lines
1.8 KiB
JavaScript
85 lines
1.8 KiB
JavaScript
// @flow
|
|
import { observable, action } from 'mobx';
|
|
import Document from 'models/Document';
|
|
import Collection from 'models/Collection';
|
|
|
|
class UiStore {
|
|
@observable activeModalName: ?string;
|
|
@observable activeModalProps: ?Object;
|
|
@observable activeDocumentId: ?string;
|
|
@observable activeCollectionId: ?string;
|
|
@observable progressBarVisible: boolean = false;
|
|
@observable editMode: boolean = false;
|
|
@observable mobileSidebarVisible: boolean = false;
|
|
|
|
/* Actions */
|
|
@action
|
|
setActiveModal = (name: string, props: ?Object): void => {
|
|
this.activeModalName = name;
|
|
this.activeModalProps = props;
|
|
};
|
|
|
|
@action
|
|
clearActiveModal = (): void => {
|
|
this.activeModalName = undefined;
|
|
this.activeModalProps = undefined;
|
|
};
|
|
|
|
@action
|
|
setActiveDocument = (document: Document): void => {
|
|
this.activeDocumentId = document.id;
|
|
|
|
if (document.publishedAt) {
|
|
this.activeCollectionId = document.collection.id;
|
|
}
|
|
};
|
|
|
|
@action
|
|
setActiveCollection = (collection: Collection): void => {
|
|
this.activeCollectionId = collection.id;
|
|
};
|
|
|
|
@action
|
|
clearActiveCollection = (): void => {
|
|
this.activeCollectionId = undefined;
|
|
};
|
|
|
|
@action
|
|
clearActiveDocument = (): void => {
|
|
this.activeDocumentId = undefined;
|
|
this.activeCollectionId = undefined;
|
|
};
|
|
|
|
@action
|
|
enableEditMode() {
|
|
this.editMode = true;
|
|
}
|
|
|
|
@action
|
|
disableEditMode() {
|
|
this.editMode = false;
|
|
}
|
|
|
|
@action
|
|
enableProgressBar() {
|
|
this.progressBarVisible = true;
|
|
}
|
|
|
|
@action
|
|
disableProgressBar() {
|
|
this.progressBarVisible = false;
|
|
}
|
|
|
|
@action
|
|
toggleMobileSidebar() {
|
|
this.mobileSidebarVisible = !this.mobileSidebarVisible;
|
|
}
|
|
|
|
@action
|
|
hideMobileSidebar() {
|
|
this.mobileSidebarVisible = false;
|
|
}
|
|
}
|
|
|
|
export default UiStore;
|