UNPKG

@cometchat/chat-uikit-angular

Version:

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

198 lines 39.6 kB
import { Component, Input, ChangeDetectionStrategy, } from "@angular/core"; import { CometChat } from "@cometchat/chat-sdk-javascript"; import { fontHelper, localize, CometChatUIKitConstants, } from "@cometchat/uikit-resources"; import "@cometchat/uikit-elements"; import { CallLogDetailsConfiguration, CallLogsConfiguration, WithDetailsStyle, } from "@cometchat/uikit-shared"; import * as i0 from "@angular/core"; import * as i1 from "../../../CometChatTheme.service"; import * as i2 from "../../CometChatCallLogs/cometchat-call-logs/cometchat-call-logs.component"; import * as i3 from "../../CometChatCallLogDetails/cometchat-call-log-details/cometchat-call-log-details.component"; import * as i4 from "@angular/common"; export class CometChatCallLogsWithDetailsComponent { constructor(elementRef, ref, themeService) { this.elementRef = elementRef; this.ref = ref; this.themeService = themeService; this.isMobileView = false; this.messageText = localize("NO_CALLS_SELECTED"); this.withDetailsStyle = {}; this.showMoreInfo = true; this.backdropStyle = {}; this.callLogDetailsConfiguration = new CallLogDetailsConfiguration({}); this.callLogConfiguration = new CallLogsConfiguration({}); this.onError = (error) => { console.log(error); }; this.computedCallLogDetailsConfig = new CallLogDetailsConfiguration({}); this.labelStyle = { background: "transparent", textFont: "700 22px Inter", textColor: "rgba(20, 20, 20, 0.33)", }; this.onBackClick = () => { this.user = null; this.group = null; this.activeCall = null; }; this.onInfoClick = (call) => { this.call = call; this.setActiveCallLog(); }; this.emptyMessageStyle = () => { return { background: this.withDetailsStyle.background || this.themeService.theme.palette.getBackground(), height: this.withDetailsStyle.height, width: `calc(${this.withDetailsStyle.width} - 280px)`, border: this.withDetailsStyle.border, borderRadius: this.withDetailsStyle.borderRadius, }; }; this.chatsWrapperStyles = () => { return { height: this.withDetailsStyle.height, width: this.withDetailsStyle.width, border: this.withDetailsStyle.border, borderRadius: this.withDetailsStyle.borderRadius, background: this.withDetailsStyle.background || this.themeService.theme.palette.getBackground(), }; }; } ngOnChanges(changes) { if (changes["user"] || changes["group"]) { this.setActiveCallLog(); } if (changes["isMobileView"]) { if (this.isMobileView) { this.backdropStyle.height = "100%"; this.backdropStyle.width = "100%"; this.computedCallLogDetailsConfig = this.computedCallLogDetailsConfiguration(); } else if (!this.isMobileView) { this.backdropStyle.height = "100%"; this.backdropStyle.width = "100%"; this.computedCallLogDetailsConfig = this.computedCallLogDetailsConfiguration(); } setTimeout(() => { this.updateBackdropHeight(); }, 100); } } 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; } this.backdropStyle = { height: divHeight + "px", width: divWidth + "px", background: "rgba(0, 0, 0, 0.5)", position: "fixed", }; if (this.isMobileView) { this.backdropStyle.height = divHeight + "px"; this.backdropStyle.width = divWidth + "px"; } else { this.backdropStyle.height = divHeight + "px"; this.backdropStyle.width = divWidth + "px"; } this.backdropStyle.height = divHeight + "px"; this.backdropStyle.width = divWidth + "px"; } setWithDetailsStyle() { let defaultStyle = new WithDetailsStyle({ width: "100%", height: "100%", background: this.themeService.theme.palette.getBackground(), borderRadius: "none", border: "none", messageTextColor: this.themeService.theme.palette.getAccent600(), messageTextFont: fontHelper(this.themeService.theme.typography.title1), }); this.withDetailsStyle = { ...defaultStyle, ...this.withDetailsStyle, }; this.labelStyle.textFont = this.withDetailsStyle.messageTextFont; this.labelStyle.textColor = this.withDetailsStyle.messageTextColor; } setActiveCallLog() { this.activeCall = this.call; if (this.call.getInitiator().getUid() == this.loggedInUser?.getUid()) { if (this.call.getReceiverType() == CometChatUIKitConstants.MessageReceiverType.user) { this.user = this.call.getReceiver(); this.group = null; } else { this.user = null; this.group = this.call.getReceiver(); } } else { this.user = this.call.getInitiator(); } } ngOnInit() { this.computedCallLogDetailsConfig = this.computedCallLogDetailsConfiguration(); this.updateBackdropHeight(); this.setWithDetailsStyle(); CometChat.getLoggedinUser() .then((user) => { this.loggedInUser = user; }) .catch((error) => { if (this.onError) { this.onError(error); } }); } computedCallLogDetailsConfiguration() { const config = new CallLogDetailsConfiguration({}); Object.assign(config, this.callLogDetailsConfiguration); config.callLogDetailsStyle = { ...config.callLogDetailsStyle, border: `1px solid ${this.themeService.theme.palette?.getAccent100()}`, }; if (this.isMobileView) config.onBackClick = () => { this.activeCall = null; this.user = null; this.group = null; }; return config; } } CometChatCallLogsWithDetailsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: CometChatCallLogsWithDetailsComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i1.CometChatThemeService }], target: i0.ɵɵFactoryTarget.Component }); CometChatCallLogsWithDetailsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: CometChatCallLogsWithDetailsComponent, selector: "cometchat-call-logs-with-details", inputs: { isMobileView: "isMobileView", messageText: "messageText", withDetailsStyle: "withDetailsStyle", showMoreInfo: "showMoreInfo", backdropStyle: "backdropStyle", call: "call", callLogDetailsConfiguration: "callLogDetailsConfiguration", callLogConfiguration: "callLogConfiguration", onError: "onError" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"cc-with-details__wrapper\" [ngStyle]=\"chatsWrapperStyles()\">\n <div class=\"cc-with-details__sidebar\" [ngClass]=\"{mobile : isMobileView}\">\n <cometchat-call-logs [activeCall]=\"activeCall\" [showMoreInfo]=\"showMoreInfo\" [backdropStyle]=\"backdropStyle\"\n [activeCall]=\"activeCall\" [titleAlignment]=\"callLogConfiguration?.titleAlignment!\"\n [emptyStateView]=\"callLogConfiguration.emptyStateView\" \n [errorStateView]=\"callLogConfiguration.errorStateView\"\n [subtitleView]=\"callLogConfiguration.subtitleView\" \n [listItemView]=\"callLogConfiguration.listItemView\" \n [tailView]=\"callLogConfiguration.tailView\" \n [loadingIconURL]=\"callLogConfiguration.loadingIconURL\" [loadingStateView]=\"callLogConfiguration.loadingStateView\"\n [callLogRequestBuilder]=\"callLogConfiguration.callLogRequestBuilder\"\n [onItemClick]=\"callLogConfiguration.onItemClick!\" [onInfoClick]=\"callLogConfiguration.onInfoClick || onInfoClick! \"\n [onError]=\"callLogConfiguration.onError!\" [listItemStyle]=\"callLogConfiguration.listItemStyle\"\n [infoIconUrl]=\"callLogConfiguration.infoIconUrl\" [datePattern]=\"callLogConfiguration.datePattern\"\n [dateSeparatorPattern]=\"callLogConfiguration.dateSeparatorPattern\"\n [incomingAudioCallIconUrl]=\"callLogConfiguration.incomingAudioCallIconUrl\"\n [incomingVideoCallIconUrl]=\"callLogConfiguration.incomingVideoCallIconUrl\"\n [outgoingAudioCallIconUrl]=\"callLogConfiguration.outgoingAudioCallIconUrl\"\n [outgoingVideoCallIconUrl]=\"callLogConfiguration.outgoingVideoCallIconUrl\"\n [missedAudioCallIconUrl]=\"callLogConfiguration.missedAudioCallIconUrl\"\n [missedVideoCallIconUrl]=\"callLogConfiguration.missedVideoCallIconUrl\"\n [callLogsStyle]=\"callLogConfiguration.callLogsStyle\" [avatarStyle]=\"callLogConfiguration.avatarStyle\"\n [hideSeparator]=\"callLogConfiguration.hideSeparator\"\n [outgoingCallConfiguration]=\"callLogConfiguration.outgoingCallConfiguration\"></cometchat-call-logs>\n </div>\n <div class=\"cc-with-details__main\" [ngClass]=\"{mobile : isMobileView}\" *ngIf=\"activeCall && (user || group)\">\n <!--call details Screen-->\n <cometchat-call-log-details [user]=\"user!\" [group]=\"group!\" [call]=\"call\"\n [backIconUrl]=\"computedCallLogDetailsConfig.backIconUrl\" [avatarStyle]=\"computedCallLogDetailsConfig.avatarStyle\"\n [onBackClick]=\"computedCallLogDetailsConfig.onBackClick || onBackClick\"\n [callLogHistoryConfiguration]=\"computedCallLogDetailsConfig.callLogHistoryConfiguration\"\n [callLogParticipantsConfiguration]=\"computedCallLogDetailsConfig.callLogParticipantsConfiguration\"\n [callLogRecordingsConfiguration]=\"computedCallLogDetailsConfig.callLogRecordingsConfiguration\"\n [callLogDetailStyle]=\"computedCallLogDetailsConfig.callLogDetailsStyle\">\n </cometchat-call-log-details>\n </div>\n\n <div class=\"cc-decorator__message--empty\" *ngIf=\"!user && !group\" [ngStyle]=\"emptyMessageStyle()\">\n <cometchat-label [text]=\"messageText\" [labelStyle]=\"labelStyle\"></cometchat-label>\n </div>", styles: [".cc-with-details__wrapper{display:flex;height:100%;width:100%;box-sizing:border-box}.cc-with-details__sidebar{width:280px;height:100%;position:relative}.cc-with-details__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.CometchatCallLogsComponent, selector: "cometchat-call-logs", inputs: ["title", "titleAlignment", "listItemView", "subtitleView", "tailView", "menu", "emptyStateView", "errorStateView", "emptyStateText", "errorStateText", "loadingStateView", "loadingIconURL", "infoIconUrl", "missedAudioCallIconUrl", "missedVideoCallIconUrl", "outgoingAudioCallIconUrl", "outgoingVideoCallIconUrl", "incomingAudioCallIconUrl", "incomingVideoCallIconUrl", "callLogRequestBuilder", "cometchatCallObject", "onItemClick", "onInfoClick", "onError", "activeCall", "datePattern", "DateSeparatorPattern", "callLogsStyle", "avatarStyle", "hideSeparator", "dateSeparatorStyle", "outgoingCallConfiguration", "hideError", "showSectionHeader", "showMoreInfo", "sectionHeaderField", "backdropStyle", "dateStyle", "listItemStyle", "ongoingCallConfiguration"] }, { type: i3.CometChatCallLogDetailsComponent, selector: "cometchat-call-log-details", inputs: ["call", "group", "user", "title", "onBackClick", "hideProfile", "subtitleView", "customProfileView", "backIconUrl", "greaterThanIconURL", "callButtonsConfiguration", "callLogParticipantsConfiguration", "callLogHistoryConfiguration", "callLogRecordingsConfiguration", "onError", "datePattern", "datePattern2", "data", "avatarStyle", "labelStyle", "callDetailsStyle", "listItemStyle", "dateStyle", "callButtonsStyle"] }], 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: CometChatCallLogsWithDetailsComponent, decorators: [{ type: Component, args: [{ selector: "cometchat-call-logs-with-details", changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"cc-with-details__wrapper\" [ngStyle]=\"chatsWrapperStyles()\">\n <div class=\"cc-with-details__sidebar\" [ngClass]=\"{mobile : isMobileView}\">\n <cometchat-call-logs [activeCall]=\"activeCall\" [showMoreInfo]=\"showMoreInfo\" [backdropStyle]=\"backdropStyle\"\n [activeCall]=\"activeCall\" [titleAlignment]=\"callLogConfiguration?.titleAlignment!\"\n [emptyStateView]=\"callLogConfiguration.emptyStateView\" \n [errorStateView]=\"callLogConfiguration.errorStateView\"\n [subtitleView]=\"callLogConfiguration.subtitleView\" \n [listItemView]=\"callLogConfiguration.listItemView\" \n [tailView]=\"callLogConfiguration.tailView\" \n [loadingIconURL]=\"callLogConfiguration.loadingIconURL\" [loadingStateView]=\"callLogConfiguration.loadingStateView\"\n [callLogRequestBuilder]=\"callLogConfiguration.callLogRequestBuilder\"\n [onItemClick]=\"callLogConfiguration.onItemClick!\" [onInfoClick]=\"callLogConfiguration.onInfoClick || onInfoClick! \"\n [onError]=\"callLogConfiguration.onError!\" [listItemStyle]=\"callLogConfiguration.listItemStyle\"\n [infoIconUrl]=\"callLogConfiguration.infoIconUrl\" [datePattern]=\"callLogConfiguration.datePattern\"\n [dateSeparatorPattern]=\"callLogConfiguration.dateSeparatorPattern\"\n [incomingAudioCallIconUrl]=\"callLogConfiguration.incomingAudioCallIconUrl\"\n [incomingVideoCallIconUrl]=\"callLogConfiguration.incomingVideoCallIconUrl\"\n [outgoingAudioCallIconUrl]=\"callLogConfiguration.outgoingAudioCallIconUrl\"\n [outgoingVideoCallIconUrl]=\"callLogConfiguration.outgoingVideoCallIconUrl\"\n [missedAudioCallIconUrl]=\"callLogConfiguration.missedAudioCallIconUrl\"\n [missedVideoCallIconUrl]=\"callLogConfiguration.missedVideoCallIconUrl\"\n [callLogsStyle]=\"callLogConfiguration.callLogsStyle\" [avatarStyle]=\"callLogConfiguration.avatarStyle\"\n [hideSeparator]=\"callLogConfiguration.hideSeparator\"\n [outgoingCallConfiguration]=\"callLogConfiguration.outgoingCallConfiguration\"></cometchat-call-logs>\n </div>\n <div class=\"cc-with-details__main\" [ngClass]=\"{mobile : isMobileView}\" *ngIf=\"activeCall && (user || group)\">\n <!--call details Screen-->\n <cometchat-call-log-details [user]=\"user!\" [group]=\"group!\" [call]=\"call\"\n [backIconUrl]=\"computedCallLogDetailsConfig.backIconUrl\" [avatarStyle]=\"computedCallLogDetailsConfig.avatarStyle\"\n [onBackClick]=\"computedCallLogDetailsConfig.onBackClick || onBackClick\"\n [callLogHistoryConfiguration]=\"computedCallLogDetailsConfig.callLogHistoryConfiguration\"\n [callLogParticipantsConfiguration]=\"computedCallLogDetailsConfig.callLogParticipantsConfiguration\"\n [callLogRecordingsConfiguration]=\"computedCallLogDetailsConfig.callLogRecordingsConfiguration\"\n [callLogDetailStyle]=\"computedCallLogDetailsConfig.callLogDetailsStyle\">\n </cometchat-call-log-details>\n </div>\n\n <div class=\"cc-decorator__message--empty\" *ngIf=\"!user && !group\" [ngStyle]=\"emptyMessageStyle()\">\n <cometchat-label [text]=\"messageText\" [labelStyle]=\"labelStyle\"></cometchat-label>\n </div>", styles: [".cc-with-details__wrapper{display:flex;height:100%;width:100%;box-sizing:border-box}.cc-with-details__sidebar{width:280px;height:100%;position:relative}.cc-with-details__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: { isMobileView: [{ type: Input }], messageText: [{ type: Input }], withDetailsStyle: [{ type: Input }], showMoreInfo: [{ type: Input }], backdropStyle: [{ type: Input }], call: [{ type: Input }], callLogDetailsConfiguration: [{ type: Input }], callLogConfiguration: [{ type: Input }], onError: [{ type: Input }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cometchat-call-logs-with-details.component.js","sourceRoot":"","sources":["../../../../../../projects/chat-uikit-angular/src/Calls/CometChatCallLogsWithDetails/cometchat-call-logs-with-details/cometchat-call-logs-with-details.component.ts","../../../../../../projects/chat-uikit-angular/src/Calls/CometChatCallLogsWithDetails/cometchat-call-logs-with-details/cometchat-call-logs-with-details.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  OnInit,\n  Input,\n  ChangeDetectionStrategy,\n  OnChanges,\n  SimpleChanges,\n  ChangeDetectorRef,\n  ElementRef,\n} from \"@angular/core\";\nimport { CometChat } from \"@cometchat/chat-sdk-javascript\";\n\nimport {\n  fontHelper,\n  localize,\n  CometChatUIKitConstants,\n} from \"@cometchat/uikit-resources\";\n\nimport \"@cometchat/uikit-elements\";\nimport { CometChatThemeService } from \"../../../CometChatTheme.service\";\nimport { BackdropStyle } from \"@cometchat/uikit-elements\";\nimport {\n  CallLogDetailsConfiguration,\n  CallLogsConfiguration,\n  WithDetailsStyle,\n} from \"@cometchat/uikit-shared\";\n\n@Component({\n  selector: \"cometchat-call-logs-with-details\",\n  templateUrl: \"./cometchat-call-logs-with-details.component.html\",\n  styleUrls: [\"./cometchat-call-logs-with-details.component.scss\"],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class CometChatCallLogsWithDetailsComponent\n  implements OnInit, OnChanges\n{\n  @Input() isMobileView: boolean = false;\n  @Input() messageText: string = localize(\"NO_CALLS_SELECTED\");\n  @Input() withDetailsStyle: WithDetailsStyle = {};\n  @Input() showMoreInfo: boolean = true;\n  @Input() backdropStyle: BackdropStyle = {};\n  @Input() call!: any;\n\n  @Input() callLogDetailsConfiguration: CallLogDetailsConfiguration =\n    new CallLogDetailsConfiguration({});\n\n  @Input() callLogConfiguration: CallLogsConfiguration =\n    new CallLogsConfiguration({});\n\n  @Input() onError: ((error: CometChat.CometChatException) => void) | null = (\n    error: CometChat.CometChatException\n  ) => {\n    console.log(error);\n  };\n  /**\n   * Properties for internal use\n   */\n  public loggedInUser!: CometChat.User | null;\n  public activeCall!:any;\n  user!: any | null;\n  group!: CometChat.Group | null;\n\n  computedCallLogDetailsConfig: CallLogDetailsConfiguration =\n    new CallLogDetailsConfiguration({});\n\n  labelStyle: any = {\n    background: \"transparent\",\n    textFont: \"700 22px Inter\",\n    textColor: \"rgba(20, 20, 20, 0.33)\",\n  };\n\n  constructor(\n    private elementRef: ElementRef,\n    private ref: ChangeDetectorRef,\n    private themeService: CometChatThemeService\n  ) {}\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes[\"user\"] || changes[\"group\"]) {\n      this.setActiveCallLog();\n    }\n\n    if (changes[\"isMobileView\"]) {\n      if (this.isMobileView) {\n        this.backdropStyle.height = \"100%\";\n        this.backdropStyle.width = \"100%\";\n        this.computedCallLogDetailsConfig =\n          this.computedCallLogDetailsConfiguration();\n      } else if (!this.isMobileView) {\n        this.backdropStyle.height = \"100%\";\n        this.backdropStyle.width = \"100%\";\n        this.computedCallLogDetailsConfig =\n          this.computedCallLogDetailsConfiguration();\n      }\n      setTimeout(() => {\n        this.updateBackdropHeight();\n      }, 100);\n    }\n  }\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    this.backdropStyle = {\n      height: divHeight + \"px\",\n      width: divWidth + \"px\",\n      background: \"rgba(0, 0, 0, 0.5)\",\n      position: \"fixed\",\n    };\n\n    if (this.isMobileView) {\n      this.backdropStyle.height = divHeight + \"px\";\n      this.backdropStyle.width = divWidth + \"px\";\n    } else {\n      this.backdropStyle.height = divHeight + \"px\";\n      this.backdropStyle.width = divWidth + \"px\";\n    }\n\n    this.backdropStyle.height = divHeight + \"px\";\n    this.backdropStyle.width = divWidth + \"px\";\n  }\n\n  onBackClick = () => {\n    this.user = null;\n    this.group = null;\n    this.activeCall = null;\n  };\n  setWithDetailsStyle() {\n    let defaultStyle: WithDetailsStyle = new WithDetailsStyle({\n      width: \"100%\",\n      height: \"100%\",\n      background: this.themeService.theme.palette.getBackground(),\n      borderRadius: \"none\",\n      border: \"none\",\n      messageTextColor: this.themeService.theme.palette.getAccent600(),\n      messageTextFont: fontHelper(this.themeService.theme.typography.title1),\n    });\n    this.withDetailsStyle = {\n      ...defaultStyle,\n      ...this.withDetailsStyle,\n    };\n    this.labelStyle.textFont = this.withDetailsStyle.messageTextFont;\n    this.labelStyle.textColor = this.withDetailsStyle.messageTextColor;\n  }\n\n  public onInfoClick: (call: any) => void = (call: any) => {\n    this.call = call;\n    this.setActiveCallLog();\n  };\n  setActiveCallLog() {\n    this.activeCall = this.call;\n    if (this.call!.getInitiator().getUid() == this.loggedInUser?.getUid()) {\n      if (\n        this.call!.getReceiverType() ==\n        CometChatUIKitConstants.MessageReceiverType.user\n      ) {\n        this.user = this.call!.getReceiver() as unknown as CometChat.User;\n        this.group = null;\n      } else {\n        this.user = null;\n        this.group = this.call!.getReceiver() as unknown as CometChat.Group;\n      }\n    } else {\n      this.user = this.call!.getInitiator() as unknown as CometChat.User;\n    }\n  }\n  ngOnInit() {\n    this.computedCallLogDetailsConfig =\n      this.computedCallLogDetailsConfiguration();\n    this.updateBackdropHeight();\n    this.setWithDetailsStyle();\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  computedCallLogDetailsConfiguration(): CallLogDetailsConfiguration {\n    const config = new CallLogDetailsConfiguration({});\n    Object.assign(config, this.callLogDetailsConfiguration);\n\n    config.callLogDetailsStyle = {\n      ...config.callLogDetailsStyle,\n      border: `1px solid ${this.themeService.theme.palette?.getAccent100()}`,\n    };\n\n    if (this.isMobileView)\n      config.onBackClick = () => {\n        this.activeCall = null;\n        this.user = null;\n        this.group = null;\n      };\n\n    return config;\n  }\n  emptyMessageStyle = () => {\n    return {\n      background:\n        this.withDetailsStyle.background ||\n        this.themeService.theme.palette.getBackground(),\n      height: this.withDetailsStyle.height,\n      width: `calc(${this.withDetailsStyle.width} - 280px)`,\n      border: this.withDetailsStyle.border,\n      borderRadius: this.withDetailsStyle.borderRadius,\n    };\n  };\n  chatsWrapperStyles = () => {\n    return {\n      height: this.withDetailsStyle.height,\n      width: this.withDetailsStyle.width,\n      border: this.withDetailsStyle.border,\n      borderRadius: this.withDetailsStyle.borderRadius,\n      background:\n        this.withDetailsStyle.background ||\n        this.themeService.theme.palette.getBackground(),\n    };\n  };\n}\n","<div class=\"cc-with-details__wrapper\" [ngStyle]=\"chatsWrapperStyles()\">\n  <div class=\"cc-with-details__sidebar\" [ngClass]=\"{mobile : isMobileView}\">\n    <cometchat-call-logs [activeCall]=\"activeCall\" [showMoreInfo]=\"showMoreInfo\" [backdropStyle]=\"backdropStyle\"\n      [activeCall]=\"activeCall\" [titleAlignment]=\"callLogConfiguration?.titleAlignment!\"\n      [emptyStateView]=\"callLogConfiguration.emptyStateView\" \n      [errorStateView]=\"callLogConfiguration.errorStateView\"\n      [subtitleView]=\"callLogConfiguration.subtitleView\" \n      [listItemView]=\"callLogConfiguration.listItemView\" \n      [tailView]=\"callLogConfiguration.tailView\" \n      [loadingIconURL]=\"callLogConfiguration.loadingIconURL\" [loadingStateView]=\"callLogConfiguration.loadingStateView\"\n      [callLogRequestBuilder]=\"callLogConfiguration.callLogRequestBuilder\"\n      [onItemClick]=\"callLogConfiguration.onItemClick!\" [onInfoClick]=\"callLogConfiguration.onInfoClick || onInfoClick! \"\n      [onError]=\"callLogConfiguration.onError!\" [listItemStyle]=\"callLogConfiguration.listItemStyle\"\n      [infoIconUrl]=\"callLogConfiguration.infoIconUrl\" [datePattern]=\"callLogConfiguration.datePattern\"\n      [dateSeparatorPattern]=\"callLogConfiguration.dateSeparatorPattern\"\n      [incomingAudioCallIconUrl]=\"callLogConfiguration.incomingAudioCallIconUrl\"\n      [incomingVideoCallIconUrl]=\"callLogConfiguration.incomingVideoCallIconUrl\"\n      [outgoingAudioCallIconUrl]=\"callLogConfiguration.outgoingAudioCallIconUrl\"\n      [outgoingVideoCallIconUrl]=\"callLogConfiguration.outgoingVideoCallIconUrl\"\n      [missedAudioCallIconUrl]=\"callLogConfiguration.missedAudioCallIconUrl\"\n      [missedVideoCallIconUrl]=\"callLogConfiguration.missedVideoCallIconUrl\"\n      [callLogsStyle]=\"callLogConfiguration.callLogsStyle\" [avatarStyle]=\"callLogConfiguration.avatarStyle\"\n      [hideSeparator]=\"callLogConfiguration.hideSeparator\"\n      [outgoingCallConfiguration]=\"callLogConfiguration.outgoingCallConfiguration\"></cometchat-call-logs>\n  </div>\n  <div class=\"cc-with-details__main\" [ngClass]=\"{mobile : isMobileView}\" *ngIf=\"activeCall && (user || group)\">\n    <!--call details Screen-->\n    <cometchat-call-log-details [user]=\"user!\" [group]=\"group!\" [call]=\"call\"\n      [backIconUrl]=\"computedCallLogDetailsConfig.backIconUrl\" [avatarStyle]=\"computedCallLogDetailsConfig.avatarStyle\"\n      [onBackClick]=\"computedCallLogDetailsConfig.onBackClick || onBackClick\"\n      [callLogHistoryConfiguration]=\"computedCallLogDetailsConfig.callLogHistoryConfiguration\"\n      [callLogParticipantsConfiguration]=\"computedCallLogDetailsConfig.callLogParticipantsConfiguration\"\n      [callLogRecordingsConfiguration]=\"computedCallLogDetailsConfig.callLogRecordingsConfiguration\"\n      [callLogDetailStyle]=\"computedCallLogDetailsConfig.callLogDetailsStyle\">\n    </cometchat-call-log-details>\n  </div>\n\n  <div class=\"cc-decorator__message--empty\" *ngIf=\"!user && !group\" [ngStyle]=\"emptyMessageStyle()\">\n    <cometchat-label [text]=\"messageText\" [labelStyle]=\"labelStyle\"></cometchat-label>\n  </div>"]}