feat: Adds support for all snooze option in bulk actions (#9361)
* feat: Add support for bulk snooze until * feat: Adds support for all snooze option in bulk actions * chore: Adds comment * chore: Review fixes * chore: Minor fix * chore: Minor fix * chore: Review fixes * chore: yarn changes * fix: terminal waring * chore: Adds spec * Update conversationHotKeys.js --------- Co-authored-by: Muhsin Keloth <muhsinkeramam@gmail.com>
This commit is contained in:
@@ -2,6 +2,7 @@ import types from '../mutation-types';
|
||||
import BulkActionsAPI from '../../api/bulkActions';
|
||||
|
||||
export const state = {
|
||||
selectedConversationIds: [],
|
||||
uiFlags: {
|
||||
isUpdating: false,
|
||||
},
|
||||
@@ -11,6 +12,9 @@ export const getters = {
|
||||
getUIFlags(_state) {
|
||||
return _state.uiFlags;
|
||||
},
|
||||
getSelectedConversationIds(_state) {
|
||||
return _state.selectedConversationIds;
|
||||
},
|
||||
};
|
||||
|
||||
export const actions = {
|
||||
@@ -24,6 +28,15 @@ export const actions = {
|
||||
commit(types.SET_BULK_ACTIONS_FLAG, { isUpdating: false });
|
||||
}
|
||||
},
|
||||
setSelectedConversationIds({ commit }, id) {
|
||||
commit(types.SET_SELECTED_CONVERSATION_IDS, id);
|
||||
},
|
||||
removeSelectedConversationIds({ commit }, id) {
|
||||
commit(types.REMOVE_SELECTED_CONVERSATION_IDS, id);
|
||||
},
|
||||
clearSelectedConversationIds({ commit }) {
|
||||
commit(types.CLEAR_SELECTED_CONVERSATION_IDS);
|
||||
},
|
||||
};
|
||||
|
||||
export const mutations = {
|
||||
@@ -33,6 +46,23 @@ export const mutations = {
|
||||
...data,
|
||||
};
|
||||
},
|
||||
[types.SET_SELECTED_CONVERSATION_IDS](_state, ids) {
|
||||
// Check if ids is an array, if not, convert it to an array
|
||||
const idsArray = Array.isArray(ids) ? ids : [ids];
|
||||
|
||||
// Concatenate the new IDs ensuring no duplicates
|
||||
_state.selectedConversationIds = [
|
||||
...new Set([..._state.selectedConversationIds, ...idsArray]),
|
||||
];
|
||||
},
|
||||
[types.REMOVE_SELECTED_CONVERSATION_IDS](_state, id) {
|
||||
_state.selectedConversationIds = _state.selectedConversationIds.filter(
|
||||
item => item !== id
|
||||
);
|
||||
},
|
||||
[types.CLEAR_SELECTED_CONVERSATION_IDS](_state) {
|
||||
_state.selectedConversationIds = [];
|
||||
},
|
||||
};
|
||||
|
||||
export default {
|
||||
|
||||
@@ -25,4 +25,28 @@ describe('#actions', () => {
|
||||
]);
|
||||
});
|
||||
});
|
||||
describe('#setSelectedConversationIds', () => {
|
||||
it('sends correct actions if API is success', async () => {
|
||||
await actions.setSelectedConversationIds({ commit }, payload.ids);
|
||||
expect(commit.mock.calls).toEqual([
|
||||
[types.default.SET_SELECTED_CONVERSATION_IDS, payload.ids],
|
||||
]);
|
||||
});
|
||||
});
|
||||
describe('#removeSelectedConversationIds', () => {
|
||||
it('sends correct actions if API is success', async () => {
|
||||
await actions.removeSelectedConversationIds({ commit }, payload.ids);
|
||||
expect(commit.mock.calls).toEqual([
|
||||
[types.default.REMOVE_SELECTED_CONVERSATION_IDS, payload.ids],
|
||||
]);
|
||||
});
|
||||
});
|
||||
describe('#clearSelectedConversationIds', () => {
|
||||
it('sends correct actions if API is success', async () => {
|
||||
await actions.clearSelectedConversationIds({ commit });
|
||||
expect(commit.mock.calls).toEqual([
|
||||
[types.default.CLEAR_SELECTED_CONVERSATION_IDS],
|
||||
]);
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
@@ -11,4 +11,10 @@ describe('#getters', () => {
|
||||
isUpdating: false,
|
||||
});
|
||||
});
|
||||
it('getSelectedConversationIds', () => {
|
||||
const state = {
|
||||
selectedConversationIds: [1, 2, 3],
|
||||
};
|
||||
expect(getters.getSelectedConversationIds(state)).toEqual([1, 2, 3]);
|
||||
});
|
||||
});
|
||||
|
||||
@@ -9,4 +9,25 @@ describe('#mutations', () => {
|
||||
expect(state.uiFlags.isUpdating).toEqual(true);
|
||||
});
|
||||
});
|
||||
describe('#setSelectedConversationIds', () => {
|
||||
it('set selected conversation ids', () => {
|
||||
const state = { selectedConversationIds: [] };
|
||||
mutations[types.SET_SELECTED_CONVERSATION_IDS](state, [1, 2, 3]);
|
||||
expect(state.selectedConversationIds).toEqual([1, 2, 3]);
|
||||
});
|
||||
});
|
||||
describe('#removeSelectedConversationIds', () => {
|
||||
it('remove selected conversation ids', () => {
|
||||
const state = { selectedConversationIds: [1, 2, 3] };
|
||||
mutations[types.REMOVE_SELECTED_CONVERSATION_IDS](state, 1);
|
||||
expect(state.selectedConversationIds).toEqual([2, 3]);
|
||||
});
|
||||
});
|
||||
describe('#clearSelectedConversationIds', () => {
|
||||
it('clear selected conversation ids', () => {
|
||||
const state = { selectedConversationIds: [1, 2, 3] };
|
||||
mutations[types.CLEAR_SELECTED_CONVERSATION_IDS](state);
|
||||
expect(state.selectedConversationIds).toEqual([]);
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
Reference in New Issue
Block a user