btv-base-controls 0.1.20 → 0.1.22
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/README.md +24 -24
- package/{esm2022 → esm2020}/btv-base-controls.mjs +4 -4
- package/{esm2022 → esm2020}/lib/basic.module.mjs +64 -64
- package/esm2020/lib/blink-message/blink-message.component.mjs +54 -0
- package/{esm2022 → esm2020}/lib/btv-icon-button/btv-counter-button.mjs +47 -47
- package/esm2020/lib/btv-icon-button/btv-icon-button.component.mjs +89 -0
- package/esm2020/lib/btv-progress/btv-progress.component.mjs +71 -0
- package/esm2020/lib/btv-search/btv-search.component.mjs +82 -0
- package/{esm2022 → esm2020}/lib/busy-indicator/busy-indicator.component.mjs +16 -16
- package/{esm2022 → esm2020}/lib/custom-tool-tip/custom-tool-tip.component.mjs +34 -34
- package/esm2020/lib/custom-tool-tip/tool-tip-renderer.directive.mjs +113 -0
- package/{esm2022 → esm2020}/lib/illustration/illustration.component.mjs +17 -17
- package/esm2020/lib/wm-avatar/avatar.component.mjs +175 -0
- package/{esm2022 → esm2020}/lib/wm-back-btn/wm-back-btn.component.mjs +26 -26
- package/{esm2022 → esm2020}/lib/wm-beta-text/wm-beta-text.component.mjs +19 -19
- package/{esm2022 → esm2020}/lib/wm-info/info-models.mjs +12 -12
- package/esm2020/lib/wm-info/wm-info.component.mjs +237 -0
- package/{esm2022 → esm2020}/lib/wm-info-card/wm-info-card.component.mjs +23 -23
- package/{esm2022 → esm2020}/lib/wm-no-content/wm-no-content.component.mjs +30 -30
- package/esm2020/lib/wm-panel-bar/wm-panel-bar.component.mjs +78 -0
- package/esm2020/lib/wm-scalable-div/scalable-div.component.mjs +105 -0
- package/esm2020/lib/wm-spinner/wm-spinner.component.mjs +135 -0
- package/{esm2022 → esm2020}/lib/wm-state-icon/wm-state-icon.component.mjs +18 -18
- package/{esm2022 → esm2020}/lib/wm-tag/wm-tag.component.mjs +28 -28
- package/esm2020/lib/wm-tamplate-image/wm-template-image.component.mjs +71 -0
- package/{esm2022 → esm2020}/lib/wm-toggle/wm-toggle.component.mjs +31 -31
- package/{esm2022 → esm2020}/models/guidExtension.mjs +14 -14
- package/{esm2022 → esm2020}/public-api.mjs +27 -27
- package/fesm2015/btv-base-controls.mjs +1479 -0
- package/fesm2015/btv-base-controls.mjs.map +1 -0
- package/{fesm2022 → fesm2020}/btv-base-controls.mjs +1427 -1427
- package/{fesm2022 → fesm2020}/btv-base-controls.mjs.map +1 -1
- package/index.d.ts +5 -5
- package/lib/basic.module.d.ts +33 -33
- package/lib/blink-message/blink-message.component.d.ts +20 -20
- package/lib/btv-icon-button/btv-counter-button.d.ts +12 -12
- package/lib/btv-icon-button/btv-icon-button.component.d.ts +30 -30
- package/lib/btv-progress/btv-progress.component.d.ts +20 -20
- package/lib/btv-search/btv-search.component.d.ts +31 -31
- package/lib/busy-indicator/busy-indicator.component.d.ts +7 -7
- package/lib/custom-tool-tip/custom-tool-tip.component.d.ts +35 -35
- package/lib/custom-tool-tip/tool-tip-renderer.directive.d.ts +49 -49
- package/lib/illustration/illustration.component.d.ts +10 -10
- package/lib/wm-avatar/avatar.component.d.ts +63 -63
- package/lib/wm-back-btn/wm-back-btn.component.d.ts +10 -10
- package/lib/wm-beta-text/wm-beta-text.component.d.ts +7 -7
- package/lib/wm-info/info-models.d.ts +20 -20
- package/lib/wm-info/wm-info.component.d.ts +34 -34
- package/lib/wm-info-card/wm-info-card.component.d.ts +9 -9
- package/lib/wm-no-content/wm-no-content.component.d.ts +11 -11
- package/lib/wm-panel-bar/wm-panel-bar.component.d.ts +25 -25
- package/lib/wm-scalable-div/scalable-div.component.d.ts +24 -24
- package/lib/wm-spinner/wm-spinner.component.d.ts +37 -37
- package/lib/wm-state-icon/wm-state-icon.component.d.ts +9 -9
- package/lib/wm-tag/wm-tag.component.d.ts +10 -10
- package/lib/wm-tamplate-image/wm-template-image.component.d.ts +49 -49
- package/lib/wm-toggle/wm-toggle.component.d.ts +11 -11
- package/models/guidExtension.d.ts +5 -5
- package/package.json +11 -5
- package/public-api.d.ts +24 -24
- package/esm2022/lib/blink-message/blink-message.component.mjs +0 -54
- package/esm2022/lib/btv-icon-button/btv-icon-button.component.mjs +0 -89
- package/esm2022/lib/btv-progress/btv-progress.component.mjs +0 -71
- package/esm2022/lib/btv-search/btv-search.component.mjs +0 -82
- package/esm2022/lib/custom-tool-tip/tool-tip-renderer.directive.mjs +0 -113
- package/esm2022/lib/wm-avatar/avatar.component.mjs +0 -175
- package/esm2022/lib/wm-info/wm-info.component.mjs +0 -237
- package/esm2022/lib/wm-panel-bar/wm-panel-bar.component.mjs +0 -78
- package/esm2022/lib/wm-scalable-div/scalable-div.component.mjs +0 -105
- package/esm2022/lib/wm-spinner/wm-spinner.component.mjs +0 -135
- package/esm2022/lib/wm-tamplate-image/wm-template-image.component.mjs +0 -71
|
@@ -1,113 +0,0 @@
|
|
|
1
|
-
import { Directive, Input, HostListener } from '@angular/core';
|
|
2
|
-
import { ConnectionPositionPair } from '@angular/cdk/overlay';
|
|
3
|
-
import { CustomToolTipComponent } from './custom-tool-tip.component';
|
|
4
|
-
import { ComponentPortal } from '@angular/cdk/portal';
|
|
5
|
-
import * as i0 from "@angular/core";
|
|
6
|
-
import * as i1 from "@angular/cdk/overlay";
|
|
7
|
-
export class ToolTipRendererDirective {
|
|
8
|
-
constructor(_overlay, _elementRef) {
|
|
9
|
-
this._overlay = _overlay;
|
|
10
|
-
this._elementRef = _elementRef;
|
|
11
|
-
/**
|
|
12
|
-
* This will be used to show tooltip or not
|
|
13
|
-
* This can be used to show the tooltip conditionally
|
|
14
|
-
*/
|
|
15
|
-
this.showToolTip = true;
|
|
16
|
-
this.useCustom = false;
|
|
17
|
-
}
|
|
18
|
-
/**
|
|
19
|
-
* Init life cycle event handler
|
|
20
|
-
*/
|
|
21
|
-
ngOnInit() { }
|
|
22
|
-
get refElement() {
|
|
23
|
-
if (this.useCustom || this.customAnchor)
|
|
24
|
-
return this.customAnchor;
|
|
25
|
-
return this._elementRef;
|
|
26
|
-
}
|
|
27
|
-
/**
|
|
28
|
-
* This method will be called whenever mouse enters in the Host element
|
|
29
|
-
* i.e. where this directive is applied
|
|
30
|
-
* This method will show the tooltip by instantiating the McToolTipComponent and attaching to the overlay
|
|
31
|
-
*/
|
|
32
|
-
show() {
|
|
33
|
-
if (this.refElement)
|
|
34
|
-
this.closeToolTip();
|
|
35
|
-
if (!this.showToolTip || (this.useCustom && !this.customAnchor)) {
|
|
36
|
-
return;
|
|
37
|
-
}
|
|
38
|
-
const positionPairs = [
|
|
39
|
-
new ConnectionPositionPair({ originX: 'center', originY: 'top' }, { overlayX: 'center', overlayY: 'bottom' }, 0, 0, 'mat-tooltip-panel-above'),
|
|
40
|
-
new ConnectionPositionPair({ originX: 'center', originY: 'bottom' }, { overlayX: 'center', overlayY: 'top' }, 0, 0, 'mat-tooltip-panel-below')
|
|
41
|
-
];
|
|
42
|
-
const positionStrategy = this._overlay.position()
|
|
43
|
-
.flexibleConnectedTo(this.refElement)
|
|
44
|
-
.withPositions(positionPairs)
|
|
45
|
-
.withFlexibleDimensions(true)
|
|
46
|
-
.withPush(true);
|
|
47
|
-
this._overlayRef = this._overlay.create({
|
|
48
|
-
panelClass: 'mat-tooltip-panel',
|
|
49
|
-
scrollStrategy: this._overlay.scrollStrategies.close(),
|
|
50
|
-
positionStrategy
|
|
51
|
-
});
|
|
52
|
-
// attach the component if it has not already attached to the overlay
|
|
53
|
-
if (this._overlayRef && !this._overlayRef.hasAttached()) {
|
|
54
|
-
const content = new ComponentPortal(CustomToolTipComponent);
|
|
55
|
-
// todo check this
|
|
56
|
-
const tooltipRef = this._overlayRef.attach(content);
|
|
57
|
-
tooltipRef.instance.text = this.text;
|
|
58
|
-
tooltipRef.instance.contentTemplate = this.contentTemplate;
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
/**
|
|
62
|
-
* This method will be called when mouse goes out of the host element
|
|
63
|
-
* i.e. where this directive is applied
|
|
64
|
-
* This method will close the tooltip by detaching the overlay from the view
|
|
65
|
-
*/
|
|
66
|
-
hide() {
|
|
67
|
-
this.closeToolTip();
|
|
68
|
-
}
|
|
69
|
-
/**
|
|
70
|
-
* Destroy lifecycle event handler
|
|
71
|
-
* This method will make sure to close the tooltip
|
|
72
|
-
* It will be needed in case when app is navigating to different page
|
|
73
|
-
* and user is still seeing the tooltip; In that case we do not want to hang around the
|
|
74
|
-
* tooltip after the page [on which tooltip visible] is destroyed
|
|
75
|
-
*/
|
|
76
|
-
ngOnDestroy() {
|
|
77
|
-
this.closeToolTip();
|
|
78
|
-
}
|
|
79
|
-
/**
|
|
80
|
-
* This method will close the tooltip by detaching the component from the overlay
|
|
81
|
-
*/
|
|
82
|
-
closeToolTip() {
|
|
83
|
-
if (this._overlayRef) {
|
|
84
|
-
this._overlayRef.detach();
|
|
85
|
-
}
|
|
86
|
-
}
|
|
87
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: ToolTipRendererDirective, deps: [{ token: i1.Overlay }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
88
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.0.1", type: ToolTipRendererDirective, selector: "[customToolTip]", inputs: { showToolTip: "showToolTip", text: ["customToolTip", "text"], contentTemplate: "contentTemplate", customAnchor: "customAnchor", useCustom: "useCustom" }, host: { listeners: { "mousemove": "show($event)", "mouseleave": "hide()" } }, ngImport: i0 }); }
|
|
89
|
-
}
|
|
90
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: ToolTipRendererDirective, decorators: [{
|
|
91
|
-
type: Directive,
|
|
92
|
-
args: [{
|
|
93
|
-
selector: '[customToolTip]'
|
|
94
|
-
}]
|
|
95
|
-
}], ctorParameters: () => [{ type: i1.Overlay }, { type: i0.ElementRef }], propDecorators: { showToolTip: [{
|
|
96
|
-
type: Input
|
|
97
|
-
}], text: [{
|
|
98
|
-
type: Input,
|
|
99
|
-
args: [`customToolTip`]
|
|
100
|
-
}], contentTemplate: [{
|
|
101
|
-
type: Input
|
|
102
|
-
}], customAnchor: [{
|
|
103
|
-
type: Input
|
|
104
|
-
}], useCustom: [{
|
|
105
|
-
type: Input
|
|
106
|
-
}], show: [{
|
|
107
|
-
type: HostListener,
|
|
108
|
-
args: ['mousemove', ['$event']]
|
|
109
|
-
}], hide: [{
|
|
110
|
-
type: HostListener,
|
|
111
|
-
args: ['mouseleave']
|
|
112
|
-
}] } });
|
|
113
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tool-tip-renderer.directive.js","sourceRoot":"","sources":["../../../../../projects/btv-base-controls/src/lib/custom-tool-tip/tool-tip-renderer.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, Input, TemplateRef, ElementRef, OnInit, HostListener, ComponentRef } from '@angular/core';\r\nimport { ConnectionPositionPair, Overlay, OverlayRef } from '@angular/cdk/overlay';\r\nimport { CustomToolTipComponent } from './custom-tool-tip.component';\r\nimport { ComponentPortal } from '@angular/cdk/portal';\r\n\r\n@Directive({\r\n    selector: '[customToolTip]'\r\n})\r\n\r\nexport class ToolTipRendererDirective implements OnInit {\r\n    /**\r\n    * This will be used to show tooltip or not\r\n    * This can be used to show the tooltip conditionally\r\n    */\r\n    @Input() showToolTip: boolean = true;\r\n\r\n    //If this is specified then specified text will be shown in the tooltip\r\n    @Input(`customToolTip`) text: string;\r\n\r\n    //If this is specified then specified template will be rendered in the tooltip\r\n    @Input() contentTemplate: TemplateRef<any>;\r\n    private _overlayRef: OverlayRef;\r\n    @Input() customAnchor?: any;\r\n    @Input() useCustom?: boolean = false;\r\n\r\n    constructor(private _overlay: Overlay,\r\n        private _elementRef: ElementRef) { }\r\n\r\n    /**\r\n     * Init life cycle event handler\r\n     */\r\n    ngOnInit() { }\r\n\r\n    get refElement() {\r\n        if (this.useCustom || this.customAnchor) return this.customAnchor;\r\n        return this._elementRef;\r\n    }\r\n    /**\r\n     * This method will be called whenever mouse enters in the Host element\r\n     * i.e. where this directive is applied\r\n     * This method will show the tooltip by instantiating the McToolTipComponent and attaching to the overlay\r\n     */\r\n    @HostListener('mousemove', ['$event'])\r\n    show() {\r\n        if (this.refElement) this.closeToolTip();\r\n        if (!this.showToolTip || (this.useCustom && !this.customAnchor)) {\r\n            return;\r\n        }\r\n\r\n        const positionPairs: ConnectionPositionPair[] = [\r\n            new ConnectionPositionPair(\r\n                { originX: 'center', originY: 'top' },\r\n                { overlayX: 'center', overlayY: 'bottom' }, 0, 0,\r\n                'mat-tooltip-panel-above'),\r\n            new ConnectionPositionPair(\r\n                { originX: 'center', originY: 'bottom' },\r\n                { overlayX: 'center', overlayY: 'top' }, 0, 0,\r\n                'mat-tooltip-panel-below')\r\n\r\n        ];\r\n        const positionStrategy = this._overlay.position()\r\n            .flexibleConnectedTo(this.refElement)\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',\r\n            scrollStrategy: this._overlay.scrollStrategies.close(),\r\n            positionStrategy\r\n        });\r\n        // attach the component if it has not already attached to the overlay\r\n        if (this._overlayRef && !this._overlayRef.hasAttached()) {\r\n            const content = new ComponentPortal(CustomToolTipComponent);\r\n            // todo check this\r\n            const tooltipRef: ComponentRef<CustomToolTipComponent> = this._overlayRef.attach(content) as any;\r\n            tooltipRef.instance.text = this.text;\r\n            tooltipRef.instance.contentTemplate = this.contentTemplate;\r\n        }\r\n    }\r\n\r\n    /**\r\n     * This method will be called when mouse goes out of the host element\r\n     * i.e. where this directive is applied\r\n     * This method will close the tooltip by detaching the overlay from the view\r\n     */\r\n    @HostListener('mouseleave')\r\n    hide() {\r\n        this.closeToolTip();\r\n    }\r\n\r\n    /**\r\n     * Destroy lifecycle event handler\r\n     * This method will make sure to close the tooltip\r\n     * It will be needed in case when app is navigating to different page\r\n     * and user is still seeing the tooltip; In that case we do not want to hang around the\r\n     * tooltip after the page [on which tooltip visible] is destroyed\r\n     */\r\n    ngOnDestroy() {\r\n        this.closeToolTip();\r\n    }\r\n\r\n    /**\r\n     * This method will close the tooltip by detaching the component from the overlay\r\n     */\r\n    private closeToolTip() {\r\n        if (this._overlayRef) {\r\n            this._overlayRef.detach();\r\n        }\r\n    }\r\n}\r\n"]}
|
|
@@ -1,175 +0,0 @@
|
|
|
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>"]}
|
|
@@ -1,237 +0,0 @@
|
|
|
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
|
-
default:
|
|
106
|
-
return 'info';
|
|
107
|
-
}
|
|
108
|
-
}
|
|
109
|
-
ngOnDestroy() {
|
|
110
|
-
this.closePopup();
|
|
111
|
-
}
|
|
112
|
-
checkPopupPosition(value) {
|
|
113
|
-
let currentPosition;
|
|
114
|
-
switch (value) {
|
|
115
|
-
case 'bottom-left':
|
|
116
|
-
currentPosition = {
|
|
117
|
-
origin: {
|
|
118
|
-
originX: 'end',
|
|
119
|
-
originY: 'bottom'
|
|
120
|
-
},
|
|
121
|
-
overlay: {
|
|
122
|
-
overlayX: 'end',
|
|
123
|
-
overlayY: 'top'
|
|
124
|
-
},
|
|
125
|
-
arrow: {
|
|
126
|
-
bottom: true,
|
|
127
|
-
left: true,
|
|
128
|
-
}
|
|
129
|
-
};
|
|
130
|
-
break;
|
|
131
|
-
case 'top-right':
|
|
132
|
-
currentPosition = {
|
|
133
|
-
origin: {
|
|
134
|
-
originX: 'start',
|
|
135
|
-
originY: 'top',
|
|
136
|
-
},
|
|
137
|
-
overlay: {
|
|
138
|
-
overlayX: 'start',
|
|
139
|
-
overlayY: 'bottom',
|
|
140
|
-
},
|
|
141
|
-
arrow: {
|
|
142
|
-
bottom: false,
|
|
143
|
-
left: true,
|
|
144
|
-
}
|
|
145
|
-
};
|
|
146
|
-
break;
|
|
147
|
-
case 'top-left':
|
|
148
|
-
currentPosition = {
|
|
149
|
-
origin: {
|
|
150
|
-
originX: 'end',
|
|
151
|
-
originY: 'top',
|
|
152
|
-
},
|
|
153
|
-
overlay: {
|
|
154
|
-
overlayX: 'end',
|
|
155
|
-
overlayY: 'bottom',
|
|
156
|
-
},
|
|
157
|
-
arrow: {
|
|
158
|
-
bottom: false,
|
|
159
|
-
left: false,
|
|
160
|
-
}
|
|
161
|
-
};
|
|
162
|
-
break;
|
|
163
|
-
case 'top-center':
|
|
164
|
-
currentPosition = {
|
|
165
|
-
origin: {
|
|
166
|
-
originX: 'center',
|
|
167
|
-
originY: 'top',
|
|
168
|
-
},
|
|
169
|
-
overlay: {
|
|
170
|
-
overlayX: 'center',
|
|
171
|
-
overlayY: 'bottom',
|
|
172
|
-
},
|
|
173
|
-
arrow: {
|
|
174
|
-
bottom: false,
|
|
175
|
-
left: true,
|
|
176
|
-
}
|
|
177
|
-
};
|
|
178
|
-
break;
|
|
179
|
-
case 'bottom-center':
|
|
180
|
-
currentPosition = {
|
|
181
|
-
origin: {
|
|
182
|
-
originX: 'center',
|
|
183
|
-
originY: 'bottom',
|
|
184
|
-
},
|
|
185
|
-
overlay: {
|
|
186
|
-
overlayX: 'center',
|
|
187
|
-
overlayY: 'top',
|
|
188
|
-
},
|
|
189
|
-
arrow: {
|
|
190
|
-
bottom: true,
|
|
191
|
-
left: true,
|
|
192
|
-
}
|
|
193
|
-
};
|
|
194
|
-
break;
|
|
195
|
-
case 'bottom-right':
|
|
196
|
-
default:
|
|
197
|
-
currentPosition = {
|
|
198
|
-
origin: {
|
|
199
|
-
originX: 'start',
|
|
200
|
-
originY: 'bottom',
|
|
201
|
-
},
|
|
202
|
-
overlay: {
|
|
203
|
-
overlayX: 'start',
|
|
204
|
-
overlayY: 'top',
|
|
205
|
-
},
|
|
206
|
-
arrow: {
|
|
207
|
-
bottom: true,
|
|
208
|
-
left: false,
|
|
209
|
-
}
|
|
210
|
-
};
|
|
211
|
-
}
|
|
212
|
-
return currentPosition;
|
|
213
|
-
}
|
|
214
|
-
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 }); }
|
|
215
|
-
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 }); }
|
|
216
|
-
}
|
|
217
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: WmInfoComponent, decorators: [{
|
|
218
|
-
type: Component,
|
|
219
|
-
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"] }]
|
|
220
|
-
}], ctorParameters: () => [{ type: i1.Overlay }, { type: i0.ElementRef }, { type: i0.ViewContainerRef }], propDecorators: { preText: [{
|
|
221
|
-
type: Input
|
|
222
|
-
}], postText: [{
|
|
223
|
-
type: Input
|
|
224
|
-
}], header: [{
|
|
225
|
-
type: Input
|
|
226
|
-
}], type: [{
|
|
227
|
-
type: Input
|
|
228
|
-
}], popupPosition: [{
|
|
229
|
-
type: Input
|
|
230
|
-
}], iconAsTemplate: [{
|
|
231
|
-
type: Input
|
|
232
|
-
}], useThemeForIconTemplate: [{
|
|
233
|
-
type: Input
|
|
234
|
-
}], smallIcon: [{
|
|
235
|
-
type: Input
|
|
236
|
-
}] } });
|
|
237
|
-
//# 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\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> "]}
|