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
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
import { Component, Input, ViewChild } from '@angular/core';
|
|
2
|
+
import { interval } from 'rxjs';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/common";
|
|
5
|
+
export class ScalableDivComponent {
|
|
6
|
+
constructor(_zone, _change) {
|
|
7
|
+
this._zone = _zone;
|
|
8
|
+
this._change = _change;
|
|
9
|
+
this.isCalculated = false;
|
|
10
|
+
}
|
|
11
|
+
get text() { return this._text; }
|
|
12
|
+
set text(value) {
|
|
13
|
+
this._text = value;
|
|
14
|
+
this.recalculateWidth();
|
|
15
|
+
}
|
|
16
|
+
ngAfterViewInit() {
|
|
17
|
+
this._zone.runOutsideAngular(() => {
|
|
18
|
+
this.firstObservable = interval(500).subscribe(it => {
|
|
19
|
+
if (this.isCalculated) {
|
|
20
|
+
this.firstObservable.unsubscribe();
|
|
21
|
+
return;
|
|
22
|
+
}
|
|
23
|
+
this.recalculateWidth();
|
|
24
|
+
this._change.detectChanges();
|
|
25
|
+
});
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
ngOnDestroy() {
|
|
29
|
+
if (!this.firstObservable)
|
|
30
|
+
return;
|
|
31
|
+
this.firstObservable.unsubscribe();
|
|
32
|
+
this.firstObservable = undefined;
|
|
33
|
+
}
|
|
34
|
+
getNumberFromFontSize(fontSize) {
|
|
35
|
+
const numberSize = Number(fontSize.substr(0, fontSize.length - 2));
|
|
36
|
+
return numberSize;
|
|
37
|
+
}
|
|
38
|
+
getFontSizeDim(fontSize) {
|
|
39
|
+
let num;
|
|
40
|
+
let dimLength = 0;
|
|
41
|
+
while (!num) {
|
|
42
|
+
dimLength = dimLength + 1;
|
|
43
|
+
num = Number(fontSize.substr(0, fontSize.length - dimLength));
|
|
44
|
+
}
|
|
45
|
+
return fontSize.substr(fontSize.length - dimLength, dimLength);
|
|
46
|
+
}
|
|
47
|
+
divWidth(text, font, padding) {
|
|
48
|
+
const f = font || '12px arial';
|
|
49
|
+
const o = document.createElement('div');
|
|
50
|
+
o.innerHTML = text;
|
|
51
|
+
o.style.position = 'absolute';
|
|
52
|
+
o.style.visibility = 'hidden';
|
|
53
|
+
o.style['text-align'] = 'center';
|
|
54
|
+
o.style.font = f;
|
|
55
|
+
o.style.padding = padding;
|
|
56
|
+
document.body.appendChild(o);
|
|
57
|
+
const w = o.clientWidth;
|
|
58
|
+
document.body.removeChild(o);
|
|
59
|
+
return w;
|
|
60
|
+
}
|
|
61
|
+
recalculateWidth() {
|
|
62
|
+
if (!this.divEl)
|
|
63
|
+
return;
|
|
64
|
+
const divTag = this.divEl.nativeElement;
|
|
65
|
+
if (divTag.clientWidth === 0)
|
|
66
|
+
return;
|
|
67
|
+
this.isCalculated = true;
|
|
68
|
+
this.doRecalculateWidth(divTag);
|
|
69
|
+
}
|
|
70
|
+
doRecalculateWidth(divTag) {
|
|
71
|
+
divTag.style.fontSize = '';
|
|
72
|
+
const style = window.getComputedStyle(divTag);
|
|
73
|
+
const availableWidth = divTag.offsetParent.clientWidth;
|
|
74
|
+
const sizeDim = this.getFontSizeDim(style.fontSize);
|
|
75
|
+
const text = divTag.textContent;
|
|
76
|
+
let font = style.font;
|
|
77
|
+
let textWidth = this.divWidth(text, font, style.padding);
|
|
78
|
+
const needChange = availableWidth < textWidth;
|
|
79
|
+
let numberSize = this.getNumberFromFontSize(style.fontSize);
|
|
80
|
+
let stringSize = numberSize.toString() + sizeDim;
|
|
81
|
+
while (textWidth - availableWidth > 1) {
|
|
82
|
+
numberSize = numberSize - 1;
|
|
83
|
+
const oldString = stringSize;
|
|
84
|
+
stringSize = numberSize.toString() + sizeDim;
|
|
85
|
+
font = font.replace(oldString, stringSize);
|
|
86
|
+
textWidth = this.divWidth(text, font, style.padding);
|
|
87
|
+
}
|
|
88
|
+
if (needChange)
|
|
89
|
+
divTag.style.fontSize = stringSize;
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
ScalableDivComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: ScalableDivComponent, deps: [{ token: i0.NgZone }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
93
|
+
ScalableDivComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.6", type: ScalableDivComponent, selector: "wm-scalable-div", inputs: { divClass: "divClass", text: "text" }, viewQueries: [{ propertyName: "divEl", first: true, predicate: ["divEl"], descendants: true, static: true }], ngImport: i0, template: "<div #divEl [ngClass]=\"divClass\">{{text}}<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}}:host{font-size:42px;color:var(--strongFontColor);font-family:Inter,Verdana,Geneva,Tahoma,sans-serif;font-weight:700;padding:0 8px;text-align:center;margin:auto}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }] });
|
|
94
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: ScalableDivComponent, decorators: [{
|
|
95
|
+
type: Component,
|
|
96
|
+
args: [{ selector: 'wm-scalable-div', template: "<div #divEl [ngClass]=\"divClass\">{{text}}<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}}:host{font-size:42px;color:var(--strongFontColor);font-family:Inter,Verdana,Geneva,Tahoma,sans-serif;font-weight:700;padding:0 8px;text-align:center;margin:auto}\n"] }]
|
|
97
|
+
}], ctorParameters: function () { return [{ type: i0.NgZone }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { divClass: [{
|
|
98
|
+
type: Input
|
|
99
|
+
}], divEl: [{
|
|
100
|
+
type: ViewChild,
|
|
101
|
+
args: ['divEl', { static: true }]
|
|
102
|
+
}], text: [{
|
|
103
|
+
type: Input
|
|
104
|
+
}] } });
|
|
105
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scalable-div.component.js","sourceRoot":"","sources":["../../../../../projects/btv-base-controls/src/lib/wm-scalable-div/scalable-div.component.ts","../../../../../projects/btv-base-controls/src/lib/wm-scalable-div/scalable-div.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ElementRef, EventEmitter, Input, ViewChild, OnDestroy, NgZone, ChangeDetectorRef } from '@angular/core';\r\nimport { interval, Subscription } from 'rxjs';\r\n\r\n@Component({\r\n    selector: 'wm-scalable-div',\r\n    styleUrls: ['./scalable-div.scss'],\r\n    templateUrl: './scalable-div.html'\r\n})\r\nexport class ScalableDivComponent implements AfterViewInit, OnDestroy {\r\n\r\n    @Input() divClass: string;\r\n    @ViewChild('divEl', { static: true }) divEl: ElementRef;\r\n    isCalculated: boolean = false;\r\n    firstObservable: Subscription;\r\n\r\n    private _text: string | number;\r\n    public get text(): string | number { return this._text; }\r\n    @Input() public set text(value: string | number) {\r\n        this._text = value;\r\n        this.recalculateWidth();\r\n    }\r\n\r\n    constructor(private _zone: NgZone, private _change: ChangeDetectorRef) {\r\n\r\n    }\r\n\r\n    public ngAfterViewInit() {\r\n        this._zone.runOutsideAngular(() => {\r\n            this.firstObservable = interval(500).subscribe(it => {\r\n                if (this.isCalculated) {\r\n                    this.firstObservable.unsubscribe();\r\n                    return;\r\n                }\r\n                this.recalculateWidth();\r\n                this._change.detectChanges();\r\n            });\r\n        });\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        if (!this.firstObservable) return;\r\n        this.firstObservable.unsubscribe();\r\n        this.firstObservable = undefined;\r\n    }\r\n\r\n    private getNumberFromFontSize(fontSize: string): number {\r\n        const numberSize = Number(fontSize.substr(0, fontSize.length - 2));\r\n        return numberSize;\r\n    }\r\n\r\n    private getFontSizeDim(fontSize: string): string {\r\n        let num: number;\r\n        let dimLength: number = 0;\r\n        while (!num) {\r\n            dimLength = dimLength + 1;\r\n            num = Number(fontSize.substr(0, fontSize.length - dimLength));\r\n        }\r\n        return fontSize.substr(fontSize.length - dimLength, dimLength);\r\n    }\r\n\r\n    private divWidth(text: string, font: string, padding: string) {\r\n        const f = font || '12px arial';\r\n        const o = document.createElement('div');\r\n        o.innerHTML = text;\r\n        o.style.position = 'absolute';\r\n        o.style.visibility = 'hidden';\r\n        o.style['text-align'] = 'center';\r\n        o.style.font = f;\r\n        o.style.padding = padding;\r\n        document.body.appendChild(o);\r\n        const w = o.clientWidth;\r\n        document.body.removeChild(o);\r\n        return w;\r\n    }\r\n\r\n    public recalculateWidth() {\r\n        if (!this.divEl) return;\r\n        const divTag = this.divEl.nativeElement;\r\n        if ((<any>divTag).clientWidth === 0) return;\r\n        this.isCalculated = true;\r\n        this.doRecalculateWidth(divTag);\r\n    }\r\n\r\n    private doRecalculateWidth(divTag: HTMLElement) {\r\n        divTag.style.fontSize = '';\r\n        const style = window.getComputedStyle(divTag);\r\n        const availableWidth = divTag.offsetParent.clientWidth;\r\n        const sizeDim = this.getFontSizeDim(style.fontSize);\r\n        const text = divTag.textContent;\r\n        let font = style.font;\r\n        let textWidth = this.divWidth(text, font, style.padding);\r\n        const needChange: boolean = availableWidth < textWidth;\r\n        let numberSize = this.getNumberFromFontSize(style.fontSize);\r\n        let stringSize = numberSize.toString() + sizeDim;\r\n        while (textWidth - availableWidth > 1) {\r\n            numberSize = numberSize - 1;\r\n            const oldString = stringSize;\r\n            stringSize = numberSize.toString() + sizeDim;\r\n            font = font.replace(oldString, stringSize);\r\n            textWidth = this.divWidth(text, font, style.padding);\r\n        }\r\n        if (needChange) divTag.style.fontSize = stringSize;\r\n    }\r\n\r\n\r\n}\r\n","<div #divEl [ngClass]=\"divClass\">{{text}}<div>"]}
|
|
@@ -0,0 +1,135 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
|
|
2
|
+
import { timer } from 'rxjs';
|
|
3
|
+
import { Guid } from '../../models/guidExtension';
|
|
4
|
+
import { InfoType } from '../wm-info/info-models';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "@angular/common";
|
|
7
|
+
import * as i2 from "../wm-info/wm-info.component";
|
|
8
|
+
export class SpinnerComponent {
|
|
9
|
+
constructor(zone, change) {
|
|
10
|
+
this.zone = zone;
|
|
11
|
+
this.change = change;
|
|
12
|
+
this.uid = Guid.newGuid();
|
|
13
|
+
this._initialized = false;
|
|
14
|
+
this.isOverlayVisible = false;
|
|
15
|
+
this.isOverlayContrast = false;
|
|
16
|
+
this.minTimeOfVisibilityMs = 500;
|
|
17
|
+
this.showDelay = 250;
|
|
18
|
+
this.delay = false;
|
|
19
|
+
this.longMessageDelay = 12500;
|
|
20
|
+
this.message = 'Waiting for data from server';
|
|
21
|
+
this.messageTakesLong = 'Request is taking a bit longer than expected';
|
|
22
|
+
this.messageBottomWait = 'Please Wait';
|
|
23
|
+
this.infoType = InfoType.Error;
|
|
24
|
+
}
|
|
25
|
+
get showSpinner() { return this._showSpinner; }
|
|
26
|
+
set showSpinner(value) {
|
|
27
|
+
// tslint:disable-next-line:triple-equals we should treat bool false and bool undefined as same. The same for all other cases.
|
|
28
|
+
if (this._showSpinner == value)
|
|
29
|
+
return;
|
|
30
|
+
this._showSpinner = value;
|
|
31
|
+
this.unsubscribeTimers();
|
|
32
|
+
if (value) {
|
|
33
|
+
console.log('spinner started', this.uid);
|
|
34
|
+
// block UI, keep it light
|
|
35
|
+
this.isOverlayVisible = true;
|
|
36
|
+
this.subscribeTimers();
|
|
37
|
+
this.detectChanges();
|
|
38
|
+
}
|
|
39
|
+
else {
|
|
40
|
+
this.stopShowingProgress();
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
ngOnInit() {
|
|
44
|
+
this._initialized = true;
|
|
45
|
+
}
|
|
46
|
+
ngOnDestroy() {
|
|
47
|
+
console.log('destroy');
|
|
48
|
+
this.unsubscribeTimers();
|
|
49
|
+
}
|
|
50
|
+
subscribeTimers() {
|
|
51
|
+
this.zone.runOutsideAngular(() => {
|
|
52
|
+
// show long wait message after few configured seconds
|
|
53
|
+
const longMessageTimer = timer(this.longMessageDelay);
|
|
54
|
+
this._longMessageTimeSubscription = longMessageTimer.subscribe(t => {
|
|
55
|
+
this.message = this.messageTakesLong;
|
|
56
|
+
this.change.detectChanges();
|
|
57
|
+
this._longMessageTimeSubscription.unsubscribe();
|
|
58
|
+
});
|
|
59
|
+
// draw overlay message after few configured seconds
|
|
60
|
+
if (!this.delay) {
|
|
61
|
+
this.startShowingProgress();
|
|
62
|
+
return;
|
|
63
|
+
}
|
|
64
|
+
const showAfterDelayTimer = timer(this.showDelay);
|
|
65
|
+
this._showOverlayTimerSubscription = showAfterDelayTimer.subscribe(t => {
|
|
66
|
+
if (this.showSpinner)
|
|
67
|
+
this.startShowingProgress();
|
|
68
|
+
this.change.detectChanges();
|
|
69
|
+
this._showOverlayTimerSubscription.unsubscribe();
|
|
70
|
+
});
|
|
71
|
+
});
|
|
72
|
+
}
|
|
73
|
+
unsubscribeTimers() {
|
|
74
|
+
if (this._longMessageTimeSubscription)
|
|
75
|
+
this._longMessageTimeSubscription.unsubscribe();
|
|
76
|
+
if (this._showOverlayTimerSubscription)
|
|
77
|
+
this._showOverlayTimerSubscription.unsubscribe();
|
|
78
|
+
}
|
|
79
|
+
stopShowingProgress() {
|
|
80
|
+
if (this._startDate) {
|
|
81
|
+
const now = new Date().getTime();
|
|
82
|
+
const duration = (now - this._startDate.getTime()); // ms
|
|
83
|
+
if (duration < this.minTimeOfVisibilityMs) {
|
|
84
|
+
this.zone.runOutsideAngular(() => {
|
|
85
|
+
// let it be at least one second.
|
|
86
|
+
console.log('remains', this.minTimeOfVisibilityMs - duration);
|
|
87
|
+
setTimeout(() => this.doStopProgress(), this.minTimeOfVisibilityMs - duration);
|
|
88
|
+
});
|
|
89
|
+
return;
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
this.doStopProgress();
|
|
93
|
+
}
|
|
94
|
+
startShowingProgress() {
|
|
95
|
+
console.log('contrast spinner', this.uid);
|
|
96
|
+
this._startDate = new Date();
|
|
97
|
+
this.isOverlayContrast = true;
|
|
98
|
+
this.detectChanges();
|
|
99
|
+
}
|
|
100
|
+
doStopProgress() {
|
|
101
|
+
console.log('spinner ended', this.uid);
|
|
102
|
+
this.isOverlayContrast = false;
|
|
103
|
+
this.isOverlayVisible = false;
|
|
104
|
+
this._startDate = undefined;
|
|
105
|
+
this.detectChanges();
|
|
106
|
+
}
|
|
107
|
+
detectChanges() {
|
|
108
|
+
if (!this._initialized)
|
|
109
|
+
return;
|
|
110
|
+
this.change.detectChanges();
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
SpinnerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: SpinnerComponent, deps: [{ token: i0.NgZone }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
114
|
+
SpinnerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.6", type: SpinnerComponent, selector: "wm-spinner", inputs: { delay: "delay", longMessageDelay: "longMessageDelay", message: "message", messageTakesLong: "messageTakesLong", messageBottomWait: "messageBottomWait", detailInfoMessage: "detailInfoMessage", infoType: "infoType", showSpinner: "showSpinner" }, ngImport: i0, template: "<div class=\"spinner-wrap flex-col wh-100\" *ngIf=\"isOverlayVisible\">\r\n <div class=\"spinner-bg wh-100\" [ngClass]=\"{'invisible': !isOverlayContrast }\"></div>\r\n <div class=\"spinner-content inline-col marginXA align-center\" [ngClass]=\"{'invisible': !isOverlayContrast }\">\r\n <div class=\"msg-wrap marginBottomX8\">\r\n <div style=\"display: flex\">\r\n <div class=\"msg\">{{message}}</div>\r\n <wm-info class=\"info\" [type]=\"infoType\" popupPosition=\"top-center\" \r\n [iconAsTemplate]=\"infoType===2\" [useThemeForIconTemplate]=\"infoType===2\"\r\n *ngIf=\"detailInfoMessage\" [header]=\"detailInfoMessage\" style=\"margin-left: 4px\"></wm-info>\r\n </div>\r\n \r\n <div class=\"msg\">{{messageBottomWait}}</div>\r\n </div>\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 168 168\" id=\"loader\">\r\n <defs>\r\n <linearGradient id=\"a\" x1=\"38.078%\" x2=\"4.941%\" y1=\"8.411%\" y2=\"16.987%\">\r\n <stop offset=\"0%\" stop-color=\"var(--brandColor)\" stop-opacity=\"0.1\" />\r\n <stop offset=\"61.554%\" stop-color=\"var(--brandColor)\" stop-opacity=\"0.4\" />\r\n <stop offset=\"100%\" stop-color=\"var(--brandColor)\" stop-opacity=\"0.5\" />\r\n </linearGradient>\r\n <radialGradient id=\"b\" cy=\"43.835%\" r=\"54.9%\" fx=\"50%\" fy=\"43.835%\"\r\n gradientTransform=\"matrix(-.77913 .62687 -.6485 -.80602 1.174 .478)\">\r\n <stop offset=\"0%\" stop-color=\"#FFF\" />\r\n <stop offset=\"100%\" stop-color=\"var(--brandColor)\" stop-opacity=\"0.5\" />\r\n </radialGradient>\r\n </defs>\r\n <g fill=\"none\" fill-rule=\"evenodd\">\r\n <g transform=\"translate(10 10)\">\r\n <path stroke=\"url(#a)\" stroke-linecap=\"round\" stroke-width=\"19\"\r\n d=\"M16.198 27.79C6.062 40.453 0 56.518 0 74c0 40.87 33.13 74 74 74s74-33.13 74-74c0-24.611-12.014-46.416-30.498-59.87C105.292 5.244 90.258 0 74 0\" />\r\n <circle cx=\"16.5\" cy=\"27.5\" r=\"9.5\" fill=\"url(#b)\" />\r\n </g>\r\n </g>\r\n </svg>\r\n </div>\r\n\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}}.spinner-wrap{position:fixed;left:0px;right:0px;top:0px;bottom:0px;z-index:5;text-shadow:0px 0px 0px var(--pageBackgroundColor);pointer-events:all}.spinner-bg{position:absolute;top:0;left:0;transition:opacity .4s ease-in;opacity:.7;background-color:var(--appBackgroundColor)}.invisible{opacity:.01}.spinner-content{z-index:1;width:80%;height:80%;min-width:120px;min-height:120px;max-width:400px;max-height:400px}.msg-wrap{width:auto;max-width:400px;box-sizing:border-box;text-align:center;font-size:16px;color:var(--strongFontColor);line-height:32px;font-weight:500;word-break:break-word}@media all and (max-width: 767px){.msg-wrap{font-size:14px;line-height:24px}}#loader{animation:rotation 2s infinite linear;animation-play-state:running;width:50%;height:50%;min-width:120px;min-height:120px;max-width:240px;max-height:240px;margin:0 auto}@keyframes rotation{0%{transform:rotate(0)}to{transform:rotate(360deg)}}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.WmInfoComponent, selector: "wm-info", inputs: ["preText", "postText", "header", "type", "popupPosition", "iconAsTemplate", "useThemeForIconTemplate", "smallIcon"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
115
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: SpinnerComponent, decorators: [{
|
|
116
|
+
type: Component,
|
|
117
|
+
args: [{ selector: 'wm-spinner', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"spinner-wrap flex-col wh-100\" *ngIf=\"isOverlayVisible\">\r\n <div class=\"spinner-bg wh-100\" [ngClass]=\"{'invisible': !isOverlayContrast }\"></div>\r\n <div class=\"spinner-content inline-col marginXA align-center\" [ngClass]=\"{'invisible': !isOverlayContrast }\">\r\n <div class=\"msg-wrap marginBottomX8\">\r\n <div style=\"display: flex\">\r\n <div class=\"msg\">{{message}}</div>\r\n <wm-info class=\"info\" [type]=\"infoType\" popupPosition=\"top-center\" \r\n [iconAsTemplate]=\"infoType===2\" [useThemeForIconTemplate]=\"infoType===2\"\r\n *ngIf=\"detailInfoMessage\" [header]=\"detailInfoMessage\" style=\"margin-left: 4px\"></wm-info>\r\n </div>\r\n \r\n <div class=\"msg\">{{messageBottomWait}}</div>\r\n </div>\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 168 168\" id=\"loader\">\r\n <defs>\r\n <linearGradient id=\"a\" x1=\"38.078%\" x2=\"4.941%\" y1=\"8.411%\" y2=\"16.987%\">\r\n <stop offset=\"0%\" stop-color=\"var(--brandColor)\" stop-opacity=\"0.1\" />\r\n <stop offset=\"61.554%\" stop-color=\"var(--brandColor)\" stop-opacity=\"0.4\" />\r\n <stop offset=\"100%\" stop-color=\"var(--brandColor)\" stop-opacity=\"0.5\" />\r\n </linearGradient>\r\n <radialGradient id=\"b\" cy=\"43.835%\" r=\"54.9%\" fx=\"50%\" fy=\"43.835%\"\r\n gradientTransform=\"matrix(-.77913 .62687 -.6485 -.80602 1.174 .478)\">\r\n <stop offset=\"0%\" stop-color=\"#FFF\" />\r\n <stop offset=\"100%\" stop-color=\"var(--brandColor)\" stop-opacity=\"0.5\" />\r\n </radialGradient>\r\n </defs>\r\n <g fill=\"none\" fill-rule=\"evenodd\">\r\n <g transform=\"translate(10 10)\">\r\n <path stroke=\"url(#a)\" stroke-linecap=\"round\" stroke-width=\"19\"\r\n d=\"M16.198 27.79C6.062 40.453 0 56.518 0 74c0 40.87 33.13 74 74 74s74-33.13 74-74c0-24.611-12.014-46.416-30.498-59.87C105.292 5.244 90.258 0 74 0\" />\r\n <circle cx=\"16.5\" cy=\"27.5\" r=\"9.5\" fill=\"url(#b)\" />\r\n </g>\r\n </g>\r\n </svg>\r\n </div>\r\n\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}}.spinner-wrap{position:fixed;left:0px;right:0px;top:0px;bottom:0px;z-index:5;text-shadow:0px 0px 0px var(--pageBackgroundColor);pointer-events:all}.spinner-bg{position:absolute;top:0;left:0;transition:opacity .4s ease-in;opacity:.7;background-color:var(--appBackgroundColor)}.invisible{opacity:.01}.spinner-content{z-index:1;width:80%;height:80%;min-width:120px;min-height:120px;max-width:400px;max-height:400px}.msg-wrap{width:auto;max-width:400px;box-sizing:border-box;text-align:center;font-size:16px;color:var(--strongFontColor);line-height:32px;font-weight:500;word-break:break-word}@media all and (max-width: 767px){.msg-wrap{font-size:14px;line-height:24px}}#loader{animation:rotation 2s infinite linear;animation-play-state:running;width:50%;height:50%;min-width:120px;min-height:120px;max-width:240px;max-height:240px;margin:0 auto}@keyframes rotation{0%{transform:rotate(0)}to{transform:rotate(360deg)}}\n"] }]
|
|
118
|
+
}], ctorParameters: function () { return [{ type: i0.NgZone }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { delay: [{
|
|
119
|
+
type: Input
|
|
120
|
+
}], longMessageDelay: [{
|
|
121
|
+
type: Input
|
|
122
|
+
}], message: [{
|
|
123
|
+
type: Input
|
|
124
|
+
}], messageTakesLong: [{
|
|
125
|
+
type: Input
|
|
126
|
+
}], messageBottomWait: [{
|
|
127
|
+
type: Input
|
|
128
|
+
}], detailInfoMessage: [{
|
|
129
|
+
type: Input
|
|
130
|
+
}], infoType: [{
|
|
131
|
+
type: Input
|
|
132
|
+
}], showSpinner: [{
|
|
133
|
+
type: Input
|
|
134
|
+
}] } });
|
|
135
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"wm-spinner.component.js","sourceRoot":"","sources":["../../../../../projects/btv-base-controls/src/lib/wm-spinner/wm-spinner.component.ts","../../../../../projects/btv-base-controls/src/lib/wm-spinner/wm-spinner.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Input, NgZone, OnDestroy, OnInit } from '@angular/core';\r\nimport { Subscription, timer } from 'rxjs';\r\nimport { Guid } from '../../models/guidExtension';\r\nimport { InfoType } from '../wm-info/info-models';\r\n\r\n@Component({\r\n  selector: 'wm-spinner',\r\n  styleUrls: ['./wm-spinner.scss'],\r\n  templateUrl: './wm-spinner.html',\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class SpinnerComponent implements OnInit, OnDestroy {\r\n\r\n  private uid = Guid.newGuid();\r\n\r\n  private _longMessageTimeSubscription: Subscription;\r\n  private _showOverlayTimerSubscription: Subscription;\r\n  private _startDate;\r\n  private _initialized = false;\r\n  public isOverlayVisible = false;\r\n  public isOverlayContrast = false;\r\n  public minTimeOfVisibilityMs = 500;\r\n  public showDelay = 250;\r\n\r\n  @Input() public delay = false;\r\n  @Input() public longMessageDelay = 12500;\r\n  @Input() public message: string = 'Waiting for data from server';\r\n  @Input() public messageTakesLong = 'Request is taking a bit longer than expected';\r\n  @Input() public messageBottomWait: string = 'Please Wait';\r\n  @Input() public detailInfoMessage: string;\r\n  @Input() public infoType: InfoType = InfoType.Error;\r\n\r\n  private _showSpinner: boolean;\r\n  public get showSpinner() { return this._showSpinner; }\r\n  @Input() public set showSpinner(value: boolean) {\r\n    // tslint:disable-next-line:triple-equals we should treat bool false and bool undefined as same. The same for all other cases.\r\n    if (this._showSpinner == value) return;\r\n    this._showSpinner = value;\r\n    this.unsubscribeTimers();\r\n\r\n    if (value) {\r\n      console.log('spinner started', this.uid);\r\n      // block UI, keep it light\r\n      this.isOverlayVisible = true;\r\n      this.subscribeTimers();\r\n      this.detectChanges();\r\n    } else {\r\n      this.stopShowingProgress();\r\n    }\r\n  }\r\n\r\n  constructor(private zone: NgZone, private change: ChangeDetectorRef) {\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this._initialized = true;\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    console.log('destroy');\r\n    this.unsubscribeTimers();\r\n  }\r\n\r\n  private subscribeTimers() {\r\n    this.zone.runOutsideAngular(() => {\r\n      // show long wait message after few configured seconds\r\n      const longMessageTimer = timer(this.longMessageDelay);\r\n      this._longMessageTimeSubscription = longMessageTimer.subscribe(t => {\r\n        this.message = this.messageTakesLong;\r\n        this.change.detectChanges();\r\n        this._longMessageTimeSubscription.unsubscribe();\r\n      });\r\n\r\n      // draw overlay message after few configured seconds\r\n      if (!this.delay) {\r\n        this.startShowingProgress();\r\n        return;\r\n      }\r\n      const showAfterDelayTimer = timer(this.showDelay);\r\n      this._showOverlayTimerSubscription = showAfterDelayTimer.subscribe(t => {\r\n        if (this.showSpinner) this.startShowingProgress();\r\n        this.change.detectChanges();\r\n        this._showOverlayTimerSubscription.unsubscribe();\r\n      });\r\n    });\r\n  }\r\n\r\n  private unsubscribeTimers() {\r\n    if (this._longMessageTimeSubscription) this._longMessageTimeSubscription.unsubscribe();\r\n    if (this._showOverlayTimerSubscription) this._showOverlayTimerSubscription.unsubscribe();\r\n  }\r\n\r\n  private stopShowingProgress() {\r\n    if (this._startDate) {\r\n      const now = new Date().getTime();\r\n      const duration = (now - this._startDate.getTime()); // ms\r\n      if (duration < this.minTimeOfVisibilityMs) {\r\n        this.zone.runOutsideAngular(() => {\r\n          // let it be at least one second.\r\n          console.log('remains', this.minTimeOfVisibilityMs - duration);\r\n          setTimeout(() => this.doStopProgress(), this.minTimeOfVisibilityMs - duration);\r\n        });\r\n        return;\r\n      }\r\n    }\r\n    this.doStopProgress();\r\n  }\r\n\r\n  private startShowingProgress() {\r\n    console.log('contrast spinner', this.uid);\r\n    this._startDate = new Date();\r\n    this.isOverlayContrast = true;\r\n    this.detectChanges();\r\n  }\r\n\r\n  private doStopProgress() {\r\n    console.log('spinner ended', this.uid);\r\n    this.isOverlayContrast = false;\r\n    this.isOverlayVisible = false;\r\n    this._startDate = undefined;\r\n    this.detectChanges();\r\n  }\r\n\r\n  private detectChanges() {\r\n    if (!this._initialized) return;\r\n    this.change.detectChanges();\r\n  }\r\n\r\n}\r\n","<div class=\"spinner-wrap flex-col wh-100\" *ngIf=\"isOverlayVisible\">\r\n    <div class=\"spinner-bg wh-100\" [ngClass]=\"{'invisible': !isOverlayContrast }\"></div>\r\n    <div class=\"spinner-content inline-col marginXA align-center\" [ngClass]=\"{'invisible': !isOverlayContrast }\">\r\n        <div class=\"msg-wrap marginBottomX8\">\r\n            <div style=\"display: flex\">\r\n                    <div class=\"msg\">{{message}}</div>\r\n                    <wm-info class=\"info\" [type]=\"infoType\" popupPosition=\"top-center\" \r\n                    [iconAsTemplate]=\"infoType===2\" [useThemeForIconTemplate]=\"infoType===2\"\r\n                    *ngIf=\"detailInfoMessage\" [header]=\"detailInfoMessage\" style=\"margin-left: 4px\"></wm-info>\r\n            </div>\r\n            \r\n            <div class=\"msg\">{{messageBottomWait}}</div>\r\n        </div>\r\n        <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 168 168\" id=\"loader\">\r\n            <defs>\r\n                <linearGradient id=\"a\" x1=\"38.078%\" x2=\"4.941%\" y1=\"8.411%\" y2=\"16.987%\">\r\n                    <stop offset=\"0%\" stop-color=\"var(--brandColor)\" stop-opacity=\"0.1\" />\r\n                    <stop offset=\"61.554%\" stop-color=\"var(--brandColor)\" stop-opacity=\"0.4\" />\r\n                    <stop offset=\"100%\" stop-color=\"var(--brandColor)\" stop-opacity=\"0.5\" />\r\n                </linearGradient>\r\n                <radialGradient id=\"b\" cy=\"43.835%\" r=\"54.9%\" fx=\"50%\" fy=\"43.835%\"\r\n                    gradientTransform=\"matrix(-.77913 .62687 -.6485 -.80602 1.174 .478)\">\r\n                    <stop offset=\"0%\" stop-color=\"#FFF\" />\r\n                    <stop offset=\"100%\" stop-color=\"var(--brandColor)\" stop-opacity=\"0.5\" />\r\n                </radialGradient>\r\n            </defs>\r\n            <g fill=\"none\" fill-rule=\"evenodd\">\r\n                <g transform=\"translate(10 10)\">\r\n                    <path stroke=\"url(#a)\" stroke-linecap=\"round\" stroke-width=\"19\"\r\n                        d=\"M16.198 27.79C6.062 40.453 0 56.518 0 74c0 40.87 33.13 74 74 74s74-33.13 74-74c0-24.611-12.014-46.416-30.498-59.87C105.292 5.244 90.258 0 74 0\" />\r\n                    <circle cx=\"16.5\" cy=\"27.5\" r=\"9.5\" fill=\"url(#b)\" />\r\n                </g>\r\n            </g>\r\n        </svg>\r\n    </div>\r\n\r\n</div>"]}
|
|
@@ -1,18 +1,18 @@
|
|
|
1
|
-
import { Component, Input, ChangeDetectionStrategy } from '@angular/core';
|
|
2
|
-
import * as i0 from "@angular/core";
|
|
3
|
-
export class WmStateIconComponent {
|
|
4
|
-
constructor() {
|
|
5
|
-
this.state = 'ok';
|
|
6
|
-
}
|
|
7
|
-
ngOnInit() {
|
|
8
|
-
}
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
}
|
|
12
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
13
|
-
type: Component,
|
|
14
|
-
args: [{ selector: 'wm-state-icon', changeDetection: ChangeDetectionStrategy.OnPush, template: "<!--workaround for css image resolve plugin-->\r\n<div class=\"icon-wrapper {{state}}\" >\r\n\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}}.icon-wrapper{margin:0 auto;text-align:center;width:50px;height:50px;background-image:url(/assets/icon/state-icons.png)}.ok{background-position-x:-77px;background-position-y:-82px}.warning{background-position-x:-129px;background-position-y:-82px}.error-i{background-position-x:-321px;background-position-y:-82px;width:70px}\n"] }]
|
|
15
|
-
}], ctorParameters: ()
|
|
16
|
-
type: Input
|
|
17
|
-
}] } });
|
|
18
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
import { Component, Input, ChangeDetectionStrategy } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class WmStateIconComponent {
|
|
4
|
+
constructor() {
|
|
5
|
+
this.state = 'ok';
|
|
6
|
+
}
|
|
7
|
+
ngOnInit() {
|
|
8
|
+
}
|
|
9
|
+
}
|
|
10
|
+
WmStateIconComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: WmStateIconComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
11
|
+
WmStateIconComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.6", type: WmStateIconComponent, selector: "wm-state-icon", inputs: { state: "state" }, ngImport: i0, template: "<!--workaround for css image resolve plugin-->\r\n<div class=\"icon-wrapper {{state}}\" >\r\n\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}}.icon-wrapper{margin:0 auto;text-align:center;width:50px;height:50px;background-image:url(/assets/icon/state-icons.png)}.ok{background-position-x:-77px;background-position-y:-82px}.warning{background-position-x:-129px;background-position-y:-82px}.error-i{background-position-x:-321px;background-position-y:-82px;width:70px}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
12
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: WmStateIconComponent, decorators: [{
|
|
13
|
+
type: Component,
|
|
14
|
+
args: [{ selector: 'wm-state-icon', changeDetection: ChangeDetectionStrategy.OnPush, template: "<!--workaround for css image resolve plugin-->\r\n<div class=\"icon-wrapper {{state}}\" >\r\n\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}}.icon-wrapper{margin:0 auto;text-align:center;width:50px;height:50px;background-image:url(/assets/icon/state-icons.png)}.ok{background-position-x:-77px;background-position-y:-82px}.warning{background-position-x:-129px;background-position-y:-82px}.error-i{background-position-x:-321px;background-position-y:-82px;width:70px}\n"] }]
|
|
15
|
+
}], ctorParameters: function () { return []; }, propDecorators: { state: [{
|
|
16
|
+
type: Input
|
|
17
|
+
}] } });
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid20tc3RhdGUtaWNvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9idHYtYmFzZS1jb250cm9scy9zcmMvbGliL3dtLXN0YXRlLWljb24vd20tc3RhdGUtaWNvbi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9idHYtYmFzZS1jb250cm9scy9zcmMvbGliL3dtLXN0YXRlLWljb24vd20tc3RhdGUtaWNvbi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFVLEtBQUssRUFBRSx1QkFBdUIsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFRbEYsTUFBTSxPQUFPLG9CQUFvQjtJQUkvQjtRQUZnQixVQUFLLEdBQVcsSUFBSSxDQUFDO0lBRXJCLENBQUM7SUFFakIsUUFBUTtJQUNSLENBQUM7O2lIQVBVLG9CQUFvQjtxR0FBcEIsb0JBQW9CLGlGQ1JqQyx5R0FHTTsyRkRLTyxvQkFBb0I7a0JBTmhDLFNBQVM7K0JBQ0UsZUFBZSxtQkFHUix1QkFBdUIsQ0FBQyxNQUFNOzBFQUkvQixLQUFLO3NCQUFwQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBPbkluaXQsIElucHV0LCBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICd3bS1zdGF0ZS1pY29uJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vd20tc3RhdGUtaWNvbi5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vd20tc3RhdGUtaWNvbi5jb21wb25lbnQuc2NzcyddLFxyXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBXbVN0YXRlSWNvbkNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcblxyXG4gIEBJbnB1dCgpIHB1YmxpYyBzdGF0ZTogc3RyaW5nID0gJ29rJztcclxuXHJcbiAgY29uc3RydWN0b3IoKSB7IH1cclxuXHJcbiAgbmdPbkluaXQoKSB7XHJcbiAgfVxyXG5cclxufVxyXG4iLCI8IS0td29ya2Fyb3VuZCBmb3IgY3NzIGltYWdlIHJlc29sdmUgcGx1Z2luLS0+XHJcbjxkaXYgY2xhc3M9XCJpY29uLXdyYXBwZXIge3tzdGF0ZX19XCIgPlxyXG5cclxuPC9kaXY+Il19
|
|
@@ -1,28 +1,28 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
|
|
2
|
-
import * as i0 from "@angular/core";
|
|
3
|
-
import * as i1 from "@angular/common";
|
|
4
|
-
import * as i2 from "../wm-tamplate-image/wm-template-image.component";
|
|
5
|
-
export class WmTagComponent {
|
|
6
|
-
constructor() {
|
|
7
|
-
this.background = 'transparent';
|
|
8
|
-
this.color = 'black';
|
|
9
|
-
this.iconSize = '20px';
|
|
10
|
-
}
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
}
|
|
14
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
15
|
-
type: Component,
|
|
16
|
-
args: [{ selector: 'wm-tag', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"text-wrap\">\r\n <span class=\"text-bg\" [ngStyle]=\"{'background': background}\"></span>\r\n <span class=\"text-bg text-bg-bor\" [ngStyle]=\"{'border-color': background}\"></span>\r\n <span class=\"text-title\" [ngStyle]=\"{'color': color}\"> \r\n <wm-template-image *ngIf=\"icon\" class=\"text-icon\" [icon]=\"icon\" [size]=\"iconSize\" [backgroundColor]=\"background\"></wm-template-image>\r\n {{text}}\r\n </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}}.text-title{color:var(--strongFontColor);display:flex;text-align:left;font-family:Inter,Verdana,Geneva,Tahoma,sans-serif;font-weight:500;font-size:14px;min-width:50px;text-align:center;padding:4px 6px;z-index:1;line-height:18px}.text-wrap{position:relative;display:inline-block;line-height:normal}.text-bg{border:1px solid transparent;box-sizing:border-box;position:absolute;width:100%;height:100%;border-radius:6px;opacity:.1}.text-bg-bor{border:1px solid;opacity:.25}.rotate{transform-origin:center center
|
|
17
|
-
}], propDecorators: { text: [{
|
|
18
|
-
type: Input
|
|
19
|
-
}], background: [{
|
|
20
|
-
type: Input
|
|
21
|
-
}], color: [{
|
|
22
|
-
type: Input
|
|
23
|
-
}], icon: [{
|
|
24
|
-
type: Input
|
|
25
|
-
}], iconSize: [{
|
|
26
|
-
type: Input
|
|
27
|
-
}] } });
|
|
28
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common";
|
|
4
|
+
import * as i2 from "../wm-tamplate-image/wm-template-image.component";
|
|
5
|
+
export class WmTagComponent {
|
|
6
|
+
constructor() {
|
|
7
|
+
this.background = 'transparent';
|
|
8
|
+
this.color = 'black';
|
|
9
|
+
this.iconSize = '20px';
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
WmTagComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: WmTagComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
13
|
+
WmTagComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.6", type: WmTagComponent, selector: "wm-tag", inputs: { text: "text", background: "background", color: "color", icon: "icon", iconSize: "iconSize" }, ngImport: i0, template: "<div class=\"text-wrap\">\r\n <span class=\"text-bg\" [ngStyle]=\"{'background': background}\"></span>\r\n <span class=\"text-bg text-bg-bor\" [ngStyle]=\"{'border-color': background}\"></span>\r\n <span class=\"text-title\" [ngStyle]=\"{'color': color}\"> \r\n <wm-template-image *ngIf=\"icon\" class=\"text-icon\" [icon]=\"icon\" [size]=\"iconSize\" [backgroundColor]=\"background\"></wm-template-image>\r\n {{text}}\r\n </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}}.text-title{color:var(--strongFontColor);display:flex;text-align:left;font-family:Inter,Verdana,Geneva,Tahoma,sans-serif;font-weight:500;font-size:14px;min-width:50px;text-align:center;padding:4px 6px;z-index:1;line-height:18px}.text-wrap{position:relative;display:inline-block;line-height:normal}.text-bg{border:1px solid transparent;box-sizing:border-box;position:absolute;width:100%;height:100%;border-radius:6px;opacity:.1}.text-bg-bor{border:1px solid;opacity:.25}.rotate{transform-origin:center center;transform:rotate(-6deg)}.text-icon{margin-right:4px}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i2.WmTemplateImageComponent, selector: "wm-template-image", inputs: ["icon", "disabled", "active", "light", "classes", "backgroundColor", "size", "sizeBox"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
14
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: WmTagComponent, decorators: [{
|
|
15
|
+
type: Component,
|
|
16
|
+
args: [{ selector: 'wm-tag', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"text-wrap\">\r\n <span class=\"text-bg\" [ngStyle]=\"{'background': background}\"></span>\r\n <span class=\"text-bg text-bg-bor\" [ngStyle]=\"{'border-color': background}\"></span>\r\n <span class=\"text-title\" [ngStyle]=\"{'color': color}\"> \r\n <wm-template-image *ngIf=\"icon\" class=\"text-icon\" [icon]=\"icon\" [size]=\"iconSize\" [backgroundColor]=\"background\"></wm-template-image>\r\n {{text}}\r\n </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}}.text-title{color:var(--strongFontColor);display:flex;text-align:left;font-family:Inter,Verdana,Geneva,Tahoma,sans-serif;font-weight:500;font-size:14px;min-width:50px;text-align:center;padding:4px 6px;z-index:1;line-height:18px}.text-wrap{position:relative;display:inline-block;line-height:normal}.text-bg{border:1px solid transparent;box-sizing:border-box;position:absolute;width:100%;height:100%;border-radius:6px;opacity:.1}.text-bg-bor{border:1px solid;opacity:.25}.rotate{transform-origin:center center;transform:rotate(-6deg)}.text-icon{margin-right:4px}\n"] }]
|
|
17
|
+
}], propDecorators: { text: [{
|
|
18
|
+
type: Input
|
|
19
|
+
}], background: [{
|
|
20
|
+
type: Input
|
|
21
|
+
}], color: [{
|
|
22
|
+
type: Input
|
|
23
|
+
}], icon: [{
|
|
24
|
+
type: Input
|
|
25
|
+
}], iconSize: [{
|
|
26
|
+
type: Input
|
|
27
|
+
}] } });
|
|
28
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid20tdGFnLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2J0di1iYXNlLWNvbnRyb2xzL3NyYy9saWIvd20tdGFnL3dtLXRhZy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9idHYtYmFzZS1jb250cm9scy9zcmMvbGliL3dtLXRhZy93bS10YWcuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7Ozs7QUFRMUUsTUFBTSxPQUFPLGNBQWM7SUFOM0I7UUFTa0IsZUFBVSxHQUFXLGFBQWEsQ0FBQztRQUNuQyxVQUFLLEdBQVcsT0FBTyxDQUFDO1FBRXhCLGFBQVEsR0FBVyxNQUFNLENBQUM7S0FFM0M7OzJHQVJZLGNBQWM7K0ZBQWQsY0FBYyxzSkNSM0IsdWRBT007MkZEQ08sY0FBYztrQkFOMUIsU0FBUzsrQkFDRSxRQUFRLG1CQUdELHVCQUF1QixDQUFDLE1BQU07OEJBSS9CLElBQUk7c0JBQW5CLEtBQUs7Z0JBQ1UsVUFBVTtzQkFBekIsS0FBSztnQkFDVSxLQUFLO3NCQUFwQixLQUFLO2dCQUNVLElBQUk7c0JBQW5CLEtBQUs7Z0JBQ1UsUUFBUTtzQkFBdkIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ3dtLXRhZycsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL3dtLXRhZy5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vd20tdGFnLmNvbXBvbmVudC5zY3NzJ10sXHJcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBXbVRhZ0NvbXBvbmVudCB7XHJcblxyXG4gIEBJbnB1dCgpIHB1YmxpYyB0ZXh0OiBzdHJpbmc7XHJcbiAgQElucHV0KCkgcHVibGljIGJhY2tncm91bmQ6IHN0cmluZyA9ICd0cmFuc3BhcmVudCc7XHJcbiAgQElucHV0KCkgcHVibGljIGNvbG9yOiBzdHJpbmcgPSAnYmxhY2snO1xyXG4gIEBJbnB1dCgpIHB1YmxpYyBpY29uOiBzdHJpbmc7XHJcbiAgQElucHV0KCkgcHVibGljIGljb25TaXplOiBzdHJpbmcgPSAnMjBweCc7XHJcblxyXG59XHJcbiIsIjxkaXYgY2xhc3M9XCJ0ZXh0LXdyYXBcIj5cclxuICAgIDxzcGFuIGNsYXNzPVwidGV4dC1iZ1wiIFtuZ1N0eWxlXT1cInsnYmFja2dyb3VuZCc6IGJhY2tncm91bmR9XCI+PC9zcGFuPlxyXG4gICAgPHNwYW4gY2xhc3M9XCJ0ZXh0LWJnIHRleHQtYmctYm9yXCIgW25nU3R5bGVdPVwieydib3JkZXItY29sb3InOiBiYWNrZ3JvdW5kfVwiPjwvc3Bhbj5cclxuICAgIDxzcGFuIGNsYXNzPVwidGV4dC10aXRsZVwiIFtuZ1N0eWxlXT1cInsnY29sb3InOiBjb2xvcn1cIj4gICAgXHJcbiAgICAgICAgPHdtLXRlbXBsYXRlLWltYWdlICpuZ0lmPVwiaWNvblwiIGNsYXNzPVwidGV4dC1pY29uXCIgW2ljb25dPVwiaWNvblwiIFtzaXplXT1cImljb25TaXplXCIgW2JhY2tncm91bmRDb2xvcl09XCJiYWNrZ3JvdW5kXCI+PC93bS10ZW1wbGF0ZS1pbWFnZT5cclxuICAgICAgICB7e3RleHR9fVxyXG4gICAgPC9zcGFuPlxyXG48L2Rpdj4iXX0=
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, Input, ViewChild } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common";
|
|
4
|
+
export class WmTemplateImageComponent {
|
|
5
|
+
constructor() {
|
|
6
|
+
this.require = ['mask-image', '-webkit-mask-image'];
|
|
7
|
+
this.classes = 'icon-svg';
|
|
8
|
+
this._size = '24px';
|
|
9
|
+
this._sizeBox = undefined;
|
|
10
|
+
}
|
|
11
|
+
get size() { return this._size; }
|
|
12
|
+
set size(value) {
|
|
13
|
+
this._size = value;
|
|
14
|
+
}
|
|
15
|
+
get sizeBox() { return this._sizeBox; }
|
|
16
|
+
set sizeBox(value) {
|
|
17
|
+
this._sizeBox = value;
|
|
18
|
+
}
|
|
19
|
+
get getStyles() {
|
|
20
|
+
if (!this.container.nativeElement)
|
|
21
|
+
return undefined;
|
|
22
|
+
if (this.require.some(it => this.container.nativeElement.style[it] !== undefined)) {
|
|
23
|
+
return {
|
|
24
|
+
'-webkit-mask-position': 'center',
|
|
25
|
+
'-webkit-mask-repeat': 'no-repeat',
|
|
26
|
+
'-webkit-mask-size': this.size,
|
|
27
|
+
'-webkit-mask-image': `url(./assets/icon/svg/${this.icon}.svg)`,
|
|
28
|
+
'mask-image': `url(./assets/icon/svg/${this.icon}.svg)`,
|
|
29
|
+
'mask-size': this.size,
|
|
30
|
+
'width': this.sizeBox ? this.sizeBox : this.size,
|
|
31
|
+
'height': this.sizeBox ? this.sizeBox : this.size,
|
|
32
|
+
'background-color': this.backgroundColor,
|
|
33
|
+
};
|
|
34
|
+
}
|
|
35
|
+
return {
|
|
36
|
+
'background-image': `url(./assets/icon/svg/${this.icon}.svg)`,
|
|
37
|
+
'background-repeat': 'no-repeat',
|
|
38
|
+
'background-position': 'center',
|
|
39
|
+
'background-size': 'contain',
|
|
40
|
+
'background-color': 'transparent',
|
|
41
|
+
'width': this.sizeBox ? this.sizeBox : this.size,
|
|
42
|
+
'height': this.sizeBox ? this.sizeBox : this.size
|
|
43
|
+
};
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
WmTemplateImageComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: WmTemplateImageComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
47
|
+
WmTemplateImageComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.6", type: WmTemplateImageComponent, selector: "wm-template-image", inputs: { icon: "icon", disabled: "disabled", active: "active", light: "light", classes: "classes", backgroundColor: "backgroundColor", size: "size", sizeBox: "sizeBox" }, viewQueries: [{ propertyName: "container", first: true, predicate: ["maskContainer"], descendants: true, static: true }], ngImport: i0, template: "<div #maskContainer class=\"{{classes}}\" [ngClass]=\"{'disabled': disabled,\r\n'active': active, 'light': light }\" [ngStyle]=\"getStyles\">\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}}:host{display:block;margin:auto}.icon-svg{background-color:var(--strongFontColor)}.disabled{background-color:var(--mediumFontColor)}.active{background-color:var(--brandColor);border:none}.light{background-color:var(--disabledTextColor)}.on-brand{background-color:var(--onBrandTextColor)}.on-disabled{background-color:var(--disabledTextColor)}\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 });
|
|
48
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: WmTemplateImageComponent, decorators: [{
|
|
49
|
+
type: Component,
|
|
50
|
+
args: [{ selector: 'wm-template-image', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div #maskContainer class=\"{{classes}}\" [ngClass]=\"{'disabled': disabled,\r\n'active': active, 'light': light }\" [ngStyle]=\"getStyles\">\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}}:host{display:block;margin:auto}.icon-svg{background-color:var(--strongFontColor)}.disabled{background-color:var(--mediumFontColor)}.active{background-color:var(--brandColor);border:none}.light{background-color:var(--disabledTextColor)}.on-brand{background-color:var(--onBrandTextColor)}.on-disabled{background-color:var(--disabledTextColor)}\n"] }]
|
|
51
|
+
}], propDecorators: { container: [{
|
|
52
|
+
type: ViewChild,
|
|
53
|
+
args: ['maskContainer', { static: true }]
|
|
54
|
+
}], icon: [{
|
|
55
|
+
type: Input
|
|
56
|
+
}], disabled: [{
|
|
57
|
+
type: Input
|
|
58
|
+
}], active: [{
|
|
59
|
+
type: Input
|
|
60
|
+
}], light: [{
|
|
61
|
+
type: Input
|
|
62
|
+
}], classes: [{
|
|
63
|
+
type: Input
|
|
64
|
+
}], backgroundColor: [{
|
|
65
|
+
type: Input
|
|
66
|
+
}], size: [{
|
|
67
|
+
type: Input
|
|
68
|
+
}], sizeBox: [{
|
|
69
|
+
type: Input
|
|
70
|
+
}] } });
|
|
71
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid20tdGVtcGxhdGUtaW1hZ2UuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYnR2LWJhc2UtY29udHJvbHMvc3JjL2xpYi93bS10YW1wbGF0ZS1pbWFnZS93bS10ZW1wbGF0ZS1pbWFnZS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9idHYtYmFzZS1jb250cm9scy9zcmMvbGliL3dtLXRhbXBsYXRlLWltYWdlL3dtLXRlbXBsYXRlLWltYWdlLmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBYyxLQUFLLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7QUFTakcsTUFBTSxPQUFPLHdCQUF3QjtJQVByQztRQVNFLFlBQU8sR0FBRyxDQUFDLFlBQVksRUFBRSxvQkFBb0IsQ0FBQyxDQUFDO1FBS3RDLFlBQU8sR0FBRyxVQUFVLENBQUM7UUFHdEIsVUFBSyxHQUFXLE1BQU0sQ0FBQztRQUt2QixhQUFRLEdBQVcsU0FBUyxDQUFDO0tBK0J0QztJQW5DQyxJQUFXLElBQUksS0FBSyxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDO0lBQ3hDLElBQW9CLElBQUksQ0FBQyxLQUFhO1FBQ3BDLElBQUksQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFDO0lBQ3JCLENBQUM7SUFFRCxJQUFXLE9BQU8sS0FBSyxPQUFPLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDO0lBQzlDLElBQW9CLE9BQU8sQ0FBQyxLQUFhO1FBQ3ZDLElBQUksQ0FBQyxRQUFRLEdBQUcsS0FBSyxDQUFDO0lBQ3hCLENBQUM7SUFFRCxJQUFJLFNBQVM7UUFDWCxJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxhQUFhO1lBQUUsT0FBTyxTQUFTLENBQUM7UUFDcEQsSUFBSSxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsS0FBSyxTQUFTLENBQUMsRUFBRTtZQUNqRixPQUFPO2dCQUNMLHVCQUF1QixFQUFFLFFBQVE7Z0JBQ2pDLHFCQUFxQixFQUFFLFdBQVc7Z0JBQ2xDLG1CQUFtQixFQUFFLElBQUksQ0FBQyxJQUFJO2dCQUM5QixvQkFBb0IsRUFBRSx5QkFBeUIsSUFBSSxDQUFDLElBQUksT0FBTztnQkFDL0QsWUFBWSxFQUFFLHlCQUF5QixJQUFJLENBQUMsSUFBSSxPQUFPO2dCQUN2RCxXQUFXLEVBQUUsSUFBSSxDQUFDLElBQUk7Z0JBQ3RCLE9BQU8sRUFBRSxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsSUFBSTtnQkFDaEQsUUFBUSxFQUFFLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxJQUFJO2dCQUNqRCxrQkFBa0IsRUFBRSxJQUFJLENBQUMsZUFBZTthQUN6QyxDQUFDO1NBQ0g7UUFDRCxPQUFPO1lBQ0wsa0JBQWtCLEVBQUUseUJBQXlCLElBQUksQ0FBQyxJQUFJLE9BQU87WUFDN0QsbUJBQW1CLEVBQUUsV0FBVztZQUNoQyxxQkFBcUIsRUFBRSxRQUFRO1lBQy9CLGlCQUFpQixFQUFFLFNBQVM7WUFDNUIsa0JBQWtCLEVBQUUsYUFBYTtZQUNqQyxPQUFPLEVBQUUsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLElBQUk7WUFDaEQsUUFBUSxFQUFFLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxJQUFJO1NBQ2xELENBQUM7SUFDSixDQUFDOztxSEE3Q1Usd0JBQXdCO3lHQUF4Qix3QkFBd0IsK1ZDVHJDLHlKQUVNOzJGRE9PLHdCQUF3QjtrQkFQcEMsU0FBUzsrQkFDRSxtQkFBbUIsbUJBR1osdUJBQXVCLENBQUMsTUFBTTs4QkFJRCxTQUFTO3NCQUF0RCxTQUFTO3VCQUFDLGVBQWUsRUFBRSxFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUU7Z0JBRW5DLElBQUk7c0JBQVosS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQUNHLE1BQU07c0JBQWQsS0FBSztnQkFDRyxLQUFLO3NCQUFiLEtBQUs7Z0JBQ0csT0FBTztzQkFBZixLQUFLO2dCQUNHLGVBQWU7c0JBQXZCLEtBQUs7Z0JBSWMsSUFBSTtzQkFBdkIsS0FBSztnQkFLYyxPQUFPO3NCQUExQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgRWxlbWVudFJlZiwgSW5wdXQsIFZpZXdDaGlsZCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICd3bS10ZW1wbGF0ZS1pbWFnZScsXHJcbiAgc3R5bGVVcmxzOiBbJy4vd20tdGVtcGxhdGUtaW1hZ2Uuc2NzcyddLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi93bS10ZW1wbGF0ZS1pbWFnZS5odG1sJyxcclxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxyXG59KVxyXG5cclxuZXhwb3J0IGNsYXNzIFdtVGVtcGxhdGVJbWFnZUNvbXBvbmVudCB7XHJcbiAgQFZpZXdDaGlsZCgnbWFza0NvbnRhaW5lcicsIHsgc3RhdGljOiB0cnVlIH0pIGNvbnRhaW5lcjogRWxlbWVudFJlZjtcclxuICByZXF1aXJlID0gWydtYXNrLWltYWdlJywgJy13ZWJraXQtbWFzay1pbWFnZSddO1xyXG4gIEBJbnB1dCgpIGljb246IHN0cmluZztcclxuICBASW5wdXQoKSBkaXNhYmxlZDogYm9vbGVhbjtcclxuICBASW5wdXQoKSBhY3RpdmU6IGJvb2xlYW47XHJcbiAgQElucHV0KCkgbGlnaHQ6IGJvb2xlYW47XHJcbiAgQElucHV0KCkgY2xhc3NlcyA9ICdpY29uLXN2Zyc7XHJcbiAgQElucHV0KCkgYmFja2dyb3VuZENvbG9yO1xyXG5cclxuICBwcml2YXRlIF9zaXplOiBzdHJpbmcgPSAnMjRweCc7XHJcbiAgcHVibGljIGdldCBzaXplKCkgeyByZXR1cm4gdGhpcy5fc2l6ZTsgfVxyXG4gIEBJbnB1dCgpIHB1YmxpYyBzZXQgc2l6ZSh2YWx1ZTogc3RyaW5nKSB7XHJcbiAgICB0aGlzLl9zaXplID0gdmFsdWU7XHJcbiAgfVxyXG4gIHByaXZhdGUgX3NpemVCb3g6IHN0cmluZyA9IHVuZGVmaW5lZDtcclxuICBwdWJsaWMgZ2V0IHNpemVCb3goKSB7IHJldHVybiB0aGlzLl9zaXplQm94OyB9XHJcbiAgQElucHV0KCkgcHVibGljIHNldCBzaXplQm94KHZhbHVlOiBzdHJpbmcpIHtcclxuICAgIHRoaXMuX3NpemVCb3ggPSB2YWx1ZTtcclxuICB9XHJcblxyXG4gIGdldCBnZXRTdHlsZXMoKSB7XHJcbiAgICBpZiAoIXRoaXMuY29udGFpbmVyLm5hdGl2ZUVsZW1lbnQpIHJldHVybiB1bmRlZmluZWQ7XHJcbiAgICBpZiAodGhpcy5yZXF1aXJlLnNvbWUoaXQgPT4gdGhpcy5jb250YWluZXIubmF0aXZlRWxlbWVudC5zdHlsZVtpdF0gIT09IHVuZGVmaW5lZCkpIHtcclxuICAgICAgcmV0dXJuIHtcclxuICAgICAgICAnLXdlYmtpdC1tYXNrLXBvc2l0aW9uJzogJ2NlbnRlcicsXHJcbiAgICAgICAgJy13ZWJraXQtbWFzay1yZXBlYXQnOiAnbm8tcmVwZWF0JyxcclxuICAgICAgICAnLXdlYmtpdC1tYXNrLXNpemUnOiB0aGlzLnNpemUsXHJcbiAgICAgICAgJy13ZWJraXQtbWFzay1pbWFnZSc6IGB1cmwoLi9hc3NldHMvaWNvbi9zdmcvJHt0aGlzLmljb259LnN2ZylgLFxyXG4gICAgICAgICdtYXNrLWltYWdlJzogYHVybCguL2Fzc2V0cy9pY29uL3N2Zy8ke3RoaXMuaWNvbn0uc3ZnKWAsXHJcbiAgICAgICAgJ21hc2stc2l6ZSc6IHRoaXMuc2l6ZSxcclxuICAgICAgICAnd2lkdGgnOiB0aGlzLnNpemVCb3ggPyB0aGlzLnNpemVCb3ggOiB0aGlzLnNpemUsXHJcbiAgICAgICAgJ2hlaWdodCc6IHRoaXMuc2l6ZUJveCA/IHRoaXMuc2l6ZUJveCA6IHRoaXMuc2l6ZSxcclxuICAgICAgICAnYmFja2dyb3VuZC1jb2xvcic6IHRoaXMuYmFja2dyb3VuZENvbG9yLFxyXG4gICAgICB9O1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIHtcclxuICAgICAgJ2JhY2tncm91bmQtaW1hZ2UnOiBgdXJsKC4vYXNzZXRzL2ljb24vc3ZnLyR7dGhpcy5pY29ufS5zdmcpYCxcclxuICAgICAgJ2JhY2tncm91bmQtcmVwZWF0JzogJ25vLXJlcGVhdCcsXHJcbiAgICAgICdiYWNrZ3JvdW5kLXBvc2l0aW9uJzogJ2NlbnRlcicsXHJcbiAgICAgICdiYWNrZ3JvdW5kLXNpemUnOiAnY29udGFpbicsXHJcbiAgICAgICdiYWNrZ3JvdW5kLWNvbG9yJzogJ3RyYW5zcGFyZW50JyxcclxuICAgICAgJ3dpZHRoJzogdGhpcy5zaXplQm94ID8gdGhpcy5zaXplQm94IDogdGhpcy5zaXplLFxyXG4gICAgICAnaGVpZ2h0JzogdGhpcy5zaXplQm94ID8gdGhpcy5zaXplQm94IDogdGhpcy5zaXplXHJcbiAgICB9O1xyXG4gIH1cclxufVxyXG4iLCI8ZGl2ICNtYXNrQ29udGFpbmVyIGNsYXNzPVwie3tjbGFzc2VzfX1cIiBbbmdDbGFzc109XCJ7J2Rpc2FibGVkJzogZGlzYWJsZWQsXHJcbidhY3RpdmUnOiBhY3RpdmUsICdsaWdodCc6IGxpZ2h0IH1cIiBbbmdTdHlsZV09XCJnZXRTdHlsZXNcIj5cclxuPC9kaXY+Il19
|
|
@@ -1,31 +1,31 @@
|
|
|
1
|
-
import { Component, Input, EventEmitter, Output, ChangeDetectionStrategy } from '@angular/core';
|
|
2
|
-
import * as i0 from "@angular/core";
|
|
3
|
-
import * as i1 from "@angular/common";
|
|
4
|
-
import * as i2 from "@angular/material/button-toggle";
|
|
5
|
-
export class WmToggleComponent {
|
|
6
|
-
constructor() {
|
|
7
|
-
this.groupValue = 0;
|
|
8
|
-
this.model = [];
|
|
9
|
-
this.disable = false;
|
|
10
|
-
this.groupValueOutput = new EventEmitter();
|
|
11
|
-
}
|
|
12
|
-
onChange(idx) {
|
|
13
|
-
this.groupValue = idx;
|
|
14
|
-
this.groupValueOutput.emit(this.groupValue);
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
}
|
|
19
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
20
|
-
type: Component,
|
|
21
|
-
args: [{ selector: 'wm-toggle', changeDetection: ChangeDetectionStrategy.OnPush, template: "<mat-button-toggle-group #group=\"matButtonToggleGroup\" [value]=\"groupValue\" [disabled]=\"disable\">\r\n <mat-button-toggle *ngFor=\"let item of model; let idx = index\" [value]=\"idx\" (change)=\"onChange(idx)\">\r\n {{ item }}\r\n </mat-button-toggle>\r\n</mat-button-toggle-group>\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}}.mat-button-toggle-label-content{height:40px;align-items:center}.mat-button-toggle{font-size:16px;font-weight:500;color:var(--mediumFontColor);line-height:40px;outline:none;background:var(--pageBackgroundColor)}.mat-button-toggle-disabled{color:var(--disabledTextColor)}.mat-button-toggle-appearance-standard{padding:0 16px}.mat-button-toggle-group-appearance-standard{border-radius:50px!important;border-color:var(--secondaryHover)}.mat-button-toggle-checked{background-color:transparent!important;color:var(--brandColor)}\n"] }]
|
|
22
|
-
}], propDecorators: { groupValue: [{
|
|
23
|
-
type: Input
|
|
24
|
-
}], model: [{
|
|
25
|
-
type: Input
|
|
26
|
-
}], disable: [{
|
|
27
|
-
type: Input
|
|
28
|
-
}], groupValueOutput: [{
|
|
29
|
-
type: Output
|
|
30
|
-
}] } });
|
|
31
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
import { Component, Input, EventEmitter, Output, ChangeDetectionStrategy } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common";
|
|
4
|
+
import * as i2 from "@angular/material/button-toggle";
|
|
5
|
+
export class WmToggleComponent {
|
|
6
|
+
constructor() {
|
|
7
|
+
this.groupValue = 0;
|
|
8
|
+
this.model = [];
|
|
9
|
+
this.disable = false;
|
|
10
|
+
this.groupValueOutput = new EventEmitter();
|
|
11
|
+
}
|
|
12
|
+
onChange(idx) {
|
|
13
|
+
this.groupValue = idx;
|
|
14
|
+
this.groupValueOutput.emit(this.groupValue);
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
WmToggleComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: WmToggleComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
18
|
+
WmToggleComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.6", type: WmToggleComponent, selector: "wm-toggle", inputs: { groupValue: "groupValue", model: "model", disable: "disable" }, outputs: { groupValueOutput: "groupValueOutput" }, ngImport: i0, template: "<mat-button-toggle-group #group=\"matButtonToggleGroup\" [value]=\"groupValue\" [disabled]=\"disable\">\r\n <mat-button-toggle *ngFor=\"let item of model; let idx = index\" [value]=\"idx\" (change)=\"onChange(idx)\">\r\n {{ item }}\r\n </mat-button-toggle>\r\n</mat-button-toggle-group>\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}}.mat-button-toggle-label-content{height:40px;align-items:center}.mat-button-toggle{font-size:16px;font-weight:500;color:var(--mediumFontColor);line-height:40px;outline:none;background:var(--pageBackgroundColor)}.mat-button-toggle-disabled{color:var(--disabledTextColor)}.mat-button-toggle-appearance-standard{padding:0 16px}.mat-button-toggle-group-appearance-standard{border-radius:50px!important;border-color:var(--secondaryHover)}.mat-button-toggle-checked{background-color:transparent!important;color:var(--brandColor)}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.MatButtonToggleGroup, selector: "mat-button-toggle-group", inputs: ["appearance", "name", "vertical", "value", "multiple", "disabled"], outputs: ["valueChange", "change"], exportAs: ["matButtonToggleGroup"] }, { kind: "component", type: i2.MatButtonToggle, selector: "mat-button-toggle", inputs: ["disableRipple", "aria-label", "aria-labelledby", "id", "name", "value", "tabIndex", "appearance", "checked", "disabled"], outputs: ["change"], exportAs: ["matButtonToggle"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
19
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: WmToggleComponent, decorators: [{
|
|
20
|
+
type: Component,
|
|
21
|
+
args: [{ selector: 'wm-toggle', changeDetection: ChangeDetectionStrategy.OnPush, template: "<mat-button-toggle-group #group=\"matButtonToggleGroup\" [value]=\"groupValue\" [disabled]=\"disable\">\r\n <mat-button-toggle *ngFor=\"let item of model; let idx = index\" [value]=\"idx\" (change)=\"onChange(idx)\">\r\n {{ item }}\r\n </mat-button-toggle>\r\n</mat-button-toggle-group>\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}}.mat-button-toggle-label-content{height:40px;align-items:center}.mat-button-toggle{font-size:16px;font-weight:500;color:var(--mediumFontColor);line-height:40px;outline:none;background:var(--pageBackgroundColor)}.mat-button-toggle-disabled{color:var(--disabledTextColor)}.mat-button-toggle-appearance-standard{padding:0 16px}.mat-button-toggle-group-appearance-standard{border-radius:50px!important;border-color:var(--secondaryHover)}.mat-button-toggle-checked{background-color:transparent!important;color:var(--brandColor)}\n"] }]
|
|
22
|
+
}], propDecorators: { groupValue: [{
|
|
23
|
+
type: Input
|
|
24
|
+
}], model: [{
|
|
25
|
+
type: Input
|
|
26
|
+
}], disable: [{
|
|
27
|
+
type: Input
|
|
28
|
+
}], groupValueOutput: [{
|
|
29
|
+
type: Output
|
|
30
|
+
}] } });
|
|
31
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid20tdG9nZ2xlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2J0di1iYXNlLWNvbnRyb2xzL3NyYy9saWIvd20tdG9nZ2xlL3dtLXRvZ2dsZS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9idHYtYmFzZS1jb250cm9scy9zcmMvbGliL3dtLXRvZ2dsZS93bS10b2dnbGUuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxZQUFZLEVBQUUsTUFBTSxFQUFFLHVCQUF1QixFQUFFLE1BQU0sZUFBZSxDQUFDOzs7O0FBU2hHLE1BQU0sT0FBTyxpQkFBaUI7SUFQOUI7UUFRVyxlQUFVLEdBQUcsQ0FBQyxDQUFDO1FBQ2YsVUFBSyxHQUFhLEVBQUUsQ0FBQztRQUNyQixZQUFPLEdBQUcsS0FBSyxDQUFDO1FBQ2YscUJBQWdCLEdBQXlCLElBQUksWUFBWSxFQUFVLENBQUM7S0FNL0U7SUFKUSxRQUFRLENBQUMsR0FBVztRQUN6QixJQUFJLENBQUMsVUFBVSxHQUFHLEdBQUcsQ0FBQztRQUN0QixJQUFJLENBQUMsZ0JBQWdCLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUM5QyxDQUFDOzs4R0FUVSxpQkFBaUI7a0dBQWpCLGlCQUFpQiw4S0NUOUIsaVRBS0E7MkZESWEsaUJBQWlCO2tCQVA3QixTQUFTOytCQUNFLFdBQVcsbUJBR0osdUJBQXVCLENBQUMsTUFBTTs4QkFJdEMsVUFBVTtzQkFBbEIsS0FBSztnQkFDRyxLQUFLO3NCQUFiLEtBQUs7Z0JBQ0csT0FBTztzQkFBZixLQUFLO2dCQUNJLGdCQUFnQjtzQkFBekIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIEV2ZW50RW1pdHRlciwgT3V0cHV0LCBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICd3bS10b2dnbGUnLFxyXG4gIHN0eWxlVXJsczogWycuL3dtLXRvZ2dsZS5zY3NzJ10sXHJcbiAgdGVtcGxhdGVVcmw6ICcuL3dtLXRvZ2dsZS5odG1sJyxcclxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxyXG59KVxyXG5cclxuZXhwb3J0IGNsYXNzIFdtVG9nZ2xlQ29tcG9uZW50IHtcclxuICBASW5wdXQoKSBncm91cFZhbHVlID0gMDtcclxuICBASW5wdXQoKSBtb2RlbDogc3RyaW5nW10gPSBbXTtcclxuICBASW5wdXQoKSBkaXNhYmxlID0gZmFsc2U7XHJcbiAgQE91dHB1dCgpIGdyb3VwVmFsdWVPdXRwdXQ6IEV2ZW50RW1pdHRlcjxudW1iZXI+ID0gbmV3IEV2ZW50RW1pdHRlcjxudW1iZXI+KCk7XHJcblxyXG4gIHB1YmxpYyBvbkNoYW5nZShpZHg6IG51bWJlcikge1xyXG4gICAgdGhpcy5ncm91cFZhbHVlID0gaWR4O1xyXG4gICAgdGhpcy5ncm91cFZhbHVlT3V0cHV0LmVtaXQodGhpcy5ncm91cFZhbHVlKTtcclxuICB9XHJcbn1cclxuIiwiPG1hdC1idXR0b24tdG9nZ2xlLWdyb3VwICNncm91cD1cIm1hdEJ1dHRvblRvZ2dsZUdyb3VwXCIgW3ZhbHVlXT1cImdyb3VwVmFsdWVcIiBbZGlzYWJsZWRdPVwiZGlzYWJsZVwiPlxyXG4gICAgPG1hdC1idXR0b24tdG9nZ2xlICpuZ0Zvcj1cImxldCBpdGVtIG9mIG1vZGVsOyBsZXQgaWR4ID0gaW5kZXhcIiBbdmFsdWVdPVwiaWR4XCIgKGNoYW5nZSk9XCJvbkNoYW5nZShpZHgpXCI+XHJcbiAgICAgICAge3sgaXRlbSB9fVxyXG4gICAgPC9tYXQtYnV0dG9uLXRvZ2dsZT5cclxuPC9tYXQtYnV0dG9uLXRvZ2dsZS1ncm91cD5cclxuIl19
|