UNPKG

@linid-dm/directory-manager-client-core

Version:

Core package by providing a set of angular components for the Directory Manager app.

129 lines 35.8 kB
/** * Copyright (C) 2020-2024 Linagora * * This program is free software: you can redistribute it and/or modify it under * the terms of the GNU Affero General Public License as published by the Free * Software Foundation, either version 3 of the License, or (at your option) any * later version, provided you comply with the Additional Terms applicable for * LinID Directory Manager software by LINAGORA pursuant to Section 7 of the GNU * Affero General Public License, subsections (b), (c), and (e), pursuant to * which these Appropriate Legal Notices must notably (i) retain the display of * the "LinID™" trademark/logo at the top of the interface window, the display * of the “You are using the Open Source and free version of LinID™, powered by * Linagora © 2009–2013. Contribute to LinID R&D by subscribing to an Enterprise * offer!” infobox and in the e-mails sent with the Program, notice appended to * any type of outbound messages (e.g. e-mail and meeting requests) as well as * in the LinID Directory Manager user interface, (ii) retain all hypertext * links between LinID Directory Manager and https://linid.org/, as well as * between LINAGORA and LINAGORA.com, and (iii) refrain from infringing LINAGORA * intellectual property rights over its trademarks and commercial brands. Other * Additional Terms apply, see <http://www.linagora.com/licenses/> for more * details. * * This program is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS * FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more * details. * * You should have received a copy of the GNU Affero General Public License and * its applicable Additional Terms for LinID Directory Manager along with this * program. If not, see <http://www.gnu.org/licenses/> for the GNU Affero * General Public License version 3 and <http://www.linagora.com/licenses/> for * the Additional Terms applicable to the LinID Directory Manager software. */ import { trigger } from '@angular/animations'; import { Component, EventEmitter, Input, Output, ViewChild, } from '@angular/core'; import { Data, fadeTree, filterList } from '../../shared'; import * as i0 from "@angular/core"; import * as i1 from "@ngxs/store"; import * as i2 from "@angular/common"; import * as i3 from "@angular/router"; import * as i4 from "@angular/flex-layout/flex"; import * as i5 from "@angular/flex-layout/extended"; import * as i6 from "@angular/material/list"; import * as i7 from "../../shared/directives/color-search-letters.directive"; export class GenericListComponent { set initialDataList(initialDataList) { if (initialDataList) { this._initialDataList = initialDataList; this.updateDataListOnSetAndOnSearch(); } } get initialDataList() { return this._initialDataList; } set search(search) { this._search = search; this.updateDataListOnSetAndOnSearch(); } get search() { return this._search; } constructor(_store$, _el) { this._store$ = _store$; this._el = _el; this.isSelectOnlyModeEnabled = false; this.selectedItem = new EventEmitter(); this._initialDataList = []; this.elementRef = this._el; } getLink(item) { return item.link.toLowerCase(); } getActiveItem(item) { this.activeItem = item; this.selectedItem.emit(this.activeItem); } setEntryIdsInStore(ids) { this._store$.dispatch(new Data.SetSelectedEntryIds({ ids })); } updateDataListOnSetAndOnSearch() { if (!this.isSelectOnlyModeEnabled && this.search !== '') { this.filteredDataList = filterList(this.initialDataList, this._search); this.dataList = [...this.filteredDataList]; } else { this.dataList = [...this.initialDataList]; } } getItemCssClass(itemId) { if (!this.isSelectOnlyModeEnabled && itemId === this.selectedItemId) { return 'active-item-link'; } else if (this.isSelectOnlyModeEnabled) { if (itemId === this.selectedItemId) { return 'disabled-div'; } else if (this.activeItem && this.activeItem.ids.id === itemId) { return 'active-item-link'; } } } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: GenericListComponent, deps: [{ token: i1.Store }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.4", type: GenericListComponent, selector: "dm-generic-list", inputs: { selectedItemId: "selectedItemId", initialDataList: "initialDataList", search: "search", isSelectOnlyModeEnabled: "isSelectOnlyModeEnabled", isLargeScreen: "isLargeScreen", actionsMenuTemplate: "actionsMenuTemplate" }, outputs: { selectedItem: "selectedItem" }, viewQueries: [{ propertyName: "divMatList", first: true, predicate: ["divMatList"], descendants: true }, { propertyName: "ulGenericList", first: true, predicate: ["ulGenericList"], descendants: true }], ngImport: i0, template: "<!-- Copyright (C) 2020-2024 Linagora\n\nThis program is free software: you can redistribute it and/or modify it under\nthe terms of the GNU Affero General Public License as published by the Free\nSoftware Foundation, either version 3 of the License, or (at your option) any\nlater version, provided you comply with the Additional Terms applicable for\nLinID Directory Manager software by LINAGORA pursuant to Section 7 of the GNU\nAffero General Public License, subsections (b), (c), and (e), pursuant to\nwhich these Appropriate Legal Notices must notably (i) retain the display of\nthe \"LinID\u2122\" trademark/logo at the top of the interface window, the display\nof the \u201CYou are using the Open Source and free version of LinID\u2122, powered by\nLinagora \u00A9 2009\u20132013. Contribute to LinID R&D by subscribing to an Enterprise\noffer!\u201D infobox and in the e-mails sent with the Program, notice appended to\nany type of outbound messages (e.g. e-mail and meeting requests) as well as\nin the LinID Directory Manager user interface, (ii) retain all hypertext\nlinks between LinID Directory Manager and https://linid.org/, as well as\nbetween LINAGORA and LINAGORA.com, and (iii) refrain from infringing LINAGORA\nintellectual property rights over its trademarks and commercial brands. Other\nAdditional Terms apply, see <http://www.linagora.com/licenses/> for more\ndetails.\n\nThis program is distributed in the hope that it will be useful, but WITHOUT\nANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS\nFOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more\ndetails.\n\nYou should have received a copy of the GNU Affero General Public License and\nits applicable Additional Terms for LinID Directory Manager along with this\nprogram. If not, see <http://www.gnu.org/licenses/> for the GNU Affero\nGeneral Public License version 3 and <http://www.linagora.com/licenses/> for\nthe Additional Terms applicable to the LinID Directory Manager software. -->\n\n<div\n [ngClass]=\"\n isSelectOnlyModeEnabled\n ? 'div-mat-list-dialog'\n : isLargeScreen\n ? 'div-mat-list-lg-screen'\n : 'div-mat-list-sm-screen'\n \"\n class=\"div-generic-list\"\n #divMatList\n>\n <mat-nav-list>\n <nav role=\"navigation\">\n <ul class=\"gnc-list\" #ulGenericList>\n <li\n mat-list-item\n fxLayout=\"row\"\n *ngFor=\"let data of dataList\"\n class=\"gnc-list-item\"\n >\n <a\n fxFlex\n draggable=\"false\"\n disableRipple=\"true\"\n [routerLink]=\"!isSelectOnlyModeEnabled ? [getLink(data)] : []\"\n (click)=\"\n isSelectOnlyModeEnabled && data.ids.id !== selectedItemId\n ? getActiveItem(data)\n : !isSelectOnlyModeEnabled\n ? setEntryIdsInStore(data.ids)\n : null\n \"\n [title]=\"data.name\"\n [id]=\"data.ids.externalId\"\n [ngClass]=\"getItemCssClass(data.ids.id)\"\n class=\"ldap-item\"\n >\n <button [title]=\"data.name\" class=\"btn-item\">\n <span\n appColorSearchedLetters\n [name]=\"data.name\"\n [title]=\"data.name\"\n [search]=\"search\"\n classToApply=\"highlight\"\n id=\"{{ data.ids.id }}\"\n class=\"ldap-item-name ellipsis\"\n ></span>\n </button>\n </a>\n <div\n *ngIf=\"!isSelectOnlyModeEnabled\"\n (click)=\"$event.preventDefault(); $event.stopPropagation()\"\n class=\"ellipsis-menu\"\n >\n <ng-container\n [ngTemplateOutlet]=\"actionsMenuTemplate\"\n [ngTemplateOutletContext]=\"{\n data\n }\"\n ></ng-container>\n </div>\n </li>\n </ul>\n </nav>\n </mat-nav-list>\n</div>\n", styles: ["@charset \"UTF-8\";:host{min-height:0px}.gnc-list-item{min-height:40px;height:40px;outline:none;border:none;display:block}.btn-item{text-align:left;height:100%;width:100%;background:transparent;outline:none;border:none;display:flex;align-items:center}.ldap-item{overflow:hidden;text-decoration:none}.ldap-item-name:after{display:block;content:attr(title);font-weight:700;height:0;overflow:hidden;visibility:hidden}div.div-generic-list{position:relative;overflow:auto;height:100%}div.div-generic-list mat-nav-list{padding:10px 10px 16px}div.div-generic-list a.ldap-item:before{content:\"\";min-height:40px;height:40px;position:absolute;left:0;right:0;transition:all .2s ease}div.div-generic-list a.ldap-item:hover:before{background-color:#0000000a}div.div-generic-list a.active-item-link:before{content:\"\";box-shadow:inset 4px 0;background-color:#0000000a;min-height:40px;height:40px;position:absolute;left:0;right:0}div.div-mat-list-lg-screen a.active-item-link:before,div.div-mat-list-sm-screen a.active-item-link:before{z-index:-1}.gnc-list{width:100%}.active-item-link,.gnc-list-item:hover{cursor:pointer}.active-item-link button,.active-item-link span,.active-item-link mat-icon,.gnc-list-item:hover button,.gnc-list-item:hover span,.gnc-list-item:hover mat-icon{cursor:pointer}.disabled-div{pointer-events:none;opacity:.4}.div-add-button{margin-top:25px;padding-right:5px}.div-mat-list-lg-screen{width:fit-content;min-width:290px;max-width:474px}.div-mat-list-sm-screen{width:290px;min-width:290px;max-width:290px}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i3.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "directive", type: i4.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { kind: "directive", type: i4.DefaultFlexDirective, selector: " [fxFlex], [fxFlex.xs], [fxFlex.sm], [fxFlex.md], [fxFlex.lg], [fxFlex.xl], [fxFlex.lt-sm], [fxFlex.lt-md], [fxFlex.lt-lg], [fxFlex.lt-xl], [fxFlex.gt-xs], [fxFlex.gt-sm], [fxFlex.gt-md], [fxFlex.gt-lg]", inputs: ["fxFlex", "fxFlex.xs", "fxFlex.sm", "fxFlex.md", "fxFlex.lg", "fxFlex.xl", "fxFlex.lt-sm", "fxFlex.lt-md", "fxFlex.lt-lg", "fxFlex.lt-xl", "fxFlex.gt-xs", "fxFlex.gt-sm", "fxFlex.gt-md", "fxFlex.gt-lg"] }, { kind: "directive", type: i5.DefaultClassDirective, selector: " [ngClass], [ngClass.xs], [ngClass.sm], [ngClass.md], [ngClass.lg], [ngClass.xl], [ngClass.lt-sm], [ngClass.lt-md], [ngClass.lt-lg], [ngClass.lt-xl], [ngClass.gt-xs], [ngClass.gt-sm], [ngClass.gt-md], [ngClass.gt-lg]", inputs: ["ngClass", "ngClass.xs", "ngClass.sm", "ngClass.md", "ngClass.lg", "ngClass.xl", "ngClass.lt-sm", "ngClass.lt-md", "ngClass.lt-lg", "ngClass.lt-xl", "ngClass.gt-xs", "ngClass.gt-sm", "ngClass.gt-md", "ngClass.gt-lg"] }, { kind: "component", type: i6.MatNavList, selector: "mat-nav-list", exportAs: ["matNavList"] }, { kind: "directive", type: i7.ColorSearchedLettersDirective, selector: "[appColorSearchedLetters]", inputs: ["search", "name", "isFilteringOnExternalId", "nodeIds", "classToApply", "nodesMatchingSearchClass", "isAdvancedSearchActivated", "nodesIdsMatchingAdvancedSearch"] }], animations: [trigger('fadeTree', fadeTree(':enter'))] }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: GenericListComponent, decorators: [{ type: Component, args: [{ selector: 'dm-generic-list', animations: [trigger('fadeTree', fadeTree(':enter'))], template: "<!-- Copyright (C) 2020-2024 Linagora\n\nThis program is free software: you can redistribute it and/or modify it under\nthe terms of the GNU Affero General Public License as published by the Free\nSoftware Foundation, either version 3 of the License, or (at your option) any\nlater version, provided you comply with the Additional Terms applicable for\nLinID Directory Manager software by LINAGORA pursuant to Section 7 of the GNU\nAffero General Public License, subsections (b), (c), and (e), pursuant to\nwhich these Appropriate Legal Notices must notably (i) retain the display of\nthe \"LinID\u2122\" trademark/logo at the top of the interface window, the display\nof the \u201CYou are using the Open Source and free version of LinID\u2122, powered by\nLinagora \u00A9 2009\u20132013. Contribute to LinID R&D by subscribing to an Enterprise\noffer!\u201D infobox and in the e-mails sent with the Program, notice appended to\nany type of outbound messages (e.g. e-mail and meeting requests) as well as\nin the LinID Directory Manager user interface, (ii) retain all hypertext\nlinks between LinID Directory Manager and https://linid.org/, as well as\nbetween LINAGORA and LINAGORA.com, and (iii) refrain from infringing LINAGORA\nintellectual property rights over its trademarks and commercial brands. Other\nAdditional Terms apply, see <http://www.linagora.com/licenses/> for more\ndetails.\n\nThis program is distributed in the hope that it will be useful, but WITHOUT\nANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS\nFOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more\ndetails.\n\nYou should have received a copy of the GNU Affero General Public License and\nits applicable Additional Terms for LinID Directory Manager along with this\nprogram. If not, see <http://www.gnu.org/licenses/> for the GNU Affero\nGeneral Public License version 3 and <http://www.linagora.com/licenses/> for\nthe Additional Terms applicable to the LinID Directory Manager software. -->\n\n<div\n [ngClass]=\"\n isSelectOnlyModeEnabled\n ? 'div-mat-list-dialog'\n : isLargeScreen\n ? 'div-mat-list-lg-screen'\n : 'div-mat-list-sm-screen'\n \"\n class=\"div-generic-list\"\n #divMatList\n>\n <mat-nav-list>\n <nav role=\"navigation\">\n <ul class=\"gnc-list\" #ulGenericList>\n <li\n mat-list-item\n fxLayout=\"row\"\n *ngFor=\"let data of dataList\"\n class=\"gnc-list-item\"\n >\n <a\n fxFlex\n draggable=\"false\"\n disableRipple=\"true\"\n [routerLink]=\"!isSelectOnlyModeEnabled ? [getLink(data)] : []\"\n (click)=\"\n isSelectOnlyModeEnabled && data.ids.id !== selectedItemId\n ? getActiveItem(data)\n : !isSelectOnlyModeEnabled\n ? setEntryIdsInStore(data.ids)\n : null\n \"\n [title]=\"data.name\"\n [id]=\"data.ids.externalId\"\n [ngClass]=\"getItemCssClass(data.ids.id)\"\n class=\"ldap-item\"\n >\n <button [title]=\"data.name\" class=\"btn-item\">\n <span\n appColorSearchedLetters\n [name]=\"data.name\"\n [title]=\"data.name\"\n [search]=\"search\"\n classToApply=\"highlight\"\n id=\"{{ data.ids.id }}\"\n class=\"ldap-item-name ellipsis\"\n ></span>\n </button>\n </a>\n <div\n *ngIf=\"!isSelectOnlyModeEnabled\"\n (click)=\"$event.preventDefault(); $event.stopPropagation()\"\n class=\"ellipsis-menu\"\n >\n <ng-container\n [ngTemplateOutlet]=\"actionsMenuTemplate\"\n [ngTemplateOutletContext]=\"{\n data\n }\"\n ></ng-container>\n </div>\n </li>\n </ul>\n </nav>\n </mat-nav-list>\n</div>\n", styles: ["@charset \"UTF-8\";:host{min-height:0px}.gnc-list-item{min-height:40px;height:40px;outline:none;border:none;display:block}.btn-item{text-align:left;height:100%;width:100%;background:transparent;outline:none;border:none;display:flex;align-items:center}.ldap-item{overflow:hidden;text-decoration:none}.ldap-item-name:after{display:block;content:attr(title);font-weight:700;height:0;overflow:hidden;visibility:hidden}div.div-generic-list{position:relative;overflow:auto;height:100%}div.div-generic-list mat-nav-list{padding:10px 10px 16px}div.div-generic-list a.ldap-item:before{content:\"\";min-height:40px;height:40px;position:absolute;left:0;right:0;transition:all .2s ease}div.div-generic-list a.ldap-item:hover:before{background-color:#0000000a}div.div-generic-list a.active-item-link:before{content:\"\";box-shadow:inset 4px 0;background-color:#0000000a;min-height:40px;height:40px;position:absolute;left:0;right:0}div.div-mat-list-lg-screen a.active-item-link:before,div.div-mat-list-sm-screen a.active-item-link:before{z-index:-1}.gnc-list{width:100%}.active-item-link,.gnc-list-item:hover{cursor:pointer}.active-item-link button,.active-item-link span,.active-item-link mat-icon,.gnc-list-item:hover button,.gnc-list-item:hover span,.gnc-list-item:hover mat-icon{cursor:pointer}.disabled-div{pointer-events:none;opacity:.4}.div-add-button{margin-top:25px;padding-right:5px}.div-mat-list-lg-screen{width:fit-content;min-width:290px;max-width:474px}.div-mat-list-sm-screen{width:290px;min-width:290px;max-width:290px}\n"] }] }], ctorParameters: () => [{ type: i1.Store }, { type: i0.ElementRef }], propDecorators: { divMatList: [{ type: ViewChild, args: ['divMatList'] }], ulGenericList: [{ type: ViewChild, args: ['ulGenericList'] }], selectedItemId: [{ type: Input }], initialDataList: [{ type: Input }], search: [{ type: Input }], isSelectOnlyModeEnabled: [{ type: Input }], isLargeScreen: [{ type: Input }], actionsMenuTemplate: [{ type: Input }], selectedItem: [{ type: Output }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"generic-list.component.js","sourceRoot":"","sources":["../../../../../../../../packages/libs/client-core/src/lib/feature/generic-list/generic-list.component.ts","../../../../../../../../packages/libs/client-core/src/lib/feature/generic-list/generic-list.component.html"],"names":[],"mappings":"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","sourcesContent":["/**\n * Copyright (C) 2020-2024 Linagora\n *\n * This program is free software: you can redistribute it and/or modify it under\n * the terms of the GNU Affero General Public License as published by the Free\n * Software Foundation, either version 3 of the License, or (at your option) any\n * later version, provided you comply with the Additional Terms applicable for\n * LinID Directory Manager software by LINAGORA pursuant to Section 7 of the GNU\n * Affero General Public License, subsections (b), (c), and (e), pursuant to\n * which these Appropriate Legal Notices must notably (i) retain the display of\n * the \"LinID™\" trademark/logo at the top of the interface window, the display\n * of the “You are using the Open Source and free version of LinID™, powered by\n * Linagora © 2009–2013. Contribute to LinID R&D by subscribing to an Enterprise\n * offer!” infobox and in the e-mails sent with the Program, notice appended to\n * any type of outbound messages (e.g. e-mail and meeting requests) as well as\n * in the LinID Directory Manager user interface, (ii) retain all hypertext\n * links between LinID Directory Manager and https://linid.org/, as well as\n * between LINAGORA and LINAGORA.com, and (iii) refrain from infringing LINAGORA\n * intellectual property rights over its trademarks and commercial brands. Other\n * Additional Terms apply, see <http://www.linagora.com/licenses/> for more\n * details.\n *\n * This program is distributed in the hope that it will be useful, but WITHOUT\n * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS\n * FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more\n * details.\n *\n * You should have received a copy of the GNU Affero General Public License and\n * its applicable Additional Terms for LinID Directory Manager along with this\n * program. If not, see <http://www.gnu.org/licenses/> for the GNU Affero\n * General Public License version 3 and <http://www.linagora.com/licenses/> for\n * the Additional Terms applicable to the LinID Directory Manager software.\n */\n\nimport { trigger } from '@angular/animations';\nimport {\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  Output,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core';\nimport { Store } from '@ngxs/store';\nimport { Data, IDataItem, IEntryIds, fadeTree, filterList } from '../../shared';\n@Component({\n  selector: 'dm-generic-list',\n  templateUrl: './generic-list.component.html',\n  styleUrls: ['./generic-list.component.scss'],\n  animations: [trigger('fadeTree', fadeTree(':enter'))],\n})\nexport class GenericListComponent {\n  @ViewChild('divMatList') divMatList: ElementRef;\n  @ViewChild('ulGenericList') ulGenericList: ElementRef;\n\n  @Input() selectedItemId: string;\n\n  @Input()\n  set initialDataList(initialDataList: IDataItem[]) {\n    if (initialDataList) {\n      this._initialDataList = initialDataList;\n      this.updateDataListOnSetAndOnSearch();\n    }\n  }\n\n  get initialDataList(): IDataItem[] {\n    return this._initialDataList;\n  }\n\n  @Input()\n  set search(search: string) {\n    this._search = search;\n    this.updateDataListOnSetAndOnSearch();\n  }\n\n  get search(): string {\n    return this._search;\n  }\n\n  @Input() isSelectOnlyModeEnabled = false;\n\n  @Input() isLargeScreen: boolean;\n\n  @Input() actionsMenuTemplate: TemplateRef<any>;\n\n  @Output() selectedItem = new EventEmitter<IDataItem>();\n\n  private _initialDataList: IDataItem[] = [];\n\n  private _search: string;\n\n  public activeItem: IDataItem;\n\n  public filteredDataList: IDataItem[];\n\n  public dataList: IDataItem[];\n\n  public elementRef: ElementRef;\n\n  constructor(\n    private _store$: Store,\n    private _el: ElementRef\n  ) {\n    this.elementRef = this._el;\n  }\n\n  getLink(item: IDataItem): string {\n    return item.link.toLowerCase();\n  }\n\n  getActiveItem(item: IDataItem): void {\n    this.activeItem = item;\n    this.selectedItem.emit(this.activeItem);\n  }\n\n  setEntryIdsInStore(ids: IEntryIds): void {\n    this._store$.dispatch(new Data.SetSelectedEntryIds({ ids }));\n  }\n\n  updateDataListOnSetAndOnSearch(): void {\n    if (!this.isSelectOnlyModeEnabled && this.search !== '') {\n      this.filteredDataList = filterList(this.initialDataList, this._search);\n      this.dataList = [...this.filteredDataList];\n    } else {\n      this.dataList = [...this.initialDataList];\n    }\n  }\n\n  public getItemCssClass(itemId: string): string {\n    if (!this.isSelectOnlyModeEnabled && itemId === this.selectedItemId) {\n      return 'active-item-link';\n    } else if (this.isSelectOnlyModeEnabled) {\n      if (itemId === this.selectedItemId) {\n        return 'disabled-div';\n      } else if (this.activeItem && this.activeItem.ids.id === itemId) {\n        return 'active-item-link';\n      }\n    }\n  }\n}\n","<!-- Copyright (C) 2020-2024 Linagora\n\nThis program is free software: you can redistribute it and/or modify it under\nthe terms of the GNU Affero General Public License as published by the Free\nSoftware Foundation, either version 3 of the License, or (at your option) any\nlater version, provided you comply with the Additional Terms applicable for\nLinID Directory Manager software by LINAGORA pursuant to Section 7 of the GNU\nAffero General Public License, subsections (b), (c), and (e), pursuant to\nwhich these Appropriate Legal Notices must notably (i) retain the display of\nthe \"LinID™\" trademark/logo at the top of the interface window, the display\nof the “You are using the Open Source and free version of LinID™, powered by\nLinagora © 2009–2013. Contribute to LinID R&D by subscribing to an Enterprise\noffer!” infobox and in the e-mails sent with the Program, notice appended to\nany type of outbound messages (e.g. e-mail and meeting requests) as well as\nin the LinID Directory Manager user interface, (ii) retain all hypertext\nlinks between LinID Directory Manager and https://linid.org/, as well as\nbetween LINAGORA and LINAGORA.com, and (iii) refrain from infringing LINAGORA\nintellectual property rights over its trademarks and commercial brands. Other\nAdditional Terms apply, see <http://www.linagora.com/licenses/> for more\ndetails.\n\nThis program is distributed in the hope that it will be useful, but WITHOUT\nANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS\nFOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more\ndetails.\n\nYou should have received a copy of the GNU Affero General Public License and\nits applicable Additional Terms for LinID Directory Manager along with this\nprogram. If not, see <http://www.gnu.org/licenses/> for the GNU Affero\nGeneral Public License version 3 and <http://www.linagora.com/licenses/> for\nthe Additional Terms applicable to the LinID Directory Manager software. -->\n\n<div\n  [ngClass]=\"\n    isSelectOnlyModeEnabled\n      ? 'div-mat-list-dialog'\n      : isLargeScreen\n        ? 'div-mat-list-lg-screen'\n        : 'div-mat-list-sm-screen'\n  \"\n  class=\"div-generic-list\"\n  #divMatList\n>\n  <mat-nav-list>\n    <nav role=\"navigation\">\n      <ul class=\"gnc-list\" #ulGenericList>\n        <li\n          mat-list-item\n          fxLayout=\"row\"\n          *ngFor=\"let data of dataList\"\n          class=\"gnc-list-item\"\n        >\n          <a\n            fxFlex\n            draggable=\"false\"\n            disableRipple=\"true\"\n            [routerLink]=\"!isSelectOnlyModeEnabled ? [getLink(data)] : []\"\n            (click)=\"\n              isSelectOnlyModeEnabled && data.ids.id !== selectedItemId\n                ? getActiveItem(data)\n                : !isSelectOnlyModeEnabled\n                  ? setEntryIdsInStore(data.ids)\n                  : null\n            \"\n            [title]=\"data.name\"\n            [id]=\"data.ids.externalId\"\n            [ngClass]=\"getItemCssClass(data.ids.id)\"\n            class=\"ldap-item\"\n          >\n            <button [title]=\"data.name\" class=\"btn-item\">\n              <span\n                appColorSearchedLetters\n                [name]=\"data.name\"\n                [title]=\"data.name\"\n                [search]=\"search\"\n                classToApply=\"highlight\"\n                id=\"{{ data.ids.id }}\"\n                class=\"ldap-item-name ellipsis\"\n              ></span>\n            </button>\n          </a>\n          <div\n            *ngIf=\"!isSelectOnlyModeEnabled\"\n            (click)=\"$event.preventDefault(); $event.stopPropagation()\"\n            class=\"ellipsis-menu\"\n          >\n            <ng-container\n              [ngTemplateOutlet]=\"actionsMenuTemplate\"\n              [ngTemplateOutletContext]=\"{\n                data\n              }\"\n            ></ng-container>\n          </div>\n        </li>\n      </ul>\n    </nav>\n  </mat-nav-list>\n</div>\n"]}