UNPKG

@cometchat/chat-uikit-angular

Version:

Ready-to-use Chat UI Components for Angular (JavaScript/Web)

413 lines 95.8 kB
import { Component, Input, ChangeDetectionStrategy } from "@angular/core"; import { CometChat } from "@cometchat/chat-sdk-javascript"; import { WithMessagesStyle, MessagesConfiguration, ConversationsConfiguration, ContactsConfiguration } from '@cometchat/uikit-shared'; import { CometChatTheme, fontHelper, localize, CometChatGroupEvents, CometChatUIKitConstants, CometChatConversationEvents, CometChatUIEvents } from '@cometchat/uikit-resources'; import '@cometchat/uikit-elements'; import * as i0 from "@angular/core"; import * as i1 from "../../CometChatTheme.service"; import * as i2 from "../../CometChatConversations/cometchat-conversations/cometchat-conversations.component"; import * as i3 from "../../CometChatMessages/cometchat-messages/cometchat-messages.component"; import * as i4 from "../../CometChatContacts/cometchat-contacts/cometchat-contacts.component"; import * as i5 from "@angular/common"; /** * * CometChatConversationsWithMessagesComponent is a wrapper component for CometChatMessagesComponent and CometChatConversations component to show chats and messages in one screen * * @version 1.0.0 * @author CometChatTeam * @copyright © 2022 CometChat Inc. * */ export class CometChatConversationsWithMessagesComponent { constructor(elementRef, ref, themeService) { this.elementRef = elementRef; this.ref = ref; this.themeService = themeService; this.isMobileView = false; this.messageText = localize("NO_CHATS_SELECTED"); this.conversationsWithMessagesStyle = {}; this.messagesConfiguration = new MessagesConfiguration({}); this.conversationConfiguration = new ConversationsConfiguration({}); this.onError = (error) => { console.log(error); }; this.startNewConversationIconURL = "assets/new-chat.svg"; this.hideStartNewConversation = false; this.StartConversationConfiguration = new ContactsConfiguration({}); this.theme = new CometChatTheme({}); /** * Properties for internal use */ this.showStartConversation = false; this.labelStyle = { background: "transparent", textFont: "700 22px Inter", textColor: "rgba(20, 20, 20, 0.33)" }; this.hideSearch = true; this.startConversationButtonStyle = {}; this.sideBarStyle = {}; this.groupListenerId = "withmessages_group_" + new Date().getTime(); this.onBack = () => { this.user = null; this.group = null; this.activeConversation = null; }; this.onContactClicked = (user, group) => { this.showStartConversation = false; if (user) { this.group = null; this.user = user; this.ref.detectChanges(); } if (group) { this.user = null; this.group = group; this.ref.detectChanges(); } }; this.onItemClick = (conversation) => { this.activeConversation = conversation; this.showStartConversation = false; if (conversation.getConversationType() && conversation.getConversationType() == CometChatUIKitConstants.MessageReceiverType.user) { this.group = null; this.user = conversation.getConversationWith(); this.ref.detectChanges(); } else if (conversation.getConversationType() && conversation.getConversationType() == CometChatUIKitConstants.MessageReceiverType.group) { this.user = null; this.group = conversation.getConversationWith(); this.ref.detectChanges(); } }; this.closeStartConversation = () => { if (this.StartConversationConfiguration.onClose) { this.StartConversationConfiguration.onClose(); } this.showStartConversation = false; }; this.emptyMessageStyle = () => { return { background: this.conversationsWithMessagesStyle.background || this.themeService.theme.palette.getBackground(), height: this.conversationsWithMessagesStyle.height, width: `calc(${this.conversationsWithMessagesStyle.width} - 280px)`, border: "none", borderRadius: this.conversationsWithMessagesStyle.borderRadius, }; }; this.chatsWrapperStyles = () => { return { height: this.conversationsWithMessagesStyle.height, width: this.conversationsWithMessagesStyle.width, border: this.conversationsWithMessagesStyle.border, borderRadius: this.conversationsWithMessagesStyle.borderRadius, background: this.conversationsWithMessagesStyle.background || this.themeService.theme.palette.getBackground(), position: 'relative' }; }; this.contactsWrapperStyles = () => { return { background: this.StartConversationConfiguration.contactsStyle.background || this.themeService.theme.palette.getBackground(), }; }; } ngOnChanges(changes) { if (changes["isMobileView"]) { if (this.isMobileView) { this.messagesConfiguration.messageHeaderConfiguration.hideBackButton = false; if (!this.messagesConfiguration.detailsConfiguration.detailsStyle.padding) { this.messagesConfiguration.detailsConfiguration.detailsStyle.padding = "0 8px"; } if (!this.messagesConfiguration.detailsConfiguration.addMembersConfiguration.addMembersStyle.padding) { this.messagesConfiguration.detailsConfiguration.addMembersConfiguration.addMembersStyle.padding = "0 8px"; } if (!this.messagesConfiguration.detailsConfiguration.bannedMembersConfiguration.bannedMembersStyle.padding) { this.messagesConfiguration.detailsConfiguration.bannedMembersConfiguration.bannedMembersStyle.padding = "0 8px"; } if (!this.messagesConfiguration.detailsConfiguration.bannedMembersConfiguration.bannedMembersStyle.padding) { this.messagesConfiguration.detailsConfiguration.bannedMembersConfiguration.bannedMembersStyle.padding = "0 8px"; } this.messagesConfiguration.messageHeaderConfiguration = { ...this.messagesConfiguration.messageHeaderConfiguration }; this.StartConversationConfiguration.contactsStyle.padding = "0 8px"; this.StartConversationConfiguration = { ...this.StartConversationConfiguration }; this.messagesConfiguration = { ...this.messagesConfiguration }; } else if (!this.isMobileView) { this.messagesConfiguration.messageListConfiguration.messageInformationConfiguration.messageInformationStyle.height = "500px"; this.messagesConfiguration.messageListConfiguration.messageInformationConfiguration.messageInformationStyle.width = "500px"; this.messagesConfiguration.messageHeaderConfiguration.hideBackButton = true; if (!this.messagesConfiguration.detailsConfiguration.detailsStyle.padding) { this.messagesConfiguration.detailsConfiguration.detailsStyle.padding = "0 100px"; } if (!this.messagesConfiguration.detailsConfiguration.addMembersConfiguration.addMembersStyle.padding) { this.messagesConfiguration.detailsConfiguration.addMembersConfiguration.addMembersStyle.padding = "0 100px"; } if (!this.messagesConfiguration.detailsConfiguration.bannedMembersConfiguration.bannedMembersStyle.padding) { this.messagesConfiguration.detailsConfiguration.bannedMembersConfiguration.bannedMembersStyle.padding = "0 100px"; } if (!this.messagesConfiguration.detailsConfiguration.bannedMembersConfiguration.bannedMembersStyle.padding) { this.messagesConfiguration.detailsConfiguration.bannedMembersConfiguration.bannedMembersStyle.padding = "0 100px"; } this.StartConversationConfiguration.contactsStyle.padding = "0 100px"; this.StartConversationConfiguration = { ...this.StartConversationConfiguration }; this.messagesConfiguration.messageHeaderConfiguration = { ...this.messagesConfiguration.messageHeaderConfiguration }; this.messagesConfiguration = { ...this.messagesConfiguration }; } setTimeout(() => { this.updateBackdropHeight(); }, 100); } if (changes["user"] || changes["group"]) { this.setActiveChat(); } } triggerStartConversation() { this.showStartConversation = true; } removeChatOnGroupAction(leftUser, message) { const isSameUser = this.loggedInUser?.getUid() === leftUser.getUid(); const actionForGroup = message.getActionFor() instanceof CometChat.Group; if (isSameUser && this.activeConversation && this.activeConversation.getConversationWith() instanceof CometChat.Group) { let group = this.activeConversation.getConversationWith(); if (actionForGroup) { let actionOnGroup = message.getActionFor(); if (actionOnGroup.getGuid() === group.getGuid()) { this.activeConversation = null; this.user = null; this.group = null; this.ref.detectChanges(); } } } } attachGroupListeners() { CometChat.addGroupListener(this.groupListenerId, new CometChat.GroupListener({ onGroupMemberKicked: (message, kickedUser, kickedBy, kickedFrom) => { this.removeChatOnGroupAction(kickedUser, message); }, onGroupMemberBanned: (message, bannedUser, bannedBy, bannedFrom) => { this.removeChatOnGroupAction(bannedUser, message); }, })); } setWithMessagesStyle() { let defaultStyle = new WithMessagesStyle({ width: "100%", height: "100%", background: this.themeService.theme.palette.getBackground(), borderRadius: "none", border: `1px solid ${this.themeService.theme.palette.getAccent200()}`, messageTextColor: this.themeService.theme.palette.getAccent600(), messageTextFont: fontHelper(this.themeService.theme.typography.title1), }); this.conversationsWithMessagesStyle = { ...defaultStyle, ...this.conversationsWithMessagesStyle }; this.labelStyle.textFont = this.conversationsWithMessagesStyle.messageTextFont; this.labelStyle.textColor = this.conversationsWithMessagesStyle.messageTextColor; this.messagesConfiguration.messagesStyle.border = this.messagesConfiguration.messagesStyle.border ?? "none"; this.conversationConfiguration.conversationsStyle.border = this.conversationConfiguration.conversationsStyle.border ?? "none"; if (!this.conversationConfiguration?.conversationsStyle?.border || this.conversationConfiguration?.conversationsStyle?.border == "none") { this.sideBarStyle = { borderRight: this.conversationsWithMessagesStyle.border }; } } ngAfterViewInit() { this.updateBackdropHeight(); } updateBackdropHeight() { let divHeight = this.elementRef.nativeElement.offsetHeight; let divWidth = this.elementRef.nativeElement.offsetWidth; if (divHeight === 0 || divWidth === 0) { const rect = this.elementRef.nativeElement.getBoundingClientRect(); divHeight = rect.height; divWidth = rect.width; } let backdropStyle = { height: divHeight + "px", width: divWidth + "px", background: "rgba(0, 0, 0, 0.5)", position: "fixed" }; if (this.isMobileView) { this.messagesConfiguration.detailsConfiguration.transferOwnershipConfiguration.transferOwnershipStyle.height = (divHeight - 30) + "px"; this.messagesConfiguration.detailsConfiguration.transferOwnershipConfiguration.transferOwnershipStyle.width = divWidth + "px"; this.messagesConfiguration.messageListConfiguration.messageInformationConfiguration.messageInformationStyle.height = divHeight + "px"; this.messagesConfiguration.messageListConfiguration.messageInformationConfiguration.messageInformationStyle.width = divWidth + "px"; } else { this.messagesConfiguration.detailsConfiguration.transferOwnershipConfiguration.transferOwnershipStyle.height = "650px"; this.messagesConfiguration.detailsConfiguration.transferOwnershipConfiguration.transferOwnershipStyle.width = "360px"; } this.messagesConfiguration.messageListConfiguration.backdropStyle = this.messagesConfiguration.messageListConfiguration.backdropStyle || backdropStyle; this.conversationConfiguration.backdropStyle = this.conversationConfiguration.backdropStyle || backdropStyle; this.messagesConfiguration.detailsConfiguration.backdropStyle = this.messagesConfiguration.detailsConfiguration.backdropStyle || backdropStyle; this.messagesConfiguration.messageComposerConfiguration.backdropStyle = this.messagesConfiguration.messageComposerConfiguration.backdropStyle || backdropStyle; this.messagesConfiguration.detailsConfiguration.backdropStyle = this.messagesConfiguration.detailsConfiguration.backdropStyle || backdropStyle; this.messagesConfiguration.detailsConfiguration.groupMembersConfiguration.backdropStyle = this.messagesConfiguration.detailsConfiguration.groupMembersConfiguration.backdropStyle || backdropStyle; this.ref.detectChanges(); } setActiveChat() { let type = this.user ? CometChatUIKitConstants.MessageReceiverType.user : CometChatUIKitConstants.MessageReceiverType.group; this.activeConversation = null; let conversationWith = this.user?.getUid() || this.group?.getGuid(); CometChat.getConversation(conversationWith, type).then((conversation) => { this.activeConversation = conversation; this.ref.detectChanges(); }) .catch((error) => { if (this.onError) { this.onError(error); } }); } ngOnInit() { this.StartConversationConfiguration.usersConfiguration.usersStyle.border = "none"; this.StartConversationConfiguration.groupsConfiguration.groupsStyle.border = "none"; this.startConversationButtonStyle = { height: "24px", width: "24px", border: "none", borderRadius: '0', background: "transparent", buttonIconTint: this.themeService.theme.palette.getPrimary() }; this.StartConversationConfiguration = { ...this.StartConversationConfiguration }; this.setWithMessagesStyle(); if (!this.messagesConfiguration.messageHeaderConfiguration.onBack) { this.messagesConfiguration.messageHeaderConfiguration.onBack = this.onBack; } CometChat.getLoggedinUser() .then((user) => { this.loggedInUser = user; this.attachGroupListeners(); this.subscribeToEvents(); }) .catch((error) => { if (this.onError) { this.onError(error); } }); } ngOnDestroy() { this.unsubscribeToEvents(); CometChat.removeGroupListener(this.groupListenerId); } // subscribe to global events subscribeToEvents() { this.ccConversationDeleted = CometChatConversationEvents.ccConversationDeleted.subscribe((conversation) => { this.removeActiveChatList(conversation); //to make m messages section empty after deleting conversation from conversationlist }); this.ccGroupDeleted = CometChatGroupEvents.ccGroupDeleted.subscribe((group) => { if (this.group && group.getGuid() == this.group.getGuid()) { this.group = null; this.activeConversation = null; this.ref.detectChanges(); } }); this.ccGroupMemberAdded = CometChatGroupEvents.ccGroupMemberAdded.subscribe((item) => { if (this.group && this.group.getGuid() == item?.userAddedIn.getGuid()) { this.group = item?.userAddedIn; this.ref.detectChanges(); } }); this.ccGroupMemberBanned = CometChatGroupEvents.ccGroupMemberBanned.subscribe((item) => { if (this.group && this.group.getGuid() == item?.kickedFrom.getGuid()) { this.group = item?.kickedFrom; this.ref.detectChanges(); } }); this.ccGroupMemberJoined = CometChatGroupEvents.ccGroupMemberJoined.subscribe((item) => { if (this.group && this.group.getGuid() == item?.joinedGroup.getGuid()) { this.group = item?.joinedGroup; this.ref.detectChanges(); } }); this.ccGroupMemberKicked = CometChatGroupEvents.ccGroupMemberKicked.subscribe((item) => { if (this.group && this.group.getGuid() == item?.kickedFrom.getGuid()) { this.group = item?.kickedFrom; this.ref.detectChanges(); } }); this.ccOwnershipChanged = CometChatGroupEvents.ccOwnershipChanged.subscribe((item) => { if (this.group && this.group.getGuid() == item?.group.getGuid()) { this.group = item?.group; this.activeConversation?.setConversationWith(this.group); this.ref.detectChanges(); } }); this.ccGroupLeft = CometChatGroupEvents.ccGroupLeft.subscribe((item) => { if (this.group && this.group.getGuid() == item?.leftGroup.getGuid() && this.loggedInUser?.getUid() == item?.userLeft?.getUid()) { this.group = null; this.activeConversation = null; this.ref.detectChanges(); } }); // open chat and mark as active conversation this.ccOpenChat = CometChatUIEvents.ccOpenChat.subscribe((item) => { this.user = item.user ? item.user : null; this.group = item.group ? item.group : null; this.setActiveChat(); }); } // unsubscribe to subscribed events. unsubscribeToEvents() { this.ccConversationDeleted?.unsubscribe(); this.ccGroupDeleted?.unsubscribe(); this.ccGroupMemberAdded?.unsubscribe(); this.ccGroupMemberBanned?.unsubscribe(); this.ccGroupMemberJoined?.unsubscribe(); this.ccGroupMemberKicked?.unsubscribe(); this.ccOwnershipChanged?.unsubscribe(); this.ccGroupLeft?.unsubscribe(); this.ccOpenChat?.unsubscribe(); } /** * remove active chat screen after deleting the conversation. * @param {CometChat.Conversation} conversation */ removeActiveChatList(conversation) { const conversationType = conversation.getConversationType(); const conversationWith = conversation.getConversationWith(); if (conversationType === CometChatUIKitConstants.MessageReceiverType.user && this.user && this.user.getUid() === conversationWith.getUid()) { this.user = null; this.ref.detectChanges(); } else if (conversationType === CometChatUIKitConstants.MessageReceiverType.group && this.group && this.group.getGuid() === conversationWith.getGuid()) { this.group = null; this.ref.detectChanges(); } else { return; } } } CometChatConversationsWithMessagesComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: CometChatConversationsWithMessagesComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i1.CometChatThemeService }], target: i0.ɵɵFactoryTarget.Component }); CometChatConversationsWithMessagesComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: CometChatConversationsWithMessagesComponent, selector: "cometchat-conversations-with-messages", inputs: { user: "user", group: "group", isMobileView: "isMobileView", messageText: "messageText", conversationsWithMessagesStyle: "conversationsWithMessagesStyle", messagesConfiguration: "messagesConfiguration", conversationConfiguration: "conversationConfiguration", onError: "onError", startNewConversationIconURL: "startNewConversationIconURL", hideStartNewConversation: "hideStartNewConversation", StartConversationConfiguration: "StartConversationConfiguration" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"cc-with-messages__wrapper\" [ngStyle]=\"chatsWrapperStyles()\">\n <div class=\"cc-with-messages__sidebar\" [ngClass]=\"{mobile : isMobileView}\"\n [ngStyle]=\"sideBarStyle\">\n <cometchat-conversations #conversationRef\n [activeConversation]=\"activeConversation\"\n [onItemClick]=\"conversationConfiguration.onItemClick || onItemClick\"\n [conversationsStyle]=\"conversationConfiguration.conversationsStyle\"\n [statusIndicatorStyle]=\"conversationConfiguration?.statusIndicatorStyle\"\n [avatarStyle]=\"conversationConfiguration?.avatarStyle!\"\n [subtitleView]=\"conversationConfiguration.subtitleView\"\n [options]=\"conversationConfiguration.options\"\n [disableUsersPresence]=\"conversationConfiguration.disableUsersPresence\"\n [disableReceipt]=\"conversationConfiguration.disableReceipt\"\n [hideReceipt]=\"conversationConfiguration.hideReceipt\"\n [disableTyping]=\"conversationConfiguration.disableTyping\"\n [deliveredIcon]=\"conversationConfiguration.deliveredIcon\"\n [readIcon]=\"conversationConfiguration.readIcon\"\n [waitIcon]=\"conversationConfiguration.waitIcon\"\n [errorIcon]=\"conversationConfiguration.errorIcon\"\n [datePattern]=\"conversationConfiguration.datePattern\"\n [receiptStyle]=\"conversationConfiguration.receiptStyle\"\n [sentIcon]=\"conversationConfiguration.sentIcon\"\n [privateGroupIcon]=\"conversationConfiguration.privateGroupIcon\"\n [protectedGroupIcon]=\"conversationConfiguration.protectedGroupIcon\"\n [passwordGroupIcon]=\"conversationConfiguration.passwordGroupIcon\"\n [customSoundForMessages]=\"conversationConfiguration.customSoundForMessages\"\n [conversationsRequestBuilder]=\"conversationConfiguration.conversationsRequestBuilder\"\n [emptyStateView]=\"conversationConfiguration.emptyStateView\"\n [onSelect]=\"conversationConfiguration.onSelect\"\n [loadingIconURL]=\"conversationConfiguration.loadingIconURL\"\n [errorStateView]=\"conversationConfiguration.errorStateView\"\n [loadingStateView]=\"conversationConfiguration.loadingStateView\"\n [titleAlignment]=\"conversationConfiguration.titleAlignment\"\n [listItemView]=\"conversationConfiguration.listItemView\"\n [menu]=\"conversationConfiguration.menu || startConversationButton\"\n [hideSeparator]=\"conversationConfiguration.hideSeparator\"\n [hideError]=\"conversationConfiguration.hideError\"\n [selectionMode]=\"conversationConfiguration.selectionMode\"\n [disableSoundForMessages]=\"conversationConfiguration.disableSoundForMessages\"\n [deleteConversationDialogStyle]=\"conversationConfiguration.deleteConversationDialogStyle\"\n [badgeStyle]=\"conversationConfiguration.badgeStyle\"\n [dateStyle]=\"conversationConfiguration.dateStyle\"\n [listItemStyle]=\"conversationConfiguration.listItemStyle\"\n [backdropStyle]=\"conversationConfiguration.backdropStyle\"\n [textFormatters]=\"conversationConfiguration?.textFormatters\"\n [disableMentions]=\"conversationConfiguration.disableMentions\"></cometchat-conversations>\n </div>\n <div class=\"cc-with-messages__main\" [ngClass]=\"{mobile : isMobileView}\"\n *ngIf=\"!showStartConversation && (user || group)\">\n <!--Message List Screen-->\n <cometchat-messages #messagesRef [user]=\"user!\" [group]=\"group!\"\n [messageHeaderConfiguration]=\"messagesConfiguration.messageHeaderConfiguration\"\n [messageListConfiguration]=\"messagesConfiguration.messageListConfiguration\"\n [messageComposerConfiguration]=\"messagesConfiguration.messageComposerConfiguration\"\n [messagesStyle]=\"messagesConfiguration.messagesStyle\"\n [customSoundForIncomingMessages]=\"messagesConfiguration.customSoundForIncomingMessages\"\n [customSoundForOutgoingMessages]=\"messagesConfiguration.customSoundForOutgoingMessages\"\n [detailsConfiguration]=\"messagesConfiguration.detailsConfiguration\"\n [disableSoundForMessages]=\"messagesConfiguration.disableSoundForMessages\"\n [disableTyping]=\"messagesConfiguration.disableTyping\"\n [hideMessageComposer]=\"messagesConfiguration.hideMessageComposer\"\n [hideMessageHeader]=\"messagesConfiguration.hideMessageHeader\"\n [messageComposerView]=\"messagesConfiguration.messageComposerView\"\n [messageHeaderView]=\"messagesConfiguration.messageHeaderView\"\n [messageListView]=\"messagesConfiguration.messageListView\"\n [hideDetails]=\"messagesConfiguration.hideDetails!\"\n [threadedMessageConfiguration]=\"messagesConfiguration.threadedMessageConfiguration\">\n </cometchat-messages>\n <!--Message List Screen ENDS-->\n </div>\n <div class=\"cc-with-messages__start-conversation\"\n [ngStyle]=\"contactsWrapperStyles()\"\n [ngClass]=\"{mobile : isMobileView}\" *ngIf=\"showStartConversation\">\n\n <cometchat-contacts [onItemClick]=\"onContactClicked\"\n [usersConfiguration]=\"StartConversationConfiguration?.usersConfiguration!\"\n [groupsConfiguration]=\"StartConversationConfiguration?.groupsConfiguration!\"\n [closeIconURL]=\"StartConversationConfiguration?.closeIconURL!\"\n [contactsStyle]=\"StartConversationConfiguration?.contactsStyle!\"\n [selectionMode]=\"StartConversationConfiguration?.selectionMode!\"\n [onClose]=\"closeStartConversation\"\n [tabVisibility]=\"StartConversationConfiguration?.tabVisibility!\"\n [selectionLimit]=\"StartConversationConfiguration?.selectionLimit!\"\n [tabs]=\"StartConversationConfiguration?.tabs!\"\n [onSubmitButtonClick]=\"StartConversationConfiguration?.onSubmitButtonClick!\"\n [hideSubmitButton]=\"StartConversationConfiguration?.hideSubmitButton!\"></cometchat-contacts>\n </div>\n <div class=\"cc-decorator__message--empty\"\n *ngIf=\"!user && !group && !showStartConversation\"\n [ngStyle]=\"emptyMessageStyle()\">\n <cometchat-label [text]=\"messageText\"\n [labelStyle]=\"labelStyle\"></cometchat-label>\n </div>\n <ng-template #startConversationButton>\n <cometchat-button *ngIf=\"!hideStartNewConversation\"\n [iconURL]=\"startNewConversationIconURL\"\n [buttonStyle]=\"startConversationButtonStyle\"\n (cc-button-clicked)=\"triggerStartConversation()\"></cometchat-button>\n\n </ng-template>\n", styles: [".cc-with-messages__wrapper{display:flex;height:100%;width:100%;box-sizing:border-box;overflow:hidden}.cc-with-messages__sidebar{width:280px;height:100%;position:relative}.cc-with-messages__main,.cc-with-messages__start-conversation{width:calc(100% - 280px);height:100%}.mobile{width:100%!important;height:100%;position:absolute}.cc-decorator__message--empty{display:flex;justify-content:center;align-items:center}\n"], components: [{ type: i2.CometChatConversationsComponent, selector: "cometchat-conversations", inputs: ["subtitleView", "title", "options", "searchPlaceHolder", "disableUsersPresence", "disableReceipt", "hideReceipt", "disableTyping", "deliveredIcon", "readIcon", "errorIcon", "datePattern", "onError", "sentIcon", "privateGroupIcon", "protectedGroupIcon", "passwordGroupIcon", "customSoundForMessages", "activeConversation", "searchIconURL", "hideSearch", "conversationsRequestBuilder", "emptyStateView", "onSelect", "loadingIconURL", "errorStateView", "loadingStateView", "emptyStateText", "errorStateText", "titleAlignment", "listItemView", "menu", "hideSeparator", "searchPlaceholder", "hideError", "selectionMode", "disableSoundForMessages", "confirmDialogTitle", "confirmButtonText", "cancelButtonText", "confirmDialogMessage", "onItemClick", "deleteConversationDialogStyle", "backdropStyle", "badgeStyle", "dateStyle", "conversationsStyle", "listItemStyle", "statusIndicatorStyle", "typingIndicatorText", "threadIndicatorText", "avatarStyle", "receiptStyle", "loggedInUser", "disableMentions", "textFormatters"] }, { type: i3.CometChatMessagesComponent, selector: "cometchat-messages", inputs: ["user", "group", "currentAskAIBot", "hideMessageComposer", "disableTyping", "messageHeaderConfiguration", "messageListConfiguration", "messageComposerConfiguration", "threadedMessageConfiguration", "detailsConfiguration", "customSoundForIncomingMessages", "customSoundForOutgoingMessages", "disableSoundForMessages", "messagesStyle", "messageHeaderView", "messageComposerView", "messageListView", "hideMessageHeader", "hideDetails", "auxiliaryMenu"] }, { type: i4.CometChatContactsComponent, selector: "cometchat-contacts", inputs: ["title", "usersTabTitle", "groupsTabTitle", "usersConfiguration", "groupsConfiguration", "onSubmitButtonClick", "closeIconURL", "contactsStyle", "selectionMode", "onClose", "onItemClick", "tabVisibility", "selectionLimit", "tabs", "hideSubmitButton", "submitButtonText"] }], directives: [{ type: i5.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: CometChatConversationsWithMessagesComponent, decorators: [{ type: Component, args: [{ selector: "cometchat-conversations-with-messages", changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"cc-with-messages__wrapper\" [ngStyle]=\"chatsWrapperStyles()\">\n <div class=\"cc-with-messages__sidebar\" [ngClass]=\"{mobile : isMobileView}\"\n [ngStyle]=\"sideBarStyle\">\n <cometchat-conversations #conversationRef\n [activeConversation]=\"activeConversation\"\n [onItemClick]=\"conversationConfiguration.onItemClick || onItemClick\"\n [conversationsStyle]=\"conversationConfiguration.conversationsStyle\"\n [statusIndicatorStyle]=\"conversationConfiguration?.statusIndicatorStyle\"\n [avatarStyle]=\"conversationConfiguration?.avatarStyle!\"\n [subtitleView]=\"conversationConfiguration.subtitleView\"\n [options]=\"conversationConfiguration.options\"\n [disableUsersPresence]=\"conversationConfiguration.disableUsersPresence\"\n [disableReceipt]=\"conversationConfiguration.disableReceipt\"\n [hideReceipt]=\"conversationConfiguration.hideReceipt\"\n [disableTyping]=\"conversationConfiguration.disableTyping\"\n [deliveredIcon]=\"conversationConfiguration.deliveredIcon\"\n [readIcon]=\"conversationConfiguration.readIcon\"\n [waitIcon]=\"conversationConfiguration.waitIcon\"\n [errorIcon]=\"conversationConfiguration.errorIcon\"\n [datePattern]=\"conversationConfiguration.datePattern\"\n [receiptStyle]=\"conversationConfiguration.receiptStyle\"\n [sentIcon]=\"conversationConfiguration.sentIcon\"\n [privateGroupIcon]=\"conversationConfiguration.privateGroupIcon\"\n [protectedGroupIcon]=\"conversationConfiguration.protectedGroupIcon\"\n [passwordGroupIcon]=\"conversationConfiguration.passwordGroupIcon\"\n [customSoundForMessages]=\"conversationConfiguration.customSoundForMessages\"\n [conversationsRequestBuilder]=\"conversationConfiguration.conversationsRequestBuilder\"\n [emptyStateView]=\"conversationConfiguration.emptyStateView\"\n [onSelect]=\"conversationConfiguration.onSelect\"\n [loadingIconURL]=\"conversationConfiguration.loadingIconURL\"\n [errorStateView]=\"conversationConfiguration.errorStateView\"\n [loadingStateView]=\"conversationConfiguration.loadingStateView\"\n [titleAlignment]=\"conversationConfiguration.titleAlignment\"\n [listItemView]=\"conversationConfiguration.listItemView\"\n [menu]=\"conversationConfiguration.menu || startConversationButton\"\n [hideSeparator]=\"conversationConfiguration.hideSeparator\"\n [hideError]=\"conversationConfiguration.hideError\"\n [selectionMode]=\"conversationConfiguration.selectionMode\"\n [disableSoundForMessages]=\"conversationConfiguration.disableSoundForMessages\"\n [deleteConversationDialogStyle]=\"conversationConfiguration.deleteConversationDialogStyle\"\n [badgeStyle]=\"conversationConfiguration.badgeStyle\"\n [dateStyle]=\"conversationConfiguration.dateStyle\"\n [listItemStyle]=\"conversationConfiguration.listItemStyle\"\n [backdropStyle]=\"conversationConfiguration.backdropStyle\"\n [textFormatters]=\"conversationConfiguration?.textFormatters\"\n [disableMentions]=\"conversationConfiguration.disableMentions\"></cometchat-conversations>\n </div>\n <div class=\"cc-with-messages__main\" [ngClass]=\"{mobile : isMobileView}\"\n *ngIf=\"!showStartConversation && (user || group)\">\n <!--Message List Screen-->\n <cometchat-messages #messagesRef [user]=\"user!\" [group]=\"group!\"\n [messageHeaderConfiguration]=\"messagesConfiguration.messageHeaderConfiguration\"\n [messageListConfiguration]=\"messagesConfiguration.messageListConfiguration\"\n [messageComposerConfiguration]=\"messagesConfiguration.messageComposerConfiguration\"\n [messagesStyle]=\"messagesConfiguration.messagesStyle\"\n [customSoundForIncomingMessages]=\"messagesConfiguration.customSoundForIncomingMessages\"\n [customSoundForOutgoingMessages]=\"messagesConfiguration.customSoundForOutgoingMessages\"\n [detailsConfiguration]=\"messagesConfiguration.detailsConfiguration\"\n [disableSoundForMessages]=\"messagesConfiguration.disableSoundForMessages\"\n [disableTyping]=\"messagesConfiguration.disableTyping\"\n [hideMessageComposer]=\"messagesConfiguration.hideMessageComposer\"\n [hideMessageHeader]=\"messagesConfiguration.hideMessageHeader\"\n [messageComposerView]=\"messagesConfiguration.messageComposerView\"\n [messageHeaderView]=\"messagesConfiguration.messageHeaderView\"\n [messageListView]=\"messagesConfiguration.messageListView\"\n [hideDetails]=\"messagesConfiguration.hideDetails!\"\n [threadedMessageConfiguration]=\"messagesConfiguration.threadedMessageConfiguration\">\n </cometchat-messages>\n <!--Message List Screen ENDS-->\n </div>\n <div class=\"cc-with-messages__start-conversation\"\n [ngStyle]=\"contactsWrapperStyles()\"\n [ngClass]=\"{mobile : isMobileView}\" *ngIf=\"showStartConversation\">\n\n <cometchat-contacts [onItemClick]=\"onContactClicked\"\n [usersConfiguration]=\"StartConversationConfiguration?.usersConfiguration!\"\n [groupsConfiguration]=\"StartConversationConfiguration?.groupsConfiguration!\"\n [closeIconURL]=\"StartConversationConfiguration?.closeIconURL!\"\n [contactsStyle]=\"StartConversationConfiguration?.contactsStyle!\"\n [selectionMode]=\"StartConversationConfiguration?.selectionMode!\"\n [onClose]=\"closeStartConversation\"\n [tabVisibility]=\"StartConversationConfiguration?.tabVisibility!\"\n [selectionLimit]=\"StartConversationConfiguration?.selectionLimit!\"\n [tabs]=\"StartConversationConfiguration?.tabs!\"\n [onSubmitButtonClick]=\"StartConversationConfiguration?.onSubmitButtonClick!\"\n [hideSubmitButton]=\"StartConversationConfiguration?.hideSubmitButton!\"></cometchat-contacts>\n </div>\n <div class=\"cc-decorator__message--empty\"\n *ngIf=\"!user && !group && !showStartConversation\"\n [ngStyle]=\"emptyMessageStyle()\">\n <cometchat-label [text]=\"messageText\"\n [labelStyle]=\"labelStyle\"></cometchat-label>\n </div>\n <ng-template #startConversationButton>\n <cometchat-button *ngIf=\"!hideStartNewConversation\"\n [iconURL]=\"startNewConversationIconURL\"\n [buttonStyle]=\"startConversationButtonStyle\"\n (cc-button-clicked)=\"triggerStartConversation()\"></cometchat-button>\n\n </ng-template>\n", styles: [".cc-with-messages__wrapper{display:flex;height:100%;width:100%;box-sizing:border-box;overflow:hidden}.cc-with-messages__sidebar{width:280px;height:100%;position:relative}.cc-with-messages__main,.cc-with-messages__start-conversation{width:calc(100% - 280px);height:100%}.mobile{width:100%!important;height:100%;position:absolute}.cc-decorator__message--empty{display:flex;justify-content:center;align-items:center}\n"] }] }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i1.CometChatThemeService }]; }, propDecorators: { user: [{ type: Input }], group: [{ type: Input }], isMobileView: [{ type: Input }], messageText: [{ type: Input }], conversationsWithMessagesStyle: [{ type: Input }], messagesConfiguration: [{ type: Input }], conversationConfiguration: [{ type: Input }], onError: [{ type: Input }], startNewConversationIconURL: [{ type: Input }], hideStartNewConversation: [{ type: Input }], StartConversationConfiguration: [{ type: Input }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cometchat-conversations-with-messages.component.js","sourceRoot":"","sources":["../../../../../projects/chat-uikit-angular/src/CometChatConversationsWithMessages/cometchat-conversations-with-messages/cometchat-conversations-with-messages.component.ts","../../../../../projects/chat-uikit-angular/src/CometChatConversationsWithMessages/cometchat-conversations-with-messages/cometchat-conversations-with-messages.component.html"],"names":[],"mappings":"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