@seniorsistemas/angular-components 17.9.0 → 17.9.1
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/bundles/seniorsistemas-angular-components.umd.js +88 -7
- package/bundles/seniorsistemas-angular-components.umd.js.map +1 -1
- package/bundles/seniorsistemas-angular-components.umd.min.js +1 -1
- package/bundles/seniorsistemas-angular-components.umd.min.js.map +1 -1
- package/components/info-sign/info-sign.component.d.ts +1 -0
- package/components/info-sign/info-sign.directive.d.ts +1 -0
- package/components/tooltip/tooltip.directive.d.ts +32 -2
- package/esm2015/components/info-sign/info-sign.component.js +2 -2
- package/esm2015/components/info-sign/info-sign.directive.js +5 -1
- package/esm2015/components/tooltip/tooltip.directive.js +84 -8
- package/esm5/components/info-sign/info-sign.component.js +2 -2
- package/esm5/components/info-sign/info-sign.directive.js +5 -1
- package/esm5/components/tooltip/tooltip.directive.js +85 -8
- package/fesm2015/seniorsistemas-angular-components.js +88 -8
- package/fesm2015/seniorsistemas-angular-components.js.map +1 -1
- package/fesm5/seniorsistemas-angular-components.js +89 -8
- package/fesm5/seniorsistemas-angular-components.js.map +1 -1
- package/package.json +1 -1
- package/seniorsistemas-angular-components.metadata.json +1 -1
|
@@ -5,6 +5,7 @@ export declare class InfoSignDirective implements OnInit, OnDestroy {
|
|
|
5
5
|
private readonly componentFactoryResolver;
|
|
6
6
|
sInfoSign: string;
|
|
7
7
|
displayTime: number;
|
|
8
|
+
focusedInputRef: HTMLInputElement;
|
|
8
9
|
private componentRef;
|
|
9
10
|
constructor(templateRef: TemplateRef<any>, viewContainer: ViewContainerRef, componentFactoryResolver: ComponentFactoryResolver);
|
|
10
11
|
ngOnInit(): void;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { ApplicationRef, ComponentFactoryResolver, ElementRef, Injector, OnDestroy, OnInit } from "@angular/core";
|
|
1
|
+
import { ApplicationRef, ComponentFactoryResolver, ElementRef, Injector, OnDestroy, OnInit, Renderer2 } from "@angular/core";
|
|
2
2
|
import { DebounceUtils } from "../utils/debouce";
|
|
3
3
|
import { MobileBehavior, TooltipEvent, TooltipPosition } from "./models";
|
|
4
4
|
export declare class TooltipDirective implements OnInit, OnDestroy {
|
|
@@ -7,6 +7,7 @@ export declare class TooltipDirective implements OnInit, OnDestroy {
|
|
|
7
7
|
private readonly componentFactoryResolver;
|
|
8
8
|
private readonly injector;
|
|
9
9
|
private readonly debounceUtils;
|
|
10
|
+
private readonly renderer;
|
|
10
11
|
tooltip: string;
|
|
11
12
|
position: TooltipPosition;
|
|
12
13
|
showDelay: number;
|
|
@@ -15,17 +16,39 @@ export declare class TooltipDirective implements OnInit, OnDestroy {
|
|
|
15
16
|
escape: boolean;
|
|
16
17
|
visible: boolean;
|
|
17
18
|
mobileBehavior: MobileBehavior;
|
|
19
|
+
focusedInputRef: HTMLInputElement;
|
|
18
20
|
private componentRef;
|
|
19
21
|
private showTimeout?;
|
|
20
22
|
private touchTimeout?;
|
|
21
23
|
private tooltipDivElement?;
|
|
22
24
|
private readonly boundOnWindowMouseMoveFunction;
|
|
23
25
|
private readonly debounceCreateTooltipFunction;
|
|
24
|
-
constructor(elementRef: ElementRef, appRef: ApplicationRef, componentFactoryResolver: ComponentFactoryResolver, injector: Injector, debounceUtils: DebounceUtils);
|
|
26
|
+
constructor(elementRef: ElementRef, appRef: ApplicationRef, componentFactoryResolver: ComponentFactoryResolver, injector: Injector, debounceUtils: DebounceUtils, renderer: Renderer2);
|
|
25
27
|
ngOnInit(): void;
|
|
26
28
|
ngOnDestroy(): void;
|
|
27
29
|
private onWindowMouseMove;
|
|
28
30
|
private isMousePositionOutsideOfElement;
|
|
31
|
+
/**
|
|
32
|
+
* Manipula a visibilidade do tooltip quando houver uma referência de input.
|
|
33
|
+
*/
|
|
34
|
+
private updateTooltipVisibilityWhenFocusOnInput;
|
|
35
|
+
/**
|
|
36
|
+
* Obtém o elemento do ícone associado ao label do input em focus.
|
|
37
|
+
* @param focusedInput O input em focus.
|
|
38
|
+
* @returns O ícone do input em focus ou null.
|
|
39
|
+
*/
|
|
40
|
+
private getIconFromFocusedInput;
|
|
41
|
+
/**
|
|
42
|
+
* Verifica se o ícone tem o tooltip correspondente ao atual.
|
|
43
|
+
* @param icon O ícone do input em focus.
|
|
44
|
+
* @returns true se o tooltip corresponde; caso contrário, false.
|
|
45
|
+
*/
|
|
46
|
+
private isMatchingTooltip;
|
|
47
|
+
/**
|
|
48
|
+
* Remove o tooltip associado ao ícone do input em focus.
|
|
49
|
+
* @param icon O ícone do input em focus.
|
|
50
|
+
*/
|
|
51
|
+
private removeTooltip;
|
|
29
52
|
onClick(): void;
|
|
30
53
|
onDocumentTouchStart(): void;
|
|
31
54
|
onFocus(): void;
|
|
@@ -36,6 +59,13 @@ export declare class TooltipDirective implements OnInit, OnDestroy {
|
|
|
36
59
|
onTouchEnd(): void;
|
|
37
60
|
private validatePosition;
|
|
38
61
|
private createTootip;
|
|
62
|
+
private getDomElement;
|
|
63
|
+
/**
|
|
64
|
+
* Cria um tooltip para o icone do input em focus.
|
|
65
|
+
*
|
|
66
|
+
* @param icon O ícone do input em focus.
|
|
67
|
+
*/
|
|
68
|
+
private createTootipByFocus;
|
|
39
69
|
private showTooltip;
|
|
40
70
|
private setTooltipComponentProperties;
|
|
41
71
|
private destroy;
|
|
@@ -5,9 +5,9 @@ let InfoSignComponent = class InfoSignComponent {
|
|
|
5
5
|
InfoSignComponent = __decorate([
|
|
6
6
|
Component({
|
|
7
7
|
selector: "s-info-sign-component",
|
|
8
|
-
template: "<span class=\"info-sign\">\n <span *ngTemplateOutlet=\"templateRef\"></span>\n <i\n class=\"info-sign__icon fa fa-info-circle\"\n aria-hidden=\"true\"\n [sTooltip]=\"tooltip\"\n [escape]=\"false\"\n tooltipPosition=\"top\"\n [displayTime]=\"displayTime\"\n mobileBehavior=\"tap\"\n showDelay=\"0\">\n </i>\n</span
|
|
8
|
+
template: "<span class=\"info-sign\">\n <span *ngTemplateOutlet=\"templateRef\"></span>\n <i\n class=\"info-sign__icon fa fa-info-circle\"\n aria-hidden=\"true\"\n [sTooltip]=\"tooltip\"\n [escape]=\"false\"\n tooltipPosition=\"top\"\n [displayTime]=\"displayTime\"\n mobileBehavior=\"tap\"\n showDelay=\"0\"\n [focusedInputRef]=\"focusedInputRef\">\n </i>\n</span>\n",
|
|
9
9
|
styles: [".info-sign{-ms-flex-align:baseline;align-items:baseline;display:-ms-inline-flexbox;display:inline-flex;-ms-flex-pack:start;justify-content:flex-start}.info-sign .info-sign__icon{padding:0 12px}"]
|
|
10
10
|
})
|
|
11
11
|
], InfoSignComponent);
|
|
12
12
|
export { InfoSignComponent };
|
|
13
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
13
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5mby1zaWduLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BzZW5pb3JzaXN0ZW1hcy9hbmd1bGFyLWNvbXBvbmVudHMvIiwic291cmNlcyI6WyJjb21wb25lbnRzL2luZm8tc2lnbi9pbmZvLXNpZ24uY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFlLE1BQU0sZUFBZSxDQUFDO0FBT3ZELElBQWEsaUJBQWlCLEdBQTlCLE1BQWEsaUJBQWlCO0NBSzdCLENBQUE7QUFMWSxpQkFBaUI7SUFMN0IsU0FBUyxDQUFDO1FBQ1AsUUFBUSxFQUFFLHVCQUF1QjtRQUNqQyx3YkFBeUM7O0tBRTVDLENBQUM7R0FDVyxpQkFBaUIsQ0FLN0I7U0FMWSxpQkFBaUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIFRlbXBsYXRlUmVmIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6IFwicy1pbmZvLXNpZ24tY29tcG9uZW50XCIsXG4gICAgdGVtcGxhdGVVcmw6IFwiLi9pbmZvLXNpZ24uY29tcG9uZW50Lmh0bWxcIixcbiAgICBzdHlsZVVybHM6IFtcIi4vaW5mby1zaWduLmNvbXBvbmVudC5zY3NzXCJdLFxufSlcbmV4cG9ydCBjbGFzcyBJbmZvU2lnbkNvbXBvbmVudCB7XG4gICAgdGVtcGxhdGVSZWY6IFRlbXBsYXRlUmVmPGFueT47XG4gICAgdG9vbHRpcDogc3RyaW5nO1xuICAgIGRpc3BsYXlUaW1lOiBudW1iZXI7XG4gICAgZm9jdXNlZElucHV0UmVmOiBIVE1MSW5wdXRFbGVtZW50O1xufVxuIl19
|
|
@@ -16,6 +16,7 @@ let InfoSignDirective = class InfoSignDirective {
|
|
|
16
16
|
this.componentRef.instance.templateRef = this.templateRef;
|
|
17
17
|
this.componentRef.instance.tooltip = this.sInfoSign;
|
|
18
18
|
this.componentRef.instance.displayTime = this.displayTime;
|
|
19
|
+
this.componentRef.instance.focusedInputRef = this.focusedInputRef;
|
|
19
20
|
}
|
|
20
21
|
else if (this.componentRef && this.sInfoSign) {
|
|
21
22
|
this.componentRef.instance.tooltip = this.sInfoSign;
|
|
@@ -42,10 +43,13 @@ __decorate([
|
|
|
42
43
|
__decorate([
|
|
43
44
|
Input('sInfoSignDisplayTime')
|
|
44
45
|
], InfoSignDirective.prototype, "displayTime", void 0);
|
|
46
|
+
__decorate([
|
|
47
|
+
Input('sInfoSignFocusedInputRef')
|
|
48
|
+
], InfoSignDirective.prototype, "focusedInputRef", void 0);
|
|
45
49
|
InfoSignDirective = __decorate([
|
|
46
50
|
Directive({
|
|
47
51
|
selector: "[sInfoSign]",
|
|
48
52
|
})
|
|
49
53
|
], InfoSignDirective);
|
|
50
54
|
export { InfoSignDirective };
|
|
51
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
55
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5mby1zaWduLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BzZW5pb3JzaXN0ZW1hcy9hbmd1bGFyLWNvbXBvbmVudHMvIiwic291cmNlcyI6WyJjb21wb25lbnRzL2luZm8tc2lnbi9pbmZvLXNpZ24uZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQ0gsd0JBQXdCLEVBQ3hCLFlBQVksRUFDWixTQUFTLEVBQ1QsS0FBSyxFQUNMLFNBQVMsRUFDVCxNQUFNLEVBQ04sV0FBVyxFQUNYLGdCQUFnQixHQUNuQixNQUFNLGVBQWUsQ0FBQztBQUV2QixPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUsxRCxJQUFhLGlCQUFpQixHQUE5QixNQUFhLGlCQUFpQjtJQVkxQixZQUNxQixXQUE2QixFQUM3QixhQUErQixFQUMvQix3QkFBa0Q7UUFGbEQsZ0JBQVcsR0FBWCxXQUFXLENBQWtCO1FBQzdCLGtCQUFhLEdBQWIsYUFBYSxDQUFrQjtRQUMvQiw2QkFBd0IsR0FBeEIsd0JBQXdCLENBQTBCO1FBVnZFLGdCQUFXLEdBQVcsSUFBSSxDQUFDO0lBV3hCLENBQUM7SUFFRyxRQUFRO1FBQ1gsSUFBSSxDQUFDLElBQUksQ0FBQyxZQUFZLElBQUksSUFBSSxDQUFDLFNBQVMsRUFBRTtZQUN0QyxJQUFJLENBQUMsYUFBYSxDQUFDLEtBQUssRUFBRSxDQUFDO1lBQzNCLE1BQU0sZ0JBQWdCLEdBQUcsSUFBSSxDQUFDLHdCQUF3QixDQUFDLHVCQUF1QixDQUFDLGlCQUFpQixDQUFDLENBQUM7WUFDbEcsSUFBSSxDQUFDLFlBQVksR0FBRyxJQUFJLENBQUMsYUFBYSxDQUFDLGVBQWUsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO1lBRXpFLElBQUksQ0FBQyxZQUFZLENBQUMsUUFBUSxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDO1lBQzFELElBQUksQ0FBQyxZQUFZLENBQUMsUUFBUSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDO1lBQ3BELElBQUksQ0FBQyxZQUFZLENBQUMsUUFBUSxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDO1lBQzFELElBQUksQ0FBQyxZQUFZLENBQUMsUUFBUSxDQUFDLGVBQWUsR0FBRyxJQUFJLENBQUMsZUFBZSxDQUFDO1NBQ3JFO2FBQU0sSUFBSSxJQUFJLENBQUMsWUFBWSxJQUFJLElBQUksQ0FBQyxTQUFTLEVBQUU7WUFDNUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxRQUFRLENBQUMsT0FBTyxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUM7U0FDdkQ7YUFBTTtZQUNILElBQUksQ0FBQyxhQUFhLENBQUMsS0FBSyxFQUFFLENBQUM7WUFDM0IsSUFBSSxDQUFDLGFBQWEsQ0FBQyxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLENBQUM7U0FDM0Q7SUFDTCxDQUFDO0lBRU0sV0FBVztRQUNkLElBQUksSUFBSSxDQUFDLFlBQVksRUFBRTtZQUNuQixJQUFJLENBQUMsWUFBWSxDQUFDLE9BQU8sRUFBRSxDQUFDO1NBQy9CO0lBQ0wsQ0FBQztDQUNKLENBQUE7O1lBNUJxQyxXQUFXO1lBQ1QsZ0JBQWdCO1lBQ0wsd0JBQXdCOztBQWJ2RTtJQURDLEtBQUssRUFBRTtvREFDVTtBQUdsQjtJQURDLEtBQUssQ0FBQyxzQkFBc0IsQ0FBQztzREFDSDtBQUczQjtJQURDLEtBQUssQ0FBQywwQkFBMEIsQ0FBQzswREFDTztBQVJoQyxpQkFBaUI7SUFIN0IsU0FBUyxDQUFDO1FBQ1AsUUFBUSxFQUFFLGFBQWE7S0FDMUIsQ0FBQztHQUNXLGlCQUFpQixDQXlDN0I7U0F6Q1ksaUJBQWlCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgICBDb21wb25lbnRGYWN0b3J5UmVzb2x2ZXIsXG4gICAgQ29tcG9uZW50UmVmLFxuICAgIERpcmVjdGl2ZSxcbiAgICBJbnB1dCxcbiAgICBPbkRlc3Ryb3ksXG4gICAgT25Jbml0LFxuICAgIFRlbXBsYXRlUmVmLFxuICAgIFZpZXdDb250YWluZXJSZWYsXG59IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5cbmltcG9ydCB7IEluZm9TaWduQ29tcG9uZW50IH0gZnJvbSBcIi4vaW5mby1zaWduLmNvbXBvbmVudFwiO1xuXG5ARGlyZWN0aXZlKHtcbiAgICBzZWxlY3RvcjogXCJbc0luZm9TaWduXVwiLFxufSlcbmV4cG9ydCBjbGFzcyBJbmZvU2lnbkRpcmVjdGl2ZSBpbXBsZW1lbnRzIE9uSW5pdCwgT25EZXN0cm95IHtcbiAgICBASW5wdXQoKVxuICAgIHNJbmZvU2lnbjogc3RyaW5nO1xuXG4gICAgQElucHV0KCdzSW5mb1NpZ25EaXNwbGF5VGltZScpXG4gICAgZGlzcGxheVRpbWU6IG51bWJlciA9IDUwMDA7XG5cbiAgICBASW5wdXQoJ3NJbmZvU2lnbkZvY3VzZWRJbnB1dFJlZicpXG4gICAgcHVibGljIGZvY3VzZWRJbnB1dFJlZjogSFRNTElucHV0RWxlbWVudDtcblxuICAgIHByaXZhdGUgY29tcG9uZW50UmVmOiBDb21wb25lbnRSZWY8YW55PjtcblxuICAgIGNvbnN0cnVjdG9yKFxuICAgICAgICBwcml2YXRlIHJlYWRvbmx5IHRlbXBsYXRlUmVmOiBUZW1wbGF0ZVJlZjxhbnk+LFxuICAgICAgICBwcml2YXRlIHJlYWRvbmx5IHZpZXdDb250YWluZXI6IFZpZXdDb250YWluZXJSZWYsXG4gICAgICAgIHByaXZhdGUgcmVhZG9ubHkgY29tcG9uZW50RmFjdG9yeVJlc29sdmVyOiBDb21wb25lbnRGYWN0b3J5UmVzb2x2ZXJcbiAgICApIHt9XG5cbiAgICBwdWJsaWMgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgICAgIGlmICghdGhpcy5jb21wb25lbnRSZWYgJiYgdGhpcy5zSW5mb1NpZ24pIHtcbiAgICAgICAgICAgIHRoaXMudmlld0NvbnRhaW5lci5jbGVhcigpO1xuICAgICAgICAgICAgY29uc3QgY29tcG9uZW50RmFjdG9yeSA9IHRoaXMuY29tcG9uZW50RmFjdG9yeVJlc29sdmVyLnJlc29sdmVDb21wb25lbnRGYWN0b3J5KEluZm9TaWduQ29tcG9uZW50KTtcbiAgICAgICAgICAgIHRoaXMuY29tcG9uZW50UmVmID0gdGhpcy52aWV3Q29udGFpbmVyLmNyZWF0ZUNvbXBvbmVudChjb21wb25lbnRGYWN0b3J5KTtcblxuICAgICAgICAgICAgdGhpcy5jb21wb25lbnRSZWYuaW5zdGFuY2UudGVtcGxhdGVSZWYgPSB0aGlzLnRlbXBsYXRlUmVmO1xuICAgICAgICAgICAgdGhpcy5jb21wb25lbnRSZWYuaW5zdGFuY2UudG9vbHRpcCA9IHRoaXMuc0luZm9TaWduO1xuICAgICAgICAgICAgdGhpcy5jb21wb25lbnRSZWYuaW5zdGFuY2UuZGlzcGxheVRpbWUgPSB0aGlzLmRpc3BsYXlUaW1lO1xuICAgICAgICAgICAgdGhpcy5jb21wb25lbnRSZWYuaW5zdGFuY2UuZm9jdXNlZElucHV0UmVmID0gdGhpcy5mb2N1c2VkSW5wdXRSZWY7XG4gICAgICAgIH0gZWxzZSBpZiAodGhpcy5jb21wb25lbnRSZWYgJiYgdGhpcy5zSW5mb1NpZ24pIHtcbiAgICAgICAgICAgIHRoaXMuY29tcG9uZW50UmVmLmluc3RhbmNlLnRvb2x0aXAgPSB0aGlzLnNJbmZvU2lnbjtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIHRoaXMudmlld0NvbnRhaW5lci5jbGVhcigpO1xuICAgICAgICAgICAgdGhpcy52aWV3Q29udGFpbmVyLmNyZWF0ZUVtYmVkZGVkVmlldyh0aGlzLnRlbXBsYXRlUmVmKTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIHB1YmxpYyBuZ09uRGVzdHJveSgpOiB2b2lkIHtcbiAgICAgICAgaWYgKHRoaXMuY29tcG9uZW50UmVmKSB7XG4gICAgICAgICAgICB0aGlzLmNvbXBvbmVudFJlZi5kZXN0cm95KCk7XG4gICAgICAgIH1cbiAgICB9XG59XG4iXX0=
|
|
@@ -1,15 +1,16 @@
|
|
|
1
1
|
import { __decorate } from "tslib";
|
|
2
|
-
import { ApplicationRef, ComponentFactoryResolver, ComponentRef, Directive, ElementRef, EmbeddedViewRef, HostListener, Injector, Input, OnDestroy, OnInit } from "@angular/core";
|
|
2
|
+
import { ApplicationRef, ComponentFactoryResolver, ComponentRef, Directive, ElementRef, EmbeddedViewRef, HostListener, Injector, Input, OnDestroy, OnInit, Renderer2 } from "@angular/core";
|
|
3
3
|
import { DebounceUtils } from "../utils/debouce";
|
|
4
4
|
import { MobileBehavior, TooltipEvent, TooltipPosition } from "./models";
|
|
5
5
|
import { TooltipComponent } from "./tooltip.component";
|
|
6
6
|
let TooltipDirective = class TooltipDirective {
|
|
7
|
-
constructor(elementRef, appRef, componentFactoryResolver, injector, debounceUtils) {
|
|
7
|
+
constructor(elementRef, appRef, componentFactoryResolver, injector, debounceUtils, renderer) {
|
|
8
8
|
this.elementRef = elementRef;
|
|
9
9
|
this.appRef = appRef;
|
|
10
10
|
this.componentFactoryResolver = componentFactoryResolver;
|
|
11
11
|
this.injector = injector;
|
|
12
12
|
this.debounceUtils = debounceUtils;
|
|
13
|
+
this.renderer = renderer;
|
|
13
14
|
this.position = TooltipPosition.Top;
|
|
14
15
|
this.showDelay = 500;
|
|
15
16
|
this.tooltipEvent = TooltipEvent.Hover;
|
|
@@ -22,6 +23,7 @@ let TooltipDirective = class TooltipDirective {
|
|
|
22
23
|
}
|
|
23
24
|
ngOnInit() {
|
|
24
25
|
this.validatePosition();
|
|
26
|
+
this.updateTooltipVisibilityWhenFocusOnInput();
|
|
25
27
|
}
|
|
26
28
|
ngOnDestroy() {
|
|
27
29
|
this.destroy();
|
|
@@ -45,6 +47,58 @@ let TooltipDirective = class TooltipDirective {
|
|
|
45
47
|
isMousePositionOutsideOfElement(mouseX, mouseY, elementArea) {
|
|
46
48
|
return mouseX < elementArea.left || mouseX >= elementArea.right || mouseY < elementArea.top || mouseY >= elementArea.bottom;
|
|
47
49
|
}
|
|
50
|
+
/**
|
|
51
|
+
* Manipula a visibilidade do tooltip quando houver uma referência de input.
|
|
52
|
+
*/
|
|
53
|
+
updateTooltipVisibilityWhenFocusOnInput() {
|
|
54
|
+
if (this.focusedInputRef) {
|
|
55
|
+
const inputFocus = this.focusedInputRef;
|
|
56
|
+
const icon = this.getIconFromFocusedInput(inputFocus);
|
|
57
|
+
this.renderer.listen(inputFocus, 'focus', () => {
|
|
58
|
+
if (icon && this.isMatchingTooltip(icon)) {
|
|
59
|
+
this.createTootipByFocus(icon);
|
|
60
|
+
}
|
|
61
|
+
});
|
|
62
|
+
this.renderer.listen(inputFocus, 'blur', () => {
|
|
63
|
+
if (icon && this.isMatchingTooltip(icon)) {
|
|
64
|
+
this.removeTooltip(icon);
|
|
65
|
+
this.destroy();
|
|
66
|
+
}
|
|
67
|
+
});
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
/**
|
|
71
|
+
* Obtém o elemento do ícone associado ao label do input em focus.
|
|
72
|
+
* @param focusedInput O input em focus.
|
|
73
|
+
* @returns O ícone do input em focus ou null.
|
|
74
|
+
*/
|
|
75
|
+
getIconFromFocusedInput(focusedInput) {
|
|
76
|
+
const label = document.querySelector(`label[for='${focusedInput.id}']`);
|
|
77
|
+
if (label) {
|
|
78
|
+
const icon = label.nextElementSibling;
|
|
79
|
+
return (icon === null || icon === void 0 ? void 0 : icon.classList.contains('info-sign__icon')) ? icon : null;
|
|
80
|
+
}
|
|
81
|
+
return null;
|
|
82
|
+
}
|
|
83
|
+
/**
|
|
84
|
+
* Verifica se o ícone tem o tooltip correspondente ao atual.
|
|
85
|
+
* @param icon O ícone do input em focus.
|
|
86
|
+
* @returns true se o tooltip corresponde; caso contrário, false.
|
|
87
|
+
*/
|
|
88
|
+
isMatchingTooltip(icon) {
|
|
89
|
+
const tooltipText = icon.getAttribute('ng-reflect-tooltip');
|
|
90
|
+
return this.tooltip === tooltipText;
|
|
91
|
+
}
|
|
92
|
+
/**
|
|
93
|
+
* Remove o tooltip associado ao ícone do input em focus.
|
|
94
|
+
* @param icon O ícone do input em focus.
|
|
95
|
+
*/
|
|
96
|
+
removeTooltip(icon) {
|
|
97
|
+
const tooltip = icon.querySelector('.tooltip');
|
|
98
|
+
if (tooltip) {
|
|
99
|
+
tooltip.remove();
|
|
100
|
+
}
|
|
101
|
+
}
|
|
48
102
|
// whenever the component with the tooltip is clicked I destroy the tooltip.
|
|
49
103
|
// whenever a key is pressed on the component with the tooltip I destroy the tooltip.
|
|
50
104
|
onClick() {
|
|
@@ -109,10 +163,7 @@ let TooltipDirective = class TooltipDirective {
|
|
|
109
163
|
createTootip() {
|
|
110
164
|
var _a;
|
|
111
165
|
if (this.componentRef === null && ((_a = this.tooltip) === null || _a === void 0 ? void 0 : _a.length)) {
|
|
112
|
-
const
|
|
113
|
-
this.componentRef = componentFactory.create(this.injector);
|
|
114
|
-
this.appRef.attachView(this.componentRef.hostView);
|
|
115
|
-
const domElem = this.componentRef.hostView.rootNodes[0];
|
|
166
|
+
const domElem = this.getDomElement();
|
|
116
167
|
document.body.appendChild(domElem);
|
|
117
168
|
this.setTooltipComponentProperties();
|
|
118
169
|
this.showTimeout = window.setTimeout(this.showTooltip.bind(this), this.showDelay);
|
|
@@ -122,6 +173,27 @@ let TooltipDirective = class TooltipDirective {
|
|
|
122
173
|
}
|
|
123
174
|
}
|
|
124
175
|
}
|
|
176
|
+
getDomElement() {
|
|
177
|
+
const componentFactory = this.componentFactoryResolver.resolveComponentFactory(TooltipComponent);
|
|
178
|
+
this.componentRef = componentFactory.create(this.injector);
|
|
179
|
+
this.appRef.attachView(this.componentRef.hostView);
|
|
180
|
+
return this.componentRef.hostView.rootNodes[0];
|
|
181
|
+
}
|
|
182
|
+
/**
|
|
183
|
+
* Cria um tooltip para o icone do input em focus.
|
|
184
|
+
*
|
|
185
|
+
* @param icon O ícone do input em focus.
|
|
186
|
+
*/
|
|
187
|
+
createTootipByFocus(icon) {
|
|
188
|
+
var _a;
|
|
189
|
+
if (this.componentRef === null && ((_a = this.tooltip) === null || _a === void 0 ? void 0 : _a.length)) {
|
|
190
|
+
const domElem = this.getDomElement();
|
|
191
|
+
const tooltip = domElem.querySelector('.tooltip');
|
|
192
|
+
icon.appendChild(tooltip);
|
|
193
|
+
this.setTooltipComponentProperties();
|
|
194
|
+
setTimeout(() => tooltip.classList.add("tooltip--visible"), 0);
|
|
195
|
+
}
|
|
196
|
+
}
|
|
125
197
|
showTooltip() {
|
|
126
198
|
if (this.componentRef !== null) {
|
|
127
199
|
this.componentRef.instance.visible = this.visible;
|
|
@@ -240,7 +312,8 @@ TooltipDirective.ctorParameters = () => [
|
|
|
240
312
|
{ type: ApplicationRef },
|
|
241
313
|
{ type: ComponentFactoryResolver },
|
|
242
314
|
{ type: Injector },
|
|
243
|
-
{ type: DebounceUtils }
|
|
315
|
+
{ type: DebounceUtils },
|
|
316
|
+
{ type: Renderer2 }
|
|
244
317
|
];
|
|
245
318
|
__decorate([
|
|
246
319
|
Input("sTooltip")
|
|
@@ -266,6 +339,9 @@ __decorate([
|
|
|
266
339
|
__decorate([
|
|
267
340
|
Input()
|
|
268
341
|
], TooltipDirective.prototype, "mobileBehavior", void 0);
|
|
342
|
+
__decorate([
|
|
343
|
+
Input()
|
|
344
|
+
], TooltipDirective.prototype, "focusedInputRef", void 0);
|
|
269
345
|
__decorate([
|
|
270
346
|
HostListener("click"),
|
|
271
347
|
HostListener("keydown")
|
|
@@ -298,4 +374,4 @@ TooltipDirective = __decorate([
|
|
|
298
374
|
})
|
|
299
375
|
], TooltipDirective);
|
|
300
376
|
export { TooltipDirective };
|
|
301
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.directive.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/tooltip/tooltip.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n   ApplicationRef,\n   ComponentFactoryResolver,\n   ComponentRef,\n   Directive,\n   ElementRef,\n   EmbeddedViewRef,\n   HostListener,\n   Injector,\n   Input,\n   OnDestroy,\n   OnInit\n} from \"@angular/core\";\nimport { DebounceUtils } from \"../utils/debouce\";\nimport { MobileBehavior, TooltipEvent, TooltipPosition } from \"./models\";\nimport { TooltipComponent } from \"./tooltip.component\";\nimport { ElementArea } from \"./models/element-area\";\n\n@Directive({\n   selector: \"[sTooltip]\",\n})\nexport class TooltipDirective implements OnInit, OnDestroy {\n   @Input(\"sTooltip\")\n   public tooltip: string;\n\n   @Input(\"tooltipPosition\")\n   public position: TooltipPosition = TooltipPosition.Top;\n\n   @Input()\n   public showDelay = 500;\n\n   @Input()\n   public displayTime: number;\n\n   @Input()\n   public tooltipEvent = TooltipEvent.Hover;\n\n   @Input()\n   public escape = false;\n\n   @Input()\n   public visible = true;\n\n   @Input()\n   public mobileBehavior = MobileBehavior.Pressing;\n\n   private componentRef: ComponentRef<any> = null;\n   private showTimeout?: number;\n   private touchTimeout?: number;\n   private tooltipDivElement?: HTMLElement;\n   private readonly boundOnWindowMouseMoveFunction: (event: MouseEvent) => void;\n   private readonly debounceCreateTooltipFunction: () => void;\n\n   constructor(\n      private readonly elementRef: ElementRef,\n      private readonly appRef: ApplicationRef,\n      private readonly componentFactoryResolver: ComponentFactoryResolver,\n      private readonly injector: Injector,\n      private readonly debounceUtils: DebounceUtils\n   ) {\n      this.boundOnWindowMouseMoveFunction = this.onWindowMouseMove.bind(this);\n      this.debounceCreateTooltipFunction = this.debounceUtils.debounceLeading(() => this.createTootip());\n   }\n\n   public ngOnInit(): void {\n      this.validatePosition();\n   }\n\n   public ngOnDestroy(): void {\n      this.destroy();\n   }\n\n   private onWindowMouseMove(event: MouseEvent) {\n      if (!this.componentRef) {\n         return;\n      }\n      const elementRect = this.elementRef.nativeElement.getBoundingClientRect();\n      const toolTipRect = this.tooltipDivElement.getBoundingClientRect();\n\n      const totalElementArea = {\n         top: Math.min(elementRect.top, toolTipRect.top),\n         right: Math.max(elementRect.right, toolTipRect.right),\n         left: Math.min(elementRect.left, toolTipRect.left),\n         bottom: Math.max(elementRect.bottom, toolTipRect.bottom)\n      };\n\n      if (this.isMousePositionOutsideOfElement(event.clientX, event.clientY, totalElementArea)) {\n         this.destroy();\n      }\n   }\n\n   private isMousePositionOutsideOfElement(mouseX: number, mouseY: number, elementArea: ElementArea) {\n      return mouseX < elementArea.left || mouseX >= elementArea.right || mouseY < elementArea.top || mouseY >= elementArea.bottom;\n   }\n\n   // whenever the component with the tooltip is clicked I destroy the tooltip.\n   // whenever a key is pressed on the component with the tooltip I destroy the tooltip.\n   @HostListener(\"click\")\n   @HostListener(\"keydown\")\n   public onClick(): void {\n      if (this.tooltipEvent === TooltipEvent.Hover &&\n         !navigator.userAgent.match(/Android/i) &&\n         !navigator.userAgent.match(/iPhone/i)) {\n         this.destroy();\n      }\n   }\n\n   // whenever you touch outside the component with the tooltip I destroy the tooltip.\n   @HostListener(\"document:touchstart\")\n   public onDocumentTouchStart(): void {\n      if (this.tooltipEvent === TooltipEvent.Hover) {\n         this.destroy();\n      }\n   }\n\n   @HostListener(\"focus\")\n   public onFocus(): void {\n      if (this.tooltipEvent === TooltipEvent.Focus) {\n         this.createTootip();\n      }\n   }\n\n   @HostListener(\"blur\")\n   public onBlur(): void {\n      if (this.tooltipEvent === TooltipEvent.Focus) {\n         this.destroy();\n      }\n   }\n\n   @HostListener(\"mouseenter\")\n   public onMouseEnter(): void {\n      if (this.tooltipEvent === TooltipEvent.Hover) {\n         this.debounceCreateTooltipFunction();\n      }\n   }\n\n   @HostListener(\"mouseleave\")\n   @HostListener(\"wheel\")\n   public onMouseLeave(): void {\n      if (this.tooltipEvent === TooltipEvent.Hover) {\n         this.destroy();\n      }\n   }\n\n   @HostListener(\"touchstart\")\n   public onTouchStart(): void {\n      if (this.tooltipEvent === TooltipEvent.Hover) {\n         window.clearTimeout(this.touchTimeout);\n         this.touchTimeout = window.setTimeout(\n            this.createTootip.bind(this),\n            this.mobileBehavior === MobileBehavior.Pressing ? this.showDelay : 0\n         );\n      }\n   }\n\n   @HostListener(\"touchend\")\n   public onTouchEnd(): void {\n      if (this.tooltipEvent === TooltipEvent.Hover) {\n         if (this.mobileBehavior === MobileBehavior.Pressing) {\n            window.clearTimeout(this.touchTimeout);\n            this.destroy();\n         }\n      }\n   }\n\n   private validatePosition() {\n      const containsPosition = [\n         TooltipPosition.Top,\n         TooltipPosition.Right,\n         TooltipPosition.Bottom,\n         TooltipPosition.Left,\n      ].includes(this.position);\n\n      if (!containsPosition) {\n         this.position = TooltipPosition.Top;\n         throw new Error(`Tooltip ${this.position} position is unexpected`);\n      }\n   }\n\n   private createTootip() {\n      if (this.componentRef === null && this.tooltip?.length) {\n         const componentFactory = this.componentFactoryResolver.resolveComponentFactory(TooltipComponent);\n         this.componentRef = componentFactory.create(this.injector);\n         this.appRef.attachView(this.componentRef.hostView);\n         const domElem = (this.componentRef.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement;\n         document.body.appendChild(domElem);\n         this.setTooltipComponentProperties();\n         this.showTimeout = window.setTimeout(this.showTooltip.bind(this), this.showDelay);\n\n         this.tooltipDivElement = domElem.querySelector('.tooltip');\n\n         if (this.displayTime) {\n            window.setTimeout(this.destroy.bind(this), this.displayTime);\n         }\n      }\n   }\n\n   private showTooltip() {\n      if (this.componentRef !== null) {\n         this.componentRef.instance.visible = this.visible;\n\n         window.addEventListener('mousemove', this.boundOnWindowMouseMoveFunction);\n      }\n   }\n\n   private setTooltipComponentProperties() {\n      const margin = 20;\n      const anchorSize = 5;\n\n      if (this.componentRef !== null) {\n         this.componentRef.instance.tooltip = this.tooltip;\n         this.componentRef.instance.escape = this.escape;\n\n         const { left, right, top, bottom } = this.elementRef.nativeElement.getBoundingClientRect();\n\n         const tooltipHeight = bottom - top;\n         const tooltipWidth = right - left;\n         const safeSpace = 150;\n\n         let positioned = false;\n         const invalidOptions: TooltipPosition[] = [];\n\n         while (!positioned) {\n            if (invalidOptions.includes(TooltipPosition.Top)\n               && invalidOptions.includes(TooltipPosition.Bottom)\n               && invalidOptions.includes(TooltipPosition.Left)\n               && invalidOptions.includes(TooltipPosition.Right)) {\n               this.destroy();\n               throw new Error(\"No space to show tooltip\");\n            }\n\n            switch (this.position) {\n               case TooltipPosition.Top: {\n                  if (invalidOptions.includes(TooltipPosition.Top)) {\n                     this.position = TooltipPosition.Left;\n                     break;\n                  }\n\n                  const topShift = top;\n\n                  if (topShift <= tooltipHeight + safeSpace) {\n                     this.position = TooltipPosition.Bottom;\n                     invalidOptions.push(TooltipPosition.Top);\n                     positioned = false;\n                     break;\n                  }\n\n                  this.componentRef.instance.left = Math.round(tooltipWidth / 2 + left);\n                  this.componentRef.instance.top = Math.round(top - margin - anchorSize);\n                  positioned = true;\n                  break;\n               }\n               case TooltipPosition.Bottom: {\n\n                  if (invalidOptions.includes(TooltipPosition.Bottom)) {\n                     this.position = TooltipPosition.Left;\n                     break;\n                  }\n\n                  const bottomShift = document.body.clientHeight - bottom;\n\n                  if (bottomShift <= tooltipHeight + safeSpace) {\n                     this.position = TooltipPosition.Top;\n                     invalidOptions.push(TooltipPosition.Bottom);\n                     break;\n                  }\n\n                  this.componentRef.instance.left = Math.round(tooltipWidth / 2 + left);\n                  this.componentRef.instance.top = Math.round(bottom + margin);\n                  positioned = true;\n                  break;\n               }\n               case TooltipPosition.Left: {\n                  if (invalidOptions.includes(TooltipPosition.Left)) {\n                     this.position = TooltipPosition.Top;\n                     break;\n                  }\n\n                  const leftShift = left;\n\n                  if (leftShift <= tooltipWidth + safeSpace) {\n                     this.position = TooltipPosition.Right;\n                     invalidOptions.push(TooltipPosition.Left);\n                     positioned = false;\n                     break;\n                  }\n\n                  this.componentRef.instance.left = Math.round(left - margin);\n                  this.componentRef.instance.top = Math.round(top + tooltipHeight / 2 - anchorSize);\n                  positioned = true;\n                  break;\n               }\n               case TooltipPosition.Right: {\n                  if (invalidOptions.includes(TooltipPosition.Right)) {\n                     this.position = TooltipPosition.Top;\n                     break;\n                  }\n\n                  const rightShift = document.body.clientWidth - right;\n\n                  if (rightShift <= tooltipWidth + safeSpace) {\n                     this.position = TooltipPosition.Left;\n                     invalidOptions.push(TooltipPosition.Right);\n                     positioned = false;\n                     break;\n                  }\n\n                  this.componentRef.instance.left = Math.round(right + margin);\n                  this.componentRef.instance.top = Math.round(top + tooltipHeight / 2 - anchorSize);\n                  positioned = true;\n                  break;\n               }\n               default: {\n                  break;\n               }\n            }\n\n            this.componentRef.instance.position = this.position;\n         }\n      }\n   }\n\n   private destroy(): void {\n      if (this.componentRef !== null) {\n         window.clearTimeout(this.showTimeout);\n         this.appRef.detachView(this.componentRef.hostView);\n         this.componentRef.destroy();\n         this.componentRef = null;\n         this.tooltipDivElement = null;\n      }\n\n      window.removeEventListener('mousemove', this.boundOnWindowMouseMoveFunction);\n   }\n}\n"]}
|
|
377
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.directive.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/tooltip/tooltip.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n   ApplicationRef,\n   ComponentFactoryResolver,\n   ComponentRef,\n   Directive,\n   ElementRef,\n   EmbeddedViewRef,\n   HostListener,\n   Injector,\n   Input,\n   OnDestroy,\n   OnInit,\n   Renderer2\n} from \"@angular/core\";\nimport { DebounceUtils } from \"../utils/debouce\";\nimport { MobileBehavior, TooltipEvent, TooltipPosition } from \"./models\";\nimport { TooltipComponent } from \"./tooltip.component\";\nimport { ElementArea } from \"./models/element-area\";\n\n@Directive({\n   selector: \"[sTooltip]\",\n})\nexport class TooltipDirective implements OnInit, OnDestroy {\n   @Input(\"sTooltip\")\n   public tooltip: string;\n\n   @Input(\"tooltipPosition\")\n   public position: TooltipPosition = TooltipPosition.Top;\n\n   @Input()\n   public showDelay = 500;\n\n   @Input()\n   public displayTime: number;\n\n   @Input()\n   public tooltipEvent = TooltipEvent.Hover;\n\n   @Input()\n   public escape = false;\n\n   @Input()\n   public visible = true;\n\n   @Input()\n   public mobileBehavior = MobileBehavior.Pressing;\n\n   @Input()\n   public focusedInputRef: HTMLInputElement;\n\n   private componentRef: ComponentRef<any> = null;\n   private showTimeout?: number;\n   private touchTimeout?: number;\n   private tooltipDivElement?: HTMLElement;\n   private readonly boundOnWindowMouseMoveFunction: (event: MouseEvent) => void;\n   private readonly debounceCreateTooltipFunction: () => void;\n\n   constructor(\n      private readonly elementRef: ElementRef,\n      private readonly appRef: ApplicationRef,\n      private readonly componentFactoryResolver: ComponentFactoryResolver,\n      private readonly injector: Injector,\n      private readonly debounceUtils: DebounceUtils,\n      private readonly renderer: Renderer2\n   ) {\n      this.boundOnWindowMouseMoveFunction = this.onWindowMouseMove.bind(this);\n      this.debounceCreateTooltipFunction = this.debounceUtils.debounceLeading(() => this.createTootip());\n   }\n\n   public ngOnInit(): void {\n      this.validatePosition();\n      this.updateTooltipVisibilityWhenFocusOnInput();\n   }\n\n   public ngOnDestroy(): void {\n      this.destroy();\n   }\n\n   private onWindowMouseMove(event: MouseEvent) {\n      if (!this.componentRef) {\n         return;\n      }\n      const elementRect = this.elementRef.nativeElement.getBoundingClientRect();\n      const toolTipRect = this.tooltipDivElement.getBoundingClientRect();\n\n      const totalElementArea = {\n         top: Math.min(elementRect.top, toolTipRect.top),\n         right: Math.max(elementRect.right, toolTipRect.right),\n         left: Math.min(elementRect.left, toolTipRect.left),\n         bottom: Math.max(elementRect.bottom, toolTipRect.bottom)\n      };\n\n      if (this.isMousePositionOutsideOfElement(event.clientX, event.clientY, totalElementArea)) {\n         this.destroy();\n      }\n   }\n\n   private isMousePositionOutsideOfElement(mouseX: number, mouseY: number, elementArea: ElementArea) {\n      return mouseX < elementArea.left || mouseX >= elementArea.right || mouseY < elementArea.top || mouseY >= elementArea.bottom;\n   }\n\n   /**\n    * Manipula a visibilidade do tooltip quando houver uma referência de input.\n    */\n   private updateTooltipVisibilityWhenFocusOnInput() {\n        if (this.focusedInputRef) {\n            const inputFocus = this.focusedInputRef;\n            const icon = this.getIconFromFocusedInput(inputFocus);\n\n            this.renderer.listen(inputFocus, 'focus', () => {\n                if (icon && this.isMatchingTooltip(icon)) {\n                    this.createTootipByFocus(icon);\n                }\n            });\n            this.renderer.listen(inputFocus, 'blur', () => {\n                if (icon && this.isMatchingTooltip(icon)) {\n                    this.removeTooltip(icon);\n                    this.destroy();\n                }\n            });\n        }\n    }\n\n    /**\n     * Obtém o elemento do ícone associado ao label do input em focus.\n     * @param focusedInput O input em focus.\n     * @returns O ícone do input em focus ou null.\n     */\n    private getIconFromFocusedInput(focusedInput: HTMLInputElement): HTMLElement | null {\n        const label = document.querySelector(`label[for='${focusedInput.id}']`);\n        if (label) {\n            const icon = label.nextElementSibling as HTMLElement;\n            return icon?.classList.contains('info-sign__icon') ? icon : null;\n        }\n        return null;\n    }\n\n    /**\n     * Verifica se o ícone tem o tooltip correspondente ao atual.\n     * @param icon O ícone do input em focus.\n     * @returns true se o tooltip corresponde; caso contrário, false.\n     */\n    private isMatchingTooltip(icon: HTMLElement): boolean {\n        const tooltipText = icon.getAttribute('ng-reflect-tooltip');\n        return this.tooltip === tooltipText;\n    }\n\n    /**\n     * Remove o tooltip associado ao ícone do input em focus.\n     * @param icon O ícone do input em focus.\n     */\n    private removeTooltip(icon: HTMLElement): void {\n        const tooltip = icon.querySelector('.tooltip') as HTMLElement;\n        if (tooltip) {\n            tooltip.remove();\n        }\n    }\n\n   // whenever the component with the tooltip is clicked I destroy the tooltip.\n   // whenever a key is pressed on the component with the tooltip I destroy the tooltip.\n   @HostListener(\"click\")\n   @HostListener(\"keydown\")\n   public onClick(): void {\n      if (this.tooltipEvent === TooltipEvent.Hover &&\n         !navigator.userAgent.match(/Android/i) &&\n         !navigator.userAgent.match(/iPhone/i)) {\n         this.destroy();\n      }\n   }\n\n   // whenever you touch outside the component with the tooltip I destroy the tooltip.\n   @HostListener(\"document:touchstart\")\n   public onDocumentTouchStart(): void {\n      if (this.tooltipEvent === TooltipEvent.Hover) {\n         this.destroy();\n      }\n   }\n\n   @HostListener(\"focus\")\n   public onFocus(): void {\n      if (this.tooltipEvent === TooltipEvent.Focus) {\n         this.createTootip();\n      }\n   }\n\n   @HostListener(\"blur\")\n   public onBlur(): void {\n      if (this.tooltipEvent === TooltipEvent.Focus) {\n         this.destroy();\n      }\n   }\n\n   @HostListener(\"mouseenter\")\n   public onMouseEnter(): void {\n      if (this.tooltipEvent === TooltipEvent.Hover) {\n         this.debounceCreateTooltipFunction();\n      }\n   }\n\n   @HostListener(\"mouseleave\")\n   @HostListener(\"wheel\")\n   public onMouseLeave(): void {\n      if (this.tooltipEvent === TooltipEvent.Hover) {\n         this.destroy();\n      }\n   }\n\n   @HostListener(\"touchstart\")\n   public onTouchStart(): void {\n      if (this.tooltipEvent === TooltipEvent.Hover) {\n         window.clearTimeout(this.touchTimeout);\n         this.touchTimeout = window.setTimeout(\n            this.createTootip.bind(this),\n            this.mobileBehavior === MobileBehavior.Pressing ? this.showDelay : 0\n         );\n      }\n   }\n\n   @HostListener(\"touchend\")\n   public onTouchEnd(): void {\n      if (this.tooltipEvent === TooltipEvent.Hover) {\n         if (this.mobileBehavior === MobileBehavior.Pressing) {\n            window.clearTimeout(this.touchTimeout);\n            this.destroy();\n         }\n      }\n   }\n\n   private validatePosition() {\n      const containsPosition = [\n         TooltipPosition.Top,\n         TooltipPosition.Right,\n         TooltipPosition.Bottom,\n         TooltipPosition.Left,\n      ].includes(this.position);\n\n      if (!containsPosition) {\n         this.position = TooltipPosition.Top;\n         throw new Error(`Tooltip ${this.position} position is unexpected`);\n      }\n   }\n\n   private createTootip() {\n      if (this.componentRef === null && this.tooltip?.length) {\n         const domElem = this.getDomElement();\n         document.body.appendChild(domElem);\n         this.setTooltipComponentProperties();\n         this.showTimeout = window.setTimeout(this.showTooltip.bind(this), this.showDelay);\n\n         this.tooltipDivElement = domElem.querySelector('.tooltip');\n\n         if (this.displayTime) {\n            window.setTimeout(this.destroy.bind(this), this.displayTime);\n         }\n      }\n   }\n\n   private getDomElement(): HTMLElement {\n        const componentFactory = this.componentFactoryResolver.resolveComponentFactory(TooltipComponent);\n        this.componentRef = componentFactory.create(this.injector);\n        this.appRef.attachView(this.componentRef.hostView);\n        return (this.componentRef.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement;\n   }\n\n   /**\n    * Cria um tooltip para o icone do input em focus.\n    *\n    * @param icon O ícone do input em focus.\n    */\n   private createTootipByFocus(icon: HTMLElement) {\n        if (this.componentRef === null && this.tooltip?.length) {\n            const domElem = this.getDomElement();\n            const tooltip = domElem.querySelector('.tooltip') as HTMLElement;\n            icon.appendChild(tooltip);\n            this.setTooltipComponentProperties();\n\n            setTimeout(() => tooltip.classList.add(\"tooltip--visible\"), 0);\n        }\n    }\n\n   private showTooltip() {\n      if (this.componentRef !== null) {\n         this.componentRef.instance.visible = this.visible;\n\n         window.addEventListener('mousemove', this.boundOnWindowMouseMoveFunction);\n      }\n   }\n\n   private setTooltipComponentProperties() {\n      const margin = 20;\n      const anchorSize = 5;\n\n      if (this.componentRef !== null) {\n         this.componentRef.instance.tooltip = this.tooltip;\n         this.componentRef.instance.escape = this.escape;\n\n         const { left, right, top, bottom } = this.elementRef.nativeElement.getBoundingClientRect();\n\n         const tooltipHeight = bottom - top;\n         const tooltipWidth = right - left;\n         const safeSpace = 150;\n\n         let positioned = false;\n         const invalidOptions: TooltipPosition[] = [];\n\n         while (!positioned) {\n            if (invalidOptions.includes(TooltipPosition.Top)\n               && invalidOptions.includes(TooltipPosition.Bottom)\n               && invalidOptions.includes(TooltipPosition.Left)\n               && invalidOptions.includes(TooltipPosition.Right)) {\n               this.destroy();\n               throw new Error(\"No space to show tooltip\");\n            }\n\n            switch (this.position) {\n               case TooltipPosition.Top: {\n                  if (invalidOptions.includes(TooltipPosition.Top)) {\n                     this.position = TooltipPosition.Left;\n                     break;\n                  }\n\n                  const topShift = top;\n\n                  if (topShift <= tooltipHeight + safeSpace) {\n                     this.position = TooltipPosition.Bottom;\n                     invalidOptions.push(TooltipPosition.Top);\n                     positioned = false;\n                     break;\n                  }\n\n                  this.componentRef.instance.left = Math.round(tooltipWidth / 2 + left);\n                  this.componentRef.instance.top = Math.round(top - margin - anchorSize);\n                  positioned = true;\n                  break;\n               }\n               case TooltipPosition.Bottom: {\n\n                  if (invalidOptions.includes(TooltipPosition.Bottom)) {\n                     this.position = TooltipPosition.Left;\n                     break;\n                  }\n\n                  const bottomShift = document.body.clientHeight - bottom;\n\n                  if (bottomShift <= tooltipHeight + safeSpace) {\n                     this.position = TooltipPosition.Top;\n                     invalidOptions.push(TooltipPosition.Bottom);\n                     break;\n                  }\n\n                  this.componentRef.instance.left = Math.round(tooltipWidth / 2 + left);\n                  this.componentRef.instance.top = Math.round(bottom + margin);\n                  positioned = true;\n                  break;\n               }\n               case TooltipPosition.Left: {\n                  if (invalidOptions.includes(TooltipPosition.Left)) {\n                     this.position = TooltipPosition.Top;\n                     break;\n                  }\n\n                  const leftShift = left;\n\n                  if (leftShift <= tooltipWidth + safeSpace) {\n                     this.position = TooltipPosition.Right;\n                     invalidOptions.push(TooltipPosition.Left);\n                     positioned = false;\n                     break;\n                  }\n\n                  this.componentRef.instance.left = Math.round(left - margin);\n                  this.componentRef.instance.top = Math.round(top + tooltipHeight / 2 - anchorSize);\n                  positioned = true;\n                  break;\n               }\n               case TooltipPosition.Right: {\n                  if (invalidOptions.includes(TooltipPosition.Right)) {\n                     this.position = TooltipPosition.Top;\n                     break;\n                  }\n\n                  const rightShift = document.body.clientWidth - right;\n\n                  if (rightShift <= tooltipWidth + safeSpace) {\n                     this.position = TooltipPosition.Left;\n                     invalidOptions.push(TooltipPosition.Right);\n                     positioned = false;\n                     break;\n                  }\n\n                  this.componentRef.instance.left = Math.round(right + margin);\n                  this.componentRef.instance.top = Math.round(top + tooltipHeight / 2 - anchorSize);\n                  positioned = true;\n                  break;\n               }\n               default: {\n                  break;\n               }\n            }\n\n            this.componentRef.instance.position = this.position;\n         }\n      }\n   }\n\n   private destroy(): void {\n      if (this.componentRef !== null) {\n         window.clearTimeout(this.showTimeout);\n         this.appRef.detachView(this.componentRef.hostView);\n         this.componentRef.destroy();\n         this.componentRef = null;\n         this.tooltipDivElement = null;\n      }\n\n      window.removeEventListener('mousemove', this.boundOnWindowMouseMoveFunction);\n   }\n}\n"]}
|
|
@@ -6,11 +6,11 @@ var InfoSignComponent = /** @class */ (function () {
|
|
|
6
6
|
InfoSignComponent = __decorate([
|
|
7
7
|
Component({
|
|
8
8
|
selector: "s-info-sign-component",
|
|
9
|
-
template: "<span class=\"info-sign\">\n <span *ngTemplateOutlet=\"templateRef\"></span>\n <i\n class=\"info-sign__icon fa fa-info-circle\"\n aria-hidden=\"true\"\n [sTooltip]=\"tooltip\"\n [escape]=\"false\"\n tooltipPosition=\"top\"\n [displayTime]=\"displayTime\"\n mobileBehavior=\"tap\"\n showDelay=\"0\">\n </i>\n</span
|
|
9
|
+
template: "<span class=\"info-sign\">\n <span *ngTemplateOutlet=\"templateRef\"></span>\n <i\n class=\"info-sign__icon fa fa-info-circle\"\n aria-hidden=\"true\"\n [sTooltip]=\"tooltip\"\n [escape]=\"false\"\n tooltipPosition=\"top\"\n [displayTime]=\"displayTime\"\n mobileBehavior=\"tap\"\n showDelay=\"0\"\n [focusedInputRef]=\"focusedInputRef\">\n </i>\n</span>\n",
|
|
10
10
|
styles: [".info-sign{-ms-flex-align:baseline;align-items:baseline;display:-ms-inline-flexbox;display:inline-flex;-ms-flex-pack:start;justify-content:flex-start}.info-sign .info-sign__icon{padding:0 12px}"]
|
|
11
11
|
})
|
|
12
12
|
], InfoSignComponent);
|
|
13
13
|
return InfoSignComponent;
|
|
14
14
|
}());
|
|
15
15
|
export { InfoSignComponent };
|
|
16
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5mby1zaWduLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BzZW5pb3JzaXN0ZW1hcy9hbmd1bGFyLWNvbXBvbmVudHMvIiwic291cmNlcyI6WyJjb21wb25lbnRzL2luZm8tc2lnbi9pbmZvLXNpZ24uY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFlLE1BQU0sZUFBZSxDQUFDO0FBT3ZEO0lBQUE7SUFLQSxDQUFDO0lBTFksaUJBQWlCO1FBTDdCLFNBQVMsQ0FBQztZQUNQLFFBQVEsRUFBRSx1QkFBdUI7WUFDakMsd2JBQXlDOztTQUU1QyxDQUFDO09BQ1csaUJBQWlCLENBSzdCO0lBQUQsd0JBQUM7Q0FBQSxBQUxELElBS0M7U0FMWSxpQkFBaUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIFRlbXBsYXRlUmVmIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6IFwicy1pbmZvLXNpZ24tY29tcG9uZW50XCIsXG4gICAgdGVtcGxhdGVVcmw6IFwiLi9pbmZvLXNpZ24uY29tcG9uZW50Lmh0bWxcIixcbiAgICBzdHlsZVVybHM6IFtcIi4vaW5mby1zaWduLmNvbXBvbmVudC5zY3NzXCJdLFxufSlcbmV4cG9ydCBjbGFzcyBJbmZvU2lnbkNvbXBvbmVudCB7XG4gICAgdGVtcGxhdGVSZWY6IFRlbXBsYXRlUmVmPGFueT47XG4gICAgdG9vbHRpcDogc3RyaW5nO1xuICAgIGRpc3BsYXlUaW1lOiBudW1iZXI7XG4gICAgZm9jdXNlZElucHV0UmVmOiBIVE1MSW5wdXRFbGVtZW50O1xufVxuIl19
|
|
@@ -16,6 +16,7 @@ var InfoSignDirective = /** @class */ (function () {
|
|
|
16
16
|
this.componentRef.instance.templateRef = this.templateRef;
|
|
17
17
|
this.componentRef.instance.tooltip = this.sInfoSign;
|
|
18
18
|
this.componentRef.instance.displayTime = this.displayTime;
|
|
19
|
+
this.componentRef.instance.focusedInputRef = this.focusedInputRef;
|
|
19
20
|
}
|
|
20
21
|
else if (this.componentRef && this.sInfoSign) {
|
|
21
22
|
this.componentRef.instance.tooltip = this.sInfoSign;
|
|
@@ -41,6 +42,9 @@ var InfoSignDirective = /** @class */ (function () {
|
|
|
41
42
|
__decorate([
|
|
42
43
|
Input('sInfoSignDisplayTime')
|
|
43
44
|
], InfoSignDirective.prototype, "displayTime", void 0);
|
|
45
|
+
__decorate([
|
|
46
|
+
Input('sInfoSignFocusedInputRef')
|
|
47
|
+
], InfoSignDirective.prototype, "focusedInputRef", void 0);
|
|
44
48
|
InfoSignDirective = __decorate([
|
|
45
49
|
Directive({
|
|
46
50
|
selector: "[sInfoSign]",
|
|
@@ -49,4 +53,4 @@ var InfoSignDirective = /** @class */ (function () {
|
|
|
49
53
|
return InfoSignDirective;
|
|
50
54
|
}());
|
|
51
55
|
export { InfoSignDirective };
|
|
52
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
56
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5mby1zaWduLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BzZW5pb3JzaXN0ZW1hcy9hbmd1bGFyLWNvbXBvbmVudHMvIiwic291cmNlcyI6WyJjb21wb25lbnRzL2luZm8tc2lnbi9pbmZvLXNpZ24uZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQ0gsd0JBQXdCLEVBQ3hCLFlBQVksRUFDWixTQUFTLEVBQ1QsS0FBSyxFQUNMLFNBQVMsRUFDVCxNQUFNLEVBQ04sV0FBVyxFQUNYLGdCQUFnQixHQUNuQixNQUFNLGVBQWUsQ0FBQztBQUV2QixPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUsxRDtJQVlJLDJCQUNxQixXQUE2QixFQUM3QixhQUErQixFQUMvQix3QkFBa0Q7UUFGbEQsZ0JBQVcsR0FBWCxXQUFXLENBQWtCO1FBQzdCLGtCQUFhLEdBQWIsYUFBYSxDQUFrQjtRQUMvQiw2QkFBd0IsR0FBeEIsd0JBQXdCLENBQTBCO1FBVnZFLGdCQUFXLEdBQVcsSUFBSSxDQUFDO0lBV3hCLENBQUM7SUFFRyxvQ0FBUSxHQUFmO1FBQ0ksSUFBSSxDQUFDLElBQUksQ0FBQyxZQUFZLElBQUksSUFBSSxDQUFDLFNBQVMsRUFBRTtZQUN0QyxJQUFJLENBQUMsYUFBYSxDQUFDLEtBQUssRUFBRSxDQUFDO1lBQzNCLElBQU0sZ0JBQWdCLEdBQUcsSUFBSSxDQUFDLHdCQUF3QixDQUFDLHVCQUF1QixDQUFDLGlCQUFpQixDQUFDLENBQUM7WUFDbEcsSUFBSSxDQUFDLFlBQVksR0FBRyxJQUFJLENBQUMsYUFBYSxDQUFDLGVBQWUsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO1lBRXpFLElBQUksQ0FBQyxZQUFZLENBQUMsUUFBUSxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDO1lBQzFELElBQUksQ0FBQyxZQUFZLENBQUMsUUFBUSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDO1lBQ3BELElBQUksQ0FBQyxZQUFZLENBQUMsUUFBUSxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDO1lBQzFELElBQUksQ0FBQyxZQUFZLENBQUMsUUFBUSxDQUFDLGVBQWUsR0FBRyxJQUFJLENBQUMsZUFBZSxDQUFDO1NBQ3JFO2FBQU0sSUFBSSxJQUFJLENBQUMsWUFBWSxJQUFJLElBQUksQ0FBQyxTQUFTLEVBQUU7WUFDNUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxRQUFRLENBQUMsT0FBTyxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUM7U0FDdkQ7YUFBTTtZQUNILElBQUksQ0FBQyxhQUFhLENBQUMsS0FBSyxFQUFFLENBQUM7WUFDM0IsSUFBSSxDQUFDLGFBQWEsQ0FBQyxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLENBQUM7U0FDM0Q7SUFDTCxDQUFDO0lBRU0sdUNBQVcsR0FBbEI7UUFDSSxJQUFJLElBQUksQ0FBQyxZQUFZLEVBQUU7WUFDbkIsSUFBSSxDQUFDLFlBQVksQ0FBQyxPQUFPLEVBQUUsQ0FBQztTQUMvQjtJQUNMLENBQUM7O2dCQTNCaUMsV0FBVztnQkFDVCxnQkFBZ0I7Z0JBQ0wsd0JBQXdCOztJQWJ2RTtRQURDLEtBQUssRUFBRTt3REFDVTtJQUdsQjtRQURDLEtBQUssQ0FBQyxzQkFBc0IsQ0FBQzswREFDSDtJQUczQjtRQURDLEtBQUssQ0FBQywwQkFBMEIsQ0FBQzs4REFDTztJQVJoQyxpQkFBaUI7UUFIN0IsU0FBUyxDQUFDO1lBQ1AsUUFBUSxFQUFFLGFBQWE7U0FDMUIsQ0FBQztPQUNXLGlCQUFpQixDQXlDN0I7SUFBRCx3QkFBQztDQUFBLEFBekNELElBeUNDO1NBekNZLGlCQUFpQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gICAgQ29tcG9uZW50RmFjdG9yeVJlc29sdmVyLFxuICAgIENvbXBvbmVudFJlZixcbiAgICBEaXJlY3RpdmUsXG4gICAgSW5wdXQsXG4gICAgT25EZXN0cm95LFxuICAgIE9uSW5pdCxcbiAgICBUZW1wbGF0ZVJlZixcbiAgICBWaWV3Q29udGFpbmVyUmVmLFxufSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuXG5pbXBvcnQgeyBJbmZvU2lnbkNvbXBvbmVudCB9IGZyb20gXCIuL2luZm8tc2lnbi5jb21wb25lbnRcIjtcblxuQERpcmVjdGl2ZSh7XG4gICAgc2VsZWN0b3I6IFwiW3NJbmZvU2lnbl1cIixcbn0pXG5leHBvcnQgY2xhc3MgSW5mb1NpZ25EaXJlY3RpdmUgaW1wbGVtZW50cyBPbkluaXQsIE9uRGVzdHJveSB7XG4gICAgQElucHV0KClcbiAgICBzSW5mb1NpZ246IHN0cmluZztcblxuICAgIEBJbnB1dCgnc0luZm9TaWduRGlzcGxheVRpbWUnKVxuICAgIGRpc3BsYXlUaW1lOiBudW1iZXIgPSA1MDAwO1xuXG4gICAgQElucHV0KCdzSW5mb1NpZ25Gb2N1c2VkSW5wdXRSZWYnKVxuICAgIHB1YmxpYyBmb2N1c2VkSW5wdXRSZWY6IEhUTUxJbnB1dEVsZW1lbnQ7XG5cbiAgICBwcml2YXRlIGNvbXBvbmVudFJlZjogQ29tcG9uZW50UmVmPGFueT47XG5cbiAgICBjb25zdHJ1Y3RvcihcbiAgICAgICAgcHJpdmF0ZSByZWFkb25seSB0ZW1wbGF0ZVJlZjogVGVtcGxhdGVSZWY8YW55PixcbiAgICAgICAgcHJpdmF0ZSByZWFkb25seSB2aWV3Q29udGFpbmVyOiBWaWV3Q29udGFpbmVyUmVmLFxuICAgICAgICBwcml2YXRlIHJlYWRvbmx5IGNvbXBvbmVudEZhY3RvcnlSZXNvbHZlcjogQ29tcG9uZW50RmFjdG9yeVJlc29sdmVyXG4gICAgKSB7fVxuXG4gICAgcHVibGljIG5nT25Jbml0KCk6IHZvaWQge1xuICAgICAgICBpZiAoIXRoaXMuY29tcG9uZW50UmVmICYmIHRoaXMuc0luZm9TaWduKSB7XG4gICAgICAgICAgICB0aGlzLnZpZXdDb250YWluZXIuY2xlYXIoKTtcbiAgICAgICAgICAgIGNvbnN0IGNvbXBvbmVudEZhY3RvcnkgPSB0aGlzLmNvbXBvbmVudEZhY3RvcnlSZXNvbHZlci5yZXNvbHZlQ29tcG9uZW50RmFjdG9yeShJbmZvU2lnbkNvbXBvbmVudCk7XG4gICAgICAgICAgICB0aGlzLmNvbXBvbmVudFJlZiA9IHRoaXMudmlld0NvbnRhaW5lci5jcmVhdGVDb21wb25lbnQoY29tcG9uZW50RmFjdG9yeSk7XG5cbiAgICAgICAgICAgIHRoaXMuY29tcG9uZW50UmVmLmluc3RhbmNlLnRlbXBsYXRlUmVmID0gdGhpcy50ZW1wbGF0ZVJlZjtcbiAgICAgICAgICAgIHRoaXMuY29tcG9uZW50UmVmLmluc3RhbmNlLnRvb2x0aXAgPSB0aGlzLnNJbmZvU2lnbjtcbiAgICAgICAgICAgIHRoaXMuY29tcG9uZW50UmVmLmluc3RhbmNlLmRpc3BsYXlUaW1lID0gdGhpcy5kaXNwbGF5VGltZTtcbiAgICAgICAgICAgIHRoaXMuY29tcG9uZW50UmVmLmluc3RhbmNlLmZvY3VzZWRJbnB1dFJlZiA9IHRoaXMuZm9jdXNlZElucHV0UmVmO1xuICAgICAgICB9IGVsc2UgaWYgKHRoaXMuY29tcG9uZW50UmVmICYmIHRoaXMuc0luZm9TaWduKSB7XG4gICAgICAgICAgICB0aGlzLmNvbXBvbmVudFJlZi5pbnN0YW5jZS50b29sdGlwID0gdGhpcy5zSW5mb1NpZ247XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICB0aGlzLnZpZXdDb250YWluZXIuY2xlYXIoKTtcbiAgICAgICAgICAgIHRoaXMudmlld0NvbnRhaW5lci5jcmVhdGVFbWJlZGRlZFZpZXcodGhpcy50ZW1wbGF0ZVJlZik7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBwdWJsaWMgbmdPbkRlc3Ryb3koKTogdm9pZCB7XG4gICAgICAgIGlmICh0aGlzLmNvbXBvbmVudFJlZikge1xuICAgICAgICAgICAgdGhpcy5jb21wb25lbnRSZWYuZGVzdHJveSgpO1xuICAgICAgICB9XG4gICAgfVxufVxuIl19
|