@cometchat/chat-uikit-angular
Version:
Ready-to-use Chat UI Components for Angular (JavaScript/Web)
225 lines • 38.9 kB
JavaScript
import { Component, Input, ViewChild, } from "@angular/core";
import { DatePatterns, localize, States, TitleAlignment, } from "@cometchat/uikit-resources";
import * as i0 from "@angular/core";
import * as i1 from "@angular/common";
export class CometchatListComponent {
constructor() {
this.list = [];
this.searchText = localize("SEARCH");
this.searchIconURL = "assets/search.svg";
this.listStyle = {
height: "100%",
width: "100%",
};
this.searchPlaceholderText = "";
this.hideSearch = false;
this.hideError = false;
this.title = "";
this.titleAlignment = TitleAlignment.left;
this.state = States.loaded;
this.errorStateText = "";
this.emptyStateText = "";
this.loadingIconURL = "assets/Spinner.svg";
this.showSectionHeader = false;
this.sectionHeaderField = "name";
this.DateSeparatorPattern = DatePatterns.DayDate;
this.dateSeparatorStyle = {
height: "",
width: "",
};
this.states = States;
this.numberOfTopScroll = 0;
this.searchStyle = {};
this.iconStyle = {};
/**
* listening to bottom scroll using intersection observer
*/
this.ioBottom = () => {
const options = {
root: this.listScroll?.nativeElement,
rootMargin: "-100% 0px 100px 0px",
threshold: 0,
};
const callback = (entries) => {
if (entries[0].isIntersecting &&
this.onScrolledToBottom &&
this.list?.length > 0) {
this.onScrolledToBottom();
}
};
var observer = new IntersectionObserver(callback, options);
observer.observe(this.bottom?.nativeElement);
};
/**
* listening to top scroll using intersection observer
*/
this.ioTop = () => {
const options = {
root: this.listScroll?.nativeElement,
rootMargin: "200px 0px 0px 0px",
threshold: 1.0,
};
const callback = (entries) => {
if (entries[0].isIntersecting) {
this.numberOfTopScroll++;
if (this.onScrolledToTop && this.numberOfTopScroll > 1) {
this.onScrolledToTop();
}
}
};
var observer = new IntersectionObserver(callback, options);
// observer.observe(this.top.nativeElement);
};
this.searchEvent = (event) => {
this.searchText = event?.detail?.searchText;
if (this.onSearch) {
this.onSearch(this.searchText);
}
};
/**
* styling part
*/
this.chatsListStyle = () => {
return {
height: this.listStyle.height,
background: this.listStyle.background,
};
};
this.messageContainerStyle = () => {
return {
width: this.listStyle.width,
};
};
this.errorStyle = () => {
return {
textFont: this.listStyle.errorStateTextFont,
textColor: this.listStyle.errorStateTextColor,
};
};
this.emptyStyle = () => {
return {
textFont: this.listStyle.emptyStateTextFont,
textColor: this.listStyle.emptyStateTextColor,
};
};
this.wrapperStyle = () => {
return {
height: this.listStyle.height,
width: this.listStyle.width,
background: this.listStyle.background,
border: this.listStyle.border,
borderRadius: this.listStyle.borderRadius,
};
};
this.headerTitle = () => {
let postiton = this.titleAlignment == TitleAlignment.left
? { textAlign: "left" }
: { textAlign: "center" };
return {
font: this.listStyle.titleTextFont,
color: this.listStyle.titleTextColor,
...postiton,
};
};
this.sectionHeaderStyle = () => {
return {
font: this.listStyle?.sectionHeaderTextFont,
color: this.listStyle?.sectionHeaderTextColor,
};
};
this.headerStyle = () => {
return {
height: "fit-content",
marginBottom: "12px",
};
};
this.listStyles = () => {
return {
height: "100%",
};
};
}
ngOnInit() {
this.iconStyle = this.listStyle.loadingIconTint;
(this.searchStyle.searchTextFont = this.listStyle?.searchTextFont),
(this.searchStyle.searchTextColor = this.listStyle?.searchTextColor),
(this.searchStyle.placeholderTextFont =
this.listStyle?.searchPlaceholderTextFont),
(this.searchStyle.placeholderTextColor =
this.listStyle?.searchPlaceholderTextColor),
(this.searchStyle.searchIconTint = this.listStyle?.searchIconTint);
(this.searchStyle.background = this.listStyle?.searchBackground),
(this.searchStyle.borderRadius = this.listStyle.searchBorderRadius);
this.searchStyle.border = this.listStyle.searchBorder;
}
ngAfterViewInit() {
this.ioBottom();
}
ngOnChanges(changes) { }
}
CometchatListComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: CometchatListComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
CometchatListComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: CometchatListComponent, selector: "cometchat-list", inputs: { listItemView: "listItemView", onScrolledToBottom: "onScrolledToBottom", onScrolledToTop: "onScrolledToTop", list: "list", onSearch: "onSearch", getSectionHeader: "getSectionHeader", searchText: "searchText", searchIconURL: "searchIconURL", listStyle: "listStyle", searchPlaceholderText: "searchPlaceholderText", hideSearch: "hideSearch", hideError: "hideError", title: "title", titleAlignment: "titleAlignment", errorStateView: "errorStateView", loadingStateView: "loadingStateView", emptyStateView: "emptyStateView", state: "state", errorStateText: "errorStateText", emptyStateText: "emptyStateText", loadingIconURL: "loadingIconURL", showSectionHeader: "showSectionHeader", sectionHeaderField: "sectionHeaderField", DateSeparatorPattern: "DateSeparatorPattern", dateSeparatorStyle: "dateSeparatorStyle" }, viewQueries: [{ propertyName: "listScroll", first: true, predicate: ["listScroll"], descendants: true }, { propertyName: "bottom", first: true, predicate: ["bottom"], descendants: true }, { propertyName: "top", first: true, predicate: ["top"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"cc-list__wrapper\">\n <div class=\"list__header\" [ngStyle]=\"headerStyle()\">\n <div *ngIf=\"title\" class=\"list__title\" [ngStyle]=\"headerTitle()\"> {{title}}\n </div>\n <div class=\"cc-list__search-input\">\n <cometchat-search-input [searchInputStyle]=\"searchStyle\"\n [placeholderText]=\"searchPlaceholderText\" *ngIf=\"!hideSearch\"\n [searchIconURL]=\"searchIconURL\"\n (cc-search-changed)=\"searchEvent($event)\"></cometchat-search-input>\n </div>\n </div>\n <div class=\"cc-list\" #listScroll [ngStyle]=\"listStyles()\">\n <div class=\"list__top\" #top>\n </div>\n <div class=\"decorator__message\"\n *ngIf=\"state == states.loading || state == states.error || state == states.empty \"\n [ngStyle]=\"messageContainerStyle()\">\n <div class=\"loading__view\" *ngIf=\"state == states.loading\">\n <cometchat-loader [iconURL]=\"loadingIconURL\" [loaderStyle]=\"iconStyle\"\n *ngIf=\"!loadingStateView\">\n </cometchat-loader>\n <span class=\"custom__view--loading\" *ngIf=\"loadingStateView\">\n <ng-container *ngTemplateOutlet=\"loadingStateView\">\n </ng-container>\n </span>\n </div>\n <div class=\"error__view\" *ngIf=\"state == states.error && !hideError\">\n <cometchat-label [labelStyle]=\"errorStyle()\" *ngIf=\"!errorStateView\"\n [text]=\"errorStateText\">\n </cometchat-label>\n <span class=\"custom__view--error\" *ngIf=\"errorStateView\">\n <ng-container *ngTemplateOutlet=\"errorStateView\">\n </ng-container>\n </span>\n </div>\n <div class=\"empty__view\" *ngIf=\"state == states.empty\">\n <cometchat-label [labelStyle]=\"emptyStyle()\"\n *ngIf=\"state == states.empty && !emptyStateView\"\n [text]=\"emptyStateText\">\n </cometchat-label>\n <span class=\"custom__view--empty\" *ngIf=\"emptyStateView\">\n <ng-container *ngTemplateOutlet=\"emptyStateView\">\n </ng-container>\n </span>\n </div>\n </div>\n <div class=\"listitem__view\" *ngFor=\"let item of list; let i = index\">\n <div class=\"list__section\" *ngIf=\"showSectionHeader\">\n <div *ngIf=\"!getSectionHeader\">\n <div *ngIf=\"i > 0; else elseBlock\" class=\"section__separator\">\n <div *ngIf=\"\n list[i - 1][sectionHeaderField][0].toUpperCase() !==\n list[i][sectionHeaderField][0].toUpperCase()\n \" class=\"section__header\" [ngStyle]=\"sectionHeaderStyle()\">\n {{ list[i][sectionHeaderField][0].toUpperCase() }}\n </div>\n </div>\n <ng-template #elseBlock>\n <div class=\"section__header\" [ngStyle]=\"sectionHeaderStyle()\">\n {{\n list[i][sectionHeaderField][0].toUpperCase()\n }}\n </div>\n </ng-template>\n </div>\n <div *ngIf=\"getSectionHeader && getSectionHeader(item,i)\"\n [ngStyle]=\"sectionHeaderStyle()\">\n <cometchat-date [timestamp]=\"getSectionHeader(item,i)\"\n [pattern]=\"DateSeparatorPattern\" [dateStyle]=\"dateSeparatorStyle\">\n </cometchat-date>\n </div>\n\n </div>\n <ng-container\n *ngTemplateOutlet=\"listItemView;context:{ $implicit: item }\">\n </ng-container>\n </div>\n <div class=\"list__bottom\" #bottom>\n </div>\n </div>\n</div>\n", styles: [".cc-list{display:flex;flex-direction:column;width:100%;overflow-y:auto;overflow-x:hidden}.cc-list__wrapper{height:100%;width:100%;display:flex;flex-direction:column}.listitem__view{display:flex;flex-direction:column}.section__header{padding:4px}.list__title{width:90%;margin:4px 0;padding-left:8px}.user__section{padding:8px}.cc-list__search-input{height:-moz-fit-content;height:fit-content;margin:0 8px}.list__header{width:100%}.list__section{margin-left:8px}.decorator__message--loading{display:block;height:24px;width:24px;margin-right:30px}.decorator__message{margin:0;line-height:30px;word-wrap:break-word;padding:0 8px;width:100%;overflow:hidden;display:flex;align-items:center;justify-content:center;height:100%}.list__title{margin-bottom:8px}.cc-list::-webkit-scrollbar{background:transparent;width:8px}.cc-list::-webkit-scrollbar-thumb{background:#e8e5e5;border-radius:8px}.error__view,.empty__view{text-align:center;width:100%;text-overflow:ellipsis;text-wrap:balance}\n"], directives: [{ type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: CometchatListComponent, decorators: [{
type: Component,
args: [{ selector: "cometchat-list", template: "<div class=\"cc-list__wrapper\">\n <div class=\"list__header\" [ngStyle]=\"headerStyle()\">\n <div *ngIf=\"title\" class=\"list__title\" [ngStyle]=\"headerTitle()\"> {{title}}\n </div>\n <div class=\"cc-list__search-input\">\n <cometchat-search-input [searchInputStyle]=\"searchStyle\"\n [placeholderText]=\"searchPlaceholderText\" *ngIf=\"!hideSearch\"\n [searchIconURL]=\"searchIconURL\"\n (cc-search-changed)=\"searchEvent($event)\"></cometchat-search-input>\n </div>\n </div>\n <div class=\"cc-list\" #listScroll [ngStyle]=\"listStyles()\">\n <div class=\"list__top\" #top>\n </div>\n <div class=\"decorator__message\"\n *ngIf=\"state == states.loading || state == states.error || state == states.empty \"\n [ngStyle]=\"messageContainerStyle()\">\n <div class=\"loading__view\" *ngIf=\"state == states.loading\">\n <cometchat-loader [iconURL]=\"loadingIconURL\" [loaderStyle]=\"iconStyle\"\n *ngIf=\"!loadingStateView\">\n </cometchat-loader>\n <span class=\"custom__view--loading\" *ngIf=\"loadingStateView\">\n <ng-container *ngTemplateOutlet=\"loadingStateView\">\n </ng-container>\n </span>\n </div>\n <div class=\"error__view\" *ngIf=\"state == states.error && !hideError\">\n <cometchat-label [labelStyle]=\"errorStyle()\" *ngIf=\"!errorStateView\"\n [text]=\"errorStateText\">\n </cometchat-label>\n <span class=\"custom__view--error\" *ngIf=\"errorStateView\">\n <ng-container *ngTemplateOutlet=\"errorStateView\">\n </ng-container>\n </span>\n </div>\n <div class=\"empty__view\" *ngIf=\"state == states.empty\">\n <cometchat-label [labelStyle]=\"emptyStyle()\"\n *ngIf=\"state == states.empty && !emptyStateView\"\n [text]=\"emptyStateText\">\n </cometchat-label>\n <span class=\"custom__view--empty\" *ngIf=\"emptyStateView\">\n <ng-container *ngTemplateOutlet=\"emptyStateView\">\n </ng-container>\n </span>\n </div>\n </div>\n <div class=\"listitem__view\" *ngFor=\"let item of list; let i = index\">\n <div class=\"list__section\" *ngIf=\"showSectionHeader\">\n <div *ngIf=\"!getSectionHeader\">\n <div *ngIf=\"i > 0; else elseBlock\" class=\"section__separator\">\n <div *ngIf=\"\n list[i - 1][sectionHeaderField][0].toUpperCase() !==\n list[i][sectionHeaderField][0].toUpperCase()\n \" class=\"section__header\" [ngStyle]=\"sectionHeaderStyle()\">\n {{ list[i][sectionHeaderField][0].toUpperCase() }}\n </div>\n </div>\n <ng-template #elseBlock>\n <div class=\"section__header\" [ngStyle]=\"sectionHeaderStyle()\">\n {{\n list[i][sectionHeaderField][0].toUpperCase()\n }}\n </div>\n </ng-template>\n </div>\n <div *ngIf=\"getSectionHeader && getSectionHeader(item,i)\"\n [ngStyle]=\"sectionHeaderStyle()\">\n <cometchat-date [timestamp]=\"getSectionHeader(item,i)\"\n [pattern]=\"DateSeparatorPattern\" [dateStyle]=\"dateSeparatorStyle\">\n </cometchat-date>\n </div>\n\n </div>\n <ng-container\n *ngTemplateOutlet=\"listItemView;context:{ $implicit: item }\">\n </ng-container>\n </div>\n <div class=\"list__bottom\" #bottom>\n </div>\n </div>\n</div>\n", styles: [".cc-list{display:flex;flex-direction:column;width:100%;overflow-y:auto;overflow-x:hidden}.cc-list__wrapper{height:100%;width:100%;display:flex;flex-direction:column}.listitem__view{display:flex;flex-direction:column}.section__header{padding:4px}.list__title{width:90%;margin:4px 0;padding-left:8px}.user__section{padding:8px}.cc-list__search-input{height:-moz-fit-content;height:fit-content;margin:0 8px}.list__header{width:100%}.list__section{margin-left:8px}.decorator__message--loading{display:block;height:24px;width:24px;margin-right:30px}.decorator__message{margin:0;line-height:30px;word-wrap:break-word;padding:0 8px;width:100%;overflow:hidden;display:flex;align-items:center;justify-content:center;height:100%}.list__title{margin-bottom:8px}.cc-list::-webkit-scrollbar{background:transparent;width:8px}.cc-list::-webkit-scrollbar-thumb{background:#e8e5e5;border-radius:8px}.error__view,.empty__view{text-align:center;width:100%;text-overflow:ellipsis;text-wrap:balance}\n"] }]
}], ctorParameters: function () { return []; }, propDecorators: { listScroll: [{
type: ViewChild,
args: ["listScroll", { static: false }]
}], bottom: [{
type: ViewChild,
args: ["bottom", { static: false }]
}], top: [{
type: ViewChild,
args: ["top", { static: false }]
}], listItemView: [{
type: Input
}], onScrolledToBottom: [{
type: Input
}], onScrolledToTop: [{
type: Input
}], list: [{
type: Input
}], onSearch: [{
type: Input
}], getSectionHeader: [{
type: Input
}], searchText: [{
type: Input
}], searchIconURL: [{
type: Input
}], listStyle: [{
type: Input
}], searchPlaceholderText: [{
type: Input
}], hideSearch: [{
type: Input
}], hideError: [{
type: Input
}], title: [{
type: Input
}], titleAlignment: [{
type: Input
}], errorStateView: [{
type: Input
}], loadingStateView: [{
type: Input
}], emptyStateView: [{
type: Input
}], state: [{
type: Input
}], errorStateText: [{
type: Input
}], emptyStateText: [{
type: Input
}], loadingIconURL: [{
type: Input
}], showSectionHeader: [{
type: Input
}], sectionHeaderField: [{
type: Input
}], DateSeparatorPattern: [{
type: Input
}], dateSeparatorStyle: [{
type: Input
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cometchat-list.component.js","sourceRoot":"","sources":["../../../../projects/chat-uikit-angular/src/CometChatList/cometchat-list.component.ts","../../../../projects/chat-uikit-angular/src/CometChatList/cometchat-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ElementRef,\n  Input,\n  OnInit,\n  SimpleChanges,\n  TemplateRef,\n  ViewChild,\n} from \"@angular/core\";\nimport { DateStyle, SearchInputStyle } from \"@cometchat/uikit-elements\";\nimport {\n  ListStyle,\n  MessageListStyle,\n  UsersStyle,\n} from \"@cometchat/uikit-shared\";\nimport {\n  DatePatterns,\n  localize,\n  States,\n  TitleAlignment,\n} from \"@cometchat/uikit-resources\";\n@Component({\n  selector: \"cometchat-list\",\n  templateUrl: \"./cometchat-list.component.html\",\n  styleUrls: [\"./cometchat-list.component.scss\"],\n})\nexport class CometchatListComponent implements OnInit {\n  @ViewChild(\"listScroll\", { static: false }) listScroll!: ElementRef;\n  @ViewChild(\"bottom\", { static: false }) bottom!: ElementRef;\n  @ViewChild(\"top\", { static: false }) top!: ElementRef;\n  @Input() listItemView!: TemplateRef<any>; //custom view\n  @Input() onScrolledToBottom!: () => void;\n  @Input() onScrolledToTop!: () => void;\n  @Input() list: any = [];\n  @Input() onSearch!: (text: string) => void;\n  @Input() getSectionHeader!: (call: any, index: any) => void;\n  @Input() searchText: string = localize(\"SEARCH\");\n  @Input() searchIconURL: String = \"assets/search.svg\";\n  @Input() listStyle: ListStyle = {\n    height: \"100%\",\n    width: \"100%\",\n  };\n  @Input() searchPlaceholderText: String = \"\";\n  @Input() hideSearch: boolean = false;\n  @Input() hideError: boolean = false;\n  @Input() title: string = \"\";\n  @Input() titleAlignment: TitleAlignment = TitleAlignment.left;\n  @Input() errorStateView!: TemplateRef<any>;\n  @Input() loadingStateView!: TemplateRef<any>;\n  @Input() emptyStateView!: TemplateRef<any>;\n  @Input() state: States = States.loaded;\n  @Input() errorStateText: string = \"\";\n  @Input() emptyStateText: string = \"\";\n  @Input() loadingIconURL: string = \"assets/Spinner.svg\";\n  @Input() showSectionHeader: boolean = false;\n  @Input() sectionHeaderField: string = \"name\";\n  @Input() DateSeparatorPattern: DatePatterns = DatePatterns.DayDate;\n  @Input() dateSeparatorStyle: DateStyle = {\n    height: \"\",\n    width: \"\",\n  };\n  public states: typeof States = States;\n  public numberOfTopScroll: number = 0;\n  searchStyle: SearchInputStyle = {};\n  iconStyle: any = {};\n  constructor() { }\n  ngOnInit(): void {\n    this.iconStyle = this.listStyle.loadingIconTint;\n    (this.searchStyle.searchTextFont = this.listStyle?.searchTextFont),\n      (this.searchStyle.searchTextColor = this.listStyle?.searchTextColor),\n      (this.searchStyle.placeholderTextFont =\n        this.listStyle?.searchPlaceholderTextFont),\n      (this.searchStyle.placeholderTextColor =\n        this.listStyle?.searchPlaceholderTextColor),\n      (this.searchStyle.searchIconTint = this.listStyle?.searchIconTint);\n    (this.searchStyle.background = this.listStyle?.searchBackground),\n      (this.searchStyle.borderRadius = this.listStyle.searchBorderRadius);\n    this.searchStyle.border = this.listStyle.searchBorder;\n  }\n  ngAfterViewInit() {\n    this.ioBottom();\n  }\n  ngOnChanges(changes: SimpleChanges): void { }\n  /**\n   * listening to bottom scroll using intersection observer\n   */\n  ioBottom = () => {\n    const options = {\n      root: this.listScroll?.nativeElement,\n      rootMargin: \"-100% 0px 100px 0px\",\n      threshold: 0,\n    };\n    const callback = (entries: any) => {\n      if (\n        entries[0].isIntersecting &&\n        this.onScrolledToBottom &&\n        this.list?.length > 0\n      ) {\n        this.onScrolledToBottom();\n      }\n    };\n    var observer: IntersectionObserver = new IntersectionObserver(\n      callback,\n      options\n    );\n    observer.observe(this.bottom?.nativeElement);\n  };\n  /**\n   * listening to top scroll using intersection observer\n   */\n  ioTop = () => {\n    const options = {\n      root: this.listScroll?.nativeElement,\n      rootMargin: \"200px 0px 0px 0px\",\n      threshold: 1.0,\n    };\n    const callback = (entries: any) => {\n      if (entries[0].isIntersecting) {\n        this.numberOfTopScroll++;\n        if (this.onScrolledToTop && this.numberOfTopScroll > 1) {\n          this.onScrolledToTop();\n        }\n      }\n    };\n    var observer: IntersectionObserver = new IntersectionObserver(\n      callback,\n      options\n    );\n    // observer.observe(this.top.nativeElement);\n  };\n  searchEvent = (event: any) => {\n    this.searchText = event?.detail?.searchText;\n    if (this.onSearch) {\n      this.onSearch(this.searchText);\n    }\n  };\n  /**\n   * styling part\n   */\n  chatsListStyle = () => {\n    return {\n      height: this.listStyle.height,\n      background: this.listStyle.background,\n    };\n  };\n  messageContainerStyle = () => {\n    return {\n      width: this.listStyle.width,\n    };\n  };\n  errorStyle = () => {\n    return {\n      textFont: this.listStyle.errorStateTextFont,\n      textColor: this.listStyle.errorStateTextColor,\n    };\n  };\n  emptyStyle = () => {\n    return {\n      textFont: this.listStyle.emptyStateTextFont,\n      textColor: this.listStyle.emptyStateTextColor,\n    };\n  };\n  wrapperStyle = () => {\n    return {\n      height: this.listStyle.height,\n      width: this.listStyle.width,\n      background: this.listStyle.background,\n      border: this.listStyle.border,\n      borderRadius: this.listStyle.borderRadius,\n    };\n  };\n  headerTitle = () => {\n    let postiton: any =\n      this.titleAlignment == TitleAlignment.left\n        ? { textAlign: \"left\" }\n        : { textAlign: \"center\" };\n    return {\n      font: this.listStyle.titleTextFont,\n      color: this.listStyle.titleTextColor,\n      ...postiton,\n    };\n  };\n  sectionHeaderStyle = () => {\n    return {\n      font: this.listStyle?.sectionHeaderTextFont,\n      color: this.listStyle?.sectionHeaderTextColor,\n    };\n  };\n  headerStyle = () => {\n    return {\n      height: \"fit-content\",\n      marginBottom: \"12px\",\n    };\n  };\n  listStyles = () => {\n    return {\n      height: \"100%\",\n    };\n  };\n}\n","<div class=\"cc-list__wrapper\">\n  <div class=\"list__header\" [ngStyle]=\"headerStyle()\">\n    <div *ngIf=\"title\" class=\"list__title\" [ngStyle]=\"headerTitle()\"> {{title}}\n    </div>\n    <div class=\"cc-list__search-input\">\n      <cometchat-search-input [searchInputStyle]=\"searchStyle\"\n        [placeholderText]=\"searchPlaceholderText\" *ngIf=\"!hideSearch\"\n        [searchIconURL]=\"searchIconURL\"\n        (cc-search-changed)=\"searchEvent($event)\"></cometchat-search-input>\n    </div>\n  </div>\n  <div class=\"cc-list\" #listScroll [ngStyle]=\"listStyles()\">\n    <div class=\"list__top\" #top>\n    </div>\n    <div class=\"decorator__message\"\n      *ngIf=\"state == states.loading || state == states.error  || state == states.empty \"\n      [ngStyle]=\"messageContainerStyle()\">\n      <div class=\"loading__view\" *ngIf=\"state == states.loading\">\n        <cometchat-loader [iconURL]=\"loadingIconURL\" [loaderStyle]=\"iconStyle\"\n          *ngIf=\"!loadingStateView\">\n        </cometchat-loader>\n        <span class=\"custom__view--loading\" *ngIf=\"loadingStateView\">\n          <ng-container *ngTemplateOutlet=\"loadingStateView\">\n          </ng-container>\n        </span>\n      </div>\n      <div class=\"error__view\" *ngIf=\"state == states.error  && !hideError\">\n        <cometchat-label [labelStyle]=\"errorStyle()\" *ngIf=\"!errorStateView\"\n          [text]=\"errorStateText\">\n        </cometchat-label>\n        <span class=\"custom__view--error\" *ngIf=\"errorStateView\">\n          <ng-container *ngTemplateOutlet=\"errorStateView\">\n          </ng-container>\n        </span>\n      </div>\n      <div class=\"empty__view\" *ngIf=\"state == states.empty\">\n        <cometchat-label [labelStyle]=\"emptyStyle()\"\n          *ngIf=\"state == states.empty && !emptyStateView\"\n          [text]=\"emptyStateText\">\n        </cometchat-label>\n        <span class=\"custom__view--empty\" *ngIf=\"emptyStateView\">\n          <ng-container *ngTemplateOutlet=\"emptyStateView\">\n          </ng-container>\n        </span>\n      </div>\n    </div>\n    <div class=\"listitem__view\" *ngFor=\"let item of list; let i = index\">\n      <div class=\"list__section\" *ngIf=\"showSectionHeader\">\n        <div *ngIf=\"!getSectionHeader\">\n          <div *ngIf=\"i > 0; else elseBlock\" class=\"section__separator\">\n            <div *ngIf=\"\n                list[i - 1][sectionHeaderField][0].toUpperCase() !==\n                list[i][sectionHeaderField][0].toUpperCase()\n              \" class=\"section__header\" [ngStyle]=\"sectionHeaderStyle()\">\n              {{ list[i][sectionHeaderField][0].toUpperCase() }}\n            </div>\n          </div>\n          <ng-template #elseBlock>\n            <div class=\"section__header\" [ngStyle]=\"sectionHeaderStyle()\">\n              {{\n              list[i][sectionHeaderField][0].toUpperCase()\n              }}\n            </div>\n          </ng-template>\n        </div>\n        <div *ngIf=\"getSectionHeader && getSectionHeader(item,i)\"\n          [ngStyle]=\"sectionHeaderStyle()\">\n          <cometchat-date [timestamp]=\"getSectionHeader(item,i)\"\n            [pattern]=\"DateSeparatorPattern\" [dateStyle]=\"dateSeparatorStyle\">\n          </cometchat-date>\n        </div>\n\n      </div>\n      <ng-container\n        *ngTemplateOutlet=\"listItemView;context:{ $implicit: item }\">\n      </ng-container>\n    </div>\n    <div class=\"list__bottom\" #bottom>\n    </div>\n  </div>\n</div>\n"]}