@kms-ngx-ui/presentational 0.0.24 → 14.0.0
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 +28 -28
- package/{esm2015/kms-ngx-ui-presentational.js → esm2020/kms-ngx-ui-presentational.mjs} +4 -4
- package/esm2020/lib/directives/directives.module.mjs +40 -0
- package/{esm2015/lib/directives/mousewheel.directive.js → esm2020/lib/directives/mousewheel.directive.mjs} +56 -56
- package/{esm2015/lib/directives/sum-of-height.directive.js → esm2020/lib/directives/sum-of-height.directive.mjs} +74 -74
- package/{esm2015/lib/directives/swipe.directive.js → esm2020/lib/directives/swipe.directive.mjs} +183 -183
- package/esm2020/lib/directives/swipe.model.mjs +5 -0
- package/{esm2015/lib/directives/tooltip.directive.js → esm2020/lib/directives/tooltip.directive.mjs} +144 -144
- package/esm2020/lib/kms-ngx-ui-presentational.component.mjs +22 -0
- package/{esm2015/lib/kms-ngx-ui-presentational.module.js → esm2020/lib/kms-ngx-ui-presentational.module.mjs} +215 -217
- package/{esm2015/lib/kms-ngx-ui-presentational.service.js → esm2020/lib/kms-ngx-ui-presentational.service.mjs} +14 -14
- package/esm2020/lib/models/address.model.mjs +6 -0
- package/{esm2015/lib/models/iconSize.enum.js → esm2020/lib/models/iconSize.enum.mjs} +17 -17
- package/{esm2015/lib/models/image-snippet.model.js → esm2020/lib/models/image-snippet.model.mjs} +18 -18
- package/{esm2015/lib/models/index.js → esm2020/lib/models/index.mjs} +5 -5
- package/{esm2015/lib/models/is-value.function.js → esm2020/lib/models/is-value.function.mjs} +17 -17
- package/{esm2015/lib/models/salutation.enum.js → esm2020/lib/models/salutation.enum.mjs} +8 -8
- package/{esm2015/lib/models/types/attached-file-dto.model.js → esm2020/lib/models/types/attached-file-dto.model.mjs} +6 -6
- package/{esm2015/lib/models/types/nullable.type.js → esm2020/lib/models/types/nullable.type.mjs} +5 -5
- package/{esm2015/lib/parent-components/actions.component.js → esm2020/lib/parent-components/actions.component.mjs} +56 -56
- package/esm2020/lib/parent-components/form-control.component.mjs +75 -0
- package/esm2020/lib/parent-components/form.component.mjs +78 -0
- package/{esm2015/lib/pipes/custom-pipes.module.js → esm2020/lib/pipes/custom-pipes.module.mjs} +71 -71
- package/esm2020/lib/pipes/decode-uri.pipe.mjs +19 -0
- package/esm2020/lib/pipes/encode-uri.pipe.mjs +19 -0
- package/{esm2015/lib/pipes/integer-currency.pipe.js → esm2020/lib/pipes/integer-currency.pipe.mjs} +27 -27
- package/{esm2015/lib/pipes/safe-html.pipe.js → esm2020/lib/pipes/safe-html.pipe.mjs} +23 -23
- package/{esm2015/lib/pipes/safe-resource-url.pipe.js → esm2020/lib/pipes/safe-resource-url.pipe.mjs} +23 -23
- package/{esm2015/lib/pipes/safe-style.pipe.js → esm2020/lib/pipes/safe-style.pipe.mjs} +23 -23
- package/{esm2015/lib/pipes/safe-url.pipe.js → esm2020/lib/pipes/safe-url.pipe.mjs} +23 -23
- package/{esm2015/lib/pipes/to-number.pipe.js → esm2020/lib/pipes/to-number.pipe.mjs} +23 -23
- package/{esm2015/lib/pipes/trim.pipe.js → esm2020/lib/pipes/trim.pipe.mjs} +20 -20
- package/{esm2015/lib/pipes/typeof.pipe.js → esm2020/lib/pipes/typeof.pipe.mjs} +16 -16
- package/esm2020/lib/services/viewport.service.mjs +216 -0
- package/esm2020/lib/ui/back-to-top/back-to-top.component.mjs +49 -0
- package/{esm2015/lib/ui/button-with-confirm-dialog/button-response-types.enum.js → esm2020/lib/ui/button-with-confirm-dialog/button-response-types.enum.mjs} +6 -6
- package/esm2020/lib/ui/button-with-confirm-dialog/button-with-confirm-dialog.component.mjs +58 -0
- package/{esm2015/lib/ui/button-with-confirm-dialog/dialog-data.model.js → esm2020/lib/ui/button-with-confirm-dialog/dialog-data.model.mjs} +2 -2
- package/esm2020/lib/ui/checkbox/checkbox.component.mjs +71 -0
- package/esm2020/lib/ui/color-input/color-input.component.mjs +76 -0
- package/esm2020/lib/ui/dropdown-from-data/dropdown-from-data.component.mjs +165 -0
- package/esm2020/lib/ui/enum-radiogroup/enum-radiogroup.component.mjs +53 -0
- package/esm2020/lib/ui/file-input/file-input.component.mjs +232 -0
- package/esm2020/lib/ui/flyout/flyout.component.mjs +119 -0
- package/esm2020/lib/ui/generic-dialog/generic-dialog.component.mjs +54 -0
- package/esm2020/lib/ui/icon/icon.component.mjs +48 -0
- package/esm2020/lib/ui/icon/iconSize.enum.mjs +17 -0
- package/esm2020/lib/ui/image-slider/image-slider.component.mjs +189 -0
- package/esm2020/lib/ui/kms-accordion-item/kms-accordion-item.component.mjs +40 -0
- package/esm2020/lib/ui/loader/loader.component.mjs +21 -0
- package/esm2020/lib/ui/map/map.component.mjs +116 -0
- package/esm2020/lib/ui/radiobutton/radiobutton.component.mjs +73 -0
- package/esm2020/lib/ui/salutation-dropdown/salutation-dropdown.component.mjs +55 -0
- package/esm2020/lib/ui/salutation-radiogroup/salutation-radiogroup.component.mjs +49 -0
- package/esm2020/lib/ui/time-input/time-input.component.mjs +83 -0
- package/esm2020/lib/ui/tooltip/tooltip.component.mjs +16 -0
- package/esm2020/lib/ui/tooltip-icon/tooltip-icon.component.mjs +35 -0
- package/esm2020/lib/ui/yes-no-radiogroup/yes-no-radiogroup.component.mjs +82 -0
- package/esm2020/public-api.mjs +49 -0
- package/fesm2015/kms-ngx-ui-presentational.mjs +3013 -0
- package/fesm2015/kms-ngx-ui-presentational.mjs.map +1 -0
- package/{fesm2015/kms-ngx-ui-presentational.js → fesm2020/kms-ngx-ui-presentational.mjs} +2894 -3108
- package/fesm2020/kms-ngx-ui-presentational.mjs.map +1 -0
- package/{kms-ngx-ui-presentational.d.ts → index.d.ts} +5 -5
- package/lib/directives/directives.module.d.ts +11 -13
- package/lib/directives/mousewheel.directive.d.ts +15 -15
- package/lib/directives/sum-of-height.directive.d.ts +31 -31
- package/lib/directives/swipe.directive.d.ts +45 -45
- package/lib/directives/swipe.model.d.ts +49 -49
- package/lib/directives/tooltip.directive.d.ts +29 -29
- package/lib/kms-ngx-ui-presentational.component.d.ts +8 -8
- package/lib/kms-ngx-ui-presentational.module.d.ts +47 -47
- package/lib/kms-ngx-ui-presentational.service.d.ts +6 -6
- package/lib/models/address.model.d.ts +14 -14
- package/lib/models/iconSize.enum.d.ts +15 -15
- package/lib/models/image-snippet.model.d.ts +15 -15
- package/lib/models/index.d.ts +4 -4
- package/lib/models/is-value.function.d.ts +9 -9
- package/lib/models/salutation.enum.d.ts +5 -5
- package/lib/models/types/attached-file-dto.model.d.ts +11 -11
- package/lib/models/types/nullable.type.d.ts +4 -4
- package/lib/parent-components/actions.component.d.ts +31 -31
- package/lib/parent-components/form-control.component.d.ts +27 -27
- package/lib/parent-components/form.component.d.ts +34 -40
- package/lib/pipes/custom-pipes.module.d.ts +17 -17
- package/lib/pipes/decode-uri.pipe.d.ts +10 -10
- package/lib/pipes/encode-uri.pipe.d.ts +10 -10
- package/lib/pipes/integer-currency.pipe.d.ts +13 -13
- package/lib/pipes/safe-html.pipe.d.ts +13 -13
- package/lib/pipes/safe-resource-url.pipe.d.ts +13 -13
- package/lib/pipes/safe-style.pipe.d.ts +13 -13
- package/lib/pipes/safe-url.pipe.d.ts +13 -13
- package/lib/pipes/to-number.pipe.d.ts +10 -10
- package/lib/pipes/trim.pipe.d.ts +10 -10
- package/lib/pipes/typeof.pipe.d.ts +7 -7
- package/lib/services/viewport.service.d.ts +74 -83
- package/lib/ui/back-to-top/back-to-top.component.d.ts +10 -10
- package/lib/ui/button-with-confirm-dialog/button-response-types.enum.d.ts +4 -4
- package/lib/ui/button-with-confirm-dialog/button-with-confirm-dialog.component.d.ts +19 -19
- package/lib/ui/button-with-confirm-dialog/dialog-data.model.d.ts +9 -9
- package/lib/ui/checkbox/checkbox.component.d.ts +31 -31
- package/lib/ui/color-input/color-input.component.d.ts +19 -19
- package/lib/ui/dropdown-from-data/dropdown-from-data.component.d.ts +55 -55
- package/lib/ui/enum-radiogroup/enum-radiogroup.component.d.ts +17 -17
- package/lib/ui/file-input/file-input.component.d.ts +89 -89
- package/lib/ui/flyout/flyout.component.d.ts +32 -32
- package/lib/ui/generic-dialog/generic-dialog.component.d.ts +26 -26
- package/lib/ui/icon/icon.component.d.ts +42 -48
- package/lib/ui/icon/iconSize.enum.d.ts +15 -25
- package/lib/ui/image-slider/image-slider.component.d.ts +62 -62
- package/lib/ui/kms-accordion-item/kms-accordion-item.component.d.ts +22 -22
- package/lib/ui/loader/loader.component.d.ts +9 -9
- package/lib/ui/map/map.component.d.ts +70 -69
- package/lib/ui/radiobutton/radiobutton.component.d.ts +26 -27
- package/lib/ui/salutation-dropdown/salutation-dropdown.component.d.ts +17 -17
- package/lib/ui/salutation-radiogroup/salutation-radiogroup.component.d.ts +15 -15
- package/lib/ui/time-input/time-input.component.d.ts +22 -22
- package/lib/ui/tooltip/tooltip.component.d.ts +6 -6
- package/lib/ui/tooltip-icon/tooltip-icon.component.d.ts +13 -13
- package/lib/ui/yes-no-radiogroup/yes-no-radiogroup.component.d.ts +27 -27
- package/package.json +27 -14
- package/public-api.d.ts +45 -46
- package/src/lib/ui/back-to-top/back-to-top.component.scss +46 -45
- package/src/lib/ui/button-with-confirm-dialog/button-with-confirm-dialog.component.scss +2 -2
- package/src/lib/ui/checkbox/checkbox.component.scss +48 -48
- package/src/lib/ui/color-input/color-input.component.scss +38 -38
- package/src/lib/ui/file-input/file-input.component.scss +2 -2
- package/src/lib/ui/flyout/flyout.component.scss +34 -34
- package/src/lib/ui/generic-dialog/generic-dialog.component.scss +59 -59
- package/src/lib/ui/icon/icon.component.scss +148 -114
- package/src/lib/ui/image-slider/image-slider.component.scss +219 -219
- package/src/lib/ui/kms-accordion-item/kms-accordion-item.component.scss +95 -95
- package/src/lib/ui/radiobutton/radiobutton.component.scss +31 -31
- package/src/lib/ui/time-input/time-input.component.scss +10 -10
- package/src/lib/ui/tooltip/tooltip.component.scss +26 -26
- package/src/lib/ui/tooltip-icon/tooltip-icon.component.scss +2 -2
- package/src/styles/mixins.scss +8 -8
- package/src/styles/styles.scss +30 -31
- package/bundles/kms-ngx-ui-presentational.umd.js +0 -3751
- package/bundles/kms-ngx-ui-presentational.umd.js.map +0 -1
- package/esm2015/lib/directives/directives.module.js +0 -45
- package/esm2015/lib/directives/size.directive.js +0 -21
- package/esm2015/lib/directives/swipe.model.js +0 -5
- package/esm2015/lib/kms-ngx-ui-presentational.component.js +0 -26
- package/esm2015/lib/models/address.model.js +0 -6
- package/esm2015/lib/parent-components/colorable.component.js +0 -35
- package/esm2015/lib/parent-components/form-control.component.js +0 -76
- package/esm2015/lib/parent-components/form.component.js +0 -99
- package/esm2015/lib/pipes/decode-uri.pipe.js +0 -19
- package/esm2015/lib/pipes/encode-uri.pipe.js +0 -19
- package/esm2015/lib/services/viewport.service.js +0 -242
- package/esm2015/lib/ui/back-to-top/back-to-top.component.js +0 -52
- package/esm2015/lib/ui/button-with-confirm-dialog/button-with-confirm-dialog.component.js +0 -62
- package/esm2015/lib/ui/checkbox/checkbox.component.js +0 -76
- package/esm2015/lib/ui/color-input/color-input.component.js +0 -81
- package/esm2015/lib/ui/dropdown-from-data/dropdown-from-data.component.js +0 -169
- package/esm2015/lib/ui/enum-radiogroup/enum-radiogroup.component.js +0 -57
- package/esm2015/lib/ui/file-input/file-input.component.js +0 -237
- package/esm2015/lib/ui/flyout/flyout.component.js +0 -125
- package/esm2015/lib/ui/generic-dialog/generic-dialog.component.js +0 -58
- package/esm2015/lib/ui/icon/icon.component.js +0 -55
- package/esm2015/lib/ui/icon/iconSize.enum.js +0 -28
- package/esm2015/lib/ui/image-slider/image-slider.component.js +0 -193
- package/esm2015/lib/ui/kms-accordion-item/kms-accordion-item.component.js +0 -44
- package/esm2015/lib/ui/loader/loader.component.js +0 -25
- package/esm2015/lib/ui/map/map.component.js +0 -120
- package/esm2015/lib/ui/radiobutton/radiobutton.component.js +0 -82
- package/esm2015/lib/ui/salutation-dropdown/salutation-dropdown.component.js +0 -59
- package/esm2015/lib/ui/salutation-radiogroup/salutation-radiogroup.component.js +0 -53
- package/esm2015/lib/ui/time-input/time-input.component.js +0 -88
- package/esm2015/lib/ui/tooltip/tooltip.component.js +0 -20
- package/esm2015/lib/ui/tooltip-icon/tooltip-icon.component.js +0 -40
- package/esm2015/lib/ui/yes-no-radiogroup/yes-no-radiogroup.component.js +0 -86
- package/esm2015/public-api.js +0 -50
- package/fesm2015/kms-ngx-ui-presentational.js.map +0 -1
- package/lib/directives/size.directive.d.ts +0 -10
- package/lib/parent-components/colorable.component.d.ts +0 -10
- package/src/styles/animations.scss +0 -47
package/{esm2015/lib/directives/tooltip.directive.js → esm2020/lib/directives/tooltip.directive.mjs}
RENAMED
|
@@ -1,144 +1,144 @@
|
|
|
1
|
-
import { Directive, Input, HostListener } from '@angular/core';
|
|
2
|
-
import * as i0 from "@angular/core";
|
|
3
|
-
export class TooltipDirective {
|
|
4
|
-
constructor(el, renderer) {
|
|
5
|
-
this.el = el;
|
|
6
|
-
this.renderer = renderer;
|
|
7
|
-
this.tooltipTitle = "";
|
|
8
|
-
this.tooltipText = "";
|
|
9
|
-
this.tooltipLinkText = "";
|
|
10
|
-
this.tooltipLinkUrl = "";
|
|
11
|
-
this.tooltipPlacement = "bottom";
|
|
12
|
-
this.tooltipDelay = 1000;
|
|
13
|
-
this.tooltipPlaceIntoHost = false;
|
|
14
|
-
this.tooltipOnlyonclick = false;
|
|
15
|
-
this.offset = 0;
|
|
16
|
-
}
|
|
17
|
-
onMouseEnter() {
|
|
18
|
-
if (!this.tooltipOnlyonclick) {
|
|
19
|
-
this.show();
|
|
20
|
-
}
|
|
21
|
-
}
|
|
22
|
-
onClick() {
|
|
23
|
-
if (this.tooltipOnlyonclick) {
|
|
24
|
-
this.show();
|
|
25
|
-
}
|
|
26
|
-
}
|
|
27
|
-
onMouseLeave() {
|
|
28
|
-
if (this.tooltipElem) {
|
|
29
|
-
this.hide();
|
|
30
|
-
}
|
|
31
|
-
}
|
|
32
|
-
show() {
|
|
33
|
-
if (!this.tooltipElem) {
|
|
34
|
-
this.create();
|
|
35
|
-
this.setPosition();
|
|
36
|
-
}
|
|
37
|
-
this.renderer.addClass(this.tooltipElem, 'tooltip-show');
|
|
38
|
-
}
|
|
39
|
-
hide() {
|
|
40
|
-
this.renderer.removeClass(this.tooltipElem, 'tooltip-show');
|
|
41
|
-
window.setTimeout(() => {
|
|
42
|
-
}, this.tooltipDelay);
|
|
43
|
-
}
|
|
44
|
-
create() {
|
|
45
|
-
this.tooltipElem = this.renderer.createElement('kms-tooltip-element');
|
|
46
|
-
this.tooltipTitleElem = this.renderer.createElement('b');
|
|
47
|
-
this.renderer.appendChild(this.tooltipTitleElem, this.renderer.createText(this.tooltipTitle));
|
|
48
|
-
this.renderer.appendChild(this.tooltipElem, this.tooltipTitleElem);
|
|
49
|
-
this.tooltipTextElem = this.renderer.createElement('div');
|
|
50
|
-
this.renderer.appendChild(this.tooltipTextElem, this.renderer.createText(this.tooltipText));
|
|
51
|
-
this.renderer.appendChild(this.tooltipElem, this.tooltipTextElem);
|
|
52
|
-
this.tooltipLinkElem = this.renderer.createElement('a');
|
|
53
|
-
this.renderer.setAttribute(this.tooltipLinkElem, 'href', this.tooltipLinkUrl);
|
|
54
|
-
this.renderer.appendChild(this.tooltipLinkElem, this.renderer.createText(this.tooltipLinkText));
|
|
55
|
-
this.renderer.appendChild(this.tooltipElem, this.tooltipLinkElem);
|
|
56
|
-
if (this.tooltipPlaceIntoHost) {
|
|
57
|
-
this.renderer.appendChild(this.el.nativeElement, this.tooltipElem);
|
|
58
|
-
}
|
|
59
|
-
else {
|
|
60
|
-
this.renderer.appendChild(document.body, this.tooltipElem);
|
|
61
|
-
}
|
|
62
|
-
this.renderer.addClass(this.tooltipElem, 'tooltip');
|
|
63
|
-
this.renderer.addClass(this.tooltipElem, `tooltip-${this.tooltipPlacement}`);
|
|
64
|
-
this.renderer.setStyle(this.tooltipElem, '-webkit-transition', `opacity ${this.tooltipDelay}ms`);
|
|
65
|
-
this.renderer.setStyle(this.tooltipElem, '-moz-transition', `opacity ${this.tooltipDelay}ms`);
|
|
66
|
-
this.renderer.setStyle(this.tooltipElem, '-o-transition', `opacity ${this.tooltipDelay}ms`);
|
|
67
|
-
this.renderer.setStyle(this.tooltipElem, 'transition', `opacity ${this.tooltipDelay}ms`);
|
|
68
|
-
}
|
|
69
|
-
setPosition() {
|
|
70
|
-
if (this.tooltipElem) {
|
|
71
|
-
const hostPos = this.el.nativeElement.getBoundingClientRect();
|
|
72
|
-
const tooltipPos = this.tooltipElem.getBoundingClientRect();
|
|
73
|
-
let top, left;
|
|
74
|
-
if (this.tooltipPlaceIntoHost) {
|
|
75
|
-
left = 0;
|
|
76
|
-
top = hostPos.height;
|
|
77
|
-
}
|
|
78
|
-
else {
|
|
79
|
-
const scrollPos = window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop || 0;
|
|
80
|
-
if (this.tooltipPlacement === 'top') {
|
|
81
|
-
top = hostPos.top - tooltipPos.height - this.offset;
|
|
82
|
-
left = hostPos.left + (hostPos.width - tooltipPos.width) / 2;
|
|
83
|
-
}
|
|
84
|
-
if (!this.tooltipPlacement || this.tooltipPlacement === 'bottom') {
|
|
85
|
-
top = hostPos.bottom + this.offset;
|
|
86
|
-
left = hostPos.left + (hostPos.width - tooltipPos.width) / 2;
|
|
87
|
-
}
|
|
88
|
-
if (this.tooltipPlacement === 'left') {
|
|
89
|
-
top = hostPos.top + (hostPos.height - tooltipPos.height) / 2;
|
|
90
|
-
left = hostPos.left - tooltipPos.width - this.offset;
|
|
91
|
-
}
|
|
92
|
-
if (this.tooltipPlacement === 'right') {
|
|
93
|
-
top = hostPos.top + (hostPos.height - tooltipPos.height) / 2;
|
|
94
|
-
left = hostPos.right + this.offset;
|
|
95
|
-
}
|
|
96
|
-
top += scrollPos;
|
|
97
|
-
}
|
|
98
|
-
this.renderer.setStyle(this.tooltipElem, 'top', `${top}px`);
|
|
99
|
-
this.renderer.setStyle(this.tooltipElem, 'left', `${left}px`);
|
|
100
|
-
}
|
|
101
|
-
}
|
|
102
|
-
}
|
|
103
|
-
TooltipDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
104
|
-
TooltipDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "
|
|
105
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
106
|
-
type: Directive,
|
|
107
|
-
args: [{
|
|
108
|
-
selector: '[kmsTooltip]'
|
|
109
|
-
}]
|
|
110
|
-
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }]; }, propDecorators: { tooltipTitle: [{
|
|
111
|
-
type: Input,
|
|
112
|
-
args: ['tooltipTitle']
|
|
113
|
-
}], tooltipText: [{
|
|
114
|
-
type: Input,
|
|
115
|
-
args: ['tooltipText']
|
|
116
|
-
}], tooltipLinkText: [{
|
|
117
|
-
type: Input,
|
|
118
|
-
args: ['tooltipLinkText']
|
|
119
|
-
}], tooltipLinkUrl: [{
|
|
120
|
-
type: Input,
|
|
121
|
-
args: ['tooltipLinkUrl']
|
|
122
|
-
}], tooltipPlacement: [{
|
|
123
|
-
type: Input,
|
|
124
|
-
args: ['tooltipPlacement']
|
|
125
|
-
}], tooltipDelay: [{
|
|
126
|
-
type: Input,
|
|
127
|
-
args: ['tooltipDelay']
|
|
128
|
-
}], tooltipPlaceIntoHost: [{
|
|
129
|
-
type: Input,
|
|
130
|
-
args: ['tooltipPlaceIntoHost']
|
|
131
|
-
}], tooltipOnlyonclick: [{
|
|
132
|
-
type: Input,
|
|
133
|
-
args: ['tooltipOnlyonclick']
|
|
134
|
-
}], onMouseEnter: [{
|
|
135
|
-
type: HostListener,
|
|
136
|
-
args: ['mouseenter']
|
|
137
|
-
}], onClick: [{
|
|
138
|
-
type: HostListener,
|
|
139
|
-
args: ['click']
|
|
140
|
-
}], onMouseLeave: [{
|
|
141
|
-
type: HostListener,
|
|
142
|
-
args: ['mouseleave']
|
|
143
|
-
}] } });
|
|
144
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.directive.js","sourceRoot":"","sources":["../../../../../../projects/kms-ngx-ui-presentational/src/lib/directives/tooltip.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, Input, ElementRef, HostListener, Renderer2 } from '@angular/core';\r\n\r\n@Directive({\r\n    selector: '[kmsTooltip]'\r\n})\r\nexport class TooltipDirective {\r\n    @Input('tooltipTitle') tooltipTitle = \"\";\r\n    @Input('tooltipText') tooltipText = \"\";\r\n    @Input('tooltipLinkText') tooltipLinkText = \"\";\r\n    @Input('tooltipLinkUrl') tooltipLinkUrl = \"\";\r\n    @Input('tooltipPlacement') tooltipPlacement = \"bottom\";\r\n    @Input('tooltipDelay') tooltipDelay = 1000;\r\n    @Input('tooltipPlaceIntoHost') tooltipPlaceIntoHost = false;\r\n    @Input('tooltipOnlyonclick') tooltipOnlyonclick = false;\r\n\r\n    tooltipElem?: HTMLElement | undefined;\r\n    tooltipLinkElem?: HTMLElement | undefined;\r\n    tooltipTitleElem?: HTMLElement | undefined;\r\n    tooltipTextElem?: HTMLElement | undefined;\r\n    offset = 0;\r\n\r\n    constructor(private el: ElementRef, private renderer: Renderer2) {\r\n\r\n    }\r\n\r\n    @HostListener('mouseenter') onMouseEnter() {\r\n        if (!this.tooltipOnlyonclick) { this.show(); }\r\n    }\r\n\r\n    @HostListener('click') onClick() {\r\n        if (this.tooltipOnlyonclick) { this.show(); }\r\n    }\r\n\r\n    @HostListener('mouseleave') onMouseLeave() {\r\n        if (this.tooltipElem) { this.hide(); }\r\n    }\r\n\r\n    show() {\r\n        if (!this.tooltipElem){\r\n            this.create();\r\n            this.setPosition();\r\n        }\r\n        this.renderer.addClass(this.tooltipElem, 'tooltip-show');\r\n    }\r\n\r\n    hide() {\r\n        this.renderer.removeClass(this.tooltipElem, 'tooltip-show');\r\n        window.setTimeout(() => {\r\n        }, this.tooltipDelay);\r\n    }\r\n\r\n    create() {\r\n        this.tooltipElem = this.renderer.createElement('kms-tooltip-element');\r\n\r\n        this.tooltipTitleElem = this.renderer.createElement('b');\r\n        this.renderer.appendChild(this.tooltipTitleElem, this.renderer.createText(this.tooltipTitle));\r\n        this.renderer.appendChild(this.tooltipElem, this.tooltipTitleElem);\r\n        \r\n        this.tooltipTextElem = this.renderer.createElement('div');\r\n        this.renderer.appendChild(this.tooltipTextElem, this.renderer.createText(this.tooltipText));\r\n        this.renderer.appendChild(this.tooltipElem, this.tooltipTextElem);\r\n        \r\n        this.tooltipLinkElem = this.renderer.createElement('a');\r\n        this.renderer.setAttribute(this.tooltipLinkElem, 'href', this.tooltipLinkUrl);\r\n        this.renderer.appendChild(this.tooltipLinkElem, this.renderer.createText(this.tooltipLinkText));\r\n        this.renderer.appendChild(this.tooltipElem, this.tooltipLinkElem);\r\n\r\n        if(this.tooltipPlaceIntoHost){\r\n            this.renderer.appendChild(this.el.nativeElement, this.tooltipElem);\r\n        }else{\r\n            this.renderer.appendChild(document.body, this.tooltipElem);\r\n        }\r\n\r\n        this.renderer.addClass(this.tooltipElem, 'tooltip');\r\n        this.renderer.addClass(this.tooltipElem, `tooltip-${this.tooltipPlacement}`);\r\n        this.renderer.setStyle(this.tooltipElem, '-webkit-transition', `opacity ${this.tooltipDelay}ms`);\r\n        this.renderer.setStyle(this.tooltipElem, '-moz-transition', `opacity ${this.tooltipDelay}ms`);\r\n        this.renderer.setStyle(this.tooltipElem, '-o-transition', `opacity ${this.tooltipDelay}ms`);\r\n        this.renderer.setStyle(this.tooltipElem, 'transition', `opacity ${this.tooltipDelay}ms`);\r\n    }\r\n\r\n    setPosition() {\r\n        if(this.tooltipElem){\r\n            const hostPos = this.el.nativeElement.getBoundingClientRect();\r\n            const tooltipPos = this.tooltipElem.getBoundingClientRect();\r\n\r\n            let top, left;\r\n\r\n            if(this.tooltipPlaceIntoHost){\r\n                left = 0;\r\n                top = hostPos.height; \r\n            } else {\r\n                const scrollPos = window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop || 0;\r\n\r\n                if (this.tooltipPlacement === 'top') {\r\n                    top = hostPos.top - tooltipPos.height - this.offset;\r\n                    left = hostPos.left + (hostPos.width - tooltipPos.width) / 2;\r\n                }\r\n\r\n                if (!this.tooltipPlacement || this.tooltipPlacement === 'bottom') {\r\n                    top = hostPos.bottom + this.offset;\r\n                    left = hostPos.left + (hostPos.width - tooltipPos.width) / 2;\r\n                }\r\n\r\n                if (this.tooltipPlacement === 'left') {\r\n                    top = hostPos.top + (hostPos.height - tooltipPos.height) / 2;\r\n                    left = hostPos.left - tooltipPos.width - this.offset;\r\n                }\r\n\r\n                if (this.tooltipPlacement === 'right') {\r\n                    top = hostPos.top + (hostPos.height - tooltipPos.height) / 2;\r\n                    left = hostPos.right + this.offset;\r\n                }\r\n                top += scrollPos;\r\n            }\r\n\r\n            this.renderer.setStyle(this.tooltipElem, 'top', `${top}px`);\r\n            this.renderer.setStyle(this.tooltipElem, 'left', `${left}px`);\r\n        }\r\n    }\r\n}"]}
|
|
1
|
+
import { Directive, Input, HostListener } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class TooltipDirective {
|
|
4
|
+
constructor(el, renderer) {
|
|
5
|
+
this.el = el;
|
|
6
|
+
this.renderer = renderer;
|
|
7
|
+
this.tooltipTitle = "";
|
|
8
|
+
this.tooltipText = "";
|
|
9
|
+
this.tooltipLinkText = "";
|
|
10
|
+
this.tooltipLinkUrl = "";
|
|
11
|
+
this.tooltipPlacement = "bottom";
|
|
12
|
+
this.tooltipDelay = 1000;
|
|
13
|
+
this.tooltipPlaceIntoHost = false;
|
|
14
|
+
this.tooltipOnlyonclick = false;
|
|
15
|
+
this.offset = 0;
|
|
16
|
+
}
|
|
17
|
+
onMouseEnter() {
|
|
18
|
+
if (!this.tooltipOnlyonclick) {
|
|
19
|
+
this.show();
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
onClick() {
|
|
23
|
+
if (this.tooltipOnlyonclick) {
|
|
24
|
+
this.show();
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
onMouseLeave() {
|
|
28
|
+
if (this.tooltipElem) {
|
|
29
|
+
this.hide();
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
show() {
|
|
33
|
+
if (!this.tooltipElem) {
|
|
34
|
+
this.create();
|
|
35
|
+
this.setPosition();
|
|
36
|
+
}
|
|
37
|
+
this.renderer.addClass(this.tooltipElem, 'tooltip-show');
|
|
38
|
+
}
|
|
39
|
+
hide() {
|
|
40
|
+
this.renderer.removeClass(this.tooltipElem, 'tooltip-show');
|
|
41
|
+
window.setTimeout(() => {
|
|
42
|
+
}, this.tooltipDelay);
|
|
43
|
+
}
|
|
44
|
+
create() {
|
|
45
|
+
this.tooltipElem = this.renderer.createElement('kms-tooltip-element');
|
|
46
|
+
this.tooltipTitleElem = this.renderer.createElement('b');
|
|
47
|
+
this.renderer.appendChild(this.tooltipTitleElem, this.renderer.createText(this.tooltipTitle));
|
|
48
|
+
this.renderer.appendChild(this.tooltipElem, this.tooltipTitleElem);
|
|
49
|
+
this.tooltipTextElem = this.renderer.createElement('div');
|
|
50
|
+
this.renderer.appendChild(this.tooltipTextElem, this.renderer.createText(this.tooltipText));
|
|
51
|
+
this.renderer.appendChild(this.tooltipElem, this.tooltipTextElem);
|
|
52
|
+
this.tooltipLinkElem = this.renderer.createElement('a');
|
|
53
|
+
this.renderer.setAttribute(this.tooltipLinkElem, 'href', this.tooltipLinkUrl);
|
|
54
|
+
this.renderer.appendChild(this.tooltipLinkElem, this.renderer.createText(this.tooltipLinkText));
|
|
55
|
+
this.renderer.appendChild(this.tooltipElem, this.tooltipLinkElem);
|
|
56
|
+
if (this.tooltipPlaceIntoHost) {
|
|
57
|
+
this.renderer.appendChild(this.el.nativeElement, this.tooltipElem);
|
|
58
|
+
}
|
|
59
|
+
else {
|
|
60
|
+
this.renderer.appendChild(document.body, this.tooltipElem);
|
|
61
|
+
}
|
|
62
|
+
this.renderer.addClass(this.tooltipElem, 'tooltip');
|
|
63
|
+
this.renderer.addClass(this.tooltipElem, `tooltip-${this.tooltipPlacement}`);
|
|
64
|
+
this.renderer.setStyle(this.tooltipElem, '-webkit-transition', `opacity ${this.tooltipDelay}ms`);
|
|
65
|
+
this.renderer.setStyle(this.tooltipElem, '-moz-transition', `opacity ${this.tooltipDelay}ms`);
|
|
66
|
+
this.renderer.setStyle(this.tooltipElem, '-o-transition', `opacity ${this.tooltipDelay}ms`);
|
|
67
|
+
this.renderer.setStyle(this.tooltipElem, 'transition', `opacity ${this.tooltipDelay}ms`);
|
|
68
|
+
}
|
|
69
|
+
setPosition() {
|
|
70
|
+
if (this.tooltipElem) {
|
|
71
|
+
const hostPos = this.el.nativeElement.getBoundingClientRect();
|
|
72
|
+
const tooltipPos = this.tooltipElem.getBoundingClientRect();
|
|
73
|
+
let top, left;
|
|
74
|
+
if (this.tooltipPlaceIntoHost) {
|
|
75
|
+
left = 0;
|
|
76
|
+
top = hostPos.height;
|
|
77
|
+
}
|
|
78
|
+
else {
|
|
79
|
+
const scrollPos = window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop || 0;
|
|
80
|
+
if (this.tooltipPlacement === 'top') {
|
|
81
|
+
top = hostPos.top - tooltipPos.height - this.offset;
|
|
82
|
+
left = hostPos.left + (hostPos.width - tooltipPos.width) / 2;
|
|
83
|
+
}
|
|
84
|
+
if (!this.tooltipPlacement || this.tooltipPlacement === 'bottom') {
|
|
85
|
+
top = hostPos.bottom + this.offset;
|
|
86
|
+
left = hostPos.left + (hostPos.width - tooltipPos.width) / 2;
|
|
87
|
+
}
|
|
88
|
+
if (this.tooltipPlacement === 'left') {
|
|
89
|
+
top = hostPos.top + (hostPos.height - tooltipPos.height) / 2;
|
|
90
|
+
left = hostPos.left - tooltipPos.width - this.offset;
|
|
91
|
+
}
|
|
92
|
+
if (this.tooltipPlacement === 'right') {
|
|
93
|
+
top = hostPos.top + (hostPos.height - tooltipPos.height) / 2;
|
|
94
|
+
left = hostPos.right + this.offset;
|
|
95
|
+
}
|
|
96
|
+
top += scrollPos;
|
|
97
|
+
}
|
|
98
|
+
this.renderer.setStyle(this.tooltipElem, 'top', `${top}px`);
|
|
99
|
+
this.renderer.setStyle(this.tooltipElem, 'left', `${left}px`);
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
TooltipDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TooltipDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive });
|
|
104
|
+
TooltipDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.3.0", type: TooltipDirective, selector: "[kmsTooltip]", inputs: { tooltipTitle: "tooltipTitle", tooltipText: "tooltipText", tooltipLinkText: "tooltipLinkText", tooltipLinkUrl: "tooltipLinkUrl", tooltipPlacement: "tooltipPlacement", tooltipDelay: "tooltipDelay", tooltipPlaceIntoHost: "tooltipPlaceIntoHost", tooltipOnlyonclick: "tooltipOnlyonclick" }, host: { listeners: { "mouseenter": "onMouseEnter()", "click": "onClick()", "mouseleave": "onMouseLeave()" } }, ngImport: i0 });
|
|
105
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TooltipDirective, decorators: [{
|
|
106
|
+
type: Directive,
|
|
107
|
+
args: [{
|
|
108
|
+
selector: '[kmsTooltip]'
|
|
109
|
+
}]
|
|
110
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }]; }, propDecorators: { tooltipTitle: [{
|
|
111
|
+
type: Input,
|
|
112
|
+
args: ['tooltipTitle']
|
|
113
|
+
}], tooltipText: [{
|
|
114
|
+
type: Input,
|
|
115
|
+
args: ['tooltipText']
|
|
116
|
+
}], tooltipLinkText: [{
|
|
117
|
+
type: Input,
|
|
118
|
+
args: ['tooltipLinkText']
|
|
119
|
+
}], tooltipLinkUrl: [{
|
|
120
|
+
type: Input,
|
|
121
|
+
args: ['tooltipLinkUrl']
|
|
122
|
+
}], tooltipPlacement: [{
|
|
123
|
+
type: Input,
|
|
124
|
+
args: ['tooltipPlacement']
|
|
125
|
+
}], tooltipDelay: [{
|
|
126
|
+
type: Input,
|
|
127
|
+
args: ['tooltipDelay']
|
|
128
|
+
}], tooltipPlaceIntoHost: [{
|
|
129
|
+
type: Input,
|
|
130
|
+
args: ['tooltipPlaceIntoHost']
|
|
131
|
+
}], tooltipOnlyonclick: [{
|
|
132
|
+
type: Input,
|
|
133
|
+
args: ['tooltipOnlyonclick']
|
|
134
|
+
}], onMouseEnter: [{
|
|
135
|
+
type: HostListener,
|
|
136
|
+
args: ['mouseenter']
|
|
137
|
+
}], onClick: [{
|
|
138
|
+
type: HostListener,
|
|
139
|
+
args: ['click']
|
|
140
|
+
}], onMouseLeave: [{
|
|
141
|
+
type: HostListener,
|
|
142
|
+
args: ['mouseleave']
|
|
143
|
+
}] } });
|
|
144
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.directive.js","sourceRoot":"","sources":["../../../../../../projects/kms-ngx-ui-presentational/src/lib/directives/tooltip.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, Input, ElementRef, HostListener, Renderer2 } from '@angular/core';\n\n@Directive({\n    selector: '[kmsTooltip]'\n})\nexport class TooltipDirective {\n    @Input('tooltipTitle') tooltipTitle = \"\";\n    @Input('tooltipText') tooltipText = \"\";\n    @Input('tooltipLinkText') tooltipLinkText = \"\";\n    @Input('tooltipLinkUrl') tooltipLinkUrl = \"\";\n    @Input('tooltipPlacement') tooltipPlacement = \"bottom\";\n    @Input('tooltipDelay') tooltipDelay = 1000;\n    @Input('tooltipPlaceIntoHost') tooltipPlaceIntoHost = false;\n    @Input('tooltipOnlyonclick') tooltipOnlyonclick = false;\n\n    tooltipElem?: HTMLElement | undefined;\n    tooltipLinkElem?: HTMLElement | undefined;\n    tooltipTitleElem?: HTMLElement | undefined;\n    tooltipTextElem?: HTMLElement | undefined;\n    offset = 0;\n\n    constructor(private el: ElementRef, private renderer: Renderer2) {\n\n    }\n\n    @HostListener('mouseenter') onMouseEnter() {\n        if (!this.tooltipOnlyonclick) { this.show(); }\n    }\n\n    @HostListener('click') onClick() {\n        if (this.tooltipOnlyonclick) { this.show(); }\n    }\n\n    @HostListener('mouseleave') onMouseLeave() {\n        if (this.tooltipElem) { this.hide(); }\n    }\n\n    show() {\n        if (!this.tooltipElem){\n            this.create();\n            this.setPosition();\n        }\n        this.renderer.addClass(this.tooltipElem, 'tooltip-show');\n    }\n\n    hide() {\n        this.renderer.removeClass(this.tooltipElem, 'tooltip-show');\n        window.setTimeout(() => {\n        }, this.tooltipDelay);\n    }\n\n    create() {\n        this.tooltipElem = this.renderer.createElement('kms-tooltip-element');\n\n        this.tooltipTitleElem = this.renderer.createElement('b');\n        this.renderer.appendChild(this.tooltipTitleElem, this.renderer.createText(this.tooltipTitle));\n        this.renderer.appendChild(this.tooltipElem, this.tooltipTitleElem);\n        \n        this.tooltipTextElem = this.renderer.createElement('div');\n        this.renderer.appendChild(this.tooltipTextElem, this.renderer.createText(this.tooltipText));\n        this.renderer.appendChild(this.tooltipElem, this.tooltipTextElem);\n        \n        this.tooltipLinkElem = this.renderer.createElement('a');\n        this.renderer.setAttribute(this.tooltipLinkElem, 'href', this.tooltipLinkUrl);\n        this.renderer.appendChild(this.tooltipLinkElem, this.renderer.createText(this.tooltipLinkText));\n        this.renderer.appendChild(this.tooltipElem, this.tooltipLinkElem);\n\n        if(this.tooltipPlaceIntoHost){\n            this.renderer.appendChild(this.el.nativeElement, this.tooltipElem);\n        }else{\n            this.renderer.appendChild(document.body, this.tooltipElem);\n        }\n\n        this.renderer.addClass(this.tooltipElem, 'tooltip');\n        this.renderer.addClass(this.tooltipElem, `tooltip-${this.tooltipPlacement}`);\n        this.renderer.setStyle(this.tooltipElem, '-webkit-transition', `opacity ${this.tooltipDelay}ms`);\n        this.renderer.setStyle(this.tooltipElem, '-moz-transition', `opacity ${this.tooltipDelay}ms`);\n        this.renderer.setStyle(this.tooltipElem, '-o-transition', `opacity ${this.tooltipDelay}ms`);\n        this.renderer.setStyle(this.tooltipElem, 'transition', `opacity ${this.tooltipDelay}ms`);\n    }\n\n    setPosition() {\n        if(this.tooltipElem){\n            const hostPos = this.el.nativeElement.getBoundingClientRect();\n            const tooltipPos = this.tooltipElem.getBoundingClientRect();\n\n            let top, left;\n\n            if(this.tooltipPlaceIntoHost){\n                left = 0;\n                top = hostPos.height; \n            } else {\n                const scrollPos = window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop || 0;\n\n                if (this.tooltipPlacement === 'top') {\n                    top = hostPos.top - tooltipPos.height - this.offset;\n                    left = hostPos.left + (hostPos.width - tooltipPos.width) / 2;\n                }\n\n                if (!this.tooltipPlacement || this.tooltipPlacement === 'bottom') {\n                    top = hostPos.bottom + this.offset;\n                    left = hostPos.left + (hostPos.width - tooltipPos.width) / 2;\n                }\n\n                if (this.tooltipPlacement === 'left') {\n                    top = hostPos.top + (hostPos.height - tooltipPos.height) / 2;\n                    left = hostPos.left - tooltipPos.width - this.offset;\n                }\n\n                if (this.tooltipPlacement === 'right') {\n                    top = hostPos.top + (hostPos.height - tooltipPos.height) / 2;\n                    left = hostPos.right + this.offset;\n                }\n                top += scrollPos;\n            }\n\n            this.renderer.setStyle(this.tooltipElem, 'top', `${top}px`);\n            this.renderer.setStyle(this.tooltipElem, 'left', `${left}px`);\n        }\n    }\n}"]}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { Component } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class KmsUiPresentationalComponent {
|
|
4
|
+
constructor() { }
|
|
5
|
+
ngOnInit() {
|
|
6
|
+
}
|
|
7
|
+
}
|
|
8
|
+
KmsUiPresentationalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: KmsUiPresentationalComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
9
|
+
KmsUiPresentationalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: KmsUiPresentationalComponent, selector: "lib-kms-ngx-ui-presentational", ngImport: i0, template: `
|
|
10
|
+
<p>
|
|
11
|
+
kms-ngx-ui-presentational works!
|
|
12
|
+
</p>
|
|
13
|
+
`, isInline: true });
|
|
14
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: KmsUiPresentationalComponent, decorators: [{
|
|
15
|
+
type: Component,
|
|
16
|
+
args: [{ selector: 'lib-kms-ngx-ui-presentational', template: `
|
|
17
|
+
<p>
|
|
18
|
+
kms-ngx-ui-presentational works!
|
|
19
|
+
</p>
|
|
20
|
+
` }]
|
|
21
|
+
}], ctorParameters: function () { return []; } });
|
|
22
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia21zLW5neC11aS1wcmVzZW50YXRpb25hbC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9rbXMtbmd4LXVpLXByZXNlbnRhdGlvbmFsL3NyYy9saWIva21zLW5neC11aS1wcmVzZW50YXRpb25hbC5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBVSxNQUFNLGVBQWUsQ0FBQzs7QUFZbEQsTUFBTSxPQUFPLDRCQUE0QjtJQUV2QyxnQkFBZ0IsQ0FBQztJQUVqQixRQUFRO0lBQ1IsQ0FBQzs7eUhBTFUsNEJBQTRCOzZHQUE1Qiw0QkFBNEIscUVBUjdCOzs7O0dBSVQ7MkZBSVUsNEJBQTRCO2tCQVZ4QyxTQUFTOytCQUNFLCtCQUErQixZQUMvQjs7OztHQUlUIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnbGliLWttcy1uZ3gtdWktcHJlc2VudGF0aW9uYWwnLFxuICB0ZW1wbGF0ZTogYFxuICAgIDxwPlxuICAgICAga21zLW5neC11aS1wcmVzZW50YXRpb25hbCB3b3JrcyFcbiAgICA8L3A+XG4gIGAsXG4gIHN0eWxlczogW1xuICBdXG59KVxuZXhwb3J0IGNsYXNzIEttc1VpUHJlc2VudGF0aW9uYWxDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuXG4gIGNvbnN0cnVjdG9yKCkgeyB9XG5cbiAgbmdPbkluaXQoKTogdm9pZCB7XG4gIH1cblxufVxuIl19
|