@norwegian/core-components 7.13.5 → 7.14.0

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.
@@ -495,4 +495,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
495
495
  type: HostListener,
496
496
  args: ["window:resize", ["$event"]]
497
497
  }] } });
498
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"airport-select.component.js","sourceRoot":"","sources":["../../../../../../projects/core-components/src/lib/components/airport-select/airport-select.component.ts","../../../../../../projects/core-components/src/lib/components/airport-select/airport-select.component.html"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Norwegian Air Shuttle. All Rights Reserved.\n */\n\nimport { AirportModel } from './models/airport.model';\nimport { ClassModel } from '../../core/models/class.model';\nimport {\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  ViewEncapsulation,\n  ViewChild,\n  ElementRef,\n  OnInit,\n  AfterViewInit,\n  HostListener,\n  ChangeDetectorRef\n} from '@angular/core';\nimport { FormGroup } from '@angular/forms';\nimport { NasComponentBase } from '../../core';\nimport { ResultsLabelsModel } from './models/results-labels.model';\nimport { AirportSelectDropdownComponent } from './airport-select-dropdown/airport-select-dropdown.component';\nimport { DeviceHelper } from '../../core/services/device/device-helper.service';\n\n/**\n * @description\n * Norwegian Airport Select Component | Functional | New design\n */\n@Component({\n  selector: 'nas-airport-select',\n  templateUrl: './airport-select.component.html',\n  styleUrls: ['./airport-select.component.scss'],\n  encapsulation: ViewEncapsulation.None\n})\nexport class AirportSelectComponent extends NasComponentBase implements OnInit, AfterViewInit {\n  airportsOrigin: Array<AirportModel>;\n  airportsDestination = new Array<AirportModel>();\n  currentLatestSearchesDestination: Array<AirportModel>;\n  closestAirportsDestination: Array<AirportModel>;\n  focusDestination = false;\n  textSelectOriginFirst: string;\n  focusedLatestSearchesAirportCodeDestination: string;\n  focusedAirportCodeDestination: string;\n  focusedLatestSearchesIndexDestination = -1;\n  focusedAirportIndexDestination = -1;\n  switchType = 'switch';\n  isDestinationValid: boolean;\n  inlineFlex = false;\n  noDestinationAirportsAvailable: boolean;\n\n  resultsLabels: ResultsLabelsModel = {\n    allAirports: '',\n    closestAirports: '',\n    latestSearches: '',\n    geolocation: '',\n    geolocationDenied: '',\n    noAirports: ''\n  };\n\n  originOpen = false;\n  destinationOpen = false;\n  cleared = false;\n\n  @ViewChild('container') container: ElementRef;\n  @ViewChild('switchButton') switchButton: ElementRef;\n  @ViewChild('airportSelectDropdownOrigin') airportSelectDropdownOrigin: ElementRef;\n  @ViewChild('airportSelectDropdownDestination') airportSelectDropdownDestination: AirportSelectDropdownComponent;\n\n  origin: AirportModel;\n  destination: AirportModel;\n\n  /**\n   * @property Input\n   * @description\n   * The outbound aiport select ID of the native input element\n   */\n  @Input() outboundId: string;\n\n  /**\n  * @property Input\n  * @description\n  * The inbound aiport select ID of the native input element\n  */\n  @Input() inboundId: string;\n\n  /**\n   * @property Input\n   * @required\n   * @description\n   * All airports that will be populated into the dropdown lists.\n   */\n  @Input() airports: Array<AirportModel>;\n\n  /**\n   * @property Input\n   * @description\n   * A record containing keys with all airport codes with corresponding array of airport codes connected to the key.\n   */\n  @Input() airportRelations: Record<string, Array<string>>;\n\n  /**\n   * @property Input\n   * @description\n   * An array of origin airports that the user has allready search for.\n   */\n  @Input() latestSearchesOrigin: Array<AirportModel>;\n\n  /**\n   * @property Input\n   * @description\n   * An array of destination airports that the user has allready search for.\n   */\n  @Input() latestSearchesDestination: Array<AirportModel>;\n\n  /**\n   * @property Input\n   * @description\n   * An array of airports that are close to the user.\n   */\n  @Input() closestAirports: Array<AirportModel>;\n\n  /**\n   * @property Input\n   * @description\n   * A list of airports that should be displayed in the origin dropdown.\n   * If not included, all airports will be displayed.\n   */\n  @Input() allowedOriginAiports: Array<AirportModel>;\n\n  /**\n   * @property Input\n   * @description\n   * An array of airports that are restricted for destination airports. It will default to airports if not set.\n   */\n  @Input() allowedDestinationAirports: Array<AirportModel>;\n\n  /**\n   * @property Input\n   * @description\n   * A boolean indicating if airports that the user allready has searh for should be displayed.\n   */\n  @Input() displayLatestSearches?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * A boolean indicating if airports that are close to the user should be displayed.\n   */\n  @Input() displayClosestAirports?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Display both orgin and destination airport selector.\n   */\n  @Input() combo?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Display switch UI to interchange origin and destination airport.\n   */\n  @Input() useSwitch?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * A label that will appear on top of all airports in the drop down list.\n   */\n  @Input() allAirportsLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * A label that will appear on top of the latest searches in the drop down list.\n   */\n  @Input() latestSearchesLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * A label that will appear on top of the closest airports in the drop down list.\n   */\n  @Input() closestAirportsLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * A label that will appear in my location in the drop down list.\n   */\n  @Input() geolocationLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * A label that will appear in my location, in the drop down list if user has denied geolocation.\n   */\n  @Input() geolocationBlockedLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * A label that will appear in the destination input field if the\n   * user tries to select a destination airport without selecting an origin airport.\n   */\n  @Input() selectOriginFirstLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * A label that appear in the list that there is currently no airports\n   */\n  @Input() noAirportsLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * A text that appears in the destinations dropdown list when origin airport is not set.\n   */\n  @Input() invalidDestinationText: string;\n\n  /**\n   * @property Input\n   * @required\n   * @description\n   * A label that will appear on top of the origin airport input field.\n   */\n  @Input() labelOrigin = '';\n\n  /**\n   * @property Input\n   * @description\n   * A placeholder that will appear on the origin airport input field.\n   */\n  @Input() placeholderOrigin = '';\n\n  /**\n   * @property Input\n   * @description\n   * A label that will appear on top of the destination airport input field.\n   */\n  @Input() labelDestination = '';\n\n  /**\n   * @property Input\n   * @description\n   * A placeholder that will appear on the destination airport input field.\n   */\n  @Input() placeholderDestination = '';\n\n  /**\n   * @property Input\n   * @description\n   * Decides if a label should be outside of the container or not.\n   */\n  @Input() labelOutside: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * A modifier that will allow always keeping the selected airport.\n   * The last selected airport will be shown once user clears the selection and blur.\n   */\n  @Input() keepSelection: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Sets a formControlName directive to the input.\n   * It requires that the consumer included ReactiveFormsModule in it's module.\n   * It requiers that the nasFormGroup input is filled.\n   */\n  @Input() nasFormControlNameOrigin: string;\n\n  /**\n   * @property Input\n   * @description\n   * Sets a formControlName directive to the input.\n   * It requires that the consumer included ReactiveFormsModule in it's module.\n   * It requiers that the nasFormGroup input is filled.\n   */\n  @Input() nasFormControlNameDestination: string;\n\n  /**\n   * @property Input\n   * @description\n   * Adds the parent's form group.\n   * It requires that the consumer included ReactiveFormsModule in it's module.\n   * It is requiered to be filled if nasFormControlName added.\n   */\n  @Input() nasFormGroup: FormGroup;\n\n  /**\n   * @property Input\n   * @description\n   * The airport code of the origin airport. It will set the selected origin airport based on this value.\n   */\n  @Input()\n  get originAirportCode() {\n    return this.originAirportCodeValue;\n  }\n  set originAirportCode(code: string) {\n    if (code) {\n      if (code !== this.originAirportCodeValue) {\n        this.originAirportCodeValue = code;\n        this.setOrigin();\n      }\n    } else {\n      this.originAirportCodeValue = '';\n      this.clearOrigin();\n    }\n  }\n\n  /**\n   * @property Input\n   * @description\n   * The airport code of the destination airport. It will set the selected destination airport based on this value.\n   */\n  @Input()\n  get destinationAirportCode() {\n    return this.destinationAirportCodeValue;\n  }\n  set destinationAirportCode(code: string) {\n    if (code) {\n      if (code !== this.destinationAirportCodeValue) {\n        this.destinationAirportCodeValue = code;\n        this.setDestination();\n      }\n    } else {\n      this.destinationAirportCodeValue = '';\n      this.clearDestination();\n    }\n  }\n\n  /**\n   * @property Input\n   * @description\n   * Adds 'aria-label' on the clear button inside the airport select inputs.\n   */\n  @Input() ariaLabelClear: string;\n\n  /**\n   * @property Input\n   * @description\n   * Adds 'aria-label' to the backdrops.\n   */\n  @Input() ariaLabelBackdrop: string;\n\n  /**\n   * @property Output\n   * @description\n   * An event that is fired every time the selected origin airport changes.\n   */\n  @Output() originChange = new EventEmitter<AirportModel>();\n\n  /**\n   * @property Output\n   * @description\n   * An event that is fired every time the origin dropdown selector opens or closes.\n   */\n  @Output() originOpenChange = new EventEmitter<boolean>();\n\n  /**\n  * @property Output\n  * @description\n  * An event that is fired every time the origin dropdown selector opens or closes.\n  */\n  @Output() destinationChange = new EventEmitter<AirportModel>();\n\n  /**\n   * @property Output\n   * @description\n   * An event that is fired every time the destination dropdown selector opens or closes.\n   */\n  @Output() destinationOpenChange = new EventEmitter<boolean>();\n\n  /**\n   * @property Output\n   * @description\n   * An event that is fired when the destination dropdown closes.\n   */\n  @Output() focusOnNext = new EventEmitter<KeyboardEvent>();\n\n  /**\n   * @property Output\n   * @description\n   * An event that is fired when geolocation position has changed.\n   */\n  @Output() positionChange = new EventEmitter<GeolocationPosition>();\n\n  private originAirportCodeValue: string;\n  private destinationAirportCodeValue: string;\n\n  constructor(private deviceHelper: DeviceHelper,\n    private cdr: ChangeDetectorRef\n  ) {\n    super('nas-airport-select');\n  }\n\n  @HostListener(\"window:resize\", [\"$event\"])\n  onResize() {\n    this.setInlineFlex();\n  }\n\n  ngOnInit() {\n    if (!this.airports) {\n      throw new Error('Missing input: [airports]');\n    }\n\n    this.resultsLabels = {\n      allAirports: this.allAirportsLabel || '',\n      closestAirports: this.closestAirportsLabel || '',\n      latestSearches: this.latestSearchesLabel || '',\n      geolocation: this.geolocationLabel || '',\n      geolocationDenied: this.geolocationBlockedLabel || '',\n      noAirports: this.noAirportsLabel || ''\n    };\n\n    this.textSelectOriginFirst = this.selectOriginFirstLabel;\n    this.airportsOrigin = this.allowedOriginAiports && this.allowedOriginAiports.length > 0 ? this.allowedOriginAiports : this.airports;\n\n    this.airportsDestination = this.getAirportsDestinations();\n\n    if (this.nasFormGroup) {\n      if (this.nasFormControlNameOrigin) {\n        const originControl = this.nasFormGroup.get(this.nasFormControlNameOrigin);\n\n        if (originControl) {\n          const origin = this.airportsOrigin.find(x => x.name === originControl.value);\n\n          if (origin) {\n            this.originAirportCode = origin.code;\n          }\n        }\n      }\n\n      if (this.nasFormControlNameDestination) {\n        const destinationControl = this.nasFormGroup.get(this.nasFormControlNameDestination);\n\n        if (destinationControl) {\n          const destination = this.airportsDestination.find(x => x.name === destinationControl.value);\n\n          if (destination) {\n            this.destinationAirportCode = destination.code;\n          }\n        }\n      }\n    }\n\n    if (!this.destination) {\n      this.clearDestination();\n      return;\n    }\n\n    this.destinationChange.emit(this.destination);\n    this.originChange.emit(this.origin);\n\n\n    if (this.originAirportCode) {\n      this.setOrigin();\n    }\n\n    if (this.destinationAirportCode) {\n      this.setDestination();\n    }\n  }\n\n  ngAfterViewInit() {\n    this.setInlineFlex();\n    this.cdr.detectChanges();\n  }\n\n  getAirportSelectComboClass(element?: string, modifiersInput?: any): ClassModel {\n    let modifiers = modifiersInput;\n\n    if (typeof modifiersInput === 'string' || modifiersInput instanceof String) {\n      modifiers = [modifiersInput];\n    }\n\n    return {\n      block: 'nas-airport-select-combo',\n      element: element,\n      modifiers: modifiers\n    };\n  }\n\n  onOriginOpen(open: boolean): void {\n    setTimeout(() => {\n      this.originOpen = open;\n    });\n    this.destinationOpen = false;\n    this.originOpenChange.emit(open);\n  }\n\n  onDestinationOpen(open: boolean): void {\n    this.destinationOpen = open;\n    this.originOpen = false;    \n\n    if(this.originAirportCode && (this.airportsDestination && this.airportsDestination.length <= 0)) {\n      this.noDestinationAirportsAvailable = true;\n      this.clearDestination();\n    }\n\n    this.destinationOpenChange.emit(open);\n  }\n\n  onSelectionCleared(): void {\n    this.cleared = true;\n  }\n\n  setSelectedOrigin(airport: AirportModel): void {\n    this.noDestinationAirportsAvailable = false;\n    if (!airport) {\n      return;\n    }\n\n    this.origin = airport;\n    this.originAirportCodeValue = airport.code;\n    this.isDestinationValid = airport.code ? true : false;\n\n    if (this.airportRelations && this.hasValidDestinations(airport)) {\n      this.updateValidAirportDestinations(airport);\n      this.setCurrentLatestSearchesDestination();\n    } else {\n      this.airportsDestination = [];\n    }\n    this.cleared = false;\n    this.originChange.emit(airport);\n  }\n\n  setSelectedDestination(airport: AirportModel): void {\n    if (!airport) {\n      return;\n    }\n\n    this.destination = airport; \n    this.destinationAirportCodeValue = airport.code;\n    this.cleared = false;\n\n    this.destinationChange.emit(airport);\n  }\n\n  setFocusOnNext(event: KeyboardEvent): void {\n    this.focusOnNext.emit(event);\n  }\n\n  onOriginFocus(): void {\n    if (this.airportSelectDropdownOrigin) {\n      this.onOriginOpen(true);\n    }\n  }\n\n  changeSwitchIcon(): void {\n    this.switchType = this.switchType === 'switch' ? 'switch--secondary' : 'switch';\n  }\n\n  swapAirports(): void {\n    const destination = { ...this.destination };\n    const origin = { ...this.origin };\n    this.destination = origin;\n    this.origin = destination;\n\n    this.setSelectedDestination(this.destination);\n    this.setSelectedOrigin(this.origin);\n  }\n\n  swapKeyDown(event: KeyboardEvent): void {\n    switch (event.key) {\n      case 'Enter':\n        this.swapAirports();\n        break;\n    }\n  }\n\n  setDestinationOpen(event: KeyboardEvent): void {\n    if (this.exists(this.combo)) {\n      this.onDestinationOpen(true);\n    } else {\n      this.setFocusOnNext(event);\n    }\n  }\n\n  getClosestAirports(position: GeolocationPosition): void {\n    this.positionChange.emit(position);\n  }\n\n  setInlineFlex(): void {\n    if (!this.container && !this.container?.nativeElement) {\n      return;\n    }\n    this.inlineFlex = !this.deviceHelper.isWidthMobile(this.container.nativeElement.offsetWidth);\n  }\n\n  private getAirportsDestinations(): Array<AirportModel> {\n    const allowedDestinationAirports = this.allowedDestinationAirports;\n\n    return allowedDestinationAirports && allowedDestinationAirports.length > 0\n      ? allowedDestinationAirports\n      : this.airports;\n  }\n\n  private setOrigin(): void {\n    const airport = this.airports.find(x => x.code === this.originAirportCode);\n\n    if (airport) {\n      this.setSelectedOrigin(airport);\n    }\n  }\n\n  private setDestination(): void {\n    const airport = this.airports.find(x => x.code === this.destinationAirportCode);\n\n    if (airport) {\n      this.setSelectedDestination(airport);\n    }\n  }\n\n  private updateValidAirportDestinations(airport: AirportModel): void {\n    if (!this.airportRelations) {\n      this.airportsDestination = this.airportsOrigin;\n    } else {\n      const validDestinations = this.getAirportRelations(airport);\n\n      if (!validDestinations) {\n        return;\n      }\n\n      if (validDestinations.length === 0) {\n        this.clearDestinations();\n      } else {\n        let isDestinationValid: boolean;\n        if (this.destination && this.destination.code) {\n          isDestinationValid = validDestinations.some(x => x && x.toLowerCase() === this.destination.code.toLowerCase());\n        }\n        if (!isDestinationValid) {\n          this.clearDestination();\n          this.destinationChange.emit(null);\n        }\n\n        if (this.airports) {\n          this.airportsDestination = this.airports\n            .filter(airportItem => airportItem\n              && airportItem.code\n              && validDestinations.some(x => x && airportItem.code.toLowerCase() === x.toLowerCase()));\n        }\n      }\n    }\n  }\n\n  private hasValidDestinations(origin: AirportModel): boolean {\n    if (!origin) {\n      return;\n    }\n    const relations = this.getAirportRelations(origin);\n\n    return relations && relations.length > 0;\n  }\n\n  private getAirportRelations(airport: AirportModel): Array<string> {\n    if (!this.airports) {\n      return new Array<string>();\n    }\n\n    return this.airportRelations[airport.code.toLowerCase()] || this.airportRelations[airport.code.toUpperCase()];\n  }\n\n  private clearOrigin() {\n    this.setSelectedOrigin({\n      code: '',\n      countryName: '',\n      name: '',\n      airportName: '',\n      displayName: '',\n      normalizedAirportName: ''\n    });\n  }\n\n  clearDestination(): void {\n    this.setSelectedDestination({\n      code: '',\n      countryName: '',\n      name: '',\n      airportName: '',\n      displayName: '',\n      normalizedAirportName: ''\n    });\n  }\n\n  private clearDestinations(): void {\n    this.airportsDestination = new Array<AirportModel>();\n\n    const model = {\n      name: this.textSelectOriginFirst,\n      countryName: '',\n      code: '',\n      airportName: '',\n      displayName: '',\n      normalizedAirportName: ''\n    };\n\n    this.airportsDestination.push(model);\n    this.clearDestination();\n    this.destinationChange.emit(model);\n  }\n\n  private setCurrentLatestSearchesDestination(): void {\n    if (this.airportsDestination) {\n      this.currentLatestSearchesDestination = this.airportsDestination.filter(airport => {\n        if (this.latestSearchesDestination) {\n          return this.latestSearchesDestination.some(x => x.code && x.code.toLowerCase() === airport.code.toLowerCase());\n        }\n      });\n    }\n  }\n}\n","<div *ngIf=\"exists(combo); else airportSelectTemplate\"\n  [nasClass]=\"getAirportSelectComboClass('', [inlineFlex && 'inline'])\" #container>\n  <ng-container *ngTemplateOutlet=\"airportSelectTemplate\"></ng-container>\n</div>\n<ng-template #airportSelectTemplate>\n  <div [nasClass]=\"getClass('', exists(useSwitch) && 'padding-origin')\" *ngIf=\"airportsOrigin\">\n    <nas-airport-select-dropdown #airportSelectDropdownOrigin displayLatestSearches [id]=\"outboundId\"\n      [enableGeolocation]=\"displayClosestAirports\" [displayClosestAirports]=\"displayClosestAirports\"\n      [airportSelectLabel]=\"labelOrigin\" [latestSearches]=\"latestSearchesOrigin\" [closestAirports]=\"closestAirports\"\n      [airport]=\"origin\" [airports]=\"airportsOrigin\" [resultsLabels]=\"resultsLabels\"\n      [airportSelectPlaceholder]=\"placeholderOrigin\" [open]=\"originOpen\" [keepSelection]=\"keepSelection\"\n      [airportSelectIconModifier]=\"'flight-departure'\" [nasFormControlName]=\"nasFormControlNameOrigin\"\n      [nasFormGroup]=\"nasFormGroup\" [ariaLabelClear]=\"ariaLabelClear\" [ariaLabelBackdrop]=\"ariaLabelBackdrop\"\n      [labelOutside]=\"labelOutside\" (clearedSelection)=\"onSelectionCleared()\" (selected)=\"setSelectedOrigin($event)\"\n      (openChange)=\"onOriginOpen($event)\" (focusOnNext)=\"setDestinationOpen($event)\"\n      (positionChange)=\"getClosestAirports($event)\"></nas-airport-select-dropdown>\n  </div>\n  <ng-container *ngIf=\"exists(combo)\">\n    <div [nasClass]=\"getClass('', exists(useSwitch) && 'padding-destination')\">\n      <nas-airport-select-dropdown #airportSelectDropdownDestination displayLatestSearches [id]=\"inboundId\"\n        [airportSelectLabel]=\"labelDestination\" [displayClosestAirports]=\"false\"\n        [latestSearches]=\"currentLatestSearchesDestination\" [airports]=\"airportsDestination\"\n        [resultsLabels]=\"resultsLabels\" [airport]=\"destination\" [airportSelectPlaceholder]=\"placeholderDestination\"\n        [open]=\"destinationOpen\" [keepSelection]=\"keepSelection\" [airportSelectIconModifier]=\"'flight-arrival'\"\n        [nasFormControlName]=\"nasFormControlNameDestination\" [nasFormGroup]=\"nasFormGroup\"\n        [ariaLabelClear]=\"ariaLabelClear\" [ariaLabelBackdrop]=\"ariaLabelBackdrop\" [isValid]=\"isDestinationValid\"\n        [invalidText]=\"invalidDestinationText\" [labelOutside]=\"labelOutside\" (clearedSelection)=\"onSelectionCleared()\"\n        (selected)=\"setSelectedDestination($event)\" (openChange)=\"onDestinationOpen($event)\"\n        (focusOnNext)=\"setFocusOnNext($event)\" (focusOnPrevious)=\"onOriginFocus()\" [noAirportsAvailable]=\"noDestinationAirportsAvailable\"></nas-airport-select-dropdown>\n    </div>\n    <div *ngIf=\"exists(useSwitch) && !(originOpen || destinationOpen || cleared)\" #switchButton\n      [nasClass]=\"getAirportSelectComboClass('switcher', (originAirportCodeValue && destinationAirportCodeValue) && 'filled')\"\n      (mouseover)=\"changeSwitchIcon()\" (mouseleave)=\"changeSwitchIcon()\" (keydown)=\"swapKeyDown($event)\"\n      (click)=\"swapAirports()\">\n      <nas-icon\n        [type]=\"(this.destinationAirportCodeValue && this.originAirportCodeValue) ? 'vector--secondary' : 'vector'\"></nas-icon>\n    </div>\n  </ng-container>\n</ng-template>"]}
498
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"airport-select.component.js","sourceRoot":"","sources":["../../../../../../projects/core-components/src/lib/components/airport-select/airport-select.component.ts","../../../../../../projects/core-components/src/lib/components/airport-select/airport-select.component.html"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Norwegian Air Shuttle. All Rights Reserved.\n */\n\nimport { AirportModel } from './models/airport.model';\nimport { ClassModel } from '../../core/models/class.model';\nimport {\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  ViewEncapsulation,\n  ViewChild,\n  ElementRef,\n  OnInit,\n  AfterViewInit,\n  HostListener,\n  ChangeDetectorRef\n} from '@angular/core';\nimport { FormGroup } from '@angular/forms';\nimport { NasComponentBase } from '../../core';\nimport { ResultsLabelsModel } from './models/results-labels.model';\nimport { AirportSelectDropdownComponent } from './airport-select-dropdown/airport-select-dropdown.component';\nimport { DeviceHelper } from '../../core/services/device/device-helper.service';\n\n/**\n * @description\n * Norwegian Airport Select Component | Functional | New design\n */\n@Component({\n  selector: 'nas-airport-select',\n  templateUrl: './airport-select.component.html',\n  styleUrls: ['./airport-select.component.scss'],\n  encapsulation: ViewEncapsulation.None\n})\nexport class AirportSelectComponent extends NasComponentBase implements OnInit, AfterViewInit {\n  airportsOrigin: Array<AirportModel>;\n  airportsDestination = new Array<AirportModel>();\n  currentLatestSearchesDestination: Array<AirportModel>;\n  closestAirportsDestination: Array<AirportModel>;\n  focusDestination = false;\n  textSelectOriginFirst: string;\n  focusedLatestSearchesAirportCodeDestination: string;\n  focusedAirportCodeDestination: string;\n  focusedLatestSearchesIndexDestination = -1;\n  focusedAirportIndexDestination = -1;\n  switchType = 'switch';\n  isDestinationValid: boolean;\n  inlineFlex = false;\n  noDestinationAirportsAvailable: boolean;\n\n  resultsLabels: ResultsLabelsModel = {\n    allAirports: '',\n    closestAirports: '',\n    latestSearches: '',\n    geolocation: '',\n    geolocationDenied: '',\n    noAirports: ''\n  };\n\n  originOpen = false;\n  destinationOpen = false;\n  cleared = false;\n\n  @ViewChild('container') container: ElementRef;\n  @ViewChild('switchButton') switchButton: ElementRef;\n  @ViewChild('airportSelectDropdownOrigin') airportSelectDropdownOrigin: AirportSelectDropdownComponent;\n  @ViewChild('airportSelectDropdownDestination') airportSelectDropdownDestination: AirportSelectDropdownComponent;\n\n  origin: AirportModel;\n  destination: AirportModel;\n\n  /**\n   * @property Input\n   * @description\n   * The outbound aiport select ID of the native input element\n   */\n  @Input() outboundId: string;\n\n  /**\n  * @property Input\n  * @description\n  * The inbound aiport select ID of the native input element\n  */\n  @Input() inboundId: string;\n\n  /**\n   * @property Input\n   * @required\n   * @description\n   * All airports that will be populated into the dropdown lists.\n   */\n  @Input() airports: Array<AirportModel>;\n\n  /**\n   * @property Input\n   * @description\n   * A record containing keys with all airport codes with corresponding array of airport codes connected to the key.\n   */\n  @Input() airportRelations: Record<string, Array<string>>;\n\n  /**\n   * @property Input\n   * @description\n   * An array of origin airports that the user has allready search for.\n   */\n  @Input() latestSearchesOrigin: Array<AirportModel>;\n\n  /**\n   * @property Input\n   * @description\n   * An array of destination airports that the user has allready search for.\n   */\n  @Input() latestSearchesDestination: Array<AirportModel>;\n\n  /**\n   * @property Input\n   * @description\n   * An array of airports that are close to the user.\n   */\n  @Input() closestAirports: Array<AirportModel>;\n\n  /**\n   * @property Input\n   * @description\n   * A list of airports that should be displayed in the origin dropdown.\n   * If not included, all airports will be displayed.\n   */\n  @Input() allowedOriginAiports: Array<AirportModel>;\n\n  /**\n   * @property Input\n   * @description\n   * An array of airports that are restricted for destination airports. It will default to airports if not set.\n   */\n  @Input() allowedDestinationAirports: Array<AirportModel>;\n\n  /**\n   * @property Input\n   * @description\n   * A boolean indicating if airports that the user allready has searh for should be displayed.\n   */\n  @Input() displayLatestSearches?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * A boolean indicating if airports that are close to the user should be displayed.\n   */\n  @Input() displayClosestAirports?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Display both orgin and destination airport selector.\n   */\n  @Input() combo?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Display switch UI to interchange origin and destination airport.\n   */\n  @Input() useSwitch?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * A label that will appear on top of all airports in the drop down list.\n   */\n  @Input() allAirportsLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * A label that will appear on top of the latest searches in the drop down list.\n   */\n  @Input() latestSearchesLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * A label that will appear on top of the closest airports in the drop down list.\n   */\n  @Input() closestAirportsLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * A label that will appear in my location in the drop down list.\n   */\n  @Input() geolocationLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * A label that will appear in my location, in the drop down list if user has denied geolocation.\n   */\n  @Input() geolocationBlockedLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * A label that will appear in the destination input field if the\n   * user tries to select a destination airport without selecting an origin airport.\n   */\n  @Input() selectOriginFirstLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * A label that appear in the list that there is currently no airports\n   */\n  @Input() noAirportsLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * A text that appears in the destinations dropdown list when origin airport is not set.\n   */\n  @Input() invalidDestinationText: string;\n\n  /**\n   * @property Input\n   * @required\n   * @description\n   * A label that will appear on top of the origin airport input field.\n   */\n  @Input() labelOrigin = '';\n\n  /**\n   * @property Input\n   * @description\n   * A placeholder that will appear on the origin airport input field.\n   */\n  @Input() placeholderOrigin = '';\n\n  /**\n   * @property Input\n   * @description\n   * A label that will appear on top of the destination airport input field.\n   */\n  @Input() labelDestination = '';\n\n  /**\n   * @property Input\n   * @description\n   * A placeholder that will appear on the destination airport input field.\n   */\n  @Input() placeholderDestination = '';\n\n  /**\n   * @property Input\n   * @description\n   * Decides if a label should be outside of the container or not.\n   */\n  @Input() labelOutside: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * A modifier that will allow always keeping the selected airport.\n   * The last selected airport will be shown once user clears the selection and blur.\n   */\n  @Input() keepSelection: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Sets a formControlName directive to the input.\n   * It requires that the consumer included ReactiveFormsModule in it's module.\n   * It requiers that the nasFormGroup input is filled.\n   */\n  @Input() nasFormControlNameOrigin: string;\n\n  /**\n   * @property Input\n   * @description\n   * Sets a formControlName directive to the input.\n   * It requires that the consumer included ReactiveFormsModule in it's module.\n   * It requiers that the nasFormGroup input is filled.\n   */\n  @Input() nasFormControlNameDestination: string;\n\n  /**\n   * @property Input\n   * @description\n   * Adds the parent's form group.\n   * It requires that the consumer included ReactiveFormsModule in it's module.\n   * It is requiered to be filled if nasFormControlName added.\n   */\n  @Input() nasFormGroup: FormGroup;\n\n  /**\n   * @property Input\n   * @description\n   * The airport code of the origin airport. It will set the selected origin airport based on this value.\n   */\n  @Input()\n  get originAirportCode() {\n    return this.originAirportCodeValue;\n  }\n  set originAirportCode(code: string) {\n    if (code) {\n      if (code !== this.originAirportCodeValue) {\n        this.originAirportCodeValue = code;\n        this.setOrigin();\n      }\n    } else {\n      this.originAirportCodeValue = '';\n      this.clearOrigin();\n    }\n  }\n\n  /**\n   * @property Input\n   * @description\n   * The airport code of the destination airport. It will set the selected destination airport based on this value.\n   */\n  @Input()\n  get destinationAirportCode() {\n    return this.destinationAirportCodeValue;\n  }\n  set destinationAirportCode(code: string) {\n    if (code) {\n      if (code !== this.destinationAirportCodeValue) {\n        this.destinationAirportCodeValue = code;\n        this.setDestination();\n      }\n    } else {\n      this.destinationAirportCodeValue = '';\n      this.clearDestination();\n    }\n  }\n\n  /**\n   * @property Input\n   * @description\n   * Adds 'aria-label' on the clear button inside the airport select inputs.\n   */\n  @Input() ariaLabelClear: string;\n\n  /**\n   * @property Input\n   * @description\n   * Adds 'aria-label' to the backdrops.\n   */\n  @Input() ariaLabelBackdrop: string;\n\n  /**\n   * @property Output\n   * @description\n   * An event that is fired every time the selected origin airport changes.\n   */\n  @Output() originChange = new EventEmitter<AirportModel>();\n\n  /**\n   * @property Output\n   * @description\n   * An event that is fired every time the origin dropdown selector opens or closes.\n   */\n  @Output() originOpenChange = new EventEmitter<boolean>();\n\n  /**\n  * @property Output\n  * @description\n  * An event that is fired every time the origin dropdown selector opens or closes.\n  */\n  @Output() destinationChange = new EventEmitter<AirportModel>();\n\n  /**\n   * @property Output\n   * @description\n   * An event that is fired every time the destination dropdown selector opens or closes.\n   */\n  @Output() destinationOpenChange = new EventEmitter<boolean>();\n\n  /**\n   * @property Output\n   * @description\n   * An event that is fired when the destination dropdown closes.\n   */\n  @Output() focusOnNext = new EventEmitter<KeyboardEvent>();\n\n  /**\n   * @property Output\n   * @description\n   * An event that is fired when geolocation position has changed.\n   */\n  @Output() positionChange = new EventEmitter<GeolocationPosition>();\n\n  private originAirportCodeValue: string;\n  private destinationAirportCodeValue: string;\n\n  constructor(private deviceHelper: DeviceHelper,\n    private cdr: ChangeDetectorRef\n  ) {\n    super('nas-airport-select');\n  }\n\n  @HostListener(\"window:resize\", [\"$event\"])\n  onResize() {\n    this.setInlineFlex();\n  }\n\n  ngOnInit() {\n    if (!this.airports) {\n      throw new Error('Missing input: [airports]');\n    }\n\n    this.resultsLabels = {\n      allAirports: this.allAirportsLabel || '',\n      closestAirports: this.closestAirportsLabel || '',\n      latestSearches: this.latestSearchesLabel || '',\n      geolocation: this.geolocationLabel || '',\n      geolocationDenied: this.geolocationBlockedLabel || '',\n      noAirports: this.noAirportsLabel || ''\n    };\n\n    this.textSelectOriginFirst = this.selectOriginFirstLabel;\n    this.airportsOrigin = this.allowedOriginAiports && this.allowedOriginAiports.length > 0 ? this.allowedOriginAiports : this.airports;\n\n    this.airportsDestination = this.getAirportsDestinations();\n\n    if (this.nasFormGroup) {\n      if (this.nasFormControlNameOrigin) {\n        const originControl = this.nasFormGroup.get(this.nasFormControlNameOrigin);\n\n        if (originControl) {\n          const origin = this.airportsOrigin.find(x => x.name === originControl.value);\n\n          if (origin) {\n            this.originAirportCode = origin.code;\n          }\n        }\n      }\n\n      if (this.nasFormControlNameDestination) {\n        const destinationControl = this.nasFormGroup.get(this.nasFormControlNameDestination);\n\n        if (destinationControl) {\n          const destination = this.airportsDestination.find(x => x.name === destinationControl.value);\n\n          if (destination) {\n            this.destinationAirportCode = destination.code;\n          }\n        }\n      }\n    }\n\n    if (!this.destination) {\n      this.clearDestination();\n      return;\n    }\n\n    this.destinationChange.emit(this.destination);\n    this.originChange.emit(this.origin);\n\n\n    if (this.originAirportCode) {\n      this.setOrigin();\n    }\n\n    if (this.destinationAirportCode) {\n      this.setDestination();\n    }\n  }\n\n  ngAfterViewInit() {\n    this.setInlineFlex();\n    this.cdr.detectChanges();\n  }\n\n  getAirportSelectComboClass(element?: string, modifiersInput?: any): ClassModel {\n    let modifiers = modifiersInput;\n\n    if (typeof modifiersInput === 'string' || modifiersInput instanceof String) {\n      modifiers = [modifiersInput];\n    }\n\n    return {\n      block: 'nas-airport-select-combo',\n      element: element,\n      modifiers: modifiers\n    };\n  }\n\n  onOriginOpen(open: boolean): void {\n    setTimeout(() => {\n      this.originOpen = open;\n    });\n    this.destinationOpen = false;\n    this.originOpenChange.emit(open);\n  }\n\n  onDestinationOpen(open: boolean): void {\n    this.destinationOpen = open;\n    this.originOpen = false;    \n\n    if(this.originAirportCode && (this.airportsDestination && this.airportsDestination.length <= 0)) {\n      this.noDestinationAirportsAvailable = true;\n      this.clearDestination();\n    }\n\n    this.destinationOpenChange.emit(open);\n  }\n\n  onSelectionCleared(): void {\n    this.cleared = true;\n  }\n\n  setSelectedOrigin(airport: AirportModel): void {\n    this.noDestinationAirportsAvailable = false;\n    if (!airport) {\n      return;\n    }\n\n    this.origin = airport;\n    this.originAirportCodeValue = airport.code;\n    this.isDestinationValid = airport.code ? true : false;\n\n    if (this.airportRelations && this.hasValidDestinations(airport)) {\n      this.updateValidAirportDestinations(airport);\n      this.setCurrentLatestSearchesDestination();\n    } else {\n      this.airportsDestination = [];\n    }\n    this.cleared = false;\n    this.originChange.emit(airport);\n  }\n\n  setSelectedDestination(airport: AirportModel): void {\n    if (!airport) {\n      return;\n    }\n\n    this.destination = airport; \n    this.destinationAirportCodeValue = airport.code;\n    this.cleared = false;\n\n    this.destinationChange.emit(airport);\n  }\n\n  setFocusOnNext(event: KeyboardEvent): void {\n    this.focusOnNext.emit(event);\n  }\n\n  onOriginFocus(): void {\n    if (this.airportSelectDropdownOrigin) {\n      this.onOriginOpen(true);\n    }\n  }\n\n  changeSwitchIcon(): void {\n    this.switchType = this.switchType === 'switch' ? 'switch--secondary' : 'switch';\n  }\n\n  swapAirports(): void {\n    const destination = { ...this.destination };\n    const origin = { ...this.origin };\n    this.destination = origin;\n    this.origin = destination;\n\n    this.setSelectedDestination(this.destination);\n    this.setSelectedOrigin(this.origin);\n  }\n\n  swapKeyDown(event: KeyboardEvent): void {\n    switch (event.key) {\n      case 'Enter':\n        this.swapAirports();\n        break;\n    }\n  }\n\n  setDestinationOpen(event: KeyboardEvent): void {\n    if (this.exists(this.combo)) {\n      this.onDestinationOpen(true);\n    } else {\n      this.setFocusOnNext(event);\n    }\n  }\n\n  getClosestAirports(position: GeolocationPosition): void {\n    this.positionChange.emit(position);\n  }\n\n  setInlineFlex(): void {\n    if (!this.container && !this.container?.nativeElement) {\n      return;\n    }\n    this.inlineFlex = !this.deviceHelper.isWidthMobile(this.container.nativeElement.offsetWidth);\n  }\n\n  private getAirportsDestinations(): Array<AirportModel> {\n    const allowedDestinationAirports = this.allowedDestinationAirports;\n\n    return allowedDestinationAirports && allowedDestinationAirports.length > 0\n      ? allowedDestinationAirports\n      : this.airports;\n  }\n\n  private setOrigin(): void {\n    const airport = this.airports.find(x => x.code === this.originAirportCode);\n\n    if (airport) {\n      this.setSelectedOrigin(airport);\n    }\n  }\n\n  private setDestination(): void {\n    const airport = this.airports.find(x => x.code === this.destinationAirportCode);\n\n    if (airport) {\n      this.setSelectedDestination(airport);\n    }\n  }\n\n  private updateValidAirportDestinations(airport: AirportModel): void {\n    if (!this.airportRelations) {\n      this.airportsDestination = this.airportsOrigin;\n    } else {\n      const validDestinations = this.getAirportRelations(airport);\n\n      if (!validDestinations) {\n        return;\n      }\n\n      if (validDestinations.length === 0) {\n        this.clearDestinations();\n      } else {\n        let isDestinationValid: boolean;\n        if (this.destination && this.destination.code) {\n          isDestinationValid = validDestinations.some(x => x && x.toLowerCase() === this.destination.code.toLowerCase());\n        }\n        if (!isDestinationValid) {\n          this.clearDestination();\n          this.destinationChange.emit(null);\n        }\n\n        if (this.airports) {\n          this.airportsDestination = this.airports\n            .filter(airportItem => airportItem\n              && airportItem.code\n              && validDestinations.some(x => x && airportItem.code.toLowerCase() === x.toLowerCase()));\n        }\n      }\n    }\n  }\n\n  private hasValidDestinations(origin: AirportModel): boolean {\n    if (!origin) {\n      return;\n    }\n    const relations = this.getAirportRelations(origin);\n\n    return relations && relations.length > 0;\n  }\n\n  private getAirportRelations(airport: AirportModel): Array<string> {\n    if (!this.airports) {\n      return new Array<string>();\n    }\n\n    return this.airportRelations[airport.code.toLowerCase()] || this.airportRelations[airport.code.toUpperCase()];\n  }\n\n  private clearOrigin() {\n    this.setSelectedOrigin({\n      code: '',\n      countryName: '',\n      name: '',\n      airportName: '',\n      displayName: '',\n      normalizedAirportName: ''\n    });\n  }\n\n  clearDestination(): void {\n    this.setSelectedDestination({\n      code: '',\n      countryName: '',\n      name: '',\n      airportName: '',\n      displayName: '',\n      normalizedAirportName: ''\n    });\n  }\n\n  private clearDestinations(): void {\n    this.airportsDestination = new Array<AirportModel>();\n\n    const model = {\n      name: this.textSelectOriginFirst,\n      countryName: '',\n      code: '',\n      airportName: '',\n      displayName: '',\n      normalizedAirportName: ''\n    };\n\n    this.airportsDestination.push(model);\n    this.clearDestination();\n    this.destinationChange.emit(model);\n  }\n\n  private setCurrentLatestSearchesDestination(): void {\n    if (this.airportsDestination) {\n      this.currentLatestSearchesDestination = this.airportsDestination.filter(airport => {\n        if (this.latestSearchesDestination) {\n          return this.latestSearchesDestination.some(x => x.code && x.code.toLowerCase() === airport.code.toLowerCase());\n        }\n      });\n    }\n  }\n}\n","<div *ngIf=\"exists(combo); else airportSelectTemplate\"\n  [nasClass]=\"getAirportSelectComboClass('', [inlineFlex && 'inline'])\" #container>\n  <ng-container *ngTemplateOutlet=\"airportSelectTemplate\"></ng-container>\n</div>\n<ng-template #airportSelectTemplate>\n  <div [nasClass]=\"getClass('', exists(useSwitch) && 'padding-origin')\" *ngIf=\"airportsOrigin\">\n    <nas-airport-select-dropdown #airportSelectDropdownOrigin displayLatestSearches [id]=\"outboundId\"\n      [enableGeolocation]=\"displayClosestAirports\" [displayClosestAirports]=\"displayClosestAirports\"\n      [airportSelectLabel]=\"labelOrigin\" [latestSearches]=\"latestSearchesOrigin\" [closestAirports]=\"closestAirports\"\n      [airport]=\"origin\" [airports]=\"airportsOrigin\" [resultsLabels]=\"resultsLabels\"\n      [airportSelectPlaceholder]=\"placeholderOrigin\" [open]=\"originOpen\" [keepSelection]=\"keepSelection\"\n      [airportSelectIconModifier]=\"'flight-departure'\" [nasFormControlName]=\"nasFormControlNameOrigin\"\n      [nasFormGroup]=\"nasFormGroup\" [ariaLabelClear]=\"ariaLabelClear\" [ariaLabelBackdrop]=\"ariaLabelBackdrop\"\n      [labelOutside]=\"labelOutside\" (clearedSelection)=\"onSelectionCleared()\" (selected)=\"setSelectedOrigin($event)\"\n      (openChange)=\"onOriginOpen($event)\" (focusOnNext)=\"setDestinationOpen($event)\"\n      (positionChange)=\"getClosestAirports($event)\"></nas-airport-select-dropdown>\n  </div>\n  <ng-container *ngIf=\"exists(combo)\">\n    <div [nasClass]=\"getClass('', exists(useSwitch) && 'padding-destination')\">\n      <nas-airport-select-dropdown #airportSelectDropdownDestination displayLatestSearches [id]=\"inboundId\"\n        [airportSelectLabel]=\"labelDestination\" [displayClosestAirports]=\"false\"\n        [latestSearches]=\"currentLatestSearchesDestination\" [airports]=\"airportsDestination\"\n        [resultsLabels]=\"resultsLabels\" [airport]=\"destination\" [airportSelectPlaceholder]=\"placeholderDestination\"\n        [open]=\"destinationOpen\" [keepSelection]=\"keepSelection\" [airportSelectIconModifier]=\"'flight-arrival'\"\n        [nasFormControlName]=\"nasFormControlNameDestination\" [nasFormGroup]=\"nasFormGroup\"\n        [ariaLabelClear]=\"ariaLabelClear\" [ariaLabelBackdrop]=\"ariaLabelBackdrop\" [isValid]=\"isDestinationValid\"\n        [invalidText]=\"invalidDestinationText\" [labelOutside]=\"labelOutside\" (clearedSelection)=\"onSelectionCleared()\"\n        (selected)=\"setSelectedDestination($event)\" (openChange)=\"onDestinationOpen($event)\"\n        (focusOnNext)=\"setFocusOnNext($event)\" (focusOnPrevious)=\"onOriginFocus()\" [noAirportsAvailable]=\"noDestinationAirportsAvailable\"></nas-airport-select-dropdown>\n    </div>\n    <div *ngIf=\"exists(useSwitch) && !(originOpen || destinationOpen || cleared)\" #switchButton\n      [nasClass]=\"getAirportSelectComboClass('switcher', (originAirportCodeValue && destinationAirportCodeValue) && 'filled')\"\n      (mouseover)=\"changeSwitchIcon()\" (mouseleave)=\"changeSwitchIcon()\" (keydown)=\"swapKeyDown($event)\"\n      (click)=\"swapAirports()\">\n      <nas-icon\n        [type]=\"(this.destinationAirportCodeValue && this.originAirportCodeValue) ? 'vector--secondary' : 'vector'\"></nas-icon>\n    </div>\n  </ng-container>\n</ng-template>"]}
@@ -264,11 +264,11 @@ export class AutocompleteComponent extends NasComponentBase {
264
264
  return this.model ? 'remove--secondary' : 'remove';
265
265
  }
266
266
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AutocompleteComponent, deps: [{ token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Component }); }
267
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: AutocompleteComponent, selector: "nas-autocomplete", inputs: { label: "label", placeholder: "placeholder", icon: "icon", items: "items", open: "open", model: "model", disableBackdrop: "disableBackdrop", nasFormControlName: "nasFormControlName", nasFormGroup: "nasFormGroup", ariaLabelBackdrop: "ariaLabelBackdrop", ariaLabelClear: "ariaLabelClear" }, outputs: { focusOnNext: "focusOnNext", selectedChange: "selectedChange", openChange: "openChange", modelChange: "modelChange" }, viewQueries: [{ propertyName: "input", first: true, predicate: ["input"], descendants: true }, { propertyName: "span", first: true, predicate: ["span"], descendants: true }, { propertyName: "results", first: true, predicate: ["results"], descendants: true }, { propertyName: "labelElement", first: true, predicate: ["labelDOM"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<ng-container *ngIf=\"!nasFormControlName; else reactiveForm\">\n <label [id]=\"getLabelId()\" (input)=\"onInput($event)\" [attr.aria-label]=\"label\" [nasClass]=\"getClass('wrapper')\"\n #labelElement>\n <span [nasClass]=\"getClass('label')\" #span>{{label}}</span>\n <input #input type=\"text\" role=\"combobox\" aria-haspopup=\"true\" aria-autocomplete=\"none\" autocomplete=\"off\"\n [id]=\"getInputId()\" [attr.aria-controls]=\"getResultsId()\" [attr.aria-expanded]=\"open ? 'true' : 'false'\"\n [attr.aria-owns]=\"getResultsId()\" [nasClass]=\"getClass('input')\" [(ngModel)]=\"model\" [placeholder]=\"placeholder\"\n (focus)=\"setOpen()\" (input)=\"filter()\" (click)=\"setOpen()\" (keydown)=\"onKeyDown($event)\" />\n <span [nasClass]=\"getClass('icon')\">\n <button type=\"button\" role=\"button\" tabindex=\"-1\" *ngIf=\"model; else isEmpty\" [attr.aria-label]=\"ariaLabelClear\"\n (click)=\"clearSelected($event)\">\n <nas-icon [type]=\"setRemoveIcon()\"></nas-icon>\n </button>\n <ng-template #isEmpty>\n <nas-icon [type]=\"'small'\" [icon]=\"icon\"></nas-icon>\n </ng-template>\n </span>\n </label>\n</ng-container>\n<ng-template #reactiveForm>\n <label [id]=\"getLabelId()\" (input)=\"onInput($event)\" [attr.aria-label]=\"label\" [nasClass]=\"getClass('wrapper')\" [formGroup]=\"nasFormGroup\">\n <span [nasClass]=\"getClass('label')\" #span>{{label}}</span>\n <input #input type=\"text\" role=\"combobox\" aria-autocomplete=\"none\" autocomplete=\"off\" [id]=\"getInputId()\"\n [attr.aria-controls]=\"getResultsId()\" [attr.aria-expanded]=\"open ? 'true' : 'false'\"\n [attr.aria-owns]=\"getResultsId()\" [formControlName]=\"nasFormControlName\" [nasClass]=\"getClass('input')\"\n [placeholder]=\"placeholder\" (focus)=\"setOpen()\" (input)=\"filter()\" (click)=\"setOpen()\"\n (keydown)=\"onKeyDown($event)\" />\n <span [nasClass]=\"getClass('icon')\">\n <button type=\"button\" role=\"button\" tabindex=\"-1\" *ngIf=\"model; else isEmpty\" [attr.aria-label]=\"ariaLabelClear\"\n (click)=\"clearSelected($event)\">\n <nas-icon [type]=\"setRemoveIcon()\"></nas-icon>\n </button>\n <ng-template #isEmpty>\n <nas-icon [type]=\"'small'\" [icon]=\"icon\"></nas-icon>\n </ng-template>\n </span>\n </label>\n</ng-template>\n<div [id]=\"getResultsId()\" [nasClass]=\"getClass('results-wrapper')\" [attr.aria-expanded]=\"open ? 'true' : 'false'\">\n <ul #results role=\"listbox\" *ngIf=\"open\" [attr.aria-labelledby]=\"getLabelId()\" [nasClass]=\"getClass('results')\">\n <li role=\"option\" *ngFor=\"let item of filteredItems\" [id]=\"item.id\"\n [nasClass]=\"getClass('list-item', item.id === focused?.id && 'focus')\">\n <button type=\"button\" [nasClass]=\"getClass('item', item.id === focused?.id && 'focus')\" (click)=\"select(item)\"\n tabindex=\"-1\">\n <span [nasClass]=\"getClass('title')\">{{item.title}}</span>\n <span [nasClass]=\"getClass('preamble')\">{{item.preamble}}</span>\n </button>\n </li>\n </ul>\n</div>\n\n<nas-backdrop *ngIf=\"!exists(disableBackdrop)\" [ariaLabelBackdrop]=\"ariaLabelBackdrop\"\n [(showBackdrop)]=\"showBackdrop\"></nas-backdrop>", styles: ["@keyframes fade-in{0%{opacity:0}}@keyframes fade-in-down{0%{opacity:0;transform:translateY(-30px)}}@keyframes fade-in-left{0%{opacity:0;transform:translate(-30px)}}@keyframes fade-in-right{0%{opacity:0;transform:translate(30px)}}@keyframes fade-out{to{opacity:0}}@keyframes flip-in{0%{opacity:0;transform:rotateX(-90deg)}40%{opacity:1;transform:rotateX(10deg)}}@keyframes flip-out{to{opacity:0;transform:rotateX(-90deg)}}@keyframes pop-in-from-top{0%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-100,1,1);opacity:0}6.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-30.227,1,1)}13.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,1.76,1,1)}20%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,7.08,1,1)}26.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,3.838,1,1)}33.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,.902,1,1);opacity:1}40%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.237,1,1)}46.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.312,1,1)}53.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.141,1,1)}60%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.021,1,1)}66.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,.015,1,1)}73.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,.013,1,1)}80%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,.005,1,1)}86.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,0,1,1)}93.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.001,1,1);-webkit-transform:translate3d(0,0,0)}to{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.001,1,1);-webkit-transform:translate3d(0,0,0)}}.nas-autocomplete__wrapper{position:relative;display:block;z-index:3}.nas-autocomplete__label{font-family:NorwegianTextPro,Arial,Helvetica Neue,Helvetica,sans-serif;font-weight:700;font-size:14px;line-height:20px;display:block;position:relative;z-index:3;padding:9px 16px 0;background-color:#fff;margin-bottom:0;border:2px solid #6F6F6F;border-bottom:0}.nas-autocomplete__input{height:35px;position:relative;z-index:3;line-height:1;margin:0;border:2px solid #6F6F6F;border-top:none;padding:12px 16px}.nas-autocomplete__icon{position:absolute;z-index:4;right:24px;bottom:21px}.nas-autocomplete__results-wrapper{position:relative;z-index:4;perspective:1000px}.nas-autocomplete__results{margin-top:-8px;position:absolute;z-index:3;width:100%;top:2px;left:0;max-height:50vh;overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch;border:2px solid #15273F;background-color:#fff;transform-origin:center top;transform-style:preserve-3d;-webkit-backface-visibility:hidden;backface-visibility:hidden;animation:results .65s ease both;scrollbar-width:none;-ms-overflow-style:none;border-top:0;border-bottom:0}.nas-autocomplete__results::-webkit-scrollbar{display:none}.nas-autocomplete__backdrop{display:block;position:fixed;z-index:2;top:0;left:0;width:100%;height:100%;color:transparent;background-color:#0b14202b;animation:backdrop .7s ease-out both}.nas-autocomplete__item{display:block;position:relative;z-index:2;width:100%;text-align:left;padding:12px 16px;margin-top:-1px;outline:0;border-bottom:2px solid #E9E7E4}.nas-autocomplete__item--focus,.nas-autocomplete__item:focus{background-color:#ebf4ff;border-bottom-color:#15273f;border-top:2px solid #15273F}.nas-autocomplete__item--focus,.nas-autocomplete__item--focus .nas-autocomplete__title,.nas-autocomplete__item--focus .nas-autocomplete__preamble,.nas-autocomplete__item:focus,.nas-autocomplete__item:focus .nas-autocomplete__title,.nas-autocomplete__item:focus .nas-autocomplete__preamble{color:#15273f}.nas-autocomplete__item:hover{background-color:#f8f8f8}.nas-autocomplete__title{display:inline-block;font-family:NorwegianTextPro,Arial,Helvetica Neue,Helvetica,sans-serif;font-weight:700;line-height:1;color:#15273f;margin-bottom:3px}.nas-autocomplete__preamble{display:block;font-size:14px}@keyframes results{0%{transform:rotateX(-90deg)}40%{transform:rotateX(20deg)}to{transform:rotateX(0)}}@keyframes backdrop{0%{opacity:0}}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NasClassDirective, selector: "[nasClass]", inputs: ["nasClass", "attr.class"] }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i4.IconComponent, selector: "nas-icon", inputs: ["icon", "type", "isIndicator", "lightCircularBackground", "cssClass"] }, { kind: "component", type: i5.BackdropComponent, selector: "nas-backdrop", inputs: ["showBackdrop", "ariaLabelBackdrop"], outputs: ["showBackdropChange"] }, { kind: "directive", type: i3.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i3.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }] }); }
267
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: AutocompleteComponent, selector: "nas-autocomplete", inputs: { label: "label", placeholder: "placeholder", icon: "icon", items: "items", open: "open", model: "model", disableBackdrop: "disableBackdrop", nasFormControlName: "nasFormControlName", nasFormGroup: "nasFormGroup", ariaLabelBackdrop: "ariaLabelBackdrop", ariaLabelClear: "ariaLabelClear" }, outputs: { focusOnNext: "focusOnNext", selectedChange: "selectedChange", openChange: "openChange", modelChange: "modelChange" }, viewQueries: [{ propertyName: "input", first: true, predicate: ["input"], descendants: true }, { propertyName: "span", first: true, predicate: ["span"], descendants: true }, { propertyName: "results", first: true, predicate: ["results"], descendants: true }, { propertyName: "labelElement", first: true, predicate: ["labelDOM"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<ng-container *ngIf=\"!nasFormControlName; else reactiveForm\">\n <label [id]=\"getLabelId()\" (input)=\"onInput($event)\" [attr.aria-label]=\"label\" [nasClass]=\"getClass('wrapper', [open && 'active'])\"\n #labelElement>\n <span [nasClass]=\"getClass('label')\" #span>{{label}}</span>\n <input #input type=\"text\" role=\"combobox\" aria-haspopup=\"true\" aria-autocomplete=\"none\" autocomplete=\"off\"\n [id]=\"getInputId()\" [attr.aria-controls]=\"getResultsId()\" [attr.aria-expanded]=\"open ? 'true' : 'false'\"\n [attr.aria-owns]=\"getResultsId()\" [nasClass]=\"getClass('input')\" [(ngModel)]=\"model\" [placeholder]=\"placeholder\"\n (focus)=\"setOpen()\" (input)=\"filter()\" (click)=\"setOpen()\" (keydown)=\"onKeyDown($event)\" />\n <span [nasClass]=\"getClass('icon')\">\n <button type=\"button\" role=\"button\" tabindex=\"-1\" *ngIf=\"model; else isEmpty\" [attr.aria-label]=\"ariaLabelClear\"\n (click)=\"clearSelected($event)\">\n <nas-icon [type]=\"setRemoveIcon()\"></nas-icon>\n </button>\n <ng-template #isEmpty>\n <nas-icon [type]=\"'small'\" [icon]=\"icon\"></nas-icon>\n </ng-template>\n </span>\n </label>\n</ng-container>\n<ng-template #reactiveForm>\n <label [id]=\"getLabelId()\" (input)=\"onInput($event)\" [attr.aria-label]=\"label\" [nasClass]=\"getClass('wrapper', [open && 'active'])\" [formGroup]=\"nasFormGroup\">\n <span [nasClass]=\"getClass('label')\" #span>{{label}}</span>\n <input #input type=\"text\" role=\"combobox\" aria-autocomplete=\"none\" autocomplete=\"off\" [id]=\"getInputId()\"\n [attr.aria-controls]=\"getResultsId()\" [attr.aria-expanded]=\"open ? 'true' : 'false'\"\n [attr.aria-owns]=\"getResultsId()\" [formControlName]=\"nasFormControlName\" [nasClass]=\"getClass('input')\"\n [placeholder]=\"placeholder\" (focus)=\"setOpen()\" (input)=\"filter()\" (click)=\"setOpen()\"\n (keydown)=\"onKeyDown($event)\" />\n <span [nasClass]=\"getClass('icon')\">\n <button type=\"button\" role=\"button\" tabindex=\"-1\" *ngIf=\"model; else isEmpty\" [attr.aria-label]=\"ariaLabelClear\"\n (click)=\"clearSelected($event)\">\n <nas-icon [type]=\"setRemoveIcon()\"></nas-icon>\n </button>\n <ng-template #isEmpty>\n <nas-icon [type]=\"'small'\" [icon]=\"icon\"></nas-icon>\n </ng-template>\n </span>\n </label>\n</ng-template>\n<div [id]=\"getResultsId()\" [nasClass]=\"getClass('results-wrapper')\" [attr.aria-expanded]=\"open ? 'true' : 'false'\">\n <ul #results role=\"listbox\" *ngIf=\"open\" [attr.aria-labelledby]=\"getLabelId()\" [nasClass]=\"getClass('results')\">\n <li role=\"option\" *ngFor=\"let item of filteredItems\" [id]=\"item.id\"\n [nasClass]=\"getClass('list-item', item.id === focused?.id && 'focus')\">\n <button type=\"button\" [nasClass]=\"getClass('item', item.id === focused?.id && 'focus')\" (click)=\"select(item)\"\n tabindex=\"-1\">\n <span [nasClass]=\"getClass('title')\">{{item.title}}</span>\n <span [nasClass]=\"getClass('preamble')\">{{item.preamble}}</span>\n </button>\n </li>\n </ul>\n</div>\n\n<nas-backdrop *ngIf=\"!exists(disableBackdrop)\" [ariaLabelBackdrop]=\"ariaLabelBackdrop\"\n [(showBackdrop)]=\"showBackdrop\"></nas-backdrop>", styles: ["@keyframes fade-in{0%{opacity:0}}@keyframes fade-in-down{0%{opacity:0;transform:translateY(-30px)}}@keyframes fade-in-left{0%{opacity:0;transform:translate(-30px)}}@keyframes fade-in-right{0%{opacity:0;transform:translate(30px)}}@keyframes fade-out{to{opacity:0}}@keyframes flip-in{0%{opacity:0;transform:rotateX(-90deg)}40%{opacity:1;transform:rotateX(10deg)}}@keyframes flip-out{to{opacity:0;transform:rotateX(-90deg)}}@keyframes pop-in-from-top{0%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-100,1,1);opacity:0}6.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-30.227,1,1)}13.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,1.76,1,1)}20%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,7.08,1,1)}26.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,3.838,1,1)}33.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,.902,1,1);opacity:1}40%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.237,1,1)}46.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.312,1,1)}53.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.141,1,1)}60%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.021,1,1)}66.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,.015,1,1)}73.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,.013,1,1)}80%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,.005,1,1)}86.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,0,1,1)}93.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.001,1,1);-webkit-transform:translate3d(0,0,0)}to{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.001,1,1);-webkit-transform:translate3d(0,0,0)}}.nas-autocomplete__wrapper{position:relative;display:block;z-index:0}.nas-autocomplete__wrapper--active{z-index:3}.nas-autocomplete__label{font-family:NorwegianTextPro,Arial,Helvetica Neue,Helvetica,sans-serif;font-weight:700;font-size:14px;line-height:20px;display:block;position:relative;z-index:3;padding:9px 16px 0;background-color:#fff;margin-bottom:0;border:2px solid #6F6F6F;border-bottom:0}.nas-autocomplete__input{height:35px;position:relative;z-index:3;line-height:1;margin:0;border:2px solid #6F6F6F;border-top:none;padding:12px 16px}.nas-autocomplete__icon{position:absolute;z-index:4;right:24px;bottom:21px}.nas-autocomplete__results-wrapper{position:relative;z-index:4;perspective:1000px}.nas-autocomplete__results{margin-top:-8px;position:absolute;z-index:3;width:100%;top:2px;left:0;max-height:50vh;overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch;border:2px solid #15273F;background-color:#fff;transform-origin:center top;transform-style:preserve-3d;-webkit-backface-visibility:hidden;backface-visibility:hidden;animation:results .65s ease both;scrollbar-width:none;-ms-overflow-style:none;border-top:0;border-bottom:0}.nas-autocomplete__results::-webkit-scrollbar{display:none}.nas-autocomplete__backdrop{display:block;position:fixed;z-index:2;top:0;left:0;width:100%;height:100%;color:transparent;background-color:#0b14202b;animation:backdrop .7s ease-out both}.nas-autocomplete__item{display:block;position:relative;z-index:2;width:100%;text-align:left;padding:12px 16px;margin-top:-1px;outline:0;border-bottom:2px solid #E9E7E4}.nas-autocomplete__item--focus,.nas-autocomplete__item:focus{background-color:#ebf4ff;border-bottom-color:#15273f;border-top:2px solid #15273F}.nas-autocomplete__item--focus,.nas-autocomplete__item--focus .nas-autocomplete__title,.nas-autocomplete__item--focus .nas-autocomplete__preamble,.nas-autocomplete__item:focus,.nas-autocomplete__item:focus .nas-autocomplete__title,.nas-autocomplete__item:focus .nas-autocomplete__preamble{color:#15273f}.nas-autocomplete__item:hover{background-color:#f8f8f8}.nas-autocomplete__title{display:inline-block;font-family:NorwegianTextPro,Arial,Helvetica Neue,Helvetica,sans-serif;font-weight:700;line-height:1;color:#15273f;margin-bottom:3px}.nas-autocomplete__preamble{display:block;font-size:14px}@keyframes results{0%{transform:rotateX(-90deg)}40%{transform:rotateX(20deg)}to{transform:rotateX(0)}}@keyframes backdrop{0%{opacity:0}}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NasClassDirective, selector: "[nasClass]", inputs: ["nasClass", "attr.class"] }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i4.IconComponent, selector: "nas-icon", inputs: ["icon", "type", "isIndicator", "lightCircularBackground", "cssClass"] }, { kind: "component", type: i5.BackdropComponent, selector: "nas-backdrop", inputs: ["showBackdrop", "ariaLabelBackdrop"], outputs: ["showBackdropChange"] }, { kind: "directive", type: i3.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i3.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }] }); }
268
268
  }
269
269
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AutocompleteComponent, decorators: [{
270
270
  type: Component,
271
- args: [{ selector: 'nas-autocomplete', template: "<ng-container *ngIf=\"!nasFormControlName; else reactiveForm\">\n <label [id]=\"getLabelId()\" (input)=\"onInput($event)\" [attr.aria-label]=\"label\" [nasClass]=\"getClass('wrapper')\"\n #labelElement>\n <span [nasClass]=\"getClass('label')\" #span>{{label}}</span>\n <input #input type=\"text\" role=\"combobox\" aria-haspopup=\"true\" aria-autocomplete=\"none\" autocomplete=\"off\"\n [id]=\"getInputId()\" [attr.aria-controls]=\"getResultsId()\" [attr.aria-expanded]=\"open ? 'true' : 'false'\"\n [attr.aria-owns]=\"getResultsId()\" [nasClass]=\"getClass('input')\" [(ngModel)]=\"model\" [placeholder]=\"placeholder\"\n (focus)=\"setOpen()\" (input)=\"filter()\" (click)=\"setOpen()\" (keydown)=\"onKeyDown($event)\" />\n <span [nasClass]=\"getClass('icon')\">\n <button type=\"button\" role=\"button\" tabindex=\"-1\" *ngIf=\"model; else isEmpty\" [attr.aria-label]=\"ariaLabelClear\"\n (click)=\"clearSelected($event)\">\n <nas-icon [type]=\"setRemoveIcon()\"></nas-icon>\n </button>\n <ng-template #isEmpty>\n <nas-icon [type]=\"'small'\" [icon]=\"icon\"></nas-icon>\n </ng-template>\n </span>\n </label>\n</ng-container>\n<ng-template #reactiveForm>\n <label [id]=\"getLabelId()\" (input)=\"onInput($event)\" [attr.aria-label]=\"label\" [nasClass]=\"getClass('wrapper')\" [formGroup]=\"nasFormGroup\">\n <span [nasClass]=\"getClass('label')\" #span>{{label}}</span>\n <input #input type=\"text\" role=\"combobox\" aria-autocomplete=\"none\" autocomplete=\"off\" [id]=\"getInputId()\"\n [attr.aria-controls]=\"getResultsId()\" [attr.aria-expanded]=\"open ? 'true' : 'false'\"\n [attr.aria-owns]=\"getResultsId()\" [formControlName]=\"nasFormControlName\" [nasClass]=\"getClass('input')\"\n [placeholder]=\"placeholder\" (focus)=\"setOpen()\" (input)=\"filter()\" (click)=\"setOpen()\"\n (keydown)=\"onKeyDown($event)\" />\n <span [nasClass]=\"getClass('icon')\">\n <button type=\"button\" role=\"button\" tabindex=\"-1\" *ngIf=\"model; else isEmpty\" [attr.aria-label]=\"ariaLabelClear\"\n (click)=\"clearSelected($event)\">\n <nas-icon [type]=\"setRemoveIcon()\"></nas-icon>\n </button>\n <ng-template #isEmpty>\n <nas-icon [type]=\"'small'\" [icon]=\"icon\"></nas-icon>\n </ng-template>\n </span>\n </label>\n</ng-template>\n<div [id]=\"getResultsId()\" [nasClass]=\"getClass('results-wrapper')\" [attr.aria-expanded]=\"open ? 'true' : 'false'\">\n <ul #results role=\"listbox\" *ngIf=\"open\" [attr.aria-labelledby]=\"getLabelId()\" [nasClass]=\"getClass('results')\">\n <li role=\"option\" *ngFor=\"let item of filteredItems\" [id]=\"item.id\"\n [nasClass]=\"getClass('list-item', item.id === focused?.id && 'focus')\">\n <button type=\"button\" [nasClass]=\"getClass('item', item.id === focused?.id && 'focus')\" (click)=\"select(item)\"\n tabindex=\"-1\">\n <span [nasClass]=\"getClass('title')\">{{item.title}}</span>\n <span [nasClass]=\"getClass('preamble')\">{{item.preamble}}</span>\n </button>\n </li>\n </ul>\n</div>\n\n<nas-backdrop *ngIf=\"!exists(disableBackdrop)\" [ariaLabelBackdrop]=\"ariaLabelBackdrop\"\n [(showBackdrop)]=\"showBackdrop\"></nas-backdrop>", styles: ["@keyframes fade-in{0%{opacity:0}}@keyframes fade-in-down{0%{opacity:0;transform:translateY(-30px)}}@keyframes fade-in-left{0%{opacity:0;transform:translate(-30px)}}@keyframes fade-in-right{0%{opacity:0;transform:translate(30px)}}@keyframes fade-out{to{opacity:0}}@keyframes flip-in{0%{opacity:0;transform:rotateX(-90deg)}40%{opacity:1;transform:rotateX(10deg)}}@keyframes flip-out{to{opacity:0;transform:rotateX(-90deg)}}@keyframes pop-in-from-top{0%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-100,1,1);opacity:0}6.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-30.227,1,1)}13.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,1.76,1,1)}20%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,7.08,1,1)}26.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,3.838,1,1)}33.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,.902,1,1);opacity:1}40%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.237,1,1)}46.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.312,1,1)}53.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.141,1,1)}60%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.021,1,1)}66.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,.015,1,1)}73.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,.013,1,1)}80%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,.005,1,1)}86.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,0,1,1)}93.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.001,1,1);-webkit-transform:translate3d(0,0,0)}to{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.001,1,1);-webkit-transform:translate3d(0,0,0)}}.nas-autocomplete__wrapper{position:relative;display:block;z-index:3}.nas-autocomplete__label{font-family:NorwegianTextPro,Arial,Helvetica Neue,Helvetica,sans-serif;font-weight:700;font-size:14px;line-height:20px;display:block;position:relative;z-index:3;padding:9px 16px 0;background-color:#fff;margin-bottom:0;border:2px solid #6F6F6F;border-bottom:0}.nas-autocomplete__input{height:35px;position:relative;z-index:3;line-height:1;margin:0;border:2px solid #6F6F6F;border-top:none;padding:12px 16px}.nas-autocomplete__icon{position:absolute;z-index:4;right:24px;bottom:21px}.nas-autocomplete__results-wrapper{position:relative;z-index:4;perspective:1000px}.nas-autocomplete__results{margin-top:-8px;position:absolute;z-index:3;width:100%;top:2px;left:0;max-height:50vh;overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch;border:2px solid #15273F;background-color:#fff;transform-origin:center top;transform-style:preserve-3d;-webkit-backface-visibility:hidden;backface-visibility:hidden;animation:results .65s ease both;scrollbar-width:none;-ms-overflow-style:none;border-top:0;border-bottom:0}.nas-autocomplete__results::-webkit-scrollbar{display:none}.nas-autocomplete__backdrop{display:block;position:fixed;z-index:2;top:0;left:0;width:100%;height:100%;color:transparent;background-color:#0b14202b;animation:backdrop .7s ease-out both}.nas-autocomplete__item{display:block;position:relative;z-index:2;width:100%;text-align:left;padding:12px 16px;margin-top:-1px;outline:0;border-bottom:2px solid #E9E7E4}.nas-autocomplete__item--focus,.nas-autocomplete__item:focus{background-color:#ebf4ff;border-bottom-color:#15273f;border-top:2px solid #15273F}.nas-autocomplete__item--focus,.nas-autocomplete__item--focus .nas-autocomplete__title,.nas-autocomplete__item--focus .nas-autocomplete__preamble,.nas-autocomplete__item:focus,.nas-autocomplete__item:focus .nas-autocomplete__title,.nas-autocomplete__item:focus .nas-autocomplete__preamble{color:#15273f}.nas-autocomplete__item:hover{background-color:#f8f8f8}.nas-autocomplete__title{display:inline-block;font-family:NorwegianTextPro,Arial,Helvetica Neue,Helvetica,sans-serif;font-weight:700;line-height:1;color:#15273f;margin-bottom:3px}.nas-autocomplete__preamble{display:block;font-size:14px}@keyframes results{0%{transform:rotateX(-90deg)}40%{transform:rotateX(20deg)}to{transform:rotateX(0)}}@keyframes backdrop{0%{opacity:0}}\n"] }]
271
+ args: [{ selector: 'nas-autocomplete', template: "<ng-container *ngIf=\"!nasFormControlName; else reactiveForm\">\n <label [id]=\"getLabelId()\" (input)=\"onInput($event)\" [attr.aria-label]=\"label\" [nasClass]=\"getClass('wrapper', [open && 'active'])\"\n #labelElement>\n <span [nasClass]=\"getClass('label')\" #span>{{label}}</span>\n <input #input type=\"text\" role=\"combobox\" aria-haspopup=\"true\" aria-autocomplete=\"none\" autocomplete=\"off\"\n [id]=\"getInputId()\" [attr.aria-controls]=\"getResultsId()\" [attr.aria-expanded]=\"open ? 'true' : 'false'\"\n [attr.aria-owns]=\"getResultsId()\" [nasClass]=\"getClass('input')\" [(ngModel)]=\"model\" [placeholder]=\"placeholder\"\n (focus)=\"setOpen()\" (input)=\"filter()\" (click)=\"setOpen()\" (keydown)=\"onKeyDown($event)\" />\n <span [nasClass]=\"getClass('icon')\">\n <button type=\"button\" role=\"button\" tabindex=\"-1\" *ngIf=\"model; else isEmpty\" [attr.aria-label]=\"ariaLabelClear\"\n (click)=\"clearSelected($event)\">\n <nas-icon [type]=\"setRemoveIcon()\"></nas-icon>\n </button>\n <ng-template #isEmpty>\n <nas-icon [type]=\"'small'\" [icon]=\"icon\"></nas-icon>\n </ng-template>\n </span>\n </label>\n</ng-container>\n<ng-template #reactiveForm>\n <label [id]=\"getLabelId()\" (input)=\"onInput($event)\" [attr.aria-label]=\"label\" [nasClass]=\"getClass('wrapper', [open && 'active'])\" [formGroup]=\"nasFormGroup\">\n <span [nasClass]=\"getClass('label')\" #span>{{label}}</span>\n <input #input type=\"text\" role=\"combobox\" aria-autocomplete=\"none\" autocomplete=\"off\" [id]=\"getInputId()\"\n [attr.aria-controls]=\"getResultsId()\" [attr.aria-expanded]=\"open ? 'true' : 'false'\"\n [attr.aria-owns]=\"getResultsId()\" [formControlName]=\"nasFormControlName\" [nasClass]=\"getClass('input')\"\n [placeholder]=\"placeholder\" (focus)=\"setOpen()\" (input)=\"filter()\" (click)=\"setOpen()\"\n (keydown)=\"onKeyDown($event)\" />\n <span [nasClass]=\"getClass('icon')\">\n <button type=\"button\" role=\"button\" tabindex=\"-1\" *ngIf=\"model; else isEmpty\" [attr.aria-label]=\"ariaLabelClear\"\n (click)=\"clearSelected($event)\">\n <nas-icon [type]=\"setRemoveIcon()\"></nas-icon>\n </button>\n <ng-template #isEmpty>\n <nas-icon [type]=\"'small'\" [icon]=\"icon\"></nas-icon>\n </ng-template>\n </span>\n </label>\n</ng-template>\n<div [id]=\"getResultsId()\" [nasClass]=\"getClass('results-wrapper')\" [attr.aria-expanded]=\"open ? 'true' : 'false'\">\n <ul #results role=\"listbox\" *ngIf=\"open\" [attr.aria-labelledby]=\"getLabelId()\" [nasClass]=\"getClass('results')\">\n <li role=\"option\" *ngFor=\"let item of filteredItems\" [id]=\"item.id\"\n [nasClass]=\"getClass('list-item', item.id === focused?.id && 'focus')\">\n <button type=\"button\" [nasClass]=\"getClass('item', item.id === focused?.id && 'focus')\" (click)=\"select(item)\"\n tabindex=\"-1\">\n <span [nasClass]=\"getClass('title')\">{{item.title}}</span>\n <span [nasClass]=\"getClass('preamble')\">{{item.preamble}}</span>\n </button>\n </li>\n </ul>\n</div>\n\n<nas-backdrop *ngIf=\"!exists(disableBackdrop)\" [ariaLabelBackdrop]=\"ariaLabelBackdrop\"\n [(showBackdrop)]=\"showBackdrop\"></nas-backdrop>", styles: ["@keyframes fade-in{0%{opacity:0}}@keyframes fade-in-down{0%{opacity:0;transform:translateY(-30px)}}@keyframes fade-in-left{0%{opacity:0;transform:translate(-30px)}}@keyframes fade-in-right{0%{opacity:0;transform:translate(30px)}}@keyframes fade-out{to{opacity:0}}@keyframes flip-in{0%{opacity:0;transform:rotateX(-90deg)}40%{opacity:1;transform:rotateX(10deg)}}@keyframes flip-out{to{opacity:0;transform:rotateX(-90deg)}}@keyframes pop-in-from-top{0%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-100,1,1);opacity:0}6.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-30.227,1,1)}13.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,1.76,1,1)}20%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,7.08,1,1)}26.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,3.838,1,1)}33.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,.902,1,1);opacity:1}40%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.237,1,1)}46.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.312,1,1)}53.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.141,1,1)}60%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.021,1,1)}66.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,.015,1,1)}73.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,.013,1,1)}80%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,.005,1,1)}86.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,0,1,1)}93.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.001,1,1);-webkit-transform:translate3d(0,0,0)}to{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.001,1,1);-webkit-transform:translate3d(0,0,0)}}.nas-autocomplete__wrapper{position:relative;display:block;z-index:0}.nas-autocomplete__wrapper--active{z-index:3}.nas-autocomplete__label{font-family:NorwegianTextPro,Arial,Helvetica Neue,Helvetica,sans-serif;font-weight:700;font-size:14px;line-height:20px;display:block;position:relative;z-index:3;padding:9px 16px 0;background-color:#fff;margin-bottom:0;border:2px solid #6F6F6F;border-bottom:0}.nas-autocomplete__input{height:35px;position:relative;z-index:3;line-height:1;margin:0;border:2px solid #6F6F6F;border-top:none;padding:12px 16px}.nas-autocomplete__icon{position:absolute;z-index:4;right:24px;bottom:21px}.nas-autocomplete__results-wrapper{position:relative;z-index:4;perspective:1000px}.nas-autocomplete__results{margin-top:-8px;position:absolute;z-index:3;width:100%;top:2px;left:0;max-height:50vh;overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch;border:2px solid #15273F;background-color:#fff;transform-origin:center top;transform-style:preserve-3d;-webkit-backface-visibility:hidden;backface-visibility:hidden;animation:results .65s ease both;scrollbar-width:none;-ms-overflow-style:none;border-top:0;border-bottom:0}.nas-autocomplete__results::-webkit-scrollbar{display:none}.nas-autocomplete__backdrop{display:block;position:fixed;z-index:2;top:0;left:0;width:100%;height:100%;color:transparent;background-color:#0b14202b;animation:backdrop .7s ease-out both}.nas-autocomplete__item{display:block;position:relative;z-index:2;width:100%;text-align:left;padding:12px 16px;margin-top:-1px;outline:0;border-bottom:2px solid #E9E7E4}.nas-autocomplete__item--focus,.nas-autocomplete__item:focus{background-color:#ebf4ff;border-bottom-color:#15273f;border-top:2px solid #15273F}.nas-autocomplete__item--focus,.nas-autocomplete__item--focus .nas-autocomplete__title,.nas-autocomplete__item--focus .nas-autocomplete__preamble,.nas-autocomplete__item:focus,.nas-autocomplete__item:focus .nas-autocomplete__title,.nas-autocomplete__item:focus .nas-autocomplete__preamble{color:#15273f}.nas-autocomplete__item:hover{background-color:#f8f8f8}.nas-autocomplete__title{display:inline-block;font-family:NorwegianTextPro,Arial,Helvetica Neue,Helvetica,sans-serif;font-weight:700;line-height:1;color:#15273f;margin-bottom:3px}.nas-autocomplete__preamble{display:block;font-size:14px}@keyframes results{0%{transform:rotateX(-90deg)}40%{transform:rotateX(20deg)}to{transform:rotateX(0)}}@keyframes backdrop{0%{opacity:0}}\n"] }]
272
272
  }], ctorParameters: function () { return [{ type: undefined, decorators: [{
273
273
  type: Inject,
274
274
  args: [DOCUMENT]
@@ -315,4 +315,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
315
315
  }], modelChange: [{
316
316
  type: Output
317
317
  }] } });
318
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete.component.js","sourceRoot":"","sources":["../../../../../../projects/core-components/src/lib/components/autocomplete/autocomplete.component.ts","../../../../../../projects/core-components/src/lib/components/autocomplete/autocomplete.component.html"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Norwegian Air Shuttle. All Rights Reserved.\n */\nimport {\n  Component,\n  ElementRef,\n  EventEmitter,\n  Inject,\n  Input,\n  Output,\n  ViewChild,\n  OnInit\n} from '@angular/core';\nimport { DOCUMENT } from '@angular/common';\nimport { NasComponentBase } from '../../core';\nimport { FormGroup } from '@angular/forms';\nimport { AutocompleteModel } from './models/autocomplete.model';\n\nlet nextId = 0;\n\n/**\n * @description\n * Norwegian Airport Select Component | Form Controls | New design\n */\n@Component({\n  selector: 'nas-autocomplete',\n  templateUrl: './autocomplete.component.html',\n  styleUrls: ['./autocomplete.component.scss']\n})\nexport class AutocompleteComponent extends NasComponentBase implements OnInit {\n  filteredItems: Array<AutocompleteModel> = this.items;\n  focused: AutocompleteModel;\n  index = -1;\n\n  get showBackdrop(): boolean {\n    return !this.exists(this.disableBackdrop) && this.open;\n  }\n  set showBackdrop(value: boolean) {\n    if (!value) {\n      this.blur();\n    }\n  }\n\n  @ViewChild('input') input: ElementRef;\n  @ViewChild('span') span: ElementRef;\n  @ViewChild('results') results: ElementRef;\n  @ViewChild('labelDOM') labelElement: ElementRef<HTMLElement>;\n\n  /**\n   * @property Input\n   * @description\n   * A label that will appear inside the text field.\n   */\n  @Input() label: string;\n\n  /**\n   * @property Input\n   * @description\n   * A placeholder that will appear inside the text field.\n   */\n  @Input() placeholder = '';\n\n  /**\n   * @property Input\n   * @description\n   * An icon that will appear inside the text field.\n   */\n  @Input() icon: string;\n\n  /**\n   * @property Input\n   * @description\n   * An array of items that will appear inside the dropdown list.\n   */\n  @Input()\n  get items(): Array<AutocompleteModel> {\n    return this.itemsValue;\n  }\n  set items(items: Array<AutocompleteModel>) {\n    if (!items || items.length <= 0) {\n      return;\n    }\n\n    this.itemsValue = items;\n\n    this.filter();\n  }\n\n  /**\n   * @property Input\n   * @description\n   * Can set and listen to wheather the dropdown list is or should be open or not.\n   */\n  @Input()\n  get open() {\n    return this.openValue;\n  }\n  set open(open: boolean) {\n    if (this.open === open || !this.items) {\n      return;\n    }\n\n    this.openValue = open;\n    this.openChange.emit(open);\n  }\n\n  /**\n   * @property Input\n   * @description\n   * Can set and listen to changes in the model of the text field.\n   */\n  @Input()\n  get model(): string {\n    return this.modelValue;\n  }\n  set model(model: string) {\n    if (this.modelValue === model) {\n      return;\n    }\n\n    this.modelValue = model;\n\n    if (model && this.filteredItems) {\n      this.index = this.filteredItems.findIndex(x => x.title === model);\n    }\n\n    this.pathReactiveFormControl(model);\n\n    this.modelChange.emit(model);\n  }\n\n  /**\n   * @property Input\n   * @description\n   * Disables the backdrop on focus.\n   */\n  @Input() disableBackdrop: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Sets a formControlName directive to the input.\n   * It requires that the consumer included ReactiveFormsModule in it's module.\n   * It requiers that the nasFormGroup input is filled.\n   */\n  @Input() nasFormControlName: string;\n\n  /**\n   * @property Input\n   * @description\n   * Adds the parent's form group.\n   * It requires that the consumer included ReactiveFormsModule in it's module.\n   * It is requiered to be filled if nasFormControlName added.\n   */\n  @Input() nasFormGroup: FormGroup;\n\n  /**\n   * @property Input\n   * @description\n   * Adds an aria-label attribute to the backdrop button.\n   */\n  @Input() ariaLabelBackdrop: string;\n\n  /**\n   * @property Input\n   * @description\n   * Adds 'aria-label' on the clear button inside input.\n   */\n  @Input() ariaLabelClear: string;\n\n  /**\n   * @property Output\n   * @description\n   * Is fired when the next element should be focused.\n   */\n  @Output() focusOnNext = new EventEmitter();\n\n  /**\n   * @property Output\n   * @description\n   * Is fired when the user selects an item in the dropdown list.\n   */\n  @Output() selectedChange = new EventEmitter<AutocompleteModel>();\n\n  @Output() openChange = new EventEmitter<boolean>();\n  @Output() modelChange = new EventEmitter<string>();\n\n  private openValue = false;\n  private itemsValue: Array<AutocompleteModel>;\n  private modelValue: string;\n  private componentId: number;\n\n  constructor(@Inject(DOCUMENT) private document: any) {\n    super('nas-autocomplete');\n    this.componentId = nextId++;\n  }\n\n  ngOnInit(): void {\n    if (!this.ariaLabelClear) {\n      this.warnMissingAccessibiltyInput('ariaLabelClear');\n    }\n\n    if (!this.ariaLabelBackdrop) {\n      this.warnMissingAccessibiltyInput('ariaLabelBackdrop');\n    }\n  }\n\n  getResultsId(): string {\n    return `nas-autocomplete-results-${this.componentId}`;\n  }\n\n  getLabelId(): string {\n    return `nas-autocomplete-label-${this.componentId}`;\n  }\n\n  getInputId(): string {\n    return `nas-autocomplete-input-${this.componentId}`;\n  }\n\n  setOpen(): void {\n    this.input.nativeElement.select();\n    this.open = true;\n  }\n\n  filter(): void {\n    if (!this.items) {\n      return;\n    }\n\n    if (!this.model && (!this.nasFormGroup || !this.nasFormControlName)) {\n      this.filteredItems = this.items;\n      return;\n    }\n\n    let currentModel = this.model;\n\n    if (this.nasFormGroup && this.nasFormControlName) {\n      const control = this.nasFormGroup.get(this.nasFormControlName);\n\n      currentModel = control.value;\n      this.model = control.value;\n    }\n\n    this.filteredItems = this.items.filter(x =>\n      (x.title && x.title.toLowerCase().includes(currentModel.toLowerCase())) ||\n      (x.preamble && x.preamble.toLowerCase().includes(currentModel.toLowerCase())));\n\n    if (currentModel === '' || this.input.nativeElement.value === '') {\n      this.filteredItems = this.items;\n    }\n\n    this.index = 0;\n    if (this.filteredItems) {\n      this.focused = this.filteredItems[this.index];\n      this.open = true;\n    } else {\n      this.open = false;\n    }\n  }\n\n  onKeyDown(event: KeyboardEvent): void {\n    switch (event.key) {\n      case 'Escape':\n        this.open = false;\n        this.blur();\n        break;\n      case 'Tab':\n      case 'Enter':\n        if (!event.shiftKey) {\n          event.preventDefault();\n          this.focusOnNext.emit(event);\n        }\n\n        if (this.focused) {\n          this.modelValue = this.focused.title;\n          this.selectedChange.emit(this.focused);\n          this.pathReactiveFormControl(this.modelValue);\n        }\n\n        this.blur();\n        break;\n      case 'ArrowDown':\n      case 'Down':\n        this.focusDown();\n        break;\n      case 'ArrowUp':\n      case 'Up':\n        this.focusUp();\n        break;\n      default:\n        break;\n    }\n  }\n\n  clearSelected(event: any): void {\n    event.preventDefault();\n\n    this.focused = null;\n    this.filteredItems = this.items;\n    this.model = '';\n    this.open = true;\n    this.index = -1;\n\n    if(!!this.input && !!this.span) {\n      this.input.nativeElement.style.borderColor = '#6f6f6f';\n      this.span.nativeElement.style.borderColor = '#6f6f6f';\n    }\n\n    this.input.nativeElement.focus();\n  }\n\n  select(item: AutocompleteModel): void {\n    this.focused = item;\n    this.model = item.title;\n    this.selectedChange.emit(item);\n\n    if (this.filteredItems) {\n      this.index = this.filteredItems.findIndex(x => x.id === item.id);\n    }\n\n    this.open = false;\n    this.focusOnNext.emit();\n  }\n\n  blur(): void {\n    this.open = false;\n    this.openChange.emit(false);\n  }\n\n  private focusDown(): void {\n    ++this.index;\n\n    if (this.filteredItems) {\n      if (!this.filteredItems[this.index]) {\n        this.index = 0;\n      }\n\n      this.focused = this.filteredItems[this.index];\n    }\n\n    if (this.index === 0) {\n      this.autoScroll(0);\n    } else {\n      this.autoScroll(131);\n    }\n  }\n\n  private focusUp(): void {\n    --this.index;\n\n    if (this.index < 0) {\n      this.index = 0;\n      this.blur();\n      return;\n    }\n\n    if (this.filteredItems) {\n      this.focused = this.filteredItems[this.index];\n    }\n\n    this.autoScroll(0);\n  }\n\n  pathReactiveFormControl(model: string): void {\n    if (this.nasFormGroup && this.nasFormControlName) {\n      const formControl = this.nasFormGroup.get(this.nasFormControlName);\n      formControl.patchValue(model);\n    }\n  }\n\n  private autoScroll(extraOffset: number): void {\n    if (!this.results) {\n      return;\n    }\n    const results = this.results.nativeElement;\n    const focusedItem = this.document.querySelector('.nas-autocomplete__list-item--focus');\n\n    if (focusedItem) {\n      results.scrollTo(0, 0);\n      results.scrollTo(0, focusedItem.offsetTop + extraOffset - results.clientHeight);\n    }\n  }\n\n  onInput(event: Event): void {\n    const inputElement = event.target as HTMLInputElement;\n    if (this.label.length > 0) {\n      this.input.nativeElement.style.borderColor = inputElement.value ? '#15273f' : '#6f6f6f';\n      this.span.nativeElement.style.borderColor = inputElement.value ? '#15273f' : '#6f6f6f';\n    }\n  }\n\n  setRemoveIcon(): string {\n    return this.model ? 'remove--secondary' : 'remove';\n  }\n}\n","<ng-container *ngIf=\"!nasFormControlName; else reactiveForm\">\n  <label [id]=\"getLabelId()\" (input)=\"onInput($event)\" [attr.aria-label]=\"label\" [nasClass]=\"getClass('wrapper')\"\n    #labelElement>\n    <span [nasClass]=\"getClass('label')\" #span>{{label}}</span>\n    <input #input type=\"text\" role=\"combobox\" aria-haspopup=\"true\" aria-autocomplete=\"none\" autocomplete=\"off\"\n      [id]=\"getInputId()\" [attr.aria-controls]=\"getResultsId()\" [attr.aria-expanded]=\"open ? 'true' : 'false'\"\n      [attr.aria-owns]=\"getResultsId()\" [nasClass]=\"getClass('input')\" [(ngModel)]=\"model\" [placeholder]=\"placeholder\"\n      (focus)=\"setOpen()\" (input)=\"filter()\" (click)=\"setOpen()\" (keydown)=\"onKeyDown($event)\" />\n    <span [nasClass]=\"getClass('icon')\">\n      <button type=\"button\" role=\"button\" tabindex=\"-1\" *ngIf=\"model; else isEmpty\" [attr.aria-label]=\"ariaLabelClear\"\n        (click)=\"clearSelected($event)\">\n        <nas-icon [type]=\"setRemoveIcon()\"></nas-icon>\n      </button>\n      <ng-template #isEmpty>\n        <nas-icon [type]=\"'small'\" [icon]=\"icon\"></nas-icon>\n      </ng-template>\n    </span>\n  </label>\n</ng-container>\n<ng-template #reactiveForm>\n  <label [id]=\"getLabelId()\" (input)=\"onInput($event)\" [attr.aria-label]=\"label\" [nasClass]=\"getClass('wrapper')\" [formGroup]=\"nasFormGroup\">\n    <span [nasClass]=\"getClass('label')\" #span>{{label}}</span>\n    <input #input type=\"text\" role=\"combobox\" aria-autocomplete=\"none\" autocomplete=\"off\" [id]=\"getInputId()\"\n      [attr.aria-controls]=\"getResultsId()\" [attr.aria-expanded]=\"open ? 'true' : 'false'\"\n      [attr.aria-owns]=\"getResultsId()\" [formControlName]=\"nasFormControlName\" [nasClass]=\"getClass('input')\"\n      [placeholder]=\"placeholder\" (focus)=\"setOpen()\" (input)=\"filter()\" (click)=\"setOpen()\"\n      (keydown)=\"onKeyDown($event)\" />\n    <span [nasClass]=\"getClass('icon')\">\n      <button type=\"button\" role=\"button\" tabindex=\"-1\" *ngIf=\"model; else isEmpty\" [attr.aria-label]=\"ariaLabelClear\"\n        (click)=\"clearSelected($event)\">\n        <nas-icon [type]=\"setRemoveIcon()\"></nas-icon>\n      </button>\n      <ng-template #isEmpty>\n        <nas-icon [type]=\"'small'\" [icon]=\"icon\"></nas-icon>\n      </ng-template>\n    </span>\n  </label>\n</ng-template>\n<div [id]=\"getResultsId()\" [nasClass]=\"getClass('results-wrapper')\" [attr.aria-expanded]=\"open ? 'true' : 'false'\">\n  <ul #results role=\"listbox\" *ngIf=\"open\" [attr.aria-labelledby]=\"getLabelId()\" [nasClass]=\"getClass('results')\">\n    <li role=\"option\" *ngFor=\"let item of filteredItems\" [id]=\"item.id\"\n      [nasClass]=\"getClass('list-item', item.id === focused?.id && 'focus')\">\n      <button type=\"button\" [nasClass]=\"getClass('item', item.id === focused?.id && 'focus')\" (click)=\"select(item)\"\n        tabindex=\"-1\">\n        <span [nasClass]=\"getClass('title')\">{{item.title}}</span>\n        <span [nasClass]=\"getClass('preamble')\">{{item.preamble}}</span>\n      </button>\n    </li>\n  </ul>\n</div>\n\n<nas-backdrop *ngIf=\"!exists(disableBackdrop)\" [ariaLabelBackdrop]=\"ariaLabelBackdrop\"\n  [(showBackdrop)]=\"showBackdrop\"></nas-backdrop>"]}
318
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete.component.js","sourceRoot":"","sources":["../../../../../../projects/core-components/src/lib/components/autocomplete/autocomplete.component.ts","../../../../../../projects/core-components/src/lib/components/autocomplete/autocomplete.component.html"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Norwegian Air Shuttle. All Rights Reserved.\n */\nimport {\n  Component,\n  ElementRef,\n  EventEmitter,\n  Inject,\n  Input,\n  Output,\n  ViewChild,\n  OnInit\n} from '@angular/core';\nimport { DOCUMENT } from '@angular/common';\nimport { NasComponentBase } from '../../core';\nimport { FormGroup } from '@angular/forms';\nimport { AutocompleteModel } from './models/autocomplete.model';\n\nlet nextId = 0;\n\n/**\n * @description\n * Norwegian Airport Select Component | Form Controls | New design\n */\n@Component({\n  selector: 'nas-autocomplete',\n  templateUrl: './autocomplete.component.html',\n  styleUrls: ['./autocomplete.component.scss']\n})\nexport class AutocompleteComponent extends NasComponentBase implements OnInit {\n  filteredItems: Array<AutocompleteModel> = this.items;\n  focused: AutocompleteModel;\n  index = -1;\n\n  get showBackdrop(): boolean {\n    return !this.exists(this.disableBackdrop) && this.open;\n  }\n  set showBackdrop(value: boolean) {\n    if (!value) {\n      this.blur();\n    }\n  }\n\n  @ViewChild('input') input: ElementRef;\n  @ViewChild('span') span: ElementRef;\n  @ViewChild('results') results: ElementRef;\n  @ViewChild('labelDOM') labelElement: ElementRef<HTMLElement>;\n\n  /**\n   * @property Input\n   * @description\n   * A label that will appear inside the text field.\n   */\n  @Input() label: string;\n\n  /**\n   * @property Input\n   * @description\n   * A placeholder that will appear inside the text field.\n   */\n  @Input() placeholder = '';\n\n  /**\n   * @property Input\n   * @description\n   * An icon that will appear inside the text field.\n   */\n  @Input() icon: string;\n\n  /**\n   * @property Input\n   * @description\n   * An array of items that will appear inside the dropdown list.\n   */\n  @Input()\n  get items(): Array<AutocompleteModel> {\n    return this.itemsValue;\n  }\n  set items(items: Array<AutocompleteModel>) {\n    if (!items || items.length <= 0) {\n      return;\n    }\n\n    this.itemsValue = items;\n\n    this.filter();\n  }\n\n  /**\n   * @property Input\n   * @description\n   * Can set and listen to wheather the dropdown list is or should be open or not.\n   */\n  @Input()\n  get open() {\n    return this.openValue;\n  }\n  set open(open: boolean) {\n    if (this.open === open || !this.items) {\n      return;\n    }\n\n    this.openValue = open;\n    this.openChange.emit(open);\n  }\n\n  /**\n   * @property Input\n   * @description\n   * Can set and listen to changes in the model of the text field.\n   */\n  @Input()\n  get model(): string {\n    return this.modelValue;\n  }\n  set model(model: string) {\n    if (this.modelValue === model) {\n      return;\n    }\n\n    this.modelValue = model;\n\n    if (model && this.filteredItems) {\n      this.index = this.filteredItems.findIndex(x => x.title === model);\n    }\n\n    this.pathReactiveFormControl(model);\n\n    this.modelChange.emit(model);\n  }\n\n  /**\n   * @property Input\n   * @description\n   * Disables the backdrop on focus.\n   */\n  @Input() disableBackdrop: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Sets a formControlName directive to the input.\n   * It requires that the consumer included ReactiveFormsModule in it's module.\n   * It requiers that the nasFormGroup input is filled.\n   */\n  @Input() nasFormControlName: string;\n\n  /**\n   * @property Input\n   * @description\n   * Adds the parent's form group.\n   * It requires that the consumer included ReactiveFormsModule in it's module.\n   * It is requiered to be filled if nasFormControlName added.\n   */\n  @Input() nasFormGroup: FormGroup;\n\n  /**\n   * @property Input\n   * @description\n   * Adds an aria-label attribute to the backdrop button.\n   */\n  @Input() ariaLabelBackdrop: string;\n\n  /**\n   * @property Input\n   * @description\n   * Adds 'aria-label' on the clear button inside input.\n   */\n  @Input() ariaLabelClear: string;\n\n  /**\n   * @property Output\n   * @description\n   * Is fired when the next element should be focused.\n   */\n  @Output() focusOnNext = new EventEmitter();\n\n  /**\n   * @property Output\n   * @description\n   * Is fired when the user selects an item in the dropdown list.\n   */\n  @Output() selectedChange = new EventEmitter<AutocompleteModel>();\n\n  @Output() openChange = new EventEmitter<boolean>();\n  @Output() modelChange = new EventEmitter<string>();\n\n  private openValue = false;\n  private itemsValue: Array<AutocompleteModel>;\n  private modelValue: string;\n  private componentId: number;\n\n  constructor(@Inject(DOCUMENT) private document: any) {\n    super('nas-autocomplete');\n    this.componentId = nextId++;\n  }\n\n  ngOnInit(): void {\n    if (!this.ariaLabelClear) {\n      this.warnMissingAccessibiltyInput('ariaLabelClear');\n    }\n\n    if (!this.ariaLabelBackdrop) {\n      this.warnMissingAccessibiltyInput('ariaLabelBackdrop');\n    }\n  }\n\n  getResultsId(): string {\n    return `nas-autocomplete-results-${this.componentId}`;\n  }\n\n  getLabelId(): string {\n    return `nas-autocomplete-label-${this.componentId}`;\n  }\n\n  getInputId(): string {\n    return `nas-autocomplete-input-${this.componentId}`;\n  }\n\n  setOpen(): void {\n    this.input.nativeElement.select();\n    this.open = true;\n  }\n\n  filter(): void {\n    if (!this.items) {\n      return;\n    }\n\n    if (!this.model && (!this.nasFormGroup || !this.nasFormControlName)) {\n      this.filteredItems = this.items;\n      return;\n    }\n\n    let currentModel = this.model;\n\n    if (this.nasFormGroup && this.nasFormControlName) {\n      const control = this.nasFormGroup.get(this.nasFormControlName);\n\n      currentModel = control.value;\n      this.model = control.value;\n    }\n\n    this.filteredItems = this.items.filter(x =>\n      (x.title && x.title.toLowerCase().includes(currentModel.toLowerCase())) ||\n      (x.preamble && x.preamble.toLowerCase().includes(currentModel.toLowerCase())));\n\n    if (currentModel === '' || this.input.nativeElement.value === '') {\n      this.filteredItems = this.items;\n    }\n\n    this.index = 0;\n    if (this.filteredItems) {\n      this.focused = this.filteredItems[this.index];\n      this.open = true;\n    } else {\n      this.open = false;\n    }\n  }\n\n  onKeyDown(event: KeyboardEvent): void {\n    switch (event.key) {\n      case 'Escape':\n        this.open = false;\n        this.blur();\n        break;\n      case 'Tab':\n      case 'Enter':\n        if (!event.shiftKey) {\n          event.preventDefault();\n          this.focusOnNext.emit(event);\n        }\n\n        if (this.focused) {\n          this.modelValue = this.focused.title;\n          this.selectedChange.emit(this.focused);\n          this.pathReactiveFormControl(this.modelValue);\n        }\n\n        this.blur();\n        break;\n      case 'ArrowDown':\n      case 'Down':\n        this.focusDown();\n        break;\n      case 'ArrowUp':\n      case 'Up':\n        this.focusUp();\n        break;\n      default:\n        break;\n    }\n  }\n\n  clearSelected(event: any): void {\n    event.preventDefault();\n\n    this.focused = null;\n    this.filteredItems = this.items;\n    this.model = '';\n    this.open = true;\n    this.index = -1;\n\n    if(!!this.input && !!this.span) {\n      this.input.nativeElement.style.borderColor = '#6f6f6f';\n      this.span.nativeElement.style.borderColor = '#6f6f6f';\n    }\n\n    this.input.nativeElement.focus();\n  }\n\n  select(item: AutocompleteModel): void {\n    this.focused = item;\n    this.model = item.title;\n    this.selectedChange.emit(item);\n\n    if (this.filteredItems) {\n      this.index = this.filteredItems.findIndex(x => x.id === item.id);\n    }\n\n    this.open = false;\n    this.focusOnNext.emit();\n  }\n\n  blur(): void {\n    this.open = false;\n    this.openChange.emit(false);\n  }\n\n  private focusDown(): void {\n    ++this.index;\n\n    if (this.filteredItems) {\n      if (!this.filteredItems[this.index]) {\n        this.index = 0;\n      }\n\n      this.focused = this.filteredItems[this.index];\n    }\n\n    if (this.index === 0) {\n      this.autoScroll(0);\n    } else {\n      this.autoScroll(131);\n    }\n  }\n\n  private focusUp(): void {\n    --this.index;\n\n    if (this.index < 0) {\n      this.index = 0;\n      this.blur();\n      return;\n    }\n\n    if (this.filteredItems) {\n      this.focused = this.filteredItems[this.index];\n    }\n\n    this.autoScroll(0);\n  }\n\n  pathReactiveFormControl(model: string): void {\n    if (this.nasFormGroup && this.nasFormControlName) {\n      const formControl = this.nasFormGroup.get(this.nasFormControlName);\n      formControl.patchValue(model);\n    }\n  }\n\n  private autoScroll(extraOffset: number): void {\n    if (!this.results) {\n      return;\n    }\n    const results = this.results.nativeElement;\n    const focusedItem = this.document.querySelector('.nas-autocomplete__list-item--focus');\n\n    if (focusedItem) {\n      results.scrollTo(0, 0);\n      results.scrollTo(0, focusedItem.offsetTop + extraOffset - results.clientHeight);\n    }\n  }\n\n  onInput(event: Event): void {\n    const inputElement = event.target as HTMLInputElement;\n    if (this.label.length > 0) {\n      this.input.nativeElement.style.borderColor = inputElement.value ? '#15273f' : '#6f6f6f';\n      this.span.nativeElement.style.borderColor = inputElement.value ? '#15273f' : '#6f6f6f';\n    }\n  }\n\n  setRemoveIcon(): string {\n    return this.model ? 'remove--secondary' : 'remove';\n  }\n}\n","<ng-container *ngIf=\"!nasFormControlName; else reactiveForm\">\n  <label [id]=\"getLabelId()\" (input)=\"onInput($event)\" [attr.aria-label]=\"label\" [nasClass]=\"getClass('wrapper', [open && 'active'])\"\n    #labelElement>\n    <span [nasClass]=\"getClass('label')\" #span>{{label}}</span>\n    <input #input type=\"text\" role=\"combobox\" aria-haspopup=\"true\" aria-autocomplete=\"none\" autocomplete=\"off\"\n      [id]=\"getInputId()\" [attr.aria-controls]=\"getResultsId()\" [attr.aria-expanded]=\"open ? 'true' : 'false'\"\n      [attr.aria-owns]=\"getResultsId()\" [nasClass]=\"getClass('input')\" [(ngModel)]=\"model\" [placeholder]=\"placeholder\"\n      (focus)=\"setOpen()\" (input)=\"filter()\" (click)=\"setOpen()\" (keydown)=\"onKeyDown($event)\" />\n    <span [nasClass]=\"getClass('icon')\">\n      <button type=\"button\" role=\"button\" tabindex=\"-1\" *ngIf=\"model; else isEmpty\" [attr.aria-label]=\"ariaLabelClear\"\n        (click)=\"clearSelected($event)\">\n        <nas-icon [type]=\"setRemoveIcon()\"></nas-icon>\n      </button>\n      <ng-template #isEmpty>\n        <nas-icon [type]=\"'small'\" [icon]=\"icon\"></nas-icon>\n      </ng-template>\n    </span>\n  </label>\n</ng-container>\n<ng-template #reactiveForm>\n  <label [id]=\"getLabelId()\" (input)=\"onInput($event)\" [attr.aria-label]=\"label\" [nasClass]=\"getClass('wrapper', [open && 'active'])\" [formGroup]=\"nasFormGroup\">\n    <span [nasClass]=\"getClass('label')\" #span>{{label}}</span>\n    <input #input type=\"text\" role=\"combobox\" aria-autocomplete=\"none\" autocomplete=\"off\" [id]=\"getInputId()\"\n      [attr.aria-controls]=\"getResultsId()\" [attr.aria-expanded]=\"open ? 'true' : 'false'\"\n      [attr.aria-owns]=\"getResultsId()\" [formControlName]=\"nasFormControlName\" [nasClass]=\"getClass('input')\"\n      [placeholder]=\"placeholder\" (focus)=\"setOpen()\" (input)=\"filter()\" (click)=\"setOpen()\"\n      (keydown)=\"onKeyDown($event)\" />\n    <span [nasClass]=\"getClass('icon')\">\n      <button type=\"button\" role=\"button\" tabindex=\"-1\" *ngIf=\"model; else isEmpty\" [attr.aria-label]=\"ariaLabelClear\"\n        (click)=\"clearSelected($event)\">\n        <nas-icon [type]=\"setRemoveIcon()\"></nas-icon>\n      </button>\n      <ng-template #isEmpty>\n        <nas-icon [type]=\"'small'\" [icon]=\"icon\"></nas-icon>\n      </ng-template>\n    </span>\n  </label>\n</ng-template>\n<div [id]=\"getResultsId()\" [nasClass]=\"getClass('results-wrapper')\" [attr.aria-expanded]=\"open ? 'true' : 'false'\">\n  <ul #results role=\"listbox\" *ngIf=\"open\" [attr.aria-labelledby]=\"getLabelId()\" [nasClass]=\"getClass('results')\">\n    <li role=\"option\" *ngFor=\"let item of filteredItems\" [id]=\"item.id\"\n      [nasClass]=\"getClass('list-item', item.id === focused?.id && 'focus')\">\n      <button type=\"button\" [nasClass]=\"getClass('item', item.id === focused?.id && 'focus')\" (click)=\"select(item)\"\n        tabindex=\"-1\">\n        <span [nasClass]=\"getClass('title')\">{{item.title}}</span>\n        <span [nasClass]=\"getClass('preamble')\">{{item.preamble}}</span>\n      </button>\n    </li>\n  </ul>\n</div>\n\n<nas-backdrop *ngIf=\"!exists(disableBackdrop)\" [ariaLabelBackdrop]=\"ariaLabelBackdrop\"\n  [(showBackdrop)]=\"showBackdrop\"></nas-backdrop>"]}
@@ -43,11 +43,11 @@ export class BackdropComponent extends NasComponentBase {
43
43
  event.preventDefault();
44
44
  }
45
45
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: BackdropComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
46
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: BackdropComponent, selector: "nas-backdrop", inputs: { showBackdrop: "showBackdrop", ariaLabelBackdrop: "ariaLabelBackdrop" }, outputs: { showBackdropChange: "showBackdropChange" }, usesInheritance: true, ngImport: i0, template: "<button type=\"button\"\n tabindex=\"0\"\n #backdrop\n [attr.aria-label]=\"ariaLabelBackdrop\"\n [nasClass]=\"getClass()\"\n (click)=\"onClose($event)\"\n *ngIf=\"show\">\n</button>", styles: ["@keyframes fade-in{0%{opacity:0}}@keyframes fade-in-down{0%{opacity:0;transform:translateY(-30px)}}@keyframes fade-in-left{0%{opacity:0;transform:translate(-30px)}}@keyframes fade-in-right{0%{opacity:0;transform:translate(30px)}}@keyframes fade-out{to{opacity:0}}@keyframes flip-in{0%{opacity:0;transform:rotateX(-90deg)}40%{opacity:1;transform:rotateX(10deg)}}@keyframes flip-out{to{opacity:0;transform:rotateX(-90deg)}}@keyframes pop-in-from-top{0%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-100,1,1);opacity:0}6.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-30.227,1,1)}13.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,1.76,1,1)}20%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,7.08,1,1)}26.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,3.838,1,1)}33.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,.902,1,1);opacity:1}40%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.237,1,1)}46.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.312,1,1)}53.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.141,1,1)}60%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.021,1,1)}66.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,.015,1,1)}73.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,.013,1,1)}80%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,.005,1,1)}86.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,0,1,1)}93.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.001,1,1);-webkit-transform:translate3d(0,0,0)}to{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.001,1,1);-webkit-transform:translate3d(0,0,0)}}.nas-backdrop{display:block;position:fixed;top:0;left:0;width:100%;height:100%;color:transparent;background-color:#0b14202b;animation:backdrop-animation .7s ease-out both}@keyframes backdrop-animation{0%{opacity:0}}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NasClassDirective, selector: "[nasClass]", inputs: ["nasClass", "attr.class"] }] }); }
46
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: BackdropComponent, selector: "nas-backdrop", inputs: { showBackdrop: "showBackdrop", ariaLabelBackdrop: "ariaLabelBackdrop" }, outputs: { showBackdropChange: "showBackdropChange" }, usesInheritance: true, ngImport: i0, template: "<button type=\"button\"\n tabindex=\"0\"\n #backdrop\n [attr.aria-label]=\"ariaLabelBackdrop\"\n [nasClass]=\"getClass()\"\n (click)=\"onClose($event)\"\n *ngIf=\"show\">\n</button>", styles: ["@keyframes fade-in{0%{opacity:0}}@keyframes fade-in-down{0%{opacity:0;transform:translateY(-30px)}}@keyframes fade-in-left{0%{opacity:0;transform:translate(-30px)}}@keyframes fade-in-right{0%{opacity:0;transform:translate(30px)}}@keyframes fade-out{to{opacity:0}}@keyframes flip-in{0%{opacity:0;transform:rotateX(-90deg)}40%{opacity:1;transform:rotateX(10deg)}}@keyframes flip-out{to{opacity:0;transform:rotateX(-90deg)}}@keyframes pop-in-from-top{0%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-100,1,1);opacity:0}6.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-30.227,1,1)}13.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,1.76,1,1)}20%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,7.08,1,1)}26.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,3.838,1,1)}33.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,.902,1,1);opacity:1}40%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.237,1,1)}46.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.312,1,1)}53.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.141,1,1)}60%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.021,1,1)}66.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,.015,1,1)}73.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,.013,1,1)}80%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,.005,1,1)}86.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,0,1,1)}93.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.001,1,1);-webkit-transform:translate3d(0,0,0)}to{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.001,1,1);-webkit-transform:translate3d(0,0,0)}}.nas-backdrop{display:block;z-index:1;position:fixed;top:0;left:0;width:100%;height:100%;color:transparent;background-color:#0b14202b;animation:backdrop-animation .7s ease-out both}@keyframes backdrop-animation{0%{opacity:0}}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NasClassDirective, selector: "[nasClass]", inputs: ["nasClass", "attr.class"] }] }); }
47
47
  }
48
48
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: BackdropComponent, decorators: [{
49
49
  type: Component,
50
- args: [{ selector: 'nas-backdrop', template: "<button type=\"button\"\n tabindex=\"0\"\n #backdrop\n [attr.aria-label]=\"ariaLabelBackdrop\"\n [nasClass]=\"getClass()\"\n (click)=\"onClose($event)\"\n *ngIf=\"show\">\n</button>", styles: ["@keyframes fade-in{0%{opacity:0}}@keyframes fade-in-down{0%{opacity:0;transform:translateY(-30px)}}@keyframes fade-in-left{0%{opacity:0;transform:translate(-30px)}}@keyframes fade-in-right{0%{opacity:0;transform:translate(30px)}}@keyframes fade-out{to{opacity:0}}@keyframes flip-in{0%{opacity:0;transform:rotateX(-90deg)}40%{opacity:1;transform:rotateX(10deg)}}@keyframes flip-out{to{opacity:0;transform:rotateX(-90deg)}}@keyframes pop-in-from-top{0%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-100,1,1);opacity:0}6.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-30.227,1,1)}13.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,1.76,1,1)}20%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,7.08,1,1)}26.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,3.838,1,1)}33.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,.902,1,1);opacity:1}40%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.237,1,1)}46.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.312,1,1)}53.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.141,1,1)}60%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.021,1,1)}66.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,.015,1,1)}73.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,.013,1,1)}80%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,.005,1,1)}86.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,0,1,1)}93.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.001,1,1);-webkit-transform:translate3d(0,0,0)}to{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.001,1,1);-webkit-transform:translate3d(0,0,0)}}.nas-backdrop{display:block;position:fixed;top:0;left:0;width:100%;height:100%;color:transparent;background-color:#0b14202b;animation:backdrop-animation .7s ease-out both}@keyframes backdrop-animation{0%{opacity:0}}\n"] }]
50
+ args: [{ selector: 'nas-backdrop', template: "<button type=\"button\"\n tabindex=\"0\"\n #backdrop\n [attr.aria-label]=\"ariaLabelBackdrop\"\n [nasClass]=\"getClass()\"\n (click)=\"onClose($event)\"\n *ngIf=\"show\">\n</button>", styles: ["@keyframes fade-in{0%{opacity:0}}@keyframes fade-in-down{0%{opacity:0;transform:translateY(-30px)}}@keyframes fade-in-left{0%{opacity:0;transform:translate(-30px)}}@keyframes fade-in-right{0%{opacity:0;transform:translate(30px)}}@keyframes fade-out{to{opacity:0}}@keyframes flip-in{0%{opacity:0;transform:rotateX(-90deg)}40%{opacity:1;transform:rotateX(10deg)}}@keyframes flip-out{to{opacity:0;transform:rotateX(-90deg)}}@keyframes pop-in-from-top{0%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-100,1,1);opacity:0}6.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-30.227,1,1)}13.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,1.76,1,1)}20%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,7.08,1,1)}26.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,3.838,1,1)}33.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,.902,1,1);opacity:1}40%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.237,1,1)}46.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.312,1,1)}53.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.141,1,1)}60%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.021,1,1)}66.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,.015,1,1)}73.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,.013,1,1)}80%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,.005,1,1)}86.67%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,0,1,1)}93.33%{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.001,1,1);-webkit-transform:translate3d(0,0,0)}to{transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,-.001,1,1);-webkit-transform:translate3d(0,0,0)}}.nas-backdrop{display:block;z-index:1;position:fixed;top:0;left:0;width:100%;height:100%;color:transparent;background-color:#0b14202b;animation:backdrop-animation .7s ease-out both}@keyframes backdrop-animation{0%{opacity:0}}\n"] }]
51
51
  }], ctorParameters: function () { return []; }, propDecorators: { showBackdropChange: [{
52
52
  type: Output
53
53
  }], showBackdrop: [{