ng-select
Version:
Select component for angular.
1,094 lines • 74.5 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, HostListener, Input, Output, EventEmitter, ViewChild, ViewEncapsulation, forwardRef, ElementRef, ContentChild, TemplateRef } from '@angular/core';
import { NG_VALUE_ACCESSOR } from '@angular/forms';
import { SelectDropdownComponent } from './select-dropdown.component';
import { OptionList } from './option-list';
/** @type {?} */
export var SELECT_VALUE_ACCESSOR = {
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef((/**
* @return {?}
*/
function () { return SelectComponent; })),
multi: true
};
var SelectComponent = /** @class */ (function () {
function SelectComponent(hostElement) {
this.hostElement = hostElement;
// Data input.
this.options = [];
// Functionality settings.
this.allowClear = false;
this.disabled = false;
this.multiple = false;
this.noFilter = 0;
// Text settings.
this.notFoundMsg = 'No results found';
this.placeholder = '';
this.filterPlaceholder = '';
this.label = '';
// Output events.
this.opened = new EventEmitter();
this.closed = new EventEmitter();
this.selected = new EventEmitter();
this.deselected = new EventEmitter();
this.focus = new EventEmitter();
this.blur = new EventEmitter();
this.noOptionsFound = new EventEmitter();
this.filterInputChanged = new EventEmitter();
this._value = [];
this.optionList = new OptionList([]);
// View state variables.
this.hasFocus = false;
this.isOpen = false;
this.isBelow = true;
this.filterEnabled = true;
this.filterInputWidth = 1;
this.isDisabled = false;
this.placeholderView = '';
this.clearClicked = false;
this.selectContainerClicked = false;
this.optionListClicked = false;
this.optionClicked = false;
this.onChange = (/**
* @param {?} _
* @return {?}
*/
function (_) { });
this.onTouched = (/**
* @return {?}
*/
function () { });
/**
* Keys. *
*/
this.KEYS = {
BACKSPACE: 8,
TAB: 9,
ENTER: 13,
ESC: 27,
SPACE: 32,
UP: 38,
DOWN: 40
};
}
/** Event handlers. **/
/**
* Event handlers. *
* @return {?}
*/
SelectComponent.prototype.ngOnInit = /**
* Event handlers. *
* @return {?}
*/
function () {
this.placeholderView = this.placeholder;
};
/**
* @param {?} changes
* @return {?}
*/
SelectComponent.prototype.ngOnChanges = /**
* @param {?} changes
* @return {?}
*/
function (changes) {
this.handleInputChanges(changes);
};
/**
* @return {?}
*/
SelectComponent.prototype.ngAfterViewInit = /**
* @return {?}
*/
function () {
this.updateState();
};
/**
* @return {?}
*/
SelectComponent.prototype.onWindowBlur = /**
* @return {?}
*/
function () {
this._blur();
};
/**
* @return {?}
*/
SelectComponent.prototype.onWindowClick = /**
* @return {?}
*/
function () {
if (!this.selectContainerClicked &&
(!this.optionListClicked || (this.optionListClicked && this.optionClicked))) {
this.closeDropdown(this.optionClicked);
if (!this.optionClicked) {
this._blur();
}
}
this.clearClicked = false;
this.selectContainerClicked = false;
this.optionListClicked = false;
this.optionClicked = false;
};
/**
* @return {?}
*/
SelectComponent.prototype.onWindowResize = /**
* @return {?}
*/
function () {
this.updateWidth();
};
/**
* @param {?} event
* @return {?}
*/
SelectComponent.prototype.onSelectContainerClick = /**
* @param {?} event
* @return {?}
*/
function (event) {
this.selectContainerClicked = true;
if (!this.clearClicked) {
this.toggleDropdown();
}
};
/**
* @return {?}
*/
SelectComponent.prototype.onSelectContainerFocus = /**
* @return {?}
*/
function () {
this._focus();
};
/**
* @param {?} event
* @return {?}
*/
SelectComponent.prototype.onSelectContainerKeydown = /**
* @param {?} event
* @return {?}
*/
function (event) {
this.handleSelectContainerKeydown(event);
};
/**
* @return {?}
*/
SelectComponent.prototype.onOptionsListClick = /**
* @return {?}
*/
function () {
this.optionListClicked = true;
};
/**
* @param {?} option
* @return {?}
*/
SelectComponent.prototype.onDropdownOptionClicked = /**
* @param {?} option
* @return {?}
*/
function (option) {
this.optionClicked = true;
this.multiple ? this.toggleSelectOption(option) : this.selectOption(option);
};
/**
* @return {?}
*/
SelectComponent.prototype.onSingleFilterClick = /**
* @return {?}
*/
function () {
this.selectContainerClicked = true;
};
/**
* @return {?}
*/
SelectComponent.prototype.onSingleFilterFocus = /**
* @return {?}
*/
function () {
this._focus();
};
/**
* @param {?} term
* @return {?}
*/
SelectComponent.prototype.onFilterInput = /**
* @param {?} term
* @return {?}
*/
function (term) {
this.filterInputChanged.emit(term);
this.filter(term);
};
/**
* @param {?} event
* @return {?}
*/
SelectComponent.prototype.onSingleFilterKeydown = /**
* @param {?} event
* @return {?}
*/
function (event) {
this.handleSingleFilterKeydown(event);
};
/**
* @param {?} event
* @return {?}
*/
SelectComponent.prototype.onMultipleFilterKeydown = /**
* @param {?} event
* @return {?}
*/
function (event) {
this.handleMultipleFilterKeydown(event);
};
/**
* @return {?}
*/
SelectComponent.prototype.onMultipleFilterFocus = /**
* @return {?}
*/
function () {
this._focus();
};
/**
* @param {?} event
* @return {?}
*/
SelectComponent.prototype.onClearSelectionClick = /**
* @param {?} event
* @return {?}
*/
function (event) {
this.clearClicked = true;
this.clearSelection();
this.closeDropdown(true);
};
/**
* @param {?} option
* @return {?}
*/
SelectComponent.prototype.onDeselectOptionClick = /**
* @param {?} option
* @return {?}
*/
function (option) {
this.clearClicked = true;
this.deselectOption(option);
};
/** API. **/
// TODO fix issues with global click/key handler that closes the dropdown.
/**
* API. *
* @return {?}
*/
// TODO fix issues with global click/key handler that closes the dropdown.
SelectComponent.prototype.open = /**
* API. *
* @return {?}
*/
// TODO fix issues with global click/key handler that closes the dropdown.
function () {
this.openDropdown();
};
/**
* @return {?}
*/
SelectComponent.prototype.close = /**
* @return {?}
*/
function () {
this.closeDropdown(false);
};
/**
* @return {?}
*/
SelectComponent.prototype.clear = /**
* @return {?}
*/
function () {
this.clearSelection();
};
/**
* @param {?} value
* @return {?}
*/
SelectComponent.prototype.select = /**
* @param {?} value
* @return {?}
*/
function (value) {
this.writeValue(value);
};
/** ControlValueAccessor interface methods. **/
/**
* ControlValueAccessor interface methods. *
* @param {?} value
* @return {?}
*/
SelectComponent.prototype.writeValue = /**
* ControlValueAccessor interface methods. *
* @param {?} value
* @return {?}
*/
function (value) {
this.value = value;
};
/**
* @param {?} fn
* @return {?}
*/
SelectComponent.prototype.registerOnChange = /**
* @param {?} fn
* @return {?}
*/
function (fn) {
this.onChange = fn;
};
/**
* @param {?} fn
* @return {?}
*/
SelectComponent.prototype.registerOnTouched = /**
* @param {?} fn
* @return {?}
*/
function (fn) {
this.onTouched = fn;
};
/**
* @param {?} isDisabled
* @return {?}
*/
SelectComponent.prototype.setDisabledState = /**
* @param {?} isDisabled
* @return {?}
*/
function (isDisabled) {
this.disabled = isDisabled;
};
/** Input change handling. **/
/**
* Input change handling. *
* @private
* @param {?} changes
* @return {?}
*/
SelectComponent.prototype.handleInputChanges = /**
* Input change handling. *
* @private
* @param {?} changes
* @return {?}
*/
function (changes) {
/** @type {?} */
var optionsChanged = changes.hasOwnProperty('options');
/** @type {?} */
var noFilterChanged = changes.hasOwnProperty('noFilter');
/** @type {?} */
var placeholderChanged = changes.hasOwnProperty('placeholder');
if (optionsChanged) {
this.updateOptionList(changes.options.currentValue);
this.updateState();
}
if (optionsChanged || noFilterChanged) {
this.updateFilterEnabled();
}
if (placeholderChanged) {
this.updateState();
}
};
/**
* @private
* @param {?} options
* @return {?}
*/
SelectComponent.prototype.updateOptionList = /**
* @private
* @param {?} options
* @return {?}
*/
function (options) {
this.optionList = new OptionList(options);
this.optionList.value = this._value;
};
/**
* @private
* @return {?}
*/
SelectComponent.prototype.updateFilterEnabled = /**
* @private
* @return {?}
*/
function () {
this.filterEnabled = this.optionList.options.length >= this.noFilter;
};
Object.defineProperty(SelectComponent.prototype, "value", {
/** Value. **/
get: /**
* Value. *
* @return {?}
*/
function () {
return this.multiple ? this._value : this._value[0];
},
set: /**
* @param {?} v
* @return {?}
*/
function (v) {
if (typeof v === 'undefined' || v === null || v === '') {
v = [];
}
else if (typeof v === 'string') {
v = [v];
}
else if (!Array.isArray(v)) {
throw new TypeError('Value must be a string or an array.');
}
this.optionList.value = v;
this._value = v;
this.updateState();
},
enumerable: true,
configurable: true
});
/**
* @private
* @return {?}
*/
SelectComponent.prototype.valueChanged = /**
* @private
* @return {?}
*/
function () {
this._value = this.optionList.value;
this.updateState();
this.onChange(this.value);
};
/**
* @private
* @return {?}
*/
SelectComponent.prototype.updateState = /**
* @private
* @return {?}
*/
function () {
var _this = this;
this.placeholderView = this.optionList.hasSelected ? '' : this.placeholder;
setTimeout((/**
* @return {?}
*/
function () {
_this.updateFilterWidth();
}));
};
/** Select. **/
/**
* Select. *
* @private
* @param {?} option
* @return {?}
*/
SelectComponent.prototype.selectOption = /**
* Select. *
* @private
* @param {?} option
* @return {?}
*/
function (option) {
if (!option.selected && !option.disabled) {
this.optionList.select(option, this.multiple);
this.valueChanged();
this.selected.emit(option.wrappedOption);
}
};
/**
* @private
* @param {?} option
* @return {?}
*/
SelectComponent.prototype.deselectOption = /**
* @private
* @param {?} option
* @return {?}
*/
function (option) {
var _this = this;
if (option.selected) {
this.optionList.deselect(option);
this.valueChanged();
this.deselected.emit(option.wrappedOption);
setTimeout((/**
* @return {?}
*/
function () {
if (_this.multiple) {
_this.updatePosition();
_this.optionList.highlight();
if (_this.isOpen) {
_this.dropdown.moveHighlightedIntoView();
}
}
}));
}
};
/**
* @private
* @return {?}
*/
SelectComponent.prototype.clearSelection = /**
* @private
* @return {?}
*/
function () {
/** @type {?} */
var selection = this.optionList.selection;
if (selection.length > 0) {
this.optionList.clearSelection();
this.valueChanged();
if (selection.length === 1) {
this.deselected.emit(selection[0].wrappedOption);
}
else {
this.deselected.emit(selection.map((/**
* @param {?} option
* @return {?}
*/
function (option) { return option.wrappedOption; })));
}
}
};
/**
* @private
* @param {?} option
* @return {?}
*/
SelectComponent.prototype.toggleSelectOption = /**
* @private
* @param {?} option
* @return {?}
*/
function (option) {
option.selected ? this.deselectOption(option) : this.selectOption(option);
};
/**
* @private
* @return {?}
*/
SelectComponent.prototype.selectHighlightedOption = /**
* @private
* @return {?}
*/
function () {
/** @type {?} */
var option = this.optionList.highlightedOption;
if (option !== null) {
this.selectOption(option);
this.closeDropdown(true);
}
};
/**
* @private
* @return {?}
*/
SelectComponent.prototype.deselectLast = /**
* @private
* @return {?}
*/
function () {
/** @type {?} */
var sel = this.optionList.selection;
if (sel.length > 0) {
/** @type {?} */
var option = sel[sel.length - 1];
this.deselectOption(option);
this.setMultipleFilterInput(option.label + ' ');
}
};
/** Dropdown. **/
/**
* Dropdown. *
* @private
* @return {?}
*/
SelectComponent.prototype.toggleDropdown = /**
* Dropdown. *
* @private
* @return {?}
*/
function () {
if (!this.isDisabled) {
this.isOpen ? this.closeDropdown(true) : this.openDropdown();
}
};
/**
* @private
* @return {?}
*/
SelectComponent.prototype.openDropdown = /**
* @private
* @return {?}
*/
function () {
var _this = this;
if (!this.isOpen) {
this.isOpen = true;
this.updateWidth();
setTimeout((/**
* @return {?}
*/
function () {
_this.updatePosition();
if (_this.multiple && _this.filterEnabled) {
_this.filterInput.nativeElement.focus();
}
_this.opened.emit(null);
}));
}
};
/**
* @private
* @param {?} focus
* @return {?}
*/
SelectComponent.prototype.closeDropdown = /**
* @private
* @param {?} focus
* @return {?}
*/
function (focus) {
if (this.isOpen) {
this.clearFilterInput();
this.updateFilterWidth();
this.isOpen = false;
if (focus) {
this._focusSelectContainer();
}
this.closed.emit(null);
}
};
/** Filter. **/
/**
* Filter. *
* @private
* @param {?} term
* @return {?}
*/
SelectComponent.prototype.filter = /**
* Filter. *
* @private
* @param {?} term
* @return {?}
*/
function (term) {
var _this = this;
if (this.multiple) {
if (!this.isOpen) {
this.openDropdown();
}
this.updateFilterWidth();
}
setTimeout((/**
* @return {?}
*/
function () {
/** @type {?} */
var hasShown = _this.optionList.filter(term);
if (!hasShown) {
_this.noOptionsFound.emit(term);
}
}));
};
/**
* @private
* @return {?}
*/
SelectComponent.prototype.clearFilterInput = /**
* @private
* @return {?}
*/
function () {
if (this.multiple && this.filterEnabled) {
this.filterInput.nativeElement.value = '';
}
};
/**
* @private
* @param {?} value
* @return {?}
*/
SelectComponent.prototype.setMultipleFilterInput = /**
* @private
* @param {?} value
* @return {?}
*/
function (value) {
if (this.filterEnabled) {
this.filterInput.nativeElement.value = value;
}
};
/**
* @private
* @param {?} event
* @return {?}
*/
SelectComponent.prototype.handleSelectContainerKeydown = /**
* @private
* @param {?} event
* @return {?}
*/
function (event) {
var _this = this;
/** @type {?} */
var key = event.which;
if (this.isOpen) {
if (key === this.KEYS.ESC || (key === this.KEYS.UP && event.altKey)) {
this.closeDropdown(true);
}
else if (key === this.KEYS.TAB) {
this.closeDropdown(event.shiftKey);
this._blur();
}
else if (key === this.KEYS.ENTER) {
this.selectHighlightedOption();
}
else if (key === this.KEYS.UP) {
this.optionList.highlightPreviousOption();
this.dropdown.moveHighlightedIntoView();
if (!this.filterEnabled) {
event.preventDefault();
}
}
else if (key === this.KEYS.DOWN) {
this.optionList.highlightNextOption();
this.dropdown.moveHighlightedIntoView();
if (!this.filterEnabled) {
event.preventDefault();
}
}
}
else {
// DEPRICATED --> SPACE
if (key === this.KEYS.ENTER || key === this.KEYS.SPACE ||
(key === this.KEYS.DOWN && event.altKey)) {
/* FIREFOX HACK:
*
* The setTimeout is added to prevent the enter keydown event
* to be triggered for the filter input field, which causes
* the dropdown to be closed again.
*/
setTimeout((/**
* @return {?}
*/
function () { _this.openDropdown(); }));
}
else if (key === this.KEYS.TAB) {
this._blur();
}
}
};
/**
* @private
* @param {?} event
* @return {?}
*/
SelectComponent.prototype.handleMultipleFilterKeydown = /**
* @private
* @param {?} event
* @return {?}
*/
function (event) {
/** @type {?} */
var key = event.which;
if (key === this.KEYS.BACKSPACE) {
if (this.optionList.hasSelected && this.filterEnabled &&
this.filterInput.nativeElement.value === '') {
this.deselectLast();
}
}
};
/**
* @private
* @param {?} event
* @return {?}
*/
SelectComponent.prototype.handleSingleFilterKeydown = /**
* @private
* @param {?} event
* @return {?}
*/
function (event) {
/** @type {?} */
var key = event.which;
if (key === this.KEYS.ESC || key === this.KEYS.TAB
|| key === this.KEYS.UP || key === this.KEYS.DOWN
|| key === this.KEYS.ENTER) {
this.handleSelectContainerKeydown(event);
}
};
/** View. **/
/**
* View. *
* @return {?}
*/
SelectComponent.prototype._blur = /**
* View. *
* @return {?}
*/
function () {
if (this.hasFocus) {
this.hasFocus = false;
this.onTouched();
this.blur.emit(null);
}
};
/**
* @return {?}
*/
SelectComponent.prototype._focus = /**
* @return {?}
*/
function () {
if (!this.hasFocus) {
this.hasFocus = true;
this.focus.emit(null);
}
};
/**
* @return {?}
*/
SelectComponent.prototype._focusSelectContainer = /**
* @return {?}
*/
function () {
this.selectionSpan.nativeElement.focus();
};
/**
* @private
* @return {?}
*/
SelectComponent.prototype.updateWidth = /**
* @private
* @return {?}
*/
function () {
this.width = this.selectionSpan.nativeElement.getBoundingClientRect().width;
};
/**
* @private
* @return {?}
*/
SelectComponent.prototype.updatePosition = /**
* @private
* @return {?}
*/
function () {
if (typeof this.dropdown !== 'undefined') {
/** @type {?} */
var hostRect = this.hostElement.nativeElement.getBoundingClientRect();
/** @type {?} */
var spanRect = this.selectionSpan.nativeElement.getBoundingClientRect();
/** @type {?} */
var dropRect = this.dropdown.hostElement.nativeElement.firstElementChild.getBoundingClientRect();
/** @type {?} */
var windowHeight = window.innerHeight;
/** @type {?} */
var top_1 = spanRect.top - hostRect.top;
/** @type {?} */
var bottom = hostRect.bottom + dropRect.height;
this.isBelow = bottom < windowHeight;
this.left = spanRect.left - hostRect.left;
this.top = this.isBelow ? top_1 + spanRect.height : top_1 - dropRect.height;
}
};
/**
* @private
* @return {?}
*/
SelectComponent.prototype.updateFilterWidth = /**
* @private
* @return {?}
*/
function () {
if (typeof this.filterInput !== 'undefined') {
/** @type {?} */
var value = this.filterInput.nativeElement.value;
this.filterInputWidth = value.length === 0 ?
1 + this.placeholderView.length * 10 : 1 + value.length * 10;
}
};
SelectComponent.decorators = [
{ type: Component, args: [{
selector: 'ng-select',
template: "<label\n *ngIf=\"label !== ''\">\n {{label}}\n</label>\n<div\n #selection\n [attr.tabindex]=\"disabled ? null : 0\"\n [ngClass]=\"{'open': isOpen, 'focus': hasFocus, 'below': isBelow, 'above': !isBelow, 'disabled': disabled}\"\n (click)=\"onSelectContainerClick($event)\"\n (focus)=\"onSelectContainerFocus()\"\n (keydown)=\"onSelectContainerKeydown($event)\">\n\n <div class=\"single\"\n *ngIf=\"!multiple\">\n <div class=\"value\"\n *ngIf=\"optionList.hasSelected\">\n <ng-container *ngTemplateOutlet=\"optionTemplate; context:{option: optionList.selection[0].wrappedOption, onDeselectOptionClick: onDeselectOptionClick}\"></ng-container>\n <span *ngIf=\"!optionTemplate\">{{optionList.selection[0].label}}</span>\n </div>\n <div class=\"placeholder\"\n *ngIf=\"!optionList.hasSelected\">\n {{placeholderView}}\n </div>\n <div class=\"clear\"\n *ngIf=\"allowClear && optionList.hasSelected\"\n (click)=\"onClearSelectionClick($event)\">\n ✕\n </div>\n <div class=\"toggle\"\n *ngIf=\"isOpen\">\n ▲\n </div>\n <div class=\"toggle\"\n *ngIf=\"!isOpen\">\n ▼\n </div>\n </div>\n\n <div class=\"multiple\"\n *ngIf=\"multiple\">\n <div class=\"option\"\n *ngFor=\"let option of optionList.selection\">\n <span class=\"deselect-option\"\n (click)=onDeselectOptionClick(option)>\n ✕\n </span>\n {{option.label}}\n </div>\n <div class=\"placeholder\"\n *ngIf=\"!filterEnabled && !optionList.hasSelected\">\n {{placeholderView}}\n </div>\n <input\n *ngIf=\"filterEnabled\"\n #filterInput\n autocomplete=\"off\"\n tabindex=\"-1\"\n [placeholder]=\"placeholderView\"\n [ngStyle]=\"{'width.px': filterInputWidth}\"\n (input)=\"onFilterInput($event.target.value)\"\n (keydown)=\"onMultipleFilterKeydown($event)\"\n (focus)=\"onMultipleFilterFocus()\"/>\n </div>\n\n</div>\n<select-dropdown\n *ngIf=\"isOpen\"\n #dropdown\n [multiple]=\"multiple\"\n [optionList]=\"optionList\"\n [notFoundMsg]=\"notFoundMsg\"\n [highlightColor]=\"highlightColor\"\n [highlightTextColor]=\"highlightTextColor\"\n [filterEnabled]=\"filterEnabled\"\n [placeholder]=\"filterPlaceholder\"\n [isBelow]=\"isBelow\"\n [width]=\"width\"\n [top]=\"top\"\n [left]=\"left\"\n [optionTemplate]=\"optionTemplate\"\n (optionClicked)=\"onDropdownOptionClicked($event)\"\n (optionsListClick)=\"onOptionsListClick()\"\n (singleFilterClick)=\"onSingleFilterClick()\"\n (singleFilterFocus)=\"onSingleFilterFocus()\"\n (singleFilterInput)=\"onFilterInput($event)\"\n (singleFilterKeydown)=\"onSingleFilterKeydown($event)\">\n</select-dropdown>\n",
providers: [SELECT_VALUE_ACCESSOR],
encapsulation: ViewEncapsulation.None,
styles: ["ng-select{display:inline-block;margin:0;position:relative;vertical-align:middle;width:100%}ng-select *{box-sizing:border-box}ng-select>div{border:1px solid #ddd;box-sizing:border-box;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;width:100%}ng-select>div.disabled{background-color:#eee;color:#aaa;cursor:default;pointer-events:none}ng-select>div>div.single{display:flex;height:30px;width:100%}ng-select>div>div.single>div.placeholder,ng-select>div>div.single>div.value{flex:1;line-height:30px;overflow:hidden;padding:0 10px;white-space:nowrap}ng-select>div>div.single>div.placeholder{color:#757575}ng-select>div>div.single>div.clear,ng-select>div>div.single>div.toggle{color:#aaa;line-height:30px;text-align:center;width:30px}ng-select>div>div.single>div.clear:hover,ng-select>div>div.single>div.toggle:hover{background-color:#ececec}ng-select>div>div.single>div.clear{font-size:18px}ng-select>div>div.single>div.toggle{font-size:14px}ng-select>div>div.multiple{display:flex;flex-flow:row wrap;height:100%;min-height:30px;padding:0 10px;width:100%}ng-select>div>div.multiple>div.option{background-color:#eee;border:1px solid #aaa;border-radius:4px;color:#333;cursor:default;display:inline-block;flex-shrink:0;font-size:14px;line-height:22px;margin:3px 5px 3px 0;padding:0 4px}ng-select>div>div.multiple>div.option span.deselect-option{color:#aaa;cursor:pointer;font-size:14px;height:20px;line-height:20px}ng-select>div>div.multiple>div.option span.deselect-option:hover{color:#555}ng-select>div>div.multiple input{background-color:transparent;border:none;cursor:pointer;height:30px;line-height:30px;padding:0}ng-select>div>div.multiple input:focus{outline:0}ng-select label{color:rgba(0,0,0,.38);display:block;font-size:13px;padding:4px 0}"]
}] }
];
/** @nocollapse */
SelectComponent.ctorParameters = function () { return [
{ type: ElementRef }
]; };
SelectComponent.propDecorators = {
options: [{ type: Input }],
allowClear: [{ type: Input }],
disabled: [{ type: Input }],
multiple: [{ type: Input }],
noFilter: [{ type: Input }],
highlightColor: [{ type: Input }],
highlightTextColor: [{ type: Input }],
notFoundMsg: [{ type: Input }],
placeholder: [{ type: Input }],
filterPlaceholder: [{ type: Input }],
label: [{ type: Input }],
opened: [{ type: Output }],
closed: [{ type: Output }],
selected: [{ type: Output }],
deselected: [{ type: Output }],
focus: [{ type: Output }],
blur: [{ type: Output }],
noOptionsFound: [{ type: Output }],
filterInputChanged: [{ type: Output }],
selectionSpan: [{ type: ViewChild, args: ['selection', { static: true },] }],
dropdown: [{ type: ViewChild, args: ['dropdown', { static: false },] }],
filterInput: [{ type: ViewChild, args: ['filterInput', { static: false },] }],
optionTemplate: [{ type: ContentChild, args: ['optionTemplate', { static: false },] }],
onWindowBlur: [{ type: HostListener, args: ['window:blur',] }],
onWindowClick: [{ type: HostListener, args: ['window:click',] }],
onWindowResize: [{ type: HostListener, args: ['window:resize',] }]
};
return SelectComponent;
}());
export { SelectComponent };
if (false) {
/** @type {?} */
SelectComponent.prototype.options;
/** @type {?} */
SelectComponent.prototype.allowClear;
/** @type {?} */
SelectComponent.prototype.disabled;
/** @type {?} */
SelectComponent.prototype.multiple;
/** @type {?} */
SelectComponent.prototype.noFilter;
/** @type {?} */
SelectComponent.prototype.highlightColor;
/** @type {?} */
SelectComponent.prototype.highlightTextColor;
/** @type {?} */
SelectComponent.prototype.notFoundMsg;
/** @type {?} */
SelectComponent.prototype.placeholder;
/** @type {?} */
SelectComponent.prototype.filterPlaceholder;
/** @type {?} */
SelectComponent.prototype.label;
/** @type {?} */
SelectComponent.prototype.opened;
/** @type {?} */
SelectComponent.prototype.closed;
/** @type {?} */
SelectComponent.prototype.selected;
/** @type {?} */
SelectComponent.prototype.deselected;
/** @type {?} */
SelectComponent.prototype.focus;
/** @type {?} */
SelectComponent.prototype.blur;
/** @type {?} */
SelectComponent.prototype.noOptionsFound;
/** @type {?} */
SelectComponent.prototype.filterInputChanged;
/** @type {?} */
SelectComponent.prototype.selectionSpan;
/** @type {?} */
SelectComponent.prototype.dropdown;
/** @type {?} */
SelectComponent.prototype.filterInput;
/** @type {?} */
SelectComponent.prototype.optionTemplate;
/**
* @type {?}
* @private
*/
SelectComponent.prototype._value;
/** @type {?} */
SelectComponent.prototype.optionList;
/** @type {?} */
SelectComponent.prototype.hasFocus;
/** @type {?} */
SelectComponent.prototype.isOpen;
/** @type {?} */
SelectComponent.prototype.isBelow;
/** @type {?} */
SelectComponent.prototype.filterEnabled;
/** @type {?} */
SelectComponent.prototype.filterInputWidth;
/**
* @type {?}
* @private
*/
SelectComponent.prototype.isDisabled;
/** @type {?} */
SelectComponent.prototype.placeholderView;
/**
* @type {?}
* @private
*/
SelectComponent.prototype.clearClicked;
/**
* @type {?}
* @private
*/
SelectComponent.prototype.selectContainerClicked;
/**
* @type {?}
* @private
*/
SelectComponent.prototype.optionListClicked;
/**
* @type {?}
* @private
*/
SelectComponent.prototype.optionClicked;
/** @type {?} */
SelectComponent.prototype.width;
/** @type {?} */
SelectComponent.prototype.top;
/** @type {?} */
SelectComponent.prototype.left;
/**
* @type {?}
* @private
*/
SelectComponent.prototype.onChange;
/**
* @type {?}
* @private
*/
SelectComponent.prototype.onTouched;
/**
* Keys. *
* @type {?}
* @private
*/
SelectComponent.prototype.KEYS;
/**
* @type {?}
* @private
*/
SelectComponent.prototype.hostElement;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"ng://ng-select/","sources":["lib/select.component.ts"],"names":[],"mappings":"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