UNPKG

ng-zorro-antd-mobile

Version:

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

529 lines 39.2 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'; 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":"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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"]}