@norwegian/core-components 7.13.7 → 7.14.1

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>"]}
@@ -118,6 +118,7 @@ export class DatepickerComboComponent extends NasComponentBase {
118
118
  super('nas-datepicker-combo');
119
119
  this.dateService = dateService;
120
120
  this.deviceHelper = deviceHelper;
121
+ this.tabIndex = 0;
121
122
  /**
122
123
  * @property Input
123
124
  * @description
@@ -149,6 +150,12 @@ export class DatepickerComboComponent extends NasComponentBase {
149
150
  * If this number is negative, the inbound lower limit date will subtract the number of days to the selected outbound date.
150
151
  */
151
152
  this.inboundLowerLimitDateOffset = 0;
153
+ /**
154
+ * @property Input
155
+ * @description
156
+ * Outbound and inbound dates keep the inline flex.
157
+ */
158
+ this.ignoreOnFocusInboundDate = false;
152
159
  /**
153
160
  * @property Output
154
161
  * @description
@@ -227,19 +234,20 @@ export class DatepickerComboComponent extends NasComponentBase {
227
234
  this.setInlineFlexOnContainterWidth();
228
235
  }
229
236
  onOutboundFocusOnNext(event) {
230
- if (!this.outboundOnly) {
237
+ if (!this.outboundOnly && !this.ignoreOnFocusInboundDate) {
231
238
  this.inboundOpen = true;
232
239
  return;
233
240
  }
234
241
  this.focusOnNextChange.emit(event);
235
242
  }
236
243
  onFocusOnNext(event) {
244
+ this.tabIndex = 0;
237
245
  this.focusOnNextChange.emit(event);
238
246
  }
239
247
  onFocusOnPrevious(event) {
240
248
  this.focusOnPreviousChange.emit(event);
241
249
  }
242
- onInboundFocusOnPrevious() {
250
+ onInboundFocusOnPrevious(event) {
243
251
  if (this.times && this.times.length > 0) {
244
252
  const selectElement = this.datepickerOutbound.timeSelector?.nativeElement;
245
253
  setTimeout(() => {
@@ -248,6 +256,12 @@ export class DatepickerComboComponent extends NasComponentBase {
248
256
  this.inboundOpenChange.emit(false);
249
257
  }
250
258
  else {
259
+ if (this.ignoreOnFocusInboundDate) {
260
+ this.tabIndex = -1;
261
+ this.onFocusOnPrevious(event);
262
+ return;
263
+ }
264
+ this.tabIndex = 0;
251
265
  this.outboundOpen = true;
252
266
  }
253
267
  }
@@ -299,11 +313,11 @@ export class DatepickerComboComponent extends NasComponentBase {
299
313
  return this.containerWidth.getValue() <= 450;
300
314
  }
301
315
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DatepickerComboComponent, deps: [{ token: i1.DateHelper }, { token: i2.DeviceHelper }], target: i0.ɵɵFactoryTarget.Component }); }
302
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DatepickerComboComponent, selector: "nas-datepicker-combo", inputs: { outboundId: "outboundId", inboundId: "inboundId", ariaLabelBackdrop: "ariaLabelBackdrop", outboundOpen: "outboundOpen", inboundOpen: "inboundOpen", noAvailableFlightsLabel: "noAvailableFlightsLabel", availableFlightsLabel: "availableFlightsLabel", disablePastSelection: "disablePastSelection", outboundDisabled: "outboundDisabled", inboundDisabled: "inboundDisabled", outboundOnly: "outboundOnly", outboundLabel: "outboundLabel", inboundLabel: "inboundLabel", timepickerLabel: "timepickerLabel", availability: "availability", outboundAvailableDates: "outboundAvailableDates", inboundAvailableDates: "inboundAvailableDates", times: "times", dateDisplayFormat: "dateDisplayFormat", timeDisplayFormat: "timeDisplayFormat", locale: "locale", compact: "compact", nasFormGroup: "nasFormGroup", nasFormControlNameOutbound: "nasFormControlNameOutbound", nasFormControlNameInbound: "nasFormControlNameInbound", outboundSelectedDate: "outboundSelectedDate", inboundSelectedDate: "inboundSelectedDate", disableBackdrop: "disableBackdrop", outboundSelectedTime: "outboundSelectedTime", inboundSelectedTime: "inboundSelectedTime", ariaLabelPreviousMonth: "ariaLabelPreviousMonth", ariaLabelNextMonth: "ariaLabelNextMonth", inboundLowerLimitDateOffset: "inboundLowerLimitDateOffset", inlineFlex: "inlineFlex" }, outputs: { outboundSelectedDateChange: "outboundSelectedDateChange", inboundSelectedDateChange: "inboundSelectedDateChange", outboundOpenChange: "outboundOpenChange", inboundOpenChange: "inboundOpenChange", outboundMonthChange: "outboundMonthChange", inboundMonthChange: "inboundMonthChange", focusOnNextChange: "focusOnNextChange", focusOnPreviousChange: "focusOnPreviousChange" }, viewQueries: [{ propertyName: "datepickerOutbound", first: true, predicate: ["datepickerOutbound"], descendants: true }, { propertyName: "datepickerInbound", first: true, predicate: ["datepickerInbound"], descendants: true }, { propertyName: "container", first: true, predicate: ["container"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div [nasClass]=\"getMainClass()\" #container>\n <div [nasClass]=\"getClass('date-picker')\">\n <nas-datepicker #datepickerOutbound compact [id]=\"outboundId\" [disableBackdrop]=\"disableBackdrop\" [nasFormGroup]=\"nasFormGroup\"\n [nasFormControlName]=\"nasFormControlNameOutbound\" [noAvailableFlightsLabel]=\"noAvailableFlightsLabel\"\n [availableFlightsLabel]=\"availableFlightsLabel\" [disablePastSelection]=\"exists(disablePastSelection)\"\n [availability]=\"exists(availability)\" [availableDates]=\"outboundAvailableDates\" [times]=\"times\"\n [timepickerLabel]=\"timepickerLabel\" [selectedTime]=\"outboundSelectedTime\" [dateDisplayFormat]=\"dateDisplayFormat\"\n [timeDisplayFormat]=\"timeDisplayFormat\" [locale]=\"locale\" [disabled]=\"exists(outboundDisabled)\"\n [ariaLabelBackdrop]=\"ariaLabelBackdrop\" [ariaLabelPreviousMonth]=\"ariaLabelPreviousMonth\"\n [ariaLabelNextMonth]=\"ariaLabelNextMonth\" (focusOnNextChange)=\"onOutboundFocusOnNext($event)\"\n (focusOnPreviousChange)=\"onFocusOnPrevious($event)\" (selectedMonthChange)=\"onOutboundMonthChange($event)\"\n [(open)]=\"outboundOpen\" [(selectedDate)]=\"outboundSelectedDate\">{{outboundLabel}}</nas-datepicker>\n </div>\n <span [nasClass]=\"getClass('separator')\"></span>\n <div *ngIf=\"checkOutboundOnly()\" [nasClass]=\"getClass('date-picker', ['inbound', checkInboundDisabled() && 'hide'])\">\n <nas-datepicker #datepickerInbound compact [id]=\"inboundId\" [disableBackdrop]=\"disableBackdrop\" [nasFormGroup]=\"nasFormGroup\"\n [nasFormControlName]=\"nasFormControlNameInbound\" [disabled]=\"checkInboundDisabled()\"\n [noAvailableFlightsLabel]=\"noAvailableFlightsLabel\" [availableFlightsLabel]=\"availableFlightsLabel\"\n [disablePastSelection]=\"exists(disablePastSelection)\" [availability]=\"exists(availability)\"\n [availableDates]=\"inboundAvailableDates\" [lowerLimitDate]=\"inboundLowerLimitDate\" [times]=\"times\"\n [timepickerLabel]=\"timepickerLabel\" [selectedTime]=\"inboundSelectedTime\" [dateDisplayFormat]=\"dateDisplayFormat\"\n [timeDisplayFormat]=\"timeDisplayFormat\" [locale]=\"locale\" [ariaLabelBackdrop]=\"ariaLabelBackdrop\"\n [ariaLabelPreviousMonth]=\"ariaLabelPreviousMonth\" [ariaLabelNextMonth]=\"ariaLabelNextMonth\"\n (focusOnNextChange)=\"onFocusOnNext($event)\" (focusOnPreviousChange)=\"onInboundFocusOnPrevious()\"\n [(open)]=\"inboundOpen\" [(selectedMonth)]=\"inboundSelectedMonth\"\n [(selectedDate)]=\"inboundSelectedDate\">{{inboundLabel}}</nas-datepicker>\n </div>\n</div>", 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-datepicker-combo{display:flex;margin:24px auto;flex-wrap:wrap;flex-direction:column;width:100%;z-index:1}.nas-datepicker-combo nas-datepicker{display:flex}.nas-datepicker-combo nas-datepicker ::ng-deep .nas-datepicker__time-selector-wrapper{padding-left:8px;padding-bottom:8px}.nas-datepicker-combo nas-datepicker ::ng-deep .nas-datepicker__time-selector-wrapper .nas-select{margin-bottom:0}.nas-datepicker-combo nas-datepicker ::ng-deep .nas-datepicker__time-selector-wrapper .nas-select:after{bottom:25px}.nas-datepicker-combo nas-datepicker ::ng-deep .nas-datepicker__time-selector-wrapper .nas-select select{background-color:#fff;height:68px;border:2px solid #15273F}.nas-datepicker-combo nas-datepicker ::ng-deep .nas-datepicker__time-selector-wrapper .nas-select select:focus{border-color:#15273f}.nas-datepicker-combo nas-datepicker ::ng-deep .nas-datepicker__date-picker-wrapper nas-calendar{right:0;left:0;margin-inline:auto;width:-webkit-fit-content;width:-moz-fit-content;width:fit-content}.nas-datepicker-combo__date-picker{width:100%}.nas-datepicker-combo__date-picker:first-child nas-datepicker ::ng-deep .nas-datepicker__date-picker-wrapper{border-bottom:none}.nas-datepicker-combo__date-picker:first-child nas-datepicker ::ng-deep .nas-datepicker__time-selector-wrapper{border-bottom:none}.nas-datepicker-combo__date-picker--hide,.nas-datepicker-combo__separator{display:none}.nas-datepicker-combo--compact{margin:0 auto}.nas-datepicker-combo--inline-flex{flex-wrap:nowrap;flex-direction:row;position:relative;margin:0}.nas-datepicker-combo--inline-flex ::ng-deep .nas-datepicker-combo__date-picker:last-child .nas-datepicker__date-picker-wrapper .nas-datepicker__controls{border-left:0}.nas-datepicker-combo--inline-flex ::ng-deep .nas-datepicker-combo__date-picker:first-child .nas-datepicker__time-selector-wrapper{padding-right:8px}.nas-datepicker-combo--inline-flex ::ng-deep .nas-datepicker-combo__date-picker--inbound:has(.nas-datepicker__time-selector-wrapper) .nas-datepicker__controls{border:2px solid #6F6F6F!important}.nas-datepicker-combo--inline-flex ::ng-deep .nas-datepicker-combo__date-picker--inbound:has(.nas-datepicker__time-selector-wrapper) .nas-datepicker__controls--filled{border:2px solid #15273F!important}.nas-datepicker-combo--inline-flex-datepicker-float ::ng-deep .nas-datepicker{position:unset}.nas-datepicker-combo--inline-flex-datepicker-float ::ng-deep .nas-datepicker__date-picker-wrapper{position:unset}.nas-datepicker-combo--inline-flex .nas-datepicker-combo__separator{display:none}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.DatepickerComponent, selector: "nas-datepicker", inputs: ["id", "ariaLabelBackdrop", "disableBackdrop", "noAvailableFlightsLabel", "availableFlightsLabel", "disablePastSelection", "lowerLimitDate", "availability", "availableDates", "disabled", "placeholder", "required", "ariaDescribedby", "ariaLabel", "dateDisplayFormat", "timeDisplayFormat", "locale", "compact", "nasFormGroup", "nasFormControlName", "times", "open", "selectedMonth", "selectedDate", "selectedTime", "ariaLabelPreviousMonth", "ariaLabelNextMonth", "timepickerLabel"], outputs: ["selectedDateChange", "selectedMonthChange", "openChange", "focusOnNextChange", "focusOnPreviousChange"] }, { kind: "directive", type: i5.NasClassDirective, selector: "[nasClass]", inputs: ["nasClass", "attr.class"] }] }); }
316
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DatepickerComboComponent, selector: "nas-datepicker-combo", inputs: { outboundId: "outboundId", inboundId: "inboundId", ariaLabelBackdrop: "ariaLabelBackdrop", outboundOpen: "outboundOpen", inboundOpen: "inboundOpen", noAvailableFlightsLabel: "noAvailableFlightsLabel", availableFlightsLabel: "availableFlightsLabel", disablePastSelection: "disablePastSelection", outboundDisabled: "outboundDisabled", inboundDisabled: "inboundDisabled", outboundOnly: "outboundOnly", outboundLabel: "outboundLabel", inboundLabel: "inboundLabel", timepickerLabel: "timepickerLabel", availability: "availability", outboundAvailableDates: "outboundAvailableDates", inboundAvailableDates: "inboundAvailableDates", times: "times", dateDisplayFormat: "dateDisplayFormat", timeDisplayFormat: "timeDisplayFormat", locale: "locale", compact: "compact", nasFormGroup: "nasFormGroup", nasFormControlNameOutbound: "nasFormControlNameOutbound", nasFormControlNameInbound: "nasFormControlNameInbound", outboundSelectedDate: "outboundSelectedDate", inboundSelectedDate: "inboundSelectedDate", disableBackdrop: "disableBackdrop", outboundSelectedTime: "outboundSelectedTime", inboundSelectedTime: "inboundSelectedTime", ariaLabelPreviousMonth: "ariaLabelPreviousMonth", ariaLabelNextMonth: "ariaLabelNextMonth", inboundLowerLimitDateOffset: "inboundLowerLimitDateOffset", inlineFlex: "inlineFlex", ignoreOnFocusInboundDate: "ignoreOnFocusInboundDate" }, outputs: { outboundSelectedDateChange: "outboundSelectedDateChange", inboundSelectedDateChange: "inboundSelectedDateChange", outboundOpenChange: "outboundOpenChange", inboundOpenChange: "inboundOpenChange", outboundMonthChange: "outboundMonthChange", inboundMonthChange: "inboundMonthChange", focusOnNextChange: "focusOnNextChange", focusOnPreviousChange: "focusOnPreviousChange" }, viewQueries: [{ propertyName: "datepickerOutbound", first: true, predicate: ["datepickerOutbound"], descendants: true }, { propertyName: "datepickerInbound", first: true, predicate: ["datepickerInbound"], descendants: true }, { propertyName: "container", first: true, predicate: ["container"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div [nasClass]=\"getMainClass()\" #container>\n <div [nasClass]=\"getClass('date-picker')\">\n <nas-datepicker #datepickerOutbound compact [id]=\"outboundId\" [disableBackdrop]=\"disableBackdrop\" [tabIndex]=\"tabIndex\"\n [nasFormGroup]=\"nasFormGroup\" [nasFormControlName]=\"nasFormControlNameOutbound\" [noAvailableFlightsLabel]=\"noAvailableFlightsLabel\"\n [availableFlightsLabel]=\"availableFlightsLabel\" [disablePastSelection]=\"exists(disablePastSelection)\"\n [availability]=\"exists(availability)\" [availableDates]=\"outboundAvailableDates\" [times]=\"times\"\n [timepickerLabel]=\"timepickerLabel\" [selectedTime]=\"outboundSelectedTime\" [dateDisplayFormat]=\"dateDisplayFormat\"\n [timeDisplayFormat]=\"timeDisplayFormat\" [locale]=\"locale\" [disabled]=\"exists(outboundDisabled)\"\n [ariaLabelBackdrop]=\"ariaLabelBackdrop\" [ariaLabelPreviousMonth]=\"ariaLabelPreviousMonth\"\n [ariaLabelNextMonth]=\"ariaLabelNextMonth\" (focusOnNextChange)=\"onOutboundFocusOnNext($event)\"\n (focusOnPreviousChange)=\"onFocusOnPrevious($event)\" (selectedMonthChange)=\"onOutboundMonthChange($event)\"\n [(open)]=\"outboundOpen\" [(selectedDate)]=\"outboundSelectedDate\">{{outboundLabel}}</nas-datepicker>\n </div>\n <span [nasClass]=\"getClass('separator')\"></span>\n <div *ngIf=\"checkOutboundOnly()\" [nasClass]=\"getClass('date-picker', ['inbound', checkInboundDisabled() && 'hide'])\">\n <nas-datepicker #datepickerInbound compact [id]=\"inboundId\" [disableBackdrop]=\"disableBackdrop\" [tabIndex]=\"tabIndex\"\n [nasFormGroup]=\"nasFormGroup\" [nasFormControlName]=\"nasFormControlNameInbound\" [disabled]=\"checkInboundDisabled()\"\n [noAvailableFlightsLabel]=\"noAvailableFlightsLabel\" [availableFlightsLabel]=\"availableFlightsLabel\"\n [disablePastSelection]=\"exists(disablePastSelection)\" [availability]=\"exists(availability)\"\n [availableDates]=\"inboundAvailableDates\" [lowerLimitDate]=\"inboundLowerLimitDate\" [times]=\"times\"\n [timepickerLabel]=\"timepickerLabel\" [selectedTime]=\"inboundSelectedTime\" [dateDisplayFormat]=\"dateDisplayFormat\"\n [timeDisplayFormat]=\"timeDisplayFormat\" [locale]=\"locale\" [ariaLabelBackdrop]=\"ariaLabelBackdrop\"\n [ariaLabelPreviousMonth]=\"ariaLabelPreviousMonth\" [ariaLabelNextMonth]=\"ariaLabelNextMonth\"\n (focusOnNextChange)=\"onFocusOnNext($event)\" (focusOnPreviousChange)=\"onInboundFocusOnPrevious($event)\"\n [(open)]=\"inboundOpen\" [(selectedMonth)]=\"inboundSelectedMonth\"\n [(selectedDate)]=\"inboundSelectedDate\">{{inboundLabel}}</nas-datepicker>\n </div>\n</div>", 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-datepicker-combo{display:flex;margin:24px auto;flex-wrap:wrap;flex-direction:column;width:100%;z-index:1}.nas-datepicker-combo nas-datepicker{display:flex}.nas-datepicker-combo nas-datepicker ::ng-deep .nas-datepicker__time-selector-wrapper{padding-left:8px;padding-bottom:8px}.nas-datepicker-combo nas-datepicker ::ng-deep .nas-datepicker__time-selector-wrapper .nas-select{margin-bottom:0}.nas-datepicker-combo nas-datepicker ::ng-deep .nas-datepicker__time-selector-wrapper .nas-select:after{bottom:25px}.nas-datepicker-combo nas-datepicker ::ng-deep .nas-datepicker__time-selector-wrapper .nas-select select{background-color:#fff;height:68px;border:2px solid #15273F}.nas-datepicker-combo nas-datepicker ::ng-deep .nas-datepicker__time-selector-wrapper .nas-select select:focus{border-color:#15273f}.nas-datepicker-combo nas-datepicker ::ng-deep .nas-datepicker__date-picker-wrapper nas-calendar{right:0;left:0;margin-inline:auto;width:-webkit-fit-content;width:-moz-fit-content;width:fit-content}.nas-datepicker-combo__date-picker{width:100%}.nas-datepicker-combo__date-picker:first-child nas-datepicker ::ng-deep .nas-datepicker__date-picker-wrapper{border-bottom:none}.nas-datepicker-combo__date-picker:first-child nas-datepicker ::ng-deep .nas-datepicker__time-selector-wrapper{border-bottom:none}.nas-datepicker-combo__date-picker--hide,.nas-datepicker-combo__separator{display:none}.nas-datepicker-combo--compact{margin:0 auto}.nas-datepicker-combo--inline-flex{flex-wrap:nowrap;flex-direction:row;position:relative;margin:0}.nas-datepicker-combo--inline-flex ::ng-deep .nas-datepicker-combo__date-picker:last-child .nas-datepicker__date-picker-wrapper .nas-datepicker__controls{border-left:0}.nas-datepicker-combo--inline-flex ::ng-deep .nas-datepicker-combo__date-picker:first-child .nas-datepicker__time-selector-wrapper{padding-right:8px}.nas-datepicker-combo--inline-flex ::ng-deep .nas-datepicker-combo__date-picker--inbound:has(.nas-datepicker__time-selector-wrapper) .nas-datepicker__controls{border:2px solid #6F6F6F!important}.nas-datepicker-combo--inline-flex ::ng-deep .nas-datepicker-combo__date-picker--inbound:has(.nas-datepicker__time-selector-wrapper) .nas-datepicker__controls--filled{border:2px solid #15273F!important}.nas-datepicker-combo--inline-flex-datepicker-float ::ng-deep .nas-datepicker{position:unset}.nas-datepicker-combo--inline-flex-datepicker-float ::ng-deep .nas-datepicker__date-picker-wrapper{position:unset}.nas-datepicker-combo--inline-flex .nas-datepicker-combo__separator{display:none}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.DatepickerComponent, selector: "nas-datepicker", inputs: ["id", "ariaLabelBackdrop", "disableBackdrop", "noAvailableFlightsLabel", "availableFlightsLabel", "disablePastSelection", "lowerLimitDate", "availability", "availableDates", "disabled", "placeholder", "required", "ariaDescribedby", "ariaLabel", "dateDisplayFormat", "timeDisplayFormat", "locale", "compact", "nasFormGroup", "nasFormControlName", "times", "open", "selectedMonth", "selectedDate", "selectedTime", "ariaLabelPreviousMonth", "ariaLabelNextMonth", "timepickerLabel"], outputs: ["selectedDateChange", "selectedMonthChange", "openChange", "focusOnNextChange", "focusOnPreviousChange"] }, { kind: "directive", type: i5.NasClassDirective, selector: "[nasClass]", inputs: ["nasClass", "attr.class"] }] }); }
303
317
  }
304
318
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DatepickerComboComponent, decorators: [{
305
319
  type: Component,
306
- args: [{ selector: 'nas-datepicker-combo', encapsulation: ViewEncapsulation.Emulated, template: "<div [nasClass]=\"getMainClass()\" #container>\n <div [nasClass]=\"getClass('date-picker')\">\n <nas-datepicker #datepickerOutbound compact [id]=\"outboundId\" [disableBackdrop]=\"disableBackdrop\" [nasFormGroup]=\"nasFormGroup\"\n [nasFormControlName]=\"nasFormControlNameOutbound\" [noAvailableFlightsLabel]=\"noAvailableFlightsLabel\"\n [availableFlightsLabel]=\"availableFlightsLabel\" [disablePastSelection]=\"exists(disablePastSelection)\"\n [availability]=\"exists(availability)\" [availableDates]=\"outboundAvailableDates\" [times]=\"times\"\n [timepickerLabel]=\"timepickerLabel\" [selectedTime]=\"outboundSelectedTime\" [dateDisplayFormat]=\"dateDisplayFormat\"\n [timeDisplayFormat]=\"timeDisplayFormat\" [locale]=\"locale\" [disabled]=\"exists(outboundDisabled)\"\n [ariaLabelBackdrop]=\"ariaLabelBackdrop\" [ariaLabelPreviousMonth]=\"ariaLabelPreviousMonth\"\n [ariaLabelNextMonth]=\"ariaLabelNextMonth\" (focusOnNextChange)=\"onOutboundFocusOnNext($event)\"\n (focusOnPreviousChange)=\"onFocusOnPrevious($event)\" (selectedMonthChange)=\"onOutboundMonthChange($event)\"\n [(open)]=\"outboundOpen\" [(selectedDate)]=\"outboundSelectedDate\">{{outboundLabel}}</nas-datepicker>\n </div>\n <span [nasClass]=\"getClass('separator')\"></span>\n <div *ngIf=\"checkOutboundOnly()\" [nasClass]=\"getClass('date-picker', ['inbound', checkInboundDisabled() && 'hide'])\">\n <nas-datepicker #datepickerInbound compact [id]=\"inboundId\" [disableBackdrop]=\"disableBackdrop\" [nasFormGroup]=\"nasFormGroup\"\n [nasFormControlName]=\"nasFormControlNameInbound\" [disabled]=\"checkInboundDisabled()\"\n [noAvailableFlightsLabel]=\"noAvailableFlightsLabel\" [availableFlightsLabel]=\"availableFlightsLabel\"\n [disablePastSelection]=\"exists(disablePastSelection)\" [availability]=\"exists(availability)\"\n [availableDates]=\"inboundAvailableDates\" [lowerLimitDate]=\"inboundLowerLimitDate\" [times]=\"times\"\n [timepickerLabel]=\"timepickerLabel\" [selectedTime]=\"inboundSelectedTime\" [dateDisplayFormat]=\"dateDisplayFormat\"\n [timeDisplayFormat]=\"timeDisplayFormat\" [locale]=\"locale\" [ariaLabelBackdrop]=\"ariaLabelBackdrop\"\n [ariaLabelPreviousMonth]=\"ariaLabelPreviousMonth\" [ariaLabelNextMonth]=\"ariaLabelNextMonth\"\n (focusOnNextChange)=\"onFocusOnNext($event)\" (focusOnPreviousChange)=\"onInboundFocusOnPrevious()\"\n [(open)]=\"inboundOpen\" [(selectedMonth)]=\"inboundSelectedMonth\"\n [(selectedDate)]=\"inboundSelectedDate\">{{inboundLabel}}</nas-datepicker>\n </div>\n</div>", 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-datepicker-combo{display:flex;margin:24px auto;flex-wrap:wrap;flex-direction:column;width:100%;z-index:1}.nas-datepicker-combo nas-datepicker{display:flex}.nas-datepicker-combo nas-datepicker ::ng-deep .nas-datepicker__time-selector-wrapper{padding-left:8px;padding-bottom:8px}.nas-datepicker-combo nas-datepicker ::ng-deep .nas-datepicker__time-selector-wrapper .nas-select{margin-bottom:0}.nas-datepicker-combo nas-datepicker ::ng-deep .nas-datepicker__time-selector-wrapper .nas-select:after{bottom:25px}.nas-datepicker-combo nas-datepicker ::ng-deep .nas-datepicker__time-selector-wrapper .nas-select select{background-color:#fff;height:68px;border:2px solid #15273F}.nas-datepicker-combo nas-datepicker ::ng-deep .nas-datepicker__time-selector-wrapper .nas-select select:focus{border-color:#15273f}.nas-datepicker-combo nas-datepicker ::ng-deep .nas-datepicker__date-picker-wrapper nas-calendar{right:0;left:0;margin-inline:auto;width:-webkit-fit-content;width:-moz-fit-content;width:fit-content}.nas-datepicker-combo__date-picker{width:100%}.nas-datepicker-combo__date-picker:first-child nas-datepicker ::ng-deep .nas-datepicker__date-picker-wrapper{border-bottom:none}.nas-datepicker-combo__date-picker:first-child nas-datepicker ::ng-deep .nas-datepicker__time-selector-wrapper{border-bottom:none}.nas-datepicker-combo__date-picker--hide,.nas-datepicker-combo__separator{display:none}.nas-datepicker-combo--compact{margin:0 auto}.nas-datepicker-combo--inline-flex{flex-wrap:nowrap;flex-direction:row;position:relative;margin:0}.nas-datepicker-combo--inline-flex ::ng-deep .nas-datepicker-combo__date-picker:last-child .nas-datepicker__date-picker-wrapper .nas-datepicker__controls{border-left:0}.nas-datepicker-combo--inline-flex ::ng-deep .nas-datepicker-combo__date-picker:first-child .nas-datepicker__time-selector-wrapper{padding-right:8px}.nas-datepicker-combo--inline-flex ::ng-deep .nas-datepicker-combo__date-picker--inbound:has(.nas-datepicker__time-selector-wrapper) .nas-datepicker__controls{border:2px solid #6F6F6F!important}.nas-datepicker-combo--inline-flex ::ng-deep .nas-datepicker-combo__date-picker--inbound:has(.nas-datepicker__time-selector-wrapper) .nas-datepicker__controls--filled{border:2px solid #15273F!important}.nas-datepicker-combo--inline-flex-datepicker-float ::ng-deep .nas-datepicker{position:unset}.nas-datepicker-combo--inline-flex-datepicker-float ::ng-deep .nas-datepicker__date-picker-wrapper{position:unset}.nas-datepicker-combo--inline-flex .nas-datepicker-combo__separator{display:none}\n"] }]
320
+ args: [{ selector: 'nas-datepicker-combo', encapsulation: ViewEncapsulation.Emulated, template: "<div [nasClass]=\"getMainClass()\" #container>\n <div [nasClass]=\"getClass('date-picker')\">\n <nas-datepicker #datepickerOutbound compact [id]=\"outboundId\" [disableBackdrop]=\"disableBackdrop\" [tabIndex]=\"tabIndex\"\n [nasFormGroup]=\"nasFormGroup\" [nasFormControlName]=\"nasFormControlNameOutbound\" [noAvailableFlightsLabel]=\"noAvailableFlightsLabel\"\n [availableFlightsLabel]=\"availableFlightsLabel\" [disablePastSelection]=\"exists(disablePastSelection)\"\n [availability]=\"exists(availability)\" [availableDates]=\"outboundAvailableDates\" [times]=\"times\"\n [timepickerLabel]=\"timepickerLabel\" [selectedTime]=\"outboundSelectedTime\" [dateDisplayFormat]=\"dateDisplayFormat\"\n [timeDisplayFormat]=\"timeDisplayFormat\" [locale]=\"locale\" [disabled]=\"exists(outboundDisabled)\"\n [ariaLabelBackdrop]=\"ariaLabelBackdrop\" [ariaLabelPreviousMonth]=\"ariaLabelPreviousMonth\"\n [ariaLabelNextMonth]=\"ariaLabelNextMonth\" (focusOnNextChange)=\"onOutboundFocusOnNext($event)\"\n (focusOnPreviousChange)=\"onFocusOnPrevious($event)\" (selectedMonthChange)=\"onOutboundMonthChange($event)\"\n [(open)]=\"outboundOpen\" [(selectedDate)]=\"outboundSelectedDate\">{{outboundLabel}}</nas-datepicker>\n </div>\n <span [nasClass]=\"getClass('separator')\"></span>\n <div *ngIf=\"checkOutboundOnly()\" [nasClass]=\"getClass('date-picker', ['inbound', checkInboundDisabled() && 'hide'])\">\n <nas-datepicker #datepickerInbound compact [id]=\"inboundId\" [disableBackdrop]=\"disableBackdrop\" [tabIndex]=\"tabIndex\"\n [nasFormGroup]=\"nasFormGroup\" [nasFormControlName]=\"nasFormControlNameInbound\" [disabled]=\"checkInboundDisabled()\"\n [noAvailableFlightsLabel]=\"noAvailableFlightsLabel\" [availableFlightsLabel]=\"availableFlightsLabel\"\n [disablePastSelection]=\"exists(disablePastSelection)\" [availability]=\"exists(availability)\"\n [availableDates]=\"inboundAvailableDates\" [lowerLimitDate]=\"inboundLowerLimitDate\" [times]=\"times\"\n [timepickerLabel]=\"timepickerLabel\" [selectedTime]=\"inboundSelectedTime\" [dateDisplayFormat]=\"dateDisplayFormat\"\n [timeDisplayFormat]=\"timeDisplayFormat\" [locale]=\"locale\" [ariaLabelBackdrop]=\"ariaLabelBackdrop\"\n [ariaLabelPreviousMonth]=\"ariaLabelPreviousMonth\" [ariaLabelNextMonth]=\"ariaLabelNextMonth\"\n (focusOnNextChange)=\"onFocusOnNext($event)\" (focusOnPreviousChange)=\"onInboundFocusOnPrevious($event)\"\n [(open)]=\"inboundOpen\" [(selectedMonth)]=\"inboundSelectedMonth\"\n [(selectedDate)]=\"inboundSelectedDate\">{{inboundLabel}}</nas-datepicker>\n </div>\n</div>", 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-datepicker-combo{display:flex;margin:24px auto;flex-wrap:wrap;flex-direction:column;width:100%;z-index:1}.nas-datepicker-combo nas-datepicker{display:flex}.nas-datepicker-combo nas-datepicker ::ng-deep .nas-datepicker__time-selector-wrapper{padding-left:8px;padding-bottom:8px}.nas-datepicker-combo nas-datepicker ::ng-deep .nas-datepicker__time-selector-wrapper .nas-select{margin-bottom:0}.nas-datepicker-combo nas-datepicker ::ng-deep .nas-datepicker__time-selector-wrapper .nas-select:after{bottom:25px}.nas-datepicker-combo nas-datepicker ::ng-deep .nas-datepicker__time-selector-wrapper .nas-select select{background-color:#fff;height:68px;border:2px solid #15273F}.nas-datepicker-combo nas-datepicker ::ng-deep .nas-datepicker__time-selector-wrapper .nas-select select:focus{border-color:#15273f}.nas-datepicker-combo nas-datepicker ::ng-deep .nas-datepicker__date-picker-wrapper nas-calendar{right:0;left:0;margin-inline:auto;width:-webkit-fit-content;width:-moz-fit-content;width:fit-content}.nas-datepicker-combo__date-picker{width:100%}.nas-datepicker-combo__date-picker:first-child nas-datepicker ::ng-deep .nas-datepicker__date-picker-wrapper{border-bottom:none}.nas-datepicker-combo__date-picker:first-child nas-datepicker ::ng-deep .nas-datepicker__time-selector-wrapper{border-bottom:none}.nas-datepicker-combo__date-picker--hide,.nas-datepicker-combo__separator{display:none}.nas-datepicker-combo--compact{margin:0 auto}.nas-datepicker-combo--inline-flex{flex-wrap:nowrap;flex-direction:row;position:relative;margin:0}.nas-datepicker-combo--inline-flex ::ng-deep .nas-datepicker-combo__date-picker:last-child .nas-datepicker__date-picker-wrapper .nas-datepicker__controls{border-left:0}.nas-datepicker-combo--inline-flex ::ng-deep .nas-datepicker-combo__date-picker:first-child .nas-datepicker__time-selector-wrapper{padding-right:8px}.nas-datepicker-combo--inline-flex ::ng-deep .nas-datepicker-combo__date-picker--inbound:has(.nas-datepicker__time-selector-wrapper) .nas-datepicker__controls{border:2px solid #6F6F6F!important}.nas-datepicker-combo--inline-flex ::ng-deep .nas-datepicker-combo__date-picker--inbound:has(.nas-datepicker__time-selector-wrapper) .nas-datepicker__controls--filled{border:2px solid #15273F!important}.nas-datepicker-combo--inline-flex-datepicker-float ::ng-deep .nas-datepicker{position:unset}.nas-datepicker-combo--inline-flex-datepicker-float ::ng-deep .nas-datepicker__date-picker-wrapper{position:unset}.nas-datepicker-combo--inline-flex .nas-datepicker-combo__separator{display:none}\n"] }]
307
321
  }], ctorParameters: function () { return [{ type: i1.DateHelper }, { type: i2.DeviceHelper }]; }, propDecorators: { datepickerOutbound: [{
308
322
  type: ViewChild,
309
323
  args: ['datepickerOutbound']
@@ -381,6 +395,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
381
395
  type: Input
382
396
  }], inlineFlex: [{
383
397
  type: Input
398
+ }], ignoreOnFocusInboundDate: [{
399
+ type: Input
384
400
  }], outboundSelectedDateChange: [{
385
401
  type: Output
386
402
  }], inboundSelectedDateChange: [{
@@ -398,4 +414,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
398
414
  }], focusOnPreviousChange: [{
399
415
  type: Output
400
416
  }] } });
401
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker-combo.component.js","sourceRoot":"","sources":["../../../../../../projects/core-components/src/lib/components/datepicker-combo/datepicker-combo.component.ts","../../../../../../projects/core-components/src/lib/components/datepicker-combo/datepicker-combo.component.html"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EACL,SAAS,EACT,YAAY,EACZ,KAAK,EACL,MAAM,EACN,iBAAiB,EACjB,SAAS,EAKV,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,gBAAgB,EAAE,MAAM,oCAAoC,CAAC;AAEtE,OAAO,EAAE,OAAO,EAAE,MAAM,kCAAkC,CAAC;AAG3D,OAAO,EAAE,eAAe,EAAgB,MAAM,MAAM,CAAC;;;;;;;AAGrD;;;GAGG;AAOH,MAAM,OAAO,wBAAyB,SAAQ,gBAAgB;IA4B5D;;;;OAIG;IACH,IACI,YAAY;QACd,OAAO,IAAI,CAAC,iBAAiB,CAAC;IAChC,CAAC;IACD,IAAI,YAAY,CAAC,KAAc;QAC7B,IAAI,IAAI,CAAC,gBAAgB,IAAI,KAAK,KAAK,IAAI,CAAC,iBAAiB,EAAE;YAC7D,OAAO;SACR;QAED,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;YAC/B,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAEpC,IAAI,KAAK,IAAI,IAAI,CAAC,WAAW,EAAE;gBAC7B,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;aAC1B;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED;;;;OAIG;IACH,IACI,WAAW;QACb,OAAO,IAAI,CAAC,gBAAgB,CAAC;IAC/B,CAAC;IACD,IAAI,WAAW,CAAC,KAAc;QAC5B,IAAI,IAAI,CAAC,eAAe,IAAI,KAAK,KAAK,IAAI,CAAC,gBAAgB,EAAE;YAC3D,OAAO;SACR;QAED,IAAI,IAAI,CAAC,YAAY,EAAE;YACrB,IAAI,CAAC,iBAAiB,CAAC,IAAI,EAAE,CAAC;YAC9B,OAAO;SACR;QAED,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,gBAAgB,GAAG,KAAK,CAAC;YAC9B,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAEnC,IAAI,KAAK,IAAI,IAAI,CAAC,YAAY,EAAE;gBAC9B,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;aAC3B;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAsJD;;;;OAIG;IACH,IACI,oBAAoB;QACtB,OAAO,IAAI,CAAC,yBAAyB,CAAC;IACxC,CAAC;IACD,IAAI,oBAAoB,CAAC,IAAa;QACpC,IAAI,CAAC,IAAI,EAAE;YACT,OAAO;SACR;QAED,IAAI,IAAI,CAAC,yBAAyB,IAAI,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,IAAI,CAAC,yBAAyB,EAAE,IAAI,CAAC,EAAE;YACvG,OAAO;SACR;QAED,IAAI,CAAC,yBAAyB,GAAG,IAAI,CAAC;QAEtC,IAAI,CAAC,qBAAqB,GAAG,IAAI,OAAO,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;QACnE,IAAI,CAAC,qBAAqB,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,2BAA2B,CAAC,CAAC;QAEjF,IAAI,CAAC,0BAA0B,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC7C,CAAC;IAED;;;;OAIG;IACH,IACI,mBAAmB;QACrB,OAAO,IAAI,CAAC,wBAAwB,CAAC;IACvC,CAAC;IACD,IAAI,mBAAmB,CAAC,IAAa;QACnC,IAAI,CAAC,IAAI,EAAE;YACT,OAAO;SACR;QAED,IAAI,IAAI,CAAC,wBAAwB,IAAI,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,IAAI,CAAC,wBAAwB,EAAE,IAAI,CAAC,EAAE;YACrG,OAAO;SACR;QAED,IAAI,CAAC,wBAAwB,GAAG,IAAI,CAAC;QACrC,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC5C,CAAC;IAiHD,IAAI,oBAAoB;QACtB,OAAO,IAAI,CAAC,yBAAyB,CAAC;IACxC,CAAC;IACD,IAAI,oBAAoB,CAAC,KAAc;QACrC,IAAI,CAAC,KAAK,EAAE;YACV,OAAO;SACR;QAED,IAAI,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,KAAK,EAAE,IAAI,CAAC,yBAAyB,CAAC,EAAE;YACvE,OAAO;SACR;QAED,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,yBAAyB,GAAG,KAAK,CAAC;YACvC,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACtC,CAAC,CAAC,CAAC;IACL,CAAC;IAYD,YACU,WAAuB,EACvB,YAA0B;QAClC,KAAK,CAAC,sBAAsB,CAAC,CAAC;QAFtB,gBAAW,GAAX,WAAW,CAAY;QACvB,iBAAY,GAAZ,YAAY,CAAc;QAtPpC;;;;;WAKG;QACM,sBAAiB,GAAG,mBAAmB,CAAC;QAEjD;;;;WAIG;QACM,sBAAiB,GAAG,OAAO,CAAC;QAErC;;;;;WAKG;QACM,WAAM,GAAG,OAAO,CAAC;QAuH1B;;;;;;;;;WASG;QACM,gCAA2B,GAAG,CAAC,CAAC;QASzC;;;;WAIG;QACO,+BAA0B,GAAG,IAAI,YAAY,EAAW,CAAC;QAEnE;;;;WAIG;QACO,8BAAyB,GAAG,IAAI,YAAY,EAAW,CAAC;QAGlE;;;;WAIG;QACO,uBAAkB,GAAG,IAAI,YAAY,EAAW,CAAC;QAE3D;;;;WAIG;QACO,sBAAiB,GAAG,IAAI,YAAY,EAAW,CAAC;QAE1D;;;;WAIG;QACO,wBAAmB,GAAG,IAAI,YAAY,EAAW,CAAC;QAE5D;;;;WAIG;QACO,uBAAkB,GAAG,IAAI,YAAY,EAAW,CAAC;QAE3D;;;;WAIG;QACO,sBAAiB,GAAG,IAAI,YAAY,EAAE,CAAC;QAEjD;;;;WAIG;QACO,0BAAqB,GAAG,IAAI,YAAY,EAA8B,CAAC;QAuBzE,qBAAgB,GAAG,KAAK,CAAC;QACzB,sBAAiB,GAAG,KAAK,CAAC;QAC1B,mBAAc,GAAG,IAAI,eAAe,CAAS,CAAC,CAAC,CAAC;QAUtD,MAAM,CAAC,QAAQ,GAAG,GAAG,EAAE;YACrB,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC9B,CAAC,CAAC;IACJ,CAAC;IAED,QAAQ;QACN,IAAI,IAAI,CAAC,YAAY,EAAE;YACrB,IAAI,IAAI,CAAC,0BAA0B,EAAE;gBACnC,IAAI,CAAC,gCAAgC,GAAG,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,CAAC,0BAA0B,CAAC;qBAC3F,YAAY;qBACZ,SAAS,CAAC,QAAQ,CAAC,EAAE;oBACpB,IAAI,CAAC,oBAAoB,GAAG,QAAQ,EAAE,IAAI,CAAC;gBAC7C,CAAC,CAAC,CAAC;aACN;YACD,IAAI,IAAI,CAAC,yBAAyB,EAAE;gBAClC,IAAI,CAAC,+BAA+B,GAAG,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,CAAC,yBAAyB,CAAC;qBACzF,YAAY;qBACZ,SAAS,CAAC,OAAO,CAAC,EAAE;oBACnB,IAAI,CAAC,mBAAmB,GAAG,OAAO,EAAE,IAAI,CAAC;gBAC3C,CAAC,CAAC,CAAC;aACN;SACF;IACH,CAAC;IAED,kBAAkB;QAChB,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC5B,IAAI,CAAC,8BAA8B,EAAE,CAAC;IACxC,CAAC;IAED,qBAAqB,CAAC,KAAiC;QACrD,IAAG,CAAC,IAAI,CAAC,YAAY,EAAE;YACrB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;YACxB,OAAO;SACR;QACD,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACrC,CAAC;IAED,aAAa,CAAC,KAAiC;QAC7C,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACrC,CAAC;IAED,iBAAiB,CAAC,KAAoB;QACpC,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACzC,CAAC;IAED,wBAAwB;QACtB,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE;YACvC,MAAM,aAAa,GAAG,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,aAA4B,CAAC;YAEzF,UAAU,CAAC,GAAG,EAAE;gBACd,aAAa,EAAE,KAAK,EAAE,CAAC;YACzB,CAAC,CAAC,CAAC;YAEH,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SACpC;aAAM;YACL,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;SAC1B;IACH,CAAC;IAED,qBAAqB,CAAC,IAAa;QACjC,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACpC,IAAI,CAAC,yBAAyB,GAAG,IAAI,CAAC;IACxC,CAAC;IAED,YAAY;QACV,MAAM,OAAO,GAAG,EAAE,CAAC;QAEnB,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE;YAC7B,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;SACzB;QAED,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,IAAI,CAAC,kBAAkB,EAAE;YAC3D,OAAO,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;YAE5B,IAAI,IAAI,CAAC,kBAAkB,EAAE,EAAE;gBAC7B,OAAO,CAAC,IAAI,CAAC,8BAA8B,CAAC,CAAC;aAC9C;SACF;QAED,OAAO,IAAI,CAAC,iBAAiB,CAAC,EAAE,EAAE,OAAO,CAAC,CAAC;IAC7C,CAAC;IAED,iBAAiB;QACf,OAAO,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,aAAa,EAAE,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC;IAChF,CAAC;IAED,oBAAoB;QAClB,OAAO,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,aAAa,EAAE,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;eACxE,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;IACzC,CAAC;IAED,WAAW;QACT,IAAI,CAAC,+BAA+B,EAAE,WAAW,EAAE,CAAC;QACpD,IAAI,CAAC,gCAAgC,EAAE,WAAW,EAAE,CAAC;IACvD,CAAC;IAEO,oBAAoB;QAC1B,MAAM,oBAAoB,GAAI,IAAI,CAAC,SAAS,CAAC,aAA6B,CAAC,WAAW,CAAC;QACvF,IAAI,oBAAoB,GAAG,CAAC,EAAE;YAC5B,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC;SAChD;IACH,CAAC;IAED,8BAA8B;QAC5B,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE;YAChC,IAAI,CAAC,kBAAkB,GAAG,KAAK,CAAC;YAChC,OAAO;SACR;QAED,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE;YACxB,OAAO;SACR;QAED,IAAI,CAAC,kBAAkB,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,IAAI,CAAC,cAAc,CAAC,QAAQ,EAAE,CAAC,CAAC;IAC7F,CAAC;IAGD,kBAAkB;QAChB,OAAO,IAAI,CAAC,cAAc,CAAC,QAAQ,EAAE,IAAI,GAAG,CAAC;IAC/C,CAAC;+GA5hBU,wBAAwB;mGAAxB,wBAAwB,0iECpCrC,ijFA2BM;;4FDSO,wBAAwB;kBANpC,SAAS;+BACE,sBAAsB,iBAGjB,iBAAiB,CAAC,QAAQ;4HAKR,kBAAkB;sBAAlD,SAAS;uBAAC,oBAAoB;gBACC,iBAAiB;sBAAhD,SAAS;uBAAC,mBAAmB;gBACN,SAAS;sBAAhC,SAAS;uBAAC,WAAW;gBAOb,UAAU;sBAAlB,KAAK;gBAOG,SAAS;sBAAjB,KAAK;gBAOG,iBAAiB;sBAAzB,KAAK;gBAQF,YAAY;sBADf,KAAK;gBAyBF,WAAW;sBADd,KAAK;gBA6BG,uBAAuB;sBAA/B,KAAK;gBAOG,qBAAqB;sBAA7B,KAAK;gBAOG,oBAAoB;sBAA5B,KAAK;gBAOG,gBAAgB;sBAAxB,KAAK;gBAOG,eAAe;sBAAvB,KAAK;gBAOG,YAAY;sBAApB,KAAK;gBAOG,aAAa;sBAArB,KAAK;gBAOG,YAAY;sBAApB,KAAK;gBAOG,eAAe;sBAAvB,KAAK;gBAOG,YAAY;sBAApB,KAAK;gBAOG,sBAAsB;sBAA9B,KAAK;gBAOG,qBAAqB;sBAA7B,KAAK;gBAOG,KAAK;sBAAb,KAAK;gBAQG,iBAAiB;sBAAzB,KAAK;gBAOG,iBAAiB;sBAAzB,KAAK;gBAQG,MAAM;sBAAd,KAAK;gBAOG,OAAO;sBAAf,KAAK;gBASG,YAAY;sBAApB,KAAK;gBASG,0BAA0B;sBAAlC,KAAK;gBASG,yBAAyB;sBAAjC,KAAK;gBAQF,oBAAoB;sBADvB,KAAK;gBA2BF,mBAAmB;sBADtB,KAAK;gBAsBG,eAAe;sBAAvB,KAAK;gBAOG,oBAAoB;sBAA5B,KAAK;gBAOG,mBAAmB;sBAA3B,KAAK;gBAOG,sBAAsB;sBAA9B,KAAK;gBAOG,kBAAkB;sBAA1B,KAAK;gBAYG,2BAA2B;sBAAnC,KAAK;gBAOG,UAAU;sBAAlB,KAAK;gBAOI,0BAA0B;sBAAnC,MAAM;gBAOG,yBAAyB;sBAAlC,MAAM;gBAQG,kBAAkB;sBAA3B,MAAM;gBAOG,iBAAiB;sBAA1B,MAAM;gBAOG,mBAAmB;sBAA5B,MAAM;gBAOG,kBAAkB;sBAA3B,MAAM;gBAOG,iBAAiB;sBAA1B,MAAM;gBAOG,qBAAqB;sBAA9B,MAAM","sourcesContent":["/**\n * @license\n * Copyright Norwegian Air Shuttle. All Rights Reserved.\n */\n\nimport {\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  ViewEncapsulation,\n  ViewChild,\n  ElementRef,\n  AfterViewChecked,\n  OnInit,\n  OnDestroy\n} from '@angular/core';\nimport { FormGroup } from '@angular/forms';\nimport { NasComponentBase } from '../../core/base/nas-component.base';\nimport { ClassModel } from '../../core/models/class.model';\nimport { UtcDate } from '../../core/models/utc-date.model';\nimport { DateHelper } from '../../core/services/date/date-helper.service';\nimport { DeviceHelper } from '../../core/services/device/device-helper.service';\nimport { BehaviorSubject, Subscription } from 'rxjs';\nimport { DatepickerComponent } from '../datepicker';\n\n/**\n * @description\n * Norwegian Datepicker Combo Component | Functional | New design\n */\n@Component({\n  selector: 'nas-datepicker-combo',\n  templateUrl: './datepicker-combo.component.html',\n  styleUrls: ['./datepicker-combo.component.scss'],\n  encapsulation: ViewEncapsulation.Emulated\n})\nexport class DatepickerComboComponent extends NasComponentBase implements OnInit, AfterViewChecked, OnDestroy {\n  inboundLowerLimitDate: UtcDate;\n\n  @ViewChild('datepickerOutbound') datepickerOutbound: DatepickerComponent;\n  @ViewChild('datepickerInbound') datepickerInbound: ElementRef;\n  @ViewChild('container') container: ElementRef;\n\n  /**\n   * @property Input\n   * @description\n   * The outbound datepicker ID of the native input element\n   */\n  @Input() outboundId: string;\n\n  /**\n   * @property Input\n   * @description\n   * The inbound datepicker ID of the native input element\n   */\n  @Input() inboundId: string;\n  \n  /**\n   * @property Input\n   * @description\n   * Adds 'aria-label' to the backdrops.\n   */\n  @Input() ariaLabelBackdrop: string;\n\n  /**\n   * @property Input\n   * @description\n   * Sets outbound datepicker open.\n   */\n  @Input()\n  get outboundOpen(): boolean {\n    return this.outboundOpenValue;\n  }\n  set outboundOpen(value: boolean) {\n    if (this.outboundDisabled || value === this.outboundOpenValue) {\n      return;\n    }\n\n    setTimeout(() => {\n      this.outboundOpenValue = value;\n      this.outboundOpenChange.emit(value);\n\n      if (value && this.inboundOpen) {\n        this.inboundOpen = false;\n      }\n    });\n  }\n\n  /**\n   * @property Input\n   * @description\n   * Sets inbound datepicker open.\n   */\n  @Input()\n  get inboundOpen(): boolean {\n    return this.inboundOpenValue;\n  }\n  set inboundOpen(value: boolean) {\n    if (this.inboundDisabled || value === this.inboundOpenValue) {\n      return;\n    }\n\n    if (this.outboundOnly) {\n      this.focusOnNextChange.emit();\n      return;\n    }\n\n    setTimeout(() => {\n      this.inboundOpenValue = value;\n      this.inboundOpenChange.emit(value);\n\n      if (value && this.outboundOpen) {\n        this.outboundOpen = false;\n      }\n    });\n  }\n\n  /**\n   * @property Input\n   * @description\n   * Label for no available flights.\n   */\n  @Input() noAvailableFlightsLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * Label for available flights.\n   */\n  @Input() availableFlightsLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * Disable possibility to select dates in the past.\n   */\n  @Input() disablePastSelection: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Disable possibility to select outbound dates.\n   */\n  @Input() outboundDisabled: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Disable possibility to select inbound dates.\n   */\n  @Input() inboundDisabled: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Remove the inbound datepicker if set.\n   */\n  @Input() outboundOnly: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Label for outbound datepicker.\n   */\n  @Input() outboundLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * Label for inbound datepicker.\n   */\n  @Input() inboundLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * Label for timepicker.\n   */\n  @Input() timepickerLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * Sets the datepickers in availability mode where available dates can be added.\n   */\n  @Input() availability: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Available dates for outbound calendar.\n   */\n  @Input() outboundAvailableDates: Array<UtcDate>;\n\n  /**\n   * @property Input\n   * @description\n   * Available dates for inbound calendar.\n   */\n  @Input() inboundAvailableDates: Array<UtcDate>;\n\n  /**\n   * @property Input\n   * @description\n   * If set, Enables the time dropdown selector alongside datepicker.\n   */\n  @Input() times: Array<UtcDate>;\n\n  /**\n   * @property Input\n   * @description\n   * The display format of the date when user has selected the date and it is being shown in the input box for the date picker.\n   * Please look at the angular Date pipe for valid formats and variations.\n   */\n  @Input() dateDisplayFormat = 'EEEE d, MMMM yyyy';\n\n  /**\n   * @property Input\n   * @description\n   * The time display format.\n   */\n  @Input() timeDisplayFormat = 'HH:mm';\n\n  /**\n   * @property Input\n   * @description\n   * A locale code for the locale format rules to use. When not supplied, uses the value of LOCALE_ID, which is en-US by default.\n   * This requires that registerLocaleData is called with the respective locale.\n   */\n  @Input() locale = 'en-US';\n\n  /**\n   * @property Input\n   * @description\n   * A modifier to remove the padding and margins around the element.\n   */\n  @Input() compact: boolean;\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   * 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() nasFormControlNameOutbound: 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() nasFormControlNameInbound: string;\n\n  /**\n   * @property Input\n   * @description\n   * Selected datefor outbound calendar.\n   */\n  @Input()\n  get outboundSelectedDate() {\n    return this.outboundSelectedDateValue;\n  }\n  set outboundSelectedDate(date: UtcDate) {\n    if (!date) {\n      return;\n    }\n\n    if (this.outboundSelectedDateValue && this.dateService.isSameDate(this.outboundSelectedDateValue, date)) {\n      return;\n    }\n\n    this.outboundSelectedDateValue = date;\n\n    this.inboundLowerLimitDate = new UtcDate(date.year, date.month, 1);\n    this.inboundLowerLimitDate.setDate(date.date + this.inboundLowerLimitDateOffset);\n\n    this.outboundSelectedDateChange.emit(date);\n  }\n\n  /**\n   * @property Input\n   * @description\n   * Selected datefor inbound calendar.\n   */\n  @Input()\n  get inboundSelectedDate() {\n    return this.inboundSelectedDateValue;\n  }\n  set inboundSelectedDate(date: UtcDate) {\n    if (!date) {\n      return;\n    }\n\n    if (this.inboundSelectedDateValue && this.dateService.isSameDate(this.inboundSelectedDateValue, date)) {\n      return;\n    }\n\n    this.inboundSelectedDateValue = date;\n    this.inboundSelectedDateChange.emit(date);\n  }\n\n  /**\n   * @property Input\n   * @description\n   * enable to disable backdrop.\n   */\n  @Input() disableBackdrop: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Sets the outbound selected time in the time selector.\n   */\n  @Input() outboundSelectedTime: UtcDate;\n\n  /**\n   * @property Input\n   * @description\n   * Sets the inbound selected time in the time selector.\n   */\n  @Input() inboundSelectedTime: UtcDate;\n\n  /**\n   * @property Input\n   * @description\n   * ARIA label for the previous month button in the calendar.\n   */\n  @Input() ariaLabelPreviousMonth: string;\n\n  /**\n   * @property Input\n   * @description\n   * ARIA label for the next month button in the calendar.\n   */\n  @Input() ariaLabelNextMonth: string;\n\n  /**\n   * @property Input\n   * @description\n   * Sets a relative number to decide when the inbound lower limit date should be based on selected outbound date.\n   *\n   * The lower limit date for inbound is set by default equal to the selected outbound date.\n   *\n   * If this number is positive, the inbound lower limit date will add the number of days to the selected outbound date.\n   * If this number is negative, the inbound lower limit date will subtract the number of days to the selected outbound date.\n   */\n  @Input() inboundLowerLimitDateOffset = 0;\n\n  /**\n   * @property Input\n   * @description\n   * Outbound and inbound dates keep the inline flex.\n   */\n  @Input() inlineFlex: boolean;\n\n  /**\n   * @property Output\n   * @description\n   * When selected datehas been changed on the outbound calendar.\n   */\n  @Output() outboundSelectedDateChange = new EventEmitter<UtcDate>();\n\n  /**\n   * @property Output\n   * @description\n   * When selected datehas been changed on the inbound calendar.\n   */\n  @Output() inboundSelectedDateChange = new EventEmitter<UtcDate>();\n\n\n  /**\n   * @property Output\n   * @description\n   * Outbound datepicker is open or closed.\n   */\n  @Output() outboundOpenChange = new EventEmitter<boolean>();\n\n  /**\n   * @property Output\n   * @description\n   * Inbound datepicker is open or closed.\n   */\n  @Output() inboundOpenChange = new EventEmitter<boolean>();\n\n  /**\n   * @property Output\n   * @description\n   * Outbound calendar changes month.\n   */\n  @Output() outboundMonthChange = new EventEmitter<UtcDate>();\n\n  /**\n   * @property Output\n   * @description\n   * Inbound calendar changes month.\n   */\n  @Output() inboundMonthChange = new EventEmitter<UtcDate>();\n\n  /**\n   * @property Output\n   * @description\n   * When a user has actively changed the date.\n   */\n  @Output() focusOnNextChange = new EventEmitter();\n\n  /**\n   * @property Output\n   * @description\n   * When a user has pressed shift + tab to go to previous control.\n   */\n  @Output() focusOnPreviousChange = new EventEmitter<KeyboardEvent | MouseEvent>();\n\n  get inboundSelectedMonth(): UtcDate {\n    return this.inboundSelectedMonthValue;\n  }\n  set inboundSelectedMonth(month: UtcDate) {\n    if (!month) {\n      return;\n    }\n\n    if (this.dateService.isSameMonth(month, this.inboundSelectedMonthValue)) {\n      return;\n    }\n\n    setTimeout(() => {\n      this.inboundSelectedMonthValue = month;\n      this.inboundMonthChange.emit(month);\n    });\n  }\n\n  private outboundSelectedDateValue: UtcDate;\n  private inboundSelectedDateValue: UtcDate;\n  private inboundSelectedMonthValue: UtcDate;\n  private inboundOpenValue = false;\n  private outboundOpenValue = false;\n  private containerWidth = new BehaviorSubject<number>(0);\n  private inboundValueChangesSubscription: Subscription;\n  private outboundValueChangesSubscription: Subscription;\n  private isInlineFlexOnView: boolean;\n\n  constructor(\n    private dateService: DateHelper,\n    private deviceHelper: DeviceHelper) {\n    super('nas-datepicker-combo');\n\n    window.onresize = () => {\n      this.updateContainerWidth();\n    };\n  }\n\n  ngOnInit(): void {\n    if (this.nasFormGroup) {\n      if (this.nasFormControlNameOutbound) {\n        this.outboundValueChangesSubscription = this.nasFormGroup.get(this.nasFormControlNameOutbound)\n          .valueChanges\n          .subscribe(outbound => {\n            this.outboundSelectedDate = outbound?.date;\n          });\n      }\n      if (this.nasFormControlNameInbound) {\n        this.inboundValueChangesSubscription = this.nasFormGroup.get(this.nasFormControlNameInbound)\n          .valueChanges\n          .subscribe(inbound => {\n            this.inboundSelectedDate = inbound?.date;\n          });\n      }\n    }\n  }\n\n  ngAfterViewChecked(): void {\n    this.updateContainerWidth();\n    this.setInlineFlexOnContainterWidth();\n  }\n\n  onOutboundFocusOnNext(event: KeyboardEvent | MouseEvent) {\n    if(!this.outboundOnly) {\n      this.inboundOpen = true;\n      return;\n    } \n    this.focusOnNextChange.emit(event);\n  }\n\n  onFocusOnNext(event: KeyboardEvent | MouseEvent): void {\n    this.focusOnNextChange.emit(event);\n  }\n\n  onFocusOnPrevious(event: KeyboardEvent): void {\n    this.focusOnPreviousChange.emit(event);\n  }\n\n  onInboundFocusOnPrevious(): void {\n    if (this.times && this.times.length > 0) {\n      const selectElement = this.datepickerOutbound.timeSelector?.nativeElement as HTMLElement;\n\n      setTimeout(() => {\n        selectElement?.focus();\n      });\n\n      this.inboundOpenChange.emit(false);\n    } else {\n      this.outboundOpen = true;\n    }\n  }\n\n  onOutboundMonthChange(date: UtcDate): void {\n    this.outboundMonthChange.emit(date);\n    this.inboundSelectedMonthValue = date;\n  }\n\n  getMainClass(): Array<ClassModel> {\n    const classes = [];\n\n    if (this.exists(this.compact)) {\n      classes.push('compact');\n    }\n\n    if (this.exists(this.inlineFlex) || this.isInlineFlexOnView) {\n      classes.push('inline-flex');\n\n      if (this.datePickerFloating()) {\n        classes.push('inline-flex-datepicker-float');\n      }\n    }\n\n    return this.getContainerClass('', classes);\n  }\n\n  checkOutboundOnly(): boolean {\n    return !(this.deviceHelper.isMobileWidth() && this.exists(this.outboundOnly));\n  }\n\n  checkInboundDisabled(): boolean {\n    return (!this.deviceHelper.isMobileWidth() && this.exists(this.outboundOnly))\n      || this.exists(this.inboundDisabled);\n  }\n\n  ngOnDestroy() {\n    this.inboundValueChangesSubscription?.unsubscribe();\n    this.outboundValueChangesSubscription?.unsubscribe();\n  }\n\n  private updateContainerWidth(): void {\n    const containerOffsetWidth = (this.container.nativeElement as HTMLElement).offsetWidth;\n    if (containerOffsetWidth > 0) {\n      this.containerWidth.next(containerOffsetWidth);\n    }\n  }\n\n  setInlineFlexOnContainterWidth(): void {\n    if (this.exists(this.inlineFlex)) {\n      this.isInlineFlexOnView = false;\n      return;\n    }\n\n    if (!this.containerWidth) {\n      return;\n    }\n  \n    this.isInlineFlexOnView = !this.deviceHelper.isWidthMobile(this.containerWidth.getValue());\n  }\n\n\n  datePickerFloating(): boolean {\n    return this.containerWidth.getValue() <= 450;\n  }\n\n}\n","<div [nasClass]=\"getMainClass()\" #container>\n  <div [nasClass]=\"getClass('date-picker')\">\n    <nas-datepicker #datepickerOutbound compact [id]=\"outboundId\" [disableBackdrop]=\"disableBackdrop\" [nasFormGroup]=\"nasFormGroup\"\n      [nasFormControlName]=\"nasFormControlNameOutbound\" [noAvailableFlightsLabel]=\"noAvailableFlightsLabel\"\n      [availableFlightsLabel]=\"availableFlightsLabel\" [disablePastSelection]=\"exists(disablePastSelection)\"\n      [availability]=\"exists(availability)\" [availableDates]=\"outboundAvailableDates\" [times]=\"times\"\n      [timepickerLabel]=\"timepickerLabel\" [selectedTime]=\"outboundSelectedTime\" [dateDisplayFormat]=\"dateDisplayFormat\"\n      [timeDisplayFormat]=\"timeDisplayFormat\" [locale]=\"locale\" [disabled]=\"exists(outboundDisabled)\"\n      [ariaLabelBackdrop]=\"ariaLabelBackdrop\" [ariaLabelPreviousMonth]=\"ariaLabelPreviousMonth\"\n      [ariaLabelNextMonth]=\"ariaLabelNextMonth\" (focusOnNextChange)=\"onOutboundFocusOnNext($event)\"\n      (focusOnPreviousChange)=\"onFocusOnPrevious($event)\" (selectedMonthChange)=\"onOutboundMonthChange($event)\"\n      [(open)]=\"outboundOpen\" [(selectedDate)]=\"outboundSelectedDate\">{{outboundLabel}}</nas-datepicker>\n  </div>\n  <span [nasClass]=\"getClass('separator')\"></span>\n  <div *ngIf=\"checkOutboundOnly()\" [nasClass]=\"getClass('date-picker', ['inbound', checkInboundDisabled() && 'hide'])\">\n    <nas-datepicker #datepickerInbound compact [id]=\"inboundId\" [disableBackdrop]=\"disableBackdrop\" [nasFormGroup]=\"nasFormGroup\"\n      [nasFormControlName]=\"nasFormControlNameInbound\" [disabled]=\"checkInboundDisabled()\"\n      [noAvailableFlightsLabel]=\"noAvailableFlightsLabel\" [availableFlightsLabel]=\"availableFlightsLabel\"\n      [disablePastSelection]=\"exists(disablePastSelection)\" [availability]=\"exists(availability)\"\n      [availableDates]=\"inboundAvailableDates\" [lowerLimitDate]=\"inboundLowerLimitDate\" [times]=\"times\"\n      [timepickerLabel]=\"timepickerLabel\" [selectedTime]=\"inboundSelectedTime\" [dateDisplayFormat]=\"dateDisplayFormat\"\n      [timeDisplayFormat]=\"timeDisplayFormat\" [locale]=\"locale\" [ariaLabelBackdrop]=\"ariaLabelBackdrop\"\n      [ariaLabelPreviousMonth]=\"ariaLabelPreviousMonth\" [ariaLabelNextMonth]=\"ariaLabelNextMonth\"\n      (focusOnNextChange)=\"onFocusOnNext($event)\" (focusOnPreviousChange)=\"onInboundFocusOnPrevious()\"\n      [(open)]=\"inboundOpen\" [(selectedMonth)]=\"inboundSelectedMonth\"\n      [(selectedDate)]=\"inboundSelectedDate\">{{inboundLabel}}</nas-datepicker>\n  </div>\n</div>"]}
417
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker-combo.component.js","sourceRoot":"","sources":["../../../../../../projects/core-components/src/lib/components/datepicker-combo/datepicker-combo.component.ts","../../../../../../projects/core-components/src/lib/components/datepicker-combo/datepicker-combo.component.html"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Norwegian Air Shuttle. All Rights Reserved.\n */\n\nimport {\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  ViewEncapsulation,\n  ViewChild,\n  ElementRef,\n  AfterViewChecked,\n  OnInit,\n  OnDestroy\n} from '@angular/core';\nimport { FormGroup } from '@angular/forms';\nimport { NasComponentBase } from '../../core/base/nas-component.base';\nimport { ClassModel } from '../../core/models/class.model';\nimport { UtcDate } from '../../core/models/utc-date.model';\nimport { DateHelper } from '../../core/services/date/date-helper.service';\nimport { DeviceHelper } from '../../core/services/device/device-helper.service';\nimport { BehaviorSubject, Subscription } from 'rxjs';\nimport { DatepickerComponent } from '../datepicker';\n\n/**\n * @description\n * Norwegian Datepicker Combo Component | Functional | New design\n */\n@Component({\n  selector: 'nas-datepicker-combo',\n  templateUrl: './datepicker-combo.component.html',\n  styleUrls: ['./datepicker-combo.component.scss'],\n  encapsulation: ViewEncapsulation.Emulated\n})\nexport class DatepickerComboComponent extends NasComponentBase implements OnInit, AfterViewChecked, OnDestroy {\n  inboundLowerLimitDate: UtcDate;\n  tabIndex: number = 0;\n\n  @ViewChild('datepickerOutbound') datepickerOutbound: DatepickerComponent;\n  @ViewChild('datepickerInbound') datepickerInbound: DatepickerComponent;\n  @ViewChild('container') container: ElementRef;\n\n  /**\n   * @property Input\n   * @description\n   * The outbound datepicker ID of the native input element\n   */\n  @Input() outboundId: string;\n\n  /**\n   * @property Input\n   * @description\n   * The inbound datepicker ID of the native input element\n   */\n  @Input() inboundId: string;\n  \n  /**\n   * @property Input\n   * @description\n   * Adds 'aria-label' to the backdrops.\n   */\n  @Input() ariaLabelBackdrop: string;\n\n  /**\n   * @property Input\n   * @description\n   * Sets outbound datepicker open.\n   */\n  @Input()\n  get outboundOpen(): boolean {\n    return this.outboundOpenValue;\n  }\n  set outboundOpen(value: boolean) {\n    if (this.outboundDisabled || value === this.outboundOpenValue) {\n      return;\n    }\n\n    setTimeout(() => {\n      this.outboundOpenValue = value;\n      this.outboundOpenChange.emit(value);\n\n      if (value && this.inboundOpen) {\n        this.inboundOpen = false;\n      }\n    });\n  }\n\n  /**\n   * @property Input\n   * @description\n   * Sets inbound datepicker open.\n   */\n  @Input()\n  get inboundOpen(): boolean {\n    return this.inboundOpenValue;\n  }\n  set inboundOpen(value: boolean) {\n    if (this.inboundDisabled || value === this.inboundOpenValue) {\n      return;\n    }\n\n    if (this.outboundOnly) {\n      this.focusOnNextChange.emit();\n      return;\n    }\n\n    setTimeout(() => {\n      this.inboundOpenValue = value;\n      this.inboundOpenChange.emit(value);\n\n      if (value && this.outboundOpen) {\n        this.outboundOpen = false;\n      }\n    });\n  }\n\n  /**\n   * @property Input\n   * @description\n   * Label for no available flights.\n   */\n  @Input() noAvailableFlightsLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * Label for available flights.\n   */\n  @Input() availableFlightsLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * Disable possibility to select dates in the past.\n   */\n  @Input() disablePastSelection: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Disable possibility to select outbound dates.\n   */\n  @Input() outboundDisabled: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Disable possibility to select inbound dates.\n   */\n  @Input() inboundDisabled: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Remove the inbound datepicker if set.\n   */\n  @Input() outboundOnly: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Label for outbound datepicker.\n   */\n  @Input() outboundLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * Label for inbound datepicker.\n   */\n  @Input() inboundLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * Label for timepicker.\n   */\n  @Input() timepickerLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * Sets the datepickers in availability mode where available dates can be added.\n   */\n  @Input() availability: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Available dates for outbound calendar.\n   */\n  @Input() outboundAvailableDates: Array<UtcDate>;\n\n  /**\n   * @property Input\n   * @description\n   * Available dates for inbound calendar.\n   */\n  @Input() inboundAvailableDates: Array<UtcDate>;\n\n  /**\n   * @property Input\n   * @description\n   * If set, Enables the time dropdown selector alongside datepicker.\n   */\n  @Input() times: Array<UtcDate>;\n\n  /**\n   * @property Input\n   * @description\n   * The display format of the date when user has selected the date and it is being shown in the input box for the date picker.\n   * Please look at the angular Date pipe for valid formats and variations.\n   */\n  @Input() dateDisplayFormat = 'EEEE d, MMMM yyyy';\n\n  /**\n   * @property Input\n   * @description\n   * The time display format.\n   */\n  @Input() timeDisplayFormat = 'HH:mm';\n\n  /**\n   * @property Input\n   * @description\n   * A locale code for the locale format rules to use. When not supplied, uses the value of LOCALE_ID, which is en-US by default.\n   * This requires that registerLocaleData is called with the respective locale.\n   */\n  @Input() locale = 'en-US';\n\n  /**\n   * @property Input\n   * @description\n   * A modifier to remove the padding and margins around the element.\n   */\n  @Input() compact: boolean;\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   * 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() nasFormControlNameOutbound: 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() nasFormControlNameInbound: string;\n\n  /**\n   * @property Input\n   * @description\n   * Selected datefor outbound calendar.\n   */\n  @Input()\n  get outboundSelectedDate() {\n    return this.outboundSelectedDateValue;\n  }\n  set outboundSelectedDate(date: UtcDate) {\n    if (!date) {\n      return;\n    }\n\n    if (this.outboundSelectedDateValue && this.dateService.isSameDate(this.outboundSelectedDateValue, date)) {\n      return;\n    }\n\n    this.outboundSelectedDateValue = date;\n\n    this.inboundLowerLimitDate = new UtcDate(date.year, date.month, 1);\n    this.inboundLowerLimitDate.setDate(date.date + this.inboundLowerLimitDateOffset);\n\n    this.outboundSelectedDateChange.emit(date);\n  }\n\n  /**\n   * @property Input\n   * @description\n   * Selected datefor inbound calendar.\n   */\n  @Input()\n  get inboundSelectedDate() {\n    return this.inboundSelectedDateValue;\n  }\n  set inboundSelectedDate(date: UtcDate) {\n    if (!date) {\n      return;\n    }\n\n    if (this.inboundSelectedDateValue && this.dateService.isSameDate(this.inboundSelectedDateValue, date)) {\n      return;\n    }\n\n    this.inboundSelectedDateValue = date;\n    this.inboundSelectedDateChange.emit(date);\n  }\n\n  /**\n   * @property Input\n   * @description\n   * enable to disable backdrop.\n   */\n  @Input() disableBackdrop: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Sets the outbound selected time in the time selector.\n   */\n  @Input() outboundSelectedTime: UtcDate;\n\n  /**\n   * @property Input\n   * @description\n   * Sets the inbound selected time in the time selector.\n   */\n  @Input() inboundSelectedTime: UtcDate;\n\n  /**\n   * @property Input\n   * @description\n   * ARIA label for the previous month button in the calendar.\n   */\n  @Input() ariaLabelPreviousMonth: string;\n\n  /**\n   * @property Input\n   * @description\n   * ARIA label for the next month button in the calendar.\n   */\n  @Input() ariaLabelNextMonth: string;\n\n  /**\n   * @property Input\n   * @description\n   * Sets a relative number to decide when the inbound lower limit date should be based on selected outbound date.\n   *\n   * The lower limit date for inbound is set by default equal to the selected outbound date.\n   *\n   * If this number is positive, the inbound lower limit date will add the number of days to the selected outbound date.\n   * If this number is negative, the inbound lower limit date will subtract the number of days to the selected outbound date.\n   */\n  @Input() inboundLowerLimitDateOffset = 0;\n\n  /**\n   * @property Input\n   * @description\n   * Outbound and inbound dates keep the inline flex.\n   */\n  @Input() inlineFlex: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Outbound and inbound dates keep the inline flex.\n   */\n  @Input() ignoreOnFocusInboundDate: boolean = false;\n\n  /**\n   * @property Output\n   * @description\n   * When selected datehas been changed on the outbound calendar.\n   */\n  @Output() outboundSelectedDateChange = new EventEmitter<UtcDate>();\n\n  /**\n   * @property Output\n   * @description\n   * When selected datehas been changed on the inbound calendar.\n   */\n  @Output() inboundSelectedDateChange = new EventEmitter<UtcDate>();\n\n\n  /**\n   * @property Output\n   * @description\n   * Outbound datepicker is open or closed.\n   */\n  @Output() outboundOpenChange = new EventEmitter<boolean>();\n\n  /**\n   * @property Output\n   * @description\n   * Inbound datepicker is open or closed.\n   */\n  @Output() inboundOpenChange = new EventEmitter<boolean>();\n\n  /**\n   * @property Output\n   * @description\n   * Outbound calendar changes month.\n   */\n  @Output() outboundMonthChange = new EventEmitter<UtcDate>();\n\n  /**\n   * @property Output\n   * @description\n   * Inbound calendar changes month.\n   */\n  @Output() inboundMonthChange = new EventEmitter<UtcDate>();\n\n  /**\n   * @property Output\n   * @description\n   * When a user has actively changed the date.\n   */\n  @Output() focusOnNextChange = new EventEmitter();\n\n  /**\n   * @property Output\n   * @description\n   * When a user has pressed shift + tab to go to previous control.\n   */\n  @Output() focusOnPreviousChange = new EventEmitter<KeyboardEvent | MouseEvent>();\n\n  get inboundSelectedMonth(): UtcDate {\n    return this.inboundSelectedMonthValue;\n  }\n  set inboundSelectedMonth(month: UtcDate) {\n    if (!month) {\n      return;\n    }\n\n    if (this.dateService.isSameMonth(month, this.inboundSelectedMonthValue)) {\n      return;\n    }\n\n    setTimeout(() => {\n      this.inboundSelectedMonthValue = month;\n      this.inboundMonthChange.emit(month);\n    });\n  }\n\n  private outboundSelectedDateValue: UtcDate;\n  private inboundSelectedDateValue: UtcDate;\n  private inboundSelectedMonthValue: UtcDate;\n  private inboundOpenValue = false;\n  private outboundOpenValue = false;\n  private containerWidth = new BehaviorSubject<number>(0);\n  private inboundValueChangesSubscription: Subscription;\n  private outboundValueChangesSubscription: Subscription;\n  private isInlineFlexOnView: boolean;\n\n  constructor(\n    private dateService: DateHelper,\n    private deviceHelper: DeviceHelper) {\n    super('nas-datepicker-combo');\n\n    window.onresize = () => {\n      this.updateContainerWidth();\n    };\n  }\n\n  ngOnInit(): void {\n    if (this.nasFormGroup) {\n      if (this.nasFormControlNameOutbound) {\n        this.outboundValueChangesSubscription = this.nasFormGroup.get(this.nasFormControlNameOutbound)\n          .valueChanges\n          .subscribe(outbound => {\n            this.outboundSelectedDate = outbound?.date;\n          });\n      }\n      if (this.nasFormControlNameInbound) {\n        this.inboundValueChangesSubscription = this.nasFormGroup.get(this.nasFormControlNameInbound)\n          .valueChanges\n          .subscribe(inbound => {\n            this.inboundSelectedDate = inbound?.date;\n          });\n      }\n    }\n  }\n\n  ngAfterViewChecked(): void {\n    this.updateContainerWidth();\n    this.setInlineFlexOnContainterWidth();\n  }\n\n  onOutboundFocusOnNext(event: KeyboardEvent | MouseEvent) {\n    if(!this.outboundOnly && !this.ignoreOnFocusInboundDate) {\n      this.inboundOpen = true;\n      return;\n    } \n    this.focusOnNextChange.emit(event);\n  }\n\n  onFocusOnNext(event: KeyboardEvent | MouseEvent): void {\n    this.tabIndex = 0;\n    this.focusOnNextChange.emit(event);\n  }\n\n  onFocusOnPrevious(event: KeyboardEvent): void {\n    this.focusOnPreviousChange.emit(event);\n  }\n\n  onInboundFocusOnPrevious(event: KeyboardEvent): void {\n    if (this.times && this.times.length > 0) {\n      const selectElement = this.datepickerOutbound.timeSelector?.nativeElement as HTMLElement;\n\n      setTimeout(() => {\n        selectElement?.focus();\n      });\n\n      this.inboundOpenChange.emit(false);\n    } else {\n      if(this.ignoreOnFocusInboundDate) {\n        this.tabIndex = -1;\n        this.onFocusOnPrevious(event);\n        return;\n      }\n      this.tabIndex = 0;\n      this.outboundOpen = true;\n    }\n  }\n\n  onOutboundMonthChange(date: UtcDate): void {\n    this.outboundMonthChange.emit(date);\n    this.inboundSelectedMonthValue = date;\n  }\n\n  getMainClass(): Array<ClassModel> {\n    const classes = [];\n\n    if (this.exists(this.compact)) {\n      classes.push('compact');\n    }\n\n    if (this.exists(this.inlineFlex) || this.isInlineFlexOnView) {\n      classes.push('inline-flex');\n\n      if (this.datePickerFloating()) {\n        classes.push('inline-flex-datepicker-float');\n      }\n    }\n\n    return this.getContainerClass('', classes);\n  }\n\n  checkOutboundOnly(): boolean {\n    return !(this.deviceHelper.isMobileWidth() && this.exists(this.outboundOnly));\n  }\n\n  checkInboundDisabled(): boolean {\n    return (!this.deviceHelper.isMobileWidth() && this.exists(this.outboundOnly))\n      || this.exists(this.inboundDisabled);\n  }\n\n  ngOnDestroy() {\n    this.inboundValueChangesSubscription?.unsubscribe();\n    this.outboundValueChangesSubscription?.unsubscribe();\n  }\n\n  private updateContainerWidth(): void {\n    const containerOffsetWidth = (this.container.nativeElement as HTMLElement).offsetWidth;\n    if (containerOffsetWidth > 0) {\n      this.containerWidth.next(containerOffsetWidth);\n    }\n  }\n\n  setInlineFlexOnContainterWidth(): void {\n    if (this.exists(this.inlineFlex)) {\n      this.isInlineFlexOnView = false;\n      return;\n    }\n\n    if (!this.containerWidth) {\n      return;\n    }\n  \n    this.isInlineFlexOnView = !this.deviceHelper.isWidthMobile(this.containerWidth.getValue());\n  }\n\n\n  datePickerFloating(): boolean {\n    return this.containerWidth.getValue() <= 450;\n  }\n\n}\n","<div [nasClass]=\"getMainClass()\" #container>\n  <div [nasClass]=\"getClass('date-picker')\">\n    <nas-datepicker #datepickerOutbound compact [id]=\"outboundId\" [disableBackdrop]=\"disableBackdrop\" [tabIndex]=\"tabIndex\"\n      [nasFormGroup]=\"nasFormGroup\" [nasFormControlName]=\"nasFormControlNameOutbound\" [noAvailableFlightsLabel]=\"noAvailableFlightsLabel\"\n      [availableFlightsLabel]=\"availableFlightsLabel\" [disablePastSelection]=\"exists(disablePastSelection)\"\n      [availability]=\"exists(availability)\" [availableDates]=\"outboundAvailableDates\" [times]=\"times\"\n      [timepickerLabel]=\"timepickerLabel\" [selectedTime]=\"outboundSelectedTime\" [dateDisplayFormat]=\"dateDisplayFormat\"\n      [timeDisplayFormat]=\"timeDisplayFormat\" [locale]=\"locale\" [disabled]=\"exists(outboundDisabled)\"\n      [ariaLabelBackdrop]=\"ariaLabelBackdrop\" [ariaLabelPreviousMonth]=\"ariaLabelPreviousMonth\"\n      [ariaLabelNextMonth]=\"ariaLabelNextMonth\" (focusOnNextChange)=\"onOutboundFocusOnNext($event)\"\n      (focusOnPreviousChange)=\"onFocusOnPrevious($event)\" (selectedMonthChange)=\"onOutboundMonthChange($event)\"\n      [(open)]=\"outboundOpen\" [(selectedDate)]=\"outboundSelectedDate\">{{outboundLabel}}</nas-datepicker>\n  </div>\n  <span [nasClass]=\"getClass('separator')\"></span>\n  <div *ngIf=\"checkOutboundOnly()\" [nasClass]=\"getClass('date-picker', ['inbound', checkInboundDisabled() && 'hide'])\">\n    <nas-datepicker #datepickerInbound compact [id]=\"inboundId\" [disableBackdrop]=\"disableBackdrop\" [tabIndex]=\"tabIndex\"\n      [nasFormGroup]=\"nasFormGroup\" [nasFormControlName]=\"nasFormControlNameInbound\" [disabled]=\"checkInboundDisabled()\"\n      [noAvailableFlightsLabel]=\"noAvailableFlightsLabel\" [availableFlightsLabel]=\"availableFlightsLabel\"\n      [disablePastSelection]=\"exists(disablePastSelection)\" [availability]=\"exists(availability)\"\n      [availableDates]=\"inboundAvailableDates\" [lowerLimitDate]=\"inboundLowerLimitDate\" [times]=\"times\"\n      [timepickerLabel]=\"timepickerLabel\" [selectedTime]=\"inboundSelectedTime\" [dateDisplayFormat]=\"dateDisplayFormat\"\n      [timeDisplayFormat]=\"timeDisplayFormat\" [locale]=\"locale\" [ariaLabelBackdrop]=\"ariaLabelBackdrop\"\n      [ariaLabelPreviousMonth]=\"ariaLabelPreviousMonth\" [ariaLabelNextMonth]=\"ariaLabelNextMonth\"\n      (focusOnNextChange)=\"onFocusOnNext($event)\" (focusOnPreviousChange)=\"onInboundFocusOnPrevious($event)\"\n      [(open)]=\"inboundOpen\" [(selectedMonth)]=\"inboundSelectedMonth\"\n      [(selectedDate)]=\"inboundSelectedDate\">{{inboundLabel}}</nas-datepicker>\n  </div>\n</div>"]}