UNPKG

@cometchat/chat-uikit-react-native

Version:

Ready-to-use Chat UI Components for React Native

183 lines 7.6 kB
import { CALL_BUSY, CALL_CANCELLED, CALL_ENDED, CALL_INITIATED, CALL_ONGOING, CALL_REJECTED, CALL_UNANSWERED, } from "../shared/constants/UIKitConstants"; import { localize } from "../shared/resources/CometChatLocalize"; export class CallUtils { /** * Checks if the given initiator is the same as the logged in user. * * @param initiator - The call initiator. * @param loggedInUser - The logged in user. * @returns True if the initiator is the logged in user. */ static isInitiator(initiator, loggedInUser) { return initiator.getUid() == loggedInUser?.getUid(); } /** * Retrieves the call status along with an appropriate icon. * * @param message - The call message. * @param loggedInUser - The logged in user. * @returns An object containing callMessageText and selectedIcon. */ static getCallStatus(message, loggedInUser) { try { // if (!(message instanceof CometChat.Call)) return ''; let call = message; let callMessageText = ""; let selectedIcon = ""; let initiator = (call?.getCallInitiator && call?.getCallInitiator()) || call.getInitiator(); switch (call.getStatus()) { case CALL_INITIATED: if (this.isInitiator(initiator, loggedInUser)) { callMessageText = `${localize(`OUTGOING_CALL`)}`; selectedIcon = call["type"] === "audio" ? "outgoing-audio" : "outgoing-video"; } else { callMessageText = `${localize(`INCOMING_CALL`)}`; selectedIcon = call["type"] === "audio" ? "incoming-audio" : "incoming-video"; } break; case CALL_ONGOING: callMessageText = `${localize(`CALL_ACCEPTED`)}`; selectedIcon = call["type"] === "audio" ? "call" : "video-call"; break; case CALL_ENDED: callMessageText = `${localize(`CALL_ENDED`)}`; selectedIcon = call["type"] === "audio" ? "call" : "video-call"; break; case CALL_UNANSWERED: if (this.isInitiator(initiator, loggedInUser)) { callMessageText = `${localize("UNANSWERED_CALL")}`; selectedIcon = call["type"] === "audio" ? "call" : "video-call"; } else { callMessageText = `${localize("MISSED_CALL")}`; selectedIcon = call["type"] === "audio" ? "phone-missed" : "missed-video-call"; } break; case CALL_CANCELLED: if (this.isInitiator(initiator, loggedInUser)) { callMessageText = `${localize("CANCELLED_CALL")}`; selectedIcon = call["type"] === "audio" ? "call" : "video-call"; } else { callMessageText = `${localize("MISSED_CALL")}`; selectedIcon = call["type"] === "audio" ? "phone-missed" : "missed-video-call"; } break; case CALL_REJECTED: callMessageText = `${localize("CALL_REJECTED")}`; selectedIcon = call["type"] === "audio" ? "call" : "video-call"; break; case CALL_BUSY: if (this.isInitiator(initiator, loggedInUser)) { callMessageText = `${localize("CALL_BUSY")}`; selectedIcon = call["type"] === "audio" ? "call" : "video-call"; } else { callMessageText = `${localize("MISSED_CALL")}`; selectedIcon = call["type"] === "audio" ? "phone-missed" : "missed-video-call"; } break; } if (callMessageText == undefined || callMessageText == "undefined") console.log(message, loggedInUser); return { callMessageText, selectedIcon }; } catch (e) { console.log("__CATCH", e); return { callMessageText: "", selectedIcon: "" }; } } /** * Determines if the given call is a missed call. * * @param call - The call object. * @param loggedInUser - The logged in user. * @returns True if it's a missed call. */ static isMissedCall(call, loggedInUser) { const callStatus = call.getStatus(); if (this.isInitiator(call?.getInitiator(), loggedInUser)) { return callStatus === CALL_UNANSWERED; } else { return [CALL_BUSY, CALL_UNANSWERED, CALL_REJECTED, CALL_CANCELLED].includes(callStatus); } } /** * Returns a call status string for displaying in call logs. * * @param call - The call object. * @param loggedInUser - The logged in user. * @returns "outgoing", "incoming", or "missed". */ static getCallStatusForCallLogs(call, loggedInUser) { const callStatus = call.getStatus(); if (this.isInitiator(call?.getInitiator(), loggedInUser)) { return "outgoing"; } else { if (this.isMissedCall(call, loggedInUser)) { return "missed"; } return "incoming"; } } /** * Converts minutes to a formatted string (hours, minutes, seconds). * * @param minutes - The time in minutes. * @returns A formatted string. */ static convertMinutesToHoursMinutesSeconds(minutes) { const hours = Math.floor(minutes / 60); const remainingMinutes = Math.floor(minutes % 60); const seconds = Math.floor((minutes - Math.floor(minutes)) * 60); let hoursString = ""; let minutesString = ""; let secondsString = ""; if (hours > 0) { hoursString = `${hours}h`; } if (remainingMinutes > 0) { minutesString = `${remainingMinutes}m`; } if (seconds >= 0) { secondsString = `${seconds}s`; } return hoursString ? `${hoursString} ${minutesString} ${secondsString}` : minutesString ? `${minutesString} ${secondsString}` : secondsString; } /** * Converts seconds to a formatted string (hours, minutes, seconds). * * @param seconds - The time in seconds. * @returns A formatted string. */ static convertSecondsToHoursMinutesSeconds(seconds) { const hours = Math.floor(seconds / 3600); const remainingMinutes = Math.floor((seconds % 3600) / 60); const remainingSeconds = Math.floor((seconds % 3600) % 60); let hoursString = ""; let minutesString = ""; let secondsString = ""; if (hours > 0) { hoursString = `${hours}h`; } if (remainingMinutes > 0) { minutesString = `${remainingMinutes}m`; } if (remainingSeconds >= 0) { secondsString = `${remainingSeconds}s`; } return hoursString ? `${hoursString} ${minutesString} ${secondsString}` : minutesString ? `${minutesString} ${secondsString}` : secondsString; } } //# sourceMappingURL=CallUtils.js.map