@datarailsshared/datarailsshared 1.3.15 → 1.3.18

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.
Files changed (30) hide show
  1. package/assets/styles/img/{spinner.gif → new-spinner.gif} +0 -0
  2. package/bundles/datarailsshared-datarailsshared.umd.js +107 -56
  3. package/bundles/datarailsshared-datarailsshared.umd.js.map +1 -1
  4. package/datarailsshared-datarailsshared-1.3.18.tgz +0 -0
  5. package/datarailsshared-datarailsshared.metadata.json +1 -1
  6. package/esm2015/lib/dr-dropdown/dr-dropdown-position.directive.js +2 -2
  7. package/esm2015/lib/dr-dropdown/dr-dropdown.component.js +5 -4
  8. package/esm2015/lib/dr-inputs/button/button.component.js +3 -3
  9. package/esm2015/lib/dr-inputs/dr-input/dr-input.component.js +1 -1
  10. package/esm2015/lib/dr-inputs/dr-select/dr-select.component.js +1 -1
  11. package/esm2015/lib/dr-inputs/dr-toggle/dr-toggle.component.js +3 -2
  12. package/esm2015/lib/dr-popover/dr-popover.component.js +36 -5
  13. package/esm2015/lib/dr-popover/dr-popover.directive.js +7 -29
  14. package/esm2015/lib/dr-popover/dr-popover.service.js +31 -5
  15. package/esm2015/lib/dr-spinner/dr-spinner.component.js +1 -1
  16. package/esm2015/lib/models/constants.js +3 -3
  17. package/esm2015/lib/models/popover.js +16 -2
  18. package/esm2015/public-api.js +2 -2
  19. package/fesm2015/datarailsshared-datarailsshared.js +105 -57
  20. package/fesm2015/datarailsshared-datarailsshared.js.map +1 -1
  21. package/lib/dr-dropdown/dr-dropdown.component.d.ts +1 -1
  22. package/lib/dr-inputs/button/button.component.d.ts +1 -1
  23. package/lib/dr-inputs/dr-toggle/dr-toggle.component.d.ts +1 -0
  24. package/lib/dr-popover/dr-popover.component.d.ts +12 -3
  25. package/lib/dr-popover/dr-popover.directive.d.ts +5 -7
  26. package/lib/dr-popover/dr-popover.service.d.ts +2 -1
  27. package/lib/models/popover.d.ts +11 -1
  28. package/package.json +1 -1
  29. package/public-api.d.ts +1 -1
  30. package/datarailsshared-datarailsshared-1.3.15.tgz +0 -0
@@ -1,10 +1,11 @@
1
+ import { first } from 'rxjs/operators';
1
2
  import { DrPopoverRef } from './dr-popover-ref';
2
3
  import { DrPopoverComponent } from './dr-popover.component';
3
4
  import { ComponentPortal } from '@angular/cdk/portal';
4
5
  import { Injectable, Injector } from '@angular/core';
5
6
  import { Overlay, OverlayConfig, OverlayPositionBuilder } from '@angular/cdk/overlay';
6
7
  import { POPUP_POSITIONS } from '../models/constants';
7
- import { DEFAULT_CONFIG, DEFAULT_MODEL } from '../models/popover';
8
+ import { DEFAULT_CONFIG, DEFAULT_MODEL, getAlignmentDimension } from '../models/popover';
8
9
  import * as i0 from "@angular/core";
9
10
  import * as i1 from "@angular/cdk/overlay";
10
11
  export class DrPopoverService {
@@ -20,10 +21,10 @@ export class DrPopoverService {
20
21
  const overlayRef = this.createOverlay(model);
21
22
  const popoverRef = new DrPopoverRef(overlayRef);
22
23
  this.attachOverlayContainer(content, model, overlayRef, popoverRef);
23
- this.registerCloseListeners(model, overlayRef, popoverRef);
24
+ this.registerListeners(model, overlayRef, popoverRef);
24
25
  return popoverRef;
25
26
  }
26
- attachOverlayContainer(content, { contentContext, position, class: elementClass, manualClosing, hostRef }, overlayRef, popoverRef) {
27
+ attachOverlayContainer(content, { contentContext, position, class: elementClass, manualClosing, hostRef, alignment }, overlayRef, popoverRef) {
27
28
  const componentPortal = new ComponentPortal(DrPopoverComponent, null, this.createInjector(popoverRef));
28
29
  const contentRef = overlayRef.attach(componentPortal);
29
30
  popoverRef.componentRef = contentRef;
@@ -32,17 +33,26 @@ export class DrPopoverService {
32
33
  contentRef.instance.class = elementClass + ' ' + position;
33
34
  contentRef.instance.manualClosing = manualClosing;
34
35
  contentRef.instance.hostRef = hostRef;
36
+ contentRef.instance.alignment = alignment;
37
+ contentRef.instance.position = position;
35
38
  }
36
39
  createOverlay(popoverModel) {
37
40
  const overlayConfig = this.getOverlayConfig(popoverModel);
38
41
  return this.overlay.create(overlayConfig);
39
42
  }
40
43
  getOverlayConfig(popoverModel) {
44
+ if (!POPUP_POSITIONS[popoverModel.position])
45
+ throw new Error(`DrPopover does not support the '${popoverModel === null || popoverModel === void 0 ? void 0 : popoverModel.position}' position!`);
41
46
  const config = Object.assign(Object.assign({}, DEFAULT_CONFIG), popoverModel.overlayConfig || {});
47
+ const hostElement = this.getHostElement(popoverModel.hostRef);
42
48
  const positionStrategy = this.overlayPositionBuilder
43
49
  .flexibleConnectedTo(popoverModel.hostRef)
44
50
  .withPositions([POPUP_POSITIONS[popoverModel.position]]);
45
51
  const overlayConfig = new OverlayConfig(Object.assign({ scrollStrategy: this.overlay.scrollStrategies.noop(), positionStrategy }, config));
52
+ if (popoverModel.alignment === 'host' && hostElement) {
53
+ const alignmentDimension = getAlignmentDimension(popoverModel.position);
54
+ overlayConfig[alignmentDimension] = hostElement.getBoundingClientRect()[alignmentDimension];
55
+ }
46
56
  return overlayConfig;
47
57
  }
48
58
  createInjector(popoverRef) {
@@ -51,15 +61,31 @@ export class DrPopoverService {
51
61
  ];
52
62
  return Injector.create({ providers: injectionTokens, parent: this.injector });
53
63
  }
54
- registerCloseListeners(popoverModel, overlayRef, popoverRef) {
64
+ registerListeners(popoverModel, overlayRef, popoverRef) {
55
65
  const config = popoverModel.overlayConfig || {};
56
66
  const targetElement = popoverModel.targetElement;
67
+ const hostElement = this.getHostElement(popoverModel.hostRef);
57
68
  if ((config === null || config === void 0 ? void 0 : config.closeOnBackdropClick) && (config === null || config === void 0 ? void 0 : config.hasBackdrop)) {
58
69
  overlayRef.backdropClick().subscribe(() => popoverRef.close());
59
70
  }
60
71
  if (targetElement) {
61
72
  targetElement.addEventListener('mouseup', () => popoverRef.close(), { once: true });
62
73
  }
74
+ if (popoverModel.alignment === 'host' && hostElement) {
75
+ const alignmentDimension = getAlignmentDimension(popoverModel.position);
76
+ const resizeObserver = new ResizeObserver(entries => {
77
+ entries.forEach(host => overlayRef.updateSize({ [alignmentDimension]: host.target.getBoundingClientRect()[alignmentDimension] }));
78
+ });
79
+ resizeObserver.observe(hostElement);
80
+ popoverRef.onClose.pipe(first()).subscribe(() => resizeObserver.unobserve(hostElement));
81
+ }
82
+ }
83
+ getHostElement(hostRef) {
84
+ if (!hostRef || hostRef.x)
85
+ return null;
86
+ if (hostRef.nativeElement)
87
+ return hostRef.nativeElement;
88
+ return hostRef;
63
89
  }
64
90
  }
65
91
  DrPopoverService.ɵprov = i0.ɵɵdefineInjectable({ factory: function DrPopoverService_Factory() { return new DrPopoverService(i0.ɵɵinject(i1.Overlay), i0.ɵɵinject(i1.OverlayPositionBuilder), i0.ɵɵinject(i0.INJECTOR)); }, token: DrPopoverService, providedIn: "root" });
@@ -73,4 +99,4 @@ DrPopoverService.ctorParameters = () => [
73
99
  { type: OverlayPositionBuilder },
74
100
  { type: Injector }
75
101
  ];
76
- //# 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 { DrPopoverRef } from './dr-popover-ref';\r\nimport { DrPopoverComponent } from './dr-popover.component';\r\nimport { ComponentPortal } from '@angular/cdk/portal';\r\nimport { Injectable, Injector, StaticProvider, TemplateRef, Type } from '@angular/core';\r\nimport { Overlay, OverlayConfig, OverlayPositionBuilder, OverlayRef } from '@angular/cdk/overlay';\r\nimport { POPUP_POSITIONS } from '../models/constants';\r\nimport { DEFAULT_CONFIG, DEFAULT_MODEL, IDrPopoverComponentModel } from '../models/popover';\r\n\r\n@Injectable({\r\n    providedIn: 'root',\r\n})\r\nexport class DrPopoverService {\r\n\r\n    constructor(\r\n        private overlay: Overlay,\r\n        private overlayPositionBuilder: OverlayPositionBuilder,\r\n        private injector: Injector,\r\n    ) { }\r\n\r\n    open<T>(content: Type<T> | TemplateRef<HTMLElement>, popoverModel: IDrPopoverComponentModel): DrPopoverRef<T> {\r\n        if (!content) return;\r\n\r\n        const model = { ...DEFAULT_MODEL, ...popoverModel };\r\n\r\n        const overlayRef = this.createOverlay(model);\r\n\r\n        const popoverRef = new DrPopoverRef<T>(overlayRef);\r\n\r\n        this.attachOverlayContainer(content, model, overlayRef, popoverRef);\r\n\r\n        this.registerCloseListeners(model, overlayRef, popoverRef);\r\n\r\n        return popoverRef;\r\n    }\r\n\r\n    private attachOverlayContainer<T>(\r\n        content: Type<T> | TemplateRef<HTMLElement>,\r\n        { contentContext, position, class: elementClass, manualClosing, hostRef }: IDrPopoverComponentModel,\r\n        overlayRef: OverlayRef,\r\n        popoverRef: DrPopoverRef<T>\r\n    ): void {\r\n        const componentPortal = new ComponentPortal<DrPopoverComponent<T>>(DrPopoverComponent, null, this.createInjector(popoverRef));\r\n        const contentRef = overlayRef.attach<DrPopoverComponent<T>>(componentPortal);\r\n\r\n        popoverRef.componentRef = contentRef;\r\n\r\n        contentRef.instance.content = content;\r\n        contentRef.instance.contentContext = { ...contentContext, closePopover: popoverRef.close.bind(popoverRef) };\r\n        contentRef.instance.class = elementClass + ' ' + position;\r\n        contentRef.instance.manualClosing = manualClosing;\r\n        contentRef.instance.hostRef = hostRef;\r\n    }\r\n\r\n    private createOverlay(popoverModel: IDrPopoverComponentModel): OverlayRef {\r\n        const overlayConfig = this.getOverlayConfig(popoverModel);\r\n        return this.overlay.create(overlayConfig);\r\n    }\r\n\r\n    private getOverlayConfig(popoverModel: IDrPopoverComponentModel): OverlayConfig {\r\n        const config = { ...DEFAULT_CONFIG, ...popoverModel.overlayConfig || {}};\r\n\r\n        const positionStrategy = this.overlayPositionBuilder\r\n            .flexibleConnectedTo(popoverModel.hostRef)\r\n            .withPositions([POPUP_POSITIONS[popoverModel.position]]);\r\n\r\n        const overlayConfig = new OverlayConfig({\r\n            scrollStrategy: this.overlay.scrollStrategies.noop(),\r\n            positionStrategy,\r\n            ...config,\r\n        });\r\n\r\n        return overlayConfig;\r\n    }\r\n\r\n    private createInjector<T>(popoverRef: DrPopoverRef<T>): Injector {\r\n        const injectionTokens: StaticProvider[] = [\r\n            { provide: DrPopoverRef, useValue: popoverRef },\r\n        ];\r\n\r\n        return Injector.create({ providers: injectionTokens, parent: this.injector });\r\n    }\r\n\r\n    private registerCloseListeners<T>(popoverModel: IDrPopoverComponentModel, overlayRef: OverlayRef, popoverRef: DrPopoverRef<T>): void {\r\n        const config = popoverModel.overlayConfig || {};\r\n        const targetElement = popoverModel.targetElement;\r\n\r\n        if (config?.closeOnBackdropClick && config?.hasBackdrop) {\r\n            overlayRef.backdropClick().subscribe(() => popoverRef.close());\r\n        }\r\n\r\n        if (targetElement) {\r\n            targetElement.addEventListener('mouseup', () => popoverRef.close(), { once: true });\r\n        }\r\n    }\r\n\r\n}\r\n"]}
102
+ //# 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';\r\nimport { DrPopoverRef } from './dr-popover-ref';\r\nimport { DrPopoverComponent } from './dr-popover.component';\r\nimport { ComponentPortal } from '@angular/cdk/portal';\r\nimport { Injectable, Injector, StaticProvider, TemplateRef, Type, ElementRef } from '@angular/core';\r\nimport { Overlay, OverlayConfig, OverlayPositionBuilder, OverlayRef } from '@angular/cdk/overlay';\r\nimport { POPUP_POSITIONS } from '../models/constants';\r\nimport { DEFAULT_CONFIG, DEFAULT_MODEL, getAlignmentDimension, IDrPopoverComponentModel, Point } from '../models/popover';\r\n\r\n@Injectable({\r\n    providedIn: 'root',\r\n})\r\nexport class DrPopoverService {\r\n\r\n    constructor(\r\n        private overlay: Overlay,\r\n        private overlayPositionBuilder: OverlayPositionBuilder,\r\n        private injector: Injector,\r\n    ) { }\r\n\r\n    open<T>(content: Type<T> | TemplateRef<HTMLElement>, popoverModel: IDrPopoverComponentModel): DrPopoverRef<T> {\r\n        if (!content) return;\r\n\r\n        const model = { ...DEFAULT_MODEL, ...popoverModel };\r\n\r\n        const overlayRef = this.createOverlay(model);\r\n\r\n        const popoverRef = new DrPopoverRef<T>(overlayRef);\r\n\r\n        this.attachOverlayContainer(content, model, overlayRef, popoverRef);\r\n\r\n        this.registerListeners(model, overlayRef, popoverRef);\r\n\r\n        return popoverRef;\r\n    }\r\n\r\n    private attachOverlayContainer<T>(\r\n        content: Type<T> | TemplateRef<HTMLElement>,\r\n        { contentContext, position, class: elementClass, manualClosing, hostRef, alignment }: IDrPopoverComponentModel,\r\n        overlayRef: OverlayRef,\r\n        popoverRef: DrPopoverRef<T>\r\n    ): void {\r\n        const componentPortal = new ComponentPortal<DrPopoverComponent<T>>(DrPopoverComponent, null, this.createInjector(popoverRef));\r\n        const contentRef = overlayRef.attach<DrPopoverComponent<T>>(componentPortal);\r\n\r\n        popoverRef.componentRef = contentRef;\r\n\r\n        contentRef.instance.content = content;\r\n        contentRef.instance.contentContext = { ...contentContext, closePopover: popoverRef.close.bind(popoverRef) };\r\n        contentRef.instance.class = elementClass + ' ' + position;\r\n        contentRef.instance.manualClosing = manualClosing;\r\n        contentRef.instance.hostRef = hostRef;\r\n        contentRef.instance.alignment = alignment;\r\n        contentRef.instance.position = position;\r\n    }\r\n\r\n    private createOverlay(popoverModel: IDrPopoverComponentModel): OverlayRef {\r\n        const overlayConfig = this.getOverlayConfig(popoverModel);\r\n        return this.overlay.create(overlayConfig);\r\n    }\r\n\r\n    private getOverlayConfig(popoverModel: IDrPopoverComponentModel): OverlayConfig {\r\n        if (!POPUP_POSITIONS[popoverModel.position]) throw new Error(`DrPopover does not support the '${popoverModel?.position}' position!`);\r\n\r\n        const config = { ...DEFAULT_CONFIG, ...popoverModel.overlayConfig || {}};\r\n        const hostElement = this.getHostElement(popoverModel.hostRef);\r\n\r\n        const positionStrategy = this.overlayPositionBuilder\r\n            .flexibleConnectedTo(popoverModel.hostRef)\r\n            .withPositions([POPUP_POSITIONS[popoverModel.position]]);\r\n\r\n        const overlayConfig = new OverlayConfig({\r\n            scrollStrategy: this.overlay.scrollStrategies.noop(),\r\n            positionStrategy,\r\n            ...config,\r\n        });\r\n\r\n        if (popoverModel.alignment === 'host' && hostElement) {\r\n            const alignmentDimension = getAlignmentDimension(popoverModel.position);\r\n            overlayConfig[alignmentDimension] = hostElement.getBoundingClientRect()[alignmentDimension];\r\n        }\r\n\r\n        return overlayConfig;\r\n    }\r\n\r\n    private createInjector<T>(popoverRef: DrPopoverRef<T>): Injector {\r\n        const injectionTokens: StaticProvider[] = [\r\n            { provide: DrPopoverRef, useValue: popoverRef },\r\n        ];\r\n\r\n        return Injector.create({ providers: injectionTokens, parent: this.injector });\r\n    }\r\n\r\n    private registerListeners<T>(popoverModel: IDrPopoverComponentModel, overlayRef: OverlayRef, popoverRef: DrPopoverRef<T>): void {\r\n        const config = popoverModel.overlayConfig || {};\r\n        const targetElement = popoverModel.targetElement;\r\n        const hostElement = this.getHostElement(popoverModel.hostRef);\r\n\r\n        if (config?.closeOnBackdropClick && config?.hasBackdrop) {\r\n            overlayRef.backdropClick().subscribe(() => popoverRef.close());\r\n        }\r\n\r\n        if (targetElement) {\r\n            targetElement.addEventListener('mouseup', () => popoverRef.close(), { once: true });\r\n        }\r\n\r\n        if (popoverModel.alignment === 'host' && hostElement) {\r\n            const alignmentDimension = getAlignmentDimension(popoverModel.position);\r\n            const resizeObserver = new ResizeObserver(entries => {\r\n                entries.forEach(host => overlayRef.updateSize({ [alignmentDimension]: host.target.getBoundingClientRect()[alignmentDimension] }));\r\n            });\r\n            resizeObserver.observe(hostElement);\r\n            popoverRef.onClose.pipe(first()).subscribe(() => resizeObserver.unobserve(hostElement));\r\n        }\r\n    }\r\n\r\n    private getHostElement<T>(hostRef: Point | HTMLElement | ElementRef<T>): HTMLElement {\r\n        if (!hostRef || (<Point>hostRef).x) return null;\r\n        if ((<ElementRef>hostRef).nativeElement) return (<ElementRef>hostRef).nativeElement;\r\n        return <HTMLElement>hostRef;\r\n    }\r\n\r\n}\r\n"]}