@mozaic-ds/angular 0.28.0 → 0.29.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/adeo/components/phone-number/phone-number.component.d.ts +2 -1
- package/adeo/components/tooltip/directive/tooltip.directive.d.ts +8 -4
- package/adeo/components/tooltip/service/tooltip.service.d.ts +14 -0
- package/adeo/esm2020/components/autocomplete/autocomplete.component.mjs +3 -3
- package/adeo/esm2020/components/dropdown/dropdown.component.mjs +3 -3
- package/adeo/esm2020/components/phone-number/phone-number.component.mjs +7 -4
- package/adeo/esm2020/components/tooltip/directive/tooltip.directive.mjs +18 -14
- package/adeo/esm2020/components/tooltip/service/tooltip.service.mjs +35 -0
- package/adeo/fesm2015/mozaic-ds-angular.mjs +57 -19
- package/adeo/fesm2015/mozaic-ds-angular.mjs.map +1 -1
- package/adeo/fesm2020/mozaic-ds-angular.mjs +56 -19
- package/adeo/fesm2020/mozaic-ds-angular.mjs.map +1 -1
- package/adeo/package.json +1 -1
- package/bricoman/components/phone-number/phone-number.component.d.ts +2 -1
- package/bricoman/components/tooltip/directive/tooltip.directive.d.ts +8 -4
- package/bricoman/components/tooltip/service/tooltip.service.d.ts +14 -0
- package/bricoman/esm2020/components/autocomplete/autocomplete.component.mjs +3 -3
- package/bricoman/esm2020/components/dropdown/dropdown.component.mjs +3 -3
- package/bricoman/esm2020/components/phone-number/phone-number.component.mjs +7 -4
- package/bricoman/esm2020/components/tooltip/directive/tooltip.directive.mjs +18 -14
- package/bricoman/esm2020/components/tooltip/service/tooltip.service.mjs +35 -0
- package/bricoman/fesm2015/mozaic-ds-angular.mjs +57 -19
- package/bricoman/fesm2015/mozaic-ds-angular.mjs.map +1 -1
- package/bricoman/fesm2020/mozaic-ds-angular.mjs +56 -19
- package/bricoman/fesm2020/mozaic-ds-angular.mjs.map +1 -1
- package/bricoman/package.json +1 -1
- package/components/phone-number/phone-number.component.d.ts +2 -1
- package/components/tooltip/directive/tooltip.directive.d.ts +8 -4
- package/components/tooltip/service/tooltip.service.d.ts +14 -0
- package/esm2020/components/autocomplete/autocomplete.component.mjs +3 -3
- package/esm2020/components/dropdown/dropdown.component.mjs +3 -3
- package/esm2020/components/phone-number/phone-number.component.mjs +7 -4
- package/esm2020/components/tooltip/directive/tooltip.directive.mjs +18 -14
- package/esm2020/components/tooltip/service/tooltip.service.mjs +35 -0
- package/fesm2015/mozaic-ds-angular.mjs +57 -19
- package/fesm2015/mozaic-ds-angular.mjs.map +1 -1
- package/fesm2020/mozaic-ds-angular.mjs +56 -19
- package/fesm2020/mozaic-ds-angular.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -1,22 +1,16 @@
|
|
|
1
|
-
import { Directive, Input,
|
|
1
|
+
import { Directive, HostListener, Input, } from '@angular/core';
|
|
2
|
+
import { tap } from 'rxjs';
|
|
2
3
|
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "../service/tooltip.service";
|
|
3
5
|
export class TooltipDirective {
|
|
4
|
-
constructor(el, renderer) {
|
|
6
|
+
constructor(el, renderer, tooltipService) {
|
|
5
7
|
this.el = el;
|
|
6
8
|
this.renderer = renderer;
|
|
9
|
+
this.tooltipService = tooltipService;
|
|
7
10
|
this.tooltipContent = '';
|
|
8
11
|
this.tooltipPosition = 'top';
|
|
9
12
|
this.tooltip = null;
|
|
10
13
|
this.offset = 16;
|
|
11
|
-
this.mutationObserver = new MutationObserver(() => {
|
|
12
|
-
if (!document.body.contains(this.el.nativeElement)) {
|
|
13
|
-
this.hideTooltip();
|
|
14
|
-
}
|
|
15
|
-
});
|
|
16
|
-
this.mutationObserver.observe(document.body, {
|
|
17
|
-
childList: true,
|
|
18
|
-
subtree: true,
|
|
19
|
-
});
|
|
20
14
|
}
|
|
21
15
|
onMouseIn() {
|
|
22
16
|
if (!this.tooltip)
|
|
@@ -26,7 +20,17 @@ export class TooltipDirective {
|
|
|
26
20
|
if (this.tooltip)
|
|
27
21
|
this.hideTooltip();
|
|
28
22
|
}
|
|
23
|
+
ngOnInit() {
|
|
24
|
+
this.hideTooltipSubscription = this.tooltipService.hideTooltip$
|
|
25
|
+
.pipe(tap(() => this.hideTooltip()))
|
|
26
|
+
.subscribe();
|
|
27
|
+
}
|
|
28
|
+
ngOnDestroy() {
|
|
29
|
+
this.hideTooltip();
|
|
30
|
+
this.hideTooltipSubscription?.unsubscribe();
|
|
31
|
+
}
|
|
29
32
|
showTooltip() {
|
|
33
|
+
this.tooltipService.setCurrentTooltip(this.el);
|
|
30
34
|
this.tooltip = this.renderer.createElement('span');
|
|
31
35
|
this.renderer.appendChild(this.tooltip, this.renderer.createText(this.tooltipContent));
|
|
32
36
|
this.renderer.appendChild(document.body, this.tooltip);
|
|
@@ -74,14 +78,14 @@ export class TooltipDirective {
|
|
|
74
78
|
}
|
|
75
79
|
}
|
|
76
80
|
}
|
|
77
|
-
TooltipDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TooltipDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive });
|
|
81
|
+
TooltipDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TooltipDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i1.TooltipService }], target: i0.ɵɵFactoryTarget.Directive });
|
|
78
82
|
TooltipDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.10", type: TooltipDirective, selector: "[mozTooltipDirective]", inputs: { tooltipContent: ["mozTooltipDirective", "tooltipContent"], tooltipPosition: "tooltipPosition" }, host: { listeners: { "mouseover": "onMouseIn()", "mouseleave": "onMouseOut()" } }, ngImport: i0 });
|
|
79
83
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TooltipDirective, decorators: [{
|
|
80
84
|
type: Directive,
|
|
81
85
|
args: [{
|
|
82
86
|
selector: '[mozTooltipDirective]',
|
|
83
87
|
}]
|
|
84
|
-
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }]; }, propDecorators: { tooltipContent: [{
|
|
88
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i1.TooltipService }]; }, propDecorators: { tooltipContent: [{
|
|
85
89
|
type: Input,
|
|
86
90
|
args: ['mozTooltipDirective']
|
|
87
91
|
}], tooltipPosition: [{
|
|
@@ -93,4 +97,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
93
97
|
type: HostListener,
|
|
94
98
|
args: ['mouseleave']
|
|
95
99
|
}] } });
|
|
96
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
100
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.directive.js","sourceRoot":"","sources":["../../../../../../../projects/kit/components/tooltip/directive/tooltip.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  ElementRef,\n  HostListener,\n  Input,\n  OnDestroy,\n  OnInit,\n  Renderer2,\n} from '@angular/core';\nimport { Subscription, tap } from 'rxjs';\nimport { TooltipService } from '../service/tooltip.service';\n\n@Directive({\n  selector: '[mozTooltipDirective]',\n})\nexport class TooltipDirective implements OnInit, OnDestroy {\n  @Input('mozTooltipDirective') tooltipContent: string = '';\n  @Input() tooltipPosition: string = 'top';\n  public tooltip: HTMLElement | null = null;\n  public offset: number = 16;\n  private hideTooltipSubscription: Subscription | undefined;\n\n  constructor(\n    private el: ElementRef,\n    private renderer: Renderer2,\n    private readonly tooltipService: TooltipService\n  ) {}\n\n  @HostListener('mouseover')\n  onMouseIn(): void {\n    if (!this.tooltip) this.showTooltip();\n  }\n\n  @HostListener('mouseleave')\n  onMouseOut(): void {\n    if (this.tooltip) this.hideTooltip();\n  }\n\n  ngOnInit(): void {\n    this.hideTooltipSubscription = this.tooltipService.hideTooltip$\n      .pipe(tap(() => this.hideTooltip()))\n      .subscribe();\n  }\n\n  ngOnDestroy(): void {\n    this.hideTooltip();\n    this.hideTooltipSubscription?.unsubscribe();\n  }\n\n  showTooltip(): void {\n    this.tooltipService.setCurrentTooltip(this.el);\n    this.tooltip = this.renderer.createElement('span');\n\n    this.renderer.appendChild(this.tooltip, this.renderer.createText(this.tooltipContent));\n\n    this.renderer.appendChild(document.body, this.tooltip);\n\n    this.renderer.addClass(this.tooltip, 'mc-tooltip__content');\n    this.renderer.addClass(this.tooltip, `mc-tooltip__content-${this.tooltipPosition}`);\n\n    this.renderer.setStyle(this.tooltip, '-webkit-transition', `opacity 500ms`);\n    this.renderer.setStyle(this.tooltip, '-moz-transition', `opacity 500ms`);\n    this.renderer.setStyle(this.tooltip, '-o-transition', `opacity 500ms`);\n    this.renderer.setStyle(this.tooltip, 'transition', `opacity 500ms`);\n\n    this.setPosition();\n    this.renderer.addClass(this.tooltip, 'mc-tooltip__content-show');\n  }\n\n  hideTooltip(): void {\n    if (this.renderer && this.tooltip) {\n      this.renderer.removeChild(document.body, this.tooltip);\n      this.tooltip = null;\n    }\n  }\n\n  setPosition(): void {\n    if (this.tooltip) {\n      const hostPos = this.el.nativeElement.getBoundingClientRect();\n      const tooltipPos = this.tooltip.getBoundingClientRect();\n      const scrollPos =\n        window.scrollY || document.documentElement.scrollTop || document.body.scrollTop || 0;\n\n      let top, left;\n\n      if (this.tooltipPosition === 'top') {\n        top = hostPos.top - tooltipPos.height - this.offset;\n        left = hostPos.left + (hostPos.width - tooltipPos.width) / 2;\n      }\n\n      if (this.tooltipPosition === 'bottom') {\n        top = hostPos.bottom + this.offset;\n        left = hostPos.left + (hostPos.width - tooltipPos.width) / 2;\n      }\n\n      if (this.tooltipPosition === 'left') {\n        top = hostPos.top + (hostPos.height - tooltipPos.height) / 2;\n        left = hostPos.left - tooltipPos.width - this.offset;\n      }\n\n      if (this.tooltipPosition === 'right') {\n        top = hostPos.top + (hostPos.height - tooltipPos.height) / 2;\n        left = hostPos.right + this.offset;\n      }\n\n      if (top) {\n        this.renderer.setStyle(this.tooltip, 'top', `${top + scrollPos}px`);\n        this.renderer.setStyle(this.tooltip, 'left', `${left}px`);\n      }\n    }\n  }\n}\n"]}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { Subject } from 'rxjs';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class TooltipService {
|
|
5
|
+
constructor() {
|
|
6
|
+
this.currentTooltip = null;
|
|
7
|
+
this.hideTooltipSubject = new Subject();
|
|
8
|
+
this.mutationObserver = null;
|
|
9
|
+
this.mutationObserver = new MutationObserver(this.mutationObserverCallback.bind(this));
|
|
10
|
+
this.mutationObserver.observe(document.body, {
|
|
11
|
+
childList: true,
|
|
12
|
+
subtree: true,
|
|
13
|
+
});
|
|
14
|
+
}
|
|
15
|
+
get hideTooltip$() {
|
|
16
|
+
return this.hideTooltipSubject.asObservable();
|
|
17
|
+
}
|
|
18
|
+
setCurrentTooltip(tooltip) {
|
|
19
|
+
this.currentTooltip = tooltip;
|
|
20
|
+
}
|
|
21
|
+
mutationObserverCallback() {
|
|
22
|
+
if (this.currentTooltip && !document.body.contains(this.currentTooltip.nativeElement)) {
|
|
23
|
+
this.hideTooltipSubject.next();
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
TooltipService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TooltipService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
28
|
+
TooltipService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TooltipService, providedIn: 'root' });
|
|
29
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TooltipService, decorators: [{
|
|
30
|
+
type: Injectable,
|
|
31
|
+
args: [{
|
|
32
|
+
providedIn: 'root',
|
|
33
|
+
}]
|
|
34
|
+
}], ctorParameters: function () { return []; } });
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbHRpcC5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2l0L2NvbXBvbmVudHMvdG9vbHRpcC9zZXJ2aWNlL3Rvb2x0aXAuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQWMsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3ZELE9BQU8sRUFBYyxPQUFPLEVBQUUsTUFBTSxNQUFNLENBQUM7O0FBSzNDLE1BQU0sT0FBTyxjQUFjO0lBS3pCO1FBSlEsbUJBQWMsR0FBc0IsSUFBSSxDQUFDO1FBQ3pDLHVCQUFrQixHQUFHLElBQUksT0FBTyxFQUFRLENBQUM7UUFDekMscUJBQWdCLEdBQTRCLElBQUksQ0FBQztRQUd2RCxJQUFJLENBQUMsZ0JBQWdCLEdBQUcsSUFBSSxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsd0JBQXdCLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUM7UUFFdkYsSUFBSSxDQUFDLGdCQUFnQixDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsSUFBSSxFQUFFO1lBQzNDLFNBQVMsRUFBRSxJQUFJO1lBQ2YsT0FBTyxFQUFFLElBQUk7U0FDZCxDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQsSUFBVyxZQUFZO1FBQ3JCLE9BQU8sSUFBSSxDQUFDLGtCQUFrQixDQUFDLFlBQVksRUFBRSxDQUFDO0lBQ2hELENBQUM7SUFFTSxpQkFBaUIsQ0FBQyxPQUFtQjtRQUMxQyxJQUFJLENBQUMsY0FBYyxHQUFHLE9BQU8sQ0FBQztJQUNoQyxDQUFDO0lBRU8sd0JBQXdCO1FBQzlCLElBQUksSUFBSSxDQUFDLGNBQWMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsYUFBYSxDQUFDLEVBQUU7WUFDckYsSUFBSSxDQUFDLGtCQUFrQixDQUFDLElBQUksRUFBRSxDQUFDO1NBQ2hDO0lBQ0gsQ0FBQzs7NEdBMUJVLGNBQWM7Z0hBQWQsY0FBYyxjQUZiLE1BQU07NEZBRVAsY0FBYztrQkFIMUIsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBFbGVtZW50UmVmLCBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBPYnNlcnZhYmxlLCBTdWJqZWN0IH0gZnJvbSAncnhqcyc7XG5cbkBJbmplY3RhYmxlKHtcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnLFxufSlcbmV4cG9ydCBjbGFzcyBUb29sdGlwU2VydmljZSB7XG4gIHByaXZhdGUgY3VycmVudFRvb2x0aXA6IEVsZW1lbnRSZWYgfCBudWxsID0gbnVsbDtcbiAgcHJpdmF0ZSBoaWRlVG9vbHRpcFN1YmplY3QgPSBuZXcgU3ViamVjdDx2b2lkPigpO1xuICBwcml2YXRlIG11dGF0aW9uT2JzZXJ2ZXI6IE11dGF0aW9uT2JzZXJ2ZXIgfCBudWxsID0gbnVsbDtcblxuICBjb25zdHJ1Y3RvcigpIHtcbiAgICB0aGlzLm11dGF0aW9uT2JzZXJ2ZXIgPSBuZXcgTXV0YXRpb25PYnNlcnZlcih0aGlzLm11dGF0aW9uT2JzZXJ2ZXJDYWxsYmFjay5iaW5kKHRoaXMpKTtcblxuICAgIHRoaXMubXV0YXRpb25PYnNlcnZlci5vYnNlcnZlKGRvY3VtZW50LmJvZHksIHtcbiAgICAgIGNoaWxkTGlzdDogdHJ1ZSxcbiAgICAgIHN1YnRyZWU6IHRydWUsXG4gICAgfSk7XG4gIH1cblxuICBwdWJsaWMgZ2V0IGhpZGVUb29sdGlwJCgpOiBPYnNlcnZhYmxlPHZvaWQ+IHtcbiAgICByZXR1cm4gdGhpcy5oaWRlVG9vbHRpcFN1YmplY3QuYXNPYnNlcnZhYmxlKCk7XG4gIH1cblxuICBwdWJsaWMgc2V0Q3VycmVudFRvb2x0aXAodG9vbHRpcDogRWxlbWVudFJlZik6IHZvaWQge1xuICAgIHRoaXMuY3VycmVudFRvb2x0aXAgPSB0b29sdGlwO1xuICB9XG5cbiAgcHJpdmF0ZSBtdXRhdGlvbk9ic2VydmVyQ2FsbGJhY2soKTogdm9pZCB7XG4gICAgaWYgKHRoaXMuY3VycmVudFRvb2x0aXAgJiYgIWRvY3VtZW50LmJvZHkuY29udGFpbnModGhpcy5jdXJyZW50VG9vbHRpcC5uYXRpdmVFbGVtZW50KSkge1xuICAgICAgdGhpcy5oaWRlVG9vbHRpcFN1YmplY3QubmV4dCgpO1xuICAgIH1cbiAgfVxufVxuIl19
|