btv-base-controls 0.1.29 → 0.1.30
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/esm2022/btv-base-controls.mjs +5 -0
- package/esm2022/lib/basic.module.mjs +64 -0
- package/esm2022/lib/blink-message/blink-message.component.mjs +54 -0
- package/esm2022/lib/btv-icon-button/btv-counter-button.mjs +47 -0
- package/esm2022/lib/btv-icon-button/btv-icon-button.component.mjs +91 -0
- package/esm2022/lib/btv-progress/btv-progress.component.mjs +71 -0
- package/esm2022/lib/btv-search/btv-search.component.mjs +82 -0
- package/esm2022/lib/btv-search/index.mjs +2 -0
- package/esm2022/lib/busy-indicator/busy-indicator.component.mjs +16 -0
- package/esm2022/lib/custom-tool-tip/custom-tool-tip.component.mjs +34 -0
- package/esm2022/lib/custom-tool-tip/tool-tip-renderer.directive.mjs +113 -0
- package/esm2022/lib/illustration/illustration.component.mjs +17 -0
- package/esm2022/lib/wm-avatar/avatar.component.mjs +175 -0
- package/esm2022/lib/wm-back-btn/wm-back-btn.component.mjs +26 -0
- package/esm2022/lib/wm-beta-text/wm-beta-text.component.mjs +19 -0
- package/esm2022/lib/wm-info/info-models.mjs +14 -0
- package/esm2022/lib/wm-info/wm-info.component.mjs +239 -0
- package/esm2022/lib/wm-info-card/wm-info-card.component.mjs +23 -0
- package/esm2022/lib/wm-no-content/wm-no-content.component.mjs +30 -0
- package/esm2022/lib/wm-panel-bar/wm-panel-bar.component.mjs +81 -0
- package/esm2022/lib/wm-scalable-div/scalable-div.component.mjs +105 -0
- package/esm2022/lib/wm-spinner/wm-spinner.component.mjs +135 -0
- package/esm2022/lib/wm-state-icon/wm-state-icon.component.mjs +18 -0
- package/esm2022/lib/wm-tag/wm-tag.component.mjs +28 -0
- package/esm2022/lib/wm-tamplate-image/wm-template-image.component.mjs +71 -0
- package/esm2022/lib/wm-toggle/wm-toggle.component.mjs +31 -0
- package/esm2022/models/guidExtension.mjs +15 -0
- package/esm2022/public-api.mjs +28 -0
- package/fesm2022/btv-base-controls.mjs +1503 -0
- package/fesm2022/btv-base-controls.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/basic.module.d.ts +33 -0
- package/lib/blink-message/blink-message.component.d.ts +20 -0
- package/lib/btv-icon-button/btv-counter-button.d.ts +12 -0
- package/lib/btv-icon-button/btv-icon-button.component.d.ts +32 -0
- package/lib/btv-progress/btv-progress.component.d.ts +20 -0
- package/lib/btv-search/btv-search.component.d.ts +31 -0
- package/{src/lib/btv-search/index.ts → lib/btv-search/index.d.ts} +1 -1
- package/lib/busy-indicator/busy-indicator.component.d.ts +7 -0
- package/lib/custom-tool-tip/custom-tool-tip.component.d.ts +35 -0
- package/lib/custom-tool-tip/tool-tip-renderer.directive.d.ts +49 -0
- package/lib/illustration/illustration.component.d.ts +10 -0
- package/lib/wm-avatar/avatar.component.d.ts +63 -0
- package/lib/wm-back-btn/wm-back-btn.component.d.ts +10 -0
- package/lib/wm-beta-text/wm-beta-text.component.d.ts +7 -0
- package/lib/wm-info/info-models.d.ts +21 -0
- package/lib/wm-info/wm-info.component.d.ts +34 -0
- package/lib/wm-info-card/wm-info-card.component.d.ts +9 -0
- package/lib/wm-no-content/wm-no-content.component.d.ts +11 -0
- package/lib/wm-panel-bar/wm-panel-bar.component.d.ts +26 -0
- package/lib/wm-scalable-div/scalable-div.component.d.ts +24 -0
- package/lib/wm-spinner/wm-spinner.component.d.ts +37 -0
- package/lib/wm-state-icon/wm-state-icon.component.d.ts +9 -0
- package/lib/wm-tag/wm-tag.component.d.ts +10 -0
- package/lib/wm-tamplate-image/wm-template-image.component.d.ts +49 -0
- package/lib/wm-toggle/wm-toggle.component.d.ts +11 -0
- package/models/guidExtension.d.ts +5 -0
- package/package.json +24 -10
- package/public-api.d.ts +24 -0
- package/.browserslistrc +0 -16
- package/karma.conf.js +0 -44
- package/ng-package.json +0 -7
- package/src/assets/icon/state-icons.png +0 -0
- package/src/assets/theme/wmGlobals.scss +0 -181
- package/src/lib/basic.module.ts +0 -48
- package/src/lib/blink-message/blink-message.component.html +0 -1
- package/src/lib/blink-message/blink-message.component.scss +0 -4
- package/src/lib/blink-message/blink-message.component.ts +0 -54
- package/src/lib/btv-icon-button/btv-counter-button.html +0 -18
- package/src/lib/btv-icon-button/btv-counter-button.ts +0 -34
- package/src/lib/btv-icon-button/btv-icon-button.component.ts +0 -64
- package/src/lib/btv-icon-button/btv-icon-button.html +0 -14
- package/src/lib/btv-icon-button/btv-icon-button.scss +0 -124
- package/src/lib/btv-icon-button/index.ts +0 -1
- package/src/lib/btv-progress/btv-progress.component.ts +0 -65
- package/src/lib/btv-progress/btv-progress.html +0 -11
- package/src/lib/btv-progress/btv-progress.scss +0 -24
- package/src/lib/btv-search/btv-search.component.ts +0 -78
- package/src/lib/btv-search/btv-search.html +0 -15
- package/src/lib/btv-search/btv-search.scss +0 -97
- package/src/lib/busy-indicator/busy-indicator.component.ts +0 -13
- package/src/lib/busy-indicator/busy-indicator.html +0 -6
- package/src/lib/busy-indicator/busy-indicator.scss +0 -86
- package/src/lib/custom-tool-tip/custom-tool-tip.component.html +0 -9
- package/src/lib/custom-tool-tip/custom-tool-tip.component.scss +0 -47
- package/src/lib/custom-tool-tip/custom-tool-tip.component.ts +0 -44
- package/src/lib/custom-tool-tip/tool-tip-renderer.directive.ts +0 -111
- package/src/lib/illustration/illustration.component.html +0 -412
- package/src/lib/illustration/illustration.component.scss +0 -48
- package/src/lib/illustration/illustration.component.ts +0 -21
- package/src/lib/wm-avatar/avatar.component.ts +0 -179
- package/src/lib/wm-avatar/avatar.html +0 -13
- package/src/lib/wm-avatar/avatar.scss +0 -3
- package/src/lib/wm-back-btn/wm-back-btn.component.ts +0 -19
- package/src/lib/wm-back-btn/wm-back-btn.html +0 -7
- package/src/lib/wm-back-btn/wm-back-btn.scss +0 -51
- package/src/lib/wm-beta-text/wm-beta-text.component.html +0 -1
- package/src/lib/wm-beta-text/wm-beta-text.component.scss +0 -44
- package/src/lib/wm-beta-text/wm-beta-text.component.ts +0 -14
- package/src/lib/wm-info/info-models.ts +0 -22
- package/src/lib/wm-info/wm-info.component.ts +0 -238
- package/src/lib/wm-info/wm-info.html +0 -19
- package/src/lib/wm-info/wm-info.scss +0 -64
- package/src/lib/wm-info-card/wm-info-card.component.ts +0 -14
- package/src/lib/wm-info-card/wm-info-card.html +0 -13
- package/src/lib/wm-info-card/wm-info-card.scss +0 -56
- package/src/lib/wm-no-content/wm-no-content.component.ts +0 -17
- package/src/lib/wm-no-content/wm-no-content.html +0 -13
- package/src/lib/wm-no-content/wm-no-content.scss +0 -60
- package/src/lib/wm-panel-bar/wm-panel-bar.component.ts +0 -60
- package/src/lib/wm-panel-bar/wm-panel-bar.html +0 -43
- package/src/lib/wm-panel-bar/wm-panel-bar.scss +0 -114
- package/src/lib/wm-scalable-div/scalable-div.component.ts +0 -106
- package/src/lib/wm-scalable-div/scalable-div.html +0 -1
- package/src/lib/wm-scalable-div/scalable-div.scss +0 -11
- package/src/lib/wm-spinner/wm-spinner.component.ts +0 -129
- package/src/lib/wm-spinner/wm-spinner.html +0 -37
- package/src/lib/wm-spinner/wm-spinner.scss +0 -72
- package/src/lib/wm-state-icon/wm-state-icon.component.html +0 -4
- package/src/lib/wm-state-icon/wm-state-icon.component.scss +0 -26
- package/src/lib/wm-state-icon/wm-state-icon.component.ts +0 -18
- package/src/lib/wm-tag/wm-tag.component.html +0 -8
- package/src/lib/wm-tag/wm-tag.component.scss +0 -48
- package/src/lib/wm-tag/wm-tag.component.ts +0 -17
- package/src/lib/wm-tamplate-image/wm-template-image.component.ts +0 -56
- package/src/lib/wm-tamplate-image/wm-template-image.html +0 -3
- package/src/lib/wm-tamplate-image/wm-template-image.scss +0 -31
- package/src/lib/wm-toggle/wm-toggle.component.ts +0 -20
- package/src/lib/wm-toggle/wm-toggle.html +0 -5
- package/src/lib/wm-toggle/wm-toggle.scss +0 -33
- package/src/models/guidExtension.ts +0 -16
- package/src/public-api.ts +0 -29
- package/src/test.ts +0 -15
- package/tsconfig.lib.json +0 -15
- package/tsconfig.lib.prod.json +0 -10
- package/tsconfig.spec.json +0 -17
|
@@ -0,0 +1,175 @@
|
|
|
1
|
+
import { Component, Input, SecurityContext } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/platform-browser";
|
|
4
|
+
import * as i2 from "@angular/common";
|
|
5
|
+
/**
|
|
6
|
+
* list of default colors
|
|
7
|
+
*/
|
|
8
|
+
export const defaultColors = [
|
|
9
|
+
'#1abc9c',
|
|
10
|
+
'#3498db',
|
|
11
|
+
'#f1c40f',
|
|
12
|
+
'#8e44ad',
|
|
13
|
+
'#e74c3c',
|
|
14
|
+
'#d35400',
|
|
15
|
+
'#2c3e50',
|
|
16
|
+
'#7f8c8d'
|
|
17
|
+
];
|
|
18
|
+
export class AvatarComponent {
|
|
19
|
+
get name() { return this._name; }
|
|
20
|
+
set name(value) {
|
|
21
|
+
this._name = value;
|
|
22
|
+
this.avatarText = this.formTextAvatar(value);
|
|
23
|
+
}
|
|
24
|
+
;
|
|
25
|
+
;
|
|
26
|
+
get src() { return this._src; }
|
|
27
|
+
;
|
|
28
|
+
set src(value) {
|
|
29
|
+
this._src = value;
|
|
30
|
+
this.avatarSrc = this.transformSrc(value);
|
|
31
|
+
}
|
|
32
|
+
constructor(sanitizer) {
|
|
33
|
+
this.sanitizer = sanitizer;
|
|
34
|
+
this.avatarText = null;
|
|
35
|
+
this.size = 50;
|
|
36
|
+
this.avatarSrc = null;
|
|
37
|
+
this.round = true;
|
|
38
|
+
this.cornerRadius = 0;
|
|
39
|
+
this.textSizeRatio = 3;
|
|
40
|
+
this.fgColor = '#FFF';
|
|
41
|
+
this.style = {};
|
|
42
|
+
this.avatarColors = defaultColors;
|
|
43
|
+
this.avatarStyle = {};
|
|
44
|
+
this.hostStyle = {};
|
|
45
|
+
}
|
|
46
|
+
transformSrc(stringInBase64) {
|
|
47
|
+
if (!stringInBase64)
|
|
48
|
+
return null;
|
|
49
|
+
return this.sanitizer.sanitize(SecurityContext.RESOURCE_URL, this.sanitizer.bypassSecurityTrustResourceUrl(stringInBase64));
|
|
50
|
+
}
|
|
51
|
+
formTextAvatar(val) {
|
|
52
|
+
if (!val)
|
|
53
|
+
return '?';
|
|
54
|
+
const name = val.trim();
|
|
55
|
+
const splitted = name.split(' ');
|
|
56
|
+
if (splitted.length === 1) {
|
|
57
|
+
if (name.length === 1) {
|
|
58
|
+
return name[0];
|
|
59
|
+
}
|
|
60
|
+
return name[0] + name[1];
|
|
61
|
+
}
|
|
62
|
+
const length = Math.min(splitted.length, 3);
|
|
63
|
+
splitted.length = length; // leave first 3 words top
|
|
64
|
+
return splitted.map(it => it[0]).join('');
|
|
65
|
+
}
|
|
66
|
+
/**
|
|
67
|
+
* Detect inputs change
|
|
68
|
+
*
|
|
69
|
+
* param {{ [propKey: string]: SimpleChange }} changes
|
|
70
|
+
*
|
|
71
|
+
* memberof AvatarComponent
|
|
72
|
+
*/
|
|
73
|
+
ngOnChanges(changes) {
|
|
74
|
+
// reinitialize the avatar component when a source property value has changed
|
|
75
|
+
// the fallback system must be re-invoked with the new values.
|
|
76
|
+
this.initializeAvatar();
|
|
77
|
+
}
|
|
78
|
+
getStyles() {
|
|
79
|
+
if (!this.src) {
|
|
80
|
+
this.avatarStyle = this.getInitialsStyle(this.avatarText);
|
|
81
|
+
}
|
|
82
|
+
else {
|
|
83
|
+
this.avatarStyle = this.getImageStyle();
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
/**
|
|
87
|
+
* Initialize the avatar component and its fallback system
|
|
88
|
+
*/
|
|
89
|
+
initializeAvatar() {
|
|
90
|
+
if (!this.src && !this.name)
|
|
91
|
+
return;
|
|
92
|
+
this.getStyles();
|
|
93
|
+
this.hostStyle = {
|
|
94
|
+
width: this.size + 'px',
|
|
95
|
+
height: this.size + 'px'
|
|
96
|
+
};
|
|
97
|
+
}
|
|
98
|
+
/**
|
|
99
|
+
*
|
|
100
|
+
* returns initials style
|
|
101
|
+
*
|
|
102
|
+
*/
|
|
103
|
+
getInitialsStyle(avatarValue) {
|
|
104
|
+
return {
|
|
105
|
+
textAlign: 'center',
|
|
106
|
+
borderRadius: this.round ? '100%' : this.cornerRadius + 'px',
|
|
107
|
+
border: this.borderColor ? '1px solid ' + this.borderColor : '',
|
|
108
|
+
textTransform: 'uppercase',
|
|
109
|
+
color: this.fgColor,
|
|
110
|
+
backgroundColor: this.bgColor
|
|
111
|
+
? this.bgColor
|
|
112
|
+
: this.getRandomColor(avatarValue),
|
|
113
|
+
font: Math.floor(+this.size / this.textSizeRatio) +
|
|
114
|
+
'px Helvetica, Arial, sans-serif',
|
|
115
|
+
lineHeight: this.size + 'px',
|
|
116
|
+
...this.style
|
|
117
|
+
};
|
|
118
|
+
}
|
|
119
|
+
/**
|
|
120
|
+
*
|
|
121
|
+
* returns image style
|
|
122
|
+
*/
|
|
123
|
+
getImageStyle() {
|
|
124
|
+
return {
|
|
125
|
+
maxWidth: '100%',
|
|
126
|
+
borderRadius: this.round ? '50%' : this.cornerRadius + 'px',
|
|
127
|
+
border: this.borderColor ? '1px solid ' + this.borderColor : '',
|
|
128
|
+
width: this.size + 'px',
|
|
129
|
+
height: this.size + 'px',
|
|
130
|
+
...this.style,
|
|
131
|
+
};
|
|
132
|
+
}
|
|
133
|
+
getRandomColor(avatarText) {
|
|
134
|
+
if (!avatarText) {
|
|
135
|
+
return 'transparent';
|
|
136
|
+
}
|
|
137
|
+
const asciiCodeSum = this.calculateAsciiCode(avatarText);
|
|
138
|
+
return this.avatarColors[asciiCodeSum % this.avatarColors.length];
|
|
139
|
+
}
|
|
140
|
+
calculateAsciiCode(value) {
|
|
141
|
+
return value
|
|
142
|
+
.split('')
|
|
143
|
+
.map(letter => letter.charCodeAt(0))
|
|
144
|
+
.reduce((previous, current) => previous + current);
|
|
145
|
+
}
|
|
146
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: AvatarComponent, deps: [{ token: i1.DomSanitizer }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
147
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.1", type: AvatarComponent, selector: "wm-avatar", inputs: { name: "name", size: "size", src: "src", value: "value", round: "round", cornerRadius: "cornerRadius", textSizeRatio: "textSizeRatio", bgColor: "bgColor", fgColor: "fgColor", borderColor: "borderColor", style: "style" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"avatar-container\" [ngStyle]=\"hostStyle\">\r\n <img *ngIf=\"avatarSrc; else textAvatar\" \r\n [src]=\"avatarSrc\" \r\n [width]=\"size\" \r\n [height]=\"size\" \r\n [ngStyle]=\"avatarStyle\"\r\n class=\"avatar-content\" loading=\"lazy\" />\r\n <ng-template #textAvatar>\r\n <div *ngIf=\"avatarText\" class=\"avatar-content\" [ngStyle]=\"avatarStyle\">\r\n {{ avatarText }}\r\n </div>\r\n </ng-template>\r\n</div>", styles: [":host{border-radius:50%}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] }); }
|
|
148
|
+
}
|
|
149
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: AvatarComponent, decorators: [{
|
|
150
|
+
type: Component,
|
|
151
|
+
args: [{ selector: 'wm-avatar', template: "<div class=\"avatar-container\" [ngStyle]=\"hostStyle\">\r\n <img *ngIf=\"avatarSrc; else textAvatar\" \r\n [src]=\"avatarSrc\" \r\n [width]=\"size\" \r\n [height]=\"size\" \r\n [ngStyle]=\"avatarStyle\"\r\n class=\"avatar-content\" loading=\"lazy\" />\r\n <ng-template #textAvatar>\r\n <div *ngIf=\"avatarText\" class=\"avatar-content\" [ngStyle]=\"avatarStyle\">\r\n {{ avatarText }}\r\n </div>\r\n </ng-template>\r\n</div>", styles: [":host{border-radius:50%}\n"] }]
|
|
152
|
+
}], ctorParameters: () => [{ type: i1.DomSanitizer }], propDecorators: { name: [{
|
|
153
|
+
type: Input
|
|
154
|
+
}], size: [{
|
|
155
|
+
type: Input
|
|
156
|
+
}], src: [{
|
|
157
|
+
type: Input
|
|
158
|
+
}], value: [{
|
|
159
|
+
type: Input
|
|
160
|
+
}], round: [{
|
|
161
|
+
type: Input
|
|
162
|
+
}], cornerRadius: [{
|
|
163
|
+
type: Input
|
|
164
|
+
}], textSizeRatio: [{
|
|
165
|
+
type: Input
|
|
166
|
+
}], bgColor: [{
|
|
167
|
+
type: Input
|
|
168
|
+
}], fgColor: [{
|
|
169
|
+
type: Input
|
|
170
|
+
}], borderColor: [{
|
|
171
|
+
type: Input
|
|
172
|
+
}], style: [{
|
|
173
|
+
type: Input
|
|
174
|
+
}] } });
|
|
175
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"avatar.component.js","sourceRoot":"","sources":["../../../../../projects/btv-base-controls/src/lib/wm-avatar/avatar.component.ts","../../../../../projects/btv-base-controls/src/lib/wm-avatar/avatar.html"],"names":[],"mappings":"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","sourcesContent":["import { DomSanitizer } from \"@angular/platform-browser\";\r\n\r\nimport {\r\n  Component,\r\n  Input,\r\n  OnChanges,\r\n  SimpleChanges,\r\n  SecurityContext\r\n} from '@angular/core';\r\n\r\ntype Style = Partial<CSSStyleDeclaration>;\r\n\r\n/**\r\n * list of default colors\r\n */\r\nexport const defaultColors = [\r\n  '#1abc9c',\r\n  '#3498db',\r\n  '#f1c40f',\r\n  '#8e44ad',\r\n  '#e74c3c',\r\n  '#d35400',\r\n  '#2c3e50',\r\n  '#7f8c8d'\r\n];\r\n\r\n\r\n@Component({\r\n  selector: 'wm-avatar',\r\n  styleUrls: ['./avatar.scss'],\r\n  templateUrl: './avatar.html'\r\n})\r\nexport class AvatarComponent implements OnChanges {\r\n\r\n  private _name: string | null;\r\n  public avatarText: string | null = null;\r\n  public get name() { return this._name; }\r\n  @Input() public set name(value: string | null) {\r\n    this._name = value;\r\n    this.avatarText = this.formTextAvatar(value);\r\n  };\r\n  @Input() public size: string | number = 50;;\r\n\r\n  public avatarSrc: string | null = null;\r\n  private _src: string | null;\r\n  public get src() { return this._src };\r\n  @Input() public set src(value: string | null) {\r\n    this._src = value;\r\n    this.avatarSrc = this.transformSrc(value);\r\n  }\r\n  @Input() public value: string | null;\r\n  @Input() public round: boolean = true;\r\n  @Input() public cornerRadius: string | number = 0;\r\n  @Input() public textSizeRatio = 3;\r\n  @Input() public bgColor: string | undefined;\r\n  @Input() public fgColor = '#FFF';\r\n  @Input() public borderColor: string | undefined;\r\n  @Input() public style: Style = {};\r\n\r\n  public avatarColors: string[] = defaultColors;\r\n\r\n  constructor(private sanitizer: DomSanitizer) { }\r\n\r\n  public transformSrc(stringInBase64: string): string {\r\n    if (!stringInBase64) return null;\r\n    return this.sanitizer.sanitize(SecurityContext.RESOURCE_URL, this.sanitizer.bypassSecurityTrustResourceUrl(stringInBase64));\r\n\r\n  }\r\n\r\n  public formTextAvatar(val: string) {\r\n    if (!val) return '?';\r\n\r\n    const name = val.trim();\r\n    const splitted = name.split(' ');\r\n\r\n    if (splitted.length === 1) {\r\n      if (name.length === 1) {\r\n        return name[0];\r\n      }\r\n      return name[0] + name[1];\r\n    }\r\n    \r\n    const length = Math.min(splitted.length, 3);\r\n\r\n    splitted.length = length; // leave first 3 words top\r\n    return splitted.map(it => it[0]).join('');\r\n  }\r\n\r\n  public avatarStyle: Style = {};\r\n  public hostStyle: Style = {};\r\n\r\n  /**\r\n   * Detect inputs change\r\n   *\r\n   * param {{ [propKey: string]: SimpleChange }} changes\r\n   *\r\n   * memberof AvatarComponent\r\n   */\r\n  public ngOnChanges(changes: SimpleChanges): void {\r\n    // reinitialize the avatar component when a source property value has changed\r\n    // the fallback system must be re-invoked with the new values.\r\n    this.initializeAvatar();\r\n  }\r\n\r\n  public getStyles(): void {\r\n\r\n    if (!this.src) {\r\n      this.avatarStyle = this.getInitialsStyle(this.avatarText);\r\n    } else {\r\n      this.avatarStyle = this.getImageStyle();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Initialize the avatar component and its fallback system\r\n   */\r\n  private initializeAvatar(): void {\r\n    if (!this.src && !this.name) return\r\n    this.getStyles();\r\n    this.hostStyle = {\r\n      width: this.size + 'px',\r\n      height: this.size + 'px'\r\n    };\r\n  }\r\n\r\n  /**\r\n   *\r\n   * returns initials style\r\n   *\r\n   */\r\n  private getInitialsStyle(avatarValue: string): Style {\r\n    return {\r\n      textAlign: 'center',\r\n      borderRadius: this.round ? '100%' : this.cornerRadius + 'px',\r\n      border: this.borderColor ? '1px solid ' + this.borderColor : '',\r\n      textTransform: 'uppercase',\r\n      color: this.fgColor,\r\n      backgroundColor: this.bgColor\r\n        ? this.bgColor\r\n        : this.getRandomColor(avatarValue),\r\n      font:\r\n        Math.floor(+this.size / this.textSizeRatio) +\r\n        'px Helvetica, Arial, sans-serif',\r\n      lineHeight: this.size + 'px',\r\n      ...this.style\r\n    };\r\n  }\r\n\r\n  /**\r\n   *\r\n   * returns image style\r\n   */\r\n  private getImageStyle(): Style {\r\n    return {\r\n      maxWidth: '100%',\r\n      borderRadius: this.round ? '50%' : this.cornerRadius + 'px',\r\n      border: this.borderColor ? '1px solid ' + this.borderColor : '',\r\n      width: this.size + 'px',\r\n      height: this.size + 'px',\r\n      ...this.style,\r\n    };\r\n  }\r\n\r\n  private getRandomColor(avatarText: string): string {\r\n    if (!avatarText) {\r\n      return 'transparent';\r\n    }\r\n    const asciiCodeSum = this.calculateAsciiCode(avatarText);\r\n    return this.avatarColors[asciiCodeSum % this.avatarColors.length];\r\n  }\r\n\r\n  private calculateAsciiCode(value: string): number {\r\n    return value\r\n      .split('')\r\n      .map(letter => letter.charCodeAt(0))\r\n      .reduce((previous, current) => previous + current);\r\n  }\r\n\r\n}\r\n","<div class=\"avatar-container\" [ngStyle]=\"hostStyle\">\r\n    <img *ngIf=\"avatarSrc; else textAvatar\" \r\n        [src]=\"avatarSrc\" \r\n        [width]=\"size\" \r\n        [height]=\"size\" \r\n        [ngStyle]=\"avatarStyle\"\r\n        class=\"avatar-content\" loading=\"lazy\" />\r\n    <ng-template #textAvatar>\r\n        <div *ngIf=\"avatarText\" class=\"avatar-content\" [ngStyle]=\"avatarStyle\">\r\n            {{ avatarText }}\r\n        </div>\r\n    </ng-template>\r\n</div>"]}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common";
|
|
4
|
+
export class WmBackBtnComponent {
|
|
5
|
+
constructor() {
|
|
6
|
+
this.icon = 'arrow-long-left';
|
|
7
|
+
this.disabled = false;
|
|
8
|
+
this.iClick = new EventEmitter();
|
|
9
|
+
}
|
|
10
|
+
onClick(event) {
|
|
11
|
+
this.iClick.emit(event);
|
|
12
|
+
}
|
|
13
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: WmBackBtnComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
14
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.1", type: WmBackBtnComponent, selector: "wm-back-btn", inputs: { icon: "icon", disabled: "disabled" }, outputs: { iClick: "iClick" }, ngImport: i0, template: "<button class=\"wm-btn-button-wrap\" (click)=\"onClick($event)\" type=\"button\">\r\n <div class=\"icon-svg\" [ngClass]=\"{'disabled': disabled}\" [ngStyle]=\"{\r\n 'mask': 'url(./assets/icon/svg/'+ icon+ '.svg) no-repeat center', \r\n '-webkit-mask':'url(./assets/icon/svg/'+icon+'.svg) no-repeat center'\r\n }\">\r\n </div>\r\n</button>", styles: ["@media print{body{all:unset!important}.wm-page{margin:0!important;display:block!important}.not-printable{display:none!important}*{visibility:hidden}.printable,.printable *{visibility:visible!important}}:host{display:flex;align-self:center}.wm-btn-button-wrap{background-color:transparent;color:var(--mediumFontColor);border:none;border-radius:0;font-size:14px;display:flex;justify-content:flex-start;align-items:center;align-content:center;outline:0;cursor:pointer;height:30px}.wm-btn-button-wrap:hover{color:var(--strongFontColor)}.wm-btn-button-wrap:hover .icon-svg{background-color:var(--strongFontColor)}.icon-svg{justify-content:center;align-items:center;background-color:var(--mediumFontColor);width:24px;height:24px}.disabled{background-color:var(--disabledColor);border-color:var(--disabledColor);color:var(--lightFontColor);cursor:default}.disabled:hover{background-color:var(--disabledColor);border-color:var(--disabledColor)}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
15
|
+
}
|
|
16
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: WmBackBtnComponent, decorators: [{
|
|
17
|
+
type: Component,
|
|
18
|
+
args: [{ selector: 'wm-back-btn', changeDetection: ChangeDetectionStrategy.OnPush, template: "<button class=\"wm-btn-button-wrap\" (click)=\"onClick($event)\" type=\"button\">\r\n <div class=\"icon-svg\" [ngClass]=\"{'disabled': disabled}\" [ngStyle]=\"{\r\n 'mask': 'url(./assets/icon/svg/'+ icon+ '.svg) no-repeat center', \r\n '-webkit-mask':'url(./assets/icon/svg/'+icon+'.svg) no-repeat center'\r\n }\">\r\n </div>\r\n</button>", styles: ["@media print{body{all:unset!important}.wm-page{margin:0!important;display:block!important}.not-printable{display:none!important}*{visibility:hidden}.printable,.printable *{visibility:visible!important}}:host{display:flex;align-self:center}.wm-btn-button-wrap{background-color:transparent;color:var(--mediumFontColor);border:none;border-radius:0;font-size:14px;display:flex;justify-content:flex-start;align-items:center;align-content:center;outline:0;cursor:pointer;height:30px}.wm-btn-button-wrap:hover{color:var(--strongFontColor)}.wm-btn-button-wrap:hover .icon-svg{background-color:var(--strongFontColor)}.icon-svg{justify-content:center;align-items:center;background-color:var(--mediumFontColor);width:24px;height:24px}.disabled{background-color:var(--disabledColor);border-color:var(--disabledColor);color:var(--lightFontColor);cursor:default}.disabled:hover{background-color:var(--disabledColor);border-color:var(--disabledColor)}\n"] }]
|
|
19
|
+
}], propDecorators: { icon: [{
|
|
20
|
+
type: Input
|
|
21
|
+
}], disabled: [{
|
|
22
|
+
type: Input
|
|
23
|
+
}], iClick: [{
|
|
24
|
+
type: Output
|
|
25
|
+
}] } });
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid20tYmFjay1idG4uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYnR2LWJhc2UtY29udHJvbHMvc3JjL2xpYi93bS1iYWNrLWJ0bi93bS1iYWNrLWJ0bi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9idHYtYmFzZS1jb250cm9scy9zcmMvbGliL3dtLWJhY2stYnRuL3dtLWJhY2stYnRuLmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQzs7O0FBUWhHLE1BQU0sT0FBTyxrQkFBa0I7SUFOL0I7UUFRb0IsU0FBSSxHQUFXLGlCQUFpQixDQUFDO1FBQ2pDLGFBQVEsR0FBWSxLQUFLLENBQUM7UUFFekIsV0FBTSxHQUFzQixJQUFJLFlBQVksRUFBTyxDQUFDO0tBS3hFO0lBSFUsT0FBTyxDQUFDLEtBQUs7UUFDaEIsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDNUIsQ0FBQzs4R0FUUSxrQkFBa0I7a0dBQWxCLGtCQUFrQixrSUNSL0IscVhBTVM7OzJGREVJLGtCQUFrQjtrQkFOOUIsU0FBUzsrQkFDSSxhQUFhLG1CQUdOLHVCQUF1QixDQUFDLE1BQU07OEJBSS9CLElBQUk7c0JBQW5CLEtBQUs7Z0JBQ1UsUUFBUTtzQkFBdkIsS0FBSztnQkFFVyxNQUFNO3NCQUF0QixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICAgIHNlbGVjdG9yOiAnd20tYmFjay1idG4nLFxyXG4gICAgc3R5bGVVcmxzOiBbJy4vd20tYmFjay1idG4uc2NzcyddLFxyXG4gICAgdGVtcGxhdGVVcmw6ICcuL3dtLWJhY2stYnRuLmh0bWwnLFxyXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcclxufSlcclxuZXhwb3J0IGNsYXNzIFdtQmFja0J0bkNvbXBvbmVudCB7XHJcblxyXG4gICAgQElucHV0KCkgcHVibGljIGljb246IHN0cmluZyA9ICdhcnJvdy1sb25nLWxlZnQnO1xyXG4gICAgQElucHV0KCkgcHVibGljIGRpc2FibGVkOiBib29sZWFuID0gZmFsc2U7XHJcblxyXG4gICAgQE91dHB1dCgpIHB1YmxpYyBpQ2xpY2s6IEV2ZW50RW1pdHRlcjxhbnk+ID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XHJcblxyXG4gICAgcHVibGljIG9uQ2xpY2soZXZlbnQpIHtcclxuICAgICAgICB0aGlzLmlDbGljay5lbWl0KGV2ZW50KTtcclxuICAgIH1cclxufVxyXG4iLCI8YnV0dG9uIGNsYXNzPVwid20tYnRuLWJ1dHRvbi13cmFwXCIgKGNsaWNrKT1cIm9uQ2xpY2soJGV2ZW50KVwiIHR5cGU9XCJidXR0b25cIj5cclxuICA8ZGl2IGNsYXNzPVwiaWNvbi1zdmdcIiBbbmdDbGFzc109XCJ7J2Rpc2FibGVkJzogZGlzYWJsZWR9XCIgW25nU3R5bGVdPVwie1xyXG4gICAgICAgICAgICAnbWFzayc6ICd1cmwoLi9hc3NldHMvaWNvbi9zdmcvJysgaWNvbisgJy5zdmcpIG5vLXJlcGVhdCBjZW50ZXInLCBcclxuICAgICAgICAgICAgJy13ZWJraXQtbWFzayc6J3VybCguL2Fzc2V0cy9pY29uL3N2Zy8nK2ljb24rJy5zdmcpIG5vLXJlcGVhdCBjZW50ZXInXHJcbiAgICAgICAgICB9XCI+XHJcbiAgPC9kaXY+XHJcbjwvYnV0dG9uPiJdfQ==
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class WmBetaTextComponent {
|
|
4
|
+
constructor() {
|
|
5
|
+
this.text = '';
|
|
6
|
+
this.wrapClass = '';
|
|
7
|
+
}
|
|
8
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: WmBetaTextComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
9
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.1", type: WmBetaTextComponent, selector: "wm-beta-text", inputs: { text: "text", wrapClass: "wrapClass" }, ngImport: i0, template: "<span class=\"text-title {{wrapClass}}\">{{text}}</span>\r\n", styles: ["@media print{body{all:unset!important}.wm-page{margin:0!important;display:block!important}.not-printable{display:none!important}*{visibility:hidden}.printable,.printable *{visibility:visible!important}}.text-title{color:var(--strongFontColor);display:block;text-align:right;transform-origin:center center;-webkit-transform:rotate(-6deg);-moz-transform:rotate(-6deg);-ms-transform:rotate(-6deg);-o-transform:rotate(-6deg);transform:rotate(-6deg);font-family:Inter,Verdana,Geneva,Tahoma,sans-serif;font-weight:500;font-size:16px;min-width:50px;border-radius:5px;padding:4px;margin:auto 12px auto 28px;text-align:center}.text-position{position:absolute;right:10px;height:23px}.center-position{line-height:22px;height:22px;margin-top:8px}.red-wrapper{background-color:var(--dangerColor);color:var(--onBrandTextColor)}.warning-wrapper{background-color:var(--warningColor);color:var(--onBrandTextColor)}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
10
|
+
}
|
|
11
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: WmBetaTextComponent, decorators: [{
|
|
12
|
+
type: Component,
|
|
13
|
+
args: [{ selector: 'wm-beta-text', changeDetection: ChangeDetectionStrategy.OnPush, template: "<span class=\"text-title {{wrapClass}}\">{{text}}</span>\r\n", styles: ["@media print{body{all:unset!important}.wm-page{margin:0!important;display:block!important}.not-printable{display:none!important}*{visibility:hidden}.printable,.printable *{visibility:visible!important}}.text-title{color:var(--strongFontColor);display:block;text-align:right;transform-origin:center center;-webkit-transform:rotate(-6deg);-moz-transform:rotate(-6deg);-ms-transform:rotate(-6deg);-o-transform:rotate(-6deg);transform:rotate(-6deg);font-family:Inter,Verdana,Geneva,Tahoma,sans-serif;font-weight:500;font-size:16px;min-width:50px;border-radius:5px;padding:4px;margin:auto 12px auto 28px;text-align:center}.text-position{position:absolute;right:10px;height:23px}.center-position{line-height:22px;height:22px;margin-top:8px}.red-wrapper{background-color:var(--dangerColor);color:var(--onBrandTextColor)}.warning-wrapper{background-color:var(--warningColor);color:var(--onBrandTextColor)}\n"] }]
|
|
14
|
+
}], propDecorators: { text: [{
|
|
15
|
+
type: Input
|
|
16
|
+
}], wrapClass: [{
|
|
17
|
+
type: Input
|
|
18
|
+
}] } });
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid20tYmV0YS10ZXh0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2J0di1iYXNlLWNvbnRyb2xzL3NyYy9saWIvd20tYmV0YS10ZXh0L3dtLWJldGEtdGV4dC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9idHYtYmFzZS1jb250cm9scy9zcmMvbGliL3dtLWJldGEtdGV4dC93bS1iZXRhLXRleHQuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBUTFFLE1BQU0sT0FBTyxtQkFBbUI7SUFOaEM7UUFRa0IsU0FBSSxHQUFXLEVBQUUsQ0FBQztRQUNsQixjQUFTLEdBQVcsRUFBRSxDQUFDO0tBRXhDOzhHQUxZLG1CQUFtQjtrR0FBbkIsbUJBQW1CLHNHQ1JoQyw4REFDQTs7MkZET2EsbUJBQW1CO2tCQU4vQixTQUFTOytCQUNFLGNBQWMsbUJBR1AsdUJBQXVCLENBQUMsTUFBTTs4QkFJL0IsSUFBSTtzQkFBbkIsS0FBSztnQkFDVSxTQUFTO3NCQUF4QixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnd20tYmV0YS10ZXh0JyxcclxuICB0ZW1wbGF0ZVVybDogJy4vd20tYmV0YS10ZXh0LmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi93bS1iZXRhLXRleHQuY29tcG9uZW50LnNjc3MnXSxcclxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcclxufSlcclxuZXhwb3J0IGNsYXNzIFdtQmV0YVRleHRDb21wb25lbnQge1xyXG5cclxuICBASW5wdXQoKSBwdWJsaWMgdGV4dDogc3RyaW5nID0gJyc7XHJcbiAgQElucHV0KCkgcHVibGljIHdyYXBDbGFzczogc3RyaW5nID0gJyc7XHJcblxyXG59XHJcbiIsIjxzcGFuIGNsYXNzPVwidGV4dC10aXRsZSB7e3dyYXBDbGFzc319XCI+e3t0ZXh0fX08L3NwYW4+XHJcbiJdfQ==
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
export var InfoType;
|
|
2
|
+
(function (InfoType) {
|
|
3
|
+
InfoType[InfoType["Error"] = 0] = "Error";
|
|
4
|
+
InfoType[InfoType["Warning"] = 1] = "Warning";
|
|
5
|
+
InfoType[InfoType["InfoMessage"] = 2] = "InfoMessage";
|
|
6
|
+
InfoType[InfoType["TabError"] = 3] = "TabError";
|
|
7
|
+
InfoType[InfoType["TabWarning"] = 4] = "TabWarning";
|
|
8
|
+
InfoType[InfoType["InfoSmall"] = 5] = "InfoSmall";
|
|
9
|
+
InfoType[InfoType["Filtered"] = 6] = "Filtered";
|
|
10
|
+
InfoType[InfoType["InlineDetails"] = 7] = "InlineDetails";
|
|
11
|
+
InfoType[InfoType["SubNavPanel"] = 8] = "SubNavPanel";
|
|
12
|
+
InfoType[InfoType["InfoGold"] = 9] = "InfoGold";
|
|
13
|
+
})(InfoType || (InfoType = {}));
|
|
14
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5mby1tb2RlbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9idHYtYmFzZS1jb250cm9scy9zcmMvbGliL3dtLWluZm8vaW5mby1tb2RlbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsTUFBTSxDQUFOLElBQVksUUFXWDtBQVhELFdBQVksUUFBUTtJQUNsQix5Q0FBUyxDQUFBO0lBQ1QsNkNBQVcsQ0FBQTtJQUNYLHFEQUFlLENBQUE7SUFDZiwrQ0FBWSxDQUFBO0lBQ1osbURBQWMsQ0FBQTtJQUNkLGlEQUFhLENBQUE7SUFDYiwrQ0FBWSxDQUFBO0lBQ1oseURBQWlCLENBQUE7SUFDakIscURBQWUsQ0FBQTtJQUNmLCtDQUFZLENBQUE7QUFDZCxDQUFDLEVBWFcsUUFBUSxLQUFSLFFBQVEsUUFXbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBPcmlnaW5Db25uZWN0aW9uUG9zaXRpb24sIE92ZXJsYXlDb25uZWN0aW9uUG9zaXRpb24gfSBmcm9tIFwiQGFuZ3VsYXIvY2RrL292ZXJsYXlcIjtcclxuXHJcbmV4cG9ydCBlbnVtIEluZm9UeXBlIHtcclxuICBFcnJvciA9IDAsXHJcbiAgV2FybmluZyA9IDEsXHJcbiAgSW5mb01lc3NhZ2UgPSAyLFxyXG4gIFRhYkVycm9yID0gMyxcclxuICBUYWJXYXJuaW5nID0gNCxcclxuICBJbmZvU21hbGwgPSA1LFxyXG4gIEZpbHRlcmVkID0gNixcclxuICBJbmxpbmVEZXRhaWxzID0gNyxcclxuICBTdWJOYXZQYW5lbCA9IDgsXHJcbiAgSW5mb0dvbGQgPSA5XHJcbn1cclxuZXhwb3J0IGludGVyZmFjZSBJV21JbmZvUG9zaXRpb25Qb3B1cCB7XHJcbiAgb3JpZ2luOiBPcmlnaW5Db25uZWN0aW9uUG9zaXRpb247XHJcbiAgb3ZlcmxheTogT3ZlcmxheUNvbm5lY3Rpb25Qb3NpdGlvbjtcclxuICBhcnJvdzoge1xyXG4gICAgYm90dG9tOiBib29sZWFuO1xyXG4gICAgbGVmdDogYm9vbGVhbjtcclxuICB9O1xyXG59XHJcbiJdfQ==
|
|
@@ -0,0 +1,239 @@
|
|
|
1
|
+
import { ConnectionPositionPair } from '@angular/cdk/overlay';
|
|
2
|
+
import { TemplatePortal } from '@angular/cdk/portal';
|
|
3
|
+
import { Component, Input, ChangeDetectionStrategy } from '@angular/core';
|
|
4
|
+
import { InfoType } from './info-models';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "@angular/cdk/overlay";
|
|
7
|
+
import * as i2 from "@angular/common";
|
|
8
|
+
import * as i3 from "../wm-tamplate-image/wm-template-image.component";
|
|
9
|
+
const DEFAULT_TOOLTIP_POSITIONS = ['bottom-right', 'bottom-center', 'bottom-left', 'top-right', 'top-center', 'top-left'];
|
|
10
|
+
export class WmInfoComponent {
|
|
11
|
+
get imageSize() {
|
|
12
|
+
return (this.smallIcon ? this.smallIconSize : this.defaultIconSize) + 'px';
|
|
13
|
+
}
|
|
14
|
+
constructor(_overlay, _elementRef, viewContainerRef) {
|
|
15
|
+
this._overlay = _overlay;
|
|
16
|
+
this._elementRef = _elementRef;
|
|
17
|
+
this.viewContainerRef = viewContainerRef;
|
|
18
|
+
this.preText = '';
|
|
19
|
+
this.postText = '';
|
|
20
|
+
this.type = InfoType.Error;
|
|
21
|
+
this.popupPosition = 'bottom-right';
|
|
22
|
+
this.useThemeForIconTemplate = false;
|
|
23
|
+
this.defaultIconSize = 24;
|
|
24
|
+
this.smallIconSize = 16;
|
|
25
|
+
this.positionBottom = true;
|
|
26
|
+
this.positionLeft = true;
|
|
27
|
+
this.currentPositions = DEFAULT_TOOLTIP_POSITIONS;
|
|
28
|
+
}
|
|
29
|
+
togglePopup(template) {
|
|
30
|
+
if (this._overlayRef) {
|
|
31
|
+
this.closePopup();
|
|
32
|
+
}
|
|
33
|
+
else {
|
|
34
|
+
this.openPopup(template);
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
openPopup(template) {
|
|
38
|
+
this.closePopup(); // close any old ones.
|
|
39
|
+
const positionPairs = this.currentPositions.map(position => {
|
|
40
|
+
const data = this.checkPopupPosition(position);
|
|
41
|
+
const vertClass = data.arrow.bottom ? 'info-bottom' : 'info-top';
|
|
42
|
+
const horClass = data.arrow.left ? 'info-left' : 'info-right';
|
|
43
|
+
return new ConnectionPositionPair({ originX: data.origin.originX, originY: data.origin.originY }, { overlayX: data.overlay.overlayX, overlayY: data.overlay.overlayY }, 0, 0, ['info-popup-wrapper', vertClass, horClass]);
|
|
44
|
+
});
|
|
45
|
+
const positionStrategy = this._overlay.position()
|
|
46
|
+
.flexibleConnectedTo(this._elementRef)
|
|
47
|
+
.withPositions(positionPairs)
|
|
48
|
+
.withFlexibleDimensions(true)
|
|
49
|
+
.withPush(true);
|
|
50
|
+
this._overlayRef = this._overlay.create({
|
|
51
|
+
panelClass: ['mat-tooltip-panel', 'modal', 'is-active'],
|
|
52
|
+
hasBackdrop: true,
|
|
53
|
+
backdropClass: 'modal-background',
|
|
54
|
+
scrollStrategy: this._overlay.scrollStrategies.reposition(),
|
|
55
|
+
positionStrategy
|
|
56
|
+
});
|
|
57
|
+
if (this._overlayRef && !this._overlayRef.hasAttached()) {
|
|
58
|
+
this._overlayRef.attach(new TemplatePortal(template, this.viewContainerRef));
|
|
59
|
+
this._overlayRef.backdropClick().subscribe(() => this.closePopup());
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
closePopup() {
|
|
63
|
+
if (this._overlayRef) {
|
|
64
|
+
this._overlayRef.detach();
|
|
65
|
+
this._overlayRef = undefined;
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
ngOnInit() {
|
|
69
|
+
if (this.popupPosition !== DEFAULT_TOOLTIP_POSITIONS[0]) {
|
|
70
|
+
const otherPositions = [];
|
|
71
|
+
const filteredByFirstPosition = DEFAULT_TOOLTIP_POSITIONS
|
|
72
|
+
.filter((item) => {
|
|
73
|
+
if (item === this.popupPosition)
|
|
74
|
+
return false;
|
|
75
|
+
if (item.startsWith(this.popupPosition.split('-')[0])) {
|
|
76
|
+
return true;
|
|
77
|
+
}
|
|
78
|
+
else {
|
|
79
|
+
otherPositions.push(item);
|
|
80
|
+
return false;
|
|
81
|
+
}
|
|
82
|
+
});
|
|
83
|
+
this.currentPositions = [this.popupPosition].concat(filteredByFirstPosition).concat(otherPositions);
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
getIconName() {
|
|
87
|
+
switch (this.type) {
|
|
88
|
+
case InfoType.Error:
|
|
89
|
+
return 'error';
|
|
90
|
+
case InfoType.Warning:
|
|
91
|
+
return 'warning';
|
|
92
|
+
case InfoType.TabError:
|
|
93
|
+
return 'bo-error';
|
|
94
|
+
case InfoType.TabWarning:
|
|
95
|
+
return 'bo-warning';
|
|
96
|
+
case InfoType.InfoSmall:
|
|
97
|
+
return 'info-s';
|
|
98
|
+
case InfoType.Filtered:
|
|
99
|
+
return 'filter';
|
|
100
|
+
case InfoType.InlineDetails:
|
|
101
|
+
return 'eye-pick';
|
|
102
|
+
case InfoType.SubNavPanel:
|
|
103
|
+
this.smallIcon = true;
|
|
104
|
+
return 'sub-nav-warning';
|
|
105
|
+
case InfoType.InfoGold:
|
|
106
|
+
return 'info-gold';
|
|
107
|
+
default:
|
|
108
|
+
return 'info';
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
ngOnDestroy() {
|
|
112
|
+
this.closePopup();
|
|
113
|
+
}
|
|
114
|
+
checkPopupPosition(value) {
|
|
115
|
+
let currentPosition;
|
|
116
|
+
switch (value) {
|
|
117
|
+
case 'bottom-left':
|
|
118
|
+
currentPosition = {
|
|
119
|
+
origin: {
|
|
120
|
+
originX: 'end',
|
|
121
|
+
originY: 'bottom'
|
|
122
|
+
},
|
|
123
|
+
overlay: {
|
|
124
|
+
overlayX: 'end',
|
|
125
|
+
overlayY: 'top'
|
|
126
|
+
},
|
|
127
|
+
arrow: {
|
|
128
|
+
bottom: true,
|
|
129
|
+
left: true,
|
|
130
|
+
}
|
|
131
|
+
};
|
|
132
|
+
break;
|
|
133
|
+
case 'top-right':
|
|
134
|
+
currentPosition = {
|
|
135
|
+
origin: {
|
|
136
|
+
originX: 'start',
|
|
137
|
+
originY: 'top',
|
|
138
|
+
},
|
|
139
|
+
overlay: {
|
|
140
|
+
overlayX: 'start',
|
|
141
|
+
overlayY: 'bottom',
|
|
142
|
+
},
|
|
143
|
+
arrow: {
|
|
144
|
+
bottom: false,
|
|
145
|
+
left: true,
|
|
146
|
+
}
|
|
147
|
+
};
|
|
148
|
+
break;
|
|
149
|
+
case 'top-left':
|
|
150
|
+
currentPosition = {
|
|
151
|
+
origin: {
|
|
152
|
+
originX: 'end',
|
|
153
|
+
originY: 'top',
|
|
154
|
+
},
|
|
155
|
+
overlay: {
|
|
156
|
+
overlayX: 'end',
|
|
157
|
+
overlayY: 'bottom',
|
|
158
|
+
},
|
|
159
|
+
arrow: {
|
|
160
|
+
bottom: false,
|
|
161
|
+
left: false,
|
|
162
|
+
}
|
|
163
|
+
};
|
|
164
|
+
break;
|
|
165
|
+
case 'top-center':
|
|
166
|
+
currentPosition = {
|
|
167
|
+
origin: {
|
|
168
|
+
originX: 'center',
|
|
169
|
+
originY: 'top',
|
|
170
|
+
},
|
|
171
|
+
overlay: {
|
|
172
|
+
overlayX: 'center',
|
|
173
|
+
overlayY: 'bottom',
|
|
174
|
+
},
|
|
175
|
+
arrow: {
|
|
176
|
+
bottom: false,
|
|
177
|
+
left: true,
|
|
178
|
+
}
|
|
179
|
+
};
|
|
180
|
+
break;
|
|
181
|
+
case 'bottom-center':
|
|
182
|
+
currentPosition = {
|
|
183
|
+
origin: {
|
|
184
|
+
originX: 'center',
|
|
185
|
+
originY: 'bottom',
|
|
186
|
+
},
|
|
187
|
+
overlay: {
|
|
188
|
+
overlayX: 'center',
|
|
189
|
+
overlayY: 'top',
|
|
190
|
+
},
|
|
191
|
+
arrow: {
|
|
192
|
+
bottom: true,
|
|
193
|
+
left: true,
|
|
194
|
+
}
|
|
195
|
+
};
|
|
196
|
+
break;
|
|
197
|
+
case 'bottom-right':
|
|
198
|
+
default:
|
|
199
|
+
currentPosition = {
|
|
200
|
+
origin: {
|
|
201
|
+
originX: 'start',
|
|
202
|
+
originY: 'bottom',
|
|
203
|
+
},
|
|
204
|
+
overlay: {
|
|
205
|
+
overlayX: 'start',
|
|
206
|
+
overlayY: 'top',
|
|
207
|
+
},
|
|
208
|
+
arrow: {
|
|
209
|
+
bottom: true,
|
|
210
|
+
left: false,
|
|
211
|
+
}
|
|
212
|
+
};
|
|
213
|
+
}
|
|
214
|
+
return currentPosition;
|
|
215
|
+
}
|
|
216
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: WmInfoComponent, deps: [{ token: i1.Overlay }, { token: i0.ElementRef }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
217
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.1", type: WmInfoComponent, selector: "wm-info", inputs: { preText: "preText", postText: "postText", header: "header", type: "type", popupPosition: "popupPosition", iconAsTemplate: "iconAsTemplate", useThemeForIconTemplate: "useThemeForIconTemplate", smallIcon: "smallIcon" }, ngImport: i0, template: "<ng-template #popupTemplate>\r\n <div class=\"u-arrow\">\r\n </div>\r\n <div class=\"u-info-content\" [ngClass]=\"{'p-error': type === 0, 'p-warning': type === 1, 'p-info': type === 2}\">\r\n <span *ngIf=\"header\" [innerHTML]=\"header\"></span>\r\n <ng-content></ng-content>\r\n </div>\r\n</ng-template>\r\n <div class=\"info-wrap flex-row\" [ngClass]=\"{'p-error': type === 0, 'p-warning': type === 1, 'p-info': type === 2}\">\r\n <span class=\"info-label\" *ngIf=\"preText\">{{preText}}</span>\r\n <span class=\"info-icon\" (click)=\"togglePopup(popupTemplate)\">\r\n <wm-template-image *ngIf=\"iconAsTemplate\" [icon]=\"getIconName()\" [size]=\"imageSize\"\r\n [active]=\"useThemeForIconTemplate\">\r\n </wm-template-image>\r\n <img *ngIf=\"!iconAsTemplate\" [attr.width]=\"imageSize\" [attr.height]=\"imageSize\"\r\n src=\"{{'./assets/icon/svg/' + getIconName() + '.svg'}}\" alt=\"{{getIconName()}}\" />\r\n </span>\r\n <span class=\"info-label\" *ngIf=\"postText\">{{postText}}</span>\r\n </div> ", styles: ["@media print{body{all:unset!important}.wm-page{margin:0!important;display:block!important}.not-printable{display:none!important}*{visibility:hidden}.printable,.printable *{visibility:visible!important}}.info-wrap{justify-content:flex-start;align-items:center;height:100%;text-align:center}.info-label{display:inline-block;color:inherit;font-size:14px}.info-icon{cursor:pointer}.info-left{margin-left:-10px;align-items:flex-start}.info-right{align-items:flex-end}.u-arrow{margin-left:4px;margin-right:4px}.u-info-content{color:var(--infoColor);text-align:left;font-size:14px;font-weight:400;max-width:50vw;white-space:normal;word-wrap:break-word;word-break:break-word;background:var(--pageBackgroundColor);overflow-x:hidden;overflow-y:auto;border-color:var(--secondaryHover);border-radius:4px;padding:16px;box-shadow:0 16px 16px -1px #051d391a}.u-info-content::-webkit-scrollbar{width:4px}.p-error{color:var(--dangerColor)}.p-warning{color:var(--warningColor)}.p-info{color:var(--brandColor)}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.WmTemplateImageComponent, selector: "wm-template-image", inputs: ["icon", "disabled", "active", "light", "classes", "backgroundColor", "size", "sizeBox"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
218
|
+
}
|
|
219
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: WmInfoComponent, decorators: [{
|
|
220
|
+
type: Component,
|
|
221
|
+
args: [{ selector: 'wm-info', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-template #popupTemplate>\r\n <div class=\"u-arrow\">\r\n </div>\r\n <div class=\"u-info-content\" [ngClass]=\"{'p-error': type === 0, 'p-warning': type === 1, 'p-info': type === 2}\">\r\n <span *ngIf=\"header\" [innerHTML]=\"header\"></span>\r\n <ng-content></ng-content>\r\n </div>\r\n</ng-template>\r\n <div class=\"info-wrap flex-row\" [ngClass]=\"{'p-error': type === 0, 'p-warning': type === 1, 'p-info': type === 2}\">\r\n <span class=\"info-label\" *ngIf=\"preText\">{{preText}}</span>\r\n <span class=\"info-icon\" (click)=\"togglePopup(popupTemplate)\">\r\n <wm-template-image *ngIf=\"iconAsTemplate\" [icon]=\"getIconName()\" [size]=\"imageSize\"\r\n [active]=\"useThemeForIconTemplate\">\r\n </wm-template-image>\r\n <img *ngIf=\"!iconAsTemplate\" [attr.width]=\"imageSize\" [attr.height]=\"imageSize\"\r\n src=\"{{'./assets/icon/svg/' + getIconName() + '.svg'}}\" alt=\"{{getIconName()}}\" />\r\n </span>\r\n <span class=\"info-label\" *ngIf=\"postText\">{{postText}}</span>\r\n </div> ", styles: ["@media print{body{all:unset!important}.wm-page{margin:0!important;display:block!important}.not-printable{display:none!important}*{visibility:hidden}.printable,.printable *{visibility:visible!important}}.info-wrap{justify-content:flex-start;align-items:center;height:100%;text-align:center}.info-label{display:inline-block;color:inherit;font-size:14px}.info-icon{cursor:pointer}.info-left{margin-left:-10px;align-items:flex-start}.info-right{align-items:flex-end}.u-arrow{margin-left:4px;margin-right:4px}.u-info-content{color:var(--infoColor);text-align:left;font-size:14px;font-weight:400;max-width:50vw;white-space:normal;word-wrap:break-word;word-break:break-word;background:var(--pageBackgroundColor);overflow-x:hidden;overflow-y:auto;border-color:var(--secondaryHover);border-radius:4px;padding:16px;box-shadow:0 16px 16px -1px #051d391a}.u-info-content::-webkit-scrollbar{width:4px}.p-error{color:var(--dangerColor)}.p-warning{color:var(--warningColor)}.p-info{color:var(--brandColor)}\n"] }]
|
|
222
|
+
}], ctorParameters: () => [{ type: i1.Overlay }, { type: i0.ElementRef }, { type: i0.ViewContainerRef }], propDecorators: { preText: [{
|
|
223
|
+
type: Input
|
|
224
|
+
}], postText: [{
|
|
225
|
+
type: Input
|
|
226
|
+
}], header: [{
|
|
227
|
+
type: Input
|
|
228
|
+
}], type: [{
|
|
229
|
+
type: Input
|
|
230
|
+
}], popupPosition: [{
|
|
231
|
+
type: Input
|
|
232
|
+
}], iconAsTemplate: [{
|
|
233
|
+
type: Input
|
|
234
|
+
}], useThemeForIconTemplate: [{
|
|
235
|
+
type: Input
|
|
236
|
+
}], smallIcon: [{
|
|
237
|
+
type: Input
|
|
238
|
+
}] } });
|
|
239
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"wm-info.component.js","sourceRoot":"","sources":["../../../../../projects/btv-base-controls/src/lib/wm-info/wm-info.component.ts","../../../../../projects/btv-base-controls/src/lib/wm-info/wm-info.html"],"names":[],"mappings":"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","sourcesContent":["import { ConnectionPositionPair, Overlay, OverlayRef } from '@angular/cdk/overlay';\r\nimport { TemplatePortal } from '@angular/cdk/portal';\r\nimport { Component, Input, OnInit, ChangeDetectionStrategy, TemplateRef, ElementRef, OnDestroy, ViewContainerRef } from '@angular/core';\r\nimport { InfoType, IWmInfoPositionPopup } from './info-models';\r\n\r\nconst DEFAULT_TOOLTIP_POSITIONS = ['bottom-right', 'bottom-center', 'bottom-left', 'top-right', 'top-center', 'top-left'];\r\n\r\n@Component({\r\n  selector: 'wm-info',\r\n  styleUrls: ['./wm-info.scss'],\r\n  templateUrl: './wm-info.html',\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\n\r\nexport class WmInfoComponent implements OnInit, OnDestroy {\r\n\r\n  @Input() preText: string = '';\r\n  @Input() postText: string = '';\r\n  @Input() header: string;\r\n  @Input() type: InfoType = InfoType.Error;\r\n  @Input() popupPosition: string = 'bottom-right';\r\n  @Input() iconAsTemplate: boolean;\r\n  @Input() useThemeForIconTemplate: boolean = false;\r\n  @Input() smallIcon: boolean;\r\n  defaultIconSize = 24;\r\n  smallIconSize = 16;\r\n  positionBottom: boolean = true;\r\n  positionLeft: boolean = true;\r\n  currentPositions: string[] = DEFAULT_TOOLTIP_POSITIONS;\r\n\r\n  get imageSize() {\r\n    return (this.smallIcon ? this.smallIconSize : this.defaultIconSize) + 'px';\r\n  }\r\n\r\n  private _overlayRef: OverlayRef;\r\n\r\n  constructor(private _overlay: Overlay,\r\n    private _elementRef: ElementRef, private viewContainerRef: ViewContainerRef) {\r\n\r\n  }\r\n\r\n  public togglePopup(template: TemplateRef<any>) {\r\n    if (this._overlayRef) {\r\n      this.closePopup();\r\n    } else {\r\n      this.openPopup(template);\r\n    }\r\n  }\r\n\r\n  private openPopup(template: TemplateRef<any>) {\r\n    this.closePopup(); // close any old ones.\r\n\r\n    const positionPairs: ConnectionPositionPair[] = this.currentPositions.map(position => {\r\n      const data: IWmInfoPositionPopup = this.checkPopupPosition(position);\r\n      const vertClass = data.arrow.bottom ? 'info-bottom' : 'info-top';\r\n      const horClass = data.arrow.left ? 'info-left' : 'info-right';\r\n      return new ConnectionPositionPair(\r\n        { originX: data.origin.originX, originY: data.origin.originY },\r\n        { overlayX: data.overlay.overlayX, overlayY: data.overlay.overlayY }, 0, 0,\r\n        ['info-popup-wrapper', vertClass, horClass]\r\n      );\r\n    });\r\n    const positionStrategy = this._overlay.position()\r\n      .flexibleConnectedTo(this._elementRef)\r\n      .withPositions(positionPairs)\r\n      .withFlexibleDimensions(true)\r\n      .withPush(true);\r\n\r\n    this._overlayRef = this._overlay.create({\r\n      panelClass: ['mat-tooltip-panel', 'modal', 'is-active'],\r\n      hasBackdrop: true,\r\n      backdropClass: 'modal-background',\r\n      scrollStrategy: this._overlay.scrollStrategies.reposition(),\r\n      positionStrategy\r\n    });\r\n    if (this._overlayRef && !this._overlayRef.hasAttached()) {\r\n      this._overlayRef.attach(new TemplatePortal(template, this.viewContainerRef));\r\n      this._overlayRef.backdropClick().subscribe(() => this.closePopup());\r\n    }\r\n  }\r\n\r\n  private closePopup() {\r\n    if (this._overlayRef) {\r\n      this._overlayRef.detach();\r\n      this._overlayRef = undefined;\r\n    }\r\n  }\r\n\r\n  ngOnInit() {\r\n    if (this.popupPosition !== DEFAULT_TOOLTIP_POSITIONS[0]) {\r\n      const otherPositions = [];\r\n      const filteredByFirstPosition = DEFAULT_TOOLTIP_POSITIONS\r\n        .filter((item) => {\r\n          if (item === this.popupPosition) return false;\r\n          if (item.startsWith(this.popupPosition.split('-')[0])) {\r\n            return true;\r\n          } else {\r\n            otherPositions.push(item);\r\n            return false;\r\n          }\r\n        });\r\n      this.currentPositions = [this.popupPosition].concat(filteredByFirstPosition).concat(otherPositions);\r\n    }\r\n  }\r\n\r\n  public getIconName() {\r\n    switch (this.type) {\r\n      case InfoType.Error:\r\n        return 'error';\r\n      case InfoType.Warning:\r\n        return 'warning';\r\n      case InfoType.TabError:\r\n        return 'bo-error';\r\n      case InfoType.TabWarning:\r\n        return 'bo-warning';\r\n      case InfoType.InfoSmall:\r\n        return 'info-s';\r\n      case InfoType.Filtered:\r\n        return 'filter';\r\n      case InfoType.InlineDetails:\r\n        return 'eye-pick';\r\n      case InfoType.SubNavPanel:\r\n        this.smallIcon = true;\r\n        return 'sub-nav-warning';\r\n      case InfoType.InfoGold:\r\n        return 'info-gold';\r\n      default:\r\n        return 'info';\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.closePopup();\r\n  }\r\n\r\n  checkPopupPosition(value: string): IWmInfoPositionPopup {\r\n    let currentPosition: IWmInfoPositionPopup;\r\n    switch (value) {\r\n      case 'bottom-left':\r\n        currentPosition = {\r\n          origin: {\r\n            originX: 'end',\r\n            originY: 'bottom'\r\n          },\r\n          overlay: {\r\n            overlayX: 'end',\r\n            overlayY: 'top'\r\n          },\r\n          arrow: {\r\n            bottom: true,\r\n            left: true,\r\n          }\r\n        };\r\n        break;\r\n      case 'top-right':\r\n        currentPosition = {\r\n          origin: {\r\n            originX: 'start',\r\n            originY: 'top',\r\n          },\r\n          overlay: {\r\n            overlayX: 'start',\r\n            overlayY: 'bottom',\r\n          },\r\n          arrow: {\r\n            bottom: false,\r\n            left: true,\r\n          }\r\n        };\r\n        break;\r\n      case 'top-left':\r\n        currentPosition = {\r\n          origin: {\r\n            originX: 'end',\r\n            originY: 'top',\r\n          },\r\n          overlay: {\r\n            overlayX: 'end',\r\n            overlayY: 'bottom',\r\n          },\r\n          arrow: {\r\n            bottom: false,\r\n            left: false,\r\n          }\r\n        };\r\n        break;\r\n      case 'top-center':\r\n        currentPosition = {\r\n          origin: {\r\n            originX: 'center',\r\n            originY: 'top',\r\n          },\r\n          overlay: {\r\n            overlayX: 'center',\r\n            overlayY: 'bottom',\r\n          },\r\n          arrow: {\r\n            bottom: false,\r\n            left: true,\r\n          }\r\n        };\r\n        break;\r\n      case 'bottom-center':\r\n        currentPosition = {\r\n          origin: {\r\n            originX: 'center',\r\n            originY: 'bottom',\r\n          },\r\n          overlay: {\r\n            overlayX: 'center',\r\n            overlayY: 'top',\r\n          },\r\n          arrow: {\r\n            bottom: true,\r\n            left: true,\r\n          }\r\n        };\r\n        break;\r\n      case 'bottom-right':\r\n      default:\r\n        currentPosition = {\r\n          origin: {\r\n            originX: 'start',\r\n            originY: 'bottom',\r\n          },\r\n          overlay: {\r\n            overlayX: 'start',\r\n            overlayY: 'top',\r\n          },\r\n          arrow: {\r\n            bottom: true,\r\n            left: false,\r\n          }\r\n        };\r\n    }\r\n    return currentPosition;\r\n  }\r\n}\r\n","<ng-template #popupTemplate>\r\n  <div class=\"u-arrow\">\r\n  </div>\r\n  <div class=\"u-info-content\" [ngClass]=\"{'p-error': type === 0, 'p-warning': type === 1, 'p-info': type === 2}\">\r\n    <span *ngIf=\"header\" [innerHTML]=\"header\"></span>\r\n    <ng-content></ng-content>\r\n  </div>\r\n</ng-template>\r\n <div class=\"info-wrap flex-row\" [ngClass]=\"{'p-error': type === 0, 'p-warning': type === 1, 'p-info': type === 2}\">\r\n    <span class=\"info-label\" *ngIf=\"preText\">{{preText}}</span>\r\n    <span class=\"info-icon\" (click)=\"togglePopup(popupTemplate)\">\r\n      <wm-template-image *ngIf=\"iconAsTemplate\" [icon]=\"getIconName()\" [size]=\"imageSize\"\r\n        [active]=\"useThemeForIconTemplate\">\r\n      </wm-template-image>\r\n      <img *ngIf=\"!iconAsTemplate\" [attr.width]=\"imageSize\" [attr.height]=\"imageSize\"\r\n        src=\"{{'./assets/icon/svg/' + getIconName() + '.svg'}}\" alt=\"{{getIconName()}}\" />\r\n    </span>\r\n    <span class=\"info-label\" *ngIf=\"postText\">{{postText}}</span>\r\n  </div> "]}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common";
|
|
4
|
+
export class InfoCardComponent {
|
|
5
|
+
constructor() {
|
|
6
|
+
this.useCustomIcon = false;
|
|
7
|
+
}
|
|
8
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: InfoCardComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
9
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.1", type: InfoCardComponent, selector: "wm-info-card", inputs: { label: "label", value: "value", icon: "icon", useCustomIcon: "useCustomIcon" }, ngImport: i0, template: "<div class=\"wm-info-card flex-row\">\r\n <div class=\"info-icon\" *ngIf=\"!useCustomIcon\">\r\n <div class=\"icon-bg\"></div>\r\n <img class=\"info-svg\" src=\"{{'./assets/icon/svg/' + icon + '.svg'}}\" alt=\"type\" />\r\n </div>\r\n <div class=\"info-icon\" *ngIf=\"useCustomIcon\">\r\n <ng-content select=\"[wmCustomIcon]\"></ng-content>\r\n </div>\r\n <div class=\"flex-col info-content\">\r\n <div class=\"info-card-value text-hidden\" title=\"{{value}}\">{{value}}</div>\r\n <div class=\"info-card-label text-hidden\" title=\"{{label}}\">{{label}}</div>\r\n </div>\r\n</div>", styles: ["@media print{body{all:unset!important}.wm-page{margin:0!important;display:block!important}.not-printable{display:none!important}*{visibility:hidden}.printable,.printable *{visibility:visible!important}}.wm-info-card{background:var(--pageBackgroundColor);width:100%;height:100px;margin-right:18px;padding:25px;border-radius:4px;box-sizing:border-box}.info-icon{display:inline-flex;width:48px;height:48px;border:1px solid transparent;border-radius:50%;margin:auto 18px auto 0;flex-shrink:0;position:relative;overflow:hidden}.icon-bg{width:100%;height:100%;position:absolute;background-color:var(--strongFontColor);opacity:.05}.info-svg{margin:auto;width:24px;height:24px;z-index:1}.info-content{justify-content:center;flex-grow:1;flex-shrink:1;overflow:hidden}.info-card-value{color:var(--strongFontColor);line-height:20px;font-size:22px;width:100%;height:20px;margin-bottom:2px}.info-card-label{color:var(--disabledTextColor);font-size:14px}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
|
|
10
|
+
}
|
|
11
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: InfoCardComponent, decorators: [{
|
|
12
|
+
type: Component,
|
|
13
|
+
args: [{ selector: 'wm-info-card', template: "<div class=\"wm-info-card flex-row\">\r\n <div class=\"info-icon\" *ngIf=\"!useCustomIcon\">\r\n <div class=\"icon-bg\"></div>\r\n <img class=\"info-svg\" src=\"{{'./assets/icon/svg/' + icon + '.svg'}}\" alt=\"type\" />\r\n </div>\r\n <div class=\"info-icon\" *ngIf=\"useCustomIcon\">\r\n <ng-content select=\"[wmCustomIcon]\"></ng-content>\r\n </div>\r\n <div class=\"flex-col info-content\">\r\n <div class=\"info-card-value text-hidden\" title=\"{{value}}\">{{value}}</div>\r\n <div class=\"info-card-label text-hidden\" title=\"{{label}}\">{{label}}</div>\r\n </div>\r\n</div>", styles: ["@media print{body{all:unset!important}.wm-page{margin:0!important;display:block!important}.not-printable{display:none!important}*{visibility:hidden}.printable,.printable *{visibility:visible!important}}.wm-info-card{background:var(--pageBackgroundColor);width:100%;height:100px;margin-right:18px;padding:25px;border-radius:4px;box-sizing:border-box}.info-icon{display:inline-flex;width:48px;height:48px;border:1px solid transparent;border-radius:50%;margin:auto 18px auto 0;flex-shrink:0;position:relative;overflow:hidden}.icon-bg{width:100%;height:100%;position:absolute;background-color:var(--strongFontColor);opacity:.05}.info-svg{margin:auto;width:24px;height:24px;z-index:1}.info-content{justify-content:center;flex-grow:1;flex-shrink:1;overflow:hidden}.info-card-value{color:var(--strongFontColor);line-height:20px;font-size:22px;width:100%;height:20px;margin-bottom:2px}.info-card-label{color:var(--disabledTextColor);font-size:14px}\n"] }]
|
|
14
|
+
}], propDecorators: { label: [{
|
|
15
|
+
type: Input
|
|
16
|
+
}], value: [{
|
|
17
|
+
type: Input
|
|
18
|
+
}], icon: [{
|
|
19
|
+
type: Input
|
|
20
|
+
}], useCustomIcon: [{
|
|
21
|
+
type: Input
|
|
22
|
+
}] } });
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid20taW5mby1jYXJkLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2J0di1iYXNlLWNvbnRyb2xzL3NyYy9saWIvd20taW5mby1jYXJkL3dtLWluZm8tY2FyZC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9idHYtYmFzZS1jb250cm9scy9zcmMvbGliL3dtLWluZm8tY2FyZC93bS1pbmZvLWNhcmQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQzs7O0FBUWpELE1BQU0sT0FBTyxpQkFBaUI7SUFOOUI7UUFVYSxrQkFBYSxHQUFZLEtBQUssQ0FBQztLQUMzQzs4R0FMWSxpQkFBaUI7a0dBQWpCLGlCQUFpQiw4SUNSOUIsMm5CQVlNOzsyRkRKTyxpQkFBaUI7a0JBTjdCLFNBQVM7K0JBQ0ksY0FBYzs4QkFNZixLQUFLO3NCQUFiLEtBQUs7Z0JBQ0csS0FBSztzQkFBYixLQUFLO2dCQUNHLElBQUk7c0JBQVosS0FBSztnQkFDRyxhQUFhO3NCQUFyQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgICBzZWxlY3RvcjogJ3dtLWluZm8tY2FyZCcsXHJcbiAgICBzdHlsZVVybHM6IFsnLi93bS1pbmZvLWNhcmQuc2NzcyddLFxyXG4gICAgdGVtcGxhdGVVcmw6ICcuL3dtLWluZm8tY2FyZC5odG1sJ1xyXG59KVxyXG5cclxuZXhwb3J0IGNsYXNzIEluZm9DYXJkQ29tcG9uZW50IHtcclxuICAgIEBJbnB1dCgpIGxhYmVsOiBzdHJpbmc7XHJcbiAgICBASW5wdXQoKSB2YWx1ZTogbnVtYmVyIHwgc3RyaW5nO1xyXG4gICAgQElucHV0KCkgaWNvbjogc3RyaW5nO1xyXG4gICAgQElucHV0KCkgdXNlQ3VzdG9tSWNvbjogYm9vbGVhbiA9IGZhbHNlO1xyXG59XHJcbiIsIjxkaXYgY2xhc3M9XCJ3bS1pbmZvLWNhcmQgZmxleC1yb3dcIj5cclxuICAgIDxkaXYgY2xhc3M9XCJpbmZvLWljb25cIiAqbmdJZj1cIiF1c2VDdXN0b21JY29uXCI+XHJcbiAgICAgICAgPGRpdiBjbGFzcz1cImljb24tYmdcIj48L2Rpdj5cclxuICAgICAgICA8aW1nIGNsYXNzPVwiaW5mby1zdmdcIiBzcmM9XCJ7eycuL2Fzc2V0cy9pY29uL3N2Zy8nICsgaWNvbiArICcuc3ZnJ319XCIgYWx0PVwidHlwZVwiIC8+XHJcbiAgICA8L2Rpdj5cclxuICAgIDxkaXYgY2xhc3M9XCJpbmZvLWljb25cIiAqbmdJZj1cInVzZUN1c3RvbUljb25cIj5cclxuICAgICAgICA8bmctY29udGVudCBzZWxlY3Q9XCJbd21DdXN0b21JY29uXVwiPjwvbmctY29udGVudD5cclxuICAgIDwvZGl2PlxyXG4gICAgPGRpdiBjbGFzcz1cImZsZXgtY29sIGluZm8tY29udGVudFwiPlxyXG4gICAgICAgIDxkaXYgY2xhc3M9XCJpbmZvLWNhcmQtdmFsdWUgdGV4dC1oaWRkZW5cIiB0aXRsZT1cInt7dmFsdWV9fVwiPnt7dmFsdWV9fTwvZGl2PlxyXG4gICAgICAgIDxkaXYgY2xhc3M9XCJpbmZvLWNhcmQtbGFiZWwgdGV4dC1oaWRkZW5cIiB0aXRsZT1cInt7bGFiZWx9fVwiPnt7bGFiZWx9fTwvZGl2PlxyXG4gICAgPC9kaXY+XHJcbjwvZGl2PiJdfQ==
|