UNPKG

ng-zorro-antd-mobile

Version:

An enterprise-class mobile UI components based on Ant Design and Angular

613 lines 42.5 kB
/** * @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'; var SearchBarComponent = /** @class */ (function () { function SearchBarComponent(_elementRef, _localeProvider) { var _a; this._elementRef = _elementRef; this._localeProvider = _localeProvider; this.prefixCls = 'am-search'; this.cancelCls = (_a = {}, _a[this.prefixCls + "-cancel"] = true, _a); 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 {?} */ function () { }); this.onTouchFn = (/** * @return {?} */ function () { }); } Object.defineProperty(SearchBarComponent.prototype, "defaultValue", { set: /** * @param {?} value * @return {?} */ function (value) { this._defaultValue = value; this._value = value; this.inputElementRef.nativeElement.value = this._value; }, enumerable: true, configurable: true }); Object.defineProperty(SearchBarComponent.prototype, "value", { get: /** * @return {?} */ function () { return this._value; }, set: /** * @param {?} v * @return {?} */ function (v) { this._value = v || ''; this.inputElementRef.nativeElement.value = this._value; this.setClass(); }, enumerable: true, configurable: true }); Object.defineProperty(SearchBarComponent.prototype, "placeholder", { get: /** * @return {?} */ function () { return this._placeholder; }, set: /** * @param {?} value * @return {?} */ function (value) { this._placeholder = value; }, enumerable: true, configurable: true }); Object.defineProperty(SearchBarComponent.prototype, "showCancelButton", { get: /** * @return {?} */ function () { return this._showCancelButton; }, set: /** * @param {?} value * @return {?} */ function (value) { this._showCancelButton = value; this.setClass(); }, enumerable: true, configurable: true }); Object.defineProperty(SearchBarComponent.prototype, "cancelText", { get: /** * @return {?} */ function () { return this._cancelText; }, set: /** * @param {?} value * @return {?} */ function (value) { if (value !== undefined) { this._cancelText = value; this._isCustomText = true; } }, enumerable: true, configurable: true }); Object.defineProperty(SearchBarComponent.prototype, "disabled", { get: /** * @return {?} */ function () { return this._disabled; }, set: /** * @param {?} value * @return {?} */ function (value) { this._disabled = value; }, enumerable: true, configurable: true }); Object.defineProperty(SearchBarComponent.prototype, "maxLength", { get: /** * @return {?} */ function () { return this._maxLength; }, set: /** * @param {?} value * @return {?} */ function (value) { this._maxLength = value; }, enumerable: true, configurable: true }); Object.defineProperty(SearchBarComponent.prototype, "setFocus", { set: /** * @param {?} value * @return {?} */ function (value) { if (value) { if (value.focusValue) { this._focus = true; this.inputElementRef.nativeElement.focus(); this._blurFromOnClear = true; this.onSearchbarFocus(); } else { this._blurFromOnClear = false; this.onSearchbarBlur(); } } }, enumerable: true, configurable: true }); /** * @return {?} */ SearchBarComponent.prototype.setClass = /** * @return {?} */ function () { var _a, _b, _c; this.wrapCls = (_a = {}, _a["" + this.prefixCls] = true, _a[this.prefixCls + "-start"] = !!(this._focus || (this._value && this._value.length > 0)) && !this._disabled, _a); this.cancelCls = (_b = {}, _b[this.prefixCls + "-cancel"] = true, _b[this.prefixCls + "-cancel-show"] = this._showCancelButton || this._focus || (this._value && this._value.length > 0), _b[this.prefixCls + "-cancel-anim"] = this._focus, _b); this.clearCls = (_c = {}, _c[this.prefixCls + "-clear"] = this._value && this._value.length > 0, _c[this.prefixCls + "-clear-show"] = this._value && this._value.length > 0 && !this._isSubmit, _c[this.prefixCls + "-clear-active"] = this._isClearClicking, _c); }; /** * @return {?} */ SearchBarComponent.prototype.setStyle = /** * @return {?} */ function () { if (this._inputContainerRef.className.indexOf(this.prefixCls + "-start") > -1) { /** @type {?} */ var 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 {?} */ var btnMarginRight = this._rightBtnRef.offsetWidth + parseInt(this._rightBtnInitMarginLeft, 10); this._rightBtnRef.style.marginRight = '-' + btnMarginRight + 'px'; } } }; /** * @return {?} */ SearchBarComponent.prototype.onSearchbarBlur = /** * @return {?} */ function () { /** @type {?} */ var self = this; setTimeout((/** * @return {?} */ function () { if (!self._blurFromOnClear && self._value === '' && self._focus) { self._focus = false; self._value = ''; self.onBlur.emit(); self.setClass(); } self._blurFromOnClear = false; }), 50); }; /** * @return {?} */ SearchBarComponent.prototype.onSearchbarFocus = /** * @return {?} */ function () { this._focus = true; this._isSubmit = false; this.onFocus.emit(); this.setClass(); }; /** * @param {?} e * @return {?} */ SearchBarComponent.prototype.onSearchbarChange = /** * @param {?} e * @return {?} */ function (e) { this._focus = true; this._value = e; this.onChange.emit(e); this.onChangeFn(e); this.setClass(); }; /** * @param {?} e * @return {?} */ SearchBarComponent.prototype.onSearchSubmit = /** * @param {?} e * @return {?} */ function (e) { e.preventDefault(); this._value = e.target[0].value; this._isSubmit = true; this.onSubmit.emit(this._value); this.setClass(); this._blurFromOnClear = true; }; /** * @return {?} */ SearchBarComponent.prototype.onSearchbarCancel = /** * @return {?} */ function () { this._focus = false; this._value = ''; this.onCancel.emit(); this.setClass(); }; /** * @return {?} */ SearchBarComponent.prototype.onSearchbarClear = /** * @return {?} */ function () { var _this = this; this._blurFromOnClear = true; this._isClearClicking = true; this.onSearchbarChange(''); this.inputElementRef.nativeElement.focus(); this.onClear.emit(this._value); this.setClass(); setTimeout((/** * @return {?} */ function () { _this._value = ''; _this._isClearClicking = false; _this._blurFromOnClear = false; _this.setClass(); }), 100); this.onSearchbarFocus(); }; /** * @param {?} value * @return {?} */ SearchBarComponent.prototype.writeValue = /** * @param {?} value * @return {?} */ function (value) { this._value = value || ''; this.inputElementRef.nativeElement.value = this._value; this.setClass(); }; /** * @param {?} fn * @return {?} */ SearchBarComponent.prototype.registerOnChange = /** * @param {?} fn * @return {?} */ function (fn) { this.onChangeFn = fn; }; /** * @param {?} fn * @return {?} */ SearchBarComponent.prototype.registerOnTouched = /** * @param {?} fn * @return {?} */ function (fn) { this.onTouchFn = fn; }; /** * @return {?} */ SearchBarComponent.prototype.ngOnInit = /** * @return {?} */ function () { var _this = this; this.setClass(); this._localeProvider.localeChange.pipe(takeUntil(this._unsubscribe$)).subscribe((/** * @param {?} _ * @return {?} */ function (_) { _this.locale = _this._localeProvider.getLocaleSubObj('SearchBar'); _this._cancelText = _this._isCustomText ? _this._cancelText : _this.locale.cancelText; })); }; /** * @return {?} */ SearchBarComponent.prototype.ngAfterViewInit = /** * @return {?} */ function () { 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 {?} */ SearchBarComponent.prototype.ngAfterViewChecked = /** * @return {?} */ function () { this.setStyle(); }; /** * @return {?} */ SearchBarComponent.prototype.ngOnDestroy = /** * @return {?} */ function () { 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 {?} */ function () { 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 = function () { return [ { 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 }] }; return SearchBarComponent; }()); export { SearchBarComponent }; 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":"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","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"]}