@ruc-lib/overlay 2.0.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/README.md ADDED
@@ -0,0 +1,113 @@
1
+ # Overlay
2
+
3
+ A customizable Angular overlay component that display richer content, such as text, images, tables, charts and more. They are useful for providing additional information to users without cluttering the interface.
4
+
5
+ ## Installation Guide
6
+
7
+ To use the Overlay component, you can install the entire RUC library or just this specific component.
8
+
9
+ ### Install the Entire Library
10
+ ```bash
11
+ npm install @uxpractice/ruc-lib
12
+ ```
13
+
14
+ ### Install Individual Component
15
+ If you only need the Overlay component:
16
+ ```bash
17
+ npm install @uxpractice/overlay
18
+ ```
19
+
20
+ ## Usage
21
+
22
+ ### 1. Import the Module
23
+ In your Angular module file (e.g., `app.module.ts`), import the `RuclibOverlayModule`:
24
+
25
+ ```typescript
26
+ import { RuclibOverlayModule } from '@uxpractice/overlay';
27
+ import { AppComponent } from './app.component';
28
+ import { NgModule } from '@angular/core';
29
+ import { BrowserModule } from '@angular/platform-browser';
30
+
31
+ @NgModule({
32
+ declarations: [AppComponent],
33
+ imports: [
34
+ BrowserModule,
35
+ RuclibOverlayModule
36
+ ],
37
+ providers: [],
38
+ bootstrap: [AppComponent]
39
+ })
40
+ export class AppModule {}
41
+ ```
42
+
43
+ ### 2. Use the Component
44
+ In your component's template, use the `<uxp-ruclib-overlay>` selector and pass the configuration object to the `rucInputData` input.
45
+
46
+ ```html
47
+ <uxp-ruclib-overlay [rucInputData]="OverlayConfig"></uxp-ruclib-overlay>
48
+ ```
49
+
50
+ ## API Reference
51
+
52
+ ### Component Inputs
53
+
54
+ | Input | Type | Description |
55
+ |----------------|--------------------|----------------------------------------------|
56
+ | `rucInputData` | `OverlayConfig` | The main configuration object for the component. |
57
+ | `customTheme` | `string` | An optional CSS class for custom theming. |
58
+
59
+
60
+ ### `OverlayConfig`
61
+ This is the main configuration object for the overlay
62
+
63
+ | Property | Type | Description |
64
+ |-----------------------------|--------------------------------------------------|---------------------------------------------------------------------------------------------------------|
65
+ | `placement` | `'bottom' \| 'top' \| 'left' \| 'right'` | The position of the overlay content (e.g., 0). |
66
+ | `trigger` | `'click'\|'hover' \` | The maximum value of the progress bar (e.g., 100). |
67
+ | `overlayTitle` | `string` | The title of the overlay content. |
68
+ | `content` | `'string' \| templateRef` | If accept string or html template both of displaying the content inside overlay area. |
69
+ | `animation` | `'fade' \| 'scale' \|` | The animation type for the overlay content (e.g., 'fade', 'scale').. Defaults to `fade`. |
70
+ | `showCloseButton` | `boolean` | It close the overlay.. Defaults to `false`. |
71
+ | `closeIcon` | `string` | Icon class for the close button. User can give his own icon for close the overlay. |
72
+ | `tableData` | `any[]` | It accept array of object and display data in table format inside overlay. |
73
+ | `tableClass` | `'basic-table' \|'striped-table' \|` | It accept table styling class .. Defaults to `basic-table`. |
74
+ | `closeDelay` | `number` | it delay the overlay close(milliseconds). |
75
+ | `chartConfig` | `any` | it can display chart if user provide chart configuration. |
76
+
77
+
78
+
79
+ ## Example Configuration
80
+
81
+ Here's an example of how to configure the Overlay in your component's TypeScript file.
82
+
83
+ ```typescript
84
+ import { Component } from '@angular/core';
85
+ import { OverlayConfig } from '@uxpractice/overlay';
86
+
87
+ @Component({
88
+ selector: 'app-root',
89
+ templateUrl: './app.component.html',
90
+ })
91
+ export class AppComponent {
92
+ overlayConfig: OverlayConfig = {
93
+ placement: 'left',
94
+ overlayTitle: 'Animated Popover with fade',
95
+ content: 'This is a simple popover triggered by a click.',
96
+ trigger: 'click',
97
+ animation: 'fade',
98
+ closeIcon: 'close',
99
+ showCloseButton : true,;
100
+ }
101
+ }
102
+ ```
103
+
104
+ ```html
105
+ <uxp-ruclib-overlay [rucInputData]="overlayConfig"></uxp-ruclib-overlay>
106
+
107
+ ## Contribution
108
+
109
+ Contributions are welcome! Feel free to open issues or pull requests for any enhancements or fixes.
110
+
111
+ ## Acknowledgements
112
+
113
+ Thank you for choosing the Overlay component. If you have any feedback or suggestions, please let us know!
@@ -0,0 +1,7 @@
1
+ export * from './lib/ruclib-overlay.module';
2
+ export * from './lib/ruc-overlay-chart/ruc-overlay-chart.component';
3
+ export * from './lib/service/overlay.service';
4
+ export * from './lib/model/overlay.types';
5
+ export * from './lib/overlay-content/overlay-content.component';
6
+ export * from './lib/ruclib-overlay/ruclib-overlay.component';
7
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLHFEQUFxRCxDQUFDO0FBQ3BFLGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYywyQkFBMkIsQ0FBQztBQUMxQyxjQUFjLGlEQUFpRCxDQUFDO0FBQ2hFLGNBQWMsK0NBQStDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2xpYi9ydWNsaWItb3ZlcmxheS5tb2R1bGUnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9ydWMtb3ZlcmxheS1jaGFydC9ydWMtb3ZlcmxheS1jaGFydC5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9zZXJ2aWNlL292ZXJsYXkuc2VydmljZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZGVsL292ZXJsYXkudHlwZXMnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9vdmVybGF5LWNvbnRlbnQvb3ZlcmxheS1jb250ZW50LmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3J1Y2xpYi1vdmVybGF5L3J1Y2xpYi1vdmVybGF5LmNvbXBvbmVudCc7XHJcbiJdfQ==
@@ -0,0 +1,7 @@
1
+ export const positions = [
2
+ { originX: 'center', originY: 'bottom', overlayX: 'center', overlayY: 'top', offsetY: 10 },
3
+ { originX: 'center', originY: 'top', overlayX: 'center', overlayY: 'bottom', offsetY: -10 },
4
+ { originX: 'end', originY: 'center', overlayX: 'start', overlayY: 'center', offsetX: 10 },
5
+ { originX: 'start', originY: 'center', overlayX: 'end', overlayY: 'center', offsetX: -10 }
6
+ ];
7
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9zaXRpb25zLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2xpYi9jb25zdGFudHMvcG9zaXRpb25zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE1BQU0sQ0FBQyxNQUFNLFNBQVMsR0FBd0I7SUFDeEMsRUFBRSxPQUFPLEVBQUUsUUFBUSxFQUFFLE9BQU8sRUFBRSxRQUFRLEVBQUUsUUFBUSxFQUFFLFFBQVEsRUFBRSxRQUFRLEVBQUUsS0FBSyxFQUFFLE9BQU8sRUFBRSxFQUFFLEVBQUU7SUFDMUYsRUFBRSxPQUFPLEVBQUUsUUFBUSxFQUFFLE9BQU8sRUFBRSxLQUFLLEVBQUUsUUFBUSxFQUFFLFFBQVEsRUFBRSxRQUFRLEVBQUUsUUFBUSxFQUFFLE9BQU8sRUFBRSxDQUFDLEVBQUUsRUFBRTtJQUMzRixFQUFFLE9BQU8sRUFBRSxLQUFLLEVBQUUsT0FBTyxFQUFFLFFBQVEsRUFBRSxRQUFRLEVBQUUsT0FBTyxFQUFFLFFBQVEsRUFBRSxRQUFRLEVBQUUsT0FBTyxFQUFFLEVBQUUsRUFBRTtJQUN6RixFQUFFLE9BQU8sRUFBRSxPQUFPLEVBQUUsT0FBTyxFQUFFLFFBQVEsRUFBRSxRQUFRLEVBQUUsS0FBSyxFQUFFLFFBQVEsRUFBRSxRQUFRLEVBQUUsT0FBTyxFQUFFLENBQUMsRUFBRSxFQUFFO0NBQzNGLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb25uZWN0ZWRQb3NpdGlvbiB9IGZyb20gXCJAYW5ndWxhci9jZGsvb3ZlcmxheVwiO1xyXG5cclxuZXhwb3J0IGNvbnN0IHBvc2l0aW9uczogQ29ubmVjdGVkUG9zaXRpb25bXSA9IFtcclxuICAgICAgeyBvcmlnaW5YOiAnY2VudGVyJywgb3JpZ2luWTogJ2JvdHRvbScsIG92ZXJsYXlYOiAnY2VudGVyJywgb3ZlcmxheVk6ICd0b3AnLCBvZmZzZXRZOiAxMCB9LFxyXG4gICAgICB7IG9yaWdpblg6ICdjZW50ZXInLCBvcmlnaW5ZOiAndG9wJywgb3ZlcmxheVg6ICdjZW50ZXInLCBvdmVybGF5WTogJ2JvdHRvbScsIG9mZnNldFk6IC0xMCB9LFxyXG4gICAgICB7IG9yaWdpblg6ICdlbmQnLCBvcmlnaW5ZOiAnY2VudGVyJywgb3ZlcmxheVg6ICdzdGFydCcsIG92ZXJsYXlZOiAnY2VudGVyJywgb2Zmc2V0WDogMTAgfSxcclxuICAgICAgeyBvcmlnaW5YOiAnc3RhcnQnLCBvcmlnaW5ZOiAnY2VudGVyJywgb3ZlcmxheVg6ICdlbmQnLCBvdmVybGF5WTogJ2NlbnRlcicsIG9mZnNldFg6IC0xMCB9XHJcbiAgICBdO1xyXG4iXX0=
@@ -0,0 +1,7 @@
1
+ import { InjectionToken } from '@angular/core';
2
+ /**
3
+ * The Injection Token used to provide the PopoverControl object to the
4
+ * PopoverContentComponent. This is the correct, final version.
5
+ */
6
+ export const OVERLAY_CONTROL = new InjectionToken('OVERLAY_CONTROL');
7
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3ZlcmxheS50eXBlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9saWIvbW9kZWwvb3ZlcmxheS50eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsY0FBYyxFQUFlLE1BQU0sZUFBZSxDQUFDO0FBdUM1RDs7O0VBR0U7QUFDRixNQUFNLENBQUMsTUFBTSxlQUFlLEdBQUcsSUFBSSxjQUFjLENBQWlCLGlCQUFpQixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3Rpb25Ub2tlbiwgVGVtcGxhdGVSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbi8qKlxyXG4qIERlZmluZXMgdGhlIGNvbmZpZ3VyYXRpb24gb3B0aW9ucyB0aGF0IGEgdXNlciBjYW4gcGFzcyB0byB0aGUgcG9wb3Zlci5cclxuKiBUaGlzIGlzIHRoZSBwdWJsaWMgQVBJIG9mIHlvdXIgY29tcG9uZW50LlxyXG4qL1xyXG5leHBvcnQgaW50ZXJmYWNlIE92ZXJsYXlDb25maWcge1xyXG4gIHBsYWNlbWVudD86ICd0b3AnIHwgJ2JvdHRvbScgfCAnbGVmdCcgfCAncmlnaHQnIHwgc3RyaW5nO1xyXG4gIG92ZXJsYXlUaXRsZT86IHN0cmluZztcclxuICBjb250ZW50Pzogc3RyaW5nIHwgVGVtcGxhdGVSZWY8YW55PjtcclxuICBhbmltYXRpb24/OiAnZmFkZScgfCAnc2NhbGUnO1xyXG4gIHRyaWdnZXI/OiAnY2xpY2snIHwgJ2hvdmVyJztcclxuICBzaG93Q2xvc2VCdXR0b24/OiBib29sZWFuO1xyXG4gIGNsb3NlSWNvbj86IHN0cmluZztcclxuICB0YWJsZURhdGE/OiBhbnlbXTtcclxuICB0YWJsZUNsYXNzPzogc3RyaW5nO1xyXG4gIGNsb3NlRGVsYXk/Om51bWJlcixcclxuICBjaGFydENvbmZpZz86YW55XHJcbn1cclxuXHJcbi8qKlxyXG4qIERlZmluZXMgdGhlIGRhdGEgcGFja2V0IHRoYXQgdGhlIFBvcG92ZXJTZXJ2aWNlIHNlbmRzLlxyXG4qIEl0IGNvbnRhaW5zIHRoZSBjb25maWd1cmF0aW9uIEFORCB0aGUgZWxlbWVudCB0byBwb3NpdGlvbiBhZ2FpbnN0LlxyXG4qIFRISVMgSVMgVEhFIE9ORSBUSEUgU0VSVklDRSBVU0VTLlxyXG4qL1xyXG5leHBvcnQgaW50ZXJmYWNlIE92ZXJsYXlEYXRhIHtcclxuICBjb25maWc6IE92ZXJsYXlDb25maWc7XHJcbiAgdHJpZ2dlcjogSFRNTEVsZW1lbnQ7XHJcbn1cclxuXHJcbi8qKlxyXG4qIERlZmluZXMgdGhlIGRhdGEgYW5kIGNvbnRyb2xzIHBhc3NlZCB0byB0aGUgZHluYW1pY2FsbHkgY3JlYXRlZCBQb3BvdmVyQ29udGVudENvbXBvbmVudC5cclxuKiBJdCBpbmNsdWRlcyB0aGUgY29uZmlnIEFORCBhIGNhbGxiYWNrIGZ1bmN0aW9uIHRvIGNsb3NlIHRoZSBwb3BvdmVyLlxyXG4qL1xyXG5leHBvcnQgaW50ZXJmYWNlIE92ZXJsYXlDb250cm9sIHtcclxuICBjb25maWc6IE92ZXJsYXlDb25maWc7XHJcbiAgY2xvc2U6ICgpID0+IHZvaWQ7XHJcbn1cclxuXHJcbi8qKlxyXG4qIFRoZSBJbmplY3Rpb24gVG9rZW4gdXNlZCB0byBwcm92aWRlIHRoZSBQb3BvdmVyQ29udHJvbCBvYmplY3QgdG8gdGhlXHJcbiogUG9wb3ZlckNvbnRlbnRDb21wb25lbnQuIFRoaXMgaXMgdGhlIGNvcnJlY3QsIGZpbmFsIHZlcnNpb24uXHJcbiovXHJcbmV4cG9ydCBjb25zdCBPVkVSTEFZX0NPTlRST0wgPSBuZXcgSW5qZWN0aW9uVG9rZW48T3ZlcmxheUNvbnRyb2w+KCdPVkVSTEFZX0NPTlRST0wnKTtcclxuIl19
@@ -0,0 +1,86 @@
1
+ import { Component, EventEmitter, HostBinding, Inject, Output, TemplateRef, } from '@angular/core';
2
+ import { animate, state, style, transition, trigger, } from '@angular/animations';
3
+ import { OVERLAY_CONTROL } from '../model/overlay.types';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "@angular/common";
6
+ import * as i2 from "@angular/material/icon";
7
+ import * as i3 from "../ruc-overlay-chart/ruc-overlay-chart.component";
8
+ export class OverlayContentComponent {
9
+ ngOnInit() {
10
+ if (this.control.config.tableData) {
11
+ this.getTableHeaders();
12
+ }
13
+ }
14
+ get animationState() {
15
+ return this.control.config.animation === 'scale'
16
+ ? 'enter-scale'
17
+ : 'enter-fade';
18
+ }
19
+ constructor(control) {
20
+ this.control = control;
21
+ this.actualPlacement = 'bottom';
22
+ this.tableHeaders = [];
23
+ this.mouseEnterPopover = new EventEmitter();
24
+ this.mouseLeavePopover = new EventEmitter();
25
+ this.actualPlacement = this.control.config.placement || 'bottom';
26
+ }
27
+ // Helper to check if content is a TemplateRef
28
+ isTemplateRef(content) {
29
+ return content instanceof TemplateRef;
30
+ }
31
+ // Helper to get keys for the table header, robustly
32
+ getTableHeaders() {
33
+ const tempData = this.control.config.tableData;
34
+ if (!tempData || tempData.length === 0) {
35
+ this.tableHeaders = [];
36
+ return;
37
+ }
38
+ // Assumes all objects in the array have the same shape
39
+ this.tableHeaders = Object.keys(tempData[0]);
40
+ }
41
+ }
42
+ OverlayContentComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: OverlayContentComponent, deps: [{ token: OVERLAY_CONTROL }], target: i0.ɵɵFactoryTarget.Component });
43
+ OverlayContentComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: OverlayContentComponent, selector: "uxp-overlay-content", outputs: { mouseEnterPopover: "mouseEnterPopover", mouseLeavePopover: "mouseLeavePopover" }, host: { properties: { "@popoverAnimation": "this.animationState" } }, ngImport: i0, template: "<div class=\"popover-container\" (click)=\"$event.stopPropagation()\">\r\n <div class=\"popover-arrow\" [attr.data-placement]=\"actualPlacement\"></div>\r\n <!-- Header with optional title and close button -->\r\n <div\r\n *ngIf=\"\r\n control.config.overlayTitle ||\r\n control.config.showCloseButton ||\r\n control.config.closeIcon\r\n \"\r\n class=\"popover-header\"\r\n >\r\n <h3 *ngIf=\"control.config.overlayTitle\">\r\n {{ control.config.overlayTitle }}\r\n </h3>\r\n\r\n\r\n <ng-container *ngIf=\"control.config.showCloseButton\">\r\n <button\r\n type=\"button\"\r\n class=\"close-btn\"\r\n aria-label=\"Close\"\r\n (click)=\"control.close()\"\r\n >\r\n <mat-icon>{{ control.config.closeIcon }}</mat-icon>\r\n </button>\r\n </ng-container>\r\n </div>\r\n\r\n <!-- Body with dynamic content -->\r\n <div class=\"popover-body\">\r\n <!-- Case 1: Content is a simple string -->\r\n <ng-container\r\n *ngIf=\"\r\n !isTemplateRef(control.config.content) && !control.config.tableData\r\n \"\r\n >\r\n {{ control.config.content }}\r\n </ng-container>\r\n\r\n <!-- Case 2: Content is a TemplateRef -->\r\n <ng-container *ngIf=\"isTemplateRef(control.config.content)\">\r\n <ng-container *ngTemplateOutlet=\"control.config.content\"></ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"control.config.chartConfig\">\r\n\r\n <uxp-ruc-overlay-chart [chartConfig]=\"control.config.chartConfig\"></uxp-ruc-overlay-chart>\r\n </ng-container>\r\n\r\n <!-- Case 3: Content is table data -->\r\n <ng-container *ngIf=\"control.config.tableData?.length\">\r\n <table\r\n class=\"popover-table\"\r\n [class]=\"control.config.tableClass || 'basic-table'\"\r\n >\r\n <thead>\r\n <tr>\r\n <th\r\n *ngFor=\"let header of this.tableHeaders!\"\r\n >\r\n {{ header }}\r\n </th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr *ngFor=\"let row of control.config.tableData\">\r\n <td\r\n *ngFor=\"let header of this.tableHeaders!\"\r\n >\r\n {{ row[header] }}\r\n </td>\r\n </tr>\r\n </tbody>\r\n </table>\r\n </ng-container>\r\n </div>\r\n</div>\r\n", styles: [":host{display:block}.popover-container{z-index:1080;background-color:#fff;border:1px solid rgba(0,0,0,.2);border-radius:6px;box-shadow:0 5px 10px #0003;position:relative;color:#333;max-width:300px}.popover-arrow{position:absolute;width:0;height:0;border-color:transparent;border-style:solid;border-width:10px}.popover-arrow[data-placement^=top]{bottom:-10px;left:50%;transform:translate(-50%);border-bottom-width:0;border-top-color:#fff;filter:drop-shadow(0 -1px 1px rgba(0,0,0,.1))}.popover-arrow[data-placement^=bottom]{top:-10px;left:50%;transform:translate(-50%);border-top-width:0;border-bottom-color:#fff;filter:drop-shadow(0 1px 1px rgba(0,0,0,.1))}.popover-arrow[data-placement^=left]{right:-10px;top:50%;transform:translateY(-50%);border-right-width:0;border-left-color:#fff;filter:drop-shadow(-1px 0 1px rgba(0,0,0,.1))}.popover-arrow[data-placement^=right]{left:-10px;top:50%;transform:translateY(-50%);border-left-width:0;border-right-color:#fff;filter:drop-shadow(1px 0 1px rgba(0,0,0,.1))}.popover-header{display:flex;justify-content:space-between;align-items:center;padding:.5rem 1rem;margin:0;font-size:1rem;background-color:#f0f0f0;border-bottom:1px solid #dcdcdc;border-radius:5px 5px 0 0}.popover-header h3{margin:0;font-size:1rem}.popover-body{padding:9px 14px;color:#212529}.close-btn,.close-icon{border:none;background:transparent;font-size:1.5rem;line-height:1;cursor:pointer;padding:0;margin-left:10px;opacity:.5}.close-btn:hover,.close-icon:hover{opacity:1}.popover-table{width:100%;border-collapse:collapse;margin-top:5px}.popover-table th,.popover-table td{border:1px solid #ddd;padding:8px;text-align:left}.popover-table th{background-color:#f2f2f2;text-transform:capitalize}.popover-table.striped-table tbody tr:nth-of-type(odd){background-color:#f9f9f9}.striped-table{width:100%;border-collapse:collapse;font-size:.9em}.striped-table th,.striped-table td{border:1px solid #ddd;padding:8px;text-align:left}.striped-table thead th{background-color:#f2f2f2;font-weight:700}.striped-table tbody tr:nth-child(even){background-color:#e9ecef}.striped-table tbody tr:hover{background-color:#f1f1f1}.basic-table{width:100%;border-collapse:collapse;font-size:.9em}.basic-table th,.basic-table td{border:1px solid #ddd;padding:8px;text-align:left}.basic-table thead th{background-color:#fff;font-weight:700}.basic-table tbody tr:nth-child(even){background-color:#fff}.basic-table tbody tr:hover{background-color:#f1f1f1}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i3.RucOverlayChartComponent, selector: "uxp-ruc-overlay-chart", inputs: ["index", "chartConfig"] }], animations: [
44
+ trigger('popoverAnimation', [
45
+ state('void', style({ transform: 'scale(0.9)', opacity: 0 })),
46
+ state('enter-scale', style({ transform: 'scale(1)', opacity: 1 })),
47
+ state('enter-fade', style({ opacity: 1 })),
48
+ transition('void => enter-scale', animate('150ms cubic-bezier(0, 0, 0.2, 1)')),
49
+ transition('void => enter-fade', [
50
+ style({ opacity: 0, transform: 'translateY(10px)' }),
51
+ animate('500ms', style({ opacity: 1, transform: 'translateY(0)' })),
52
+ ]),
53
+ transition('* => void', [
54
+ animate('500ms', style({ opacity: 0, transform: 'translateY(10px)' })),
55
+ ]),
56
+ ]),
57
+ ] });
58
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: OverlayContentComponent, decorators: [{
59
+ type: Component,
60
+ args: [{ selector: 'uxp-overlay-content', animations: [
61
+ trigger('popoverAnimation', [
62
+ state('void', style({ transform: 'scale(0.9)', opacity: 0 })),
63
+ state('enter-scale', style({ transform: 'scale(1)', opacity: 1 })),
64
+ state('enter-fade', style({ opacity: 1 })),
65
+ transition('void => enter-scale', animate('150ms cubic-bezier(0, 0, 0.2, 1)')),
66
+ transition('void => enter-fade', [
67
+ style({ opacity: 0, transform: 'translateY(10px)' }),
68
+ animate('500ms', style({ opacity: 1, transform: 'translateY(0)' })),
69
+ ]),
70
+ transition('* => void', [
71
+ animate('500ms', style({ opacity: 0, transform: 'translateY(10px)' })),
72
+ ]),
73
+ ]),
74
+ ], template: "<div class=\"popover-container\" (click)=\"$event.stopPropagation()\">\r\n <div class=\"popover-arrow\" [attr.data-placement]=\"actualPlacement\"></div>\r\n <!-- Header with optional title and close button -->\r\n <div\r\n *ngIf=\"\r\n control.config.overlayTitle ||\r\n control.config.showCloseButton ||\r\n control.config.closeIcon\r\n \"\r\n class=\"popover-header\"\r\n >\r\n <h3 *ngIf=\"control.config.overlayTitle\">\r\n {{ control.config.overlayTitle }}\r\n </h3>\r\n\r\n\r\n <ng-container *ngIf=\"control.config.showCloseButton\">\r\n <button\r\n type=\"button\"\r\n class=\"close-btn\"\r\n aria-label=\"Close\"\r\n (click)=\"control.close()\"\r\n >\r\n <mat-icon>{{ control.config.closeIcon }}</mat-icon>\r\n </button>\r\n </ng-container>\r\n </div>\r\n\r\n <!-- Body with dynamic content -->\r\n <div class=\"popover-body\">\r\n <!-- Case 1: Content is a simple string -->\r\n <ng-container\r\n *ngIf=\"\r\n !isTemplateRef(control.config.content) && !control.config.tableData\r\n \"\r\n >\r\n {{ control.config.content }}\r\n </ng-container>\r\n\r\n <!-- Case 2: Content is a TemplateRef -->\r\n <ng-container *ngIf=\"isTemplateRef(control.config.content)\">\r\n <ng-container *ngTemplateOutlet=\"control.config.content\"></ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"control.config.chartConfig\">\r\n\r\n <uxp-ruc-overlay-chart [chartConfig]=\"control.config.chartConfig\"></uxp-ruc-overlay-chart>\r\n </ng-container>\r\n\r\n <!-- Case 3: Content is table data -->\r\n <ng-container *ngIf=\"control.config.tableData?.length\">\r\n <table\r\n class=\"popover-table\"\r\n [class]=\"control.config.tableClass || 'basic-table'\"\r\n >\r\n <thead>\r\n <tr>\r\n <th\r\n *ngFor=\"let header of this.tableHeaders!\"\r\n >\r\n {{ header }}\r\n </th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr *ngFor=\"let row of control.config.tableData\">\r\n <td\r\n *ngFor=\"let header of this.tableHeaders!\"\r\n >\r\n {{ row[header] }}\r\n </td>\r\n </tr>\r\n </tbody>\r\n </table>\r\n </ng-container>\r\n </div>\r\n</div>\r\n", styles: [":host{display:block}.popover-container{z-index:1080;background-color:#fff;border:1px solid rgba(0,0,0,.2);border-radius:6px;box-shadow:0 5px 10px #0003;position:relative;color:#333;max-width:300px}.popover-arrow{position:absolute;width:0;height:0;border-color:transparent;border-style:solid;border-width:10px}.popover-arrow[data-placement^=top]{bottom:-10px;left:50%;transform:translate(-50%);border-bottom-width:0;border-top-color:#fff;filter:drop-shadow(0 -1px 1px rgba(0,0,0,.1))}.popover-arrow[data-placement^=bottom]{top:-10px;left:50%;transform:translate(-50%);border-top-width:0;border-bottom-color:#fff;filter:drop-shadow(0 1px 1px rgba(0,0,0,.1))}.popover-arrow[data-placement^=left]{right:-10px;top:50%;transform:translateY(-50%);border-right-width:0;border-left-color:#fff;filter:drop-shadow(-1px 0 1px rgba(0,0,0,.1))}.popover-arrow[data-placement^=right]{left:-10px;top:50%;transform:translateY(-50%);border-left-width:0;border-right-color:#fff;filter:drop-shadow(1px 0 1px rgba(0,0,0,.1))}.popover-header{display:flex;justify-content:space-between;align-items:center;padding:.5rem 1rem;margin:0;font-size:1rem;background-color:#f0f0f0;border-bottom:1px solid #dcdcdc;border-radius:5px 5px 0 0}.popover-header h3{margin:0;font-size:1rem}.popover-body{padding:9px 14px;color:#212529}.close-btn,.close-icon{border:none;background:transparent;font-size:1.5rem;line-height:1;cursor:pointer;padding:0;margin-left:10px;opacity:.5}.close-btn:hover,.close-icon:hover{opacity:1}.popover-table{width:100%;border-collapse:collapse;margin-top:5px}.popover-table th,.popover-table td{border:1px solid #ddd;padding:8px;text-align:left}.popover-table th{background-color:#f2f2f2;text-transform:capitalize}.popover-table.striped-table tbody tr:nth-of-type(odd){background-color:#f9f9f9}.striped-table{width:100%;border-collapse:collapse;font-size:.9em}.striped-table th,.striped-table td{border:1px solid #ddd;padding:8px;text-align:left}.striped-table thead th{background-color:#f2f2f2;font-weight:700}.striped-table tbody tr:nth-child(even){background-color:#e9ecef}.striped-table tbody tr:hover{background-color:#f1f1f1}.basic-table{width:100%;border-collapse:collapse;font-size:.9em}.basic-table th,.basic-table td{border:1px solid #ddd;padding:8px;text-align:left}.basic-table thead th{background-color:#fff;font-weight:700}.basic-table tbody tr:nth-child(even){background-color:#fff}.basic-table tbody tr:hover{background-color:#f1f1f1}\n"] }]
75
+ }], ctorParameters: function () { return [{ type: undefined, decorators: [{
76
+ type: Inject,
77
+ args: [OVERLAY_CONTROL]
78
+ }] }]; }, propDecorators: { mouseEnterPopover: [{
79
+ type: Output
80
+ }], mouseLeavePopover: [{
81
+ type: Output
82
+ }], animationState: [{
83
+ type: HostBinding,
84
+ args: ['@popoverAnimation']
85
+ }] } });
86
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"overlay-content.component.js","sourceRoot":"","sources":["../../../../src/lib/overlay-content/overlay-content.component.ts","../../../../src/lib/overlay-content/overlay-content.component.html"],"names":[],"mappings":"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","sourcesContent":["import { OverlayControl } from './../model/overlay.types';\r\n\r\nimport {\r\n  Component,\r\n  EventEmitter,\r\n  HostBinding,\r\n  Inject,\r\n  OnInit,\r\n  Output,\r\n  TemplateRef,\r\n} from '@angular/core';\r\nimport {\r\n  animate,\r\n  state,\r\n  style,\r\n  transition,\r\n  trigger,\r\n} from '@angular/animations';\r\nimport { OVERLAY_CONTROL } from '../model/overlay.types';\r\nimport { PopoverPlacement } from '../ruclib-overlay/ruclib-overlay.component';\r\n\r\n@Component({\r\n  selector: 'uxp-overlay-content',\r\n  templateUrl: './overlay-content.component.html',\r\n  styleUrls: ['./overlay-content.component.scss'],\r\n  animations: [\r\n    trigger('popoverAnimation', [\r\n      state('void', style({ transform: 'scale(0.9)', opacity: 0 })),\r\n      state('enter-scale', style({ transform: 'scale(1)', opacity: 1 })),\r\n      state('enter-fade', style({ opacity: 1 })),\r\n      transition(\r\n        'void => enter-scale',\r\n        animate('150ms cubic-bezier(0, 0, 0.2, 1)')\r\n      ),\r\n      transition('void => enter-fade', [\r\n        style({ opacity: 0, transform: 'translateY(10px)' }),\r\n        animate('500ms', style({ opacity: 1, transform: 'translateY(0)' })),\r\n      ]),\r\n      transition('* => void', [\r\n        animate('500ms', style({ opacity: 0, transform: 'translateY(10px)' })),\r\n      ]),\r\n    ]),\r\n  ],\r\n})\r\n\r\nexport class OverlayContentComponent implements OnInit {\r\n  public actualPlacement: string | PopoverPlacement = 'bottom';\r\n  public tableHeaders:any[]=[];\r\n\r\n  @Output() mouseEnterPopover = new EventEmitter<void>();\r\n  @Output() mouseLeavePopover = new EventEmitter<void>();\r\n\r\n\r\n  ngOnInit(): void {\r\n    if(this.control.config.tableData) {\r\n        this.getTableHeaders();\r\n    }    \r\n  }\r\n\r\n  @HostBinding('@popoverAnimation')\r\n  get animationState() {\r\n    return this.control.config.animation === 'scale'\r\n      ? 'enter-scale'\r\n      : 'enter-fade';\r\n  }\r\n\r\n  constructor(@Inject(OVERLAY_CONTROL) public control: OverlayControl) {\r\n    this.actualPlacement = this.control.config.placement || 'bottom';\r\n  }\r\n\r\n  // Helper to check if content is a TemplateRef\r\n  isTemplateRef(content: any): content is TemplateRef<any> {\r\n    return content instanceof TemplateRef;\r\n  }\r\n\r\n  // Helper to get keys for the table header, robustly\r\n  getTableHeaders(): void {\r\n    const tempData = this.control.config.tableData;\r\n\r\n    if (!tempData || tempData.length === 0) {\r\n      this.tableHeaders = [];\r\n      return;\r\n    }\r\n    // Assumes all objects in the array have the same shape\r\n    this.tableHeaders = Object.keys(tempData[0]);\r\n  }\r\n}\r\n","<div class=\"popover-container\" (click)=\"$event.stopPropagation()\">\r\n  <div class=\"popover-arrow\" [attr.data-placement]=\"actualPlacement\"></div>\r\n  <!-- Header with optional title and close button -->\r\n  <div\r\n    *ngIf=\"\r\n      control.config.overlayTitle ||\r\n      control.config.showCloseButton ||\r\n      control.config.closeIcon\r\n    \"\r\n    class=\"popover-header\"\r\n  >\r\n    <h3 *ngIf=\"control.config.overlayTitle\">\r\n      {{ control.config.overlayTitle }}\r\n    </h3>\r\n\r\n\r\n    <ng-container *ngIf=\"control.config.showCloseButton\">\r\n      <button\r\n        type=\"button\"\r\n        class=\"close-btn\"\r\n        aria-label=\"Close\"\r\n        (click)=\"control.close()\"\r\n      >\r\n        <mat-icon>{{ control.config.closeIcon }}</mat-icon>\r\n      </button>\r\n    </ng-container>\r\n  </div>\r\n\r\n  <!-- Body with dynamic content -->\r\n  <div class=\"popover-body\">\r\n    <!-- Case 1: Content is a simple string -->\r\n    <ng-container\r\n      *ngIf=\"\r\n        !isTemplateRef(control.config.content) && !control.config.tableData\r\n      \"\r\n    >\r\n      {{ control.config.content }}\r\n    </ng-container>\r\n\r\n    <!-- Case 2: Content is a TemplateRef -->\r\n    <ng-container *ngIf=\"isTemplateRef(control.config.content)\">\r\n      <ng-container *ngTemplateOutlet=\"control.config.content\"></ng-container>\r\n    </ng-container>\r\n\r\n    <ng-container *ngIf=\"control.config.chartConfig\">\r\n\r\n      <uxp-ruc-overlay-chart  [chartConfig]=\"control.config.chartConfig\"></uxp-ruc-overlay-chart>\r\n    </ng-container>\r\n\r\n    <!-- Case 3: Content is table data -->\r\n    <ng-container *ngIf=\"control.config.tableData?.length\">\r\n      <table\r\n        class=\"popover-table\"\r\n        [class]=\"control.config.tableClass || 'basic-table'\"\r\n      >\r\n        <thead>\r\n          <tr>\r\n            <th\r\n              *ngFor=\"let header of this.tableHeaders!\"\r\n            >\r\n              {{ header }}\r\n            </th>\r\n          </tr>\r\n        </thead>\r\n        <tbody>\r\n          <tr *ngFor=\"let row of control.config.tableData\">\r\n            <td\r\n              *ngFor=\"let header of this.tableHeaders!\"\r\n            >\r\n              {{ row[header] }}\r\n            </td>\r\n          </tr>\r\n        </tbody>\r\n      </table>\r\n    </ng-container>\r\n  </div>\r\n</div>\r\n"]}
@@ -0,0 +1,29 @@
1
+ import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
2
+ import Chart from 'chart.js/auto';
3
+ import * as i0 from "@angular/core";
4
+ export class RucOverlayChartComponent {
5
+ constructor() {
6
+ this.index = 0;
7
+ }
8
+ ngAfterViewInit() {
9
+ if (this.chartConfig) {
10
+ this.chart = new Chart('canvas' + this.index, this.chartConfig);
11
+ }
12
+ }
13
+ ngOnDestroy() {
14
+ this.chart?.destroy();
15
+ this.chart = null;
16
+ this.chartConfig = null;
17
+ }
18
+ }
19
+ RucOverlayChartComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: RucOverlayChartComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
20
+ RucOverlayChartComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: RucOverlayChartComponent, selector: "uxp-ruc-overlay-chart", inputs: { index: "index", chartConfig: "chartConfig" }, ngImport: i0, template: "<div style=\"position: relative; height:220px;\">\r\n <canvas id=\"canvas{{index}}\">{{chart}}</canvas>\r\n</div>\r\n", styles: [""], changeDetection: i0.ChangeDetectionStrategy.OnPush });
21
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: RucOverlayChartComponent, decorators: [{
22
+ type: Component,
23
+ args: [{ selector: 'uxp-ruc-overlay-chart', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div style=\"position: relative; height:220px;\">\r\n <canvas id=\"canvas{{index}}\">{{chart}}</canvas>\r\n</div>\r\n" }]
24
+ }], propDecorators: { index: [{
25
+ type: Input
26
+ }], chartConfig: [{
27
+ type: Input
28
+ }] } });
29
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicnVjLW92ZXJsYXktY2hhcnQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2xpYi9ydWMtb3ZlcmxheS1jaGFydC9ydWMtb3ZlcmxheS1jaGFydC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi9zcmMvbGliL3J1Yy1vdmVybGF5LWNoYXJ0L3J1Yy1vdmVybGF5LWNoYXJ0LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFFTCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULEtBQUssRUFFTixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEtBQUssTUFBTSxlQUFlLENBQUM7O0FBT2xDLE1BQU0sT0FBTyx3QkFBd0I7SUFOckM7UUFRVyxVQUFLLEdBQVcsQ0FBQyxDQUFDO0tBYzVCO0lBWEMsZUFBZTtRQUNiLElBQUcsSUFBSSxDQUFDLFdBQVcsRUFBRTtZQUNuQixJQUFJLENBQUMsS0FBSyxHQUFHLElBQUksS0FBSyxDQUFDLFFBQVEsR0FBRyxJQUFJLENBQUMsS0FBSyxFQUFFLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQztTQUNqRTtJQUNILENBQUM7SUFFRCxXQUFXO1FBQ1QsSUFBSSxDQUFDLEtBQUssRUFBRSxPQUFPLEVBQUUsQ0FBQztRQUN0QixJQUFJLENBQUMsS0FBSyxHQUFHLElBQUksQ0FBQztRQUNsQixJQUFJLENBQUMsV0FBVyxHQUFHLElBQUksQ0FBQztJQUMxQixDQUFDOztzSEFmVSx3QkFBd0I7MEdBQXhCLHdCQUF3QixxSENkckMsMEhBR0E7NEZEV2Esd0JBQXdCO2tCQU5wQyxTQUFTOytCQUNFLHVCQUF1QixtQkFHaEIsdUJBQXVCLENBQUMsTUFBTTs4QkFJdEMsS0FBSztzQkFBYixLQUFLO2dCQUNHLFdBQVc7c0JBQW5CLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xyXG4gIEFmdGVyVmlld0luaXQsXHJcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXHJcbiAgQ29tcG9uZW50LFxyXG4gIElucHV0LFxyXG4gIE9uRGVzdHJveVxyXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgQ2hhcnQgZnJvbSAnY2hhcnQuanMvYXV0byc7XHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAndXhwLXJ1Yy1vdmVybGF5LWNoYXJ0JyxcclxuICB0ZW1wbGF0ZVVybDogJy4vcnVjLW92ZXJsYXktY2hhcnQuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL3J1Yy1vdmVybGF5LWNoYXJ0LmNvbXBvbmVudC5zY3NzJ10sXHJcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBSdWNPdmVybGF5Q2hhcnRDb21wb25lbnQgaW1wbGVtZW50cyBBZnRlclZpZXdJbml0LCBPbkRlc3Ryb3kge1xyXG4gIGNoYXJ0OiBhbnk7XHJcbiAgQElucHV0KCkgaW5kZXg/Om51bWJlciA9IDA7XHJcbiAgQElucHV0KCkgY2hhcnRDb25maWc6IGFueTtcclxuXHJcbiAgbmdBZnRlclZpZXdJbml0KCk6IHZvaWQge1xyXG4gICAgaWYodGhpcy5jaGFydENvbmZpZykge1xyXG4gICAgICB0aGlzLmNoYXJ0ID0gbmV3IENoYXJ0KCdjYW52YXMnICsgdGhpcy5pbmRleCwgdGhpcy5jaGFydENvbmZpZyk7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBuZ09uRGVzdHJveSgpOiB2b2lkIHtcclxuICAgIHRoaXMuY2hhcnQ/LmRlc3Ryb3koKTtcclxuICAgIHRoaXMuY2hhcnQgPSBudWxsO1xyXG4gICAgdGhpcy5jaGFydENvbmZpZyA9IG51bGw7XHJcbiAgfVxyXG59XHJcbiIsIjxkaXYgc3R5bGU9XCJwb3NpdGlvbjogcmVsYXRpdmU7IGhlaWdodDoyMjBweDtcIj5cclxuICAgIDxjYW52YXMgaWQ9XCJjYW52YXN7e2luZGV4fX1cIj57e2NoYXJ0fX08L2NhbnZhcz5cclxuPC9kaXY+XHJcbiJdfQ==
@@ -0,0 +1,182 @@
1
+ import { Overlay } from '@angular/cdk/overlay';
2
+ import { Component, ElementRef, HostListener, Injector, Input, ViewChild } from '@angular/core';
3
+ import { OVERLAY_CONTROL } from '../model/overlay.types';
4
+ import { filter } from 'rxjs';
5
+ import { ComponentPortal } from '@angular/cdk/portal';
6
+ import { OverlayService } from '../service/overlay.service';
7
+ import { OverlayContentComponent } from '../overlay-content/overlay-content.component';
8
+ import { MatButton } from '@angular/material/button';
9
+ import { ESCAPE } from '@angular/cdk/keycodes';
10
+ import { positions } from '../constants/positions';
11
+ import * as i0 from "@angular/core";
12
+ import * as i1 from "@angular/cdk/overlay";
13
+ import * as i2 from "../service/overlay.service";
14
+ import * as i3 from "@angular/common";
15
+ import * as i4 from "@angular/material/button";
16
+ export class RuclibOverlayComponent {
17
+ constructor(overlay, injector, overlayService) {
18
+ this.overlay = overlay;
19
+ this.injector = injector;
20
+ this.overlayService = overlayService;
21
+ this.rucInputData = {
22
+ content: 'Default content',
23
+ };
24
+ this.overlayRef = null;
25
+ }
26
+ ngOnInit() {
27
+ if (!this.buttonText) {
28
+ this.serviceSubscription = this.overlayService.popoverState$.subscribe((data) => {
29
+ if (data && !this.isOpen) {
30
+ this.show(data.trigger, data.config);
31
+ }
32
+ else if (!data) {
33
+ this.destroy();
34
+ }
35
+ });
36
+ }
37
+ }
38
+ ngOnDestroy() {
39
+ this.positionSubscription?.unsubscribe();
40
+ this.serviceSubscription?.unsubscribe();
41
+ this.destroy();
42
+ }
43
+ get isOpen() {
44
+ return !!this.overlayRef;
45
+ }
46
+ // --- Trigger Handlers for self-contained button ---
47
+ toggle() {
48
+ if (this.rucInputData.trigger !== 'hover') {
49
+ this.isOpen ? this.destroy() : this.show(this.triggerButtonRef.nativeElement, this.rucInputData);
50
+ }
51
+ }
52
+ handleMouseEnter() {
53
+ if (this.rucInputData.trigger === 'hover') {
54
+ if (this.closeTimeout)
55
+ clearTimeout(this.closeTimeout); // Clear any pending close command
56
+ this.show(this.triggerButtonRef.nativeElement, this.rucInputData);
57
+ }
58
+ }
59
+ handleMouseLeave() {
60
+ if (this.rucInputData.trigger === 'hover') {
61
+ // Use the configurable closeDelay
62
+ const delay = this.rucInputData.closeDelay ?? 200;
63
+ this.closeTimeout = setTimeout(() => this.destroy(), delay);
64
+ }
65
+ }
66
+ show(trigger, config) {
67
+ if (this.isOpen) {
68
+ return;
69
+ }
70
+ const positionStrategy = this.createPositionStrategy(trigger, config.placement || 'bottom');
71
+ this.overlayRef = this.overlay.create({
72
+ positionStrategy,
73
+ hasBackdrop: config.trigger !== 'hover',
74
+ backdropClass: 'cdk-overlay-transparent-backdrop',
75
+ scrollStrategy: this.overlay.scrollStrategies.reposition(),
76
+ disposeOnNavigation: true
77
+ });
78
+ this.overlayRef.keydownEvents().pipe(filter(event => event.keyCode === ESCAPE)).subscribe(() => this.destroy());
79
+ // Create the control object with the close callback
80
+ const control = {
81
+ config,
82
+ close: this.destroy.bind(this),
83
+ };
84
+ const injector = Injector.create({
85
+ parent: this.injector,
86
+ providers: [{ provide: OVERLAY_CONTROL, useValue: control }],
87
+ });
88
+ const portal = new ComponentPortal(OverlayContentComponent, null, injector);
89
+ const componentRef = this.overlayRef.attach(portal);
90
+ this.positionSubscription = positionStrategy.positionChanges.subscribe(change => {
91
+ const newPlacement = this.getPlacementFromPosition(change.connectionPair);
92
+ componentRef.instance.actualPlacement = newPlacement;
93
+ componentRef.changeDetectorRef.detectChanges();
94
+ });
95
+ // --- NEW: Subscribe to the content component's events ---
96
+ componentRef.instance.mouseEnterPopover.subscribe(() => {
97
+ if (this.closeTimeout)
98
+ clearTimeout(this.closeTimeout);
99
+ });
100
+ componentRef.instance.mouseLeavePopover.subscribe(() => {
101
+ this.handleMouseLeave(); // Re-use the same logic
102
+ });
103
+ // Close on backdrop click for 'click' triggers
104
+ if (config.trigger !== 'hover') {
105
+ this.overlayRef.backdropClick().subscribe(() => this.destroy());
106
+ }
107
+ // --- NEW: Accessibility ---
108
+ const popoverId = `popover-${Math.random().toString(36).substring(2, 9)}`;
109
+ componentRef.location.nativeElement.setAttribute('id', popoverId);
110
+ trigger.setAttribute('aria-describedby', popoverId);
111
+ this.lastTriggerElement = trigger;
112
+ }
113
+ // Renamed from hide() to destroy() for clarity
114
+ destroy() {
115
+ if (!this.overlayRef)
116
+ return; // Prevent multiple calls
117
+ if (this.lastTriggerElement) {
118
+ this.lastTriggerElement.removeAttribute('aria-describedby');
119
+ this.lastTriggerElement = undefined;
120
+ }
121
+ this.positionSubscription?.unsubscribe();
122
+ this.overlayRef.dispose();
123
+ this.overlayRef = null;
124
+ }
125
+ getPlacementFromPosition(position) {
126
+ if (position.originY === 'top' && position.overlayY === 'bottom')
127
+ return 'top';
128
+ if (position.originY === 'bottom' && position.overlayY === 'top')
129
+ return 'bottom';
130
+ if (position.originX === 'start' && position.overlayX === 'end')
131
+ return 'left';
132
+ if (position.originX === 'end' && position.overlayX === 'start')
133
+ return 'right';
134
+ return 'bottom';
135
+ }
136
+ createPositionStrategy(origin, placement) {
137
+ let preferredPosition;
138
+ switch (placement) {
139
+ case 'top':
140
+ preferredPosition = positions[1];
141
+ break;
142
+ case 'right':
143
+ preferredPosition = positions[2];
144
+ break;
145
+ case 'left':
146
+ preferredPosition = positions[3];
147
+ break;
148
+ default:
149
+ preferredPosition = positions[0];
150
+ break;
151
+ }
152
+ return this.overlay.position()
153
+ .flexibleConnectedTo(origin)
154
+ .withPositions([preferredPosition, ...positions])
155
+ .withPush(true);
156
+ }
157
+ //Document-level listeners for closing
158
+ onEscape() {
159
+ this.positionSubscription?.unsubscribe();
160
+ this.serviceSubscription?.unsubscribe();
161
+ this.destroy();
162
+ }
163
+ }
164
+ RuclibOverlayComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: RuclibOverlayComponent, deps: [{ token: i1.Overlay }, { token: i0.Injector }, { token: i2.OverlayService }], target: i0.ɵɵFactoryTarget.Component });
165
+ RuclibOverlayComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: RuclibOverlayComponent, selector: "uxp-ruclib-overlay", inputs: { buttonText: "buttonText", rucInputData: "rucInputData", customTheme: "customTheme" }, host: { listeners: { "document:keydown:escape": "onEscape()" } }, viewQueries: [{ propertyName: "triggerButtonRef", first: true, predicate: MatButton, descendants: true, read: ElementRef }], ngImport: i0, template: "<button\r\nmat-raised-button\r\n color=\"primary\"\r\n *ngIf=\"buttonText\"\r\n #triggerButton\r\n (click)=\"toggle()\"\r\n (mouseenter)=\"handleMouseEnter()\"\r\n (mouseleave)=\"handleMouseLeave()\"\r\n class=\"popover-trigger-btn\">\r\n {{ buttonText }}\r\n</button>\r\n", styles: [""], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }] });
166
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: RuclibOverlayComponent, decorators: [{
167
+ type: Component,
168
+ args: [{ selector: 'uxp-ruclib-overlay', template: "<button\r\nmat-raised-button\r\n color=\"primary\"\r\n *ngIf=\"buttonText\"\r\n #triggerButton\r\n (click)=\"toggle()\"\r\n (mouseenter)=\"handleMouseEnter()\"\r\n (mouseleave)=\"handleMouseLeave()\"\r\n class=\"popover-trigger-btn\">\r\n {{ buttonText }}\r\n</button>\r\n" }]
169
+ }], ctorParameters: function () { return [{ type: i1.Overlay }, { type: i0.Injector }, { type: i2.OverlayService }]; }, propDecorators: { buttonText: [{
170
+ type: Input
171
+ }], rucInputData: [{
172
+ type: Input
173
+ }], customTheme: [{
174
+ type: Input
175
+ }], triggerButtonRef: [{
176
+ type: ViewChild,
177
+ args: [MatButton, { read: ElementRef }]
178
+ }], onEscape: [{
179
+ type: HostListener,
180
+ args: ['document:keydown:escape']
181
+ }] } });
182
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ruclib-overlay.component.js","sourceRoot":"","sources":["../../../../src/lib/ruclib-overlay/ruclib-overlay.component.ts","../../../../src/lib/ruclib-overlay/ruclib-overlay.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ConnectedPosition, ConnectionPositionPair, FlexibleConnectedPositionStrategy, Overlay, OverlayRef } from '@angular/cdk/overlay';\r\nimport { Component, ElementRef, HostListener, Injector, Input, OnDestroy, OnInit, ViewChild } from '@angular/core';\r\nimport { OVERLAY_CONTROL, OverlayConfig, OverlayControl, OverlayData } from '../model/overlay.types';\r\nimport { filter, Subscription } from 'rxjs';\r\nimport { ComponentPortal } from '@angular/cdk/portal';\r\nimport { OverlayService } from '../service/overlay.service';\r\nimport { OverlayContentComponent } from '../overlay-content/overlay-content.component';\r\nimport { MatButton } from '@angular/material/button';\r\nimport { ESCAPE } from '@angular/cdk/keycodes';\r\nimport { positions } from '../constants/positions';\r\n\r\nexport type PopoverPlacement = 'top' | 'bottom' | 'left' | 'right';\r\nexport type PopoverAnimation = 'fade' | 'scale';\r\nexport type ChartType = 'doughnut' | 'pie' | 'bar';\r\n\r\nexport interface ChartModel {\r\n  chartType: ChartType;\r\n  data: any;\r\n}\r\n\r\n@Component({\r\n  selector: 'uxp-ruclib-overlay',\r\n  templateUrl: './ruclib-overlay.component.html',\r\n  styleUrls: ['./ruclib-overlay.component.scss'],\r\n\r\n})\r\nexport class RuclibOverlayComponent implements OnInit, OnDestroy {\r\n  @Input() buttonText?: string;\r\n  @Input() rucInputData: OverlayConfig = {\r\n    content: 'Default content',\r\n  };\r\n  @Input() customTheme!:string;\r\n\r\n  \r\n  @ViewChild(MatButton, { read: ElementRef }) private triggerButtonRef!: ElementRef;\r\n\r\n  private overlayRef: OverlayRef | null = null;\r\n  private serviceSubscription!: Subscription;\r\n  private closeTimeout?: ReturnType<typeof setTimeout>; // Use the correct type\r\n  private lastTriggerElement?: HTMLElement;\r\n  private positionSubscription!: Subscription;\r\n\r\n\r\n  constructor(\r\n    private overlay: Overlay,\r\n    private injector: Injector,\r\n    private overlayService: OverlayService\r\n  ) {}\r\n\r\n  ngOnInit(): void {\r\n    if (!this.buttonText) {\r\n      this.serviceSubscription = this.overlayService.popoverState$.subscribe(\r\n        (data:any) => {\r\n          if (data && !this.isOpen) {\r\n            this.show(data.trigger, data.config);\r\n          } else if (!data) {\r\n            this.destroy();\r\n          }\r\n        }\r\n      );\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.positionSubscription?.unsubscribe();\r\n    this.serviceSubscription?.unsubscribe();\r\n    this.destroy();\r\n  }\r\n\r\n  get isOpen(): boolean {\r\n    return !!this.overlayRef;\r\n  }\r\n\r\n  // --- Trigger Handlers for self-contained button ---\r\n  toggle(): void {\r\n    if (this.rucInputData.trigger !== 'hover') {\r\nthis.isOpen ? this.destroy() : this.show(this.triggerButtonRef.nativeElement, this.rucInputData);\r\n    }\r\n  }\r\n\r\n  handleMouseEnter(): void {\r\n    if (this.rucInputData.trigger === 'hover') {\r\n      if (this.closeTimeout) clearTimeout(this.closeTimeout); // Clear any pending close command\r\nthis.show(this.triggerButtonRef.nativeElement, this.rucInputData);\r\n    }\r\n  }\r\n\r\n  handleMouseLeave(): void {\r\n    if (this.rucInputData.trigger === 'hover') {\r\n      // Use the configurable closeDelay\r\n      const delay = this.rucInputData.closeDelay ?? 200;\r\n      this.closeTimeout = setTimeout(() => this.destroy(), delay);\r\n    }\r\n  }\r\n\r\n\r\n  private show(trigger: HTMLElement, config: OverlayConfig): void {\r\n    if (this.isOpen) {\r\n      return;\r\n    }\r\n\r\n    const positionStrategy = this.createPositionStrategy(\r\n      trigger,\r\n      config.placement || 'bottom'\r\n    );\r\n\r\n    this.overlayRef = this.overlay.create({\r\n      positionStrategy,\r\n      hasBackdrop: config.trigger !== 'hover', // No backdrop for hover\r\n      backdropClass: 'cdk-overlay-transparent-backdrop',\r\n      scrollStrategy: this.overlay.scrollStrategies.reposition(),\r\n      disposeOnNavigation:true\r\n    });\r\n\r\n\r\n    this.overlayRef.keydownEvents().pipe(filter(event=> event.keyCode === ESCAPE)).subscribe(()=> this.destroy());\r\n\r\n    // Create the control object with the close callback\r\n    const control: OverlayControl = {\r\n      config,\r\n      close: this.destroy.bind(this),\r\n    };\r\n\r\n    const injector = Injector.create({\r\n      parent: this.injector,\r\n      providers: [{ provide: OVERLAY_CONTROL, useValue: control }],\r\n    });\r\n\r\n    const portal = new ComponentPortal(OverlayContentComponent, null, injector);\r\n    const componentRef = this.overlayRef.attach(portal);\r\n\r\n    this.positionSubscription = positionStrategy.positionChanges.subscribe(change => {\r\n      const newPlacement = this.getPlacementFromPosition(change.connectionPair);\r\n      componentRef.instance.actualPlacement = newPlacement;\r\n      componentRef.changeDetectorRef.detectChanges();\r\n    });\r\n\r\n    // --- NEW: Subscribe to the content component's events ---\r\n    componentRef.instance.mouseEnterPopover.subscribe(() => {\r\n      if (this.closeTimeout) clearTimeout(this.closeTimeout);\r\n    });\r\n    componentRef.instance.mouseLeavePopover.subscribe(() => {\r\n      this.handleMouseLeave(); // Re-use the same logic\r\n    });\r\n\r\n       // Close on backdrop click for 'click' triggers\r\n    if (config.trigger !== 'hover') {\r\n      this.overlayRef.backdropClick().subscribe(() => this.destroy());\r\n    }\r\n\r\n    // --- NEW: Accessibility ---\r\n    const popoverId = `popover-${Math.random().toString(36).substring(2, 9)}`;\r\n    componentRef.location.nativeElement.setAttribute('id', popoverId);\r\n    trigger.setAttribute('aria-describedby', popoverId);\r\n    this.lastTriggerElement = trigger;\r\n\r\n  }\r\n\r\n   // Renamed from hide() to destroy() for clarity\r\n private destroy(): void {\r\n    if (!this.overlayRef) return; // Prevent multiple calls\r\n\r\n    if (this.lastTriggerElement) {\r\n      this.lastTriggerElement.removeAttribute('aria-describedby');\r\n      this.lastTriggerElement = undefined;\r\n    }\r\n    this.positionSubscription?.unsubscribe();\r\n    this.overlayRef.dispose();\r\n    this.overlayRef = null;\r\n  }\r\n\r\n  private getPlacementFromPosition(position: ConnectionPositionPair): PopoverPlacement {\r\n    if (position.originY === 'top' && position.overlayY === 'bottom') return 'top';\r\n    if (position.originY === 'bottom' && position.overlayY === 'top') return 'bottom';\r\n    if (position.originX === 'start' && position.overlayX === 'end') return 'left';\r\n    if (position.originX === 'end' && position.overlayX === 'start') return 'right';\r\n    return 'bottom';\r\n  }\r\n\r\n  private createPositionStrategy(origin: HTMLElement, placement: string): FlexibleConnectedPositionStrategy {\r\n    let preferredPosition: ConnectedPosition;\r\n    switch (placement) {\r\n      case 'top': preferredPosition = positions[1]; break;\r\n      case 'right': preferredPosition = positions[2]; break;\r\n      case 'left': preferredPosition = positions[3]; break;\r\n      default: preferredPosition = positions[0]; break;\r\n    }\r\n\r\n    return this.overlay.position()\r\n      .flexibleConnectedTo(origin)\r\n      .withPositions([preferredPosition, ...positions])\r\n      .withPush(true);\r\n  }\r\n\r\n   //Document-level listeners for closing\r\n   @HostListener('document:keydown:escape')\r\n   onEscape():void {\r\n   this.positionSubscription?.unsubscribe();\r\n    this.serviceSubscription?.unsubscribe();\r\n    this.destroy();\r\n   }\r\n\r\n}\r\n","<button\r\nmat-raised-button\r\n                      color=\"primary\"\r\n  *ngIf=\"buttonText\"\r\n  #triggerButton\r\n  (click)=\"toggle()\"\r\n  (mouseenter)=\"handleMouseEnter()\"\r\n  (mouseleave)=\"handleMouseLeave()\"\r\n  class=\"popover-trigger-btn\">\r\n  {{ buttonText }}\r\n</button>\r\n"]}
@@ -0,0 +1,44 @@
1
+ import { BrowserAnimationsModule } from '@angular/platform-browser/animations';
2
+ import { NgModule } from '@angular/core';
3
+ import { CommonModule } from '@angular/common';
4
+ import { RuclibOverlayComponent } from './ruclib-overlay/ruclib-overlay.component';
5
+ import { OverlayContentComponent } from './overlay-content/overlay-content.component';
6
+ import { MatIconModule } from '@angular/material/icon';
7
+ import { OverlayModule } from '@angular/cdk/overlay';
8
+ import { MatButtonModule } from '@angular/material/button';
9
+ import { RucOverlayChartComponent } from './ruc-overlay-chart/ruc-overlay-chart.component';
10
+ import * as i0 from "@angular/core";
11
+ export class RuclibOverlayModule {
12
+ }
13
+ RuclibOverlayModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: RuclibOverlayModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
14
+ RuclibOverlayModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.10", ngImport: i0, type: RuclibOverlayModule, declarations: [RuclibOverlayComponent,
15
+ OverlayContentComponent,
16
+ RucOverlayChartComponent], imports: [CommonModule,
17
+ MatIconModule,
18
+ OverlayModule,
19
+ BrowserAnimationsModule,
20
+ MatButtonModule], exports: [RuclibOverlayComponent, RucOverlayChartComponent] });
21
+ RuclibOverlayModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: RuclibOverlayModule, imports: [CommonModule,
22
+ MatIconModule,
23
+ OverlayModule,
24
+ BrowserAnimationsModule,
25
+ MatButtonModule] });
26
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: RuclibOverlayModule, decorators: [{
27
+ type: NgModule,
28
+ args: [{
29
+ imports: [
30
+ CommonModule,
31
+ MatIconModule,
32
+ OverlayModule,
33
+ BrowserAnimationsModule,
34
+ MatButtonModule,
35
+ ],
36
+ declarations: [
37
+ RuclibOverlayComponent,
38
+ OverlayContentComponent,
39
+ RucOverlayChartComponent
40
+ ],
41
+ exports: [RuclibOverlayComponent, RucOverlayChartComponent],
42
+ }]
43
+ }] });
44
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicnVjbGliLW92ZXJsYXkubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2xpYi9ydWNsaWItb3ZlcmxheS5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sc0NBQXNDLENBQUM7QUFDL0UsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sMkNBQTJDLENBQUM7QUFDbkYsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sNkNBQTZDLENBQUM7QUFDdEYsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUNyRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0saURBQWlELENBQUM7O0FBaUIzRixNQUFNLE9BQU8sbUJBQW1COztpSEFBbkIsbUJBQW1CO2tIQUFuQixtQkFBbUIsaUJBTjVCLHNCQUFzQjtRQUN0Qix1QkFBdUI7UUFDdkIsd0JBQXdCLGFBVHhCLFlBQVk7UUFDWixhQUFhO1FBQ2IsYUFBYTtRQUNiLHVCQUF1QjtRQUN2QixlQUFlLGFBT1Asc0JBQXNCLEVBQUUsd0JBQXdCO2tIQUUvQyxtQkFBbUIsWUFiNUIsWUFBWTtRQUNaLGFBQWE7UUFDYixhQUFhO1FBQ2IsdUJBQXVCO1FBQ3ZCLGVBQWU7NEZBU04sbUJBQW1CO2tCQWYvQixRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLGFBQWE7d0JBQ2IsYUFBYTt3QkFDYix1QkFBdUI7d0JBQ3ZCLGVBQWU7cUJBQ2hCO29CQUNELFlBQVksRUFBRTt3QkFDWixzQkFBc0I7d0JBQ3RCLHVCQUF1Qjt3QkFDdkIsd0JBQXdCO3FCQUN6QjtvQkFDRCxPQUFPLEVBQUUsQ0FBQyxzQkFBc0IsRUFBRSx3QkFBd0IsQ0FBQztpQkFDNUQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBCcm93c2VyQW5pbWF0aW9uc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL3BsYXRmb3JtLWJyb3dzZXIvYW5pbWF0aW9ucyc7XHJcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7IFJ1Y2xpYk92ZXJsYXlDb21wb25lbnQgfSBmcm9tICcuL3J1Y2xpYi1vdmVybGF5L3J1Y2xpYi1vdmVybGF5LmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IE92ZXJsYXlDb250ZW50Q29tcG9uZW50IH0gZnJvbSAnLi9vdmVybGF5LWNvbnRlbnQvb3ZlcmxheS1jb250ZW50LmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IE1hdEljb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pY29uJztcclxuaW1wb3J0IHsgT3ZlcmxheU1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9vdmVybGF5JztcclxuaW1wb3J0IHsgTWF0QnV0dG9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvYnV0dG9uJztcclxuaW1wb3J0IHsgUnVjT3ZlcmxheUNoYXJ0Q29tcG9uZW50IH0gZnJvbSAnLi9ydWMtb3ZlcmxheS1jaGFydC9ydWMtb3ZlcmxheS1jaGFydC5jb21wb25lbnQnO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICBpbXBvcnRzOiBbXHJcbiAgICBDb21tb25Nb2R1bGUsXHJcbiAgICBNYXRJY29uTW9kdWxlLFxyXG4gICAgT3ZlcmxheU1vZHVsZSxcclxuICAgIEJyb3dzZXJBbmltYXRpb25zTW9kdWxlLFxyXG4gICAgTWF0QnV0dG9uTW9kdWxlLFxyXG4gIF0sXHJcbiAgZGVjbGFyYXRpb25zOiBbXHJcbiAgICBSdWNsaWJPdmVybGF5Q29tcG9uZW50LFxyXG4gICAgT3ZlcmxheUNvbnRlbnRDb21wb25lbnQsXHJcbiAgICBSdWNPdmVybGF5Q2hhcnRDb21wb25lbnRcclxuICBdLFxyXG4gIGV4cG9ydHM6IFtSdWNsaWJPdmVybGF5Q29tcG9uZW50LCBSdWNPdmVybGF5Q2hhcnRDb21wb25lbnRdLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgUnVjbGliT3ZlcmxheU1vZHVsZSB7fVxyXG4iXX0=
@@ -0,0 +1,33 @@
1
+ import { Injectable } from '@angular/core';
2
+ import { Subject } from 'rxjs';
3
+ import * as i0 from "@angular/core";
4
+ export class OverlayService {
5
+ constructor() {
6
+ this.popoverState = new Subject();
7
+ this.popoverState$ = this.popoverState.asObservable();
8
+ }
9
+ /**
10
+ * Broadcasts a command to open a popover using the OverlayData structure.
11
+ */
12
+ open(config, trigger) {
13
+ console.log(config, trigger);
14
+ // The service's responsibility is to bundle the config and trigger
15
+ // into a PopoverData object and send it.
16
+ this.popoverState.next({ config, trigger });
17
+ }
18
+ /**
19
+ * Broadcasts a command to close any currently open service-controlled popover.
20
+ */
21
+ close() {
22
+ this.popoverState.next(null);
23
+ }
24
+ }
25
+ OverlayService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: OverlayService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
26
+ OverlayService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: OverlayService, providedIn: 'root' });
27
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: OverlayService, decorators: [{
28
+ type: Injectable,
29
+ args: [{
30
+ providedIn: 'root'
31
+ }]
32
+ }] });
33
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3ZlcmxheS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2xpYi9zZXJ2aWNlL292ZXJsYXkuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzNDLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxNQUFNLENBQUM7O0FBSy9CLE1BQU0sT0FBTyxjQUFjO0lBSDNCO1FBS1UsaUJBQVksR0FBRyxJQUFJLE9BQU8sRUFBc0IsQ0FBQztRQUVsRCxrQkFBYSxHQUFHLElBQUksQ0FBQyxZQUFZLENBQUMsWUFBWSxFQUFFLENBQUM7S0FvQnpEO0lBaEJDOztPQUVHO0lBQ0gsSUFBSSxDQUFDLE1BQTZCLEVBQUUsT0FBK0I7UUFDakUsT0FBTyxDQUFDLEdBQUcsQ0FBQyxNQUFNLEVBQUUsT0FBTyxDQUFDLENBQUM7UUFDN0IsbUVBQW1FO1FBQ25FLHlDQUF5QztRQUN6QyxJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxFQUFFLE1BQU0sRUFBRSxPQUFPLEVBQUUsQ0FBQyxDQUFDO0lBQzlDLENBQUM7SUFFRDs7T0FFRztJQUNILEtBQUs7UUFDSCxJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUMvQixDQUFDOzs0R0F2QlUsY0FBYztnSEFBZCxjQUFjLGNBRmIsTUFBTTs0RkFFUCxjQUFjO2tCQUgxQixVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE92ZXJsYXlEYXRhIH0gZnJvbSAnLi8uLi9tb2RlbC9vdmVybGF5LnR5cGVzJztcclxuaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBTdWJqZWN0IH0gZnJvbSAncnhqcyc7XHJcblxyXG5ASW5qZWN0YWJsZSh7XHJcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBPdmVybGF5U2VydmljZSB7XHJcblxyXG4gIHByaXZhdGUgcG9wb3ZlclN0YXRlID0gbmV3IFN1YmplY3Q8T3ZlcmxheURhdGEgfCBudWxsPigpO1xyXG5cclxuICBwdWJsaWMgcG9wb3ZlclN0YXRlJCA9IHRoaXMucG9wb3ZlclN0YXRlLmFzT2JzZXJ2YWJsZSgpO1xyXG5cclxuXHJcblxyXG4gIC8qKlxyXG4gICAqIEJyb2FkY2FzdHMgYSBjb21tYW5kIHRvIG9wZW4gYSBwb3BvdmVyIHVzaW5nIHRoZSBPdmVybGF5RGF0YSBzdHJ1Y3R1cmUuXHJcbiAgICovXHJcbiAgb3Blbihjb25maWc6IE92ZXJsYXlEYXRhWydjb25maWcnXSwgdHJpZ2dlcjogT3ZlcmxheURhdGFbJ3RyaWdnZXInXSkge1xyXG4gICAgY29uc29sZS5sb2coY29uZmlnLCB0cmlnZ2VyKTtcclxuICAgIC8vIFRoZSBzZXJ2aWNlJ3MgcmVzcG9uc2liaWxpdHkgaXMgdG8gYnVuZGxlIHRoZSBjb25maWcgYW5kIHRyaWdnZXJcclxuICAgIC8vIGludG8gYSBQb3BvdmVyRGF0YSBvYmplY3QgYW5kIHNlbmQgaXQuXHJcbiAgICB0aGlzLnBvcG92ZXJTdGF0ZS5uZXh0KHsgY29uZmlnLCB0cmlnZ2VyIH0pO1xyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogQnJvYWRjYXN0cyBhIGNvbW1hbmQgdG8gY2xvc2UgYW55IGN1cnJlbnRseSBvcGVuIHNlcnZpY2UtY29udHJvbGxlZCBwb3BvdmVyLlxyXG4gICAqL1xyXG4gIGNsb3NlKCkge1xyXG4gICAgdGhpcy5wb3BvdmVyU3RhdGUubmV4dChudWxsKTtcclxuICB9XHJcbn1cclxuIl19
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './index';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicnVjLWxpYi1vdmVybGF5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3J1Yy1saWItb3ZlcmxheS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcbiJdfQ==