@radix-ng/primitives 0.16.0 → 0.18.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/checkbox/src/checkbox-input.directive.d.ts +2 -1
- package/compodoc/documentation.json +7419 -2200
- package/esm2022/accordion/index.mjs +4 -4
- package/esm2022/accordion/src/accordion-content.directive.mjs +3 -3
- package/esm2022/accordion/src/accordion-header.directive.mjs +3 -3
- package/esm2022/accordion/src/accordion-item.directive.mjs +3 -3
- package/esm2022/accordion/src/accordion-root.directive.mjs +3 -3
- package/esm2022/accordion/src/accordion-trigger.directive.mjs +3 -3
- package/esm2022/alert-dialog/index.mjs +4 -4
- package/esm2022/alert-dialog/src/alert-dialog-cancel.directive.mjs +3 -3
- package/esm2022/alert-dialog/src/alert-dialog-content.directive.mjs +3 -3
- package/esm2022/alert-dialog/src/alert-dialog-root.directive.mjs +3 -3
- package/esm2022/alert-dialog/src/alert-dialog-title.directive.mjs +3 -3
- package/esm2022/alert-dialog/src/alert-dialog-trigger.directive.mjs +3 -3
- package/esm2022/alert-dialog/src/alert-dialog.service.mjs +3 -3
- package/esm2022/aspect-ratio/src/aspect-ratio.directive.mjs +3 -3
- package/esm2022/avatar/src/avatar-fallback.directive.mjs +3 -3
- package/esm2022/avatar/src/avatar-image.directive.mjs +3 -3
- package/esm2022/avatar/src/avatar-root.directive.mjs +3 -3
- package/esm2022/checkbox/src/checkbox-button.directive.mjs +3 -3
- package/esm2022/checkbox/src/checkbox-indicator.directive.mjs +3 -3
- package/esm2022/checkbox/src/checkbox-input.directive.mjs +7 -4
- package/esm2022/checkbox/src/checkbox.directive.mjs +3 -3
- package/esm2022/collapsible/src/collapsible-content.directive.mjs +3 -3
- package/esm2022/collapsible/src/collapsible-root.directive.mjs +3 -3
- package/esm2022/collapsible/src/collapsible-trigger.directive.mjs +3 -3
- package/esm2022/context-menu/index.mjs +4 -4
- package/esm2022/context-menu/src/context-menu-content.directive.mjs +3 -3
- package/esm2022/context-menu/src/context-menu-item-checkbox.directive.mjs +3 -3
- package/esm2022/context-menu/src/context-menu-item-indicator.directive.mjs +3 -3
- package/esm2022/context-menu/src/context-menu-item-radio-group.directive.mjs +3 -3
- package/esm2022/context-menu/src/context-menu-item-radio.directive.mjs +3 -3
- package/esm2022/context-menu/src/context-menu-item-selectable.mjs +3 -3
- package/esm2022/context-menu/src/context-menu-item.directive.mjs +3 -3
- package/esm2022/context-menu/src/context-menu-label.directive.mjs +3 -3
- package/esm2022/context-menu/src/context-menu-separator.directive.mjs +3 -3
- package/esm2022/context-menu/src/context-menu-trigger.directive.mjs +3 -3
- package/esm2022/core/src/auto-focus.directive.mjs +3 -3
- package/esm2022/dialog/index.mjs +4 -4
- package/esm2022/dialog/src/dialog-close.directive.mjs +3 -3
- package/esm2022/dialog/src/dialog-content.directive.mjs +3 -3
- package/esm2022/dialog/src/dialog-description.directive.mjs +3 -3
- package/esm2022/dialog/src/dialog-dismiss.directive.mjs +3 -3
- package/esm2022/dialog/src/dialog-title.directive.mjs +3 -3
- package/esm2022/dialog/src/dialog-trigger.directive.mjs +3 -3
- package/esm2022/dialog/src/dialog.service.mjs +3 -3
- package/esm2022/dropdown-menu/index.mjs +4 -4
- package/esm2022/dropdown-menu/src/dropdown-menu-content.directive.mjs +3 -3
- package/esm2022/dropdown-menu/src/dropdown-menu-item-checkbox.directive.mjs +3 -3
- package/esm2022/dropdown-menu/src/dropdown-menu-item-indicator.directive.mjs +3 -3
- package/esm2022/dropdown-menu/src/dropdown-menu-item-radio-group.directive.mjs +3 -3
- package/esm2022/dropdown-menu/src/dropdown-menu-item-radio.directive.mjs +3 -3
- package/esm2022/dropdown-menu/src/dropdown-menu-item-selectable.mjs +3 -3
- package/esm2022/dropdown-menu/src/dropdown-menu-item.directive.mjs +3 -3
- package/esm2022/dropdown-menu/src/dropdown-menu-label.directive.mjs +3 -3
- package/esm2022/dropdown-menu/src/dropdown-menu-separator.directive.mjs +3 -3
- package/esm2022/dropdown-menu/src/dropdown-menu-trigger.directive.mjs +3 -3
- package/esm2022/label/src/label.directive.mjs +3 -3
- package/esm2022/menu/index.mjs +4 -4
- package/esm2022/menu/src/menu-content.directive.mjs +3 -3
- package/esm2022/menu/src/menu-directive.mjs +3 -3
- package/esm2022/menu/src/menu-group.directive.mjs +3 -3
- package/esm2022/menu/src/menu-item.directive.mjs +3 -3
- package/esm2022/menu/src/menu-label.directive.mjs +3 -3
- package/esm2022/menu/src/menu-separator.directive.mjs +3 -3
- package/esm2022/menubar/index.mjs +4 -4
- package/esm2022/menubar/src/menubar-content.directive.mjs +3 -3
- package/esm2022/menubar/src/menubar-item-checkbox.directive.mjs +3 -3
- package/esm2022/menubar/src/menubar-item-indicator.directive.mjs +3 -3
- package/esm2022/menubar/src/menubar-item-radio.directive.mjs +3 -3
- package/esm2022/menubar/src/menubar-item.directive.mjs +3 -3
- package/esm2022/menubar/src/menubar-radio-group.directive.mjs +3 -3
- package/esm2022/menubar/src/menubar-root.directive.mjs +3 -3
- package/esm2022/menubar/src/menubar-separator.directive.mjs +3 -3
- package/esm2022/menubar/src/menubar-trigger.directive.mjs +3 -3
- package/esm2022/progress/index.mjs +4 -4
- package/esm2022/progress/src/progress-indicator.directive.mjs +3 -3
- package/esm2022/progress/src/progress-root.directive.mjs +3 -3
- package/esm2022/radio/src/radio-indicator.directive.mjs +3 -3
- package/esm2022/radio/src/radio-item.directive.mjs +3 -3
- package/esm2022/radio/src/radio-root.directive.mjs +3 -3
- package/esm2022/select/index.mjs +65 -0
- package/esm2022/select/radix-ng-primitives-select.mjs +5 -0
- package/esm2022/select/src/select-content.directive.mjs +53 -0
- package/esm2022/select/src/select-group.directive.mjs +18 -0
- package/esm2022/select/src/select-icon.directive.mjs +18 -0
- package/esm2022/select/src/select-item-indicator.directive.mjs +23 -0
- package/esm2022/select/src/select-item.directive.mjs +116 -0
- package/esm2022/select/src/select-label.directive.mjs +15 -0
- package/esm2022/select/src/select-separator.directive.mjs +18 -0
- package/esm2022/select/src/select-trigger.directive.mjs +38 -0
- package/esm2022/select/src/select-value.directive.mjs +21 -0
- package/esm2022/select/src/select.component.mjs +234 -0
- package/esm2022/separator/src/separator.directive.mjs +3 -3
- package/esm2022/slider/index.mjs +28 -0
- package/esm2022/slider/radix-ng-primitives-slider.mjs +5 -0
- package/esm2022/slider/src/slider-horizontal.component.mjs +117 -0
- package/esm2022/slider/src/slider-impl.directive.mjs +89 -0
- package/esm2022/slider/src/slider-orientation-context.service.mjs +28 -0
- package/esm2022/slider/src/slider-range.component.mjs +41 -0
- package/esm2022/slider/src/slider-root.component.mjs +207 -0
- package/esm2022/slider/src/slider-thumb-impl.directive.mjs +102 -0
- package/esm2022/slider/src/slider-thumb.component.mjs +22 -0
- package/esm2022/slider/src/slider-track.component.mjs +27 -0
- package/esm2022/slider/src/slider-vertical.component.mjs +117 -0
- package/esm2022/slider/src/utils.mjs +94 -0
- package/esm2022/switch/index.mjs +4 -4
- package/esm2022/switch/src/switch-input.directive.mjs +3 -3
- package/esm2022/switch/src/switch-root.directive.mjs +3 -3
- package/esm2022/switch/src/switch-thumb.directive.mjs +3 -3
- package/esm2022/tabs/index.mjs +4 -4
- package/esm2022/tabs/src/tabs-content.directive.mjs +3 -3
- package/esm2022/tabs/src/tabs-context.service.mjs +3 -3
- package/esm2022/tabs/src/tabs-list.directive.mjs +3 -3
- package/esm2022/tabs/src/tabs-root.directive.mjs +3 -3
- package/esm2022/tabs/src/tabs-trigger.directive.mjs +3 -3
- package/esm2022/toggle/src/toggle-input.directive.mjs +3 -3
- package/esm2022/toggle/src/toggle.directive.mjs +3 -3
- package/esm2022/toggle-group/src/toggle-group-item.directive.mjs +3 -3
- package/esm2022/toggle-group/src/toggle-group-multiple.directive.mjs +3 -3
- package/esm2022/toggle-group/src/toggle-group.directive.mjs +3 -3
- package/esm2022/tooltip/index.mjs +41 -0
- package/esm2022/tooltip/radix-ng-primitives-tooltip.mjs +5 -0
- package/esm2022/tooltip/src/get-content-position.mjs +31 -0
- package/esm2022/tooltip/src/tooltip-arrow.directive.mjs +92 -0
- package/esm2022/tooltip/src/tooltip-arrow.token.mjs +3 -0
- package/esm2022/tooltip/src/tooltip-content-attributes.directive.mjs +24 -0
- package/esm2022/tooltip/src/tooltip-content.directive.mjs +48 -0
- package/esm2022/tooltip/src/tooltip-content.token.mjs +3 -0
- package/esm2022/tooltip/src/tooltip-root.directive.mjs +288 -0
- package/esm2022/tooltip/src/tooltip-trigger.directive.mjs +70 -0
- package/esm2022/tooltip/src/tooltip.config.mjs +18 -0
- package/esm2022/tooltip/src/tooltip.constants.mjs +84 -0
- package/esm2022/tooltip/src/tooltip.types.mjs +14 -0
- package/esm2022/visually-hidden/src/visually-hidden-input-bubble.directive.mjs +3 -3
- package/esm2022/visually-hidden/src/visually-hidden-input.directive.mjs +3 -3
- package/esm2022/visually-hidden/src/visually-hidden.directive.mjs +3 -3
- package/fesm2022/radix-ng-primitives-accordion.mjs +19 -19
- package/fesm2022/radix-ng-primitives-alert-dialog.mjs +22 -22
- package/fesm2022/radix-ng-primitives-aspect-ratio.mjs +3 -3
- package/fesm2022/radix-ng-primitives-avatar.mjs +9 -9
- package/fesm2022/radix-ng-primitives-checkbox.mjs +15 -12
- package/fesm2022/radix-ng-primitives-checkbox.mjs.map +1 -1
- package/fesm2022/radix-ng-primitives-collapsible.mjs +9 -9
- package/fesm2022/radix-ng-primitives-context-menu.mjs +34 -34
- package/fesm2022/radix-ng-primitives-core.mjs +3 -3
- package/fesm2022/radix-ng-primitives-dialog.mjs +25 -25
- package/fesm2022/radix-ng-primitives-dropdown-menu.mjs +34 -34
- package/fesm2022/radix-ng-primitives-label.mjs +3 -3
- package/fesm2022/radix-ng-primitives-menu.mjs +22 -22
- package/fesm2022/radix-ng-primitives-menubar.mjs +31 -31
- package/fesm2022/radix-ng-primitives-progress.mjs +10 -10
- package/fesm2022/radix-ng-primitives-radio.mjs +9 -9
- package/fesm2022/radix-ng-primitives-select.mjs +572 -0
- package/fesm2022/radix-ng-primitives-select.mjs.map +1 -0
- package/fesm2022/radix-ng-primitives-separator.mjs +3 -3
- package/fesm2022/radix-ng-primitives-slider.mjs +830 -0
- package/fesm2022/radix-ng-primitives-slider.mjs.map +1 -0
- package/fesm2022/radix-ng-primitives-switch.mjs +13 -13
- package/fesm2022/radix-ng-primitives-tabs.mjs +19 -19
- package/fesm2022/radix-ng-primitives-toggle-group.mjs +9 -9
- package/fesm2022/radix-ng-primitives-toggle.mjs +6 -6
- package/fesm2022/radix-ng-primitives-tooltip.mjs +684 -0
- package/fesm2022/radix-ng-primitives-tooltip.mjs.map +1 -0
- package/fesm2022/radix-ng-primitives-visually-hidden.mjs +9 -9
- package/package.json +19 -1
- package/select/README.md +1 -0
- package/select/index.d.ts +26 -0
- package/select/src/select-content.directive.d.ts +20 -0
- package/select/src/select-group.directive.d.ts +5 -0
- package/select/src/select-icon.directive.d.ts +5 -0
- package/select/src/select-item-indicator.directive.d.ts +7 -0
- package/select/src/select-item.directive.d.ts +47 -0
- package/select/src/select-label.directive.d.ts +5 -0
- package/select/src/select-separator.directive.d.ts +5 -0
- package/select/src/select-trigger.directive.d.ts +11 -0
- package/select/src/select-value.directive.d.ts +8 -0
- package/select/src/select.component.d.ts +81 -0
- package/slider/README.md +1 -0
- package/slider/index.d.ts +18 -0
- package/slider/src/slider-horizontal.component.d.ts +29 -0
- package/slider/src/slider-impl.directive.d.ts +18 -0
- package/slider/src/slider-orientation-context.service.d.ts +14 -0
- package/slider/src/slider-range.component.d.ts +13 -0
- package/slider/src/slider-root.component.d.ts +47 -0
- package/slider/src/slider-thumb-impl.directive.d.ts +26 -0
- package/slider/src/slider-thumb.component.d.ts +6 -0
- package/slider/src/slider-track.component.d.ts +7 -0
- package/slider/src/slider-vertical.component.d.ts +29 -0
- package/slider/src/utils.d.ts +52 -0
- package/tooltip/README.md +1 -0
- package/tooltip/index.d.ts +17 -0
- package/tooltip/src/get-content-position.d.ts +3 -0
- package/tooltip/src/tooltip-arrow.directive.d.ts +25 -0
- package/tooltip/src/tooltip-arrow.token.d.ts +3 -0
- package/tooltip/src/tooltip-content-attributes.directive.d.ts +8 -0
- package/tooltip/src/tooltip-content.directive.d.ts +36 -0
- package/tooltip/src/tooltip-content.token.d.ts +3 -0
- package/tooltip/src/tooltip-root.directive.d.ts +103 -0
- package/tooltip/src/tooltip-trigger.directive.d.ts +26 -0
- package/tooltip/src/tooltip.config.d.ts +6 -0
- package/tooltip/src/tooltip.constants.d.ts +9 -0
- package/tooltip/src/tooltip.types.d.ts +18 -0
@@ -0,0 +1,288 @@
|
|
1
|
+
import { Overlay } from '@angular/cdk/overlay';
|
2
|
+
import { TemplatePortal } from '@angular/cdk/portal';
|
3
|
+
import { DOCUMENT, isPlatformBrowser } from '@angular/common';
|
4
|
+
import { computed, contentChild, DestroyRef, Directive, effect, ElementRef, forwardRef, inject, InjectionToken, input, output, PLATFORM_ID, signal, untracked, ViewContainerRef } from '@angular/core';
|
5
|
+
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
6
|
+
import { asyncScheduler, filter, take } from 'rxjs';
|
7
|
+
import { RdxTooltipContentToken } from './tooltip-content.token';
|
8
|
+
import { RdxTooltipTriggerDirective } from './tooltip-trigger.directive';
|
9
|
+
import { injectTooltipConfig } from './tooltip.config';
|
10
|
+
import * as i0 from "@angular/core";
|
11
|
+
export const RdxTooltipRootToken = new InjectionToken('RdxTooltipRootToken');
|
12
|
+
export function injectTooltipRoot() {
|
13
|
+
return inject(RdxTooltipRootToken);
|
14
|
+
}
|
15
|
+
export class RdxTooltipRootDirective {
|
16
|
+
constructor() {
|
17
|
+
/** @ignore */
|
18
|
+
this.viewContainerRef = inject(ViewContainerRef);
|
19
|
+
/** @ignore */
|
20
|
+
this.destroyRef = inject(DestroyRef);
|
21
|
+
/** @ignore */
|
22
|
+
this.overlay = inject(Overlay);
|
23
|
+
/** @ignore */
|
24
|
+
this.platformId = inject(PLATFORM_ID);
|
25
|
+
/** @ignore */
|
26
|
+
this.document = inject(DOCUMENT);
|
27
|
+
/** @ignore */
|
28
|
+
this.tooltipConfig = injectTooltipConfig();
|
29
|
+
/**
|
30
|
+
* The open state of the tooltip when it is initially rendered. Use when you do not need to control its open state.
|
31
|
+
*/
|
32
|
+
this.defaultOpen = input(false);
|
33
|
+
/**
|
34
|
+
* The controlled open state of the tooltip. Must be used in conjunction with onOpenChange.
|
35
|
+
*/
|
36
|
+
this.open = input();
|
37
|
+
/**
|
38
|
+
* Override the duration given to the configuration to customise the open delay for a specific tooltip.
|
39
|
+
*/
|
40
|
+
this.delayDuration = input(this.tooltipConfig.delayDuration);
|
41
|
+
/** @ignore */
|
42
|
+
this.disableHoverableContent = input(this.tooltipConfig.disableHoverableContent ?? false);
|
43
|
+
/**
|
44
|
+
* Event handler called when the open state of the tooltip changes.
|
45
|
+
*/
|
46
|
+
this.onOpenChange = output();
|
47
|
+
/** @ignore */
|
48
|
+
this.isOpen = signal(this.defaultOpen());
|
49
|
+
/** @ignore */
|
50
|
+
this.isOpenDelayed = signal(true);
|
51
|
+
/** @ignore */
|
52
|
+
this.wasOpenDelayed = signal(false);
|
53
|
+
/** @ignore */
|
54
|
+
this.state = computed(() => {
|
55
|
+
const currentIsOpen = this.isOpen();
|
56
|
+
const currentWasOpenDelayed = this.wasOpenDelayed();
|
57
|
+
if (currentIsOpen) {
|
58
|
+
return currentWasOpenDelayed ? 'delayed-open' : 'instant-open';
|
59
|
+
}
|
60
|
+
return 'closed';
|
61
|
+
});
|
62
|
+
/** @ignore */
|
63
|
+
this.tooltipContentDirective = contentChild.required(RdxTooltipContentToken);
|
64
|
+
/** @ignore */
|
65
|
+
this.tooltipTriggerElementRef = contentChild.required(RdxTooltipTriggerDirective, { read: ElementRef });
|
66
|
+
/** @ignore */
|
67
|
+
this.openTimer = 0;
|
68
|
+
/** @ignore */
|
69
|
+
this.skipDelayTimer = 0;
|
70
|
+
/** @ignore */
|
71
|
+
this.isControlledExternally = false;
|
72
|
+
/** @ignore */
|
73
|
+
this.onIsOpenChangeEffect = effect(() => {
|
74
|
+
const isOpen = this.isOpen();
|
75
|
+
untracked(() => {
|
76
|
+
if (isOpen) {
|
77
|
+
this.show();
|
78
|
+
}
|
79
|
+
else {
|
80
|
+
this.hide();
|
81
|
+
}
|
82
|
+
});
|
83
|
+
});
|
84
|
+
/** @ignore */
|
85
|
+
this.onPositionChangeEffect = effect(() => {
|
86
|
+
const position = this.tooltipContentDirective().position();
|
87
|
+
if (this.overlayRef) {
|
88
|
+
const positionStrategy = this.getPositionStrategy(position);
|
89
|
+
this.overlayRef.updatePositionStrategy(positionStrategy);
|
90
|
+
}
|
91
|
+
});
|
92
|
+
/** @ignore */
|
93
|
+
this.onOpenChangeEffect = effect(() => {
|
94
|
+
const currentOpen = this.open();
|
95
|
+
this.isControlledExternally = currentOpen !== undefined;
|
96
|
+
untracked(() => {
|
97
|
+
if (this.isControlledExternally) {
|
98
|
+
this.setOpen(currentOpen);
|
99
|
+
}
|
100
|
+
});
|
101
|
+
});
|
102
|
+
}
|
103
|
+
/** @ignore */
|
104
|
+
ngOnInit() {
|
105
|
+
if (this.defaultOpen()) {
|
106
|
+
this.handleOpen();
|
107
|
+
}
|
108
|
+
this.isControlledExternally = this.open() !== undefined;
|
109
|
+
}
|
110
|
+
/** @ignore */
|
111
|
+
onTriggerEnter() {
|
112
|
+
if (this.isControlledExternally) {
|
113
|
+
return;
|
114
|
+
}
|
115
|
+
if (this.isOpenDelayed()) {
|
116
|
+
this.handleDelayedOpen();
|
117
|
+
}
|
118
|
+
else {
|
119
|
+
this.handleOpen();
|
120
|
+
}
|
121
|
+
}
|
122
|
+
/** @ignore */
|
123
|
+
onTriggerLeave() {
|
124
|
+
this.clearTimeout(this.openTimer);
|
125
|
+
this.handleClose();
|
126
|
+
}
|
127
|
+
/** @ignore */
|
128
|
+
onOpen() {
|
129
|
+
this.clearTimeout(this.skipDelayTimer);
|
130
|
+
this.isOpenDelayed.set(false);
|
131
|
+
}
|
132
|
+
/** @ignore */
|
133
|
+
onClose() {
|
134
|
+
this.clearTimeout(this.skipDelayTimer);
|
135
|
+
if (isPlatformBrowser(this.platformId)) {
|
136
|
+
this.skipDelayTimer = window.setTimeout(() => {
|
137
|
+
this.isOpenDelayed.set(true);
|
138
|
+
}, this.tooltipConfig.skipDelayDuration);
|
139
|
+
}
|
140
|
+
}
|
141
|
+
/** @ignore */
|
142
|
+
handleOpen() {
|
143
|
+
if (this.isControlledExternally) {
|
144
|
+
return;
|
145
|
+
}
|
146
|
+
this.wasOpenDelayed.set(false);
|
147
|
+
this.setOpen(true);
|
148
|
+
}
|
149
|
+
/** @ignore */
|
150
|
+
handleClose() {
|
151
|
+
if (this.isControlledExternally) {
|
152
|
+
return;
|
153
|
+
}
|
154
|
+
this.clearTimeout(this.openTimer);
|
155
|
+
this.setOpen(false);
|
156
|
+
}
|
157
|
+
/** @ignore */
|
158
|
+
handleOverlayKeydown() {
|
159
|
+
if (!this.overlayRef) {
|
160
|
+
return;
|
161
|
+
}
|
162
|
+
this.overlayRef
|
163
|
+
.keydownEvents()
|
164
|
+
.pipe(filter((event) => event.key === 'Escape'), takeUntilDestroyed(this.destroyRef))
|
165
|
+
.subscribe((event) => {
|
166
|
+
this.tooltipContentDirective().onEscapeKeyDown.emit(event);
|
167
|
+
if (!event.defaultPrevented) {
|
168
|
+
this.handleClose();
|
169
|
+
}
|
170
|
+
});
|
171
|
+
}
|
172
|
+
/** @ignore */
|
173
|
+
handlePointerDownOutside() {
|
174
|
+
if (!this.overlayRef) {
|
175
|
+
return;
|
176
|
+
}
|
177
|
+
this.overlayRef
|
178
|
+
.outsidePointerEvents()
|
179
|
+
.pipe(takeUntilDestroyed(this.destroyRef))
|
180
|
+
.subscribe((event) => this.tooltipContentDirective().onPointerDownOutside.emit(event));
|
181
|
+
}
|
182
|
+
/** @ignore */
|
183
|
+
handleDelayedOpen() {
|
184
|
+
this.clearTimeout(this.openTimer);
|
185
|
+
if (isPlatformBrowser(this.platformId)) {
|
186
|
+
this.openTimer = window.setTimeout(() => {
|
187
|
+
this.wasOpenDelayed.set(true);
|
188
|
+
this.setOpen(true);
|
189
|
+
}, this.delayDuration());
|
190
|
+
}
|
191
|
+
}
|
192
|
+
/** @ignore */
|
193
|
+
setOpen(open = false) {
|
194
|
+
if (open) {
|
195
|
+
this.onOpen();
|
196
|
+
this.document.dispatchEvent(new CustomEvent('tooltip.open'));
|
197
|
+
}
|
198
|
+
else {
|
199
|
+
this.onClose();
|
200
|
+
}
|
201
|
+
this.isOpen.set(open);
|
202
|
+
this.onOpenChange.emit(open);
|
203
|
+
}
|
204
|
+
/** @ignore */
|
205
|
+
createOverlayRef() {
|
206
|
+
if (this.overlayRef) {
|
207
|
+
return this.overlayRef;
|
208
|
+
}
|
209
|
+
this.overlayRef = this.overlay.create({
|
210
|
+
direction: undefined,
|
211
|
+
positionStrategy: this.getPositionStrategy(this.tooltipContentDirective().position()),
|
212
|
+
scrollStrategy: this.overlay.scrollStrategies.close()
|
213
|
+
});
|
214
|
+
this.overlayRef
|
215
|
+
.detachments()
|
216
|
+
.pipe(take(1), takeUntilDestroyed(this.destroyRef))
|
217
|
+
.subscribe(() => this.detach());
|
218
|
+
this.handleOverlayKeydown();
|
219
|
+
this.handlePointerDownOutside();
|
220
|
+
return this.overlayRef;
|
221
|
+
}
|
222
|
+
/** @ignore */
|
223
|
+
show() {
|
224
|
+
this.overlayRef = this.createOverlayRef();
|
225
|
+
this.detach();
|
226
|
+
this.portal =
|
227
|
+
this.portal ||
|
228
|
+
new TemplatePortal(this.tooltipContentDirective().templateRef, this.viewContainerRef, {
|
229
|
+
state: this.state,
|
230
|
+
side: this.tooltipContentDirective().side
|
231
|
+
});
|
232
|
+
this.instance = this.overlayRef.attach(this.portal);
|
233
|
+
}
|
234
|
+
/** @ignore */
|
235
|
+
detach() {
|
236
|
+
if (this.overlayRef?.hasAttached()) {
|
237
|
+
this.overlayRef.detach();
|
238
|
+
}
|
239
|
+
}
|
240
|
+
/** @ignore */
|
241
|
+
hide() {
|
242
|
+
if (this.isControlledExternally && this.open()) {
|
243
|
+
return;
|
244
|
+
}
|
245
|
+
asyncScheduler.schedule(() => {
|
246
|
+
this.instance?.destroy();
|
247
|
+
}, this.tooltipConfig.hideDelayDuration ?? 0);
|
248
|
+
}
|
249
|
+
/** @ignore */
|
250
|
+
getPositionStrategy(connectedPosition) {
|
251
|
+
return this.overlay
|
252
|
+
.position()
|
253
|
+
.flexibleConnectedTo(this.tooltipTriggerElementRef())
|
254
|
+
.withFlexibleDimensions(false)
|
255
|
+
.withPositions([
|
256
|
+
connectedPosition
|
257
|
+
])
|
258
|
+
.withLockedPosition();
|
259
|
+
}
|
260
|
+
/** @ignore */
|
261
|
+
clearTimeout(timeoutId) {
|
262
|
+
if (isPlatformBrowser(this.platformId)) {
|
263
|
+
window.clearTimeout(timeoutId);
|
264
|
+
}
|
265
|
+
}
|
266
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxTooltipRootDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
267
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.2.0", version: "18.2.11", type: RdxTooltipRootDirective, isStandalone: true, selector: "[rdxTooltipRoot]", inputs: { defaultOpen: { classPropertyName: "defaultOpen", publicName: "defaultOpen", isSignal: true, isRequired: false, transformFunction: null }, open: { classPropertyName: "open", publicName: "open", isSignal: true, isRequired: false, transformFunction: null }, delayDuration: { classPropertyName: "delayDuration", publicName: "delayDuration", isSignal: true, isRequired: false, transformFunction: null }, disableHoverableContent: { classPropertyName: "disableHoverableContent", publicName: "disableHoverableContent", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { onOpenChange: "onOpenChange" }, providers: [
|
268
|
+
{
|
269
|
+
provide: RdxTooltipRootToken,
|
270
|
+
useExisting: forwardRef(() => RdxTooltipRootDirective)
|
271
|
+
}
|
272
|
+
], queries: [{ propertyName: "tooltipContentDirective", first: true, predicate: RdxTooltipContentToken, descendants: true, isSignal: true }, { propertyName: "tooltipTriggerElementRef", first: true, predicate: RdxTooltipTriggerDirective, descendants: true, read: ElementRef, isSignal: true }], exportAs: ["rdxTooltipRoot"], ngImport: i0 }); }
|
273
|
+
}
|
274
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxTooltipRootDirective, decorators: [{
|
275
|
+
type: Directive,
|
276
|
+
args: [{
|
277
|
+
selector: '[rdxTooltipRoot]',
|
278
|
+
standalone: true,
|
279
|
+
providers: [
|
280
|
+
{
|
281
|
+
provide: RdxTooltipRootToken,
|
282
|
+
useExisting: forwardRef(() => RdxTooltipRootDirective)
|
283
|
+
}
|
284
|
+
],
|
285
|
+
exportAs: 'rdxTooltipRoot'
|
286
|
+
}]
|
287
|
+
}] });
|
288
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip-root.directive.js","sourceRoot":"","sources":["../../../../../packages/primitives/tooltip/src/tooltip-root.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { ConnectedPosition, Overlay, OverlayRef, PositionStrategy } from '@angular/cdk/overlay';\nimport { TemplatePortal } from '@angular/cdk/portal';\nimport { DOCUMENT, isPlatformBrowser } from '@angular/common';\nimport {\n    computed,\n    contentChild,\n    DestroyRef,\n    Directive,\n    effect,\n    ElementRef,\n    forwardRef,\n    inject,\n    InjectionToken,\n    input,\n    OnInit,\n    output,\n    PLATFORM_ID,\n    signal,\n    untracked,\n    ViewContainerRef,\n    ViewRef\n} from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { asyncScheduler, filter, take } from 'rxjs';\nimport { RdxTooltipContentToken } from './tooltip-content.token';\nimport { RdxTooltipTriggerDirective } from './tooltip-trigger.directive';\nimport { injectTooltipConfig } from './tooltip.config';\nimport { RdxTooltipState } from './tooltip.types';\n\nexport const RdxTooltipRootToken = new InjectionToken<RdxTooltipRootDirective>('RdxTooltipRootToken');\n\nexport function injectTooltipRoot(): RdxTooltipRootDirective {\n    return inject(RdxTooltipRootToken);\n}\n\n@Directive({\n    selector: '[rdxTooltipRoot]',\n    standalone: true,\n    providers: [\n        {\n            provide: RdxTooltipRootToken,\n            useExisting: forwardRef(() => RdxTooltipRootDirective)\n        }\n    ],\n    exportAs: 'rdxTooltipRoot'\n})\nexport class RdxTooltipRootDirective implements OnInit {\n    /** @ignore */\n    private readonly viewContainerRef = inject(ViewContainerRef);\n    /** @ignore */\n    private readonly destroyRef = inject(DestroyRef);\n    /** @ignore */\n    private readonly overlay = inject(Overlay);\n    /** @ignore */\n    private readonly platformId = inject(PLATFORM_ID);\n    /** @ignore */\n    private readonly document = inject(DOCUMENT);\n    /** @ignore */\n    readonly tooltipConfig = injectTooltipConfig();\n\n    /**\n     * The open state of the tooltip when it is initially rendered. Use when you do not need to control its open state.\n     */\n    readonly defaultOpen = input<boolean>(false);\n\n    /**\n     * The controlled open state of the tooltip. Must be used in conjunction with onOpenChange.\n     */\n    readonly open = input<boolean | undefined>();\n\n    /**\n     * Override the duration given to the configuration to customise the open delay for a specific tooltip.\n     */\n    readonly delayDuration = input<number>(this.tooltipConfig.delayDuration);\n\n    /** @ignore */\n    readonly disableHoverableContent = input<boolean>(this.tooltipConfig.disableHoverableContent ?? false);\n\n    /**\n     * Event handler called when the open state of the tooltip changes.\n     */\n    readonly onOpenChange = output<boolean>();\n\n    /** @ignore */\n    readonly isOpen = signal<boolean>(this.defaultOpen());\n    /** @ignore */\n    readonly isOpenDelayed = signal<boolean>(true);\n    /** @ignore */\n    readonly wasOpenDelayed = signal<boolean>(false);\n    /** @ignore */\n    readonly state = computed<RdxTooltipState>(() => {\n        const currentIsOpen = this.isOpen();\n        const currentWasOpenDelayed = this.wasOpenDelayed();\n\n        if (currentIsOpen) {\n            return currentWasOpenDelayed ? 'delayed-open' : 'instant-open';\n        }\n\n        return 'closed';\n    });\n    /** @ignore */\n    readonly tooltipContentDirective = contentChild.required(RdxTooltipContentToken);\n    /** @ignore */\n    readonly tooltipTriggerElementRef = contentChild.required(RdxTooltipTriggerDirective, { read: ElementRef });\n\n    /** @ignore */\n    private openTimer = 0;\n    /** @ignore */\n    private skipDelayTimer = 0;\n    /** @ignore */\n    private overlayRef?: OverlayRef;\n    /** @ignore */\n    private instance?: ViewRef;\n    /** @ignore */\n    private portal: TemplatePortal<unknown>;\n    /** @ignore */\n    private isControlledExternally = false;\n\n    /** @ignore */\n    ngOnInit(): void {\n        if (this.defaultOpen()) {\n            this.handleOpen();\n        }\n\n        this.isControlledExternally = this.open() !== undefined;\n    }\n\n    /** @ignore */\n    onTriggerEnter(): void {\n        if (this.isControlledExternally) {\n            return;\n        }\n\n        if (this.isOpenDelayed()) {\n            this.handleDelayedOpen();\n        } else {\n            this.handleOpen();\n        }\n    }\n\n    /** @ignore */\n    onTriggerLeave(): void {\n        this.clearTimeout(this.openTimer);\n        this.handleClose();\n    }\n\n    /** @ignore */\n    onOpen(): void {\n        this.clearTimeout(this.skipDelayTimer);\n        this.isOpenDelayed.set(false);\n    }\n\n    /** @ignore */\n    onClose(): void {\n        this.clearTimeout(this.skipDelayTimer);\n\n        if (isPlatformBrowser(this.platformId)) {\n            this.skipDelayTimer = window.setTimeout(() => {\n                this.isOpenDelayed.set(true);\n            }, this.tooltipConfig.skipDelayDuration);\n        }\n    }\n\n    /** @ignore */\n    handleOpen(): void {\n        if (this.isControlledExternally) {\n            return;\n        }\n\n        this.wasOpenDelayed.set(false);\n        this.setOpen(true);\n    }\n\n    /** @ignore */\n    handleClose(): void {\n        if (this.isControlledExternally) {\n            return;\n        }\n\n        this.clearTimeout(this.openTimer);\n        this.setOpen(false);\n    }\n\n    /** @ignore */\n    private handleOverlayKeydown(): void {\n        if (!this.overlayRef) {\n            return;\n        }\n\n        this.overlayRef\n            .keydownEvents()\n            .pipe(\n                filter((event) => event.key === 'Escape'),\n                takeUntilDestroyed(this.destroyRef)\n            )\n            .subscribe((event) => {\n                this.tooltipContentDirective().onEscapeKeyDown.emit(event);\n\n                if (!event.defaultPrevented) {\n                    this.handleClose();\n                }\n            });\n    }\n\n    /** @ignore */\n    private handlePointerDownOutside(): void {\n        if (!this.overlayRef) {\n            return;\n        }\n\n        this.overlayRef\n            .outsidePointerEvents()\n            .pipe(takeUntilDestroyed(this.destroyRef))\n            .subscribe((event) => this.tooltipContentDirective().onPointerDownOutside.emit(event));\n    }\n\n    /** @ignore */\n    private handleDelayedOpen(): void {\n        this.clearTimeout(this.openTimer);\n\n        if (isPlatformBrowser(this.platformId)) {\n            this.openTimer = window.setTimeout(() => {\n                this.wasOpenDelayed.set(true);\n                this.setOpen(true);\n            }, this.delayDuration());\n        }\n    }\n\n    /** @ignore */\n    private setOpen(open = false): void {\n        if (open) {\n            this.onOpen();\n\n            this.document.dispatchEvent(new CustomEvent('tooltip.open'));\n        } else {\n            this.onClose();\n        }\n\n        this.isOpen.set(open);\n        this.onOpenChange.emit(open);\n    }\n\n    /** @ignore */\n    private createOverlayRef(): OverlayRef {\n        if (this.overlayRef) {\n            return this.overlayRef;\n        }\n\n        this.overlayRef = this.overlay.create({\n            direction: undefined,\n            positionStrategy: this.getPositionStrategy(this.tooltipContentDirective().position()),\n            scrollStrategy: this.overlay.scrollStrategies.close()\n        });\n\n        this.overlayRef\n            .detachments()\n            .pipe(take(1), takeUntilDestroyed(this.destroyRef))\n            .subscribe(() => this.detach());\n\n        this.handleOverlayKeydown();\n        this.handlePointerDownOutside();\n\n        return this.overlayRef;\n    }\n\n    /** @ignore */\n    private show(): void {\n        this.overlayRef = this.createOverlayRef();\n\n        this.detach();\n\n        this.portal =\n            this.portal ||\n            new TemplatePortal(this.tooltipContentDirective().templateRef, this.viewContainerRef, {\n                state: this.state,\n                side: this.tooltipContentDirective().side\n            });\n\n        this.instance = this.overlayRef.attach(this.portal);\n    }\n\n    /** @ignore */\n    private detach(): void {\n        if (this.overlayRef?.hasAttached()) {\n            this.overlayRef.detach();\n        }\n    }\n\n    /** @ignore */\n    private hide(): void {\n        if (this.isControlledExternally && this.open()) {\n            return;\n        }\n\n        asyncScheduler.schedule(() => {\n            this.instance?.destroy();\n        }, this.tooltipConfig.hideDelayDuration ?? 0);\n    }\n\n    /** @ignore */\n    private getPositionStrategy(connectedPosition: ConnectedPosition): PositionStrategy {\n        return this.overlay\n            .position()\n            .flexibleConnectedTo(this.tooltipTriggerElementRef())\n            .withFlexibleDimensions(false)\n            .withPositions([\n                connectedPosition\n            ])\n            .withLockedPosition();\n    }\n\n    /** @ignore */\n    private clearTimeout(timeoutId: number): void {\n        if (isPlatformBrowser(this.platformId)) {\n            window.clearTimeout(timeoutId);\n        }\n    }\n\n    /** @ignore */\n    private readonly onIsOpenChangeEffect = effect(() => {\n        const isOpen = this.isOpen();\n\n        untracked(() => {\n            if (isOpen) {\n                this.show();\n            } else {\n                this.hide();\n            }\n        });\n    });\n\n    /** @ignore */\n    private readonly onPositionChangeEffect = effect(() => {\n        const position = this.tooltipContentDirective().position();\n\n        if (this.overlayRef) {\n            const positionStrategy = this.getPositionStrategy(position);\n\n            this.overlayRef.updatePositionStrategy(positionStrategy);\n        }\n    });\n\n    /** @ignore */\n    private readonly onOpenChangeEffect = effect(() => {\n        const currentOpen = this.open();\n        this.isControlledExternally = currentOpen !== undefined;\n\n        untracked(() => {\n            if (this.isControlledExternally) {\n                this.setOpen(currentOpen);\n            }\n        });\n    });\n}\n"]}
|
@@ -0,0 +1,70 @@
|
|
1
|
+
import { Directive, ElementRef, inject } from '@angular/core';
|
2
|
+
import { injectTooltipRoot } from './tooltip-root.directive';
|
3
|
+
import * as i0 from "@angular/core";
|
4
|
+
export class RdxTooltipTriggerDirective {
|
5
|
+
constructor() {
|
6
|
+
/** @ignore */
|
7
|
+
this.tooltipRoot = injectTooltipRoot();
|
8
|
+
/** @ignore */
|
9
|
+
this.elementRef = inject((ElementRef));
|
10
|
+
/** @ignore */
|
11
|
+
this.isPointerDown = false;
|
12
|
+
/** @ignore */
|
13
|
+
this.isPointerInside = false;
|
14
|
+
}
|
15
|
+
/** @ignore */
|
16
|
+
onPointerMove(event) {
|
17
|
+
if (event.pointerType === 'touch') {
|
18
|
+
return;
|
19
|
+
}
|
20
|
+
if (!this.isPointerInside) {
|
21
|
+
this.tooltipRoot.onTriggerEnter();
|
22
|
+
this.isPointerInside = true;
|
23
|
+
}
|
24
|
+
}
|
25
|
+
/** @ignore */
|
26
|
+
onPointerLeave() {
|
27
|
+
this.isPointerInside = false;
|
28
|
+
this.tooltipRoot.onTriggerLeave();
|
29
|
+
}
|
30
|
+
/** @ignore */
|
31
|
+
onPointerDown() {
|
32
|
+
this.isPointerDown = true;
|
33
|
+
this.elementRef.nativeElement.addEventListener('pointerup', () => {
|
34
|
+
this.isPointerDown = false;
|
35
|
+
}, { once: true });
|
36
|
+
}
|
37
|
+
/** @ignore */
|
38
|
+
onFocus() {
|
39
|
+
if (!this.isPointerDown) {
|
40
|
+
this.tooltipRoot.handleOpen();
|
41
|
+
}
|
42
|
+
}
|
43
|
+
/** @ignore */
|
44
|
+
onBlur() {
|
45
|
+
this.tooltipRoot.handleClose();
|
46
|
+
}
|
47
|
+
/** @ignore */
|
48
|
+
onClick() {
|
49
|
+
this.tooltipRoot.handleClose();
|
50
|
+
}
|
51
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxTooltipTriggerDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
52
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.11", type: RdxTooltipTriggerDirective, isStandalone: true, selector: "[rdxTooltipTrigger]", host: { listeners: { "pointermove": "onPointerMove($event)", "pointerleave": "onPointerLeave()", "pointerdown": "onPointerDown()", "focus": "onFocus()", "blur": "onBlur()", "click": "onClick()" }, properties: { "attr.data-state": "tooltipRoot.state()" } }, ngImport: i0 }); }
|
53
|
+
}
|
54
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxTooltipTriggerDirective, decorators: [{
|
55
|
+
type: Directive,
|
56
|
+
args: [{
|
57
|
+
selector: '[rdxTooltipTrigger]',
|
58
|
+
standalone: true,
|
59
|
+
host: {
|
60
|
+
'[attr.data-state]': 'tooltipRoot.state()',
|
61
|
+
'(pointermove)': 'onPointerMove($event)',
|
62
|
+
'(pointerleave)': 'onPointerLeave()',
|
63
|
+
'(pointerdown)': 'onPointerDown()',
|
64
|
+
'(focus)': 'onFocus()',
|
65
|
+
'(blur)': 'onBlur()',
|
66
|
+
'(click)': 'onClick()'
|
67
|
+
}
|
68
|
+
}]
|
69
|
+
}] });
|
70
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbHRpcC10cmlnZ2VyLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3ByaW1pdGl2ZXMvdG9vbHRpcC9zcmMvdG9vbHRpcC10cmlnZ2VyLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDOUQsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7O0FBZTdELE1BQU0sT0FBTywwQkFBMEI7SUFidkM7UUFjSSxjQUFjO1FBQ0wsZ0JBQVcsR0FBRyxpQkFBaUIsRUFBRSxDQUFDO1FBQzNDLGNBQWM7UUFDTCxlQUFVLEdBQUcsTUFBTSxDQUEwQixDQUFBLFVBQXVCLENBQUEsQ0FBQyxDQUFDO1FBRS9FLGNBQWM7UUFDTixrQkFBYSxHQUFHLEtBQUssQ0FBQztRQUM5QixjQUFjO1FBQ04sb0JBQWUsR0FBRyxLQUFLLENBQUM7S0FpRG5DO0lBL0NHLGNBQWM7SUFDZCxhQUFhLENBQUMsS0FBbUI7UUFDN0IsSUFBSSxLQUFLLENBQUMsV0FBVyxLQUFLLE9BQU8sRUFBRSxDQUFDO1lBQ2hDLE9BQU87UUFDWCxDQUFDO1FBRUQsSUFBSSxDQUFDLElBQUksQ0FBQyxlQUFlLEVBQUUsQ0FBQztZQUN4QixJQUFJLENBQUMsV0FBVyxDQUFDLGNBQWMsRUFBRSxDQUFDO1lBQ2xDLElBQUksQ0FBQyxlQUFlLEdBQUcsSUFBSSxDQUFDO1FBQ2hDLENBQUM7SUFDTCxDQUFDO0lBRUQsY0FBYztJQUNkLGNBQWM7UUFDVixJQUFJLENBQUMsZUFBZSxHQUFHLEtBQUssQ0FBQztRQUM3QixJQUFJLENBQUMsV0FBVyxDQUFDLGNBQWMsRUFBRSxDQUFDO0lBQ3RDLENBQUM7SUFFRCxjQUFjO0lBQ2QsYUFBYTtRQUNULElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxDQUFDO1FBRTFCLElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYSxDQUFDLGdCQUFnQixDQUMxQyxXQUFXLEVBQ1gsR0FBRyxFQUFFO1lBQ0QsSUFBSSxDQUFDLGFBQWEsR0FBRyxLQUFLLENBQUM7UUFDL0IsQ0FBQyxFQUNELEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxDQUNqQixDQUFDO0lBQ04sQ0FBQztJQUVELGNBQWM7SUFDZCxPQUFPO1FBQ0gsSUFBSSxDQUFDLElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQztZQUN0QixJQUFJLENBQUMsV0FBVyxDQUFDLFVBQVUsRUFBRSxDQUFDO1FBQ2xDLENBQUM7SUFDTCxDQUFDO0lBRUQsY0FBYztJQUNkLE1BQU07UUFDRixJQUFJLENBQUMsV0FBVyxDQUFDLFdBQVcsRUFBRSxDQUFDO0lBQ25DLENBQUM7SUFFRCxjQUFjO0lBQ2QsT0FBTztRQUNILElBQUksQ0FBQyxXQUFXLENBQUMsV0FBVyxFQUFFLENBQUM7SUFDbkMsQ0FBQzsrR0F6RFEsMEJBQTBCO21HQUExQiwwQkFBMEI7OzRGQUExQiwwQkFBMEI7a0JBYnRDLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLHFCQUFxQjtvQkFDL0IsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLElBQUksRUFBRTt3QkFDRixtQkFBbUIsRUFBRSxxQkFBcUI7d0JBQzFDLGVBQWUsRUFBRSx1QkFBdUI7d0JBQ3hDLGdCQUFnQixFQUFFLGtCQUFrQjt3QkFDcEMsZUFBZSxFQUFFLGlCQUFpQjt3QkFDbEMsU0FBUyxFQUFFLFdBQVc7d0JBQ3RCLFFBQVEsRUFBRSxVQUFVO3dCQUNwQixTQUFTLEVBQUUsV0FBVztxQkFDekI7aUJBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIEVsZW1lbnRSZWYsIGluamVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgaW5qZWN0VG9vbHRpcFJvb3QgfSBmcm9tICcuL3Rvb2x0aXAtcm9vdC5kaXJlY3RpdmUnO1xuXG5ARGlyZWN0aXZlKHtcbiAgICBzZWxlY3RvcjogJ1tyZHhUb29sdGlwVHJpZ2dlcl0nLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgaG9zdDoge1xuICAgICAgICAnW2F0dHIuZGF0YS1zdGF0ZV0nOiAndG9vbHRpcFJvb3Quc3RhdGUoKScsXG4gICAgICAgICcocG9pbnRlcm1vdmUpJzogJ29uUG9pbnRlck1vdmUoJGV2ZW50KScsXG4gICAgICAgICcocG9pbnRlcmxlYXZlKSc6ICdvblBvaW50ZXJMZWF2ZSgpJyxcbiAgICAgICAgJyhwb2ludGVyZG93biknOiAnb25Qb2ludGVyRG93bigpJyxcbiAgICAgICAgJyhmb2N1cyknOiAnb25Gb2N1cygpJyxcbiAgICAgICAgJyhibHVyKSc6ICdvbkJsdXIoKScsXG4gICAgICAgICcoY2xpY2spJzogJ29uQ2xpY2soKSdcbiAgICB9XG59KVxuZXhwb3J0IGNsYXNzIFJkeFRvb2x0aXBUcmlnZ2VyRGlyZWN0aXZlIHtcbiAgICAvKiogQGlnbm9yZSAqL1xuICAgIHJlYWRvbmx5IHRvb2x0aXBSb290ID0gaW5qZWN0VG9vbHRpcFJvb3QoKTtcbiAgICAvKiogQGlnbm9yZSAqL1xuICAgIHJlYWRvbmx5IGVsZW1lbnRSZWYgPSBpbmplY3Q8RWxlbWVudFJlZjxIVE1MRWxlbWVudD4+KEVsZW1lbnRSZWY8SFRNTEVsZW1lbnQ+KTtcblxuICAgIC8qKiBAaWdub3JlICovXG4gICAgcHJpdmF0ZSBpc1BvaW50ZXJEb3duID0gZmFsc2U7XG4gICAgLyoqIEBpZ25vcmUgKi9cbiAgICBwcml2YXRlIGlzUG9pbnRlckluc2lkZSA9IGZhbHNlO1xuXG4gICAgLyoqIEBpZ25vcmUgKi9cbiAgICBvblBvaW50ZXJNb3ZlKGV2ZW50OiBQb2ludGVyRXZlbnQpOiB2b2lkIHtcbiAgICAgICAgaWYgKGV2ZW50LnBvaW50ZXJUeXBlID09PSAndG91Y2gnKSB7XG4gICAgICAgICAgICByZXR1cm47XG4gICAgICAgIH1cblxuICAgICAgICBpZiAoIXRoaXMuaXNQb2ludGVySW5zaWRlKSB7XG4gICAgICAgICAgICB0aGlzLnRvb2x0aXBSb290Lm9uVHJpZ2dlckVudGVyKCk7XG4gICAgICAgICAgICB0aGlzLmlzUG9pbnRlckluc2lkZSA9IHRydWU7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICAvKiogQGlnbm9yZSAqL1xuICAgIG9uUG9pbnRlckxlYXZlKCk6IHZvaWQge1xuICAgICAgICB0aGlzLmlzUG9pbnRlckluc2lkZSA9IGZhbHNlO1xuICAgICAgICB0aGlzLnRvb2x0aXBSb290Lm9uVHJpZ2dlckxlYXZlKCk7XG4gICAgfVxuXG4gICAgLyoqIEBpZ25vcmUgKi9cbiAgICBvblBvaW50ZXJEb3duKCk6IHZvaWQge1xuICAgICAgICB0aGlzLmlzUG9pbnRlckRvd24gPSB0cnVlO1xuXG4gICAgICAgIHRoaXMuZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50LmFkZEV2ZW50TGlzdGVuZXIoXG4gICAgICAgICAgICAncG9pbnRlcnVwJyxcbiAgICAgICAgICAgICgpID0+IHtcbiAgICAgICAgICAgICAgICB0aGlzLmlzUG9pbnRlckRvd24gPSBmYWxzZTtcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICB7IG9uY2U6IHRydWUgfVxuICAgICAgICApO1xuICAgIH1cblxuICAgIC8qKiBAaWdub3JlICovXG4gICAgb25Gb2N1cygpOiB2b2lkIHtcbiAgICAgICAgaWYgKCF0aGlzLmlzUG9pbnRlckRvd24pIHtcbiAgICAgICAgICAgIHRoaXMudG9vbHRpcFJvb3QuaGFuZGxlT3BlbigpO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgLyoqIEBpZ25vcmUgKi9cbiAgICBvbkJsdXIoKTogdm9pZCB7XG4gICAgICAgIHRoaXMudG9vbHRpcFJvb3QuaGFuZGxlQ2xvc2UoKTtcbiAgICB9XG5cbiAgICAvKiogQGlnbm9yZSAqL1xuICAgIG9uQ2xpY2soKTogdm9pZCB7XG4gICAgICAgIHRoaXMudG9vbHRpcFJvb3QuaGFuZGxlQ2xvc2UoKTtcbiAgICB9XG59XG4iXX0=
|
@@ -0,0 +1,18 @@
|
|
1
|
+
import { inject, InjectionToken } from '@angular/core';
|
2
|
+
export const defaultTooltipConfig = {
|
3
|
+
delayDuration: 700,
|
4
|
+
skipDelayDuration: 300
|
5
|
+
};
|
6
|
+
export const RdxTooltipConfigToken = new InjectionToken('RdxTooltipConfigToken');
|
7
|
+
export function provideRdxTooltipConfig(config) {
|
8
|
+
return [
|
9
|
+
{
|
10
|
+
provide: RdxTooltipConfigToken,
|
11
|
+
useValue: { ...defaultTooltipConfig, ...config }
|
12
|
+
}
|
13
|
+
];
|
14
|
+
}
|
15
|
+
export function injectTooltipConfig() {
|
16
|
+
return inject(RdxTooltipConfigToken, { optional: true }) ?? defaultTooltipConfig;
|
17
|
+
}
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbHRpcC5jb25maWcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9wcmltaXRpdmVzL3Rvb2x0aXAvc3JjL3Rvb2x0aXAuY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxNQUFNLEVBQUUsY0FBYyxFQUFZLE1BQU0sZUFBZSxDQUFDO0FBR2pFLE1BQU0sQ0FBQyxNQUFNLG9CQUFvQixHQUFxQjtJQUNsRCxhQUFhLEVBQUUsR0FBRztJQUNsQixpQkFBaUIsRUFBRSxHQUFHO0NBQ3pCLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxxQkFBcUIsR0FBRyxJQUFJLGNBQWMsQ0FBbUIsdUJBQXVCLENBQUMsQ0FBQztBQUVuRyxNQUFNLFVBQVUsdUJBQXVCLENBQUMsTUFBaUM7SUFDckUsT0FBTztRQUNIO1lBQ0ksT0FBTyxFQUFFLHFCQUFxQjtZQUM5QixRQUFRLEVBQUUsRUFBRSxHQUFHLG9CQUFvQixFQUFFLEdBQUcsTUFBTSxFQUFFO1NBQ25EO0tBQ0osQ0FBQztBQUNOLENBQUM7QUFFRCxNQUFNLFVBQVUsbUJBQW1CO0lBQy9CLE9BQU8sTUFBTSxDQUFDLHFCQUFxQixFQUFFLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRSxDQUFDLElBQUksb0JBQW9CLENBQUM7QUFDckYsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGluamVjdCwgSW5qZWN0aW9uVG9rZW4sIFByb3ZpZGVyIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBSZHhUb29sdGlwQ29uZmlnIH0gZnJvbSAnLi90b29sdGlwLnR5cGVzJztcblxuZXhwb3J0IGNvbnN0IGRlZmF1bHRUb29sdGlwQ29uZmlnOiBSZHhUb29sdGlwQ29uZmlnID0ge1xuICAgIGRlbGF5RHVyYXRpb246IDcwMCxcbiAgICBza2lwRGVsYXlEdXJhdGlvbjogMzAwXG59O1xuXG5leHBvcnQgY29uc3QgUmR4VG9vbHRpcENvbmZpZ1Rva2VuID0gbmV3IEluamVjdGlvblRva2VuPFJkeFRvb2x0aXBDb25maWc+KCdSZHhUb29sdGlwQ29uZmlnVG9rZW4nKTtcblxuZXhwb3J0IGZ1bmN0aW9uIHByb3ZpZGVSZHhUb29sdGlwQ29uZmlnKGNvbmZpZzogUGFydGlhbDxSZHhUb29sdGlwQ29uZmlnPik6IFByb3ZpZGVyW10ge1xuICAgIHJldHVybiBbXG4gICAgICAgIHtcbiAgICAgICAgICAgIHByb3ZpZGU6IFJkeFRvb2x0aXBDb25maWdUb2tlbixcbiAgICAgICAgICAgIHVzZVZhbHVlOiB7IC4uLmRlZmF1bHRUb29sdGlwQ29uZmlnLCAuLi5jb25maWcgfVxuICAgICAgICB9XG4gICAgXTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGluamVjdFRvb2x0aXBDb25maWcoKTogUmR4VG9vbHRpcENvbmZpZyB7XG4gICAgcmV0dXJuIGluamVjdChSZHhUb29sdGlwQ29uZmlnVG9rZW4sIHsgb3B0aW9uYWw6IHRydWUgfSkgPz8gZGVmYXVsdFRvb2x0aXBDb25maWc7XG59XG4iXX0=
|
@@ -0,0 +1,84 @@
|
|
1
|
+
import { RdxTooltipAlign, RdxTooltipSide } from './tooltip.types';
|
2
|
+
export const TOOLTIP_POSITIONS = {
|
3
|
+
[RdxTooltipSide.Top]: {
|
4
|
+
[RdxTooltipAlign.Center]: {
|
5
|
+
originX: 'center',
|
6
|
+
originY: 'top',
|
7
|
+
overlayX: 'center',
|
8
|
+
overlayY: 'bottom'
|
9
|
+
},
|
10
|
+
[RdxTooltipAlign.Start]: {
|
11
|
+
originX: 'start',
|
12
|
+
originY: 'top',
|
13
|
+
overlayX: 'start',
|
14
|
+
overlayY: 'bottom'
|
15
|
+
},
|
16
|
+
[RdxTooltipAlign.End]: {
|
17
|
+
originX: 'end',
|
18
|
+
originY: 'top',
|
19
|
+
overlayX: 'end',
|
20
|
+
overlayY: 'bottom'
|
21
|
+
}
|
22
|
+
},
|
23
|
+
[RdxTooltipSide.Right]: {
|
24
|
+
[RdxTooltipAlign.Center]: {
|
25
|
+
originX: 'end',
|
26
|
+
originY: 'center',
|
27
|
+
overlayX: 'start',
|
28
|
+
overlayY: 'center'
|
29
|
+
},
|
30
|
+
[RdxTooltipAlign.Start]: {
|
31
|
+
originX: 'end',
|
32
|
+
originY: 'top',
|
33
|
+
overlayX: 'start',
|
34
|
+
overlayY: 'top'
|
35
|
+
},
|
36
|
+
[RdxTooltipAlign.End]: {
|
37
|
+
originX: 'end',
|
38
|
+
originY: 'bottom',
|
39
|
+
overlayX: 'start',
|
40
|
+
overlayY: 'bottom'
|
41
|
+
}
|
42
|
+
},
|
43
|
+
[RdxTooltipSide.Bottom]: {
|
44
|
+
[RdxTooltipAlign.Center]: {
|
45
|
+
originX: 'center',
|
46
|
+
originY: 'bottom',
|
47
|
+
overlayX: 'center',
|
48
|
+
overlayY: 'top'
|
49
|
+
},
|
50
|
+
[RdxTooltipAlign.Start]: {
|
51
|
+
originX: 'start',
|
52
|
+
originY: 'bottom',
|
53
|
+
overlayX: 'start',
|
54
|
+
overlayY: 'top'
|
55
|
+
},
|
56
|
+
[RdxTooltipAlign.End]: {
|
57
|
+
originX: 'end',
|
58
|
+
originY: 'bottom',
|
59
|
+
overlayX: 'end',
|
60
|
+
overlayY: 'top'
|
61
|
+
}
|
62
|
+
},
|
63
|
+
[RdxTooltipSide.Left]: {
|
64
|
+
[RdxTooltipAlign.Center]: {
|
65
|
+
originX: 'start',
|
66
|
+
originY: 'center',
|
67
|
+
overlayX: 'end',
|
68
|
+
overlayY: 'center'
|
69
|
+
},
|
70
|
+
[RdxTooltipAlign.Start]: {
|
71
|
+
originX: 'start',
|
72
|
+
originY: 'top',
|
73
|
+
overlayX: 'end',
|
74
|
+
overlayY: 'top'
|
75
|
+
},
|
76
|
+
[RdxTooltipAlign.End]: {
|
77
|
+
originX: 'start',
|
78
|
+
originY: 'bottom',
|
79
|
+
overlayX: 'end',
|
80
|
+
overlayY: 'bottom'
|
81
|
+
}
|
82
|
+
}
|
83
|
+
};
|
84
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbHRpcC5jb25zdGFudHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9wcmltaXRpdmVzL3Rvb2x0aXAvc3JjL3Rvb2x0aXAuY29uc3RhbnRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxlQUFlLEVBQUUsY0FBYyxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFRbEUsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQXFCO0lBQy9DLENBQUMsY0FBYyxDQUFDLEdBQUcsQ0FBQyxFQUFFO1FBQ2xCLENBQUMsZUFBZSxDQUFDLE1BQU0sQ0FBQyxFQUFFO1lBQ3RCLE9BQU8sRUFBRSxRQUFRO1lBQ2pCLE9BQU8sRUFBRSxLQUFLO1lBQ2QsUUFBUSxFQUFFLFFBQVE7WUFDbEIsUUFBUSxFQUFFLFFBQVE7U0FDckI7UUFDRCxDQUFDLGVBQWUsQ0FBQyxLQUFLLENBQUMsRUFBRTtZQUNyQixPQUFPLEVBQUUsT0FBTztZQUNoQixPQUFPLEVBQUUsS0FBSztZQUNkLFFBQVEsRUFBRSxPQUFPO1lBQ2pCLFFBQVEsRUFBRSxRQUFRO1NBQ3JCO1FBQ0QsQ0FBQyxlQUFlLENBQUMsR0FBRyxDQUFDLEVBQUU7WUFDbkIsT0FBTyxFQUFFLEtBQUs7WUFDZCxPQUFPLEVBQUUsS0FBSztZQUNkLFFBQVEsRUFBRSxLQUFLO1lBQ2YsUUFBUSxFQUFFLFFBQVE7U0FDckI7S0FDSjtJQUNELENBQUMsY0FBYyxDQUFDLEtBQUssQ0FBQyxFQUFFO1FBQ3BCLENBQUMsZUFBZSxDQUFDLE1BQU0sQ0FBQyxFQUFFO1lBQ3RCLE9BQU8sRUFBRSxLQUFLO1lBQ2QsT0FBTyxFQUFFLFFBQVE7WUFDakIsUUFBUSxFQUFFLE9BQU87WUFDakIsUUFBUSxFQUFFLFFBQVE7U0FDckI7UUFDRCxDQUFDLGVBQWUsQ0FBQyxLQUFLLENBQUMsRUFBRTtZQUNyQixPQUFPLEVBQUUsS0FBSztZQUNkLE9BQU8sRUFBRSxLQUFLO1lBQ2QsUUFBUSxFQUFFLE9BQU87WUFDakIsUUFBUSxFQUFFLEtBQUs7U0FDbEI7UUFDRCxDQUFDLGVBQWUsQ0FBQyxHQUFHLENBQUMsRUFBRTtZQUNuQixPQUFPLEVBQUUsS0FBSztZQUNkLE9BQU8sRUFBRSxRQUFRO1lBQ2pCLFFBQVEsRUFBRSxPQUFPO1lBQ2pCLFFBQVEsRUFBRSxRQUFRO1NBQ3JCO0tBQ0o7SUFDRCxDQUFDLGNBQWMsQ0FBQyxNQUFNLENBQUMsRUFBRTtRQUNyQixDQUFDLGVBQWUsQ0FBQyxNQUFNLENBQUMsRUFBRTtZQUN0QixPQUFPLEVBQUUsUUFBUTtZQUNqQixPQUFPLEVBQUUsUUFBUTtZQUNqQixRQUFRLEVBQUUsUUFBUTtZQUNsQixRQUFRLEVBQUUsS0FBSztTQUNsQjtRQUNELENBQUMsZUFBZSxDQUFDLEtBQUssQ0FBQyxFQUFFO1lBQ3JCLE9BQU8sRUFBRSxPQUFPO1lBQ2hCLE9BQU8sRUFBRSxRQUFRO1lBQ2pCLFFBQVEsRUFBRSxPQUFPO1lBQ2pCLFFBQVEsRUFBRSxLQUFLO1NBQ2xCO1FBQ0QsQ0FBQyxlQUFlLENBQUMsR0FBRyxDQUFDLEVBQUU7WUFDbkIsT0FBTyxFQUFFLEtBQUs7WUFDZCxPQUFPLEVBQUUsUUFBUTtZQUNqQixRQUFRLEVBQUUsS0FBSztZQUNmLFFBQVEsRUFBRSxLQUFLO1NBQ2xCO0tBQ0o7SUFDRCxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsRUFBRTtRQUNuQixDQUFDLGVBQWUsQ0FBQyxNQUFNLENBQUMsRUFBRTtZQUN0QixPQUFPLEVBQUUsT0FBTztZQUNoQixPQUFPLEVBQUUsUUFBUTtZQUNqQixRQUFRLEVBQUUsS0FBSztZQUNmLFFBQVEsRUFBRSxRQUFRO1NBQ3JCO1FBQ0QsQ0FBQyxlQUFlLENBQUMsS0FBSyxDQUFDLEVBQUU7WUFDckIsT0FBTyxFQUFFLE9BQU87WUFDaEIsT0FBTyxFQUFFLEtBQUs7WUFDZCxRQUFRLEVBQUUsS0FBSztZQUNmLFFBQVEsRUFBRSxLQUFLO1NBQ2xCO1FBQ0QsQ0FBQyxlQUFlLENBQUMsR0FBRyxDQUFDLEVBQUU7WUFDbkIsT0FBTyxFQUFFLE9BQU87WUFDaEIsT0FBTyxFQUFFLFFBQVE7WUFDakIsUUFBUSxFQUFFLEtBQUs7WUFDZixRQUFRLEVBQUUsUUFBUTtTQUNyQjtLQUNKO0NBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbm5lY3Rpb25Qb3NpdGlvblBhaXIgfSBmcm9tICdAYW5ndWxhci9jZGsvb3ZlcmxheSc7XG5pbXBvcnQgeyBSZHhUb29sdGlwQWxpZ24sIFJkeFRvb2x0aXBTaWRlIH0gZnJvbSAnLi90b29sdGlwLnR5cGVzJztcblxudHlwZSBUb29sdGlwUG9zaXRpb25zID0ge1xuICAgIFtrZXkgaW4gUmR4VG9vbHRpcFNpZGVdOiB7XG4gICAgICAgIFtrZXkgaW4gUmR4VG9vbHRpcEFsaWduXTogQ29ubmVjdGlvblBvc2l0aW9uUGFpcjtcbiAgICB9O1xufTtcblxuZXhwb3J0IGNvbnN0IFRPT0xUSVBfUE9TSVRJT05TOiBUb29sdGlwUG9zaXRpb25zID0ge1xuICAgIFtSZHhUb29sdGlwU2lkZS5Ub3BdOiB7XG4gICAgICAgIFtSZHhUb29sdGlwQWxpZ24uQ2VudGVyXToge1xuICAgICAgICAgICAgb3JpZ2luWDogJ2NlbnRlcicsXG4gICAgICAgICAgICBvcmlnaW5ZOiAndG9wJyxcbiAgICAgICAgICAgIG92ZXJsYXlYOiAnY2VudGVyJyxcbiAgICAgICAgICAgIG92ZXJsYXlZOiAnYm90dG9tJ1xuICAgICAgICB9LFxuICAgICAgICBbUmR4VG9vbHRpcEFsaWduLlN0YXJ0XToge1xuICAgICAgICAgICAgb3JpZ2luWDogJ3N0YXJ0JyxcbiAgICAgICAgICAgIG9yaWdpblk6ICd0b3AnLFxuICAgICAgICAgICAgb3ZlcmxheVg6ICdzdGFydCcsXG4gICAgICAgICAgICBvdmVybGF5WTogJ2JvdHRvbSdcbiAgICAgICAgfSxcbiAgICAgICAgW1JkeFRvb2x0aXBBbGlnbi5FbmRdOiB7XG4gICAgICAgICAgICBvcmlnaW5YOiAnZW5kJyxcbiAgICAgICAgICAgIG9yaWdpblk6ICd0b3AnLFxuICAgICAgICAgICAgb3ZlcmxheVg6ICdlbmQnLFxuICAgICAgICAgICAgb3ZlcmxheVk6ICdib3R0b20nXG4gICAgICAgIH1cbiAgICB9LFxuICAgIFtSZHhUb29sdGlwU2lkZS5SaWdodF06IHtcbiAgICAgICAgW1JkeFRvb2x0aXBBbGlnbi5DZW50ZXJdOiB7XG4gICAgICAgICAgICBvcmlnaW5YOiAnZW5kJyxcbiAgICAgICAgICAgIG9yaWdpblk6ICdjZW50ZXInLFxuICAgICAgICAgICAgb3ZlcmxheVg6ICdzdGFydCcsXG4gICAgICAgICAgICBvdmVybGF5WTogJ2NlbnRlcidcbiAgICAgICAgfSxcbiAgICAgICAgW1JkeFRvb2x0aXBBbGlnbi5TdGFydF06IHtcbiAgICAgICAgICAgIG9yaWdpblg6ICdlbmQnLFxuICAgICAgICAgICAgb3JpZ2luWTogJ3RvcCcsXG4gICAgICAgICAgICBvdmVybGF5WDogJ3N0YXJ0JyxcbiAgICAgICAgICAgIG92ZXJsYXlZOiAndG9wJ1xuICAgICAgICB9LFxuICAgICAgICBbUmR4VG9vbHRpcEFsaWduLkVuZF06IHtcbiAgICAgICAgICAgIG9yaWdpblg6ICdlbmQnLFxuICAgICAgICAgICAgb3JpZ2luWTogJ2JvdHRvbScsXG4gICAgICAgICAgICBvdmVybGF5WDogJ3N0YXJ0JyxcbiAgICAgICAgICAgIG92ZXJsYXlZOiAnYm90dG9tJ1xuICAgICAgICB9XG4gICAgfSxcbiAgICBbUmR4VG9vbHRpcFNpZGUuQm90dG9tXToge1xuICAgICAgICBbUmR4VG9vbHRpcEFsaWduLkNlbnRlcl06IHtcbiAgICAgICAgICAgIG9yaWdpblg6ICdjZW50ZXInLFxuICAgICAgICAgICAgb3JpZ2luWTogJ2JvdHRvbScsXG4gICAgICAgICAgICBvdmVybGF5WDogJ2NlbnRlcicsXG4gICAgICAgICAgICBvdmVybGF5WTogJ3RvcCdcbiAgICAgICAgfSxcbiAgICAgICAgW1JkeFRvb2x0aXBBbGlnbi5TdGFydF06IHtcbiAgICAgICAgICAgIG9yaWdpblg6ICdzdGFydCcsXG4gICAgICAgICAgICBvcmlnaW5ZOiAnYm90dG9tJyxcbiAgICAgICAgICAgIG92ZXJsYXlYOiAnc3RhcnQnLFxuICAgICAgICAgICAgb3ZlcmxheVk6ICd0b3AnXG4gICAgICAgIH0sXG4gICAgICAgIFtSZHhUb29sdGlwQWxpZ24uRW5kXToge1xuICAgICAgICAgICAgb3JpZ2luWDogJ2VuZCcsXG4gICAgICAgICAgICBvcmlnaW5ZOiAnYm90dG9tJyxcbiAgICAgICAgICAgIG92ZXJsYXlYOiAnZW5kJyxcbiAgICAgICAgICAgIG92ZXJsYXlZOiAndG9wJ1xuICAgICAgICB9XG4gICAgfSxcbiAgICBbUmR4VG9vbHRpcFNpZGUuTGVmdF06IHtcbiAgICAgICAgW1JkeFRvb2x0aXBBbGlnbi5DZW50ZXJdOiB7XG4gICAgICAgICAgICBvcmlnaW5YOiAnc3RhcnQnLFxuICAgICAgICAgICAgb3JpZ2luWTogJ2NlbnRlcicsXG4gICAgICAgICAgICBvdmVybGF5WDogJ2VuZCcsXG4gICAgICAgICAgICBvdmVybGF5WTogJ2NlbnRlcidcbiAgICAgICAgfSxcbiAgICAgICAgW1JkeFRvb2x0aXBBbGlnbi5TdGFydF06IHtcbiAgICAgICAgICAgIG9yaWdpblg6ICdzdGFydCcsXG4gICAgICAgICAgICBvcmlnaW5ZOiAndG9wJyxcbiAgICAgICAgICAgIG92ZXJsYXlYOiAnZW5kJyxcbiAgICAgICAgICAgIG92ZXJsYXlZOiAndG9wJ1xuICAgICAgICB9LFxuICAgICAgICBbUmR4VG9vbHRpcEFsaWduLkVuZF06IHtcbiAgICAgICAgICAgIG9yaWdpblg6ICdzdGFydCcsXG4gICAgICAgICAgICBvcmlnaW5ZOiAnYm90dG9tJyxcbiAgICAgICAgICAgIG92ZXJsYXlYOiAnZW5kJyxcbiAgICAgICAgICAgIG92ZXJsYXlZOiAnYm90dG9tJ1xuICAgICAgICB9XG4gICAgfVxufTtcbiJdfQ==
|
@@ -0,0 +1,14 @@
|
|
1
|
+
export var RdxTooltipSide;
|
2
|
+
(function (RdxTooltipSide) {
|
3
|
+
RdxTooltipSide["Top"] = "top";
|
4
|
+
RdxTooltipSide["Right"] = "right";
|
5
|
+
RdxTooltipSide["Bottom"] = "bottom";
|
6
|
+
RdxTooltipSide["Left"] = "left";
|
7
|
+
})(RdxTooltipSide || (RdxTooltipSide = {}));
|
8
|
+
export var RdxTooltipAlign;
|
9
|
+
(function (RdxTooltipAlign) {
|
10
|
+
RdxTooltipAlign["Start"] = "start";
|
11
|
+
RdxTooltipAlign["Center"] = "center";
|
12
|
+
RdxTooltipAlign["End"] = "end";
|
13
|
+
})(RdxTooltipAlign || (RdxTooltipAlign = {}));
|
14
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbHRpcC50eXBlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3ByaW1pdGl2ZXMvdG9vbHRpcC9zcmMvdG9vbHRpcC50eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQU4sSUFBWSxjQUtYO0FBTEQsV0FBWSxjQUFjO0lBQ3RCLDZCQUFXLENBQUE7SUFDWCxpQ0FBZSxDQUFBO0lBQ2YsbUNBQWlCLENBQUE7SUFDakIsK0JBQWEsQ0FBQTtBQUNqQixDQUFDLEVBTFcsY0FBYyxLQUFkLGNBQWMsUUFLekI7QUFFRCxNQUFNLENBQU4sSUFBWSxlQUlYO0FBSkQsV0FBWSxlQUFlO0lBQ3ZCLGtDQUFlLENBQUE7SUFDZixvQ0FBaUIsQ0FBQTtJQUNqQiw4QkFBVyxDQUFBO0FBQ2YsQ0FBQyxFQUpXLGVBQWUsS0FBZixlQUFlLFFBSTFCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGVudW0gUmR4VG9vbHRpcFNpZGUge1xuICAgIFRvcCA9ICd0b3AnLFxuICAgIFJpZ2h0ID0gJ3JpZ2h0JyxcbiAgICBCb3R0b20gPSAnYm90dG9tJyxcbiAgICBMZWZ0ID0gJ2xlZnQnXG59XG5cbmV4cG9ydCBlbnVtIFJkeFRvb2x0aXBBbGlnbiB7XG4gICAgU3RhcnQgPSAnc3RhcnQnLFxuICAgIENlbnRlciA9ICdjZW50ZXInLFxuICAgIEVuZCA9ICdlbmQnXG59XG5cbmV4cG9ydCB0eXBlIFJkeFRvb2x0aXBDb25maWcgPSB7XG4gICAgZGVsYXlEdXJhdGlvbjogbnVtYmVyO1xuICAgIHNraXBEZWxheUR1cmF0aW9uOiBudW1iZXI7XG4gICAgZGlzYWJsZUhvdmVyYWJsZUNvbnRlbnQ/OiBib29sZWFuO1xuICAgIGhpZGVEZWxheUR1cmF0aW9uPzogbnVtYmVyO1xufTtcblxuZXhwb3J0IHR5cGUgUmR4VG9vbHRpcFN0YXRlID0gJ2RlbGF5ZWQtb3BlbicgfCAnaW5zdGFudC1vcGVuJyB8ICdjbG9zZWQnO1xuIl19
|
@@ -52,10 +52,10 @@ export class RdxVisuallyHiddenInputBubbleDirective {
|
|
52
52
|
this.inputElement.dispatchEvent(inputEvent);
|
53
53
|
this.inputElement.dispatchEvent(changeEvent);
|
54
54
|
}
|
55
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.
|
56
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.
|
55
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxVisuallyHiddenInputBubbleDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
56
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.11", type: RdxVisuallyHiddenInputBubbleDirective, isStandalone: true, selector: "[rdxVisuallyHiddenInputBubble]", inputs: { name: { classPropertyName: "name", publicName: "name", isSignal: true, isRequired: false, transformFunction: null }, value: { classPropertyName: "value", publicName: "value", isSignal: true, isRequired: false, transformFunction: null }, checked: { classPropertyName: "checked", publicName: "checked", isSignal: true, isRequired: false, transformFunction: null }, required: { classPropertyName: "required", publicName: "required", isSignal: true, isRequired: false, transformFunction: null }, disabled: { classPropertyName: "disabled", publicName: "disabled", isSignal: true, isRequired: false, transformFunction: null }, feature: { classPropertyName: "feature", publicName: "feature", isSignal: true, isRequired: false, transformFunction: null } }, host: { listeners: { "change": "onChange()" }, properties: { "attr.name": "name()", "attr.required": "required()", "attr.disabled": "disabled()", "attr.checked": "checked()", "value": "value()" } }, hostDirectives: [{ directive: i1.RdxVisuallyHiddenDirective, inputs: ["feature", "feature"] }], ngImport: i0 }); }
|
57
57
|
}
|
58
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.
|
58
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxVisuallyHiddenInputBubbleDirective, decorators: [{
|
59
59
|
type: Directive,
|
60
60
|
args: [{
|
61
61
|
selector: '[rdxVisuallyHiddenInputBubble]',
|
@@ -48,10 +48,10 @@ export class RdxVisuallyHiddenInputDirective {
|
|
48
48
|
inputElement.setAttribute('value', parsed.value);
|
49
49
|
});
|
50
50
|
}
|
51
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.
|
52
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.
|
51
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxVisuallyHiddenInputDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
52
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.11", type: RdxVisuallyHiddenInputDirective, isStandalone: true, selector: "[rdxVisuallyHiddenInput]", inputs: { name: { classPropertyName: "name", publicName: "name", isSignal: true, isRequired: false, transformFunction: null }, value: { classPropertyName: "value", publicName: "value", isSignal: true, isRequired: false, transformFunction: null }, checked: { classPropertyName: "checked", publicName: "checked", isSignal: true, isRequired: false, transformFunction: null }, required: { classPropertyName: "required", publicName: "required", isSignal: true, isRequired: false, transformFunction: null }, disabled: { classPropertyName: "disabled", publicName: "disabled", isSignal: true, isRequired: false, transformFunction: null }, feature: { classPropertyName: "feature", publicName: "feature", isSignal: true, isRequired: false, transformFunction: null } }, hostDirectives: [{ directive: i1.RdxVisuallyHiddenInputBubbleDirective, inputs: ["feature", "feature", "name", "name", "value", "value", "checked", "checked", "disabled", "disabled", "required", "required"] }], ngImport: i0 }); }
|
53
53
|
}
|
54
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.
|
54
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxVisuallyHiddenInputDirective, decorators: [{
|
55
55
|
type: Directive,
|
56
56
|
args: [{
|
57
57
|
selector: '[rdxVisuallyHiddenInput]',
|
@@ -13,10 +13,10 @@ export class RdxVisuallyHiddenDirective {
|
|
13
13
|
constructor() {
|
14
14
|
this.feature = input('focusable');
|
15
15
|
}
|
16
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.
|
17
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.
|
16
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxVisuallyHiddenDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
17
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.11", type: RdxVisuallyHiddenDirective, isStandalone: true, selector: "[rdxVisuallyHidden]", inputs: { feature: { classPropertyName: "feature", publicName: "feature", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "attr.aria-hidden": "feature() === \"focusable\" ? \"true\" : null", "hidden": "feature() === \"fully-hidden\" ? true : null", "attr.tabindex": "feature() === \"fully-hidden\" ? \"-1\" : null", "style.position": "\"absolute\"", "style.border": "\"0\"", "style.width": "\"1px\"", "style.display": "feature() === \"focusable\" ? \"inline-block\" : \"none\"", "style.height": "\"1px\"", "style.padding": "\"0\"", "style.margin": "\"-1px\"", "style.overflow": "\"hidden\"", "style.clip": "\"rect(0, 0, 0, 0)\"", "style.white-space": "\"nowrap\"", "style.word-wrap": "\"normal\"" } }, ngImport: i0 }); }
|
18
18
|
}
|
19
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.
|
19
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxVisuallyHiddenDirective, decorators: [{
|
20
20
|
type: Directive,
|
21
21
|
args: [{
|
22
22
|
selector: '[rdxVisuallyHidden]',
|