@elderbyte/ngx-starter 16.4.6 → 16.4.8

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"]}
@@ -7448,10 +7448,11 @@ class ParseUtil {
7448
7448
  /**
7449
7449
  * Tries to parse a given value to a boolean.
7450
7450
  * @param bool a value representing a boolean state.
7451
- * @return undefined, if the value is null or undefined, false, if the value is false, else true.
7451
+ * @return undefined, if the value is null/undefined/empty
7452
+ * @return false, if the value is false, else true.
7452
7453
  */
7453
- static parseBoolean(bool) {
7454
- if (bool === undefined || bool == null) {
7454
+ static parseBoolOrUndefined(bool) {
7455
+ if (bool === undefined || bool === null || bool === '') {
7455
7456
  return undefined;
7456
7457
  }
7457
7458
  else {
@@ -15772,6 +15773,7 @@ class ElderTripleStateCheckboxDirective {
15772
15773
  constructor(checkbox, ngModel) {
15773
15774
  this.checkbox = checkbox;
15774
15775
  this.ngModel = ngModel;
15776
+ this.log = LoggerFactory.getLogger(this.constructor.name);
15775
15777
  }
15776
15778
  /***************************************************************************
15777
15779
  * *
@@ -15788,14 +15790,7 @@ class ElderTripleStateCheckboxDirective {
15788
15790
  * *
15789
15791
  **************************************************************************/
15790
15792
  get state() {
15791
- switch (ParseUtil.parseBoolean(this.getModelValOrFallback())) {
15792
- case false:
15793
- return ElderCheckboxState.UNCHECKED;
15794
- case true:
15795
- return ElderCheckboxState.CHECKED;
15796
- case undefined:
15797
- return ElderCheckboxState.INDETERMINATE;
15798
- }
15793
+ return this.controlValueToState(this.readControlValue());
15799
15794
  }
15800
15795
  set state(newState) {
15801
15796
  switch (newState) {
@@ -15815,6 +15810,16 @@ class ElderTripleStateCheckboxDirective {
15815
15810
  * Private methods *
15816
15811
  * *
15817
15812
  **************************************************************************/
15813
+ controlValueToState(value) {
15814
+ switch (ParseUtil.parseBoolOrUndefined(value)) {
15815
+ case false:
15816
+ return ElderCheckboxState.UNCHECKED;
15817
+ case true:
15818
+ return ElderCheckboxState.CHECKED;
15819
+ case undefined:
15820
+ return ElderCheckboxState.INDETERMINATE;
15821
+ }
15822
+ }
15818
15823
  toggleNextState() {
15819
15824
  this.state = (this.state + 1) % 3;
15820
15825
  }
@@ -15835,8 +15840,8 @@ class ElderTripleStateCheckboxDirective {
15835
15840
  this.checkbox.indeterminate = true;
15836
15841
  this.updateModelIfPresent(undefined);
15837
15842
  }
15838
- getModelValOrFallback() {
15839
- if (this.ngModel !== null) {
15843
+ readControlValue() {
15844
+ if (this.ngModel) {
15840
15845
  return this.ngModel.viewModel;
15841
15846
  }
15842
15847
  else {
@@ -15845,7 +15850,12 @@ class ElderTripleStateCheckboxDirective {
15845
15850
  }
15846
15851
  updateModelIfPresent(val) {
15847
15852
  if (this.ngModel !== null) {
15848
- this.ngModel.viewToModelUpdate(val);
15853
+ this.ngModel.control.setValue(val, {
15854
+ onlySelf: false,
15855
+ emitEvent: true,
15856
+ emitModelToViewChange: true,
15857
+ emitViewToModelChange: true
15858
+ });
15849
15859
  }
15850
15860
  }
15851
15861
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ElderTripleStateCheckboxDirective, deps: [{ token: i1$8.MatCheckbox }, { token: i3.NgModel, optional: true }], target: i0.ɵɵFactoryTarget.Directive }); }
@@ -26125,7 +26135,9 @@ class ElderSearchContextDirective {
26125
26135
  * Returns the current user touched attributes. (ignoring fallbacks)
26126
26136
  */
26127
26137
  get userDefinedAttributes$() {
26128
- return this.states$.pipe(map(states => states.filter(s => !s.pristine)));
26138
+ return this.states$.pipe(map(states => states
26139
+ .filter(s => !s.pristine)
26140
+ .filter(s => !s.hasFallbackValue)));
26129
26141
  }
26130
26142
  /***************************************************************************
26131
26143
  * *
@@ -26171,6 +26183,7 @@ class ElderSearchContextDirective {
26171
26183
  }
26172
26184
  syncSearchInputsToSearchContext() {
26173
26185
  this._searchInputs$.pipe(takeUntilDestroyed(this.destroyRef), switchMap$1(inputs => combineLatest(inputs.map(i => i.state$))), debounceTime(5)).subscribe(states => {
26186
+ /// this.log.error('SearchInputStates Changed: ', states);
26174
26187
  this._searchStates$.next(states);
26175
26188
  });
26176
26189
  const inputFilters$ = this._searchStates$.pipe(map(states => this.convertToFilters(states)), filter(filters => filters.length > 0));
@@ -26222,7 +26235,7 @@ class ElderSearchContextDirective {
26222
26235
  }
26223
26236
  convertToFilters(states) {
26224
26237
  return states
26225
- .filter(s => s.userEvent)
26238
+ .filter(s => (s.userEvent || s.hasFallbackValue))
26226
26239
  .filter(s => !!s.queryKey)
26227
26240
  .map(s => new Filter(s.queryKey, s.queryValue));
26228
26241
  }
@@ -26313,6 +26326,9 @@ class SearchInputState {
26313
26326
  get hasValue() {
26314
26327
  return SearchInputState.isValueDefined(this.queryValue);
26315
26328
  }
26329
+ get hasFallbackValue() {
26330
+ return this.hasValue && this.pristine;
26331
+ }
26316
26332
  /***************************************************************************
26317
26333
  * *
26318
26334
  * Public Api *
@@ -26429,7 +26445,7 @@ class ElderSearchInputDirective {
26429
26445
  }
26430
26446
  ngAfterViewInit() {
26431
26447
  this._extractedName = this.extractName();
26432
- this.log.debug(this._extractedName + "|" + this.queryKey + "|" + this.resolvePath);
26448
+ this.log.debug(this._extractedName + '|' + this.queryKey + '|' + this.resolvePath);
26433
26449
  }
26434
26450
  ngOnDestroy() {
26435
26451
  this.destroy$.next();
@@ -26450,8 +26466,8 @@ class ElderSearchInputDirective {
26450
26466
  if (this._extractedName) {
26451
26467
  return this._extractedName;
26452
26468
  }
26453
- throw new Error("Could not determine the search name key name." +
26454
- " Either specify the name property or explicitly set [elderSearchInputKey].");
26469
+ throw new Error('Could not determine the search name key name.' +
26470
+ ' Either specify the name property or explicitly set [elderSearchInputKey].');
26455
26471
  }
26456
26472
  get value() {
26457
26473
  return this.ngModel.value;
@@ -26494,7 +26510,12 @@ class ElderSearchInputDirective {
26494
26510
  }
26495
26511
  buildInputState(controlValue, userEvent) {
26496
26512
  const queryValue = this.convertRawModelValueToQueryString(controlValue);
26497
- const pristine = !this.isAttributeValuePresent(controlValue);
26513
+ let pristine = !this.isAttributeValuePresent(controlValue);
26514
+ if (this.hasFallback) {
26515
+ if (this.fallbackValue === queryValue) {
26516
+ pristine = true;
26517
+ }
26518
+ }
26498
26519
  return new SearchInputState(this.name, queryValue, this.queryKey || this.name, pristine, userEvent);
26499
26520
  }
26500
26521
  convertQueryStringToRawModelValue(queryString) {
@@ -26534,14 +26555,14 @@ class ElderSearchInputDirective {
26534
26555
  return value;
26535
26556
  }
26536
26557
  convertEmptyStringToNull(value) {
26537
- if (typeof value === "string" && value.length === 0) {
26558
+ if (typeof value === 'string' && value.length === 0) {
26538
26559
  return null;
26539
26560
  }
26540
26561
  return value;
26541
26562
  }
26542
26563
  isAttributeValuePresent(value) {
26543
26564
  return SearchInputState.isValueDefined(value)
26544
- && (value + "").length !== 0;
26565
+ && (value + '').length !== 0;
26545
26566
  }
26546
26567
  resolveValue(value) {
26547
26568
  if (Objects.nonNull(value)) {
@@ -26596,29 +26617,29 @@ class ElderSearchInputDirective {
26596
26617
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ElderSearchInputDirective, decorators: [{
26597
26618
  type: Directive,
26598
26619
  args: [{
26599
- selector: "[elderSearchInput]",
26600
- exportAs: "elderSearchInput"
26620
+ selector: '[elderSearchInput]',
26621
+ exportAs: 'elderSearchInput'
26601
26622
  }]
26602
26623
  }], ctorParameters: function () { return [{ type: ElderSearchContextDirective }, { type: i3.NgModel, decorators: [{
26603
26624
  type: Host
26604
26625
  }] }]; }, propDecorators: { queryKey: [{
26605
26626
  type: Input,
26606
- args: ["elderSearchInputKey"]
26627
+ args: ['elderSearchInputKey']
26607
26628
  }], valueTransform: [{
26608
26629
  type: Input,
26609
- args: ["elderSearchInputTransform"]
26630
+ args: ['elderSearchInputTransform']
26610
26631
  }], resolvePath: [{
26611
26632
  type: Input,
26612
- args: ["elderSearchInput"]
26633
+ args: ['elderSearchInput']
26613
26634
  }], dataSource: [{
26614
26635
  type: Input,
26615
- args: ["dataSource"]
26636
+ args: ['dataSource']
26616
26637
  }], fallbackValue: [{
26617
26638
  type: Input,
26618
- args: ["elderSearchInputFallback"]
26639
+ args: ['elderSearchInputFallback']
26619
26640
  }], valueAsId: [{
26620
26641
  type: Input,
26621
- args: ["valueAsId"]
26642
+ args: ['valueAsId']
26622
26643
  }] } });
26623
26644
 
26624
26645
  class ElderSearchPanelComponent {
@@ -26976,7 +26997,7 @@ class ElderSearchBoxComponent {
26976
26997
  this._dense = false;
26977
26998
  this.autocomplete = 'off';
26978
26999
  this.userFilters$ = searchContextDirective.userDefinedAttributes$.pipe(
26979
- //switchMap(ctx => ctx.userFilters.filters)
27000
+ // tap(attrs => this.logger.error('Attrs', attrs))
26980
27001
  );
26981
27002
  }
26982
27003
  /***************************************************************************