ngx-tethys 14.0.6 → 14.0.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +17 -0
- package/badge/badge.component.d.ts +25 -26
- package/badge/examples/custom-color/custom-color.component.scss +9 -0
- package/badge/styles/badge.scss +20 -6
- package/cascader/cascader.component.d.ts +2 -2
- package/core/color/color.d.ts +1 -1
- package/esm2020/badge/badge.component.mjs +112 -131
- package/esm2020/cascader/cascader.component.mjs +7 -6
- package/esm2020/core/color/color.mjs +2 -2
- package/esm2020/table/table.component.mjs +21 -5
- package/esm2020/table/table.interface.mjs +1 -1
- package/esm2020/timeline/timeline-item.component.mjs +1 -1
- package/esm2020/timeline/timeline.component.mjs +13 -3
- package/esm2020/version.mjs +2 -2
- package/fesm2015/ngx-tethys-badge.mjs +111 -130
- package/fesm2015/ngx-tethys-badge.mjs.map +1 -1
- package/fesm2015/ngx-tethys-cascader.mjs +6 -5
- package/fesm2015/ngx-tethys-cascader.mjs.map +1 -1
- package/fesm2015/ngx-tethys-core.mjs +1 -1
- package/fesm2015/ngx-tethys-core.mjs.map +1 -1
- package/fesm2015/ngx-tethys-table.mjs +20 -4
- package/fesm2015/ngx-tethys-table.mjs.map +1 -1
- package/fesm2015/ngx-tethys-timeline.mjs +12 -2
- package/fesm2015/ngx-tethys-timeline.mjs.map +1 -1
- package/fesm2015/ngx-tethys.mjs +1 -1
- package/fesm2015/ngx-tethys.mjs.map +1 -1
- package/fesm2020/ngx-tethys-badge.mjs +111 -130
- package/fesm2020/ngx-tethys-badge.mjs.map +1 -1
- package/fesm2020/ngx-tethys-cascader.mjs +6 -5
- package/fesm2020/ngx-tethys-cascader.mjs.map +1 -1
- package/fesm2020/ngx-tethys-core.mjs +1 -1
- package/fesm2020/ngx-tethys-core.mjs.map +1 -1
- package/fesm2020/ngx-tethys-table.mjs +20 -4
- package/fesm2020/ngx-tethys-table.mjs.map +1 -1
- package/fesm2020/ngx-tethys-timeline.mjs +12 -2
- package/fesm2020/ngx-tethys-timeline.mjs.map +1 -1
- package/fesm2020/ngx-tethys.mjs +1 -1
- package/fesm2020/ngx-tethys.mjs.map +1 -1
- package/package.json +1 -1
- package/schematics/version.d.ts +1 -1
- package/schematics/version.js +1 -1
- package/styles/mixins/link.scss +6 -2
- package/styles/modules/link.scss +2 -1
- package/styles/variables.scss +2 -0
- package/table/table.component.d.ts +5 -1
- package/table/table.interface.d.ts +1 -0
- package/timeline/timeline-item.component.d.ts +3 -2
- package/timeline/timeline.component.d.ts +1 -1
package/CHANGELOG.md
CHANGED
|
@@ -2,6 +2,23 @@
|
|
|
2
2
|
|
|
3
3
|
All notable changes to this project will be documented in this file. See [standard-version](https://github.com/conventional-changelog/standard-version) for commit guidelines.
|
|
4
4
|
|
|
5
|
+
## [14.0.7](https://github.com/atinc/ngx-tethys/compare/14.0.6...14.0.7) (2022-09-08)
|
|
6
|
+
|
|
7
|
+
|
|
8
|
+
### Bug Fixes
|
|
9
|
+
|
|
10
|
+
* **cascader:** should only show one column when first opened #INFR-4617 ([#2177](https://github.com/atinc/ngx-tethys/issues/2177)) ([09bfbc9](https://github.com/atinc/ngx-tethys/commit/09bfbc9fc23ce2507d802b8277a83b304041f6f9)), closes [#INFR-4617](https://github.com/atinc/ngx-tethys/issues/INFR-4617) [#INFR-4617](https://github.com/atinc/ngx-tethys/issues/INFR-4617)
|
|
11
|
+
|
|
12
|
+
|
|
13
|
+
### Features
|
|
14
|
+
|
|
15
|
+
* **badge:** add default type instead of secondary and support built-in color for thyTextColor and thyBackgroundColor #INFR-4576 ([#2173](https://github.com/atinc/ngx-tethys/issues/2173)) ([7cc2dcf](https://github.com/atinc/ngx-tethys/commit/7cc2dcff398808337d6b46624e4ae80086210868)), closes [#INFR-4576](https://github.com/atinc/ngx-tethys/issues/INFR-4576)
|
|
16
|
+
* **link:** set opacity to 50% for disabled #INFR-4621 ([#2178](https://github.com/atinc/ngx-tethys/issues/2178)) ([bf4fe5c](https://github.com/atinc/ngx-tethys/commit/bf4fe5ce77a934562aa00b86140574572cb62b9d)), closes [#INFR-4621](https://github.com/atinc/ngx-tethys/issues/INFR-4621)
|
|
17
|
+
* **table:** add page size controller to table pagination #INFR-3371 ([#2138](https://github.com/atinc/ngx-tethys/issues/2138)) ([736f495](https://github.com/atinc/ngx-tethys/commit/736f4956a7e8e7e2b0fb8e01f433acbe9582c0b6)), closes [#INFR-3371](https://github.com/atinc/ngx-tethys/issues/INFR-3371)
|
|
18
|
+
* **timeline:** improve timeline examples and overview #INFR-4538 ([d4267c0](https://github.com/atinc/ngx-tethys/commit/d4267c0a37a11a0e6a76860a3ebbdc610f6ab3e4)), closes [#INFR-4538](https://github.com/atinc/ngx-tethys/issues/INFR-4538)
|
|
19
|
+
|
|
20
|
+
|
|
21
|
+
|
|
5
22
|
## [14.0.6](https://github.com/atinc/ngx-tethys/compare/14.0.5...14.0.6) (2022-09-06)
|
|
6
23
|
|
|
7
24
|
|
|
@@ -1,34 +1,35 @@
|
|
|
1
1
|
import { ElementRef, OnInit } from '@angular/core';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
|
+
export declare type ThyBadgeSize = 'md' | 'sm' | 'lg';
|
|
3
4
|
/**
|
|
4
5
|
* 徽标组件,支持组件`thy-badge`和`thyBadge`指令两种使用方式
|
|
6
|
+
* @name thy-badge,[thyBadge]
|
|
5
7
|
*/
|
|
6
8
|
export declare class ThyBadgeComponent implements OnInit {
|
|
7
9
|
private elementRef;
|
|
8
10
|
displayContent: string;
|
|
9
11
|
badgeClassName: string;
|
|
10
12
|
private nativeElement;
|
|
11
|
-
private
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
backgroundColor: string;
|
|
13
|
+
private initialized;
|
|
14
|
+
protected isWrapper: boolean;
|
|
15
|
+
isShowBadge: boolean;
|
|
16
|
+
private keepShowValue;
|
|
17
|
+
private value;
|
|
18
|
+
private valueHasBeenSet;
|
|
19
|
+
private maxCount;
|
|
20
|
+
private type;
|
|
21
|
+
private size;
|
|
22
|
+
private isDot;
|
|
23
|
+
private isHollow;
|
|
24
|
+
protected textColor: string;
|
|
25
|
+
protected builtInTextColorClass: string;
|
|
26
|
+
protected backgroundColor: string;
|
|
27
|
+
protected builtInBackgroundColorClass: string;
|
|
28
|
+
protected supClasses: string[];
|
|
28
29
|
constructor(elementRef: ElementRef);
|
|
29
|
-
containerClassName: boolean;
|
|
30
30
|
/**
|
|
31
|
-
* 徽标类型, 类型为 'primary' | 'danger' | 'warning' | '
|
|
31
|
+
* 徽标类型, 类型为 'default' | 'primary' | 'danger' | 'warning' | 'success'
|
|
32
|
+
* @default danger
|
|
32
33
|
*/
|
|
33
34
|
set thyType(value: string);
|
|
34
35
|
/**
|
|
@@ -49,13 +50,12 @@ export declare class ThyBadgeComponent implements OnInit {
|
|
|
49
50
|
*/
|
|
50
51
|
set thyMaxCount(value: number);
|
|
51
52
|
/**
|
|
52
|
-
* 徽标显示的大小,分别为
|
|
53
|
+
* 徽标显示的大小,分别为 'sm' | 'md' | 'lg'
|
|
53
54
|
* @default md
|
|
54
55
|
*/
|
|
55
|
-
set thySize(value:
|
|
56
|
+
set thySize(value: ThyBadgeSize);
|
|
56
57
|
/**
|
|
57
58
|
* 已废弃,徽标是一个实心点,已经被废弃
|
|
58
|
-
* @default md
|
|
59
59
|
*/
|
|
60
60
|
set thyIsDot(value: boolean);
|
|
61
61
|
/**
|
|
@@ -67,17 +67,16 @@ export declare class ThyBadgeComponent implements OnInit {
|
|
|
67
67
|
*/
|
|
68
68
|
set thyKeepShow(value: boolean);
|
|
69
69
|
/**
|
|
70
|
-
*
|
|
70
|
+
* 设置徽标字体的颜色,支持内置颜色和自定义颜色 'primary' | '#87d068' | ...
|
|
71
71
|
*/
|
|
72
72
|
set thyTextColor(value: string);
|
|
73
73
|
/**
|
|
74
|
-
*
|
|
74
|
+
* 设置徽标的背景颜色,支持内置颜色和自定义颜色 'primary' | '#87d068' | ...
|
|
75
75
|
*/
|
|
76
76
|
set thyBackgroundColor(value: string);
|
|
77
77
|
ngOnInit(): void;
|
|
78
|
-
private
|
|
78
|
+
private combineBadgeClasses;
|
|
79
79
|
private combineBadgeDisplayContent;
|
|
80
|
-
private resetBadgeClassNameMap;
|
|
81
80
|
static ɵfac: i0.ɵɵFactoryDeclaration<ThyBadgeComponent, never>;
|
|
82
81
|
static ɵcmp: i0.ɵɵComponentDeclaration<ThyBadgeComponent, "thy-badge,[thyBadge]", never, { "thyType": "thyType"; "thyCount": "thyCount"; "thyContent": "thyContent"; "thyContext": "thyContext"; "thyMaxCount": "thyMaxCount"; "thySize": "thySize"; "thyIsDot": "thyIsDot"; "thyIsHollow": "thyIsHollow"; "thyKeepShow": "thyKeepShow"; "thyTextColor": "thyTextColor"; "thyBackgroundColor": "thyBackgroundColor"; }, {}, never, ["*"]>;
|
|
83
82
|
}
|
package/badge/styles/badge.scss
CHANGED
|
@@ -75,6 +75,18 @@
|
|
|
75
75
|
}
|
|
76
76
|
}
|
|
77
77
|
|
|
78
|
+
.thy-badge-default {
|
|
79
|
+
@include mixin.set-badge-color(variables.$gray-600, variables.$gray-200);
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
.thy-badge-success {
|
|
83
|
+
@include mixin.set-badge-color(variables.$white, variables.$success);
|
|
84
|
+
&.thy-badge-hollow {
|
|
85
|
+
background-color: transparent;
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
// 使用 thy-badge-default,暂时没有去除
|
|
78
90
|
.thy-badge-secondary {
|
|
79
91
|
@include mixin.set-badge-color(variables.$gray-600, variables.$gray-200);
|
|
80
92
|
&.thy-badge-dot {
|
|
@@ -88,12 +100,14 @@
|
|
|
88
100
|
|
|
89
101
|
// #endregion
|
|
90
102
|
// #region
|
|
91
|
-
.thy-badge-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
103
|
+
.thy-badge-wrapper {
|
|
104
|
+
.thy-badge {
|
|
105
|
+
position: absolute;
|
|
106
|
+
top: 0px;
|
|
107
|
+
right: 0;
|
|
108
|
+
transform: translateY(-50%) translateX(50%);
|
|
109
|
+
z-index: 1;
|
|
110
|
+
}
|
|
97
111
|
}
|
|
98
112
|
|
|
99
113
|
.thy-badge-lg {
|
|
@@ -1,10 +1,10 @@
|
|
|
1
|
+
import { SelectionModel } from '@angular/cdk/collections';
|
|
1
2
|
import { CdkConnectedOverlay, ConnectedOverlayPositionChange, ConnectionPositionPair, ViewportRuler } from '@angular/cdk/overlay';
|
|
2
3
|
import { ChangeDetectorRef, ElementRef, EventEmitter, OnDestroy, OnInit, QueryList, TemplateRef } from '@angular/core';
|
|
3
4
|
import { ControlValueAccessor } from '@angular/forms';
|
|
4
5
|
import { UpdateHostClassService } from 'ngx-tethys/core';
|
|
5
|
-
import { CascaderOption } from './types';
|
|
6
6
|
import { SelectControlSize, SelectOptionBase } from 'ngx-tethys/shared';
|
|
7
|
-
import {
|
|
7
|
+
import { CascaderOption } from './types';
|
|
8
8
|
import * as i0 from "@angular/core";
|
|
9
9
|
export declare type ThyCascaderTriggerType = 'click' | 'hover';
|
|
10
10
|
export declare type ThyCascaderExpandTrigger = 'click' | 'hover';
|
package/core/color/color.d.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
export declare const presetThemeColors: readonly ["primary", "success", "info", "warning", "danger", "default", "light"];
|
|
2
2
|
export declare type ThyThemeColor = typeof presetThemeColors[number];
|
|
3
3
|
export declare function isThemeColor(color: ThyThemeColor | string): boolean;
|
|
4
|
-
export declare const presetTextColors: readonly ["secondary", "muted", "desc", "placeholder"];
|
|
4
|
+
export declare const presetTextColors: readonly ["primary", "success", "info", "warning", "danger", "default", "light", "secondary", "muted", "desc", "placeholder", "white", "body"];
|
|
5
5
|
export declare type ThyTextColor = typeof presetTextColors[number];
|
|
6
6
|
export declare function isTextColor(color: ThyTextColor | string): boolean;
|
|
@@ -1,96 +1,58 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { UpdateHostClassService } from 'ngx-tethys/core';
|
|
1
|
+
import { __decorate, __metadata } from "tslib";
|
|
2
|
+
import { InputBoolean, isTextColor, UpdateHostClassService } from 'ngx-tethys/core';
|
|
3
3
|
import { coerceBooleanProperty } from 'ngx-tethys/util';
|
|
4
|
+
import { ChangeDetectionStrategy, Component, ElementRef, Input } from '@angular/core';
|
|
4
5
|
import * as i0 from "@angular/core";
|
|
5
6
|
import * as i1 from "@angular/common";
|
|
6
|
-
const badgeMutexTypes = ['thy-badge-count', 'thy-badge-dot', 'thy-badge-hollow'];
|
|
7
|
-
const BadgeMutexTheme = ['thy-badge-primary', 'thy-badge-warning', 'thy-badge-danger', 'thy-badge-secondary'];
|
|
8
|
-
const BadgeMutexSize = ['thy-badge-lg', 'thy-badge-sm'];
|
|
9
7
|
/**
|
|
10
8
|
* 徽标组件,支持组件`thy-badge`和`thyBadge`指令两种使用方式
|
|
9
|
+
* @name thy-badge,[thyBadge]
|
|
11
10
|
*/
|
|
12
11
|
export class ThyBadgeComponent {
|
|
13
12
|
constructor(elementRef) {
|
|
14
13
|
this.elementRef = elementRef;
|
|
15
14
|
this.displayContent = '';
|
|
16
15
|
this.badgeClassName = '';
|
|
17
|
-
this.
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
'thy-badge-primary': false,
|
|
26
|
-
'thy-badge-warning': false,
|
|
27
|
-
'thy-badge-secondary': false,
|
|
28
|
-
'thy-badge-sup': true
|
|
29
|
-
};
|
|
30
|
-
this.st = {
|
|
31
|
-
value: '',
|
|
32
|
-
isValueOfString: false,
|
|
33
|
-
isSetValue: false,
|
|
34
|
-
isValueKeepShow: false,
|
|
35
|
-
max: {
|
|
36
|
-
is: false,
|
|
37
|
-
value: null
|
|
38
|
-
},
|
|
39
|
-
isElement: false,
|
|
40
|
-
isSup: false,
|
|
41
|
-
isShowBadge: true
|
|
42
|
-
};
|
|
43
|
-
this.containerClassName = true;
|
|
16
|
+
this.initialized = false;
|
|
17
|
+
// 是否包裹在元素上
|
|
18
|
+
this.isWrapper = false;
|
|
19
|
+
this.isShowBadge = true;
|
|
20
|
+
this.keepShowValue = false;
|
|
21
|
+
this.value = '';
|
|
22
|
+
this.valueHasBeenSet = false;
|
|
23
|
+
this.supClasses = [];
|
|
44
24
|
this.nativeElement = this.elementRef.nativeElement;
|
|
45
|
-
this.st.isElement = this.nativeElement.localName === 'thy-badge';
|
|
46
25
|
}
|
|
47
26
|
/**
|
|
48
|
-
* 徽标类型, 类型为 'primary' | 'danger' | 'warning' | '
|
|
27
|
+
* 徽标类型, 类型为 'default' | 'primary' | 'danger' | 'warning' | 'success'
|
|
28
|
+
* @default danger
|
|
49
29
|
*/
|
|
50
30
|
set thyType(value) {
|
|
51
|
-
this.
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
this.badgeClassNameMap['thy-badge-danger'] = true;
|
|
55
|
-
break;
|
|
56
|
-
case 'primary':
|
|
57
|
-
this.badgeClassNameMap['thy-badge-primary'] = true;
|
|
58
|
-
break;
|
|
59
|
-
case 'warning':
|
|
60
|
-
this.badgeClassNameMap['thy-badge-warning'] = true;
|
|
61
|
-
break;
|
|
62
|
-
case 'secondary':
|
|
63
|
-
this.badgeClassNameMap['thy-badge-secondary'] = true;
|
|
64
|
-
break;
|
|
65
|
-
default:
|
|
66
|
-
this.badgeClassNameMap['thy-badge-danger'] = true;
|
|
67
|
-
break;
|
|
68
|
-
}
|
|
69
|
-
if (this._initialized) {
|
|
70
|
-
this.combineBadgeClassName();
|
|
31
|
+
this.type = value;
|
|
32
|
+
if (this.initialized) {
|
|
33
|
+
this.combineBadgeClasses();
|
|
71
34
|
}
|
|
72
35
|
}
|
|
73
36
|
/**
|
|
74
37
|
* 徽标内容数字
|
|
75
38
|
*/
|
|
76
39
|
set thyCount(value) {
|
|
77
|
-
this.
|
|
78
|
-
this.
|
|
79
|
-
if (this.
|
|
40
|
+
this.value = value;
|
|
41
|
+
this.valueHasBeenSet = true;
|
|
42
|
+
if (this.initialized) {
|
|
80
43
|
this.combineBadgeDisplayContent();
|
|
81
|
-
this.
|
|
44
|
+
this.combineBadgeClasses();
|
|
82
45
|
}
|
|
83
46
|
}
|
|
84
47
|
/**
|
|
85
48
|
* 徽标内容文本
|
|
86
49
|
*/
|
|
87
50
|
set thyContent(value) {
|
|
88
|
-
this.
|
|
89
|
-
this.
|
|
90
|
-
this.
|
|
91
|
-
if (this._initialized) {
|
|
51
|
+
this.value = value;
|
|
52
|
+
this.valueHasBeenSet = true;
|
|
53
|
+
if (this.initialized) {
|
|
92
54
|
this.combineBadgeDisplayContent();
|
|
93
|
-
this.
|
|
55
|
+
this.combineBadgeClasses();
|
|
94
56
|
}
|
|
95
57
|
}
|
|
96
58
|
/**
|
|
@@ -104,73 +66,80 @@ export class ThyBadgeComponent {
|
|
|
104
66
|
* 徽标显示的最大值, 与 thyCount 一起使用,thyCount 超过了 thyMaxCount 设置的值时,徽标内容为 thyMaxCount+
|
|
105
67
|
*/
|
|
106
68
|
set thyMaxCount(value) {
|
|
107
|
-
this.
|
|
108
|
-
this.
|
|
109
|
-
if (this._initialized) {
|
|
69
|
+
this.maxCount = value;
|
|
70
|
+
if (this.initialized) {
|
|
110
71
|
this.combineBadgeDisplayContent();
|
|
111
|
-
this.
|
|
72
|
+
this.combineBadgeClasses();
|
|
112
73
|
}
|
|
113
74
|
}
|
|
114
75
|
/**
|
|
115
|
-
* 徽标显示的大小,分别为
|
|
76
|
+
* 徽标显示的大小,分别为 'sm' | 'md' | 'lg'
|
|
116
77
|
* @default md
|
|
117
78
|
*/
|
|
118
79
|
set thySize(value) {
|
|
119
|
-
this.
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
this.badgeClassNameMap['thy-badge-lg'] = true;
|
|
123
|
-
break;
|
|
124
|
-
case 'sm':
|
|
125
|
-
this.badgeClassNameMap['thy-badge-sm'] = true;
|
|
126
|
-
break;
|
|
127
|
-
}
|
|
128
|
-
if (this._initialized) {
|
|
129
|
-
this.combineBadgeClassName();
|
|
80
|
+
this.size = value;
|
|
81
|
+
if (this.initialized) {
|
|
82
|
+
this.combineBadgeClasses();
|
|
130
83
|
}
|
|
131
84
|
}
|
|
132
85
|
/**
|
|
133
86
|
* 已废弃,徽标是一个实心点,已经被废弃
|
|
134
|
-
* @default md
|
|
135
87
|
*/
|
|
136
88
|
set thyIsDot(value) {
|
|
137
|
-
this.
|
|
138
|
-
this.
|
|
139
|
-
|
|
140
|
-
this.combineBadgeClassName();
|
|
89
|
+
this.isDot = value;
|
|
90
|
+
if (this.initialized) {
|
|
91
|
+
this.combineBadgeClasses();
|
|
141
92
|
}
|
|
142
93
|
}
|
|
143
94
|
/**
|
|
144
95
|
* 已废弃,徽标是一个空心点,
|
|
145
96
|
*/
|
|
146
97
|
set thyIsHollow(value) {
|
|
147
|
-
this.
|
|
148
|
-
this.
|
|
149
|
-
|
|
150
|
-
this.combineBadgeClassName();
|
|
98
|
+
this.isHollow = value;
|
|
99
|
+
if (this.initialized) {
|
|
100
|
+
this.combineBadgeClasses();
|
|
151
101
|
}
|
|
152
102
|
}
|
|
153
103
|
/**
|
|
154
104
|
* thyCount 为 0 时,强制显示数字 0,默认不显示
|
|
155
105
|
*/
|
|
156
106
|
set thyKeepShow(value) {
|
|
157
|
-
this.
|
|
158
|
-
if (this.
|
|
107
|
+
this.keepShowValue = coerceBooleanProperty(value);
|
|
108
|
+
if (this.initialized) {
|
|
159
109
|
this.combineBadgeDisplayContent();
|
|
160
110
|
}
|
|
161
111
|
}
|
|
162
112
|
/**
|
|
163
|
-
*
|
|
113
|
+
* 设置徽标字体的颜色,支持内置颜色和自定义颜色 'primary' | '#87d068' | ...
|
|
164
114
|
*/
|
|
165
115
|
set thyTextColor(value) {
|
|
166
|
-
|
|
116
|
+
if (isTextColor(value)) {
|
|
117
|
+
this.builtInTextColorClass = `text-${value}`;
|
|
118
|
+
this.textColor = null;
|
|
119
|
+
}
|
|
120
|
+
else {
|
|
121
|
+
this.textColor = value;
|
|
122
|
+
this.builtInTextColorClass = null;
|
|
123
|
+
}
|
|
124
|
+
if (this.initialized) {
|
|
125
|
+
this.combineBadgeClasses();
|
|
126
|
+
}
|
|
167
127
|
}
|
|
168
128
|
/**
|
|
169
|
-
*
|
|
129
|
+
* 设置徽标的背景颜色,支持内置颜色和自定义颜色 'primary' | '#87d068' | ...
|
|
170
130
|
*/
|
|
171
131
|
set thyBackgroundColor(value) {
|
|
172
|
-
|
|
173
|
-
|
|
132
|
+
if (isTextColor(value)) {
|
|
133
|
+
this.builtInBackgroundColorClass = `bg-${value}`;
|
|
134
|
+
this.backgroundColor = null;
|
|
135
|
+
}
|
|
136
|
+
else {
|
|
137
|
+
this.backgroundColor = value;
|
|
138
|
+
this.builtInBackgroundColorClass = null;
|
|
139
|
+
}
|
|
140
|
+
if (this.initialized) {
|
|
141
|
+
this.combineBadgeClasses();
|
|
142
|
+
}
|
|
174
143
|
}
|
|
175
144
|
ngOnInit() {
|
|
176
145
|
let childNodeCount = 0;
|
|
@@ -179,56 +148,68 @@ export class ThyBadgeComponent {
|
|
|
179
148
|
childNodeCount++;
|
|
180
149
|
}
|
|
181
150
|
});
|
|
182
|
-
this.
|
|
183
|
-
this.
|
|
184
|
-
if (this.
|
|
151
|
+
this.isWrapper = childNodeCount > 0;
|
|
152
|
+
this.combineBadgeClasses();
|
|
153
|
+
if (this.valueHasBeenSet) {
|
|
185
154
|
this.combineBadgeDisplayContent();
|
|
186
155
|
}
|
|
187
|
-
this.
|
|
156
|
+
this.initialized = true;
|
|
188
157
|
}
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
if (this.badgeClassNameMap[key]) {
|
|
195
|
-
_badgeClassNames.push(key);
|
|
196
|
-
}
|
|
197
|
-
}
|
|
158
|
+
combineBadgeClasses() {
|
|
159
|
+
const classes = [];
|
|
160
|
+
classes.push(`thy-badge-${this.type || 'danger'}`);
|
|
161
|
+
if (this.size) {
|
|
162
|
+
classes.push(`thy-badge-${this.size}`);
|
|
198
163
|
}
|
|
199
|
-
this.
|
|
200
|
-
|
|
201
|
-
combineBadgeDisplayContent() {
|
|
202
|
-
this.displayContent = this.st.value;
|
|
203
|
-
if (this.st.value && this.st.max.is && this.st.value > this.st.max.value) {
|
|
204
|
-
this.displayContent = `${this.st.max.value}+`;
|
|
164
|
+
if (this.isDot) {
|
|
165
|
+
classes.push(`thy-badge-dot`);
|
|
205
166
|
}
|
|
206
|
-
if (
|
|
207
|
-
|
|
167
|
+
else if (this.isHollow) {
|
|
168
|
+
classes.push(`thy-badge-hollow`);
|
|
208
169
|
}
|
|
209
170
|
else {
|
|
210
|
-
|
|
171
|
+
classes.push(`thy-badge-count`);
|
|
172
|
+
}
|
|
173
|
+
if (this.builtInTextColorClass) {
|
|
174
|
+
classes.push(this.builtInTextColorClass);
|
|
211
175
|
}
|
|
176
|
+
if (this.builtInBackgroundColorClass) {
|
|
177
|
+
classes.push(this.builtInBackgroundColorClass);
|
|
178
|
+
}
|
|
179
|
+
this.badgeClassName = classes.join(' ');
|
|
212
180
|
}
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
181
|
+
combineBadgeDisplayContent() {
|
|
182
|
+
this.displayContent = this.value;
|
|
183
|
+
if (this.value && this.maxCount != undefined && this.value > this.maxCount) {
|
|
184
|
+
this.displayContent = `${this.maxCount}+`;
|
|
185
|
+
}
|
|
186
|
+
if (!this.value && !this.keepShowValue) {
|
|
187
|
+
this.isShowBadge = false;
|
|
188
|
+
}
|
|
189
|
+
else {
|
|
190
|
+
this.isShowBadge = true;
|
|
220
191
|
}
|
|
221
192
|
}
|
|
222
193
|
}
|
|
223
194
|
ThyBadgeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.6", ngImport: i0, type: ThyBadgeComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
224
|
-
ThyBadgeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.6", type: ThyBadgeComponent, selector: "thy-badge,[thyBadge]", inputs: { thyType: "thyType", thyCount: "thyCount", thyContent: "thyContent", thyContext: "thyContext", thyMaxCount: "thyMaxCount", thySize: "thySize", thyIsDot: "thyIsDot", thyIsHollow: "thyIsHollow", thyKeepShow: "thyKeepShow", thyTextColor: "thyTextColor", thyBackgroundColor: "thyBackgroundColor" }, host: { properties: { "class.thy-badge-
|
|
195
|
+
ThyBadgeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.6", type: ThyBadgeComponent, selector: "thy-badge,[thyBadge]", inputs: { thyType: "thyType", thyCount: "thyCount", thyContent: "thyContent", thyContext: "thyContext", thyMaxCount: "thyMaxCount", thySize: "thySize", thyIsDot: "thyIsDot", thyIsHollow: "thyIsHollow", thyKeepShow: "thyKeepShow", thyTextColor: "thyTextColor", thyBackgroundColor: "thyBackgroundColor" }, host: { properties: { "class.thy-badge-wrapper": "isWrapper" }, classAttribute: "thy-badge-container" }, providers: [UpdateHostClassService], ngImport: i0, template: "<div *ngIf=\"isShowBadge\" class=\"thy-badge {{ badgeClassName }}\" [style.color]=\"textColor\" [style.backgroundColor]=\"backgroundColor\">\n <span>{{ displayContent }}</span>\n</div>\n<ng-content></ng-content>\n", directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
196
|
+
__decorate([
|
|
197
|
+
InputBoolean(),
|
|
198
|
+
__metadata("design:type", Boolean),
|
|
199
|
+
__metadata("design:paramtypes", [Boolean])
|
|
200
|
+
], ThyBadgeComponent.prototype, "thyIsDot", null);
|
|
201
|
+
__decorate([
|
|
202
|
+
InputBoolean(),
|
|
203
|
+
__metadata("design:type", Boolean),
|
|
204
|
+
__metadata("design:paramtypes", [Boolean])
|
|
205
|
+
], ThyBadgeComponent.prototype, "thyIsHollow", null);
|
|
225
206
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.6", ngImport: i0, type: ThyBadgeComponent, decorators: [{
|
|
226
207
|
type: Component,
|
|
227
|
-
args: [{ selector: 'thy-badge,[thyBadge]', changeDetection: ChangeDetectionStrategy.OnPush, providers: [UpdateHostClassService],
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
208
|
+
args: [{ selector: 'thy-badge,[thyBadge]', changeDetection: ChangeDetectionStrategy.OnPush, providers: [UpdateHostClassService], host: {
|
|
209
|
+
class: 'thy-badge-container',
|
|
210
|
+
'[class.thy-badge-wrapper]': 'isWrapper'
|
|
211
|
+
}, template: "<div *ngIf=\"isShowBadge\" class=\"thy-badge {{ badgeClassName }}\" [style.color]=\"textColor\" [style.backgroundColor]=\"backgroundColor\">\n <span>{{ displayContent }}</span>\n</div>\n<ng-content></ng-content>\n" }]
|
|
212
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { thyType: [{
|
|
232
213
|
type: Input
|
|
233
214
|
}], thyCount: [{
|
|
234
215
|
type: Input
|
|
@@ -251,4 +232,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.6", ngImpor
|
|
|
251
232
|
}], thyBackgroundColor: [{
|
|
252
233
|
type: Input
|
|
253
234
|
}] } });
|
|
254
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"badge.component.js","sourceRoot":"","sources":["../../../../src/badge/badge.component.ts","../../../../src/badge/badge.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, HostBinding, Input, OnInit, ChangeDetectionStrategy } from '@angular/core';\n\nimport { InputBoolean, UpdateHostClassService } from 'ngx-tethys/core';\nimport { coerceBooleanProperty } from 'ngx-tethys/util';\n\nconst badgeMutexTypes = ['thy-badge-count', 'thy-badge-dot', 'thy-badge-hollow'];\nconst BadgeMutexTheme = ['thy-badge-primary', 'thy-badge-warning', 'thy-badge-danger', 'thy-badge-secondary'];\nconst BadgeMutexSize = ['thy-badge-lg', 'thy-badge-sm'];\n\n/**\n * 徽标组件，支持组件`thy-badge`和`thyBadge`指令两种使用方式\n */\n@Component({\n    selector: 'thy-badge,[thyBadge]',\n    templateUrl: './badge.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [UpdateHostClassService]\n})\nexport class ThyBadgeComponent implements OnInit {\n    displayContent = '';\n\n    badgeClassName = '';\n\n    private nativeElement: any;\n\n    private _initialized = false;\n\n    private badgeClassNameMap = {\n        'thy-badge-count': true,\n        'thy-badge-dot': false,\n        'thy-badge-hollow': false,\n        'thy-badge-lg': false,\n        'thy-badge-sm': false,\n        'thy-badge-danger': true,\n        'thy-badge-primary': false,\n        'thy-badge-warning': false,\n        'thy-badge-secondary': false,\n        'thy-badge-sup': true\n    };\n\n    st: {\n        value: number | string;\n        isValueOfString: boolean;\n        isSetValue: boolean;\n        isValueKeepShow: boolean;\n        max: {\n            is: boolean;\n            value: number;\n        };\n        isElement: boolean;\n        isSup: boolean;\n        isShowBadge: boolean;\n    } = {\n        value: '',\n        isValueOfString: false,\n        isSetValue: false,\n        isValueKeepShow: false,\n        max: {\n            is: false,\n            value: null\n        },\n        isElement: false,\n        isSup: false,\n        isShowBadge: true\n    };\n\n    public textColor: string;\n\n    public backgroundColor: string;\n\n    constructor(private elementRef: ElementRef) {\n        this.nativeElement = this.elementRef.nativeElement;\n        this.st.isElement = this.nativeElement.localName === 'thy-badge';\n    }\n\n    @HostBinding('class.thy-badge-container') containerClassName = true;\n\n    /**\n     * 徽标类型, 类型为 'primary' | 'danger' | 'warning' | 'secondary'\n     */\n    @Input()\n    set thyType(value: string) {\n        this.resetBadgeClassNameMap(BadgeMutexTheme);\n        switch (value) {\n            case 'danger':\n                this.badgeClassNameMap['thy-badge-danger'] = true;\n                break;\n            case 'primary':\n                this.badgeClassNameMap['thy-badge-primary'] = true;\n                break;\n            case 'warning':\n                this.badgeClassNameMap['thy-badge-warning'] = true;\n                break;\n            case 'secondary':\n                this.badgeClassNameMap['thy-badge-secondary'] = true;\n                break;\n            default:\n                this.badgeClassNameMap['thy-badge-danger'] = true;\n                break;\n        }\n        if (this._initialized) {\n            this.combineBadgeClassName();\n        }\n    }\n\n    /**\n     * 徽标内容数字\n     */\n    @Input()\n    set thyCount(value: number) {\n        this.st.value = value;\n        this.st.isSetValue = true;\n        if (this._initialized) {\n            this.combineBadgeDisplayContent();\n            this.combineBadgeClassName();\n        }\n    }\n\n    /**\n     * 徽标内容文本\n     */\n    @Input()\n    set thyContent(value: string) {\n        this.st.value = value;\n        this.st.isValueOfString = true;\n        this.st.isSetValue = true;\n        if (this._initialized) {\n            this.combineBadgeDisplayContent();\n            this.combineBadgeClassName();\n        }\n    }\n\n    /**\n     * 已废弃，徽标内容文本，命名错误，请使用 thyContent\n     * @deprecated\n     */\n    @Input()\n    set thyContext(value: string) {\n        this.thyContent = value;\n    }\n\n    /**\n     * 徽标显示的最大值, 与 thyCount 一起使用,thyCount 超过了 thyMaxCount 设置的值时，徽标内容为 thyMaxCount+\n     */\n    @Input()\n    set thyMaxCount(value: number) {\n        this.st.max.is = true;\n        this.st.max.value = value;\n        if (this._initialized) {\n            this.combineBadgeDisplayContent();\n            this.combineBadgeClassName();\n        }\n    }\n\n    /**\n     * 徽标显示的大小，分别为 `sm` | `md` | `lg`\n     * @default md\n     */\n    @Input()\n    set thySize(value: string) {\n        this.resetBadgeClassNameMap(BadgeMutexSize);\n        switch (value) {\n            case 'lg':\n                this.badgeClassNameMap['thy-badge-lg'] = true;\n                break;\n            case 'sm':\n                this.badgeClassNameMap['thy-badge-sm'] = true;\n                break;\n        }\n        if (this._initialized) {\n            this.combineBadgeClassName();\n        }\n    }\n\n    /**\n     * 已废弃，徽标是一个实心点，已经被废弃\n     * @default md\n     */\n    @Input()\n    set thyIsDot(value: boolean) {\n        this.resetBadgeClassNameMap(badgeMutexTypes);\n        this.badgeClassNameMap['thy-badge-dot'] = coerceBooleanProperty(value);\n        if (this._initialized) {\n            this.combineBadgeClassName();\n        }\n    }\n\n    /**\n     * 已废弃，徽标是一个空心点，\n     */\n    @Input()\n    set thyIsHollow(value: boolean) {\n        this.resetBadgeClassNameMap(badgeMutexTypes);\n        this.badgeClassNameMap['thy-badge-hollow'] = coerceBooleanProperty(value);\n        if (this._initialized) {\n            this.combineBadgeClassName();\n        }\n    }\n\n    /**\n     * thyCount 为 0 时，强制显示数字 0，默认不显示\n     */\n    @Input()\n    set thyKeepShow(value: boolean) {\n        this.st.isValueKeepShow = coerceBooleanProperty(value);\n        if (this._initialized) {\n            this.combineBadgeDisplayContent();\n        }\n    }\n\n    /**\n     * 设置徽标字体的颜色\n     */\n    @Input()\n    set thyTextColor(value: string) {\n        this.textColor = value;\n    }\n\n    /**\n     * 设置徽标的背景颜色\n     */\n    @Input()\n    set thyBackgroundColor(value: string) {\n        this.backgroundColor = value;\n        this.resetBadgeClassNameMap(BadgeMutexTheme);\n    }\n\n    ngOnInit() {\n        let childNodeCount = 0;\n        this.nativeElement.childNodes.forEach((n: HTMLElement) => {\n            if (['#comment'].indexOf(n.nodeName) < 0) {\n                childNodeCount++;\n            }\n        });\n        this.st.isSup = childNodeCount > 0;\n\n        this.combineBadgeClassName();\n\n        if (this.st.isSetValue) {\n            this.combineBadgeDisplayContent();\n        }\n\n        this._initialized = true;\n    }\n\n    private combineBadgeClassName() {\n        this.badgeClassNameMap['thy-badge-sup'] = this.st.isSup;\n\n        const _badgeClassNames = [];\n        for (const key in this.badgeClassNameMap) {\n            if (this.badgeClassNameMap.hasOwnProperty(key)) {\n                if (this.badgeClassNameMap[key]) {\n                    _badgeClassNames.push(key);\n                }\n            }\n        }\n        this.badgeClassName = _badgeClassNames.join(' ');\n    }\n\n    private combineBadgeDisplayContent() {\n        this.displayContent = this.st.value as string;\n        if (this.st.value && this.st.max.is && this.st.value > this.st.max.value) {\n            this.displayContent = `${this.st.max.value}+`;\n        }\n\n        if (!this.st.value && !this.st.isValueKeepShow) {\n            this.st.isShowBadge = false;\n        } else {\n            this.st.isShowBadge = true;\n        }\n    }\n\n    private resetBadgeClassNameMap(mutexArray: any) {\n        for (const key in this.badgeClassNameMap) {\n            if (this.badgeClassNameMap.hasOwnProperty(key)) {\n                if (mutexArray.includes(key)) {\n                    this.badgeClassNameMap[key] = false;\n                }\n            }\n        }\n    }\n}\n","<ng-container>\n  <div *ngIf=\"st.isShowBadge\" class=\"thy-badge {{ badgeClassName }}\" [style.color]=\"textColor\" [style.backgroundColor]=\"backgroundColor\">\n    <span>{{ displayContent }}</span>\n  </div>\n</ng-container>\n<ng-content></ng-content>\n"]}
|
|
235
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"badge.component.js","sourceRoot":"","sources":["../../../../src/badge/badge.component.ts","../../../../src/badge/badge.component.html"],"names":[],"mappings":"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","sourcesContent":["import { InputBoolean, isTextColor, UpdateHostClassService } from 'ngx-tethys/core';\nimport { coerceBooleanProperty } from 'ngx-tethys/util';\n\nimport { ChangeDetectionStrategy, Component, ElementRef, Input, OnInit } from '@angular/core';\n\nexport type ThyBadgeSize = 'md' | 'sm' | 'lg';\n\n/**\n * 徽标组件，支持组件`thy-badge`和`thyBadge`指令两种使用方式\n * @name thy-badge,[thyBadge]\n */\n@Component({\n    selector: 'thy-badge,[thyBadge]',\n    templateUrl: './badge.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [UpdateHostClassService],\n    host: {\n        class: 'thy-badge-container',\n        '[class.thy-badge-wrapper]': 'isWrapper'\n    }\n})\nexport class ThyBadgeComponent implements OnInit {\n    displayContent = '';\n\n    badgeClassName = '';\n\n    private nativeElement: any;\n\n    private initialized = false;\n\n    // 是否包裹在元素上\n    protected isWrapper = false;\n\n    public isShowBadge = true;\n\n    private keepShowValue = false;\n\n    private value: number | string = '';\n\n    private valueHasBeenSet = false;\n\n    private maxCount: number;\n\n    private type: string;\n\n    private size: ThyBadgeSize;\n\n    private isDot: boolean;\n\n    private isHollow: boolean;\n\n    protected textColor: string;\n\n    protected builtInTextColorClass: string;\n\n    protected backgroundColor: string;\n\n    protected builtInBackgroundColorClass: string;\n\n    protected supClasses: string[] = [];\n\n    constructor(private elementRef: ElementRef) {\n        this.nativeElement = this.elementRef.nativeElement;\n    }\n\n    /**\n     * 徽标类型, 类型为 'default' | 'primary' | 'danger' | 'warning' | 'success'\n     * @default danger\n     */\n    @Input()\n    set thyType(value: string) {\n        this.type = value;\n        if (this.initialized) {\n            this.combineBadgeClasses();\n        }\n    }\n\n    /**\n     * 徽标内容数字\n     */\n    @Input()\n    set thyCount(value: number) {\n        this.value = value;\n        this.valueHasBeenSet = true;\n        if (this.initialized) {\n            this.combineBadgeDisplayContent();\n            this.combineBadgeClasses();\n        }\n    }\n\n    /**\n     * 徽标内容文本\n     */\n    @Input()\n    set thyContent(value: string) {\n        this.value = value;\n        this.valueHasBeenSet = true;\n        if (this.initialized) {\n            this.combineBadgeDisplayContent();\n            this.combineBadgeClasses();\n        }\n    }\n\n    /**\n     * 已废弃，徽标内容文本，命名错误，请使用 thyContent\n     * @deprecated\n     */\n    @Input()\n    set thyContext(value: string) {\n        this.thyContent = value;\n    }\n\n    /**\n     * 徽标显示的最大值, 与 thyCount 一起使用,thyCount 超过了 thyMaxCount 设置的值时，徽标内容为 thyMaxCount+\n     */\n    @Input()\n    set thyMaxCount(value: number) {\n        this.maxCount = value;\n        if (this.initialized) {\n            this.combineBadgeDisplayContent();\n            this.combineBadgeClasses();\n        }\n    }\n\n    /**\n     * 徽标显示的大小，分别为 'sm' | 'md' | 'lg'\n     * @default md\n     */\n    @Input()\n    set thySize(value: ThyBadgeSize) {\n        this.size = value;\n\n        if (this.initialized) {\n            this.combineBadgeClasses();\n        }\n    }\n\n    /**\n     * 已废弃，徽标是一个实心点，已经被废弃\n     */\n    @Input()\n    @InputBoolean()\n    set thyIsDot(value: boolean) {\n        this.isDot = value;\n        if (this.initialized) {\n            this.combineBadgeClasses();\n        }\n    }\n\n    /**\n     * 已废弃，徽标是一个空心点，\n     */\n    @Input()\n    @InputBoolean()\n    set thyIsHollow(value: boolean) {\n        this.isHollow = value;\n        if (this.initialized) {\n            this.combineBadgeClasses();\n        }\n    }\n\n    /**\n     * thyCount 为 0 时，强制显示数字 0，默认不显示\n     */\n    @Input()\n    set thyKeepShow(value: boolean) {\n        this.keepShowValue = coerceBooleanProperty(value);\n        if (this.initialized) {\n            this.combineBadgeDisplayContent();\n        }\n    }\n\n    /**\n     * 设置徽标字体的颜色，支持内置颜色和自定义颜色 'primary' | '#87d068' | ...\n     */\n    @Input()\n    set thyTextColor(value: string) {\n        if (isTextColor(value)) {\n            this.builtInTextColorClass = `text-${value}`;\n            this.textColor = null;\n        } else {\n            this.textColor = value;\n            this.builtInTextColorClass = null;\n        }\n        if (this.initialized) {\n            this.combineBadgeClasses();\n        }\n    }\n\n    /**\n     * 设置徽标的背景颜色，支持内置颜色和自定义颜色 'primary' | '#87d068' | ...\n     */\n    @Input()\n    set thyBackgroundColor(value: string) {\n        if (isTextColor(value)) {\n            this.builtInBackgroundColorClass = `bg-${value}`;\n            this.backgroundColor = null;\n        } else {\n            this.backgroundColor = value;\n            this.builtInBackgroundColorClass = null;\n        }\n        if (this.initialized) {\n            this.combineBadgeClasses();\n        }\n    }\n\n    ngOnInit() {\n        let childNodeCount = 0;\n        this.nativeElement.childNodes.forEach((n: HTMLElement) => {\n            if (['#comment'].indexOf(n.nodeName) < 0) {\n                childNodeCount++;\n            }\n        });\n        this.isWrapper = childNodeCount > 0;\n\n        this.combineBadgeClasses();\n\n        if (this.valueHasBeenSet) {\n            this.combineBadgeDisplayContent();\n        }\n\n        this.initialized = true;\n    }\n\n    private combineBadgeClasses() {\n        const classes: string[] = [];\n        classes.push(`thy-badge-${this.type || 'danger'}`);\n        if (this.size) {\n            classes.push(`thy-badge-${this.size}`);\n        }\n        if (this.isDot) {\n            classes.push(`thy-badge-dot`);\n        } else if (this.isHollow) {\n            classes.push(`thy-badge-hollow`);\n        } else {\n            classes.push(`thy-badge-count`);\n        }\n\n        if (this.builtInTextColorClass) {\n            classes.push(this.builtInTextColorClass);\n        }\n        if (this.builtInBackgroundColorClass) {\n            classes.push(this.builtInBackgroundColorClass);\n        }\n        this.badgeClassName = classes.join(' ');\n    }\n\n    private combineBadgeDisplayContent() {\n        this.displayContent = this.value as string;\n        if (this.value && this.maxCount != undefined && this.value > this.maxCount) {\n            this.displayContent = `${this.maxCount}+`;\n        }\n\n        if (!this.value && !this.keepShowValue) {\n            this.isShowBadge = false;\n        } else {\n            this.isShowBadge = true;\n        }\n    }\n}\n","<div *ngIf=\"isShowBadge\" class=\"thy-badge {{ badgeClassName }}\" [style.color]=\"textColor\" [style.backgroundColor]=\"backgroundColor\">\n  <span>{{ displayContent }}</span>\n</div>\n<ng-content></ng-content>\n"]}
|