UNPKG

ng-select

Version:
263 lines 21.5 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, ElementRef, EventEmitter, Input, Output, ViewChild, TemplateRef, ViewEncapsulation } from '@angular/core'; import { OptionList } from './option-list'; export class SelectDropdownComponent { /** * @param {?} hostElement */ constructor(hostElement) { this.hostElement = hostElement; this.optionClicked = new EventEmitter(); this.optionsListClick = new EventEmitter(); this.singleFilterClick = new EventEmitter(); this.singleFilterFocus = new EventEmitter(); this.singleFilterInput = new EventEmitter(); this.singleFilterKeydown = new EventEmitter(); this.disabledColor = '#fff'; this.disabledTextColor = '9e9e9e'; } /** * Event handlers. * * @return {?} */ ngOnInit() { this.optionsReset(); } /** * @param {?} changes * @return {?} */ ngOnChanges(changes) { if (changes.hasOwnProperty('optionList')) { this.optionsReset(); } } /** * @return {?} */ ngAfterViewInit() { this.moveHighlightedIntoView(); if (!this.multiple && this.filterEnabled) { this.filterInput.nativeElement.focus(); } } /** * @return {?} */ onOptionsListClick() { this.optionsListClick.emit(null); } /** * @return {?} */ onSingleFilterClick() { this.singleFilterClick.emit(null); } /** * @param {?} event * @return {?} */ onSingleFilterInput(event) { this.singleFilterInput.emit(event.target.value); } /** * @param {?} event * @return {?} */ onSingleFilterKeydown(event) { this.singleFilterKeydown.emit(event); } /** * @return {?} */ onSingleFilterFocus() { this.singleFilterFocus.emit(null); } /** * @param {?} event * @return {?} */ onOptionsWheel(event) { this.handleOptionsWheel(event); } /** * @param {?} option * @return {?} */ onOptionMouseover(option) { this.optionList.highlightOption(option); } /** * @param {?} option * @return {?} */ onOptionClick(option) { this.optionClicked.emit(option); } /** * Initialization. * * @private * @return {?} */ optionsReset() { this.optionList.filter(''); this.optionList.highlight(); } /** * View. * * @param {?} option * @return {?} */ getOptionStyle(option) { if (option.highlighted) { /** @type {?} */ let style = {}; if (typeof this.highlightColor !== 'undefined') { style['background-color'] = this.highlightColor; } if (typeof this.highlightTextColor !== 'undefined') { style['color'] = this.highlightTextColor; } return style; } else { return {}; } } /** * @return {?} */ moveHighlightedIntoView() { /** @type {?} */ let list = this.optionsList.nativeElement; /** @type {?} */ let listHeight = list.offsetHeight; /** @type {?} */ let itemIndex = this.optionList.getHighlightedIndex(); if (itemIndex > -1) { /** @type {?} */ let item = list.children[0].children[itemIndex]; /** @type {?} */ let itemHeight = item.offsetHeight; /** @type {?} */ let itemTop = itemIndex * itemHeight; /** @type {?} */ let itemBottom = itemTop + itemHeight; /** @type {?} */ let viewTop = list.scrollTop; /** @type {?} */ let viewBottom = viewTop + listHeight; if (itemBottom > viewBottom) { list.scrollTop = itemBottom - listHeight; } else if (itemTop < viewTop) { list.scrollTop = itemTop; } } } /** * @private * @param {?} e * @return {?} */ handleOptionsWheel(e) { /** @type {?} */ let div = this.optionsList.nativeElement; /** @type {?} */ let atTop = div.scrollTop === 0; /** @type {?} */ let atBottom = div.offsetHeight + div.scrollTop === div.scrollHeight; if (atTop && e.deltaY < 0) { e.preventDefault(); } else if (atBottom && e.deltaY > 0) { e.preventDefault(); } } } SelectDropdownComponent.decorators = [ { type: Component, args: [{ selector: 'select-dropdown', template: "<div\n [ngClass]=\"{'below': isBelow, 'above': !isBelow}\"\n [ngStyle]=\"{'top.px': top, 'left.px': left, 'width.px': width}\">\n\n <div class=\"filter\"\n *ngIf=\"!multiple && filterEnabled\">\n <input\n #filterInput\n autocomplete=\"off\"\n [placeholder]=\"placeholder\"\n (click)=\"onSingleFilterClick()\"\n (input)=\"onSingleFilterInput($event)\"\n (keydown)=\"onSingleFilterKeydown($event)\"\n (focus)=\"onSingleFilterFocus()\">\n </div>\n\n <div class=\"options\"\n (click)=\"onOptionsListClick()\"\n #optionsList>\n <ul\n (wheel)=\"onOptionsWheel($event)\">\n <li *ngFor=\"let option of optionList.filtered\"\n [ngClass]=\"{'highlighted': option.highlighted, 'selected': option.selected, 'disabled': option.disabled}\"\n [ngStyle]=\"getOptionStyle(option)\"\n (click)=\"onOptionClick(option)\"\n (mouseover)=\"onOptionMouseover(option)\">\n <ng-container *ngTemplateOutlet=\"optionTemplate; context:{option: option.wrappedOption}\"></ng-container>\n <span *ngIf=\"!optionTemplate\">{{option.label}}</span>\n </li>\n <li\n *ngIf=\"!optionList.hasShown\"\n class=\"message\">\n {{notFoundMsg}}\n </li>\n </ul>\n </div>\n</div>\n", encapsulation: ViewEncapsulation.None, styles: ["select-dropdown,select-dropdown *{box-sizing:border-box}select-dropdown>div{background-color:#fff;border:1px solid #ccc;box-sizing:border-box;position:absolute;z-index:1}select-dropdown>div.above{border-bottom:none}select-dropdown>div.below{border-top:none}select-dropdown>div .filter{padding:3px;width:100%}select-dropdown>div .filter input{border:1px solid #eee;box-sizing:border-box;padding:4px;width:100%}select-dropdown>div .options{max-height:200px;overflow-y:auto}select-dropdown>div .options ul{list-style:none;margin:0;padding:0}select-dropdown>div .options ul li{padding:4px 8px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}select-dropdown .selected{background-color:#e0e0e0}select-dropdown .highlighted,select-dropdown .selected.highlighted{background-color:#2196f3;color:#fff}select-dropdown .disabled{background-color:#fff;color:#9e9e9e;cursor:default;pointer-events:none}"] }] } ]; /** @nocollapse */ SelectDropdownComponent.ctorParameters = () => [ { type: ElementRef } ]; SelectDropdownComponent.propDecorators = { filterEnabled: [{ type: Input }], highlightColor: [{ type: Input }], highlightTextColor: [{ type: Input }], left: [{ type: Input }], multiple: [{ type: Input }], notFoundMsg: [{ type: Input }], optionList: [{ type: Input }], isBelow: [{ type: Input }], top: [{ type: Input }], width: [{ type: Input }], placeholder: [{ type: Input }], optionTemplate: [{ type: Input }], optionClicked: [{ type: Output }], optionsListClick: [{ type: Output }], singleFilterClick: [{ type: Output }], singleFilterFocus: [{ type: Output }], singleFilterInput: [{ type: Output }], singleFilterKeydown: [{ type: Output }], filterInput: [{ type: ViewChild, args: ['filterInput', { static: false },] }], optionsList: [{ type: ViewChild, args: ['optionsList', { static: true },] }] }; if (false) { /** @type {?} */ SelectDropdownComponent.prototype.filterEnabled; /** @type {?} */ SelectDropdownComponent.prototype.highlightColor; /** @type {?} */ SelectDropdownComponent.prototype.highlightTextColor; /** @type {?} */ SelectDropdownComponent.prototype.left; /** @type {?} */ SelectDropdownComponent.prototype.multiple; /** @type {?} */ SelectDropdownComponent.prototype.notFoundMsg; /** @type {?} */ SelectDropdownComponent.prototype.optionList; /** @type {?} */ SelectDropdownComponent.prototype.isBelow; /** @type {?} */ SelectDropdownComponent.prototype.top; /** @type {?} */ SelectDropdownComponent.prototype.width; /** @type {?} */ SelectDropdownComponent.prototype.placeholder; /** @type {?} */ SelectDropdownComponent.prototype.optionTemplate; /** @type {?} */ SelectDropdownComponent.prototype.optionClicked; /** @type {?} */ SelectDropdownComponent.prototype.optionsListClick; /** @type {?} */ SelectDropdownComponent.prototype.singleFilterClick; /** @type {?} */ SelectDropdownComponent.prototype.singleFilterFocus; /** @type {?} */ SelectDropdownComponent.prototype.singleFilterInput; /** @type {?} */ SelectDropdownComponent.prototype.singleFilterKeydown; /** @type {?} */ SelectDropdownComponent.prototype.filterInput; /** @type {?} */ SelectDropdownComponent.prototype.optionsList; /** @type {?} */ SelectDropdownComponent.prototype.disabledColor; /** @type {?} */ SelectDropdownComponent.prototype.disabledTextColor; /** @type {?} */ SelectDropdownComponent.prototype.hostElement; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-dropdown.component.js","sourceRoot":"ng://ng-select/","sources":["lib/select-dropdown.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, Component, ElementRef, EventEmitter, Input, OnChanges, OnInit, Output, ViewChild, TemplateRef, ViewEncapsulation} from '@angular/core';\nimport {Option} from './option';\nimport {OptionList} from './option-list';\n\n@Component({\n    selector: 'select-dropdown',\n    templateUrl: 'select-dropdown.component.html',\n    styleUrls: ['select-dropdown.component.scss'],\n    encapsulation: ViewEncapsulation.None\n})\n\nexport class SelectDropdownComponent\n        implements AfterViewInit, OnChanges, OnInit {\n\n    @Input() filterEnabled: boolean;\n    @Input() highlightColor: string;\n    @Input() highlightTextColor: string;\n    @Input() left: number;\n    @Input() multiple: boolean;\n    @Input() notFoundMsg: string;\n    @Input() optionList: OptionList;\n    @Input() isBelow: boolean;\n    @Input() top: number;\n    @Input() width: number;\n    @Input() placeholder: string;\n    @Input() optionTemplate: TemplateRef<any>;\n\n    @Output() optionClicked = new EventEmitter<Option>();\n    @Output() optionsListClick = new EventEmitter<null>();\n    @Output() singleFilterClick = new EventEmitter<null>();\n    @Output() singleFilterFocus = new EventEmitter<null>();\n    @Output() singleFilterInput = new EventEmitter<string>();\n    @Output() singleFilterKeydown = new EventEmitter<any>();\n\n    @ViewChild('filterInput', { static: false }) filterInput: any;\n    @ViewChild('optionsList', { static: true }) optionsList: any;\n\n    disabledColor: string = '#fff';\n    disabledTextColor: string = '9e9e9e';\n\n    constructor(\n        public hostElement: ElementRef\n    ) {}\n\n    /** Event handlers. **/\n\n    ngOnInit() {\n        this.optionsReset();\n    }\n\n    ngOnChanges(changes: any) {\n        if (changes.hasOwnProperty('optionList')) {\n            this.optionsReset();\n        }\n    }\n\n    ngAfterViewInit() {\n        this.moveHighlightedIntoView();\n        if (!this.multiple && this.filterEnabled) {\n            this.filterInput.nativeElement.focus();\n        }\n    }\n\n    onOptionsListClick() {\n        this.optionsListClick.emit(null);\n    }\n\n    onSingleFilterClick() {\n        this.singleFilterClick.emit(null);\n    }\n\n    onSingleFilterInput(event: any) {\n        this.singleFilterInput.emit(event.target.value);\n    }\n\n    onSingleFilterKeydown(event: any) {\n        this.singleFilterKeydown.emit(event);\n    }\n\n    onSingleFilterFocus() {\n        this.singleFilterFocus.emit(null);\n    }\n\n    onOptionsWheel(event: any) {\n        this.handleOptionsWheel(event);\n    }\n\n    onOptionMouseover(option: Option) {\n        this.optionList.highlightOption(option);\n    }\n\n    onOptionClick(option: Option) {\n        this.optionClicked.emit(option);\n    }\n\n    /** Initialization. **/\n\n    private optionsReset() {\n        this.optionList.filter('');\n        this.optionList.highlight();\n    }\n\n    /** View. **/\n\n    getOptionStyle(option: Option): any {\n        if (option.highlighted) {\n            let style: any = {};\n\n            if (typeof this.highlightColor !== 'undefined') {\n                style['background-color'] = this.highlightColor;\n            }\n            if (typeof this.highlightTextColor !== 'undefined') {\n                style['color'] = this.highlightTextColor;\n            }\n            return style;\n        }\n        else {\n            return {};\n        }\n    }\n\n    moveHighlightedIntoView() {\n\n        let list = this.optionsList.nativeElement;\n        let listHeight = list.offsetHeight;\n\n        let itemIndex = this.optionList.getHighlightedIndex();\n\n        if (itemIndex > -1) {\n            let item = list.children[0].children[itemIndex];\n            let itemHeight = item.offsetHeight;\n\n            let itemTop = itemIndex * itemHeight;\n            let itemBottom = itemTop + itemHeight;\n\n            let viewTop = list.scrollTop;\n            let viewBottom = viewTop + listHeight;\n\n            if (itemBottom > viewBottom) {\n                list.scrollTop = itemBottom - listHeight;\n            }\n            else if (itemTop < viewTop) {\n                list.scrollTop = itemTop;\n            }\n        }\n    }\n\n    private handleOptionsWheel(e: any) {\n        let div = this.optionsList.nativeElement;\n        let atTop = div.scrollTop === 0;\n        let atBottom = div.offsetHeight + div.scrollTop === div.scrollHeight;\n\n        if (atTop && e.deltaY < 0) {\n            e.preventDefault();\n        }\n        else if (atBottom && e.deltaY > 0) {\n            e.preventDefault();\n        }\n    }\n}\n"]}