ngx-tencent-im
Version:
Instant messaging for Angular.
78 lines • 12.8 kB
JavaScript
import { createReducer, on } from '@ngrx/store';
import { checkoutConversationAction, pushCurrentMessageListAction, removeMessageAction, resetConversationAction, resetCurrentConversationAction, updateConversationListAction, updateCurrentConversationAction, updateMessageAction } from '../actions';
export const initialState = {
currentConversation: {},
currentMessageList: [],
nextReqMessageID: '',
isCompleted: false,
conversationList: []
};
const _conversationReducer = createReducer(initialState, on(updateCurrentConversationAction, (state, { conversation }) => {
return {
...state,
currentConversation: conversation,
currentMessageList: [],
nextReqMessageID: '',
isCompleted: false // 当前会话消息列表是否已经拉完了所有消息
};
}), on(updateMessageAction, (state, { nextReqMessageID, isCompleted, currentMessageList }) => {
return {
...state,
currentMessageList,
nextReqMessageID,
isCompleted // 当前会话消息列表是否已经拉完了所有消息
};
}), on(updateConversationListAction, (state, { conversationList }) => {
return {
...state,
conversationList
};
}), on(resetCurrentConversationAction, (state) => ({
...state,
currentConversation: {},
})), on(pushCurrentMessageListAction, (state, { message }) => {
// 还没当前会话,则跳过
if (!state.currentConversation.conversationID) {
return { ...state };
}
if (Array.isArray(message)) {
// 筛选出当前会话的消息
const result = message.filter(item => item.conversationID === state.currentConversation.conversationID);
const currentMessageList = [...state.currentMessageList, ...result];
return { ...state, currentMessageList };
}
else if (message.conversationID === state.currentConversation.conversationID) {
const currentMessageList = [...state.currentMessageList, message];
return { ...state, currentMessageList };
}
return { ...state };
}), on(removeMessageAction, (state, { message }) => {
const index = state.currentMessageList.findIndex(({ ID }) => ID === message.ID);
if (index >= 0) {
const currentMessageList = state.currentMessageList;
currentMessageList.splice(index, 1);
return { ...state, currentMessageList };
}
return { ...state };
}), on(resetConversationAction, (state) => {
return Object.assign(state, {
currentConversation: {},
currentMessageList: [],
nextReqMessageID: '',
isCompleted: false,
conversationList: []
});
}));
export function conversationReducer(state, action) {
return _conversationReducer(state, action);
}
export const conversationIDInitialState = {
conversationID: '',
};
const _conversationIDReducer = createReducer(conversationIDInitialState, on(checkoutConversationAction, (state, { conversationID }) => ({
conversationID
})));
export function conversationIDReducer(state, action) {
return _conversationIDReducer(state, action);
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"conversation.reducer.js","sourceRoot":"","sources":["../../../../../projects/ngx-tencent-im/src/store/reducer/conversation.reducer.ts"],"names":[],"mappings":"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","sourcesContent":["\r\nimport { Action, createReducer, on } from '@ngrx/store';\r\nimport { Conversation, Message } from 'tim-js-sdk';\r\nimport {\r\n  checkoutConversationAction,\r\n  pushCurrentMessageListAction,\r\n  removeMessageAction,\r\n  resetConversationAction,\r\n  resetCurrentConversationAction,\r\n  updateConversationListAction,\r\n  updateCurrentConversationAction,\r\n  updateMessageAction\r\n} from '../actions';\r\n\r\nexport interface ConversationState {\r\n  currentConversation: Conversation;\r\n  currentMessageList: Array<Message>;\r\n  nextReqMessageID: string;\r\n  isCompleted: boolean; // 当前会话消息列表是否已经拉完了所有消息\r\n  conversationList: Array<Conversation>;\r\n}\r\n\r\nexport const initialState: ConversationState = {\r\n  currentConversation: {} as Conversation,\r\n  currentMessageList: [],\r\n  nextReqMessageID: '',\r\n  isCompleted: false, // 当前会话消息列表是否已经拉完了所有消息\r\n  conversationList: []\r\n};\r\n\r\nconst _conversationReducer = createReducer(\r\n  initialState,\r\n  on(updateCurrentConversationAction, (state, { conversation }) => {\r\n    return {\r\n      ...state,\r\n      currentConversation: conversation,\r\n      currentMessageList: [],\r\n      nextReqMessageID: '',\r\n      isCompleted: false // 当前会话消息列表是否已经拉完了所有消息\r\n    };\r\n  }),\r\n  on(updateMessageAction, (state, { nextReqMessageID, isCompleted, currentMessageList }) => {\r\n    return {\r\n      ...state,\r\n      currentMessageList,\r\n      nextReqMessageID,\r\n      isCompleted // 当前会话消息列表是否已经拉完了所有消息\r\n    };\r\n  }),\r\n  on(updateConversationListAction, (state, { conversationList }) => {\r\n    return {\r\n      ...state,\r\n      conversationList\r\n    };\r\n  }),\r\n  on(resetCurrentConversationAction, (state) => ({\r\n    ...state,\r\n    currentConversation: {} as Conversation,\r\n  })),\r\n  on(pushCurrentMessageListAction, (state, { message }) => {\r\n\r\n    // 还没当前会话，则跳过\r\n    if (!state.currentConversation.conversationID) {\r\n      return { ...state };\r\n    }\r\n    if (Array.isArray(message)) {\r\n      // 筛选出当前会话的消息\r\n      const result = message.filter(item => item.conversationID === state.currentConversation.conversationID);\r\n      const currentMessageList = [...state.currentMessageList, ...result];\r\n      return { ...state, currentMessageList };\r\n    } else if (message.conversationID === state.currentConversation.conversationID) {\r\n      const currentMessageList = [...state.currentMessageList, message];\r\n      return { ...state, currentMessageList };\r\n    }\r\n    return { ...state };\r\n  }),\r\n  on(removeMessageAction, (state, { message }) => {\r\n    const index = state.currentMessageList.findIndex(({ ID }) => ID === message.ID);\r\n    if (index >= 0) {\r\n      const currentMessageList: Array<any> = state.currentMessageList;\r\n      currentMessageList.splice(index, 1);\r\n      return { ...state, currentMessageList };\r\n    }\r\n    return { ...state };\r\n\r\n  }),\r\n  on(resetConversationAction, (state) => {\r\n    return Object.assign(state, {\r\n      currentConversation: {},\r\n      currentMessageList: [],\r\n      nextReqMessageID: '',\r\n      isCompleted: false, // 当前会话消息列表是否已经拉完了所有消息\r\n      conversationList: []\r\n    });\r\n  }),\r\n);\r\n\r\nexport function conversationReducer(state: ConversationState | undefined, action: Action) {\r\n  return _conversationReducer(state, action);\r\n}\r\n\r\nexport interface ConversationIDState {\r\n  conversationID: string;\r\n}\r\nexport const conversationIDInitialState: ConversationIDState = {\r\n  conversationID: '',\r\n};\r\n\r\nconst _conversationIDReducer = createReducer(conversationIDInitialState,\r\n  on(checkoutConversationAction, (state, { conversationID }) => ({\r\n    conversationID\r\n  })));\r\n\r\nexport function conversationIDReducer(state: ConversationIDState | undefined, action: Action) {\r\n  return _conversationIDReducer(state, action);\r\n}\r\n"]}