UNPKG

ng-zorro-antd-mobile

Version:

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

177 lines 20.4 kB
import { Component, ViewEncapsulation, Input, Output, ElementRef, HostListener, EventEmitter, Renderer2, TemplateRef } from '@angular/core'; import * as i0 from "@angular/core"; import * as i1 from "@angular/common"; import * as i2 from "ng-zorro-antd-mobile/icon"; export class ButtonComponent { get type() { return this._type; } get size() { return this._size; } get disabled() { return this._disabled; } get loading() { return this._loading; } get inline() { return this._inline; } get icon() { return this._icon; } set icon(value) { if (value instanceof TemplateRef) { this.ngTemplate = true; this._icon = value; } else { this.ngTemplate = false; this._icon = value; this.setClassMap(); } } set className(v) { this._className = this._className + ' ' + v; this.setClassMap(); } touchStart(event) { if (this._disabled) { return; } this._active = true; this.setClassMap(); } touchEnd(event) { if (this._disabled) { return; } this._active = false; this.setClassMap(); } click(event) { if (this._disabled) { return; } this.onClick.emit(); } constructor(_elementRef, _render) { this._elementRef = _elementRef; this._render = _render; this.prefixCls = 'am-button'; this.ngTemplate = false; this._className = ''; this._classList = []; this._size = 'large'; this._loading = false; this._active = false; this._inline = false; this._disabled = false; this._icon = ''; this._userAgent = navigator.userAgent || navigator.vendor || window.opera; this.onClick = new EventEmitter(); this._el = this._elementRef.nativeElement; this._render.addClass(this._el, this.prefixCls); this._className = this._el.className; } isTemplateRef(value) { if (value) { return value instanceof TemplateRef; } return false; } set type(value) { this._type = value; this.setClassMap(); } set disabled(value) { this._disabled = value; this.setClassMap(); } set loading(value) { this._loading = value; if (this._el.querySelector('icon')) { const icon = this._el.querySelector('icon'); icon.style.display = value ? '' : 'none'; } this.setClassMap(); } set size(value) { this._size = value; this.setClassMap(); } set inline(value) { this._inline = value; this.setClassMap(); } ngAfterViewInit() { if (this._el.querySelector('img')) { const amSize = this._size === 'small' ? 'am-icon-xxs' : 'am-icon-md'; this._el.querySelector('img').setAttribute('class', `am-icon ${this.prefixCls}-icon ${amSize}`); this._render.addClass(this._el, `${this.prefixCls}-icon`); } } setClassMap() { this.iconType = this._loading ? 'loading' : this._icon; this._classList = [ this._type && `${this.prefixCls}-${this._type}`, this._size === 'small' && `${this.prefixCls}-${this._size}`, this._disabled && `${this.prefixCls}-disabled`, this._loading && `${this.prefixCls}-loading`, this.iconType && `${this.prefixCls}-icon`, this._active && `${this.prefixCls}-active`, this._inline && `${this.prefixCls}-inline` ].filter(item => { return !!item; }); this._el.className = this._className + ' ' + this._classList.join(' '); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: ButtonComponent, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: ButtonComponent, selector: "[Button], nzm-button", inputs: { type: "type", size: "size", disabled: "disabled", loading: "loading", inline: "inline", icon: "icon", className: "className" }, outputs: { onClick: "onClick" }, host: { listeners: { "touchstart": "touchStart($event)", "mousedown": "touchStart($event)", "touchend": "touchEnd($event)", "mouseup": "touchEnd($event)", "touchmove": "touchEnd($event)", "mousemove": "touchEnd($event)", "touchcancel": "touchEnd($event)", "click": "click($event)" } }, ngImport: i0, template: "<Icon\n *ngIf=\"!ngTemplate\"\n class=\"{{ prefixCls }}-icon\"\n [type]=\"iconType\"\n [size]=\"size === 'small' ? 'xxs' : 'md'\"\n></Icon>\n<ng-template *ngIf=\"ngTemplate\" [ngTemplateOutlet]=\"icon\"></ng-template>\n<ng-content select=\"img\"></ng-content>\n<div class=\"{{ prefixCls }}-content\">\n <span>\n <ng-content></ng-content>\n </span>\n</div>\n", dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.IconComponent, selector: "Icon, nzm-icon", inputs: ["color", "type", "src", "size"] }], encapsulation: i0.ViewEncapsulation.None }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: ButtonComponent, decorators: [{ type: Component, args: [{ selector: '[Button], nzm-button', encapsulation: ViewEncapsulation.None, template: "<Icon\n *ngIf=\"!ngTemplate\"\n class=\"{{ prefixCls }}-icon\"\n [type]=\"iconType\"\n [size]=\"size === 'small' ? 'xxs' : 'md'\"\n></Icon>\n<ng-template *ngIf=\"ngTemplate\" [ngTemplateOutlet]=\"icon\"></ng-template>\n<ng-content select=\"img\"></ng-content>\n<div class=\"{{ prefixCls }}-content\">\n <span>\n <ng-content></ng-content>\n </span>\n</div>\n" }] }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }], propDecorators: { type: [{ type: Input }], size: [{ type: Input }], disabled: [{ type: Input }], loading: [{ type: Input }], inline: [{ type: Input }], icon: [{ type: Input }], className: [{ type: Input }], onClick: [{ type: Output }], touchStart: [{ type: HostListener, args: ['touchstart', ['$event']] }, { type: HostListener, args: ['mousedown', ['$event']] }], touchEnd: [{ type: HostListener, args: ['touchend', ['$event']] }, { type: HostListener, args: ['mouseup', ['$event']] }, { type: HostListener, args: ['touchmove', ['$event']] }, { type: HostListener, args: ['mousemove', ['$event']] }, { type: HostListener, args: ['touchcancel', ['$event']] }], click: [{ type: HostListener, args: ['click', ['$event']] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button.component.js","sourceRoot":"","sources":["../../../components/button/button.component.ts","../../../components/button/button.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ViewEncapsulation,\n  Input,\n  Output,\n  ElementRef,\n  HostListener,\n  EventEmitter,\n  Renderer2,\n  TemplateRef,\n  AfterViewInit\n} from '@angular/core';\n\n@Component({\n  selector: '[Button], nzm-button',\n  encapsulation: ViewEncapsulation.None,\n  templateUrl: './button.component.html'\n})\nexport class ButtonComponent implements AfterViewInit {\n  prefixCls: string = 'am-button';\n  ngTemplate: boolean = false;\n  iconType: any;\n\n  private _el: HTMLElement;\n  private _className = '';\n  private _classList: any = [];\n  private _type: string;\n  private _size = 'large';\n  private _loading = false;\n  private _active = false;\n  private _inline = false;\n  private _disabled = false;\n  private _icon: string | TemplateRef<any> = '';\n  private _userAgent = (<any>navigator).userAgent || (<any>navigator).vendor || (<any>window).opera;\n\n  @Input()\n  get type(): string {\n    return this._type;\n  }\n  @Input()\n  get size(): string {\n    return this._size;\n  }\n  @Input()\n  get disabled(): boolean {\n    return this._disabled;\n  }\n  @Input()\n  get loading(): boolean {\n    return this._loading;\n  }\n  @Input()\n  get inline(): boolean {\n    return this._inline;\n  }\n  @Input()\n  get icon(): string | TemplateRef<any> {\n    return this._icon;\n  }\n  set icon(value: string | TemplateRef<any>) {\n    if (value instanceof TemplateRef) {\n      this.ngTemplate = true;\n      this._icon = value;\n    } else {\n      this.ngTemplate = false;\n      this._icon = <string>value;\n      this.setClassMap();\n    }\n  }\n  @Input()\n  set className(v) {\n    this._className = this._className + ' ' + v;\n    this.setClassMap();\n  }\n  @Output()\n  onClick: EventEmitter<any> = new EventEmitter();\n\n  @HostListener('touchstart', ['$event'])\n  @HostListener('mousedown', ['$event'])\n  touchStart(event) {\n    if (this._disabled) {\n      return;\n    }\n    this._active = true;\n    this.setClassMap();\n  }\n  @HostListener('touchend', ['$event'])\n  @HostListener('mouseup', ['$event'])\n  @HostListener('touchmove', ['$event'])\n  @HostListener('mousemove', ['$event'])\n  @HostListener('touchcancel', ['$event'])\n  touchEnd(event) {\n    if (this._disabled) {\n      return;\n    }\n    this._active = false;\n    this.setClassMap();\n  }\n\n  @HostListener('click', ['$event'])\n  click(event) {\n    if (this._disabled) {\n      return;\n    }\n    this.onClick.emit();\n  }\n\n  constructor(private _elementRef: ElementRef, private _render: Renderer2) {\n    this._el = this._elementRef.nativeElement;\n    this._render.addClass(this._el, this.prefixCls);\n    this._className = this._el.className;\n  }\n\n  isTemplateRef(value) {\n    if (value) {\n      return value instanceof TemplateRef;\n    }\n    return false;\n  }\n\n  set type(value: string) {\n    this._type = value;\n    this.setClassMap();\n  }\n\n  set disabled(value: boolean) {\n    this._disabled = value;\n    this.setClassMap();\n  }\n\n  set loading(value: boolean) {\n    this._loading = value;\n    if (this._el.querySelector('icon')) {\n      const icon = this._el.querySelector('icon') as HTMLElement;\n      icon.style.display = value ? '' : 'none';\n    }\n    this.setClassMap();\n  }\n\n  set size(value: string) {\n    this._size = value;\n    this.setClassMap();\n  }\n\n  set inline(value: boolean) {\n    this._inline = value;\n    this.setClassMap();\n  }\n\n  ngAfterViewInit() {\n    if (this._el.querySelector('img')) {\n      const amSize = this._size === 'small' ? 'am-icon-xxs' : 'am-icon-md';\n      this._el.querySelector('img').setAttribute('class', `am-icon ${this.prefixCls}-icon ${amSize}`);\n      this._render.addClass(this._el, `${this.prefixCls}-icon`);\n    }\n  }\n\n  private setClassMap(): void {\n    this.iconType = this._loading ? 'loading' : this._icon;\n    this._classList = [\n      this._type && `${this.prefixCls}-${this._type}`,\n      this._size === 'small' && `${this.prefixCls}-${this._size}`,\n      this._disabled && `${this.prefixCls}-disabled`,\n      this._loading && `${this.prefixCls}-loading`,\n      this.iconType && `${this.prefixCls}-icon`,\n      this._active && `${this.prefixCls}-active`,\n      this._inline && `${this.prefixCls}-inline`\n    ].filter(item => {\n      return !!item;\n    });\n    this._el.className = this._className + ' ' + this._classList.join(' ');\n  }\n}\n","<Icon\n  *ngIf=\"!ngTemplate\"\n  class=\"{{ prefixCls }}-icon\"\n  [type]=\"iconType\"\n  [size]=\"size === 'small' ? 'xxs' : 'md'\"\n></Icon>\n<ng-template *ngIf=\"ngTemplate\" [ngTemplateOutlet]=\"icon\"></ng-template>\n<ng-content select=\"img\"></ng-content>\n<div class=\"{{ prefixCls }}-content\">\n  <span>\n    <ng-content></ng-content>\n  </span>\n</div>\n"]}