@datarailsshared/datarailsshared 1.3.3 → 1.3.6
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/assets/styles/img/spinner.gif +0 -0
- package/bundles/datarailsshared-datarailsshared.umd.js +527 -16
- package/bundles/datarailsshared-datarailsshared.umd.js.map +1 -1
- package/datarailsshared-datarailsshared-1.3.6.tgz +0 -0
- package/datarailsshared-datarailsshared.metadata.json +1 -1
- package/esm2015/lib/date-tags/month-tag/month-tag.component.js +3 -2
- package/esm2015/lib/dr-avatar/dr-avatar.component.js +40 -0
- package/esm2015/lib/dr-avatar/dr-avatar.module.js +23 -0
- package/esm2015/lib/dr-inputs/dr-inputs.module.js +3 -2
- package/esm2015/lib/dr-inputs/dr-select/dr-select.component.js +14 -6
- package/esm2015/lib/dr-inputs/dr-toggle/dr-toggle.component.js +55 -0
- package/esm2015/lib/dr-spinner/dr-spinner.component.js +29 -0
- package/esm2015/lib/dr-spinner/dr-spinner.directive.js +53 -0
- package/esm2015/lib/dr-spinner/dr-spinner.module.js +18 -0
- package/esm2015/lib/dr-tooltip/dr-tooltip.component.js +37 -0
- package/esm2015/lib/dr-tooltip/dr-tooltip.directive.js +203 -0
- package/esm2015/lib/dr-tooltip/dr-tooltip.module.js +23 -0
- package/esm2015/public-api.js +10 -1
- package/fesm2015/datarailsshared-datarailsshared.js +482 -14
- package/fesm2015/datarailsshared-datarailsshared.js.map +1 -1
- package/lib/dr-avatar/dr-avatar.component.d.ts +10 -0
- package/lib/dr-avatar/dr-avatar.module.d.ts +2 -0
- package/lib/dr-inputs/dr-select/dr-select.component.d.ts +4 -1
- package/lib/dr-inputs/dr-toggle/dr-toggle.component.d.ts +19 -0
- package/lib/dr-spinner/dr-spinner.component.d.ts +10 -0
- package/lib/dr-spinner/dr-spinner.directive.d.ts +15 -0
- package/lib/dr-spinner/dr-spinner.module.d.ts +2 -0
- package/lib/dr-tooltip/dr-tooltip.component.d.ts +16 -0
- package/lib/dr-tooltip/dr-tooltip.directive.d.ts +39 -0
- package/lib/dr-tooltip/dr-tooltip.module.d.ts +2 -0
- package/package.json +1 -1
- package/public-api.d.ts +9 -0
- package/datarailsshared-datarailsshared-1.3.3.tgz +0 -0
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { ComponentFactoryResolver, Directive, ElementRef, Inject, Input, Renderer2, ViewChild, ViewContainerRef } from '@angular/core';
|
|
2
|
+
import { DOCUMENT } from '@angular/common';
|
|
3
|
+
import { DrSpinnerComponent } from './dr-spinner.component';
|
|
4
|
+
export class DrSpinnerDirective {
|
|
5
|
+
constructor(componentFactoryResolver, viewContainerRef, el, rdr, _document) {
|
|
6
|
+
this.componentFactoryResolver = componentFactoryResolver;
|
|
7
|
+
this.viewContainerRef = viewContainerRef;
|
|
8
|
+
this.el = el;
|
|
9
|
+
this.rdr = rdr;
|
|
10
|
+
this._document = _document;
|
|
11
|
+
}
|
|
12
|
+
ngOnChanges(changes) {
|
|
13
|
+
const show = changes.drSpinner.currentValue;
|
|
14
|
+
const options = this.el.nativeElement.getBoundingClientRect();
|
|
15
|
+
if (this.contentCmpRef && !show) {
|
|
16
|
+
this.contentCmpRef.destroy();
|
|
17
|
+
this.contentCmpRef = null;
|
|
18
|
+
}
|
|
19
|
+
else if (this.drSpinner) {
|
|
20
|
+
this.showSpinner(Object.assign(Object.assign({}, options), { size: this.drSpinnerSize }));
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
ngOnDestroy() {
|
|
24
|
+
if (this.contentCmpRef) {
|
|
25
|
+
this.contentCmpRef.destroy();
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
showSpinner(options) {
|
|
29
|
+
let componentFactory;
|
|
30
|
+
componentFactory = this.componentFactoryResolver.resolveComponentFactory(DrSpinnerComponent);
|
|
31
|
+
this.contentCmpRef = this.viewContainerRef.createComponent(componentFactory);
|
|
32
|
+
this.rdr.appendChild(this.el.nativeElement, this.contentCmpRef.location.nativeElement);
|
|
33
|
+
this.contentCmpRef.instance.options = options;
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
DrSpinnerDirective.decorators = [
|
|
37
|
+
{ type: Directive, args: [{
|
|
38
|
+
selector: '[drSpinner]'
|
|
39
|
+
},] }
|
|
40
|
+
];
|
|
41
|
+
DrSpinnerDirective.ctorParameters = () => [
|
|
42
|
+
{ type: ComponentFactoryResolver },
|
|
43
|
+
{ type: ViewContainerRef },
|
|
44
|
+
{ type: ElementRef },
|
|
45
|
+
{ type: Renderer2 },
|
|
46
|
+
{ type: undefined, decorators: [{ type: Inject, args: [DOCUMENT,] }] }
|
|
47
|
+
];
|
|
48
|
+
DrSpinnerDirective.propDecorators = {
|
|
49
|
+
contentCmpRef: [{ type: ViewChild, args: [DrSpinnerComponent, { static: true, read: ViewContainerRef },] }],
|
|
50
|
+
drSpinner: [{ type: Input }],
|
|
51
|
+
drSpinnerSize: [{ type: Input }]
|
|
52
|
+
};
|
|
53
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHItc3Bpbm5lci5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kYXRhcmFpbHNzaGFyZWQvc3JjL2xpYi9kci1zcGlubmVyL2RyLXNwaW5uZXIuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFFSCx3QkFBd0IsRUFDeEIsU0FBUyxFQUNULFVBQVUsRUFDVixNQUFNLEVBQ04sS0FBSyxFQUdMLFNBQVMsRUFFVCxTQUFTLEVBQ1QsZ0JBQWdCLEVBQ25CLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMzQyxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUs1RCxNQUFNLE9BQU8sa0JBQWtCO0lBTTNCLFlBQW9CLHdCQUFrRCxFQUNsRCxnQkFBa0MsRUFDbEMsRUFBYyxFQUNkLEdBQWMsRUFDSSxTQUFjO1FBSmhDLDZCQUF3QixHQUF4Qix3QkFBd0IsQ0FBMEI7UUFDbEQscUJBQWdCLEdBQWhCLGdCQUFnQixDQUFrQjtRQUNsQyxPQUFFLEdBQUYsRUFBRSxDQUFZO1FBQ2QsUUFBRyxHQUFILEdBQUcsQ0FBVztRQUNJLGNBQVMsR0FBVCxTQUFTLENBQUs7SUFDcEQsQ0FBQztJQUVELFdBQVcsQ0FBQyxPQUFzQjtRQUM5QixNQUFNLElBQUksR0FBRyxPQUFPLENBQUMsU0FBUyxDQUFDLFlBQVksQ0FBQztRQUM1QyxNQUFNLE9BQU8sR0FBRyxJQUFJLENBQUMsRUFBRSxDQUFDLGFBQWEsQ0FBQyxxQkFBcUIsRUFBRSxDQUFDO1FBQzlELElBQUksSUFBSSxDQUFDLGFBQWEsSUFBSSxDQUFDLElBQUksRUFBRTtZQUM3QixJQUFJLENBQUMsYUFBYSxDQUFDLE9BQU8sRUFBRSxDQUFDO1lBQzdCLElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxDQUFDO1NBQzdCO2FBQU0sSUFBSSxJQUFJLENBQUMsU0FBUyxFQUFFO1lBQ3ZCLElBQUksQ0FBQyxXQUFXLGlDQUFLLE9BQU8sS0FBRSxJQUFJLEVBQUUsSUFBSSxDQUFDLGFBQWEsSUFBRSxDQUFDO1NBQzVEO0lBQ0wsQ0FBQztJQUVNLFdBQVc7UUFDZCxJQUFJLElBQUksQ0FBQyxhQUFhLEVBQUU7WUFDcEIsSUFBSSxDQUFDLGFBQWEsQ0FBQyxPQUFPLEVBQUUsQ0FBQztTQUNoQztJQUNMLENBQUM7SUFFTyxXQUFXLENBQUMsT0FBTztRQUN2QixJQUFJLGdCQUFzRCxDQUFDO1FBQzNELGdCQUFnQixHQUFHLElBQUksQ0FBQyx3QkFBd0IsQ0FBQyx1QkFBdUIsQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO1FBQzdGLElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxDQUFDLGdCQUFnQixDQUFDLGVBQWUsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO1FBQzdFLElBQUksQ0FBQyxHQUFHLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsYUFBYSxFQUFFLElBQUksQ0FBQyxhQUFhLENBQUMsUUFBUSxDQUFDLGFBQWEsQ0FBQyxDQUFDO1FBQ3ZGLElBQUksQ0FBQyxhQUFhLENBQUMsUUFBUSxDQUFDLE9BQU8sR0FBRyxPQUFPLENBQUM7SUFDbEQsQ0FBQzs7O1lBdkNKLFNBQVMsU0FBQztnQkFDUCxRQUFRLEVBQUUsYUFBYTthQUMxQjs7O1lBakJHLHdCQUF3QjtZQVV4QixnQkFBZ0I7WUFSaEIsVUFBVTtZQUtWLFNBQVM7NENBcUJJLE1BQU0sU0FBQyxRQUFROzs7NEJBUjNCLFNBQVMsU0FBQyxrQkFBa0IsRUFBRSxFQUFDLE1BQU0sRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLGdCQUFnQixFQUFDO3dCQUNwRSxLQUFLOzRCQUNMLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xyXG4gICAgQ29tcG9uZW50RmFjdG9yeSxcclxuICAgIENvbXBvbmVudEZhY3RvcnlSZXNvbHZlcixcclxuICAgIERpcmVjdGl2ZSxcclxuICAgIEVsZW1lbnRSZWYsXHJcbiAgICBJbmplY3QsXHJcbiAgICBJbnB1dCxcclxuICAgIE9uQ2hhbmdlcyxcclxuICAgIE9uRGVzdHJveSxcclxuICAgIFJlbmRlcmVyMixcclxuICAgIFNpbXBsZUNoYW5nZXMsXHJcbiAgICBWaWV3Q2hpbGQsXHJcbiAgICBWaWV3Q29udGFpbmVyUmVmXHJcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IERPQ1VNRU5UIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgRHJTcGlubmVyQ29tcG9uZW50IH0gZnJvbSAnLi9kci1zcGlubmVyLmNvbXBvbmVudCc7XHJcblxyXG5ARGlyZWN0aXZlKHtcclxuICAgIHNlbGVjdG9yOiAnW2RyU3Bpbm5lcl0nXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBEclNwaW5uZXJEaXJlY3RpdmUgaW1wbGVtZW50cyBPbkNoYW5nZXMsIE9uRGVzdHJveSB7XHJcblxyXG4gICAgQFZpZXdDaGlsZChEclNwaW5uZXJDb21wb25lbnQsIHtzdGF0aWM6IHRydWUsIHJlYWQ6IFZpZXdDb250YWluZXJSZWZ9KSBjb250ZW50Q21wUmVmO1xyXG4gICAgQElucHV0KCkgZHJTcGlubmVyO1xyXG4gICAgQElucHV0KCkgZHJTcGlubmVyU2l6ZTogJ3NtYWxsJyB8ICdtZWRpdW0nIHwgJ2JpZycgfCAnZ2lhbnQnO1xyXG5cclxuICAgIGNvbnN0cnVjdG9yKHByaXZhdGUgY29tcG9uZW50RmFjdG9yeVJlc29sdmVyOiBDb21wb25lbnRGYWN0b3J5UmVzb2x2ZXIsXHJcbiAgICAgICAgICAgICAgICBwcml2YXRlIHZpZXdDb250YWluZXJSZWY6IFZpZXdDb250YWluZXJSZWYsXHJcbiAgICAgICAgICAgICAgICBwcml2YXRlIGVsOiBFbGVtZW50UmVmLFxyXG4gICAgICAgICAgICAgICAgcHJpdmF0ZSByZHI6IFJlbmRlcmVyMixcclxuICAgICAgICAgICAgICAgIEBJbmplY3QoRE9DVU1FTlQpIHByaXZhdGUgX2RvY3VtZW50OiBhbnkpIHtcclxuICAgIH1cclxuXHJcbiAgICBuZ09uQ2hhbmdlcyhjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKSB7XHJcbiAgICAgICAgY29uc3Qgc2hvdyA9IGNoYW5nZXMuZHJTcGlubmVyLmN1cnJlbnRWYWx1ZTtcclxuICAgICAgICBjb25zdCBvcHRpb25zID0gdGhpcy5lbC5uYXRpdmVFbGVtZW50LmdldEJvdW5kaW5nQ2xpZW50UmVjdCgpO1xyXG4gICAgICAgIGlmICh0aGlzLmNvbnRlbnRDbXBSZWYgJiYgIXNob3cpIHtcclxuICAgICAgICAgICAgdGhpcy5jb250ZW50Q21wUmVmLmRlc3Ryb3koKTtcclxuICAgICAgICAgICAgdGhpcy5jb250ZW50Q21wUmVmID0gbnVsbDtcclxuICAgICAgICB9IGVsc2UgaWYgKHRoaXMuZHJTcGlubmVyKSB7XHJcbiAgICAgICAgICAgIHRoaXMuc2hvd1NwaW5uZXIoey4uLm9wdGlvbnMsIHNpemU6IHRoaXMuZHJTcGlubmVyU2l6ZX0pO1xyXG4gICAgICAgIH1cclxuICAgIH1cclxuXHJcbiAgICBwdWJsaWMgbmdPbkRlc3Ryb3koKSB7XHJcbiAgICAgICAgaWYgKHRoaXMuY29udGVudENtcFJlZikge1xyXG4gICAgICAgICAgICB0aGlzLmNvbnRlbnRDbXBSZWYuZGVzdHJveSgpO1xyXG4gICAgICAgIH1cclxuICAgIH1cclxuXHJcbiAgICBwcml2YXRlIHNob3dTcGlubmVyKG9wdGlvbnMpIHtcclxuICAgICAgICBsZXQgY29tcG9uZW50RmFjdG9yeTogQ29tcG9uZW50RmFjdG9yeTxEclNwaW5uZXJDb21wb25lbnQ+O1xyXG4gICAgICAgIGNvbXBvbmVudEZhY3RvcnkgPSB0aGlzLmNvbXBvbmVudEZhY3RvcnlSZXNvbHZlci5yZXNvbHZlQ29tcG9uZW50RmFjdG9yeShEclNwaW5uZXJDb21wb25lbnQpO1xyXG4gICAgICAgIHRoaXMuY29udGVudENtcFJlZiA9IHRoaXMudmlld0NvbnRhaW5lclJlZi5jcmVhdGVDb21wb25lbnQoY29tcG9uZW50RmFjdG9yeSk7XHJcbiAgICAgICAgdGhpcy5yZHIuYXBwZW5kQ2hpbGQodGhpcy5lbC5uYXRpdmVFbGVtZW50LCB0aGlzLmNvbnRlbnRDbXBSZWYubG9jYXRpb24ubmF0aXZlRWxlbWVudCk7XHJcbiAgICAgICAgdGhpcy5jb250ZW50Q21wUmVmLmluc3RhbmNlLm9wdGlvbnMgPSBvcHRpb25zO1xyXG4gICAgfVxyXG59XHJcbiJdfQ==
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from "@angular/common";
|
|
3
|
+
import { DrSpinnerComponent } from './dr-spinner.component';
|
|
4
|
+
import { DrSpinnerDirective } from './dr-spinner.directive';
|
|
5
|
+
const components = [DrSpinnerComponent];
|
|
6
|
+
const directives = [DrSpinnerDirective];
|
|
7
|
+
export class DrSpinnerModule {
|
|
8
|
+
}
|
|
9
|
+
DrSpinnerModule.decorators = [
|
|
10
|
+
{ type: NgModule, args: [{
|
|
11
|
+
imports: [
|
|
12
|
+
CommonModule,
|
|
13
|
+
],
|
|
14
|
+
exports: [...components, ...directives],
|
|
15
|
+
declarations: [...components, ...directives]
|
|
16
|
+
},] }
|
|
17
|
+
];
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHItc3Bpbm5lci5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kYXRhcmFpbHNzaGFyZWQvc3JjL2xpYi9kci1zcGlubmVyL2RyLXNwaW5uZXIubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQzVELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBRTVELE1BQU0sVUFBVSxHQUFHLENBQUMsa0JBQWtCLENBQUMsQ0FBQztBQUN4QyxNQUFNLFVBQVUsR0FBRyxDQUFDLGtCQUFrQixDQUFDLENBQUM7QUFVeEMsTUFBTSxPQUFPLGVBQWU7OztZQVIzQixRQUFRLFNBQUM7Z0JBQ1IsT0FBTyxFQUFFO29CQUNQLFlBQVk7aUJBQ2I7Z0JBQ0QsT0FBTyxFQUFFLENBQUMsR0FBRyxVQUFVLEVBQUUsR0FBRyxVQUFVLENBQUM7Z0JBQ3ZDLFlBQVksRUFBRSxDQUFDLEdBQUcsVUFBVSxFQUFFLEdBQUcsVUFBVSxDQUFDO2FBQzdDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vblwiO1xyXG5pbXBvcnQgeyBEclNwaW5uZXJDb21wb25lbnQgfSBmcm9tICcuL2RyLXNwaW5uZXIuY29tcG9uZW50JztcclxuaW1wb3J0IHsgRHJTcGlubmVyRGlyZWN0aXZlIH0gZnJvbSAnLi9kci1zcGlubmVyLmRpcmVjdGl2ZSc7XHJcblxyXG5jb25zdCBjb21wb25lbnRzID0gW0RyU3Bpbm5lckNvbXBvbmVudF07XHJcbmNvbnN0IGRpcmVjdGl2ZXMgPSBbRHJTcGlubmVyRGlyZWN0aXZlXTtcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgaW1wb3J0czogW1xyXG4gICAgQ29tbW9uTW9kdWxlLFxyXG4gIF0sXHJcbiAgZXhwb3J0czogWy4uLmNvbXBvbmVudHMsIC4uLmRpcmVjdGl2ZXNdLFxyXG4gIGRlY2xhcmF0aW9uczogWy4uLmNvbXBvbmVudHMsIC4uLmRpcmVjdGl2ZXNdXHJcbn0pXHJcblxyXG5leHBvcnQgY2xhc3MgRHJTcGlubmVyTW9kdWxlIHt9XHJcbiJdfQ==
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { Component, Input, TemplateRef } from '@angular/core';
|
|
2
|
+
import { animate, style, transition, trigger } from '@angular/animations';
|
|
3
|
+
export class TooltipComponent {
|
|
4
|
+
constructor() {
|
|
5
|
+
this.isContentTemplate = false;
|
|
6
|
+
}
|
|
7
|
+
ngOnInit() {
|
|
8
|
+
this.isContentTemplate = this.content instanceof TemplateRef;
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
TooltipComponent.decorators = [
|
|
12
|
+
{ type: Component, args: [{
|
|
13
|
+
selector: 'dr-tooltip',
|
|
14
|
+
template: "<div [class]=\"position + ' ' + class\" [ngClass]=\"{'dr-tooltip': !options?.withoutContainerStyles}\">\r\n <div *ngIf=\"!options?.withoutArrow\" class=\"dr-tooltip-arrow\"></div>\r\n <ng-container *ngIf=\"isContentTemplate; else defaultContent\">\r\n <ng-container *ngTemplateOutlet=\"content; context: contentContext\"></ng-container>\r\n </ng-container>\r\n <ng-template #defaultContent>\r\n <div class=\"default-content\">{{ content }}</div>\r\n </ng-template>\r\n</div>\r\n",
|
|
15
|
+
animations: [
|
|
16
|
+
trigger('tooltip', [
|
|
17
|
+
transition(':enter', [
|
|
18
|
+
style({ opacity: 0 }),
|
|
19
|
+
animate(300, style({ opacity: 1 })),
|
|
20
|
+
]),
|
|
21
|
+
transition(':leave', [
|
|
22
|
+
animate(300, style({ opacity: 0 })),
|
|
23
|
+
]),
|
|
24
|
+
]),
|
|
25
|
+
],
|
|
26
|
+
styles: [":host{display:block}.dr-tooltip{background:#fff;border:1px solid #cfd7dd;box-sizing:border-box;border-radius:4px;font-size:12px;color:#545a6b;max-width:80vh!important;box-shadow:0 2px 4px #9199b4}.dr-tooltip .default-content{padding:.5rem;font-size:11px;line-height:16px;white-space:pre;text-overflow:ellipsis;overflow:hidden}.dr-tooltip-arrow{border-width:8px}.dr-tooltip-arrow,.dr-tooltip-arrow:after{position:absolute;display:block;width:0;height:0;border-color:transparent;border-style:solid}.dr-tooltip-arrow:after{content:\"\";border-width:8px}.top .dr-tooltip-arrow,.top-left .dr-tooltip-arrow,.top-right .dr-tooltip-arrow{bottom:-16px;border-top-color:#cfd7dd!important}.top .dr-tooltip-arrow:after,.top-left .dr-tooltip-arrow:after,.top-right .dr-tooltip-arrow:after{bottom:-6px;left:-8px;border-top-color:#fff}.bottom .dr-tooltip-arrow,.bottom-left .dr-tooltip-arrow,.bottom-right .dr-tooltip-arrow{top:-7px;border-top:none;border-bottom-color:#cfd7dd!important}.bottom .dr-tooltip-arrow:after,.bottom-left .dr-tooltip-arrow:after,.bottom-right .dr-tooltip-arrow:after{border-top:none;top:1px;left:-8px;border-bottom-color:#fff}.left .dr-tooltip-arrow,.left-top .dr-tooltip-arrow,.left-bottom .dr-tooltip-arrow{right:-16px;border-left-color:#cfd7dd!important}.left .dr-tooltip-arrow:after,.left-top .dr-tooltip-arrow:after,.left-bottom .dr-tooltip-arrow:after{bottom:-8px;left:-9px;border-left-color:#fff}.right .dr-tooltip-arrow,.right-top .dr-tooltip-arrow,.right-bottom .dr-tooltip-arrow{left:-16px;border-right-color:#cfd7dd!important}.right .dr-tooltip-arrow:after,.right-top .dr-tooltip-arrow:after,.right-bottom .dr-tooltip-arrow:after{bottom:-8px;left:-7px;border-right-color:#fff}.top .dr-tooltip-arrow,.bottom .dr-tooltip-arrow{left:calc(50% - 4px)}.bottom-left .dr-tooltip-arrow,.top-left .dr-tooltip-arrow{left:4px}.bottom-right .dr-tooltip-arrow,.top-right .dr-tooltip-arrow{right:4px}.left .dr-tooltip-arrow,.right .dr-tooltip-arrow{top:calc(50% - 4px)}.left-top .dr-tooltip-arrow,.dr-tooltip-arrow .right-top{top:4px}.right-bottom .dr-tooltip-arrow,.left-bottom .dr-tooltip-arrow{bottom:4px}\n"]
|
|
27
|
+
},] }
|
|
28
|
+
];
|
|
29
|
+
TooltipComponent.ctorParameters = () => [];
|
|
30
|
+
TooltipComponent.propDecorators = {
|
|
31
|
+
content: [{ type: Input }],
|
|
32
|
+
contentContext: [{ type: Input }],
|
|
33
|
+
position: [{ type: Input }],
|
|
34
|
+
options: [{ type: Input }],
|
|
35
|
+
class: [{ type: Input }]
|
|
36
|
+
};
|
|
37
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHItdG9vbHRpcC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kYXRhcmFpbHNzaGFyZWQvc3JjL2xpYi9kci10b29sdGlwL2RyLXRvb2x0aXAuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFVLFdBQVcsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN0RSxPQUFPLEVBQUUsT0FBTyxFQUFFLEtBQUssRUFBRSxVQUFVLEVBQUUsT0FBTyxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUF1QjFFLE1BQU0sT0FBTyxnQkFBZ0I7SUFTM0I7UUFGQSxzQkFBaUIsR0FBRyxLQUFLLENBQUM7SUFFVixDQUFDO0lBRWpCLFFBQVE7UUFDTixJQUFJLENBQUMsaUJBQWlCLEdBQUcsSUFBSSxDQUFDLE9BQU8sWUFBWSxXQUFXLENBQUM7SUFDL0QsQ0FBQzs7O1lBN0JGLFNBQVMsU0FBQztnQkFDVCxRQUFRLEVBQUUsWUFBWTtnQkFDdEIseWdCQUEwQztnQkFFMUMsVUFBVSxFQUFFO29CQUNWLE9BQU8sQ0FBQyxTQUFTLEVBQUU7d0JBQ2pCLFVBQVUsQ0FBQyxRQUFRLEVBQUU7NEJBQ25CLEtBQUssQ0FBQyxFQUFFLE9BQU8sRUFBRSxDQUFDLEVBQUUsQ0FBQzs0QkFDckIsT0FBTyxDQUFDLEdBQUcsRUFBRSxLQUFLLENBQUMsRUFBRSxPQUFPLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQzt5QkFDcEMsQ0FBQzt3QkFDRixVQUFVLENBQUMsUUFBUSxFQUFFOzRCQUNuQixPQUFPLENBQUMsR0FBRyxFQUFFLEtBQUssQ0FBQyxFQUFFLE9BQU8sRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDO3lCQUNwQyxDQUFDO3FCQUNILENBQUM7aUJBQ0g7O2FBQ0Y7Ozs7c0JBR0UsS0FBSzs2QkFDTCxLQUFLO3VCQUNMLEtBQUs7c0JBQ0wsS0FBSztvQkFDTCxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgT25Jbml0LCBUZW1wbGF0ZVJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBhbmltYXRlLCBzdHlsZSwgdHJhbnNpdGlvbiwgdHJpZ2dlciB9IGZyb20gJ0Bhbmd1bGFyL2FuaW1hdGlvbnMnO1xyXG5cclxudHlwZSBUb29sdGlwT3B0aW9ucyA9IHtcclxuICB3aXRob3V0Q29udGFpbmVyU3R5bGVzPzogYm9vbGVhbjtcclxuICB3aXRob3V0QXJyb3c/OiBib29sZWFuO1xyXG59O1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdkci10b29sdGlwJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vZHItdG9vbHRpcC5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vZHItdG9vbHRpcC5jb21wb25lbnQuc2NzcyddLFxyXG4gIGFuaW1hdGlvbnM6IFtcclxuICAgIHRyaWdnZXIoJ3Rvb2x0aXAnLCBbXHJcbiAgICAgIHRyYW5zaXRpb24oJzplbnRlcicsIFtcclxuICAgICAgICBzdHlsZSh7IG9wYWNpdHk6IDAgfSksXHJcbiAgICAgICAgYW5pbWF0ZSgzMDAsIHN0eWxlKHsgb3BhY2l0eTogMSB9KSksXHJcbiAgICAgIF0pLFxyXG4gICAgICB0cmFuc2l0aW9uKCc6bGVhdmUnLCBbXHJcbiAgICAgICAgYW5pbWF0ZSgzMDAsIHN0eWxlKHsgb3BhY2l0eTogMCB9KSksXHJcbiAgICAgIF0pLFxyXG4gICAgXSksXHJcbiAgXSxcclxufSlcclxuZXhwb3J0IGNsYXNzIFRvb2x0aXBDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xyXG5cclxuICBASW5wdXQoKSBjb250ZW50O1xyXG4gIEBJbnB1dCgpIGNvbnRlbnRDb250ZXh0O1xyXG4gIEBJbnB1dCgpIHBvc2l0aW9uO1xyXG4gIEBJbnB1dCgpIG9wdGlvbnM6IFRvb2x0aXBPcHRpb25zO1xyXG4gIEBJbnB1dCgpIGNsYXNzOiBzdHJpbmc7XHJcbiAgaXNDb250ZW50VGVtcGxhdGUgPSBmYWxzZTtcclxuXHJcbiAgY29uc3RydWN0b3IoKSB7IH1cclxuXHJcbiAgbmdPbkluaXQoKTogdm9pZCB7XHJcbiAgICB0aGlzLmlzQ29udGVudFRlbXBsYXRlID0gdGhpcy5jb250ZW50IGluc3RhbmNlb2YgVGVtcGxhdGVSZWY7XHJcbiAgfVxyXG5cclxufVxyXG4iXX0=
|
|
@@ -0,0 +1,203 @@
|
|
|
1
|
+
import { Directive, ElementRef, HostListener, Input } from '@angular/core';
|
|
2
|
+
import { Overlay, OverlayPositionBuilder } from '@angular/cdk/overlay';
|
|
3
|
+
import { ComponentPortal } from '@angular/cdk/portal';
|
|
4
|
+
import { TooltipComponent } from './dr-tooltip.component';
|
|
5
|
+
export var TooltipPosition;
|
|
6
|
+
(function (TooltipPosition) {
|
|
7
|
+
TooltipPosition["TOP"] = "top";
|
|
8
|
+
TooltipPosition["BOTTOM"] = "bottom";
|
|
9
|
+
TooltipPosition["LEFT"] = "left";
|
|
10
|
+
TooltipPosition["RIGHT"] = "right";
|
|
11
|
+
TooltipPosition["TOP_RIGHT"] = "top-right";
|
|
12
|
+
TooltipPosition["TOP_LEFT"] = "top-left";
|
|
13
|
+
TooltipPosition["BOTTOM_RIGHT"] = "bottom-right";
|
|
14
|
+
TooltipPosition["BOTTOM_LEFT"] = "bottom-left";
|
|
15
|
+
TooltipPosition["RIGHT_TOP"] = "right-top";
|
|
16
|
+
TooltipPosition["RIGHT_BOTTOM"] = "right-bottom";
|
|
17
|
+
TooltipPosition["LEFT_TOP"] = "left-top";
|
|
18
|
+
TooltipPosition["LEFT_BOTTOM"] = "left-bottom";
|
|
19
|
+
})(TooltipPosition || (TooltipPosition = {}));
|
|
20
|
+
export class DrTooltipDirective {
|
|
21
|
+
constructor(overlay, overlayPositionBuilder, elementRef) {
|
|
22
|
+
this.overlay = overlay;
|
|
23
|
+
this.overlayPositionBuilder = overlayPositionBuilder;
|
|
24
|
+
this.elementRef = elementRef;
|
|
25
|
+
this.contentContext = {};
|
|
26
|
+
this.position = 'top';
|
|
27
|
+
this.class = '';
|
|
28
|
+
this.tooltipPositions = {
|
|
29
|
+
top: {
|
|
30
|
+
originX: 'center',
|
|
31
|
+
originY: 'top',
|
|
32
|
+
overlayX: 'center',
|
|
33
|
+
overlayY: 'bottom',
|
|
34
|
+
offsetY: -8
|
|
35
|
+
},
|
|
36
|
+
'top-left': {
|
|
37
|
+
originX: 'start',
|
|
38
|
+
originY: 'top',
|
|
39
|
+
overlayX: 'start',
|
|
40
|
+
overlayY: 'bottom',
|
|
41
|
+
offsetY: -8
|
|
42
|
+
},
|
|
43
|
+
'top-right': {
|
|
44
|
+
originX: 'end',
|
|
45
|
+
originY: 'top',
|
|
46
|
+
overlayX: 'end',
|
|
47
|
+
overlayY: 'bottom',
|
|
48
|
+
offsetY: -8
|
|
49
|
+
},
|
|
50
|
+
bottom: {
|
|
51
|
+
originX: 'center',
|
|
52
|
+
originY: 'bottom',
|
|
53
|
+
overlayX: 'center',
|
|
54
|
+
overlayY: 'top',
|
|
55
|
+
offsetY: 7
|
|
56
|
+
},
|
|
57
|
+
'bottom-left': {
|
|
58
|
+
originX: 'start',
|
|
59
|
+
originY: 'bottom',
|
|
60
|
+
overlayX: 'start',
|
|
61
|
+
overlayY: 'top',
|
|
62
|
+
offsetY: 7
|
|
63
|
+
},
|
|
64
|
+
'bottom-right': {
|
|
65
|
+
originX: 'end',
|
|
66
|
+
originY: 'bottom',
|
|
67
|
+
overlayX: 'end',
|
|
68
|
+
overlayY: 'top',
|
|
69
|
+
offsetY: 7
|
|
70
|
+
},
|
|
71
|
+
left: {
|
|
72
|
+
originX: 'start',
|
|
73
|
+
originY: 'center',
|
|
74
|
+
overlayX: 'end',
|
|
75
|
+
overlayY: 'center',
|
|
76
|
+
offsetX: -8
|
|
77
|
+
},
|
|
78
|
+
'left-top': {
|
|
79
|
+
originX: 'start',
|
|
80
|
+
originY: 'top',
|
|
81
|
+
overlayX: 'end',
|
|
82
|
+
overlayY: 'top',
|
|
83
|
+
offsetX: -8
|
|
84
|
+
},
|
|
85
|
+
'left-bottom': {
|
|
86
|
+
originX: 'start',
|
|
87
|
+
originY: 'bottom',
|
|
88
|
+
overlayX: 'end',
|
|
89
|
+
overlayY: 'bottom',
|
|
90
|
+
offsetX: -8
|
|
91
|
+
},
|
|
92
|
+
right: {
|
|
93
|
+
originX: 'end',
|
|
94
|
+
originY: 'center',
|
|
95
|
+
overlayX: 'start',
|
|
96
|
+
overlayY: 'center',
|
|
97
|
+
offsetX: 8
|
|
98
|
+
},
|
|
99
|
+
'right-top': {
|
|
100
|
+
originX: 'end',
|
|
101
|
+
originY: 'top',
|
|
102
|
+
overlayX: 'start',
|
|
103
|
+
overlayY: 'top',
|
|
104
|
+
offsetX: 8
|
|
105
|
+
},
|
|
106
|
+
'right-bottom': {
|
|
107
|
+
originX: 'end',
|
|
108
|
+
originY: 'bottom',
|
|
109
|
+
overlayX: 'start',
|
|
110
|
+
overlayY: 'bottom',
|
|
111
|
+
offsetX: 8
|
|
112
|
+
}
|
|
113
|
+
};
|
|
114
|
+
}
|
|
115
|
+
set drTooltipOptions(options) {
|
|
116
|
+
if (options === null || options === void 0 ? void 0 : options.indent) {
|
|
117
|
+
const position = this.tooltipPositions[this.position];
|
|
118
|
+
if (position.offsetY) {
|
|
119
|
+
position.offsetY = position.offsetY < 0 ? -options.indent : options.indent;
|
|
120
|
+
}
|
|
121
|
+
if (position.offsetX) {
|
|
122
|
+
position.offsetX = position.offsetX < 0 ? -options.indent : options.indent;
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
this.options = options;
|
|
126
|
+
}
|
|
127
|
+
set showTooltip(value) {
|
|
128
|
+
this.manualHandling = true;
|
|
129
|
+
if (value) {
|
|
130
|
+
this.renderTooltip();
|
|
131
|
+
}
|
|
132
|
+
else {
|
|
133
|
+
this.destroyTooltip();
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
ngOnDestroy() {
|
|
137
|
+
if (!this.overlayRef)
|
|
138
|
+
return null;
|
|
139
|
+
if (this.overlayRef.hasAttached()) {
|
|
140
|
+
this.hide();
|
|
141
|
+
}
|
|
142
|
+
// TODO: Temporary solution. line 162 doesn't stop function execution
|
|
143
|
+
if (this.overlayRef) {
|
|
144
|
+
this.overlayRef.dispose();
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
show() {
|
|
148
|
+
if (this.manualHandling)
|
|
149
|
+
return;
|
|
150
|
+
this.renderTooltip();
|
|
151
|
+
}
|
|
152
|
+
hide() {
|
|
153
|
+
if (this.manualHandling)
|
|
154
|
+
return;
|
|
155
|
+
this.destroyTooltip();
|
|
156
|
+
}
|
|
157
|
+
createOverlay() {
|
|
158
|
+
const positionStrategy = this.overlayPositionBuilder
|
|
159
|
+
.flexibleConnectedTo(this.elementRef)
|
|
160
|
+
.withPositions([this.tooltipPositions[this.position]]);
|
|
161
|
+
this.overlayRef = this.overlay.create({ positionStrategy });
|
|
162
|
+
}
|
|
163
|
+
renderTooltip() {
|
|
164
|
+
var _a;
|
|
165
|
+
this.createOverlay();
|
|
166
|
+
if (!((_a = this.overlayRef) === null || _a === void 0 ? void 0 : _a.hasAttached()) && this.content) {
|
|
167
|
+
const tooltipRef = this.overlayRef.attach(new ComponentPortal(TooltipComponent));
|
|
168
|
+
tooltipRef.instance.content = this.content;
|
|
169
|
+
tooltipRef.instance.contentContext = this.contentContext;
|
|
170
|
+
tooltipRef.instance.position = this.position;
|
|
171
|
+
tooltipRef.instance.options = this.options;
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
destroyTooltip() {
|
|
175
|
+
if (this.overlayRef) {
|
|
176
|
+
this.overlayRef.dispose();
|
|
177
|
+
}
|
|
178
|
+
this.overlayRef = null;
|
|
179
|
+
}
|
|
180
|
+
ngOnInit() {
|
|
181
|
+
}
|
|
182
|
+
}
|
|
183
|
+
DrTooltipDirective.decorators = [
|
|
184
|
+
{ type: Directive, args: [{
|
|
185
|
+
selector: '[drTooltip]'
|
|
186
|
+
},] }
|
|
187
|
+
];
|
|
188
|
+
DrTooltipDirective.ctorParameters = () => [
|
|
189
|
+
{ type: Overlay },
|
|
190
|
+
{ type: OverlayPositionBuilder },
|
|
191
|
+
{ type: ElementRef }
|
|
192
|
+
];
|
|
193
|
+
DrTooltipDirective.propDecorators = {
|
|
194
|
+
content: [{ type: Input, args: ['drTooltip',] }],
|
|
195
|
+
contentContext: [{ type: Input, args: ['drTooltipContext',] }],
|
|
196
|
+
position: [{ type: Input, args: ['drTooltipPosition',] }],
|
|
197
|
+
class: [{ type: Input, args: ['drTooltipClass',] }],
|
|
198
|
+
drTooltipOptions: [{ type: Input }],
|
|
199
|
+
showTooltip: [{ type: Input, args: ['drTooltipShow',] }],
|
|
200
|
+
show: [{ type: HostListener, args: ['mouseenter',] }],
|
|
201
|
+
hide: [{ type: HostListener, args: ['mouseleave',] }]
|
|
202
|
+
};
|
|
203
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-tooltip.directive.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/dr-tooltip/dr-tooltip.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { ComponentRef, Directive, ElementRef, HostListener, Input, OnInit, OnDestroy } from '@angular/core';\r\nimport { Overlay, OverlayPositionBuilder, OverlayRef } from '@angular/cdk/overlay';\r\nimport { ComponentPortal } from '@angular/cdk/portal';\r\nimport { TooltipComponent } from './dr-tooltip.component';\r\n\r\nexport enum TooltipPosition {\r\n  TOP = 'top',\r\n  BOTTOM = 'bottom',\r\n  LEFT = 'left',\r\n  RIGHT = 'right',\r\n  TOP_RIGHT = 'top-right',\r\n  TOP_LEFT = 'top-left',\r\n  BOTTOM_RIGHT = 'bottom-right',\r\n  BOTTOM_LEFT = 'bottom-left',\r\n  RIGHT_TOP = 'right-top',\r\n  RIGHT_BOTTOM = 'right-bottom',\r\n  LEFT_TOP = 'left-top',\r\n  LEFT_BOTTOM = 'left-bottom',\r\n}\r\n\r\n@Directive({\r\n  selector: '[drTooltip]'\r\n})\r\nexport class DrTooltipDirective implements OnInit, OnDestroy  {\r\n\r\n  @Input('drTooltip')\r\n  content: any;\r\n  @Input('drTooltipContext')\r\n  contentContext = {};\r\n  @Input('drTooltipPosition')\r\n  position = 'top';\r\n  @Input('drTooltipClass')\r\n  class = '';\r\n  @Input()\r\n  set drTooltipOptions(options: any) {\r\n    if (options?.indent) {\r\n      const position = this.tooltipPositions[this.position];\r\n      if (position.offsetY) {\r\n        position.offsetY = position.offsetY < 0 ? -options.indent : options.indent;\r\n      }\r\n      if (position.offsetX) {\r\n        position.offsetX = position.offsetX < 0 ? -options.indent : options.indent;\r\n      }\r\n    }\r\n    this.options = options;\r\n  }\r\n\r\n  @Input('drTooltipShow')\r\n  set showTooltip(value: boolean) {\r\n    this.manualHandling = true;\r\n    if (value) {\r\n      this.renderTooltip();\r\n    } else {\r\n      this.destroyTooltip();\r\n    }\r\n  }\r\n\r\n  private overlayRef: OverlayRef;\r\n\r\n  private tooltipPositions = {\r\n    top: {\r\n      originX: 'center',\r\n      originY: 'top',\r\n      overlayX: 'center',\r\n      overlayY: 'bottom',\r\n      offsetY: -8\r\n    },\r\n    'top-left': {\r\n      originX: 'start',\r\n      originY: 'top',\r\n      overlayX: 'start',\r\n      overlayY: 'bottom',\r\n      offsetY: -8\r\n    },\r\n    'top-right': {\r\n      originX: 'end',\r\n      originY: 'top',\r\n      overlayX: 'end',\r\n      overlayY: 'bottom',\r\n      offsetY: -8\r\n    },\r\n    bottom: {\r\n      originX: 'center',\r\n      originY: 'bottom',\r\n      overlayX: 'center',\r\n      overlayY: 'top',\r\n      offsetY: 7\r\n    },\r\n    'bottom-left': {\r\n      originX: 'start',\r\n      originY: 'bottom',\r\n      overlayX: 'start',\r\n      overlayY: 'top',\r\n      offsetY: 7\r\n    },\r\n    'bottom-right': {\r\n      originX: 'end',\r\n      originY: 'bottom',\r\n      overlayX: 'end',\r\n      overlayY: 'top',\r\n      offsetY: 7\r\n    },\r\n    left: {\r\n      originX: 'start',\r\n      originY: 'center',\r\n      overlayX: 'end',\r\n      overlayY: 'center',\r\n      offsetX: -8\r\n    },\r\n    'left-top': {\r\n      originX: 'start',\r\n      originY: 'top',\r\n      overlayX: 'end',\r\n      overlayY: 'top',\r\n      offsetX: -8\r\n    },\r\n    'left-bottom': {\r\n      originX: 'start',\r\n      originY: 'bottom',\r\n      overlayX: 'end',\r\n      overlayY: 'bottom',\r\n      offsetX: -8\r\n    },\r\n    right: {\r\n      originX: 'end',\r\n      originY: 'center',\r\n      overlayX: 'start',\r\n      overlayY: 'center',\r\n      offsetX: 8\r\n    },\r\n    'right-top': {\r\n      originX: 'end',\r\n      originY: 'top',\r\n      overlayX: 'start',\r\n      overlayY: 'top',\r\n      offsetX: 8\r\n    },\r\n    'right-bottom': {\r\n      originX: 'end',\r\n      originY: 'bottom',\r\n      overlayX: 'start',\r\n      overlayY: 'bottom',\r\n      offsetX: 8\r\n    }\r\n  };\r\n  private options;\r\n  private manualHandling: boolean;\r\n\r\n  constructor(private overlay: Overlay,\r\n              private overlayPositionBuilder: OverlayPositionBuilder,\r\n              private elementRef: ElementRef) { }\r\n\r\n  ngOnDestroy(): void {\r\n    if (!this.overlayRef) return null;\r\n\r\n    if (this.overlayRef.hasAttached()) {\r\n      this.hide();\r\n    }\r\n    // TODO: Temporary solution. line 162 doesn't stop function execution\r\n    if (this.overlayRef) {\r\n      this.overlayRef.dispose();\r\n    }\r\n  }\r\n\r\n  @HostListener('mouseenter')\r\n  show() {\r\n    if (this.manualHandling) return;\r\n\r\n    this.renderTooltip();\r\n  }\r\n\r\n  @HostListener('mouseleave')\r\n  hide() {\r\n    if (this.manualHandling) return;\r\n\r\n    this.destroyTooltip();\r\n  }\r\n\r\n  private createOverlay(): void {\r\n    const positionStrategy = this.overlayPositionBuilder\r\n      .flexibleConnectedTo(this.elementRef)\r\n      .withPositions([this.tooltipPositions[this.position]]);\r\n\r\n    this.overlayRef = this.overlay.create({ positionStrategy });\r\n  }\r\n\r\n  private renderTooltip(): void {\r\n    this.createOverlay();\r\n    if (!this.overlayRef?.hasAttached() && this.content) {\r\n      const tooltipRef: ComponentRef<TooltipComponent> = this.overlayRef.attach(new ComponentPortal(TooltipComponent));\r\n      tooltipRef.instance.content = this.content;\r\n      tooltipRef.instance.contentContext = this.contentContext;\r\n      tooltipRef.instance.position = this.position;\r\n      tooltipRef.instance.options = this.options;\r\n    }\r\n  }\r\n\r\n  private destroyTooltip(): void {\r\n    if (this.overlayRef) {\r\n      this.overlayRef.dispose();\r\n    }\r\n    this.overlayRef = null;\r\n  }\r\n\r\n  ngOnInit(): void {\r\n  }\r\n}\r\n"]}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { DrTooltipDirective } from "./dr-tooltip.directive";
|
|
3
|
+
import { TooltipComponent } from "./dr-tooltip.component";
|
|
4
|
+
import { CommonModule } from "@angular/common";
|
|
5
|
+
export class DrTooltipModule {
|
|
6
|
+
}
|
|
7
|
+
DrTooltipModule.decorators = [
|
|
8
|
+
{ type: NgModule, args: [{
|
|
9
|
+
imports: [
|
|
10
|
+
CommonModule
|
|
11
|
+
],
|
|
12
|
+
exports: [
|
|
13
|
+
TooltipComponent,
|
|
14
|
+
DrTooltipDirective,
|
|
15
|
+
],
|
|
16
|
+
providers: [],
|
|
17
|
+
declarations: [
|
|
18
|
+
TooltipComponent,
|
|
19
|
+
DrTooltipDirective,
|
|
20
|
+
],
|
|
21
|
+
},] }
|
|
22
|
+
];
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHItdG9vbHRpcC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kYXRhcmFpbHNzaGFyZWQvc3JjL2xpYi9kci10b29sdGlwL2RyLXRvb2x0aXAubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDNUQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDMUQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBaUIvQyxNQUFNLE9BQU8sZUFBZTs7O1lBZjNCLFFBQVEsU0FBQztnQkFDUixPQUFPLEVBQUU7b0JBQ1AsWUFBWTtpQkFDYjtnQkFDRCxPQUFPLEVBQUU7b0JBQ1AsZ0JBQWdCO29CQUNoQixrQkFBa0I7aUJBQ25CO2dCQUNELFNBQVMsRUFBRSxFQUFFO2dCQUNiLFlBQVksRUFBRTtvQkFDWixnQkFBZ0I7b0JBQ2hCLGtCQUFrQjtpQkFDbkI7YUFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IERyVG9vbHRpcERpcmVjdGl2ZSB9IGZyb20gXCIuL2RyLXRvb2x0aXAuZGlyZWN0aXZlXCI7XHJcbmltcG9ydCB7IFRvb2x0aXBDb21wb25lbnQgfSBmcm9tIFwiLi9kci10b29sdGlwLmNvbXBvbmVudFwiO1xyXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29tbW9uXCI7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGltcG9ydHM6IFtcclxuICAgIENvbW1vbk1vZHVsZVxyXG4gIF0sXHJcbiAgZXhwb3J0czogW1xyXG4gICAgVG9vbHRpcENvbXBvbmVudCxcclxuICAgIERyVG9vbHRpcERpcmVjdGl2ZSxcclxuICBdLFxyXG4gIHByb3ZpZGVyczogW10sXHJcbiAgZGVjbGFyYXRpb25zOiBbXHJcbiAgICBUb29sdGlwQ29tcG9uZW50LFxyXG4gICAgRHJUb29sdGlwRGlyZWN0aXZlLFxyXG4gIF0sXHJcbn0pXHJcblxyXG5leHBvcnQgY2xhc3MgRHJUb29sdGlwTW9kdWxlIHt9XHJcbiJdfQ==
|
package/esm2015/public-api.js
CHANGED
|
@@ -13,8 +13,17 @@ export * from "./lib/dr-inputs/radio-button/radio-button.component";
|
|
|
13
13
|
export * from "./lib/dr-inputs/checkbox/checkbox.component";
|
|
14
14
|
export * from "./lib/dr-inputs/dr-input/dr-input.component";
|
|
15
15
|
export * from "./lib/dr-inputs/dr-select/dr-select.component";
|
|
16
|
+
export * from './lib/dr-avatar/dr-avatar.component';
|
|
17
|
+
export * from './lib/dr-tooltip/dr-tooltip.component';
|
|
18
|
+
export * from './lib/dr-tooltip/dr-tooltip.directive';
|
|
19
|
+
export * from "./lib/dr-inputs/dr-toggle/dr-toggle.component";
|
|
20
|
+
export * from "./lib/dr-spinner/dr-spinner.component";
|
|
21
|
+
export * from "./lib/dr-spinner/dr-spinner.directive";
|
|
16
22
|
export { DateTagModule } from "./lib/date-tags/date-tag.module";
|
|
17
23
|
export { ListTagModule } from "./lib/list-tags/list-tag.module";
|
|
18
24
|
export { DrTagModule } from "./lib/dr-tags/dr-tag.module";
|
|
19
25
|
export { DrInputsModule } from "./lib/dr-inputs/dr-inputs.module";
|
|
20
|
-
|
|
26
|
+
export { DrTooltipModule } from './lib/dr-tooltip/dr-tooltip.module';
|
|
27
|
+
export { DrAvatarModule } from './lib/dr-avatar/dr-avatar.module';
|
|
28
|
+
export { DrSpinnerModule } from "./lib/dr-spinner/dr-spinner.module";
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2RhdGFyYWlsc3NoYXJlZC9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxnQkFBZ0I7QUFDaEIsY0FBYyxvQ0FBb0MsQ0FBQztBQUNuRCxjQUFjLHFEQUFxRCxDQUFDO0FBQ3BFLGNBQWMsK0NBQStDLENBQUM7QUFDOUQsY0FBYyxtREFBbUQsQ0FBQztBQUNsRSxjQUFjLDZDQUE2QyxDQUFDO0FBQzVELGNBQWMsNkNBQTZDLENBQUM7QUFDNUQsY0FBYyxnQ0FBZ0MsQ0FBQztBQUMvQyxjQUFjLG9DQUFvQyxDQUFDO0FBQ25ELGNBQWMsMkNBQTJDLENBQUM7QUFDMUQsY0FBYyxvQ0FBb0MsQ0FBQztBQUNuRCxjQUFjLHFEQUFxRCxDQUFDO0FBQ3BFLGNBQWMsNkNBQTZDLENBQUM7QUFDNUQsY0FBYyw2Q0FBNkMsQ0FBQztBQUM1RCxjQUFjLCtDQUErQyxDQUFDO0FBQzlELGNBQWMscUNBQXFDLENBQUM7QUFDcEQsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLHVDQUF1QyxDQUFDO0FBQ3RELGNBQWMsK0NBQStDLENBQUM7QUFDOUQsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLHVDQUF1QyxDQUFDO0FBR3RELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUNoRSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDaEUsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBQzFELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUNsRSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sb0NBQW9DLENBQUM7QUFDckUsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGtDQUFrQyxDQUFDO0FBQ2xFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qIGNvbXBvbmVudHMgKi9cclxuZXhwb3J0ICogZnJvbSBcIi4vbGliL2RhdGUtdGFncy9kYXRlLXRhZy5jb21wb25lbnRcIjtcclxuZXhwb3J0ICogZnJvbSBcIi4vbGliL2RhdGUtdGFncy9mb3JlY2FzdC10YWcvZm9yZWNhc3QtdGFnLmNvbXBvbmVudFwiO1xyXG5leHBvcnQgKiBmcm9tIFwiLi9saWIvZGF0ZS10YWdzL21vbnRoLXRhZy9tb250aC10YWcuY29tcG9uZW50XCI7XHJcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9kYXRlLXRhZ3MvcXVhcnRlci10YWcvcXVhcnRlci10YWcuY29tcG9uZW50XCI7XHJcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9kYXRlLXRhZ3Mvd2Vlay10YWcvd2Vlay10YWcuY29tcG9uZW50XCI7XHJcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9kYXRlLXRhZ3MveWVhci10YWcveWVhci10YWcuY29tcG9uZW50XCI7XHJcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9kci10YWdzL2RyLXRhZy5jb21wb25lbnRcIjtcclxuZXhwb3J0ICogZnJvbSBcIi4vbGliL2xpc3QtdGFncy9saXN0LXRhZy5jb21wb25lbnRcIjtcclxuZXhwb3J0ICogZnJvbSBcIi4vbGliL2RhdGUtdGFncy9kYXktdGFnL2RheS10YWcuY29tcG9uZW50XCI7XHJcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9kYXRlLXRhZ3MvZGF0ZS10YWcuY29tcG9uZW50XCI7XHJcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9kci1pbnB1dHMvcmFkaW8tYnV0dG9uL3JhZGlvLWJ1dHRvbi5jb21wb25lbnRcIjtcclxuZXhwb3J0ICogZnJvbSBcIi4vbGliL2RyLWlucHV0cy9jaGVja2JveC9jaGVja2JveC5jb21wb25lbnRcIjtcclxuZXhwb3J0ICogZnJvbSBcIi4vbGliL2RyLWlucHV0cy9kci1pbnB1dC9kci1pbnB1dC5jb21wb25lbnRcIjtcclxuZXhwb3J0ICogZnJvbSBcIi4vbGliL2RyLWlucHV0cy9kci1zZWxlY3QvZHItc2VsZWN0LmNvbXBvbmVudFwiO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9kci1hdmF0YXIvZHItYXZhdGFyLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RyLXRvb2x0aXAvZHItdG9vbHRpcC5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9kci10b29sdGlwL2RyLXRvb2x0aXAuZGlyZWN0aXZlJztcclxuZXhwb3J0ICogZnJvbSBcIi4vbGliL2RyLWlucHV0cy9kci10b2dnbGUvZHItdG9nZ2xlLmNvbXBvbmVudFwiO1xyXG5leHBvcnQgKiBmcm9tIFwiLi9saWIvZHItc3Bpbm5lci9kci1zcGlubmVyLmNvbXBvbmVudFwiO1xyXG5leHBvcnQgKiBmcm9tIFwiLi9saWIvZHItc3Bpbm5lci9kci1zcGlubmVyLmRpcmVjdGl2ZVwiO1xyXG4vKiBtb2R1bGVzICovXHJcbmV4cG9ydCB7IFRBR19UWVBFUywgSVRhZywgSURhdGVUYWcsIElMaXN0VGFnLCBJVGFnRm9yU2VydmVyIH0gZnJvbSBcIi4vbGliL21vZGVscy9zZXJ2ZXJUYWdzXCI7XHJcbmV4cG9ydCB7IERhdGVUYWdNb2R1bGUgfSBmcm9tIFwiLi9saWIvZGF0ZS10YWdzL2RhdGUtdGFnLm1vZHVsZVwiO1xyXG5leHBvcnQgeyBMaXN0VGFnTW9kdWxlIH0gZnJvbSBcIi4vbGliL2xpc3QtdGFncy9saXN0LXRhZy5tb2R1bGVcIjtcclxuZXhwb3J0IHsgRHJUYWdNb2R1bGUgfSBmcm9tIFwiLi9saWIvZHItdGFncy9kci10YWcubW9kdWxlXCI7XHJcbmV4cG9ydCB7IERySW5wdXRzTW9kdWxlIH0gZnJvbSBcIi4vbGliL2RyLWlucHV0cy9kci1pbnB1dHMubW9kdWxlXCI7XHJcbmV4cG9ydCB7IERyVG9vbHRpcE1vZHVsZSB9IGZyb20gJy4vbGliL2RyLXRvb2x0aXAvZHItdG9vbHRpcC5tb2R1bGUnO1xyXG5leHBvcnQgeyBEckF2YXRhck1vZHVsZSB9IGZyb20gJy4vbGliL2RyLWF2YXRhci9kci1hdmF0YXIubW9kdWxlJztcclxuZXhwb3J0IHsgRHJTcGlubmVyTW9kdWxlIH0gZnJvbSBcIi4vbGliL2RyLXNwaW5uZXIvZHItc3Bpbm5lci5tb2R1bGVcIjtcclxuIl19
|