@cometchat/chat-uikit-angular
Version:
Ready-to-use Chat UI Components for Angular (JavaScript/Web)
413 lines • 95.8 kB
JavaScript
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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