@hxui/angular
Version:
* * *
650 lines • 69.5 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
*/
import { Input, forwardRef, Component, ViewChild, Output, EventEmitter, IterableDiffers, ViewEncapsulation, Renderer2 } from '@angular/core';
import { NG_VALUE_ACCESSOR, FormControl } from '@angular/forms';
import * as _ from 'lodash';
import { SelectizeConfig } from './selectize.config';
/** @type {?} */
export var SELECTIZE_VALUE_ACCESSOR = {
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(function () { return SelectizeComponent; }),
multi: true
};
var SelectizeComponent = /** @class */ (function () {
function SelectizeComponent(_differs, renderer) {
this._differs = _differs;
this.renderer = renderer;
this.enabled = true;
this.value = [];
this.isFocused = false;
this.isValid = false;
this.onBlur = new EventEmitter(false);
this.onFocus = new EventEmitter(false);
/**
* Invoked anytime a key is pressed down on the selectize search field
* @param e
*/
this.onKeydown = function (e) {
console.log(e);
/** @type {?} */
var TABKEY = 9;
if (e.keyCode === TABKEY) {
e.preventDefault();
e.stopImmediatePropagation();
e.stopPropagation();
}
};
}
/**
* @return {?}
*/
SelectizeComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
if (this.id && this.id.length > 0) {
this.renderer.setAttribute(this.selectizeInput.nativeElement, 'id', this.id);
}
this.reset();
};
/**
* @return {?}
*/
SelectizeComponent.prototype.reset = /**
* @return {?}
*/
function () {
this.selectize = $(this.selectizeInput.nativeElement).selectize(this.config)[0].selectize;
this.selectize.on('change', this.onSelectizeValueChange.bind(this));
this.selectize.on('blur', this.onBlurEvent.bind(this));
this.selectize.on('focus', this.onFocusEvent.bind(this));
this.selectize.on('type', this.onSelectizeType.bind(this));
this.selectize.on('item_add', this.onSelectizeItemSelected.bind(this));
this.updatePlaceholder();
this.onEnabledStatusChange();
this.hasCaret();
};
/**
* @return {?}
*/
SelectizeComponent.prototype.ngOnDestroy = /**
* @return {?}
*/
function () {
if (this.selectize) {
this.selectize.off('change');
this.selectize.off('blur');
this.selectize.off('focus');
this.selectize.off('type');
}
};
/**
* Change detection for primitive types.
*/
/**
* Change detection for primitive types.
* @param {?} changes
* @return {?}
*/
SelectizeComponent.prototype.ngOnChanges = /**
* Change detection for primitive types.
* @param {?} changes
* @return {?}
*/
function (changes) {
if (this.selectize) {
if (changes.hasOwnProperty('placeholder') ||
changes.hasOwnProperty('hasOptionsPlaceholder') ||
changes.hasOwnProperty('noOptionsPlaceholder')) {
this.updatePlaceholder();
}
if (changes.hasOwnProperty('enabled')) {
this.onEnabledStatusChange();
}
}
};
/**
* Implementing deep check for option comparison
*
* FIXME -> Implement deep check to only compare against label and value fields.
*/
/**
* Implementing deep check for option comparison
*
* FIXME -> Implement deep check to only compare against label and value fields.
* @return {?}
*/
SelectizeComponent.prototype.ngDoCheck = /**
* Implementing deep check for option comparison
*
* FIXME -> Implement deep check to only compare against label and value fields.
* @return {?}
*/
function () {
if (this._options_differ) {
/** @type {?} */
var changes = this._options_differ.diff(this._options);
if (changes) {
this._applyOptionsChanges(changes);
}
}
if (this._optgroups_differ) {
/** @type {?} */
var changes = this._optgroups_differ.diff(this._optgroups);
if (changes) {
this._applyOptionGroupChanges(changes);
}
}
};
/**
* @param {?} changes
* @return {?}
*/
SelectizeComponent.prototype._applyOptionsChanges = /**
* @param {?} changes
* @return {?}
*/
function (changes) {
var _this = this;
changes.forEachRemovedItem(function (record) {
_this.onSelectizeOptionRemove(record.item);
});
changes.forEachAddedItem(function (record) {
_this.onSelectizeOptionAdd(record.item);
});
this.updatePlaceholder();
this.evalHasError();
};
/**
* @param {?} changes
* @return {?}
*/
SelectizeComponent.prototype._applyOptionGroupChanges = /**
* @param {?} changes
* @return {?}
*/
function (changes) {
var _this = this;
changes.forEachRemovedItem(function (record) {
_this.onSelectizeOptGroupRemove(record.item);
});
changes.forEachAddedItem(function (record) {
_this.onSelectizeOptGroupAdd(record.item);
});
this.updatePlaceholder();
this.evalHasError();
};
/**
* @return {?}
*/
SelectizeComponent.prototype.clearhighlight = /**
* @return {?}
*/
function () {
// remove highlight to help selectize bug
// https://github.com/selectize/selectize.js/issues/1141
this.selectize.$dropdown_content.removeHighlight();
};
/**
* @return {?}
*/
SelectizeComponent.prototype.onBlurEvent = /**
* @return {?}
*/
function () {
if (this.formControl) {
this.formControl.markAsTouched();
}
this.onBlur.emit();
this.evalHasError();
this.isFocused = false;
this.isValid = (this.selectize.getValue().length > 0);
};
/**
* @return {?}
*/
SelectizeComponent.prototype.onFocusEvent = /**
* @return {?}
*/
function () {
if (this.formControl) {
this.formControl.markAsTouched();
}
this.onFocus.emit();
this.evalHasError();
this.isFocused = true;
};
/**
* @param {?} optgroup
* @return {?}
*/
SelectizeComponent.prototype.onSelectizeOptGroupAdd = /**
* @param {?} optgroup
* @return {?}
*/
function (optgroup) {
this.selectize.addOptionGroup(optgroup[this.getOptgroupField()], optgroup);
};
/**
* @param {?} optgroup
* @return {?}
*/
SelectizeComponent.prototype.onSelectizeOptGroupRemove = /**
* @param {?} optgroup
* @return {?}
*/
function (optgroup) {
this.selectize.removeOptionGroup(optgroup[this.getOptgroupField()]);
};
/**
* Refresh selected values when options change.
*/
/**
* Refresh selected values when options change.
* @param {?} option
* @return {?}
*/
SelectizeComponent.prototype.onSelectizeOptionAdd = /**
* Refresh selected values when options change.
* @param {?} option
* @return {?}
*/
function (option) {
this.selectize.addOption(_.cloneDeep(option));
/** @type {?} */
var valueField = this.config.valueField;
if (this.value) {
/** @type {?} */
var items = typeof this.value === 'string' || typeof this.value === 'number'
? [this.value]
: this.value;
if (items &&
items instanceof Array &&
items.find(function (value) { return value === option[valueField]; })) {
this.selectize.addItem(option[valueField], true);
}
}
};
/**
* @param {?} option
* @return {?}
*/
SelectizeComponent.prototype.onSelectizeOptionRemove = /**
* @param {?} option
* @return {?}
*/
function (option) {
this.selectize.removeOption(option[this.config.valueField]);
};
/**
* @return {?}
*/
SelectizeComponent.prototype.evalHasError = /**
* @return {?}
*/
function () {
/** @type {?} */
var parent = $(this.selectize.$control).parent();
if (this.formControl) {
if (this.formControl.touched && this.formControl.invalid) {
parent.addClass(this.errorClass || 'has-error');
}
else if (parent.hasClass('has-error')) {
parent.removeClass(this.errorClass || 'has-error');
}
}
};
/**
* @return {?}
*/
SelectizeComponent.prototype.updateLabel = /**
* @return {?}
*/
function () {
};
/**
* Update the current placeholder based on the given input parameter.
*/
/**
* Update the current placeholder based on the given input parameter.
* @return {?}
*/
SelectizeComponent.prototype.updatePlaceholder = /**
* Update the current placeholder based on the given input parameter.
* @return {?}
*/
function () {
if (this.selectize.items.length === 0 &&
this.selectize.settings.placeholder !== this.getPlaceholder()) {
this.selectize.settings.placeholder = this.getPlaceholder();
this.selectize.updatePlaceholder();
this.selectize.showInput(); // Without this, when options are cleared placeholder only appears after focus.
}
};
/**
* Called when a change is detected in the 'enabled' input field.
* Sets the selectize state based on the new value.
*/
/**
* Called when a change is detected in the 'enabled' input field.
* Sets the selectize state based on the new value.
* @return {?}
*/
SelectizeComponent.prototype.onEnabledStatusChange = /**
* Called when a change is detected in the 'enabled' input field.
* Sets the selectize state based on the new value.
* @return {?}
*/
function () {
this.enabled ? this.selectize.enable() : this.selectize.disable();
};
/**
* @return {?}
*/
SelectizeComponent.prototype.hasCaret = /**
* @return {?}
*/
function () {
if (this.config.hasCaret) {
/** @type {?} */
var parent_1 = $(this.selectize.$control).parent();
parent_1.addClass('hasCaret');
}
};
/**
* Dispatches change event when a value change is detected.
* @param $event
*/
/**
* Dispatches change event when a value change is detected.
* @param {?} $event
* @return {?}
*/
SelectizeComponent.prototype.onSelectizeValueChange = /**
* Dispatches change event when a value change is detected.
* @param {?} $event
* @return {?}
*/
function ($event) {
var _this = this;
// In some cases this gets called before registerOnChange.
if (this.onChangeCallback) {
// Map selectize's value collection back to original ISelectizeItem object
/** @type {?} */
var data = this.selectize.items.map(function (v) {
return _this.selectize.options[v];
});
this.onChangeCallback(data);
}
};
/**
* Invoked when the user types while filtering options.
* @param str
*/
/**
* Invoked when the user types while filtering options.
* @param {?} str
* @return {?}
*/
SelectizeComponent.prototype.onSelectizeType = /**
* Invoked when the user types while filtering options.
* @param {?} str
* @return {?}
*/
function (str) {
if (str.length === 0) {
this.clearhighlight();
this.selectize.close();
}
};
/**
* @param {?} $event
* @return {?}
*/
SelectizeComponent.prototype.onSelectizeItemSelected = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
this.clearhighlight();
if (this.config.closeAfterSelect) {
this.selectize.close();
}
};
/**
* Returns the applicable placeholder.
*/
/**
* Returns the applicable placeholder.
* @return {?}
*/
SelectizeComponent.prototype.getPlaceholder = /**
* Returns the applicable placeholder.
* @return {?}
*/
function () {
if (this.hasOptionsPlaceholder) {
if (this.options && this.options.length > 0) {
return this.hasOptionsPlaceholder;
}
}
if (this.noOptionsPlaceholder) {
if (!this.options || this.options.length === 0) {
return this.noOptionsPlaceholder;
}
}
return this.placeholder;
};
/**
* Implementation from ControlValueAccessor
*
* @param obj
*/
/**
* Implementation from ControlValueAccessor
*
* @param {?} obj
* @return {?}
*/
SelectizeComponent.prototype.writeValue = /**
* Implementation from ControlValueAccessor
*
* @param {?} obj
* @return {?}
*/
function (obj) {
var _this = this;
if (obj === this.value) {
return;
}
this.value = obj;
if (!obj || obj.length === 0) {
this.selectize.setValue('');
return;
}
/** @type {?} */
var stringValue = obj.map(function (v) {
if (!Object.keys(_this.selectize.options).some(function (x) { return x === v.value; })) {
_this.selectize.addOption(v);
}
return v.value;
});
this.selectize.setValue(stringValue);
this.evalHasError();
this.isValid = (this.selectize.getValue().length > 0);
};
/**
* Implementation from ControlValueAccessor, callback for (ngModelChange)
* @param fn
*/
/**
* Implementation from ControlValueAccessor, callback for (ngModelChange)
* @param {?} fn
* @return {?}
*/
SelectizeComponent.prototype.registerOnChange = /**
* Implementation from ControlValueAccessor, callback for (ngModelChange)
* @param {?} fn
* @return {?}
*/
function (fn) {
this.onChangeCallback = fn;
};
/**
* Implementation from ControlValueAccessor
* @param fn
*/
/**
* Implementation from ControlValueAccessor
* @param {?} fn
* @return {?}
*/
SelectizeComponent.prototype.registerOnTouched = /**
* Implementation from ControlValueAccessor
* @param {?} fn
* @return {?}
*/
function (fn) {
this.onTouchedCallback = fn;
};
/**
* @return {?}
*/
SelectizeComponent.prototype.getOptgroupField = /**
* @return {?}
*/
function () {
return this.config['optgroupField']
? this.config['optgroupField']
: 'optgroup';
};
Object.defineProperty(SelectizeComponent.prototype, "options", {
get: /**
* @return {?}
*/
function () {
return this._options;
},
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._options = value;
if (!this._options_differ && value) {
this._options_differ = this._differs.find(value).create();
}
},
enumerable: true,
configurable: true
});
Object.defineProperty(SelectizeComponent.prototype, "optgroups", {
get: /**
* @return {?}
*/
function () {
return this._optgroups;
},
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._optgroups = value;
if (!this._optgroups_differ && value) {
this._optgroups_differ = this._differs.find(value).create();
}
},
enumerable: true,
configurable: true
});
SelectizeComponent.decorators = [
{ type: Component, args: [{
selector: 'hxa-selectize',
template: "<div class=\"hx-input-control\" [ngClass]=\"config.inputControlClasses\" [class.is-focused]=\"isFocused\" [class.is-valid]=\"isValid\">\n <select #selectizeInput></select>\n <label for=\"{{id}}\" class=\"hx-label\">{{config.label}} <sup *ngIf=\"config.mandatory\">*</sup></label>\n <div class=\"hx-help\">{{config.help}}</div>\n </div>",
providers: [SELECTIZE_VALUE_ACCESSOR],
encapsulation: ViewEncapsulation.None,
styles: [".selectize-control{position:relative}.selectize-dropdown,.selectize-input,.selectize-input input{color:#2a2c2d;font-family:inherit;font-size:.92rem;line-height:1.5;-webkit-font-smoothing:inherit}.selectize-control.single .selectize-input.input-active,.selectize-input{background:0 0;cursor:text;display:inline-block}.selectize-input{border:1px solid rgba(0,0,0,.2);padding:8px 0;display:inline-block;width:100%;overflow:hidden;position:relative;z-index:1;box-sizing:border-box;box-shadow:none;border-radius:0;border-width:0 0 1px}.selectize-control.multi .selectize-input.has-items{padding:6px 0 3px}.selectize-control.multi.hasCaret .selectize-input.has-items{padding-right:1rem}.selectize-input.full{background-color:transparent}.selectize-input.disabled,.selectize-input.disabled *{cursor:default!important}.selectize-input.focus{box-shadow:none}.selectize-input.dropdown-active{border-radius:0}.selectize-input>*{vertical-align:baseline;display:inline-block;zoom:1}.selectize-control.multi .selectize-input>div{cursor:pointer;margin:4px;padding:2px 6px;background:rgba(0,0,0,.05);color:#2a2c2d;border:0 solid transparent;border-radius:290486px;font-size:.75rem;justify-content:center;line-height:1.5;white-space:nowrap}.selectize-control.multi .selectize-input>div.active{background:#e8e8e8;color:#2a2c2d;border:0 solid #cacaca}.selectize-control.multi .selectize-input.disabled>div,.selectize-control.multi .selectize-input.disabled>div.active{color:#787878;background:rgba(77,77,77,.05);border:0 solid rgba(77,77,77,0)}.selectize-input>input{display:inline-block!important;padding:0!important;min-height:0!important;max-height:none!important;max-width:100%!important;margin:0 2px 0 0!important;text-indent:0!important;border:0!important;background:0 0!important;line-height:inherit!important;-webkit-user-select:auto!important}.selectize-input>input::-ms-clear{display:none}.selectize-input>input:focus{outline:0!important}.selectize-input::after{content:' ';display:block;clear:left}.selectize-input.dropdown-active::before{content:' ';display:block;position:absolute;background:#f0f0f0;height:1px;bottom:0;left:0;right:0}.hx-select-control:after{display:none}.selectize-dropdown{position:absolute;z-index:10;border:transparent;background:#fff;margin:1px 0 0;border-top:0;box-sizing:border-box;box-shadow:0 6px 12px rgba(0,0,0,.145);border-radius:0}.selectize-dropdown [data-selectable]{cursor:pointer;overflow:hidden}.selectize-dropdown [data-selectable] .highlight{background:rgba(35,49,43,.23);border-radius:1px;font-weight:700}.selectize-dropdown .optgroup-header,.selectize-dropdown [data-selectable]{padding:5px 8px}.selectize-dropdown .optgroup:first-child .optgroup-header{border-top:0}.selectize-dropdown .optgroup-header{color:#2a2c2d;background:#fff;cursor:default}.selectize-dropdown .active{background-color:#41b987;color:#fff}.selectize-dropdown .active.create{color:#fff}.selectize-dropdown .create{color:rgba(42,44,45,.5)}.selectize-dropdown-content{overflow-y:auto;overflow-x:hidden;max-height:200px;-webkit-overflow-scrolling:touch}.selectize-control.hasCaret .selectize-input,.selectize-control.hasCaret .selectize-input input,.selectize-control.single .selectize-input,.selectize-control.single .selectize-input input{cursor:pointer}.selectize-control.hasCaret .selectize-input.input-active,.selectize-control.hasCaret .selectize-input.input-active input,.selectize-control.single .selectize-input.input-active,.selectize-control.single .selectize-input.input-active input{cursor:text}.selectize-control.hasCaret .selectize-input:after,.selectize-control.single .selectize-input:after{content:' ';display:block;position:absolute;top:50%;right:15px;margin-top:-3px;width:0;height:0;border-style:solid;border-width:5px 5px 0;border-color:grey transparent transparent}.selectize-control.hasCaret .selectize-input.dropdown-active:after,.selectize-control.single .selectize-input.dropdown-active:after{margin-top:-4px;border-width:0 5px 5px;border-color:transparent transparent grey}.selectize-control.multi.hasCaret .selectize-input.has-items:after{top:initial;bottom:1.3rem}.selectize-control.rtl.hasCaret .selectize-input:after,.selectize-control.rtl.single .selectize-input:after{left:15px;right:auto}.selectize-control.rtl .selectize-input>input{margin:0 4px 0 -2px!important}.selectize-control .selectize-input.disabled{opacity:.5;background-color:#fafafa}hxa-selectize .hx-input-control{padding-top:.21rem}hxa-selectize .hx-input-control .hx-label{position:absolute;top:.7rem;margin:0;font-weight:400;color:#aeadad;left:0;transition:.3s;z-index:0}hxa-selectize .hx-input-control .hx-label sup{top:-.2rem;color:#b81e4f;font-size:.7rem;transition:.3s}hxa-selectize .hx-input-control .hx-label+.hx-help{font-size:.75rem;margin-top:-.09rem;color:#63605f;transition:.3s;opacity:0;position:relative}hxa-selectize .hx-input-control .hx-label+.hx-help:after,hxa-selectize .hx-input-control .hx-label+.hx-help:before{content:'';position:absolute;top:-.4rem;width:0%;height:3px;background-color:#41b987;transition:.3s;z-index:1}hxa-selectize .hx-input-control .hx-label+.hx-help:before{left:50%}hxa-selectize .hx-input-control .hx-label+.hx-help:after{right:50%}hxa-selectize .hx-input-control.is-focused .hx-label{color:#41b987}hxa-selectize .hx-input-control.is-focused .hx-help{opacity:1}hxa-selectize .hx-input-control.is-focused .hx-help:after,hxa-selectize .hx-input-control.is-focused .hx-help:before{width:50%}hxa-selectize .hx-input-control.is-focused .hx-label,hxa-selectize .hx-input-control.is-valid .hx-label{top:-.5rem;font-size:.75rem}hxa-selectize .hx-input-control.is-focused .hx-label sup,hxa-selectize .hx-input-control.is-valid .hx-label sup{top:-.3rem;font-size:.4rem}hxa-selectize .selectize-control:focus{outline:0}hxa-selectize .selectize-control:-webkit-autofill~.hx-label,hxa-selectize .selectize-control:focus~.hx-label,hxa-selectize .selectize-control:valid~.hx-label{top:-.5rem;font-size:.75rem}hxa-selectize .selectize-control:-webkit-autofill~.hx-label sup,hxa-selectize .selectize-control:focus~.hx-label sup,hxa-selectize .selectize-control:valid~.hx-label sup{top:-.3rem;font-size:.4rem}hxa-selectize .selectize-control:-webkit-autofill~.hx-label,hxa-selectize .selectize-control:focus~.hx-label{color:#41b987}hxa-selectize .selectize-control:-webkit-autofill~.hx-label,hxa-selectize .selectize-control:focus~.hx-help{opacity:1}hxa-selectize .selectize-control:-webkit-autofill~.hx-label:after,hxa-selectize .selectize-control:-webkit-autofill~.hx-label:before,hxa-selectize .selectize-control:focus~.hx-help:after,hxa-selectize .selectize-control:focus~.hx-help:before{width:50%}hxa-selectize .selectize-control.is-disabled,hxa-selectize .selectize-control[disabled]{border-color:#aeadad;color:#aeadad;cursor:not-allowed}hxa-selectize .selectize-control.is-disabled~.hx-label,hxa-selectize .selectize-control[disabled]~.hx-label{top:-.5rem;font-size:.75rem;color:#aeadad;cursor:not-allowed}hxa-selectize .selectize-control.is-disabled~.hx-label sup,hxa-selectize .selectize-control[disabled]~.hx-label sup{font-size:.4rem}hxa-selectize.ng-invalid.ng-dirty .hx-label{color:#b81e4f}hxa-selectize.ng-invalid.ng-dirty .hx-label+.hx-help{position:relative;opacity:1;color:#b81e4f}hxa-selectize.ng-invalid.ng-dirty .hx-label+.hx-help:after,hxa-selectize.ng-invalid.ng-dirty .hx-label+.hx-help:before{width:50%;background-color:#b81e4f}.selectize-control.plugin-remove_button [data-value]{position:relative;padding-right:.7rem!important}.selectize-control.plugin-remove_button [data-value].is-medium{padding-right:1rem!important}.selectize-control.plugin-remove_button [data-value] .hx-delete{margin-left:-.2rem;height:16px;width:16px;max-height:16px;max-width:16px;min-height:16px;min-width:16px}.selectize-control.plugin-remove_button [data-value].is-medium .hx-delete{margin-left:-.5rem}.selectize-control.plugin-remove_button [data-value].is-large .hx-delete{margin-left:-.2rem;height:20px;width:20px;max-height:20px;max-width:20px;min-height:20px;min-width:20px}.selectize-control.plugin-remove_button .disabled [data-value] .hx-remove:hover{background:0 0}.selectize-control.plugin-remove_button .disabled [data-value] .hx-remove{border-left-color:rgba(77,77,77,0)}.selectize-control.plugin-remove_button .remove-single{position:absolute;right:28px;top:6px;font-size:23px}"]
},] },
];
/** @nocollapse */
SelectizeComponent.ctorParameters = function () { return [
{ type: IterableDiffers },
{ type: Renderer2 }
]; };
SelectizeComponent.propDecorators = {
config: [{ type: Input }],
id: [{ type: Input }],
placeholder: [{ type: Input }],
hasOptionsPlaceholder: [{ type: Input }],
noOptionsPlaceholder: [{ type: Input }],
enabled: [{ type: Input }],
value: [{ type: Input }],
formControl: [{ type: Input }],
errorClass: [{ type: Input }],
onBlur: [{ type: Output }],
onFocus: [{ type: Output }],
selectizeInput: [{ type: ViewChild, args: ['selectizeInput',] }],
options: [{ type: Input }],
optgroups: [{ type: Input }]
};
return SelectizeComponent;
}());
export { SelectizeComponent };
if (false) {
/** @type {?} */
SelectizeComponent.prototype._options;
/** @type {?} */
SelectizeComponent.prototype._options_differ;
/** @type {?} */
SelectizeComponent.prototype._optgroups;
/** @type {?} */
SelectizeComponent.prototype._optgroups_differ;
/** @type {?} */
SelectizeComponent.prototype.config;
/** @type {?} */
SelectizeComponent.prototype.id;
/** @type {?} */
SelectizeComponent.prototype.placeholder;
/** @type {?} */
SelectizeComponent.prototype.hasOptionsPlaceholder;
/** @type {?} */
SelectizeComponent.prototype.noOptionsPlaceholder;
/** @type {?} */
SelectizeComponent.prototype.enabled;
/** @type {?} */
SelectizeComponent.prototype.value;
/** @type {?} */
SelectizeComponent.prototype.formControl;
/** @type {?} */
SelectizeComponent.prototype.errorClass;
/** @type {?} */
SelectizeComponent.prototype.isFocused;
/** @type {?} */
SelectizeComponent.prototype.isValid;
/** @type {?} */
SelectizeComponent.prototype.onBlur;
/** @type {?} */
SelectizeComponent.prototype.onFocus;
/** @type {?} */
SelectizeComponent.prototype.selectizeInput;
/** @type {?} */
SelectizeComponent.prototype.selectize;
/** @type {?} */
SelectizeComponent.prototype.onTouchedCallback;
/** @type {?} */
SelectizeComponent.prototype.onChangeCallback;
/**
* Invoked anytime a key is pressed down on the selectize search field
* \@param e
* @type {?}
*/
SelectizeComponent.prototype.onKeydown;
/** @type {?} */
SelectizeComponent.prototype._differs;
/** @type {?} */
SelectizeComponent.prototype.renderer;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"selectize.component.js","sourceRoot":"ng://@hxui/angular/","sources":["lib/selectize/selectize.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Input,\r\n  OnInit,\r\n  OnChanges,\r\n  SimpleChanges,\r\n  DoCheck,\r\n  forwardRef,\r\n  Component,\r\n  ViewChild,\r\n  Output,\r\n  EventEmitter,\r\n  IterableDiffers,\r\n  IterableDiffer,\r\n  IterableChangeRecord,\r\n  IterableChanges,\r\n  ViewEncapsulation,\r\n  Renderer2,\r\n  OnDestroy\r\n} from '@angular/core';\r\nimport {\r\n  NG_VALUE_ACCESSOR,\r\n  ControlValueAccessor,\r\n  FormControl\r\n} from '@angular/forms';\r\n\r\nimport * as _ from 'lodash';\r\nimport { SelectizeConfig } from './selectize.config';\r\nimport {ISelectizeItem} from './selectize-item.interface';\r\n\r\ndeclare var $: any;\r\n\r\nexport const SELECTIZE_VALUE_ACCESSOR: any = {\r\n  provide: NG_VALUE_ACCESSOR,\r\n  useExisting: forwardRef(() => SelectizeComponent),\r\n  multi: true\r\n};\r\n\r\n@Component({\r\n  selector: 'hxa-selectize',\r\n  template: `<div class=\"hx-input-control\" [ngClass]=\"config.inputControlClasses\" [class.is-focused]=\"isFocused\" [class.is-valid]=\"isValid\">\r\n                  <select #selectizeInput></select>\r\n                  <label for=\"{{id}}\" class=\"hx-label\">{{config.label}} <sup *ngIf=\"config.mandatory\">*</sup></label>\r\n                  <div class=\"hx-help\">{{config.help}}</div>\r\n              </div>`,\r\n  providers: [SELECTIZE_VALUE_ACCESSOR],\r\n  encapsulation: ViewEncapsulation.None,\r\n  styles: [`.selectize-control{position:relative}.selectize-dropdown,.selectize-input,.selectize-input input{color:#2a2c2d;font-family:inherit;font-size:.92rem;line-height:1.5;-webkit-font-smoothing:inherit}.selectize-control.single .selectize-input.input-active,.selectize-input{background:0 0;cursor:text;display:inline-block}.selectize-input{border:1px solid rgba(0,0,0,.2);padding:8px 0;display:inline-block;width:100%;overflow:hidden;position:relative;z-index:1;box-sizing:border-box;box-shadow:none;border-radius:0;border-width:0 0 1px}.selectize-control.multi .selectize-input.has-items{padding:6px 0 3px}.selectize-control.multi.hasCaret .selectize-input.has-items{padding-right:1rem}.selectize-input.full{background-color:transparent}.selectize-input.disabled,.selectize-input.disabled *{cursor:default!important}.selectize-input.focus{box-shadow:none}.selectize-input.dropdown-active{border-radius:0}.selectize-input>*{vertical-align:baseline;display:inline-block;zoom:1}.selectize-control.multi .selectize-input>div{cursor:pointer;margin:4px;padding:2px 6px;background:rgba(0,0,0,.05);color:#2a2c2d;border:0 solid transparent;border-radius:290486px;font-size:.75rem;justify-content:center;line-height:1.5;white-space:nowrap}.selectize-control.multi .selectize-input>div.active{background:#e8e8e8;color:#2a2c2d;border:0 solid #cacaca}.selectize-control.multi .selectize-input.disabled>div,.selectize-control.multi .selectize-input.disabled>div.active{color:#787878;background:rgba(77,77,77,.05);border:0 solid rgba(77,77,77,0)}.selectize-input>input{display:inline-block!important;padding:0!important;min-height:0!important;max-height:none!important;max-width:100%!important;margin:0 2px 0 0!important;text-indent:0!important;border:0!important;background:0 0!important;line-height:inherit!important;-webkit-user-select:auto!important}.selectize-input>input::-ms-clear{display:none}.selectize-input>input:focus{outline:0!important}.selectize-input::after{content:' ';display:block;clear:left}.selectize-input.dropdown-active::before{content:' ';display:block;position:absolute;background:#f0f0f0;height:1px;bottom:0;left:0;right:0}.hx-select-control:after{display:none}.selectize-dropdown{position:absolute;z-index:10;border:transparent;background:#fff;margin:1px 0 0;border-top:0;box-sizing:border-box;box-shadow:0 6px 12px rgba(0,0,0,.145);border-radius:0}.selectize-dropdown [data-selectable]{cursor:pointer;overflow:hidden}.selectize-dropdown [data-selectable] .highlight{background:rgba(35,49,43,.23);border-radius:1px;font-weight:700}.selectize-dropdown .optgroup-header,.selectize-dropdown [data-selectable]{padding:5px 8px}.selectize-dropdown .optgroup:first-child .optgroup-header{border-top:0}.selectize-dropdown .optgroup-header{color:#2a2c2d;background:#fff;cursor:default}.selectize-dropdown .active{background-color:#41b987;color:#fff}.selectize-dropdown .active.create{color:#fff}.selectize-dropdown .create{color:rgba(42,44,45,.5)}.selectize-dropdown-content{overflow-y:auto;overflow-x:hidden;max-height:200px;-webkit-overflow-scrolling:touch}.selectize-control.hasCaret .selectize-input,.selectize-control.hasCaret .selectize-input input,.selectize-control.single .selectize-input,.selectize-control.single .selectize-input input{cursor:pointer}.selectize-control.hasCaret .selectize-input.input-active,.selectize-control.hasCaret .selectize-input.input-active input,.selectize-control.single .selectize-input.input-active,.selectize-control.single .selectize-input.input-active input{cursor:text}.selectize-control.hasCaret .selectize-input:after,.selectize-control.single .selectize-input:after{content:' ';display:block;position:absolute;top:50%;right:15px;margin-top:-3px;width:0;height:0;border-style:solid;border-width:5px 5px 0;border-color:grey transparent transparent}.selectize-control.hasCaret .selectize-input.dropdown-active:after,.selectize-control.single .selectize-input.dropdown-active:after{margin-top:-4px;border-width:0 5px 5px;border-color:transparent transparent grey}.selectize-control.multi.hasCaret .selectize-input.has-items:after{top:initial;bottom:1.3rem}.selectize-control.rtl.hasCaret .selectize-input:after,.selectize-control.rtl.single .selectize-input:after{left:15px;right:auto}.selectize-control.rtl .selectize-input>input{margin:0 4px 0 -2px!important}.selectize-control .selectize-input.disabled{opacity:.5;background-color:#fafafa}hxa-selectize .hx-input-control{padding-top:.21rem}hxa-selectize .hx-input-control .hx-label{position:absolute;top:.7rem;margin: