ng-zorro-antd-mobile
Version:
An enterprise-class mobile UI components based on Ant Design and Angular
254 lines • 15.7 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, Input, HostBinding, ElementRef, Renderer2 } from '@angular/core';
export class BadgeComponent {
/**
* @param {?} _ref
* @param {?} render
*/
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';
}
/**
* @param {?} v
* @return {?}
*/
set size(v) {
this._size = v;
this.setCls();
}
/**
* @return {?}
*/
get text() {
return this._text;
}
/**
* @param {?} v
* @return {?}
*/
set text(v) {
this._text = v;
this.setCls();
}
/**
* @param {?} v
* @return {?}
*/
set corner(v) {
this._corner = v;
this.setCls();
}
/**
* @return {?}
*/
get dot() {
return this._dot;
}
/**
* @param {?} v
* @return {?}
*/
set dot(v) {
this._dot = v;
if (this._dot) {
this._text = '';
}
this.setCls();
}
/**
* @param {?} v
* @return {?}
*/
set overflowCount(v) {
this._overflowCount = v;
}
/**
* @param {?} v
* @return {?}
*/
set hot(v) {
this._hot = v;
this.setCls();
}
/**
* @param {?} v
* @return {?}
*/
set setStyle(v) {
this.style = v;
}
/**
* @param {?} v
* @return {?}
*/
set className(v) {
this._setClass = v;
/** @type {?} */
const clsArr = this._setClass.split(' ');
clsArr.forEach((/**
* @param {?} cls
* @return {?}
*/
cls => {
this.render.addClass(this._ref.nativeElement, cls);
}));
}
/**
* @return {?}
*/
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';
}
/**
* @return {?}
*/
ngOnChanges() {
if (typeof this._text === 'number' && this._text > this._overflowCount) {
this._text = this._overflowCount + '+';
}
}
/**
* @return {?}
*/
ngOnInit() {
this.setCls();
}
/**
* @return {?}
*/
ngAfterViewInit() {
setTimeout((/**
* @return {?}
*/
() => {
if (this._ref.nativeElement.children.length > 1 ||
(this._ref.nativeElement.children.length === 1 && !this.dot && !this.text)) {
this._children = true;
this.setCls();
}
}), 10);
}
}
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"
}] }
];
/** @nocollapse */
BadgeComponent.ctorParameters = () => [
{ type: ElementRef },
{ type: Renderer2 }
];
BadgeComponent.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',] }]
};
if (false) {
/** @type {?} */
BadgeComponent.prototype.prefixCls;
/** @type {?} */
BadgeComponent.prototype.scrollNumberCls;
/** @type {?} */
BadgeComponent.prototype.style;
/**
* @type {?}
* @private
*/
BadgeComponent.prototype._text;
/**
* @type {?}
* @private
*/
BadgeComponent.prototype._setClass;
/**
* @type {?}
* @private
*/
BadgeComponent.prototype._size;
/**
* @type {?}
* @private
*/
BadgeComponent.prototype._dot;
/**
* @type {?}
* @private
*/
BadgeComponent.prototype._hot;
/**
* @type {?}
* @private
*/
BadgeComponent.prototype._corner;
/**
* @type {?}
* @private
*/
BadgeComponent.prototype._children;
/**
* @type {?}
* @private
*/
BadgeComponent.prototype._overflowCount;
/** @type {?} */
BadgeComponent.prototype.clsBadge;
/** @type {?} */
BadgeComponent.prototype.clsBadgeWrp;
/** @type {?} */
BadgeComponent.prototype.clsBadgeCornerWrp;
/** @type {?} */
BadgeComponent.prototype.clsBadgeHot;
/** @type {?} */
BadgeComponent.prototype.clsBadgeCornerWrpLg;
/**
* @type {?}
* @private
*/
BadgeComponent.prototype._ref;
/**
* @type {?}
* @private
*/
BadgeComponent.prototype.render;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"badge.component.js","sourceRoot":"ng://ng-zorro-antd-mobile/","sources":["badge/badge.component.ts"],"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"]}