Commit c32c9d9f authored by Tom Quirk's avatar Tom Quirk

Update global todo counter in design management

parent ebebafb3
...@@ -5,7 +5,7 @@ import createDesignTodoMutation from '../graphql/mutations/create_design_todo.mu ...@@ -5,7 +5,7 @@ import createDesignTodoMutation from '../graphql/mutations/create_design_todo.mu
import TodoButton from '~/vue_shared/components/todo_button.vue'; import TodoButton from '~/vue_shared/components/todo_button.vue';
import allVersionsMixin from '../mixins/all_versions'; import allVersionsMixin from '../mixins/all_versions';
import { updateStoreAfterDeleteDesignTodo } from '../utils/cache_update'; import { updateStoreAfterDeleteDesignTodo } from '../utils/cache_update';
import { findIssueId } from '../utils/design_management_utils'; import { findIssueId, dispatchDocumentEvent } from '../utils/design_management_utils';
import { CREATE_DESIGN_TODO_ERROR, DELETE_DESIGN_TODO_ERROR } from '../utils/error_messages'; import { CREATE_DESIGN_TODO_ERROR, DELETE_DESIGN_TODO_ERROR } from '../utils/error_messages';
export default { export default {
...@@ -59,6 +59,21 @@ export default { ...@@ -59,6 +59,21 @@ export default {
}, },
}, },
methods: { methods: {
updateGlobalTodoCount(additionalTodoCount) {
const currentCount = parseInt(document.querySelector('.js-todos-count').innerText, 10);
dispatchDocumentEvent('todo:toggle', {
detail: {
count: Math.max(currentCount + additionalTodoCount, 0),
},
});
},
incrementGlobalTodoCount() {
this.updateGlobalTodoCount(1);
},
decrementGlobalTodoCount() {
this.updateGlobalTodoCount(-1);
},
createTodo() { createTodo() {
this.todoLoading = true; this.todoLoading = true;
return this.$apollo return this.$apollo
...@@ -75,6 +90,9 @@ export default { ...@@ -75,6 +90,9 @@ export default {
} }
}, },
}) })
.then(() => {
this.incrementGlobalTodoCount();
})
.catch(err => { .catch(err => {
this.$emit('error', Error(CREATE_DESIGN_TODO_ERROR)); this.$emit('error', Error(CREATE_DESIGN_TODO_ERROR));
throw err; throw err;
...@@ -115,6 +133,9 @@ export default { ...@@ -115,6 +133,9 @@ export default {
} }
}, },
}) })
.then(() => {
this.decrementGlobalTodoCount();
})
.catch(err => { .catch(err => {
this.$emit('error', Error(DELETE_DESIGN_TODO_ERROR)); this.$emit('error', Error(DELETE_DESIGN_TODO_ERROR));
throw err; throw err;
......
...@@ -167,3 +167,12 @@ export const createPendingTodo = todoId => { ...@@ -167,3 +167,12 @@ export const createPendingTodo = todoId => {
id: createTodoGid(todoId), id: createTodoGid(todoId),
}; };
}; };
/**
* Dispatch an event on the document
* @param {String} eventName
* @param {Object} eventData
*/
export const dispatchDocumentEvent = (eventName, eventData) => {
document.dispatchEvent(new CustomEvent(eventName, eventData));
};
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment