cloud-ide-element 0.0.1 → 1.0.2
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/README.md +271 -24
- package/esm2022/lib/components/confirmation-modal/confirmation-modal.component.mjs +182 -0
- package/esm2022/lib/components/data-grid/data-grid.component.mjs +1363 -0
- package/esm2022/lib/components/data-grid/data-grid.types.mjs +37 -0
- package/esm2022/lib/components/dropdown/dropdown.component.mjs +396 -0
- package/esm2022/lib/components/global-notifications/global-notifications.component.mjs +30 -0
- package/esm2022/lib/components/json-editor/json-editor.component.mjs +521 -0
- package/esm2022/lib/components/skeleton-loader/skeleton-loader.component.mjs +33 -0
- package/esm2022/lib/components/toast-notification/toast-notification.component.mjs +152 -0
- package/esm2022/lib/elements/button/cide-ele-button.component.mjs +249 -0
- package/esm2022/lib/elements/file-input/file-input.component.mjs +83 -0
- package/esm2022/lib/elements/icon/icon.component.mjs +5 -3
- package/esm2022/lib/elements/input/input.component.mjs +34 -20
- package/esm2022/lib/elements/select/select.component.mjs +471 -0
- package/esm2022/lib/elements/tab/cide-ele-tab.component.mjs +74 -0
- package/esm2022/lib/elements/textarea/textarea.component.mjs +157 -0
- package/esm2022/lib/services/confirmation.service.mjs +151 -0
- package/esm2022/lib/services/dropdown-manager.service.mjs +93 -0
- package/esm2022/lib/services/notification.service.mjs +196 -0
- package/esm2022/lib/utils/directives/resizer/resizer.directive.mjs +231 -0
- package/esm2022/lib/utils/directives/tooltip/tooltip.directive.mjs +294 -0
- package/esm2022/lib/utils/services/elements/elements.service.mjs +9 -7
- package/esm2022/public-api.mjs +23 -2
- package/fesm2022/cloud-ide-element.mjs +4646 -47
- package/fesm2022/cloud-ide-element.mjs.map +1 -1
- package/lib/components/confirmation-modal/confirmation-modal.component.d.ts +16 -0
- package/lib/components/data-grid/data-grid.component.d.ts +244 -0
- package/lib/components/data-grid/data-grid.types.d.ts +146 -0
- package/lib/components/dropdown/dropdown.component.d.ts +75 -0
- package/lib/components/global-notifications/global-notifications.component.d.ts +5 -0
- package/lib/components/json-editor/json-editor.component.d.ts +116 -0
- package/lib/components/skeleton-loader/skeleton-loader.component.d.ts +11 -0
- package/lib/components/toast-notification/toast-notification.component.d.ts +13 -0
- package/lib/elements/button/cide-ele-button.component.d.ts +85 -0
- package/lib/elements/file-input/file-input.component.d.ts +25 -0
- package/lib/elements/input/input.component.d.ts +7 -4
- package/lib/elements/select/select.component.d.ts +91 -0
- package/lib/elements/tab/cide-ele-tab.component.d.ts +26 -0
- package/lib/elements/textarea/textarea.component.d.ts +47 -0
- package/lib/services/confirmation.service.d.ts +65 -0
- package/lib/services/dropdown-manager.service.d.ts +22 -0
- package/lib/services/notification.service.d.ts +81 -0
- package/lib/utils/directives/resizer/resizer.directive.d.ts +44 -0
- package/lib/utils/directives/tooltip/tooltip.directive.d.ts +43 -0
- package/package.json +30 -4
- package/public-api.d.ts +18 -1
- package/src/lib/assets/css/cide-ele-style.scss +85 -0
- package/src/lib/assets/css/cide-ele-variable.scss +336 -0
- package/esm2022/lib/elements/button/button.component.mjs +0 -60
- package/lib/elements/button/button.component.d.ts +0 -27
|
@@ -0,0 +1,294 @@
|
|
|
1
|
+
import { Directive, HostListener, Input } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class TooltipDirective {
|
|
4
|
+
constructor(el, renderer) {
|
|
5
|
+
this.el = el;
|
|
6
|
+
this.renderer = renderer;
|
|
7
|
+
this.cideEleTooltip = '';
|
|
8
|
+
this.tooltipColor = '';
|
|
9
|
+
this.tooltipBg = '';
|
|
10
|
+
this.tooltipPlacement = 'top';
|
|
11
|
+
this.tooltipType = 'default';
|
|
12
|
+
this.tooltipDelay = 300; // ms
|
|
13
|
+
this.tooltipDir = 'top'; // Alias for tooltipPlacement for backward compatibility
|
|
14
|
+
this.tooltipShowArrow = false;
|
|
15
|
+
this.tooltipMultiline = false;
|
|
16
|
+
this.tooltipMaxWidth = '200px';
|
|
17
|
+
this.tooltipInteractive = false;
|
|
18
|
+
this.tooltipClass = '';
|
|
19
|
+
this.tooltipElement = null;
|
|
20
|
+
this.visible = false;
|
|
21
|
+
this.showTimeout = null;
|
|
22
|
+
this.hideTimeout = null;
|
|
23
|
+
this.hideDelay = 150; // ms
|
|
24
|
+
this.interactiveMouseLeaveHandler = null;
|
|
25
|
+
}
|
|
26
|
+
ngOnInit() {
|
|
27
|
+
// Use tooltipDir as fallback if provided and tooltipPlacement is default
|
|
28
|
+
if (this.tooltipDir && this.tooltipPlacement === 'top') {
|
|
29
|
+
this.tooltipPlacement = this.tooltipDir;
|
|
30
|
+
}
|
|
31
|
+
// If user hasn't provided custom colors and is using a predefined type,
|
|
32
|
+
// we'll leave colors empty to use CSS class colors
|
|
33
|
+
if (this.tooltipType !== 'default' && !this.tooltipColor && !this.tooltipBg) {
|
|
34
|
+
this.tooltipColor = '';
|
|
35
|
+
this.tooltipBg = '';
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
onMouseEnter() {
|
|
39
|
+
this.clearTimeouts();
|
|
40
|
+
this.showTimeout = window.setTimeout(() => {
|
|
41
|
+
this.show();
|
|
42
|
+
}, this.tooltipDelay);
|
|
43
|
+
}
|
|
44
|
+
onFocus() {
|
|
45
|
+
this.clearTimeouts();
|
|
46
|
+
this.showTimeout = window.setTimeout(() => {
|
|
47
|
+
this.show();
|
|
48
|
+
}, this.tooltipDelay);
|
|
49
|
+
}
|
|
50
|
+
onMouseLeave() {
|
|
51
|
+
this.clearTimeouts();
|
|
52
|
+
// Don't hide immediately if interactive
|
|
53
|
+
if (!this.tooltipInteractive) {
|
|
54
|
+
this.hide();
|
|
55
|
+
}
|
|
56
|
+
else {
|
|
57
|
+
// For interactive tooltips, delay hiding to allow user to move to tooltip
|
|
58
|
+
this.hideTimeout = window.setTimeout(() => {
|
|
59
|
+
this.hide();
|
|
60
|
+
}, this.hideDelay);
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
onBlur() {
|
|
64
|
+
this.clearTimeouts();
|
|
65
|
+
this.hide();
|
|
66
|
+
}
|
|
67
|
+
onClick() {
|
|
68
|
+
if (this.visible && !this.tooltipInteractive) {
|
|
69
|
+
this.hide();
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
ngOnDestroy() {
|
|
73
|
+
this.clearTimeouts();
|
|
74
|
+
this.destroyTooltip();
|
|
75
|
+
}
|
|
76
|
+
clearTimeouts() {
|
|
77
|
+
if (this.showTimeout) {
|
|
78
|
+
clearTimeout(this.showTimeout);
|
|
79
|
+
this.showTimeout = null;
|
|
80
|
+
}
|
|
81
|
+
if (this.hideTimeout) {
|
|
82
|
+
clearTimeout(this.hideTimeout);
|
|
83
|
+
this.hideTimeout = null;
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
show() {
|
|
87
|
+
if (!this.cideEleTooltip || this.visible)
|
|
88
|
+
return;
|
|
89
|
+
this.createTooltip();
|
|
90
|
+
this.styleTooltip();
|
|
91
|
+
this.positionTooltip();
|
|
92
|
+
// Add animation with requestAnimationFrame for smoother transition
|
|
93
|
+
requestAnimationFrame(() => {
|
|
94
|
+
if (this.tooltipElement) {
|
|
95
|
+
this.renderer.addClass(this.tooltipElement, 'tooltip-visible');
|
|
96
|
+
// Show arrow if enabled
|
|
97
|
+
if (this.tooltipShowArrow) {
|
|
98
|
+
this.renderer.addClass(this.tooltipElement, 'tooltip-arrow-visible');
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
});
|
|
102
|
+
this.visible = true;
|
|
103
|
+
// Add mouseleave event listener if interactive
|
|
104
|
+
if (this.tooltipInteractive && this.tooltipElement) {
|
|
105
|
+
this.interactiveMouseLeaveHandler = () => {
|
|
106
|
+
this.clearTimeouts();
|
|
107
|
+
this.hide();
|
|
108
|
+
};
|
|
109
|
+
this.tooltipElement.addEventListener('mouseleave', this.interactiveMouseLeaveHandler);
|
|
110
|
+
// Also add mouseenter to cancel any pending hide
|
|
111
|
+
this.tooltipElement.addEventListener('mouseenter', () => {
|
|
112
|
+
this.clearTimeouts();
|
|
113
|
+
});
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
hide() {
|
|
117
|
+
if (!this.visible || !this.tooltipElement)
|
|
118
|
+
return;
|
|
119
|
+
this.renderer.removeClass(this.tooltipElement, 'tooltip-visible');
|
|
120
|
+
this.renderer.removeClass(this.tooltipElement, 'tooltip-arrow-visible');
|
|
121
|
+
// Use timeout for smoother hide animation
|
|
122
|
+
setTimeout(() => {
|
|
123
|
+
if (!this.visible) { // Double-check in case tooltip was reshown
|
|
124
|
+
this.destroyTooltip();
|
|
125
|
+
}
|
|
126
|
+
}, this.hideDelay);
|
|
127
|
+
this.visible = false;
|
|
128
|
+
}
|
|
129
|
+
createTooltip() {
|
|
130
|
+
this.destroyTooltip();
|
|
131
|
+
this.tooltipElement = this.renderer.createElement('div');
|
|
132
|
+
this.renderer.addClass(this.tooltipElement, 'tooltip');
|
|
133
|
+
// Add placement class for arrow
|
|
134
|
+
this.renderer.addClass(this.tooltipElement, `tooltip-${this.tooltipPlacement}`);
|
|
135
|
+
// Add type class if using a predefined type
|
|
136
|
+
if (this.tooltipType !== 'default') {
|
|
137
|
+
this.renderer.addClass(this.tooltipElement, `tooltip-${this.tooltipType}`);
|
|
138
|
+
}
|
|
139
|
+
// Add multiline class if enabled
|
|
140
|
+
if (this.tooltipMultiline) {
|
|
141
|
+
this.renderer.addClass(this.tooltipElement, 'tooltip-multiline');
|
|
142
|
+
}
|
|
143
|
+
// Add interactive class if enabled
|
|
144
|
+
if (this.tooltipInteractive) {
|
|
145
|
+
this.renderer.addClass(this.tooltipElement, 'tooltip-interactive');
|
|
146
|
+
}
|
|
147
|
+
// Add custom classes if provided
|
|
148
|
+
if (this.tooltipClass) {
|
|
149
|
+
const classes = this.tooltipClass.split(' ');
|
|
150
|
+
classes.forEach(className => {
|
|
151
|
+
if (className.trim()) {
|
|
152
|
+
this.renderer.addClass(this.tooltipElement, className.trim());
|
|
153
|
+
}
|
|
154
|
+
});
|
|
155
|
+
}
|
|
156
|
+
// Create HTML content if multiline
|
|
157
|
+
if (this.tooltipMultiline) {
|
|
158
|
+
this.renderer.setProperty(this.tooltipElement, 'innerHTML', this.cideEleTooltip);
|
|
159
|
+
}
|
|
160
|
+
else {
|
|
161
|
+
const textNode = this.renderer.createText(this.cideEleTooltip);
|
|
162
|
+
this.renderer.appendChild(this.tooltipElement, textNode);
|
|
163
|
+
}
|
|
164
|
+
this.renderer.appendChild(document.body, this.tooltipElement);
|
|
165
|
+
}
|
|
166
|
+
styleTooltip() {
|
|
167
|
+
if (!this.tooltipElement)
|
|
168
|
+
return;
|
|
169
|
+
// Set custom CSS variables for the tooltip colors if provided
|
|
170
|
+
if (this.tooltipColor) {
|
|
171
|
+
this.renderer.setStyle(this.tooltipElement, '--tooltip-color', this.tooltipColor);
|
|
172
|
+
}
|
|
173
|
+
if (this.tooltipBg) {
|
|
174
|
+
this.renderer.setStyle(this.tooltipElement, '--tooltip-bg', this.tooltipBg);
|
|
175
|
+
}
|
|
176
|
+
// Set custom max width if provided
|
|
177
|
+
if (this.tooltipMaxWidth && this.tooltipMultiline) {
|
|
178
|
+
this.renderer.setStyle(this.tooltipElement, '--tooltip-max-width', this.tooltipMaxWidth);
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
positionTooltip() {
|
|
182
|
+
if (!this.tooltipElement)
|
|
183
|
+
return;
|
|
184
|
+
const hostRect = this.el.nativeElement.getBoundingClientRect();
|
|
185
|
+
const tooltipRect = this.tooltipElement.getBoundingClientRect();
|
|
186
|
+
// Account for page scroll
|
|
187
|
+
const scrollLeft = window.pageXOffset || document.documentElement.scrollLeft;
|
|
188
|
+
const scrollTop = window.pageYOffset || document.documentElement.scrollTop;
|
|
189
|
+
let top = 0;
|
|
190
|
+
let left = 0;
|
|
191
|
+
// Calculate position based on placement
|
|
192
|
+
switch (this.tooltipPlacement) {
|
|
193
|
+
case 'top':
|
|
194
|
+
top = hostRect.top + scrollTop - tooltipRect.height - 6;
|
|
195
|
+
left = hostRect.left + scrollLeft + (hostRect.width / 2) - (tooltipRect.width / 2);
|
|
196
|
+
break;
|
|
197
|
+
case 'bottom':
|
|
198
|
+
top = hostRect.bottom + scrollTop + 6;
|
|
199
|
+
left = hostRect.left + scrollLeft + (hostRect.width / 2) - (tooltipRect.width / 2);
|
|
200
|
+
break;
|
|
201
|
+
case 'left':
|
|
202
|
+
top = hostRect.top + scrollTop + (hostRect.height / 2) - (tooltipRect.height / 2);
|
|
203
|
+
left = hostRect.left + scrollLeft - tooltipRect.width - 6;
|
|
204
|
+
break;
|
|
205
|
+
case 'right':
|
|
206
|
+
top = hostRect.top + scrollTop + (hostRect.height / 2) - (tooltipRect.height / 2);
|
|
207
|
+
left = hostRect.right + scrollLeft + 6;
|
|
208
|
+
break;
|
|
209
|
+
}
|
|
210
|
+
// Adjust if tooltip would be outside viewport
|
|
211
|
+
const viewportWidth = window.innerWidth;
|
|
212
|
+
const viewportHeight = window.innerHeight;
|
|
213
|
+
// Top boundary check
|
|
214
|
+
if (top < scrollTop + 4) {
|
|
215
|
+
top = scrollTop + 4;
|
|
216
|
+
}
|
|
217
|
+
else if (top + tooltipRect.height > scrollTop + viewportHeight - 4) {
|
|
218
|
+
top = scrollTop + viewportHeight - tooltipRect.height - 4;
|
|
219
|
+
}
|
|
220
|
+
// Left boundary check
|
|
221
|
+
if (left < scrollLeft + 4) {
|
|
222
|
+
left = scrollLeft + 4;
|
|
223
|
+
}
|
|
224
|
+
else if (left + tooltipRect.width > scrollLeft + viewportWidth - 4) {
|
|
225
|
+
left = scrollLeft + viewportWidth - tooltipRect.width - 4;
|
|
226
|
+
}
|
|
227
|
+
this.renderer.setStyle(this.tooltipElement, 'position', 'absolute');
|
|
228
|
+
this.renderer.setStyle(this.tooltipElement, 'top', `${top}px`);
|
|
229
|
+
this.renderer.setStyle(this.tooltipElement, 'left', `${left}px`);
|
|
230
|
+
}
|
|
231
|
+
destroyTooltip() {
|
|
232
|
+
if (this.tooltipElement) {
|
|
233
|
+
// Remove event listeners for interactive tooltips using the stored reference
|
|
234
|
+
if (this.tooltipInteractive && this.interactiveMouseLeaveHandler) {
|
|
235
|
+
this.tooltipElement.removeEventListener('mouseleave', this.interactiveMouseLeaveHandler);
|
|
236
|
+
this.interactiveMouseLeaveHandler = null;
|
|
237
|
+
}
|
|
238
|
+
const parent = this.tooltipElement.parentNode;
|
|
239
|
+
if (parent) {
|
|
240
|
+
this.renderer.removeChild(parent, this.tooltipElement);
|
|
241
|
+
}
|
|
242
|
+
this.tooltipElement = null;
|
|
243
|
+
}
|
|
244
|
+
}
|
|
245
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: TooltipDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
246
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.7", type: TooltipDirective, isStandalone: true, selector: "[cideEleTooltip]", inputs: { cideEleTooltip: "cideEleTooltip", tooltipColor: "tooltipColor", tooltipBg: "tooltipBg", tooltipPlacement: "tooltipPlacement", tooltipType: "tooltipType", tooltipDelay: "tooltipDelay", tooltipDir: "tooltipDir", tooltipShowArrow: "tooltipShowArrow", tooltipMultiline: "tooltipMultiline", tooltipMaxWidth: "tooltipMaxWidth", tooltipInteractive: "tooltipInteractive", tooltipClass: "tooltipClass" }, host: { listeners: { "mouseenter": "onMouseEnter()", "focus": "onFocus()", "mouseleave": "onMouseLeave()", "blur": "onBlur()", "click": "onClick()" } }, ngImport: i0 }); }
|
|
247
|
+
}
|
|
248
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: TooltipDirective, decorators: [{
|
|
249
|
+
type: Directive,
|
|
250
|
+
args: [{
|
|
251
|
+
selector: '[cideEleTooltip]',
|
|
252
|
+
standalone: true
|
|
253
|
+
}]
|
|
254
|
+
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }], propDecorators: { cideEleTooltip: [{
|
|
255
|
+
type: Input
|
|
256
|
+
}], tooltipColor: [{
|
|
257
|
+
type: Input
|
|
258
|
+
}], tooltipBg: [{
|
|
259
|
+
type: Input
|
|
260
|
+
}], tooltipPlacement: [{
|
|
261
|
+
type: Input
|
|
262
|
+
}], tooltipType: [{
|
|
263
|
+
type: Input
|
|
264
|
+
}], tooltipDelay: [{
|
|
265
|
+
type: Input
|
|
266
|
+
}], tooltipDir: [{
|
|
267
|
+
type: Input
|
|
268
|
+
}], tooltipShowArrow: [{
|
|
269
|
+
type: Input
|
|
270
|
+
}], tooltipMultiline: [{
|
|
271
|
+
type: Input
|
|
272
|
+
}], tooltipMaxWidth: [{
|
|
273
|
+
type: Input
|
|
274
|
+
}], tooltipInteractive: [{
|
|
275
|
+
type: Input
|
|
276
|
+
}], tooltipClass: [{
|
|
277
|
+
type: Input
|
|
278
|
+
}], onMouseEnter: [{
|
|
279
|
+
type: HostListener,
|
|
280
|
+
args: ['mouseenter']
|
|
281
|
+
}], onFocus: [{
|
|
282
|
+
type: HostListener,
|
|
283
|
+
args: ['focus']
|
|
284
|
+
}], onMouseLeave: [{
|
|
285
|
+
type: HostListener,
|
|
286
|
+
args: ['mouseleave']
|
|
287
|
+
}], onBlur: [{
|
|
288
|
+
type: HostListener,
|
|
289
|
+
args: ['blur']
|
|
290
|
+
}], onClick: [{
|
|
291
|
+
type: HostListener,
|
|
292
|
+
args: ['click']
|
|
293
|
+
}] } });
|
|
294
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.directive.js","sourceRoot":"","sources":["../../../../../../../projects/cloud-ide-element/src/lib/utils/directives/tooltip/tooltip.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, HostListener, Input, OnDestroy, OnInit, Renderer2 } from '@angular/core';\r\n\r\nexport type TooltipPlacement = 'top' | 'bottom' | 'left' | 'right';\r\nexport type TooltipType = 'default' | 'success' | 'warning' | 'error' | 'info' | 'light' | 'dark';\r\n\r\n@Directive({\r\n  selector: '[cideEleTooltip]',\r\n  standalone: true\r\n})\r\nexport class TooltipDirective implements OnInit, OnDestroy {\r\n  @Input() cideEleTooltip: string = '';\r\n  @Input() tooltipColor: string = '';\r\n  @Input() tooltipBg: string = '';\r\n  @Input() tooltipPlacement: TooltipPlacement = 'top';\r\n  @Input() tooltipType: TooltipType = 'default';\r\n  @Input() tooltipDelay: number = 300; // ms\r\n  @Input() tooltipDir: TooltipPlacement = 'top'; // Alias for tooltipPlacement for backward compatibility\r\n  @Input() tooltipShowArrow: boolean = false;\r\n  @Input() tooltipMultiline: boolean = false;\r\n  @Input() tooltipMaxWidth: string = '200px';\r\n  @Input() tooltipInteractive: boolean = false;\r\n  @Input() tooltipClass: string = '';\r\n  \r\n  private tooltipElement: HTMLElement | null = null;\r\n  private visible = false;\r\n  private showTimeout: number | null = null;\r\n  private hideTimeout: number | null = null;\r\n  private hideDelay = 150; // ms\r\n  private interactiveMouseLeaveHandler: (() => void) | null = null;\r\n\r\n  constructor(private el: ElementRef, private renderer: Renderer2) {}\r\n\r\n  ngOnInit(): void {\r\n    // Use tooltipDir as fallback if provided and tooltipPlacement is default\r\n    if (this.tooltipDir && this.tooltipPlacement === 'top') {\r\n      this.tooltipPlacement = this.tooltipDir;\r\n    }\r\n\r\n    // If user hasn't provided custom colors and is using a predefined type,\r\n    // we'll leave colors empty to use CSS class colors\r\n    if (this.tooltipType !== 'default' && !this.tooltipColor && !this.tooltipBg) {\r\n      this.tooltipColor = '';\r\n      this.tooltipBg = '';\r\n    }\r\n  }\r\n\r\n  @HostListener('mouseenter')\r\n  onMouseEnter(): void {\r\n    this.clearTimeouts();\r\n    this.showTimeout = window.setTimeout(() => {\r\n      this.show();\r\n    }, this.tooltipDelay);\r\n  }\r\n\r\n  @HostListener('focus')\r\n  onFocus(): void {\r\n    this.clearTimeouts();\r\n    this.showTimeout = window.setTimeout(() => {\r\n      this.show();\r\n    }, this.tooltipDelay);\r\n  }\r\n\r\n  @HostListener('mouseleave')\r\n  onMouseLeave(): void {\r\n    this.clearTimeouts();\r\n    \r\n    // Don't hide immediately if interactive\r\n    if (!this.tooltipInteractive) {\r\n      this.hide();\r\n    } else {\r\n      // For interactive tooltips, delay hiding to allow user to move to tooltip\r\n      this.hideTimeout = window.setTimeout(() => {\r\n        this.hide();\r\n      }, this.hideDelay);\r\n    }\r\n  }\r\n\r\n  @HostListener('blur')\r\n  onBlur(): void {\r\n    this.clearTimeouts();\r\n    this.hide();\r\n  }\r\n\r\n  @HostListener('click')\r\n  onClick(): void {\r\n    if (this.visible && !this.tooltipInteractive) {\r\n      this.hide();\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.clearTimeouts();\r\n    this.destroyTooltip();\r\n  }\r\n\r\n  private clearTimeouts(): void {\r\n    if (this.showTimeout) {\r\n      clearTimeout(this.showTimeout);\r\n      this.showTimeout = null;\r\n    }\r\n    if (this.hideTimeout) {\r\n      clearTimeout(this.hideTimeout);\r\n      this.hideTimeout = null;\r\n    }\r\n  }\r\n\r\n  private show(): void {\r\n    if (!this.cideEleTooltip || this.visible) return;\r\n    \r\n    this.createTooltip();\r\n    this.styleTooltip();\r\n    this.positionTooltip();\r\n    \r\n    // Add animation with requestAnimationFrame for smoother transition\r\n    requestAnimationFrame(() => {\r\n      if (this.tooltipElement) {\r\n        this.renderer.addClass(this.tooltipElement, 'tooltip-visible');\r\n        \r\n        // Show arrow if enabled\r\n        if (this.tooltipShowArrow) {\r\n          this.renderer.addClass(this.tooltipElement, 'tooltip-arrow-visible');\r\n        }\r\n      }\r\n    });\r\n    \r\n    this.visible = true;\r\n\r\n    // Add mouseleave event listener if interactive\r\n    if (this.tooltipInteractive && this.tooltipElement) {\r\n      this.interactiveMouseLeaveHandler = () => {\r\n        this.clearTimeouts();\r\n        this.hide();\r\n      };\r\n      this.tooltipElement.addEventListener('mouseleave', this.interactiveMouseLeaveHandler);\r\n      \r\n      // Also add mouseenter to cancel any pending hide\r\n      this.tooltipElement.addEventListener('mouseenter', () => {\r\n        this.clearTimeouts();\r\n      });\r\n    }\r\n  }\r\n\r\n  private hide(): void {\r\n    if (!this.visible || !this.tooltipElement) return;\r\n\r\n    this.renderer.removeClass(this.tooltipElement, 'tooltip-visible');\r\n    this.renderer.removeClass(this.tooltipElement, 'tooltip-arrow-visible');\r\n    \r\n    // Use timeout for smoother hide animation\r\n    setTimeout(() => {\r\n      if (!this.visible) { // Double-check in case tooltip was reshown\r\n        this.destroyTooltip();\r\n      }\r\n    }, this.hideDelay);\r\n    \r\n    this.visible = false;\r\n  }\r\n\r\n  private createTooltip(): void {\r\n    this.destroyTooltip();\r\n\r\n    this.tooltipElement = this.renderer.createElement('div');\r\n    this.renderer.addClass(this.tooltipElement, 'tooltip');\r\n    \r\n    // Add placement class for arrow\r\n    this.renderer.addClass(this.tooltipElement, `tooltip-${this.tooltipPlacement}`);\r\n    \r\n    // Add type class if using a predefined type\r\n    if (this.tooltipType !== 'default') {\r\n      this.renderer.addClass(this.tooltipElement, `tooltip-${this.tooltipType}`);\r\n    }\r\n    \r\n    // Add multiline class if enabled\r\n    if (this.tooltipMultiline) {\r\n      this.renderer.addClass(this.tooltipElement, 'tooltip-multiline');\r\n    }\r\n    \r\n    // Add interactive class if enabled\r\n    if (this.tooltipInteractive) {\r\n      this.renderer.addClass(this.tooltipElement, 'tooltip-interactive');\r\n    }\r\n    \r\n    // Add custom classes if provided\r\n    if (this.tooltipClass) {\r\n      const classes = this.tooltipClass.split(' ');\r\n      classes.forEach(className => {\r\n        if (className.trim()) {\r\n          this.renderer.addClass(this.tooltipElement, className.trim());\r\n        }\r\n      });\r\n    }\r\n\r\n    // Create HTML content if multiline\r\n    if (this.tooltipMultiline) {\r\n      this.renderer.setProperty(this.tooltipElement, 'innerHTML', this.cideEleTooltip);\r\n    } else {\r\n      const textNode = this.renderer.createText(this.cideEleTooltip);\r\n      this.renderer.appendChild(this.tooltipElement, textNode);\r\n    }\r\n    \r\n    this.renderer.appendChild(document.body, this.tooltipElement);\r\n  }\r\n\r\n  private styleTooltip(): void {\r\n    if (!this.tooltipElement) return;\r\n\r\n    // Set custom CSS variables for the tooltip colors if provided\r\n    if (this.tooltipColor) {\r\n      this.renderer.setStyle(this.tooltipElement, '--tooltip-color', this.tooltipColor);\r\n    }\r\n    \r\n    if (this.tooltipBg) {\r\n      this.renderer.setStyle(this.tooltipElement, '--tooltip-bg', this.tooltipBg);\r\n    }\r\n    \r\n    // Set custom max width if provided\r\n    if (this.tooltipMaxWidth && this.tooltipMultiline) {\r\n      this.renderer.setStyle(this.tooltipElement, '--tooltip-max-width', this.tooltipMaxWidth);\r\n    }\r\n  }\r\n\r\n  private positionTooltip(): void {\r\n    if (!this.tooltipElement) return;\r\n\r\n    const hostRect = this.el.nativeElement.getBoundingClientRect();\r\n    const tooltipRect = this.tooltipElement.getBoundingClientRect();\r\n    \r\n    // Account for page scroll\r\n    const scrollLeft = window.pageXOffset || document.documentElement.scrollLeft;\r\n    const scrollTop = window.pageYOffset || document.documentElement.scrollTop;\r\n    \r\n    let top = 0;\r\n    let left = 0;\r\n    \r\n    // Calculate position based on placement\r\n    switch (this.tooltipPlacement) {\r\n      case 'top':\r\n        top = hostRect.top + scrollTop - tooltipRect.height - 6;\r\n        left = hostRect.left + scrollLeft + (hostRect.width / 2) - (tooltipRect.width / 2);\r\n        break;\r\n      case 'bottom':\r\n        top = hostRect.bottom + scrollTop + 6;\r\n        left = hostRect.left + scrollLeft + (hostRect.width / 2) - (tooltipRect.width / 2);\r\n        break;\r\n      case 'left':\r\n        top = hostRect.top + scrollTop + (hostRect.height / 2) - (tooltipRect.height / 2);\r\n        left = hostRect.left + scrollLeft - tooltipRect.width - 6;\r\n        break;\r\n      case 'right':\r\n        top = hostRect.top + scrollTop + (hostRect.height / 2) - (tooltipRect.height / 2);\r\n        left = hostRect.right + scrollLeft + 6;\r\n        break;\r\n    }\r\n    \r\n    // Adjust if tooltip would be outside viewport\r\n    const viewportWidth = window.innerWidth;\r\n    const viewportHeight = window.innerHeight;\r\n    \r\n    // Top boundary check\r\n    if (top < scrollTop + 4) {\r\n      top = scrollTop + 4;\r\n    } else if (top + tooltipRect.height > scrollTop + viewportHeight - 4) {\r\n      top = scrollTop + viewportHeight - tooltipRect.height - 4;\r\n    }\r\n    \r\n    // Left boundary check\r\n    if (left < scrollLeft + 4) {\r\n      left = scrollLeft + 4;\r\n    } else if (left + tooltipRect.width > scrollLeft + viewportWidth - 4) {\r\n      left = scrollLeft + viewportWidth - tooltipRect.width - 4;\r\n    }\r\n    \r\n    this.renderer.setStyle(this.tooltipElement, 'position', 'absolute');\r\n    this.renderer.setStyle(this.tooltipElement, 'top', `${top}px`);\r\n    this.renderer.setStyle(this.tooltipElement, 'left', `${left}px`);\r\n  }\r\n\r\n  private destroyTooltip(): void {\r\n    if (this.tooltipElement) {\r\n      // Remove event listeners for interactive tooltips using the stored reference\r\n      if (this.tooltipInteractive && this.interactiveMouseLeaveHandler) {\r\n        this.tooltipElement.removeEventListener('mouseleave', this.interactiveMouseLeaveHandler);\r\n        this.interactiveMouseLeaveHandler = null;\r\n      }\r\n      \r\n      const parent = this.tooltipElement.parentNode;\r\n      if (parent) {\r\n        this.renderer.removeChild(parent, this.tooltipElement);\r\n      }\r\n      this.tooltipElement = null;\r\n    }\r\n  }\r\n}\r\n"]}
|
|
@@ -13,12 +13,14 @@ export class CideElementsService {
|
|
|
13
13
|
resolve(cide_element_data);
|
|
14
14
|
}
|
|
15
15
|
else {
|
|
16
|
-
const subscription = this.is_cide_element_data_updated?.subscribe(
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
16
|
+
const subscription = this.is_cide_element_data_updated?.subscribe({
|
|
17
|
+
next: (is_cide_element_data_updated) => {
|
|
18
|
+
if (is_cide_element_data_updated) {
|
|
19
|
+
const cide_element_data = this.cide_element_data[body?.sype_key];
|
|
20
|
+
if (cide_element_data) {
|
|
21
|
+
subscription?.unsubscribe();
|
|
22
|
+
resolve(cide_element_data);
|
|
23
|
+
}
|
|
22
24
|
}
|
|
23
25
|
}
|
|
24
26
|
});
|
|
@@ -34,4 +36,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImpor
|
|
|
34
36
|
providedIn: 'root'
|
|
35
37
|
}]
|
|
36
38
|
}] });
|
|
37
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
39
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxlbWVudHMuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Nsb3VkLWlkZS1lbGVtZW50L3NyYy9saWIvdXRpbHMvc2VydmljZXMvZWxlbWVudHMvZWxlbWVudHMuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTNDLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxNQUFNLENBQUM7O0FBS3ZDLE1BQU0sT0FBTyxtQkFBbUI7SUFIaEM7UUFJRSxzQkFBaUIsR0FBaUMsRUFBRSxDQUFDO1FBQ3JELGlDQUE0QixHQUE2QixJQUFJLGVBQWUsQ0FBQyxLQUFLLENBQUMsQ0FBQztLQXFCckY7SUFwQkMsS0FBSyxDQUFDLGNBQWMsQ0FBQyxJQUEyQjtRQUM5QyxPQUFPLElBQUksT0FBTyxDQUFZLENBQUMsT0FBTyxFQUFFLEVBQUU7WUFDeEMsTUFBTSxpQkFBaUIsR0FBRyxJQUFJLENBQUMsaUJBQWlCLENBQUMsSUFBSSxFQUFFLFFBQVEsQ0FBQyxDQUFDO1lBQ2pFLElBQUksaUJBQWlCLEVBQUUsQ0FBQztnQkFDdEIsT0FBTyxDQUFDLGlCQUFpQixDQUFDLENBQUM7WUFDN0IsQ0FBQztpQkFBTSxDQUFDO2dCQUNOLE1BQU0sWUFBWSxHQUFHLElBQUksQ0FBQyw0QkFBNEIsRUFBRSxTQUFTLENBQUM7b0JBQ2hFLElBQUksRUFBRSxDQUFDLDRCQUFxQyxFQUFFLEVBQUU7d0JBQzlDLElBQUksNEJBQTRCLEVBQUUsQ0FBQzs0QkFDakMsTUFBTSxpQkFBaUIsR0FBRyxJQUFJLENBQUMsaUJBQWlCLENBQUMsSUFBSSxFQUFFLFFBQVEsQ0FBQyxDQUFDOzRCQUNqRSxJQUFJLGlCQUFpQixFQUFFLENBQUM7Z0NBQ3RCLFlBQVksRUFBRSxXQUFXLEVBQUUsQ0FBQztnQ0FDNUIsT0FBTyxDQUFDLGlCQUFpQixDQUFDLENBQUM7NEJBQzdCLENBQUM7d0JBQ0gsQ0FBQztvQkFDSCxDQUFDO2lCQUNGLENBQUMsQ0FBQztZQUNMLENBQUM7UUFDSCxDQUFDLENBQUMsQ0FBQTtJQUNKLENBQUM7OEdBdEJVLG1CQUFtQjtrSEFBbkIsbUJBQW1CLGNBRmxCLE1BQU07OzJGQUVQLG1CQUFtQjtrQkFIL0IsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEdldEVsZW1lbnREYXRhUmVxdWVzdCwgSUNvcmVTeXBlIH0gZnJvbSAnY2xvdWQtaWRlLWxtcy1tb2RlbCc7XHJcbmltcG9ydCB7IEJlaGF2aW9yU3ViamVjdCB9IGZyb20gJ3J4anMnO1xyXG5cclxuQEluamVjdGFibGUoe1xyXG4gIHByb3ZpZGVkSW46ICdyb290J1xyXG59KVxyXG5leHBvcnQgY2xhc3MgQ2lkZUVsZW1lbnRzU2VydmljZSB7XHJcbiAgY2lkZV9lbGVtZW50X2RhdGE6IHsgW2tleTogc3RyaW5nXTogSUNvcmVTeXBlIH0gPSB7fTtcclxuICBpc19jaWRlX2VsZW1lbnRfZGF0YV91cGRhdGVkOiBCZWhhdmlvclN1YmplY3Q8Ym9vbGVhbj4gPSBuZXcgQmVoYXZpb3JTdWJqZWN0KGZhbHNlKTtcclxuICBhc3luYyBnZXRFbGVtZW50RGF0YShib2R5OiBHZXRFbGVtZW50RGF0YVJlcXVlc3QpOiBQcm9taXNlPElDb3JlU3lwZT4ge1xyXG4gICAgcmV0dXJuIG5ldyBQcm9taXNlPElDb3JlU3lwZT4oKHJlc29sdmUpID0+IHtcclxuICAgICAgY29uc3QgY2lkZV9lbGVtZW50X2RhdGEgPSB0aGlzLmNpZGVfZWxlbWVudF9kYXRhW2JvZHk/LnN5cGVfa2V5XTtcclxuICAgICAgaWYgKGNpZGVfZWxlbWVudF9kYXRhKSB7XHJcbiAgICAgICAgcmVzb2x2ZShjaWRlX2VsZW1lbnRfZGF0YSk7XHJcbiAgICAgIH0gZWxzZSB7XHJcbiAgICAgICAgY29uc3Qgc3Vic2NyaXB0aW9uID0gdGhpcy5pc19jaWRlX2VsZW1lbnRfZGF0YV91cGRhdGVkPy5zdWJzY3JpYmUoe1xyXG4gICAgICAgICAgbmV4dDogKGlzX2NpZGVfZWxlbWVudF9kYXRhX3VwZGF0ZWQ6IGJvb2xlYW4pID0+IHtcclxuICAgICAgICAgICAgaWYgKGlzX2NpZGVfZWxlbWVudF9kYXRhX3VwZGF0ZWQpIHtcclxuICAgICAgICAgICAgICBjb25zdCBjaWRlX2VsZW1lbnRfZGF0YSA9IHRoaXMuY2lkZV9lbGVtZW50X2RhdGFbYm9keT8uc3lwZV9rZXldO1xyXG4gICAgICAgICAgICAgIGlmIChjaWRlX2VsZW1lbnRfZGF0YSkge1xyXG4gICAgICAgICAgICAgICAgc3Vic2NyaXB0aW9uPy51bnN1YnNjcmliZSgpO1xyXG4gICAgICAgICAgICAgICAgcmVzb2x2ZShjaWRlX2VsZW1lbnRfZGF0YSk7XHJcbiAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgICB9XHJcbiAgICAgICAgfSk7XHJcbiAgICAgIH1cclxuICAgIH0pXHJcbiAgfVxyXG59XHJcbiJdfQ==
|
package/esm2022/public-api.mjs
CHANGED
|
@@ -3,8 +3,29 @@
|
|
|
3
3
|
* Here we can add what need to be exported from library
|
|
4
4
|
*/
|
|
5
5
|
export * from './lib/elements/input/input.component';
|
|
6
|
-
export * from './lib/elements/button/button.component';
|
|
6
|
+
export * from './lib/elements/button/cide-ele-button.component';
|
|
7
7
|
export * from './lib/elements/spinner/spinner.component';
|
|
8
8
|
export * from './lib/elements/icon/icon.component';
|
|
9
|
+
export * from './lib/elements/select/select.component';
|
|
10
|
+
export * from './lib/elements/tab/cide-ele-tab.component';
|
|
11
|
+
export * from './lib/elements/file-input/file-input.component';
|
|
12
|
+
export * from './lib/elements/textarea/textarea.component';
|
|
9
13
|
export * from './lib/utils/services/elements/elements.service';
|
|
10
|
-
|
|
14
|
+
export * from './lib/utils/directives/resizer/resizer.directive';
|
|
15
|
+
export * from './lib/utils/directives/tooltip/tooltip.directive';
|
|
16
|
+
export * from './lib/components/skeleton-loader/skeleton-loader.component';
|
|
17
|
+
// Data Grid Component and Types
|
|
18
|
+
export * from './lib/components/data-grid/data-grid.component';
|
|
19
|
+
export * from './lib/components/data-grid/data-grid.types';
|
|
20
|
+
// Dropdown Component and Service
|
|
21
|
+
export * from './lib/components/dropdown/dropdown.component';
|
|
22
|
+
export * from './lib/services/dropdown-manager.service';
|
|
23
|
+
// Confirmation and Notification System
|
|
24
|
+
export * from './lib/services/confirmation.service';
|
|
25
|
+
export * from './lib/services/notification.service';
|
|
26
|
+
export * from './lib/components/confirmation-modal/confirmation-modal.component';
|
|
27
|
+
export * from './lib/components/toast-notification/toast-notification.component';
|
|
28
|
+
export * from './lib/components/global-notifications/global-notifications.component';
|
|
29
|
+
// JSON Editor Component
|
|
30
|
+
export * from './lib/components/json-editor/json-editor.component';
|
|
31
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2Nsb3VkLWlkZS1lbGVtZW50L3NyYy9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7R0FHRztBQUVILGNBQWMsc0NBQXNDLENBQUM7QUFDckQsY0FBYyxpREFBaUQsQ0FBQztBQUNoRSxjQUFjLDBDQUEwQyxDQUFDO0FBQ3pELGNBQWMsb0NBQW9DLENBQUM7QUFDbkQsY0FBYyx3Q0FBd0MsQ0FBQztBQUN2RCxjQUFjLDJDQUEyQyxDQUFDO0FBQzFELGNBQWMsZ0RBQWdELENBQUM7QUFDL0QsY0FBYyw0Q0FBNEMsQ0FBQztBQUMzRCxjQUFjLGdEQUFnRCxDQUFDO0FBQy9ELGNBQWMsa0RBQWtELENBQUM7QUFDakUsY0FBYyxrREFBa0QsQ0FBQztBQUNqRSxjQUFjLDREQUE0RCxDQUFDO0FBRTNFLGdDQUFnQztBQUNoQyxjQUFjLGdEQUFnRCxDQUFDO0FBQy9ELGNBQWMsNENBQTRDLENBQUM7QUFFM0QsaUNBQWlDO0FBQ2pDLGNBQWMsOENBQThDLENBQUM7QUFDN0QsY0FBYyx5Q0FBeUMsQ0FBQztBQUV4RCx1Q0FBdUM7QUFDdkMsY0FBYyxxQ0FBcUMsQ0FBQztBQUNwRCxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMsa0VBQWtFLENBQUM7QUFDakYsY0FBYyxrRUFBa0UsQ0FBQztBQUNqRixjQUFjLHNFQUFzRSxDQUFDO0FBRXJGLHdCQUF3QjtBQUN4QixjQUFjLG9EQUFvRCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBjbG91ZC1pZGUtZWxlbWVudFxuICogSGVyZSB3ZSBjYW4gYWRkIHdoYXQgbmVlZCB0byBiZSBleHBvcnRlZCBmcm9tIGxpYnJhcnlcbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi9lbGVtZW50cy9pbnB1dC9pbnB1dC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZWxlbWVudHMvYnV0dG9uL2NpZGUtZWxlLWJ1dHRvbi5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZWxlbWVudHMvc3Bpbm5lci9zcGlubmVyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9lbGVtZW50cy9pY29uL2ljb24uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2VsZW1lbnRzL3NlbGVjdC9zZWxlY3QuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2VsZW1lbnRzL3RhYi9jaWRlLWVsZS10YWIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2VsZW1lbnRzL2ZpbGUtaW5wdXQvZmlsZS1pbnB1dC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZWxlbWVudHMvdGV4dGFyZWEvdGV4dGFyZWEuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3V0aWxzL3NlcnZpY2VzL2VsZW1lbnRzL2VsZW1lbnRzLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdXRpbHMvZGlyZWN0aXZlcy9yZXNpemVyL3Jlc2l6ZXIuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3V0aWxzL2RpcmVjdGl2ZXMvdG9vbHRpcC90b29sdGlwLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL3NrZWxldG9uLWxvYWRlci9za2VsZXRvbi1sb2FkZXIuY29tcG9uZW50JztcblxuLy8gRGF0YSBHcmlkIENvbXBvbmVudCBhbmQgVHlwZXNcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvZGF0YS1ncmlkL2RhdGEtZ3JpZC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9kYXRhLWdyaWQvZGF0YS1ncmlkLnR5cGVzJztcblxuLy8gRHJvcGRvd24gQ29tcG9uZW50IGFuZCBTZXJ2aWNlXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Ryb3Bkb3duL2Ryb3Bkb3duLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zZXJ2aWNlcy9kcm9wZG93bi1tYW5hZ2VyLnNlcnZpY2UnO1xuXG4vLyBDb25maXJtYXRpb24gYW5kIE5vdGlmaWNhdGlvbiBTeXN0ZW1cbmV4cG9ydCAqIGZyb20gJy4vbGliL3NlcnZpY2VzL2NvbmZpcm1hdGlvbi5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3NlcnZpY2VzL25vdGlmaWNhdGlvbi5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY29uZmlybWF0aW9uLW1vZGFsL2NvbmZpcm1hdGlvbi1tb2RhbC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy90b2FzdC1ub3RpZmljYXRpb24vdG9hc3Qtbm90aWZpY2F0aW9uLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2dsb2JhbC1ub3RpZmljYXRpb25zL2dsb2JhbC1ub3RpZmljYXRpb25zLmNvbXBvbmVudCc7XG5cbi8vIEpTT04gRWRpdG9yIENvbXBvbmVudFxuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9qc29uLWVkaXRvci9qc29uLWVkaXRvci5jb21wb25lbnQnO1xuXG4iXX0=
|