ng-zorro-antd-mobile
Version:
An enterprise-class mobile UI components based on Ant Design and Angular
133 lines • 15 kB
JavaScript
import { Component, Input, HostBinding, ElementRef, Renderer2 } from '@angular/core';
import * as i0 from "@angular/core";
import * as i1 from "@angular/common";
export class BadgeComponent {
set size(v) {
this._size = v;
this.setCls();
}
get text() {
return this._text;
}
set text(v) {
this._text = v;
this.setCls();
}
set corner(v) {
this._corner = v;
this.setCls();
}
get dot() {
return this._dot;
}
set dot(v) {
this._dot = v;
if (this._dot) {
this._text = '';
}
this.setCls();
}
set overflowCount(v) {
this._overflowCount = v;
}
set hot(v) {
this._hot = v;
this.setCls();
}
set setStyle(v) {
this.style = v;
}
set className(v) {
this._setClass = v;
const clsArr = this._setClass.split(' ');
clsArr.forEach(cls => {
this.render.addClass(this._ref.nativeElement, cls);
});
}
constructor(_ref, render) {
this._ref = _ref;
this.render = render;
this.prefixCls = 'am-badge';
this.scrollNumberCls = {};
this.style = {};
this._size = 'small';
this._dot = false;
this._hot = false;
this._corner = false;
this._children = false;
this._overflowCount = 99;
this.clsBadge = true;
this.clsBadgeWrp = !this._children;
this.clsBadgeCornerWrp = this._corner;
this.clsBadgeHot = !!this._hot;
this.clsBadgeCornerWrpLg = this._corner && this._size === 'large';
}
setCls() {
this.scrollNumberCls = {
[`${this.prefixCls}-dot`]: this._dot,
[`${this.prefixCls}-dot-large`]: this._dot && this._size === 'large',
[`${this.prefixCls}-text`]: !this._dot && !this._corner,
[`${this.prefixCls}-corner`]: this._corner,
[`${this.prefixCls}-corner-large`]: this._corner && this._size === 'large'
};
this.clsBadgeWrp = !this._children;
this.clsBadgeCornerWrp = this._corner;
this.clsBadgeHot = !!this._hot;
this.clsBadgeCornerWrpLg = this._corner && this._size === 'large';
}
ngOnChanges() {
if (typeof this._text === 'number' && this._text > this._overflowCount) {
this._text = this._overflowCount + '+';
}
}
ngOnInit() {
this.setCls();
}
ngAfterViewInit() {
setTimeout(() => {
if (this._ref.nativeElement.children.length > 1 ||
(this._ref.nativeElement.children.length === 1 && !this.dot && !this.text)) {
this._children = true;
this.setCls();
}
}, 10);
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: BadgeComponent, 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: BadgeComponent, selector: "Badge, nzm-badge", inputs: { size: "size", text: "text", corner: "corner", dot: "dot", overflowCount: "overflowCount", hot: "hot", setStyle: "setStyle", className: "className" }, host: { properties: { "class.am-badge": "this.clsBadge", "class.am-badge-not-a-wrapper": "this.clsBadgeWrp", "class.am-badge-corner-wrapper": "this.clsBadgeCornerWrp", "class.am-badge-hot": "this.clsBadgeHot", "class.am-badge-corner-wrapper-large": "this.clsBadgeCornerWrpLg" } }, usesOnChanges: true, ngImport: i0, template: "<ng-content></ng-content>\n<sup *ngIf=\"dot || text\" [ngClass]=\"scrollNumberCls\" [ngStyle]=\"style\">\n <span>{{ text }}</span>\n</sup>\n", dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: BadgeComponent, decorators: [{
type: Component,
args: [{ selector: 'Badge, nzm-badge', template: "<ng-content></ng-content>\n<sup *ngIf=\"dot || text\" [ngClass]=\"scrollNumberCls\" [ngStyle]=\"style\">\n <span>{{ text }}</span>\n</sup>\n" }]
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }], propDecorators: { size: [{
type: Input
}], text: [{
type: Input
}], corner: [{
type: Input
}], dot: [{
type: Input
}], overflowCount: [{
type: Input
}], hot: [{
type: Input
}], setStyle: [{
type: Input
}], className: [{
type: Input
}], clsBadge: [{
type: HostBinding,
args: ['class.am-badge']
}], clsBadgeWrp: [{
type: HostBinding,
args: ['class.am-badge-not-a-wrapper']
}], clsBadgeCornerWrp: [{
type: HostBinding,
args: ['class.am-badge-corner-wrapper']
}], clsBadgeHot: [{
type: HostBinding,
args: ['class.am-badge-hot']
}], clsBadgeCornerWrpLg: [{
type: HostBinding,
args: ['class.am-badge-corner-wrapper-large']
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"badge.component.js","sourceRoot":"","sources":["../../../components/badge/badge.component.ts","../../../components/badge/badge.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, HostBinding, OnChanges, ElementRef, AfterViewInit, Renderer2 } from '@angular/core';\n\n@Component({\n  selector: 'Badge, nzm-badge',\n  templateUrl: './badge.component.html'\n})\nexport class BadgeComponent implements OnChanges, OnInit, AfterViewInit {\n  prefixCls: string = 'am-badge';\n  scrollNumberCls: object = {};\n  style: object = {};\n\n  private _text: string;\n  private _setClass: string;\n  private _size: string = 'small';\n  private _dot: boolean = false;\n  private _hot: boolean = false;\n  private _corner: boolean = false;\n  private _children: boolean = false;\n  private _overflowCount: number = 99;\n\n  @Input()\n  set size(v: string) {\n    this._size = v;\n    this.setCls();\n  }\n  @Input()\n  get text(): string {\n    return this._text;\n  }\n  set text(v: string) {\n    this._text = v;\n    this.setCls();\n  }\n  @Input()\n  set corner(v: boolean) {\n    this._corner = v;\n    this.setCls();\n  }\n  @Input()\n  get dot(): boolean {\n    return this._dot;\n  }\n  set dot(v: boolean) {\n    this._dot = v;\n    if (this._dot) {\n      this._text = '';\n    }\n    this.setCls();\n  }\n  @Input()\n  set overflowCount(v: number) {\n    this._overflowCount = v;\n  }\n  @Input()\n  set hot(v: boolean) {\n    this._hot = v;\n    this.setCls();\n  }\n  @Input()\n  set setStyle(v: object) {\n    this.style = v;\n  }\n  @Input()\n  set className(v: string) {\n    this._setClass = v;\n    const clsArr = this._setClass.split(' ');\n    clsArr.forEach(cls => {\n      this.render.addClass(this._ref.nativeElement, cls);\n    });\n  }\n\n  @HostBinding('class.am-badge')\n  clsBadge: boolean = true;\n  @HostBinding('class.am-badge-not-a-wrapper')\n  clsBadgeWrp: boolean = !this._children;\n  @HostBinding('class.am-badge-corner-wrapper')\n  clsBadgeCornerWrp: boolean = this._corner;\n  @HostBinding('class.am-badge-hot')\n  clsBadgeHot: boolean = !!this._hot;\n  @HostBinding('class.am-badge-corner-wrapper-large')\n  clsBadgeCornerWrpLg: boolean = this._corner && this._size === 'large';\n\n  constructor(private _ref: ElementRef, private render: Renderer2) {}\n\n  setCls() {\n    this.scrollNumberCls = {\n      [`${this.prefixCls}-dot`]: this._dot,\n      [`${this.prefixCls}-dot-large`]: this._dot && this._size === 'large',\n      [`${this.prefixCls}-text`]: !this._dot && !this._corner,\n      [`${this.prefixCls}-corner`]: this._corner,\n      [`${this.prefixCls}-corner-large`]: this._corner && this._size === 'large'\n    };\n    this.clsBadgeWrp = !this._children;\n    this.clsBadgeCornerWrp = this._corner;\n    this.clsBadgeHot = !!this._hot;\n    this.clsBadgeCornerWrpLg = this._corner && this._size === 'large';\n  }\n\n  ngOnChanges() {\n    if (typeof this._text === 'number' && this._text > this._overflowCount) {\n      this._text = this._overflowCount + '+';\n    }\n  }\n\n  ngOnInit() {\n    this.setCls();\n  }\n\n  ngAfterViewInit() {\n    setTimeout(() => {\n      if (\n        this._ref.nativeElement.children.length > 1 ||\n        (this._ref.nativeElement.children.length === 1 && !this.dot && !this.text)\n      ) {\n        this._children = true;\n        this.setCls();\n      }\n    }, 10);\n  }\n}\n","<ng-content></ng-content>\n<sup *ngIf=\"dot || text\" [ngClass]=\"scrollNumberCls\" [ngStyle]=\"style\">\n  <span>{{ text }}</span>\n</sup>\n"]}