UNPKG

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

Version:

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

173 lines 40.3 kB
import { __decorate } from "tslib"; /** * 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 { Component, EventEmitter, Input, Output, ViewChild, } from '@angular/core'; import { Select } from '@ngxs/store'; import { Subject, debounceTime, takeUntil, tap } from 'rxjs'; import { Data, UiState, } 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/forms"; import * as i4 from "@angular/flex-layout/flex"; import * as i5 from "@angular/flex-layout/extended"; import * as i6 from "@angular/material/button"; import * as i7 from "@angular/material/form-field"; import * as i8 from "@angular/material/icon"; import * as i9 from "@angular/material/input"; import * as i10 from "@angular/material/tooltip"; export class GenericDataHeaderComponent { set advancedSearchMatHint(advancedSearchMatHint) { if (!!advancedSearchMatHint) { this._advancedSearchMatHint = advancedSearchMatHint; this.lineHeight = Math.round(Number(getComputedStyle(this._advancedSearchMatHint.nativeElement) .getPropertyValue('line-height') .replace('px', ''))); } } get advancedSearchMatHint() { return this._advancedSearchMatHint; } set selectedResourceRootTypeId(selectedResourceRootTypeId) { this._largeHeaderWidth = null; this.largeBtnAdditionnalClasses = { 'hide-btn': false }; this.smallBtnAdditionnalClasses = { 'hide-btn': false }; this._selectedResourceRootTypeId = selectedResourceRootTypeId; this.search = this.dataJsTable.byId[this.selectedResourceRootTypeId]?.filterValue; } get selectedResourceRootTypeId() { return this._selectedResourceRootTypeId; } set offsetWidth(offsetWidth) { if (!!offsetWidth) { this._offsetWidth = offsetWidth; this._updateButtonDisplay(); } } get offsetWidth() { return this._offsetWidth; } constructor(_store$) { this._store$ = _store$; this._COMPONENT_MIN_WIDTH = 290; this.largeBtnAdditionnalClasses = { 'hide-btn': false, }; this.smallBtnAdditionnalClasses = { 'hide-btn': false, }; this.clickOnAddResourceBtn = new EventEmitter(); this._onDestroy$ = new Subject(); this.search = ''; this.modelChanged = new Subject(); } ngOnInit() { this.modelChanged .pipe(debounceTime(300), takeUntil(this._onDestroy$), tap((currentSearch) => { this._store$.dispatch(new Data.SetFilterValue({ filterValue: currentSearch, dataTypeId: this.selectedResourceRootTypeId, })); })) .subscribe(); } ngAfterViewInit() { let largeBtnWidth = 0; let smallBtnWidth = 0; if (this.canCreate) { largeBtnWidth = this.createLargeBtn._elementRef.nativeElement.offsetWidth; smallBtnWidth = this.createMiniFabBtn._elementRef.nativeElement.offsetWidth; } let filterMinWidth = this._COMPONENT_MIN_WIDTH - smallBtnWidth; this._largeHeaderWidth = filterMinWidth + largeBtnWidth; this._updateButtonDisplay(); } clearInputFilter() { this.search = ''; this.modelChanged.next(''); } updateSearch(search) { this.modelChanged.next(search); } addNewResource() { this.clickOnAddResourceBtn.emit(); } ngOnDestroy() { this._onDestroy$.next(); this._onDestroy$.complete(); } _updateButtonDisplay() { if (this._largeHeaderWidth != null) { const displayLargeBtn = this._largeHeaderWidth <= this.offsetWidth; this.largeBtnAdditionnalClasses = { 'hide-btn': !displayLargeBtn }; this.smallBtnAdditionnalClasses = { 'hide-btn': displayLargeBtn }; } } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: GenericDataHeaderComponent, deps: [{ token: i1.Store }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.4", type: GenericDataHeaderComponent, selector: "dm-generic-data-header", inputs: { advancedSearchMatHint: "advancedSearchMatHint", canCreate: "canCreate", addBtnLabel: "addBtnLabel", dataJsTable: "dataJsTable", selectedResourceRootTypeId: "selectedResourceRootTypeId", offsetWidth: "offsetWidth", isLargeScreen: "isLargeScreen", isAdvancedSearchActivated: "isAdvancedSearchActivated" }, outputs: { clickOnAddResourceBtn: "clickOnAddResourceBtn" }, viewQueries: [{ propertyName: "createLargeBtn", first: true, predicate: ["createLargeBtn"], descendants: true }, { propertyName: "createMiniFabBtn", first: true, predicate: ["createMiniFabBtn"], 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 fxLayout=\"row\" class=\"div-gnc-filter\">\n <mat-form-field\n *ngIf=\"filterAccessibility$ | async as filterAccessibility\"\n fxFlex\n color=\"accent\"\n [ngClass]=\"{\n 'gnc-filter-activated':\n advancedSearchMatHint?.nativeElement.offsetHeight <= lineHeight\n }\"\n class=\"gnc-filter\"\n >\n <mat-label>\n <mat-icon aria-hidden=\"true\">filter_list_alt</mat-icon>\n {{ filterAccessibility.label }}\n </mat-label>\n <input\n type=\"text\"\n matInput\n [(ngModel)]=\"search\"\n (ngModelChange)=\"updateSearch($event)\"\n class=\"filter\"\n />\n <button\n *ngIf=\"search\"\n matSuffix\n mat-icon-button\n [attr.aria-label]=\"filterAccessibility.clearSearch\"\n (click)=\"clearInputFilter()\"\n class=\"reset-input-btn\"\n [matTooltip]=\"filterAccessibility.clearSearch\"\n >\n <mat-icon aria-hidden=\"true\"> clear </mat-icon>\n </button>\n </mat-form-field>\n <div\n *ngIf=\"canCreate\"\n class=\"div-add-button\"\n [ngClass]=\"{\n 'div-add-button-with-advanced-search':\n advancedSearchMatHint?.nativeElement.offsetHeight <= lineHeight\n }\"\n >\n <button\n #createLargeBtn\n mat-raised-button\n color=\"accent\"\n (click)=\"addNewResource()\"\n class=\"lg-add-btn\"\n [ngClass]=\"largeBtnAdditionnalClasses\"\n >\n {{ addBtnLabel }}\n </button>\n <button\n #createMiniFabBtn\n mat-mini-fab\n color=\"accent\"\n matTooltipPosition=\"right\"\n [matTooltip]=\"addBtnLabel\"\n (click)=\"addNewResource()\"\n class=\"sm-add-btn\"\n [ngClass]=\"smallBtnAdditionnalClasses\"\n >\n <mat-icon aria-hidden=\"true\">add</mat-icon>\n </button>\n </div>\n</div>\n", styles: ["@charset \"UTF-8\";.gnc-filter{padding:20px 20px 0}.gnc-filter-activated{padding-top:10px}.div-add-button{margin-top:25px;padding-right:5px}.div-add-button-with-advanced-search{margin-top:15px}.lg-add-btn{width:max-content}button.mdc-fab--mini.sm-add-btn:active:not([class*=mat-elevation-z]){box-shadow:none}.hide-btn{display:none}mat-label{display:flex}.reset-input-btn{height:1.5em;width:1.5em;padding:0;display:flex;align-items:center;justify-content:center}.reset-input-btn mat-icon{font-size:inherit;height:auto;width:auto}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { 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.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: i6.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "component", type: i6.MatMiniFabButton, selector: "button[mat-mini-fab]", exportAs: ["matButton"] }, { kind: "component", type: i7.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i7.MatLabel, selector: "mat-label" }, { kind: "directive", type: i7.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "component", type: i8.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i9.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "directive", type: i10.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }] }); } } __decorate([ Select(UiState.getFilterAccessibility) ], GenericDataHeaderComponent.prototype, "filterAccessibility$", void 0); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: GenericDataHeaderComponent, decorators: [{ type: Component, args: [{ selector: 'dm-generic-data-header', 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 fxLayout=\"row\" class=\"div-gnc-filter\">\n <mat-form-field\n *ngIf=\"filterAccessibility$ | async as filterAccessibility\"\n fxFlex\n color=\"accent\"\n [ngClass]=\"{\n 'gnc-filter-activated':\n advancedSearchMatHint?.nativeElement.offsetHeight <= lineHeight\n }\"\n class=\"gnc-filter\"\n >\n <mat-label>\n <mat-icon aria-hidden=\"true\">filter_list_alt</mat-icon>\n {{ filterAccessibility.label }}\n </mat-label>\n <input\n type=\"text\"\n matInput\n [(ngModel)]=\"search\"\n (ngModelChange)=\"updateSearch($event)\"\n class=\"filter\"\n />\n <button\n *ngIf=\"search\"\n matSuffix\n mat-icon-button\n [attr.aria-label]=\"filterAccessibility.clearSearch\"\n (click)=\"clearInputFilter()\"\n class=\"reset-input-btn\"\n [matTooltip]=\"filterAccessibility.clearSearch\"\n >\n <mat-icon aria-hidden=\"true\"> clear </mat-icon>\n </button>\n </mat-form-field>\n <div\n *ngIf=\"canCreate\"\n class=\"div-add-button\"\n [ngClass]=\"{\n 'div-add-button-with-advanced-search':\n advancedSearchMatHint?.nativeElement.offsetHeight <= lineHeight\n }\"\n >\n <button\n #createLargeBtn\n mat-raised-button\n color=\"accent\"\n (click)=\"addNewResource()\"\n class=\"lg-add-btn\"\n [ngClass]=\"largeBtnAdditionnalClasses\"\n >\n {{ addBtnLabel }}\n </button>\n <button\n #createMiniFabBtn\n mat-mini-fab\n color=\"accent\"\n matTooltipPosition=\"right\"\n [matTooltip]=\"addBtnLabel\"\n (click)=\"addNewResource()\"\n class=\"sm-add-btn\"\n [ngClass]=\"smallBtnAdditionnalClasses\"\n >\n <mat-icon aria-hidden=\"true\">add</mat-icon>\n </button>\n </div>\n</div>\n", styles: ["@charset \"UTF-8\";.gnc-filter{padding:20px 20px 0}.gnc-filter-activated{padding-top:10px}.div-add-button{margin-top:25px;padding-right:5px}.div-add-button-with-advanced-search{margin-top:15px}.lg-add-btn{width:max-content}button.mdc-fab--mini.sm-add-btn:active:not([class*=mat-elevation-z]){box-shadow:none}.hide-btn{display:none}mat-label{display:flex}.reset-input-btn{height:1.5em;width:1.5em;padding:0;display:flex;align-items:center;justify-content:center}.reset-input-btn mat-icon{font-size:inherit;height:auto;width:auto}\n"] }] }], ctorParameters: () => [{ type: i1.Store }], propDecorators: { filterAccessibility$: [], createLargeBtn: [{ type: ViewChild, args: ['createLargeBtn'] }], createMiniFabBtn: [{ type: ViewChild, args: ['createMiniFabBtn'] }], advancedSearchMatHint: [{ type: Input }], canCreate: [{ type: Input }], addBtnLabel: [{ type: Input }], dataJsTable: [{ type: Input }], selectedResourceRootTypeId: [{ type: Input }], offsetWidth: [{ type: Input }], isLargeScreen: [{ type: Input }], isAdvancedSearchActivated: [{ type: Input }], clickOnAddResourceBtn: [{ type: Output }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"generic-data-header.component.js","sourceRoot":"","sources":["../../../../../../../../packages/libs/client-core/src/lib/feature/generic-data-header/generic-data-header.component.ts","../../../../../../../../packages/libs/client-core/src/lib/feature/generic-data-header/generic-data-header.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 {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewChild,\n} from '@angular/core';\nimport { MatButton } from '@angular/material/button';\nimport { Select, Store } from '@ngxs/store';\nimport { Observable, Subject, debounceTime, takeUntil, tap } from 'rxjs';\nimport {\n  Data,\n  IFilterAccessibility,\n  IPersistentUiData,\n  JsTable,\n  UiState,\n} from '../../shared';\n\n@Component({\n  selector: 'dm-generic-data-header',\n  templateUrl: './generic-data-header.component.html',\n  styleUrls: ['./generic-data-header.component.scss'],\n})\nexport class GenericDataHeaderComponent\n  implements OnInit, OnDestroy, AfterViewInit\n{\n  @Select(UiState.getFilterAccessibility)\n  filterAccessibility$: Observable<IFilterAccessibility>;\n\n  private readonly _COMPONENT_MIN_WIDTH = 290;\n  private _largeHeaderWidth: number;\n  public largeBtnAdditionnalClasses: Record<string, boolean> = {\n    'hide-btn': false,\n  };\n  public smallBtnAdditionnalClasses: Record<string, boolean> = {\n    'hide-btn': false,\n  };\n\n  @ViewChild('createLargeBtn') createLargeBtn: MatButton;\n  @ViewChild('createMiniFabBtn') createMiniFabBtn: MatButton;\n\n  @Input() set advancedSearchMatHint(advancedSearchMatHint: ElementRef) {\n    if (!!advancedSearchMatHint) {\n      this._advancedSearchMatHint = advancedSearchMatHint;\n\n      this.lineHeight = Math.round(\n        Number(\n          getComputedStyle(this._advancedSearchMatHint.nativeElement)\n            .getPropertyValue('line-height')\n            .replace('px', '')\n        )\n      );\n    }\n  }\n\n  get advancedSearchMatHint(): ElementRef {\n    return this._advancedSearchMatHint;\n  }\n\n  @Input() canCreate: boolean;\n\n  @Input() addBtnLabel: string;\n\n  @Input() dataJsTable: JsTable<IPersistentUiData>;\n\n  @Input() set selectedResourceRootTypeId(selectedResourceRootTypeId: string) {\n    this._largeHeaderWidth = null;\n    this.largeBtnAdditionnalClasses = { 'hide-btn': false };\n    this.smallBtnAdditionnalClasses = { 'hide-btn': false };\n    this._selectedResourceRootTypeId = selectedResourceRootTypeId;\n    this.search =\n      this.dataJsTable.byId[this.selectedResourceRootTypeId]?.filterValue;\n  }\n\n  get selectedResourceRootTypeId(): string {\n    return this._selectedResourceRootTypeId;\n  }\n\n  @Input() set offsetWidth(offsetWidth: number) {\n    if (!!offsetWidth) {\n      this._offsetWidth = offsetWidth;\n      this._updateButtonDisplay();\n    }\n  }\n\n  get offsetWidth(): number {\n    return this._offsetWidth;\n  }\n\n  @Input() isLargeScreen: boolean;\n\n  @Input() isAdvancedSearchActivated: boolean;\n\n  @Output() clickOnAddResourceBtn = new EventEmitter<void>();\n\n  private _onDestroy$ = new Subject<void>();\n\n  private _advancedSearchMatHint: ElementRef;\n\n  private _offsetWidth: number;\n\n  private _selectedResourceRootTypeId: string;\n\n  public divAddButtonMaxWidth: number;\n\n  public search = '';\n\n  public modelChanged = new Subject<string>();\n\n  public lineHeight: number;\n\n  constructor(private _store$: Store) {}\n\n  ngOnInit(): void {\n    this.modelChanged\n      .pipe(\n        debounceTime(300),\n        takeUntil(this._onDestroy$),\n        tap((currentSearch) => {\n          this._store$.dispatch(\n            new Data.SetFilterValue({\n              filterValue: currentSearch,\n              dataTypeId: this.selectedResourceRootTypeId,\n            })\n          );\n        })\n      )\n      .subscribe();\n  }\n\n  ngAfterViewInit(): void {\n    let largeBtnWidth = 0;\n    let smallBtnWidth = 0;\n    if (this.canCreate) {\n      largeBtnWidth = this.createLargeBtn._elementRef.nativeElement.offsetWidth;\n      smallBtnWidth =\n        this.createMiniFabBtn._elementRef.nativeElement.offsetWidth;\n    }\n    let filterMinWidth = this._COMPONENT_MIN_WIDTH - smallBtnWidth;\n    this._largeHeaderWidth = filterMinWidth + largeBtnWidth;\n    this._updateButtonDisplay();\n  }\n\n  clearInputFilter(): void {\n    this.search = '';\n    this.modelChanged.next('');\n  }\n\n  updateSearch(search: string): void {\n    this.modelChanged.next(search);\n  }\n\n  addNewResource(): void {\n    this.clickOnAddResourceBtn.emit();\n  }\n\n  ngOnDestroy(): void {\n    this._onDestroy$.next();\n    this._onDestroy$.complete();\n  }\n\n  private _updateButtonDisplay(): void {\n    if (this._largeHeaderWidth != null) {\n      const displayLargeBtn = this._largeHeaderWidth <= this.offsetWidth;\n      this.largeBtnAdditionnalClasses = { 'hide-btn': !displayLargeBtn };\n      this.smallBtnAdditionnalClasses = { 'hide-btn': displayLargeBtn };\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 fxLayout=\"row\" class=\"div-gnc-filter\">\n  <mat-form-field\n    *ngIf=\"filterAccessibility$ | async as filterAccessibility\"\n    fxFlex\n    color=\"accent\"\n    [ngClass]=\"{\n      'gnc-filter-activated':\n        advancedSearchMatHint?.nativeElement.offsetHeight <= lineHeight\n    }\"\n    class=\"gnc-filter\"\n  >\n    <mat-label>\n      <mat-icon aria-hidden=\"true\">filter_list_alt</mat-icon>\n      {{ filterAccessibility.label }}\n    </mat-label>\n    <input\n      type=\"text\"\n      matInput\n      [(ngModel)]=\"search\"\n      (ngModelChange)=\"updateSearch($event)\"\n      class=\"filter\"\n    />\n    <button\n      *ngIf=\"search\"\n      matSuffix\n      mat-icon-button\n      [attr.aria-label]=\"filterAccessibility.clearSearch\"\n      (click)=\"clearInputFilter()\"\n      class=\"reset-input-btn\"\n      [matTooltip]=\"filterAccessibility.clearSearch\"\n    >\n      <mat-icon aria-hidden=\"true\"> clear </mat-icon>\n    </button>\n  </mat-form-field>\n  <div\n    *ngIf=\"canCreate\"\n    class=\"div-add-button\"\n    [ngClass]=\"{\n      'div-add-button-with-advanced-search':\n        advancedSearchMatHint?.nativeElement.offsetHeight <= lineHeight\n    }\"\n  >\n    <button\n      #createLargeBtn\n      mat-raised-button\n      color=\"accent\"\n      (click)=\"addNewResource()\"\n      class=\"lg-add-btn\"\n      [ngClass]=\"largeBtnAdditionnalClasses\"\n    >\n      {{ addBtnLabel }}\n    </button>\n    <button\n      #createMiniFabBtn\n      mat-mini-fab\n      color=\"accent\"\n      matTooltipPosition=\"right\"\n      [matTooltip]=\"addBtnLabel\"\n      (click)=\"addNewResource()\"\n      class=\"sm-add-btn\"\n      [ngClass]=\"smallBtnAdditionnalClasses\"\n    >\n      <mat-icon aria-hidden=\"true\">add</mat-icon>\n    </button>\n  </div>\n</div>\n"]}