UNPKG

@cometchat/chat-uikit-react-native

Version:

Ready-to-use Chat UI Components for React Native

311 lines 13.4 kB
import { CometChat } from "@cometchat/chat-sdk-react-native"; import { Platform } from "react-native"; import { CallingExtension } from "../../calls/CallingExtension"; import { CallingPackage } from "../../calls/CallingPackage"; import { CollaborativeDocumentExtension } from "../../extensions/CollaborativeDocument/CollaborativeDocumentExtension"; import { CollaborativeWhiteboardExtension } from "../../extensions/CollaborativeWhiteboard/CollaborativeWhiteboardExtension"; import { LinkPreviewExtension } from "../../extensions/LinkPreview"; import { MessageTranslationExtension } from "../../extensions/MessageTranslation"; import { PollsExtension } from "../../extensions/Polls/PollsExtension"; import { StickersExtension } from "../../extensions/Stickers"; import { ThumbnailGenerationExtension } from "../../extensions/ThumbnailGeneration"; import { ListenerInitializer } from "../events/ListenerInitializer"; import { ChatConfigurator } from "../framework"; import { CometChatLocalize, CometChatSoundManager } from "../resources"; import { getUnixTimestampInMilliseconds, messageStatus } from "../utils/CometChatMessageHelper"; import { permissionUtil } from "../utils/PermissionUtil"; import { CometChatUIKitHelper } from "./CometChatUIKitHelper"; class CometChatUIKit { static uiKitSettings; static loggedInUser = null; static conversationUpdateSettings = new CometChat.ConversationUpdateSettings(); static loginListenerID = ``; static isLoginListenerAttached = false; static init(uiKitSettings) { //perform sdk init taking values from uiKitSettings CometChatUIKit.uiKitSettings = { ...uiKitSettings, }; var appSetting = new CometChat.AppSettingsBuilder() .autoEstablishSocketConnection(uiKitSettings.autoEstablishSocketConnection) .overrideAdminHost(uiKitSettings?.overrideAdminHost || "") .overrideClientHost(uiKitSettings?.overrideClientHost || "") .setRegion(uiKitSettings.region); appSetting.subscriptionType = uiKitSettings.subscriptionType || ""; if (appSetting.subscriptionType === "ROLES" && Array.isArray(uiKitSettings.roles) && uiKitSettings.roles.length > 0) { appSetting.roles = uiKitSettings.roles; } CometChatUIKit.attachListener(); return CometChat.init(uiKitSettings.appId, appSetting.build()).then(async () => { CometChat.setSource("uikit-v5", Platform.OS, "react-native"); ListenerInitializer.attachListeners(); await CometChat.getLoggedinUser() .then((user) => { CometChatUIKit.setLoggedInUser(user); if (user) { this.enableExtensions(); } CometChat.getConversationUpdateSettings().then((conversationUpdateSettings) => { CometChatUIKit.setConversationUpdateSettings(conversationUpdateSettings); }); permissionUtil.init().then((res) => { if (res !== true) { console.warn("[IOS] Permission initialization failed."); } }); }) .catch((error) => { // CometChatUIKit.setLoggedInUser(null); }); }, (error) => { // console.log("Initialization failed with error:", error); }); } static defaultExtensions = [ new StickersExtension(), new CollaborativeWhiteboardExtension(), new CollaborativeDocumentExtension(), new MessageTranslationExtension(), new ThumbnailGenerationExtension(), new LinkPreviewExtension(), new PollsExtension(), ]; static attachListener() { if (CometChatUIKit.isLoginListenerAttached) { CometChatUIKit.removeListener(); CometChatUIKit.isLoginListenerAttached = false; CometChatUIKit.loginListenerID = ``; } CometChatUIKit.loginListenerID = `__CometChatLoginListener__`; CometChat.addLoginListener(CometChatUIKit.loginListenerID, new CometChat.LoginListener({ onLoggedIn: (user) => { CometChatUIKit.setLoggedInUser(user); CometChat.getConversationUpdateSettings().then((conversationUpdateSettings) => { CometChatUIKit.setConversationUpdateSettings(conversationUpdateSettings); }); }, onLoggedOut: () => { CometChatUIKit.removeLoggedInUser(); }, })); CometChatUIKit.isLoginListenerAttached = true; } static enableExtensions() { ChatConfigurator.init(); //re-initialize data source let isCallingExtensionEnabled = false; let extensionList = this.uiKitSettings?.extensions || this.defaultExtensions; if (this.uiKitSettings.callingExtension) { this.uiKitSettings.callingExtension.enable(); } if (extensionList.length > 0) { extensionList.forEach((extension) => { if (extension.getExtensionId() == "calling") { isCallingExtensionEnabled = true; } extension?.enable(); }); } if (!CometChatUIKit.uiKitSettings.disableCalling && !isCallingExtensionEnabled) { if (CallingPackage.isCallingPackageInstalled) new CallingExtension().enable(); } } static async getLoggedInUser() { if (CometChatUIKit.checkAuthSettings(Promise.reject)) null; let user = await CometChat.getLoggedinUser().catch((e) => Promise.reject(e)); if (user == null) { throw new CometChat.CometChatException({ code: "NOT_FOUND", message: "Login user not found", }); } else { this.enableExtensions(); } return user; } static setLoggedInUser(user) { this.loggedInUser = user; } static setConversationUpdateSettings(conversationUpdateSettings) { this.conversationUpdateSettings = conversationUpdateSettings; } static getConversationUpdateSettings() { return this.conversationUpdateSettings; } static removeLoggedInUser() { this.loggedInUser = null; } static removeListener() { if (CometChatUIKit.isLoginListenerAttached) { CometChat.removeLoginListener(CometChatUIKit.loginListenerID); CometChatUIKit.isLoginListenerAttached = false; CometChatUIKit.loginListenerID = ``; } } static async login({ uid, authToken, }) { if (CometChatUIKit.checkAuthSettings(Promise.reject)) null; if (uid) { let user = await CometChat.login(uid, CometChatUIKit.uiKitSettings?.authKey).catch((e) => Promise.reject(e)); CometChatUIKit.setLoggedInUser(user); CometChatUIKit.setConversationUpdateSettings(await CometChat.getConversationUpdateSettings()); this.enableExtensions(); return user; } if (authToken) { let user = await CometChat.login(authToken).catch((e) => Promise.reject(e)); this.enableExtensions(); return user; } return Promise.reject(new CometChat.CometChatException({ code: "INVALID_LOGIN_ATTEMPT", message: "Provide uid or authToken", })); } static logout() { if (this.checkAuthSettings(Promise.reject)) { } return CometChat.logout(); } static createUser(user) { if (this.checkAuthSettings(Promise.reject)) { } return CometChat.createUser(user, this.uiKitSettings.authKey); } static updateUser(user) { if (this.checkAuthSettings(Promise.reject)) { } return CometChat.updateUser(user, this.uiKitSettings.authKey); } //Error handling to give better logs static checkAuthSettings(onError) { if (this.uiKitSettings == null) { if (onError != null) { onError(new CometChat.CometChatException({ code: "ERR", name: "Authentication null", message: "Populate authSettings before initializing", })); } return false; } if (!this.uiKitSettings?.appId) { if (onError != null) { onError(new CometChat.CometChatException({ code: "appIdErr", name: "APP ID null", message: "Populate appId in authSettings before initializing", })); } return false; } return true; } //---------- Helper methods to send messages ---------- ///[sendCustomMessage] used to send a custom message static sendCustomMessage(message) { return new Promise((resolve, reject) => { if (!message.getMuid()) { message.setMuid(String(getUnixTimestampInMilliseconds())); } if (!message.getSender() && this.loggedInUser) { message.setSender(this.loggedInUser); } CometChatUIKitHelper.onMessageSent(message, messageStatus.inprogress); CometChat.sendCustomMessage(message) .then((customMessage) => { CometChatUIKitHelper.onMessageSent(customMessage, messageStatus.success); resolve(customMessage); }) .catch((err) => { let msg = message; if (msg.data) msg.data.metaData = { ...(msg.data.metaData ? msg.data.metaData : {}), error: true }; CometChatUIKitHelper.onMessageSent(msg, messageStatus.error); reject(err); }); }); } ///[sendMediaMessage] used to send a media message static sendMediaMessage(message) { return new Promise((resolve, reject) => { if (!message.getMuid()) { message.setMuid(String(getUnixTimestampInMilliseconds())); } if (!message.getSender() && this.loggedInUser) { message.setSender(this.loggedInUser); } let hasAttachment; try { hasAttachment = message.getAttachment(); } catch (error) { console.log("no attachment found"); } if (hasAttachment == undefined) { let file = message["files"][0]; if (file == undefined) { reject(new CometChat.CometChatException({ code: "Invalid Media message object", message: "file object not found.", })); } let attachmentObject = new CometChat.Attachment(file); attachmentObject.setName(file["name"]); attachmentObject.setExtension((file["name"].lastIndexOf(".") + 1).toString()); attachmentObject.setMimeType(file["type"]); attachmentObject.setSize(0); attachmentObject.setUrl(file["uri"]); message.setAttachment(attachmentObject); } CometChatUIKitHelper.onMessageSent(message, messageStatus.inprogress); CometChat.sendMediaMessage(message) .then((mediaMessage) => { CometChatUIKitHelper.onMessageSent(mediaMessage, messageStatus.success); resolve(mediaMessage); }) .catch((err) => { let msg = message; if (msg.data) msg.data.metaData = { ...(msg.data.metaData ? msg.data.metaData : {}), error: true }; CometChatUIKitHelper.onMessageSent(msg, messageStatus.error); reject(err); }); }); } ///[sendTextMessage] used to send a text message static sendTextMessage(message) { return new Promise((resolve, reject) => { if (!message?.getMuid()) { message.setMuid(String(getUnixTimestampInMilliseconds())); } if (!message?.getSender() && this.loggedInUser) { message.setSender(this.loggedInUser); } CometChatUIKitHelper.onMessageSent(message, messageStatus.inprogress); CometChat.sendMessage(message) .then((textMessage) => { CometChatUIKitHelper.onMessageSent(textMessage, messageStatus.success); resolve(textMessage); }) .catch((err) => { let msg = message; if (msg.data) msg.data.metaData = { ...(msg.data.metaData ? msg.data.metaData : {}), error: true }; CometChatUIKitHelper.onMessageSent(msg, messageStatus.error); reject(err); }); }); } static getDataSource() { return ChatConfigurator.getDataSource(); } static SoundManager = CometChatSoundManager; static Localize = CometChatLocalize; } export { CometChatUIKit }; //# sourceMappingURL=CometChatUIKit.js.map