Some checks failed
Lock Threads / action (push) Has been cancelled
Mark stale issues and pull requests / stale (push) Has been cancelled
Publish Chatwoot EE docker images / build (linux/amd64, ubuntu-latest) (push) Has been cancelled
Publish Chatwoot EE docker images / build (linux/arm64, ubuntu-22.04-arm) (push) Has been cancelled
Publish Chatwoot EE docker images / merge (push) Has been cancelled
Publish Chatwoot CE docker images / build (linux/amd64, ubuntu-latest) (push) Has been cancelled
Publish Chatwoot CE docker images / build (linux/arm64, ubuntu-22.04-arm) (push) Has been cancelled
Publish Chatwoot CE docker images / merge (push) Has been cancelled
Run Chatwoot CE spec / lint-backend (push) Has been cancelled
Run Chatwoot CE spec / lint-frontend (push) Has been cancelled
Run Chatwoot CE spec / frontend-tests (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (0, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (1, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (10, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (11, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (12, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (13, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (14, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (15, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (2, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (3, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (4, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (5, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (6, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (7, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (8, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (9, 16) (push) Has been cancelled
Run Linux nightly installer / nightly (push) Has been cancelled
- Add Logistics component with progress tracking - Add OrderDetail component for order information - Support data-driven steps and actions - Add blue color scale to widget SCSS - Fix node overflow and progress bar rendering issues - Add English translations for dashboard components Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
187 lines
5.6 KiB
JavaScript
187 lines
5.6 KiB
JavaScript
import SearchAPI from '../../api/search';
|
|
import types from '../mutation-types';
|
|
export const initialState = {
|
|
records: [],
|
|
contactRecords: [],
|
|
conversationRecords: [],
|
|
messageRecords: [],
|
|
articleRecords: [],
|
|
uiFlags: {
|
|
isFetching: false,
|
|
isSearchCompleted: false,
|
|
contact: { isFetching: false },
|
|
conversation: { isFetching: false },
|
|
message: { isFetching: false },
|
|
article: { isFetching: false },
|
|
},
|
|
};
|
|
|
|
export const getters = {
|
|
getConversations(state) {
|
|
return state.records;
|
|
},
|
|
getContactRecords(state) {
|
|
return state.contactRecords;
|
|
},
|
|
getConversationRecords(state) {
|
|
return state.conversationRecords;
|
|
},
|
|
getMessageRecords(state) {
|
|
return state.messageRecords;
|
|
},
|
|
getArticleRecords(state) {
|
|
return state.articleRecords;
|
|
},
|
|
getUIFlags(state) {
|
|
return state.uiFlags;
|
|
},
|
|
};
|
|
|
|
export const actions = {
|
|
async get({ commit }, { q }) {
|
|
commit(types.SEARCH_CONVERSATIONS_SET, []);
|
|
if (!q) {
|
|
return;
|
|
}
|
|
commit(types.SEARCH_CONVERSATIONS_SET_UI_FLAG, { isFetching: true });
|
|
try {
|
|
const {
|
|
data: { payload },
|
|
} = await SearchAPI.get({ q });
|
|
commit(types.SEARCH_CONVERSATIONS_SET, payload);
|
|
} catch (error) {
|
|
// Ignore error
|
|
} finally {
|
|
commit(types.SEARCH_CONVERSATIONS_SET_UI_FLAG, {
|
|
isFetching: false,
|
|
});
|
|
}
|
|
},
|
|
async fullSearch({ commit, dispatch }, payload) {
|
|
const { q, ...filters } = payload;
|
|
if (!q && !Object.keys(filters).length) {
|
|
return;
|
|
}
|
|
commit(types.FULL_SEARCH_SET_UI_FLAG, {
|
|
isFetching: true,
|
|
isSearchCompleted: false,
|
|
});
|
|
try {
|
|
await Promise.all([
|
|
dispatch('contactSearch', { q, ...filters }),
|
|
dispatch('conversationSearch', { q, ...filters }),
|
|
dispatch('messageSearch', { q, ...filters }),
|
|
dispatch('articleSearch', { q, ...filters }),
|
|
]);
|
|
} catch (error) {
|
|
// Ignore error
|
|
} finally {
|
|
commit(types.FULL_SEARCH_SET_UI_FLAG, {
|
|
isFetching: false,
|
|
isSearchCompleted: true,
|
|
});
|
|
}
|
|
},
|
|
async contactSearch({ commit }, payload) {
|
|
const { page = 1, ...searchParams } = payload;
|
|
commit(types.CONTACT_SEARCH_SET_UI_FLAG, { isFetching: true });
|
|
try {
|
|
const { data } = await SearchAPI.contacts({ ...searchParams, page });
|
|
commit(types.CONTACT_SEARCH_SET, data.payload.contacts);
|
|
} catch (error) {
|
|
// Ignore error
|
|
} finally {
|
|
commit(types.CONTACT_SEARCH_SET_UI_FLAG, { isFetching: false });
|
|
}
|
|
},
|
|
async conversationSearch({ commit }, payload) {
|
|
const { page = 1, ...searchParams } = payload;
|
|
commit(types.CONVERSATION_SEARCH_SET_UI_FLAG, { isFetching: true });
|
|
try {
|
|
const { data } = await SearchAPI.conversations({ ...searchParams, page });
|
|
commit(types.CONVERSATION_SEARCH_SET, data.payload.conversations);
|
|
} catch (error) {
|
|
// Ignore error
|
|
} finally {
|
|
commit(types.CONVERSATION_SEARCH_SET_UI_FLAG, { isFetching: false });
|
|
}
|
|
},
|
|
async messageSearch({ commit }, payload) {
|
|
const { page = 1, ...searchParams } = payload;
|
|
commit(types.MESSAGE_SEARCH_SET_UI_FLAG, { isFetching: true });
|
|
try {
|
|
const { data } = await SearchAPI.messages({ ...searchParams, page });
|
|
commit(types.MESSAGE_SEARCH_SET, data.payload.messages);
|
|
} catch (error) {
|
|
// Ignore error
|
|
} finally {
|
|
commit(types.MESSAGE_SEARCH_SET_UI_FLAG, { isFetching: false });
|
|
}
|
|
},
|
|
async articleSearch({ commit }, payload) {
|
|
const { page = 1, ...searchParams } = payload;
|
|
commit(types.ARTICLE_SEARCH_SET_UI_FLAG, { isFetching: true });
|
|
try {
|
|
const { data } = await SearchAPI.articles({ ...searchParams, page });
|
|
commit(types.ARTICLE_SEARCH_SET, data.payload.articles);
|
|
} catch (error) {
|
|
// Ignore error
|
|
} finally {
|
|
commit(types.ARTICLE_SEARCH_SET_UI_FLAG, { isFetching: false });
|
|
}
|
|
},
|
|
async clearSearchResults({ commit }) {
|
|
commit(types.CLEAR_SEARCH_RESULTS);
|
|
},
|
|
};
|
|
|
|
export const mutations = {
|
|
[types.SEARCH_CONVERSATIONS_SET](state, records) {
|
|
state.records = records;
|
|
},
|
|
[types.CONTACT_SEARCH_SET](state, records) {
|
|
state.contactRecords = [...state.contactRecords, ...records];
|
|
},
|
|
[types.CONVERSATION_SEARCH_SET](state, records) {
|
|
state.conversationRecords = [...state.conversationRecords, ...records];
|
|
},
|
|
[types.MESSAGE_SEARCH_SET](state, records) {
|
|
state.messageRecords = [...state.messageRecords, ...records];
|
|
},
|
|
[types.ARTICLE_SEARCH_SET](state, records) {
|
|
state.articleRecords = [...state.articleRecords, ...records];
|
|
},
|
|
[types.SEARCH_CONVERSATIONS_SET_UI_FLAG](state, uiFlags) {
|
|
state.uiFlags = { ...state.uiFlags, ...uiFlags };
|
|
},
|
|
[types.FULL_SEARCH_SET_UI_FLAG](state, uiFlags) {
|
|
state.uiFlags = { ...state.uiFlags, ...uiFlags };
|
|
},
|
|
[types.CONTACT_SEARCH_SET_UI_FLAG](state, uiFlags) {
|
|
state.uiFlags.contact = { ...state.uiFlags.contact, ...uiFlags };
|
|
},
|
|
[types.CONVERSATION_SEARCH_SET_UI_FLAG](state, uiFlags) {
|
|
state.uiFlags.conversation = { ...state.uiFlags.conversation, ...uiFlags };
|
|
},
|
|
[types.MESSAGE_SEARCH_SET_UI_FLAG](state, uiFlags) {
|
|
state.uiFlags.message = { ...state.uiFlags.message, ...uiFlags };
|
|
},
|
|
[types.ARTICLE_SEARCH_SET_UI_FLAG](state, uiFlags) {
|
|
state.uiFlags.article = { ...state.uiFlags.article, ...uiFlags };
|
|
},
|
|
[types.CLEAR_SEARCH_RESULTS](state) {
|
|
state.contactRecords = [];
|
|
state.conversationRecords = [];
|
|
state.messageRecords = [];
|
|
state.articleRecords = [];
|
|
},
|
|
};
|
|
|
|
export default {
|
|
namespaced: true,
|
|
state: initialState,
|
|
getters,
|
|
actions,
|
|
mutations,
|
|
};
|