@datarailsshared/datarailsshared 1.5.389 → 1.5.397
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/datarailsshared-datarailsshared-1.5.397.tgz +0 -0
- package/esm2022/lib/date-tags/any-tag.component.mjs +18 -18
- package/esm2022/lib/date-tags/date-tag.component.mjs +99 -23
- package/esm2022/lib/date-tags/date-tag.module.mjs +27 -26
- package/esm2022/lib/date-tags/day-tag/day-tag.component.mjs +40 -26
- package/esm2022/lib/date-tags/forecast-tag/forecast-tag.component.mjs +43 -25
- package/esm2022/lib/date-tags/month-tag/month-tag.component.mjs +40 -26
- package/esm2022/lib/date-tags/quarter-tag/quarter-tag.component.mjs +26 -12
- package/esm2022/lib/date-tags/week-tag/week-tag.component.mjs +40 -26
- package/esm2022/lib/date-tags/year-tag/year-tag.component.mjs +40 -26
- package/esm2022/lib/directives/click-outside/click-outside.directive.mjs +16 -16
- package/esm2022/lib/directives/click-outside/click-outside.module.mjs +13 -12
- package/esm2022/lib/dr-accordion/accordion-item-body.component.mjs +18 -15
- package/esm2022/lib/dr-accordion/accordion-item-header.component.mjs +71 -54
- package/esm2022/lib/dr-accordion/accordion-item.component.mjs +37 -32
- package/esm2022/lib/dr-accordion/accordion.component.mjs +15 -10
- package/esm2022/lib/dr-accordion/accordion.module.mjs +20 -19
- package/esm2022/lib/dr-alert/dr-alert.component.mjs +44 -16
- package/esm2022/lib/dr-alert/dr-alert.module.mjs +14 -13
- package/esm2022/lib/dr-avatar/dr-avatar.component.mjs +98 -23
- package/esm2022/lib/dr-avatar/dr-avatar.module.mjs +13 -12
- package/esm2022/lib/dr-avatar/dr-avatar.pipe.mjs +9 -9
- package/esm2022/lib/dr-badge-status/dr-badge-status.component.mjs +43 -17
- package/esm2022/lib/dr-badge-status/dr-badge-status.module.mjs +14 -13
- package/esm2022/lib/dr-chat/chat.component.mjs +115 -38
- package/esm2022/lib/dr-chat/chat.module.mjs +27 -26
- package/esm2022/lib/dr-chat/dr-chat-alert/dr-chat-alert.component.mjs +21 -11
- package/esm2022/lib/dr-chat/dr-chat-form/chat-form.component.mjs +128 -37
- package/esm2022/lib/dr-chat/dr-chat-message/chat-message.component.mjs +126 -41
- package/esm2022/lib/dr-chat/dr-chat-message/dr-chat-message-custom/chat-custom-message.directive.mjs +11 -11
- package/esm2022/lib/dr-chat/dr-chat-message/dr-chat-message-custom/chat-custom-message.service.mjs +6 -6
- package/esm2022/lib/dr-chat/dr-chat-message/dr-chat-message-file/chat-message-file.component.mjs +40 -11
- package/esm2022/lib/dr-chat/dr-chat-message/dr-chat-message-text/chat-message-text.component.mjs +22 -9
- package/esm2022/lib/dr-chat/dr-chat-suggestions/chat-suggestions.component.mjs +86 -20
- package/esm2022/lib/dr-chat/dr-dot-flashing/dr-dot-flashing.component.mjs +9 -7
- package/esm2022/lib/dr-chip/dr-chip.component.mjs +49 -15
- package/esm2022/lib/dr-code-editor/components/code-editor-hint-wrapper.component.mjs +14 -10
- package/esm2022/lib/dr-code-editor/components/dr-codemirror.component.mjs +62 -57
- package/esm2022/lib/dr-code-editor/dr-code-editor.component.mjs +48 -20
- package/esm2022/lib/dr-code-editor/dr-code-editor.module.mjs +14 -13
- package/esm2022/lib/dr-details-list/dr-details-list.component.mjs +69 -41
- package/esm2022/lib/dr-details-list/dr-details-list.module.mjs +14 -13
- package/esm2022/lib/dr-dialog/components/dialog-modal-wrapper/dialog-modal-wrapper.component.mjs +265 -13
- package/esm2022/lib/dr-dialog/components/dialog-wrapper/dialog-wrapper.component.mjs +154 -16
- package/esm2022/lib/dr-dialog/dialog.module.mjs +14 -13
- package/esm2022/lib/dr-dialog/services/dialog.service.mjs +9 -9
- package/esm2022/lib/dr-dropdown/dr-dropdown-item/dr-dropdown-item.component.mjs +29 -0
- package/esm2022/lib/dr-dropdown/dr-dropdown-item-show.pipe.mjs +9 -9
- package/esm2022/lib/dr-dropdown/dr-dropdown.component.mjs +175 -56
- package/esm2022/lib/dr-dropdown/dr-dropdown.directive.mjs +98 -87
- package/esm2022/lib/dr-dropdown/dr-dropdown.module.mjs +32 -15
- package/esm2022/lib/dr-dropdown/dr-dropdown.service.mjs +55 -18
- package/esm2022/lib/dr-dynamic-tag/dr-dynamic-tag.component.mjs +92 -25
- package/esm2022/lib/dr-dynamic-tag/dr-dynamic-tag.module.mjs +13 -12
- package/esm2022/lib/dr-error/dr-error.component.mjs +48 -24
- package/esm2022/lib/dr-error/dr-error.module.mjs +14 -13
- package/esm2022/lib/dr-inputs/button/button.component.mjs +88 -45
- package/esm2022/lib/dr-inputs/checkbox/checkbox.component.mjs +53 -28
- package/esm2022/lib/dr-inputs/date-pickers/directives/dr-date-picker-format.directive.mjs +32 -32
- package/esm2022/lib/dr-inputs/date-pickers/dr-date-picker/dr-date-picker.component.mjs +67 -42
- package/esm2022/lib/dr-inputs/date-pickers/dr-date-picker-range/dr-date-picker-range.component.mjs +72 -32
- package/esm2022/lib/dr-inputs/date-pickers/dr-date-picker-with-timeframe/dr-date-picker-with-timeframe.component.mjs +111 -42
- package/esm2022/lib/dr-inputs/date-pickers/dr-date-picker_custom-header/dr-date-picker_custom-header.component.mjs +99 -10
- package/esm2022/lib/dr-inputs/date-pickers/dr-show-timeframe.pipe.mjs +9 -9
- package/esm2022/lib/dr-inputs/date-pickers/services/dr-date-picker.service.mjs +6 -6
- package/esm2022/lib/dr-inputs/dr-input/dr-input.component.mjs +168 -84
- package/esm2022/lib/dr-inputs/dr-inputs.module.mjs +64 -63
- package/esm2022/lib/dr-inputs/dr-link/dr-link.component.mjs +26 -16
- package/esm2022/lib/dr-inputs/dr-model-debounce-change.directive.mjs +13 -13
- package/esm2022/lib/dr-inputs/dr-select/dr-select.component.mjs +243 -104
- package/esm2022/lib/dr-inputs/dr-select-add-item/dr-select-add-item.component.mjs +77 -20
- package/esm2022/lib/dr-inputs/dr-slider/dr-slider.component.mjs +23 -17
- package/esm2022/lib/dr-inputs/dr-toggle/dr-toggle.component.mjs +64 -22
- package/esm2022/lib/dr-inputs/dr-toggle-button/dr-toggle-button.component.mjs +53 -21
- package/esm2022/lib/dr-inputs/radio-button/radio-button.component.mjs +40 -28
- package/esm2022/lib/dr-inputs/radio-button/radio-group.component.mjs +51 -41
- package/esm2022/lib/dr-layout/dr-layout-body.component.mjs +14 -10
- package/esm2022/lib/dr-layout/dr-layout-header.component.mjs +16 -14
- package/esm2022/lib/dr-layout/dr-layout.component.mjs +16 -7
- package/esm2022/lib/dr-layout/dr-layout.module.mjs +13 -12
- package/esm2022/lib/dr-popover/dr-popover-ref.mjs +4 -1
- package/esm2022/lib/dr-popover/dr-popover.component.mjs +71 -40
- package/esm2022/lib/dr-popover/dr-popover.directive.mjs +51 -49
- package/esm2022/lib/dr-popover/dr-popover.module.mjs +13 -12
- package/esm2022/lib/dr-popover/dr-popover.service.mjs +25 -13
- package/esm2022/lib/dr-scenario/components/dr-scenario-configuration/dr-scenario-configuration.component.mjs +41 -17
- package/esm2022/lib/dr-scenario/components/dr-scenario-tag-configuration/dr-scenario-tag-configuration.component.mjs +42 -27
- package/esm2022/lib/dr-scenario/dr-scenario.module.mjs +14 -13
- package/esm2022/lib/dr-scenario/services/scenario.service.mjs +6 -6
- package/esm2022/lib/dr-spinner/dr-spinner.component.mjs +17 -7
- package/esm2022/lib/dr-spinner/dr-spinner.directive.mjs +25 -20
- package/esm2022/lib/dr-spinner/dr-spinner.module.mjs +13 -12
- package/esm2022/lib/dr-tabs/dr-tab.component.mjs +33 -25
- package/esm2022/lib/dr-tabs/dr-tabs.component.mjs +118 -30
- package/esm2022/lib/dr-tabs/dr-tabs.module.mjs +14 -13
- package/esm2022/lib/dr-tags/dr-tag.component.mjs +75 -33
- package/esm2022/lib/dr-tags/dr-tag.module.mjs +14 -13
- package/esm2022/lib/dr-tags-constructor/dr-tags-constructor.component.mjs +72 -19
- package/esm2022/lib/dr-tags-constructor/dr-tags-constructor.module.mjs +14 -13
- package/esm2022/lib/dr-tags-constructor/tags-constructor.service.mjs +6 -6
- package/esm2022/lib/dr-toastr/default-toastr/default-toastr.component.mjs +48 -10
- package/esm2022/lib/dr-toastr/dr-toastr.module.mjs +19 -18
- package/esm2022/lib/dr-toastr/dr-toastr.service.mjs +9 -9
- package/esm2022/lib/dr-tooltip/components/tooltip-default/tooltip-default.component.mjs +23 -14
- package/esm2022/lib/dr-tooltip/components/tooltip-info/tooltip-info.component.mjs +76 -9
- package/esm2022/lib/dr-tooltip/dr-tooltip.component.mjs +63 -25
- package/esm2022/lib/dr-tooltip/dr-tooltip.directive.mjs +41 -39
- package/esm2022/lib/dr-tooltip/dr-tooltip.module.mjs +14 -13
- package/esm2022/lib/dr-treeview/components/treeview/treeview.component.mjs +211 -19
- package/esm2022/lib/dr-treeview/components/treeview-item/treeview-item.component.mjs +52 -15
- package/esm2022/lib/dr-treeview/dr-tree-view.module.mjs +14 -13
- package/esm2022/lib/dr-treeview/helpers/treeview-event-parser.mjs +21 -21
- package/esm2022/lib/dr-treeview/models/treeview-config.mjs +6 -6
- package/esm2022/lib/dr-treeview/models/treeview-i18n.mjs +11 -11
- package/esm2022/lib/dr-treeview/pipes/treeview.pipe.mjs +9 -9
- package/esm2022/lib/image-cropper/dr-image-cropper-canvas.service.mjs +6 -6
- package/esm2022/lib/image-cropper/dr-image-cropper.component.mjs +67 -28
- package/esm2022/lib/list-tags/list-tag.component.mjs +57 -17
- package/esm2022/lib/list-tags/list-tag.module.mjs +14 -13
- package/esm2022/lib/models/dropdown.mjs +1 -1
- package/esm2022/lib/models/popover.mjs +1 -1
- package/esm2022/lib/models/serverTags.mjs +1 -1
- package/esm2022/lib/stepper/stepper.component.mjs +225 -28
- package/esm2022/lib/stepper/stepper.module.mjs +13 -12
- package/esm2022/lib/utils/decorators.mjs +12 -0
- package/esm2022/public-api.mjs +2 -2
- package/fesm2022/datarailsshared-datarailsshared.mjs +5787 -2724
- package/fesm2022/datarailsshared-datarailsshared.mjs.map +1 -1
- package/lib/dr-dropdown/dr-dropdown-item/dr-dropdown-item.component.d.ts +8 -0
- package/lib/dr-dropdown/dr-dropdown.component.d.ts +24 -22
- package/lib/dr-dropdown/dr-dropdown.directive.d.ts +16 -15
- package/lib/dr-dropdown/dr-dropdown.module.d.ts +5 -4
- package/lib/dr-dropdown/dr-dropdown.service.d.ts +23 -8
- package/lib/dr-popover/dr-popover-ref.d.ts +1 -0
- package/lib/dr-popover/dr-popover.service.d.ts +2 -1
- package/lib/models/dropdown.d.ts +13 -21
- package/lib/models/popover.d.ts +6 -3
- package/lib/models/serverTags.d.ts +1 -0
- package/lib/utils/decorators.d.ts +1 -0
- package/package.json +5 -2
- package/public-api.d.ts +2 -2
- package/datarailsshared-datarailsshared-1.5.389.tgz +0 -0
- package/esm2022/lib/dr-dropdown/dr-dropdown-position.directive.mjs +0 -113
- package/lib/dr-dropdown/dr-dropdown-position.directive.d.ts +0 -15
|
@@ -6,6 +6,19 @@ import { getAlignmentDimension } from '../models/popover';
|
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
7
|
import * as i1 from "./dr-popover-ref";
|
|
8
8
|
import * as i2 from "@angular/common";
|
|
9
|
+
const _c0 = ["popoverContainer"];
|
|
10
|
+
function DrPopoverComponent_ng_container_2_ng_container_1_Template(rf, ctx) { if (rf & 1) {
|
|
11
|
+
i0.ɵɵelementContainer(0);
|
|
12
|
+
} }
|
|
13
|
+
function DrPopoverComponent_ng_container_2_Template(rf, ctx) { if (rf & 1) {
|
|
14
|
+
i0.ɵɵelementContainerStart(0);
|
|
15
|
+
i0.ɵɵtemplate(1, DrPopoverComponent_ng_container_2_ng_container_1_Template, 1, 0, "ng-container", 3);
|
|
16
|
+
i0.ɵɵelementContainerEnd();
|
|
17
|
+
} if (rf & 2) {
|
|
18
|
+
const ctx_r1 = i0.ɵɵnextContext();
|
|
19
|
+
i0.ɵɵadvance(1);
|
|
20
|
+
i0.ɵɵproperty("ngTemplateOutlet", ctx_r1._contentAsTemplate)("ngTemplateOutletContext", ctx_r1.contentContext);
|
|
21
|
+
} }
|
|
9
22
|
export class DrPopoverComponent {
|
|
10
23
|
set content(value) {
|
|
11
24
|
this.isContentTemplate = value instanceof TemplateRef;
|
|
@@ -79,44 +92,62 @@ export class DrPopoverComponent {
|
|
|
79
92
|
});
|
|
80
93
|
}
|
|
81
94
|
}
|
|
82
|
-
/** @nocollapse */ static { this.ɵfac =
|
|
83
|
-
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵ
|
|
95
|
+
/** @nocollapse */ static { this.ɵfac = function DrPopoverComponent_Factory(t) { return new (t || DrPopoverComponent)(i0.ɵɵdirectiveInject(i0.ChangeDetectorRef), i0.ɵɵdirectiveInject(i0.ViewContainerRef), i0.ɵɵdirectiveInject(i0.ElementRef), i0.ɵɵdirectiveInject(i1.DrPopoverRef)); }; }
|
|
96
|
+
/** @nocollapse */ static { this.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: DrPopoverComponent, selectors: [["dr-popover"]], viewQuery: function DrPopoverComponent_Query(rf, ctx) { if (rf & 1) {
|
|
97
|
+
i0.ɵɵviewQuery(_c0, 7, ElementRef);
|
|
98
|
+
} if (rf & 2) {
|
|
99
|
+
let _t;
|
|
100
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.popoverContainer = _t.first);
|
|
101
|
+
} }, hostVars: 5, hostBindings: function DrPopoverComponent_HostBindings(rf, ctx) { if (rf & 1) {
|
|
102
|
+
i0.ɵɵlistener("mouseup", function DrPopoverComponent_mouseup_HostBindingHandler($event) { return ctx.clickOutside($event); }, false, i0.ɵɵresolveDocument);
|
|
103
|
+
} if (rf & 2) {
|
|
104
|
+
i0.ɵɵsyntheticHostProperty("@popover", ctx.popover);
|
|
105
|
+
i0.ɵɵstyleProp("width", ctx.width)("height", ctx.height);
|
|
106
|
+
} }, inputs: { content: "content", contentContext: "contentContext", class: "class", hostRef: "hostRef", manualClosing: "manualClosing", alignment: "alignment", position: "position", freezeToContainerSelector: "freezeToContainerSelector" }, outputs: { popoverOpened: "popoverOpened" }, decls: 3, vars: 3, consts: [[1, "dr-popover"], ["popoverContainer", ""], [4, "ngIf"], [4, "ngTemplateOutlet", "ngTemplateOutletContext"]], template: function DrPopoverComponent_Template(rf, ctx) { if (rf & 1) {
|
|
107
|
+
i0.ɵɵelementStart(0, "div", 0, 1);
|
|
108
|
+
i0.ɵɵtemplate(2, DrPopoverComponent_ng_container_2_Template, 2, 2, "ng-container", 2);
|
|
109
|
+
i0.ɵɵelementEnd();
|
|
110
|
+
} if (rf & 2) {
|
|
111
|
+
i0.ɵɵclassMap(ctx.class);
|
|
112
|
+
i0.ɵɵadvance(2);
|
|
113
|
+
i0.ɵɵproperty("ngIf", ctx.isContentTemplate);
|
|
114
|
+
} }, dependencies: [i2.NgIf, i2.NgTemplateOutlet], styles: [".dr-popover[_ngcontent-%COMP%]{display:flex;background:#fff;border:1px solid #e5e5e5;border-radius:5px;box-sizing:border-box;box-shadow:0 4px 14px #0003;font-size:12px;color:#545a6b;max-height:100vh;max-width:100vw;overflow:auto} .dr-popover-transparent-backdrop{background-color:transparent}"], data: { animation: [trigger('popover', POPUP_ANIMATION)] }, changeDetection: 0 }); }
|
|
84
115
|
}
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-popover.component.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/dr-popover/dr-popover.component.ts","../../../../../projects/datarailsshared/src/lib/dr-popover/dr-popover.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ComponentRef,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    HostListener,\n    Input,\n    OnInit,\n    Output,\n    TemplateRef,\n    Type,\n    ViewChild,\n    ViewContainerRef,\n} from '@angular/core';\nimport { trigger } from '@angular/animations';\nimport { POPUP_ANIMATION } from '../models/constants';\nimport { DrPopoverRef } from './dr-popover-ref';\nimport { DrPopoverAlignment, getAlignmentDimension, IPopoverManualClosing, Point } from '../models/popover';\n\n@Component({\n    selector: 'dr-popover',\n    templateUrl: './dr-popover.component.html',\n    styleUrls: ['./dr-popover.component.scss'],\n    animations: [trigger('popover', POPUP_ANIMATION)],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DrPopoverComponent<T> implements OnInit {\n    @Output() popoverOpened: EventEmitter<void> = new EventEmitter<void>();\n\n    _contentAsType: Type<T>;\n    _contentAsTemplate: TemplateRef<any>;\n    @Input() set content(value: TemplateRef<any> | Type<T>) {\n        this.isContentTemplate = value instanceof TemplateRef;\n        if (this.isContentTemplate) {\n            this._contentAsTemplate = value as TemplateRef<any>;\n        } else {\n            this._contentAsType = value as Type<T>;\n        }\n    }\n    @Input() contentContext: any;\n    @Input() class = '';\n    @Input() hostRef: ElementRef<unknown> | HTMLElement | Point;\n    @Input() manualClosing: IPopoverManualClosing;\n    @Input() alignment: DrPopoverAlignment;\n    @Input() position: string;\n    @Input() freezeToContainerSelector: string;\n\n    @ViewChild('popoverContainer', { read: ElementRef, static: true }) popoverContainer: ElementRef<HTMLElement>;\n    isContentTemplate = false;\n    componentRef: ComponentRef<T>;\n\n    @HostBinding('style.width') width: string;\n    @HostBinding('style.height') height: string;\n\n    @HostBinding('@popover') public popover = true;\n\n    @HostListener('document:mouseup', ['$event'])\n    clickOutside(e): void {\n        const isTargetHost =\n            this.hostRef instanceof ElementRef &&\n            (this.hostRef.nativeElement === e.target || (this.hostRef.nativeElement as HTMLElement).contains(e.target));\n        const isTargetInPopover = this.elementRef.nativeElement.contains(e.target);\n        const isTargetInDatepicker = e.target.closest('mat-datepicker-popup');\n        const isTargetInSelect = e.target.closest('ng-dropdown-panel');\n        const isTargetInDatepickerContent = e.target.closest('mat-datepicker-content');\n\n        if (\n            !isTargetHost &&\n            !isTargetInPopover &&\n            !isTargetInDatepicker &&\n            !isTargetInSelect &&\n            !isTargetInDatepickerContent &&\n            !this.manualClosing.enabled\n        ) {\n            this.popoverRef.close();\n        }\n    }\n\n    constructor(\n        private cdr: ChangeDetectorRef,\n        private viewContainerRef: ViewContainerRef,\n        private elementRef: ElementRef,\n        private popoverRef: DrPopoverRef<T>,\n    ) {}\n\n    ngOnInit(): void {\n        if (!this.isContentTemplate) {\n            this.componentRef = this.viewContainerRef.createComponent(this._contentAsType);\n            Object.assign(this.componentRef.instance, this.contentContext);\n            this.popoverContainer.nativeElement.appendChild(this.componentRef.location.nativeElement);\n        }\n        if (this.alignment === 'host') {\n            this[getAlignmentDimension(this.position)] = '100%';\n        }\n\n        this.popoverOpened.emit();\n        this.repositionToNewContainerAndFreeze();\n        this.cdr.detectChanges();\n    }\n\n    /**\n     * Removing popover element from cdk-overlay and attach to provided container after element is positioned\n     * is required for specific case of preserving popover at same position on document while scroll (not fixed)\n     *\n     * TODO: implement more neat, transparent and Angular way solution: i.e. create another service (or extend existiong one)\n     * without attaching component to cdk Overlay and instead positioning it to element passed in directive input parameter\n     */\n    private repositionToNewContainerAndFreeze(): void {\n        const newContainer = !!this.freezeToContainerSelector && document.querySelector(this.freezeToContainerSelector);\n        if (newContainer) {\n            // waiting until element is positioned on overlay\n            setTimeout(() => {\n                const element: HTMLElement = this.elementRef.nativeElement;\n\n                if (!element.closest('.cdk-overlay-container')) return;\n\n                const position = element.getBoundingClientRect();\n                const newContainerPosition = newContainer.getBoundingClientRect();\n\n                element.style.position = 'absolute';\n                element.style.top = `${newContainer.scrollTop + position.top - newContainerPosition.top}px`;\n                element.style.left = `${newContainerPosition.left + position.left}px`;\n\n                newContainer.appendChild(element);\n            });\n        }\n    }\n}\n","<div class=\"dr-popover\" [class]=\"class\" #popoverContainer>\n    <ng-container *ngIf=\"isContentTemplate\">\n        <ng-container *ngTemplateOutlet=\"_contentAsTemplate; context: contentContext\"></ng-container>\n    </ng-container>\n</div>\n"]}
|
|
116
|
+
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DrPopoverComponent, [{
|
|
117
|
+
type: Component,
|
|
118
|
+
args: [{ selector: 'dr-popover', animations: [trigger('popover', POPUP_ANIMATION)], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"dr-popover\" [class]=\"class\" #popoverContainer>\n <ng-container *ngIf=\"isContentTemplate\">\n <ng-container *ngTemplateOutlet=\"_contentAsTemplate; context: contentContext\"></ng-container>\n </ng-container>\n</div>\n", styles: [".dr-popover{display:flex;background:#fff;border:1px solid #e5e5e5;border-radius:5px;box-sizing:border-box;box-shadow:0 4px 14px #0003;font-size:12px;color:#545a6b;max-height:100vh;max-width:100vw;overflow:auto}::ng-deep .dr-popover-transparent-backdrop{background-color:transparent}\n"] }]
|
|
119
|
+
}], function () { return [{ type: i0.ChangeDetectorRef }, { type: i0.ViewContainerRef }, { type: i0.ElementRef }, { type: i1.DrPopoverRef }]; }, { popoverOpened: [{
|
|
120
|
+
type: Output
|
|
121
|
+
}], content: [{
|
|
122
|
+
type: Input
|
|
123
|
+
}], contentContext: [{
|
|
124
|
+
type: Input
|
|
125
|
+
}], class: [{
|
|
126
|
+
type: Input
|
|
127
|
+
}], hostRef: [{
|
|
128
|
+
type: Input
|
|
129
|
+
}], manualClosing: [{
|
|
130
|
+
type: Input
|
|
131
|
+
}], alignment: [{
|
|
132
|
+
type: Input
|
|
133
|
+
}], position: [{
|
|
134
|
+
type: Input
|
|
135
|
+
}], freezeToContainerSelector: [{
|
|
136
|
+
type: Input
|
|
137
|
+
}], popoverContainer: [{
|
|
138
|
+
type: ViewChild,
|
|
139
|
+
args: ['popoverContainer', { read: ElementRef, static: true }]
|
|
140
|
+
}], width: [{
|
|
141
|
+
type: HostBinding,
|
|
142
|
+
args: ['style.width']
|
|
143
|
+
}], height: [{
|
|
144
|
+
type: HostBinding,
|
|
145
|
+
args: ['style.height']
|
|
146
|
+
}], popover: [{
|
|
147
|
+
type: HostBinding,
|
|
148
|
+
args: ['@popover']
|
|
149
|
+
}], clickOutside: [{
|
|
150
|
+
type: HostListener,
|
|
151
|
+
args: ['document:mouseup', ['$event']]
|
|
152
|
+
}] }); })();
|
|
153
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-popover.component.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/dr-popover/dr-popover.component.ts","../../../../../projects/datarailsshared/src/lib/dr-popover/dr-popover.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ComponentRef,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    HostListener,\n    Input,\n    OnInit,\n    Output,\n    TemplateRef,\n    Type,\n    ViewChild,\n    ViewContainerRef,\n} from '@angular/core';\nimport { trigger } from '@angular/animations';\nimport { POPUP_ANIMATION } from '../models/constants';\nimport { DrPopoverRef } from './dr-popover-ref';\nimport { DrPopoverAlignment, getAlignmentDimension, IPopoverManualClosing, Point } from '../models/popover';\n\n@Component({\n    selector: 'dr-popover',\n    templateUrl: './dr-popover.component.html',\n    styleUrls: ['./dr-popover.component.scss'],\n    animations: [trigger('popover', POPUP_ANIMATION)],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DrPopoverComponent<T> implements OnInit {\n    @Output() popoverOpened: EventEmitter<void> = new EventEmitter<void>();\n\n    _contentAsType: Type<T>;\n    _contentAsTemplate: TemplateRef<any>;\n    @Input() set content(value: TemplateRef<any> | Type<T>) {\n        this.isContentTemplate = value instanceof TemplateRef;\n        if (this.isContentTemplate) {\n            this._contentAsTemplate = value as TemplateRef<any>;\n        } else {\n            this._contentAsType = value as Type<T>;\n        }\n    }\n    @Input() contentContext: any;\n    @Input() class = '';\n    @Input() hostRef: ElementRef<unknown> | HTMLElement | Point;\n    @Input() manualClosing: IPopoverManualClosing;\n    @Input() alignment: DrPopoverAlignment;\n    @Input() position: string;\n    @Input() freezeToContainerSelector: string;\n\n    @ViewChild('popoverContainer', { read: ElementRef, static: true }) popoverContainer: ElementRef<HTMLElement>;\n    isContentTemplate = false;\n    componentRef: ComponentRef<T>;\n\n    @HostBinding('style.width') width: string;\n    @HostBinding('style.height') height: string;\n\n    @HostBinding('@popover') public popover = true;\n\n    @HostListener('document:mouseup', ['$event'])\n    clickOutside(e): void {\n        const isTargetHost =\n            this.hostRef instanceof ElementRef &&\n            (this.hostRef.nativeElement === e.target || (this.hostRef.nativeElement as HTMLElement).contains(e.target));\n        const isTargetInPopover = this.elementRef.nativeElement.contains(e.target);\n        const isTargetInDatepicker = e.target.closest('mat-datepicker-popup');\n        const isTargetInSelect = e.target.closest('ng-dropdown-panel');\n        const isTargetInDatepickerContent = e.target.closest('mat-datepicker-content');\n\n        if (\n            !isTargetHost &&\n            !isTargetInPopover &&\n            !isTargetInDatepicker &&\n            !isTargetInSelect &&\n            !isTargetInDatepickerContent &&\n            !this.manualClosing.enabled\n        ) {\n            this.popoverRef.close();\n        }\n    }\n\n    constructor(\n        private cdr: ChangeDetectorRef,\n        private viewContainerRef: ViewContainerRef,\n        private elementRef: ElementRef,\n        private popoverRef: DrPopoverRef<T>,\n    ) {}\n\n    ngOnInit(): void {\n        if (!this.isContentTemplate) {\n            this.componentRef = this.viewContainerRef.createComponent(this._contentAsType);\n            Object.assign(this.componentRef.instance, this.contentContext);\n            this.popoverContainer.nativeElement.appendChild(this.componentRef.location.nativeElement);\n        }\n        if (this.alignment === 'host') {\n            this[getAlignmentDimension(this.position)] = '100%';\n        }\n\n        this.popoverOpened.emit();\n        this.repositionToNewContainerAndFreeze();\n        this.cdr.detectChanges();\n    }\n\n    /**\n     * Removing popover element from cdk-overlay and attach to provided container after element is positioned\n     * is required for specific case of preserving popover at same position on document while scroll (not fixed)\n     *\n     * TODO: implement more neat, transparent and Angular way solution: i.e. create another service (or extend existiong one)\n     * without attaching component to cdk Overlay and instead positioning it to element passed in directive input parameter\n     */\n    private repositionToNewContainerAndFreeze(): void {\n        const newContainer = !!this.freezeToContainerSelector && document.querySelector(this.freezeToContainerSelector);\n        if (newContainer) {\n            // waiting until element is positioned on overlay\n            setTimeout(() => {\n                const element: HTMLElement = this.elementRef.nativeElement;\n\n                if (!element.closest('.cdk-overlay-container')) return;\n\n                const position = element.getBoundingClientRect();\n                const newContainerPosition = newContainer.getBoundingClientRect();\n\n                element.style.position = 'absolute';\n                element.style.top = `${newContainer.scrollTop + position.top - newContainerPosition.top}px`;\n                element.style.left = `${newContainerPosition.left + position.left}px`;\n\n                newContainer.appendChild(element);\n            });\n        }\n    }\n}\n","<div class=\"dr-popover\" [class]=\"class\" #popoverContainer>\n    <ng-container *ngIf=\"isContentTemplate\">\n        <ng-container *ngTemplateOutlet=\"_contentAsTemplate; context: contentContext\"></ng-container>\n    </ng-container>\n</div>\n"]}
|
|
@@ -56,53 +56,55 @@ export class DrPopoverDirective {
|
|
|
56
56
|
ngOnDestroy() {
|
|
57
57
|
this.closePopover();
|
|
58
58
|
}
|
|
59
|
-
/** @nocollapse */ static { this.ɵfac =
|
|
60
|
-
/** @nocollapse */ static { this.ɵdir = i0.ɵɵ
|
|
59
|
+
/** @nocollapse */ static { this.ɵfac = function DrPopoverDirective_Factory(t) { return new (t || DrPopoverDirective)(i0.ɵɵdirectiveInject(i0.ElementRef), i0.ɵɵdirectiveInject(i1.DrPopoverService)); }; }
|
|
60
|
+
/** @nocollapse */ static { this.ɵdir = /** @pureOrBreakMyCode */ i0.ɵɵdefineDirective({ type: DrPopoverDirective, selectors: [["", "drPopover", ""]], hostBindings: function DrPopoverDirective_HostBindings(rf, ctx) { if (rf & 1) {
|
|
61
|
+
i0.ɵɵlistener("click", function DrPopoverDirective_click_HostBindingHandler() { return ctx.togglePopover(); });
|
|
62
|
+
} }, inputs: { content: ["drPopover", "content"], contentContext: ["drPopoverContext", "contentContext"], position: ["drPopoverPosition", "position"], class: ["drPopoverClass", "class"], overlayConfig: ["drPopoverOverlayConfig", "overlayConfig"], manualClosing: ["drPopoverManualClosing", "manualClosing"], alignment: ["drPopoverAlignment", "alignment"], disabled: ["drPopoverDisabled", "disabled"], freezeToContainerSelector: ["drPopoverFreezeToContainerSelector", "freezeToContainerSelector"] }, outputs: { popoverClose: "drPopoverClose", popoverOpened: "drPopoverOpened", showStateChange: "drPopoverShowStateChange" }, exportAs: ["drPopoverInstance"] }); }
|
|
61
63
|
}
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
64
|
+
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DrPopoverDirective, [{
|
|
65
|
+
type: Directive,
|
|
66
|
+
args: [{
|
|
67
|
+
selector: '[drPopover]',
|
|
68
|
+
exportAs: 'drPopoverInstance',
|
|
69
|
+
}]
|
|
70
|
+
}], function () { return [{ type: i0.ElementRef }, { type: i1.DrPopoverService }]; }, { content: [{
|
|
71
|
+
type: Input,
|
|
72
|
+
args: ['drPopover']
|
|
73
|
+
}], contentContext: [{
|
|
74
|
+
type: Input,
|
|
75
|
+
args: ['drPopoverContext']
|
|
76
|
+
}], position: [{
|
|
77
|
+
type: Input,
|
|
78
|
+
args: ['drPopoverPosition']
|
|
79
|
+
}], class: [{
|
|
80
|
+
type: Input,
|
|
81
|
+
args: ['drPopoverClass']
|
|
82
|
+
}], overlayConfig: [{
|
|
83
|
+
type: Input,
|
|
84
|
+
args: ['drPopoverOverlayConfig']
|
|
85
|
+
}], manualClosing: [{
|
|
86
|
+
type: Input,
|
|
87
|
+
args: ['drPopoverManualClosing']
|
|
88
|
+
}], alignment: [{
|
|
89
|
+
type: Input,
|
|
90
|
+
args: ['drPopoverAlignment']
|
|
91
|
+
}], disabled: [{
|
|
92
|
+
type: Input,
|
|
93
|
+
args: ['drPopoverDisabled']
|
|
94
|
+
}], freezeToContainerSelector: [{
|
|
95
|
+
type: Input,
|
|
96
|
+
args: ['drPopoverFreezeToContainerSelector']
|
|
97
|
+
}], popoverClose: [{
|
|
98
|
+
type: Output,
|
|
99
|
+
args: ['drPopoverClose']
|
|
100
|
+
}], popoverOpened: [{
|
|
101
|
+
type: Output,
|
|
102
|
+
args: ['drPopoverOpened']
|
|
103
|
+
}], showStateChange: [{
|
|
104
|
+
type: Output,
|
|
105
|
+
args: ['drPopoverShowStateChange']
|
|
106
|
+
}], togglePopover: [{
|
|
107
|
+
type: HostListener,
|
|
108
|
+
args: ['click']
|
|
109
|
+
}] }); })();
|
|
110
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHItcG9wb3Zlci5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kYXRhcmFpbHNzaGFyZWQvc3JjL2xpYi9kci1wb3BvdmVyL2RyLXBvcG92ZXIuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsVUFBVSxFQUFFLFlBQVksRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFhLE1BQU0sRUFBcUIsTUFBTSxlQUFlLENBQUM7QUFDL0gsT0FBTyxFQUFFLEtBQUssRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBR3ZDLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHNCQUFzQixDQUFDOzs7QUFPeEQsTUFBTSxPQUFPLGtCQUFrQjtJQTJCM0IsWUFDWSxVQUFzQixFQUN0QixnQkFBa0M7UUFEbEMsZUFBVSxHQUFWLFVBQVUsQ0FBWTtRQUN0QixxQkFBZ0IsR0FBaEIsZ0JBQWdCLENBQWtCO1FBMUJuQixtQkFBYyxHQUFlLEVBQWdCLENBQUM7UUFFN0MsYUFBUSxHQUFlLFFBQVEsQ0FBQztRQUVuQyxVQUFLLEdBQUcsRUFBRSxDQUFDO1FBRUgsa0JBQWEsR0FBb0IsRUFBRSxDQUFDO1FBRXBDLGtCQUFhLEdBQTBCLEVBQUUsT0FBTyxFQUFFLEtBQUssRUFBRSxDQUFDO1FBUWpFLGlCQUFZLEdBQUcsSUFBSSxZQUFZLEVBQU8sQ0FBQztRQUV0QyxrQkFBYSxHQUFHLElBQUksWUFBWSxFQUFRLENBQUM7UUFFaEMsb0JBQWUsR0FBRyxJQUFJLFlBQVksRUFBd0IsQ0FBQztJQU81RixDQUFDO0lBR0osYUFBYTtRQUNULElBQUksSUFBSSxDQUFDLFFBQVE7WUFBRSxPQUFPO1FBRTFCLElBQUksSUFBSSxDQUFDLFVBQVUsRUFBRTtZQUNqQixJQUFJLENBQUMsWUFBWSxFQUFFLENBQUM7U0FDdkI7YUFBTTtZQUNILElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQztZQUNyQixJQUFJLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxFQUFFLE9BQU8sRUFBRSxDQUFDLENBQUMsSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDLENBQUM7U0FDN0Q7SUFDTCxDQUFDO0lBRUQsWUFBWSxDQUFDLEdBQVM7UUFDbEIsSUFBSSxJQUFJLENBQUMsVUFBVSxFQUFFO1lBQ2pCLElBQUksQ0FBQyxVQUFVLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1lBQzNCLElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBSSxDQUFDO1NBQzFCO0lBQ0wsQ0FBQztJQUVPLGFBQWE7UUFDakIsTUFBTSxVQUFVLEdBQUcsQ0FBQyxJQUFJLENBQUMsVUFBVSxHQUFHLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRTtZQUMzRSxPQUFPLEVBQUUsSUFBSSxDQUFDLFVBQVU7WUFDeEIsYUFBYSxFQUFFLElBQUksQ0FBQyxhQUFhO1lBQ2pDLEtBQUssRUFBRSxJQUFJLENBQUMsS0FBSztZQUNqQixhQUFhLEVBQUUsSUFBSSxDQUFDLGFBQWE7WUFDakMsUUFBUSxFQUFFLElBQUksQ0FBQyxRQUFRO1lBQ3ZCLGNBQWMsRUFBRSxJQUFJLENBQUMsY0FBYztZQUNuQyxTQUFTLEVBQUUsSUFBSSxDQUFDLFNBQVM7WUFDekIseUJBQXlCLEVBQUUsSUFBSSxDQUFDLHlCQUF5QjtTQUM1RCxDQUFDLENBQUMsQ0FBQztRQUVKLFVBQVUsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDLENBQUMsU0FBUyxDQUFDLENBQUMsR0FBRyxFQUFFLEVBQUU7WUFDL0MsSUFBSSxDQUFDLFlBQVksRUFBRSxDQUFDO1lBQ3BCLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1lBQzVCLElBQUksQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLEVBQUUsT0FBTyxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUMsQ0FBQztRQUM5RCxDQUFDLENBQUMsQ0FBQztRQUVILFVBQVUsQ0FBQyxZQUFZLENBQUMsUUFBUSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFO1lBQ3hFLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDOUIsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO0lBRUQsV0FBVztRQUNQLElBQUksQ0FBQyxZQUFZLEVBQUUsQ0FBQztJQUN4QixDQUFDO3NHQTVFUSxrQkFBa0I7bUdBQWxCLGtCQUFrQjttR0FBbEIsbUJBQWU7Ozt1RkFBZixrQkFBa0I7Y0FKOUIsU0FBUztlQUFDO2dCQUNQLFFBQVEsRUFBRSxhQUFhO2dCQUN2QixRQUFRLEVBQUUsbUJBQW1CO2FBQ2hDOzRGQUV1QixPQUFPO2tCQUExQixLQUFLO21CQUFDLFdBQVc7WUFFUyxjQUFjO2tCQUF4QyxLQUFLO21CQUFDLGtCQUFrQjtZQUVHLFFBQVE7a0JBQW5DLEtBQUs7bUJBQUMsbUJBQW1CO1lBRUQsS0FBSztrQkFBN0IsS0FBSzttQkFBQyxnQkFBZ0I7WUFFVSxhQUFhO2tCQUE3QyxLQUFLO21CQUFDLHdCQUF3QjtZQUVFLGFBQWE7a0JBQTdDLEtBQUs7bUJBQUMsd0JBQXdCO1lBRUYsU0FBUztrQkFBckMsS0FBSzttQkFBQyxvQkFBb0I7WUFFQyxRQUFRO2tCQUFuQyxLQUFLO21CQUFDLG1CQUFtQjtZQUVtQix5QkFBeUI7a0JBQXJFLEtBQUs7bUJBQUMsb0NBQW9DO1lBRWpCLFlBQVk7a0JBQXJDLE1BQU07bUJBQUMsZ0JBQWdCO1lBRUcsYUFBYTtrQkFBdkMsTUFBTTttQkFBQyxpQkFBaUI7WUFFVyxlQUFlO2tCQUFsRCxNQUFNO21CQUFDLDBCQUEwQjtZQVVsQyxhQUFhO2tCQURaLFlBQVk7bUJBQUMsT0FBTyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgRWxlbWVudFJlZiwgRXZlbnRFbWl0dGVyLCBIb3N0TGlzdGVuZXIsIElucHV0LCBPbkRlc3Ryb3ksIE91dHB1dCwgVGVtcGxhdGVSZWYsIFR5cGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IGZpcnN0IH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xuaW1wb3J0IHsgRWxQb3NpdGlvbiB9IGZyb20gJy4vLi4vbW9kZWxzL2Ryb3Bkb3duJztcbmltcG9ydCB7IERyUG9wb3ZlclJlZiB9IGZyb20gJy4vZHItcG9wb3Zlci1yZWYnO1xuaW1wb3J0IHsgRHJQb3BvdmVyU2VydmljZSB9IGZyb20gJy4vZHItcG9wb3Zlci5zZXJ2aWNlJztcbmltcG9ydCB7IERyUG9wb3ZlckFsaWdubWVudCwgRHJQb3BvdmVyQ29uZmlnLCBJUG9wb3Zlck1hbnVhbENsb3NpbmcgfSBmcm9tICcuLi9tb2RlbHMvcG9wb3Zlcic7XG5cbkBEaXJlY3RpdmUoe1xuICAgIHNlbGVjdG9yOiAnW2RyUG9wb3Zlcl0nLFxuICAgIGV4cG9ydEFzOiAnZHJQb3BvdmVySW5zdGFuY2UnLFxufSlcbmV4cG9ydCBjbGFzcyBEclBvcG92ZXJEaXJlY3RpdmU8VD4gaW1wbGVtZW50cyBPbkRlc3Ryb3kge1xuICAgIEBJbnB1dCgnZHJQb3BvdmVyJykgY29udGVudDogVGVtcGxhdGVSZWY8VD4gfCBUeXBlPFQ+O1xuXG4gICAgQElucHV0KCdkclBvcG92ZXJDb250ZXh0JykgY29udGVudENvbnRleHQ6IFBhcnRpYWw8VD4gPSB7fSBhcyBQYXJ0aWFsPFQ+O1xuXG4gICAgQElucHV0KCdkclBvcG92ZXJQb3NpdGlvbicpIHBvc2l0aW9uOiBFbFBvc2l0aW9uID0gJ2JvdHRvbSc7XG5cbiAgICBASW5wdXQoJ2RyUG9wb3ZlckNsYXNzJykgY2xhc3MgPSAnJztcblxuICAgIEBJbnB1dCgnZHJQb3BvdmVyT3ZlcmxheUNvbmZpZycpIG92ZXJsYXlDb25maWc6IERyUG9wb3ZlckNvbmZpZyA9IHt9O1xuXG4gICAgQElucHV0KCdkclBvcG92ZXJNYW51YWxDbG9zaW5nJykgbWFudWFsQ2xvc2luZzogSVBvcG92ZXJNYW51YWxDbG9zaW5nID0geyBlbmFibGVkOiBmYWxzZSB9O1xuXG4gICAgQElucHV0KCdkclBvcG92ZXJBbGlnbm1lbnQnKSBhbGlnbm1lbnQ6IERyUG9wb3ZlckFsaWdubWVudDtcblxuICAgIEBJbnB1dCgnZHJQb3BvdmVyRGlzYWJsZWQnKSBkaXNhYmxlZDogYm9vbGVhbjtcblxuICAgIEBJbnB1dCgnZHJQb3BvdmVyRnJlZXplVG9Db250YWluZXJTZWxlY3RvcicpIGZyZWV6ZVRvQ29udGFpbmVyU2VsZWN0b3I6IHN0cmluZztcblxuICAgIEBPdXRwdXQoJ2RyUG9wb3ZlckNsb3NlJykgcG9wb3ZlckNsb3NlID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XG5cbiAgICBAT3V0cHV0KCdkclBvcG92ZXJPcGVuZWQnKSBwb3BvdmVyT3BlbmVkID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xuXG4gICAgQE91dHB1dCgnZHJQb3BvdmVyU2hvd1N0YXRlQ2hhbmdlJykgc2hvd1N0YXRlQ2hhbmdlID0gbmV3IEV2ZW50RW1pdHRlcjx7IGlzU2hvd246IGJvb2xlYW4gfT4oKTtcblxuICAgIHByaXZhdGUgcG9wb3ZlclJlZjogRHJQb3BvdmVyUmVmPFQ+O1xuXG4gICAgY29uc3RydWN0b3IoXG4gICAgICAgIHByaXZhdGUgZWxlbWVudFJlZjogRWxlbWVudFJlZixcbiAgICAgICAgcHJpdmF0ZSBkclBvcG92ZXJTZXJ2aWNlOiBEclBvcG92ZXJTZXJ2aWNlLFxuICAgICkge31cblxuICAgIEBIb3N0TGlzdGVuZXIoJ2NsaWNrJylcbiAgICB0b2dnbGVQb3BvdmVyKCk6IHZvaWQge1xuICAgICAgICBpZiAodGhpcy5kaXNhYmxlZCkgcmV0dXJuO1xuXG4gICAgICAgIGlmICh0aGlzLnBvcG92ZXJSZWYpIHtcbiAgICAgICAgICAgIHRoaXMuY2xvc2VQb3BvdmVyKCk7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICB0aGlzLnJlbmRlclBvcG92ZXIoKTtcbiAgICAgICAgICAgIHRoaXMuc2hvd1N0YXRlQ2hhbmdlLmVtaXQoeyBpc1Nob3duOiAhIXRoaXMucG9wb3ZlclJlZiB9KTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIGNsb3NlUG9wb3ZlcihyZXM/OiBhbnkpOiB2b2lkIHtcbiAgICAgICAgaWYgKHRoaXMucG9wb3ZlclJlZikge1xuICAgICAgICAgICAgdGhpcy5wb3BvdmVyUmVmLmNsb3NlKHJlcyk7XG4gICAgICAgICAgICB0aGlzLnBvcG92ZXJSZWYgPSBudWxsO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgcHJpdmF0ZSByZW5kZXJQb3BvdmVyKCk6IHZvaWQge1xuICAgICAgICBjb25zdCBwb3BvdmVyUmVmID0gKHRoaXMucG9wb3ZlclJlZiA9IHRoaXMuZHJQb3BvdmVyU2VydmljZS5vcGVuKHRoaXMuY29udGVudCwge1xuICAgICAgICAgICAgaG9zdFJlZjogdGhpcy5lbGVtZW50UmVmLFxuICAgICAgICAgICAgb3ZlcmxheUNvbmZpZzogdGhpcy5vdmVybGF5Q29uZmlnLFxuICAgICAgICAgICAgY2xhc3M6IHRoaXMuY2xhc3MsXG4gICAgICAgICAgICBtYW51YWxDbG9zaW5nOiB0aGlzLm1hbnVhbENsb3NpbmcsXG4gICAgICAgICAgICBwb3NpdGlvbjogdGhpcy5wb3NpdGlvbixcbiAgICAgICAgICAgIGNvbnRlbnRDb250ZXh0OiB0aGlzLmNvbnRlbnRDb250ZXh0LFxuICAgICAgICAgICAgYWxpZ25tZW50OiB0aGlzLmFsaWdubWVudCxcbiAgICAgICAgICAgIGZyZWV6ZVRvQ29udGFpbmVyU2VsZWN0b3I6IHRoaXMuZnJlZXplVG9Db250YWluZXJTZWxlY3RvcixcbiAgICAgICAgfSkpO1xuXG4gICAgICAgIHBvcG92ZXJSZWYub25DbG9zZS5waXBlKGZpcnN0KCkpLnN1YnNjcmliZSgocmVzKSA9PiB7XG4gICAgICAgICAgICB0aGlzLmNsb3NlUG9wb3ZlcigpO1xuICAgICAgICAgICAgdGhpcy5wb3BvdmVyQ2xvc2UuZW1pdChyZXMpO1xuICAgICAgICAgICAgdGhpcy5zaG93U3RhdGVDaGFuZ2UuZW1pdCh7IGlzU2hvd246ICEhdGhpcy5wb3BvdmVyUmVmIH0pO1xuICAgICAgICB9KTtcblxuICAgICAgICBwb3BvdmVyUmVmLmNvbXBvbmVudFJlZi5pbnN0YW5jZS5wb3BvdmVyT3BlbmVkLnBpcGUoZmlyc3QoKSkuc3Vic2NyaWJlKCgpID0+IHtcbiAgICAgICAgICAgIHRoaXMucG9wb3Zlck9wZW5lZC5lbWl0KCk7XG4gICAgICAgIH0pO1xuICAgIH1cblxuICAgIG5nT25EZXN0cm95KCk6IHZvaWQge1xuICAgICAgICB0aGlzLmNsb3NlUG9wb3ZlcigpO1xuICAgIH1cbn1cbiJdfQ==
|
|
@@ -4,16 +4,17 @@ import { CommonModule } from '@angular/common';
|
|
|
4
4
|
import { DrPopoverComponent } from './dr-popover.component';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
export class DrPopoverModule {
|
|
7
|
-
/** @nocollapse */ static { this.ɵfac =
|
|
8
|
-
/** @nocollapse */ static { this.ɵmod = i0.ɵɵ
|
|
9
|
-
/** @nocollapse */ static { this.ɵinj = i0.ɵɵ
|
|
7
|
+
/** @nocollapse */ static { this.ɵfac = function DrPopoverModule_Factory(t) { return new (t || DrPopoverModule)(); }; }
|
|
8
|
+
/** @nocollapse */ static { this.ɵmod = /** @pureOrBreakMyCode */ i0.ɵɵdefineNgModule({ type: DrPopoverModule }); }
|
|
9
|
+
/** @nocollapse */ static { this.ɵinj = /** @pureOrBreakMyCode */ i0.ɵɵdefineInjector({ imports: [CommonModule] }); }
|
|
10
10
|
}
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
11
|
+
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DrPopoverModule, [{
|
|
12
|
+
type: NgModule,
|
|
13
|
+
args: [{
|
|
14
|
+
imports: [CommonModule],
|
|
15
|
+
exports: [DrPopoverDirective, DrPopoverComponent],
|
|
16
|
+
declarations: [DrPopoverDirective, DrPopoverComponent],
|
|
17
|
+
}]
|
|
18
|
+
}], null, null); })();
|
|
19
|
+
(function () { (typeof ngJitMode === "undefined" || ngJitMode) && i0.ɵɵsetNgModuleScope(DrPopoverModule, { declarations: [DrPopoverDirective, DrPopoverComponent], imports: [CommonModule], exports: [DrPopoverDirective, DrPopoverComponent] }); })();
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHItcG9wb3Zlci5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kYXRhcmFpbHNzaGFyZWQvc3JjL2xpYi9kci1wb3BvdmVyL2RyLXBvcG92ZXIubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDNUQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHdCQUF3QixDQUFDOztBQU81RCxNQUFNLE9BQU8sZUFBZTttR0FBZixlQUFlO2tHQUFmLGVBQWU7c0dBSmQsWUFBWTs7dUZBSWIsZUFBZTtjQUwzQixRQUFRO2VBQUM7Z0JBQ04sT0FBTyxFQUFFLENBQUMsWUFBWSxDQUFDO2dCQUN2QixPQUFPLEVBQUUsQ0FBQyxrQkFBa0IsRUFBRSxrQkFBa0IsQ0FBQztnQkFDakQsWUFBWSxFQUFFLENBQUMsa0JBQWtCLEVBQUUsa0JBQWtCLENBQUM7YUFDekQ7O3dGQUNZLGVBQWUsbUJBRlQsa0JBQWtCLEVBQUUsa0JBQWtCLGFBRjNDLFlBQVksYUFDWixrQkFBa0IsRUFBRSxrQkFBa0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRHJQb3BvdmVyRGlyZWN0aXZlIH0gZnJvbSAnLi9kci1wb3BvdmVyLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgRHJQb3BvdmVyQ29tcG9uZW50IH0gZnJvbSAnLi9kci1wb3BvdmVyLmNvbXBvbmVudCc7XG5cbkBOZ01vZHVsZSh7XG4gICAgaW1wb3J0czogW0NvbW1vbk1vZHVsZV0sXG4gICAgZXhwb3J0czogW0RyUG9wb3ZlckRpcmVjdGl2ZSwgRHJQb3BvdmVyQ29tcG9uZW50XSxcbiAgICBkZWNsYXJhdGlvbnM6IFtEclBvcG92ZXJEaXJlY3RpdmUsIERyUG9wb3ZlckNvbXBvbmVudF0sXG59KVxuZXhwb3J0IGNsYXNzIERyUG9wb3Zlck1vZHVsZSB7fVxuIl19
|
|
@@ -24,8 +24,8 @@ export class DrPopoverService {
|
|
|
24
24
|
this.registerListeners(model, overlayRef, popoverRef);
|
|
25
25
|
return popoverRef;
|
|
26
26
|
}
|
|
27
|
-
attachOverlayContainer(content, { contentContext, position, class: elementClass, manualClosing, hostRef, alignment, freezeToContainerSelector, }, overlayRef, popoverRef) {
|
|
28
|
-
const componentPortal = new ComponentPortal(DrPopoverComponent, null, this.createInjector(popoverRef));
|
|
27
|
+
attachOverlayContainer(content, { contentContext, position, class: elementClass, manualClosing, hostRef, alignment, freezeToContainerSelector, overlayConfig, }, overlayRef, popoverRef) {
|
|
28
|
+
const componentPortal = new ComponentPortal(DrPopoverComponent, null, this.createInjector(popoverRef, overlayConfig.providers));
|
|
29
29
|
const contentRef = overlayRef.attach(componentPortal);
|
|
30
30
|
popoverRef.componentRef = contentRef;
|
|
31
31
|
contentRef.instance.content = content;
|
|
@@ -45,6 +45,18 @@ export class DrPopoverService {
|
|
|
45
45
|
if (!POPUP_POSITIONS[popoverModel.position])
|
|
46
46
|
throw new Error(`DrPopover does not support the '${popoverModel?.position}' position!`);
|
|
47
47
|
const position = { ...POPUP_POSITIONS[popoverModel.position] };
|
|
48
|
+
const positionOffsetY = popoverModel.overlayConfig.positionOffsetY;
|
|
49
|
+
const positionOffsetX = popoverModel.overlayConfig.positionOffsetX;
|
|
50
|
+
if (positionOffsetY || positionOffsetX) {
|
|
51
|
+
if (position.offsetY) {
|
|
52
|
+
position.offsetY = position.offsetY < 0 ? positionOffsetY : positionOffsetY;
|
|
53
|
+
position.offsetX = positionOffsetX;
|
|
54
|
+
}
|
|
55
|
+
if (position.offsetX) {
|
|
56
|
+
position.offsetX = position.offsetX < 0 ? -positionOffsetX : positionOffsetX;
|
|
57
|
+
position.offsetY = positionOffsetY;
|
|
58
|
+
}
|
|
59
|
+
}
|
|
48
60
|
if (popoverModel.overlayConfig.noPadding) {
|
|
49
61
|
position.offsetY = 0;
|
|
50
62
|
position.offsetX = 0;
|
|
@@ -63,8 +75,8 @@ export class DrPopoverService {
|
|
|
63
75
|
}
|
|
64
76
|
return overlayConfig;
|
|
65
77
|
}
|
|
66
|
-
createInjector(popoverRef) {
|
|
67
|
-
const injectionTokens = [{ provide: DrPopoverRef, useValue: popoverRef }];
|
|
78
|
+
createInjector(popoverRef, tokens) {
|
|
79
|
+
const injectionTokens = [...(tokens || []), { provide: DrPopoverRef, useValue: popoverRef }];
|
|
68
80
|
return Injector.create({ providers: injectionTokens, parent: this.injector });
|
|
69
81
|
}
|
|
70
82
|
registerListeners(popoverModel, overlayRef, popoverRef) {
|
|
@@ -93,13 +105,13 @@ export class DrPopoverService {
|
|
|
93
105
|
return hostRef.nativeElement;
|
|
94
106
|
return hostRef;
|
|
95
107
|
}
|
|
96
|
-
/** @nocollapse */ static { this.ɵfac =
|
|
97
|
-
/** @nocollapse */ static { this.ɵprov = i0.ɵɵ
|
|
108
|
+
/** @nocollapse */ static { this.ɵfac = function DrPopoverService_Factory(t) { return new (t || DrPopoverService)(i0.ɵɵinject(i1.Overlay), i0.ɵɵinject(i1.OverlayPositionBuilder), i0.ɵɵinject(i0.Injector)); }; }
|
|
109
|
+
/** @nocollapse */ static { this.ɵprov = /** @pureOrBreakMyCode */ i0.ɵɵdefineInjectable({ token: DrPopoverService, factory: DrPopoverService.ɵfac, providedIn: 'root' }); }
|
|
98
110
|
}
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-popover.service.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/dr-popover/dr-popover.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { first } from 'rxjs/operators';\nimport { DrPopoverRef } from './dr-popover-ref';\nimport { DrPopoverComponent } from './dr-popover.component';\nimport { ComponentPortal } from '@angular/cdk/portal';\nimport { ElementRef, Injectable, Injector, StaticProvider, TemplateRef, Type } from '@angular/core';\nimport { Overlay, OverlayConfig, OverlayPositionBuilder, OverlayRef } from '@angular/cdk/overlay';\nimport { POPUP_POSITIONS } from '../models/constants';\nimport { DEFAULT_CONFIG, DEFAULT_MODEL, getAlignmentDimension, IDrPopoverComponentModel, Point } from '../models/popover';\n\n@Injectable({\n    providedIn: 'root',\n})\nexport class DrPopoverService {\n    constructor(\n        private overlay: Overlay,\n        private overlayPositionBuilder: OverlayPositionBuilder,\n        private injector: Injector,\n    ) {}\n\n    open<T>(content: Type<T> | TemplateRef<unknown>, popoverModel: IDrPopoverComponentModel): DrPopoverRef<T> {\n        if (!content) return;\n\n        const model = { ...DEFAULT_MODEL, ...popoverModel };\n\n        const overlayRef = this.createOverlay(model);\n\n        const popoverRef = new DrPopoverRef<T>(overlayRef);\n\n        this.attachOverlayContainer(content, model, overlayRef, popoverRef);\n\n        this.registerListeners(model, overlayRef, popoverRef);\n\n        return popoverRef;\n    }\n\n    private attachOverlayContainer<T>(\n        content: Type<T> | TemplateRef<unknown>,\n        {\n            contentContext,\n            position,\n            class: elementClass,\n            manualClosing,\n            hostRef,\n            alignment,\n            freezeToContainerSelector,\n        }: IDrPopoverComponentModel,\n        overlayRef: OverlayRef,\n        popoverRef: DrPopoverRef<T>,\n    ): void {\n        const componentPortal = new ComponentPortal<DrPopoverComponent<T>>(\n            DrPopoverComponent,\n            null,\n            this.createInjector(popoverRef),\n        );\n        const contentRef = overlayRef.attach<DrPopoverComponent<T>>(componentPortal);\n\n        popoverRef.componentRef = contentRef;\n\n        contentRef.instance.content = content;\n        contentRef.instance.contentContext = { ...contentContext, closePopover: popoverRef.close.bind(popoverRef) };\n        contentRef.instance.class = elementClass + ' ' + position;\n        contentRef.instance.manualClosing = manualClosing;\n        contentRef.instance.hostRef = hostRef;\n        contentRef.instance.alignment = alignment;\n        contentRef.instance.position = position;\n        contentRef.instance.freezeToContainerSelector = freezeToContainerSelector;\n    }\n\n    private createOverlay(popoverModel: IDrPopoverComponentModel): OverlayRef {\n        const overlayConfig = this.getOverlayConfig(popoverModel);\n        return this.overlay.create(overlayConfig);\n    }\n\n    private getOverlayConfig(popoverModel: IDrPopoverComponentModel): OverlayConfig {\n        if (!POPUP_POSITIONS[popoverModel.position])\n            throw new Error(`DrPopover does not support the '${popoverModel?.position}' position!`);\n\n        const position = { ...POPUP_POSITIONS[popoverModel.position] };\n        if (popoverModel.overlayConfig.noPadding) {\n            position.offsetY = 0;\n            position.offsetX = 0;\n        }\n        const config = { ...DEFAULT_CONFIG, ...(popoverModel.overlayConfig || {}) };\n        const hostElement = this.getHostElement(popoverModel.hostRef);\n\n        const positionStrategy = this.overlayPositionBuilder.flexibleConnectedTo(popoverModel.hostRef).withPositions([position]);\n\n        const overlayConfig = new OverlayConfig({\n            scrollStrategy: this.overlay.scrollStrategies.noop(),\n            positionStrategy,\n            ...config,\n        });\n\n        if (popoverModel.alignment === 'host' && hostElement) {\n            const alignmentDimension = getAlignmentDimension(popoverModel.position);\n            overlayConfig[alignmentDimension] = hostElement.getBoundingClientRect()[alignmentDimension];\n        }\n\n        return overlayConfig;\n    }\n\n    private createInjector<T>(popoverRef: DrPopoverRef<T>): Injector {\n        const injectionTokens: StaticProvider[] = [{ provide: DrPopoverRef, useValue: popoverRef }];\n\n        return Injector.create({ providers: injectionTokens, parent: this.injector });\n    }\n\n    private registerListeners<T>(\n        popoverModel: IDrPopoverComponentModel,\n        overlayRef: OverlayRef,\n        popoverRef: DrPopoverRef<T>,\n    ): void {\n        const config = popoverModel.overlayConfig || {};\n        const targetElement = popoverModel.targetElement;\n        const hostElement = this.getHostElement(popoverModel.hostRef);\n\n        if (config?.closeOnBackdropClick && config?.hasBackdrop) {\n            overlayRef.backdropClick().subscribe(() => popoverRef.close());\n        }\n\n        if (targetElement) {\n            targetElement.addEventListener('mouseup', () => popoverRef.close(), { once: true });\n        }\n\n        if (popoverModel.alignment === 'host' && hostElement) {\n            const alignmentDimension = getAlignmentDimension(popoverModel.position);\n            const resizeObserver = new ResizeObserver((entries) => {\n                entries.forEach((host) =>\n                    overlayRef.updateSize({ [alignmentDimension]: host.target.getBoundingClientRect()[alignmentDimension] }),\n                );\n            });\n            resizeObserver.observe(hostElement);\n            popoverRef.onClose.pipe(first()).subscribe(() => resizeObserver.unobserve(hostElement));\n        }\n    }\n\n    private getHostElement<T>(hostRef: Point | HTMLElement | ElementRef<T>): HTMLElement {\n        if (!hostRef || (<Point>hostRef).x) return null;\n        if ((<ElementRef>hostRef).nativeElement) return (<ElementRef>hostRef).nativeElement;\n        return <HTMLElement>hostRef;\n    }\n}\n"]}
|
|
111
|
+
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DrPopoverService, [{
|
|
112
|
+
type: Injectable,
|
|
113
|
+
args: [{
|
|
114
|
+
providedIn: 'root',
|
|
115
|
+
}]
|
|
116
|
+
}], function () { return [{ type: i1.Overlay }, { type: i1.OverlayPositionBuilder }, { type: i0.Injector }]; }, null); })();
|
|
117
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-popover.service.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/dr-popover/dr-popover.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { first } from 'rxjs/operators';\nimport { DrPopoverRef } from './dr-popover-ref';\nimport { DrPopoverComponent } from './dr-popover.component';\nimport { ComponentPortal, ComponentType } from '@angular/cdk/portal';\nimport { ElementRef, Injectable, Injector, StaticProvider, TemplateRef, Type } from '@angular/core';\nimport { Overlay, OverlayConfig, OverlayPositionBuilder, OverlayRef } from '@angular/cdk/overlay';\nimport { POPUP_POSITIONS } from '../models/constants';\nimport { DEFAULT_CONFIG, DEFAULT_MODEL, getAlignmentDimension, IDrPopoverComponentModel, Point } from '../models/popover';\n\n@Injectable({\n    providedIn: 'root',\n})\nexport class DrPopoverService {\n    constructor(\n        private overlay: Overlay,\n        private overlayPositionBuilder: OverlayPositionBuilder,\n        private injector: Injector,\n    ) {}\n\n    open<T>(\n        content: Type<T> | TemplateRef<unknown> | ComponentType<T>,\n        popoverModel: IDrPopoverComponentModel<T>,\n    ): DrPopoverRef<T> {\n        if (!content) return;\n\n        const model = { ...DEFAULT_MODEL, ...popoverModel };\n\n        const overlayRef = this.createOverlay(model);\n\n        const popoverRef = new DrPopoverRef<T>(overlayRef);\n\n        this.attachOverlayContainer(content, model, overlayRef, popoverRef);\n\n        this.registerListeners(model, overlayRef, popoverRef);\n\n        return popoverRef;\n    }\n\n    private attachOverlayContainer<T>(\n        content: Type<T> | TemplateRef<unknown>,\n        {\n            contentContext,\n            position,\n            class: elementClass,\n            manualClosing,\n            hostRef,\n            alignment,\n            freezeToContainerSelector,\n            overlayConfig,\n        }: IDrPopoverComponentModel,\n        overlayRef: OverlayRef,\n        popoverRef: DrPopoverRef<T>,\n    ): void {\n        const componentPortal = new ComponentPortal<DrPopoverComponent<T>>(\n            DrPopoverComponent,\n            null,\n            this.createInjector(popoverRef, overlayConfig.providers),\n        );\n        const contentRef = overlayRef.attach<DrPopoverComponent<T>>(componentPortal);\n\n        popoverRef.componentRef = contentRef;\n\n        contentRef.instance.content = content;\n        contentRef.instance.contentContext = { ...contentContext, closePopover: popoverRef.close.bind(popoverRef) };\n        contentRef.instance.class = elementClass + ' ' + position;\n        contentRef.instance.manualClosing = manualClosing;\n        contentRef.instance.hostRef = hostRef;\n        contentRef.instance.alignment = alignment;\n        contentRef.instance.position = position;\n        contentRef.instance.freezeToContainerSelector = freezeToContainerSelector;\n    }\n\n    private createOverlay(popoverModel: IDrPopoverComponentModel): OverlayRef {\n        const overlayConfig = this.getOverlayConfig(popoverModel);\n        return this.overlay.create(overlayConfig);\n    }\n\n    private getOverlayConfig(popoverModel: IDrPopoverComponentModel): OverlayConfig {\n        if (!POPUP_POSITIONS[popoverModel.position])\n            throw new Error(`DrPopover does not support the '${popoverModel?.position}' position!`);\n\n        const position: any = { ...POPUP_POSITIONS[popoverModel.position] };\n        const positionOffsetY = popoverModel.overlayConfig.positionOffsetY;\n        const positionOffsetX = popoverModel.overlayConfig.positionOffsetX;\n\n        if (positionOffsetY || positionOffsetX) {\n            if (position.offsetY) {\n                position.offsetY = position.offsetY < 0 ? positionOffsetY : positionOffsetY;\n                position.offsetX = positionOffsetX;\n            }\n            if (position.offsetX) {\n                position.offsetX = position.offsetX < 0 ? -positionOffsetX : positionOffsetX;\n                position.offsetY = positionOffsetY;\n            }\n        }\n\n        if (popoverModel.overlayConfig.noPadding) {\n            position.offsetY = 0;\n            position.offsetX = 0;\n        }\n        const config = { ...DEFAULT_CONFIG, ...(popoverModel.overlayConfig || {}) };\n        const hostElement = this.getHostElement(popoverModel.hostRef);\n\n        const positionStrategy = this.overlayPositionBuilder.flexibleConnectedTo(popoverModel.hostRef).withPositions([position]);\n\n        const overlayConfig = new OverlayConfig({\n            scrollStrategy: this.overlay.scrollStrategies.noop(),\n            positionStrategy,\n            ...config,\n        });\n\n        if (popoverModel.alignment === 'host' && hostElement) {\n            const alignmentDimension = getAlignmentDimension(popoverModel.position);\n            overlayConfig[alignmentDimension] = hostElement.getBoundingClientRect()[alignmentDimension];\n        }\n\n        return overlayConfig;\n    }\n\n    private createInjector<T>(popoverRef: DrPopoverRef<T>, tokens: StaticProvider[]): Injector {\n        const injectionTokens: StaticProvider[] = [...(tokens || []), { provide: DrPopoverRef, useValue: popoverRef }];\n\n        return Injector.create({ providers: injectionTokens, parent: this.injector });\n    }\n\n    private registerListeners<T>(\n        popoverModel: IDrPopoverComponentModel,\n        overlayRef: OverlayRef,\n        popoverRef: DrPopoverRef<T>,\n    ): void {\n        const config = popoverModel.overlayConfig || {};\n        const targetElement = popoverModel.targetElement;\n        const hostElement = this.getHostElement(popoverModel.hostRef);\n\n        if (config?.closeOnBackdropClick && config?.hasBackdrop) {\n            overlayRef.backdropClick().subscribe(() => popoverRef.close());\n        }\n\n        if (targetElement) {\n            targetElement.addEventListener('mouseup', () => popoverRef.close(), { once: true });\n        }\n\n        if (popoverModel.alignment === 'host' && hostElement) {\n            const alignmentDimension = getAlignmentDimension(popoverModel.position);\n            const resizeObserver = new ResizeObserver((entries) => {\n                entries.forEach((host) =>\n                    overlayRef.updateSize({ [alignmentDimension]: host.target.getBoundingClientRect()[alignmentDimension] }),\n                );\n            });\n            resizeObserver.observe(hostElement);\n            popoverRef.onClose.pipe(first()).subscribe(() => resizeObserver.unobserve(hostElement));\n        }\n    }\n\n    private getHostElement<T>(hostRef: Point | HTMLElement | ElementRef<T>): HTMLElement {\n        if (!hostRef || (<Point>hostRef).x) return null;\n        if ((<ElementRef>hostRef).nativeElement) return (<ElementRef>hostRef).nativeElement;\n        return <HTMLElement>hostRef;\n    }\n}\n"]}
|