@cometchat/chat-uikit-angular
Version:
Ready-to-use Chat UI Components for Angular (JavaScript/Web)
205 lines • 44.8 kB
JavaScript
import { Component, ViewChild, Input, ChangeDetectionStrategy } from "@angular/core";
import { CometChat } from "@cometchat/chat-sdk-javascript";
import '@cometchat/uikit-elements';
import { localize, CometChatTheme, fontHelper, CometChatUserEvents } from "@cometchat/uikit-resources";
import { WithMessagesStyle, MessagesConfiguration, UsersConfiguration } from "@cometchat/uikit-shared";
import * as i0 from "@angular/core";
import * as i1 from "../../CometChatTheme.service";
import * as i2 from "../../CometChatUsers/cometchat-users/cometchat-users.component";
import * as i3 from "../../CometChatMessages/cometchat-messages/cometchat-messages.component";
import * as i4 from "@angular/common";
/**
*
* CometChatUsersWithMessagesComponent 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 CometChatUsersWithMessagesComponent {
constructor(elementRef, ref, themeService) {
this.elementRef = elementRef;
this.ref = ref;
this.themeService = themeService;
this.isMobileView = false;
this.messageText = localize("NO_USERS_SELECTED");
this.usersWithMessagesStyle = {
width: "100%",
height: "100%",
borderRadius: "none",
};
this.messagesConfiguration = new MessagesConfiguration({});
this.usersConfiguration = new UsersConfiguration({});
this.onError = (error) => {
console.log(error);
};
this.theme = new CometChatTheme({});
this.labelStyle = {
background: "transparent",
textFont: "700 22px Inter",
textColor: "rgba(20, 20, 20, 0.33)"
};
this.sideBarStyle = {};
this.onBack = () => {
this.user = null;
};
this.onItemClick = (user) => {
this.user = user;
this.ref.detectChanges();
};
this.emptyMessageStyle = () => {
return {
background: this.usersWithMessagesStyle.background || this.themeService.theme.palette.getBackground(),
height: this.usersWithMessagesStyle.height,
width: `calc(${this.usersWithMessagesStyle.width} - 280px)`,
border: "none",
borderRadius: this.usersWithMessagesStyle.borderRadius,
};
};
this.usersWrapperStyles = () => {
return {
height: this.usersWithMessagesStyle.height,
width: this.usersWithMessagesStyle.width,
border: this.usersWithMessagesStyle.border,
borderRadius: this.usersWithMessagesStyle.borderRadius,
background: this.usersWithMessagesStyle.background || this.themeService.theme.palette.getBackground(),
position: 'relative'
};
};
}
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"
};
this.messagesConfiguration.messageListConfiguration.backdropStyle = backdropStyle;
this.messagesConfiguration.detailsConfiguration.backdropStyle = backdropStyle;
this.messagesConfiguration.messageComposerConfiguration.backdropStyle = backdropStyle;
this.messagesConfiguration.detailsConfiguration.groupMembersConfiguration.backdropStyle = backdropStyle;
this.ref.detectChanges();
}
ngOnChanges(changes) {
if (changes["isMobileView"]) {
if (this.isMobileView) {
this.messagesConfiguration.messageListConfiguration.messageInformationConfiguration.messageInformationStyle.height = "100%";
this.messagesConfiguration.messageListConfiguration.messageInformationConfiguration.messageInformationStyle.width = "100%";
this.messagesConfiguration.detailsConfiguration.detailsStyle.padding = "0 8px";
this.messagesConfiguration.messageHeaderConfiguration.hideBackButton = false;
this.messagesConfiguration.messageHeaderConfiguration = { ...this.messagesConfiguration.messageHeaderConfiguration };
this.messagesConfiguration = { ...this.messagesConfiguration };
}
else if (!this.isMobileView) {
this.messagesConfiguration.messageListConfiguration.messageInformationConfiguration.messageInformationStyle.height = "500px";
this.messagesConfiguration.messageListConfiguration.messageInformationConfiguration.messageInformationStyle.width = "500px";
this.messagesConfiguration.detailsConfiguration.detailsStyle.padding = "0 100px";
this.messagesConfiguration.messageHeaderConfiguration.hideBackButton = true;
this.messagesConfiguration.messageHeaderConfiguration = { ...this.messagesConfiguration.messageHeaderConfiguration };
this.messagesConfiguration = { ...this.messagesConfiguration };
}
setTimeout(() => {
this.updateBackdropHeight();
}, 100);
}
}
ngOnInit() {
this.setWithMessagesStyle();
if (!this.messagesConfiguration.messageHeaderConfiguration.onBack) {
this.messagesConfiguration.messageHeaderConfiguration.onBack = this.onBack;
}
this.subscribeToEvents();
CometChat.getLoggedinUser()
.then((user) => {
this.loggedInUser = user;
})
.catch((error) => {
if (this.onError) {
this.onError(error);
}
});
}
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.usersWithMessagesStyle = {
...defaultStyle,
...this.usersWithMessagesStyle
};
this.labelStyle.textFont = this.usersWithMessagesStyle.messageTextFont;
this.labelStyle.textColor = this.usersWithMessagesStyle.messageTextColor;
this.messagesConfiguration.messagesStyle.border = this.messagesConfiguration.messagesStyle.border ?? "none";
this.usersConfiguration.usersStyle.border = this.usersConfiguration.usersStyle.border ?? "none";
if (!this.usersConfiguration?.usersStyle?.border || this.usersConfiguration?.usersStyle?.border == "none") {
this.sideBarStyle = { borderRight: this.usersWithMessagesStyle.border };
}
}
ngOnDestroy() {
this.unsubscribeToEvents();
}
// subscribe to global events
subscribeToEvents() {
this.ccUserBlocked = CometChatUserEvents.ccUserBlocked.subscribe((user) => {
if (this.user && user.getUid() == this.user.getUid()) {
this.user = user;
this.ref.detectChanges();
}
});
this.ccUserUnBlocked = CometChatUserEvents.ccUserUnblocked.subscribe((user) => {
if (this.user && user.getUid() == this.user.getUid()) {
this.user = user;
this.ref.detectChanges();
}
});
}
// unsubscribe to subscribed events.
unsubscribeToEvents() {
this.ccUserBlocked?.unsubscribe();
this.ccUserUnBlocked?.unsubscribe();
}
}
CometChatUsersWithMessagesComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: CometChatUsersWithMessagesComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i1.CometChatThemeService }], target: i0.ɵɵFactoryTarget.Component });
CometChatUsersWithMessagesComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: CometChatUsersWithMessagesComponent, selector: "cometchat-users-with-messages", inputs: { user: "user", isMobileView: "isMobileView", messageText: "messageText", usersWithMessagesStyle: "usersWithMessagesStyle", messagesConfiguration: "messagesConfiguration", usersConfiguration: "usersConfiguration", onError: "onError" }, viewQueries: [{ propertyName: "userRef", first: true, predicate: ["usersRef"], descendants: true }, { propertyName: "messageListRef", first: true, predicate: ["messagesRef"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"cc-with-messages__wrapper\" [ngStyle]=\"usersWrapperStyles()\">\n <div class=\"cc-with-messages__sidebar\" [ngClass]=\"{mobile : isMobileView}\" [ngStyle]=\"sideBarStyle\">\n <cometchat-users\n #usersRef\n [activeUser]=\"user\"\n [hideSearch]=\"usersConfiguration.hideSearch\"\n [searchIconURL]=\"usersConfiguration.searchIconURL\"\n [searchRequestBuilder]=\"usersConfiguration.searchRequestBuilder\"\n [onItemClick]=\"usersConfiguration.onItemClick || onItemClick\"\n [usersStyle]=\"usersConfiguration.usersStyle\"\n [subtitleView]=\"usersConfiguration.subtitleView\"\n [options]=\"usersConfiguration.options\"\n [usersRequestBuilder]=\"usersConfiguration.usersRequestBuilder\"\n [emptyStateView]=\"usersConfiguration.emptyStateView\"\n [onSelect]=\"usersConfiguration.onSelect\"\n [loadingIconURL]=\"usersConfiguration.loadingIconURL\"\n [errorStateView]=\"usersConfiguration.errorStateView\"\n [loadingStateView]=\"usersConfiguration.loadingStateView\"\n [titleAlignment]=\"usersConfiguration.titleAlignment\"\n [showSectionHeader]=\"usersConfiguration.showSectionHeader\"\n [listItemView]=\"usersConfiguration.listItemView\"\n [menu]=\"usersConfiguration.menu\"\n [hideSeparator]=\"usersConfiguration.hideSeparator\"\n [hideError]=\"usersConfiguration.hideError\"\n [selectionMode]=\"usersConfiguration.selectionMode\"\n [listItemStyle]=\"usersConfiguration.listItemStyle\"\n [statusIndicatorStyle]=\"usersConfiguration.statusIndicatorStyle\"\n ></cometchat-users>\n </div>\n <div class=\"cc-with-messages__main\" [ngClass]=\"{mobile : isMobileView}\" *ngIf=\"user\">\n <!--Message List Screen-->\n <cometchat-messages\n #messagesRef\n [user]=\"user!\"\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 >\n </cometchat-messages>\n <!--Message List Screen ENDS-->\n </div>\n <div class=\"cc-decorator__message--empty\" *ngIf=\"!user\" [ngStyle]=\"emptyMessageStyle()\">\n <cometchat-label [text]=\"messageText\" [labelStyle]=\"labelStyle\"></cometchat-label>\n </div>\n</div>", styles: [".cc-with-messages__wrapper{display:flex;height:100%;width:100%;box-sizing:border-box}.cc-with-messages__sidebar{width:280px;height:100%;position:relative}.cc-with-messages__main{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.CometChatUsersComponent, selector: "cometchat-users", inputs: ["usersRequestBuilder", "searchRequestBuilder", "subtitleView", "disableUsersPresence", "listItemView", "menu", "options", "activeUser", "hideSeparator", "searchPlaceholder", "hideError", "selectionMode", "searchIconURL", "hideSearch", "title", "onError", "emptyStateView", "onSelect", "errorStateView", "loadingIconURL", "showSectionHeader", "sectionHeaderField", "loadingStateView", "emptyStateText", "errorStateText", "titleAlignment", "usersStyle", "listItemStyle", "statusIndicatorStyle", "avatarStyle", "onItemClick", "searchKeyword", "onEmpty", "userPresencePlacement", "disableLoadingState"] }, { 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"] }], directives: [{ type: i4.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: CometChatUsersWithMessagesComponent, decorators: [{
type: Component,
args: [{ selector: "cometchat-users-with-messages", changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"cc-with-messages__wrapper\" [ngStyle]=\"usersWrapperStyles()\">\n <div class=\"cc-with-messages__sidebar\" [ngClass]=\"{mobile : isMobileView}\" [ngStyle]=\"sideBarStyle\">\n <cometchat-users\n #usersRef\n [activeUser]=\"user\"\n [hideSearch]=\"usersConfiguration.hideSearch\"\n [searchIconURL]=\"usersConfiguration.searchIconURL\"\n [searchRequestBuilder]=\"usersConfiguration.searchRequestBuilder\"\n [onItemClick]=\"usersConfiguration.onItemClick || onItemClick\"\n [usersStyle]=\"usersConfiguration.usersStyle\"\n [subtitleView]=\"usersConfiguration.subtitleView\"\n [options]=\"usersConfiguration.options\"\n [usersRequestBuilder]=\"usersConfiguration.usersRequestBuilder\"\n [emptyStateView]=\"usersConfiguration.emptyStateView\"\n [onSelect]=\"usersConfiguration.onSelect\"\n [loadingIconURL]=\"usersConfiguration.loadingIconURL\"\n [errorStateView]=\"usersConfiguration.errorStateView\"\n [loadingStateView]=\"usersConfiguration.loadingStateView\"\n [titleAlignment]=\"usersConfiguration.titleAlignment\"\n [showSectionHeader]=\"usersConfiguration.showSectionHeader\"\n [listItemView]=\"usersConfiguration.listItemView\"\n [menu]=\"usersConfiguration.menu\"\n [hideSeparator]=\"usersConfiguration.hideSeparator\"\n [hideError]=\"usersConfiguration.hideError\"\n [selectionMode]=\"usersConfiguration.selectionMode\"\n [listItemStyle]=\"usersConfiguration.listItemStyle\"\n [statusIndicatorStyle]=\"usersConfiguration.statusIndicatorStyle\"\n ></cometchat-users>\n </div>\n <div class=\"cc-with-messages__main\" [ngClass]=\"{mobile : isMobileView}\" *ngIf=\"user\">\n <!--Message List Screen-->\n <cometchat-messages\n #messagesRef\n [user]=\"user!\"\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 >\n </cometchat-messages>\n <!--Message List Screen ENDS-->\n </div>\n <div class=\"cc-decorator__message--empty\" *ngIf=\"!user\" [ngStyle]=\"emptyMessageStyle()\">\n <cometchat-label [text]=\"messageText\" [labelStyle]=\"labelStyle\"></cometchat-label>\n </div>\n</div>", styles: [".cc-with-messages__wrapper{display:flex;height:100%;width:100%;box-sizing:border-box}.cc-with-messages__sidebar{width:280px;height:100%;position:relative}.cc-with-messages__main{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: { userRef: [{
type: ViewChild,
args: ["usersRef", { static: false }]
}], messageListRef: [{
type: ViewChild,
args: ["messagesRef", { static: false }]
}], user: [{
type: Input
}], isMobileView: [{
type: Input
}], messageText: [{
type: Input
}], usersWithMessagesStyle: [{
type: Input
}], messagesConfiguration: [{
type: Input
}], usersConfiguration: [{
type: Input
}], onError: [{
type: Input
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cometchat-users-with-messages.component.js","sourceRoot":"","sources":["../../../../../projects/chat-uikit-angular/src/CometChatUsersWithMessages/cometchat-users-with-messages/cometchat-users-with-messages.component.ts","../../../../../projects/chat-uikit-angular/src/CometChatUsersWithMessages/cometchat-users-with-messages/cometchat-users-with-messages.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ViewChild, Input, ChangeDetectionStrategy, OnChanges, SimpleChanges, ChangeDetectorRef, ElementRef } from \"@angular/core\";\nimport { CometChat } from \"@cometchat/chat-sdk-javascript\";\nimport { CometChatMessagesComponent } from \"../../CometChatMessages/cometchat-messages/cometchat-messages.component\";\nimport { CometChatConversationsComponent } from \"../../CometChatConversations/cometchat-conversations/cometchat-conversations.component\";\nimport '@cometchat/uikit-elements'\nimport { Subscription } from \"rxjs\";\nimport { CometChatThemeService } from \"../../CometChatTheme.service\";\nimport { localize, CometChatTheme, fontHelper, CometChatUserEvents } from \"@cometchat/uikit-resources\";\nimport { WithMessagesStyle, MessagesConfiguration, UsersConfiguration } from \"@cometchat/uikit-shared\";\n  /**\n *\n * CometChatUsersWithMessagesComponent is a wrapper component for CometChatMessagesComponent and CometChatConversations component to show chats and messages in one screen\n *\n * @version 1.0.0\n * @author CometChatTeam\n * @copyright © 2022 CometChat Inc.\n *\n */\n@Component({\n  selector: \"cometchat-users-with-messages\",\n  templateUrl: \"./cometchat-users-with-messages.component.html\",\n  styleUrls: [\"./cometchat-users-with-messages.component.scss\"],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class CometChatUsersWithMessagesComponent implements OnInit, OnChanges {\n  // taking reference of conversationComponent and MessagesComponent\n  @ViewChild(\"usersRef\", { static: false }) userRef!: CometChatConversationsComponent;\n  @ViewChild(\"messagesRef\", { static: false }) messageListRef!: CometChatMessagesComponent;\n  @Input() user!: CometChat.User | null;\n  @Input() isMobileView: boolean = false;\n  @Input() messageText: string = localize(\"NO_USERS_SELECTED\");\n  @Input()  usersWithMessagesStyle: WithMessagesStyle = {\n    width: \"100%\",\n    height: \"100%\",\n    borderRadius: \"none\",\n  \n  };\n  @Input() messagesConfiguration: MessagesConfiguration = new MessagesConfiguration({});\n  @Input() usersConfiguration: UsersConfiguration = new UsersConfiguration({});\n  @Input() onError:((error:CometChat.CometChatException)=>void ) | null= (error:CometChat.CometChatException)=>{\n    console.log(error)\n  }\n   theme: CometChatTheme = new CometChatTheme({});\n    /**\n     * Properties for internal use\n     */\n  public loggedInUser!: CometChat.User | null;\n  labelStyle:any = {\n    background:\"transparent\",\n    textFont:\"700 22px Inter\",\n    textColor:\"rgba(20, 20, 20, 0.33)\"\n  }\n     /**\n     * Events\n     */\n  ccUserBlocked!:Subscription;\n  ccUserUnBlocked!:Subscription;\n  sideBarStyle:any = {}\n  constructor(private elementRef: ElementRef,private ref: ChangeDetectorRef,private themeService:CometChatThemeService) {\n   }\n   ngAfterViewInit() {\n    this.updateBackdropHeight()\n      }\n      updateBackdropHeight(){\n        let divHeight = this.elementRef.nativeElement.offsetHeight;\n        let divWidth = this.elementRef.nativeElement.offsetWidth;\n        if (divHeight === 0 || divWidth === 0) {\n          const rect = this.elementRef.nativeElement.getBoundingClientRect();\n          divHeight = rect.height;\n          divWidth = rect.width;\n        }\n        let backdropStyle =  {\n          height:divHeight + \"px\",\n          width:divWidth + \"px\",\n          background:\"rgba(0, 0, 0, 0.5)\",\n          position:\"fixed\"\n        }\n        this.messagesConfiguration.messageListConfiguration.backdropStyle = backdropStyle\n        this.messagesConfiguration.detailsConfiguration.backdropStyle = backdropStyle\n        this.messagesConfiguration.messageComposerConfiguration.backdropStyle = backdropStyle\n        this.messagesConfiguration.detailsConfiguration.groupMembersConfiguration.backdropStyle = backdropStyle\n        this.ref.detectChanges()\n      }\n  ngOnChanges(changes: SimpleChanges): void {\n    if(changes[\"isMobileView\"]){\n      if (this.isMobileView) {\n        this.messagesConfiguration.messageListConfiguration.messageInformationConfiguration.messageInformationStyle.height = \"100%\"\n        this.messagesConfiguration.messageListConfiguration.messageInformationConfiguration.messageInformationStyle.width = \"100%\"\n        this.messagesConfiguration.detailsConfiguration.detailsStyle.padding = \"0 8px\"\n        this.messagesConfiguration.messageHeaderConfiguration.hideBackButton = false;\n        this.messagesConfiguration.messageHeaderConfiguration = {...this.messagesConfiguration.messageHeaderConfiguration}\n        this.messagesConfiguration = { ...this.messagesConfiguration }\n\n      }\n      else if (!this.isMobileView) {\n        this.messagesConfiguration.messageListConfiguration.messageInformationConfiguration.messageInformationStyle.height = \"500px\"\n        this.messagesConfiguration.messageListConfiguration.messageInformationConfiguration.messageInformationStyle.width = \"500px\"\n        this.messagesConfiguration.detailsConfiguration.detailsStyle.padding = \"0 100px\"\n        this.messagesConfiguration.messageHeaderConfiguration.hideBackButton = true;\n        this.messagesConfiguration.messageHeaderConfiguration = {...this.messagesConfiguration.messageHeaderConfiguration}\n        this.messagesConfiguration = { ...this.messagesConfiguration }\n      }\n      setTimeout(() => {\n        this.updateBackdropHeight()\n      }, 100);\n    }\n  }\n  onBack = ()=>{\n    this.user = null\n  }\n   onItemClick: ((user:CometChat.User)=>void) = (user:CometChat.User)=>{\n    this.user = user;\n    this.ref.detectChanges();\n\n  };\n  ngOnInit() {\n    this.setWithMessagesStyle()\n    if(!this.messagesConfiguration.messageHeaderConfiguration.onBack){\n      this.messagesConfiguration.messageHeaderConfiguration.onBack = this.onBack\n    }\n    this.subscribeToEvents();\n      CometChat.getLoggedinUser()\n        .then((user:CometChat.User | null) => {\n          this.loggedInUser = user;\n        })\n        .catch((error:CometChat.CometChatException) => {\n          if(this.onError){\n            this.onError(error)\n          }\n        });\n\n  }\n  setWithMessagesStyle(){\n    let defaultStyle:WithMessagesStyle = new WithMessagesStyle({\n      width: \"100%\",\n      height: \"100%\",\n      background: this.themeService.theme.palette.getBackground(),\n      borderRadius: \"none\",\n      border: `1px solid ${this.themeService.theme.palette.getAccent200()}`,\n      messageTextColor: this.themeService.theme.palette.getAccent600(),\n      messageTextFont: fontHelper(this.themeService.theme.typography.title1),\n    })\n    this.usersWithMessagesStyle = {\n      ...defaultStyle,\n      ...this.usersWithMessagesStyle\n    }\n    this.labelStyle.textFont = this.usersWithMessagesStyle.messageTextFont\n    this.labelStyle.textColor = this.usersWithMessagesStyle.messageTextColor;\n    this.messagesConfiguration.messagesStyle.border =  this.messagesConfiguration.messagesStyle.border ??  \"none\"\n    this.usersConfiguration.usersStyle.border =  this.usersConfiguration.usersStyle.border ??  \"none\"\n    if(!this.usersConfiguration?.usersStyle?.border || this.usersConfiguration?.usersStyle?.border == \"none\"){\n      this.sideBarStyle = {borderRight:this.usersWithMessagesStyle.border}\n      \n    }\n  }\n  ngOnDestroy() {\n    this.unsubscribeToEvents();\n  }\n\n  // subscribe to global events\n  subscribeToEvents() {\n    this.ccUserBlocked = CometChatUserEvents.ccUserBlocked.subscribe((user:CometChat.User) => {\n       if(this.user && user.getUid() == this.user.getUid()){\n         this.user = user;\n         this.ref.detectChanges()\n       }\n    })\n    this.ccUserUnBlocked = CometChatUserEvents.ccUserUnblocked.subscribe((user:CometChat.User) => {\n      if(this.user && user.getUid() == this.user.getUid()){\n        this.user = user;\n        this.ref.detectChanges()\n      }\n    })\n\n  }\n  // unsubscribe to subscribed events.\n  unsubscribeToEvents() {\n    this.ccUserBlocked?.unsubscribe();\n    this.ccUserUnBlocked?.unsubscribe();\n  }\n  emptyMessageStyle = ()=>{\n    return {\n      background: this.usersWithMessagesStyle.background || this.themeService.theme.palette.getBackground(),\n      height:this.usersWithMessagesStyle.height,\n      width:`calc(${this.usersWithMessagesStyle.width} - 280px)`,\n      border:\"none\",\n      borderRadius:this.usersWithMessagesStyle.borderRadius,\n    }\n  }\n  usersWrapperStyles =  () => {\n    return {\n      height: this.usersWithMessagesStyle.height,\n      width: this.usersWithMessagesStyle.width,\n      border: this.usersWithMessagesStyle.border,\n      borderRadius: this.usersWithMessagesStyle.borderRadius,\n      background: this.usersWithMessagesStyle.background || this.themeService.theme.palette.getBackground(),\n      position: 'relative'\n    }\n  }\n}\n","<div class=\"cc-with-messages__wrapper\" [ngStyle]=\"usersWrapperStyles()\">\n  <div class=\"cc-with-messages__sidebar\" [ngClass]=\"{mobile : isMobileView}\" [ngStyle]=\"sideBarStyle\">\n    <cometchat-users\n    #usersRef\n    [activeUser]=\"user\"\n    [hideSearch]=\"usersConfiguration.hideSearch\"\n    [searchIconURL]=\"usersConfiguration.searchIconURL\"\n    [searchRequestBuilder]=\"usersConfiguration.searchRequestBuilder\"\n    [onItemClick]=\"usersConfiguration.onItemClick || onItemClick\"\n    [usersStyle]=\"usersConfiguration.usersStyle\"\n    [subtitleView]=\"usersConfiguration.subtitleView\"\n    [options]=\"usersConfiguration.options\"\n    [usersRequestBuilder]=\"usersConfiguration.usersRequestBuilder\"\n    [emptyStateView]=\"usersConfiguration.emptyStateView\"\n    [onSelect]=\"usersConfiguration.onSelect\"\n    [loadingIconURL]=\"usersConfiguration.loadingIconURL\"\n    [errorStateView]=\"usersConfiguration.errorStateView\"\n    [loadingStateView]=\"usersConfiguration.loadingStateView\"\n    [titleAlignment]=\"usersConfiguration.titleAlignment\"\n    [showSectionHeader]=\"usersConfiguration.showSectionHeader\"\n    [listItemView]=\"usersConfiguration.listItemView\"\n    [menu]=\"usersConfiguration.menu\"\n    [hideSeparator]=\"usersConfiguration.hideSeparator\"\n    [hideError]=\"usersConfiguration.hideError\"\n    [selectionMode]=\"usersConfiguration.selectionMode\"\n    [listItemStyle]=\"usersConfiguration.listItemStyle\"\n    [statusIndicatorStyle]=\"usersConfiguration.statusIndicatorStyle\"\n    ></cometchat-users>\n  </div>\n  <div class=\"cc-with-messages__main\" [ngClass]=\"{mobile : isMobileView}\" *ngIf=\"user\">\n    <!--Message List Screen-->\n    <cometchat-messages\n    #messagesRef\n    [user]=\"user!\"\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    >\n    </cometchat-messages>\n    <!--Message List Screen ENDS-->\n  </div>\n  <div class=\"cc-decorator__message--empty\" *ngIf=\"!user\" [ngStyle]=\"emptyMessageStyle()\">\n    <cometchat-label [text]=\"messageText\" [labelStyle]=\"labelStyle\"></cometchat-label>\n   </div>\n</div>"]}