@norwegian/core-components 6.26.0 → 6.27.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.
|
@@ -108,8 +108,10 @@ export class SelectComponent extends NasComponentBase {
|
|
|
108
108
|
}
|
|
109
109
|
return;
|
|
110
110
|
}
|
|
111
|
-
if (this.selectedValue) {
|
|
111
|
+
if (this.selectedValue && this.selectedValue.value !== this.selectControl.value) {
|
|
112
112
|
this.selectControl.setValue(this.selectedValue.value);
|
|
113
|
+
}
|
|
114
|
+
if (this.selectedValue) {
|
|
113
115
|
this.setSelectedTitle(this.selectedValue);
|
|
114
116
|
}
|
|
115
117
|
}
|
|
@@ -355,4 +357,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.5", ngImpor
|
|
|
355
357
|
}], keydown: [{
|
|
356
358
|
type: Output
|
|
357
359
|
}], setSelectedAndEmitChange: [] } });
|
|
358
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../../../projects/core-components/src/lib/components/select/select.component.ts","../../../../../../projects/core-components/src/lib/components/select/select.component.html"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Norwegian Air Shuttle. All Rights Reserved.\n */\n\nimport {\n  Component,\n  Input,\n  Output,\n  EventEmitter,\n  ViewEncapsulation,\n  ElementRef,\n  ViewChild,\n  ChangeDetectorRef,\n  OnChanges,\n  ContentChildren,\n  QueryList,\n  AfterContentInit,\n  AfterViewChecked,\n} from '@angular/core';\nimport { FormControl, FormGroup } from '@angular/forms';\n\nimport { NasComponentBase } from '../../core';\nimport { ClassModel } from '../../core/models';\nimport { SelectOptionModel } from './models/select-option.model';\nimport { OptionComponent } from './option/option.component';\nimport { OptgroupComponent } from './optgroup/optgroup.component';\nimport { Debounce } from '../../core/decorators/debounce.decorator';\n\nlet nextId = 0;\n\n/**\n * @description\n * Norwegian Select Component | Form Controls\n */\n@Component({\n  selector: 'nas-select',\n  templateUrl: './select.component.html',\n  styleUrls: ['./select.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class SelectComponent extends NasComponentBase implements OnChanges, AfterViewChecked, AfterContentInit {\n  selectControl = new FormControl();\n  labelWidth: number;\n  selectTitle: string;\n  hasContent = false;\n\n  @ViewChild('selectTitleWrapper', { static: true }) selectTitleWrapper: ElementRef;\n  @ViewChild('errorMessageWrapper') errorMessageWrapper: ElementRef;\n  @ViewChild('select') select: ElementRef<HTMLSelectElement>;\n  @ContentChildren(OptionComponent) optionComponents: QueryList<OptionComponent>;\n  @ContentChildren(OptgroupComponent) optgroupComponents: QueryList<OptgroupComponent>;\n\n  private optionsValue: Array<SelectOptionModel>;\n\n  /**\n   * @property Input\n   * @description\n   * The ID of the native input element\n  */\n  @Input() id: string;\n\n  /**\n   * @property Input\n   * @description\n   * Add custom inline styling.\n  */\n  @Input() inline?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Add custom label styling.\n  */\n  @Input() label: string;\n\n  /**\n   * @property Input\n   * @description\n   * Sets block styling.\n  */\n  @Input() block?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Sets spaceless styling.\n  */\n  @Input() spaceless?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Sets stretch styling.\n  */\n  @Input() stretch?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Sets compact styling.\n  */\n  @Input() compact?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Sets simple styling.\n  */\n  @Input() simple?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Sets light styling.\n  */\n  @Input() light?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Sets fill styling.\n  */\n  @Input() fill?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Sets error styling.\n  */\n  @Input() error?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * The error message to display when error occur. Error attribute need to be true.\n  */\n  @Input() errorMessage?: string;\n\n  /**\n   * @property Input\n   * @description\n   * Sets disabled styling.\n  */\n  @Input() disabled?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Makes the select component autogrow.\n  */\n  @Input() autogrow?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Add custom CSS class to the selector.\n  */\n  @Input() cssClass: ClassModel;\n\n  /**\n   * @property Input\n   * @description\n   * Sets a formControlName directive to the select.\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-select [nasFormControlName]=\"'fareClass'\"></nas-select>\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-select [nasFormGroup]=\"classGroup\"></nas-select>\n  */\n  @Input() nasFormGroup: FormGroup;\n\n  /**\n   * @property Input\n   * @description\n   * Add options to the selector.\n  */\n  @Input()\n  public get options(): Array<SelectOptionModel> {\n    return this.optionsValue;\n  }\n  public set options(value: Array<SelectOptionModel>) {\n    this.optionsValue = value;\n\n    if (this.options && this.options.length > 0 && !this.selected) {\n      const option = this.options[0];\n\n      this.setSelectedTitle(option);\n\n      if (this.selectedValue === option) {\n        return;\n      }\n\n      this.selectedValue = option;\n      this.selectControl.setValue(this.selectedValue.value);\n    }\n  }\n\n  /**\n   * @property Input\n   * @description\n   * The default selected value.\n  */\n  @Input() selectedValue: SelectOptionModel;\n\n  /**\n   * @property Input\n   * @description\n   * Gets or sets the selected value.\n  */\n  @Input()\n  get selected(): SelectOptionModel {\n    return this.selectedValue;\n  }\n  set selected(option: SelectOptionModel) {\n    if (!option) {\n      return;\n    }\n\n    this.setSelectedTitle(option);\n\n    if (this.selectedValue === option) {\n      return;\n    }\n\n    this.selectedValue = option;\n    this.selectControl.setValue(this.selectedValue.value);\n  }\n\n  /**\n   * @property Output\n   * @description\n   * An event that is fired every time a selection is done.\n  */\n  @Output() selectedChange = new EventEmitter<SelectOptionModel>();\n\n  /**\n   * @property Output\n   * @description\n   * An events that fires every type a keydown event has been pressed on the select element.\n  */\n  @Output() keydown = new EventEmitter<KeyboardEvent>();\n\n  private open = false;\n  private componentId: number;\n\n  constructor(private change: ChangeDetectorRef) {\n    super('nas-select');\n    this.componentId = nextId++;\n  }\n\n  ngOnChanges() {\n    if (this.selectedValue) {\n      this.selectControl.setValue(this.selectedValue.value);\n    }\n  }\n\n  ngAfterContentInit(): void {\n    if (this.optionComponents && this.optionComponents.length > 0\n      || this.optgroupComponents && this.optgroupComponents.length > 0) {\n      this.hasContent = true;\n    }\n\n    if (this.selectedValue) {\n      return;\n    }\n\n    if (this.optionComponents && this.optionComponents.length > 0) {\n      this.setFirstOptionSelected(this.optionComponents);\n    } else if (this.optgroupComponents && this.optgroupComponents.length > 0) {\n      const firstOptgroupComponent = this.optgroupComponents.first;\n\n      if (firstOptgroupComponent) {\n        this.setFirstOptionSelected(firstOptgroupComponent.optionComponents);\n      }\n    }\n  }\n\n  ngAfterViewChecked() {\n    if (!this.hasContent && !this.selectedValue) {\n      if (this.options && this.options.length > 0) {\n        this.setSelectedTitle(this.options[0]);\n      }\n      return;\n    }\n\n    if (this.selectedValue) {\n      this.selectControl.setValue(this.selectedValue.value);\n      this.setSelectedTitle(this.selectedValue);\n    }\n  }\n\n  getSelectId(): string {\n    return `nas-select-${this.componentId}`;\n  }\n\n  get selectId(): string {\n    return this.id ? this.id : `nas-select-${this.componentId}`;\n  }\n\n  get errorId(): string {\n    return this.id ? this.id + '__error' : `nas-select-${this.componentId}__error`;\n  }\n\n  toggleSelect(event: any, keydown?: boolean): void {\n    if ((event && event.key === 'Enter') || !event || !event.key) {\n      this.open = !this.open;\n\n      if (keydown) {\n        this.keydown.emit(event);\n      }\n\n      if (!event) {\n        return;\n      }\n\n      const target = event.target;\n\n      if (this.options) {\n        const selected = this.options.find(x => x.value === target.value);\n        if (selected && (!this.selected || selected.value !== this.selected.value)) {\n          this.setSelectedAndEmitChange(selected);\n        }\n      }\n\n      if (this.optionComponents && this.optionComponents.length > 0) {\n        const selected = this.optionComponents.find(x => x.option.value === target.value);\n        if (selected && (!this.selected || selected.option.value !== this.selected.value)) {\n          this.setSelectedAndEmitChange(selected.option);\n          return;\n        }\n      }\n\n      if (this.optgroupComponents && this.optgroupComponents.length > 0) {\n        this.optgroupComponents.forEach(optgroupComponent => {\n          if (optgroupComponent.optionComponents) {\n            const selected = optgroupComponent.optionComponents.find(x => x.option.value === target.value);\n            if (selected && (!this.selected || selected.option.value !== this.selected.value)) {\n              this.setSelectedAndEmitChange(selected.option);\n              return;\n            }\n          }\n        });\n      }\n\n      this.updateShadow(target, target.value);\n    }\n  }\n\n  blurSelect(): void {\n    this.open = false;\n  }\n\n  getClasses(): Array<ClassModel> {\n    const classes: Array<ClassModel> = [\n      this.getClass('', [\n        this.label,\n        this.exists(this.inline) && 'inline',\n        this.exists(this.block) && 'block',\n        this.exists(this.spaceless) && 'spaceless',\n        this.exists(this.stretch) && 'stretch',\n        this.exists(this.compact) && 'compact',\n        this.exists(this.simple) && 'simple',\n        this.exists(this.light) && 'light',\n        this.exists(this.fill) && 'fill',\n        this.exists(this.error) && 'error',\n        this.exists(this.disabled) && 'disabled',\n        this.open && 'rotate'\n      ])\n    ];\n\n    if (this.cssClass) {\n      classes.push(this.cssClass);\n    }\n\n    return classes;\n  }\n\n  @Debounce(150)\n  private setSelectedAndEmitChange(selected: SelectOptionModel): void {\n    if (!selected) {\n      return;\n    }\n\n    if (this.selected !== selected) {\n      this.selectedChange.emit(selected);\n    }\n\n    this.selected = selected;\n  }\n\n  private setFirstOptionSelected(optionComponents: QueryList<OptionComponent>): void {\n    if (!optionComponents || optionComponents.length <= 0) {\n      return;\n    }\n\n    const firstOptionComponent = optionComponents.first;\n\n    if (firstOptionComponent) {\n      this.selectedValue = firstOptionComponent.option;\n      this.setSelectedTitle(this.selectedValue);\n    }\n  }\n\n  private updateShadow(target: any, targetValue: string) {\n    if (this.label || this.block || !this.autogrow || !target) {\n      return;\n    }\n\n    let value: string;\n\n    if (target.selectedOptions && target.selectedOptions.length) {\n      value = target.selectedOptions[0].innerHTML;\n    } else {\n      value = targetValue;\n    }\n\n    const shadow = document.createElement('select');\n    const computedStyle = window.getComputedStyle(target);\n    shadow.style.position = 'absolute';\n    shadow.style.top = '-1000px';\n    shadow.style.left = '-1000px';\n    shadow.style.width = 'auto';\n    shadow.style.maxWidth = 'none';\n    shadow.style.fontSize = computedStyle.getPropertyValue('font-size');\n    shadow.style.fontFamily = computedStyle.getPropertyValue('font-family');\n    shadow.style.fontWeight = computedStyle.getPropertyValue('font-weight');\n    shadow.style.letterSpacing = computedStyle.getPropertyValue('letter-spacing');\n    shadow.style.paddingTop = computedStyle.getPropertyValue('padding-top');\n    shadow.style.paddingRight = computedStyle.getPropertyValue('padding-right');\n    shadow.style.paddingBottom = computedStyle.getPropertyValue('padding-bottom');\n    shadow.style.paddingLeft = computedStyle.getPropertyValue('padding-left');\n    shadow.style.borderTop = computedStyle.getPropertyValue('border-top');\n    shadow.style.borderRight = computedStyle.getPropertyValue('border-right');\n    shadow.style.borderBottom = computedStyle.getPropertyValue('border-bottom');\n    shadow.style.borderLeft = computedStyle.getPropertyValue('border-left');\n\n    const option = document.createElement('option');\n    option.value = value;\n    option.innerHTML = value;\n    shadow.appendChild(option);\n\n    target.style.width = `${shadow.offsetWidth + 6}px`;\n  }\n\n  private setSelectedTitle(option: SelectOptionModel): void {\n    const selectTitleWrapper = this.selectTitleWrapper.nativeElement as HTMLElement;\n\n    if (!selectTitleWrapper) {\n      return;\n    }\n\n    if (!option) {\n      selectTitleWrapper.style.display = 'none';\n      return;\n    }\n\n    this.selectTitle = option.title;\n    selectTitleWrapper.style.display = 'block';\n    selectTitleWrapper.style.whiteSpace = 'nowrap';\n\n    if (!this.select) {\n      return;\n    }\n\n    const selectElement = this.select.nativeElement as HTMLElement;\n\n    if (!selectElement) {\n      return;\n    }\n\n    const selectStyle = window.getComputedStyle(selectElement);\n    let selectPaddingLeft = 0;\n    let selectPaddingRight = 0;\n    let selectBorderLeft = 0;\n    let selectBorderRight = 0;\n\n    if (selectStyle) {\n      selectPaddingLeft = parseInt(selectStyle.paddingLeft, 10);\n      selectPaddingRight = parseInt(selectStyle.paddingRight, 10);\n      selectBorderLeft = parseInt(selectStyle.borderLeft, 10);\n      selectBorderRight = parseInt(selectStyle.borderRight, 10);\n    }\n\n    const selectTitleWrapperTitle = selectTitleWrapper.lastElementChild as HTMLElement;\n    let offsetWidth = selectPaddingLeft + selectPaddingRight + selectBorderLeft + selectBorderRight;\n\n    if (selectTitleWrapperTitle) {\n      offsetWidth += selectTitleWrapperTitle.offsetWidth;\n      if (this.exists(this.error) && this.errorMessageWrapper) {\n        const selectErrorWidth = parseInt(window.getComputedStyle(this.errorMessageWrapper.nativeElement).width, 10);\n        if (selectErrorWidth > offsetWidth) {\n          offsetWidth = selectErrorWidth;\n        }\n      }\n    }\n\n    if (offsetWidth > 0) {\n      this.labelWidth = offsetWidth;\n      this.change.detectChanges();\n    }\n\n    selectTitleWrapper.style.display = 'none';\n  }\n}\n","<label for=\"getSelectId()\"\n  *ngIf=\"label && !inline\">\n  <span [nasClass]=\"getClass('label')\">{{label}}</span>\n</label>\n<div [nasClass]=\"getClasses()\">\n  <ng-container *ngIf=\"!nasFormGroup || !nasFormControlName; else reactiveForm\">\n    <select #select\n      [id]=\"selectId\"\n      [attr.disabled]=\"disabled\"\n      [attr.aria-label]=\"'select'\"\n      [attr.aria-labelledby]=\"getSelectId()\"\n      [style.width.px]=\"labelWidth\"\n      [formControl]=\"selectControl\"\n      (mousedown)=\"toggleSelect($event)\"\n      (keydown)=\"toggleSelect($event, true)\"\n      (blur)=\"blurSelect()\"\n      (change)=\"toggleSelect($event)\">\n      <ng-container *ngIf=\"!hasContent\">\n        <option *ngFor=\"let option of options\"\n          [value]=\"option?.value\"\n          [attr.aria-label]=\"option?.title\">\n          {{option?.title}}</option>\n      </ng-container>\n      <ng-container *ngTemplateOutlet=\"contentOptions\"></ng-container>\n    </select>\n  </ng-container>\n  <ng-template #reactiveForm>\n    <ng-container [formGroup]=\"nasFormGroup\">\n      <select #select\n        [formControlName]=\"nasFormControlName\"\n        [id]=\"selectId\"\n        [attr.disabled]=\"disabled\"\n        [attr.aria-label]=\"'select'\"\n        [attr.aria-labelledby]=\"getSelectId()\"\n        [style.width.px]=\"labelWidth\"\n        (mousedown)=\"toggleSelect($event)\"\n        (keydown)=\"toggleSelect($event, true)\"\n        (blur)=\"blurSelect()\"\n        (change)=\"toggleSelect($event)\">\n        <ng-container *ngIf=\"!hasContent\">\n          <option *ngFor=\"let option of options\"\n            [value]=\"option?.value\"\n            [attr.aria-label]=\"option?.title\">{{option?.title}}</option>\n        </ng-container>\n        <ng-container *ngTemplateOutlet=\"contentOptions\"></ng-container>\n      </select>\n    </ng-container>\n  </ng-template>\n  <p [nasClass]=\"getClass('error')\"\n    #errorMessageWrapper\n    *ngIf=\"exists(error) && errorMessage\" [id]=\"errorId\">{{errorMessage}}</p>\n  <div #selectTitleWrapper\n    [style.display]=\"'none'\"\n    aria-hidden=\"true\">\n    <span>{{selectTitle}}</span>\n  </div>\n  <ng-template #contentOptions>\n    <ng-content></ng-content>\n  </ng-template>\n</div>"]}
|
|
360
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../../../projects/core-components/src/lib/components/select/select.component.ts","../../../../../../projects/core-components/src/lib/components/select/select.component.html"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Norwegian Air Shuttle. All Rights Reserved.\n */\n\nimport {\n  Component,\n  Input,\n  Output,\n  EventEmitter,\n  ViewEncapsulation,\n  ElementRef,\n  ViewChild,\n  ChangeDetectorRef,\n  OnChanges,\n  ContentChildren,\n  QueryList,\n  AfterContentInit,\n  AfterViewChecked,\n} from '@angular/core';\nimport { FormControl, FormGroup } from '@angular/forms';\n\nimport { NasComponentBase } from '../../core';\nimport { ClassModel } from '../../core/models';\nimport { SelectOptionModel } from './models/select-option.model';\nimport { OptionComponent } from './option/option.component';\nimport { OptgroupComponent } from './optgroup/optgroup.component';\nimport { Debounce } from '../../core/decorators/debounce.decorator';\n\nlet nextId = 0;\n\n/**\n * @description\n * Norwegian Select Component | Form Controls\n */\n@Component({\n  selector: 'nas-select',\n  templateUrl: './select.component.html',\n  styleUrls: ['./select.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class SelectComponent extends NasComponentBase implements OnChanges, AfterViewChecked, AfterContentInit {\n  selectControl = new FormControl();\n  labelWidth: number;\n  selectTitle: string;\n  hasContent = false;\n\n  @ViewChild('selectTitleWrapper', { static: true }) selectTitleWrapper: ElementRef;\n  @ViewChild('errorMessageWrapper') errorMessageWrapper: ElementRef;\n  @ViewChild('select') select: ElementRef<HTMLSelectElement>;\n  @ContentChildren(OptionComponent) optionComponents: QueryList<OptionComponent>;\n  @ContentChildren(OptgroupComponent) optgroupComponents: QueryList<OptgroupComponent>;\n\n  private optionsValue: Array<SelectOptionModel>;\n\n  /**\n   * @property Input\n   * @description\n   * The ID of the native input element\n  */\n  @Input() id: string;\n\n  /**\n   * @property Input\n   * @description\n   * Add custom inline styling.\n  */\n  @Input() inline?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Add custom label styling.\n  */\n  @Input() label: string;\n\n  /**\n   * @property Input\n   * @description\n   * Sets block styling.\n  */\n  @Input() block?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Sets spaceless styling.\n  */\n  @Input() spaceless?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Sets stretch styling.\n  */\n  @Input() stretch?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Sets compact styling.\n  */\n  @Input() compact?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Sets simple styling.\n  */\n  @Input() simple?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Sets light styling.\n  */\n  @Input() light?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Sets fill styling.\n  */\n  @Input() fill?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Sets error styling.\n  */\n  @Input() error?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * The error message to display when error occur. Error attribute need to be true.\n  */\n  @Input() errorMessage?: string;\n\n  /**\n   * @property Input\n   * @description\n   * Sets disabled styling.\n  */\n  @Input() disabled?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Makes the select component autogrow.\n  */\n  @Input() autogrow?: boolean;\n\n  /**\n   * @property Input\n   * @description\n   * Add custom CSS class to the selector.\n  */\n  @Input() cssClass: ClassModel;\n\n  /**\n   * @property Input\n   * @description\n   * Sets a formControlName directive to the select.\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-select [nasFormControlName]=\"'fareClass'\"></nas-select>\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-select [nasFormGroup]=\"classGroup\"></nas-select>\n  */\n  @Input() nasFormGroup: FormGroup;\n\n  /**\n   * @property Input\n   * @description\n   * Add options to the selector.\n  */\n  @Input()\n  public get options(): Array<SelectOptionModel> {\n    return this.optionsValue;\n  }\n  public set options(value: Array<SelectOptionModel>) {\n    this.optionsValue = value;\n\n    if (this.options && this.options.length > 0 && !this.selected) {\n      const option = this.options[0];\n\n      this.setSelectedTitle(option);\n\n      if (this.selectedValue === option) {\n        return;\n      }\n\n      this.selectedValue = option;\n      this.selectControl.setValue(this.selectedValue.value);\n    }\n  }\n\n  /**\n   * @property Input\n   * @description\n   * The default selected value.\n  */\n  @Input() selectedValue: SelectOptionModel;\n\n  /**\n   * @property Input\n   * @description\n   * Gets or sets the selected value.\n  */\n  @Input()\n  get selected(): SelectOptionModel {\n    return this.selectedValue;\n  }\n  set selected(option: SelectOptionModel) {\n    if (!option) {\n      return;\n    }\n\n    this.setSelectedTitle(option);\n\n    if (this.selectedValue === option) {\n      return;\n    }\n\n    this.selectedValue = option;\n    this.selectControl.setValue(this.selectedValue.value);\n  }\n\n  /**\n   * @property Output\n   * @description\n   * An event that is fired every time a selection is done.\n  */\n  @Output() selectedChange = new EventEmitter<SelectOptionModel>();\n\n  /**\n   * @property Output\n   * @description\n   * An events that fires every type a keydown event has been pressed on the select element.\n  */\n  @Output() keydown = new EventEmitter<KeyboardEvent>();\n\n  private open = false;\n  private componentId: number;\n\n  constructor(private change: ChangeDetectorRef) {\n    super('nas-select');\n    this.componentId = nextId++;\n  }\n\n  ngOnChanges() {\n    if (this.selectedValue) {\n      this.selectControl.setValue(this.selectedValue.value);\n    }\n  }\n\n  ngAfterContentInit(): void {\n    if (this.optionComponents && this.optionComponents.length > 0\n      || this.optgroupComponents && this.optgroupComponents.length > 0) {\n      this.hasContent = true;\n    }\n\n    if (this.selectedValue) {\n      return;\n    }\n\n    if (this.optionComponents && this.optionComponents.length > 0) {\n      this.setFirstOptionSelected(this.optionComponents);\n    } else if (this.optgroupComponents && this.optgroupComponents.length > 0) {\n      const firstOptgroupComponent = this.optgroupComponents.first;\n\n      if (firstOptgroupComponent) {\n        this.setFirstOptionSelected(firstOptgroupComponent.optionComponents);\n      }\n    }\n  }\n\n  ngAfterViewChecked() {\n    if (!this.hasContent && !this.selectedValue) {\n      if (this.options && this.options.length > 0) {\n        this.setSelectedTitle(this.options[0]);\n      }\n      return;\n    }\n\n    if (this.selectedValue && this.selectedValue.value !== this.selectControl.value) {\n      this.selectControl.setValue(this.selectedValue.value);\n    }\n\n    if (this.selectedValue) {\n      this.setSelectedTitle(this.selectedValue);\n    }\n  }\n\n  getSelectId(): string {\n    return `nas-select-${this.componentId}`;\n  }\n\n  get selectId(): string {\n    return this.id ? this.id : `nas-select-${this.componentId}`;\n  }\n\n  get errorId(): string {\n    return this.id ? this.id + '__error' : `nas-select-${this.componentId}__error`;\n  }\n\n  toggleSelect(event: any, keydown?: boolean): void {\n    if ((event && event.key === 'Enter') || !event || !event.key) {\n      this.open = !this.open;\n\n      if (keydown) {\n        this.keydown.emit(event);\n      }\n\n      if (!event) {\n        return;\n      }\n\n      const target = event.target;\n\n      if (this.options) {\n        const selected = this.options.find(x => x.value === target.value);\n        if (selected && (!this.selected || selected.value !== this.selected.value)) {\n          this.setSelectedAndEmitChange(selected);\n        }\n      }\n\n      if (this.optionComponents && this.optionComponents.length > 0) {\n        const selected = this.optionComponents.find(x => x.option.value === target.value);\n        if (selected && (!this.selected || selected.option.value !== this.selected.value)) {\n          this.setSelectedAndEmitChange(selected.option);\n          return;\n        }\n      }\n\n      if (this.optgroupComponents && this.optgroupComponents.length > 0) {\n        this.optgroupComponents.forEach(optgroupComponent => {\n          if (optgroupComponent.optionComponents) {\n            const selected = optgroupComponent.optionComponents.find(x => x.option.value === target.value);\n            if (selected && (!this.selected || selected.option.value !== this.selected.value)) {\n              this.setSelectedAndEmitChange(selected.option);\n              return;\n            }\n          }\n        });\n      }\n\n      this.updateShadow(target, target.value);\n    }\n  }\n\n  blurSelect(): void {\n    this.open = false;\n  }\n\n  getClasses(): Array<ClassModel> {\n    const classes: Array<ClassModel> = [\n      this.getClass('', [\n        this.label,\n        this.exists(this.inline) && 'inline',\n        this.exists(this.block) && 'block',\n        this.exists(this.spaceless) && 'spaceless',\n        this.exists(this.stretch) && 'stretch',\n        this.exists(this.compact) && 'compact',\n        this.exists(this.simple) && 'simple',\n        this.exists(this.light) && 'light',\n        this.exists(this.fill) && 'fill',\n        this.exists(this.error) && 'error',\n        this.exists(this.disabled) && 'disabled',\n        this.open && 'rotate'\n      ])\n    ];\n\n    if (this.cssClass) {\n      classes.push(this.cssClass);\n    }\n\n    return classes;\n  }\n\n  @Debounce(150)\n  private setSelectedAndEmitChange(selected: SelectOptionModel): void {\n    if (!selected) {\n      return;\n    }\n\n    if (this.selected !== selected) {\n      this.selectedChange.emit(selected);\n    }\n\n    this.selected = selected;\n  }\n\n  private setFirstOptionSelected(optionComponents: QueryList<OptionComponent>): void {\n    if (!optionComponents || optionComponents.length <= 0) {\n      return;\n    }\n\n    const firstOptionComponent = optionComponents.first;\n\n    if (firstOptionComponent) {\n      this.selectedValue = firstOptionComponent.option;\n      this.setSelectedTitle(this.selectedValue);\n    }\n  }\n\n  private updateShadow(target: any, targetValue: string) {\n    if (this.label || this.block || !this.autogrow || !target) {\n      return;\n    }\n\n    let value: string;\n\n    if (target.selectedOptions && target.selectedOptions.length) {\n      value = target.selectedOptions[0].innerHTML;\n    } else {\n      value = targetValue;\n    }\n\n    const shadow = document.createElement('select');\n    const computedStyle = window.getComputedStyle(target);\n    shadow.style.position = 'absolute';\n    shadow.style.top = '-1000px';\n    shadow.style.left = '-1000px';\n    shadow.style.width = 'auto';\n    shadow.style.maxWidth = 'none';\n    shadow.style.fontSize = computedStyle.getPropertyValue('font-size');\n    shadow.style.fontFamily = computedStyle.getPropertyValue('font-family');\n    shadow.style.fontWeight = computedStyle.getPropertyValue('font-weight');\n    shadow.style.letterSpacing = computedStyle.getPropertyValue('letter-spacing');\n    shadow.style.paddingTop = computedStyle.getPropertyValue('padding-top');\n    shadow.style.paddingRight = computedStyle.getPropertyValue('padding-right');\n    shadow.style.paddingBottom = computedStyle.getPropertyValue('padding-bottom');\n    shadow.style.paddingLeft = computedStyle.getPropertyValue('padding-left');\n    shadow.style.borderTop = computedStyle.getPropertyValue('border-top');\n    shadow.style.borderRight = computedStyle.getPropertyValue('border-right');\n    shadow.style.borderBottom = computedStyle.getPropertyValue('border-bottom');\n    shadow.style.borderLeft = computedStyle.getPropertyValue('border-left');\n\n    const option = document.createElement('option');\n    option.value = value;\n    option.innerHTML = value;\n    shadow.appendChild(option);\n\n    target.style.width = `${shadow.offsetWidth + 6}px`;\n  }\n\n  private setSelectedTitle(option: SelectOptionModel): void {\n    const selectTitleWrapper = this.selectTitleWrapper.nativeElement as HTMLElement;\n\n    if (!selectTitleWrapper) {\n      return;\n    }\n\n    if (!option) {\n      selectTitleWrapper.style.display = 'none';\n      return;\n    }\n\n    this.selectTitle = option.title;\n    selectTitleWrapper.style.display = 'block';\n    selectTitleWrapper.style.whiteSpace = 'nowrap';\n\n    if (!this.select) {\n      return;\n    }\n\n    const selectElement = this.select.nativeElement as HTMLElement;\n\n    if (!selectElement) {\n      return;\n    }\n\n    const selectStyle = window.getComputedStyle(selectElement);\n    let selectPaddingLeft = 0;\n    let selectPaddingRight = 0;\n    let selectBorderLeft = 0;\n    let selectBorderRight = 0;\n\n    if (selectStyle) {\n      selectPaddingLeft = parseInt(selectStyle.paddingLeft, 10);\n      selectPaddingRight = parseInt(selectStyle.paddingRight, 10);\n      selectBorderLeft = parseInt(selectStyle.borderLeft, 10);\n      selectBorderRight = parseInt(selectStyle.borderRight, 10);\n    }\n\n    const selectTitleWrapperTitle = selectTitleWrapper.lastElementChild as HTMLElement;\n    let offsetWidth = selectPaddingLeft + selectPaddingRight + selectBorderLeft + selectBorderRight;\n\n    if (selectTitleWrapperTitle) {\n      offsetWidth += selectTitleWrapperTitle.offsetWidth;\n      if (this.exists(this.error) && this.errorMessageWrapper) {\n        const selectErrorWidth = parseInt(window.getComputedStyle(this.errorMessageWrapper.nativeElement).width, 10);\n        if (selectErrorWidth > offsetWidth) {\n          offsetWidth = selectErrorWidth;\n        }\n      }\n    }\n\n    if (offsetWidth > 0) {\n      this.labelWidth = offsetWidth;\n      this.change.detectChanges();\n    }\n\n    selectTitleWrapper.style.display = 'none';\n  }\n}\n","<label for=\"getSelectId()\"\n  *ngIf=\"label && !inline\">\n  <span [nasClass]=\"getClass('label')\">{{label}}</span>\n</label>\n<div [nasClass]=\"getClasses()\">\n  <ng-container *ngIf=\"!nasFormGroup || !nasFormControlName; else reactiveForm\">\n    <select #select\n      [id]=\"selectId\"\n      [attr.disabled]=\"disabled\"\n      [attr.aria-label]=\"'select'\"\n      [attr.aria-labelledby]=\"getSelectId()\"\n      [style.width.px]=\"labelWidth\"\n      [formControl]=\"selectControl\"\n      (mousedown)=\"toggleSelect($event)\"\n      (keydown)=\"toggleSelect($event, true)\"\n      (blur)=\"blurSelect()\"\n      (change)=\"toggleSelect($event)\">\n      <ng-container *ngIf=\"!hasContent\">\n        <option *ngFor=\"let option of options\"\n          [value]=\"option?.value\"\n          [attr.aria-label]=\"option?.title\">\n          {{option?.title}}</option>\n      </ng-container>\n      <ng-container *ngTemplateOutlet=\"contentOptions\"></ng-container>\n    </select>\n  </ng-container>\n  <ng-template #reactiveForm>\n    <ng-container [formGroup]=\"nasFormGroup\">\n      <select #select\n        [formControlName]=\"nasFormControlName\"\n        [id]=\"selectId\"\n        [attr.disabled]=\"disabled\"\n        [attr.aria-label]=\"'select'\"\n        [attr.aria-labelledby]=\"getSelectId()\"\n        [style.width.px]=\"labelWidth\"\n        (mousedown)=\"toggleSelect($event)\"\n        (keydown)=\"toggleSelect($event, true)\"\n        (blur)=\"blurSelect()\"\n        (change)=\"toggleSelect($event)\">\n        <ng-container *ngIf=\"!hasContent\">\n          <option *ngFor=\"let option of options\"\n            [value]=\"option?.value\"\n            [attr.aria-label]=\"option?.title\">{{option?.title}}</option>\n        </ng-container>\n        <ng-container *ngTemplateOutlet=\"contentOptions\"></ng-container>\n      </select>\n    </ng-container>\n  </ng-template>\n  <p [nasClass]=\"getClass('error')\"\n    #errorMessageWrapper\n    *ngIf=\"exists(error) && errorMessage\" [id]=\"errorId\">{{errorMessage}}</p>\n  <div #selectTitleWrapper\n    [style.display]=\"'none'\"\n    aria-hidden=\"true\">\n    <span>{{selectTitle}}</span>\n  </div>\n  <ng-template #contentOptions>\n    <ng-content></ng-content>\n  </ng-template>\n</div>"]}
|
|
@@ -3697,8 +3697,10 @@ class SelectComponent extends NasComponentBase {
|
|
|
3697
3697
|
}
|
|
3698
3698
|
return;
|
|
3699
3699
|
}
|
|
3700
|
-
if (this.selectedValue) {
|
|
3700
|
+
if (this.selectedValue && this.selectedValue.value !== this.selectControl.value) {
|
|
3701
3701
|
this.selectControl.setValue(this.selectedValue.value);
|
|
3702
|
+
}
|
|
3703
|
+
if (this.selectedValue) {
|
|
3702
3704
|
this.setSelectedTitle(this.selectedValue);
|
|
3703
3705
|
}
|
|
3704
3706
|
}
|