@hmcts/rpx-xui-common-lib 2.0.25 → 2.0.26
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.
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
2
|
import { FormControl, FormGroup } from '@angular/forms';
|
|
3
3
|
import { iif, of } from 'rxjs';
|
|
4
|
-
import { debounceTime, map, switchMap, tap } from 'rxjs/operators';
|
|
4
|
+
import { catchError, debounceTime, map, switchMap, tap } from 'rxjs/operators';
|
|
5
5
|
import { BookingCheckType } from '../../models';
|
|
6
6
|
import { LocationService } from '../../services/locations/location.service';
|
|
7
7
|
import { RefDataService } from '../../services/ref-data';
|
|
@@ -108,7 +108,10 @@ export class SearchLocationComponent {
|
|
|
108
108
|
else {
|
|
109
109
|
this.filteredList$ = searchInputChanges$.pipe(
|
|
110
110
|
// Debounce needed to prevent multiple API calls being made
|
|
111
|
-
debounceTime(this.debounceTimeInput), switchMap((term) => iif(() => (!!term && term.length >= this.minSearchCharacters), this.getLocations(term).pipe(map((locations) => this.filterUnselectedLocations(locations, this.selectedLocations, this.singleMode))
|
|
111
|
+
debounceTime(this.debounceTimeInput), switchMap((term) => iif(() => (!!term && term.length >= this.minSearchCharacters), this.getLocations(term).pipe(map((locations) => this.filterUnselectedLocations(locations, this.selectedLocations, this.singleMode)), catchError(() => {
|
|
112
|
+
// returns false so the user is not shown the no results found message
|
|
113
|
+
return of(false);
|
|
114
|
+
})), of(false))));
|
|
112
115
|
}
|
|
113
116
|
if (this.singleMode && this.selectedLocations.length > 0) {
|
|
114
117
|
const location = this.selectedLocations[0];
|
|
@@ -234,4 +237,4 @@ export class SearchLocationComponent {
|
|
|
234
237
|
type: Input
|
|
235
238
|
}] }); })();
|
|
236
239
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(SearchLocationComponent, { className: "SearchLocationComponent", filePath: "lib/components/search-location/search-location.component.ts", lineNumber: 20 }); })();
|
|
237
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search-location.component.js","sourceRoot":"","sources":["../../../../../../projects/exui-common-lib/src/lib/components/search-location/search-location.component.ts","../../../../../../projects/exui-common-lib/src/lib/components/search-location/search-location.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { FormControl, FormGroup } from '@angular/forms';\nimport { iif, Observable, of } from 'rxjs';\nimport { debounceTime, map, switchMap, tap } from 'rxjs/operators';\nimport {\n  BookingCheckType, FilterConfigOption,\n  FilterFieldConfig,\n  LocationByEPIMMSModel,\n  LocationsByService\n} from '../../models';\nimport { LocationService } from '../../services/locations/location.service';\nimport { RefDataService } from '../../services/ref-data';\nimport { SessionStorageService } from '../../services/storage/session-storage/session-storage.service';\n\n@Component({\n  selector: 'exui-search-location',\n  templateUrl: './search-location.component.html',\n  styleUrls: ['./search-location.component.scss']\n})\nexport class SearchLocationComponent implements OnInit {\n  private static readonly allLocationAPI = `api/locations/getLocations`;\n  @Input() public form: FormGroup;\n  @Input() public field: FilterFieldConfig;\n  @Input() public disabled: boolean = null;\n  @Input() public singleMode: boolean = false;\n  @Input() public locationType: string = '';\n  @Input() public serviceIds: string = '';\n  @Input() public submitted?: boolean = true;\n  @Input() public bookingCheck: BookingCheckType;\n  @Input() public selectedLocations: LocationByEPIMMSModel[] = [];\n  @Input() public propertyNameFilter: keyof LocationByEPIMMSModel = 'site_name';\n  @Input() public delay?: number = 500;\n  @Output() public locationSelected = new EventEmitter<LocationByEPIMMSModel>();\n  @Output() public locationTermSearchInputChanged: EventEmitter<string> = new EventEmitter<string>();\n  @Output() public searchLocationChanged: EventEmitter<void> = new EventEmitter<void>();\n  public searchTermFormControl = new FormControl('');\n  public readonly minSearchCharacters = 3;\n  public term: string = '';\n  private pReset: boolean = true;\n  public filteredList$: Observable<LocationByEPIMMSModel[] | boolean>;\n  private readonly debounceTimeInput = 300;\n  public previousValue = '';\n\n  public get reset(): boolean {\n    return this.pReset;\n  }\n\n  @Input()\n  public set reset(value: boolean) {\n    this.pReset = value;\n    this.resetSearchTerm();\n  }\n\n  constructor(private readonly locationService: LocationService,\n    private readonly sessionStorageService: SessionStorageService,\n    private readonly refDataService: RefDataService\n  ) { }\n\n  public ngOnInit(): void {\n    const searchInputChanges$ = this.searchTermFormControl.valueChanges\n      .pipe(\n        tap((term) => this.locationTermSearchInputChanged.emit(term))\n      );\n\n    // if servicesField exists, then we should filter locations by the service codes\n    if (this.field && this.field.servicesField) {\n      this.filteredList$ = searchInputChanges$.pipe(\n        switchMap((term: string) => iif(\n          // Seems more responsive to do length 0 if locationsByServiceCodes are cached\n          () => (!!term && term.length >= 0),\n          this.refDataService.getLocationsByServiceCodes(\n            (this.form.get(this.field.servicesField)?.value as FilterConfigOption[]).map((service) => service.key)\n          ).pipe(\n            // Filter locations by the search input term and the chosen property name\n            map((locations) => locations\n              .filter((location) => location[this.propertyNameFilter].toLowerCase().includes(term.toLowerCase()))),\n            // Filter out locations that are already selected\n            map((locations) => this.filterUnselectedLocations(locations, this.selectedLocations, this.singleMode)),\n            // Filter out duplicate locations (by propertyNameFilter)\n            map((locations) => locations.filter((location, index, array) =>\n              index === array.findIndex((item) => item[this.propertyNameFilter] === location[this.propertyNameFilter])\n            )),\n          ),\n          // Returns false if the search term is empty to not show the autocomplete field i.e. ngIf should be false\n          of(false)\n        )),\n      );\n    } else {\n      this.filteredList$ = searchInputChanges$.pipe(\n        // Debounce needed to prevent multiple API calls being made\n        debounceTime(this.debounceTimeInput),\n        switchMap((term: string) => iif(\n          () => (!!term && term.length >= this.minSearchCharacters),\n          this.getLocations(term).pipe(\n            map((locations) => this.filterUnselectedLocations(locations, this.selectedLocations, this.singleMode)),\n          ),\n          of(false)\n        )),\n      );\n    }\n\n    if (this.singleMode && this.selectedLocations.length > 0) {\n      const location = this.selectedLocations[0];\n      this.searchTermFormControl.patchValue(location[this.propertyNameFilter], { emitEvent: false, onlySelf: true });\n    }\n  }\n\n  public onSelectedLocation(location: LocationByEPIMMSModel): void {\n    this.searchTermFormControl.patchValue(location[this.propertyNameFilter], { emitEvent: false, onlySelf: true });\n    this.locationSelected.emit(location);\n  }\n  public onInput(): void {\n    this.searchLocationChanged.emit();\n  }\n\n  public getLocations(term: string): Observable<LocationByEPIMMSModel[]> {\n    let userLocations;\n    // Booking type info - can create more\n    // NO_CHECK - All work - Do not filter out locations - Default assumption\n    // BOOKINGS_AND_BASE - My work - Try to only show base locations/regions\n    // POSSIBLE_BOOKINGS - Create booking screen - Show only potential bookings\n    if (this.bookingCheck === BookingCheckType.BOOKINGS_AND_BASE) {\n      userLocations = JSON.parse(this.sessionStorageService.getItem('userLocations')) as LocationsByService[];\n    } else if (this.bookingCheck === BookingCheckType.POSSIBLE_BOOKINGS) {\n      this.serviceIds = this.serviceIds && this.serviceIds.length ? this.serviceIds : JSON.parse(this.sessionStorageService.getItem('bookableServices'));\n      userLocations = JSON.parse(this.sessionStorageService.getItem('bookableUserLocations')) as LocationsByService[];\n    }\n    // get all locations will resolve filter setting using objects above\n    // if no userLocations, NO_CHECK\n    // if just getting all substantive user locations, BOOKINGS_AND_BASE\n    // fee paid user locations are used for POSSIBLE_BOOKINGS\n    return this.locationService.getAllLocations(SearchLocationComponent.allLocationAPI, this.serviceIds, this.locationType, term, userLocations);\n  }\n\n  public resetSearchTerm(): void {\n    this.searchTermFormControl.setValue('');\n  }\n\n  private filterUnselectedLocations(\n    locations: LocationByEPIMMSModel[],\n    selectedLocations: LocationByEPIMMSModel[],\n    singleMode: boolean\n  ): LocationByEPIMMSModel[] {\n    if (singleMode) {\n      return locations;\n    }\n    return locations.filter(\n      location => !selectedLocations.map(selectedLocation => selectedLocation.epimms_id).includes(location.epimms_id) && location[this.propertyNameFilter]\n    );\n  }\n\n  public removeInvalidString(formInputValue: KeyboardEvent) {\n    if (!this.isCharacterValid(formInputValue)) {\n      formInputValue.preventDefault();\n    }\n  }\n\n  public isCharacterValid(event: KeyboardEvent): boolean {\n    let pressed = undefined\n    if (event.key !== undefined) {\n      pressed = event.key;\n      if (pressed.length > 1) {\n        switch (pressed) {\n          case 'Tab':\n            return true;\n          case 'ArrowRight':\n            return true;\n          case 'ArrowLeft':\n            return true;\n          case 'Backspace':\n            return true;\n          case 'Enter':\n            return true;\n          default: return false;\n        }\n      }\n    } else if (event.keyCode !== undefined) {\n      pressed = String.fromCharCode(event.keyCode);\n    }\n    return pressed && (/[a-zA-Z \\s'-]/).test(pressed);\n  }\n\n}","<div class=\"auto-complete-container\">\n  <input\n    id=\"inputLocationSearch\"\n    #char\n    (keydown)=\"removeInvalidString($event)\"\n    (input)=\"onInput()\"\n    [formControl]=\"searchTermFormControl\"\n    [matAutocomplete]=\"autoSearchLocation\"\n    class=\"govuk-input\"\n    [attr.disabled]=\"disabled\">\n  <mat-autocomplete class=\"mat-autocomplete-panel-extend\" autoActiveFirstOption #autoSearchLocation=\"matAutocomplete\">\n    <ng-container *ngIf=\"filteredList$ | async as filteredList\">\n      <ng-container *ngIf=\"filteredList && filteredList.length >= 0\">\n        <mat-option *ngFor=\"let location of filteredList\" (onSelectionChange)=\"onSelectedLocation(location)\">\n          {{ location[propertyNameFilter] }}\n        </mat-option>\n        <mat-option *ngIf=\"filteredList.length === 0\">{{'No results found' | rpxTranslate}}</mat-option>\n      </ng-container>\n    </ng-container>\n  </mat-autocomplete>\n</div>\n"]}
|
|
240
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search-location.component.js","sourceRoot":"","sources":["../../../../../../projects/exui-common-lib/src/lib/components/search-location/search-location.component.ts","../../../../../../projects/exui-common-lib/src/lib/components/search-location/search-location.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;AAC/E,OAAO,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AACxD,OAAO,EAAE,GAAG,EAAc,EAAE,EAAE,MAAM,MAAM,CAAC;AAC3C,OAAO,EAAE,UAAU,EAAE,YAAY,EAAE,GAAG,EAAE,SAAS,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AAC/E,OAAO,EACL,gBAAgB,EAIjB,MAAM,cAAc,CAAC;AACtB,OAAO,EAAE,eAAe,EAAE,MAAM,2CAA2C,CAAC;AAC5E,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AACzD,OAAO,EAAE,qBAAqB,EAAE,MAAM,gEAAgE,CAAC;;;;;;;;;;;;ICC/F,qCAAqG;IAAnD,mRAAqB,sCAA4B,KAAC;IAClG,YACF;IAAA,iBAAa;;;;IADX,cACF;IADE,uEACF;;;IACA,kCAA8C;IAAA,YAAqC;;IAAA,iBAAa;;IAAlD,cAAqC;IAArC,8DAAqC;;;IAJrF,6BAA+D;IAI7D,AAHA,oHAAqG,uGAGvD;;;;IAHb,cAAe;IAAf,yCAAe;IAGnC,cAA+B;IAA/B,mDAA+B;;;IALhD,6BAA4D;IAC1D,yGAA+D;;;;IAAhD,cAA8C;IAA9C,qEAA8C;;ADOnE,MAAM,OAAO,uBAAuB;aACV,mBAAc,GAAG,4BAA4B,AAA/B,CAAgC;IAuBtE,IAAW,KAAK;QACd,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAED,IACW,KAAK,CAAC,KAAc;QAC7B,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,eAAe,EAAE,CAAC;IACzB,CAAC;IAED,YAA6B,eAAgC,EAC1C,qBAA4C,EAC5C,cAA8B;QAFpB,oBAAe,GAAf,eAAe,CAAiB;QAC1C,0BAAqB,GAArB,qBAAqB,CAAuB;QAC5C,mBAAc,GAAd,cAAc,CAAgB;QAhCjC,aAAQ,GAAY,IAAI,CAAC;QACzB,eAAU,GAAY,KAAK,CAAC;QAC5B,iBAAY,GAAW,EAAE,CAAC;QAC1B,eAAU,GAAW,EAAE,CAAC;QACxB,cAAS,GAAa,IAAI,CAAC;QAE3B,sBAAiB,GAA4B,EAAE,CAAC;QAChD,uBAAkB,GAAgC,WAAW,CAAC;QAC9D,UAAK,GAAY,GAAG,CAAC;QACpB,qBAAgB,GAAG,IAAI,YAAY,EAAyB,CAAC;QAC7D,mCAA8B,GAAyB,IAAI,YAAY,EAAU,CAAC;QAClF,0BAAqB,GAAuB,IAAI,YAAY,EAAQ,CAAC;QAC/E,0BAAqB,GAAG,IAAI,WAAW,CAAC,EAAE,CAAC,CAAC;QACnC,wBAAmB,GAAG,CAAC,CAAC;QACjC,SAAI,GAAW,EAAE,CAAC;QACjB,WAAM,GAAY,IAAI,CAAC;QAEd,sBAAiB,GAAG,GAAG,CAAC;QAClC,kBAAa,GAAG,EAAE,CAAC;IAetB,CAAC;IAEE,QAAQ;QACb,MAAM,mBAAmB,GAAG,IAAI,CAAC,qBAAqB,CAAC,YAAY;aAChE,IAAI,CACH,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,8BAA8B,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAC9D,CAAC;QAEJ,gFAAgF;QAChF,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC;YAC3C,IAAI,CAAC,aAAa,GAAG,mBAAmB,CAAC,IAAI,CAC3C,SAAS,CAAC,CAAC,IAAY,EAAE,EAAE,CAAC,GAAG;YAC7B,6EAA6E;YAC7E,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,IAAI,IAAI,CAAC,MAAM,IAAI,CAAC,CAAC,EAClC,IAAI,CAAC,cAAc,CAAC,0BAA0B,CAC5C,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,EAAE,KAA8B,CAAA,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,CACvG,CAAC,IAAI;YACJ,yEAAyE;YACzE,GAAG,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,SAAS;iBACzB,MAAM,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC;YACtG,iDAAiD;YACjD,GAAG,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,IAAI,CAAC,yBAAyB,CAAC,SAAS,EAAE,IAAI,CAAC,iBAAiB,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;YACtG,yDAAyD;YACzD,GAAG,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,QAAQ,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,CAC7D,KAAK,KAAK,KAAK,CAAC,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,kBAAkB,CAAC,KAAK,QAAQ,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC,CACzG,CAAC,CACH;YACD,yGAAyG;YACzG,EAAE,CAAC,KAAK,CAAC,CACV,CAAC,CACH,CAAC;QACJ,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,aAAa,GAAG,mBAAmB,CAAC,IAAI;YAC3C,2DAA2D;YAC3D,YAAY,CAAC,IAAI,CAAC,iBAAiB,CAAC,EACpC,SAAS,CAAC,CAAC,IAAY,EAAE,EAAE,CAAC,GAAG,CAC7B,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,IAAI,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,mBAAmB,CAAC,EACzD,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,IAAI,CAC1B,GAAG,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,IAAI,CAAC,yBAAyB,CAAC,SAAS,EAAE,IAAI,CAAC,iBAAiB,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC,EACtG,UAAU,CAAC,GAAG,EAAE;gBACd,sEAAsE;gBACtE,OAAO,EAAE,CAAC,KAAK,CAAC,CAAC;YACnB,CAAC,CAAC,CACH,EACD,EAAE,CAAC,KAAK,CAAC,CACV,CAAC,CACH,CAAC;QACJ,CAAC;QAED,IAAI,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,iBAAiB,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACzD,MAAM,QAAQ,GAAG,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC;YAC3C,IAAI,CAAC,qBAAqB,CAAC,UAAU,CAAC,QAAQ,CAAC,IAAI,CAAC,kBAAkB,CAAC,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC;QACjH,CAAC;IACH,CAAC;IAEM,kBAAkB,CAAC,QAA+B;QACvD,IAAI,CAAC,qBAAqB,CAAC,UAAU,CAAC,QAAQ,CAAC,IAAI,CAAC,kBAAkB,CAAC,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC;QAC/G,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACvC,CAAC;IACM,OAAO;QACZ,IAAI,CAAC,qBAAqB,CAAC,IAAI,EAAE,CAAC;IACpC,CAAC;IAEM,YAAY,CAAC,IAAY;QAC9B,IAAI,aAAa,CAAC;QAClB,sCAAsC;QACtC,yEAAyE;QACzE,wEAAwE;QACxE,2EAA2E;QAC3E,IAAI,IAAI,CAAC,YAAY,KAAK,gBAAgB,CAAC,iBAAiB,EAAE,CAAC;YAC7D,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,qBAAqB,CAAC,OAAO,CAAC,eAAe,CAAC,CAAyB,CAAC;QAC1G,CAAC;aAAM,IAAI,IAAI,CAAC,YAAY,KAAK,gBAAgB,CAAC,iBAAiB,EAAE,CAAC;YACpE,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,qBAAqB,CAAC,OAAO,CAAC,kBAAkB,CAAC,CAAC,CAAC;YACnJ,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,qBAAqB,CAAC,OAAO,CAAC,uBAAuB,CAAC,CAAyB,CAAC;QAClH,CAAC;QACD,oEAAoE;QACpE,gCAAgC;QAChC,oEAAoE;QACpE,yDAAyD;QACzD,OAAO,IAAI,CAAC,eAAe,CAAC,eAAe,CAAC,uBAAuB,CAAC,cAAc,EAAE,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,YAAY,EAAE,IAAI,EAAE,aAAa,CAAC,CAAC;IAC/I,CAAC;IAEM,eAAe;QACpB,IAAI,CAAC,qBAAqB,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;IAC1C,CAAC;IAEO,yBAAyB,CAC/B,SAAkC,EAClC,iBAA0C,EAC1C,UAAmB;QAEnB,IAAI,UAAU,EAAE,CAAC;YACf,OAAO,SAAS,CAAC;QACnB,CAAC;QACD,OAAO,SAAS,CAAC,MAAM,CACrB,QAAQ,CAAC,EAAE,CAAC,CAAC,iBAAiB,CAAC,GAAG,CAAC,gBAAgB,CAAC,EAAE,CAAC,gBAAgB,CAAC,SAAS,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,IAAI,QAAQ,CAAC,IAAI,CAAC,kBAAkB,CAAC,CACrJ,CAAC;IACJ,CAAC;IAEM,mBAAmB,CAAC,cAA6B;QACtD,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,cAAc,CAAC,EAAE,CAAC;YAC3C,cAAc,CAAC,cAAc,EAAE,CAAC;QAClC,CAAC;IACH,CAAC;IAEM,gBAAgB,CAAC,KAAoB;QAC1C,IAAI,OAAO,GAAG,SAAS,CAAA;QACvB,IAAI,KAAK,CAAC,GAAG,KAAK,SAAS,EAAE,CAAC;YAC5B,OAAO,GAAG,KAAK,CAAC,GAAG,CAAC;YACpB,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBACvB,QAAQ,OAAO,EAAE,CAAC;oBAChB,KAAK,KAAK;wBACR,OAAO,IAAI,CAAC;oBACd,KAAK,YAAY;wBACf,OAAO,IAAI,CAAC;oBACd,KAAK,WAAW;wBACd,OAAO,IAAI,CAAC;oBACd,KAAK,WAAW;wBACd,OAAO,IAAI,CAAC;oBACd,KAAK,OAAO;wBACV,OAAO,IAAI,CAAC;oBACd,OAAO,CAAC,CAAC,OAAO,KAAK,CAAC;gBACxB,CAAC;YACH,CAAC;QACH,CAAC;aAAM,IAAI,KAAK,CAAC,OAAO,KAAK,SAAS,EAAE,CAAC;YACvC,OAAO,GAAG,MAAM,CAAC,YAAY,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QAC/C,CAAC;QACD,OAAO,OAAO,IAAI,CAAC,eAAe,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACpD,CAAC;wFArKU,uBAAuB;oEAAvB,uBAAuB;;YClBlC,AADF,8BAAqC,kBASN;YAJ3B,AADA,mJAAW,+BAA2B,KAAC,4HAC9B,aAAS,KAAC;YAJrB,iBAQ6B;YAC7B,8CAAoH;YAClH,0FAA4D;;YAShE,AADE,iBAAmB,EACf;;;YAdF,cAAqC;YACrC,AADA,uDAAqC,0CACC;;YAIvB,eAA4B;YAA5B,8DAA4B;;;iFDQlC,uBAAuB;cALnC,SAAS;2BACE,sBAAsB;iHAMhB,IAAI;kBAAnB,KAAK;YACU,KAAK;kBAApB,KAAK;YACU,QAAQ;kBAAvB,KAAK;YACU,UAAU;kBAAzB,KAAK;YACU,YAAY;kBAA3B,KAAK;YACU,UAAU;kBAAzB,KAAK;YACU,SAAS;kBAAxB,KAAK;YACU,YAAY;kBAA3B,KAAK;YACU,iBAAiB;kBAAhC,KAAK;YACU,kBAAkB;kBAAjC,KAAK;YACU,KAAK;kBAApB,KAAK;YACW,gBAAgB;kBAAhC,MAAM;YACU,8BAA8B;kBAA9C,MAAM;YACU,qBAAqB;kBAArC,MAAM;YAcI,KAAK;kBADf,KAAK;;kFA5BK,uBAAuB","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { FormControl, FormGroup } from '@angular/forms';\nimport { iif, Observable, of } from 'rxjs';\nimport { catchError, debounceTime, map, switchMap, tap } from 'rxjs/operators';\nimport {\n  BookingCheckType, FilterConfigOption,\n  FilterFieldConfig,\n  LocationByEPIMMSModel,\n  LocationsByService\n} from '../../models';\nimport { LocationService } from '../../services/locations/location.service';\nimport { RefDataService } from '../../services/ref-data';\nimport { SessionStorageService } from '../../services/storage/session-storage/session-storage.service';\n\n@Component({\n  selector: 'exui-search-location',\n  templateUrl: './search-location.component.html',\n  styleUrls: ['./search-location.component.scss']\n})\nexport class SearchLocationComponent implements OnInit {\n  private static readonly allLocationAPI = `api/locations/getLocations`;\n  @Input() public form: FormGroup;\n  @Input() public field: FilterFieldConfig;\n  @Input() public disabled: boolean = null;\n  @Input() public singleMode: boolean = false;\n  @Input() public locationType: string = '';\n  @Input() public serviceIds: string = '';\n  @Input() public submitted?: boolean = true;\n  @Input() public bookingCheck: BookingCheckType;\n  @Input() public selectedLocations: LocationByEPIMMSModel[] = [];\n  @Input() public propertyNameFilter: keyof LocationByEPIMMSModel = 'site_name';\n  @Input() public delay?: number = 500;\n  @Output() public locationSelected = new EventEmitter<LocationByEPIMMSModel>();\n  @Output() public locationTermSearchInputChanged: EventEmitter<string> = new EventEmitter<string>();\n  @Output() public searchLocationChanged: EventEmitter<void> = new EventEmitter<void>();\n  public searchTermFormControl = new FormControl('');\n  public readonly minSearchCharacters = 3;\n  public term: string = '';\n  private pReset: boolean = true;\n  public filteredList$: Observable<LocationByEPIMMSModel[] | boolean>;\n  private readonly debounceTimeInput = 300;\n  public previousValue = '';\n\n  public get reset(): boolean {\n    return this.pReset;\n  }\n\n  @Input()\n  public set reset(value: boolean) {\n    this.pReset = value;\n    this.resetSearchTerm();\n  }\n\n  constructor(private readonly locationService: LocationService,\n    private readonly sessionStorageService: SessionStorageService,\n    private readonly refDataService: RefDataService\n  ) { }\n\n  public ngOnInit(): void {\n    const searchInputChanges$ = this.searchTermFormControl.valueChanges\n      .pipe(\n        tap((term) => this.locationTermSearchInputChanged.emit(term))\n      );\n\n    // if servicesField exists, then we should filter locations by the service codes\n    if (this.field && this.field.servicesField) {\n      this.filteredList$ = searchInputChanges$.pipe(\n        switchMap((term: string) => iif(\n          // Seems more responsive to do length 0 if locationsByServiceCodes are cached\n          () => (!!term && term.length >= 0),\n          this.refDataService.getLocationsByServiceCodes(\n            (this.form.get(this.field.servicesField)?.value as FilterConfigOption[]).map((service) => service.key)\n          ).pipe(\n            // Filter locations by the search input term and the chosen property name\n            map((locations) => locations\n              .filter((location) => location[this.propertyNameFilter].toLowerCase().includes(term.toLowerCase()))),\n            // Filter out locations that are already selected\n            map((locations) => this.filterUnselectedLocations(locations, this.selectedLocations, this.singleMode)),\n            // Filter out duplicate locations (by propertyNameFilter)\n            map((locations) => locations.filter((location, index, array) =>\n              index === array.findIndex((item) => item[this.propertyNameFilter] === location[this.propertyNameFilter])\n            )),\n          ),\n          // Returns false if the search term is empty to not show the autocomplete field i.e. ngIf should be false\n          of(false)\n        )),\n      );\n    } else {\n      this.filteredList$ = searchInputChanges$.pipe(\n        // Debounce needed to prevent multiple API calls being made\n        debounceTime(this.debounceTimeInput),\n        switchMap((term: string) => iif(\n          () => (!!term && term.length >= this.minSearchCharacters),\n          this.getLocations(term).pipe(\n            map((locations) => this.filterUnselectedLocations(locations, this.selectedLocations, this.singleMode)),\n            catchError(() => {\n              // returns false so the user is not shown the no results found message\n              return of(false);\n            }),\n          ),\n          of(false)\n        )),\n      );\n    }\n\n    if (this.singleMode && this.selectedLocations.length > 0) {\n      const location = this.selectedLocations[0];\n      this.searchTermFormControl.patchValue(location[this.propertyNameFilter], { emitEvent: false, onlySelf: true });\n    }\n  }\n\n  public onSelectedLocation(location: LocationByEPIMMSModel): void {\n    this.searchTermFormControl.patchValue(location[this.propertyNameFilter], { emitEvent: false, onlySelf: true });\n    this.locationSelected.emit(location);\n  }\n  public onInput(): void {\n    this.searchLocationChanged.emit();\n  }\n\n  public getLocations(term: string): Observable<LocationByEPIMMSModel[]> {\n    let userLocations;\n    // Booking type info - can create more\n    // NO_CHECK - All work - Do not filter out locations - Default assumption\n    // BOOKINGS_AND_BASE - My work - Try to only show base locations/regions\n    // POSSIBLE_BOOKINGS - Create booking screen - Show only potential bookings\n    if (this.bookingCheck === BookingCheckType.BOOKINGS_AND_BASE) {\n      userLocations = JSON.parse(this.sessionStorageService.getItem('userLocations')) as LocationsByService[];\n    } else if (this.bookingCheck === BookingCheckType.POSSIBLE_BOOKINGS) {\n      this.serviceIds = this.serviceIds && this.serviceIds.length ? this.serviceIds : JSON.parse(this.sessionStorageService.getItem('bookableServices'));\n      userLocations = JSON.parse(this.sessionStorageService.getItem('bookableUserLocations')) as LocationsByService[];\n    }\n    // get all locations will resolve filter setting using objects above\n    // if no userLocations, NO_CHECK\n    // if just getting all substantive user locations, BOOKINGS_AND_BASE\n    // fee paid user locations are used for POSSIBLE_BOOKINGS\n    return this.locationService.getAllLocations(SearchLocationComponent.allLocationAPI, this.serviceIds, this.locationType, term, userLocations);\n  }\n\n  public resetSearchTerm(): void {\n    this.searchTermFormControl.setValue('');\n  }\n\n  private filterUnselectedLocations(\n    locations: LocationByEPIMMSModel[],\n    selectedLocations: LocationByEPIMMSModel[],\n    singleMode: boolean\n  ): LocationByEPIMMSModel[] {\n    if (singleMode) {\n      return locations;\n    }\n    return locations.filter(\n      location => !selectedLocations.map(selectedLocation => selectedLocation.epimms_id).includes(location.epimms_id) && location[this.propertyNameFilter]\n    );\n  }\n\n  public removeInvalidString(formInputValue: KeyboardEvent) {\n    if (!this.isCharacterValid(formInputValue)) {\n      formInputValue.preventDefault();\n    }\n  }\n\n  public isCharacterValid(event: KeyboardEvent): boolean {\n    let pressed = undefined\n    if (event.key !== undefined) {\n      pressed = event.key;\n      if (pressed.length > 1) {\n        switch (pressed) {\n          case 'Tab':\n            return true;\n          case 'ArrowRight':\n            return true;\n          case 'ArrowLeft':\n            return true;\n          case 'Backspace':\n            return true;\n          case 'Enter':\n            return true;\n          default: return false;\n        }\n      }\n    } else if (event.keyCode !== undefined) {\n      pressed = String.fromCharCode(event.keyCode);\n    }\n    return pressed && (/[a-zA-Z \\s'-]/).test(pressed);\n  }\n\n}","<div class=\"auto-complete-container\">\n  <input\n    id=\"inputLocationSearch\"\n    #char\n    (keydown)=\"removeInvalidString($event)\"\n    (input)=\"onInput()\"\n    [formControl]=\"searchTermFormControl\"\n    [matAutocomplete]=\"autoSearchLocation\"\n    class=\"govuk-input\"\n    [attr.disabled]=\"disabled\">\n  <mat-autocomplete class=\"mat-autocomplete-panel-extend\" autoActiveFirstOption #autoSearchLocation=\"matAutocomplete\">\n    <ng-container *ngIf=\"filteredList$ | async as filteredList\">\n      <ng-container *ngIf=\"filteredList && filteredList.length >= 0\">\n        <mat-option *ngFor=\"let location of filteredList\" (onSelectionChange)=\"onSelectedLocation(location)\">\n          {{ location[propertyNameFilter] }}\n        </mat-option>\n        <mat-option *ngIf=\"filteredList.length === 0\">{{'No results found' | rpxTranslate}}</mat-option>\n      </ng-container>\n    </ng-container>\n  </mat-autocomplete>\n</div>\n"]}
|
|
@@ -2581,7 +2581,10 @@ class SearchLocationComponent {
|
|
|
2581
2581
|
else {
|
|
2582
2582
|
this.filteredList$ = searchInputChanges$.pipe(
|
|
2583
2583
|
// Debounce needed to prevent multiple API calls being made
|
|
2584
|
-
debounceTime(this.debounceTimeInput), switchMap((term) => iif(() => (!!term && term.length >= this.minSearchCharacters), this.getLocations(term).pipe(map((locations) => this.filterUnselectedLocations(locations, this.selectedLocations, this.singleMode))
|
|
2584
|
+
debounceTime(this.debounceTimeInput), switchMap((term) => iif(() => (!!term && term.length >= this.minSearchCharacters), this.getLocations(term).pipe(map((locations) => this.filterUnselectedLocations(locations, this.selectedLocations, this.singleMode)), catchError(() => {
|
|
2585
|
+
// returns false so the user is not shown the no results found message
|
|
2586
|
+
return of$1(false);
|
|
2587
|
+
})), of$1(false))));
|
|
2585
2588
|
}
|
|
2586
2589
|
if (this.singleMode && this.selectedLocations.length > 0) {
|
|
2587
2590
|
const location = this.selectedLocations[0];
|