diff --git a/app/javascript/dashboard/store/modules/auth.js b/app/javascript/dashboard/store/modules/auth.js index 8251046fc..27103a0c5 100644 --- a/app/javascript/dashboard/store/modules/auth.js +++ b/app/javascript/dashboard/store/modules/auth.js @@ -105,10 +105,13 @@ export const actions = { } }, - updateAvailability: ({ commit }, { availability }) => { + updateAvailability: ({ commit, dispatch }, { availability }) => { authAPI.updateAvailability({ availability }).then(response => { - setUser(response.data, getHeaderExpiry(response)); + const userData = response.data; + const { id, availability_status: availabilityStatus } = userData; + setUser(userData, getHeaderExpiry(response)); commit(types.default.SET_CURRENT_USER); + dispatch('agents/updatePresence', { [id]: availabilityStatus }); }); }, diff --git a/app/javascript/dashboard/store/modules/specs/auth/actions.spec.js b/app/javascript/dashboard/store/modules/specs/auth/actions.spec.js index 1081196d6..21043898e 100644 --- a/app/javascript/dashboard/store/modules/specs/auth/actions.spec.js +++ b/app/javascript/dashboard/store/modules/specs/auth/actions.spec.js @@ -52,6 +52,24 @@ describe('#actions', () => { }); }); + describe('#updateAvailability', () => { + it('sends correct actions if API is success', async () => { + axios.put.mockResolvedValue({ + data: { id: 1, name: 'John', availability_status: 'offline' }, + headers: { expiry: 581842904 }, + }); + await actions.updateAvailability( + { commit, dispatch }, + { availability: 'offline' } + ); + expect(setUser).toHaveBeenCalledTimes(1); + expect(commit.mock.calls).toEqual([[types.default.SET_CURRENT_USER]]); + expect(dispatch.mock.calls).toEqual([ + ['agents/updatePresence', { 1: 'offline' }], + ]); + }); + }); + describe('#setUser', () => { it('sends correct actions if user is logged in', async () => { Cookies.getJSON.mockImplementation(() => true);