@norwegian/core-components 6.58.1 → 6.60.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/alert/alert.component.mjs +3 -8
- package/esm2022/lib/components/alert/models/alert.model.mjs +1 -1
- package/esm2022/lib/components/info/info.component.mjs +2 -2
- package/esm2022/lib/components/page-header/wallet/wallet.component.mjs +1 -1
- package/esm2022/lib/components/passenger-select/passenger-select.component.mjs +8 -2
- package/esm2022/lib/components/passenger-select-new/passenger-select-new.component.mjs +8 -2
- package/esm2022/lib/components/status-box/status-box.component.mjs +2 -2
- package/esm2022/lib/components/toggle/models/options.model.mjs +1 -1
- package/esm2022/lib/components/toggle/toggle.component.mjs +11 -3
- package/fesm2022/norwegian-core-components.mjs +30 -15
- package/fesm2022/norwegian-core-components.mjs.map +1 -1
- package/lib/components/alert/alert.component.d.ts +1 -7
- package/lib/components/alert/models/alert.model.d.ts +0 -1
- package/lib/components/info/info.component.d.ts +1 -1
- package/lib/components/toggle/models/options.model.d.ts +1 -0
- package/lib/components/toggle/toggle.component.d.ts +1 -0
- package/package.json +1 -1
|
@@ -23,6 +23,12 @@ export class PassengerSelectNewComponent extends NasComponentBase {
|
|
|
23
23
|
* An array of different passenger types that will be displayed.
|
|
24
24
|
*/
|
|
25
25
|
this.passengers = new Array();
|
|
26
|
+
/**
|
|
27
|
+
* @property Input
|
|
28
|
+
* @description
|
|
29
|
+
* The total maximum amount of passengers.
|
|
30
|
+
*/
|
|
31
|
+
this.maxPaxCount = 10;
|
|
26
32
|
/**
|
|
27
33
|
* @property Output
|
|
28
34
|
* @description
|
|
@@ -214,7 +220,7 @@ export class PassengerSelectNewComponent extends NasComponentBase {
|
|
|
214
220
|
}
|
|
215
221
|
return 0;
|
|
216
222
|
}
|
|
217
|
-
else if (passengers.type === PassengerType.Child && this.totalCount <
|
|
223
|
+
else if (passengers.type === PassengerType.Child && this.totalCount < this.maxPaxCount) {
|
|
218
224
|
if (adults && youngAdult) {
|
|
219
225
|
if (adults.count <= 0) {
|
|
220
226
|
return 0;
|
|
@@ -414,4 +420,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.5", ngImpor
|
|
|
414
420
|
}], focusOnPrevious: [{
|
|
415
421
|
type: Output
|
|
416
422
|
}] } });
|
|
417
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"passenger-select-new.component.js","sourceRoot":"","sources":["../../../../../../projects/core-components/src/lib/components/passenger-select-new/passenger-select-new.component.ts","../../../../../../projects/core-components/src/lib/components/passenger-select-new/passenger-select-new.component.html"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Norwegian Air Shuttle. All Rights Reserved.\n */\nimport {\n  Component,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n  ViewChildren,\n  QueryList\n} from '@angular/core';\nimport { FormGroup } from '@angular/forms';\nimport { PassengerType } from './enums/passenger-type.enum';\nimport { PassengersModel } from './models/passengers.model';\nimport { NasComponentBase } from '../../core/base/nas-component.base';\nimport { NumberFieldNewComponent } from '../number-field-new';\n\n/**\n * @description\n * Norwegian Passenger Select Component | New design | Beta\n*/\n@Component({\n  selector: 'nas-passenger-select-new',\n  templateUrl: './passenger-select-new.component.html',\n  styleUrls: ['./passenger-select-new.component.scss']\n})\nexport class PassengerSelectNewComponent extends NasComponentBase implements OnInit {\n  @ViewChildren(NumberFieldNewComponent) numberFields!: QueryList<NumberFieldNewComponent>;\n\n  totalCount: number;\n  isGroupBooking: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * An array of different passenger types that will be displayed.\n  */\n  @Input() passengers = new Array<PassengersModel>();\n\n  /**\n   * @property Input\n   * @description\n   * The total maximum amount of passengers.\n  */\n  @Input() maxPaxCount: number;\n\n  /**\n   * @property Input\n   * @description\n   * The minimum amount of adults that can be selected.\n  */\n  @Input() minAdultCount: number;\n\n  /**\n   * @property Input\n   * @description\n   * The limit for when the total amount of passengers exceeds to be a group booking.\n  */\n  @Input() groupBookingLimit: number;\n\n  /**\n   * @property Input\n   * @description\n   * A title that will be added to the dropdown.\n  */\n  @Input() title: string;\n\n  /**\n   * @property Input\n   * @description\n   * A label for the adults passenger type.\n  */\n  @Input() adultsLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * A label for the children passenger type.\n  */\n  @Input() childrenLabel: string;\n\n  /**\n   * @description\n   * A label for the infants passenger type.\n   */\n  @Input() infantsLabel: string;\n\n  /**\n * @property Input\n * @description\n * A label for the adults passenger type.\n*/\n  @Input() youthsLabel: string;\n\n/**\n * @property Input\n * @description\n * A label for the adults passenger type.\n*/\n  @Input() youngAdultsLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * A label that will appear when total number of selected passengers exceeds the group booking limit\n  */\n  @Input() groupBookingLabel: 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   * 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() nasFormControlGroupBooking: string;\n\n  /**\n   * @property Input\n   * @description\n   * ARIA label for the subtract buttons.\n  */\n  @Input() ariaLabelSubtract: string;\n\n  /**\n   * @property Input\n   * @description\n   * ARIA label for the add buttons.\n   */\n  @Input() ariaLabelAdd: string;\n\n  /**\n   * @property Output\n   * @description\n   * An event that is fired every time a passenger selection change is performed.\n  */\n  @Output() passengersChange = new EventEmitter<Array<PassengersModel>>();\n\n  /**\n   * @property Output\n   * @description\n   * An event that is fired every time a passenger selection change is performed.\n  */\n  @Output() focusOnNext = new EventEmitter<any>();\n\n  /**\n   * @property Output\n   * @description\n   * An event that is fired every time a passenger selection change is performed.\n  */\n  @Output() focusOnPrevious = new EventEmitter<any>();\n\n  constructor() {\n    super('nas-passenger-select-new');\n  }\n\n  ngOnInit() {\n    this.setTotalCount();\n  }\n\n  getLabel(type: PassengerType): string {\n    switch (type) {\n      case PassengerType.Adult:\n        return this.adultsLabel;\n      case PassengerType.Child:\n        return this.childrenLabel;\n      case PassengerType.Infant:\n        return this.infantsLabel;\n      case PassengerType.Youth:\n        return this.youthsLabel;\n      case PassengerType.YoungAdult:\n        return this.youngAdultsLabel;\n    }\n  }\n\n  keyDown(event: KeyboardEvent, index: number): void {\n    event.preventDefault();\n\n    switch (event.key) {\n      case 'ArrowDown':\n        if (index === this.passengers.length - 1) {\n          this.numberFields.first.input.nativeElement.focus();\n        } else {\n          this.numberFields.toArray()[index + 1].input.nativeElement.focus();\n        }\n        break;\n      case 'ArrowUp':\n        if (index === 0) {\n          this.numberFields.toArray()[this.passengers.length - 1].input.nativeElement.focus();\n        } else {\n          this.numberFields.toArray()[index - 1].input.nativeElement.focus();\n        }\n        break;\n      case 'Tab':\n        if (!event.shiftKey) {\n          this.focusOnNext.emit();\n        } else if (event.shiftKey) {\n          this.focusOnPrevious.emit();\n        }\n    }\n  }\n\n  setPassengersCount(passengers: PassengersModel, count: number): void {\n    passengers.count = count;\n\n    if (passengers.type === PassengerType.Adult) {\n      if (this.passengers.find(x => x.type === PassengerType.Infant)) {\n        const infantsCount = this.passengers.find(x => x.type === PassengerType.Infant).count;\n        if (infantsCount > passengers.count && this.passengers.find(x => x.type === PassengerType.Infant)) {\n          const infant = this.passengers.find(x => x.type === PassengerType.Infant);\n\n          if (infant) {\n            infant.count = passengers.count;\n\n            if (infant.formGroup && infant.formControlName) {\n              infant.formGroup.get(infant.formControlName).patchValue(infant.count);\n            }\n          }\n        }\n      }\n\n      const youngAdult = this.passengers.find(x => x.type === PassengerType.YoungAdult);\n      const child = this.passengers.find(x => x.type === PassengerType.Child);\n      if (youngAdult && child) {\n        if ( passengers.count === 0 && child) {\n\n          if (child) {\n            child.count = 0;\n\n            if (child.formGroup && child.formControlName) {\n              child.formGroup.get(child.formControlName).patchValue(0);\n            }\n          }\n        }\n      }\n    }\n\n    if (passengers.type === PassengerType.Youth) {\n      if (this.passengers.find(x => x.type === PassengerType.Infant)) {\n        const infantsCount = this.passengers.find(x => x.type === PassengerType.Infant).count;\n        if (infantsCount > passengers.count && this.passengers.find(x => x.type === PassengerType.Infant)) {\n          const infant = this.passengers.find(x => x.type === PassengerType.Infant);\n\n          if (infant) {\n            infant.count = passengers.count;\n\n            if (infant.formGroup && infant.formControlName) {\n              infant.formGroup.get(infant.formControlName).patchValue(infant.count);\n            }\n          }\n        }\n      }\n    }\n\n    if (passengers.type === PassengerType.Adult || passengers.type === PassengerType.Youth) {\n      const adult = this.passengers.find(x => x.type === PassengerType.Adult);\n      const youth = this.passengers.find(x => x.type === PassengerType.Youth);\n\n      if (adult && youth) {\n        if (passengers.type === PassengerType.Adult && adult.count > 0) {\n          if (youth.formGroup && youth.formControlName && youth.count !== 0) {\n            youth.formGroup.get(youth.formControlName).patchValue(0);\n          }\n          youth.count = 0;\n        }\n\n        if (passengers.type === PassengerType.Youth) {\n          adult.count = youth.count > 0 ? 0 : adult.count;\n\n          if (adult.formGroup && adult.formControlName && youth.formGroup && youth.formControlName) {\n            if (this.minAdultCount && youth.count === 0) {\n              adult.formGroup.get(adult.formControlName).patchValue(this.minAdultCount);\n            } else if (youth.count > 0) {\n              adult.formGroup.get(adult.formControlName).patchValue(0);\n            }\n          }\n        }\n      }\n    }\n\n    if (passengers.type === PassengerType.YoungAdult || passengers.type === PassengerType.Youth) {\n      const youngAdult = this.passengers.find(x => x.type === PassengerType.YoungAdult);\n      const youth = this.passengers.find(x => x.type === PassengerType.Youth);\n\n      if (youngAdult && youth) {\n        if (passengers.type === PassengerType.Youth && youth.count > 0) {\n          if (youngAdult.formGroup && youth.formControlName && youngAdult.count !== 0) {\n            youngAdult.formGroup.get(youth.formControlName).patchValue(0);\n          }\n          youngAdult.count = 0;\n        }\n\n        if (passengers.type === PassengerType.YoungAdult) {\n          youth.count = youngAdult.count > 0 ? 0 : youth.count;\n\n          if (youth.formGroup && youth.formControlName && youngAdult.formGroup && youngAdult.formControlName) {\n            if (this.minAdultCount && youngAdult.count === 0) {\n              youth.formGroup.get(youth.formControlName).patchValue(this.minAdultCount);\n            } else if (youth.count > 0) {\n              youth.formGroup.get(youth.formControlName).patchValue(0);\n            }\n          }\n        }\n      }\n    }\n\n    this.setTotalCount();\n    this.passengersChange.emit(this.passengers);\n  }\n\n  getMax(passengers: PassengersModel): number {\n    if(passengers?.disabled) {\n      return passengers?.count;\n    }\n\n    const adults = this.passengers.find(x => x.type === PassengerType.Adult);\n    const youths = this.passengers.find(x => x.type === PassengerType.Youth);\n    const youngAdult = this.passengers.find(x => x.type === PassengerType.YoungAdult);\n\n    if (passengers.type === PassengerType.Infant) {\n      if (adults && adults.count > 0) {\n        if (!adults.formGroup || !adults.formControlName) {\n          return adults.count;\n        }\n\n        const adultsFormControl = adults.formGroup.get(adults.formControlName);\n\n        if (!adultsFormControl) {\n          return adults.count;\n        }\n\n        return adultsFormControl.value as number;\n      }\n\n      if (youths && youths.count > 0) {\n        if (!youths.formGroup || !youths.formControlName) {\n          return youths.count;\n        }\n\n        const youthsFormControl = youths.formGroup.get(youths.formControlName);\n\n        if (!youthsFormControl) {\n          return youths.count;\n        }\n\n        return youthsFormControl.value as number;\n      }\n\n      if (youngAdult && (adults && adults.count <= 0)) {\n        return 0;\n      }\n\n      if (youngAdult && (youths && youths.count <= 0)) {\n        return 0;\n      }\n\n      return 0;\n\n    } else if (passengers.type === PassengerType.Child && this.totalCount < 10) { \n      if (adults && youngAdult) {\n        if (adults.count <= 0) {\n          return 0;\n        }\n      }\n      if (youths && youngAdult) {\n        if (youths.count <= 0) {\n          return 0;\n        }\n      }\n    } else if (this.totalCount >= this.maxPaxCount) {\n\n      if (!passengers.formGroup || !passengers.formControlName) {\n        return passengers.count;\n      }\n\n      const passengersFormControl = passengers.formGroup.get(passengers.formControlName);\n\n      if (!passengersFormControl) {\n        return passengers.count;\n      }\n\n      return passengersFormControl.value;\n    } else {\n      return this.maxPaxCount;\n    }\n  }\n\n  getMin(passengers: PassengersModel): number {\n    if (passengers?.disabled) {\n      return passengers?.count;\n    }\n    const adult = this.passengers.find(x => x.type === PassengerType.Adult);\n    const youth = this.passengers.find(x => x.type === PassengerType.Youth);\n    const youngAdult = this.passengers.find(x => x.type === PassengerType.YoungAdult);\n\n    if (passengers.type === PassengerType.Adult && youth) {\n      const min = !this.minAdultCount ? 0 : this.minAdultCount;\n      if (passengers.type === PassengerType.Adult && adult.count < min && youth.count === 0) {\n        passengers.count = min;\n        return min;\n      }\n      if (passengers.type === PassengerType.Adult && adult.formGroup && adult.formControlName) {\n        return min;\n      }\n    } else if (passengers.type === PassengerType.Youth && youngAdult) {\n      const min = !this.minAdultCount ? 0 : this.minAdultCount;\n      if (passengers.type === PassengerType.Youth && youth.count < min && youngAdult.count === 0) {\n        passengers.count = min;\n        return min;\n      }\n      if (passengers.type === PassengerType.Youth && youth.formGroup && youth.formControlName) {\n        return min;\n      }\n    } else if (!adult && passengers.type === PassengerType.Youth) {\n      const min = !this.minAdultCount ? 0 : this.minAdultCount;\n      return min;\n    } else if (passengers.type === PassengerType.Adult && youngAdult) {\n      if (youngAdult.count > 0) {\n        return 0;\n      }\n      return this.minAdultCount;\n    } else if (passengers.type === PassengerType.YoungAdult && adult) {\n      if (adult.count > 0) {\n        return 0;\n      }\n      return this.minAdultCount;\n    }  else if (passengers.type === PassengerType.Adult) {\n      return this.minAdultCount;\n    }\n\n    return 0;\n  }\n\n  private setTotalCount() {\n    const adult = this.passengers.find(x => x.type === PassengerType.Adult);\n    const youth = this.passengers.find(x => x.type === PassengerType.Youth);\n    const youngAdult = this.passengers.find(x => x.type === PassengerType.YoungAdult);\n    const child = this.passengers.find(x => x.type === PassengerType.Child);\n\n    let adultCount = 0;\n    let youthCount = 0;\n    let youngAdultCount = 0;\n    let childCount = 0;\n\n    if (adult) {\n\n      if (!adult.formGroup || !adult.formControlName) {\n        adultCount = adult.count;\n      } else {\n        const adultsControl = adult.formGroup.get(adult.formControlName);\n\n        if (!adultsControl) {\n          adultCount = adult.count;\n        } else {\n          adultCount = adultsControl.value as number;\n        }\n      }\n    }\n\n    if (youth) {\n      if (!youth.formGroup || !youth.formControlName) {\n        youthCount = youth.count;\n      } else {\n        const youthsControl = youth.formGroup.get(youth.formControlName);\n\n        if (!youthsControl) {\n          youthCount = youth.count;\n        } else {\n          youthCount = youthsControl.value as number;\n        }\n      }\n    }\n\n    if (youngAdult) {\n      if (!youngAdult.formGroup || !youngAdult.formControlName) {\n        youngAdultCount = youngAdult.count;\n      } else {\n        const youngAdultsControl = youngAdult.formGroup.get(youngAdult.formControlName);\n\n        if (!youngAdultsControl) {\n          youngAdultCount = youngAdult.count;\n        } else {\n          youngAdultCount = youngAdultsControl.value as number;\n        }\n      }\n    }\n\n    if (child) {\n      if (!child.formGroup || !child.formControlName) {\n        childCount = child.count;\n      } else {\n        const childsControl = child.formGroup.get(child.formControlName);\n\n        if (!childsControl) {\n          childCount = child.count;\n        } else {\n          childCount = childsControl.value as number;\n        }\n      }\n    }\n\n    this.totalCount = adultCount + childCount + youthCount + youngAdultCount;\n\n    if (this.nasFormGroup && this.nasFormControlGroupBooking) {\n      const groupBookingControl = this.nasFormGroup.get(this.nasFormControlGroupBooking);\n\n      this.isGroupBooking = this.totalCount >= this.groupBookingLimit;\n\n      if (this.groupBookingLimit < 1) {\n        this.isGroupBooking = false;\n      }\n\n      if (groupBookingControl.value !== this.isGroupBooking) {\n        groupBookingControl.patchValue(this.isGroupBooking);\n      }\n    } else if (this.groupBookingLimit) {\n      this.isGroupBooking = this.totalCount >= this.groupBookingLimit;\n    }\n\n  }\n\n}\n","<h2 *ngIf=\"title || isGroupBooking\" [nasClass]=\"getClass('title')\">\n    <span *ngIf=\"title\">{{title}}</span>\n    <span *ngIf=\"isGroupBooking\" [nasClass]=\"getClass('title--group-booking')\">{{groupBookingLabel}}</span>\n</h2>\n<ul [nasClass]=\"getClass('list')\">\n  <li *ngFor=\"let item of passengers; index as count\"\n    [nasClass]=\"getClass('list-item')\">\n    <label [nasClass]=\"getClass('label')\"\n      [attr.aria-label]=\"getLabel(item.type)\">{{getLabel(item.type)}}</label>\n    <ng-container *ngIf=\"!item.formGroup || !item.formControlName; else reactiveForm\">\n      <nas-number-field-new compact\n        spaceless\n        simple\n        [ariaLabel]=\"getLabel(item.type)\"\n        [ariaLabelSubtract]=\"ariaLabelSubtract\"\n        [ariaLabelAdd]=\"ariaLabelAdd\"\n        [number]=\"item.count\"\n        [max]=\"getMax(item)\"\n        [min]=\"getMin(item)\"\n        (numberChange)=\"setPassengersCount(item, $event)\"\n        (keydown)=\"keyDown($event, count)\"></nas-number-field-new>\n    </ng-container>\n    <ng-template #reactiveForm>\n      <nas-number-field-new compact\n        spaceless\n        simple\n        [ariaLabel]=\"getLabel(item.type)\"\n        [ariaLabelSubtract]=\"ariaLabelSubtract\"\n        [ariaLabelAdd]=\"ariaLabelAdd\"\n        [nasFormGroup]=\"item.formGroup\"\n        [nasFormControlName]=\"item.formControlName\"\n        [number]=\"item.formGroup?.get(item.formControlName)?.value\"\n        [max]=\"getMax(item)\"\n        [min]=\"getMin(item)\"\n        (keydown)=\"keyDown($event, count)\"\n        (numberChange)=\"setPassengersCount(item, $event)\"></nas-number-field-new>\n    </ng-template>\n  </li>\n</ul>"]}
|
|
423
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"passenger-select-new.component.js","sourceRoot":"","sources":["../../../../../../projects/core-components/src/lib/components/passenger-select-new/passenger-select-new.component.ts","../../../../../../projects/core-components/src/lib/components/passenger-select-new/passenger-select-new.component.html"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Norwegian Air Shuttle. All Rights Reserved.\n */\nimport {\n  Component,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n  ViewChildren,\n  QueryList\n} from '@angular/core';\nimport { FormGroup } from '@angular/forms';\nimport { PassengerType } from './enums/passenger-type.enum';\nimport { PassengersModel } from './models/passengers.model';\nimport { NasComponentBase } from '../../core/base/nas-component.base';\nimport { NumberFieldNewComponent } from '../number-field-new';\n\n/**\n * @description\n * Norwegian Passenger Select Component | New design | Beta\n*/\n@Component({\n  selector: 'nas-passenger-select-new',\n  templateUrl: './passenger-select-new.component.html',\n  styleUrls: ['./passenger-select-new.component.scss']\n})\nexport class PassengerSelectNewComponent extends NasComponentBase implements OnInit {\n  @ViewChildren(NumberFieldNewComponent) numberFields!: QueryList<NumberFieldNewComponent>;\n\n  totalCount: number;\n  isGroupBooking: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * An array of different passenger types that will be displayed.\n  */\n  @Input() passengers = new Array<PassengersModel>();\n\n  /**\n   * @property Input\n   * @description\n   * The total maximum amount of passengers.\n  */\n  @Input() maxPaxCount: number = 10;\n\n  /**\n   * @property Input\n   * @description\n   * The minimum amount of adults that can be selected.\n  */\n  @Input() minAdultCount: number;\n\n  /**\n   * @property Input\n   * @description\n   * The limit for when the total amount of passengers exceeds to be a group booking.\n  */\n  @Input() groupBookingLimit: number;\n\n  /**\n   * @property Input\n   * @description\n   * A title that will be added to the dropdown.\n  */\n  @Input() title: string;\n\n  /**\n   * @property Input\n   * @description\n   * A label for the adults passenger type.\n  */\n  @Input() adultsLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * A label for the children passenger type.\n  */\n  @Input() childrenLabel: string;\n\n  /**\n   * @description\n   * A label for the infants passenger type.\n   */\n  @Input() infantsLabel: string;\n\n  /**\n * @property Input\n * @description\n * A label for the adults passenger type.\n*/\n  @Input() youthsLabel: string;\n\n/**\n * @property Input\n * @description\n * A label for the adults passenger type.\n*/\n  @Input() youngAdultsLabel: string;\n\n  /**\n   * @property Input\n   * @description\n   * A label that will appear when total number of selected passengers exceeds the group booking limit\n  */\n  @Input() groupBookingLabel: 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   * 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() nasFormControlGroupBooking: string;\n\n  /**\n   * @property Input\n   * @description\n   * ARIA label for the subtract buttons.\n  */\n  @Input() ariaLabelSubtract: string;\n\n  /**\n   * @property Input\n   * @description\n   * ARIA label for the add buttons.\n   */\n  @Input() ariaLabelAdd: string;\n\n  /**\n   * @property Output\n   * @description\n   * An event that is fired every time a passenger selection change is performed.\n  */\n  @Output() passengersChange = new EventEmitter<Array<PassengersModel>>();\n\n  /**\n   * @property Output\n   * @description\n   * An event that is fired every time a passenger selection change is performed.\n  */\n  @Output() focusOnNext = new EventEmitter<any>();\n\n  /**\n   * @property Output\n   * @description\n   * An event that is fired every time a passenger selection change is performed.\n  */\n  @Output() focusOnPrevious = new EventEmitter<any>();\n\n  constructor() {\n    super('nas-passenger-select-new');\n  }\n\n  ngOnInit() {\n    this.setTotalCount();\n  }\n\n  getLabel(type: PassengerType): string {\n    switch (type) {\n      case PassengerType.Adult:\n        return this.adultsLabel;\n      case PassengerType.Child:\n        return this.childrenLabel;\n      case PassengerType.Infant:\n        return this.infantsLabel;\n      case PassengerType.Youth:\n        return this.youthsLabel;\n      case PassengerType.YoungAdult:\n        return this.youngAdultsLabel;\n    }\n  }\n\n  keyDown(event: KeyboardEvent, index: number): void {\n    event.preventDefault();\n\n    switch (event.key) {\n      case 'ArrowDown':\n        if (index === this.passengers.length - 1) {\n          this.numberFields.first.input.nativeElement.focus();\n        } else {\n          this.numberFields.toArray()[index + 1].input.nativeElement.focus();\n        }\n        break;\n      case 'ArrowUp':\n        if (index === 0) {\n          this.numberFields.toArray()[this.passengers.length - 1].input.nativeElement.focus();\n        } else {\n          this.numberFields.toArray()[index - 1].input.nativeElement.focus();\n        }\n        break;\n      case 'Tab':\n        if (!event.shiftKey) {\n          this.focusOnNext.emit();\n        } else if (event.shiftKey) {\n          this.focusOnPrevious.emit();\n        }\n    }\n  }\n\n  setPassengersCount(passengers: PassengersModel, count: number): void {\n    passengers.count = count;\n\n    if (passengers.type === PassengerType.Adult) {\n      if (this.passengers.find(x => x.type === PassengerType.Infant)) {\n        const infantsCount = this.passengers.find(x => x.type === PassengerType.Infant).count;\n        if (infantsCount > passengers.count && this.passengers.find(x => x.type === PassengerType.Infant)) {\n          const infant = this.passengers.find(x => x.type === PassengerType.Infant);\n\n          if (infant) {\n            infant.count = passengers.count;\n\n            if (infant.formGroup && infant.formControlName) {\n              infant.formGroup.get(infant.formControlName).patchValue(infant.count);\n            }\n          }\n        }\n      }\n\n      const youngAdult = this.passengers.find(x => x.type === PassengerType.YoungAdult);\n      const child = this.passengers.find(x => x.type === PassengerType.Child);\n      if (youngAdult && child) {\n        if ( passengers.count === 0 && child) {\n\n          if (child) {\n            child.count = 0;\n\n            if (child.formGroup && child.formControlName) {\n              child.formGroup.get(child.formControlName).patchValue(0);\n            }\n          }\n        }\n      }\n    }\n\n    if (passengers.type === PassengerType.Youth) {\n      if (this.passengers.find(x => x.type === PassengerType.Infant)) {\n        const infantsCount = this.passengers.find(x => x.type === PassengerType.Infant).count;\n        if (infantsCount > passengers.count && this.passengers.find(x => x.type === PassengerType.Infant)) {\n          const infant = this.passengers.find(x => x.type === PassengerType.Infant);\n\n          if (infant) {\n            infant.count = passengers.count;\n\n            if (infant.formGroup && infant.formControlName) {\n              infant.formGroup.get(infant.formControlName).patchValue(infant.count);\n            }\n          }\n        }\n      }\n    }\n\n    if (passengers.type === PassengerType.Adult || passengers.type === PassengerType.Youth) {\n      const adult = this.passengers.find(x => x.type === PassengerType.Adult);\n      const youth = this.passengers.find(x => x.type === PassengerType.Youth);\n\n      if (adult && youth) {\n        if (passengers.type === PassengerType.Adult && adult.count > 0) {\n          if (youth.formGroup && youth.formControlName && youth.count !== 0) {\n            youth.formGroup.get(youth.formControlName).patchValue(0);\n          }\n          youth.count = 0;\n        }\n\n        if (passengers.type === PassengerType.Youth) {\n          adult.count = youth.count > 0 ? 0 : adult.count;\n\n          if (adult.formGroup && adult.formControlName && youth.formGroup && youth.formControlName) {\n            if (this.minAdultCount && youth.count === 0) {\n              adult.formGroup.get(adult.formControlName).patchValue(this.minAdultCount);\n            } else if (youth.count > 0) {\n              adult.formGroup.get(adult.formControlName).patchValue(0);\n            }\n          }\n        }\n      }\n    }\n\n    if (passengers.type === PassengerType.YoungAdult || passengers.type === PassengerType.Youth) {\n      const youngAdult = this.passengers.find(x => x.type === PassengerType.YoungAdult);\n      const youth = this.passengers.find(x => x.type === PassengerType.Youth);\n\n      if (youngAdult && youth) {\n        if (passengers.type === PassengerType.Youth && youth.count > 0) {\n          if (youngAdult.formGroup && youth.formControlName && youngAdult.count !== 0) {\n            youngAdult.formGroup.get(youth.formControlName).patchValue(0);\n          }\n          youngAdult.count = 0;\n        }\n\n        if (passengers.type === PassengerType.YoungAdult) {\n          youth.count = youngAdult.count > 0 ? 0 : youth.count;\n\n          if (youth.formGroup && youth.formControlName && youngAdult.formGroup && youngAdult.formControlName) {\n            if (this.minAdultCount && youngAdult.count === 0) {\n              youth.formGroup.get(youth.formControlName).patchValue(this.minAdultCount);\n            } else if (youth.count > 0) {\n              youth.formGroup.get(youth.formControlName).patchValue(0);\n            }\n          }\n        }\n      }\n    }\n\n    this.setTotalCount();\n    this.passengersChange.emit(this.passengers);\n  }\n\n  getMax(passengers: PassengersModel): number {\n    if(passengers?.disabled) {\n      return passengers?.count;\n    }\n\n    const adults = this.passengers.find(x => x.type === PassengerType.Adult);\n    const youths = this.passengers.find(x => x.type === PassengerType.Youth);\n    const youngAdult = this.passengers.find(x => x.type === PassengerType.YoungAdult);\n\n    if (passengers.type === PassengerType.Infant) {\n      if (adults && adults.count > 0) {\n        if (!adults.formGroup || !adults.formControlName) {\n          return adults.count;\n        }\n\n        const adultsFormControl = adults.formGroup.get(adults.formControlName);\n\n        if (!adultsFormControl) {\n          return adults.count;\n        }\n\n        return adultsFormControl.value as number;\n      }\n\n      if (youths && youths.count > 0) {\n        if (!youths.formGroup || !youths.formControlName) {\n          return youths.count;\n        }\n\n        const youthsFormControl = youths.formGroup.get(youths.formControlName);\n\n        if (!youthsFormControl) {\n          return youths.count;\n        }\n\n        return youthsFormControl.value as number;\n      }\n\n      if (youngAdult && (adults && adults.count <= 0)) {\n        return 0;\n      }\n\n      if (youngAdult && (youths && youths.count <= 0)) {\n        return 0;\n      }\n\n      return 0;\n\n    } else if (passengers.type === PassengerType.Child && this.totalCount < this.maxPaxCount) { \n      if (adults && youngAdult) {\n        if (adults.count <= 0) {\n          return 0;\n        }\n      }\n      if (youths && youngAdult) {\n        if (youths.count <= 0) {\n          return 0;\n        }\n      }\n    } else if (this.totalCount >= this.maxPaxCount) {\n\n      if (!passengers.formGroup || !passengers.formControlName) {\n        return passengers.count;\n      }\n\n      const passengersFormControl = passengers.formGroup.get(passengers.formControlName);\n\n      if (!passengersFormControl) {\n        return passengers.count;\n      }\n\n      return passengersFormControl.value;\n    } else {\n      return this.maxPaxCount;\n    }\n  }\n\n  getMin(passengers: PassengersModel): number {\n    if (passengers?.disabled) {\n      return passengers?.count;\n    }\n    const adult = this.passengers.find(x => x.type === PassengerType.Adult);\n    const youth = this.passengers.find(x => x.type === PassengerType.Youth);\n    const youngAdult = this.passengers.find(x => x.type === PassengerType.YoungAdult);\n\n    if (passengers.type === PassengerType.Adult && youth) {\n      const min = !this.minAdultCount ? 0 : this.minAdultCount;\n      if (passengers.type === PassengerType.Adult && adult.count < min && youth.count === 0) {\n        passengers.count = min;\n        return min;\n      }\n      if (passengers.type === PassengerType.Adult && adult.formGroup && adult.formControlName) {\n        return min;\n      }\n    } else if (passengers.type === PassengerType.Youth && youngAdult) {\n      const min = !this.minAdultCount ? 0 : this.minAdultCount;\n      if (passengers.type === PassengerType.Youth && youth.count < min && youngAdult.count === 0) {\n        passengers.count = min;\n        return min;\n      }\n      if (passengers.type === PassengerType.Youth && youth.formGroup && youth.formControlName) {\n        return min;\n      }\n    } else if (!adult && passengers.type === PassengerType.Youth) {\n      const min = !this.minAdultCount ? 0 : this.minAdultCount;\n      return min;\n    } else if (passengers.type === PassengerType.Adult && youngAdult) {\n      if (youngAdult.count > 0) {\n        return 0;\n      }\n      return this.minAdultCount;\n    } else if (passengers.type === PassengerType.YoungAdult && adult) {\n      if (adult.count > 0) {\n        return 0;\n      }\n      return this.minAdultCount;\n    }  else if (passengers.type === PassengerType.Adult) {\n      return this.minAdultCount;\n    }\n\n    return 0;\n  }\n\n  private setTotalCount() {\n    const adult = this.passengers.find(x => x.type === PassengerType.Adult);\n    const youth = this.passengers.find(x => x.type === PassengerType.Youth);\n    const youngAdult = this.passengers.find(x => x.type === PassengerType.YoungAdult);\n    const child = this.passengers.find(x => x.type === PassengerType.Child);\n\n    let adultCount = 0;\n    let youthCount = 0;\n    let youngAdultCount = 0;\n    let childCount = 0;\n\n    if (adult) {\n\n      if (!adult.formGroup || !adult.formControlName) {\n        adultCount = adult.count;\n      } else {\n        const adultsControl = adult.formGroup.get(adult.formControlName);\n\n        if (!adultsControl) {\n          adultCount = adult.count;\n        } else {\n          adultCount = adultsControl.value as number;\n        }\n      }\n    }\n\n    if (youth) {\n      if (!youth.formGroup || !youth.formControlName) {\n        youthCount = youth.count;\n      } else {\n        const youthsControl = youth.formGroup.get(youth.formControlName);\n\n        if (!youthsControl) {\n          youthCount = youth.count;\n        } else {\n          youthCount = youthsControl.value as number;\n        }\n      }\n    }\n\n    if (youngAdult) {\n      if (!youngAdult.formGroup || !youngAdult.formControlName) {\n        youngAdultCount = youngAdult.count;\n      } else {\n        const youngAdultsControl = youngAdult.formGroup.get(youngAdult.formControlName);\n\n        if (!youngAdultsControl) {\n          youngAdultCount = youngAdult.count;\n        } else {\n          youngAdultCount = youngAdultsControl.value as number;\n        }\n      }\n    }\n\n    if (child) {\n      if (!child.formGroup || !child.formControlName) {\n        childCount = child.count;\n      } else {\n        const childsControl = child.formGroup.get(child.formControlName);\n\n        if (!childsControl) {\n          childCount = child.count;\n        } else {\n          childCount = childsControl.value as number;\n        }\n      }\n    }\n\n    this.totalCount = adultCount + childCount + youthCount + youngAdultCount;\n\n    if (this.nasFormGroup && this.nasFormControlGroupBooking) {\n      const groupBookingControl = this.nasFormGroup.get(this.nasFormControlGroupBooking);\n\n      this.isGroupBooking = this.totalCount >= this.groupBookingLimit;\n\n      if (this.groupBookingLimit < 1) {\n        this.isGroupBooking = false;\n      }\n\n      if (groupBookingControl.value !== this.isGroupBooking) {\n        groupBookingControl.patchValue(this.isGroupBooking);\n      }\n    } else if (this.groupBookingLimit) {\n      this.isGroupBooking = this.totalCount >= this.groupBookingLimit;\n    }\n\n  }\n\n}\n","<h2 *ngIf=\"title || isGroupBooking\" [nasClass]=\"getClass('title')\">\n    <span *ngIf=\"title\">{{title}}</span>\n    <span *ngIf=\"isGroupBooking\" [nasClass]=\"getClass('title--group-booking')\">{{groupBookingLabel}}</span>\n</h2>\n<ul [nasClass]=\"getClass('list')\">\n  <li *ngFor=\"let item of passengers; index as count\"\n    [nasClass]=\"getClass('list-item')\">\n    <label [nasClass]=\"getClass('label')\"\n      [attr.aria-label]=\"getLabel(item.type)\">{{getLabel(item.type)}}</label>\n    <ng-container *ngIf=\"!item.formGroup || !item.formControlName; else reactiveForm\">\n      <nas-number-field-new compact\n        spaceless\n        simple\n        [ariaLabel]=\"getLabel(item.type)\"\n        [ariaLabelSubtract]=\"ariaLabelSubtract\"\n        [ariaLabelAdd]=\"ariaLabelAdd\"\n        [number]=\"item.count\"\n        [max]=\"getMax(item)\"\n        [min]=\"getMin(item)\"\n        (numberChange)=\"setPassengersCount(item, $event)\"\n        (keydown)=\"keyDown($event, count)\"></nas-number-field-new>\n    </ng-container>\n    <ng-template #reactiveForm>\n      <nas-number-field-new compact\n        spaceless\n        simple\n        [ariaLabel]=\"getLabel(item.type)\"\n        [ariaLabelSubtract]=\"ariaLabelSubtract\"\n        [ariaLabelAdd]=\"ariaLabelAdd\"\n        [nasFormGroup]=\"item.formGroup\"\n        [nasFormControlName]=\"item.formControlName\"\n        [number]=\"item.formGroup?.get(item.formControlName)?.value\"\n        [max]=\"getMax(item)\"\n        [min]=\"getMin(item)\"\n        (keydown)=\"keyDown($event, count)\"\n        (numberChange)=\"setPassengersCount(item, $event)\"></nas-number-field-new>\n    </ng-template>\n  </li>\n</ul>"]}
|
|
@@ -81,11 +81,11 @@ export class StatusBoxComponent extends NasComponentBase {
|
|
|
81
81
|
this.clickChange.emit(event);
|
|
82
82
|
}
|
|
83
83
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.5", ngImport: i0, type: StatusBoxComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
84
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.5", type: StatusBoxComponent, selector: "nas-status-box", inputs: { info: "info", warning: "warning", error: "error", success: "success", title: "title", text: "text", buttonText: "buttonText", statusBox: "statusBox", trackingvalue: "trackingvalue" }, outputs: { clickChange: "clickChange" }, usesInheritance: true, ngImport: i0, template: "<div [nasClass]=\"getClass('container')\">\n <div [nasClass]=\"getClass('icon')\">\n <nas-icon [icon]=\"getIcon()\" [type]=\"'large'\"></nas-icon>\n </div>\n <div [nasClass]=\"getClass('content')\">\n <div [nasClass]=\"getClass('text-container')\">\n <div [nasClass]=\"getClass('text')\">{{title}}</div>\n <span [nasClass]=\"getClass('text--small')\">{{text}}</span>\n </div>\n <div *ngIf=\"buttonText\">\n <nas-button-new secondary (clickChange)=\"statusBoxEvent($event)\">{{buttonText}}</nas-button-new>\n </div>\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-status-box__container{
|
|
84
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.5", type: StatusBoxComponent, selector: "nas-status-box", inputs: { info: "info", warning: "warning", error: "error", success: "success", title: "title", text: "text", buttonText: "buttonText", statusBox: "statusBox", trackingvalue: "trackingvalue" }, outputs: { clickChange: "clickChange" }, usesInheritance: true, ngImport: i0, template: "<div [nasClass]=\"getClass('container')\">\n <div [nasClass]=\"getClass('icon')\">\n <nas-icon [icon]=\"getIcon()\" [type]=\"'large'\"></nas-icon>\n </div>\n <div [nasClass]=\"getClass('content')\">\n <div [nasClass]=\"getClass('text-container')\">\n <div [nasClass]=\"getClass('text')\">{{title}}</div>\n <span [nasClass]=\"getClass('text--small')\">{{text}}</span>\n </div>\n <div *ngIf=\"buttonText\">\n <nas-button-new secondary (clickChange)=\"statusBoxEvent($event)\">{{buttonText}}</nas-button-new>\n </div>\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-status-box__container{display:block;align-items:center;justify-content:center;text-align:center;background-color:#fff;padding:16px}.nas-status-box__container ::ng-deep .nas-button-new--secondary{width:100%}@media (min-width: 1000px){.nas-status-box__container ::ng-deep .nas-button-new--secondary{width:-webkit-max-content;width:max-content}}@media (min-width: 1000px){.nas-status-box__container{text-align:unset;display:flex}}.nas-status-box__content{margin:24px 48px;align-items:center;display:inline-block}@media (min-width: 1280px){.nas-status-box__content{display:flex}}.nas-status-box__text-container{margin:0 0 16px}@media (min-width: 1000px){.nas-status-box__text-container{margin:24px 48px 24px 0}}.nas-status-box__text,.nas-status-box__text--small{color:#15273f;font-size:22px;line-height:28px;font-weight:700;line-height:20px;margin-bottom:4px}.nas-status-box__text--small{font-weight:400;font-size:16px;line-height:26px}.nas-status-box__icon{width:100%;height:170px}@media (min-width: 1000px){.nas-status-box__icon{width:170px}}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NasClassDirective, selector: "[nasClass]", inputs: ["nasClass", "attr.class"] }, { kind: "component", type: i3.ButtonNewComponent, selector: "nas-button-new", inputs: ["primary", "secondary", "link", "light", "large", "block", "flex", "compact", "right", "spaceless", "href", "trackingvalue", "canContinueOnDisabled", "disabled", "type", "cssClass", "ariaLabel", "cssStyle", "tabindex", "overrideBaseCssClass", "useRouterLink", "id", "target", "icon", "iconLeft", "iconType", "buttonlink"], outputs: ["clickChange"] }, { kind: "component", type: i4.IconComponent, selector: "nas-icon", inputs: ["icon", "type", "isIndicator", "lightCircularBackground", "cssClass"] }] }); }
|
|
85
85
|
}
|
|
86
86
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.5", ngImport: i0, type: StatusBoxComponent, decorators: [{
|
|
87
87
|
type: Component,
|
|
88
|
-
args: [{ selector: 'nas-status-box', template: "<div [nasClass]=\"getClass('container')\">\n <div [nasClass]=\"getClass('icon')\">\n <nas-icon [icon]=\"getIcon()\" [type]=\"'large'\"></nas-icon>\n </div>\n <div [nasClass]=\"getClass('content')\">\n <div [nasClass]=\"getClass('text-container')\">\n <div [nasClass]=\"getClass('text')\">{{title}}</div>\n <span [nasClass]=\"getClass('text--small')\">{{text}}</span>\n </div>\n <div *ngIf=\"buttonText\">\n <nas-button-new secondary (clickChange)=\"statusBoxEvent($event)\">{{buttonText}}</nas-button-new>\n </div>\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-status-box__container{
|
|
88
|
+
args: [{ selector: 'nas-status-box', template: "<div [nasClass]=\"getClass('container')\">\n <div [nasClass]=\"getClass('icon')\">\n <nas-icon [icon]=\"getIcon()\" [type]=\"'large'\"></nas-icon>\n </div>\n <div [nasClass]=\"getClass('content')\">\n <div [nasClass]=\"getClass('text-container')\">\n <div [nasClass]=\"getClass('text')\">{{title}}</div>\n <span [nasClass]=\"getClass('text--small')\">{{text}}</span>\n </div>\n <div *ngIf=\"buttonText\">\n <nas-button-new secondary (clickChange)=\"statusBoxEvent($event)\">{{buttonText}}</nas-button-new>\n </div>\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-status-box__container{display:block;align-items:center;justify-content:center;text-align:center;background-color:#fff;padding:16px}.nas-status-box__container ::ng-deep .nas-button-new--secondary{width:100%}@media (min-width: 1000px){.nas-status-box__container ::ng-deep .nas-button-new--secondary{width:-webkit-max-content;width:max-content}}@media (min-width: 1000px){.nas-status-box__container{text-align:unset;display:flex}}.nas-status-box__content{margin:24px 48px;align-items:center;display:inline-block}@media (min-width: 1280px){.nas-status-box__content{display:flex}}.nas-status-box__text-container{margin:0 0 16px}@media (min-width: 1000px){.nas-status-box__text-container{margin:24px 48px 24px 0}}.nas-status-box__text,.nas-status-box__text--small{color:#15273f;font-size:22px;line-height:28px;font-weight:700;line-height:20px;margin-bottom:4px}.nas-status-box__text--small{font-weight:400;font-size:16px;line-height:26px}.nas-status-box__icon{width:100%;height:170px}@media (min-width: 1000px){.nas-status-box__icon{width:170px}}\n"] }]
|
|
89
89
|
}], ctorParameters: function () { return []; }, propDecorators: { info: [{
|
|
90
90
|
type: Input
|
|
91
91
|
}], warning: [{
|
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
export class OptionModel {
|
|
2
2
|
}
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3B0aW9ucy5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUtY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvdG9nZ2xlL21vZGVscy9vcHRpb25zLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sT0FBTyxXQUFXO0NBTXZCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNsYXNzIE9wdGlvbk1vZGVsIHtcbiAgICBuYW1lOiBzdHJpbmc7XG4gICAgdmFsdWU6IHN0cmluZztcbiAgICB0ZXh0OiBzdHJpbmc7XG4gICAgaWNvbj86IHN0cmluZztcbiAgICBocmVmPzogc3RyaW5nO1xufVxuIl19
|
|
@@ -61,12 +61,20 @@ export class ToggleComponent extends NasComponentBase {
|
|
|
61
61
|
this.exists(this.scrollable) && 'scrollable'
|
|
62
62
|
]);
|
|
63
63
|
}
|
|
64
|
+
onClickHref(event, option) {
|
|
65
|
+
if (option?.href == null || option?.href == '') {
|
|
66
|
+
return;
|
|
67
|
+
}
|
|
68
|
+
event.preventDefault();
|
|
69
|
+
this.onChange(option);
|
|
70
|
+
history.pushState(null, '', option.href);
|
|
71
|
+
}
|
|
64
72
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.5", ngImport: i0, type: ToggleComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
65
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.5", type: ToggleComponent, selector: "nas-toggle", inputs: { options: "options", large: "large", compact: "compact", light: "light", rounded: "rounded", small: "small", big: "big", selectedValue: "selectedValue", label: "label", vertical: "vertical", grouped: "grouped", group: "group", nasFormControlName: "nasFormControlName", nasFormGroup: "nasFormGroup", scrollable: "scrollable" }, outputs: { handleChange: "handleChange" }, usesInheritance: true, ngImport: i0, template: "<div [nasClass]=\"mainClasses()\" *ngIf=\"!nasFormControlName; else reactiveForm\">\n <h3 [nasClass]=\"getClass('title')\">{{label}}</h3>\n <div [nasClass]=\"getClass('items')\">\n <span [nasClass]=\"getClass('item')\" *ngFor=\"let option of options\">\n <input [nasClass]=\"getClass('radio')\" [attr.id]=\"getOptionId(option)\" [checked]=\"option.value === selectedValue\" [attr.name]=\"group\" type=\"radio\" [attr.value]=\"option.value\" (change)=\"onChange(option)\">\n <label [nasClass]=\"getClass('label')\" [attr.for]=\"getOptionId(option)\">\n <nas-icon *ngIf=\"option.icon\" [icon]=\"getIcon(option)\" [type]=\"iconType\"></nas-icon>\n <span [nasClass]=\"getClass('text')\" *ngIf=\"!isRounded\">{{option.text}}</span>\n </label>\n <span [nasClass]=\"getClass('text')\" *ngIf=\"isRounded\">{{option.text}}</span>\n </span>\n </div>\n</div>\n<ng-template #reactiveForm>\n <div [nasClass]=\"mainClasses()\" >\n <h3 [nasClass]=\"getClass('title')\">{{label}}</h3>\n <div [nasClass]=\"getClass('items')\" [formGroup]=\"nasFormGroup\">\n <span [nasClass]=\"getClass('item')\" *ngFor=\"let option of options\">\n <input [formControlName]=\"nasFormControlName\" [nasClass]=\"getClass('radio')\" [attr.id]=\"getOptionId(option)\" [checked]=\"option.value === selectedValue\" [name]=\"group\" type=\"radio\" [value]=\"option.value\" (change)=\"onChange(option)\">\n <label [nasClass]=\"getClass('label')\" [attr.for]=\"getOptionId(option)\">\n <nas-icon *ngIf=\"option.icon\" [icon]=\"getIcon(option)\" [type]=\"iconType\"></nas-icon>\n <span [nasClass]=\"getClass('text')\" *ngIf=\"!isRounded\">{{option.text}}</span>\n </label>\n <span [nasClass]=\"getClass('text')\" *ngIf=\"isRounded\">{{option.text}}</span>\n </span>\n </div>\n</div>\n</ng-template>\n\n", 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-toggle__items{display:flex;flex-grow:2;perspective:1000px}.nas-toggle__title{font-size:16px;line-height:26px}.nas-toggle .icon-small{display:none;margin-left:-3px;margin-right:9px}@media (min-width: 640px){.nas-toggle .icon-small{display:inline-block}}.nas-toggle__item{transform-origin:center top;transform-style:preserve-3d;-webkit-backface-visibility:hidden;backface-visibility:hidden;animation:flip-in .55s ease both;animation-delay:.42s;-webkit-user-select:none;user-select:none;width:100%}.nas-toggle__item:nth-child(1){animation-delay:60ms}.nas-toggle__item:nth-child(2){animation-delay:.12s}.nas-toggle__item:nth-child(3){animation-delay:.18s}.nas-toggle__item:nth-child(4){animation-delay:.24s}.nas-toggle__item:nth-child(5){animation-delay:.3s}.nas-toggle__item:nth-child(6){animation-delay:.36s}.nas-toggle__item:not(:first-child){margin-left:2px}.nas-toggle__item:not(:last-child){margin-right:2px}.nas-toggle__label{font-family:Apercu,Helvetica Neue,Helvetica,Arial,sans-serif;font-weight:600;font-size:16px;line-height:26px;text-align:center;color:#15273f;white-space:nowrap;cursor:pointer;padding:12px;margin:0;border:3px solid #e3e3e3;background-color:#e3e3e3;transition:transform .15s cubic-bezier(0,0,.1,1)}.nas-toggle__label:hover,.nas-toggle__label:focus{border-color:#15273f}.nas-toggle__label:active{transform:translateY(3px)}.nas-toggle__price{display:block}@media (min-width: 640px){.nas-toggle__price{display:none}}.nas-toggle--compact .nas-toggle__label{font-size:14px;line-height:20px;padding:6px}.nas-toggle--large{align-items:stretch}.nas-toggle--large .icon-small{margin:0}.nas-toggle--large .nas-toggle__label{height:100%;padding:24px;border-color:#fff;background-color:#fff}.nas-toggle--large .nas-toggle__label:hover,.nas-toggle--large .nas-toggle__label:focus{border-color:#15273f}.nas-toggle--large .nas-toggle__item:not(:first-child){margin-left:6px}.nas-toggle--large .nas-toggle__item:not(:last-child){margin-right:6px}.nas-toggle--large .nas-toggle__text{display:block}@media (min-width: 640px){.nas-toggle--large .nas-toggle__price{display:block;margin-bottom:-9px}}.nas-toggle--light .nas-toggle__label{border-color:#fff;background-color:#fff}.nas-toggle--light .nas-toggle__label:hover,.nas-toggle--light .nas-toggle__label:focus{border-color:#15273f}.nas-toggle--grouped{padding-bottom:3px;border-bottom:3px solid #15273f}.nas-toggle--vertical .nas-toggle__items{flex-direction:column;padding-bottom:0;border-bottom:0}.nas-toggle--vertical .nas-toggle__item,.nas-toggle--vertical .nas-toggle__item:not(:first-child),.nas-toggle--vertical .nas-toggle__item:not(:last-child){margin:0 0 3px}.nas-toggle--vertical .nas-toggle__label{padding:9px 24px}.nas-toggle--vertical:not(.nas-toggle--large) .nas-toggle__label{text-align:left;padding:6px 24px}.nas-toggle--rounded .nas-toggle__label{margin:0 auto 6px;padding-top:15px;height:83px;width:83px;border-radius:100%}.nas-toggle--rounded .nas-toggle__label:hover,.nas-toggle--rounded .nas-toggle__label:focus{border-color:#fff;background-color:#fff}.nas-toggle--rounded .nas-toggle__item:not(:first-child){margin-left:12px}.nas-toggle--rounded .nas-toggle__item:not(:last-child){margin-right:12px}.nas-toggle--rounded .nas-toggle__text{display:block;text-align:center}.nas-toggle--big .nas-toggle__label{height:96px;width:96px;padding-top:20px}.nas-toggle--small .nas-toggle__label{padding-top:17px;height:65px;width:65px}.nas-toggle__radio{position:fixed;top:-99px;left:-99px;opacity:0}.nas-toggle__radio:checked~.nas-toggle__label{color:#fff;border-color:#15273f;background-color:#15273f}.nas-toggle__radio:focus~.nas-toggle__label{box-shadow:0 0 1px 2px #e3e3e3,0 0 2px 3px #3b99fc}.nas-toggle__radio:disabled~.nas-toggle__label{opacity:.4;pointer-events:none}.nas-toggle--scrollable .nas-toggle__items{overflow-x:auto;overflow-y:hidden;padding-bottom:20px;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar}.nas-toggle--scrollable .nas-toggle__items::-webkit-scrollbar{height:4px;width:4px}.nas-toggle--scrollable .nas-toggle__items::-webkit-scrollbar-thumb{background:#15273f;border-radius:2px}.nas-toggle--scrollable .nas-toggle__items::-webkit-scrollbar-track-piece:end{margin-right:100px;background:#fff}.nas-toggle--scrollable .nas-toggle__items::-webkit-scrollbar-track-piece:start{margin-left:100px;background:#fff}.nas-toggle--scrollable .nas-toggle__items::-moz-scrollbar{height:4px;width:4px}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.IconComponent, selector: "nas-icon", inputs: ["icon", "type", "isIndicator", "lightCircularBackground", "cssClass"] }, { kind: "directive", type: i3.NasClassDirective, selector: "[nasClass]", inputs: ["nasClass", "attr.class"] }, { kind: "directive", type: i4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i4.RadioControlValueAccessor, selector: "input[type=radio][formControlName],input[type=radio][formControl],input[type=radio][ngModel]", inputs: ["name", "formControlName", "value"] }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i4.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i4.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }] }); }
|
|
73
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.5", type: ToggleComponent, selector: "nas-toggle", inputs: { options: "options", large: "large", compact: "compact", light: "light", rounded: "rounded", small: "small", big: "big", selectedValue: "selectedValue", label: "label", vertical: "vertical", grouped: "grouped", group: "group", nasFormControlName: "nasFormControlName", nasFormGroup: "nasFormGroup", scrollable: "scrollable" }, outputs: { handleChange: "handleChange" }, usesInheritance: true, ngImport: i0, template: "<div [nasClass]=\"mainClasses()\" *ngIf=\"!nasFormControlName; else reactiveForm\">\n <h3 [nasClass]=\"getClass('title')\">{{label}}</h3>\n <div [nasClass]=\"getClass('items')\">\n <span [nasClass]=\"getClass('item')\" *ngFor=\"let option of options\">\n <input [nasClass]=\"getClass('radio')\" [attr.id]=\"getOptionId(option)\" [checked]=\"option.value === selectedValue\" [attr.name]=\"group\" type=\"radio\" [attr.value]=\"option.value\" (change)=\"onChange(option)\">\n <label [nasClass]=\"getClass('label')\" [attr.for]=\"getOptionId(option)\">\n <ng-container *ngIf=\"option?.href; else noLink\">\n <a [nasClass]=\"getClass('link', selectedValue == option.value && 'selected')\" [href]=\"option.href\" (click)=\"onClickHref($event, option)\">\n <nas-icon *ngIf=\"option.icon\" [icon]=\"getIcon(option)\" [type]=\"iconType\"></nas-icon>\n <span [nasClass]=\"getClass('text')\" *ngIf=\"!isRounded\">{{ option.text }}</span>\n </a>\n </ng-container>\n <ng-template #noLink>\n <div [nasClass]=\"getClass('label--content')\">\n <nas-icon *ngIf=\"option.icon\" [icon]=\"getIcon(option)\" [type]=\"iconType\"></nas-icon>\n <span [nasClass]=\"getClass('text')\" *ngIf=\"!isRounded\">{{ option.text }}</span>\n </div>\n </ng-template>\n </label>\n <span [nasClass]=\"getClass('text')\" *ngIf=\"isRounded\">{{option.text}}</span>\n </span>\n </div>\n</div>\n<ng-template #reactiveForm>\n <div [nasClass]=\"mainClasses()\" >\n <h3 [nasClass]=\"getClass('title')\">{{label}}</h3>\n <div [nasClass]=\"getClass('items')\" [formGroup]=\"nasFormGroup\">\n <span [nasClass]=\"getClass('item')\" *ngFor=\"let option of options\">\n <input [formControlName]=\"nasFormControlName\" [nasClass]=\"getClass('radio')\" [attr.id]=\"getOptionId(option)\" [checked]=\"option.value === selectedValue\" [name]=\"group\" type=\"radio\" [value]=\"option.value\" (change)=\"onChange(option)\">\n <label [nasClass]=\"getClass('label')\" [attr.for]=\"getOptionId(option)\">\n <ng-container *ngIf=\"option?.href; else noLink\">\n <a [nasClass]=\"getClass('link', selectedValue == option.value && 'selected')\" [href]=\"option.href\" (click)=\"onClickHref($event, option)\">\n <nas-icon *ngIf=\"option.icon\" [icon]=\"getIcon(option)\" [type]=\"iconType\"></nas-icon>\n <span [nasClass]=\"getClass('text')\" *ngIf=\"!isRounded\">{{ option.text }}</span>\n </a>\n </ng-container>\n <ng-template #noLink>\n <div [nasClass]=\"getClass('label--content')\">\n <nas-icon *ngIf=\"option.icon\" [icon]=\"getIcon(option)\" [type]=\"iconType\"></nas-icon>\n <span [nasClass]=\"getClass('text')\" *ngIf=\"!isRounded\">{{ option.text }}</span>\n </div>\n </ng-template>\n </label>\n <span [nasClass]=\"getClass('text')\" *ngIf=\"isRounded\">{{option.text}}</span>\n </span>\n </div>\n</div>\n</ng-template>\n\n", 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-toggle__items{display:flex;flex-grow:2;perspective:1000px}.nas-toggle__title{font-size:16px;line-height:26px}.nas-toggle .icon-small{display:none;margin-left:-3px;margin-right:9px}@media (min-width: 640px){.nas-toggle .icon-small{display:inline-block}}.nas-toggle__item{transform-origin:center top;transform-style:preserve-3d;-webkit-backface-visibility:hidden;backface-visibility:hidden;animation:flip-in .55s ease both;animation-delay:.42s;-webkit-user-select:none;user-select:none;width:100%}.nas-toggle__item:nth-child(1){animation-delay:60ms}.nas-toggle__item:nth-child(2){animation-delay:.12s}.nas-toggle__item:nth-child(3){animation-delay:.18s}.nas-toggle__item:nth-child(4){animation-delay:.24s}.nas-toggle__item:nth-child(5){animation-delay:.3s}.nas-toggle__item:nth-child(6){animation-delay:.36s}.nas-toggle__item:not(:first-child){margin-left:2px}.nas-toggle__item:not(:last-child){margin-right:2px}.nas-toggle__label{font-family:Apercu,Helvetica Neue,Helvetica,Arial,sans-serif;font-weight:600;font-size:16px;line-height:26px;text-align:center;color:#15273f;white-space:nowrap;cursor:pointer;margin:0;border:3px solid #e3e3e3;background-color:#e3e3e3;transition:transform .15s cubic-bezier(0,0,.1,1)}.nas-toggle__label--content{padding:12px}.nas-toggle__label:hover,.nas-toggle__label:focus{border-color:#15273f}.nas-toggle__label:active{transform:translateY(3px)}.nas-toggle__price{display:block}@media (min-width: 640px){.nas-toggle__price{display:none}}.nas-toggle--compact .nas-toggle__label{font-size:14px;line-height:20px}.nas-toggle--compact .nas-toggle__label--content,.nas-toggle--compact .nas-toggle__link{padding:6px}.nas-toggle--large{align-items:stretch}.nas-toggle--large .icon-small{margin:0}.nas-toggle--large .nas-toggle__label{height:100%;border-color:#fff;background-color:#fff}.nas-toggle--large .nas-toggle__label--content{padding:24px}.nas-toggle--large .nas-toggle__label:hover,.nas-toggle--large .nas-toggle__label:focus{border-color:#15273f}.nas-toggle--large .nas-toggle__item:not(:first-child){margin-left:6px}.nas-toggle--large .nas-toggle__item:not(:last-child){margin-right:6px}.nas-toggle--large .nas-toggle__text{display:block}@media (min-width: 640px){.nas-toggle--large .nas-toggle__price{display:block;margin-bottom:-9px}}.nas-toggle--large .nas-toggle__link{height:100%;display:flex;flex-direction:column;justify-content:center;align-items:center}.nas-toggle--light .nas-toggle__label{border-color:#fff;background-color:#fff}.nas-toggle--light .nas-toggle__label:hover,.nas-toggle--light .nas-toggle__label:focus{border-color:#15273f}.nas-toggle--grouped{padding-bottom:3px;border-bottom:3px solid #15273f}.nas-toggle--vertical .nas-toggle__items{flex-direction:column;padding-bottom:0;border-bottom:0}.nas-toggle--vertical .nas-toggle__item,.nas-toggle--vertical .nas-toggle__item:not(:first-child),.nas-toggle--vertical .nas-toggle__item:not(:last-child){margin:0 0 3px}.nas-toggle--vertical .nas-toggle__label{text-align:left}.nas-toggle--vertical .nas-toggle__label--content,.nas-toggle--vertical .nas-toggle__link{padding:6px 24px}.nas-toggle--rounded .nas-toggle__label{margin:0 auto 6px;height:83px;width:83px;border-radius:100%}.nas-toggle--rounded .nas-toggle__label:hover,.nas-toggle--rounded .nas-toggle__label:focus{border-color:#fff;background-color:#fff}.nas-toggle--rounded .nas-toggle__item:not(:first-child){margin-left:12px}.nas-toggle--rounded .nas-toggle__item:not(:last-child){margin-right:12px}.nas-toggle--rounded .nas-toggle__text{display:block;text-align:center}.nas-toggle--big .nas-toggle__label{height:96px;width:96px;padding-top:9px}.nas-toggle--small .nas-toggle__label{padding-top:6px;height:65px;width:65px}.nas-toggle__radio{position:fixed;top:-99px;left:-99px;opacity:0}.nas-toggle__radio:checked~.nas-toggle__label{color:#fff;border-color:#15273f;background-color:#15273f}.nas-toggle__radio:focus~.nas-toggle__label{box-shadow:0 0 1px 2px #e3e3e3,0 0 2px 3px #3b99fc}.nas-toggle__radio:disabled~.nas-toggle__label{opacity:.4;pointer-events:none}.nas-toggle--scrollable .nas-toggle__items{overflow-x:auto;overflow-y:hidden;padding-bottom:20px;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar}.nas-toggle--scrollable .nas-toggle__items::-webkit-scrollbar{height:4px;width:4px}.nas-toggle--scrollable .nas-toggle__items::-webkit-scrollbar-thumb{background:#15273f;border-radius:2px}.nas-toggle--scrollable .nas-toggle__items::-webkit-scrollbar-track-piece:end{margin-right:100px;background:#fff}.nas-toggle--scrollable .nas-toggle__items::-webkit-scrollbar-track-piece:start{margin-left:100px;background:#fff}.nas-toggle--scrollable .nas-toggle__items::-moz-scrollbar{height:4px;width:4px}.nas-toggle__link{display:block;color:#15273f;border:0;padding:12px}.nas-toggle__link--selected{color:#fff}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.IconComponent, selector: "nas-icon", inputs: ["icon", "type", "isIndicator", "lightCircularBackground", "cssClass"] }, { kind: "directive", type: i3.NasClassDirective, selector: "[nasClass]", inputs: ["nasClass", "attr.class"] }, { kind: "directive", type: i4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i4.RadioControlValueAccessor, selector: "input[type=radio][formControlName],input[type=radio][formControl],input[type=radio][ngModel]", inputs: ["name", "formControlName", "value"] }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i4.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i4.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }] }); }
|
|
66
74
|
}
|
|
67
75
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.5", ngImport: i0, type: ToggleComponent, decorators: [{
|
|
68
76
|
type: Component,
|
|
69
|
-
args: [{ selector: 'nas-toggle', template: "<div [nasClass]=\"mainClasses()\" *ngIf=\"!nasFormControlName; else reactiveForm\">\n <h3 [nasClass]=\"getClass('title')\">{{label}}</h3>\n <div [nasClass]=\"getClass('items')\">\n <span [nasClass]=\"getClass('item')\" *ngFor=\"let option of options\">\n <input [nasClass]=\"getClass('radio')\" [attr.id]=\"getOptionId(option)\" [checked]=\"option.value === selectedValue\" [attr.name]=\"group\" type=\"radio\" [attr.value]=\"option.value\" (change)=\"onChange(option)\">\n <label [nasClass]=\"getClass('label')\" [attr.for]=\"getOptionId(option)\">\n <nas-icon *ngIf=\"option.icon\" [icon]=\"getIcon(option)\" [type]=\"iconType\"></nas-icon>\n <span [nasClass]=\"getClass('text')\" *ngIf=\"!isRounded\">{{option.text}}</span>\n </label>\n <span [nasClass]=\"getClass('text')\" *ngIf=\"isRounded\">{{option.text}}</span>\n </span>\n </div>\n</div>\n<ng-template #reactiveForm>\n <div [nasClass]=\"mainClasses()\" >\n <h3 [nasClass]=\"getClass('title')\">{{label}}</h3>\n <div [nasClass]=\"getClass('items')\" [formGroup]=\"nasFormGroup\">\n <span [nasClass]=\"getClass('item')\" *ngFor=\"let option of options\">\n <input [formControlName]=\"nasFormControlName\" [nasClass]=\"getClass('radio')\" [attr.id]=\"getOptionId(option)\" [checked]=\"option.value === selectedValue\" [name]=\"group\" type=\"radio\" [value]=\"option.value\" (change)=\"onChange(option)\">\n <label [nasClass]=\"getClass('label')\" [attr.for]=\"getOptionId(option)\">\n
|
|
77
|
+
args: [{ selector: 'nas-toggle', template: "<div [nasClass]=\"mainClasses()\" *ngIf=\"!nasFormControlName; else reactiveForm\">\n <h3 [nasClass]=\"getClass('title')\">{{label}}</h3>\n <div [nasClass]=\"getClass('items')\">\n <span [nasClass]=\"getClass('item')\" *ngFor=\"let option of options\">\n <input [nasClass]=\"getClass('radio')\" [attr.id]=\"getOptionId(option)\" [checked]=\"option.value === selectedValue\" [attr.name]=\"group\" type=\"radio\" [attr.value]=\"option.value\" (change)=\"onChange(option)\">\n <label [nasClass]=\"getClass('label')\" [attr.for]=\"getOptionId(option)\">\n <ng-container *ngIf=\"option?.href; else noLink\">\n <a [nasClass]=\"getClass('link', selectedValue == option.value && 'selected')\" [href]=\"option.href\" (click)=\"onClickHref($event, option)\">\n <nas-icon *ngIf=\"option.icon\" [icon]=\"getIcon(option)\" [type]=\"iconType\"></nas-icon>\n <span [nasClass]=\"getClass('text')\" *ngIf=\"!isRounded\">{{ option.text }}</span>\n </a>\n </ng-container>\n <ng-template #noLink>\n <div [nasClass]=\"getClass('label--content')\">\n <nas-icon *ngIf=\"option.icon\" [icon]=\"getIcon(option)\" [type]=\"iconType\"></nas-icon>\n <span [nasClass]=\"getClass('text')\" *ngIf=\"!isRounded\">{{ option.text }}</span>\n </div>\n </ng-template>\n </label>\n <span [nasClass]=\"getClass('text')\" *ngIf=\"isRounded\">{{option.text}}</span>\n </span>\n </div>\n</div>\n<ng-template #reactiveForm>\n <div [nasClass]=\"mainClasses()\" >\n <h3 [nasClass]=\"getClass('title')\">{{label}}</h3>\n <div [nasClass]=\"getClass('items')\" [formGroup]=\"nasFormGroup\">\n <span [nasClass]=\"getClass('item')\" *ngFor=\"let option of options\">\n <input [formControlName]=\"nasFormControlName\" [nasClass]=\"getClass('radio')\" [attr.id]=\"getOptionId(option)\" [checked]=\"option.value === selectedValue\" [name]=\"group\" type=\"radio\" [value]=\"option.value\" (change)=\"onChange(option)\">\n <label [nasClass]=\"getClass('label')\" [attr.for]=\"getOptionId(option)\">\n <ng-container *ngIf=\"option?.href; else noLink\">\n <a [nasClass]=\"getClass('link', selectedValue == option.value && 'selected')\" [href]=\"option.href\" (click)=\"onClickHref($event, option)\">\n <nas-icon *ngIf=\"option.icon\" [icon]=\"getIcon(option)\" [type]=\"iconType\"></nas-icon>\n <span [nasClass]=\"getClass('text')\" *ngIf=\"!isRounded\">{{ option.text }}</span>\n </a>\n </ng-container>\n <ng-template #noLink>\n <div [nasClass]=\"getClass('label--content')\">\n <nas-icon *ngIf=\"option.icon\" [icon]=\"getIcon(option)\" [type]=\"iconType\"></nas-icon>\n <span [nasClass]=\"getClass('text')\" *ngIf=\"!isRounded\">{{ option.text }}</span>\n </div>\n </ng-template>\n </label>\n <span [nasClass]=\"getClass('text')\" *ngIf=\"isRounded\">{{option.text}}</span>\n </span>\n </div>\n</div>\n</ng-template>\n\n", 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-toggle__items{display:flex;flex-grow:2;perspective:1000px}.nas-toggle__title{font-size:16px;line-height:26px}.nas-toggle .icon-small{display:none;margin-left:-3px;margin-right:9px}@media (min-width: 640px){.nas-toggle .icon-small{display:inline-block}}.nas-toggle__item{transform-origin:center top;transform-style:preserve-3d;-webkit-backface-visibility:hidden;backface-visibility:hidden;animation:flip-in .55s ease both;animation-delay:.42s;-webkit-user-select:none;user-select:none;width:100%}.nas-toggle__item:nth-child(1){animation-delay:60ms}.nas-toggle__item:nth-child(2){animation-delay:.12s}.nas-toggle__item:nth-child(3){animation-delay:.18s}.nas-toggle__item:nth-child(4){animation-delay:.24s}.nas-toggle__item:nth-child(5){animation-delay:.3s}.nas-toggle__item:nth-child(6){animation-delay:.36s}.nas-toggle__item:not(:first-child){margin-left:2px}.nas-toggle__item:not(:last-child){margin-right:2px}.nas-toggle__label{font-family:Apercu,Helvetica Neue,Helvetica,Arial,sans-serif;font-weight:600;font-size:16px;line-height:26px;text-align:center;color:#15273f;white-space:nowrap;cursor:pointer;margin:0;border:3px solid #e3e3e3;background-color:#e3e3e3;transition:transform .15s cubic-bezier(0,0,.1,1)}.nas-toggle__label--content{padding:12px}.nas-toggle__label:hover,.nas-toggle__label:focus{border-color:#15273f}.nas-toggle__label:active{transform:translateY(3px)}.nas-toggle__price{display:block}@media (min-width: 640px){.nas-toggle__price{display:none}}.nas-toggle--compact .nas-toggle__label{font-size:14px;line-height:20px}.nas-toggle--compact .nas-toggle__label--content,.nas-toggle--compact .nas-toggle__link{padding:6px}.nas-toggle--large{align-items:stretch}.nas-toggle--large .icon-small{margin:0}.nas-toggle--large .nas-toggle__label{height:100%;border-color:#fff;background-color:#fff}.nas-toggle--large .nas-toggle__label--content{padding:24px}.nas-toggle--large .nas-toggle__label:hover,.nas-toggle--large .nas-toggle__label:focus{border-color:#15273f}.nas-toggle--large .nas-toggle__item:not(:first-child){margin-left:6px}.nas-toggle--large .nas-toggle__item:not(:last-child){margin-right:6px}.nas-toggle--large .nas-toggle__text{display:block}@media (min-width: 640px){.nas-toggle--large .nas-toggle__price{display:block;margin-bottom:-9px}}.nas-toggle--large .nas-toggle__link{height:100%;display:flex;flex-direction:column;justify-content:center;align-items:center}.nas-toggle--light .nas-toggle__label{border-color:#fff;background-color:#fff}.nas-toggle--light .nas-toggle__label:hover,.nas-toggle--light .nas-toggle__label:focus{border-color:#15273f}.nas-toggle--grouped{padding-bottom:3px;border-bottom:3px solid #15273f}.nas-toggle--vertical .nas-toggle__items{flex-direction:column;padding-bottom:0;border-bottom:0}.nas-toggle--vertical .nas-toggle__item,.nas-toggle--vertical .nas-toggle__item:not(:first-child),.nas-toggle--vertical .nas-toggle__item:not(:last-child){margin:0 0 3px}.nas-toggle--vertical .nas-toggle__label{text-align:left}.nas-toggle--vertical .nas-toggle__label--content,.nas-toggle--vertical .nas-toggle__link{padding:6px 24px}.nas-toggle--rounded .nas-toggle__label{margin:0 auto 6px;height:83px;width:83px;border-radius:100%}.nas-toggle--rounded .nas-toggle__label:hover,.nas-toggle--rounded .nas-toggle__label:focus{border-color:#fff;background-color:#fff}.nas-toggle--rounded .nas-toggle__item:not(:first-child){margin-left:12px}.nas-toggle--rounded .nas-toggle__item:not(:last-child){margin-right:12px}.nas-toggle--rounded .nas-toggle__text{display:block;text-align:center}.nas-toggle--big .nas-toggle__label{height:96px;width:96px;padding-top:9px}.nas-toggle--small .nas-toggle__label{padding-top:6px;height:65px;width:65px}.nas-toggle__radio{position:fixed;top:-99px;left:-99px;opacity:0}.nas-toggle__radio:checked~.nas-toggle__label{color:#fff;border-color:#15273f;background-color:#15273f}.nas-toggle__radio:focus~.nas-toggle__label{box-shadow:0 0 1px 2px #e3e3e3,0 0 2px 3px #3b99fc}.nas-toggle__radio:disabled~.nas-toggle__label{opacity:.4;pointer-events:none}.nas-toggle--scrollable .nas-toggle__items{overflow-x:auto;overflow-y:hidden;padding-bottom:20px;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar}.nas-toggle--scrollable .nas-toggle__items::-webkit-scrollbar{height:4px;width:4px}.nas-toggle--scrollable .nas-toggle__items::-webkit-scrollbar-thumb{background:#15273f;border-radius:2px}.nas-toggle--scrollable .nas-toggle__items::-webkit-scrollbar-track-piece:end{margin-right:100px;background:#fff}.nas-toggle--scrollable .nas-toggle__items::-webkit-scrollbar-track-piece:start{margin-left:100px;background:#fff}.nas-toggle--scrollable .nas-toggle__items::-moz-scrollbar{height:4px;width:4px}.nas-toggle__link{display:block;color:#15273f;border:0;padding:12px}.nas-toggle__link--selected{color:#fff}\n"] }]
|
|
70
78
|
}], ctorParameters: function () { return []; }, propDecorators: { options: [{
|
|
71
79
|
type: Input
|
|
72
80
|
}], large: [{
|
|
@@ -100,4 +108,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.5", ngImpor
|
|
|
100
108
|
}], scrollable: [{
|
|
101
109
|
type: Input
|
|
102
110
|
}] } });
|
|
103
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toggle.component.js","sourceRoot":"","sources":["../../../../../../projects/core-components/src/lib/components/toggle/toggle.component.ts","../../../../../../projects/core-components/src/lib/components/toggle/toggle.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, EventEmitter, Input, Output } from '@angular/core';\n\nimport { FormGroup } from '@angular/forms';\nimport { OptionModel } from './models/options.model';\nimport { NasComponentBase } from '../../core/base/nas-component.base';\n\n/**\n * @description\n * Norwegian Toogle Component | Buttons and Indicators\n*/\n@Component({\n  selector: 'nas-toggle',\n  templateUrl: './toggle.component.html',\n  styleUrls: ['./toggle.component.scss']\n})\nexport class ToggleComponent extends NasComponentBase implements OnInit {\n\n  /**\n   * @property Input\n   * @description\n   * Toggle options.\n   * @example\n   * <nas-toggle [options]=\"options\"></nas-toggle>\n  */\n  @Input() options: Array<OptionModel>;\n\n  /**\n   * @property Input\n   * @description\n   * Set icon size large.\n   * @example\n   * <nas-toggle large></nas-toggle>\n   * or\n   * <nas-toggle [large]=\"true\"></nas-toggle>\n  */\n  @Input() large?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Set compact styling.\n   * @example\n   * <nas-toggle compact></nas-toggle>\n   * or\n   * <nas-toggle [compact]=\"true\"></nas-toggle>\n  */\n  @Input() compact?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Set light styling.\n   * @example\n   * <nas-toggle light></nas-toggle>\n   * or\n   * <nas-toggle [light]=\"true\"></nas-toggle>\n  */\n  @Input() light?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Set rounded styling.\n   * @example\n   * <nas-toggle rounded></nas-toggle>\n   * or\n   * <nas-toggle [rounded]=\"true\"></nas-toggle>\n  */\n  @Input() rounded?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Set small size of rounded styling.\n   * @example\n   * <nas-toggle rounded small></nas-toggle>\n   * or\n   * <nas-toggle [rounded]=\"true\" [small]=\"true\"></nas-toggle>\n  */\n  @Input() small?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Set big size of rounded styling.\n   * @example\n   * <nas-toggle rounded big></nas-toggle>\n   * or\n   * <nas-toggle [rounded]=\"true\" [big]=\"true\"></nas-toggle>\n  */\n  @Input() big?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Set the selected option.\n   * @example\n   * <nas-toggle [selectedValue]=\"selectedValue\"></nas-toggle>\n  */\n  @Input() selectedValue: string;\n\n  /**\n   * @property Input\n   * @description\n   * The label for toggle.\n   * @example\n   * <nas-toggle [label]=\"'Toggle label'\"></nas-toggle>\n  */\n  @Input() label: string;\n\n  /**\n   * @property Input\n   * @description\n   * Set vertical styling.\n   * @example\n   * <nas-toggle vertical></nas-toggle>\n   * or\n   * <nas-toggle [vertical]=\"true\"></nas-toggle>\n  */\n  @Input() vertical?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Set grouped styling.\n   * @example\n   * <nas-toggle grouped></nas-toggle>\n   * or\n   * <nas-toggle [grouped]=\"true\"></nas-toggle>\n  */\n  @Input() grouped?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Toggle group name.\n   * @example\n   * <nas-toggle [group]=\"'Group name'\"></nas-toggle>\n  */\n  @Input() group: string;\n\n  /**\n   * @property Output\n   * @description\n   * An event that is fired every time a toggle is performed.\n   * @example\n   * <nas-toggle (handleChange)=\"onHandleChange($event)\"></nas-toggle>\n  */\n  @Output() handleChange = new EventEmitter<OptionModel>();\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   * @example\n   * <nas-toggle [nasFormControlName]=\"'summer'\"></nas-toggle>\n  */\n  @Input() nasFormControlName: string;\n\n  /**\n   * @property Input\n   * @description\n   * Adds the parent's form group.\n   * It requires that the consumer included ReactiveFormsModule in it's module.\n   * It is requiered to be filled if nasFormControlName added.\n   * @example\n   * <nas-toggle [nasFormGroup]=\"formGroup\"></nas-toggle>\n  */\n  @Input() nasFormGroup: FormGroup;\n\n  /**\n   * @property Input\n   * @description\n   * To set horizontal scroll.\n   * @example\n   * <nas-toggle scrollable></nas-toggle>\n  */\n  @Input() scrollable = false;\n\n  iconType: string;\n\n  isRounded: boolean;\n\n  constructor() {\n    super('nas-toggle');\n  }\n\n  ngOnInit(): void {\n    this.iconType = this.exists(this.rounded) && this.exists(this.small) ? 'small' :\n      this.exists(this.large) || this.exists(this.rounded) ? 'medium' : 'small';\n    this.isRounded = this.exists(this.rounded) ? true : false;\n  }\n\n  getIcon(option: OptionModel): string {\n    if (this.selectedValue != null && option.value === this.selectedValue) {\n      return option.icon + '--light';\n    }\n    return option.icon;\n  }\n\n  getOptionId(option: OptionModel): string {\n    return this.group + '-' + option.name;\n  }\n\n  onChange(option: OptionModel) {\n    const selectedOption = this.options.find(x => x.value === option.value);\n    this.selectedValue = selectedOption.value;\n    this.handleChange.emit(selectedOption);\n  }\n\n  mainClasses() {\n    return this.getClass('', [\n      this.exists(this.large) && 'large',\n      this.exists(this.compact) && 'compact',\n      this.exists(this.light) && 'light',\n      this.exists(this.vertical) && 'vertical',\n      this.exists(this.grouped) && 'grouped',\n      this.exists(this.rounded) && 'rounded',\n      this.exists(this.big) && 'big',\n      this.exists(this.small) && 'small',\n      this.exists(this.scrollable) && 'scrollable'\n    ]);\n  }\n}\n","<div [nasClass]=\"mainClasses()\" *ngIf=\"!nasFormControlName; else reactiveForm\">\n  <h3 [nasClass]=\"getClass('title')\">{{label}}</h3>\n  <div [nasClass]=\"getClass('items')\">\n    <span [nasClass]=\"getClass('item')\" *ngFor=\"let option of options\">\n      <input [nasClass]=\"getClass('radio')\" [attr.id]=\"getOptionId(option)\" [checked]=\"option.value === selectedValue\" [attr.name]=\"group\" type=\"radio\" [attr.value]=\"option.value\" (change)=\"onChange(option)\">\n      <label [nasClass]=\"getClass('label')\" [attr.for]=\"getOptionId(option)\">\n        <nas-icon *ngIf=\"option.icon\" [icon]=\"getIcon(option)\" [type]=\"iconType\"></nas-icon>\n        <span [nasClass]=\"getClass('text')\" *ngIf=\"!isRounded\">{{option.text}}</span>\n      </label>\n      <span [nasClass]=\"getClass('text')\" *ngIf=\"isRounded\">{{option.text}}</span>\n    </span>\n  </div>\n</div>\n<ng-template #reactiveForm>\n  <div [nasClass]=\"mainClasses()\" >\n  <h3 [nasClass]=\"getClass('title')\">{{label}}</h3>\n  <div [nasClass]=\"getClass('items')\" [formGroup]=\"nasFormGroup\">\n    <span [nasClass]=\"getClass('item')\" *ngFor=\"let option of options\">\n      <input [formControlName]=\"nasFormControlName\" [nasClass]=\"getClass('radio')\" [attr.id]=\"getOptionId(option)\" [checked]=\"option.value === selectedValue\" [name]=\"group\" type=\"radio\" [value]=\"option.value\" (change)=\"onChange(option)\">\n      <label [nasClass]=\"getClass('label')\" [attr.for]=\"getOptionId(option)\">\n        <nas-icon *ngIf=\"option.icon\" [icon]=\"getIcon(option)\" [type]=\"iconType\"></nas-icon>\n        <span [nasClass]=\"getClass('text')\" *ngIf=\"!isRounded\">{{option.text}}</span>\n      </label>\n      <span [nasClass]=\"getClass('text')\" *ngIf=\"isRounded\">{{option.text}}</span>\n    </span>\n  </div>\n</div>\n</ng-template>\n\n"]}
|
|
111
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toggle.component.js","sourceRoot":"","sources":["../../../../../../projects/core-components/src/lib/components/toggle/toggle.component.ts","../../../../../../projects/core-components/src/lib/components/toggle/toggle.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, EventEmitter, Input, Output } from '@angular/core';\n\nimport { FormGroup } from '@angular/forms';\nimport { OptionModel } from './models/options.model';\nimport { NasComponentBase } from '../../core/base/nas-component.base';\n\n/**\n * @description\n * Norwegian Toogle Component | Buttons and Indicators\n*/\n@Component({\n  selector: 'nas-toggle',\n  templateUrl: './toggle.component.html',\n  styleUrls: ['./toggle.component.scss']\n})\nexport class ToggleComponent extends NasComponentBase implements OnInit {\n\n  /**\n   * @property Input\n   * @description\n   * Toggle options.\n   * @example\n   * <nas-toggle [options]=\"options\"></nas-toggle>\n  */\n  @Input() options: Array<OptionModel>;\n\n  /**\n   * @property Input\n   * @description\n   * Set icon size large.\n   * @example\n   * <nas-toggle large></nas-toggle>\n   * or\n   * <nas-toggle [large]=\"true\"></nas-toggle>\n  */\n  @Input() large?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Set compact styling.\n   * @example\n   * <nas-toggle compact></nas-toggle>\n   * or\n   * <nas-toggle [compact]=\"true\"></nas-toggle>\n  */\n  @Input() compact?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Set light styling.\n   * @example\n   * <nas-toggle light></nas-toggle>\n   * or\n   * <nas-toggle [light]=\"true\"></nas-toggle>\n  */\n  @Input() light?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Set rounded styling.\n   * @example\n   * <nas-toggle rounded></nas-toggle>\n   * or\n   * <nas-toggle [rounded]=\"true\"></nas-toggle>\n  */\n  @Input() rounded?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Set small size of rounded styling.\n   * @example\n   * <nas-toggle rounded small></nas-toggle>\n   * or\n   * <nas-toggle [rounded]=\"true\" [small]=\"true\"></nas-toggle>\n  */\n  @Input() small?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Set big size of rounded styling.\n   * @example\n   * <nas-toggle rounded big></nas-toggle>\n   * or\n   * <nas-toggle [rounded]=\"true\" [big]=\"true\"></nas-toggle>\n  */\n  @Input() big?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Set the selected option.\n   * @example\n   * <nas-toggle [selectedValue]=\"selectedValue\"></nas-toggle>\n  */\n  @Input() selectedValue: string;\n\n  /**\n   * @property Input\n   * @description\n   * The label for toggle.\n   * @example\n   * <nas-toggle [label]=\"'Toggle label'\"></nas-toggle>\n  */\n  @Input() label: string;\n\n  /**\n   * @property Input\n   * @description\n   * Set vertical styling.\n   * @example\n   * <nas-toggle vertical></nas-toggle>\n   * or\n   * <nas-toggle [vertical]=\"true\"></nas-toggle>\n  */\n  @Input() vertical?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Set grouped styling.\n   * @example\n   * <nas-toggle grouped></nas-toggle>\n   * or\n   * <nas-toggle [grouped]=\"true\"></nas-toggle>\n  */\n  @Input() grouped?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Toggle group name.\n   * @example\n   * <nas-toggle [group]=\"'Group name'\"></nas-toggle>\n  */\n  @Input() group: string;\n\n  /**\n   * @property Output\n   * @description\n   * An event that is fired every time a toggle is performed.\n   * @example\n   * <nas-toggle (handleChange)=\"onHandleChange($event)\"></nas-toggle>\n  */\n  @Output() handleChange = new EventEmitter<OptionModel>();\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   * @example\n   * <nas-toggle [nasFormControlName]=\"'summer'\"></nas-toggle>\n  */\n  @Input() nasFormControlName: string;\n\n  /**\n   * @property Input\n   * @description\n   * Adds the parent's form group.\n   * It requires that the consumer included ReactiveFormsModule in it's module.\n   * It is requiered to be filled if nasFormControlName added.\n   * @example\n   * <nas-toggle [nasFormGroup]=\"formGroup\"></nas-toggle>\n  */\n  @Input() nasFormGroup: FormGroup;\n\n  /**\n   * @property Input\n   * @description\n   * To set horizontal scroll.\n   * @example\n   * <nas-toggle scrollable></nas-toggle>\n  */\n  @Input() scrollable = false;\n\n  iconType: string;\n\n  isRounded: boolean;\n\n  constructor() {\n    super('nas-toggle');\n  }\n\n  ngOnInit(): void {\n    this.iconType = this.exists(this.rounded) && this.exists(this.small) ? 'small' :\n      this.exists(this.large) || this.exists(this.rounded) ? 'medium' : 'small';\n    this.isRounded = this.exists(this.rounded) ? true : false;\n  }\n\n  getIcon(option: OptionModel): string {\n    if (this.selectedValue != null && option.value === this.selectedValue) {\n      return option.icon + '--light';\n    }\n    return option.icon;\n  }\n\n  getOptionId(option: OptionModel): string {\n    return this.group + '-' + option.name;\n  }\n\n  onChange(option: OptionModel) {\n    const selectedOption = this.options.find(x => x.value === option.value);\n    this.selectedValue = selectedOption.value;\n    this.handleChange.emit(selectedOption);\n  }\n\n  mainClasses() {\n    return this.getClass('', [\n      this.exists(this.large) && 'large',\n      this.exists(this.compact) && 'compact',\n      this.exists(this.light) && 'light',\n      this.exists(this.vertical) && 'vertical',\n      this.exists(this.grouped) && 'grouped',\n      this.exists(this.rounded) && 'rounded',\n      this.exists(this.big) && 'big',\n      this.exists(this.small) && 'small',\n      this.exists(this.scrollable) && 'scrollable'\n    ]);\n  }\n\n  onClickHref(event: MouseEvent, option: OptionModel): void {\n    if(option?.href == null || option?.href == '') {\n      return;\n    }\n    \n    event.preventDefault();\n    this.onChange(option);\n    history.pushState(null, '', option.href);\n  }\n}\n","<div [nasClass]=\"mainClasses()\" *ngIf=\"!nasFormControlName; else reactiveForm\">\n  <h3 [nasClass]=\"getClass('title')\">{{label}}</h3>\n  <div [nasClass]=\"getClass('items')\">\n    <span [nasClass]=\"getClass('item')\" *ngFor=\"let option of options\">\n      <input [nasClass]=\"getClass('radio')\" [attr.id]=\"getOptionId(option)\" [checked]=\"option.value === selectedValue\" [attr.name]=\"group\" type=\"radio\" [attr.value]=\"option.value\" (change)=\"onChange(option)\">\n      <label [nasClass]=\"getClass('label')\" [attr.for]=\"getOptionId(option)\">\n        <ng-container *ngIf=\"option?.href; else noLink\">\n          <a [nasClass]=\"getClass('link', selectedValue == option.value && 'selected')\" [href]=\"option.href\" (click)=\"onClickHref($event, option)\">\n            <nas-icon *ngIf=\"option.icon\" [icon]=\"getIcon(option)\" [type]=\"iconType\"></nas-icon>\n            <span [nasClass]=\"getClass('text')\" *ngIf=\"!isRounded\">{{ option.text }}</span>\n          </a>\n        </ng-container>\n        <ng-template #noLink>\n          <div [nasClass]=\"getClass('label--content')\">\n             <nas-icon *ngIf=\"option.icon\" [icon]=\"getIcon(option)\" [type]=\"iconType\"></nas-icon>\n              <span [nasClass]=\"getClass('text')\" *ngIf=\"!isRounded\">{{ option.text }}</span>\n          </div>\n        </ng-template>\n      </label>\n      <span [nasClass]=\"getClass('text')\" *ngIf=\"isRounded\">{{option.text}}</span>\n    </span>\n  </div>\n</div>\n<ng-template #reactiveForm>\n  <div [nasClass]=\"mainClasses()\" >\n  <h3 [nasClass]=\"getClass('title')\">{{label}}</h3>\n  <div [nasClass]=\"getClass('items')\" [formGroup]=\"nasFormGroup\">\n    <span [nasClass]=\"getClass('item')\" *ngFor=\"let option of options\">\n      <input [formControlName]=\"nasFormControlName\" [nasClass]=\"getClass('radio')\" [attr.id]=\"getOptionId(option)\" [checked]=\"option.value === selectedValue\" [name]=\"group\" type=\"radio\" [value]=\"option.value\" (change)=\"onChange(option)\">\n      <label [nasClass]=\"getClass('label')\" [attr.for]=\"getOptionId(option)\">\n         <ng-container *ngIf=\"option?.href; else noLink\">\n          <a [nasClass]=\"getClass('link', selectedValue == option.value && 'selected')\" [href]=\"option.href\" (click)=\"onClickHref($event, option)\">\n            <nas-icon *ngIf=\"option.icon\" [icon]=\"getIcon(option)\" [type]=\"iconType\"></nas-icon>\n            <span [nasClass]=\"getClass('text')\" *ngIf=\"!isRounded\">{{ option.text }}</span>\n          </a>\n        </ng-container>\n        <ng-template #noLink>\n          <div [nasClass]=\"getClass('label--content')\">\n             <nas-icon *ngIf=\"option.icon\" [icon]=\"getIcon(option)\" [type]=\"iconType\"></nas-icon>\n              <span [nasClass]=\"getClass('text')\" *ngIf=\"!isRounded\">{{ option.text }}</span>\n          </div>\n        </ng-template>\n      </label>\n      <span [nasClass]=\"getClass('text')\" *ngIf=\"isRounded\">{{option.text}}</span>\n    </span>\n  </div>\n</div>\n</ng-template>\n\n"]}
|