@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.
- package/esm2022/lib/common/utils/parse-util.mjs +5 -4
- package/esm2022/lib/components/forms/directives/elder-triple-state-checkbox.directive.mjs +22 -12
- 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 +6 -3
- 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 +52 -31
- package/fesm2022/elderbyte-ngx-starter.mjs.map +1 -1
- package/lib/common/utils/parse-util.d.ts +3 -2
- package/lib/components/forms/directives/elder-triple-state-checkbox.directive.d.ts +3 -1
- package/lib/components/forms/search/domain/input/search-input-state.d.ts +1 -0
- 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"]}
|
|
@@ -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
|
|
7451
|
+
* @return undefined, if the value is null/undefined/empty
|
|
7452
|
+
* @return false, if the value is false, else true.
|
|
7452
7453
|
*/
|
|
7453
|
-
static
|
|
7454
|
-
if (bool === undefined || bool
|
|
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
|
-
|
|
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
|
-
|
|
15839
|
-
if (this.ngModel
|
|
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.
|
|
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
|
|
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 +
|
|
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(
|
|
26454
|
-
|
|
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
|
-
|
|
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 ===
|
|
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 +
|
|
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:
|
|
26600
|
-
exportAs:
|
|
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: [
|
|
26627
|
+
args: ['elderSearchInputKey']
|
|
26607
26628
|
}], valueTransform: [{
|
|
26608
26629
|
type: Input,
|
|
26609
|
-
args: [
|
|
26630
|
+
args: ['elderSearchInputTransform']
|
|
26610
26631
|
}], resolvePath: [{
|
|
26611
26632
|
type: Input,
|
|
26612
|
-
args: [
|
|
26633
|
+
args: ['elderSearchInput']
|
|
26613
26634
|
}], dataSource: [{
|
|
26614
26635
|
type: Input,
|
|
26615
|
-
args: [
|
|
26636
|
+
args: ['dataSource']
|
|
26616
26637
|
}], fallbackValue: [{
|
|
26617
26638
|
type: Input,
|
|
26618
|
-
args: [
|
|
26639
|
+
args: ['elderSearchInputFallback']
|
|
26619
26640
|
}], valueAsId: [{
|
|
26620
26641
|
type: Input,
|
|
26621
|
-
args: [
|
|
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
|
-
//
|
|
27000
|
+
// tap(attrs => this.logger.error('Attrs', attrs))
|
|
26980
27001
|
);
|
|
26981
27002
|
}
|
|
26982
27003
|
/***************************************************************************
|