@cometchat/chat-uikit-react-native
Version:
Ready-to-use Chat UI Components for React Native
183 lines • 7.6 kB
JavaScript
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