ng-zorro-antd-mobile
Version:
An enterprise-class mobile UI components based on Ant Design and Angular
529 lines • 39.2 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, ViewEncapsulation, Input, Output, forwardRef, ElementRef, EventEmitter, ViewChild } from '@angular/core';
import { trigger, state, animate, transition, style } from '@angular/animations';
import { LocaleProviderService } from '../locale-provider/locale-provider.service';
import { Subject } from 'rxjs';
import { takeUntil } from 'rxjs/operators';
import { NG_VALUE_ACCESSOR } from '@angular/forms';
export class SearchBarComponent {
/**
* @param {?} _elementRef
* @param {?} _localeProvider
*/
constructor(_elementRef, _localeProvider) {
this._elementRef = _elementRef;
this._localeProvider = _localeProvider;
this.prefixCls = 'am-search';
this.cancelCls = {
[`${this.prefixCls}-cancel`]: true
};
this._defaultValue = '';
this._value = '';
this._placeholder = '';
this._showCancelButton = false;
this._disabled = false;
this._focus = false;
this._isSubmit = false;
this._isCustomText = false;
this._isClearClicking = false;
this._blurFromOnClear = false;
this.locale = {};
this._unsubscribe$ = new Subject();
this.onSubmit = new EventEmitter();
this.onChange = new EventEmitter();
this.onFocus = new EventEmitter();
this.onBlur = new EventEmitter();
this.onCancel = new EventEmitter();
this.onClear = new EventEmitter();
this.onChangeFn = (/**
* @return {?}
*/
() => { });
this.onTouchFn = (/**
* @return {?}
*/
() => { });
}
/**
* @param {?} value
* @return {?}
*/
set defaultValue(value) {
this._defaultValue = value;
this._value = value;
this.inputElementRef.nativeElement.value = this._value;
}
/**
* @return {?}
*/
get value() {
return this._value;
}
/**
* @param {?} v
* @return {?}
*/
set value(v) {
this._value = v || '';
this.inputElementRef.nativeElement.value = this._value;
this.setClass();
}
/**
* @return {?}
*/
get placeholder() {
return this._placeholder;
}
/**
* @param {?} value
* @return {?}
*/
set placeholder(value) {
this._placeholder = value;
}
/**
* @return {?}
*/
get showCancelButton() {
return this._showCancelButton;
}
/**
* @param {?} value
* @return {?}
*/
set showCancelButton(value) {
this._showCancelButton = value;
this.setClass();
}
/**
* @return {?}
*/
get cancelText() {
return this._cancelText;
}
/**
* @param {?} value
* @return {?}
*/
set cancelText(value) {
if (value !== undefined) {
this._cancelText = value;
this._isCustomText = true;
}
}
/**
* @return {?}
*/
get disabled() {
return this._disabled;
}
/**
* @param {?} value
* @return {?}
*/
set disabled(value) {
this._disabled = value;
}
/**
* @return {?}
*/
get maxLength() {
return this._maxLength;
}
/**
* @param {?} value
* @return {?}
*/
set maxLength(value) {
this._maxLength = value;
}
/**
* @param {?} value
* @return {?}
*/
set setFocus(value) {
if (value) {
if (value.focusValue) {
this._focus = true;
this.inputElementRef.nativeElement.focus();
this._blurFromOnClear = true;
this.onSearchbarFocus();
}
else {
this._blurFromOnClear = false;
this.onSearchbarBlur();
}
}
}
/**
* @return {?}
*/
setClass() {
this.wrapCls = {
[`${this.prefixCls}`]: true,
[`${this.prefixCls}-start`]: !!(this._focus || (this._value && this._value.length > 0)) && !this._disabled
};
this.cancelCls = {
[`${this.prefixCls}-cancel`]: true,
[`${this.prefixCls}-cancel-show`]: this._showCancelButton || this._focus || (this._value && this._value.length > 0),
[`${this.prefixCls}-cancel-anim`]: this._focus
};
this.clearCls = {
[`${this.prefixCls}-clear`]: this._value && this._value.length > 0,
[`${this.prefixCls}-clear-show`]: this._value && this._value.length > 0 && !this._isSubmit,
[`${this.prefixCls}-clear-active`]: this._isClearClicking
};
}
/**
* @return {?}
*/
setStyle() {
if (this._inputContainerRef.className.indexOf(`${this.prefixCls}-start`) > -1) {
/** @type {?} */
const realWidth = this._syntheticPhContainerRef.getBoundingClientRect().width;
this._syntheticPhRef.style.width = Math.ceil(realWidth) + 'px';
if (!this._showCancelButton) {
this._rightBtnRef.style.marginRight = '0';
}
}
else {
this._syntheticPhRef.style.width = '100%';
if (!this._showCancelButton) {
this._rightBtnInitMarginLeft = window.getComputedStyle(this._rightBtnRef)['margin-left'];
/** @type {?} */
const btnMarginRight = this._rightBtnRef.offsetWidth + parseInt(this._rightBtnInitMarginLeft, 10);
this._rightBtnRef.style.marginRight = '-' + btnMarginRight + 'px';
}
}
}
/**
* @return {?}
*/
onSearchbarBlur() {
/** @type {?} */
const self = this;
setTimeout((/**
* @return {?}
*/
() => {
if (!self._blurFromOnClear && self._value === '' && self._focus) {
self._focus = false;
self._value = '';
self.onBlur.emit();
self.setClass();
}
self._blurFromOnClear = false;
}), 50);
}
/**
* @return {?}
*/
onSearchbarFocus() {
this._focus = true;
this._isSubmit = false;
this.onFocus.emit();
this.setClass();
}
/**
* @param {?} e
* @return {?}
*/
onSearchbarChange(e) {
this._focus = true;
this._value = e;
this.onChange.emit(e);
this.onChangeFn(e);
this.setClass();
}
/**
* @param {?} e
* @return {?}
*/
onSearchSubmit(e) {
e.preventDefault();
this._value = e.target[0].value;
this._isSubmit = true;
this.onSubmit.emit(this._value);
this.setClass();
this._blurFromOnClear = true;
}
/**
* @return {?}
*/
onSearchbarCancel() {
this._focus = false;
this._value = '';
this.onCancel.emit();
this.setClass();
}
/**
* @return {?}
*/
onSearchbarClear() {
this._blurFromOnClear = true;
this._isClearClicking = true;
this.onSearchbarChange('');
this.inputElementRef.nativeElement.focus();
this.onClear.emit(this._value);
this.setClass();
setTimeout((/**
* @return {?}
*/
() => {
this._value = '';
this._isClearClicking = false;
this._blurFromOnClear = false;
this.setClass();
}), 100);
this.onSearchbarFocus();
}
/**
* @param {?} value
* @return {?}
*/
writeValue(value) {
this._value = value || '';
this.inputElementRef.nativeElement.value = this._value;
this.setClass();
}
/**
* @param {?} fn
* @return {?}
*/
registerOnChange(fn) {
this.onChangeFn = fn;
}
/**
* @param {?} fn
* @return {?}
*/
registerOnTouched(fn) {
this.onTouchFn = fn;
}
/**
* @return {?}
*/
ngOnInit() {
this.setClass();
this._localeProvider.localeChange.pipe(takeUntil(this._unsubscribe$)).subscribe((/**
* @param {?} _
* @return {?}
*/
_ => {
this.locale = this._localeProvider.getLocaleSubObj('SearchBar');
this._cancelText = this._isCustomText ? this._cancelText : this.locale.cancelText;
}));
}
/**
* @return {?}
*/
ngAfterViewInit() {
this._syntheticPhContainerRef = this._elementRef.nativeElement.getElementsByClassName(`${this.prefixCls}-synthetic-ph-container`)[0];
this._syntheticPhRef = this._elementRef.nativeElement.getElementsByClassName(`${this.prefixCls}-synthetic-ph`)[0];
this._rightBtnRef = this._elementRef.nativeElement.getElementsByClassName('cancel')[0];
this._inputContainerRef = this._elementRef.nativeElement.getElementsByClassName(`${this.prefixCls}`)[0];
}
/**
* @return {?}
*/
ngAfterViewChecked() {
this.setStyle();
}
/**
* @return {?}
*/
ngOnDestroy() {
this._unsubscribe$.next();
this._unsubscribe$.complete();
}
}
SearchBarComponent.decorators = [
{ type: Component, args: [{
selector: 'SearchBar, nzm-search-bar',
template: "<form name=\"myForm\" class=\"{{ prefixCls }}\" [ngClass]=\"wrapCls\" action=\"#\" (submit)=\"onSearchSubmit($event)\">\n <div class=\"{{ prefixCls }}-input\">\n <div\n class=\"{{ prefixCls }}-synthetic-ph\"\n style=\"box-sizing:unset\"\n [@cancelButtonState]=\"showCancelButton ? 'visible' : 'hidden'\"\n >\n <span class=\"{{ prefixCls }}-synthetic-ph-container\">\n <i class=\"{{ prefixCls }}-synthetic-ph-icon\"></i>\n <span\n class=\"{{ prefixCls }}-synthetic-ph-placeholder\"\n [ngStyle]=\"{ visibility: placeholder && !value ? 'visible' : 'hidden' }\"\n >\n {{ placeholder }}\n </span>\n </span>\n </div>\n <input\n #search\n class=\"{{ prefixCls }}-value\"\n style=\"outline:none;\"\n [name]=\"'search'\"\n [type]=\"'search'\"\n [disabled]=\"disabled\"\n [maxlength]=\"maxLength\"\n [placeholder]=\"placeholder\"\n [ngModel]=\"value\"\n (blur)=\"onSearchbarBlur()\"\n (focus)=\"onSearchbarFocus()\"\n (ngModelChange)=\"onSearchbarChange($event)\"\n />\n <a [ngClass]=\"clearCls\" style=\"box-sizing: content-box;transition: 0s\" (click)=\"onSearchbarClear()\"></a>\n </div>\n <div class=\"cancel\" [ngClass]=\"cancelCls\" (click)=\"onSearchbarCancel()\">\n {{ cancelText }}\n </div>\n</form>\n",
encapsulation: ViewEncapsulation.None,
providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef((/**
* @return {?}
*/
() => SearchBarComponent)),
multi: true
}
],
animations: [
trigger('cancelButtonState', [
state('visible', style({ width: '*' })),
state('hidden', style({ width: '100%' })),
transition('visible =>hidden', [animate(300, style({ width: '100%' }))]),
transition('hidden => visible', [animate(300, style({ width: '*' }))])
])
]
}] }
];
/** @nocollapse */
SearchBarComponent.ctorParameters = () => [
{ type: ElementRef },
{ type: LocaleProviderService }
];
SearchBarComponent.propDecorators = {
inputElementRef: [{ type: ViewChild, args: ['search', { static: true },] }],
defaultValue: [{ type: Input }],
value: [{ type: Input }],
placeholder: [{ type: Input }],
showCancelButton: [{ type: Input }],
cancelText: [{ type: Input }],
disabled: [{ type: Input }],
maxLength: [{ type: Input }],
setFocus: [{ type: Input }],
onSubmit: [{ type: Output }],
onChange: [{ type: Output }],
onFocus: [{ type: Output }],
onBlur: [{ type: Output }],
onCancel: [{ type: Output }],
onClear: [{ type: Output }]
};
if (false) {
/** @type {?} */
SearchBarComponent.prototype.prefixCls;
/** @type {?} */
SearchBarComponent.prototype.clearCls;
/** @type {?} */
SearchBarComponent.prototype.wrapCls;
/** @type {?} */
SearchBarComponent.prototype.cancelCls;
/**
* @type {?}
* @private
*/
SearchBarComponent.prototype._defaultValue;
/**
* @type {?}
* @private
*/
SearchBarComponent.prototype._value;
/**
* @type {?}
* @private
*/
SearchBarComponent.prototype._placeholder;
/**
* @type {?}
* @private
*/
SearchBarComponent.prototype._showCancelButton;
/**
* @type {?}
* @private
*/
SearchBarComponent.prototype._cancelText;
/**
* @type {?}
* @private
*/
SearchBarComponent.prototype._disabled;
/**
* @type {?}
* @private
*/
SearchBarComponent.prototype._maxLength;
/**
* @type {?}
* @private
*/
SearchBarComponent.prototype._focus;
/**
* @type {?}
* @private
*/
SearchBarComponent.prototype._isSubmit;
/**
* @type {?}
* @private
*/
SearchBarComponent.prototype._isCustomText;
/**
* @type {?}
* @private
*/
SearchBarComponent.prototype._isClearClicking;
/**
* @type {?}
* @private
*/
SearchBarComponent.prototype._syntheticPhContainerRef;
/**
* @type {?}
* @private
*/
SearchBarComponent.prototype._syntheticPhRef;
/**
* @type {?}
* @private
*/
SearchBarComponent.prototype._rightBtnRef;
/**
* @type {?}
* @private
*/
SearchBarComponent.prototype._inputContainerRef;
/**
* @type {?}
* @private
*/
SearchBarComponent.prototype._rightBtnInitMarginLeft;
/**
* @type {?}
* @private
*/
SearchBarComponent.prototype._blurFromOnClear;
/**
* @type {?}
* @private
*/
SearchBarComponent.prototype.locale;
/**
* @type {?}
* @private
*/
SearchBarComponent.prototype._unsubscribe$;
/** @type {?} */
SearchBarComponent.prototype.inputElementRef;
/** @type {?} */
SearchBarComponent.prototype.onSubmit;
/** @type {?} */
SearchBarComponent.prototype.onChange;
/** @type {?} */
SearchBarComponent.prototype.onFocus;
/** @type {?} */
SearchBarComponent.prototype.onBlur;
/** @type {?} */
SearchBarComponent.prototype.onCancel;
/** @type {?} */
SearchBarComponent.prototype.onClear;
/**
* @type {?}
* @private
*/
SearchBarComponent.prototype.onChangeFn;
/**
* @type {?}
* @private
*/
SearchBarComponent.prototype.onTouchFn;
/**
* @type {?}
* @private
*/
SearchBarComponent.prototype._elementRef;
/**
* @type {?}
* @private
*/
SearchBarComponent.prototype._localeProvider;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search-bar.component.js","sourceRoot":"ng://ng-zorro-antd-mobile/","sources":["search-bar/search-bar.component.ts"],"names":[],"mappings":";;;;AAAA,OAAO,EACL,SAAS,EAIT,iBAAiB,EACjB,KAAK,EACL,MAAM,EACN,UAAU,EACV,UAAU,EACV,YAAY,EAEZ,SAAS,EACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,UAAU,EAAE,KAAK,EAAE,MAAM,qBAAqB,CAAC;AACjF,OAAO,EAAE,qBAAqB,EAAE,MAAM,4CAA4C,CAAC;AACnF,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC3C,OAAO,EAAE,iBAAiB,EAAwB,MAAM,gBAAgB,CAAC;AAsBzE,MAAM,OAAO,kBAAkB;;;;;IAkH7B,YAAoB,WAAuB,EAAU,eAAsC;QAAvE,gBAAW,GAAX,WAAW,CAAY;QAAU,oBAAe,GAAf,eAAe,CAAuB;QAjH3F,cAAS,GAAW,WAAW,CAAC;QAGhC,cAAS,GAAW;YAClB,CAAC,GAAG,IAAI,CAAC,SAAS,SAAS,CAAC,EAAE,IAAI;SACnC,CAAC;QAEM,kBAAa,GAAW,EAAE,CAAC;QAC3B,WAAM,GAAW,EAAE,CAAC;QACpB,iBAAY,GAAW,EAAE,CAAC;QAC1B,sBAAiB,GAAY,KAAK,CAAC;QAEnC,cAAS,GAAY,KAAK,CAAC;QAE3B,WAAM,GAAY,KAAK,CAAC;QACxB,cAAS,GAAY,KAAK,CAAC;QAC3B,kBAAa,GAAY,KAAK,CAAC;QAC/B,qBAAgB,GAAY,KAAK,CAAC;QAMlC,qBAAgB,GAAY,KAAK,CAAC;QAClC,WAAM,GAAQ,EAAE,CAAC;QACjB,kBAAa,GAAG,IAAI,OAAO,EAAQ,CAAC;QA0E5C,aAAQ,GAAG,IAAI,YAAY,EAAO,CAAC;QAEnC,aAAQ,GAAG,IAAI,YAAY,EAAO,CAAC;QAEnC,YAAO,GAAG,IAAI,YAAY,EAAO,CAAC;QAElC,WAAM,GAAG,IAAI,YAAY,EAAO,CAAC;QAEjC,aAAQ,GAAG,IAAI,YAAY,EAAO,CAAC;QAEnC,YAAO,GAAG,IAAI,YAAY,EAAO,CAAC;QAC1B,eAAU;;;QAA4B,GAAG,EAAE,GAAE,CAAC,EAAC;QAC/C,cAAS;;;QAA4B,GAAG,EAAE,GAAE,CAAC,EAAC;IAEwC,CAAC;;;;;IAnF/F,IACI,YAAY,CAAC,KAAa;QAC5B,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;QAC3B,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC;IACzD,CAAC;;;;IACD,IACI,KAAK;QACP,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;;;;;IACD,IAAI,KAAK,CAAC,CAAS;QACjB,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,EAAE,CAAC;QACtB,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC;QACvD,IAAI,CAAC,QAAQ,EAAE,CAAC;IAClB,CAAC;;;;IACD,IACI,WAAW;QACb,OAAO,IAAI,CAAC,YAAY,CAAC;IAC3B,CAAC;;;;;IACD,IAAI,WAAW,CAAC,KAAa;QAC3B,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;IAC5B,CAAC;;;;IACD,IACI,gBAAgB;QAClB,OAAO,IAAI,CAAC,iBAAiB,CAAC;IAChC,CAAC;;;;;IACD,IAAI,gBAAgB,CAAC,KAAc;QACjC,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;QAC/B,IAAI,CAAC,QAAQ,EAAE,CAAC;IAClB,CAAC;;;;IACD,IACI,UAAU;QACZ,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;;;;;IACD,IAAI,UAAU,CAAC,KAAa;QAC1B,IAAI,KAAK,KAAK,SAAS,EAAE;YACvB,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;YACzB,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;SAC3B;IACH,CAAC;;;;IACD,IACI,QAAQ;QACV,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;;;;;IACD,IAAI,QAAQ,CAAC,KAAc;QACzB,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;IACzB,CAAC;;;;IACD,IACI,SAAS;QACX,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;;;;;IACD,IAAI,SAAS,CAAC,KAAa;QACzB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;IAC1B,CAAC;;;;;IACD,IACI,QAAQ,CAAC,KAAK;QAChB,IAAI,KAAK,EAAE;YACT,IAAI,KAAK,CAAC,UAAU,EAAE;gBACpB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;gBACnB,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;gBAC3C,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC;gBAC7B,IAAI,CAAC,gBAAgB,EAAE,CAAC;aACzB;iBAAM;gBACL,IAAI,CAAC,gBAAgB,GAAG,KAAK,CAAC;gBAC9B,IAAI,CAAC,eAAe,EAAE,CAAC;aACxB;SACF;IACH,CAAC;;;;IAkBD,QAAQ;QACN,IAAI,CAAC,OAAO,GAAG;YACb,CAAC,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC,EAAE,IAAI;YAC3B,CAAC,GAAG,IAAI,CAAC,SAAS,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS;SAC3G,CAAC;QACF,IAAI,CAAC,SAAS,GAAG;YACf,CAAC,GAAG,IAAI,CAAC,SAAS,SAAS,CAAC,EAAE,IAAI;YAClC,CAAC,GAAG,IAAI,CAAC,SAAS,cAAc,CAAC,EAC/B,IAAI,CAAC,iBAAiB,IAAI,IAAI,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC;YAClF,CAAC,GAAG,IAAI,CAAC,SAAS,cAAc,CAAC,EAAE,IAAI,CAAC,MAAM;SAC/C,CAAC;QACF,IAAI,CAAC,QAAQ,GAAG;YACd,CAAC,GAAG,IAAI,CAAC,SAAS,QAAQ,CAAC,EAAE,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC;YAClE,CAAC,GAAG,IAAI,CAAC,SAAS,aAAa,CAAC,EAAE,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS;YAC1F,CAAC,GAAG,IAAI,CAAC,SAAS,eAAe,CAAC,EAAE,IAAI,CAAC,gBAAgB;SAC1D,CAAC;IACJ,CAAC;;;;IAED,QAAQ;QACN,IAAI,IAAI,CAAC,kBAAkB,CAAC,SAAS,CAAC,OAAO,CAAC,GAAG,IAAI,CAAC,SAAS,QAAQ,CAAC,GAAG,CAAC,CAAC,EAAE;;kBACvE,SAAS,GAAG,IAAI,CAAC,wBAAwB,CAAC,qBAAqB,EAAE,CAAC,KAAK;YAC7E,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,KAAK,GAAG,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,IAAI,CAAC;YAC/D,IAAI,CAAC,IAAI,CAAC,iBAAiB,EAAE;gBAC3B,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,WAAW,GAAG,GAAG,CAAC;aAC3C;SACF;aAAM;YACL,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,KAAK,GAAG,MAAM,CAAC;YAC1C,IAAI,CAAC,IAAI,CAAC,iBAAiB,EAAE;gBAC3B,IAAI,CAAC,uBAAuB,GAAG,MAAM,CAAC,gBAAgB,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,aAAa,CAAC,CAAC;;sBACnF,cAAc,GAAG,IAAI,CAAC,YAAY,CAAC,WAAW,GAAG,QAAQ,CAAC,IAAI,CAAC,uBAAuB,EAAE,EAAE,CAAC;gBACjG,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,WAAW,GAAG,GAAG,GAAG,cAAc,GAAG,IAAI,CAAC;aACnE;SACF;IACH,CAAC;;;;IAED,eAAe;;cACP,IAAI,GAAG,IAAI;QACjB,UAAU;;;QAAC,GAAG,EAAE;YACd,IAAI,CAAC,IAAI,CAAC,gBAAgB,IAAI,IAAI,CAAC,MAAM,KAAK,EAAE,IAAI,IAAI,CAAC,MAAM,EAAE;gBAC/D,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;gBACpB,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;gBACjB,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;gBACnB,IAAI,CAAC,QAAQ,EAAE,CAAC;aACjB;YACD,IAAI,CAAC,gBAAgB,GAAG,KAAK,CAAC;QAChC,CAAC,GAAE,EAAE,CAAC,CAAC;IACT,CAAC;;;;IAED,gBAAgB;QACd,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;QACnB,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACvB,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC;QACpB,IAAI,CAAC,QAAQ,EAAE,CAAC;IAClB,CAAC;;;;;IAED,iBAAiB,CAAC,CAAC;QACjB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;QACnB,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;QAChB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACtB,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;QACnB,IAAI,CAAC,QAAQ,EAAE,CAAC;IAClB,CAAC;;;;;IAED,cAAc,CAAC,CAAC;QACd,CAAC,CAAC,cAAc,EAAE,CAAC;QACnB,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;QAChC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACtB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAChC,IAAI,CAAC,QAAQ,EAAE,CAAC;QAChB,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC;IAC/B,CAAC;;;;IAED,iBAAiB;QACf,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;QACjB,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QACrB,IAAI,CAAC,QAAQ,EAAE,CAAC;IAClB,CAAC;;;;IAED,gBAAgB;QACd,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC;QAC7B,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC;QAC7B,IAAI,CAAC,iBAAiB,CAAC,EAAE,CAAC,CAAC;QAC3B,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;QAC3C,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAC/B,IAAI,CAAC,QAAQ,EAAE,CAAC;QAChB,UAAU;;;QAAC,GAAG,EAAE;YACd,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;YACjB,IAAI,CAAC,gBAAgB,GAAG,KAAK,CAAC;YAC9B,IAAI,CAAC,gBAAgB,GAAG,KAAK,CAAC;YAC9B,IAAI,CAAC,QAAQ,EAAE,CAAC;QAClB,CAAC,GAAE,GAAG,CAAC,CAAC;QACR,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC1B,CAAC;;;;;IAED,UAAU,CAAC,KAAU;QACnB,IAAI,CAAC,MAAM,GAAG,KAAK,IAAI,EAAE,CAAC;QAC1B,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC;QACvD,IAAI,CAAC,QAAQ,EAAE,CAAC;IAClB,CAAC;;;;;IAED,gBAAgB,CAAC,EAA2B;QAC1C,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;IACvB,CAAC;;;;;IAED,iBAAiB,CAAC,EAA2B;QAC3C,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;;;;IAED,QAAQ;QACN,IAAI,CAAC,QAAQ,EAAE,CAAC;QAChB,IAAI,CAAC,eAAe,CAAC,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,SAAS;;;;QAAC,CAAC,CAAC,EAAE;YAClF,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,eAAe,CAAC,eAAe,CAAC,WAAW,CAAC,CAAC;YAChE,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC;QACpF,CAAC,EAAC,CAAC;IACL,CAAC;;;;IAED,eAAe;QACb,IAAI,CAAC,wBAAwB,GAAG,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,sBAAsB,CACnF,GAAG,IAAI,CAAC,SAAS,yBAAyB,CAC3C,CAAC,CAAC,CAAC,CAAC;QACL,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,sBAAsB,CAAC,GAAG,IAAI,CAAC,SAAS,eAAe,CAAC,CAAC,CAAC,CAAC,CAAC;QAClH,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,sBAAsB,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;QACvF,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,sBAAsB,CAAC,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;IAC1G,CAAC;;;;IAED,kBAAkB;QAChB,IAAI,CAAC,QAAQ,EAAE,CAAC;IAClB,CAAC;;;;IAED,WAAW;QACT,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;QAC1B,IAAI,CAAC,aAAa,CAAC,QAAQ,EAAE,CAAC;IAChC,CAAC;;;YA7QF,SAAS,SAAC;gBACT,QAAQ,EAAE,2BAA2B;gBACrC,i2CAA0C;gBAC1C,aAAa,EAAE,iBAAiB,CAAC,IAAI;gBACrC,SAAS,EAAE;oBACT;wBACE,OAAO,EAAE,iBAAiB;wBAC1B,WAAW,EAAE,UAAU;;;wBAAC,GAAG,EAAE,CAAC,kBAAkB,EAAC;wBACjD,KAAK,EAAE,IAAI;qBACZ;iBACF;gBACD,UAAU,EAAE;oBACV,OAAO,CAAC,mBAAmB,EAAE;wBAC3B,KAAK,CAAC,SAAS,EAAE,KAAK,CAAC,EAAE,KAAK,EAAE,GAAG,EAAE,CAAC,CAAC;wBACvC,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC,CAAC;wBACzC,UAAU,CAAC,kBAAkB,EAAE,CAAC,OAAO,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC,CAAC,CAAC,CAAC;wBACxE,UAAU,CAAC,mBAAmB,EAAE,CAAC,OAAO,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,KAAK,EAAE,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC;qBACvE,CAAC;iBACH;aACF;;;;YA9BC,UAAU;YAMH,qBAAqB;;;8BAqD3B,SAAS,SAAC,QAAQ,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;2BAGpC,KAAK;oBAML,KAAK;0BASL,KAAK;+BAOL,KAAK;yBAQL,KAAK;uBAUL,KAAK;wBAOL,KAAK;uBAOL,KAAK;uBAcL,MAAM;uBAEN,MAAM;sBAEN,MAAM;qBAEN,MAAM;uBAEN,MAAM;sBAEN,MAAM;;;;IA5GP,uCAAgC;;IAChC,sCAAiB;;IACjB,qCAAgB;;IAChB,uCAEE;;;;;IAEF,2CAAmC;;;;;IACnC,oCAA4B;;;;;IAC5B,0CAAkC;;;;;IAClC,+CAA2C;;;;;IAC3C,yCAA4B;;;;;IAC5B,uCAAmC;;;;;IACnC,wCAA2B;;;;;IAC3B,oCAAgC;;;;;IAChC,uCAAmC;;;;;IACnC,2CAAuC;;;;;IACvC,8CAA0C;;;;;IAC1C,sDAA8C;;;;;IAC9C,6CAAqC;;;;;IACrC,0CAAkC;;;;;IAClC,gDAAwC;;;;;IACxC,qDAAwC;;;;;IACxC,8CAA0C;;;;;IAC1C,oCAAyB;;;;;IACzB,2CAA4C;;IAE5C,6CACgB;;IAsEhB,sCACmC;;IACnC,sCACmC;;IACnC,qCACkC;;IAClC,oCACiC;;IACjC,sCACmC;;IACnC,qCACkC;;;;;IAClC,wCAAuD;;;;;IACvD,uCAAsD;;;;;IAE1C,yCAA+B;;;;;IAAE,6CAA8C","sourcesContent":["import {\n  Component,\n  OnInit,\n  AfterViewInit,\n  AfterViewChecked,\n  ViewEncapsulation,\n  Input,\n  Output,\n  forwardRef,\n  ElementRef,\n  EventEmitter,\n  OnDestroy,\n  ViewChild\n} from '@angular/core';\nimport { trigger, state, animate, transition, style } from '@angular/animations';\nimport { LocaleProviderService } from '../locale-provider/locale-provider.service';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { NG_VALUE_ACCESSOR, ControlValueAccessor } from '@angular/forms';\n\n@Component({\n  selector: 'SearchBar, nzm-search-bar',\n  templateUrl: './search-bar.component.html',\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => SearchBarComponent),\n      multi: true\n    }\n  ],\n  animations: [\n    trigger('cancelButtonState', [\n      state('visible', style({ width: '*' })),\n      state('hidden', style({ width: '100%' })),\n      transition('visible =>hidden', [animate(300, style({ width: '100%' }))]),\n      transition('hidden => visible', [animate(300, style({ width: '*' }))])\n    ])\n  ]\n})\nexport class SearchBarComponent implements OnInit, AfterViewInit, AfterViewChecked, OnDestroy, ControlValueAccessor {\n  prefixCls: string = 'am-search';\n  clearCls: object;\n  wrapCls: object;\n  cancelCls: object = {\n    [`${this.prefixCls}-cancel`]: true\n  };\n\n  private _defaultValue: string = '';\n  private _value: string = '';\n  private _placeholder: string = '';\n  private _showCancelButton: boolean = false;\n  private _cancelText: string;\n  private _disabled: boolean = false;\n  private _maxLength: number;\n  private _focus: boolean = false;\n  private _isSubmit: boolean = false;\n  private _isCustomText: boolean = false;\n  private _isClearClicking: boolean = false;\n  private _syntheticPhContainerRef: HTMLElement;\n  private _syntheticPhRef: HTMLElement;\n  private _rightBtnRef: HTMLElement;\n  private _inputContainerRef: HTMLElement;\n  private _rightBtnInitMarginLeft: string;\n  private _blurFromOnClear: boolean = false;\n  private locale: any = {};\n  private _unsubscribe$ = new Subject<void>();\n\n  @ViewChild('search', { static: true })\n  inputElementRef;\n\n  @Input()\n  set defaultValue(value: string) {\n    this._defaultValue = value;\n    this._value = value;\n    this.inputElementRef.nativeElement.value = this._value;\n  }\n  @Input()\n  get value(): string {\n    return this._value;\n  }\n  set value(v: string) {\n    this._value = v || '';\n    this.inputElementRef.nativeElement.value = this._value;\n    this.setClass();\n  }\n  @Input()\n  get placeholder(): string {\n    return this._placeholder;\n  }\n  set placeholder(value: string) {\n    this._placeholder = value;\n  }\n  @Input()\n  get showCancelButton(): boolean {\n    return this._showCancelButton;\n  }\n  set showCancelButton(value: boolean) {\n    this._showCancelButton = value;\n    this.setClass();\n  }\n  @Input()\n  get cancelText(): string {\n    return this._cancelText;\n  }\n  set cancelText(value: string) {\n    if (value !== undefined) {\n      this._cancelText = value;\n      this._isCustomText = true;\n    }\n  }\n  @Input()\n  get disabled(): boolean {\n    return this._disabled;\n  }\n  set disabled(value: boolean) {\n    this._disabled = value;\n  }\n  @Input()\n  get maxLength(): number {\n    return this._maxLength;\n  }\n  set maxLength(value: number) {\n    this._maxLength = value;\n  }\n  @Input()\n  set setFocus(value) {\n    if (value) {\n      if (value.focusValue) {\n        this._focus = true;\n        this.inputElementRef.nativeElement.focus();\n        this._blurFromOnClear = true;\n        this.onSearchbarFocus();\n      } else {\n        this._blurFromOnClear = false;\n        this.onSearchbarBlur();\n      }\n    }\n  }\n  @Output()\n  onSubmit = new EventEmitter<any>();\n  @Output()\n  onChange = new EventEmitter<any>();\n  @Output()\n  onFocus = new EventEmitter<any>();\n  @Output()\n  onBlur = new EventEmitter<any>();\n  @Output()\n  onCancel = new EventEmitter<any>();\n  @Output()\n  onClear = new EventEmitter<any>();\n  private onChangeFn: (value: string) => void = () => {};\n  private onTouchFn: (value: string) => void = () => {};\n\n  constructor(private _elementRef: ElementRef, private _localeProvider: LocaleProviderService) {}\n\n  setClass() {\n    this.wrapCls = {\n      [`${this.prefixCls}`]: true,\n      [`${this.prefixCls}-start`]: !!(this._focus || (this._value && this._value.length > 0)) && !this._disabled\n    };\n    this.cancelCls = {\n      [`${this.prefixCls}-cancel`]: true,\n      [`${this.prefixCls}-cancel-show`]:\n        this._showCancelButton || this._focus || (this._value && this._value.length > 0),\n      [`${this.prefixCls}-cancel-anim`]: this._focus\n    };\n    this.clearCls = {\n      [`${this.prefixCls}-clear`]: this._value && this._value.length > 0,\n      [`${this.prefixCls}-clear-show`]: this._value && this._value.length > 0 && !this._isSubmit,\n      [`${this.prefixCls}-clear-active`]: this._isClearClicking\n    };\n  }\n\n  setStyle() {\n    if (this._inputContainerRef.className.indexOf(`${this.prefixCls}-start`) > -1) {\n      const realWidth = this._syntheticPhContainerRef.getBoundingClientRect().width;\n      this._syntheticPhRef.style.width = Math.ceil(realWidth) + 'px';\n      if (!this._showCancelButton) {\n        this._rightBtnRef.style.marginRight = '0';\n      }\n    } else {\n      this._syntheticPhRef.style.width = '100%';\n      if (!this._showCancelButton) {\n        this._rightBtnInitMarginLeft = window.getComputedStyle(this._rightBtnRef)['margin-left'];\n        const btnMarginRight = this._rightBtnRef.offsetWidth + parseInt(this._rightBtnInitMarginLeft, 10);\n        this._rightBtnRef.style.marginRight = '-' + btnMarginRight + 'px';\n      }\n    }\n  }\n\n  onSearchbarBlur() {\n    const self = this;\n    setTimeout(() => {\n      if (!self._blurFromOnClear && self._value === '' && self._focus) {\n        self._focus = false;\n        self._value = '';\n        self.onBlur.emit();\n        self.setClass();\n      }\n      self._blurFromOnClear = false;\n    }, 50);\n  }\n\n  onSearchbarFocus() {\n    this._focus = true;\n    this._isSubmit = false;\n    this.onFocus.emit();\n    this.setClass();\n  }\n\n  onSearchbarChange(e) {\n    this._focus = true;\n    this._value = e;\n    this.onChange.emit(e);\n    this.onChangeFn(e);\n    this.setClass();\n  }\n\n  onSearchSubmit(e) {\n    e.preventDefault();\n    this._value = e.target[0].value;\n    this._isSubmit = true;\n    this.onSubmit.emit(this._value);\n    this.setClass();\n    this._blurFromOnClear = true;\n  }\n\n  onSearchbarCancel() {\n    this._focus = false;\n    this._value = '';\n    this.onCancel.emit();\n    this.setClass();\n  }\n\n  onSearchbarClear() {\n    this._blurFromOnClear = true;\n    this._isClearClicking = true;\n    this.onSearchbarChange('');\n    this.inputElementRef.nativeElement.focus();\n    this.onClear.emit(this._value);\n    this.setClass();\n    setTimeout(() => {\n      this._value = '';\n      this._isClearClicking = false;\n      this._blurFromOnClear = false;\n      this.setClass();\n    }, 100);\n    this.onSearchbarFocus();\n  }\n\n  writeValue(value: any): void {\n    this._value = value || '';\n    this.inputElementRef.nativeElement.value = this._value;\n    this.setClass();\n  }\n\n  registerOnChange(fn: (value: string) => void): void {\n    this.onChangeFn = fn;\n  }\n\n  registerOnTouched(fn: (value: string) => void): void {\n    this.onTouchFn = fn;\n  }\n\n  ngOnInit() {\n    this.setClass();\n    this._localeProvider.localeChange.pipe(takeUntil(this._unsubscribe$)).subscribe(_ => {\n      this.locale = this._localeProvider.getLocaleSubObj('SearchBar');\n      this._cancelText = this._isCustomText ? this._cancelText : this.locale.cancelText;\n    });\n  }\n\n  ngAfterViewInit() {\n    this._syntheticPhContainerRef = this._elementRef.nativeElement.getElementsByClassName(\n      `${this.prefixCls}-synthetic-ph-container`\n    )[0];\n    this._syntheticPhRef = this._elementRef.nativeElement.getElementsByClassName(`${this.prefixCls}-synthetic-ph`)[0];\n    this._rightBtnRef = this._elementRef.nativeElement.getElementsByClassName('cancel')[0];\n    this._inputContainerRef = this._elementRef.nativeElement.getElementsByClassName(`${this.prefixCls}`)[0];\n  }\n\n  ngAfterViewChecked() {\n    this.setStyle();\n  }\n\n  ngOnDestroy() {\n    this._unsubscribe$.next();\n    this._unsubscribe$.complete();\n  }\n}\n"]}