ng2-input-autocomplete
Advanced tools
Comparing version
(function (global, factory) { | ||
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@angular/core'), require('@angular/common'), require('@angular/forms')) : | ||
typeof define === 'function' && define.amd ? define('ng2-input-autocomplete', ['exports', '@angular/core', '@angular/common', '@angular/forms'], factory) : | ||
(factory((global['ng2-input-autocomplete'] = {}),global.ng.core,global.ng.common,global.ng.forms)); | ||
}(this, (function (exports,core,common,forms) { 'use strict'; | ||
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@angular/core'), require('@angular/forms'), require('@angular/common')) : | ||
typeof define === 'function' && define.amd ? define('ng2-input-autocomplete', ['exports', '@angular/core', '@angular/forms', '@angular/common'], factory) : | ||
(global = global || self, factory(global['ng2-input-autocomplete'] = {}, global.ng.core, global.ng.forms, global.ng.common)); | ||
}(this, (function (exports, core, forms, common) { 'use strict'; | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc | ||
* Generated from: lib/autocomplete.component.ts | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -28,22 +29,22 @@ var AutocompleteComponent = /** @class */ (function () { | ||
*/ | ||
function () { | ||
if (this.config && this.config.class) { | ||
this.classList += ' ' + this.config.class; | ||
function () { | ||
if (this.config && this.config.class) { | ||
this.classList += ' ' + this.config.class; | ||
} | ||
if (this.config && this.config.max > 0) { | ||
this.maxLimit = this.config.max; | ||
} | ||
this.placeholder = 'autocomplete'; | ||
this.inputElement = (/** @type {?} */ (this.thisElement.querySelector('input'))); | ||
if (!this.isNull(this.config)) { | ||
if (!this.isNull(this.config.placeholder)) { | ||
this.placeholder = this.config.placeholder; | ||
} | ||
if (this.config && this.config.max > 0) { | ||
this.maxLimit = this.config.max; | ||
if (!this.isNull(this.config.sourceField)) { | ||
this.sourceField = this.config.sourceField; | ||
} | ||
this.placeholder = 'autocomplete'; | ||
this.inputElement = /** @type {?} */ (this.thisElement.querySelector('input')); | ||
if (!this.isNull(this.config)) { | ||
if (!this.isNull(this.config.placeholder)) { | ||
this.placeholder = this.config.placeholder; | ||
} | ||
if (!this.isNull(this.config.sourceField)) { | ||
this.sourceField = this.config.sourceField; | ||
} | ||
} | ||
this.filterItems(this.value); | ||
this.inputElement.focus(); | ||
}; | ||
} | ||
this.filterItems(this.value); | ||
this.inputElement.focus(); | ||
}; | ||
/** | ||
@@ -55,5 +56,5 @@ * @return {?} | ||
*/ | ||
function () { | ||
this.filterItems(this.value); | ||
}; | ||
function () { | ||
this.filterItems(this.value); | ||
}; | ||
/** | ||
@@ -67,27 +68,27 @@ * @param {?} event | ||
*/ | ||
function (event) { | ||
/** @type {?} */ | ||
var total = this.candidates.length; | ||
switch (event.keyCode) { | ||
case 27: | ||
this.showAutoComplete = false; | ||
break; | ||
case 38: | ||
this.selectedIndex = (total + this.selectedIndex - 1) % total; | ||
break; | ||
case 40: | ||
this.selectedIndex = (total + this.selectedIndex + 1) % total; | ||
break; | ||
case 13: | ||
if (this.candidates.length > 0) { | ||
this.onSelect(this.selectedIndex); | ||
} | ||
event.preventDefault(); | ||
break; | ||
default: | ||
this.value = event.target.value; | ||
this.inputChangedEvent.emit(this.value); | ||
break; | ||
} | ||
}; | ||
function (event) { | ||
/** @type {?} */ | ||
var total = this.candidates.length; | ||
switch (event.keyCode) { | ||
case 27: | ||
this.showAutoComplete = false; | ||
break; | ||
case 38: | ||
this.selectedIndex = (total + this.selectedIndex - 1) % total; | ||
break; | ||
case 40: | ||
this.selectedIndex = (total + this.selectedIndex + 1) % total; | ||
break; | ||
case 13: | ||
if (this.candidates.length > 0) { | ||
this.onSelect(this.selectedIndex); | ||
} | ||
event.preventDefault(); | ||
break; | ||
default: | ||
this.value = event.target.value; | ||
this.inputChangedEvent.emit(this.value); | ||
break; | ||
} | ||
}; | ||
/** | ||
@@ -101,7 +102,7 @@ * @param {?} idx | ||
*/ | ||
function (idx) { | ||
this.showAutoComplete = false; | ||
this.value = this.candidatesLabels[idx]; | ||
this.selectEvent.emit(this.candidates[idx]); | ||
}; | ||
function (idx) { | ||
this.showAutoComplete = false; | ||
this.value = this.candidatesLabels[idx]; | ||
this.selectEvent.emit(this.candidates[idx]); | ||
}; | ||
/** | ||
@@ -117,7 +118,7 @@ * @param {?} event | ||
*/ | ||
function (event, idx) { | ||
if (event.keyCode === 13) { | ||
this.onSelect(idx); | ||
} | ||
}; | ||
function (event, idx) { | ||
if (event.keyCode === 13) { | ||
this.onSelect(idx); | ||
} | ||
}; | ||
/** | ||
@@ -131,18 +132,23 @@ * @param {?} search | ||
*/ | ||
function (search) { | ||
/** @type {?} */ | ||
var field = this.sourceField; | ||
/** @type {?} */ | ||
var filterItem = this.filterItem; | ||
if (this.items) { | ||
this.candidates = this.items.filter(function (item) { | ||
return filterItem(item, field, search); | ||
}); | ||
if (this.maxLimit > 0) { | ||
this.candidates = this.candidates.slice(0, this.maxLimit); | ||
} | ||
this.buildLabels(); | ||
function (search) { | ||
/** @type {?} */ | ||
var field = this.sourceField; | ||
/** @type {?} */ | ||
var filterItem = this.filterItem; | ||
if (this.items) { | ||
this.candidates = this.items.filter((/** | ||
* @param {?} item | ||
* @return {?} | ||
*/ | ||
function (item) { | ||
return filterItem(item, field, search); | ||
})); | ||
if (this.maxLimit > 0) { | ||
this.candidates = this.candidates.slice(0, this.maxLimit); | ||
} | ||
}; | ||
this.buildLabels(); | ||
} | ||
}; | ||
/** | ||
* @private | ||
* @param {?} object | ||
@@ -153,2 +159,3 @@ * @param {?} path | ||
AutocompleteComponent.prototype.getFieldValue = /** | ||
* @private | ||
* @param {?} object | ||
@@ -158,27 +165,32 @@ * @param {?} path | ||
*/ | ||
function (object, path) { | ||
if (typeof object === 'string') { | ||
return object; | ||
} | ||
if (path instanceof Array) { | ||
/** @type {?} */ | ||
var result_1 = object; | ||
path.forEach(function (element) { | ||
if (result_1 !== null && | ||
result_1 !== undefined && | ||
result_1[element] !== null && | ||
result_1[element] !== undefined) { | ||
result_1 = result_1[element]; | ||
} | ||
else { | ||
result_1 = ''; | ||
} | ||
}); | ||
return result_1; | ||
} | ||
else { | ||
return object[path] || ''; | ||
} | ||
}; | ||
function (object, path) { | ||
if (typeof object === 'string') { | ||
return object; | ||
} | ||
if (path instanceof Array) { | ||
/** @type {?} */ | ||
var result_1 = object; | ||
path.forEach((/** | ||
* @param {?} element | ||
* @return {?} | ||
*/ | ||
function (element) { | ||
if (result_1 !== null && | ||
result_1 !== undefined && | ||
result_1[element] !== null && | ||
result_1[element] !== undefined) { | ||
result_1 = result_1[element]; | ||
} | ||
else { | ||
result_1 = ''; | ||
} | ||
})); | ||
return result_1; | ||
} | ||
else { | ||
return object[path] || ''; | ||
} | ||
}; | ||
/** | ||
* @private | ||
* @param {?} object | ||
@@ -188,24 +200,32 @@ * @return {?} | ||
AutocompleteComponent.prototype.isNull = /** | ||
* @private | ||
* @param {?} object | ||
* @return {?} | ||
*/ | ||
function (object) { | ||
return object === null || object === undefined; | ||
}; | ||
function (object) { | ||
return object === null || object === undefined; | ||
}; | ||
/** | ||
* @private | ||
* @return {?} | ||
*/ | ||
AutocompleteComponent.prototype.buildLabels = /** | ||
* @private | ||
* @return {?} | ||
*/ | ||
function () { | ||
/** @type {?} */ | ||
var field = this.sourceField; | ||
/** @type {?} */ | ||
var getFieldValue = this.getFieldValue; | ||
this.candidatesLabels = this.candidates.map(function (e) { | ||
return getFieldValue(e, field); | ||
}); | ||
}; | ||
function () { | ||
/** @type {?} */ | ||
var field = this.sourceField; | ||
/** @type {?} */ | ||
var getFieldValue = this.getFieldValue; | ||
this.candidatesLabels = this.candidates.map((/** | ||
* @param {?} e | ||
* @return {?} | ||
*/ | ||
function (e) { | ||
return getFieldValue(e, field); | ||
})); | ||
}; | ||
/** | ||
* @private | ||
* @param {?} item | ||
@@ -217,2 +237,3 @@ * @param {?} path | ||
AutocompleteComponent.prototype.filterItem = /** | ||
* @private | ||
* @param {?} item | ||
@@ -223,30 +244,34 @@ * @param {?} path | ||
*/ | ||
function (item, path, search) { | ||
if (search === null || search === undefined || search.length === 0) { | ||
return true; | ||
} | ||
/** @type {?} */ | ||
var result; | ||
if (typeof item === 'string') { | ||
result = item; | ||
} | ||
else if (path instanceof Array) { | ||
result = item; | ||
path.forEach(function (element) { | ||
if (result !== null && | ||
result !== undefined && | ||
result[element] !== null && | ||
result[element] !== undefined) { | ||
result = result[element]; | ||
} | ||
else { | ||
result = ''; | ||
} | ||
}); | ||
} | ||
else { | ||
result = item[path] || ''; | ||
} | ||
return result.toLowerCase().indexOf(search.toLowerCase()) >= 0; | ||
}; | ||
function (item, path, search) { | ||
if (search === null || search === undefined || search.length === 0) { | ||
return true; | ||
} | ||
/** @type {?} */ | ||
var result; | ||
if (typeof item === 'string') { | ||
result = item; | ||
} | ||
else if (path instanceof Array) { | ||
result = item; | ||
path.forEach((/** | ||
* @param {?} element | ||
* @return {?} | ||
*/ | ||
function (element) { | ||
if (result !== null && | ||
result !== undefined && | ||
result[element] !== null && | ||
result[element] !== undefined) { | ||
result = result[element]; | ||
} | ||
else { | ||
result = ''; | ||
} | ||
})); | ||
} | ||
else { | ||
result = item[path] || ''; | ||
} | ||
return result.toLowerCase().indexOf(search.toLowerCase()) >= 0; | ||
}; | ||
AutocompleteComponent.decorators = [ | ||
@@ -261,7 +286,5 @@ { type: core.Component, args: [{ | ||
/** @nocollapse */ | ||
AutocompleteComponent.ctorParameters = function () { | ||
return [ | ||
{ type: core.ElementRef } | ||
]; | ||
}; | ||
AutocompleteComponent.ctorParameters = function () { return [ | ||
{ type: core.ElementRef } | ||
]; }; | ||
AutocompleteComponent.propDecorators = { | ||
@@ -275,2 +298,40 @@ items: [{ type: core.Input }], | ||
}()); | ||
if (false) { | ||
/** @type {?} */ | ||
AutocompleteComponent.prototype.classList; | ||
/** @type {?} */ | ||
AutocompleteComponent.prototype.items; | ||
/** @type {?} */ | ||
AutocompleteComponent.prototype.config; | ||
/** @type {?} */ | ||
AutocompleteComponent.prototype.selectEvent; | ||
/** @type {?} */ | ||
AutocompleteComponent.prototype.inputChangedEvent; | ||
/** @type {?} */ | ||
AutocompleteComponent.prototype.inputElement; | ||
/** @type {?} */ | ||
AutocompleteComponent.prototype.value; | ||
/** @type {?} */ | ||
AutocompleteComponent.prototype.candidates; | ||
/** @type {?} */ | ||
AutocompleteComponent.prototype.candidatesLabels; | ||
/** @type {?} */ | ||
AutocompleteComponent.prototype.selectedIndex; | ||
/** @type {?} */ | ||
AutocompleteComponent.prototype.showAutoComplete; | ||
/** @type {?} */ | ||
AutocompleteComponent.prototype.placeholder; | ||
/** @type {?} */ | ||
AutocompleteComponent.prototype.maxLimit; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
AutocompleteComponent.prototype.sourceField; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
AutocompleteComponent.prototype.thisElement; | ||
} | ||
var AutocompleteDirective = /** @class */ (function () { | ||
@@ -285,3 +346,7 @@ function AutocompleteDirective(resolver, viewContainerRef) { | ||
this.reset = false; | ||
this.hideAutocomplete = function (event) { | ||
this.hideAutocomplete = (/** | ||
* @param {?=} event | ||
* @return {?} | ||
*/ | ||
function (event) { | ||
if (!_this.componentRef) { | ||
@@ -301,4 +366,8 @@ return; | ||
} | ||
}; | ||
this.onInputChanged = function (val) { | ||
}); | ||
this.onInputChanged = (/** | ||
* @param {?} val | ||
* @return {?} | ||
*/ | ||
function (val) { | ||
_this.inputElement.value = val; | ||
@@ -313,4 +382,8 @@ if (val !== _this.ngModel) { | ||
_this.inputChangedEvent.emit(val); | ||
}; | ||
this.onSelect = function (item) { | ||
}); | ||
this.onSelect = (/** | ||
* @param {?} item | ||
* @return {?} | ||
*/ | ||
function (item) { | ||
/** @type {?} */ | ||
@@ -329,3 +402,3 @@ var component = _this.componentRef.instance; | ||
_this.hideAutocomplete(); | ||
}; | ||
}); | ||
this.thisElement = this.viewContainerRef.element.nativeElement; | ||
@@ -339,8 +412,8 @@ } | ||
*/ | ||
function () { | ||
if (this.thisElement.tagName.toLowerCase() === 'form') { | ||
return; | ||
} | ||
this.createDiv(); | ||
}; | ||
function () { | ||
if (this.thisElement.tagName.toLowerCase() === 'form') { | ||
return; | ||
} | ||
this.createDiv(); | ||
}; | ||
/** | ||
@@ -352,9 +425,9 @@ * @return {?} | ||
*/ | ||
function () { | ||
if (this.componentRef) { | ||
this.componentRef.instance.selectEvent.unsubscribe(); | ||
this.componentRef.instance.inputChangedEvent.unsubscribe(); | ||
} | ||
document.removeEventListener('click', this.hideAutocomplete); | ||
}; | ||
function () { | ||
if (this.componentRef) { | ||
this.componentRef.instance.selectEvent.unsubscribe(); | ||
this.componentRef.instance.inputChangedEvent.unsubscribe(); | ||
} | ||
document.removeEventListener('click', this.hideAutocomplete); | ||
}; | ||
/** | ||
@@ -368,10 +441,10 @@ * @param {?} changes | ||
*/ | ||
function (changes) { | ||
if (changes['items'] && this.componentRef) { | ||
/** @type {?} */ | ||
var component = this.componentRef.instance; | ||
component.items = changes['items'].currentValue; | ||
component.filterItems(component.value); | ||
} | ||
}; | ||
function (changes) { | ||
if (changes['items'] && this.componentRef) { | ||
/** @type {?} */ | ||
var component = this.componentRef.instance; | ||
component.items = changes['items'].currentValue; | ||
component.filterItems(component.value); | ||
} | ||
}; | ||
/** | ||
@@ -383,17 +456,23 @@ * @return {?} | ||
*/ | ||
function () { | ||
var _this = this; | ||
/** @type {?} */ | ||
var input = this.getInputElement(); | ||
if (this.control) { | ||
this.control.valueChanges.subscribe(function () { | ||
_this.reset = true; | ||
}); | ||
} | ||
if (input.form) { | ||
input.form.addEventListener('reset', function () { | ||
_this.reset = true; | ||
}); | ||
} | ||
}; | ||
function () { | ||
var _this = this; | ||
/** @type {?} */ | ||
var input = this.getInputElement(); | ||
if (this.control) { | ||
this.control.valueChanges.subscribe((/** | ||
* @return {?} | ||
*/ | ||
function () { | ||
_this.reset = true; | ||
})); | ||
} | ||
if (input.form) { | ||
input.form.addEventListener('reset', (/** | ||
* @return {?} | ||
*/ | ||
function () { | ||
_this.reset = true; | ||
})); | ||
} | ||
}; | ||
/** | ||
@@ -407,8 +486,8 @@ * @param {?} event | ||
*/ | ||
function (event) { | ||
this.hideAutocomplete(); | ||
if (event === this.thisElement) { | ||
this.createAutocomplete(); | ||
} | ||
}; | ||
function (event) { | ||
this.hideAutocomplete(); | ||
if (event === this.thisElement) { | ||
this.createAutocomplete(); | ||
} | ||
}; | ||
/** | ||
@@ -420,68 +499,72 @@ * @return {?} | ||
*/ | ||
function () { | ||
/** @type {?} */ | ||
var input = /** @type {?} */ (this.thisElement); | ||
if (this.thisElement.tagName !== 'INPUT' && this.autocompleteElement) { | ||
input = /** @type {?} */ (this.thisElement.querySelector('input')); | ||
} | ||
return input; | ||
}; | ||
function () { | ||
/** @type {?} */ | ||
var input = (/** @type {?} */ (this.thisElement)); | ||
if (this.thisElement.tagName !== 'INPUT' && this.autocompleteElement) { | ||
input = (/** @type {?} */ (this.thisElement.querySelector('input'))); | ||
} | ||
return input; | ||
}; | ||
/** | ||
* @private | ||
* @return {?} | ||
*/ | ||
AutocompleteDirective.prototype.createDiv = /** | ||
* @private | ||
* @return {?} | ||
*/ | ||
function () { | ||
/** @type {?} */ | ||
var element = document.createElement('div'); | ||
element.style.display = 'inline-block'; | ||
element.style.position = 'relative'; | ||
this.thisElement.parentElement.insertBefore(element, this.thisElement.nextSibling); | ||
element.appendChild(this.thisElement); | ||
document.addEventListener('click', this.hideAutocomplete); | ||
}; | ||
function () { | ||
/** @type {?} */ | ||
var element = document.createElement('div'); | ||
element.style.display = 'inline-block'; | ||
element.style.position = 'relative'; | ||
this.thisElement.parentElement.insertBefore(element, this.thisElement.nextSibling); | ||
element.appendChild(this.thisElement); | ||
document.addEventListener('click', this.hideAutocomplete); | ||
}; | ||
/** | ||
* @private | ||
* @return {?} | ||
*/ | ||
AutocompleteDirective.prototype.createAutocomplete = /** | ||
* @private | ||
* @return {?} | ||
*/ | ||
function () { | ||
function () { | ||
/** @type {?} */ | ||
var factory = this.resolver.resolveComponentFactory(AutocompleteComponent); | ||
this.componentRef = this.viewContainerRef.createComponent(factory); | ||
/** @type {?} */ | ||
var component = this.componentRef.instance; | ||
component.config = this.config; | ||
component.items = this.items; | ||
component.selectEvent.subscribe(this.onSelect); | ||
component.inputChangedEvent.subscribe(this.onInputChanged); | ||
this.autocompleteElement = this.componentRef.location.nativeElement; | ||
this.autocompleteElement.style.display = 'none'; | ||
this.inputElement = this.getInputElement(); | ||
if (this.thisElement.tagName !== 'INPUT' && this.autocompleteElement) { | ||
this.inputElement.parentElement.insertBefore(this.autocompleteElement, this.inputElement.nextSibling); | ||
} | ||
if (this.reset) { | ||
this.ngModel = ''; | ||
this.reset = false; | ||
} | ||
this.inputElement.value = this.ngModel ? this.ngModel : ''; | ||
component.value = this.inputElement.value; | ||
this.tabIndex = this.inputElement['tabIndex']; | ||
this.inputElement['tabIndex'] = -100; | ||
if (this.componentRef) { | ||
/** @type {?} */ | ||
var factory = this.resolver.resolveComponentFactory(AutocompleteComponent); | ||
this.componentRef = this.viewContainerRef.createComponent(factory); | ||
var rect = this.thisElement.getBoundingClientRect(); | ||
/** @type {?} */ | ||
var component = this.componentRef.instance; | ||
component.config = this.config; | ||
component.items = this.items; | ||
component.selectEvent.subscribe(this.onSelect); | ||
component.inputChangedEvent.subscribe(this.onInputChanged); | ||
this.autocompleteElement = this.componentRef.location.nativeElement; | ||
this.autocompleteElement.style.display = 'none'; | ||
this.inputElement = this.getInputElement(); | ||
if (this.thisElement.tagName !== 'INPUT' && this.autocompleteElement) { | ||
this.inputElement.parentElement.insertBefore(this.autocompleteElement, this.inputElement.nextSibling); | ||
} | ||
if (this.reset) { | ||
this.ngModel = ''; | ||
this.reset = false; | ||
} | ||
this.inputElement.value = this.ngModel ? this.ngModel : ''; | ||
component.value = this.inputElement.value; | ||
this.tabIndex = this.inputElement['tabIndex']; | ||
this.inputElement['tabIndex'] = -100; | ||
if (this.componentRef) { | ||
/** @type {?} */ | ||
var rect = this.thisElement.getBoundingClientRect(); | ||
/** @type {?} */ | ||
var style = this.autocompleteElement.style; | ||
style.width = rect.width + 'px'; | ||
style.position = 'absolute'; | ||
style.zIndex = '1'; | ||
style.top = '0'; | ||
style.left = '0'; | ||
style.display = 'inline-block'; | ||
} | ||
}; | ||
var style = this.autocompleteElement.style; | ||
style.width = rect.width + 'px'; | ||
style.position = 'absolute'; | ||
style.zIndex = '1'; | ||
style.top = '0'; | ||
style.left = '0'; | ||
style.display = 'inline-block'; | ||
} | ||
}; | ||
AutocompleteDirective.decorators = [ | ||
@@ -494,8 +577,6 @@ { type: core.Directive, args: [{ | ||
/** @nocollapse */ | ||
AutocompleteDirective.ctorParameters = function () { | ||
return [ | ||
{ type: core.ComponentFactoryResolver }, | ||
{ type: core.ViewContainerRef } | ||
]; | ||
}; | ||
AutocompleteDirective.ctorParameters = function () { return [ | ||
{ type: core.ComponentFactoryResolver }, | ||
{ type: core.ViewContainerRef } | ||
]; }; | ||
AutocompleteDirective.propDecorators = { | ||
@@ -513,6 +594,66 @@ config: [{ type: core.Input }], | ||
}()); | ||
if (false) { | ||
/** @type {?} */ | ||
AutocompleteDirective.prototype.config; | ||
/** @type {?} */ | ||
AutocompleteDirective.prototype.items; | ||
/** @type {?} */ | ||
AutocompleteDirective.prototype.ngModel; | ||
/** @type {?} */ | ||
AutocompleteDirective.prototype.control; | ||
/** @type {?} */ | ||
AutocompleteDirective.prototype.ngModelChange; | ||
/** @type {?} */ | ||
AutocompleteDirective.prototype.inputChangedEvent; | ||
/** @type {?} */ | ||
AutocompleteDirective.prototype.selectEvent; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
AutocompleteDirective.prototype.componentRef; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
AutocompleteDirective.prototype.thisElement; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
AutocompleteDirective.prototype.autocompleteElement; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
AutocompleteDirective.prototype.inputElement; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
AutocompleteDirective.prototype.tabIndex; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
AutocompleteDirective.prototype.reset; | ||
/** @type {?} */ | ||
AutocompleteDirective.prototype.hideAutocomplete; | ||
/** @type {?} */ | ||
AutocompleteDirective.prototype.onInputChanged; | ||
/** @type {?} */ | ||
AutocompleteDirective.prototype.onSelect; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
AutocompleteDirective.prototype.resolver; | ||
/** @type {?} */ | ||
AutocompleteDirective.prototype.viewContainerRef; | ||
} | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc | ||
* Generated from: lib/autocomplete.module.ts | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -528,7 +669,7 @@ var AutocompleteModule = /** @class */ (function () { | ||
*/ | ||
function () { | ||
return { | ||
ngModule: AutocompleteModule | ||
}; | ||
function () { | ||
return { | ||
ngModule: AutocompleteModule | ||
}; | ||
}; | ||
AutocompleteModule.decorators = [ | ||
@@ -545,12 +686,2 @@ { type: core.NgModule, args: [{ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc | ||
*/ | ||
exports.AutocompleteComponent = AutocompleteComponent; | ||
@@ -563,3 +694,2 @@ exports.AutocompleteDirective = AutocompleteDirective; | ||
}))); | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"ng2-input-autocomplete.umd.js.map","sources":["ng://ng2-input-autocomplete/lib/autocomplete.component.ts","ng://ng2-input-autocomplete/lib/autocomplete.module.ts"],"sourcesContent":["/*\n  MIT LICENSE @liuy97\n*/\nimport {\n  Component,\n  ComponentFactoryResolver,\n  ComponentRef,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  AfterViewInit,\n  Output,\n  SimpleChange,\n  ViewContainerRef,\n  HostBinding\n} from '@angular/core';\nimport {FormControl} from '@angular/forms';\n\n@Component({\n  // tslint:disable-next-line\n  selector: 'ng2-input-autocomplete',\n  template: `\n  <div [ngClass]=\"classList\">\n    <input type=\"text\"\n      placeholder=\"{{placeholder}}\"\n      (blur)=\"showAutoComplete = false;\"\n      (focus)=\"showAutoComplete = true;\"\n      [value]=\"value\"\n      (keyup)=\"enterText($event)\">\n    <ul *ngIf=\"showAutoComplete && candidates && candidates.length > 0\">\n      <li *ngFor=\"let candidate of candidates; let idx = index\"\n        [ngClass]=\"{ active: (idx === selectedIndex) }\"\n        (keyup)=\"onKeyUpEvent($event, idx)\"\n        (mouseover)=\"selectedIndex = idx;\"\n        (mousedown)=\"onSelect(idx)\">\n        {{candidatesLabels[idx]}}\n      </li>\n    </ul>\n  </div>`,\n  styles: [\n    `.autocomplete ul {\n       position: absolute;\n       left: 0;\n       width: 100%;\n       border-left: 1px solid #888;\n       border-right: 1px solid #888;\n       border-bottom: 1px solid #888;\n       list-style: none;\n       padding-left: 0px;\n       margin-top: 2px;\n       background-color: #fff;\n       z-index: 100;\n     }\n     .autocomplete li {\n       text-align: left;\n       list-style: none;\n       width: 100%;\n       padding: 0.4em 0 0.4em 0;\n     }\n     .autocomplete li.active {\n       width: 100%;\n       background-color: #4bf;\n     }\n\n     .autocomplete .highlight {\n       background-color: #e2e2e2;\n     }\n     .autocomplete li.active .highlight {\n       background: #666;\n       color: #fff;\n     }`\n  ]\n})\nexport class AutocompleteComponent implements OnInit, OnChanges {\n  classList = 'autocomplete';\n  @Input() items: any[];\n  @Input() config: any;\n  @Output() selectEvent: EventEmitter<any> = new EventEmitter<any>();\n  @Output() inputChangedEvent: EventEmitter<any> = new EventEmitter<any>();\n  inputElement: HTMLInputElement;\n  value: string;\n  candidates: any[];\n  candidatesLabels: any[];\n  selectedIndex: number;\n  showAutoComplete: boolean;\n  placeholder: string;\n  maxLimit = 0;\n  private sourceField: any;\n  private thisElement: HTMLElement;\n\n  constructor(elementRef: ElementRef) {\n    this.thisElement = elementRef.nativeElement;\n    this.selectedIndex = 0;\n    this.showAutoComplete = false;\n    this.value = '';\n  }\n\n  ngOnInit() {\n    if (this.config && this.config.class) {\n      this.classList += ' ' + this.config.class;\n    }\n    if (this.config && this.config.max > 0) {\n      this.maxLimit = this.config.max;\n    }\n    this.placeholder = 'autocomplete';\n    this.inputElement = this.thisElement.querySelector(\n      'input'\n    ) as HTMLInputElement;\n\n    if (!this.isNull(this.config)) {\n      if (!this.isNull(this.config.placeholder)) {\n        this.placeholder = this.config.placeholder;\n      }\n      if (!this.isNull(this.config.sourceField)) {\n        this.sourceField = this.config.sourceField;\n      }\n    }\n    this.filterItems(this.value);\n    this.inputElement.focus();\n  }\n\n  ngOnChanges() {\n    this.filterItems(this.value);\n  }\n\n  enterText(event: any) {\n    const total = this.candidates.length;\n    switch (event.keyCode) {\n      case 27:\n        this.showAutoComplete = false;\n        break;\n      case 38:\n        this.selectedIndex = (total + this.selectedIndex - 1) % total;\n        break;\n      case 40:\n        this.selectedIndex = (total + this.selectedIndex + 1) % total;\n        break;\n      case 13:\n        if (this.candidates.length > 0) {\n          this.onSelect(this.selectedIndex);\n        }\n        event.preventDefault();\n        break;\n      default:\n        this.value = event.target.value;\n        this.inputChangedEvent.emit(this.value);\n        break;\n    }\n  }\n\n  onSelect(idx: number) {\n    this.showAutoComplete = false;\n    this.value = this.candidatesLabels[idx];\n    this.selectEvent.emit(this.candidates[idx]);\n  }\n\n  onKeyUpEvent(event: KeyboardEvent, idx: number): void {\n    if (event.keyCode === 13) {\n      this.onSelect(idx);\n    }\n }\n\n  filterItems(search: string) {\n    const field = this.sourceField;\n    const filterItem = this.filterItem;\n    if (this.items) {\n      this.candidates = this.items.filter(item => {\n        return filterItem(item, field, search);\n      });\n      if (this.maxLimit > 0) {\n        this.candidates = this.candidates.slice(0, this.maxLimit);\n      }\n      this.buildLabels();\n    }\n  }\n\n  private getFieldValue(object: any, path: any) {\n    if (typeof object === 'string') {\n      return object;\n    }\n    if (path instanceof Array) {\n      let result: any = object;\n      path.forEach((element: any) => {\n        if (\n          result !== null &&\n          result !== undefined &&\n          result[element] !== null &&\n          result[element] !== undefined\n        ) {\n          result = result[element];\n        } else {\n          result = '';\n        }\n      });\n      return result;\n    } else {\n      return object[path] || '';\n    }\n  }\n\n  private isNull(object: any) {\n    return object === null || object === undefined;\n  }\n\n  private buildLabels() {\n    const field = this.sourceField;\n    const getFieldValue = this.getFieldValue;\n    this.candidatesLabels = this.candidates.map((e: any) =>\n      getFieldValue(e, field)\n    );\n  }\n\n  private filterItem(item: any, path: any, search: string) {\n    if (search === null || search === undefined || search.length === 0) {\n      return true;\n    }\n    let result: any;\n    if (typeof item === 'string') {\n      result = item;\n    } else if (path instanceof Array) {\n      result = item;\n      path.forEach((element: any) => {\n        if (\n          result !== null &&\n          result !== undefined &&\n          result[element] !== null &&\n          result[element] !== undefined\n        ) {\n          result = result[element];\n        } else {\n          result = '';\n        }\n      });\n    } else {\n      result = item[path] || '';\n    }\n    return result.toLowerCase().indexOf(search.toLowerCase()) >= 0;\n  }\n}\n\n@Directive({\n  // tslint:disable-next-line\n  selector: '[input-autocomplete]'\n})\nexport class AutocompleteDirective implements OnInit, OnDestroy, OnChanges, AfterViewInit {\n  @Input() config: any;\n  @Input() items: any;\n  @Input() ngModel: string;\n  @Input() control: FormControl;\n  @Output() ngModelChange = new EventEmitter();\n  @Output() inputChangedEvent = new EventEmitter();\n  @Output() selectEvent = new EventEmitter();\n\n  private componentRef: ComponentRef<AutocompleteComponent>;\n  private thisElement: HTMLElement;\n  private autocompleteElement: HTMLElement;\n  private inputElement: HTMLInputElement;\n  private tabIndex: number;\n  private reset = false;\n\n  constructor(\n    private resolver: ComponentFactoryResolver,\n    public viewContainerRef: ViewContainerRef\n  ) {\n    this.thisElement = this.viewContainerRef.element.nativeElement;\n  }\n\n  ngOnInit() {\n    if (this.thisElement.tagName.toLowerCase() === 'form') {\n      return;\n    }\n    this.createDiv();\n  }\n\n  ngOnDestroy() {\n    if (this.componentRef) {\n      this.componentRef.instance.selectEvent.unsubscribe();\n      this.componentRef.instance.inputChangedEvent.unsubscribe();\n    }\n    document.removeEventListener('click', this.hideAutocomplete);\n  }\n\n  ngOnChanges(changes: { [propKey: string]: SimpleChange }) {\n    if (changes['items'] && this.componentRef) {\n      const component = this.componentRef.instance;\n      component.items = changes['items'].currentValue;\n      component.filterItems(component.value);\n    }\n  }\n\n  ngAfterViewInit() {\n    const input = this.getInputElement();\n    if (this.control) {\n      this.control.valueChanges.subscribe(() => {\n        this.reset = true;\n      });\n    }\n    if (input.form) {\n      input.form.addEventListener('reset', () => {\n        this.reset = true;\n      });\n    }\n  }\n\n  @HostListener('click', ['$event.target'])\n  @HostListener('focus', ['$event.target'])\n  showAutocomplete(event: any) {\n    this.hideAutocomplete();\n    if (event === this.thisElement) {\n      this.createAutocomplete();\n    }\n  }\n\n  getInputElement() {\n    let input = this.thisElement as HTMLInputElement;\n\n    if (this.thisElement.tagName !== 'INPUT' && this.autocompleteElement) {\n      input = this.thisElement.querySelector(\n        'input'\n      ) as HTMLInputElement;\n    }\n\n    return input;\n  }\n\n  hideAutocomplete = (event?: any): void => {\n    if (!this.componentRef) {\n      return;\n    }\n    if (event && event.target && this.thisElement && event.target === this.thisElement.parentElement) {\n      return;\n    }\n    if (\n      !event ||\n      (event.target !== this.thisElement && event.type === 'click')\n    ) {\n      this.componentRef.destroy();\n      this.componentRef = undefined;\n    }\n    if (this.inputElement['tabIndex'] < 0) {\n      this.inputElement['tabIndex'] = this.tabIndex;\n    }\n  }\n\n  onInputChanged = (val: string) => {\n    this.inputElement.value = val;\n    if (val !== this.ngModel) {\n      this.ngModel = val;\n      this.ngModelChange.emit(val);\n    }\n    const component = this.componentRef.instance;\n    component.filterItems(val);\n    this.inputChangedEvent.emit(val);\n  }\n\n  onSelect = (item: any) => {\n    const component = this.componentRef.instance;\n    const val = component.value;\n    if (val !== this.ngModel) {\n      this.ngModel = val;\n      this.ngModelChange.emit(val);\n    }\n    this.selectEvent.emit(item);\n    if (this.inputElement) {\n      this.inputElement.value = '' + val;\n    }\n    this.hideAutocomplete();\n  }\n\n  private createDiv() {\n    const element = document.createElement('div');\n    element.style.display = 'inline-block';\n    element.style.position = 'relative';\n    this.thisElement.parentElement.insertBefore(\n      element,\n      this.thisElement.nextSibling\n    );\n    element.appendChild(this.thisElement);\n    document.addEventListener('click', this.hideAutocomplete);\n  }\n\n  private createAutocomplete() {\n    const factory = this.resolver.resolveComponentFactory(\n      AutocompleteComponent\n    );\n    this.componentRef = this.viewContainerRef.createComponent(factory);\n    const component = this.componentRef.instance;\n    component.config = this.config;\n    component.items = this.items;\n    component.selectEvent.subscribe(this.onSelect);\n    component.inputChangedEvent.subscribe(this.onInputChanged);\n    this.autocompleteElement = this.componentRef.location.nativeElement;\n    this.autocompleteElement.style.display = 'none';\n    this.inputElement = this.getInputElement();\n    if (this.thisElement.tagName !== 'INPUT' && this.autocompleteElement) {\n      this.inputElement.parentElement.insertBefore(\n        this.autocompleteElement,\n        this.inputElement.nextSibling\n      );\n    }\n\n    if (this.reset) {\n      this.ngModel = '';\n      this.reset = false;\n    }\n\n    this.inputElement.value = this.ngModel ? this.ngModel : '';\n    component.value = this.inputElement.value;\n    this.tabIndex = this.inputElement['tabIndex'];\n    this.inputElement['tabIndex'] = -100;\n    if (this.componentRef) {\n      const rect = this.thisElement.getBoundingClientRect();\n      const style = this.autocompleteElement.style;\n      style.width = rect.width + 'px';\n      style.position = 'absolute';\n      style.zIndex = '1';\n      style.top = '0';\n      style.left = '0';\n      style.display = 'inline-block';\n    }\n  }\n}\n","import { NgModule, ModuleWithProviders } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormsModule } from '@angular/forms';\nimport { AutocompleteComponent, AutocompleteDirective } from './autocomplete.component';\n\n@NgModule({\n  imports: [CommonModule, FormsModule],\n  declarations: [AutocompleteComponent, AutocompleteDirective],\n  exports: [AutocompleteComponent, AutocompleteDirective],\n  entryComponents: [AutocompleteComponent]\n})\nexport class AutocompleteModule {\n  static forRoot(): ModuleWithProviders {\n    return {\n      ngModule: AutocompleteModule\n    };\n  }\n}\n\n"],"names":["EventEmitter","Component","ElementRef","Input","Output","Directive","ComponentFactoryResolver","ViewContainerRef","HostListener","NgModule","CommonModule","FormsModule"],"mappings":"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"} | ||
//# sourceMappingURL=ng2-input-autocomplete.umd.js.map |
@@ -1,2 +0,2 @@ | ||
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/core"),require("@angular/common"),require("@angular/forms")):"function"==typeof define&&define.amd?define("ng2-input-autocomplete",["exports","@angular/core","@angular/common","@angular/forms"],t):t(e["ng2-input-autocomplete"]={},e.ng.core,e.ng.common,e.ng.forms)}(this,function(e,i,t,n){"use strict";var o=function(){function e(e){this.classList="autocomplete",this.selectEvent=new i.EventEmitter,this.inputChangedEvent=new i.EventEmitter,this.maxLimit=0,this.thisElement=e.nativeElement,this.selectedIndex=0,this.showAutoComplete=!1,this.value=""}return e.prototype.ngOnInit=function(){this.config&&this.config["class"]&&(this.classList+=" "+this.config["class"]),this.config&&0<this.config.max&&(this.maxLimit=this.config.max),this.placeholder="autocomplete",this.inputElement=this.thisElement.querySelector("input"),this.isNull(this.config)||(this.isNull(this.config.placeholder)||(this.placeholder=this.config.placeholder),this.isNull(this.config.sourceField)||(this.sourceField=this.config.sourceField)),this.filterItems(this.value),this.inputElement.focus()},e.prototype.ngOnChanges=function(){this.filterItems(this.value)},e.prototype.enterText=function(e){var t=this.candidates.length;switch(e.keyCode){case 27:this.showAutoComplete=!1;break;case 38:this.selectedIndex=(t+this.selectedIndex-1)%t;break;case 40:this.selectedIndex=(t+this.selectedIndex+1)%t;break;case 13:0<this.candidates.length&&this.onSelect(this.selectedIndex),e.preventDefault();break;default:this.value=e.target.value,this.inputChangedEvent.emit(this.value)}},e.prototype.onSelect=function(e){this.showAutoComplete=!1,this.value=this.candidatesLabels[e],this.selectEvent.emit(this.candidates[e])},e.prototype.onKeyUpEvent=function(e,t){13===e.keyCode&&this.onSelect(t)},e.prototype.filterItems=function(t){var n=this.sourceField,i=this.filterItem;this.items&&(this.candidates=this.items.filter(function(e){return i(e,n,t)}),0<this.maxLimit&&(this.candidates=this.candidates.slice(0,this.maxLimit)),this.buildLabels())},e.prototype.getFieldValue=function(e,t){if("string"==typeof e)return e;if(t instanceof Array){var n=e;return t.forEach(function(e){n=null!==n&&n!==undefined&&null!==n[e]&&n[e]!==undefined?n[e]:""}),n}return e[t]||""},e.prototype.isNull=function(e){return null===e||e===undefined},e.prototype.buildLabels=function(){var t=this.sourceField,n=this.getFieldValue;this.candidatesLabels=this.candidates.map(function(e){return n(e,t)})},e.prototype.filterItem=function(e,t,n){return null===n||n===undefined||0===n.length||("string"==typeof e?i=e:t instanceof Array?(i=e,t.forEach(function(e){i=null!==i&&i!==undefined&&null!==i[e]&&i[e]!==undefined?i[e]:""})):i=e[t]||"",0<=i.toLowerCase().indexOf(n.toLowerCase()));var i},e.decorators=[{type:i.Component,args:[{selector:"ng2-input-autocomplete",template:'\n <div [ngClass]="classList">\n <input type="text"\n placeholder="{{placeholder}}"\n (blur)="showAutoComplete = false;"\n (focus)="showAutoComplete = true;"\n [value]="value"\n (keyup)="enterText($event)">\n <ul *ngIf="showAutoComplete && candidates && candidates.length > 0">\n <li *ngFor="let candidate of candidates; let idx = index"\n [ngClass]="{ active: (idx === selectedIndex) }"\n (keyup)="onKeyUpEvent($event, idx)"\n (mouseover)="selectedIndex = idx;"\n (mousedown)="onSelect(idx)">\n {{candidatesLabels[idx]}}\n </li>\n </ul>\n </div>',styles:[".autocomplete ul {\n position: absolute;\n left: 0;\n width: 100%;\n border-left: 1px solid #888;\n border-right: 1px solid #888;\n border-bottom: 1px solid #888;\n list-style: none;\n padding-left: 0px;\n margin-top: 2px;\n background-color: #fff;\n z-index: 100;\n }\n .autocomplete li {\n text-align: left;\n list-style: none;\n width: 100%;\n padding: 0.4em 0 0.4em 0;\n }\n .autocomplete li.active {\n width: 100%;\n background-color: #4bf;\n }\n\n .autocomplete .highlight {\n background-color: #e2e2e2;\n }\n .autocomplete li.active .highlight {\n background: #666;\n color: #fff;\n }"]}]}],e.ctorParameters=function(){return[{type:i.ElementRef}]},e.propDecorators={items:[{type:i.Input}],config:[{type:i.Input}],selectEvent:[{type:i.Output}],inputChangedEvent:[{type:i.Output}]},e}(),s=function(){function e(e,t){var n=this;this.resolver=e,this.viewContainerRef=t,this.ngModelChange=new i.EventEmitter,this.inputChangedEvent=new i.EventEmitter,this.selectEvent=new i.EventEmitter,this.reset=!1,this.hideAutocomplete=function(e){n.componentRef&&(e&&e.target&&n.thisElement&&e.target===n.thisElement.parentElement||((!e||e.target!==n.thisElement&&"click"===e.type)&&(n.componentRef.destroy(),n.componentRef=undefined),n.inputElement.tabIndex<0&&(n.inputElement.tabIndex=n.tabIndex)))},this.onInputChanged=function(e){(n.inputElement.value=e)!==n.ngModel&&(n.ngModel=e,n.ngModelChange.emit(e)),n.componentRef.instance.filterItems(e),n.inputChangedEvent.emit(e)},this.onSelect=function(e){var t=n.componentRef.instance.value;t!==n.ngModel&&(n.ngModel=t,n.ngModelChange.emit(t)),n.selectEvent.emit(e),n.inputElement&&(n.inputElement.value=""+t),n.hideAutocomplete()},this.thisElement=this.viewContainerRef.element.nativeElement}return e.prototype.ngOnInit=function(){"form"!==this.thisElement.tagName.toLowerCase()&&this.createDiv()},e.prototype.ngOnDestroy=function(){this.componentRef&&(this.componentRef.instance.selectEvent.unsubscribe(),this.componentRef.instance.inputChangedEvent.unsubscribe()),document.removeEventListener("click",this.hideAutocomplete)},e.prototype.ngOnChanges=function(e){if(e.items&&this.componentRef){var t=this.componentRef.instance;t.items=e.items.currentValue,t.filterItems(t.value)}},e.prototype.ngAfterViewInit=function(){var e=this,t=this.getInputElement();this.control&&this.control.valueChanges.subscribe(function(){e.reset=!0}),t.form&&t.form.addEventListener("reset",function(){e.reset=!0})},e.prototype.showAutocomplete=function(e){this.hideAutocomplete(),e===this.thisElement&&this.createAutocomplete()},e.prototype.getInputElement=function(){var e=this.thisElement;return"INPUT"!==this.thisElement.tagName&&this.autocompleteElement&&(e=this.thisElement.querySelector("input")),e},e.prototype.createDiv=function(){var e=document.createElement("div");e.style.display="inline-block",e.style.position="relative",this.thisElement.parentElement.insertBefore(e,this.thisElement.nextSibling),e.appendChild(this.thisElement),document.addEventListener("click",this.hideAutocomplete)},e.prototype.createAutocomplete=function(){var e=this.resolver.resolveComponentFactory(o);this.componentRef=this.viewContainerRef.createComponent(e);var t=this.componentRef.instance;if(t.config=this.config,t.items=this.items,t.selectEvent.subscribe(this.onSelect),t.inputChangedEvent.subscribe(this.onInputChanged),this.autocompleteElement=this.componentRef.location.nativeElement,this.autocompleteElement.style.display="none",this.inputElement=this.getInputElement(),"INPUT"!==this.thisElement.tagName&&this.autocompleteElement&&this.inputElement.parentElement.insertBefore(this.autocompleteElement,this.inputElement.nextSibling),this.reset&&(this.ngModel="",this.reset=!1),this.inputElement.value=this.ngModel?this.ngModel:"",t.value=this.inputElement.value,this.tabIndex=this.inputElement.tabIndex,this.inputElement.tabIndex=-100,this.componentRef){var n=this.thisElement.getBoundingClientRect(),i=this.autocompleteElement.style;i.width=n.width+"px",i.position="absolute",i.zIndex="1",i.top="0",i.left="0",i.display="inline-block"}},e.decorators=[{type:i.Directive,args:[{selector:"[input-autocomplete]"}]}],e.ctorParameters=function(){return[{type:i.ComponentFactoryResolver},{type:i.ViewContainerRef}]},e.propDecorators={config:[{type:i.Input}],items:[{type:i.Input}],ngModel:[{type:i.Input}],control:[{type:i.Input}],ngModelChange:[{type:i.Output}],inputChangedEvent:[{type:i.Output}],selectEvent:[{type:i.Output}],showAutocomplete:[{type:i.HostListener,args:["click",["$event.target"]]},{type:i.HostListener,args:["focus",["$event.target"]]}]},e}(),l=function(){function e(){}return e.forRoot=function(){return{ngModule:e}},e.decorators=[{type:i.NgModule,args:[{imports:[t.CommonModule,n.FormsModule],declarations:[o,s],exports:[o,s],entryComponents:[o]}]}],e}();e.AutocompleteComponent=o,e.AutocompleteDirective=s,e.AutocompleteModule=l,Object.defineProperty(e,"__esModule",{value:!0})}); | ||
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/core"),require("@angular/forms"),require("@angular/common")):"function"==typeof define&&define.amd?define("ng2-input-autocomplete",["exports","@angular/core","@angular/forms","@angular/common"],t):t((e=e||self)["ng2-input-autocomplete"]={},e.ng.core,e.ng.forms,e.ng.common)}(this,(function(e,t,n,i){"use strict";var o=function(){function e(e){this.classList="autocomplete",this.selectEvent=new t.EventEmitter,this.inputChangedEvent=new t.EventEmitter,this.maxLimit=0,this.thisElement=e.nativeElement,this.selectedIndex=0,this.showAutoComplete=!1,this.value=""}return e.prototype.ngOnInit=function(){this.config&&this.config.class&&(this.classList+=" "+this.config.class),this.config&&this.config.max>0&&(this.maxLimit=this.config.max),this.placeholder="autocomplete",this.inputElement=this.thisElement.querySelector("input"),this.isNull(this.config)||(this.isNull(this.config.placeholder)||(this.placeholder=this.config.placeholder),this.isNull(this.config.sourceField)||(this.sourceField=this.config.sourceField)),this.filterItems(this.value),this.inputElement.focus()},e.prototype.ngOnChanges=function(){this.filterItems(this.value)},e.prototype.enterText=function(e){var t=this.candidates.length;switch(e.keyCode){case 27:this.showAutoComplete=!1;break;case 38:this.selectedIndex=(t+this.selectedIndex-1)%t;break;case 40:this.selectedIndex=(t+this.selectedIndex+1)%t;break;case 13:this.candidates.length>0&&this.onSelect(this.selectedIndex),e.preventDefault();break;default:this.value=e.target.value,this.inputChangedEvent.emit(this.value)}},e.prototype.onSelect=function(e){this.showAutoComplete=!1,this.value=this.candidatesLabels[e],this.selectEvent.emit(this.candidates[e])},e.prototype.onKeyUpEvent=function(e,t){13===e.keyCode&&this.onSelect(t)},e.prototype.filterItems=function(e){var t=this.sourceField,n=this.filterItem;this.items&&(this.candidates=this.items.filter((function(i){return n(i,t,e)})),this.maxLimit>0&&(this.candidates=this.candidates.slice(0,this.maxLimit)),this.buildLabels())},e.prototype.getFieldValue=function(e,t){if("string"==typeof e)return e;if(t instanceof Array){var n=e;return t.forEach((function(e){n=null!=n&&null!==n[e]&&void 0!==n[e]?n[e]:""})),n}return e[t]||""},e.prototype.isNull=function(e){return null==e},e.prototype.buildLabels=function(){var e=this.sourceField,t=this.getFieldValue;this.candidatesLabels=this.candidates.map((function(n){return t(n,e)}))},e.prototype.filterItem=function(e,t,n){return null==n||0===n.length||("string"==typeof e?i=e:t instanceof Array?(i=e,t.forEach((function(e){i=null!=i&&null!==i[e]&&void 0!==i[e]?i[e]:""}))):i=e[t]||"",i.toLowerCase().indexOf(n.toLowerCase())>=0);var i},e.decorators=[{type:t.Component,args:[{selector:"ng2-input-autocomplete",template:'\n <div [ngClass]="classList">\n <input type="text"\n placeholder="{{placeholder}}"\n (blur)="showAutoComplete = false;"\n (focus)="showAutoComplete = true;"\n [value]="value"\n (keyup)="enterText($event)">\n <ul *ngIf="showAutoComplete && candidates && candidates.length > 0">\n <li *ngFor="let candidate of candidates; let idx = index"\n [ngClass]="{ active: (idx === selectedIndex) }"\n (keyup)="onKeyUpEvent($event, idx)"\n (mouseover)="selectedIndex = idx;"\n (mousedown)="onSelect(idx)">\n {{candidatesLabels[idx]}}\n </li>\n </ul>\n </div>',styles:[".autocomplete ul {\n position: absolute;\n left: 0;\n width: 100%;\n border-left: 1px solid #888;\n border-right: 1px solid #888;\n border-bottom: 1px solid #888;\n list-style: none;\n padding-left: 0px;\n margin-top: 2px;\n background-color: #fff;\n z-index: 100;\n }\n .autocomplete li {\n text-align: left;\n list-style: none;\n width: 100%;\n padding: 0.4em 0 0.4em 0;\n }\n .autocomplete li.active {\n width: 100%;\n background-color: #4bf;\n }\n\n .autocomplete .highlight {\n background-color: #e2e2e2;\n }\n .autocomplete li.active .highlight {\n background: #666;\n color: #fff;\n }"]}]}],e.ctorParameters=function(){return[{type:t.ElementRef}]},e.propDecorators={items:[{type:t.Input}],config:[{type:t.Input}],selectEvent:[{type:t.Output}],inputChangedEvent:[{type:t.Output}]},e}();var s=function(){function e(e,n){var i=this;this.resolver=e,this.viewContainerRef=n,this.ngModelChange=new t.EventEmitter,this.inputChangedEvent=new t.EventEmitter,this.selectEvent=new t.EventEmitter,this.reset=!1,this.hideAutocomplete=function(e){i.componentRef&&(e&&e.target&&i.thisElement&&e.target===i.thisElement.parentElement||((!e||e.target!==i.thisElement&&"click"===e.type)&&(i.componentRef.destroy(),i.componentRef=void 0),i.inputElement.tabIndex<0&&(i.inputElement.tabIndex=i.tabIndex)))},this.onInputChanged=function(e){i.inputElement.value=e,e!==i.ngModel&&(i.ngModel=e,i.ngModelChange.emit(e)),i.componentRef.instance.filterItems(e),i.inputChangedEvent.emit(e)},this.onSelect=function(e){var t=i.componentRef.instance.value;t!==i.ngModel&&(i.ngModel=t,i.ngModelChange.emit(t)),i.selectEvent.emit(e),i.inputElement&&(i.inputElement.value=""+t),i.hideAutocomplete()},this.thisElement=this.viewContainerRef.element.nativeElement}return e.prototype.ngOnInit=function(){"form"!==this.thisElement.tagName.toLowerCase()&&this.createDiv()},e.prototype.ngOnDestroy=function(){this.componentRef&&(this.componentRef.instance.selectEvent.unsubscribe(),this.componentRef.instance.inputChangedEvent.unsubscribe()),document.removeEventListener("click",this.hideAutocomplete)},e.prototype.ngOnChanges=function(e){if(e.items&&this.componentRef){var t=this.componentRef.instance;t.items=e.items.currentValue,t.filterItems(t.value)}},e.prototype.ngAfterViewInit=function(){var e=this,t=this.getInputElement();this.control&&this.control.valueChanges.subscribe((function(){e.reset=!0})),t.form&&t.form.addEventListener("reset",(function(){e.reset=!0}))},e.prototype.showAutocomplete=function(e){this.hideAutocomplete(),e===this.thisElement&&this.createAutocomplete()},e.prototype.getInputElement=function(){var e=this.thisElement;return"INPUT"!==this.thisElement.tagName&&this.autocompleteElement&&(e=this.thisElement.querySelector("input")),e},e.prototype.createDiv=function(){var e=document.createElement("div");e.style.display="inline-block",e.style.position="relative",this.thisElement.parentElement.insertBefore(e,this.thisElement.nextSibling),e.appendChild(this.thisElement),document.addEventListener("click",this.hideAutocomplete)},e.prototype.createAutocomplete=function(){var e=this.resolver.resolveComponentFactory(o);this.componentRef=this.viewContainerRef.createComponent(e);var t=this.componentRef.instance;if(t.config=this.config,t.items=this.items,t.selectEvent.subscribe(this.onSelect),t.inputChangedEvent.subscribe(this.onInputChanged),this.autocompleteElement=this.componentRef.location.nativeElement,this.autocompleteElement.style.display="none",this.inputElement=this.getInputElement(),"INPUT"!==this.thisElement.tagName&&this.autocompleteElement&&this.inputElement.parentElement.insertBefore(this.autocompleteElement,this.inputElement.nextSibling),this.reset&&(this.ngModel="",this.reset=!1),this.inputElement.value=this.ngModel?this.ngModel:"",t.value=this.inputElement.value,this.tabIndex=this.inputElement.tabIndex,this.inputElement.tabIndex=-100,this.componentRef){var n=this.thisElement.getBoundingClientRect(),i=this.autocompleteElement.style;i.width=n.width+"px",i.position="absolute",i.zIndex="1",i.top="0",i.left="0",i.display="inline-block"}},e.decorators=[{type:t.Directive,args:[{selector:"[input-autocomplete]"}]}],e.ctorParameters=function(){return[{type:t.ComponentFactoryResolver},{type:t.ViewContainerRef}]},e.propDecorators={config:[{type:t.Input}],items:[{type:t.Input}],ngModel:[{type:t.Input}],control:[{type:t.Input}],ngModelChange:[{type:t.Output}],inputChangedEvent:[{type:t.Output}],selectEvent:[{type:t.Output}],showAutocomplete:[{type:t.HostListener,args:["click",["$event.target"]]},{type:t.HostListener,args:["focus",["$event.target"]]}]},e}();var l=function(){function e(){}return e.forRoot=function(){return{ngModule:e}},e.decorators=[{type:t.NgModule,args:[{imports:[i.CommonModule,n.FormsModule],declarations:[o,s],exports:[o,s],entryComponents:[o]}]}],e}();e.AutocompleteComponent=o,e.AutocompleteDirective=s,e.AutocompleteModule=l,Object.defineProperty(e,"__esModule",{value:!0})})); | ||
//# sourceMappingURL=ng2-input-autocomplete.umd.min.js.map |
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc | ||
* Generated from: lib/autocomplete.component.ts | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/* | ||
MIT LICENSE @liuy97 | ||
*/ | ||
import { Component, ComponentFactoryResolver, Directive, ElementRef, EventEmitter, HostListener, Input, Output, ViewContainerRef } from '@angular/core'; | ||
@@ -32,3 +36,3 @@ import { FormControl } from '@angular/forms'; | ||
this.placeholder = 'autocomplete'; | ||
this.inputElement = /** @type {?} */ (this.thisElement.querySelector('input')); | ||
this.inputElement = (/** @type {?} */ (this.thisElement.querySelector('input'))); | ||
if (!this.isNull(this.config)) { | ||
@@ -109,5 +113,9 @@ if (!this.isNull(this.config.placeholder)) { | ||
if (this.items) { | ||
this.candidates = this.items.filter(item => { | ||
this.candidates = this.items.filter((/** | ||
* @param {?} item | ||
* @return {?} | ||
*/ | ||
item => { | ||
return filterItem(item, field, search); | ||
}); | ||
})); | ||
if (this.maxLimit > 0) { | ||
@@ -120,2 +128,3 @@ this.candidates = this.candidates.slice(0, this.maxLimit); | ||
/** | ||
* @private | ||
* @param {?} object | ||
@@ -132,3 +141,7 @@ * @param {?} path | ||
let result = object; | ||
path.forEach((element) => { | ||
path.forEach((/** | ||
* @param {?} element | ||
* @return {?} | ||
*/ | ||
(element) => { | ||
if (result !== null && | ||
@@ -143,3 +156,3 @@ result !== undefined && | ||
} | ||
}); | ||
})); | ||
return result; | ||
@@ -152,2 +165,3 @@ } | ||
/** | ||
* @private | ||
* @param {?} object | ||
@@ -160,2 +174,3 @@ * @return {?} | ||
/** | ||
* @private | ||
* @return {?} | ||
@@ -168,5 +183,10 @@ */ | ||
const getFieldValue = this.getFieldValue; | ||
this.candidatesLabels = this.candidates.map((e) => getFieldValue(e, field)); | ||
this.candidatesLabels = this.candidates.map((/** | ||
* @param {?} e | ||
* @return {?} | ||
*/ | ||
(e) => getFieldValue(e, field))); | ||
} | ||
/** | ||
* @private | ||
* @param {?} item | ||
@@ -188,3 +208,7 @@ * @param {?} path | ||
result = item; | ||
path.forEach((element) => { | ||
path.forEach((/** | ||
* @param {?} element | ||
* @return {?} | ||
*/ | ||
(element) => { | ||
if (result !== null && | ||
@@ -199,3 +223,3 @@ result !== undefined && | ||
} | ||
}); | ||
})); | ||
} | ||
@@ -300,5 +324,11 @@ else { | ||
AutocompleteComponent.prototype.maxLimit; | ||
/** @type {?} */ | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
AutocompleteComponent.prototype.sourceField; | ||
/** @type {?} */ | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
AutocompleteComponent.prototype.thisElement; | ||
@@ -318,3 +348,7 @@ } | ||
this.reset = false; | ||
this.hideAutocomplete = (event) => { | ||
this.hideAutocomplete = (/** | ||
* @param {?=} event | ||
* @return {?} | ||
*/ | ||
(event) => { | ||
if (!this.componentRef) { | ||
@@ -334,4 +368,8 @@ return; | ||
} | ||
}; | ||
this.onInputChanged = (val) => { | ||
}); | ||
this.onInputChanged = (/** | ||
* @param {?} val | ||
* @return {?} | ||
*/ | ||
(val) => { | ||
this.inputElement.value = val; | ||
@@ -346,4 +384,8 @@ if (val !== this.ngModel) { | ||
this.inputChangedEvent.emit(val); | ||
}; | ||
this.onSelect = (item) => { | ||
}); | ||
this.onSelect = (/** | ||
* @param {?} item | ||
* @return {?} | ||
*/ | ||
(item) => { | ||
/** @type {?} */ | ||
@@ -362,3 +404,3 @@ const component = this.componentRef.instance; | ||
this.hideAutocomplete(); | ||
}; | ||
}); | ||
this.thisElement = this.viewContainerRef.element.nativeElement; | ||
@@ -404,10 +446,16 @@ } | ||
if (this.control) { | ||
this.control.valueChanges.subscribe(() => { | ||
this.control.valueChanges.subscribe((/** | ||
* @return {?} | ||
*/ | ||
() => { | ||
this.reset = true; | ||
}); | ||
})); | ||
} | ||
if (input.form) { | ||
input.form.addEventListener('reset', () => { | ||
input.form.addEventListener('reset', (/** | ||
* @return {?} | ||
*/ | ||
() => { | ||
this.reset = true; | ||
}); | ||
})); | ||
} | ||
@@ -430,5 +478,5 @@ } | ||
/** @type {?} */ | ||
let input = /** @type {?} */ (this.thisElement); | ||
let input = (/** @type {?} */ (this.thisElement)); | ||
if (this.thisElement.tagName !== 'INPUT' && this.autocompleteElement) { | ||
input = /** @type {?} */ (this.thisElement.querySelector('input')); | ||
input = (/** @type {?} */ (this.thisElement.querySelector('input'))); | ||
} | ||
@@ -438,2 +486,3 @@ return input; | ||
/** | ||
* @private | ||
* @return {?} | ||
@@ -451,2 +500,3 @@ */ | ||
/** | ||
* @private | ||
* @return {?} | ||
@@ -528,13 +578,31 @@ */ | ||
AutocompleteDirective.prototype.selectEvent; | ||
/** @type {?} */ | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
AutocompleteDirective.prototype.componentRef; | ||
/** @type {?} */ | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
AutocompleteDirective.prototype.thisElement; | ||
/** @type {?} */ | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
AutocompleteDirective.prototype.autocompleteElement; | ||
/** @type {?} */ | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
AutocompleteDirective.prototype.inputElement; | ||
/** @type {?} */ | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
AutocompleteDirective.prototype.tabIndex; | ||
/** @type {?} */ | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
AutocompleteDirective.prototype.reset; | ||
@@ -547,3 +615,6 @@ /** @type {?} */ | ||
AutocompleteDirective.prototype.onSelect; | ||
/** @type {?} */ | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
AutocompleteDirective.prototype.resolver; | ||
@@ -553,3 +624,2 @@ /** @type {?} */ | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete.component.js","sourceRoot":"ng://ng2-input-autocomplete/","sources":["lib/autocomplete.component.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n  MIT LICENSE @liuy97\n*/\nimport {\n  Component,\n  ComponentFactoryResolver,\n  ComponentRef,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  AfterViewInit,\n  Output,\n  SimpleChange,\n  ViewContainerRef,\n  HostBinding\n} from '@angular/core';\nimport {FormControl} from '@angular/forms';\n\n@Component({\n  // tslint:disable-next-line\n  selector: 'ng2-input-autocomplete',\n  template: `\n  <div [ngClass]=\"classList\">\n    <input type=\"text\"\n      placeholder=\"{{placeholder}}\"\n      (blur)=\"showAutoComplete = false;\"\n      (focus)=\"showAutoComplete = true;\"\n      [value]=\"value\"\n      (keyup)=\"enterText($event)\">\n    <ul *ngIf=\"showAutoComplete && candidates && candidates.length > 0\">\n      <li *ngFor=\"let candidate of candidates; let idx = index\"\n        [ngClass]=\"{ active: (idx === selectedIndex) }\"\n        (keyup)=\"onKeyUpEvent($event, idx)\"\n        (mouseover)=\"selectedIndex = idx;\"\n        (mousedown)=\"onSelect(idx)\">\n        {{candidatesLabels[idx]}}\n      </li>\n    </ul>\n  </div>`,\n  styles: [\n    `.autocomplete ul {\n       position: absolute;\n       left: 0;\n       width: 100%;\n       border-left: 1px solid #888;\n       border-right: 1px solid #888;\n       border-bottom: 1px solid #888;\n       list-style: none;\n       padding-left: 0px;\n       margin-top: 2px;\n       background-color: #fff;\n       z-index: 100;\n     }\n     .autocomplete li {\n       text-align: left;\n       list-style: none;\n       width: 100%;\n       padding: 0.4em 0 0.4em 0;\n     }\n     .autocomplete li.active {\n       width: 100%;\n       background-color: #4bf;\n     }\n\n     .autocomplete .highlight {\n       background-color: #e2e2e2;\n     }\n     .autocomplete li.active .highlight {\n       background: #666;\n       color: #fff;\n     }`\n  ]\n})\nexport class AutocompleteComponent implements OnInit, OnChanges {\n  classList = 'autocomplete';\n  @Input() items: any[];\n  @Input() config: any;\n  @Output() selectEvent: EventEmitter<any> = new EventEmitter<any>();\n  @Output() inputChangedEvent: EventEmitter<any> = new EventEmitter<any>();\n  inputElement: HTMLInputElement;\n  value: string;\n  candidates: any[];\n  candidatesLabels: any[];\n  selectedIndex: number;\n  showAutoComplete: boolean;\n  placeholder: string;\n  maxLimit = 0;\n  private sourceField: any;\n  private thisElement: HTMLElement;\n\n  constructor(elementRef: ElementRef) {\n    this.thisElement = elementRef.nativeElement;\n    this.selectedIndex = 0;\n    this.showAutoComplete = false;\n    this.value = '';\n  }\n\n  ngOnInit() {\n    if (this.config && this.config.class) {\n      this.classList += ' ' + this.config.class;\n    }\n    if (this.config && this.config.max > 0) {\n      this.maxLimit = this.config.max;\n    }\n    this.placeholder = 'autocomplete';\n    this.inputElement = this.thisElement.querySelector(\n      'input'\n    ) as HTMLInputElement;\n\n    if (!this.isNull(this.config)) {\n      if (!this.isNull(this.config.placeholder)) {\n        this.placeholder = this.config.placeholder;\n      }\n      if (!this.isNull(this.config.sourceField)) {\n        this.sourceField = this.config.sourceField;\n      }\n    }\n    this.filterItems(this.value);\n    this.inputElement.focus();\n  }\n\n  ngOnChanges() {\n    this.filterItems(this.value);\n  }\n\n  enterText(event: any) {\n    const total = this.candidates.length;\n    switch (event.keyCode) {\n      case 27:\n        this.showAutoComplete = false;\n        break;\n      case 38:\n        this.selectedIndex = (total + this.selectedIndex - 1) % total;\n        break;\n      case 40:\n        this.selectedIndex = (total + this.selectedIndex + 1) % total;\n        break;\n      case 13:\n        if (this.candidates.length > 0) {\n          this.onSelect(this.selectedIndex);\n        }\n        event.preventDefault();\n        break;\n      default:\n        this.value = event.target.value;\n        this.inputChangedEvent.emit(this.value);\n        break;\n    }\n  }\n\n  onSelect(idx: number) {\n    this.showAutoComplete = false;\n    this.value = this.candidatesLabels[idx];\n    this.selectEvent.emit(this.candidates[idx]);\n  }\n\n  onKeyUpEvent(event: KeyboardEvent, idx: number): void {\n    if (event.keyCode === 13) {\n      this.onSelect(idx);\n    }\n }\n\n  filterItems(search: string) {\n    const field = this.sourceField;\n    const filterItem = this.filterItem;\n    if (this.items) {\n      this.candidates = this.items.filter(item => {\n        return filterItem(item, field, search);\n      });\n      if (this.maxLimit > 0) {\n        this.candidates = this.candidates.slice(0, this.maxLimit);\n      }\n      this.buildLabels();\n    }\n  }\n\n  private getFieldValue(object: any, path: any) {\n    if (typeof object === 'string') {\n      return object;\n    }\n    if (path instanceof Array) {\n      let result: any = object;\n      path.forEach((element: any) => {\n        if (\n          result !== null &&\n          result !== undefined &&\n          result[element] !== null &&\n          result[element] !== undefined\n        ) {\n          result = result[element];\n        } else {\n          result = '';\n        }\n      });\n      return result;\n    } else {\n      return object[path] || '';\n    }\n  }\n\n  private isNull(object: any) {\n    return object === null || object === undefined;\n  }\n\n  private buildLabels() {\n    const field = this.sourceField;\n    const getFieldValue = this.getFieldValue;\n    this.candidatesLabels = this.candidates.map((e: any) =>\n      getFieldValue(e, field)\n    );\n  }\n\n  private filterItem(item: any, path: any, search: string) {\n    if (search === null || search === undefined || search.length === 0) {\n      return true;\n    }\n    let result: any;\n    if (typeof item === 'string') {\n      result = item;\n    } else if (path instanceof Array) {\n      result = item;\n      path.forEach((element: any) => {\n        if (\n          result !== null &&\n          result !== undefined &&\n          result[element] !== null &&\n          result[element] !== undefined\n        ) {\n          result = result[element];\n        } else {\n          result = '';\n        }\n      });\n    } else {\n      result = item[path] || '';\n    }\n    return result.toLowerCase().indexOf(search.toLowerCase()) >= 0;\n  }\n}\n\n@Directive({\n  // tslint:disable-next-line\n  selector: '[input-autocomplete]'\n})\nexport class AutocompleteDirective implements OnInit, OnDestroy, OnChanges, AfterViewInit {\n  @Input() config: any;\n  @Input() items: any;\n  @Input() ngModel: string;\n  @Input() control: FormControl;\n  @Output() ngModelChange = new EventEmitter();\n  @Output() inputChangedEvent = new EventEmitter();\n  @Output() selectEvent = new EventEmitter();\n\n  private componentRef: ComponentRef<AutocompleteComponent>;\n  private thisElement: HTMLElement;\n  private autocompleteElement: HTMLElement;\n  private inputElement: HTMLInputElement;\n  private tabIndex: number;\n  private reset = false;\n\n  constructor(\n    private resolver: ComponentFactoryResolver,\n    public viewContainerRef: ViewContainerRef\n  ) {\n    this.thisElement = this.viewContainerRef.element.nativeElement;\n  }\n\n  ngOnInit() {\n    if (this.thisElement.tagName.toLowerCase() === 'form') {\n      return;\n    }\n    this.createDiv();\n  }\n\n  ngOnDestroy() {\n    if (this.componentRef) {\n      this.componentRef.instance.selectEvent.unsubscribe();\n      this.componentRef.instance.inputChangedEvent.unsubscribe();\n    }\n    document.removeEventListener('click', this.hideAutocomplete);\n  }\n\n  ngOnChanges(changes: { [propKey: string]: SimpleChange }) {\n    if (changes['items'] && this.componentRef) {\n      const component = this.componentRef.instance;\n      component.items = changes['items'].currentValue;\n      component.filterItems(component.value);\n    }\n  }\n\n  ngAfterViewInit() {\n    const input = this.getInputElement();\n    if (this.control) {\n      this.control.valueChanges.subscribe(() => {\n        this.reset = true;\n      });\n    }\n    if (input.form) {\n      input.form.addEventListener('reset', () => {\n        this.reset = true;\n      });\n    }\n  }\n\n  @HostListener('click', ['$event.target'])\n  @HostListener('focus', ['$event.target'])\n  showAutocomplete(event: any) {\n    this.hideAutocomplete();\n    if (event === this.thisElement) {\n      this.createAutocomplete();\n    }\n  }\n\n  getInputElement() {\n    let input = this.thisElement as HTMLInputElement;\n\n    if (this.thisElement.tagName !== 'INPUT' && this.autocompleteElement) {\n      input = this.thisElement.querySelector(\n        'input'\n      ) as HTMLInputElement;\n    }\n\n    return input;\n  }\n\n  hideAutocomplete = (event?: any): void => {\n    if (!this.componentRef) {\n      return;\n    }\n    if (event && event.target && this.thisElement && event.target === this.thisElement.parentElement) {\n      return;\n    }\n    if (\n      !event ||\n      (event.target !== this.thisElement && event.type === 'click')\n    ) {\n      this.componentRef.destroy();\n      this.componentRef = undefined;\n    }\n    if (this.inputElement['tabIndex'] < 0) {\n      this.inputElement['tabIndex'] = this.tabIndex;\n    }\n  }\n\n  onInputChanged = (val: string) => {\n    this.inputElement.value = val;\n    if (val !== this.ngModel) {\n      this.ngModel = val;\n      this.ngModelChange.emit(val);\n    }\n    const component = this.componentRef.instance;\n    component.filterItems(val);\n    this.inputChangedEvent.emit(val);\n  }\n\n  onSelect = (item: any) => {\n    const component = this.componentRef.instance;\n    const val = component.value;\n    if (val !== this.ngModel) {\n      this.ngModel = val;\n      this.ngModelChange.emit(val);\n    }\n    this.selectEvent.emit(item);\n    if (this.inputElement) {\n      this.inputElement.value = '' + val;\n    }\n    this.hideAutocomplete();\n  }\n\n  private createDiv() {\n    const element = document.createElement('div');\n    element.style.display = 'inline-block';\n    element.style.position = 'relative';\n    this.thisElement.parentElement.insertBefore(\n      element,\n      this.thisElement.nextSibling\n    );\n    element.appendChild(this.thisElement);\n    document.addEventListener('click', this.hideAutocomplete);\n  }\n\n  private createAutocomplete() {\n    const factory = this.resolver.resolveComponentFactory(\n      AutocompleteComponent\n    );\n    this.componentRef = this.viewContainerRef.createComponent(factory);\n    const component = this.componentRef.instance;\n    component.config = this.config;\n    component.items = this.items;\n    component.selectEvent.subscribe(this.onSelect);\n    component.inputChangedEvent.subscribe(this.onInputChanged);\n    this.autocompleteElement = this.componentRef.location.nativeElement;\n    this.autocompleteElement.style.display = 'none';\n    this.inputElement = this.getInputElement();\n    if (this.thisElement.tagName !== 'INPUT' && this.autocompleteElement) {\n      this.inputElement.parentElement.insertBefore(\n        this.autocompleteElement,\n        this.inputElement.nextSibling\n      );\n    }\n\n    if (this.reset) {\n      this.ngModel = '';\n      this.reset = false;\n    }\n\n    this.inputElement.value = this.ngModel ? this.ngModel : '';\n    component.value = this.inputElement.value;\n    this.tabIndex = this.inputElement['tabIndex'];\n    this.inputElement['tabIndex'] = -100;\n    if (this.componentRef) {\n      const rect = this.thisElement.getBoundingClientRect();\n      const style = this.autocompleteElement.style;\n      style.width = rect.width + 'px';\n      style.position = 'absolute';\n      style.zIndex = '1';\n      style.top = '0';\n      style.left = '0';\n      style.display = 'inline-block';\n    }\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete.component.js","sourceRoot":"ng://ng2-input-autocomplete/","sources":["lib/autocomplete.component.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n  MIT LICENSE @liuy97\n*/\nimport {\n  Component,\n  ComponentFactoryResolver,\n  ComponentRef,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  AfterViewInit,\n  Output,\n  SimpleChange,\n  ViewContainerRef,\n  HostBinding\n} from '@angular/core';\nimport {FormControl} from '@angular/forms';\n\n@Component({\n  // tslint:disable-next-line\n  selector: 'ng2-input-autocomplete',\n  template: `\n  <div [ngClass]=\"classList\">\n    <input type=\"text\"\n      placeholder=\"{{placeholder}}\"\n      (blur)=\"showAutoComplete = false;\"\n      (focus)=\"showAutoComplete = true;\"\n      [value]=\"value\"\n      (keyup)=\"enterText($event)\">\n    <ul *ngIf=\"showAutoComplete && candidates && candidates.length > 0\">\n      <li *ngFor=\"let candidate of candidates; let idx = index\"\n        [ngClass]=\"{ active: (idx === selectedIndex) }\"\n        (keyup)=\"onKeyUpEvent($event, idx)\"\n        (mouseover)=\"selectedIndex = idx;\"\n        (mousedown)=\"onSelect(idx)\">\n        {{candidatesLabels[idx]}}\n      </li>\n    </ul>\n  </div>`,\n  styles: [\n    `.autocomplete ul {\n       position: absolute;\n       left: 0;\n       width: 100%;\n       border-left: 1px solid #888;\n       border-right: 1px solid #888;\n       border-bottom: 1px solid #888;\n       list-style: none;\n       padding-left: 0px;\n       margin-top: 2px;\n       background-color: #fff;\n       z-index: 100;\n     }\n     .autocomplete li {\n       text-align: left;\n       list-style: none;\n       width: 100%;\n       padding: 0.4em 0 0.4em 0;\n     }\n     .autocomplete li.active {\n       width: 100%;\n       background-color: #4bf;\n     }\n\n     .autocomplete .highlight {\n       background-color: #e2e2e2;\n     }\n     .autocomplete li.active .highlight {\n       background: #666;\n       color: #fff;\n     }`\n  ]\n})\nexport class AutocompleteComponent implements OnInit, OnChanges {\n  classList = 'autocomplete';\n  @Input() items: any[];\n  @Input() config: any;\n  @Output() selectEvent: EventEmitter<any> = new EventEmitter<any>();\n  @Output() inputChangedEvent: EventEmitter<any> = new EventEmitter<any>();\n  inputElement: HTMLInputElement;\n  value: string;\n  candidates: any[];\n  candidatesLabels: any[];\n  selectedIndex: number;\n  showAutoComplete: boolean;\n  placeholder: string;\n  maxLimit = 0;\n  private sourceField: any;\n  private thisElement: HTMLElement;\n\n  constructor(elementRef: ElementRef) {\n    this.thisElement = elementRef.nativeElement;\n    this.selectedIndex = 0;\n    this.showAutoComplete = false;\n    this.value = '';\n  }\n\n  ngOnInit() {\n    if (this.config && this.config.class) {\n      this.classList += ' ' + this.config.class;\n    }\n    if (this.config && this.config.max > 0) {\n      this.maxLimit = this.config.max;\n    }\n    this.placeholder = 'autocomplete';\n    this.inputElement = this.thisElement.querySelector(\n      'input'\n    ) as HTMLInputElement;\n\n    if (!this.isNull(this.config)) {\n      if (!this.isNull(this.config.placeholder)) {\n        this.placeholder = this.config.placeholder;\n      }\n      if (!this.isNull(this.config.sourceField)) {\n        this.sourceField = this.config.sourceField;\n      }\n    }\n    this.filterItems(this.value);\n    this.inputElement.focus();\n  }\n\n  ngOnChanges() {\n    this.filterItems(this.value);\n  }\n\n  enterText(event: any) {\n    const total = this.candidates.length;\n    switch (event.keyCode) {\n      case 27:\n        this.showAutoComplete = false;\n        break;\n      case 38:\n        this.selectedIndex = (total + this.selectedIndex - 1) % total;\n        break;\n      case 40:\n        this.selectedIndex = (total + this.selectedIndex + 1) % total;\n        break;\n      case 13:\n        if (this.candidates.length > 0) {\n          this.onSelect(this.selectedIndex);\n        }\n        event.preventDefault();\n        break;\n      default:\n        this.value = event.target.value;\n        this.inputChangedEvent.emit(this.value);\n        break;\n    }\n  }\n\n  onSelect(idx: number) {\n    this.showAutoComplete = false;\n    this.value = this.candidatesLabels[idx];\n    this.selectEvent.emit(this.candidates[idx]);\n  }\n\n  onKeyUpEvent(event: KeyboardEvent, idx: number): void {\n    if (event.keyCode === 13) {\n      this.onSelect(idx);\n    }\n }\n\n  filterItems(search: string) {\n    const field = this.sourceField;\n    const filterItem = this.filterItem;\n    if (this.items) {\n      this.candidates = this.items.filter(item => {\n        return filterItem(item, field, search);\n      });\n      if (this.maxLimit > 0) {\n        this.candidates = this.candidates.slice(0, this.maxLimit);\n      }\n      this.buildLabels();\n    }\n  }\n\n  private getFieldValue(object: any, path: any) {\n    if (typeof object === 'string') {\n      return object;\n    }\n    if (path instanceof Array) {\n      let result: any = object;\n      path.forEach((element: any) => {\n        if (\n          result !== null &&\n          result !== undefined &&\n          result[element] !== null &&\n          result[element] !== undefined\n        ) {\n          result = result[element];\n        } else {\n          result = '';\n        }\n      });\n      return result;\n    } else {\n      return object[path] || '';\n    }\n  }\n\n  private isNull(object: any) {\n    return object === null || object === undefined;\n  }\n\n  private buildLabels() {\n    const field = this.sourceField;\n    const getFieldValue = this.getFieldValue;\n    this.candidatesLabels = this.candidates.map((e: any) =>\n      getFieldValue(e, field)\n    );\n  }\n\n  private filterItem(item: any, path: any, search: string) {\n    if (search === null || search === undefined || search.length === 0) {\n      return true;\n    }\n    let result: any;\n    if (typeof item === 'string') {\n      result = item;\n    } else if (path instanceof Array) {\n      result = item;\n      path.forEach((element: any) => {\n        if (\n          result !== null &&\n          result !== undefined &&\n          result[element] !== null &&\n          result[element] !== undefined\n        ) {\n          result = result[element];\n        } else {\n          result = '';\n        }\n      });\n    } else {\n      result = item[path] || '';\n    }\n    return result.toLowerCase().indexOf(search.toLowerCase()) >= 0;\n  }\n}\n\n@Directive({\n  // tslint:disable-next-line\n  selector: '[input-autocomplete]'\n})\nexport class AutocompleteDirective implements OnInit, OnDestroy, OnChanges, AfterViewInit {\n  @Input() config: any;\n  @Input() items: any;\n  @Input() ngModel: string;\n  @Input() control: FormControl;\n  @Output() ngModelChange = new EventEmitter();\n  @Output() inputChangedEvent = new EventEmitter();\n  @Output() selectEvent = new EventEmitter();\n\n  private componentRef: ComponentRef<AutocompleteComponent>;\n  private thisElement: HTMLElement;\n  private autocompleteElement: HTMLElement;\n  private inputElement: HTMLInputElement;\n  private tabIndex: number;\n  private reset = false;\n\n  constructor(\n    private resolver: ComponentFactoryResolver,\n    public viewContainerRef: ViewContainerRef\n  ) {\n    this.thisElement = this.viewContainerRef.element.nativeElement;\n  }\n\n  ngOnInit() {\n    if (this.thisElement.tagName.toLowerCase() === 'form') {\n      return;\n    }\n    this.createDiv();\n  }\n\n  ngOnDestroy() {\n    if (this.componentRef) {\n      this.componentRef.instance.selectEvent.unsubscribe();\n      this.componentRef.instance.inputChangedEvent.unsubscribe();\n    }\n    document.removeEventListener('click', this.hideAutocomplete);\n  }\n\n  ngOnChanges(changes: { [propKey: string]: SimpleChange }) {\n    if (changes['items'] && this.componentRef) {\n      const component = this.componentRef.instance;\n      component.items = changes['items'].currentValue;\n      component.filterItems(component.value);\n    }\n  }\n\n  ngAfterViewInit() {\n    const input = this.getInputElement();\n    if (this.control) {\n      this.control.valueChanges.subscribe(() => {\n        this.reset = true;\n      });\n    }\n    if (input.form) {\n      input.form.addEventListener('reset', () => {\n        this.reset = true;\n      });\n    }\n  }\n\n  @HostListener('click', ['$event.target'])\n  @HostListener('focus', ['$event.target'])\n  showAutocomplete(event: any) {\n    this.hideAutocomplete();\n    if (event === this.thisElement) {\n      this.createAutocomplete();\n    }\n  }\n\n  getInputElement() {\n    let input = this.thisElement as HTMLInputElement;\n\n    if (this.thisElement.tagName !== 'INPUT' && this.autocompleteElement) {\n      input = this.thisElement.querySelector(\n        'input'\n      ) as HTMLInputElement;\n    }\n\n    return input;\n  }\n\n  hideAutocomplete = (event?: any): void => {\n    if (!this.componentRef) {\n      return;\n    }\n    if (event && event.target && this.thisElement && event.target === this.thisElement.parentElement) {\n      return;\n    }\n    if (\n      !event ||\n      (event.target !== this.thisElement && event.type === 'click')\n    ) {\n      this.componentRef.destroy();\n      this.componentRef = undefined;\n    }\n    if (this.inputElement['tabIndex'] < 0) {\n      this.inputElement['tabIndex'] = this.tabIndex;\n    }\n  }\n\n  onInputChanged = (val: string) => {\n    this.inputElement.value = val;\n    if (val !== this.ngModel) {\n      this.ngModel = val;\n      this.ngModelChange.emit(val);\n    }\n    const component = this.componentRef.instance;\n    component.filterItems(val);\n    this.inputChangedEvent.emit(val);\n  }\n\n  onSelect = (item: any) => {\n    const component = this.componentRef.instance;\n    const val = component.value;\n    if (val !== this.ngModel) {\n      this.ngModel = val;\n      this.ngModelChange.emit(val);\n    }\n    this.selectEvent.emit(item);\n    if (this.inputElement) {\n      this.inputElement.value = '' + val;\n    }\n    this.hideAutocomplete();\n  }\n\n  private createDiv() {\n    const element = document.createElement('div');\n    element.style.display = 'inline-block';\n    element.style.position = 'relative';\n    this.thisElement.parentElement.insertBefore(\n      element,\n      this.thisElement.nextSibling\n    );\n    element.appendChild(this.thisElement);\n    document.addEventListener('click', this.hideAutocomplete);\n  }\n\n  private createAutocomplete() {\n    const factory = this.resolver.resolveComponentFactory(\n      AutocompleteComponent\n    );\n    this.componentRef = this.viewContainerRef.createComponent(factory);\n    const component = this.componentRef.instance;\n    component.config = this.config;\n    component.items = this.items;\n    component.selectEvent.subscribe(this.onSelect);\n    component.inputChangedEvent.subscribe(this.onInputChanged);\n    this.autocompleteElement = this.componentRef.location.nativeElement;\n    this.autocompleteElement.style.display = 'none';\n    this.inputElement = this.getInputElement();\n    if (this.thisElement.tagName !== 'INPUT' && this.autocompleteElement) {\n      this.inputElement.parentElement.insertBefore(\n        this.autocompleteElement,\n        this.inputElement.nextSibling\n      );\n    }\n\n    if (this.reset) {\n      this.ngModel = '';\n      this.reset = false;\n    }\n\n    this.inputElement.value = this.ngModel ? this.ngModel : '';\n    component.value = this.inputElement.value;\n    this.tabIndex = this.inputElement['tabIndex'];\n    this.inputElement['tabIndex'] = -100;\n    if (this.componentRef) {\n      const rect = this.thisElement.getBoundingClientRect();\n      const style = this.autocompleteElement.style;\n      style.width = rect.width + 'px';\n      style.position = 'absolute';\n      style.zIndex = '1';\n      style.top = '0';\n      style.left = '0';\n      style.display = 'inline-block';\n    }\n  }\n}\n"]} |
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc | ||
* Generated from: lib/autocomplete.module.ts | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -27,3 +28,2 @@ import { NgModule } from '@angular/core'; | ||
]; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0b2NvbXBsZXRlLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25nMi1pbnB1dC1hdXRvY29tcGxldGUvIiwic291cmNlcyI6WyJsaWIvYXV0b2NvbXBsZXRlLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7O0FBQUEsT0FBTyxFQUFFLFFBQVEsRUFBdUIsTUFBTSxlQUFlLENBQUM7QUFDOUQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM3QyxPQUFPLEVBQUUscUJBQXFCLEVBQUUscUJBQXFCLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQVF4RixNQUFNOzs7O0lBQ0osTUFBTSxDQUFDLE9BQU87UUFDWixPQUFPO1lBQ0wsUUFBUSxFQUFFLGtCQUFrQjtTQUM3QixDQUFDO0tBQ0g7OztZQVhGLFFBQVEsU0FBQztnQkFDUixPQUFPLEVBQUUsQ0FBQyxZQUFZLEVBQUUsV0FBVyxDQUFDO2dCQUNwQyxZQUFZLEVBQUUsQ0FBQyxxQkFBcUIsRUFBRSxxQkFBcUIsQ0FBQztnQkFDNUQsT0FBTyxFQUFFLENBQUMscUJBQXFCLEVBQUUscUJBQXFCLENBQUM7Z0JBQ3ZELGVBQWUsRUFBRSxDQUFDLHFCQUFxQixDQUFDO2FBQ3pDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUsIE1vZHVsZVdpdGhQcm92aWRlcnMgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IEF1dG9jb21wbGV0ZUNvbXBvbmVudCwgQXV0b2NvbXBsZXRlRGlyZWN0aXZlIH0gZnJvbSAnLi9hdXRvY29tcGxldGUuY29tcG9uZW50JztcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgRm9ybXNNb2R1bGVdLFxuICBkZWNsYXJhdGlvbnM6IFtBdXRvY29tcGxldGVDb21wb25lbnQsIEF1dG9jb21wbGV0ZURpcmVjdGl2ZV0sXG4gIGV4cG9ydHM6IFtBdXRvY29tcGxldGVDb21wb25lbnQsIEF1dG9jb21wbGV0ZURpcmVjdGl2ZV0sXG4gIGVudHJ5Q29tcG9uZW50czogW0F1dG9jb21wbGV0ZUNvbXBvbmVudF1cbn0pXG5leHBvcnQgY2xhc3MgQXV0b2NvbXBsZXRlTW9kdWxlIHtcbiAgc3RhdGljIGZvclJvb3QoKTogTW9kdWxlV2l0aFByb3ZpZGVycyB7XG4gICAgcmV0dXJuIHtcbiAgICAgIG5nTW9kdWxlOiBBdXRvY29tcGxldGVNb2R1bGVcbiAgICB9O1xuICB9XG59XG5cbiJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0b2NvbXBsZXRlLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25nMi1pbnB1dC1hdXRvY29tcGxldGUvIiwic291cmNlcyI6WyJsaWIvYXV0b2NvbXBsZXRlLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQXVCLE1BQU0sZUFBZSxDQUFDO0FBQzlELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDN0MsT0FBTyxFQUFFLHFCQUFxQixFQUFFLHFCQUFxQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFReEYsTUFBTSxPQUFPLGtCQUFrQjs7OztJQUM3QixNQUFNLENBQUMsT0FBTztRQUNaLE9BQU87WUFDTCxRQUFRLEVBQUUsa0JBQWtCO1NBQzdCLENBQUM7SUFDSixDQUFDOzs7WUFYRixRQUFRLFNBQUM7Z0JBQ1IsT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLFdBQVcsQ0FBQztnQkFDcEMsWUFBWSxFQUFFLENBQUMscUJBQXFCLEVBQUUscUJBQXFCLENBQUM7Z0JBQzVELE9BQU8sRUFBRSxDQUFDLHFCQUFxQixFQUFFLHFCQUFxQixDQUFDO2dCQUN2RCxlQUFlLEVBQUUsQ0FBQyxxQkFBcUIsQ0FBQzthQUN6QyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlLCBNb2R1bGVXaXRoUHJvdmlkZXJzIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBBdXRvY29tcGxldGVDb21wb25lbnQsIEF1dG9jb21wbGV0ZURpcmVjdGl2ZSB9IGZyb20gJy4vYXV0b2NvbXBsZXRlLmNvbXBvbmVudCc7XG5cbkBOZ01vZHVsZSh7XG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIEZvcm1zTW9kdWxlXSxcbiAgZGVjbGFyYXRpb25zOiBbQXV0b2NvbXBsZXRlQ29tcG9uZW50LCBBdXRvY29tcGxldGVEaXJlY3RpdmVdLFxuICBleHBvcnRzOiBbQXV0b2NvbXBsZXRlQ29tcG9uZW50LCBBdXRvY29tcGxldGVEaXJlY3RpdmVdLFxuICBlbnRyeUNvbXBvbmVudHM6IFtBdXRvY29tcGxldGVDb21wb25lbnRdXG59KVxuZXhwb3J0IGNsYXNzIEF1dG9jb21wbGV0ZU1vZHVsZSB7XG4gIHN0YXRpYyBmb3JSb290KCk6IE1vZHVsZVdpdGhQcm92aWRlcnMge1xuICAgIHJldHVybiB7XG4gICAgICBuZ01vZHVsZTogQXV0b2NvbXBsZXRlTW9kdWxlXG4gICAgfTtcbiAgfVxufVxuXG4iXX0= |
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc | ||
* Generated from: ng2-input-autocomplete.ts | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -9,3 +10,2 @@ /** | ||
export { AutocompleteComponent, AutocompleteDirective, AutocompleteModule } from './public_api'; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmcyLWlucHV0LWF1dG9jb21wbGV0ZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25nMi1pbnB1dC1hdXRvY29tcGxldGUvIiwic291cmNlcyI6WyJuZzItaW5wdXQtYXV0b2NvbXBsZXRlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFJQSxpRkFBYyxjQUFjLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vcHVibGljX2FwaSc7XG4iXX0= | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmcyLWlucHV0LWF1dG9jb21wbGV0ZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25nMi1pbnB1dC1hdXRvY29tcGxldGUvIiwic291cmNlcyI6WyJuZzItaW5wdXQtYXV0b2NvbXBsZXRlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7O0FBSUEsaUZBQWMsY0FBYyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL3B1YmxpY19hcGknO1xuIl19 |
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc | ||
* Generated from: public_api.ts | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -10,3 +11,2 @@ /* | ||
export { AutocompleteModule } from './lib/autocomplete.module'; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25nMi1pbnB1dC1hdXRvY29tcGxldGUvIiwic291cmNlcyI6WyJwdWJsaWNfYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFJQSw2REFBYyw4QkFBOEIsQ0FBQztBQUM3QyxtQ0FBYywyQkFBMkIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2YgYXV0b2NvbXBsZXRlXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9saWIvYXV0b2NvbXBsZXRlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9hdXRvY29tcGxldGUubW9kdWxlJztcbiJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25nMi1pbnB1dC1hdXRvY29tcGxldGUvIiwic291cmNlcyI6WyJwdWJsaWNfYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7O0FBSUEsNkRBQWMsOEJBQThCLENBQUM7QUFDN0MsbUNBQWMsMkJBQTJCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIGF1dG9jb21wbGV0ZVxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vbGliL2F1dG9jb21wbGV0ZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYXV0b2NvbXBsZXRlLm1vZHVsZSc7XG4iXX0= |
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc | ||
* Generated from: lib/autocomplete.component.ts | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/* | ||
MIT LICENSE @liuy97 | ||
*/ | ||
import { Component, ComponentFactoryResolver, Directive, ElementRef, EventEmitter, HostListener, Input, Output, ViewContainerRef } from '@angular/core'; | ||
@@ -32,3 +36,3 @@ import { FormControl } from '@angular/forms'; | ||
this.placeholder = 'autocomplete'; | ||
this.inputElement = /** @type {?} */ (this.thisElement.querySelector('input')); | ||
this.inputElement = (/** @type {?} */ (this.thisElement.querySelector('input'))); | ||
if (!this.isNull(this.config)) { | ||
@@ -129,5 +133,9 @@ if (!this.isNull(this.config.placeholder)) { | ||
if (this.items) { | ||
this.candidates = this.items.filter(function (item) { | ||
this.candidates = this.items.filter((/** | ||
* @param {?} item | ||
* @return {?} | ||
*/ | ||
function (item) { | ||
return filterItem(item, field, search); | ||
}); | ||
})); | ||
if (this.maxLimit > 0) { | ||
@@ -140,2 +148,3 @@ this.candidates = this.candidates.slice(0, this.maxLimit); | ||
/** | ||
* @private | ||
* @param {?} object | ||
@@ -146,2 +155,3 @@ * @param {?} path | ||
AutocompleteComponent.prototype.getFieldValue = /** | ||
* @private | ||
* @param {?} object | ||
@@ -158,3 +168,7 @@ * @param {?} path | ||
var result_1 = object; | ||
path.forEach(function (element) { | ||
path.forEach((/** | ||
* @param {?} element | ||
* @return {?} | ||
*/ | ||
function (element) { | ||
if (result_1 !== null && | ||
@@ -169,3 +183,3 @@ result_1 !== undefined && | ||
} | ||
}); | ||
})); | ||
return result_1; | ||
@@ -178,2 +192,3 @@ } | ||
/** | ||
* @private | ||
* @param {?} object | ||
@@ -183,2 +198,3 @@ * @return {?} | ||
AutocompleteComponent.prototype.isNull = /** | ||
* @private | ||
* @param {?} object | ||
@@ -191,5 +207,7 @@ * @return {?} | ||
/** | ||
* @private | ||
* @return {?} | ||
*/ | ||
AutocompleteComponent.prototype.buildLabels = /** | ||
* @private | ||
* @return {?} | ||
@@ -202,7 +220,12 @@ */ | ||
var getFieldValue = this.getFieldValue; | ||
this.candidatesLabels = this.candidates.map(function (e) { | ||
this.candidatesLabels = this.candidates.map((/** | ||
* @param {?} e | ||
* @return {?} | ||
*/ | ||
function (e) { | ||
return getFieldValue(e, field); | ||
}); | ||
})); | ||
}; | ||
/** | ||
* @private | ||
* @param {?} item | ||
@@ -214,2 +237,3 @@ * @param {?} path | ||
AutocompleteComponent.prototype.filterItem = /** | ||
* @private | ||
* @param {?} item | ||
@@ -231,3 +255,7 @@ * @param {?} path | ||
result = item; | ||
path.forEach(function (element) { | ||
path.forEach((/** | ||
* @param {?} element | ||
* @return {?} | ||
*/ | ||
function (element) { | ||
if (result !== null && | ||
@@ -242,3 +270,3 @@ result !== undefined && | ||
} | ||
}); | ||
})); | ||
} | ||
@@ -298,5 +326,11 @@ else { | ||
AutocompleteComponent.prototype.maxLimit; | ||
/** @type {?} */ | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
AutocompleteComponent.prototype.sourceField; | ||
/** @type {?} */ | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
AutocompleteComponent.prototype.thisElement; | ||
@@ -313,3 +347,7 @@ } | ||
this.reset = false; | ||
this.hideAutocomplete = function (event) { | ||
this.hideAutocomplete = (/** | ||
* @param {?=} event | ||
* @return {?} | ||
*/ | ||
function (event) { | ||
if (!_this.componentRef) { | ||
@@ -329,4 +367,8 @@ return; | ||
} | ||
}; | ||
this.onInputChanged = function (val) { | ||
}); | ||
this.onInputChanged = (/** | ||
* @param {?} val | ||
* @return {?} | ||
*/ | ||
function (val) { | ||
_this.inputElement.value = val; | ||
@@ -341,4 +383,8 @@ if (val !== _this.ngModel) { | ||
_this.inputChangedEvent.emit(val); | ||
}; | ||
this.onSelect = function (item) { | ||
}); | ||
this.onSelect = (/** | ||
* @param {?} item | ||
* @return {?} | ||
*/ | ||
function (item) { | ||
/** @type {?} */ | ||
@@ -357,3 +403,3 @@ var component = _this.componentRef.instance; | ||
_this.hideAutocomplete(); | ||
}; | ||
}); | ||
this.thisElement = this.viewContainerRef.element.nativeElement; | ||
@@ -413,10 +459,16 @@ } | ||
if (this.control) { | ||
this.control.valueChanges.subscribe(function () { | ||
this.control.valueChanges.subscribe((/** | ||
* @return {?} | ||
*/ | ||
function () { | ||
_this.reset = true; | ||
}); | ||
})); | ||
} | ||
if (input.form) { | ||
input.form.addEventListener('reset', function () { | ||
input.form.addEventListener('reset', (/** | ||
* @return {?} | ||
*/ | ||
function () { | ||
_this.reset = true; | ||
}); | ||
})); | ||
} | ||
@@ -446,5 +498,5 @@ }; | ||
/** @type {?} */ | ||
var input = /** @type {?} */ (this.thisElement); | ||
var input = (/** @type {?} */ (this.thisElement)); | ||
if (this.thisElement.tagName !== 'INPUT' && this.autocompleteElement) { | ||
input = /** @type {?} */ (this.thisElement.querySelector('input')); | ||
input = (/** @type {?} */ (this.thisElement.querySelector('input'))); | ||
} | ||
@@ -454,5 +506,7 @@ return input; | ||
/** | ||
* @private | ||
* @return {?} | ||
*/ | ||
AutocompleteDirective.prototype.createDiv = /** | ||
* @private | ||
* @return {?} | ||
@@ -470,5 +524,7 @@ */ | ||
/** | ||
* @private | ||
* @return {?} | ||
*/ | ||
AutocompleteDirective.prototype.createAutocomplete = /** | ||
* @private | ||
* @return {?} | ||
@@ -552,13 +608,31 @@ */ | ||
AutocompleteDirective.prototype.selectEvent; | ||
/** @type {?} */ | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
AutocompleteDirective.prototype.componentRef; | ||
/** @type {?} */ | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
AutocompleteDirective.prototype.thisElement; | ||
/** @type {?} */ | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
AutocompleteDirective.prototype.autocompleteElement; | ||
/** @type {?} */ | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
AutocompleteDirective.prototype.inputElement; | ||
/** @type {?} */ | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
AutocompleteDirective.prototype.tabIndex; | ||
/** @type {?} */ | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
AutocompleteDirective.prototype.reset; | ||
@@ -571,3 +645,6 @@ /** @type {?} */ | ||
AutocompleteDirective.prototype.onSelect; | ||
/** @type {?} */ | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
AutocompleteDirective.prototype.resolver; | ||
@@ -577,3 +654,2 @@ /** @type {?} */ | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete.component.js","sourceRoot":"ng://ng2-input-autocomplete/","sources":["lib/autocomplete.component.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n  MIT LICENSE @liuy97\n*/\nimport {\n  Component,\n  ComponentFactoryResolver,\n  ComponentRef,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  AfterViewInit,\n  Output,\n  SimpleChange,\n  ViewContainerRef,\n  HostBinding\n} from '@angular/core';\nimport {FormControl} from '@angular/forms';\n\n@Component({\n  // tslint:disable-next-line\n  selector: 'ng2-input-autocomplete',\n  template: `\n  <div [ngClass]=\"classList\">\n    <input type=\"text\"\n      placeholder=\"{{placeholder}}\"\n      (blur)=\"showAutoComplete = false;\"\n      (focus)=\"showAutoComplete = true;\"\n      [value]=\"value\"\n      (keyup)=\"enterText($event)\">\n    <ul *ngIf=\"showAutoComplete && candidates && candidates.length > 0\">\n      <li *ngFor=\"let candidate of candidates; let idx = index\"\n        [ngClass]=\"{ active: (idx === selectedIndex) }\"\n        (keyup)=\"onKeyUpEvent($event, idx)\"\n        (mouseover)=\"selectedIndex = idx;\"\n        (mousedown)=\"onSelect(idx)\">\n        {{candidatesLabels[idx]}}\n      </li>\n    </ul>\n  </div>`,\n  styles: [\n    `.autocomplete ul {\n       position: absolute;\n       left: 0;\n       width: 100%;\n       border-left: 1px solid #888;\n       border-right: 1px solid #888;\n       border-bottom: 1px solid #888;\n       list-style: none;\n       padding-left: 0px;\n       margin-top: 2px;\n       background-color: #fff;\n       z-index: 100;\n     }\n     .autocomplete li {\n       text-align: left;\n       list-style: none;\n       width: 100%;\n       padding: 0.4em 0 0.4em 0;\n     }\n     .autocomplete li.active {\n       width: 100%;\n       background-color: #4bf;\n     }\n\n     .autocomplete .highlight {\n       background-color: #e2e2e2;\n     }\n     .autocomplete li.active .highlight {\n       background: #666;\n       color: #fff;\n     }`\n  ]\n})\nexport class AutocompleteComponent implements OnInit, OnChanges {\n  classList = 'autocomplete';\n  @Input() items: any[];\n  @Input() config: any;\n  @Output() selectEvent: EventEmitter<any> = new EventEmitter<any>();\n  @Output() inputChangedEvent: EventEmitter<any> = new EventEmitter<any>();\n  inputElement: HTMLInputElement;\n  value: string;\n  candidates: any[];\n  candidatesLabels: any[];\n  selectedIndex: number;\n  showAutoComplete: boolean;\n  placeholder: string;\n  maxLimit = 0;\n  private sourceField: any;\n  private thisElement: HTMLElement;\n\n  constructor(elementRef: ElementRef) {\n    this.thisElement = elementRef.nativeElement;\n    this.selectedIndex = 0;\n    this.showAutoComplete = false;\n    this.value = '';\n  }\n\n  ngOnInit() {\n    if (this.config && this.config.class) {\n      this.classList += ' ' + this.config.class;\n    }\n    if (this.config && this.config.max > 0) {\n      this.maxLimit = this.config.max;\n    }\n    this.placeholder = 'autocomplete';\n    this.inputElement = this.thisElement.querySelector(\n      'input'\n    ) as HTMLInputElement;\n\n    if (!this.isNull(this.config)) {\n      if (!this.isNull(this.config.placeholder)) {\n        this.placeholder = this.config.placeholder;\n      }\n      if (!this.isNull(this.config.sourceField)) {\n        this.sourceField = this.config.sourceField;\n      }\n    }\n    this.filterItems(this.value);\n    this.inputElement.focus();\n  }\n\n  ngOnChanges() {\n    this.filterItems(this.value);\n  }\n\n  enterText(event: any) {\n    const total = this.candidates.length;\n    switch (event.keyCode) {\n      case 27:\n        this.showAutoComplete = false;\n        break;\n      case 38:\n        this.selectedIndex = (total + this.selectedIndex - 1) % total;\n        break;\n      case 40:\n        this.selectedIndex = (total + this.selectedIndex + 1) % total;\n        break;\n      case 13:\n        if (this.candidates.length > 0) {\n          this.onSelect(this.selectedIndex);\n        }\n        event.preventDefault();\n        break;\n      default:\n        this.value = event.target.value;\n        this.inputChangedEvent.emit(this.value);\n        break;\n    }\n  }\n\n  onSelect(idx: number) {\n    this.showAutoComplete = false;\n    this.value = this.candidatesLabels[idx];\n    this.selectEvent.emit(this.candidates[idx]);\n  }\n\n  onKeyUpEvent(event: KeyboardEvent, idx: number): void {\n    if (event.keyCode === 13) {\n      this.onSelect(idx);\n    }\n }\n\n  filterItems(search: string) {\n    const field = this.sourceField;\n    const filterItem = this.filterItem;\n    if (this.items) {\n      this.candidates = this.items.filter(item => {\n        return filterItem(item, field, search);\n      });\n      if (this.maxLimit > 0) {\n        this.candidates = this.candidates.slice(0, this.maxLimit);\n      }\n      this.buildLabels();\n    }\n  }\n\n  private getFieldValue(object: any, path: any) {\n    if (typeof object === 'string') {\n      return object;\n    }\n    if (path instanceof Array) {\n      let result: any = object;\n      path.forEach((element: any) => {\n        if (\n          result !== null &&\n          result !== undefined &&\n          result[element] !== null &&\n          result[element] !== undefined\n        ) {\n          result = result[element];\n        } else {\n          result = '';\n        }\n      });\n      return result;\n    } else {\n      return object[path] || '';\n    }\n  }\n\n  private isNull(object: any) {\n    return object === null || object === undefined;\n  }\n\n  private buildLabels() {\n    const field = this.sourceField;\n    const getFieldValue = this.getFieldValue;\n    this.candidatesLabels = this.candidates.map((e: any) =>\n      getFieldValue(e, field)\n    );\n  }\n\n  private filterItem(item: any, path: any, search: string) {\n    if (search === null || search === undefined || search.length === 0) {\n      return true;\n    }\n    let result: any;\n    if (typeof item === 'string') {\n      result = item;\n    } else if (path instanceof Array) {\n      result = item;\n      path.forEach((element: any) => {\n        if (\n          result !== null &&\n          result !== undefined &&\n          result[element] !== null &&\n          result[element] !== undefined\n        ) {\n          result = result[element];\n        } else {\n          result = '';\n        }\n      });\n    } else {\n      result = item[path] || '';\n    }\n    return result.toLowerCase().indexOf(search.toLowerCase()) >= 0;\n  }\n}\n\n@Directive({\n  // tslint:disable-next-line\n  selector: '[input-autocomplete]'\n})\nexport class AutocompleteDirective implements OnInit, OnDestroy, OnChanges, AfterViewInit {\n  @Input() config: any;\n  @Input() items: any;\n  @Input() ngModel: string;\n  @Input() control: FormControl;\n  @Output() ngModelChange = new EventEmitter();\n  @Output() inputChangedEvent = new EventEmitter();\n  @Output() selectEvent = new EventEmitter();\n\n  private componentRef: ComponentRef<AutocompleteComponent>;\n  private thisElement: HTMLElement;\n  private autocompleteElement: HTMLElement;\n  private inputElement: HTMLInputElement;\n  private tabIndex: number;\n  private reset = false;\n\n  constructor(\n    private resolver: ComponentFactoryResolver,\n    public viewContainerRef: ViewContainerRef\n  ) {\n    this.thisElement = this.viewContainerRef.element.nativeElement;\n  }\n\n  ngOnInit() {\n    if (this.thisElement.tagName.toLowerCase() === 'form') {\n      return;\n    }\n    this.createDiv();\n  }\n\n  ngOnDestroy() {\n    if (this.componentRef) {\n      this.componentRef.instance.selectEvent.unsubscribe();\n      this.componentRef.instance.inputChangedEvent.unsubscribe();\n    }\n    document.removeEventListener('click', this.hideAutocomplete);\n  }\n\n  ngOnChanges(changes: { [propKey: string]: SimpleChange }) {\n    if (changes['items'] && this.componentRef) {\n      const component = this.componentRef.instance;\n      component.items = changes['items'].currentValue;\n      component.filterItems(component.value);\n    }\n  }\n\n  ngAfterViewInit() {\n    const input = this.getInputElement();\n    if (this.control) {\n      this.control.valueChanges.subscribe(() => {\n        this.reset = true;\n      });\n    }\n    if (input.form) {\n      input.form.addEventListener('reset', () => {\n        this.reset = true;\n      });\n    }\n  }\n\n  @HostListener('click', ['$event.target'])\n  @HostListener('focus', ['$event.target'])\n  showAutocomplete(event: any) {\n    this.hideAutocomplete();\n    if (event === this.thisElement) {\n      this.createAutocomplete();\n    }\n  }\n\n  getInputElement() {\n    let input = this.thisElement as HTMLInputElement;\n\n    if (this.thisElement.tagName !== 'INPUT' && this.autocompleteElement) {\n      input = this.thisElement.querySelector(\n        'input'\n      ) as HTMLInputElement;\n    }\n\n    return input;\n  }\n\n  hideAutocomplete = (event?: any): void => {\n    if (!this.componentRef) {\n      return;\n    }\n    if (event && event.target && this.thisElement && event.target === this.thisElement.parentElement) {\n      return;\n    }\n    if (\n      !event ||\n      (event.target !== this.thisElement && event.type === 'click')\n    ) {\n      this.componentRef.destroy();\n      this.componentRef = undefined;\n    }\n    if (this.inputElement['tabIndex'] < 0) {\n      this.inputElement['tabIndex'] = this.tabIndex;\n    }\n  }\n\n  onInputChanged = (val: string) => {\n    this.inputElement.value = val;\n    if (val !== this.ngModel) {\n      this.ngModel = val;\n      this.ngModelChange.emit(val);\n    }\n    const component = this.componentRef.instance;\n    component.filterItems(val);\n    this.inputChangedEvent.emit(val);\n  }\n\n  onSelect = (item: any) => {\n    const component = this.componentRef.instance;\n    const val = component.value;\n    if (val !== this.ngModel) {\n      this.ngModel = val;\n      this.ngModelChange.emit(val);\n    }\n    this.selectEvent.emit(item);\n    if (this.inputElement) {\n      this.inputElement.value = '' + val;\n    }\n    this.hideAutocomplete();\n  }\n\n  private createDiv() {\n    const element = document.createElement('div');\n    element.style.display = 'inline-block';\n    element.style.position = 'relative';\n    this.thisElement.parentElement.insertBefore(\n      element,\n      this.thisElement.nextSibling\n    );\n    element.appendChild(this.thisElement);\n    document.addEventListener('click', this.hideAutocomplete);\n  }\n\n  private createAutocomplete() {\n    const factory = this.resolver.resolveComponentFactory(\n      AutocompleteComponent\n    );\n    this.componentRef = this.viewContainerRef.createComponent(factory);\n    const component = this.componentRef.instance;\n    component.config = this.config;\n    component.items = this.items;\n    component.selectEvent.subscribe(this.onSelect);\n    component.inputChangedEvent.subscribe(this.onInputChanged);\n    this.autocompleteElement = this.componentRef.location.nativeElement;\n    this.autocompleteElement.style.display = 'none';\n    this.inputElement = this.getInputElement();\n    if (this.thisElement.tagName !== 'INPUT' && this.autocompleteElement) {\n      this.inputElement.parentElement.insertBefore(\n        this.autocompleteElement,\n        this.inputElement.nextSibling\n      );\n    }\n\n    if (this.reset) {\n      this.ngModel = '';\n      this.reset = false;\n    }\n\n    this.inputElement.value = this.ngModel ? this.ngModel : '';\n    component.value = this.inputElement.value;\n    this.tabIndex = this.inputElement['tabIndex'];\n    this.inputElement['tabIndex'] = -100;\n    if (this.componentRef) {\n      const rect = this.thisElement.getBoundingClientRect();\n      const style = this.autocompleteElement.style;\n      style.width = rect.width + 'px';\n      style.position = 'absolute';\n      style.zIndex = '1';\n      style.top = '0';\n      style.left = '0';\n      style.display = 'inline-block';\n    }\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete.component.js","sourceRoot":"ng://ng2-input-autocomplete/","sources":["lib/autocomplete.component.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n  MIT LICENSE @liuy97\n*/\nimport {\n  Component,\n  ComponentFactoryResolver,\n  ComponentRef,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  AfterViewInit,\n  Output,\n  SimpleChange,\n  ViewContainerRef,\n  HostBinding\n} from '@angular/core';\nimport {FormControl} from '@angular/forms';\n\n@Component({\n  // tslint:disable-next-line\n  selector: 'ng2-input-autocomplete',\n  template: `\n  <div [ngClass]=\"classList\">\n    <input type=\"text\"\n      placeholder=\"{{placeholder}}\"\n      (blur)=\"showAutoComplete = false;\"\n      (focus)=\"showAutoComplete = true;\"\n      [value]=\"value\"\n      (keyup)=\"enterText($event)\">\n    <ul *ngIf=\"showAutoComplete && candidates && candidates.length > 0\">\n      <li *ngFor=\"let candidate of candidates; let idx = index\"\n        [ngClass]=\"{ active: (idx === selectedIndex) }\"\n        (keyup)=\"onKeyUpEvent($event, idx)\"\n        (mouseover)=\"selectedIndex = idx;\"\n        (mousedown)=\"onSelect(idx)\">\n        {{candidatesLabels[idx]}}\n      </li>\n    </ul>\n  </div>`,\n  styles: [\n    `.autocomplete ul {\n       position: absolute;\n       left: 0;\n       width: 100%;\n       border-left: 1px solid #888;\n       border-right: 1px solid #888;\n       border-bottom: 1px solid #888;\n       list-style: none;\n       padding-left: 0px;\n       margin-top: 2px;\n       background-color: #fff;\n       z-index: 100;\n     }\n     .autocomplete li {\n       text-align: left;\n       list-style: none;\n       width: 100%;\n       padding: 0.4em 0 0.4em 0;\n     }\n     .autocomplete li.active {\n       width: 100%;\n       background-color: #4bf;\n     }\n\n     .autocomplete .highlight {\n       background-color: #e2e2e2;\n     }\n     .autocomplete li.active .highlight {\n       background: #666;\n       color: #fff;\n     }`\n  ]\n})\nexport class AutocompleteComponent implements OnInit, OnChanges {\n  classList = 'autocomplete';\n  @Input() items: any[];\n  @Input() config: any;\n  @Output() selectEvent: EventEmitter<any> = new EventEmitter<any>();\n  @Output() inputChangedEvent: EventEmitter<any> = new EventEmitter<any>();\n  inputElement: HTMLInputElement;\n  value: string;\n  candidates: any[];\n  candidatesLabels: any[];\n  selectedIndex: number;\n  showAutoComplete: boolean;\n  placeholder: string;\n  maxLimit = 0;\n  private sourceField: any;\n  private thisElement: HTMLElement;\n\n  constructor(elementRef: ElementRef) {\n    this.thisElement = elementRef.nativeElement;\n    this.selectedIndex = 0;\n    this.showAutoComplete = false;\n    this.value = '';\n  }\n\n  ngOnInit() {\n    if (this.config && this.config.class) {\n      this.classList += ' ' + this.config.class;\n    }\n    if (this.config && this.config.max > 0) {\n      this.maxLimit = this.config.max;\n    }\n    this.placeholder = 'autocomplete';\n    this.inputElement = this.thisElement.querySelector(\n      'input'\n    ) as HTMLInputElement;\n\n    if (!this.isNull(this.config)) {\n      if (!this.isNull(this.config.placeholder)) {\n        this.placeholder = this.config.placeholder;\n      }\n      if (!this.isNull(this.config.sourceField)) {\n        this.sourceField = this.config.sourceField;\n      }\n    }\n    this.filterItems(this.value);\n    this.inputElement.focus();\n  }\n\n  ngOnChanges() {\n    this.filterItems(this.value);\n  }\n\n  enterText(event: any) {\n    const total = this.candidates.length;\n    switch (event.keyCode) {\n      case 27:\n        this.showAutoComplete = false;\n        break;\n      case 38:\n        this.selectedIndex = (total + this.selectedIndex - 1) % total;\n        break;\n      case 40:\n        this.selectedIndex = (total + this.selectedIndex + 1) % total;\n        break;\n      case 13:\n        if (this.candidates.length > 0) {\n          this.onSelect(this.selectedIndex);\n        }\n        event.preventDefault();\n        break;\n      default:\n        this.value = event.target.value;\n        this.inputChangedEvent.emit(this.value);\n        break;\n    }\n  }\n\n  onSelect(idx: number) {\n    this.showAutoComplete = false;\n    this.value = this.candidatesLabels[idx];\n    this.selectEvent.emit(this.candidates[idx]);\n  }\n\n  onKeyUpEvent(event: KeyboardEvent, idx: number): void {\n    if (event.keyCode === 13) {\n      this.onSelect(idx);\n    }\n }\n\n  filterItems(search: string) {\n    const field = this.sourceField;\n    const filterItem = this.filterItem;\n    if (this.items) {\n      this.candidates = this.items.filter(item => {\n        return filterItem(item, field, search);\n      });\n      if (this.maxLimit > 0) {\n        this.candidates = this.candidates.slice(0, this.maxLimit);\n      }\n      this.buildLabels();\n    }\n  }\n\n  private getFieldValue(object: any, path: any) {\n    if (typeof object === 'string') {\n      return object;\n    }\n    if (path instanceof Array) {\n      let result: any = object;\n      path.forEach((element: any) => {\n        if (\n          result !== null &&\n          result !== undefined &&\n          result[element] !== null &&\n          result[element] !== undefined\n        ) {\n          result = result[element];\n        } else {\n          result = '';\n        }\n      });\n      return result;\n    } else {\n      return object[path] || '';\n    }\n  }\n\n  private isNull(object: any) {\n    return object === null || object === undefined;\n  }\n\n  private buildLabels() {\n    const field = this.sourceField;\n    const getFieldValue = this.getFieldValue;\n    this.candidatesLabels = this.candidates.map((e: any) =>\n      getFieldValue(e, field)\n    );\n  }\n\n  private filterItem(item: any, path: any, search: string) {\n    if (search === null || search === undefined || search.length === 0) {\n      return true;\n    }\n    let result: any;\n    if (typeof item === 'string') {\n      result = item;\n    } else if (path instanceof Array) {\n      result = item;\n      path.forEach((element: any) => {\n        if (\n          result !== null &&\n          result !== undefined &&\n          result[element] !== null &&\n          result[element] !== undefined\n        ) {\n          result = result[element];\n        } else {\n          result = '';\n        }\n      });\n    } else {\n      result = item[path] || '';\n    }\n    return result.toLowerCase().indexOf(search.toLowerCase()) >= 0;\n  }\n}\n\n@Directive({\n  // tslint:disable-next-line\n  selector: '[input-autocomplete]'\n})\nexport class AutocompleteDirective implements OnInit, OnDestroy, OnChanges, AfterViewInit {\n  @Input() config: any;\n  @Input() items: any;\n  @Input() ngModel: string;\n  @Input() control: FormControl;\n  @Output() ngModelChange = new EventEmitter();\n  @Output() inputChangedEvent = new EventEmitter();\n  @Output() selectEvent = new EventEmitter();\n\n  private componentRef: ComponentRef<AutocompleteComponent>;\n  private thisElement: HTMLElement;\n  private autocompleteElement: HTMLElement;\n  private inputElement: HTMLInputElement;\n  private tabIndex: number;\n  private reset = false;\n\n  constructor(\n    private resolver: ComponentFactoryResolver,\n    public viewContainerRef: ViewContainerRef\n  ) {\n    this.thisElement = this.viewContainerRef.element.nativeElement;\n  }\n\n  ngOnInit() {\n    if (this.thisElement.tagName.toLowerCase() === 'form') {\n      return;\n    }\n    this.createDiv();\n  }\n\n  ngOnDestroy() {\n    if (this.componentRef) {\n      this.componentRef.instance.selectEvent.unsubscribe();\n      this.componentRef.instance.inputChangedEvent.unsubscribe();\n    }\n    document.removeEventListener('click', this.hideAutocomplete);\n  }\n\n  ngOnChanges(changes: { [propKey: string]: SimpleChange }) {\n    if (changes['items'] && this.componentRef) {\n      const component = this.componentRef.instance;\n      component.items = changes['items'].currentValue;\n      component.filterItems(component.value);\n    }\n  }\n\n  ngAfterViewInit() {\n    const input = this.getInputElement();\n    if (this.control) {\n      this.control.valueChanges.subscribe(() => {\n        this.reset = true;\n      });\n    }\n    if (input.form) {\n      input.form.addEventListener('reset', () => {\n        this.reset = true;\n      });\n    }\n  }\n\n  @HostListener('click', ['$event.target'])\n  @HostListener('focus', ['$event.target'])\n  showAutocomplete(event: any) {\n    this.hideAutocomplete();\n    if (event === this.thisElement) {\n      this.createAutocomplete();\n    }\n  }\n\n  getInputElement() {\n    let input = this.thisElement as HTMLInputElement;\n\n    if (this.thisElement.tagName !== 'INPUT' && this.autocompleteElement) {\n      input = this.thisElement.querySelector(\n        'input'\n      ) as HTMLInputElement;\n    }\n\n    return input;\n  }\n\n  hideAutocomplete = (event?: any): void => {\n    if (!this.componentRef) {\n      return;\n    }\n    if (event && event.target && this.thisElement && event.target === this.thisElement.parentElement) {\n      return;\n    }\n    if (\n      !event ||\n      (event.target !== this.thisElement && event.type === 'click')\n    ) {\n      this.componentRef.destroy();\n      this.componentRef = undefined;\n    }\n    if (this.inputElement['tabIndex'] < 0) {\n      this.inputElement['tabIndex'] = this.tabIndex;\n    }\n  }\n\n  onInputChanged = (val: string) => {\n    this.inputElement.value = val;\n    if (val !== this.ngModel) {\n      this.ngModel = val;\n      this.ngModelChange.emit(val);\n    }\n    const component = this.componentRef.instance;\n    component.filterItems(val);\n    this.inputChangedEvent.emit(val);\n  }\n\n  onSelect = (item: any) => {\n    const component = this.componentRef.instance;\n    const val = component.value;\n    if (val !== this.ngModel) {\n      this.ngModel = val;\n      this.ngModelChange.emit(val);\n    }\n    this.selectEvent.emit(item);\n    if (this.inputElement) {\n      this.inputElement.value = '' + val;\n    }\n    this.hideAutocomplete();\n  }\n\n  private createDiv() {\n    const element = document.createElement('div');\n    element.style.display = 'inline-block';\n    element.style.position = 'relative';\n    this.thisElement.parentElement.insertBefore(\n      element,\n      this.thisElement.nextSibling\n    );\n    element.appendChild(this.thisElement);\n    document.addEventListener('click', this.hideAutocomplete);\n  }\n\n  private createAutocomplete() {\n    const factory = this.resolver.resolveComponentFactory(\n      AutocompleteComponent\n    );\n    this.componentRef = this.viewContainerRef.createComponent(factory);\n    const component = this.componentRef.instance;\n    component.config = this.config;\n    component.items = this.items;\n    component.selectEvent.subscribe(this.onSelect);\n    component.inputChangedEvent.subscribe(this.onInputChanged);\n    this.autocompleteElement = this.componentRef.location.nativeElement;\n    this.autocompleteElement.style.display = 'none';\n    this.inputElement = this.getInputElement();\n    if (this.thisElement.tagName !== 'INPUT' && this.autocompleteElement) {\n      this.inputElement.parentElement.insertBefore(\n        this.autocompleteElement,\n        this.inputElement.nextSibling\n      );\n    }\n\n    if (this.reset) {\n      this.ngModel = '';\n      this.reset = false;\n    }\n\n    this.inputElement.value = this.ngModel ? this.ngModel : '';\n    component.value = this.inputElement.value;\n    this.tabIndex = this.inputElement['tabIndex'];\n    this.inputElement['tabIndex'] = -100;\n    if (this.componentRef) {\n      const rect = this.thisElement.getBoundingClientRect();\n      const style = this.autocompleteElement.style;\n      style.width = rect.width + 'px';\n      style.position = 'absolute';\n      style.zIndex = '1';\n      style.top = '0';\n      style.left = '0';\n      style.display = 'inline-block';\n    }\n  }\n}\n"]} |
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc | ||
* Generated from: lib/autocomplete.module.ts | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -34,3 +35,2 @@ import { NgModule } from '@angular/core'; | ||
export { AutocompleteModule }; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0b2NvbXBsZXRlLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25nMi1pbnB1dC1hdXRvY29tcGxldGUvIiwic291cmNlcyI6WyJsaWIvYXV0b2NvbXBsZXRlLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7O0FBQUEsT0FBTyxFQUFFLFFBQVEsRUFBdUIsTUFBTSxlQUFlLENBQUM7QUFDOUQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM3QyxPQUFPLEVBQUUscUJBQXFCLEVBQUUscUJBQXFCLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQzs7Ozs7OztJQVMvRSwwQkFBTzs7O0lBQWQ7UUFDRSxPQUFPO1lBQ0wsUUFBUSxFQUFFLGtCQUFrQjtTQUM3QixDQUFDO0tBQ0g7O2dCQVhGLFFBQVEsU0FBQztvQkFDUixPQUFPLEVBQUUsQ0FBQyxZQUFZLEVBQUUsV0FBVyxDQUFDO29CQUNwQyxZQUFZLEVBQUUsQ0FBQyxxQkFBcUIsRUFBRSxxQkFBcUIsQ0FBQztvQkFDNUQsT0FBTyxFQUFFLENBQUMscUJBQXFCLEVBQUUscUJBQXFCLENBQUM7b0JBQ3ZELGVBQWUsRUFBRSxDQUFDLHFCQUFxQixDQUFDO2lCQUN6Qzs7NkJBVkQ7O1NBV2Esa0JBQWtCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUsIE1vZHVsZVdpdGhQcm92aWRlcnMgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IEF1dG9jb21wbGV0ZUNvbXBvbmVudCwgQXV0b2NvbXBsZXRlRGlyZWN0aXZlIH0gZnJvbSAnLi9hdXRvY29tcGxldGUuY29tcG9uZW50JztcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgRm9ybXNNb2R1bGVdLFxuICBkZWNsYXJhdGlvbnM6IFtBdXRvY29tcGxldGVDb21wb25lbnQsIEF1dG9jb21wbGV0ZURpcmVjdGl2ZV0sXG4gIGV4cG9ydHM6IFtBdXRvY29tcGxldGVDb21wb25lbnQsIEF1dG9jb21wbGV0ZURpcmVjdGl2ZV0sXG4gIGVudHJ5Q29tcG9uZW50czogW0F1dG9jb21wbGV0ZUNvbXBvbmVudF1cbn0pXG5leHBvcnQgY2xhc3MgQXV0b2NvbXBsZXRlTW9kdWxlIHtcbiAgc3RhdGljIGZvclJvb3QoKTogTW9kdWxlV2l0aFByb3ZpZGVycyB7XG4gICAgcmV0dXJuIHtcbiAgICAgIG5nTW9kdWxlOiBBdXRvY29tcGxldGVNb2R1bGVcbiAgICB9O1xuICB9XG59XG5cbiJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0b2NvbXBsZXRlLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25nMi1pbnB1dC1hdXRvY29tcGxldGUvIiwic291cmNlcyI6WyJsaWIvYXV0b2NvbXBsZXRlLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQXVCLE1BQU0sZUFBZSxDQUFDO0FBQzlELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDN0MsT0FBTyxFQUFFLHFCQUFxQixFQUFFLHFCQUFxQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFFeEY7SUFBQTtJQVlBLENBQUM7Ozs7SUFMUSwwQkFBTzs7O0lBQWQ7UUFDRSxPQUFPO1lBQ0wsUUFBUSxFQUFFLGtCQUFrQjtTQUM3QixDQUFDO0lBQ0osQ0FBQzs7Z0JBWEYsUUFBUSxTQUFDO29CQUNSLE9BQU8sRUFBRSxDQUFDLFlBQVksRUFBRSxXQUFXLENBQUM7b0JBQ3BDLFlBQVksRUFBRSxDQUFDLHFCQUFxQixFQUFFLHFCQUFxQixDQUFDO29CQUM1RCxPQUFPLEVBQUUsQ0FBQyxxQkFBcUIsRUFBRSxxQkFBcUIsQ0FBQztvQkFDdkQsZUFBZSxFQUFFLENBQUMscUJBQXFCLENBQUM7aUJBQ3pDOztJQU9ELHlCQUFDO0NBQUEsQUFaRCxJQVlDO1NBTlksa0JBQWtCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUsIE1vZHVsZVdpdGhQcm92aWRlcnMgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IEF1dG9jb21wbGV0ZUNvbXBvbmVudCwgQXV0b2NvbXBsZXRlRGlyZWN0aXZlIH0gZnJvbSAnLi9hdXRvY29tcGxldGUuY29tcG9uZW50JztcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgRm9ybXNNb2R1bGVdLFxuICBkZWNsYXJhdGlvbnM6IFtBdXRvY29tcGxldGVDb21wb25lbnQsIEF1dG9jb21wbGV0ZURpcmVjdGl2ZV0sXG4gIGV4cG9ydHM6IFtBdXRvY29tcGxldGVDb21wb25lbnQsIEF1dG9jb21wbGV0ZURpcmVjdGl2ZV0sXG4gIGVudHJ5Q29tcG9uZW50czogW0F1dG9jb21wbGV0ZUNvbXBvbmVudF1cbn0pXG5leHBvcnQgY2xhc3MgQXV0b2NvbXBsZXRlTW9kdWxlIHtcbiAgc3RhdGljIGZvclJvb3QoKTogTW9kdWxlV2l0aFByb3ZpZGVycyB7XG4gICAgcmV0dXJuIHtcbiAgICAgIG5nTW9kdWxlOiBBdXRvY29tcGxldGVNb2R1bGVcbiAgICB9O1xuICB9XG59XG5cbiJdfQ== |
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc | ||
* Generated from: ng2-input-autocomplete.ts | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -9,3 +10,2 @@ /** | ||
export { AutocompleteComponent, AutocompleteDirective, AutocompleteModule } from './public_api'; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmcyLWlucHV0LWF1dG9jb21wbGV0ZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25nMi1pbnB1dC1hdXRvY29tcGxldGUvIiwic291cmNlcyI6WyJuZzItaW5wdXQtYXV0b2NvbXBsZXRlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFJQSxpRkFBYyxjQUFjLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vcHVibGljX2FwaSc7XG4iXX0= | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmcyLWlucHV0LWF1dG9jb21wbGV0ZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25nMi1pbnB1dC1hdXRvY29tcGxldGUvIiwic291cmNlcyI6WyJuZzItaW5wdXQtYXV0b2NvbXBsZXRlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7O0FBSUEsaUZBQWMsY0FBYyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL3B1YmxpY19hcGknO1xuIl19 |
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc | ||
* Generated from: public_api.ts | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -10,3 +11,2 @@ /* | ||
export { AutocompleteModule } from './lib/autocomplete.module'; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25nMi1pbnB1dC1hdXRvY29tcGxldGUvIiwic291cmNlcyI6WyJwdWJsaWNfYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFJQSw2REFBYyw4QkFBOEIsQ0FBQztBQUM3QyxtQ0FBYywyQkFBMkIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2YgYXV0b2NvbXBsZXRlXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9saWIvYXV0b2NvbXBsZXRlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9hdXRvY29tcGxldGUubW9kdWxlJztcbiJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25nMi1pbnB1dC1hdXRvY29tcGxldGUvIiwic291cmNlcyI6WyJwdWJsaWNfYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7O0FBSUEsNkRBQWMsOEJBQThCLENBQUM7QUFDN0MsbUNBQWMsMkJBQTJCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIGF1dG9jb21wbGV0ZVxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vbGliL2F1dG9jb21wbGV0ZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYXV0b2NvbXBsZXRlLm1vZHVsZSc7XG4iXX0= |
@@ -1,2 +0,2 @@ | ||
import { Component, ComponentFactoryResolver, Directive, ElementRef, EventEmitter, HostListener, Input, Output, ViewContainerRef, NgModule } from '@angular/core'; | ||
import { EventEmitter, Component, ElementRef, Input, Output, Directive, ComponentFactoryResolver, ViewContainerRef, HostListener, NgModule } from '@angular/core'; | ||
import { FormsModule } from '@angular/forms'; | ||
@@ -7,3 +7,4 @@ import { CommonModule } from '@angular/common'; | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc | ||
* Generated from: lib/autocomplete.component.ts | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -35,3 +36,3 @@ class AutocompleteComponent { | ||
this.placeholder = 'autocomplete'; | ||
this.inputElement = /** @type {?} */ (this.thisElement.querySelector('input')); | ||
this.inputElement = (/** @type {?} */ (this.thisElement.querySelector('input'))); | ||
if (!this.isNull(this.config)) { | ||
@@ -112,5 +113,9 @@ if (!this.isNull(this.config.placeholder)) { | ||
if (this.items) { | ||
this.candidates = this.items.filter(item => { | ||
this.candidates = this.items.filter((/** | ||
* @param {?} item | ||
* @return {?} | ||
*/ | ||
item => { | ||
return filterItem(item, field, search); | ||
}); | ||
})); | ||
if (this.maxLimit > 0) { | ||
@@ -123,2 +128,3 @@ this.candidates = this.candidates.slice(0, this.maxLimit); | ||
/** | ||
* @private | ||
* @param {?} object | ||
@@ -135,3 +141,7 @@ * @param {?} path | ||
let result = object; | ||
path.forEach((element) => { | ||
path.forEach((/** | ||
* @param {?} element | ||
* @return {?} | ||
*/ | ||
(element) => { | ||
if (result !== null && | ||
@@ -146,3 +156,3 @@ result !== undefined && | ||
} | ||
}); | ||
})); | ||
return result; | ||
@@ -155,2 +165,3 @@ } | ||
/** | ||
* @private | ||
* @param {?} object | ||
@@ -163,2 +174,3 @@ * @return {?} | ||
/** | ||
* @private | ||
* @return {?} | ||
@@ -171,5 +183,10 @@ */ | ||
const getFieldValue = this.getFieldValue; | ||
this.candidatesLabels = this.candidates.map((e) => getFieldValue(e, field)); | ||
this.candidatesLabels = this.candidates.map((/** | ||
* @param {?} e | ||
* @return {?} | ||
*/ | ||
(e) => getFieldValue(e, field))); | ||
} | ||
/** | ||
* @private | ||
* @param {?} item | ||
@@ -191,3 +208,7 @@ * @param {?} path | ||
result = item; | ||
path.forEach((element) => { | ||
path.forEach((/** | ||
* @param {?} element | ||
* @return {?} | ||
*/ | ||
(element) => { | ||
if (result !== null && | ||
@@ -202,3 +223,3 @@ result !== undefined && | ||
} | ||
}); | ||
})); | ||
} | ||
@@ -276,2 +297,40 @@ else { | ||
}; | ||
if (false) { | ||
/** @type {?} */ | ||
AutocompleteComponent.prototype.classList; | ||
/** @type {?} */ | ||
AutocompleteComponent.prototype.items; | ||
/** @type {?} */ | ||
AutocompleteComponent.prototype.config; | ||
/** @type {?} */ | ||
AutocompleteComponent.prototype.selectEvent; | ||
/** @type {?} */ | ||
AutocompleteComponent.prototype.inputChangedEvent; | ||
/** @type {?} */ | ||
AutocompleteComponent.prototype.inputElement; | ||
/** @type {?} */ | ||
AutocompleteComponent.prototype.value; | ||
/** @type {?} */ | ||
AutocompleteComponent.prototype.candidates; | ||
/** @type {?} */ | ||
AutocompleteComponent.prototype.candidatesLabels; | ||
/** @type {?} */ | ||
AutocompleteComponent.prototype.selectedIndex; | ||
/** @type {?} */ | ||
AutocompleteComponent.prototype.showAutoComplete; | ||
/** @type {?} */ | ||
AutocompleteComponent.prototype.placeholder; | ||
/** @type {?} */ | ||
AutocompleteComponent.prototype.maxLimit; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
AutocompleteComponent.prototype.sourceField; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
AutocompleteComponent.prototype.thisElement; | ||
} | ||
class AutocompleteDirective { | ||
@@ -289,3 +348,7 @@ /** | ||
this.reset = false; | ||
this.hideAutocomplete = (event) => { | ||
this.hideAutocomplete = (/** | ||
* @param {?=} event | ||
* @return {?} | ||
*/ | ||
(event) => { | ||
if (!this.componentRef) { | ||
@@ -305,4 +368,8 @@ return; | ||
} | ||
}; | ||
this.onInputChanged = (val) => { | ||
}); | ||
this.onInputChanged = (/** | ||
* @param {?} val | ||
* @return {?} | ||
*/ | ||
(val) => { | ||
this.inputElement.value = val; | ||
@@ -317,4 +384,8 @@ if (val !== this.ngModel) { | ||
this.inputChangedEvent.emit(val); | ||
}; | ||
this.onSelect = (item) => { | ||
}); | ||
this.onSelect = (/** | ||
* @param {?} item | ||
* @return {?} | ||
*/ | ||
(item) => { | ||
/** @type {?} */ | ||
@@ -333,3 +404,3 @@ const component = this.componentRef.instance; | ||
this.hideAutocomplete(); | ||
}; | ||
}); | ||
this.thisElement = this.viewContainerRef.element.nativeElement; | ||
@@ -375,10 +446,16 @@ } | ||
if (this.control) { | ||
this.control.valueChanges.subscribe(() => { | ||
this.control.valueChanges.subscribe((/** | ||
* @return {?} | ||
*/ | ||
() => { | ||
this.reset = true; | ||
}); | ||
})); | ||
} | ||
if (input.form) { | ||
input.form.addEventListener('reset', () => { | ||
input.form.addEventListener('reset', (/** | ||
* @return {?} | ||
*/ | ||
() => { | ||
this.reset = true; | ||
}); | ||
})); | ||
} | ||
@@ -401,5 +478,5 @@ } | ||
/** @type {?} */ | ||
let input = /** @type {?} */ (this.thisElement); | ||
let input = (/** @type {?} */ (this.thisElement)); | ||
if (this.thisElement.tagName !== 'INPUT' && this.autocompleteElement) { | ||
input = /** @type {?} */ (this.thisElement.querySelector('input')); | ||
input = (/** @type {?} */ (this.thisElement.querySelector('input'))); | ||
} | ||
@@ -409,2 +486,3 @@ return input; | ||
/** | ||
* @private | ||
* @return {?} | ||
@@ -422,2 +500,3 @@ */ | ||
/** | ||
* @private | ||
* @return {?} | ||
@@ -484,6 +563,66 @@ */ | ||
}; | ||
if (false) { | ||
/** @type {?} */ | ||
AutocompleteDirective.prototype.config; | ||
/** @type {?} */ | ||
AutocompleteDirective.prototype.items; | ||
/** @type {?} */ | ||
AutocompleteDirective.prototype.ngModel; | ||
/** @type {?} */ | ||
AutocompleteDirective.prototype.control; | ||
/** @type {?} */ | ||
AutocompleteDirective.prototype.ngModelChange; | ||
/** @type {?} */ | ||
AutocompleteDirective.prototype.inputChangedEvent; | ||
/** @type {?} */ | ||
AutocompleteDirective.prototype.selectEvent; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
AutocompleteDirective.prototype.componentRef; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
AutocompleteDirective.prototype.thisElement; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
AutocompleteDirective.prototype.autocompleteElement; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
AutocompleteDirective.prototype.inputElement; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
AutocompleteDirective.prototype.tabIndex; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
AutocompleteDirective.prototype.reset; | ||
/** @type {?} */ | ||
AutocompleteDirective.prototype.hideAutocomplete; | ||
/** @type {?} */ | ||
AutocompleteDirective.prototype.onInputChanged; | ||
/** @type {?} */ | ||
AutocompleteDirective.prototype.onSelect; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
AutocompleteDirective.prototype.resolver; | ||
/** @type {?} */ | ||
AutocompleteDirective.prototype.viewContainerRef; | ||
} | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc | ||
* Generated from: lib/autocomplete.module.ts | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -511,3 +650,4 @@ class AutocompleteModule { | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc | ||
* Generated from: public_api.ts | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -517,7 +657,7 @@ | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc | ||
* Generated from: ng2-input-autocomplete.ts | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
export { AutocompleteComponent, AutocompleteDirective, AutocompleteModule }; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"ng2-input-autocomplete.js.map","sources":["ng://ng2-input-autocomplete/lib/autocomplete.component.ts","ng://ng2-input-autocomplete/lib/autocomplete.module.ts"],"sourcesContent":["/*\n  MIT LICENSE @liuy97\n*/\nimport {\n  Component,\n  ComponentFactoryResolver,\n  ComponentRef,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  AfterViewInit,\n  Output,\n  SimpleChange,\n  ViewContainerRef,\n  HostBinding\n} from '@angular/core';\nimport {FormControl} from '@angular/forms';\n\n@Component({\n  // tslint:disable-next-line\n  selector: 'ng2-input-autocomplete',\n  template: `\n  <div [ngClass]=\"classList\">\n    <input type=\"text\"\n      placeholder=\"{{placeholder}}\"\n      (blur)=\"showAutoComplete = false;\"\n      (focus)=\"showAutoComplete = true;\"\n      [value]=\"value\"\n      (keyup)=\"enterText($event)\">\n    <ul *ngIf=\"showAutoComplete && candidates && candidates.length > 0\">\n      <li *ngFor=\"let candidate of candidates; let idx = index\"\n        [ngClass]=\"{ active: (idx === selectedIndex) }\"\n        (keyup)=\"onKeyUpEvent($event, idx)\"\n        (mouseover)=\"selectedIndex = idx;\"\n        (mousedown)=\"onSelect(idx)\">\n        {{candidatesLabels[idx]}}\n      </li>\n    </ul>\n  </div>`,\n  styles: [\n    `.autocomplete ul {\n       position: absolute;\n       left: 0;\n       width: 100%;\n       border-left: 1px solid #888;\n       border-right: 1px solid #888;\n       border-bottom: 1px solid #888;\n       list-style: none;\n       padding-left: 0px;\n       margin-top: 2px;\n       background-color: #fff;\n       z-index: 100;\n     }\n     .autocomplete li {\n       text-align: left;\n       list-style: none;\n       width: 100%;\n       padding: 0.4em 0 0.4em 0;\n     }\n     .autocomplete li.active {\n       width: 100%;\n       background-color: #4bf;\n     }\n\n     .autocomplete .highlight {\n       background-color: #e2e2e2;\n     }\n     .autocomplete li.active .highlight {\n       background: #666;\n       color: #fff;\n     }`\n  ]\n})\nexport class AutocompleteComponent implements OnInit, OnChanges {\n  classList = 'autocomplete';\n  @Input() items: any[];\n  @Input() config: any;\n  @Output() selectEvent: EventEmitter<any> = new EventEmitter<any>();\n  @Output() inputChangedEvent: EventEmitter<any> = new EventEmitter<any>();\n  inputElement: HTMLInputElement;\n  value: string;\n  candidates: any[];\n  candidatesLabels: any[];\n  selectedIndex: number;\n  showAutoComplete: boolean;\n  placeholder: string;\n  maxLimit = 0;\n  private sourceField: any;\n  private thisElement: HTMLElement;\n\n  constructor(elementRef: ElementRef) {\n    this.thisElement = elementRef.nativeElement;\n    this.selectedIndex = 0;\n    this.showAutoComplete = false;\n    this.value = '';\n  }\n\n  ngOnInit() {\n    if (this.config && this.config.class) {\n      this.classList += ' ' + this.config.class;\n    }\n    if (this.config && this.config.max > 0) {\n      this.maxLimit = this.config.max;\n    }\n    this.placeholder = 'autocomplete';\n    this.inputElement = this.thisElement.querySelector(\n      'input'\n    ) as HTMLInputElement;\n\n    if (!this.isNull(this.config)) {\n      if (!this.isNull(this.config.placeholder)) {\n        this.placeholder = this.config.placeholder;\n      }\n      if (!this.isNull(this.config.sourceField)) {\n        this.sourceField = this.config.sourceField;\n      }\n    }\n    this.filterItems(this.value);\n    this.inputElement.focus();\n  }\n\n  ngOnChanges() {\n    this.filterItems(this.value);\n  }\n\n  enterText(event: any) {\n    const total = this.candidates.length;\n    switch (event.keyCode) {\n      case 27:\n        this.showAutoComplete = false;\n        break;\n      case 38:\n        this.selectedIndex = (total + this.selectedIndex - 1) % total;\n        break;\n      case 40:\n        this.selectedIndex = (total + this.selectedIndex + 1) % total;\n        break;\n      case 13:\n        if (this.candidates.length > 0) {\n          this.onSelect(this.selectedIndex);\n        }\n        event.preventDefault();\n        break;\n      default:\n        this.value = event.target.value;\n        this.inputChangedEvent.emit(this.value);\n        break;\n    }\n  }\n\n  onSelect(idx: number) {\n    this.showAutoComplete = false;\n    this.value = this.candidatesLabels[idx];\n    this.selectEvent.emit(this.candidates[idx]);\n  }\n\n  onKeyUpEvent(event: KeyboardEvent, idx: number): void {\n    if (event.keyCode === 13) {\n      this.onSelect(idx);\n    }\n }\n\n  filterItems(search: string) {\n    const field = this.sourceField;\n    const filterItem = this.filterItem;\n    if (this.items) {\n      this.candidates = this.items.filter(item => {\n        return filterItem(item, field, search);\n      });\n      if (this.maxLimit > 0) {\n        this.candidates = this.candidates.slice(0, this.maxLimit);\n      }\n      this.buildLabels();\n    }\n  }\n\n  private getFieldValue(object: any, path: any) {\n    if (typeof object === 'string') {\n      return object;\n    }\n    if (path instanceof Array) {\n      let result: any = object;\n      path.forEach((element: any) => {\n        if (\n          result !== null &&\n          result !== undefined &&\n          result[element] !== null &&\n          result[element] !== undefined\n        ) {\n          result = result[element];\n        } else {\n          result = '';\n        }\n      });\n      return result;\n    } else {\n      return object[path] || '';\n    }\n  }\n\n  private isNull(object: any) {\n    return object === null || object === undefined;\n  }\n\n  private buildLabels() {\n    const field = this.sourceField;\n    const getFieldValue = this.getFieldValue;\n    this.candidatesLabels = this.candidates.map((e: any) =>\n      getFieldValue(e, field)\n    );\n  }\n\n  private filterItem(item: any, path: any, search: string) {\n    if (search === null || search === undefined || search.length === 0) {\n      return true;\n    }\n    let result: any;\n    if (typeof item === 'string') {\n      result = item;\n    } else if (path instanceof Array) {\n      result = item;\n      path.forEach((element: any) => {\n        if (\n          result !== null &&\n          result !== undefined &&\n          result[element] !== null &&\n          result[element] !== undefined\n        ) {\n          result = result[element];\n        } else {\n          result = '';\n        }\n      });\n    } else {\n      result = item[path] || '';\n    }\n    return result.toLowerCase().indexOf(search.toLowerCase()) >= 0;\n  }\n}\n\n@Directive({\n  // tslint:disable-next-line\n  selector: '[input-autocomplete]'\n})\nexport class AutocompleteDirective implements OnInit, OnDestroy, OnChanges, AfterViewInit {\n  @Input() config: any;\n  @Input() items: any;\n  @Input() ngModel: string;\n  @Input() control: FormControl;\n  @Output() ngModelChange = new EventEmitter();\n  @Output() inputChangedEvent = new EventEmitter();\n  @Output() selectEvent = new EventEmitter();\n\n  private componentRef: ComponentRef<AutocompleteComponent>;\n  private thisElement: HTMLElement;\n  private autocompleteElement: HTMLElement;\n  private inputElement: HTMLInputElement;\n  private tabIndex: number;\n  private reset = false;\n\n  constructor(\n    private resolver: ComponentFactoryResolver,\n    public viewContainerRef: ViewContainerRef\n  ) {\n    this.thisElement = this.viewContainerRef.element.nativeElement;\n  }\n\n  ngOnInit() {\n    if (this.thisElement.tagName.toLowerCase() === 'form') {\n      return;\n    }\n    this.createDiv();\n  }\n\n  ngOnDestroy() {\n    if (this.componentRef) {\n      this.componentRef.instance.selectEvent.unsubscribe();\n      this.componentRef.instance.inputChangedEvent.unsubscribe();\n    }\n    document.removeEventListener('click', this.hideAutocomplete);\n  }\n\n  ngOnChanges(changes: { [propKey: string]: SimpleChange }) {\n    if (changes['items'] && this.componentRef) {\n      const component = this.componentRef.instance;\n      component.items = changes['items'].currentValue;\n      component.filterItems(component.value);\n    }\n  }\n\n  ngAfterViewInit() {\n    const input = this.getInputElement();\n    if (this.control) {\n      this.control.valueChanges.subscribe(() => {\n        this.reset = true;\n      });\n    }\n    if (input.form) {\n      input.form.addEventListener('reset', () => {\n        this.reset = true;\n      });\n    }\n  }\n\n  @HostListener('click', ['$event.target'])\n  @HostListener('focus', ['$event.target'])\n  showAutocomplete(event: any) {\n    this.hideAutocomplete();\n    if (event === this.thisElement) {\n      this.createAutocomplete();\n    }\n  }\n\n  getInputElement() {\n    let input = this.thisElement as HTMLInputElement;\n\n    if (this.thisElement.tagName !== 'INPUT' && this.autocompleteElement) {\n      input = this.thisElement.querySelector(\n        'input'\n      ) as HTMLInputElement;\n    }\n\n    return input;\n  }\n\n  hideAutocomplete = (event?: any): void => {\n    if (!this.componentRef) {\n      return;\n    }\n    if (event && event.target && this.thisElement && event.target === this.thisElement.parentElement) {\n      return;\n    }\n    if (\n      !event ||\n      (event.target !== this.thisElement && event.type === 'click')\n    ) {\n      this.componentRef.destroy();\n      this.componentRef = undefined;\n    }\n    if (this.inputElement['tabIndex'] < 0) {\n      this.inputElement['tabIndex'] = this.tabIndex;\n    }\n  }\n\n  onInputChanged = (val: string) => {\n    this.inputElement.value = val;\n    if (val !== this.ngModel) {\n      this.ngModel = val;\n      this.ngModelChange.emit(val);\n    }\n    const component = this.componentRef.instance;\n    component.filterItems(val);\n    this.inputChangedEvent.emit(val);\n  }\n\n  onSelect = (item: any) => {\n    const component = this.componentRef.instance;\n    const val = component.value;\n    if (val !== this.ngModel) {\n      this.ngModel = val;\n      this.ngModelChange.emit(val);\n    }\n    this.selectEvent.emit(item);\n    if (this.inputElement) {\n      this.inputElement.value = '' + val;\n    }\n    this.hideAutocomplete();\n  }\n\n  private createDiv() {\n    const element = document.createElement('div');\n    element.style.display = 'inline-block';\n    element.style.position = 'relative';\n    this.thisElement.parentElement.insertBefore(\n      element,\n      this.thisElement.nextSibling\n    );\n    element.appendChild(this.thisElement);\n    document.addEventListener('click', this.hideAutocomplete);\n  }\n\n  private createAutocomplete() {\n    const factory = this.resolver.resolveComponentFactory(\n      AutocompleteComponent\n    );\n    this.componentRef = this.viewContainerRef.createComponent(factory);\n    const component = this.componentRef.instance;\n    component.config = this.config;\n    component.items = this.items;\n    component.selectEvent.subscribe(this.onSelect);\n    component.inputChangedEvent.subscribe(this.onInputChanged);\n    this.autocompleteElement = this.componentRef.location.nativeElement;\n    this.autocompleteElement.style.display = 'none';\n    this.inputElement = this.getInputElement();\n    if (this.thisElement.tagName !== 'INPUT' && this.autocompleteElement) {\n      this.inputElement.parentElement.insertBefore(\n        this.autocompleteElement,\n        this.inputElement.nextSibling\n      );\n    }\n\n    if (this.reset) {\n      this.ngModel = '';\n      this.reset = false;\n    }\n\n    this.inputElement.value = this.ngModel ? this.ngModel : '';\n    component.value = this.inputElement.value;\n    this.tabIndex = this.inputElement['tabIndex'];\n    this.inputElement['tabIndex'] = -100;\n    if (this.componentRef) {\n      const rect = this.thisElement.getBoundingClientRect();\n      const style = this.autocompleteElement.style;\n      style.width = rect.width + 'px';\n      style.position = 'absolute';\n      style.zIndex = '1';\n      style.top = '0';\n      style.left = '0';\n      style.display = 'inline-block';\n    }\n  }\n}\n","import { NgModule, ModuleWithProviders } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormsModule } from '@angular/forms';\nimport { AutocompleteComponent, AutocompleteDirective } from './autocomplete.component';\n\n@NgModule({\n  imports: [CommonModule, FormsModule],\n  declarations: [AutocompleteComponent, AutocompleteDirective],\n  exports: [AutocompleteComponent, AutocompleteDirective],\n  entryComponents: [AutocompleteComponent]\n})\nexport class AutocompleteModule {\n  static forRoot(): ModuleWithProviders {\n    return {\n      ngModule: AutocompleteModule\n    };\n  }\n}\n\n"],"names":[],"mappings":"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"} | ||
//# sourceMappingURL=ng2-input-autocomplete.js.map |
@@ -1,2 +0,2 @@ | ||
import { Component, ComponentFactoryResolver, Directive, ElementRef, EventEmitter, HostListener, Input, Output, ViewContainerRef, NgModule } from '@angular/core'; | ||
import { EventEmitter, Component, ElementRef, Input, Output, Directive, ComponentFactoryResolver, ViewContainerRef, HostListener, NgModule } from '@angular/core'; | ||
import { FormsModule } from '@angular/forms'; | ||
@@ -7,3 +7,4 @@ import { CommonModule } from '@angular/common'; | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc | ||
* Generated from: lib/autocomplete.component.ts | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -35,3 +36,3 @@ var AutocompleteComponent = /** @class */ (function () { | ||
this.placeholder = 'autocomplete'; | ||
this.inputElement = /** @type {?} */ (this.thisElement.querySelector('input')); | ||
this.inputElement = (/** @type {?} */ (this.thisElement.querySelector('input'))); | ||
if (!this.isNull(this.config)) { | ||
@@ -132,5 +133,9 @@ if (!this.isNull(this.config.placeholder)) { | ||
if (this.items) { | ||
this.candidates = this.items.filter(function (item) { | ||
this.candidates = this.items.filter((/** | ||
* @param {?} item | ||
* @return {?} | ||
*/ | ||
function (item) { | ||
return filterItem(item, field, search); | ||
}); | ||
})); | ||
if (this.maxLimit > 0) { | ||
@@ -143,2 +148,3 @@ this.candidates = this.candidates.slice(0, this.maxLimit); | ||
/** | ||
* @private | ||
* @param {?} object | ||
@@ -149,2 +155,3 @@ * @param {?} path | ||
AutocompleteComponent.prototype.getFieldValue = /** | ||
* @private | ||
* @param {?} object | ||
@@ -161,3 +168,7 @@ * @param {?} path | ||
var result_1 = object; | ||
path.forEach(function (element) { | ||
path.forEach((/** | ||
* @param {?} element | ||
* @return {?} | ||
*/ | ||
function (element) { | ||
if (result_1 !== null && | ||
@@ -172,3 +183,3 @@ result_1 !== undefined && | ||
} | ||
}); | ||
})); | ||
return result_1; | ||
@@ -181,2 +192,3 @@ } | ||
/** | ||
* @private | ||
* @param {?} object | ||
@@ -186,2 +198,3 @@ * @return {?} | ||
AutocompleteComponent.prototype.isNull = /** | ||
* @private | ||
* @param {?} object | ||
@@ -194,5 +207,7 @@ * @return {?} | ||
/** | ||
* @private | ||
* @return {?} | ||
*/ | ||
AutocompleteComponent.prototype.buildLabels = /** | ||
* @private | ||
* @return {?} | ||
@@ -205,7 +220,12 @@ */ | ||
var getFieldValue = this.getFieldValue; | ||
this.candidatesLabels = this.candidates.map(function (e) { | ||
this.candidatesLabels = this.candidates.map((/** | ||
* @param {?} e | ||
* @return {?} | ||
*/ | ||
function (e) { | ||
return getFieldValue(e, field); | ||
}); | ||
})); | ||
}; | ||
/** | ||
* @private | ||
* @param {?} item | ||
@@ -217,2 +237,3 @@ * @param {?} path | ||
AutocompleteComponent.prototype.filterItem = /** | ||
* @private | ||
* @param {?} item | ||
@@ -234,3 +255,7 @@ * @param {?} path | ||
result = item; | ||
path.forEach(function (element) { | ||
path.forEach((/** | ||
* @param {?} element | ||
* @return {?} | ||
*/ | ||
function (element) { | ||
if (result !== null && | ||
@@ -245,3 +270,3 @@ result !== undefined && | ||
} | ||
}); | ||
})); | ||
} | ||
@@ -273,2 +298,40 @@ else { | ||
}()); | ||
if (false) { | ||
/** @type {?} */ | ||
AutocompleteComponent.prototype.classList; | ||
/** @type {?} */ | ||
AutocompleteComponent.prototype.items; | ||
/** @type {?} */ | ||
AutocompleteComponent.prototype.config; | ||
/** @type {?} */ | ||
AutocompleteComponent.prototype.selectEvent; | ||
/** @type {?} */ | ||
AutocompleteComponent.prototype.inputChangedEvent; | ||
/** @type {?} */ | ||
AutocompleteComponent.prototype.inputElement; | ||
/** @type {?} */ | ||
AutocompleteComponent.prototype.value; | ||
/** @type {?} */ | ||
AutocompleteComponent.prototype.candidates; | ||
/** @type {?} */ | ||
AutocompleteComponent.prototype.candidatesLabels; | ||
/** @type {?} */ | ||
AutocompleteComponent.prototype.selectedIndex; | ||
/** @type {?} */ | ||
AutocompleteComponent.prototype.showAutoComplete; | ||
/** @type {?} */ | ||
AutocompleteComponent.prototype.placeholder; | ||
/** @type {?} */ | ||
AutocompleteComponent.prototype.maxLimit; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
AutocompleteComponent.prototype.sourceField; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
AutocompleteComponent.prototype.thisElement; | ||
} | ||
var AutocompleteDirective = /** @class */ (function () { | ||
@@ -283,3 +346,7 @@ function AutocompleteDirective(resolver, viewContainerRef) { | ||
this.reset = false; | ||
this.hideAutocomplete = function (event) { | ||
this.hideAutocomplete = (/** | ||
* @param {?=} event | ||
* @return {?} | ||
*/ | ||
function (event) { | ||
if (!_this.componentRef) { | ||
@@ -299,4 +366,8 @@ return; | ||
} | ||
}; | ||
this.onInputChanged = function (val) { | ||
}); | ||
this.onInputChanged = (/** | ||
* @param {?} val | ||
* @return {?} | ||
*/ | ||
function (val) { | ||
_this.inputElement.value = val; | ||
@@ -311,4 +382,8 @@ if (val !== _this.ngModel) { | ||
_this.inputChangedEvent.emit(val); | ||
}; | ||
this.onSelect = function (item) { | ||
}); | ||
this.onSelect = (/** | ||
* @param {?} item | ||
* @return {?} | ||
*/ | ||
function (item) { | ||
/** @type {?} */ | ||
@@ -327,3 +402,3 @@ var component = _this.componentRef.instance; | ||
_this.hideAutocomplete(); | ||
}; | ||
}); | ||
this.thisElement = this.viewContainerRef.element.nativeElement; | ||
@@ -383,10 +458,16 @@ } | ||
if (this.control) { | ||
this.control.valueChanges.subscribe(function () { | ||
this.control.valueChanges.subscribe((/** | ||
* @return {?} | ||
*/ | ||
function () { | ||
_this.reset = true; | ||
}); | ||
})); | ||
} | ||
if (input.form) { | ||
input.form.addEventListener('reset', function () { | ||
input.form.addEventListener('reset', (/** | ||
* @return {?} | ||
*/ | ||
function () { | ||
_this.reset = true; | ||
}); | ||
})); | ||
} | ||
@@ -416,5 +497,5 @@ }; | ||
/** @type {?} */ | ||
var input = /** @type {?} */ (this.thisElement); | ||
var input = (/** @type {?} */ (this.thisElement)); | ||
if (this.thisElement.tagName !== 'INPUT' && this.autocompleteElement) { | ||
input = /** @type {?} */ (this.thisElement.querySelector('input')); | ||
input = (/** @type {?} */ (this.thisElement.querySelector('input'))); | ||
} | ||
@@ -424,5 +505,7 @@ return input; | ||
/** | ||
* @private | ||
* @return {?} | ||
*/ | ||
AutocompleteDirective.prototype.createDiv = /** | ||
* @private | ||
* @return {?} | ||
@@ -440,5 +523,7 @@ */ | ||
/** | ||
* @private | ||
* @return {?} | ||
*/ | ||
AutocompleteDirective.prototype.createAutocomplete = /** | ||
* @private | ||
* @return {?} | ||
@@ -506,6 +591,66 @@ */ | ||
}()); | ||
if (false) { | ||
/** @type {?} */ | ||
AutocompleteDirective.prototype.config; | ||
/** @type {?} */ | ||
AutocompleteDirective.prototype.items; | ||
/** @type {?} */ | ||
AutocompleteDirective.prototype.ngModel; | ||
/** @type {?} */ | ||
AutocompleteDirective.prototype.control; | ||
/** @type {?} */ | ||
AutocompleteDirective.prototype.ngModelChange; | ||
/** @type {?} */ | ||
AutocompleteDirective.prototype.inputChangedEvent; | ||
/** @type {?} */ | ||
AutocompleteDirective.prototype.selectEvent; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
AutocompleteDirective.prototype.componentRef; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
AutocompleteDirective.prototype.thisElement; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
AutocompleteDirective.prototype.autocompleteElement; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
AutocompleteDirective.prototype.inputElement; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
AutocompleteDirective.prototype.tabIndex; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
AutocompleteDirective.prototype.reset; | ||
/** @type {?} */ | ||
AutocompleteDirective.prototype.hideAutocomplete; | ||
/** @type {?} */ | ||
AutocompleteDirective.prototype.onInputChanged; | ||
/** @type {?} */ | ||
AutocompleteDirective.prototype.onSelect; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
AutocompleteDirective.prototype.resolver; | ||
/** @type {?} */ | ||
AutocompleteDirective.prototype.viewContainerRef; | ||
} | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc | ||
* Generated from: lib/autocomplete.module.ts | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -539,3 +684,4 @@ var AutocompleteModule = /** @class */ (function () { | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc | ||
* Generated from: public_api.ts | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -545,7 +691,7 @@ | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc | ||
* Generated from: ng2-input-autocomplete.ts | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
export { AutocompleteComponent, AutocompleteDirective, AutocompleteModule }; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"ng2-input-autocomplete.js.map","sources":["ng://ng2-input-autocomplete/lib/autocomplete.component.ts","ng://ng2-input-autocomplete/lib/autocomplete.module.ts"],"sourcesContent":["/*\n  MIT LICENSE @liuy97\n*/\nimport {\n  Component,\n  ComponentFactoryResolver,\n  ComponentRef,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  AfterViewInit,\n  Output,\n  SimpleChange,\n  ViewContainerRef,\n  HostBinding\n} from '@angular/core';\nimport {FormControl} from '@angular/forms';\n\n@Component({\n  // tslint:disable-next-line\n  selector: 'ng2-input-autocomplete',\n  template: `\n  <div [ngClass]=\"classList\">\n    <input type=\"text\"\n      placeholder=\"{{placeholder}}\"\n      (blur)=\"showAutoComplete = false;\"\n      (focus)=\"showAutoComplete = true;\"\n      [value]=\"value\"\n      (keyup)=\"enterText($event)\">\n    <ul *ngIf=\"showAutoComplete && candidates && candidates.length > 0\">\n      <li *ngFor=\"let candidate of candidates; let idx = index\"\n        [ngClass]=\"{ active: (idx === selectedIndex) }\"\n        (keyup)=\"onKeyUpEvent($event, idx)\"\n        (mouseover)=\"selectedIndex = idx;\"\n        (mousedown)=\"onSelect(idx)\">\n        {{candidatesLabels[idx]}}\n      </li>\n    </ul>\n  </div>`,\n  styles: [\n    `.autocomplete ul {\n       position: absolute;\n       left: 0;\n       width: 100%;\n       border-left: 1px solid #888;\n       border-right: 1px solid #888;\n       border-bottom: 1px solid #888;\n       list-style: none;\n       padding-left: 0px;\n       margin-top: 2px;\n       background-color: #fff;\n       z-index: 100;\n     }\n     .autocomplete li {\n       text-align: left;\n       list-style: none;\n       width: 100%;\n       padding: 0.4em 0 0.4em 0;\n     }\n     .autocomplete li.active {\n       width: 100%;\n       background-color: #4bf;\n     }\n\n     .autocomplete .highlight {\n       background-color: #e2e2e2;\n     }\n     .autocomplete li.active .highlight {\n       background: #666;\n       color: #fff;\n     }`\n  ]\n})\nexport class AutocompleteComponent implements OnInit, OnChanges {\n  classList = 'autocomplete';\n  @Input() items: any[];\n  @Input() config: any;\n  @Output() selectEvent: EventEmitter<any> = new EventEmitter<any>();\n  @Output() inputChangedEvent: EventEmitter<any> = new EventEmitter<any>();\n  inputElement: HTMLInputElement;\n  value: string;\n  candidates: any[];\n  candidatesLabels: any[];\n  selectedIndex: number;\n  showAutoComplete: boolean;\n  placeholder: string;\n  maxLimit = 0;\n  private sourceField: any;\n  private thisElement: HTMLElement;\n\n  constructor(elementRef: ElementRef) {\n    this.thisElement = elementRef.nativeElement;\n    this.selectedIndex = 0;\n    this.showAutoComplete = false;\n    this.value = '';\n  }\n\n  ngOnInit() {\n    if (this.config && this.config.class) {\n      this.classList += ' ' + this.config.class;\n    }\n    if (this.config && this.config.max > 0) {\n      this.maxLimit = this.config.max;\n    }\n    this.placeholder = 'autocomplete';\n    this.inputElement = this.thisElement.querySelector(\n      'input'\n    ) as HTMLInputElement;\n\n    if (!this.isNull(this.config)) {\n      if (!this.isNull(this.config.placeholder)) {\n        this.placeholder = this.config.placeholder;\n      }\n      if (!this.isNull(this.config.sourceField)) {\n        this.sourceField = this.config.sourceField;\n      }\n    }\n    this.filterItems(this.value);\n    this.inputElement.focus();\n  }\n\n  ngOnChanges() {\n    this.filterItems(this.value);\n  }\n\n  enterText(event: any) {\n    const total = this.candidates.length;\n    switch (event.keyCode) {\n      case 27:\n        this.showAutoComplete = false;\n        break;\n      case 38:\n        this.selectedIndex = (total + this.selectedIndex - 1) % total;\n        break;\n      case 40:\n        this.selectedIndex = (total + this.selectedIndex + 1) % total;\n        break;\n      case 13:\n        if (this.candidates.length > 0) {\n          this.onSelect(this.selectedIndex);\n        }\n        event.preventDefault();\n        break;\n      default:\n        this.value = event.target.value;\n        this.inputChangedEvent.emit(this.value);\n        break;\n    }\n  }\n\n  onSelect(idx: number) {\n    this.showAutoComplete = false;\n    this.value = this.candidatesLabels[idx];\n    this.selectEvent.emit(this.candidates[idx]);\n  }\n\n  onKeyUpEvent(event: KeyboardEvent, idx: number): void {\n    if (event.keyCode === 13) {\n      this.onSelect(idx);\n    }\n }\n\n  filterItems(search: string) {\n    const field = this.sourceField;\n    const filterItem = this.filterItem;\n    if (this.items) {\n      this.candidates = this.items.filter(item => {\n        return filterItem(item, field, search);\n      });\n      if (this.maxLimit > 0) {\n        this.candidates = this.candidates.slice(0, this.maxLimit);\n      }\n      this.buildLabels();\n    }\n  }\n\n  private getFieldValue(object: any, path: any) {\n    if (typeof object === 'string') {\n      return object;\n    }\n    if (path instanceof Array) {\n      let result: any = object;\n      path.forEach((element: any) => {\n        if (\n          result !== null &&\n          result !== undefined &&\n          result[element] !== null &&\n          result[element] !== undefined\n        ) {\n          result = result[element];\n        } else {\n          result = '';\n        }\n      });\n      return result;\n    } else {\n      return object[path] || '';\n    }\n  }\n\n  private isNull(object: any) {\n    return object === null || object === undefined;\n  }\n\n  private buildLabels() {\n    const field = this.sourceField;\n    const getFieldValue = this.getFieldValue;\n    this.candidatesLabels = this.candidates.map((e: any) =>\n      getFieldValue(e, field)\n    );\n  }\n\n  private filterItem(item: any, path: any, search: string) {\n    if (search === null || search === undefined || search.length === 0) {\n      return true;\n    }\n    let result: any;\n    if (typeof item === 'string') {\n      result = item;\n    } else if (path instanceof Array) {\n      result = item;\n      path.forEach((element: any) => {\n        if (\n          result !== null &&\n          result !== undefined &&\n          result[element] !== null &&\n          result[element] !== undefined\n        ) {\n          result = result[element];\n        } else {\n          result = '';\n        }\n      });\n    } else {\n      result = item[path] || '';\n    }\n    return result.toLowerCase().indexOf(search.toLowerCase()) >= 0;\n  }\n}\n\n@Directive({\n  // tslint:disable-next-line\n  selector: '[input-autocomplete]'\n})\nexport class AutocompleteDirective implements OnInit, OnDestroy, OnChanges, AfterViewInit {\n  @Input() config: any;\n  @Input() items: any;\n  @Input() ngModel: string;\n  @Input() control: FormControl;\n  @Output() ngModelChange = new EventEmitter();\n  @Output() inputChangedEvent = new EventEmitter();\n  @Output() selectEvent = new EventEmitter();\n\n  private componentRef: ComponentRef<AutocompleteComponent>;\n  private thisElement: HTMLElement;\n  private autocompleteElement: HTMLElement;\n  private inputElement: HTMLInputElement;\n  private tabIndex: number;\n  private reset = false;\n\n  constructor(\n    private resolver: ComponentFactoryResolver,\n    public viewContainerRef: ViewContainerRef\n  ) {\n    this.thisElement = this.viewContainerRef.element.nativeElement;\n  }\n\n  ngOnInit() {\n    if (this.thisElement.tagName.toLowerCase() === 'form') {\n      return;\n    }\n    this.createDiv();\n  }\n\n  ngOnDestroy() {\n    if (this.componentRef) {\n      this.componentRef.instance.selectEvent.unsubscribe();\n      this.componentRef.instance.inputChangedEvent.unsubscribe();\n    }\n    document.removeEventListener('click', this.hideAutocomplete);\n  }\n\n  ngOnChanges(changes: { [propKey: string]: SimpleChange }) {\n    if (changes['items'] && this.componentRef) {\n      const component = this.componentRef.instance;\n      component.items = changes['items'].currentValue;\n      component.filterItems(component.value);\n    }\n  }\n\n  ngAfterViewInit() {\n    const input = this.getInputElement();\n    if (this.control) {\n      this.control.valueChanges.subscribe(() => {\n        this.reset = true;\n      });\n    }\n    if (input.form) {\n      input.form.addEventListener('reset', () => {\n        this.reset = true;\n      });\n    }\n  }\n\n  @HostListener('click', ['$event.target'])\n  @HostListener('focus', ['$event.target'])\n  showAutocomplete(event: any) {\n    this.hideAutocomplete();\n    if (event === this.thisElement) {\n      this.createAutocomplete();\n    }\n  }\n\n  getInputElement() {\n    let input = this.thisElement as HTMLInputElement;\n\n    if (this.thisElement.tagName !== 'INPUT' && this.autocompleteElement) {\n      input = this.thisElement.querySelector(\n        'input'\n      ) as HTMLInputElement;\n    }\n\n    return input;\n  }\n\n  hideAutocomplete = (event?: any): void => {\n    if (!this.componentRef) {\n      return;\n    }\n    if (event && event.target && this.thisElement && event.target === this.thisElement.parentElement) {\n      return;\n    }\n    if (\n      !event ||\n      (event.target !== this.thisElement && event.type === 'click')\n    ) {\n      this.componentRef.destroy();\n      this.componentRef = undefined;\n    }\n    if (this.inputElement['tabIndex'] < 0) {\n      this.inputElement['tabIndex'] = this.tabIndex;\n    }\n  }\n\n  onInputChanged = (val: string) => {\n    this.inputElement.value = val;\n    if (val !== this.ngModel) {\n      this.ngModel = val;\n      this.ngModelChange.emit(val);\n    }\n    const component = this.componentRef.instance;\n    component.filterItems(val);\n    this.inputChangedEvent.emit(val);\n  }\n\n  onSelect = (item: any) => {\n    const component = this.componentRef.instance;\n    const val = component.value;\n    if (val !== this.ngModel) {\n      this.ngModel = val;\n      this.ngModelChange.emit(val);\n    }\n    this.selectEvent.emit(item);\n    if (this.inputElement) {\n      this.inputElement.value = '' + val;\n    }\n    this.hideAutocomplete();\n  }\n\n  private createDiv() {\n    const element = document.createElement('div');\n    element.style.display = 'inline-block';\n    element.style.position = 'relative';\n    this.thisElement.parentElement.insertBefore(\n      element,\n      this.thisElement.nextSibling\n    );\n    element.appendChild(this.thisElement);\n    document.addEventListener('click', this.hideAutocomplete);\n  }\n\n  private createAutocomplete() {\n    const factory = this.resolver.resolveComponentFactory(\n      AutocompleteComponent\n    );\n    this.componentRef = this.viewContainerRef.createComponent(factory);\n    const component = this.componentRef.instance;\n    component.config = this.config;\n    component.items = this.items;\n    component.selectEvent.subscribe(this.onSelect);\n    component.inputChangedEvent.subscribe(this.onInputChanged);\n    this.autocompleteElement = this.componentRef.location.nativeElement;\n    this.autocompleteElement.style.display = 'none';\n    this.inputElement = this.getInputElement();\n    if (this.thisElement.tagName !== 'INPUT' && this.autocompleteElement) {\n      this.inputElement.parentElement.insertBefore(\n        this.autocompleteElement,\n        this.inputElement.nextSibling\n      );\n    }\n\n    if (this.reset) {\n      this.ngModel = '';\n      this.reset = false;\n    }\n\n    this.inputElement.value = this.ngModel ? this.ngModel : '';\n    component.value = this.inputElement.value;\n    this.tabIndex = this.inputElement['tabIndex'];\n    this.inputElement['tabIndex'] = -100;\n    if (this.componentRef) {\n      const rect = this.thisElement.getBoundingClientRect();\n      const style = this.autocompleteElement.style;\n      style.width = rect.width + 'px';\n      style.position = 'absolute';\n      style.zIndex = '1';\n      style.top = '0';\n      style.left = '0';\n      style.display = 'inline-block';\n    }\n  }\n}\n","import { NgModule, ModuleWithProviders } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormsModule } from '@angular/forms';\nimport { AutocompleteComponent, AutocompleteDirective } from './autocomplete.component';\n\n@NgModule({\n  imports: [CommonModule, FormsModule],\n  declarations: [AutocompleteComponent, AutocompleteDirective],\n  exports: [AutocompleteComponent, AutocompleteDirective],\n  entryComponents: [AutocompleteComponent]\n})\nexport class AutocompleteModule {\n  static forRoot(): ModuleWithProviders {\n    return {\n      ngModule: AutocompleteModule\n    };\n  }\n}\n\n"],"names":[],"mappings":"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"} | ||
//# sourceMappingURL=ng2-input-autocomplete.js.map |
{ | ||
"name": "ng2-input-autocomplete", | ||
"version": "1.1.2", | ||
"version": "2.0.0-rc.0", | ||
"description": "Angular input auto complete", | ||
@@ -21,4 +21,4 @@ "repository": { | ||
"peerDependencies": { | ||
"@angular/common": ">=2.0.0", | ||
"@angular/core": ">=2.0.0" | ||
"@angular/common": ">=8.0.0", | ||
"@angular/core": ">=8.0.0" | ||
}, | ||
@@ -25,0 +25,0 @@ "main": "bundles/ng2-input-autocomplete.umd.js", |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
No v1
QualityPackage is not semver >=1. This means it is not stable and does not support ^ ranges.
Found 1 instance in 1 package
3406
20.4%285890
-20.17%3
50%