UNPKG

ng-zorro-antd

Version:

An enterprise-class UI components based on Ant Design and Angular

122 lines 13.2 kB
/** * Use of this source code is governed by an MIT-style license that can be * found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE */ import { __decorate, __metadata } from "tslib"; import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, Input, Optional, Output, ViewEncapsulation } from '@angular/core'; import { InputBoolean, scrollIntoView } from 'ng-zorro-antd/core/util'; import { NzAutocompleteOptgroupComponent } from './autocomplete-optgroup.component'; export class NzOptionSelectionChange { constructor(source, isUserInput = false) { this.source = source; this.isUserInput = isUserInput; } } export class NzAutocompleteOptionComponent { constructor(changeDetectorRef, element, nzAutocompleteOptgroupComponent) { this.changeDetectorRef = changeDetectorRef; this.element = element; this.nzAutocompleteOptgroupComponent = nzAutocompleteOptgroupComponent; this.nzDisabled = false; this.selectionChange = new EventEmitter(); this.mouseEntered = new EventEmitter(); this.active = false; this.selected = false; } select(emit = true) { this.selected = true; this.changeDetectorRef.markForCheck(); if (emit) { this.emitSelectionChangeEvent(); } } onMouseEnter() { this.mouseEntered.emit(this); } deselect() { this.selected = false; this.changeDetectorRef.markForCheck(); this.emitSelectionChangeEvent(); } /** Git display label */ getLabel() { return this.nzLabel || this.nzValue.toString(); } /** Set active (only styles) */ setActiveStyles() { if (!this.active) { this.active = true; this.changeDetectorRef.markForCheck(); } } /** Unset active (only styles) */ setInactiveStyles() { if (this.active) { this.active = false; this.changeDetectorRef.markForCheck(); } } scrollIntoViewIfNeeded() { scrollIntoView(this.element.nativeElement); } selectViaInteraction() { if (!this.nzDisabled) { this.selected = !this.selected; if (this.selected) { this.setActiveStyles(); } else { this.setInactiveStyles(); } this.emitSelectionChangeEvent(true); this.changeDetectorRef.markForCheck(); } } emitSelectionChangeEvent(isUserInput = false) { this.selectionChange.emit(new NzOptionSelectionChange(this, isUserInput)); } } NzAutocompleteOptionComponent.decorators = [ { type: Component, args: [{ selector: 'nz-auto-option', exportAs: 'nzAutoOption', preserveWhitespaces: false, changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, template: ` <div class="ant-select-item-option-content"> <ng-content></ng-content> </div> `, host: { role: 'menuitem', class: 'ant-select-item ant-select-item-option', '[class.ant-select-item-option-grouped]': 'nzAutocompleteOptgroupComponent', '[class.ant-select-item-option-selected]': 'selected', '[class.ant-select-item-option-active]': 'active', '[class.ant-select-item-option-disabled]': 'nzDisabled', '[attr.aria-selected]': 'selected.toString()', '[attr.aria-disabled]': 'nzDisabled.toString()', '(click)': 'selectViaInteraction()', '(mouseenter)': 'onMouseEnter()', '(mousedown)': '$event.preventDefault()' } },] } ]; NzAutocompleteOptionComponent.ctorParameters = () => [ { type: ChangeDetectorRef }, { type: ElementRef }, { type: NzAutocompleteOptgroupComponent, decorators: [{ type: Optional }] } ]; NzAutocompleteOptionComponent.propDecorators = { nzValue: [{ type: Input }], nzLabel: [{ type: Input }], nzDisabled: [{ type: Input }], selectionChange: [{ type: Output }], mouseEntered: [{ type: Output }] }; __decorate([ InputBoolean(), __metadata("design:type", Object) ], NzAutocompleteOptionComponent.prototype, "nzDisabled", void 0); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete-option.component.js","sourceRoot":"","sources":["../../../components/auto-complete/autocomplete-option.component.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE\n */\n\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  Optional,\n  Output,\n  ViewEncapsulation\n} from '@angular/core';\nimport { BooleanInput, NzSafeAny } from 'ng-zorro-antd/core/types';\nimport { InputBoolean, scrollIntoView } from 'ng-zorro-antd/core/util';\n\nimport { NzAutocompleteOptgroupComponent } from './autocomplete-optgroup.component';\n\nexport class NzOptionSelectionChange {\n  constructor(public source: NzAutocompleteOptionComponent, public isUserInput: boolean = false) {}\n}\n\n@Component({\n  selector: 'nz-auto-option',\n  exportAs: 'nzAutoOption',\n  preserveWhitespaces: false,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  template: `\n    <div class=\"ant-select-item-option-content\">\n      <ng-content></ng-content>\n    </div>\n  `,\n  host: {\n    role: 'menuitem',\n    class: 'ant-select-item ant-select-item-option',\n    '[class.ant-select-item-option-grouped]': 'nzAutocompleteOptgroupComponent',\n    '[class.ant-select-item-option-selected]': 'selected',\n    '[class.ant-select-item-option-active]': 'active',\n    '[class.ant-select-item-option-disabled]': 'nzDisabled',\n    '[attr.aria-selected]': 'selected.toString()',\n    '[attr.aria-disabled]': 'nzDisabled.toString()',\n    '(click)': 'selectViaInteraction()',\n    '(mouseenter)': 'onMouseEnter()',\n    '(mousedown)': '$event.preventDefault()'\n  }\n})\nexport class NzAutocompleteOptionComponent {\n  static ngAcceptInputType_nzDisabled: BooleanInput;\n\n  @Input() nzValue: NzSafeAny;\n  @Input() nzLabel?: string;\n  @Input() @InputBoolean() nzDisabled = false;\n  @Output() readonly selectionChange = new EventEmitter<NzOptionSelectionChange>();\n  @Output() readonly mouseEntered = new EventEmitter<NzAutocompleteOptionComponent>();\n\n  active = false;\n  selected = false;\n\n  constructor(\n    private changeDetectorRef: ChangeDetectorRef,\n    private element: ElementRef,\n    @Optional()\n    public nzAutocompleteOptgroupComponent: NzAutocompleteOptgroupComponent\n  ) {}\n\n  select(emit: boolean = true): void {\n    this.selected = true;\n    this.changeDetectorRef.markForCheck();\n    if (emit) {\n      this.emitSelectionChangeEvent();\n    }\n  }\n\n  onMouseEnter(): void {\n    this.mouseEntered.emit(this);\n  }\n\n  deselect(): void {\n    this.selected = false;\n    this.changeDetectorRef.markForCheck();\n    this.emitSelectionChangeEvent();\n  }\n\n  /** Git display label */\n  getLabel(): string {\n    return this.nzLabel || this.nzValue.toString();\n  }\n\n  /** Set active (only styles) */\n  setActiveStyles(): void {\n    if (!this.active) {\n      this.active = true;\n      this.changeDetectorRef.markForCheck();\n    }\n  }\n\n  /** Unset active (only styles) */\n  setInactiveStyles(): void {\n    if (this.active) {\n      this.active = false;\n      this.changeDetectorRef.markForCheck();\n    }\n  }\n\n  scrollIntoViewIfNeeded(): void {\n    scrollIntoView(this.element.nativeElement);\n  }\n\n  selectViaInteraction(): void {\n    if (!this.nzDisabled) {\n      this.selected = !this.selected;\n      if (this.selected) {\n        this.setActiveStyles();\n      } else {\n        this.setInactiveStyles();\n      }\n      this.emitSelectionChangeEvent(true);\n      this.changeDetectorRef.markForCheck();\n    }\n  }\n\n  private emitSelectionChangeEvent(isUserInput: boolean = false): void {\n    this.selectionChange.emit(new NzOptionSelectionChange(this, isUserInput));\n  }\n}\n"]}