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.
Files changed (48) hide show
  1. package/CHANGELOG.md +17 -0
  2. package/badge/badge.component.d.ts +25 -26
  3. package/badge/examples/custom-color/custom-color.component.scss +9 -0
  4. package/badge/styles/badge.scss +20 -6
  5. package/cascader/cascader.component.d.ts +2 -2
  6. package/core/color/color.d.ts +1 -1
  7. package/esm2020/badge/badge.component.mjs +112 -131
  8. package/esm2020/cascader/cascader.component.mjs +7 -6
  9. package/esm2020/core/color/color.mjs +2 -2
  10. package/esm2020/table/table.component.mjs +21 -5
  11. package/esm2020/table/table.interface.mjs +1 -1
  12. package/esm2020/timeline/timeline-item.component.mjs +1 -1
  13. package/esm2020/timeline/timeline.component.mjs +13 -3
  14. package/esm2020/version.mjs +2 -2
  15. package/fesm2015/ngx-tethys-badge.mjs +111 -130
  16. package/fesm2015/ngx-tethys-badge.mjs.map +1 -1
  17. package/fesm2015/ngx-tethys-cascader.mjs +6 -5
  18. package/fesm2015/ngx-tethys-cascader.mjs.map +1 -1
  19. package/fesm2015/ngx-tethys-core.mjs +1 -1
  20. package/fesm2015/ngx-tethys-core.mjs.map +1 -1
  21. package/fesm2015/ngx-tethys-table.mjs +20 -4
  22. package/fesm2015/ngx-tethys-table.mjs.map +1 -1
  23. package/fesm2015/ngx-tethys-timeline.mjs +12 -2
  24. package/fesm2015/ngx-tethys-timeline.mjs.map +1 -1
  25. package/fesm2015/ngx-tethys.mjs +1 -1
  26. package/fesm2015/ngx-tethys.mjs.map +1 -1
  27. package/fesm2020/ngx-tethys-badge.mjs +111 -130
  28. package/fesm2020/ngx-tethys-badge.mjs.map +1 -1
  29. package/fesm2020/ngx-tethys-cascader.mjs +6 -5
  30. package/fesm2020/ngx-tethys-cascader.mjs.map +1 -1
  31. package/fesm2020/ngx-tethys-core.mjs +1 -1
  32. package/fesm2020/ngx-tethys-core.mjs.map +1 -1
  33. package/fesm2020/ngx-tethys-table.mjs +20 -4
  34. package/fesm2020/ngx-tethys-table.mjs.map +1 -1
  35. package/fesm2020/ngx-tethys-timeline.mjs +12 -2
  36. package/fesm2020/ngx-tethys-timeline.mjs.map +1 -1
  37. package/fesm2020/ngx-tethys.mjs +1 -1
  38. package/fesm2020/ngx-tethys.mjs.map +1 -1
  39. package/package.json +1 -1
  40. package/schematics/version.d.ts +1 -1
  41. package/schematics/version.js +1 -1
  42. package/styles/mixins/link.scss +6 -2
  43. package/styles/modules/link.scss +2 -1
  44. package/styles/variables.scss +2 -0
  45. package/table/table.component.d.ts +5 -1
  46. package/table/table.interface.d.ts +1 -0
  47. package/timeline/timeline-item.component.d.ts +3 -2
  48. 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 _initialized;
12
- private badgeClassNameMap;
13
- st: {
14
- value: number | string;
15
- isValueOfString: boolean;
16
- isSetValue: boolean;
17
- isValueKeepShow: boolean;
18
- max: {
19
- is: boolean;
20
- value: number;
21
- };
22
- isElement: boolean;
23
- isSup: boolean;
24
- isShowBadge: boolean;
25
- };
26
- textColor: string;
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' | 'secondary'
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
- * 徽标显示的大小,分别为 `sm` | `md` | `lg`
53
+ * 徽标显示的大小,分别为 'sm' | 'md' | 'lg'
53
54
  * @default md
54
55
  */
55
- set thySize(value: string);
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 combineBadgeClassName;
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
  }
@@ -0,0 +1,9 @@
1
+ thy-badge {
2
+ margin-right: 40px;
3
+ }
4
+ .square {
5
+ width: 42px;
6
+ height: 42px;
7
+ border-radius: 5px;
8
+ background: #eee;
9
+ }
@@ -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-sup {
92
- position: absolute;
93
- top: 0px;
94
- right: 0;
95
- transform: translateY(-50%) translateX(50%);
96
- z-index: 1;
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 { SelectionModel } from '@angular/cdk/collections';
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';
@@ -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 { Component, ElementRef, HostBinding, Input, ChangeDetectionStrategy } from '@angular/core';
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._initialized = false;
18
- this.badgeClassNameMap = {
19
- 'thy-badge-count': true,
20
- 'thy-badge-dot': false,
21
- 'thy-badge-hollow': false,
22
- 'thy-badge-lg': false,
23
- 'thy-badge-sm': false,
24
- 'thy-badge-danger': true,
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' | 'secondary'
27
+ * 徽标类型, 类型为 'default' | 'primary' | 'danger' | 'warning' | 'success'
28
+ * @default danger
49
29
  */
50
30
  set thyType(value) {
51
- this.resetBadgeClassNameMap(BadgeMutexTheme);
52
- switch (value) {
53
- case 'danger':
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.st.value = value;
78
- this.st.isSetValue = true;
79
- if (this._initialized) {
40
+ this.value = value;
41
+ this.valueHasBeenSet = true;
42
+ if (this.initialized) {
80
43
  this.combineBadgeDisplayContent();
81
- this.combineBadgeClassName();
44
+ this.combineBadgeClasses();
82
45
  }
83
46
  }
84
47
  /**
85
48
  * 徽标内容文本
86
49
  */
87
50
  set thyContent(value) {
88
- this.st.value = value;
89
- this.st.isValueOfString = true;
90
- this.st.isSetValue = true;
91
- if (this._initialized) {
51
+ this.value = value;
52
+ this.valueHasBeenSet = true;
53
+ if (this.initialized) {
92
54
  this.combineBadgeDisplayContent();
93
- this.combineBadgeClassName();
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.st.max.is = true;
108
- this.st.max.value = value;
109
- if (this._initialized) {
69
+ this.maxCount = value;
70
+ if (this.initialized) {
110
71
  this.combineBadgeDisplayContent();
111
- this.combineBadgeClassName();
72
+ this.combineBadgeClasses();
112
73
  }
113
74
  }
114
75
  /**
115
- * 徽标显示的大小,分别为 `sm` | `md` | `lg`
76
+ * 徽标显示的大小,分别为 'sm' | 'md' | 'lg'
116
77
  * @default md
117
78
  */
118
79
  set thySize(value) {
119
- this.resetBadgeClassNameMap(BadgeMutexSize);
120
- switch (value) {
121
- case 'lg':
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.resetBadgeClassNameMap(badgeMutexTypes);
138
- this.badgeClassNameMap['thy-badge-dot'] = coerceBooleanProperty(value);
139
- if (this._initialized) {
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.resetBadgeClassNameMap(badgeMutexTypes);
148
- this.badgeClassNameMap['thy-badge-hollow'] = coerceBooleanProperty(value);
149
- if (this._initialized) {
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.st.isValueKeepShow = coerceBooleanProperty(value);
158
- if (this._initialized) {
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
- this.textColor = value;
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
- this.backgroundColor = value;
173
- this.resetBadgeClassNameMap(BadgeMutexTheme);
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.st.isSup = childNodeCount > 0;
183
- this.combineBadgeClassName();
184
- if (this.st.isSetValue) {
151
+ this.isWrapper = childNodeCount > 0;
152
+ this.combineBadgeClasses();
153
+ if (this.valueHasBeenSet) {
185
154
  this.combineBadgeDisplayContent();
186
155
  }
187
- this._initialized = true;
156
+ this.initialized = true;
188
157
  }
189
- combineBadgeClassName() {
190
- this.badgeClassNameMap['thy-badge-sup'] = this.st.isSup;
191
- const _badgeClassNames = [];
192
- for (const key in this.badgeClassNameMap) {
193
- if (this.badgeClassNameMap.hasOwnProperty(key)) {
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.badgeClassName = _badgeClassNames.join(' ');
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 (!this.st.value && !this.st.isValueKeepShow) {
207
- this.st.isShowBadge = false;
167
+ else if (this.isHollow) {
168
+ classes.push(`thy-badge-hollow`);
208
169
  }
209
170
  else {
210
- this.st.isShowBadge = true;
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
- resetBadgeClassNameMap(mutexArray) {
214
- for (const key in this.badgeClassNameMap) {
215
- if (this.badgeClassNameMap.hasOwnProperty(key)) {
216
- if (mutexArray.includes(key)) {
217
- this.badgeClassNameMap[key] = false;
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-container": "this.containerClassName" } }, providers: [UpdateHostClassService], ngImport: i0, template: "<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", directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
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], template: "<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" }]
228
- }], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { containerClassName: [{
229
- type: HostBinding,
230
- args: ['class.thy-badge-container']
231
- }], thyType: [{
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"]}