@datarailsshared/datarailsshared 1.6.204 → 1.6.208
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/datarailsshared-datarailsshared-1.6.208.tgz +0 -0
- package/esm2022/lib/dr-dropdown/dr-dropdown.component.mjs +73 -37
- package/esm2022/lib/dr-tooltip/components/tooltip-custom/tooltip-custom.component.mjs +58 -0
- package/esm2022/lib/dr-tooltip/dr-tooltip.component.mjs +28 -8
- package/esm2022/lib/dr-tooltip/dr-tooltip.module.mjs +22 -4
- package/esm2022/lib/emoji-picker/emoji-picker.component.mjs +2 -2
- package/esm2022/lib/models/dropdown.mjs +1 -1
- package/esm2022/public-api.mjs +1 -1
- package/fesm2022/datarailsshared-datarailsshared.mjs +187 -61
- package/fesm2022/datarailsshared-datarailsshared.mjs.map +1 -1
- package/lib/dr-dropdown/dr-dropdown.component.d.ts +18 -9
- package/lib/dr-tooltip/components/tooltip-custom/tooltip-custom.component.d.ts +14 -0
- package/lib/dr-tooltip/dr-tooltip.component.d.ts +2 -2
- package/lib/dr-tooltip/dr-tooltip.module.d.ts +4 -3
- package/lib/models/dropdown.d.ts +16 -1
- package/package.json +1 -1
- package/public-api.d.ts +1 -1
- package/datarailsshared-datarailsshared-1.6.204.tgz +0 -0
|
Binary file
|
|
@@ -12,6 +12,7 @@ import { DrPopoverRef } from '../models/popover';
|
|
|
12
12
|
import { first, merge, Subject, takeUntil } from 'rxjs';
|
|
13
13
|
import { DropdownInstanceService } from './dr-dropdown.service';
|
|
14
14
|
import { Debounce } from '../utils/decorators';
|
|
15
|
+
import { TooltipTheme } from '../dr-tooltip/enums/tooltip-theme.enum';
|
|
15
16
|
import * as i0 from "@angular/core";
|
|
16
17
|
const _c0 = ["menuContainer"];
|
|
17
18
|
function DrDropdownComponent_dr_dropdown_item_4_ng_container_1_i_1_Template(rf, ctx) { if (rf & 1) {
|
|
@@ -70,7 +71,6 @@ function DrDropdownComponent_dr_dropdown_item_4_ng_container_3_Template(rf, ctx)
|
|
|
70
71
|
const act_r2 = i0.ɵɵnextContext().$implicit;
|
|
71
72
|
i0.ɵɵproperty("ngTemplateOutlet", act_r2.templateRef)("ngTemplateOutletContext", i0.ɵɵpureFunction1(2, _c1, act_r2));
|
|
72
73
|
} }
|
|
73
|
-
const _c2 = function () { return { withoutArrow: true }; };
|
|
74
74
|
function DrDropdownComponent_dr_dropdown_item_4_Template(rf, ctx) { if (rf & 1) {
|
|
75
75
|
const _r20 = i0.ɵɵgetCurrentView();
|
|
76
76
|
i0.ɵɵelementStart(0, "dr-dropdown-item", 4);
|
|
@@ -83,7 +83,7 @@ function DrDropdownComponent_dr_dropdown_item_4_Template(rf, ctx) { if (rf & 1)
|
|
|
83
83
|
const act_r2 = ctx.$implicit;
|
|
84
84
|
const index_r3 = ctx.index;
|
|
85
85
|
const ctx_r1 = i0.ɵɵnextContext();
|
|
86
|
-
i0.ɵɵproperty("drTooltip", ctx_r1.tooltipToShow(act_r2))("drTooltipPosition", "
|
|
86
|
+
i0.ɵɵproperty("drTooltip", ctx_r1.tooltipToShow(act_r2))("drTooltipPosition", ctx_r1.getTooltipPosition(act_r2))("drTooltipOptions", ctx_r1.getTooltipOptions(act_r2))("drTooltipTheme", ctx_r1.getTooltipTheme(act_r2))("drTooltipMousleaveTimeout", ctx_r1.getTooltipMousleaveTimeout(act_r2))("drTooltipMouseEnterTimeout", ctx_r1.getTooltipMouseEnterTimeout(act_r2))("drTooltipClass", "dr-dropdown__tooltip")("drDropdown", ctx_r1.hasChildren(act_r2) && act_r2.children)("drDropdownClass", act_r2.childOptions == null ? null : act_r2.childOptions.class)("drDropdownInHover", true)("drDropdownPosition", act_r2.childOptions == null ? null : act_r2.childOptions.position)("disabled", ctx_r1.disabled(act_r2))("selected", ctx_r1.selected(act_r2))("divider", act_r2.separateLine);
|
|
87
87
|
i0.ɵɵattribute("data-analytics", ctx_r1.getDataAnalyticsTag(act_r2, index_r3));
|
|
88
88
|
i0.ɵɵadvance(1);
|
|
89
89
|
i0.ɵɵproperty("ngIf", !act_r2.templateRef);
|
|
@@ -92,9 +92,29 @@ function DrDropdownComponent_dr_dropdown_item_4_Template(rf, ctx) { if (rf & 1)
|
|
|
92
92
|
i0.ɵɵadvance(1);
|
|
93
93
|
i0.ɵɵproperty("ngIf", act_r2.templateRef);
|
|
94
94
|
} }
|
|
95
|
-
const
|
|
96
|
-
const
|
|
95
|
+
const _c2 = [[["dr-dropdown-item"]]];
|
|
96
|
+
const _c3 = ["dr-dropdown-item"];
|
|
97
97
|
export class DrDropdownComponent {
|
|
98
|
+
constructor() {
|
|
99
|
+
this.cdr = inject(ChangeDetectorRef);
|
|
100
|
+
this.popoverRef = inject(DrPopoverRef, { optional: true });
|
|
101
|
+
this.dropdownInstanceService = inject(DropdownInstanceService, { optional: true });
|
|
102
|
+
this.drDropdownInHoverChange$ = new Subject();
|
|
103
|
+
this.destroy$ = new Subject();
|
|
104
|
+
this._active = true;
|
|
105
|
+
this.list = [];
|
|
106
|
+
this.wasHovered = false;
|
|
107
|
+
this.asChild = false;
|
|
108
|
+
this.onAction = new EventEmitter();
|
|
109
|
+
if (!this.dropdownInstanceService)
|
|
110
|
+
return;
|
|
111
|
+
this.dropdownInstanceService.register(this);
|
|
112
|
+
inject(DestroyRef).onDestroy(() => {
|
|
113
|
+
this.dropdownInstanceService.unregister(this);
|
|
114
|
+
this.destroy$.next();
|
|
115
|
+
this.destroy$.next();
|
|
116
|
+
});
|
|
117
|
+
}
|
|
98
118
|
set options(data) {
|
|
99
119
|
if (data) {
|
|
100
120
|
this.drDropdownInHover = data.drDropdownInHover;
|
|
@@ -120,31 +140,17 @@ export class DrDropdownComponent {
|
|
|
120
140
|
}
|
|
121
141
|
}
|
|
122
142
|
}
|
|
123
|
-
constructor() {
|
|
124
|
-
this.cdr = inject(ChangeDetectorRef);
|
|
125
|
-
this.popoverRef = inject(DrPopoverRef, { optional: true });
|
|
126
|
-
this.dropdownInstanceService = inject(DropdownInstanceService, { optional: true });
|
|
127
|
-
this.destroy$ = new Subject();
|
|
128
|
-
this._active = true;
|
|
129
|
-
this.drDropdownInHoverChange$ = new Subject();
|
|
130
|
-
this.list = [];
|
|
131
|
-
this.wasHovered = false;
|
|
132
|
-
this.asChild = false;
|
|
133
|
-
this.onAction = new EventEmitter();
|
|
134
|
-
if (!this.dropdownInstanceService)
|
|
135
|
-
return;
|
|
136
|
-
this.dropdownInstanceService.register(this);
|
|
137
|
-
inject(DestroyRef).onDestroy(() => {
|
|
138
|
-
this.dropdownInstanceService.unregister(this);
|
|
139
|
-
this.destroy$.next();
|
|
140
|
-
this.destroy$.next();
|
|
141
|
-
});
|
|
142
|
-
}
|
|
143
143
|
ngOnChanges(changes) {
|
|
144
144
|
if (!changes?.drDropdownInHover?.isFirstChange()) {
|
|
145
145
|
this.drDropdownInHoverChange$.next();
|
|
146
146
|
}
|
|
147
147
|
}
|
|
148
|
+
onMouseleave() {
|
|
149
|
+
this._active = false;
|
|
150
|
+
}
|
|
151
|
+
active() {
|
|
152
|
+
return this._active;
|
|
153
|
+
}
|
|
148
154
|
disabled(act) {
|
|
149
155
|
if (!act.disabled) {
|
|
150
156
|
return false;
|
|
@@ -168,9 +174,45 @@ export class DrDropdownComponent {
|
|
|
168
174
|
}
|
|
169
175
|
}
|
|
170
176
|
tooltipToShow(act) {
|
|
171
|
-
if (act.toolTipIfDisabled && !this.disabled(act))
|
|
177
|
+
if (act.toolTipIfDisabled && !this.disabled(act)) {
|
|
172
178
|
return '';
|
|
173
|
-
|
|
179
|
+
}
|
|
180
|
+
if (act.customTooltip) {
|
|
181
|
+
return act.customTooltip(act.data);
|
|
182
|
+
}
|
|
183
|
+
if (act.toolTip) {
|
|
184
|
+
return act.toolTip;
|
|
185
|
+
}
|
|
186
|
+
return '';
|
|
187
|
+
}
|
|
188
|
+
getTooltipOptions(act) {
|
|
189
|
+
const customOptions = this.getCustomTooltipComponent(act)?.options;
|
|
190
|
+
if (!customOptions)
|
|
191
|
+
return { withoutArrow: true };
|
|
192
|
+
return {
|
|
193
|
+
withoutArrow: customOptions.withoutArrow,
|
|
194
|
+
withoutContainerStyles: customOptions.withoutContainerStyles,
|
|
195
|
+
};
|
|
196
|
+
}
|
|
197
|
+
getTooltipPosition(act) {
|
|
198
|
+
return this.getCustomTooltipComponent(act)?.options?.position ?? 'left';
|
|
199
|
+
}
|
|
200
|
+
getTooltipTheme(act) {
|
|
201
|
+
return this.getCustomTooltipComponent(act)?.options?.theme ?? TooltipTheme.LIGHT;
|
|
202
|
+
}
|
|
203
|
+
getTooltipMousleaveTimeout(act) {
|
|
204
|
+
return this.getCustomTooltipComponent(act)?.options?.drTooltipMousleaveTimeout ?? 0;
|
|
205
|
+
}
|
|
206
|
+
getTooltipMouseEnterTimeout(act) {
|
|
207
|
+
return this.getCustomTooltipComponent(act)?.options?.drTooltipMouseEnterTimeout ?? 0;
|
|
208
|
+
}
|
|
209
|
+
getCustomTooltipComponent(act) {
|
|
210
|
+
if (act.customTooltip) {
|
|
211
|
+
const result = act.customTooltip(act.data);
|
|
212
|
+
if (typeof result !== 'string')
|
|
213
|
+
return result;
|
|
214
|
+
}
|
|
215
|
+
return null;
|
|
174
216
|
}
|
|
175
217
|
action(act) {
|
|
176
218
|
if (!this.disabled(act)) {
|
|
@@ -194,12 +236,6 @@ export class DrDropdownComponent {
|
|
|
194
236
|
this.wasHovered = true;
|
|
195
237
|
this._active = true;
|
|
196
238
|
}
|
|
197
|
-
onMouseleave() {
|
|
198
|
-
this._active = false;
|
|
199
|
-
}
|
|
200
|
-
active() {
|
|
201
|
-
return this._active;
|
|
202
|
-
}
|
|
203
239
|
getDataAnalyticsTag(act, index) {
|
|
204
240
|
return act.dataAnalytics
|
|
205
241
|
? act.dataAnalytics
|
|
@@ -213,12 +249,12 @@ export class DrDropdownComponent {
|
|
|
213
249
|
} if (rf & 2) {
|
|
214
250
|
let _t;
|
|
215
251
|
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.menuContainer = _t.first);
|
|
216
|
-
} }, inputs: { options: "options" }, outputs: { onAction: "action" }, features: [i0.ɵɵNgOnChangesFeature], ngContentSelectors:
|
|
217
|
-
i0.ɵɵprojectionDef(
|
|
252
|
+
} }, inputs: { options: "options" }, outputs: { onAction: "action" }, features: [i0.ɵɵNgOnChangesFeature], ngContentSelectors: _c3, decls: 6, vars: 5, consts: [[1, "dr-dropdown"], ["menuContainer", ""], ["tabindex", "-1", "role", "listbox", 1, "dr-dropdown__container", 3, "mouseenter", "mouseleave"], ["drDropdownChild", "", "tabindex", "0", 3, "drTooltip", "drTooltipPosition", "drTooltipOptions", "drTooltipTheme", "drTooltipMousleaveTimeout", "drTooltipMouseEnterTimeout", "drTooltipClass", "drDropdown", "drDropdownClass", "drDropdownInHover", "drDropdownPosition", "disabled", "selected", "divider", "mousedown", 4, "ngFor", "ngForOf"], ["drDropdownChild", "", "tabindex", "0", 3, "drTooltip", "drTooltipPosition", "drTooltipOptions", "drTooltipTheme", "drTooltipMousleaveTimeout", "drTooltipMouseEnterTimeout", "drTooltipClass", "drDropdown", "drDropdownClass", "drDropdownInHover", "drDropdownPosition", "disabled", "selected", "divider", "mousedown"], ["dropdownItemContent", "", 4, "ngIf"], ["dropdownItemActions", "", 4, "ngIf"], ["dropdownItemContent", "", 3, "ngTemplateOutlet", "ngTemplateOutletContext", 4, "ngIf"], ["dropdownItemContent", ""], ["class", "dr-dropdown__icon", 3, "class", 4, "ngIf"], [1, "dr-dropdown__text"], [1, "dr-dropdown__icon"], ["dropdownItemActions", ""], [3, "class", "showOnHover", "mousedown", 4, "ngFor", "ngForOf"], ["class", "dr-icon-arrow-right", 4, "ngIf"], [3, "mousedown"], [1, "dr-icon-arrow-right"], ["dropdownItemContent", "", 3, "ngTemplateOutlet", "ngTemplateOutletContext"]], template: function DrDropdownComponent_Template(rf, ctx) { if (rf & 1) {
|
|
253
|
+
i0.ɵɵprojectionDef(_c2);
|
|
218
254
|
i0.ɵɵelementStart(0, "div", 0, 1)(2, "div", 2);
|
|
219
255
|
i0.ɵɵlistener("mouseenter", function DrDropdownComponent_Template_div_mouseenter_2_listener() { return ctx.onMouseenter(); })("mouseleave", function DrDropdownComponent_Template_div_mouseleave_2_listener() { return ctx.onMouseleave(); });
|
|
220
256
|
i0.ɵɵprojection(3);
|
|
221
|
-
i0.ɵɵtemplate(4, DrDropdownComponent_dr_dropdown_item_4_Template, 4,
|
|
257
|
+
i0.ɵɵtemplate(4, DrDropdownComponent_dr_dropdown_item_4_Template, 4, 18, "dr-dropdown-item", 3);
|
|
222
258
|
i0.ɵɵpipe(5, "drDropdownItemShowPipe");
|
|
223
259
|
i0.ɵɵelementEnd()();
|
|
224
260
|
} if (rf & 2) {
|
|
@@ -235,7 +271,7 @@ __decorate([
|
|
|
235
271
|
], DrDropdownComponent.prototype, "onMouseleave", null);
|
|
236
272
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DrDropdownComponent, [{
|
|
237
273
|
type: Component,
|
|
238
|
-
args: [{ selector: 'dr-dropdown', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div #menuContainer [class]=\"containerClass\" class=\"dr-dropdown\">\n <div class=\"dr-dropdown__container\" (mouseenter)=\"onMouseenter()\" (mouseleave)=\"onMouseleave()\" tabindex=\"-1\" role=\"listbox\">\n <ng-content select=\"dr-dropdown-item\"></ng-content>\n\n <dr-dropdown-item\n *ngFor=\"let act of list | drDropdownItemShowPipe; let index = index\"\n (mousedown)=\"action(act)\"\n [drTooltip]=\"tooltipToShow(act)\"\n [drTooltipPosition]=\"
|
|
274
|
+
args: [{ selector: 'dr-dropdown', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div #menuContainer [class]=\"containerClass\" class=\"dr-dropdown\">\n <div class=\"dr-dropdown__container\" (mouseenter)=\"onMouseenter()\" (mouseleave)=\"onMouseleave()\" tabindex=\"-1\" role=\"listbox\">\n <ng-content select=\"dr-dropdown-item\"></ng-content>\n\n <dr-dropdown-item\n *ngFor=\"let act of list | drDropdownItemShowPipe; let index = index\"\n (mousedown)=\"action(act)\"\n [drTooltip]=\"tooltipToShow(act)\"\n [drTooltipPosition]=\"getTooltipPosition(act)\"\n [drTooltipOptions]=\"getTooltipOptions(act)\"\n [drTooltipTheme]=\"getTooltipTheme(act)\"\n [drTooltipMousleaveTimeout]=\"getTooltipMousleaveTimeout(act)\"\n [drTooltipMouseEnterTimeout]=\"getTooltipMouseEnterTimeout(act)\"\n [drTooltipClass]=\"'dr-dropdown__tooltip'\"\n [drDropdown]=\"hasChildren(act) && act.children\"\n [drDropdownClass]=\"act.childOptions?.class\"\n [drDropdownInHover]=\"true\"\n [drDropdownPosition]=\"act.childOptions?.position\"\n drDropdownChild\n [disabled]=\"disabled(act)\"\n [selected]=\"selected(act)\"\n [divider]=\"act.separateLine\"\n [attr.data-analytics]=\"getDataAnalyticsTag(act, index)\"\n tabindex=\"0\">\n <ng-container dropdownItemContent *ngIf=\"!act.templateRef\">\n <i *ngIf=\"act.icon\" [class]=\"act.icon\" class=\"dr-dropdown__icon\"></i>\n <span class=\"dr-dropdown__text\">{{ act.title }}</span>\n </ng-container>\n\n <ng-container dropdownItemActions *ngIf=\"!act.templateRef\">\n <i\n *ngFor=\"let actionIcon of act.actionIcons\"\n [attr.data-analytics]=\"getDataAnalyticsTag(actionIcon, index)\"\n [class]=\"actionIcon.icon\"\n [class.showOnHover]=\"actionIcon.showOnHover\"\n (mousedown)=\"onActionIconClick($event, actionIcon, act.data)\"></i>\n <i *ngIf=\"hasChildren(act)\" class=\"dr-icon-arrow-right\"></i>\n </ng-container>\n\n <ng-container\n *ngIf=\"act.templateRef\"\n dropdownItemContent\n [ngTemplateOutlet]=\"act.templateRef\"\n [ngTemplateOutletContext]=\"{ $implicit: act }\">\n </ng-container>\n </dr-dropdown-item>\n </div>\n</div>\n", styles: ["::ng-deep .dr-dropdown__item .dr-dropdown{visibility:hidden;transition-delay:.2s}::ng-deep .dr-dropdown__item:hover>*>.dr-dropdown{visibility:visible;transition-delay:0s}::ng-deep .dr-dropdown__tooltip>.default-content{max-width:300px;white-space:normal!important}.dr-dropdown{width:auto}.dr-dropdown__text{overflow:hidden;text-overflow:ellipsis;flex:1}.dr-dropdown__container{display:flex;flex-direction:column;background:#fff;padding:8px 0;overflow-y:auto;max-height:60vh;max-width:300px}.dr-dropdown__icon{margin-right:8px}.dr-dropdown i:not(:first-child):hover{color:#4646ce}.dr-dropdown dr-dropdown-item:hover .showOnHover{visibility:visible}.dr-dropdown .showOnHover{visibility:hidden}\n"] }]
|
|
239
275
|
}], function () { return []; }, { menuContainer: [{
|
|
240
276
|
type: ViewChild,
|
|
241
277
|
args: ['menuContainer', { static: true }]
|
|
@@ -245,4 +281,4 @@ __decorate([
|
|
|
245
281
|
type: Output,
|
|
246
282
|
args: ['action']
|
|
247
283
|
}], onMouseleave: [] }); })();
|
|
248
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-dropdown.component.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/dr-dropdown/dr-dropdown.component.ts","../../../../../projects/datarailsshared/src/lib/dr-dropdown/dr-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    DestroyRef,\n    ElementRef,\n    EventEmitter,\n    inject,\n    Input,\n    Output,\n    SimpleChanges,\n    ViewChild,\n} from '@angular/core';\nimport { IDropdown, IDropdownAction, IDropdownActionIcon, IDropdownItem } from '../models/dropdown';\nimport { DrPopoverRef } from '../models/popover';\nimport { first, merge, Subject, takeUntil } from 'rxjs';\nimport { DropdownInstanceRef, DropdownInstanceService } from './dr-dropdown.service';\nimport { Debounce } from '../utils/decorators';\n\n@Component({\n    selector: 'dr-dropdown',\n    templateUrl: './dr-dropdown.component.html',\n    styleUrls: ['./dr-dropdown.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DrDropdownComponent implements DropdownInstanceRef {\n    private readonly cdr = inject(ChangeDetectorRef);\n    private readonly popoverRef = inject(DrPopoverRef, { optional: true });\n    private readonly dropdownInstanceService = inject(DropdownInstanceService, { optional: true });\n\n    private readonly destroy$ = new Subject<void>();\n\n    private _active = true;\n\n    @ViewChild('menuContainer', { static: true })\n    menuContainer: ElementRef<HTMLDivElement>;\n\n    drDropdownInHover: boolean;\n    private readonly drDropdownInHoverChange$ = new Subject<void>();\n    list: IDropdownItem<unknown>[] = [];\n    containerClass: string;\n    wasHovered = false;\n    asChild = false;\n    dataAnalytics: string;\n\n    @Input()\n    set options(data: IDropdown<IDropdownItem<unknown>>) {\n        if (data) {\n            this.drDropdownInHover = data.drDropdownInHover;\n            this.containerClass = data.class;\n            this.dataAnalytics = data.dataAnalytics;\n            this.list = data.list || [];\n            this.list.forEach((item) => {\n                if (item.children?.length) {\n                    item.childOptions = {\n                        class: item?.childOptions?.class || '',\n                        position: item?.childOptions?.position || 'left-top',\n                    };\n                }\n            });\n            this.cdr.markForCheck();\n\n            if (this.drDropdownInHover) {\n                this.dropdownInstanceService\n                    .inactive(this)\n                    .pipe(first(), takeUntil(merge(this.destroy$, this.drDropdownInHoverChange$)))\n                    .subscribe(() => {\n                        this.popoverRef.close();\n                    });\n            }\n        }\n    }\n\n    @Output('action')\n    onAction = new EventEmitter<IDropdownAction<unknown>>();\n\n    constructor() {\n        if (!this.dropdownInstanceService) return;\n\n        this.dropdownInstanceService.register(this);\n        inject(DestroyRef).onDestroy(() => {\n            this.dropdownInstanceService.unregister(this);\n            this.destroy$.next();\n            this.destroy$.next();\n        });\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (!changes?.drDropdownInHover?.isFirstChange()) {\n            this.drDropdownInHoverChange$.next();\n        }\n    }\n\n    disabled(act: IDropdownItem<unknown>): boolean {\n        if (!act.disabled) {\n            return false;\n        }\n        if (typeof act.disabled === 'boolean') {\n            return act.disabled;\n        } else {\n            return act.disabled(act.data);\n        }\n    }\n\n    selected(act: IDropdownItem<unknown>): boolean {\n        if (!act.selected) {\n            return false;\n        }\n        if (typeof act.selected === 'boolean') {\n            return act.selected;\n        } else {\n            return act.selected(act.data);\n        }\n    }\n\n    tooltipToShow(act: IDropdownItem<unknown>): string {\n        if (act.toolTipIfDisabled && !this.disabled(act)) return '';\n        return act.customTooltip ? act.customTooltip(act.data) : act.toolTip;\n    }\n\n    action(act: IDropdownItem<unknown>) {\n        if (!this.disabled(act)) {\n            if (act.action) {\n                act.action(act.data);\n            } else {\n                const event = { event: act.event || act.title || 'default', data: act.data };\n                this.onAction.emit(event);\n            }\n        }\n    }\n\n    onActionIconClick($event: MouseEvent, actionIcon: IDropdownActionIcon<unknown>, data: unknown) {\n        $event.stopPropagation();\n        actionIcon.action(data);\n    }\n\n    hasChildren(item: IDropdownItem<unknown>): boolean {\n        return !!item.children?.length;\n    }\n\n    onMouseenter(): void {\n        this.wasHovered = true;\n        this._active = true;\n    }\n\n    @Debounce(200)\n    onMouseleave(): void {\n        this._active = false;\n    }\n\n    active(): boolean {\n        return this._active;\n    }\n\n    getDataAnalyticsTag(act: IDropdownItem<unknown>, index: number): string {\n        return act.dataAnalytics\n            ? act.dataAnalytics\n            : this.dataAnalytics\n              ? this.dataAnalytics + '_' + (act.title?.replace(/ /g, '-') || index)\n              : null;\n    }\n}\n","<div #menuContainer [class]=\"containerClass\" class=\"dr-dropdown\">\n    <div class=\"dr-dropdown__container\" (mouseenter)=\"onMouseenter()\" (mouseleave)=\"onMouseleave()\" tabindex=\"-1\" role=\"listbox\">\n        <ng-content select=\"dr-dropdown-item\"></ng-content>\n\n        <dr-dropdown-item\n            *ngFor=\"let act of list | drDropdownItemShowPipe; let index = index\"\n            (mousedown)=\"action(act)\"\n            [drTooltip]=\"tooltipToShow(act)\"\n            [drTooltipPosition]=\"'left'\"\n            [drTooltipOptions]=\"{ withoutArrow: true }\"\n            [drTooltipClass]=\"'dr-dropdown__tooltip'\"\n            [drDropdown]=\"hasChildren(act) && act.children\"\n            [drDropdownClass]=\"act.childOptions?.class\"\n            [drDropdownInHover]=\"true\"\n            [drDropdownPosition]=\"act.childOptions?.position\"\n            drDropdownChild\n            [disabled]=\"disabled(act)\"\n            [selected]=\"selected(act)\"\n            [divider]=\"act.separateLine\"\n            [attr.data-analytics]=\"getDataAnalyticsTag(act, index)\"\n            tabindex=\"0\">\n            <ng-container dropdownItemContent *ngIf=\"!act.templateRef\">\n                <i *ngIf=\"act.icon\" [class]=\"act.icon\" class=\"dr-dropdown__icon\"></i>\n                <span class=\"dr-dropdown__text\">{{ act.title }}</span>\n            </ng-container>\n\n            <ng-container dropdownItemActions *ngIf=\"!act.templateRef\">\n                <i\n                    *ngFor=\"let actionIcon of act.actionIcons\"\n                    [attr.data-analytics]=\"getDataAnalyticsTag(actionIcon, index)\"\n                    [class]=\"actionIcon.icon\"\n                    [class.showOnHover]=\"actionIcon.showOnHover\"\n                    (mousedown)=\"onActionIconClick($event, actionIcon, act.data)\"></i>\n                <i *ngIf=\"hasChildren(act)\" class=\"dr-icon-arrow-right\"></i>\n            </ng-container>\n\n            <ng-container\n                *ngIf=\"act.templateRef\"\n                dropdownItemContent\n                [ngTemplateOutlet]=\"act.templateRef\"\n                [ngTemplateOutletContext]=\"{ $implicit: act }\">\n            </ng-container>\n        </dr-dropdown-item>\n    </div>\n</div>\n"]}
|
|
284
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-dropdown.component.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/dr-dropdown/dr-dropdown.component.ts","../../../../../projects/datarailsshared/src/lib/dr-dropdown/dr-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    DestroyRef,\n    ElementRef,\n    EventEmitter,\n    inject,\n    Input,\n    OnChanges,\n    Output,\n    SimpleChanges,\n    ViewChild,\n} from '@angular/core';\nimport { ICustomTooltipComponent, IDropdown, IDropdownAction, IDropdownActionIcon, IDropdownItem } from '../models/dropdown';\nimport { DrPopoverRef } from '../models/popover';\nimport { first, merge, Subject, takeUntil } from 'rxjs';\nimport { DropdownInstanceRef, DropdownInstanceService } from './dr-dropdown.service';\nimport { Debounce } from '../utils/decorators';\nimport { Position } from '../models/position';\nimport { TooltipOptions } from '../dr-tooltip/dr-tooltip.component';\nimport { TooltipTheme } from '../dr-tooltip/enums/tooltip-theme.enum';\n\n@Component({\n    selector: 'dr-dropdown',\n    templateUrl: './dr-dropdown.component.html',\n    styleUrls: ['./dr-dropdown.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DrDropdownComponent implements DropdownInstanceRef, OnChanges {\n    constructor() {\n        if (!this.dropdownInstanceService) return;\n\n        this.dropdownInstanceService.register(this);\n        inject(DestroyRef).onDestroy(() => {\n            this.dropdownInstanceService.unregister(this);\n            this.destroy$.next();\n            this.destroy$.next();\n        });\n    }\n\n    private readonly cdr = inject(ChangeDetectorRef);\n    private readonly popoverRef = inject(DrPopoverRef, { optional: true });\n    private readonly dropdownInstanceService = inject(DropdownInstanceService, { optional: true });\n    private readonly drDropdownInHoverChange$ = new Subject<void>();\n    private readonly destroy$ = new Subject<void>();\n    private _active = true;\n\n    public drDropdownInHover: boolean;\n    public list: IDropdownItem<unknown>[] = [];\n    public containerClass: string;\n    public wasHovered = false;\n    public asChild = false;\n    public dataAnalytics: string;\n\n    @ViewChild('menuContainer', { static: true })\n    menuContainer: ElementRef<HTMLDivElement>;\n\n    @Input()\n    set options(data: IDropdown<IDropdownItem<unknown>>) {\n        if (data) {\n            this.drDropdownInHover = data.drDropdownInHover;\n            this.containerClass = data.class;\n            this.dataAnalytics = data.dataAnalytics;\n            this.list = data.list || [];\n            this.list.forEach((item) => {\n                if (item.children?.length) {\n                    item.childOptions = {\n                        class: item?.childOptions?.class || '',\n                        position: item?.childOptions?.position || 'left-top',\n                    };\n                }\n            });\n            this.cdr.markForCheck();\n\n            if (this.drDropdownInHover) {\n                this.dropdownInstanceService\n                    .inactive(this)\n                    .pipe(first(), takeUntil(merge(this.destroy$, this.drDropdownInHoverChange$)))\n                    .subscribe(() => {\n                        this.popoverRef.close();\n                    });\n            }\n        }\n    }\n\n    @Output('action')\n    onAction = new EventEmitter<IDropdownAction<unknown>>();\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (!changes?.drDropdownInHover?.isFirstChange()) {\n            this.drDropdownInHoverChange$.next();\n        }\n    }\n\n    @Debounce(200)\n    public onMouseleave(): void {\n        this._active = false;\n    }\n\n    public active(): boolean {\n        return this._active;\n    }\n\n    public disabled(act: IDropdownItem<unknown>): boolean {\n        if (!act.disabled) {\n            return false;\n        }\n        if (typeof act.disabled === 'boolean') {\n            return act.disabled;\n        } else {\n            return act.disabled(act.data);\n        }\n    }\n\n    public selected(act: IDropdownItem<unknown>): boolean {\n        if (!act.selected) {\n            return false;\n        }\n        if (typeof act.selected === 'boolean') {\n            return act.selected;\n        } else {\n            return act.selected(act.data);\n        }\n    }\n\n    public tooltipToShow(act: IDropdownItem<unknown>): string | ICustomTooltipComponent {\n        if (act.toolTipIfDisabled && !this.disabled(act)) {\n            return '';\n        }\n\n        if (act.customTooltip) {\n            return act.customTooltip(act.data);\n        }\n\n        if (act.toolTip) {\n            return act.toolTip;\n        }\n\n        return '';\n    }\n\n    public getTooltipOptions(act: IDropdownItem<unknown>): TooltipOptions {\n        const customOptions = this.getCustomTooltipComponent(act)?.options;\n        if (!customOptions) return <TooltipOptions>{ withoutArrow: true };\n\n        return <TooltipOptions>{\n            withoutArrow: customOptions.withoutArrow,\n            withoutContainerStyles: customOptions.withoutContainerStyles,\n        };\n    }\n\n    public getTooltipPosition(act: IDropdownItem<unknown>): Position {\n        return this.getCustomTooltipComponent(act)?.options?.position ?? 'left';\n    }\n\n    public getTooltipTheme(act: IDropdownItem<unknown>): TooltipTheme {\n        return this.getCustomTooltipComponent(act)?.options?.theme ?? TooltipTheme.LIGHT;\n    }\n\n    public getTooltipMousleaveTimeout(act: IDropdownItem<unknown>): number {\n        return this.getCustomTooltipComponent(act)?.options?.drTooltipMousleaveTimeout ?? 0;\n    }\n\n    public getTooltipMouseEnterTimeout(act: IDropdownItem<unknown>): number {\n        return this.getCustomTooltipComponent(act)?.options?.drTooltipMouseEnterTimeout ?? 0;\n    }\n\n    private getCustomTooltipComponent(act: IDropdownItem<unknown>): ICustomTooltipComponent | null {\n        if (act.customTooltip) {\n            const result = act.customTooltip(act.data);\n            if (typeof result !== 'string') return result;\n        }\n        return null;\n    }\n\n    public action(act: IDropdownItem<unknown>) {\n        if (!this.disabled(act)) {\n            if (act.action) {\n                act.action(act.data);\n            } else {\n                const event = { event: act.event || act.title || 'default', data: act.data };\n                this.onAction.emit(event);\n            }\n        }\n    }\n\n    public onActionIconClick($event: MouseEvent, actionIcon: IDropdownActionIcon<unknown>, data: unknown): void {\n        $event.stopPropagation();\n        actionIcon.action(data);\n    }\n\n    public hasChildren(item: IDropdownItem<unknown>): boolean {\n        return !!item.children?.length;\n    }\n\n    public onMouseenter(): void {\n        this.wasHovered = true;\n        this._active = true;\n    }\n\n    public getDataAnalyticsTag(act: IDropdownItem<unknown>, index: number): string {\n        return act.dataAnalytics\n            ? act.dataAnalytics\n            : this.dataAnalytics\n              ? this.dataAnalytics + '_' + (act.title?.replace(/ /g, '-') || index)\n              : null;\n    }\n}\n","<div #menuContainer [class]=\"containerClass\" class=\"dr-dropdown\">\n    <div class=\"dr-dropdown__container\" (mouseenter)=\"onMouseenter()\" (mouseleave)=\"onMouseleave()\" tabindex=\"-1\" role=\"listbox\">\n        <ng-content select=\"dr-dropdown-item\"></ng-content>\n\n        <dr-dropdown-item\n            *ngFor=\"let act of list | drDropdownItemShowPipe; let index = index\"\n            (mousedown)=\"action(act)\"\n            [drTooltip]=\"tooltipToShow(act)\"\n            [drTooltipPosition]=\"getTooltipPosition(act)\"\n            [drTooltipOptions]=\"getTooltipOptions(act)\"\n            [drTooltipTheme]=\"getTooltipTheme(act)\"\n            [drTooltipMousleaveTimeout]=\"getTooltipMousleaveTimeout(act)\"\n            [drTooltipMouseEnterTimeout]=\"getTooltipMouseEnterTimeout(act)\"\n            [drTooltipClass]=\"'dr-dropdown__tooltip'\"\n            [drDropdown]=\"hasChildren(act) && act.children\"\n            [drDropdownClass]=\"act.childOptions?.class\"\n            [drDropdownInHover]=\"true\"\n            [drDropdownPosition]=\"act.childOptions?.position\"\n            drDropdownChild\n            [disabled]=\"disabled(act)\"\n            [selected]=\"selected(act)\"\n            [divider]=\"act.separateLine\"\n            [attr.data-analytics]=\"getDataAnalyticsTag(act, index)\"\n            tabindex=\"0\">\n            <ng-container dropdownItemContent *ngIf=\"!act.templateRef\">\n                <i *ngIf=\"act.icon\" [class]=\"act.icon\" class=\"dr-dropdown__icon\"></i>\n                <span class=\"dr-dropdown__text\">{{ act.title }}</span>\n            </ng-container>\n\n            <ng-container dropdownItemActions *ngIf=\"!act.templateRef\">\n                <i\n                    *ngFor=\"let actionIcon of act.actionIcons\"\n                    [attr.data-analytics]=\"getDataAnalyticsTag(actionIcon, index)\"\n                    [class]=\"actionIcon.icon\"\n                    [class.showOnHover]=\"actionIcon.showOnHover\"\n                    (mousedown)=\"onActionIconClick($event, actionIcon, act.data)\"></i>\n                <i *ngIf=\"hasChildren(act)\" class=\"dr-icon-arrow-right\"></i>\n            </ng-container>\n\n            <ng-container\n                *ngIf=\"act.templateRef\"\n                dropdownItemContent\n                [ngTemplateOutlet]=\"act.templateRef\"\n                [ngTemplateOutletContext]=\"{ $implicit: act }\">\n            </ng-container>\n        </dr-dropdown-item>\n    </div>\n</div>\n"]}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { ChangeDetectionStrategy, Component, Input, ViewChild, ViewContainerRef, Injector, EnvironmentInjector, inject, } from '@angular/core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
const _c0 = ["container"];
|
|
5
|
+
export class TooltipCustomComponent {
|
|
6
|
+
constructor() {
|
|
7
|
+
this.injector = inject(Injector);
|
|
8
|
+
this.environmentInjector = inject(EnvironmentInjector);
|
|
9
|
+
}
|
|
10
|
+
ngOnChanges(changes) {
|
|
11
|
+
if (changes.content) {
|
|
12
|
+
this.renderComponent();
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
renderComponent() {
|
|
16
|
+
this.cmpRef?.destroy();
|
|
17
|
+
this.container.clear();
|
|
18
|
+
const customInjector = Injector.create({
|
|
19
|
+
providers: this.content.providers ?? [],
|
|
20
|
+
parent: this.injector,
|
|
21
|
+
});
|
|
22
|
+
this.cmpRef = this.container.createComponent(this.content.component, {
|
|
23
|
+
injector: customInjector,
|
|
24
|
+
environmentInjector: this.environmentInjector,
|
|
25
|
+
});
|
|
26
|
+
if (this.content.inputs) {
|
|
27
|
+
Object.entries(this.content.inputs).forEach(([key, value]) => {
|
|
28
|
+
this.cmpRef.setInput(key, value);
|
|
29
|
+
});
|
|
30
|
+
this.cmpRef.changeDetectorRef.detectChanges();
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
/** @nocollapse */ static { this.ɵfac = function TooltipCustomComponent_Factory(t) { return new (t || TooltipCustomComponent)(); }; }
|
|
34
|
+
/** @nocollapse */ static { this.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: TooltipCustomComponent, selectors: [["dr-tooltip-custom"]], viewQuery: function TooltipCustomComponent_Query(rf, ctx) { if (rf & 1) {
|
|
35
|
+
i0.ɵɵviewQuery(_c0, 7, ViewContainerRef);
|
|
36
|
+
} if (rf & 2) {
|
|
37
|
+
let _t;
|
|
38
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.container = _t.first);
|
|
39
|
+
} }, inputs: { content: "content" }, standalone: true, features: [i0.ɵɵNgOnChangesFeature, i0.ɵɵStandaloneFeature], decls: 2, vars: 0, consts: [["container", ""]], template: function TooltipCustomComponent_Template(rf, ctx) { if (rf & 1) {
|
|
40
|
+
i0.ɵɵelementContainer(0, null, 0);
|
|
41
|
+
} }, dependencies: [CommonModule], encapsulation: 2, changeDetection: 0 }); }
|
|
42
|
+
}
|
|
43
|
+
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(TooltipCustomComponent, [{
|
|
44
|
+
type: Component,
|
|
45
|
+
args: [{
|
|
46
|
+
selector: 'dr-tooltip-custom',
|
|
47
|
+
template: `<ng-container #container></ng-container>`,
|
|
48
|
+
standalone: true,
|
|
49
|
+
imports: [CommonModule],
|
|
50
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
51
|
+
}]
|
|
52
|
+
}], null, { container: [{
|
|
53
|
+
type: ViewChild,
|
|
54
|
+
args: ['container', { read: ViewContainerRef, static: true }]
|
|
55
|
+
}], content: [{
|
|
56
|
+
type: Input
|
|
57
|
+
}] }); })();
|
|
58
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbHRpcC1jdXN0b20uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZGF0YXJhaWxzc2hhcmVkL3NyYy9saWIvZHItdG9vbHRpcC9jb21wb25lbnRzL3Rvb2x0aXAtY3VzdG9tL3Rvb2x0aXAtY3VzdG9tLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUNILHVCQUF1QixFQUN2QixTQUFTLEVBQ1QsS0FBSyxFQUNMLFNBQVMsRUFDVCxnQkFBZ0IsRUFFaEIsUUFBUSxFQUNSLG1CQUFtQixFQUNuQixNQUFNLEdBR1QsTUFBTSxlQUFlLENBQUM7OztBQVV2QixNQUFNLE9BQU8sc0JBQXNCO0lBUG5DO1FBUXFCLGFBQVEsR0FBYSxNQUFNLENBQUMsUUFBUSxDQUFDLENBQUM7UUFDdEMsd0JBQW1CLEdBQXdCLE1BQU0sQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDO0tBb0MzRjtJQTVCRyxXQUFXLENBQUMsT0FBc0I7UUFDOUIsSUFBSSxPQUFPLENBQUMsT0FBTyxFQUFFO1lBQ2pCLElBQUksQ0FBQyxlQUFlLEVBQUUsQ0FBQztTQUMxQjtJQUNMLENBQUM7SUFFTyxlQUFlO1FBQ25CLElBQUksQ0FBQyxNQUFNLEVBQUUsT0FBTyxFQUFFLENBQUM7UUFDdkIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUV2QixNQUFNLGNBQWMsR0FBRyxRQUFRLENBQUMsTUFBTSxDQUFDO1lBQ25DLFNBQVMsRUFBRSxJQUFJLENBQUMsT0FBTyxDQUFDLFNBQVMsSUFBSSxFQUFFO1lBQ3ZDLE1BQU0sRUFBRSxJQUFJLENBQUMsUUFBUTtTQUN4QixDQUFDLENBQUM7UUFFSCxJQUFJLENBQUMsTUFBTSxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsU0FBUyxFQUFFO1lBQ2pFLFFBQVEsRUFBRSxjQUFjO1lBQ3hCLG1CQUFtQixFQUFFLElBQUksQ0FBQyxtQkFBbUI7U0FDaEQsQ0FBQyxDQUFDO1FBRUgsSUFBSSxJQUFJLENBQUMsT0FBTyxDQUFDLE1BQU0sRUFBRTtZQUNyQixNQUFNLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxHQUFHLEVBQUUsS0FBSyxDQUFDLEVBQUUsRUFBRTtnQkFDekQsSUFBSSxDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUMsR0FBYSxFQUFFLEtBQUssQ0FBQyxDQUFDO1lBQy9DLENBQUMsQ0FBQyxDQUFDO1lBRUgsSUFBSSxDQUFDLE1BQU0sQ0FBQyxpQkFBaUIsQ0FBQyxhQUFhLEVBQUUsQ0FBQztTQUNqRDtJQUNMLENBQUM7MEdBckNRLHNCQUFzQjttR0FBdEIsc0JBQXNCO21DQUtDLGdCQUFnQjs7Ozs7WUFWckMsaUNBQXdDOzRCQUV6QyxZQUFZOzt1RkFHYixzQkFBc0I7Y0FQbEMsU0FBUztlQUFDO2dCQUNQLFFBQVEsRUFBRSxtQkFBbUI7Z0JBQzdCLFFBQVEsRUFBRSwwQ0FBMEM7Z0JBQ3BELFVBQVUsRUFBRSxJQUFJO2dCQUNoQixPQUFPLEVBQUUsQ0FBQyxZQUFZLENBQUM7Z0JBQ3ZCLGVBQWUsRUFBRSx1QkFBdUIsQ0FBQyxNQUFNO2FBQ2xEO2dCQU9XLFNBQVM7a0JBRGhCLFNBQVM7bUJBQUMsV0FBVyxFQUFFLEVBQUUsSUFBSSxFQUFFLGdCQUFnQixFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUU7WUFHdkQsT0FBTztrQkFBZixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7XG4gICAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gICAgQ29tcG9uZW50LFxuICAgIElucHV0LFxuICAgIFZpZXdDaGlsZCxcbiAgICBWaWV3Q29udGFpbmVyUmVmLFxuICAgIENvbXBvbmVudFJlZixcbiAgICBJbmplY3RvcixcbiAgICBFbnZpcm9ubWVudEluamVjdG9yLFxuICAgIGluamVjdCxcbiAgICBPbkNoYW5nZXMsXG4gICAgU2ltcGxlQ2hhbmdlcyxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBJQ3VzdG9tVG9vbHRpcENvbXBvbmVudCB9IGZyb20gJy4uLy4uLy4uL21vZGVscy9kcm9wZG93bic7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnZHItdG9vbHRpcC1jdXN0b20nLFxuICAgIHRlbXBsYXRlOiBgPG5nLWNvbnRhaW5lciAjY29udGFpbmVyPjwvbmctY29udGFpbmVyPmAsXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlXSxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG5leHBvcnQgY2xhc3MgVG9vbHRpcEN1c3RvbUNvbXBvbmVudCBpbXBsZW1lbnRzIE9uQ2hhbmdlcyB7XG4gICAgcHJpdmF0ZSByZWFkb25seSBpbmplY3RvcjogSW5qZWN0b3IgPSBpbmplY3QoSW5qZWN0b3IpO1xuICAgIHByaXZhdGUgcmVhZG9ubHkgZW52aXJvbm1lbnRJbmplY3RvcjogRW52aXJvbm1lbnRJbmplY3RvciA9IGluamVjdChFbnZpcm9ubWVudEluamVjdG9yKTtcbiAgICBwcml2YXRlIGNtcFJlZjogQ29tcG9uZW50UmVmPGFueT47XG5cbiAgICBAVmlld0NoaWxkKCdjb250YWluZXInLCB7IHJlYWQ6IFZpZXdDb250YWluZXJSZWYsIHN0YXRpYzogdHJ1ZSB9KVxuICAgIHByaXZhdGUgY29udGFpbmVyITogVmlld0NvbnRhaW5lclJlZjtcblxuICAgIEBJbnB1dCgpIGNvbnRlbnQ6IElDdXN0b21Ub29sdGlwQ29tcG9uZW50O1xuXG4gICAgbmdPbkNoYW5nZXMoY2hhbmdlczogU2ltcGxlQ2hhbmdlcyk6IHZvaWQge1xuICAgICAgICBpZiAoY2hhbmdlcy5jb250ZW50KSB7XG4gICAgICAgICAgICB0aGlzLnJlbmRlckNvbXBvbmVudCgpO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgcHJpdmF0ZSByZW5kZXJDb21wb25lbnQoKTogdm9pZCB7XG4gICAgICAgIHRoaXMuY21wUmVmPy5kZXN0cm95KCk7XG4gICAgICAgIHRoaXMuY29udGFpbmVyLmNsZWFyKCk7XG5cbiAgICAgICAgY29uc3QgY3VzdG9tSW5qZWN0b3IgPSBJbmplY3Rvci5jcmVhdGUoe1xuICAgICAgICAgICAgcHJvdmlkZXJzOiB0aGlzLmNvbnRlbnQucHJvdmlkZXJzID8/IFtdLFxuICAgICAgICAgICAgcGFyZW50OiB0aGlzLmluamVjdG9yLFxuICAgICAgICB9KTtcblxuICAgICAgICB0aGlzLmNtcFJlZiA9IHRoaXMuY29udGFpbmVyLmNyZWF0ZUNvbXBvbmVudCh0aGlzLmNvbnRlbnQuY29tcG9uZW50LCB7XG4gICAgICAgICAgICBpbmplY3RvcjogY3VzdG9tSW5qZWN0b3IsXG4gICAgICAgICAgICBlbnZpcm9ubWVudEluamVjdG9yOiB0aGlzLmVudmlyb25tZW50SW5qZWN0b3IsXG4gICAgICAgIH0pO1xuXG4gICAgICAgIGlmICh0aGlzLmNvbnRlbnQuaW5wdXRzKSB7XG4gICAgICAgICAgICBPYmplY3QuZW50cmllcyh0aGlzLmNvbnRlbnQuaW5wdXRzKS5mb3JFYWNoKChba2V5LCB2YWx1ZV0pID0+IHtcbiAgICAgICAgICAgICAgICB0aGlzLmNtcFJlZi5zZXRJbnB1dChrZXkgYXMgc3RyaW5nLCB2YWx1ZSk7XG4gICAgICAgICAgICB9KTtcblxuICAgICAgICAgICAgdGhpcy5jbXBSZWYuY2hhbmdlRGV0ZWN0b3JSZWYuZGV0ZWN0Q2hhbmdlcygpO1xuICAgICAgICB9XG4gICAgfVxufVxuIl19
|
|
@@ -5,38 +5,57 @@ import { BehaviorSubject } from 'rxjs';
|
|
|
5
5
|
import { TooltipTheme } from './enums/tooltip-theme.enum';
|
|
6
6
|
import { CommonModule } from '@angular/common';
|
|
7
7
|
import { TooltipDefaultComponent } from './components/tooltip-default/tooltip-default.component';
|
|
8
|
+
import { TooltipCustomComponent } from './components/tooltip-custom/tooltip-custom.component';
|
|
8
9
|
import * as i0 from "@angular/core";
|
|
9
10
|
import * as i1 from "@angular/common";
|
|
10
11
|
function TooltipComponent_div_1_Template(rf, ctx) { if (rf & 1) {
|
|
11
|
-
i0.ɵɵelement(0, "div",
|
|
12
|
+
i0.ɵɵelement(0, "div", 5);
|
|
12
13
|
} }
|
|
13
14
|
function TooltipComponent_ng_container_2_ng_container_1_Template(rf, ctx) { if (rf & 1) {
|
|
14
15
|
i0.ɵɵelementContainer(0);
|
|
15
16
|
} }
|
|
16
17
|
function TooltipComponent_ng_container_2_Template(rf, ctx) { if (rf & 1) {
|
|
17
18
|
i0.ɵɵelementContainerStart(0);
|
|
18
|
-
i0.ɵɵtemplate(1, TooltipComponent_ng_container_2_ng_container_1_Template, 1, 0, "ng-container",
|
|
19
|
+
i0.ɵɵtemplate(1, TooltipComponent_ng_container_2_ng_container_1_Template, 1, 0, "ng-container", 6);
|
|
19
20
|
i0.ɵɵelementContainerEnd();
|
|
20
21
|
} if (rf & 2) {
|
|
21
22
|
const ctx_r1 = i0.ɵɵnextContext();
|
|
22
23
|
i0.ɵɵadvance(1);
|
|
23
24
|
i0.ɵɵproperty("ngTemplateOutlet", ctx_r1.content)("ngTemplateOutletContext", ctx_r1.contentContext);
|
|
24
25
|
} }
|
|
26
|
+
function TooltipComponent_ng_template_3_ng_container_0_Template(rf, ctx) { if (rf & 1) {
|
|
27
|
+
i0.ɵɵelementContainerStart(0);
|
|
28
|
+
i0.ɵɵelement(1, "dr-tooltip-custom", 7);
|
|
29
|
+
i0.ɵɵelementContainerEnd();
|
|
30
|
+
} if (rf & 2) {
|
|
31
|
+
const ctx_r7 = i0.ɵɵnextContext(2);
|
|
32
|
+
i0.ɵɵadvance(1);
|
|
33
|
+
i0.ɵɵproperty("content", ctx_r7.content);
|
|
34
|
+
} }
|
|
25
35
|
function TooltipComponent_ng_template_3_Template(rf, ctx) { if (rf & 1) {
|
|
26
|
-
i0.ɵɵ
|
|
36
|
+
i0.ɵɵtemplate(0, TooltipComponent_ng_template_3_ng_container_0_Template, 2, 1, "ng-container", 2);
|
|
27
37
|
} if (rf & 2) {
|
|
28
38
|
const ctx_r3 = i0.ɵɵnextContext();
|
|
29
|
-
i0.ɵɵ
|
|
39
|
+
const _r4 = i0.ɵɵreference(6);
|
|
40
|
+
i0.ɵɵproperty("ngIf", ctx_r3.isCustomTooltip)("ngIfElse", _r4);
|
|
41
|
+
} }
|
|
42
|
+
function TooltipComponent_ng_template_5_Template(rf, ctx) { if (rf & 1) {
|
|
43
|
+
i0.ɵɵelement(0, "dr-tooltip-default", 8);
|
|
44
|
+
} if (rf & 2) {
|
|
45
|
+
const ctx_r5 = i0.ɵɵnextContext();
|
|
46
|
+
i0.ɵɵproperty("content", ctx_r5.content)("theme", ctx_r5.theme);
|
|
30
47
|
} }
|
|
31
48
|
const _c0 = function (a0) { return { "dr-tooltip": a0 }; };
|
|
32
49
|
export class TooltipComponent {
|
|
33
50
|
constructor() {
|
|
34
51
|
this.isContentTemplate = false;
|
|
52
|
+
this.isCustomTooltip = false;
|
|
35
53
|
this.role = 'tooltip';
|
|
36
54
|
this.isMouseOn$ = new BehaviorSubject(false);
|
|
37
55
|
}
|
|
38
56
|
ngOnInit() {
|
|
39
57
|
this.isContentTemplate = this.content instanceof TemplateRef;
|
|
58
|
+
this.isCustomTooltip = typeof this.content === 'object' && !!this.content?.component;
|
|
40
59
|
}
|
|
41
60
|
setMouseOn() {
|
|
42
61
|
this.isMouseOn$.next(true);
|
|
@@ -49,11 +68,12 @@ export class TooltipComponent {
|
|
|
49
68
|
i0.ɵɵlistener("mouseenter", function TooltipComponent_mouseenter_HostBindingHandler() { return ctx.setMouseOn(); })("mouseleave", function TooltipComponent_mouseleave_HostBindingHandler() { return ctx.unsetMouseOn(); });
|
|
50
69
|
} if (rf & 2) {
|
|
51
70
|
i0.ɵɵattribute("role", ctx.role);
|
|
52
|
-
} }, inputs: { content: "content", contentContext: "contentContext", position: "position", options: "options", class: "class", theme: "theme" }, standalone: true, features: [i0.ɵɵStandaloneFeature], decls:
|
|
71
|
+
} }, inputs: { content: "content", contentContext: "contentContext", position: "position", options: "options", class: "class", theme: "theme" }, standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 7, vars: 8, consts: [[3, "ngClass"], ["class", "dr-tooltip-arrow", 4, "ngIf"], [4, "ngIf", "ngIfElse"], ["checkCustomTooltip", ""], ["defaultContent", ""], [1, "dr-tooltip-arrow"], [4, "ngTemplateOutlet", "ngTemplateOutletContext"], [3, "content"], [3, "content", "theme"]], template: function TooltipComponent_Template(rf, ctx) { if (rf & 1) {
|
|
53
72
|
i0.ɵɵelementStart(0, "div", 0);
|
|
54
73
|
i0.ɵɵtemplate(1, TooltipComponent_div_1_Template, 1, 0, "div", 1);
|
|
55
74
|
i0.ɵɵtemplate(2, TooltipComponent_ng_container_2_Template, 2, 2, "ng-container", 2);
|
|
56
75
|
i0.ɵɵtemplate(3, TooltipComponent_ng_template_3_Template, 1, 2, "ng-template", null, 3, i0.ɵɵtemplateRefExtractor);
|
|
76
|
+
i0.ɵɵtemplate(5, TooltipComponent_ng_template_5_Template, 1, 2, "ng-template", null, 4, i0.ɵɵtemplateRefExtractor);
|
|
57
77
|
i0.ɵɵelementEnd();
|
|
58
78
|
} if (rf & 2) {
|
|
59
79
|
const _r2 = i0.ɵɵreference(4);
|
|
@@ -63,11 +83,11 @@ export class TooltipComponent {
|
|
|
63
83
|
i0.ɵɵproperty("ngIf", !(ctx.options == null ? null : ctx.options.withoutArrow));
|
|
64
84
|
i0.ɵɵadvance(1);
|
|
65
85
|
i0.ɵɵproperty("ngIf", ctx.isContentTemplate)("ngIfElse", _r2);
|
|
66
|
-
} }, dependencies: [CommonModule, i1.NgClass, i1.NgIf, i1.NgTemplateOutlet, TooltipDefaultComponent], styles: ["[_nghost-%COMP%]{display:block;font-family:Poppins,sans-serif}.top[_ngcontent-%COMP%], .top-left[_ngcontent-%COMP%], .top-right.dr-tooltip[_ngcontent-%COMP%]{transform:translateY(-8px)}.bottom[_ngcontent-%COMP%], .bottom-left[_ngcontent-%COMP%], .bottom-right.dr-tooltip[_ngcontent-%COMP%]{transform:translateY(8px)}.left[_ngcontent-%COMP%], .left-top[_ngcontent-%COMP%], .left-bottom.dr-tooltip[_ngcontent-%COMP%]{transform:translate(-8px)}.right[_ngcontent-%COMP%], .right-top[_ngcontent-%COMP%], .right-bottom.dr-tooltip[_ngcontent-%COMP%]{transform:translate(8px)}.dr-tooltip[_ngcontent-%COMP%]{background:#fff;border:1px solid #cfd7dd;box-sizing:border-box;border-radius:8px;font-size:12px;color:#545a6b;max-width:80vw!important;box-shadow:0 2px 4px #9199b440}.dr-tooltip-arrow[_ngcontent-%COMP%]{border-width:8px}.dr-tooltip-arrow[_ngcontent-%COMP%], .dr-tooltip-arrow[_ngcontent-%COMP%]:after{position:absolute;display:block;width:0;height:0;border-color:transparent;border-style:solid}.dr-tooltip-arrow[_ngcontent-%COMP%]:after{content:\"\";border-width:8px}.top[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%], .top-left[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%], .top-right[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]{bottom:-16px;border-top-color:#cfd7dd!important}.top[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]:after, .top-left[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]:after, .top-right[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]:after{bottom:-6px;left:-8px;border-top-color:#fff}.bottom[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%], .bottom-left[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%], .bottom-right[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]{top:-7px;border-top:none;border-bottom-color:#cfd7dd!important}.bottom[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]:after, .bottom-left[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]:after, .bottom-right[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]:after{border-top:none;top:1px;left:-8px;border-bottom-color:#fff}.left[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%], .left-top[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%], .left-bottom[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]{right:-16px;border-left-color:#cfd7dd!important}.left[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]:after, .left-top[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]:after, .left-bottom[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]:after{bottom:-8px;left:-9px;border-left-color:#fff}.right[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%], .right-top[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%], .right-bottom[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]{left:-16px;border-right-color:#cfd7dd!important}.right[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]:after, .right-top[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]:after, .right-bottom[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]:after{bottom:-8px;left:-7px;border-right-color:#fff}.top[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%], .bottom[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]{left:calc(50% - 8px)}.bottom-left[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%], .top-left[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]{left:8px}.bottom-right[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%], .top-right[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]{right:8px}.left[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%], .right[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]{top:calc(50% - 8px)}.left-top[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%], .
|
|
86
|
+
} }, dependencies: [CommonModule, i1.NgClass, i1.NgIf, i1.NgTemplateOutlet, TooltipDefaultComponent, TooltipCustomComponent], styles: ["[_nghost-%COMP%]{display:block;font-family:Poppins,sans-serif}.top[_ngcontent-%COMP%], .top-left[_ngcontent-%COMP%], .top-right.dr-tooltip[_ngcontent-%COMP%]{transform:translateY(-8px)}.bottom[_ngcontent-%COMP%], .bottom-left[_ngcontent-%COMP%], .bottom-right.dr-tooltip[_ngcontent-%COMP%]{transform:translateY(8px)}.left[_ngcontent-%COMP%], .left-top[_ngcontent-%COMP%], .left-bottom.dr-tooltip[_ngcontent-%COMP%]{transform:translate(-8px)}.right[_ngcontent-%COMP%], .right-top[_ngcontent-%COMP%], .right-bottom.dr-tooltip[_ngcontent-%COMP%]{transform:translate(8px)}.dr-tooltip[_ngcontent-%COMP%]{background:#fff;border:1px solid #cfd7dd;box-sizing:border-box;border-radius:8px;font-size:12px;color:#545a6b;max-width:80vw!important;box-shadow:0 2px 4px #9199b440}.dr-tooltip-arrow[_ngcontent-%COMP%]{border-width:8px}.dr-tooltip-arrow[_ngcontent-%COMP%], .dr-tooltip-arrow[_ngcontent-%COMP%]:after{position:absolute;display:block;width:0;height:0;border-color:transparent;border-style:solid}.dr-tooltip-arrow[_ngcontent-%COMP%]:after{content:\"\";border-width:8px}.top[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%], .top-left[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%], .top-right[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]{bottom:-16px;border-top-color:#cfd7dd!important}.top[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]:after, .top-left[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]:after, .top-right[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]:after{bottom:-6px;left:-8px;border-top-color:#fff}.bottom[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%], .bottom-left[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%], .bottom-right[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]{top:-7px;border-top:none;border-bottom-color:#cfd7dd!important}.bottom[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]:after, .bottom-left[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]:after, .bottom-right[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]:after{border-top:none;top:1px;left:-8px;border-bottom-color:#fff}.left[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%], .left-top[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%], .left-bottom[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]{right:-16px;border-left-color:#cfd7dd!important}.left[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]:after, .left-top[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]:after, .left-bottom[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]:after{bottom:-8px;left:-9px;border-left-color:#fff}.right[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%], .right-top[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%], .right-bottom[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]{left:-16px;border-right-color:#cfd7dd!important}.right[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]:after, .right-top[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]:after, .right-bottom[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]:after{bottom:-8px;left:-7px;border-right-color:#fff}.top[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%], .bottom[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]{left:calc(50% - 8px)}.bottom-left[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%], .top-left[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]{left:8px}.bottom-right[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%], .top-right[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]{right:8px}.left[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%], .right[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]{top:calc(50% - 8px)}.left-top[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%], .right-top[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]{top:8px}.right-bottom[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%], .left-bottom[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]{bottom:8px}.dr-tooltip.dark[_ngcontent-%COMP%]{background:#0c142bcc;border:none;border-radius:8px;color:#fff}.dr-tooltip.dark.top[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%], .dr-tooltip.dark.top-left[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%], .dr-tooltip.dark.top-right[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]{border-top-color:#0c142bcc!important}.dr-tooltip.dark.top[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]:after, .dr-tooltip.dark.top-left[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]:after, .dr-tooltip.dark.top-right[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]:after{border-top-color:transparent}.dr-tooltip.dark.bottom[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%], .dr-tooltip.dark.bottom-left[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%], .dr-tooltip.dark.bottom-right[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]{border-bottom-color:#0c142bcc!important}.dr-tooltip.dark.bottom[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]:after, .dr-tooltip.dark.bottom-left[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]:after, .dr-tooltip.dark.bottom-right[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]:after{border-bottom-color:transparent}.dr-tooltip.dark.left[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%], .dr-tooltip.dark.left-top[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%], .dr-tooltip.dark.left-bottom[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]{border-left-color:#0c142bcc!important}.dr-tooltip.dark.left[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]:after, .dr-tooltip.dark.left-top[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]:after, .dr-tooltip.dark.left-bottom[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]:after{border-left-color:transparent}.dr-tooltip.dark.right[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%], .dr-tooltip.dark.right-top[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%], .dr-tooltip.dark.right-bottom[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]{border-right-color:#0c142bcc!important}.dr-tooltip.dark.right[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]:after, .dr-tooltip.dark.right-top[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]:after, .dr-tooltip.dark.right-bottom[_ngcontent-%COMP%] .dr-tooltip-arrow[_ngcontent-%COMP%]:after{border-right-color:transparent}"], data: { animation: [trigger('tooltip', POPUP_ANIMATION)] } }); }
|
|
67
87
|
}
|
|
68
88
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(TooltipComponent, [{
|
|
69
89
|
type: Component,
|
|
70
|
-
args: [{ selector: 'dr-tooltip', animations: [trigger('tooltip', POPUP_ANIMATION)], standalone: true, imports: [CommonModule, TooltipDefaultComponent], template: "<div [class]=\"position + ' ' + class + ' ' + theme\" [ngClass]=\"{ 'dr-tooltip': !options?.withoutContainerStyles }\">\n <div *ngIf=\"!options?.withoutArrow\" class=\"dr-tooltip-arrow\"></div>\n <ng-container *ngIf=\"isContentTemplate; else
|
|
90
|
+
args: [{ selector: 'dr-tooltip', animations: [trigger('tooltip', POPUP_ANIMATION)], standalone: true, imports: [CommonModule, TooltipDefaultComponent, TooltipCustomComponent], template: "<div [class]=\"position + ' ' + class + ' ' + theme\" [ngClass]=\"{ 'dr-tooltip': !options?.withoutContainerStyles }\">\n <div *ngIf=\"!options?.withoutArrow\" class=\"dr-tooltip-arrow\"></div>\n\n <ng-container *ngIf=\"isContentTemplate; else checkCustomTooltip\">\n <ng-container *ngTemplateOutlet=\"content; context: contentContext\"></ng-container>\n </ng-container>\n\n <ng-template #checkCustomTooltip>\n <ng-container *ngIf=\"isCustomTooltip; else defaultContent\">\n <dr-tooltip-custom [content]=\"content\"></dr-tooltip-custom>\n </ng-container>\n </ng-template>\n\n <ng-template #defaultContent>\n <dr-tooltip-default [content]=\"content\" [theme]=\"theme\"></dr-tooltip-default>\n </ng-template>\n</div>\n", styles: [":host{display:block;font-family:Poppins,sans-serif}.top,.top-left,.top-right.dr-tooltip{transform:translateY(-8px)}.bottom,.bottom-left,.bottom-right.dr-tooltip{transform:translateY(8px)}.left,.left-top,.left-bottom.dr-tooltip{transform:translate(-8px)}.right,.right-top,.right-bottom.dr-tooltip{transform:translate(8px)}.dr-tooltip{background:#fff;border:1px solid #cfd7dd;box-sizing:border-box;border-radius:8px;font-size:12px;color:#545a6b;max-width:80vw!important;box-shadow:0 2px 4px #9199b440}.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% - 8px)}.bottom-left .dr-tooltip-arrow,.top-left .dr-tooltip-arrow{left:8px}.bottom-right .dr-tooltip-arrow,.top-right .dr-tooltip-arrow{right:8px}.left .dr-tooltip-arrow,.right .dr-tooltip-arrow{top:calc(50% - 8px)}.left-top .dr-tooltip-arrow,.right-top .dr-tooltip-arrow{top:8px}.right-bottom .dr-tooltip-arrow,.left-bottom .dr-tooltip-arrow{bottom:8px}.dr-tooltip.dark{background:#0c142bcc;border:none;border-radius:8px;color:#fff}.dr-tooltip.dark.top .dr-tooltip-arrow,.dr-tooltip.dark.top-left .dr-tooltip-arrow,.dr-tooltip.dark.top-right .dr-tooltip-arrow{border-top-color:#0c142bcc!important}.dr-tooltip.dark.top .dr-tooltip-arrow:after,.dr-tooltip.dark.top-left .dr-tooltip-arrow:after,.dr-tooltip.dark.top-right .dr-tooltip-arrow:after{border-top-color:transparent}.dr-tooltip.dark.bottom .dr-tooltip-arrow,.dr-tooltip.dark.bottom-left .dr-tooltip-arrow,.dr-tooltip.dark.bottom-right .dr-tooltip-arrow{border-bottom-color:#0c142bcc!important}.dr-tooltip.dark.bottom .dr-tooltip-arrow:after,.dr-tooltip.dark.bottom-left .dr-tooltip-arrow:after,.dr-tooltip.dark.bottom-right .dr-tooltip-arrow:after{border-bottom-color:transparent}.dr-tooltip.dark.left .dr-tooltip-arrow,.dr-tooltip.dark.left-top .dr-tooltip-arrow,.dr-tooltip.dark.left-bottom .dr-tooltip-arrow{border-left-color:#0c142bcc!important}.dr-tooltip.dark.left .dr-tooltip-arrow:after,.dr-tooltip.dark.left-top .dr-tooltip-arrow:after,.dr-tooltip.dark.left-bottom .dr-tooltip-arrow:after{border-left-color:transparent}.dr-tooltip.dark.right .dr-tooltip-arrow,.dr-tooltip.dark.right-top .dr-tooltip-arrow,.dr-tooltip.dark.right-bottom .dr-tooltip-arrow{border-right-color:#0c142bcc!important}.dr-tooltip.dark.right .dr-tooltip-arrow:after,.dr-tooltip.dark.right-top .dr-tooltip-arrow:after,.dr-tooltip.dark.right-bottom .dr-tooltip-arrow:after{border-right-color:transparent}\n"] }]
|
|
71
91
|
}], null, { content: [{
|
|
72
92
|
type: Input
|
|
73
93
|
}], contentContext: [{
|
|
@@ -90,4 +110,4 @@ export class TooltipComponent {
|
|
|
90
110
|
type: HostListener,
|
|
91
111
|
args: ['mouseleave']
|
|
92
112
|
}] }); })();
|
|
93
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
113
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHItdG9vbHRpcC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kYXRhcmFpbHNzaGFyZWQvc3JjL2xpYi9kci10b29sdGlwL2RyLXRvb2x0aXAuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZGF0YXJhaWxzc2hhcmVkL3NyYy9saWIvZHItdG9vbHRpcC9kci10b29sdGlwLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsV0FBVyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQVUsV0FBVyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2pHLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUM5QyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDdEQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUN2QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDMUQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLHdEQUF3RCxDQUFDO0FBQ2pHLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLHNEQUFzRCxDQUFDOzs7O0lDTjFGLHlCQUFtRTs7O0lBRy9ELHdCQUFrRjs7O0lBRHRGLDZCQUFpRTtJQUM3RCxrR0FBa0Y7SUFDdEYsMEJBQWU7OztJQURJLGVBQTJCO0lBQTNCLGlEQUEyQixrREFBQTs7O0lBSTFDLDZCQUEyRDtJQUN2RCx1Q0FBMkQ7SUFDL0QsMEJBQWU7OztJQURRLGVBQW1CO0lBQW5CLHdDQUFtQjs7O0lBRDFDLGlHQUVlOzs7O0lBRkEsNkNBQXVCLGlCQUFBOzs7SUFNdEMsd0NBQTZFOzs7SUFBekQsd0NBQW1CLHVCQUFBOzs7QURRL0MsTUFBTSxPQUFPLGdCQUFnQjtJQVI3QjtRQWVXLHNCQUFpQixHQUFHLEtBQUssQ0FBQztRQUMxQixvQkFBZSxHQUFHLEtBQUssQ0FBQztRQUd0QixTQUFJLEdBQUcsU0FBUyxDQUFDO1FBRW5CLGVBQVUsR0FBNkIsSUFBSSxlQUFlLENBQVUsS0FBSyxDQUFDLENBQUM7S0FnQnJGO0lBZEcsUUFBUTtRQUNKLElBQUksQ0FBQyxpQkFBaUIsR0FBRyxJQUFJLENBQUMsT0FBTyxZQUFZLFdBQVcsQ0FBQztRQUM3RCxJQUFJLENBQUMsZUFBZSxHQUFHLE9BQU8sSUFBSSxDQUFDLE9BQU8sS0FBSyxRQUFRLElBQUksQ0FBQyxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsU0FBUyxDQUFDO0lBQ3pGLENBQUM7SUFHRCxVQUFVO1FBQ04sSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDL0IsQ0FBQztJQUdELFlBQVk7UUFDUixJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNoQyxDQUFDO29HQTVCUSxnQkFBZ0I7bUdBQWhCLGdCQUFnQjsyR0FBaEIsZ0JBQVksc0ZBQVosa0JBQWM7Ozs7WUN0QjNCLDhCQUFtSDtZQUMvRyxpRUFBbUU7WUFFbkUsbUZBRWU7WUFFZixrSEFJYztZQUVkLGtIQUVjO1lBQ2xCLGlCQUFNOzs7WUFoQkQsK0RBQThDO1lBQUMsd0hBQThEO1lBQ3hHLGVBQTRCO1lBQTVCLCtFQUE0QjtZQUVuQixlQUF5QjtZQUF6Qiw0Q0FBeUIsaUJBQUE7NEJEaUI5QixZQUFZLDRDQUFFLHVCQUF1QixFQUFFLHNCQUFzQixvOU1BRjNELENBQUMsT0FBTyxDQUFDLFNBQVMsRUFBRSxlQUFlLENBQUMsQ0FBQzs7dUZBSXhDLGdCQUFnQjtjQVI1QixTQUFTOzJCQUNJLFlBQVksY0FHVixDQUFDLE9BQU8sQ0FBQyxTQUFTLEVBQUUsZUFBZSxDQUFDLENBQUMsY0FDckMsSUFBSSxXQUNQLENBQUMsWUFBWSxFQUFFLHVCQUF1QixFQUFFLHNCQUFzQixDQUFDO2dCQUcvRCxPQUFPO2tCQUFmLEtBQUs7WUFDRyxjQUFjO2tCQUF0QixLQUFLO1lBQ0csUUFBUTtrQkFBaEIsS0FBSztZQUNHLE9BQU87a0JBQWYsS0FBSztZQUNHLEtBQUs7a0JBQWIsS0FBSztZQUNHLEtBQUs7a0JBQWIsS0FBSztZQUtHLElBQUk7a0JBRFosV0FBVzttQkFBQyxXQUFXO1lBV3hCLFVBQVU7a0JBRFQsWUFBWTttQkFBQyxZQUFZO1lBTTFCLFlBQVk7a0JBRFgsWUFBWTttQkFBQyxZQUFZIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBIb3N0QmluZGluZywgSG9zdExpc3RlbmVyLCBJbnB1dCwgT25Jbml0LCBUZW1wbGF0ZVJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgdHJpZ2dlciB9IGZyb20gJ0Bhbmd1bGFyL2FuaW1hdGlvbnMnO1xuaW1wb3J0IHsgUE9QVVBfQU5JTUFUSU9OIH0gZnJvbSAnLi4vbW9kZWxzL2NvbnN0YW50cyc7XG5pbXBvcnQgeyBCZWhhdmlvclN1YmplY3QgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IFRvb2x0aXBUaGVtZSB9IGZyb20gJy4vZW51bXMvdG9vbHRpcC10aGVtZS5lbnVtJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBUb29sdGlwRGVmYXVsdENvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy90b29sdGlwLWRlZmF1bHQvdG9vbHRpcC1kZWZhdWx0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBUb29sdGlwQ3VzdG9tQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL3Rvb2x0aXAtY3VzdG9tL3Rvb2x0aXAtY3VzdG9tLmNvbXBvbmVudCc7XG5cbmV4cG9ydCB0eXBlIFRvb2x0aXBPcHRpb25zID0ge1xuICAgIHdpdGhvdXRDb250YWluZXJTdHlsZXM/OiBib29sZWFuO1xuICAgIHdpdGhvdXRBcnJvdz86IGJvb2xlYW47XG59O1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2RyLXRvb2x0aXAnLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9kci10b29sdGlwLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9kci10b29sdGlwLmNvbXBvbmVudC5zY3NzJ10sXG4gICAgYW5pbWF0aW9uczogW3RyaWdnZXIoJ3Rvb2x0aXAnLCBQT1BVUF9BTklNQVRJT04pXSxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIFRvb2x0aXBEZWZhdWx0Q29tcG9uZW50LCBUb29sdGlwQ3VzdG9tQ29tcG9uZW50XSxcbn0pXG5leHBvcnQgY2xhc3MgVG9vbHRpcENvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gICAgQElucHV0KCkgY29udGVudDtcbiAgICBASW5wdXQoKSBjb250ZW50Q29udGV4dDtcbiAgICBASW5wdXQoKSBwb3NpdGlvbjtcbiAgICBASW5wdXQoKSBvcHRpb25zOiBUb29sdGlwT3B0aW9ucztcbiAgICBASW5wdXQoKSBjbGFzczogc3RyaW5nO1xuICAgIEBJbnB1dCgpIHRoZW1lOiBUb29sdGlwVGhlbWU7XG4gICAgcHVibGljIGlzQ29udGVudFRlbXBsYXRlID0gZmFsc2U7XG4gICAgcHVibGljIGlzQ3VzdG9tVG9vbHRpcCA9IGZhbHNlO1xuXG4gICAgQEhvc3RCaW5kaW5nKCdhdHRyLnJvbGUnKVxuICAgIHJlYWRvbmx5IHJvbGUgPSAndG9vbHRpcCc7XG5cbiAgICBwdWJsaWMgaXNNb3VzZU9uJDogQmVoYXZpb3JTdWJqZWN0PGJvb2xlYW4+ID0gbmV3IEJlaGF2aW9yU3ViamVjdDxib29sZWFuPihmYWxzZSk7XG5cbiAgICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5pc0NvbnRlbnRUZW1wbGF0ZSA9IHRoaXMuY29udGVudCBpbnN0YW5jZW9mIFRlbXBsYXRlUmVmO1xuICAgICAgICB0aGlzLmlzQ3VzdG9tVG9vbHRpcCA9IHR5cGVvZiB0aGlzLmNvbnRlbnQgPT09ICdvYmplY3QnICYmICEhdGhpcy5jb250ZW50Py5jb21wb25lbnQ7XG4gICAgfVxuXG4gICAgQEhvc3RMaXN0ZW5lcignbW91c2VlbnRlcicpXG4gICAgc2V0TW91c2VPbigpIHtcbiAgICAgICAgdGhpcy5pc01vdXNlT24kLm5leHQodHJ1ZSk7XG4gICAgfVxuXG4gICAgQEhvc3RMaXN0ZW5lcignbW91c2VsZWF2ZScpXG4gICAgdW5zZXRNb3VzZU9uKCkge1xuICAgICAgICB0aGlzLmlzTW91c2VPbiQubmV4dChmYWxzZSk7XG4gICAgfVxufVxuIiwiPGRpdiBbY2xhc3NdPVwicG9zaXRpb24gKyAnICcgKyBjbGFzcyArICcgJyArIHRoZW1lXCIgW25nQ2xhc3NdPVwieyAnZHItdG9vbHRpcCc6ICFvcHRpb25zPy53aXRob3V0Q29udGFpbmVyU3R5bGVzIH1cIj5cbiAgICA8ZGl2ICpuZ0lmPVwiIW9wdGlvbnM/LndpdGhvdXRBcnJvd1wiIGNsYXNzPVwiZHItdG9vbHRpcC1hcnJvd1wiPjwvZGl2PlxuXG4gICAgPG5nLWNvbnRhaW5lciAqbmdJZj1cImlzQ29udGVudFRlbXBsYXRlOyBlbHNlIGNoZWNrQ3VzdG9tVG9vbHRpcFwiPlxuICAgICAgICA8bmctY29udGFpbmVyICpuZ1RlbXBsYXRlT3V0bGV0PVwiY29udGVudDsgY29udGV4dDogY29udGVudENvbnRleHRcIj48L25nLWNvbnRhaW5lcj5cbiAgICA8L25nLWNvbnRhaW5lcj5cblxuICAgIDxuZy10ZW1wbGF0ZSAjY2hlY2tDdXN0b21Ub29sdGlwPlxuICAgICAgICA8bmctY29udGFpbmVyICpuZ0lmPVwiaXNDdXN0b21Ub29sdGlwOyBlbHNlIGRlZmF1bHRDb250ZW50XCI+XG4gICAgICAgICAgICA8ZHItdG9vbHRpcC1jdXN0b20gW2NvbnRlbnRdPVwiY29udGVudFwiPjwvZHItdG9vbHRpcC1jdXN0b20+XG4gICAgICAgIDwvbmctY29udGFpbmVyPlxuICAgIDwvbmctdGVtcGxhdGU+XG5cbiAgICA8bmctdGVtcGxhdGUgI2RlZmF1bHRDb250ZW50PlxuICAgICAgICA8ZHItdG9vbHRpcC1kZWZhdWx0IFtjb250ZW50XT1cImNvbnRlbnRcIiBbdGhlbWVdPVwidGhlbWVcIj48L2RyLXRvb2x0aXAtZGVmYXVsdD5cbiAgICA8L25nLXRlbXBsYXRlPlxuPC9kaXY+XG4iXX0=
|
|
@@ -3,12 +3,22 @@ import { DrTooltipDirective } from './dr-tooltip.directive';
|
|
|
3
3
|
import { TooltipComponent } from './dr-tooltip.component';
|
|
4
4
|
import { TooltipInfoComponent } from './components/tooltip-info/tooltip-info.component';
|
|
5
5
|
import { TooltipDefaultComponent } from './components/tooltip-default/tooltip-default.component';
|
|
6
|
+
import { TooltipCustomComponent } from './components/tooltip-custom/tooltip-custom.component';
|
|
6
7
|
import * as i0 from "@angular/core";
|
|
7
|
-
const TOOLTIP_COMPONENTS = [
|
|
8
|
+
const TOOLTIP_COMPONENTS = [
|
|
9
|
+
TooltipDefaultComponent,
|
|
10
|
+
TooltipInfoComponent,
|
|
11
|
+
TooltipCustomComponent,
|
|
12
|
+
TooltipComponent,
|
|
13
|
+
DrTooltipDirective,
|
|
14
|
+
];
|
|
8
15
|
export class DrTooltipModule {
|
|
9
16
|
/** @nocollapse */ static { this.ɵfac = function DrTooltipModule_Factory(t) { return new (t || DrTooltipModule)(); }; }
|
|
10
17
|
/** @nocollapse */ static { this.ɵmod = /** @pureOrBreakMyCode */ i0.ɵɵdefineNgModule({ type: DrTooltipModule }); }
|
|
11
|
-
/** @nocollapse */ static { this.ɵinj = /** @pureOrBreakMyCode */ i0.ɵɵdefineInjector({ imports: [TooltipDefaultComponent,
|
|
18
|
+
/** @nocollapse */ static { this.ɵinj = /** @pureOrBreakMyCode */ i0.ɵɵdefineInjector({ imports: [TooltipDefaultComponent,
|
|
19
|
+
TooltipInfoComponent,
|
|
20
|
+
TooltipCustomComponent,
|
|
21
|
+
TooltipComponent] }); }
|
|
12
22
|
}
|
|
13
23
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DrTooltipModule, [{
|
|
14
24
|
type: NgModule,
|
|
@@ -17,5 +27,13 @@ export class DrTooltipModule {
|
|
|
17
27
|
exports: [...TOOLTIP_COMPONENTS],
|
|
18
28
|
}]
|
|
19
29
|
}], null, null); })();
|
|
20
|
-
(function () { (typeof ngJitMode === "undefined" || ngJitMode) && i0.ɵɵsetNgModuleScope(DrTooltipModule, { imports: [TooltipDefaultComponent,
|
|
21
|
-
|
|
30
|
+
(function () { (typeof ngJitMode === "undefined" || ngJitMode) && i0.ɵɵsetNgModuleScope(DrTooltipModule, { imports: [TooltipDefaultComponent,
|
|
31
|
+
TooltipInfoComponent,
|
|
32
|
+
TooltipCustomComponent,
|
|
33
|
+
TooltipComponent,
|
|
34
|
+
DrTooltipDirective], exports: [TooltipDefaultComponent,
|
|
35
|
+
TooltipInfoComponent,
|
|
36
|
+
TooltipCustomComponent,
|
|
37
|
+
TooltipComponent,
|
|
38
|
+
DrTooltipDirective] }); })();
|
|
39
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHItdG9vbHRpcC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kYXRhcmFpbHNzaGFyZWQvc3JjL2xpYi9kci10b29sdGlwL2RyLXRvb2x0aXAubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDNUQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDMUQsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sa0RBQWtELENBQUM7QUFDeEYsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sd0RBQXdELENBQUM7QUFDakcsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sc0RBQXNELENBQUM7O0FBRTlGLE1BQU0sa0JBQWtCLEdBQUc7SUFDdkIsdUJBQXVCO0lBQ3ZCLG9CQUFvQjtJQUNwQixzQkFBc0I7SUFDdEIsZ0JBQWdCO0lBQ2hCLGtCQUFrQjtDQUNyQixDQUFDO0FBTUYsTUFBTSxPQUFPLGVBQWU7bUdBQWYsZUFBZTtrR0FBZixlQUFlO3NHQVh4Qix1QkFBdUI7WUFDdkIsb0JBQW9CO1lBQ3BCLHNCQUFzQjtZQUN0QixnQkFBZ0I7O3VGQVFQLGVBQWU7Y0FKM0IsUUFBUTtlQUFDO2dCQUNOLE9BQU8sRUFBRSxDQUFDLEdBQUcsa0JBQWtCLENBQUM7Z0JBQ2hDLE9BQU8sRUFBRSxDQUFDLEdBQUcsa0JBQWtCLENBQUM7YUFDbkM7O3dGQUNZLGVBQWUsY0FYeEIsdUJBQXVCO1FBQ3ZCLG9CQUFvQjtRQUNwQixzQkFBc0I7UUFDdEIsZ0JBQWdCO1FBQ2hCLGtCQUFrQixhQUpsQix1QkFBdUI7UUFDdkIsb0JBQW9CO1FBQ3BCLHNCQUFzQjtRQUN0QixnQkFBZ0I7UUFDaEIsa0JBQWtCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IERyVG9vbHRpcERpcmVjdGl2ZSB9IGZyb20gJy4vZHItdG9vbHRpcC5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgVG9vbHRpcENvbXBvbmVudCB9IGZyb20gJy4vZHItdG9vbHRpcC5jb21wb25lbnQnO1xuaW1wb3J0IHsgVG9vbHRpcEluZm9Db21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvdG9vbHRpcC1pbmZvL3Rvb2x0aXAtaW5mby5jb21wb25lbnQnO1xuaW1wb3J0IHsgVG9vbHRpcERlZmF1bHRDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvdG9vbHRpcC1kZWZhdWx0L3Rvb2x0aXAtZGVmYXVsdC5jb21wb25lbnQnO1xuaW1wb3J0IHsgVG9vbHRpcEN1c3RvbUNvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy90b29sdGlwLWN1c3RvbS90b29sdGlwLWN1c3RvbS5jb21wb25lbnQnO1xuXG5jb25zdCBUT09MVElQX0NPTVBPTkVOVFMgPSBbXG4gICAgVG9vbHRpcERlZmF1bHRDb21wb25lbnQsXG4gICAgVG9vbHRpcEluZm9Db21wb25lbnQsXG4gICAgVG9vbHRpcEN1c3RvbUNvbXBvbmVudCxcbiAgICBUb29sdGlwQ29tcG9uZW50LFxuICAgIERyVG9vbHRpcERpcmVjdGl2ZSxcbl07XG5cbkBOZ01vZHVsZSh7XG4gICAgaW1wb3J0czogWy4uLlRPT0xUSVBfQ09NUE9ORU5UU10sXG4gICAgZXhwb3J0czogWy4uLlRPT0xUSVBfQ09NUE9ORU5UU10sXG59KVxuZXhwb3J0IGNsYXNzIERyVG9vbHRpcE1vZHVsZSB7fVxuIl19
|
|
@@ -66,11 +66,11 @@ export class EmojiPickerComponent {
|
|
|
66
66
|
} if (rf & 2) {
|
|
67
67
|
const _r1 = i0.ɵɵreference(2);
|
|
68
68
|
i0.ɵɵproperty("ngIf", ctx.mode === ctx.EmojiPickerMode.BUTTON)("ngIfElse", _r1);
|
|
69
|
-
} }, dependencies: [DrButtonComponent, PickerComponent, CdkOverlayOrigin, CdkConnectedOverlay, NgIf, NgTemplateOutlet], styles: [".emoji-picker-popup[_ngcontent-%COMP%]{position:relative;overflow:hidden;margin-top:8px;z-index:1000;box-shadow:0 2px 36px #00000026;border-radius:12px}.emoji-picker-popup-section[_ngcontent-%COMP%]{display:block}.emoji-picker-popup-section[_ngcontent-%COMP%] section.emoji-mart{border-color:transparent}"], changeDetection: 0 }); }
|
|
69
|
+
} }, dependencies: [DrButtonComponent, PickerComponent, CdkOverlayOrigin, CdkConnectedOverlay, NgIf, NgTemplateOutlet], styles: [".emoji-picker-popup[_ngcontent-%COMP%]{position:relative;overflow:hidden;margin-top:8px;z-index:1000;box-shadow:0 2px 36px #00000026;border-radius:12px}.emoji-picker-popup[_ngcontent-%COMP%] .emoji-picker-section[_ngcontent-%COMP%]{display:block}.emoji-picker-popup[_ngcontent-%COMP%] .emoji-picker-section[_ngcontent-%COMP%] section.emoji-mart{border-color:transparent}"], changeDetection: 0 }); }
|
|
70
70
|
}
|
|
71
71
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(EmojiPickerComponent, [{
|
|
72
72
|
type: Component,
|
|
73
|
-
args: [{ selector: 'dr-emoji-picker', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [DrButtonComponent, PickerComponent, CdkOverlayOrigin, CdkConnectedOverlay, NgIf, NgTemplateOutlet], template: "<ng-container *ngIf=\"mode === EmojiPickerMode.BUTTON; else flatTpl\">\n <dr-button\n #emojiButton\n theme=\"icon\"\n icon=\"dr-icon-emoji-smiley\"\n cdkOverlayOrigin\n #trigger=\"cdkOverlayOrigin\"\n (click)=\"toggleEmojiPicker()\"></dr-button>\n <ng-template\n cdkConnectedOverlay\n [cdkConnectedOverlayOrigin]=\"trigger\"\n [cdkConnectedOverlayOpen]=\"emojisOpened\"\n [cdkConnectedOverlayHasBackdrop]=\"true\"\n [cdkConnectedOverlayBackdropClass]=\"'emoji-modal-backdrop'\"\n (backdropClick)=\"closeEmojiPicker()\">\n <div class=\"emoji-picker-popup\">\n <ng-container *ngTemplateOutlet=\"flatTpl\"></ng-container>\n </div>\n </ng-template>\n</ng-container>\n\n<ng-template #flatTpl>\n <!-- See details here: https://github.com/scttcper/ngx-emoji-mart -->\n <emoji-mart\n emoji=\"thumbsup\"\n color=\"#0D99FF\"\n [darkMode]=\"false\"\n (emojiSelect)=\"onEmojiSelected($event)\"\n class=\"emoji-picker-section\"></emoji-mart>\n</ng-template>\n", styles: [".emoji-picker-popup{position:relative;overflow:hidden;margin-top:8px;z-index:1000;box-shadow:0 2px 36px #00000026;border-radius:12px}.emoji-picker-popup-section{display:block}.emoji-picker-popup-section ::ng-deep section.emoji-mart{border-color:transparent}\n"] }]
|
|
73
|
+
args: [{ selector: 'dr-emoji-picker', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [DrButtonComponent, PickerComponent, CdkOverlayOrigin, CdkConnectedOverlay, NgIf, NgTemplateOutlet], template: "<ng-container *ngIf=\"mode === EmojiPickerMode.BUTTON; else flatTpl\">\n <dr-button\n #emojiButton\n theme=\"icon\"\n icon=\"dr-icon-emoji-smiley\"\n cdkOverlayOrigin\n #trigger=\"cdkOverlayOrigin\"\n (click)=\"toggleEmojiPicker()\"></dr-button>\n <ng-template\n cdkConnectedOverlay\n [cdkConnectedOverlayOrigin]=\"trigger\"\n [cdkConnectedOverlayOpen]=\"emojisOpened\"\n [cdkConnectedOverlayHasBackdrop]=\"true\"\n [cdkConnectedOverlayBackdropClass]=\"'emoji-modal-backdrop'\"\n (backdropClick)=\"closeEmojiPicker()\">\n <div class=\"emoji-picker-popup\">\n <ng-container *ngTemplateOutlet=\"flatTpl\"></ng-container>\n </div>\n </ng-template>\n</ng-container>\n\n<ng-template #flatTpl>\n <!-- See details here: https://github.com/scttcper/ngx-emoji-mart -->\n <emoji-mart\n emoji=\"thumbsup\"\n color=\"#0D99FF\"\n [darkMode]=\"false\"\n (emojiSelect)=\"onEmojiSelected($event)\"\n class=\"emoji-picker-section\"></emoji-mart>\n</ng-template>\n", styles: [".emoji-picker-popup{position:relative;overflow:hidden;margin-top:8px;z-index:1000;box-shadow:0 2px 36px #00000026;border-radius:12px}.emoji-picker-popup .emoji-picker-section{display:block}.emoji-picker-popup .emoji-picker-section ::ng-deep section.emoji-mart{border-color:transparent}\n"] }]
|
|
74
74
|
}], null, { mode: [{
|
|
75
75
|
type: Input
|
|
76
76
|
}], emojiSelected: [{
|