@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.
- package/esm2022/lib/components/forms/search/domain/context/search-context.mjs +10 -16
- package/esm2022/lib/components/forms/search/domain/input/search-input-state.mjs +4 -1
- package/esm2022/lib/components/forms/search/elder-search-context.directive.mjs +18 -18
- package/esm2022/lib/components/forms/search/elder-search-input.directive.mjs +27 -22
- package/esm2022/lib/components/forms/search/search-box/elder-search-box.component.mjs +2 -2
- package/fesm2022/elderbyte-ngx-starter.mjs +46 -44
- package/fesm2022/elderbyte-ngx-starter.mjs.map +1 -1
- package/lib/components/forms/search/domain/context/search-context.d.ts +1 -2
- package/lib/components/forms/search/domain/input/search-input-state.d.ts +1 -0
- package/lib/components/forms/search/elder-search-context.directive.d.ts +4 -5
- package/lib/components/forms/search/elder-search-input.directive.d.ts +8 -8
- package/package.json +1 -1
|
@@ -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
|
-
//
|
|
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
|
-
|
|
25958
|
+
/***************************************************************************
|
|
25959
|
+
* *
|
|
25960
|
+
* Public API *
|
|
25961
|
+
* *
|
|
25962
|
+
**************************************************************************/
|
|
25963
|
+
updateUserFiltersSave(filters) {
|
|
25964
25964
|
// this.log.error('updateDefaultFilters, acceptDefaultFilters: ' + this.acceptDefaultFilters, filters);
|
|
25965
|
-
|
|
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(
|
|
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
|
|
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.
|
|
26172
|
+
dcFilters.filters.pipe(takeUntilDestroyed(this.destroyRef), map(filters => searchContext.updateUserFiltersSave(filters))).subscribe();
|
|
26180
26173
|
}
|
|
26181
26174
|
syncSearchInputsToSearchContext() {
|
|
26182
|
-
this._searchInputs$.pipe(
|
|
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(
|
|
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(
|
|
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 +
|
|
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(
|
|
26463
|
-
|
|
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
|
-
|
|
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 ===
|
|
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 +
|
|
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:
|
|
26609
|
-
exportAs:
|
|
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: [
|
|
26617
|
+
args: ['elderSearchInputKey']
|
|
26616
26618
|
}], valueTransform: [{
|
|
26617
26619
|
type: Input,
|
|
26618
|
-
args: [
|
|
26620
|
+
args: ['elderSearchInputTransform']
|
|
26619
26621
|
}], resolvePath: [{
|
|
26620
26622
|
type: Input,
|
|
26621
|
-
args: [
|
|
26623
|
+
args: ['elderSearchInput']
|
|
26622
26624
|
}], dataSource: [{
|
|
26623
26625
|
type: Input,
|
|
26624
|
-
args: [
|
|
26626
|
+
args: ['dataSource']
|
|
26625
26627
|
}], fallbackValue: [{
|
|
26626
26628
|
type: Input,
|
|
26627
|
-
args: [
|
|
26629
|
+
args: ['elderSearchInputFallback']
|
|
26628
26630
|
}], valueAsId: [{
|
|
26629
26631
|
type: Input,
|
|
26630
|
-
args: [
|
|
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
|
-
//
|
|
26990
|
+
// tap(attrs => this.logger.error('Attrs', attrs))
|
|
26989
26991
|
);
|
|
26990
26992
|
}
|
|
26991
26993
|
/***************************************************************************
|