@elderbyte/ngx-starter 16.4.5 → 16.4.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -54,7 +54,7 @@ export class ElderSearchBoxComponent {
54
54
  this._dense = false;
55
55
  this.autocomplete = 'off';
56
56
  this.userFilters$ = searchContextDirective.userDefinedAttributes$.pipe(
57
- //switchMap(ctx => ctx.userFilters.filters)
57
+ // tap(attrs => this.logger.error('Attrs', attrs))
58
58
  );
59
59
  }
60
60
  /***************************************************************************
@@ -121,4 +121,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
121
121
  }], dense: [{
122
122
  type: Input
123
123
  }] } });
124
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-search-box.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/forms/search/search-box/elder-search-box.component.ts","../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/forms/search/search-box/elder-search-box.component.html"],"names":[],"mappings":"AAAA,OAAO,EAC4B,uBAAuB,EACxD,SAAS,EAAE,YAAY,EACX,KAAK,EAEjB,SAAS,GACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAErD,OAAO,EAAC,yBAAyB,EAAC,MAAM,gCAAgC,CAAC;AACzE,OAAO,EAAC,eAAe,EAAc,OAAO,EAAY,MAAM,MAAM,CAAC;AACrE,OAAO,EAAC,qBAAqB,EAAC,MAAM,uBAAuB,CAAC;;;;;;;;;;;;;;;;;AAM5D,MAAM,OAAO,YAAY;IACvB,YACS,UAAmB;QAAnB,eAAU,GAAV,UAAU,CAAS;IACxB,CAAC;CACN;AAWD,MAAM,OAAO,uBAAuB;IAwDlC;;;;gFAI4E;IAE5E,YACkB,sBAAmD;QAAnD,2BAAsB,GAAtB,sBAAsB,CAA6B;QA7DrE;;;;oFAI4E;QAE3D,WAAM,GAAG,aAAa,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QAExD,iBAAY,GAAG,IAAI,OAAO,EAAQ,CAAC;QAOpC,kBAAa,GAAG,IAAI,eAAe,CAAe,IAAI,YAAY,CAAC,KAAK,CAAC,CAAC,CAAC;QAE3F;;;;oFAI4E;QAE5E;;WAEG;QAEI,cAAS,GAAG,IAAI,CAAC;QAGjB,SAAI,GAAG,kBAAkB,CAAC;QAG1B,aAAQ,GAAG,OAAO,CAAC;QAWlB,WAAM,GAAG,KAAK,CAAC;QAGhB,iBAAY,GAAG,KAAK,CAAC;QAgB1B,IAAI,CAAC,YAAY,GAAG,sBAAsB,CAAC,sBAAsB,CAAC,IAAI;QACpE,2CAA2C;SAC5C,CAAC;IACJ,CAAC;IAED;;;;gFAI4E;IAErE,kBAAkB;QACvB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC;IACnE,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;QACzB,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE,CAAC;IAC/B,CAAC;IAED;;;;gFAI4E;IAE5E,IACW,KAAK,CAAC,KAAc,IAAI,IAAI,CAAC,MAAM,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IAChF,IAAW,KAAK,KAAc,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC;IAGnD;;;;gFAI4E;IAErE,SAAS,CAAC,KAAU;QACzB,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,CAAC;IACxD,CAAC;IAED;;OAEG;IACI,WAAW,CAAC,KAAU;QAC3B,IAAI,CAAC,sBAAsB,CAAC,KAAK,EAAE,CAAC;IACtC,CAAC;+GA/GU,uBAAuB;mGAAvB,uBAAuB,iWAepB,yBAAyB,gLC/CzC,ywFAsEA;;4FDtCa,uBAAuB;kBATnC,SAAS;+BACE,kBAAkB,YAClB,gBAAgB,QAIpB,EAAC,OAAO,EAAE,uBAAuB,EAAC,mBACvB,uBAAuB,CAAC,MAAM;kHAe1B,MAAM;sBAA1B,SAAS;uBAAC,QAAQ;gBAEsB,cAAc;sBAAtD,YAAY;uBAAC,yBAAyB;gBAchC,SAAS;sBADf,KAAK;gBAIC,IAAI;sBADV,KAAK;gBAIC,QAAQ;sBADd,KAAK;gBAIC,WAAW;sBADjB,KAAK;gBAIC,KAAK;sBADX,KAAK;gBAIC,IAAI;sBADV,KAAK;gBAMC,YAAY;sBADlB,KAAK;gBAIC,UAAU;sBADhB,KAAK;gBAyCK,KAAK;sBADf,KAAK","sourcesContent":["import {\n  AfterContentInit, AfterViewInit, ChangeDetectionStrategy,\n  Component, ContentChild,\n  ElementRef, Input, OnDestroy,\n  OnInit,\n  ViewChild, ViewEncapsulation,\n} from '@angular/core';\nimport { LoggerFactory } from '@elderbyte/ts-logger';\nimport {ElderSearchContextDirective} from '../elder-search-context.directive';\nimport {ElderSearchPanelComponent} from './elder-search-panel.component';\nimport {BehaviorSubject, Observable, Subject, switchMap} from 'rxjs';\nimport {coerceBooleanProperty} from '@angular/cdk/coercion';\nimport {MatFormFieldAppearance} from '@angular/material/form-field';\nimport {Filter} from '../../../../common/data/filters/filter';\nimport {map} from 'rxjs/operators';\n\n\nexport class OverlayState {\n  constructor(\n    public hasOverlay: boolean\n  ) { }\n}\n\n@Component({\n  selector: 'elder-search-box',\n  exportAs: 'elderSearchBox',\n  templateUrl: './elder-search-box.component.html',\n  styleUrls: ['./elder-search-box.component.scss'],\n  // eslint-disable-next-line @angular-eslint/no-host-metadata-property\n  host: {'class': 'elder-form-field-host'},\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ElderSearchBoxComponent implements OnDestroy, AfterContentInit {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n\n  private readonly unsubscribe$ = new Subject<void>();\n\n  // The search expression input Element\n  @ViewChild('search') search: ElementRef<HTMLInputElement>;\n\n  @ContentChild(ElderSearchPanelComponent) advancedSearch: ElderSearchPanelComponent;\n\n  public readonly overlayState$ = new BehaviorSubject<OverlayState>(new OverlayState(false));\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API Fields                                                       *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Display the search panel immediately when the user enters the search box.\n   */\n  @Input()\n  public autoPanel = true;\n\n  @Input()\n  public name = 'searchExpression';\n\n  @Input()\n  public queryKey = 'query';\n\n  @Input()\n  public placeholder: string;\n\n  @Input()\n  public label: string;\n\n  @Input()\n  public hint: string;\n\n  private _dense = false;\n\n  @Input()\n  public autocomplete = 'off';\n\n  @Input()\n  public appearance: MatFormFieldAppearance;\n\n  public readonly userFilters$: Observable<any[]>;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    public readonly searchContextDirective: ElderSearchContextDirective,\n  ) {\n    this.userFilters$ = searchContextDirective.userDefinedAttributes$.pipe(\n      //switchMap(ctx => ctx.userFilters.filters)\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngAfterContentInit(): void {\n    this.overlayState$.next(new OverlayState(!!this.advancedSearch));\n  }\n\n  public ngOnDestroy(): void {\n    this.unsubscribe$.next();\n    this.unsubscribe$.complete();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set dense(value: boolean) { this._dense = coerceBooleanProperty(value); }\n  public get dense(): boolean { return this._dense; }\n\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public blurFocus(event: any): void {\n    setTimeout(() => this.search.nativeElement.blur(), 0);\n  }\n\n  /**\n   * Occurs when the user clicks the clear search button\n   */\n  public clearSearch(event: any): void {\n    this.searchContextDirective.reset();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n}\n","<div class=\"layout-row place-stretch-center full flex\" style=\"overflow: hidden\">\n  <mat-form-field\n    *ngIf=\"overlayState$ | async as overlayState\"\n    [appearance]=\"appearance\"\n    class=\"elder-search-box-field flex-auto\" subscriptSizing=\"dynamic\"\n    [elderDense]=\"dense\">\n\n    <button matPrefix mat-icon-button type=\"button\"\n            [elderOverlayTrigger]=\"searchPanel\" (click)=\"blurFocus($event)\"\n    >\n      <mat-icon>search</mat-icon>\n    </button>\n\n    <input matInput type=\"text\" [name]=\"name\" [placeholder]=\"placeholder\" #search cdkFocusInitial\n           ngModel\n           elderSearchInput [elderSearchInputKey]=\"queryKey\" #searchInput=\"elderSearchInput\"\n           [autocomplete]=\"(autoPanel && overlayState.hasOverlay) ? 'off' : autocomplete\"\n           [elderOverlayOrigin]=\"searchPanel\"\n           [elderOverlayTrigger]=\"searchPanel\"\n           [elderOverlayTriggerType]=\"'focus'\"\n           [elderOverlayTriggerEnabled]=\"autoPanel && overlayState.hasOverlay && (searchInput?.state$ | async)?.pristine\"\n    >\n    <mat-hint *ngIf=\"hint\">{{hint}}</mat-hint>\n\n    <div class=\"layout-row\" matSuffix *ngIf=\"userFilters$ | async as userDefinedFilters\">\n\n      <button mat-icon-button type=\"button\"\n              *ngIf=\"userDefinedFilters.length > 0\"\n              (click)=\"clearSearch($event)\"\n              name=\"clear\" aria-label=\"Clear\">\n        <mat-icon>close</mat-icon>\n      </button>\n\n      <button mat-icon-button type=\"button\"\n              *ngIf=\"overlayState.hasOverlay\" name=\"openPanel\"\n              [elderOverlayTrigger]=\"searchPanel\" (click)=\"blurFocus($event)\">\n        <mat-icon\n          [matBadge]=\"userDefinedFilters.length\"\n          matBadgeSize=\"small\"\n          [matBadgeOverlap]=\"true\"\n          [matBadgeHidden]=\"userDefinedFilters.length === 0\"\n          matBadgeColor=\"accent\"\n          [color]=\"userDefinedFilters.length > 0 ? 'accent' : undefined\"\n        >\n          filter_list\n        </mat-icon>\n      </button>\n    </div>\n  </mat-form-field>\n</div>\n\n\n<!-- Overlay Panel for advanced search -->\n<elder-overlay #searchPanel=\"elderOverlay\">\n  <elder-dialog-panel class=\"elder-search-panel-container\">\n\n    <!-- Project the users search inputs here -->\n    <ng-content select=\"elder-search-panel\"></ng-content>\n\n    <div class=\"layout-row place-between-center\">\n      <button mat-raised-button type=\"button\" name=\"clear\"\n              (click)=\"clearSearch($event)\">{{'context.reset' | translate}}\n      </button>\n\n      <button mat-raised-button type=\"button\" name=\"ok\" color=\"primary\"\n              (click)=\"searchPanel.closeOverlay()\">Ok\n      </button>\n    </div>\n  </elder-dialog-panel>\n</elder-overlay>\n"]}
124
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-search-box.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/forms/search/search-box/elder-search-box.component.ts","../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/forms/search/search-box/elder-search-box.component.html"],"names":[],"mappings":"AAAA,OAAO,EAC4B,uBAAuB,EACxD,SAAS,EAAE,YAAY,EACX,KAAK,EAEjB,SAAS,GACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAErD,OAAO,EAAC,yBAAyB,EAAC,MAAM,gCAAgC,CAAC;AACzE,OAAO,EAAC,eAAe,EAAc,OAAO,EAAY,MAAM,MAAM,CAAC;AACrE,OAAO,EAAC,qBAAqB,EAAC,MAAM,uBAAuB,CAAC;;;;;;;;;;;;;;;;;AAM5D,MAAM,OAAO,YAAY;IACvB,YACS,UAAmB;QAAnB,eAAU,GAAV,UAAU,CAAS;IACxB,CAAC;CACN;AAWD,MAAM,OAAO,uBAAuB;IAwDlC;;;;gFAI4E;IAE5E,YACkB,sBAAmD;QAAnD,2BAAsB,GAAtB,sBAAsB,CAA6B;QA7DrE;;;;oFAI4E;QAE3D,WAAM,GAAG,aAAa,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QAExD,iBAAY,GAAG,IAAI,OAAO,EAAQ,CAAC;QAOpC,kBAAa,GAAG,IAAI,eAAe,CAAe,IAAI,YAAY,CAAC,KAAK,CAAC,CAAC,CAAC;QAE3F;;;;oFAI4E;QAE5E;;WAEG;QAEI,cAAS,GAAG,IAAI,CAAC;QAGjB,SAAI,GAAG,kBAAkB,CAAC;QAG1B,aAAQ,GAAG,OAAO,CAAC;QAWlB,WAAM,GAAG,KAAK,CAAC;QAGhB,iBAAY,GAAG,KAAK,CAAC;QAgB1B,IAAI,CAAC,YAAY,GAAG,sBAAsB,CAAC,sBAAsB,CAAC,IAAI;QACpE,kDAAkD;SACnD,CAAC;IACJ,CAAC;IAED;;;;gFAI4E;IAErE,kBAAkB;QACvB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC;IACnE,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;QACzB,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE,CAAC;IAC/B,CAAC;IAED;;;;gFAI4E;IAE5E,IACW,KAAK,CAAC,KAAc,IAAI,IAAI,CAAC,MAAM,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IAChF,IAAW,KAAK,KAAc,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC;IAGnD;;;;gFAI4E;IAErE,SAAS,CAAC,KAAU;QACzB,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,CAAC;IACxD,CAAC;IAED;;OAEG;IACI,WAAW,CAAC,KAAU;QAC3B,IAAI,CAAC,sBAAsB,CAAC,KAAK,EAAE,CAAC;IACtC,CAAC;+GA/GU,uBAAuB;mGAAvB,uBAAuB,iWAepB,yBAAyB,gLC/CzC,ywFAsEA;;4FDtCa,uBAAuB;kBATnC,SAAS;+BACE,kBAAkB,YAClB,gBAAgB,QAIpB,EAAC,OAAO,EAAE,uBAAuB,EAAC,mBACvB,uBAAuB,CAAC,MAAM;kHAe1B,MAAM;sBAA1B,SAAS;uBAAC,QAAQ;gBAEsB,cAAc;sBAAtD,YAAY;uBAAC,yBAAyB;gBAchC,SAAS;sBADf,KAAK;gBAIC,IAAI;sBADV,KAAK;gBAIC,QAAQ;sBADd,KAAK;gBAIC,WAAW;sBADjB,KAAK;gBAIC,KAAK;sBADX,KAAK;gBAIC,IAAI;sBADV,KAAK;gBAMC,YAAY;sBADlB,KAAK;gBAIC,UAAU;sBADhB,KAAK;gBAyCK,KAAK;sBADf,KAAK","sourcesContent":["import {\n  AfterContentInit, AfterViewInit, ChangeDetectionStrategy,\n  Component, ContentChild,\n  ElementRef, Input, OnDestroy,\n  OnInit,\n  ViewChild, ViewEncapsulation,\n} from '@angular/core';\nimport { LoggerFactory } from '@elderbyte/ts-logger';\nimport {ElderSearchContextDirective} from '../elder-search-context.directive';\nimport {ElderSearchPanelComponent} from './elder-search-panel.component';\nimport {BehaviorSubject, Observable, Subject, switchMap} from 'rxjs';\nimport {coerceBooleanProperty} from '@angular/cdk/coercion';\nimport {MatFormFieldAppearance} from '@angular/material/form-field';\nimport {Filter} from '../../../../common/data/filters/filter';\nimport {map, tap} from 'rxjs/operators';\n\n\nexport class OverlayState {\n  constructor(\n    public hasOverlay: boolean\n  ) { }\n}\n\n@Component({\n  selector: 'elder-search-box',\n  exportAs: 'elderSearchBox',\n  templateUrl: './elder-search-box.component.html',\n  styleUrls: ['./elder-search-box.component.scss'],\n  // eslint-disable-next-line @angular-eslint/no-host-metadata-property\n  host: {'class': 'elder-form-field-host'},\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ElderSearchBoxComponent implements OnDestroy, AfterContentInit {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n\n  private readonly unsubscribe$ = new Subject<void>();\n\n  // The search expression input Element\n  @ViewChild('search') search: ElementRef<HTMLInputElement>;\n\n  @ContentChild(ElderSearchPanelComponent) advancedSearch: ElderSearchPanelComponent;\n\n  public readonly overlayState$ = new BehaviorSubject<OverlayState>(new OverlayState(false));\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API Fields                                                       *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Display the search panel immediately when the user enters the search box.\n   */\n  @Input()\n  public autoPanel = true;\n\n  @Input()\n  public name = 'searchExpression';\n\n  @Input()\n  public queryKey = 'query';\n\n  @Input()\n  public placeholder: string;\n\n  @Input()\n  public label: string;\n\n  @Input()\n  public hint: string;\n\n  private _dense = false;\n\n  @Input()\n  public autocomplete = 'off';\n\n  @Input()\n  public appearance: MatFormFieldAppearance;\n\n  public readonly userFilters$: Observable<any[]>;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    public readonly searchContextDirective: ElderSearchContextDirective,\n  ) {\n    this.userFilters$ = searchContextDirective.userDefinedAttributes$.pipe(\n      // tap(attrs => this.logger.error('Attrs', attrs))\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngAfterContentInit(): void {\n    this.overlayState$.next(new OverlayState(!!this.advancedSearch));\n  }\n\n  public ngOnDestroy(): void {\n    this.unsubscribe$.next();\n    this.unsubscribe$.complete();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set dense(value: boolean) { this._dense = coerceBooleanProperty(value); }\n  public get dense(): boolean { return this._dense; }\n\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public blurFocus(event: any): void {\n    setTimeout(() => this.search.nativeElement.blur(), 0);\n  }\n\n  /**\n   * Occurs when the user clicks the clear search button\n   */\n  public clearSearch(event: any): void {\n    this.searchContextDirective.reset();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n}\n","<div class=\"layout-row place-stretch-center full flex\" style=\"overflow: hidden\">\n  <mat-form-field\n    *ngIf=\"overlayState$ | async as overlayState\"\n    [appearance]=\"appearance\"\n    class=\"elder-search-box-field flex-auto\" subscriptSizing=\"dynamic\"\n    [elderDense]=\"dense\">\n\n    <button matPrefix mat-icon-button type=\"button\"\n            [elderOverlayTrigger]=\"searchPanel\" (click)=\"blurFocus($event)\"\n    >\n      <mat-icon>search</mat-icon>\n    </button>\n\n    <input matInput type=\"text\" [name]=\"name\" [placeholder]=\"placeholder\" #search cdkFocusInitial\n           ngModel\n           elderSearchInput [elderSearchInputKey]=\"queryKey\" #searchInput=\"elderSearchInput\"\n           [autocomplete]=\"(autoPanel && overlayState.hasOverlay) ? 'off' : autocomplete\"\n           [elderOverlayOrigin]=\"searchPanel\"\n           [elderOverlayTrigger]=\"searchPanel\"\n           [elderOverlayTriggerType]=\"'focus'\"\n           [elderOverlayTriggerEnabled]=\"autoPanel && overlayState.hasOverlay && (searchInput?.state$ | async)?.pristine\"\n    >\n    <mat-hint *ngIf=\"hint\">{{hint}}</mat-hint>\n\n    <div class=\"layout-row\" matSuffix *ngIf=\"userFilters$ | async as userDefinedFilters\">\n\n      <button mat-icon-button type=\"button\"\n              *ngIf=\"userDefinedFilters.length > 0\"\n              (click)=\"clearSearch($event)\"\n              name=\"clear\" aria-label=\"Clear\">\n        <mat-icon>close</mat-icon>\n      </button>\n\n      <button mat-icon-button type=\"button\"\n              *ngIf=\"overlayState.hasOverlay\" name=\"openPanel\"\n              [elderOverlayTrigger]=\"searchPanel\" (click)=\"blurFocus($event)\">\n        <mat-icon\n          [matBadge]=\"userDefinedFilters.length\"\n          matBadgeSize=\"small\"\n          [matBadgeOverlap]=\"true\"\n          [matBadgeHidden]=\"userDefinedFilters.length === 0\"\n          matBadgeColor=\"accent\"\n          [color]=\"userDefinedFilters.length > 0 ? 'accent' : undefined\"\n        >\n          filter_list\n        </mat-icon>\n      </button>\n    </div>\n  </mat-form-field>\n</div>\n\n\n<!-- Overlay Panel for advanced search -->\n<elder-overlay #searchPanel=\"elderOverlay\">\n  <elder-dialog-panel class=\"elder-search-panel-container\">\n\n    <!-- Project the users search inputs here -->\n    <ng-content select=\"elder-search-panel\"></ng-content>\n\n    <div class=\"layout-row place-between-center\">\n      <button mat-raised-button type=\"button\" name=\"clear\"\n              (click)=\"clearSearch($event)\">{{'context.reset' | translate}}\n      </button>\n\n      <button mat-raised-button type=\"button\" name=\"ok\" color=\"primary\"\n              (click)=\"searchPanel.closeOverlay()\">Ok\n      </button>\n    </div>\n  </elder-dialog-panel>\n</elder-overlay>\n"]}
@@ -84,6 +84,7 @@ import { MatSidenavModule } from '@angular/material/sidenav';
84
84
  import * as i6 from '@angular/material/datepicker';
85
85
  import { MatDatepicker, MatDatepickerModule } from '@angular/material/datepicker';
86
86
  import localeDECH from '@angular/common/locales/de-CH';
87
+ import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
87
88
  import { TemplatePortal } from '@angular/cdk/portal';
88
89
  import * as i1$a from '@angular/cdk/overlay';
89
90
  import { OverlayModule } from '@angular/cdk/overlay';
@@ -25934,12 +25935,6 @@ class SearchContext {
25934
25935
  this.userFilterContext = new FilterContext();
25935
25936
  this.forcedFilterContext = new FilterContext();
25936
25937
  this.allFilters$ = new BehaviorSubject(undefined);
25937
- /***************************************************************************
25938
- * *
25939
- * Public API *
25940
- * *
25941
- **************************************************************************/
25942
- this.acceptDefaultFilters = true;
25943
25938
  this.id = id;
25944
25939
  this.userFilterContext.filters.pipe(combineLatestWith(this.forcedFilterContext.filters), skip(1), map(([userFilters, forcedFilters]) => FilterUtil.mergeCombine(userFilters, forcedFilters)), tap(x => this.log.debug('allFilters changed: ', x))).subscribe(merged => this.allFilters$.next(merged));
25945
25940
  }
@@ -25949,7 +25944,7 @@ class SearchContext {
25949
25944
  * *
25950
25945
  **************************************************************************/
25951
25946
  get allFiltersChanged() {
25952
- return this.allFilters$.pipe(filter(filters => !!filters));
25947
+ return this.allFilters$.pipe(filter(filters => !!filters), distinctUntilChanged((a, b) => FilterUtil.equals(a, b)));
25953
25948
  }
25954
25949
  get userFilters() {
25955
25950
  return this.userFilterContext.filtersSnapshot;
@@ -25960,23 +25955,23 @@ class SearchContext {
25960
25955
  get forcedFilters() {
25961
25956
  return this.forcedFilterContext.filtersSnapshot;
25962
25957
  }
25963
- updateDefaultFilters(filters) {
25958
+ /***************************************************************************
25959
+ * *
25960
+ * Public API *
25961
+ * *
25962
+ **************************************************************************/
25963
+ updateUserFiltersSave(filters) {
25964
25964
  // this.log.error('updateDefaultFilters, acceptDefaultFilters: ' + this.acceptDefaultFilters, filters);
25965
- if (this.acceptDefaultFilters) {
25966
- this.userFilterContext.updateFilters(FilterUtil.strip(filters, this.forcedFilters));
25967
- }
25968
- return this.acceptDefaultFilters;
25965
+ this.userFilterContext.updateFilters(FilterUtil.strip(filters, this.forcedFilters));
25969
25966
  }
25970
25967
  updateUserFilters(filters) {
25971
25968
  if (filters.length > 0) {
25972
25969
  // this.log.error('updateUserFilters', filters);
25973
- this.acceptDefaultFilters = false;
25974
25970
  this.userFilterContext.updateFilters(filters);
25975
25971
  }
25976
25972
  }
25977
25973
  replaceUserFilters(filters) {
25978
25974
  // this.log.error('replaceUserFilters', filters);
25979
- this.acceptDefaultFilters = false;
25980
25975
  this.userFilterContext.replaceFilters(filters);
25981
25976
  }
25982
25977
  replaceForcedFilters(filters) {
@@ -26036,21 +26031,21 @@ class ElderSearchContextDirective {
26036
26031
  * Constructor *
26037
26032
  * *
26038
26033
  **************************************************************************/
26039
- constructor(searchContextService) {
26034
+ constructor(searchContextService, destroyRef) {
26035
+ this.destroyRef = destroyRef;
26040
26036
  /***************************************************************************
26041
26037
  * *
26042
26038
  * Fields *
26043
26039
  * *
26044
26040
  **************************************************************************/
26045
26041
  this.log = LoggerFactory.getLogger(this.constructor.name);
26046
- this.destroy$ = new Subject();
26047
26042
  this.filtersToApplyAtRegistration = new Map;
26048
26043
  this._searchInputs$ = new BehaviorSubject([]);
26049
26044
  this._searchStates$ = new BehaviorSubject([]);
26050
26045
  this._filterContext$ = new BehaviorSubject(null);
26051
26046
  this._searchContext$ = new BehaviorSubject(SearchContext.standalone());
26052
26047
  this.searchContextId$ = new BehaviorSubject(null);
26053
- this.searchContextId$.pipe(takeUntil(this.destroy$), filter(contextId => !!contextId), map(contextId => searchContextService.context(contextId))).subscribe(ctx => this._searchContext$.next(ctx));
26048
+ this.searchContextId$.pipe(takeUntilDestroyed(this.destroyRef), filter(contextId => !!contextId), map(contextId => searchContextService.context(contextId))).subscribe(ctx => this._searchContext$.next(ctx));
26054
26049
  }
26055
26050
  /***************************************************************************
26056
26051
  * *
@@ -26066,10 +26061,6 @@ class ElderSearchContextDirective {
26066
26061
  this.applySearchContextToInputs(searchContext);
26067
26062
  this.syncSearchInputsToSearchContext();
26068
26063
  }
26069
- ngOnDestroy() {
26070
- this.destroy$.next();
26071
- this.destroy$.complete();
26072
- }
26073
26064
  /***************************************************************************
26074
26065
  * *
26075
26066
  * Properties *
@@ -26134,7 +26125,9 @@ class ElderSearchContextDirective {
26134
26125
  * Returns the current user touched attributes. (ignoring fallbacks)
26135
26126
  */
26136
26127
  get userDefinedAttributes$() {
26137
- return this.states$.pipe(map(states => states.filter(s => !s.pristine)));
26128
+ return this.states$.pipe(map(states => states
26129
+ .filter(s => !s.pristine)
26130
+ .filter(s => !s.hasFallbackValue)));
26138
26131
  }
26139
26132
  /***************************************************************************
26140
26133
  * *
@@ -26176,21 +26169,22 @@ class ElderSearchContextDirective {
26176
26169
  }
26177
26170
  }
26178
26171
  applyAsDefaultsUntilUserAction(searchContext, dcFilters) {
26179
- dcFilters.filters.pipe(map(filters => searchContext.updateDefaultFilters(filters)), takeWhile(acceptDefaultFilters => acceptDefaultFilters)).subscribe();
26172
+ dcFilters.filters.pipe(takeUntilDestroyed(this.destroyRef), map(filters => searchContext.updateUserFiltersSave(filters))).subscribe();
26180
26173
  }
26181
26174
  syncSearchInputsToSearchContext() {
26182
- this._searchInputs$.pipe(takeUntil(this.destroy$), switchMap$1(inputs => combineLatest(inputs.map(i => i.state$))), debounceTime(5)).subscribe(states => {
26175
+ this._searchInputs$.pipe(takeUntilDestroyed(this.destroyRef), switchMap$1(inputs => combineLatest(inputs.map(i => i.state$))), debounceTime(5)).subscribe(states => {
26176
+ /// this.log.error('SearchInputStates Changed: ', states);
26183
26177
  this._searchStates$.next(states);
26184
26178
  });
26185
26179
  const inputFilters$ = this._searchStates$.pipe(map(states => this.convertToFilters(states)), filter(filters => filters.length > 0));
26186
26180
  inputFilters$
26187
- .pipe(takeUntil(this.destroy$), combineLatestWith(this._searchContext$))
26181
+ .pipe(takeUntilDestroyed(this.destroyRef), combineLatestWith(this._searchContext$))
26188
26182
  .subscribe(([inputFilters, searchContext]) => {
26189
26183
  searchContext.updateUserFilters(inputFilters);
26190
26184
  });
26191
26185
  }
26192
26186
  syncSearchContextToBoundFilterContext() {
26193
- this._searchContext$.pipe(takeUntil(this.destroy$), switchMap$1(context => context.allFiltersChanged)).subscribe(allFilters => this.applyToBoundFilterContext(allFilters));
26187
+ this._searchContext$.pipe(takeUntilDestroyed(this.destroyRef), switchMap$1(context => context.allFiltersChanged)).subscribe(allFilters => this.applyToBoundFilterContext(allFilters));
26194
26188
  }
26195
26189
  applyToBoundFilterContext(filters) {
26196
26190
  const filterCtx = this.filterContext;
@@ -26231,11 +26225,11 @@ class ElderSearchContextDirective {
26231
26225
  }
26232
26226
  convertToFilters(states) {
26233
26227
  return states
26234
- .filter(s => s.userEvent)
26228
+ .filter(s => (s.userEvent || s.hasFallbackValue))
26235
26229
  .filter(s => !!s.queryKey)
26236
26230
  .map(s => new Filter(s.queryKey, s.queryValue));
26237
26231
  }
26238
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ElderSearchContextDirective, deps: [{ token: SearchContextService }], target: i0.ɵɵFactoryTarget.Directive }); }
26232
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ElderSearchContextDirective, deps: [{ token: SearchContextService }, { token: i0.DestroyRef }], target: i0.ɵɵFactoryTarget.Directive }); }
26239
26233
  static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: ElderSearchContextDirective, selector: "[elderSearchContext]", inputs: { searchContextId: "searchContextId", filterContext: ["elderSearchContext", "filterContext"], forcedFilters: "forcedFilters" }, exportAs: ["elderSearchContext"], ngImport: i0 }); }
26240
26234
  }
26241
26235
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ElderSearchContextDirective, decorators: [{
@@ -26244,7 +26238,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
26244
26238
  selector: '[elderSearchContext]',
26245
26239
  exportAs: 'elderSearchContext'
26246
26240
  }]
26247
- }], ctorParameters: function () { return [{ type: SearchContextService }]; }, propDecorators: { searchContextId: [{
26241
+ }], ctorParameters: function () { return [{ type: SearchContextService }, { type: i0.DestroyRef }]; }, propDecorators: { searchContextId: [{
26248
26242
  type: Input
26249
26243
  }], filterContext: [{
26250
26244
  type: Input,
@@ -26322,6 +26316,9 @@ class SearchInputState {
26322
26316
  get hasValue() {
26323
26317
  return SearchInputState.isValueDefined(this.queryValue);
26324
26318
  }
26319
+ get hasFallbackValue() {
26320
+ return this.hasValue && this.pristine;
26321
+ }
26325
26322
  /***************************************************************************
26326
26323
  * *
26327
26324
  * Public Api *
@@ -26438,7 +26435,7 @@ class ElderSearchInputDirective {
26438
26435
  }
26439
26436
  ngAfterViewInit() {
26440
26437
  this._extractedName = this.extractName();
26441
- this.log.debug(this._extractedName + "|" + this.queryKey + "|" + this.resolvePath);
26438
+ this.log.debug(this._extractedName + '|' + this.queryKey + '|' + this.resolvePath);
26442
26439
  }
26443
26440
  ngOnDestroy() {
26444
26441
  this.destroy$.next();
@@ -26459,8 +26456,8 @@ class ElderSearchInputDirective {
26459
26456
  if (this._extractedName) {
26460
26457
  return this._extractedName;
26461
26458
  }
26462
- throw new Error("Could not determine the search name key name." +
26463
- " Either specify the name property or explicitly set [elderSearchInputKey].");
26459
+ throw new Error('Could not determine the search name key name.' +
26460
+ ' Either specify the name property or explicitly set [elderSearchInputKey].');
26464
26461
  }
26465
26462
  get value() {
26466
26463
  return this.ngModel.value;
@@ -26503,7 +26500,12 @@ class ElderSearchInputDirective {
26503
26500
  }
26504
26501
  buildInputState(controlValue, userEvent) {
26505
26502
  const queryValue = this.convertRawModelValueToQueryString(controlValue);
26506
- const pristine = !this.isAttributeValuePresent(controlValue);
26503
+ let pristine = !this.isAttributeValuePresent(controlValue);
26504
+ if (this.hasFallback) {
26505
+ if (this.fallbackValue === queryValue) {
26506
+ pristine = true;
26507
+ }
26508
+ }
26507
26509
  return new SearchInputState(this.name, queryValue, this.queryKey || this.name, pristine, userEvent);
26508
26510
  }
26509
26511
  convertQueryStringToRawModelValue(queryString) {
@@ -26543,14 +26545,14 @@ class ElderSearchInputDirective {
26543
26545
  return value;
26544
26546
  }
26545
26547
  convertEmptyStringToNull(value) {
26546
- if (typeof value === "string" && value.length === 0) {
26548
+ if (typeof value === 'string' && value.length === 0) {
26547
26549
  return null;
26548
26550
  }
26549
26551
  return value;
26550
26552
  }
26551
26553
  isAttributeValuePresent(value) {
26552
26554
  return SearchInputState.isValueDefined(value)
26553
- && (value + "").length !== 0;
26555
+ && (value + '').length !== 0;
26554
26556
  }
26555
26557
  resolveValue(value) {
26556
26558
  if (Objects.nonNull(value)) {
@@ -26605,29 +26607,29 @@ class ElderSearchInputDirective {
26605
26607
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ElderSearchInputDirective, decorators: [{
26606
26608
  type: Directive,
26607
26609
  args: [{
26608
- selector: "[elderSearchInput]",
26609
- exportAs: "elderSearchInput"
26610
+ selector: '[elderSearchInput]',
26611
+ exportAs: 'elderSearchInput'
26610
26612
  }]
26611
26613
  }], ctorParameters: function () { return [{ type: ElderSearchContextDirective }, { type: i3.NgModel, decorators: [{
26612
26614
  type: Host
26613
26615
  }] }]; }, propDecorators: { queryKey: [{
26614
26616
  type: Input,
26615
- args: ["elderSearchInputKey"]
26617
+ args: ['elderSearchInputKey']
26616
26618
  }], valueTransform: [{
26617
26619
  type: Input,
26618
- args: ["elderSearchInputTransform"]
26620
+ args: ['elderSearchInputTransform']
26619
26621
  }], resolvePath: [{
26620
26622
  type: Input,
26621
- args: ["elderSearchInput"]
26623
+ args: ['elderSearchInput']
26622
26624
  }], dataSource: [{
26623
26625
  type: Input,
26624
- args: ["dataSource"]
26626
+ args: ['dataSource']
26625
26627
  }], fallbackValue: [{
26626
26628
  type: Input,
26627
- args: ["elderSearchInputFallback"]
26629
+ args: ['elderSearchInputFallback']
26628
26630
  }], valueAsId: [{
26629
26631
  type: Input,
26630
- args: ["valueAsId"]
26632
+ args: ['valueAsId']
26631
26633
  }] } });
26632
26634
 
26633
26635
  class ElderSearchPanelComponent {
@@ -26985,7 +26987,7 @@ class ElderSearchBoxComponent {
26985
26987
  this._dense = false;
26986
26988
  this.autocomplete = 'off';
26987
26989
  this.userFilters$ = searchContextDirective.userDefinedAttributes$.pipe(
26988
- //switchMap(ctx => ctx.userFilters.filters)
26990
+ // tap(attrs => this.logger.error('Attrs', attrs))
26989
26991
  );
26990
26992
  }
26991
26993
  /***************************************************************************