@leanix/components 0.4.407 → 0.4.409
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/esm2022/index.mjs +2 -1
- package/esm2022/lib/core-ui/components/badge/badge.component.mjs +21 -1
- package/esm2022/lib/core-ui/components/banner/banner.component.mjs +23 -1
- package/esm2022/lib/core-ui/components/button/button.component.mjs +40 -1
- package/esm2022/lib/core-ui/components/card/card.component.mjs +16 -1
- package/esm2022/lib/core-ui/components/content-panel/content-panel.component.mjs +18 -3
- package/esm2022/lib/core-ui/components/counter/counter.component.mjs +14 -1
- package/esm2022/lib/core-ui/components/integration-link-card/integration-link-card.component.mjs +47 -1
- package/esm2022/lib/core-ui/components/skeleton/skeleton.component.mjs +19 -1
- package/esm2022/lib/core-ui/components/stepper/stepper.component.mjs +41 -1
- package/esm2022/lib/core-ui/components/tiny-spinner/tiny-spinner.component.mjs +12 -1
- package/esm2022/lib/core-ui/components/tokenizer/tokenizer-overflow-popover/tokenizer-overflow-popover.component.mjs +44 -0
- package/esm2022/lib/core-ui/components/tokenizer/tokenizer.component.mjs +3 -3
- package/esm2022/lib/core-ui/tooltip/tooltip.directive.mjs +16 -1
- package/esm2022/lib/forms-ui/components/breadcrumb/breadcrumb.component.mjs +17 -1
- package/esm2022/lib/forms-ui/components/date-input/date-input.component.mjs +100 -38
- package/esm2022/lib/forms-ui/components/slider-toggle/slider-toggle.component.mjs +18 -1
- package/esm2022/lib/modal-ui/components/modal/modal.component.mjs +55 -7
- package/esm2022/lib/popover-ui/components/popover/popover.component.mjs +31 -6
- package/fesm2022/leanix-components.mjs +541 -82
- package/fesm2022/leanix-components.mjs.map +1 -1
- package/index.d.ts +1 -0
- package/lib/core-ui/components/badge/badge.component.d.ts +23 -0
- package/lib/core-ui/components/banner/banner.component.d.ts +22 -0
- package/lib/core-ui/components/button/button.component.d.ts +39 -0
- package/lib/core-ui/components/card/card.component.d.ts +15 -0
- package/lib/core-ui/components/content-panel/content-panel.component.d.ts +18 -1
- package/lib/core-ui/components/counter/counter.component.d.ts +14 -0
- package/lib/core-ui/components/integration-link-card/integration-link-card.component.d.ts +60 -0
- package/lib/core-ui/components/skeleton/skeleton.component.d.ts +18 -0
- package/lib/core-ui/components/stepper/stepper.component.d.ts +40 -0
- package/lib/core-ui/components/tiny-spinner/tiny-spinner.component.d.ts +11 -0
- package/lib/core-ui/components/tokenizer/tokenizer-overflow-popover/tokenizer-overflow-popover.component.d.ts +19 -0
- package/lib/core-ui/tooltip/tooltip.directive.d.ts +17 -0
- package/lib/forms-ui/components/breadcrumb/breadcrumb.component.d.ts +16 -0
- package/lib/forms-ui/components/date-input/date-input.component.d.ts +80 -7
- package/lib/forms-ui/components/slider-toggle/slider-toggle.component.d.ts +20 -0
- package/lib/modal-ui/components/modal/modal.component.d.ts +59 -5
- package/lib/popover-ui/components/popover/popover.component.d.ts +37 -5
- package/package.json +1 -1
@@ -16,12 +16,42 @@ import * as i3 from "@angular/cdk/portal";
|
|
16
16
|
import * as i4 from "@ngx-translate/core";
|
17
17
|
import * as i5 from "rxjs";
|
18
18
|
/**
|
19
|
-
*
|
20
|
-
* - provideAnimations()
|
19
|
+
* This documentation provides details on the usage and configuration of the Modal.
|
21
20
|
*
|
22
|
-
*
|
21
|
+
* ## Usage
|
22
|
+
*
|
23
|
+
* 1. Import `LxModalModule` and `LxCoreUiModule` modules from `@leanix/components` in your module where you want to use the component.
|
24
|
+
*
|
25
|
+
* ```ts
|
26
|
+
* import { LxModalModule, LxCoreUiModule } from '@leanix/components';
|
27
|
+
* ```
|
28
|
+
*
|
29
|
+
* 2. Use the **lx-modal** component in your template with the parameters described below.
|
30
|
+
*
|
31
|
+
* - **`open`**: Whether the modal is open or closed.
|
32
|
+
* - **`size`**: 'dialog' | 'dialog-large'.
|
33
|
+
* - **`verticalScroll`**: Whether the modal is scrollable or not.
|
34
|
+
* - **`showHeader`**: Whether the modal has a header or not.
|
35
|
+
* - **`showFooter`**: Whether the modal has a footer or not.
|
36
|
+
* - **`showCloseButton`**: Whether to show the close button.
|
37
|
+
* - **`showBackButton`**: Whether to show the back button.
|
38
|
+
*
|
39
|
+
* 3. Use optional **lx-modal-header** component in your template with the parameters described below.
|
40
|
+
*
|
41
|
+
* - **`title`**: Title of the modal.
|
42
|
+
* - **`subtitle`**: Subtitle of the modal.
|
43
|
+
* - **`bottomBorder`**: Whether to show a bottom border.
|
44
|
+
*
|
45
|
+
* 4. Use optional **lx-modal-footer** component in your template with the parameters described below.
|
46
|
+
*
|
47
|
+
* - **`border`**: Whether to show the footer at the bottom of the modal.
|
48
|
+
*
|
49
|
+
* **GLOBAL PROVIDERS** required for this component:
|
50
|
+
* - `provideAnimations()`
|
51
|
+
*
|
52
|
+
* **ATTENTION - SCROLLABLE DIALOG**:
|
23
53
|
* The <lx-modal> component when used as "dialog" is not designed to work with a
|
24
|
-
* scrollable body (via
|
54
|
+
* scrollable body (via `overflow: auto | scroll`) in combination with dropdowns.
|
25
55
|
* The overflow on the body will also clip the dropdowns, which is expected.
|
26
56
|
*
|
27
57
|
* Reasoning:
|
@@ -30,12 +60,12 @@ import * as i5 from "rxjs";
|
|
30
60
|
* requires scrolling, we should discuss whether to put it into a dialog at all
|
31
61
|
* and rather think about putting the content on a separate route or
|
32
62
|
* using the fullscreen version of the modal.
|
33
|
-
*
|
34
63
|
*/
|
35
64
|
export class ModalComponent {
|
36
65
|
get content() {
|
37
66
|
return this.explicitContent || this.implicitContent;
|
38
67
|
}
|
68
|
+
/** @internal */
|
39
69
|
onEscape() {
|
40
70
|
if (this.open && this.showCloseButton) {
|
41
71
|
this.closeModal(ModalCloseClickLocation.Escape);
|
@@ -46,21 +76,36 @@ export class ModalComponent {
|
|
46
76
|
this.renderer = renderer;
|
47
77
|
this.closeModal$ = closeModal$;
|
48
78
|
this.focusTrap = focusTrap;
|
79
|
+
/** @internal */
|
49
80
|
this.NAME = 'ModalComponent';
|
81
|
+
/** Whether the modal is open or closed. */
|
50
82
|
this.open = false;
|
83
|
+
/** Whether to show the close button. */
|
51
84
|
this.showCloseButton = true;
|
85
|
+
/** Whether to show the back button. */
|
52
86
|
this.showBackButton = false;
|
53
87
|
/*
|
54
88
|
* If true, then the content area scrolls vertically instead of expanding its height.
|
55
89
|
* This can be a problem if the content has dropdowns or date inputs, but can be good if the content has a huge amount of text.
|
56
90
|
*/
|
57
91
|
this.verticalScroll = false;
|
92
|
+
/** The size of the modal. */
|
58
93
|
this.size = 'fullscreen';
|
59
|
-
|
94
|
+
/**
|
95
|
+
* Minimum width of the modal.
|
96
|
+
*
|
97
|
+
* _NB: Some modal implementations rely on this minWidth being 600px_
|
98
|
+
*/
|
99
|
+
this.minWidth = '600px';
|
100
|
+
/** Whether the modal is a focus trap. */
|
60
101
|
this.isFocusTrap = false;
|
102
|
+
/** Event emitted when the modal is closed. */
|
61
103
|
this.close = new EventEmitter();
|
104
|
+
/** Event emitted when the back button is clicked. */
|
62
105
|
this.back = new EventEmitter();
|
106
|
+
/** @internal */
|
63
107
|
this.closeLocation = ModalCloseClickLocation;
|
108
|
+
/** @internal */
|
64
109
|
this.destroyed$ = new Subject();
|
65
110
|
}
|
66
111
|
ngOnInit() {
|
@@ -120,6 +165,7 @@ export class ModalComponent {
|
|
120
165
|
.subscribe(() => this.openModal());
|
121
166
|
}
|
122
167
|
}
|
168
|
+
/** @internal */
|
123
169
|
openModal() {
|
124
170
|
this.oldOverflow = document.documentElement.style.overflowY;
|
125
171
|
if (this.size === 'fullscreen') {
|
@@ -128,6 +174,7 @@ export class ModalComponent {
|
|
128
174
|
this.overlayRef.attach(this.cdkPortal);
|
129
175
|
this.trapFocusInModal(this.overlayRef.hostElement);
|
130
176
|
}
|
177
|
+
/** @internal */
|
131
178
|
emitBack() {
|
132
179
|
this.back.emit();
|
133
180
|
}
|
@@ -140,6 +187,7 @@ export class ModalComponent {
|
|
140
187
|
this.overlayRef.dispose();
|
141
188
|
}
|
142
189
|
}
|
190
|
+
/** @internal */
|
143
191
|
async closeModal(closeLocation) {
|
144
192
|
if (!this.canModalBeClosed || (await this.canModalBeClosed(closeLocation))) {
|
145
193
|
this.open = false;
|
@@ -213,4 +261,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
|
|
213
261
|
type: HostListener,
|
214
262
|
args: ['document:keydown.escape']
|
215
263
|
}] } });
|
216
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/src/lib/modal-ui/components/modal/modal.component.ts","../../../../../../../../libs/components/src/lib/modal-ui/components/modal/modal.component.html"],"names":[],"mappings":"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","sourcesContent":["import { animate, style, transition, trigger } from '@angular/animations';\nimport { ConfigurableFocusTrapFactory } from '@angular/cdk/a11y';\nimport { Overlay, OverlayRef } from '@angular/cdk/overlay';\nimport { CdkPortal, Portal, PortalModule } from '@angular/cdk/portal';\nimport { NgIf, NgTemplateOutlet } from '@angular/common';\nimport {\n  AfterViewInit,\n  Component,\n  ContentChild,\n  EventEmitter,\n  HostListener,\n  Inject,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  Renderer2,\n  TemplateRef,\n  ViewChild\n} from '@angular/core';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { Observable, Subject, timer } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { ModalContentDirective } from '../../directives/modal-content.directive';\nimport { MODAL_CLOSE, ModalCloseClickLocation } from '../../modal.constants';\nimport { ModalFooterComponent } from '../modal-footer/modal-footer.component';\nimport { ModalHeaderComponent } from '../modal-header/modal-header.component';\n\n/**\n * GLOBAL PROVIDERS required for this component:\n * - provideAnimations()\n *\n * ATTENTION - SCROLLABLE DIALOG:\n * The <lx-modal> component when used as \"dialog\" is not designed to work with a\n * scrollable body (via \"overflow: auto | scroll\") in combination with dropdowns.\n * The overflow on the body will also clip the dropdowns, which is expected.\n *\n * Reasoning:\n * The contents within the dialog should be just a few elements which fit and\n * justify the usage of a dialog. If the content is larger than the dialog, and thus\n * requires scrolling, we should discuss whether to put it into a dialog at all\n * and rather think about putting the content on a separate route or\n * using the fullscreen version of the modal.\n *\n */\n@Component({\n  selector: 'lx-modal',\n  templateUrl: 'modal.component.html',\n  styleUrls: ['modal.component.scss'],\n  animations: [\n    trigger('modal', [\n      transition(':enter', [style({ opacity: 0 }), animate('0.15s', style({ opacity: 1 }))]),\n      transition(':leave', animate('0.15s', style({ opacity: 0 })))\n    ])\n  ],\n  standalone: true,\n  imports: [PortalModule, NgIf, NgTemplateOutlet, TranslateModule]\n})\nexport class ModalComponent implements OnChanges, OnInit, OnDestroy, AfterViewInit {\n  readonly NAME = 'ModalComponent';\n  @Input() open: boolean = false;\n  @Input() showCloseButton = true;\n  @Input() showBackButton = false;\n  /*\n   * If true, then the content area scrolls vertically instead of expanding its height.\n   * This can be a problem if the content has dropdowns or date inputs, but can be good if the content has a huge amount of text.\n   */\n  @Input() verticalScroll = false;\n  @Input() size: 'fullscreen' | 'dialog-large' | 'dialog' = 'fullscreen';\n  @Input() minWidth: string = '600px'; // NB: Some modal implementations rely on this minWidth being 600px\n  @Input() isFocusTrap: boolean = false;\n  @Input() canModalBeClosed?: (closeLocation: ModalCloseClickLocation | boolean) => Promise<boolean>;\n  @Output() close = new EventEmitter<ModalCloseClickLocation>();\n  @Output() back = new EventEmitter<void>();\n\n  @ContentChild(ModalHeaderComponent) header?: ModalHeaderComponent;\n  @ContentChild(ModalFooterComponent) footer?: ModalFooterComponent;\n  @ViewChild(CdkPortal, { static: true }) cdkPortal!: Portal<CdkPortal>;\n  private overlayRef!: OverlayRef;\n  private oldOverflow?: string;\n  closeLocation = ModalCloseClickLocation;\n\n  readonly destroyed$ = new Subject<void>();\n\n  @ViewChild('implicitContent', { static: true }) implicitContent!: TemplateRef<any>;\n\n  @ContentChild(ModalContentDirective, { read: TemplateRef, static: true }) explicitContent?: TemplateRef<any>;\n\n  get content() {\n    return this.explicitContent || this.implicitContent;\n  }\n\n  @HostListener('document:keydown.escape') onEscape() {\n    if (this.open && this.showCloseButton) {\n      this.closeModal(ModalCloseClickLocation.Escape);\n    }\n  }\n\n  constructor(\n    private overlay: Overlay,\n    private renderer: Renderer2,\n    @Optional() @Inject(MODAL_CLOSE) private closeModal$: Observable<ModalCloseClickLocation | boolean>,\n    private focusTrap: ConfigurableFocusTrapFactory\n  ) {}\n\n  ngOnInit() {\n    this.closeModal$\n      ?.pipe(takeUntil(this.destroyed$))\n      .subscribe((closeLocation: ModalCloseClickLocation | boolean) => this.closeModal(closeLocation));\n\n    if (this.size === 'fullscreen') {\n      this.overlayRef = this.overlay.create({\n        panelClass: this.size,\n        width: '100%',\n        height: '100vh'\n      });\n    } else if (this.size === 'dialog-large') {\n      const positionStrategy = this.overlay.position().global().top('4vh').centerHorizontally();\n      this.overlayRef = this.overlay.create({\n        panelClass: this.size,\n        positionStrategy,\n        hasBackdrop: true,\n        width: '90%',\n        height: '90vh'\n      });\n    } else {\n      // size 'dialog'\n      const positionStrategy = this.overlay.position().global().top('8vh').centerHorizontally();\n      this.overlayRef = this.overlay.create({\n        panelClass: this.size,\n        minWidth: this.minWidth,\n        positionStrategy,\n        hasBackdrop: true,\n        scrollStrategy: this.overlay.scrollStrategies.block()\n      });\n    }\n\n    if (this.size !== 'fullscreen') {\n      this.overlayRef\n        .backdropClick()\n        .pipe(takeUntil(this.destroyed$))\n        .subscribe(() => this.closeModal(ModalCloseClickLocation.OutsideClick));\n    }\n  }\n\n  ngOnChanges() {\n    if (this.open && this.overlayRef && !this.overlayRef.hasAttached()) {\n      this.openModal();\n    }\n    if (!this.open && this.overlayRef && this.overlayRef.hasAttached()) {\n      this.closeModal(ModalCloseClickLocation.Other);\n    }\n    if (this.open && this.overlayRef && this.overlayRef.hasAttached() && this.isFocusTrap) {\n      this.trapFocusInModal(this.overlayRef.hostElement);\n    }\n  }\n\n  ngAfterViewInit() {\n    if (this.open) {\n      timer(0)\n        .pipe(takeUntil(this.destroyed$))\n        .subscribe(() => this.openModal());\n    }\n  }\n\n  openModal() {\n    this.oldOverflow = document.documentElement.style.overflowY;\n    if (this.size === 'fullscreen') {\n      this.renderer.setStyle(document.documentElement, 'overflowY', 'hidden');\n    }\n\n    this.overlayRef.attach(this.cdkPortal);\n    this.trapFocusInModal(this.overlayRef.hostElement);\n  }\n\n  emitBack() {\n    this.back.emit();\n  }\n\n  ngOnDestroy() {\n    this.destroyed$.next();\n\n    if (this.size === 'fullscreen') {\n      this.renderer.setStyle(document.documentElement, 'overflowY', this.oldOverflow);\n    }\n\n    if (this.overlayRef) {\n      this.overlayRef.dispose();\n    }\n  }\n\n  async closeModal(closeLocation: ModalCloseClickLocation | boolean) {\n    if (!this.canModalBeClosed || (await this.canModalBeClosed(closeLocation))) {\n      this.open = false;\n      this.overlayRef.detach();\n\n      if (this.size === 'fullscreen') {\n        this.renderer.setStyle(document.documentElement, 'overflowY', this.oldOverflow);\n      }\n\n      this.close.emit(typeof closeLocation === 'boolean' ? ModalCloseClickLocation.Other : closeLocation);\n    }\n  }\n\n  private trapFocusInModal(hostElement: HTMLElement) {\n    this.focusTrap.create(hostElement);\n  }\n}\n","<ng-template cdkPortal>\n  <div\n    *ngIf=\"open\"\n    role=\"dialog\"\n    class=\"lxmodal\"\n    [class.lxmodal--fullscreen]=\"size === 'fullscreen'\"\n    [class.lxmodal--dialog]=\"size === 'dialog'\"\n    [class.lxmodal--dialog-large]=\"size === 'dialog-large'\"\n    [class.lxmodal--withFooter]=\"!!footer\"\n    [class.lxmodal--verticalScroll]=\"verticalScroll\"\n    @modal\n  >\n    <div\n      *ngIf=\"size === 'fullscreen' && showBackButton\"\n      (click)=\"emitBack()\"\n      (keyup.enter)=\"emitBack()\"\n      tabindex=\"0\"\n      role=\"button\"\n      class=\"fal fa-long-arrow-left\"\n    ></div>\n    <button\n      *ngIf=\"showCloseButton\"\n      (click)=\"closeModal(closeLocation.CloseButton)\"\n      [attr.aria-label]=\"NAME + '.close' | translate\"\n      class=\"fal fa-times closeButton\"\n    ></button>\n    <ng-content *ngIf=\"header\" select=\"lx-modal-header\" />\n    <div class=\"modalContentContainer\" [class.lxThinScrollbar]=\"verticalScroll\">\n      <ng-container *ngTemplateOutlet=\"content\" />\n    </div>\n    <ng-content *ngIf=\"footer\" select=\"lx-modal-footer\" />\n  </div>\n</ng-template>\n<ng-template #implicitContent>\n  <ng-content />\n</ng-template>\n"]}
|
264
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/src/lib/modal-ui/components/modal/modal.component.ts","../../../../../../../../libs/components/src/lib/modal-ui/components/modal/modal.component.html"],"names":[],"mappings":"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","sourcesContent":["import { animate, style, transition, trigger } from '@angular/animations';\nimport { ConfigurableFocusTrapFactory } from '@angular/cdk/a11y';\nimport { Overlay, OverlayRef } from '@angular/cdk/overlay';\nimport { CdkPortal, Portal, PortalModule } from '@angular/cdk/portal';\nimport { NgIf, NgTemplateOutlet } from '@angular/common';\nimport {\n  AfterViewInit,\n  Component,\n  ContentChild,\n  EventEmitter,\n  HostListener,\n  Inject,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  Renderer2,\n  TemplateRef,\n  ViewChild\n} from '@angular/core';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { Observable, Subject, timer } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { ModalContentDirective } from '../../directives/modal-content.directive';\nimport { MODAL_CLOSE, ModalCloseClickLocation } from '../../modal.constants';\nimport { ModalFooterComponent } from '../modal-footer/modal-footer.component';\nimport { ModalHeaderComponent } from '../modal-header/modal-header.component';\n\n/**\n * This documentation provides details on the usage and configuration of the Modal.\n *\n * ## Usage\n *\n * 1. Import `LxModalModule` and `LxCoreUiModule` modules from `@leanix/components` in your module where you want to use the component.\n *\n * ```ts\n * import { LxModalModule, LxCoreUiModule } from '@leanix/components';\n * ```\n *\n * 2. Use the **lx-modal** component in your template with the parameters described below.\n *\n * - **`open`**: Whether the modal is open or closed.\n * - **`size`**: 'dialog' | 'dialog-large'.\n * - **`verticalScroll`**: Whether the modal is scrollable or not.\n * - **`showHeader`**: Whether the modal has a header or not.\n * - **`showFooter`**: Whether the modal has a footer or not.\n * - **`showCloseButton`**: Whether to show the close button.\n * - **`showBackButton`**: Whether to show the back button.\n *\n * 3. Use optional **lx-modal-header** component in your template with the parameters described below.\n *\n * - **`title`**: Title of the modal.\n * - **`subtitle`**: Subtitle of the modal.\n * - **`bottomBorder`**: Whether to show a bottom border.\n *\n * 4. Use optional **lx-modal-footer** component in your template with the parameters described below.\n *\n * - **`border`**: Whether to show the footer at the bottom of the modal.\n *\n * **GLOBAL PROVIDERS** required for this component:\n * - `provideAnimations()`\n *\n * **ATTENTION - SCROLLABLE DIALOG**:\n * The <lx-modal> component when used as \"dialog\" is not designed to work with a\n * scrollable body (via `overflow: auto | scroll`) in combination with dropdowns.\n * The overflow on the body will also clip the dropdowns, which is expected.\n *\n * Reasoning:\n * The contents within the dialog should be just a few elements which fit and\n * justify the usage of a dialog. If the content is larger than the dialog, and thus\n * requires scrolling, we should discuss whether to put it into a dialog at all\n * and rather think about putting the content on a separate route or\n * using the fullscreen version of the modal.\n */\n@Component({\n  selector: 'lx-modal',\n  templateUrl: 'modal.component.html',\n  styleUrls: ['modal.component.scss'],\n  animations: [\n    trigger('modal', [\n      transition(':enter', [style({ opacity: 0 }), animate('0.15s', style({ opacity: 1 }))]),\n      transition(':leave', animate('0.15s', style({ opacity: 0 })))\n    ])\n  ],\n  standalone: true,\n  imports: [PortalModule, NgIf, NgTemplateOutlet, TranslateModule]\n})\nexport class ModalComponent implements OnChanges, OnInit, OnDestroy, AfterViewInit {\n  /** @internal */\n  readonly NAME = 'ModalComponent';\n  /** Whether the modal is open or closed. */\n  @Input() open: boolean = false;\n  /** Whether to show the close button. */\n  @Input() showCloseButton = true;\n  /** Whether to show the back button. */\n  @Input() showBackButton = false;\n  /*\n   * If true, then the content area scrolls vertically instead of expanding its height.\n   * This can be a problem if the content has dropdowns or date inputs, but can be good if the content has a huge amount of text.\n   */\n  @Input() verticalScroll = false;\n  /** The size of the modal. */\n  @Input() size: 'fullscreen' | 'dialog-large' | 'dialog' = 'fullscreen';\n  /**\n   * Minimum width of the modal.\n   *\n   * _NB: Some modal implementations rely on this minWidth being 600px_\n   */\n  @Input() minWidth: string = '600px';\n  /** Whether the modal is a focus trap. */\n  @Input() isFocusTrap: boolean = false;\n  /** Function to check if the modal can be closed. */\n  @Input() canModalBeClosed?: (closeLocation: ModalCloseClickLocation | boolean) => Promise<boolean>;\n  /** Event emitted when the modal is closed. */\n  @Output() close = new EventEmitter<ModalCloseClickLocation>();\n  /** Event emitted when the back button is clicked. */\n  @Output() back = new EventEmitter<void>();\n\n  /** @internal */\n  @ContentChild(ModalHeaderComponent) header?: ModalHeaderComponent;\n  /** @internal */\n  @ContentChild(ModalFooterComponent) footer?: ModalFooterComponent;\n  /** @internal */\n  @ViewChild(CdkPortal, { static: true }) cdkPortal!: Portal<CdkPortal>;\n  private overlayRef!: OverlayRef;\n  private oldOverflow?: string;\n  /** @internal */\n  closeLocation = ModalCloseClickLocation;\n\n  /** @internal */\n  readonly destroyed$ = new Subject<void>();\n\n  /** @internal */\n  @ViewChild('implicitContent', { static: true }) implicitContent!: TemplateRef<any>;\n\n  /** @internal */\n  @ContentChild(ModalContentDirective, { read: TemplateRef, static: true }) explicitContent?: TemplateRef<any>;\n\n  get content() {\n    return this.explicitContent || this.implicitContent;\n  }\n\n  /** @internal */\n  @HostListener('document:keydown.escape') onEscape() {\n    if (this.open && this.showCloseButton) {\n      this.closeModal(ModalCloseClickLocation.Escape);\n    }\n  }\n\n  constructor(\n    private overlay: Overlay,\n    private renderer: Renderer2,\n    @Optional() @Inject(MODAL_CLOSE) private closeModal$: Observable<ModalCloseClickLocation | boolean>,\n    private focusTrap: ConfigurableFocusTrapFactory\n  ) {}\n\n  ngOnInit() {\n    this.closeModal$\n      ?.pipe(takeUntil(this.destroyed$))\n      .subscribe((closeLocation: ModalCloseClickLocation | boolean) => this.closeModal(closeLocation));\n\n    if (this.size === 'fullscreen') {\n      this.overlayRef = this.overlay.create({\n        panelClass: this.size,\n        width: '100%',\n        height: '100vh'\n      });\n    } else if (this.size === 'dialog-large') {\n      const positionStrategy = this.overlay.position().global().top('4vh').centerHorizontally();\n      this.overlayRef = this.overlay.create({\n        panelClass: this.size,\n        positionStrategy,\n        hasBackdrop: true,\n        width: '90%',\n        height: '90vh'\n      });\n    } else {\n      // size 'dialog'\n      const positionStrategy = this.overlay.position().global().top('8vh').centerHorizontally();\n      this.overlayRef = this.overlay.create({\n        panelClass: this.size,\n        minWidth: this.minWidth,\n        positionStrategy,\n        hasBackdrop: true,\n        scrollStrategy: this.overlay.scrollStrategies.block()\n      });\n    }\n\n    if (this.size !== 'fullscreen') {\n      this.overlayRef\n        .backdropClick()\n        .pipe(takeUntil(this.destroyed$))\n        .subscribe(() => this.closeModal(ModalCloseClickLocation.OutsideClick));\n    }\n  }\n\n  ngOnChanges() {\n    if (this.open && this.overlayRef && !this.overlayRef.hasAttached()) {\n      this.openModal();\n    }\n    if (!this.open && this.overlayRef && this.overlayRef.hasAttached()) {\n      this.closeModal(ModalCloseClickLocation.Other);\n    }\n    if (this.open && this.overlayRef && this.overlayRef.hasAttached() && this.isFocusTrap) {\n      this.trapFocusInModal(this.overlayRef.hostElement);\n    }\n  }\n\n  ngAfterViewInit() {\n    if (this.open) {\n      timer(0)\n        .pipe(takeUntil(this.destroyed$))\n        .subscribe(() => this.openModal());\n    }\n  }\n\n  /** @internal */\n  openModal() {\n    this.oldOverflow = document.documentElement.style.overflowY;\n    if (this.size === 'fullscreen') {\n      this.renderer.setStyle(document.documentElement, 'overflowY', 'hidden');\n    }\n\n    this.overlayRef.attach(this.cdkPortal);\n    this.trapFocusInModal(this.overlayRef.hostElement);\n  }\n\n  /** @internal */\n  emitBack() {\n    this.back.emit();\n  }\n\n  ngOnDestroy() {\n    this.destroyed$.next();\n\n    if (this.size === 'fullscreen') {\n      this.renderer.setStyle(document.documentElement, 'overflowY', this.oldOverflow);\n    }\n\n    if (this.overlayRef) {\n      this.overlayRef.dispose();\n    }\n  }\n\n  /** @internal */\n  async closeModal(closeLocation: ModalCloseClickLocation | boolean) {\n    if (!this.canModalBeClosed || (await this.canModalBeClosed(closeLocation))) {\n      this.open = false;\n      this.overlayRef.detach();\n\n      if (this.size === 'fullscreen') {\n        this.renderer.setStyle(document.documentElement, 'overflowY', this.oldOverflow);\n      }\n\n      this.close.emit(typeof closeLocation === 'boolean' ? ModalCloseClickLocation.Other : closeLocation);\n    }\n  }\n\n  private trapFocusInModal(hostElement: HTMLElement) {\n    this.focusTrap.create(hostElement);\n  }\n}\n","<ng-template cdkPortal>\n  <div\n    *ngIf=\"open\"\n    role=\"dialog\"\n    class=\"lxmodal\"\n    [class.lxmodal--fullscreen]=\"size === 'fullscreen'\"\n    [class.lxmodal--dialog]=\"size === 'dialog'\"\n    [class.lxmodal--dialog-large]=\"size === 'dialog-large'\"\n    [class.lxmodal--withFooter]=\"!!footer\"\n    [class.lxmodal--verticalScroll]=\"verticalScroll\"\n    @modal\n  >\n    <div\n      *ngIf=\"size === 'fullscreen' && showBackButton\"\n      (click)=\"emitBack()\"\n      (keyup.enter)=\"emitBack()\"\n      tabindex=\"0\"\n      role=\"button\"\n      class=\"fal fa-long-arrow-left\"\n    ></div>\n    <button\n      *ngIf=\"showCloseButton\"\n      (click)=\"closeModal(closeLocation.CloseButton)\"\n      [attr.aria-label]=\"NAME + '.close' | translate\"\n      class=\"fal fa-times closeButton\"\n    ></button>\n    <ng-content *ngIf=\"header\" select=\"lx-modal-header\" />\n    <div class=\"modalContentContainer\" [class.lxThinScrollbar]=\"verticalScroll\">\n      <ng-container *ngTemplateOutlet=\"content\" />\n    </div>\n    <ng-content *ngIf=\"footer\" select=\"lx-modal-footer\" />\n  </div>\n</ng-template>\n<ng-template #implicitContent>\n  <ng-content />\n</ng-template>\n"]}
|
@@ -5,7 +5,15 @@ import { PopoverContentDirective } from '../../directives/popover-content.direct
|
|
5
5
|
import * as i0 from "@angular/core";
|
6
6
|
import * as i1 from "@ncstate/sat-popover";
|
7
7
|
/**
|
8
|
-
*
|
8
|
+
* The Popover component is based on the [ncstate-sat/popover](https://github.com/ncstate-sat/popover) library.
|
9
|
+
*
|
10
|
+
* ## Usage
|
11
|
+
*
|
12
|
+
* 1. Import `LxPopoverUiModule` and `LxCoreUiModule` module from `@leanix/components` in your module where you want to use the component.
|
13
|
+
*
|
14
|
+
* ```ts
|
15
|
+
* import { LxPopoverUiModule, LxCoreUiModule } from '@leanix/components';
|
16
|
+
* ```
|
9
17
|
*
|
10
18
|
* This popover encapsulates this open source library: https://github.com/ncstate-sat/popover,
|
11
19
|
* make sure to also check out the docs over there.
|
@@ -16,7 +24,8 @@ import * as i1 from "@ncstate/sat-popover";
|
|
16
24
|
*
|
17
25
|
* For use case 1. you would use the lxPopoverHover directive, which exports as hoverAnchor.
|
18
26
|
*
|
19
|
-
* Example:
|
27
|
+
* ### Example:
|
28
|
+
* ```html
|
20
29
|
* <div lxPopoverHover
|
21
30
|
* hoverAnchor
|
22
31
|
* satPopoverAnchor
|
@@ -26,13 +35,15 @@ import * as i1 from "@ncstate/sat-popover";
|
|
26
35
|
* verticalAlign="center">
|
27
36
|
* <p>Popover content</p>
|
28
37
|
* </lx-popover>
|
38
|
+
* ```
|
29
39
|
*
|
30
40
|
* For use case 2. you would use the lxPopoverClick directive, which exports as clickAnchor.
|
31
41
|
* Note: Since the only component where we use the lxPopoverClick directive (ReportComponent)
|
32
42
|
* needs to fetch some data before opening it, we do not register a click EventListener in this directive,
|
33
43
|
* but require the developer to implement that in the component, where the popover is used.
|
34
44
|
*
|
35
|
-
* Example:
|
45
|
+
* ### Example:
|
46
|
+
* ```html
|
36
47
|
* <div lxPopoverClick
|
37
48
|
* clickAnchor
|
38
49
|
* satPopoverAnchor
|
@@ -44,21 +55,28 @@ import * as i1 from "@ncstate/sat-popover";
|
|
44
55
|
* #popover>
|
45
56
|
* <p>Popover content</p>
|
46
57
|
* </lx-popover>
|
58
|
+
* ```
|
47
59
|
*
|
48
60
|
* If this component is used with angularCompilerOptions strictTemplates=true,
|
49
61
|
* satPopoverAnchor must be set to the reference to the SatPopover inside lx-popover.
|
50
62
|
*
|
51
|
-
* Example:
|
52
|
-
*
|
63
|
+
* ### Example:
|
64
|
+
* ```html
|
65
|
+
* <div [satPopoverAnchor]="popover.satPopover"></div>
|
53
66
|
* <lx-popover #popover>
|
54
67
|
* <p>Popover content</p>
|
55
68
|
* </lx-popover>
|
69
|
+
* ```
|
56
70
|
*/
|
57
71
|
export class PopoverComponent {
|
58
72
|
constructor() {
|
73
|
+
/** Whether to apply margins. */
|
59
74
|
this.noMargin = false;
|
75
|
+
/** Whether to allow the popover to overflow the viewport. */
|
60
76
|
this.allowOverflow = false;
|
77
|
+
/** Whether to focus the first focusable element in the popover when it is opened. */
|
61
78
|
this.autoFocus = false;
|
79
|
+
/** Whether to restore focus to the previously-focused element when the popover is closed. */
|
62
80
|
this.restoreFocus = true;
|
63
81
|
/**
|
64
82
|
* If you have a popover, that should usually be displayed above or below its anchor,
|
@@ -69,7 +87,9 @@ export class PopoverComponent {
|
|
69
87
|
* position of the popover after opening.
|
70
88
|
*/
|
71
89
|
this.adaptMarginsForViewportAlignChange = false;
|
90
|
+
/** Event emitted when the popover is opened. */
|
72
91
|
this.opened = new EventEmitter();
|
92
|
+
/** Event emitted when the popover is closed. */
|
73
93
|
this.closed = new EventEmitter();
|
74
94
|
this._isOpen = false;
|
75
95
|
}
|
@@ -84,21 +104,26 @@ export class PopoverComponent {
|
|
84
104
|
this.marginClasses = this.getDefaultMarginClasses(this.horizontalAlign, this.verticalAlign);
|
85
105
|
}
|
86
106
|
}
|
107
|
+
/** @internal */
|
87
108
|
open() {
|
88
109
|
this.satPopover.open();
|
89
110
|
}
|
111
|
+
/** @internal */
|
90
112
|
close() {
|
91
113
|
this.satPopover.close();
|
92
114
|
}
|
115
|
+
/** @internal */
|
93
116
|
onOpen() {
|
94
117
|
this._isOpen = true;
|
95
118
|
this.opened.emit();
|
96
119
|
}
|
120
|
+
/** @internal */
|
97
121
|
onAfterOpen() {
|
98
122
|
if (this.adaptMarginsForViewportAlignChange) {
|
99
123
|
this.marginClasses = this.getMarginClassesForClassList(this.satPopover._classList);
|
100
124
|
}
|
101
125
|
}
|
126
|
+
/** @internal */
|
102
127
|
onClose() {
|
103
128
|
this._isOpen = false;
|
104
129
|
this.closed.emit();
|
@@ -202,4 +227,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
|
|
202
227
|
type: ContentChild,
|
203
228
|
args: [PopoverContentDirective, { read: TemplateRef, static: true }]
|
204
229
|
}] } });
|
205
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/src/lib/popover-ui/components/popover/popover.component.ts","../../../../../../../../libs/components/src/lib/popover-ui/components/popover/popover.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgClass, NgIf, NgTemplateOutlet } from '@angular/common';\nimport { Component, ContentChild, EventEmitter, Input, OnChanges, Output, SimpleChanges, TemplateRef, ViewChild } from '@angular/core';\nimport { SatPopoverComponent, SatPopoverHorizontalAlign, SatPopoverModule, SatPopoverVerticalAlign } from '@ncstate/sat-popover';\nimport { PopoverContentDirective } from '../../directives/popover-content.directive';\nimport { PopoverTriggerDirective } from '../../directives/popover-hover.directive';\n\n/**\n * HOW TO USE\n *\n * This popover encapsulates this open source library: https://github.com/ncstate-sat/popover,\n * make sure to also check out the docs over there.\n *\n * As of today they are two trigger strategies to display a popover.\n * 1. Show on hovering the anchor and while hovering the popover body.\n * 2. Show on click and while hovering the popover body.\n *\n * For use case 1. you would use the lxPopoverHover directive, which exports as hoverAnchor.\n *\n * Example:\n * <div lxPopoverHover\n *      hoverAnchor\n *      satPopoverAnchor\n *      #anchor=\"hoverAnchor\"></div>\n * <lx-popover [trigger]=\"anchor\"\n *             horizontalAlign=\"after\"\n *             verticalAlign=\"center\">\n *    <p>Popover content</p>\n * </lx-popover>\n *\n * For use case 2. you would use the lxPopoverClick directive, which exports as clickAnchor.\n * Note: Since the only component where we use the lxPopoverClick directive (ReportComponent)\n * needs to fetch some data before opening it, we do not register a click EventListener in this directive,\n * but require the developer to implement that in the component, where the popover is used.\n *\n * Example:\n * <div lxPopoverClick\n *      clickAnchor\n *      satPopoverAnchor\n *      #anchor=\"clickAnchor\"\n *      (click)=\"popover.open()\">Click Me!</div>\n * <lx-popover [trigger]=\"anchor\"\n *             horizontalAlign=\"after\"\n *             verticalAlign=\"center\"\n *             #popover>\n *    <p>Popover content</p>\n * </lx-popover>\n *\n * If this component is used with angularCompilerOptions strictTemplates=true,\n * satPopoverAnchor must be set to the reference to the SatPopover inside lx-popover.\n *\n * Example:\n *  <div [satPopoverAnchor]=\"popover.satPopover\"></div>\n * <lx-popover #popover>\n *    <p>Popover content</p>\n * </lx-popover>\n */\n@Component({\n  selector: 'lx-popover',\n  templateUrl: 'popover.component.html',\n  styleUrls: ['popover.component.scss'],\n  standalone: true,\n  imports: [SatPopoverModule, NgClass, NgIf, NgTemplateOutlet]\n})\nexport class PopoverComponent implements OnChanges {\n  @Input() trigger!: PopoverTriggerDirective;\n  @Input() horizontalAlign!: SatPopoverHorizontalAlign;\n  @Input() verticalAlign!: SatPopoverVerticalAlign;\n  @Input() noMargin = false;\n  @Input() allowOverflow = false;\n  @Input() autoFocus = false;\n  @Input() restoreFocus = true;\n\n  /**\n   * If you have a popover, that should usually be displayed above or below its anchor,\n   * and this anchor is in a scrollable container, you should set this to true.\n   * SatPopover will open this popover in the direction where there is enough space,\n   * so its position might differ from the horizontalAlign and verticalAlign values.\n   * In this case we rely on the SatPopover::_classList property to get the computed\n   * position of the popover after opening.\n   */\n  @Input() adaptMarginsForViewportAlignChange = false;\n\n  @Output() opened = new EventEmitter<void>();\n  @Output() closed = new EventEmitter<void>();\n\n  @ViewChild(SatPopoverComponent, { static: true }) satPopover!: SatPopoverComponent;\n  @ViewChild('implicitContent', { static: true }) implicitContent!: TemplateRef<any>;\n\n  @ContentChild(PopoverContentDirective, { read: TemplateRef, static: true }) explicitContent?: TemplateRef<any>;\n\n  marginClasses!: string;\n\n  get content() {\n    return this.explicitContent || this.implicitContent;\n  }\n\n  get isOpen() {\n    return this._isOpen;\n  }\n  private _isOpen = false;\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['horizontalAlign'] && changes['verticalAlign']) {\n      this.marginClasses = this.getDefaultMarginClasses(this.horizontalAlign, this.verticalAlign);\n    }\n  }\n\n  open() {\n    this.satPopover.open();\n  }\n\n  close() {\n    this.satPopover.close();\n  }\n\n  onOpen() {\n    this._isOpen = true;\n    this.opened.emit();\n  }\n\n  onAfterOpen() {\n    if (this.adaptMarginsForViewportAlignChange) {\n      this.marginClasses = this.getMarginClassesForClassList(this.satPopover._classList);\n    }\n  }\n\n  onClose() {\n    this._isOpen = false;\n    this.closed.emit();\n  }\n\n  /**\n   * SatPopover::_classList will contain a map of alignment CSS classes, once the popover was opened.\n   * These alignment classes can be different from what you would expect from the horizontal- and verticalAlign inputs,\n   * because there might not be enough space above the anchor to meet the verticalAlign='above' criteria,\n   * so it will be displayed below the anchor instead.\n   */\n  private getMarginClassesForClassList(satPopoverClassList: { [className: string]: boolean }): string {\n    if (this.noMargin) {\n      return '';\n    }\n\n    if (satPopoverClassList['sat-popover-above']) {\n      return this.marginClasses.includes('top') ? this.marginClasses : 'top';\n    }\n\n    if (satPopoverClassList['sat-popover-below']) {\n      return this.marginClasses.includes('bottom') ? this.marginClasses : 'bottom';\n    }\n\n    if (satPopoverClassList['sat-popover-before']) {\n      return this.marginClasses.includes('left') ? this.marginClasses : 'left';\n    }\n\n    if (satPopoverClassList['sat-popover-after']) {\n      return this.marginClasses.includes('right') ? this.marginClasses : 'right';\n    }\n\n    if (satPopoverClassList['sat-popover-center']) {\n      return '';\n    }\n    return '';\n  }\n\n  private getDefaultMarginClasses(horizontalAlign: SatPopoverHorizontalAlign, verticalAlign: SatPopoverVerticalAlign): string {\n    if (this.noMargin) {\n      return '';\n    }\n\n    if (horizontalAlign === 'after') {\n      if (verticalAlign === 'center' || verticalAlign === 'start' || verticalAlign === 'end') {\n        return 'right';\n      } else if (verticalAlign === 'above') {\n        return 'right top';\n      } else if (verticalAlign === 'below') {\n        return 'right bottom';\n      }\n    }\n\n    if (horizontalAlign === 'before') {\n      if (verticalAlign === 'center' || verticalAlign === 'start' || verticalAlign === 'end') {\n        return 'left';\n      } else if (verticalAlign === 'above') {\n        return 'left top';\n      } else if (verticalAlign === 'below') {\n        return 'left bottom';\n      }\n    }\n\n    if (horizontalAlign === 'center' || horizontalAlign === 'start' || horizontalAlign === 'end') {\n      if (verticalAlign === 'above') {\n        return 'top';\n      } else if (verticalAlign === 'below') {\n        return 'bottom';\n      }\n    }\n    return '';\n  }\n}\n","<sat-popover\n  [anchor]=\"trigger.anchor\"\n  [horizontalAlign]=\"horizontalAlign\"\n  [verticalAlign]=\"verticalAlign\"\n  [restoreFocus]=\"restoreFocus\"\n  [lockAlignment]=\"true\"\n  [autoFocus]=\"autoFocus\"\n  openTransition=\"0ms\"\n  closeTransition=\"0ms\"\n  (opened)=\"onOpen()\"\n  (afterOpen)=\"onAfterOpen()\"\n  (closed)=\"onClose()\"\n>\n  <div\n    class=\"popoverContainer\"\n    [ngClass]=\"marginClasses\"\n    [class.overflowHidden]=\"!allowOverflow\"\n    (mouseenter)=\"trigger.showPopover(true)\"\n    (mouseleave)=\"trigger.closePopover(true)\"\n    (keydown.escape)=\"$event.stopPropagation(); trigger.closePopover(true)\"\n  >\n    <ng-container *ngIf=\"isOpen\">\n      <ng-container *ngTemplateOutlet=\"content\" />\n    </ng-container>\n  </div>\n</sat-popover>\n<ng-template #implicitContent>\n  <ng-content />\n</ng-template>\n"]}
|
230
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/src/lib/popover-ui/components/popover/popover.component.ts","../../../../../../../../libs/components/src/lib/popover-ui/components/popover/popover.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgClass, NgIf, NgTemplateOutlet } from '@angular/common';\nimport { Component, ContentChild, EventEmitter, Input, OnChanges, Output, SimpleChanges, TemplateRef, ViewChild } from '@angular/core';\nimport { SatPopoverComponent, SatPopoverHorizontalAlign, SatPopoverModule, SatPopoverVerticalAlign } from '@ncstate/sat-popover';\nimport { PopoverContentDirective } from '../../directives/popover-content.directive';\nimport { PopoverTriggerDirective } from '../../directives/popover-hover.directive';\n\n/**\n * The Popover component is based on the [ncstate-sat/popover](https://github.com/ncstate-sat/popover) library.\n *\n * ## Usage\n *\n * 1. Import `LxPopoverUiModule` and `LxCoreUiModule` module from `@leanix/components` in your module where you want to use the component.\n *\n * ```ts\n * import { LxPopoverUiModule, LxCoreUiModule } from '@leanix/components';\n * ```\n *\n * This popover encapsulates this open source library: https://github.com/ncstate-sat/popover,\n * make sure to also check out the docs over there.\n *\n * As of today they are two trigger strategies to display a popover.\n * 1. Show on hovering the anchor and while hovering the popover body.\n * 2. Show on click and while hovering the popover body.\n *\n * For use case 1. you would use the lxPopoverHover directive, which exports as hoverAnchor.\n *\n * ### Example:\n * ```html\n * <div lxPopoverHover\n *      hoverAnchor\n *      satPopoverAnchor\n *      #anchor=\"hoverAnchor\"></div>\n * <lx-popover [trigger]=\"anchor\"\n *             horizontalAlign=\"after\"\n *             verticalAlign=\"center\">\n *    <p>Popover content</p>\n * </lx-popover>\n * ```\n *\n * For use case 2. you would use the lxPopoverClick directive, which exports as clickAnchor.\n * Note: Since the only component where we use the lxPopoverClick directive (ReportComponent)\n * needs to fetch some data before opening it, we do not register a click EventListener in this directive,\n * but require the developer to implement that in the component, where the popover is used.\n *\n * ### Example:\n * ```html\n * <div lxPopoverClick\n *      clickAnchor\n *      satPopoverAnchor\n *      #anchor=\"clickAnchor\"\n *      (click)=\"popover.open()\">Click Me!</div>\n * <lx-popover [trigger]=\"anchor\"\n *             horizontalAlign=\"after\"\n *             verticalAlign=\"center\"\n *             #popover>\n *    <p>Popover content</p>\n * </lx-popover>\n * ```\n *\n * If this component is used with angularCompilerOptions strictTemplates=true,\n * satPopoverAnchor must be set to the reference to the SatPopover inside lx-popover.\n *\n * ### Example:\n * ```html\n * <div [satPopoverAnchor]=\"popover.satPopover\"></div>\n * <lx-popover #popover>\n *    <p>Popover content</p>\n * </lx-popover>\n * ```\n */\n@Component({\n  selector: 'lx-popover',\n  templateUrl: 'popover.component.html',\n  styleUrls: ['popover.component.scss'],\n  standalone: true,\n  imports: [SatPopoverModule, NgClass, NgIf, NgTemplateOutlet]\n})\nexport class PopoverComponent implements OnChanges {\n  /** The trigger directive that will open the popover. This is also the anchor for the popover. */\n  @Input() trigger!: PopoverTriggerDirective;\n  /** The horizontal alignment of the popover (`center` by default). */\n  @Input() horizontalAlign!: SatPopoverHorizontalAlign;\n  /** The vertical alignment of the popover (`above` by default). */\n  @Input() verticalAlign!: SatPopoverVerticalAlign;\n  /** Whether to apply margins. */\n  @Input() noMargin = false;\n  /** Whether to allow the popover to overflow the viewport. */\n  @Input() allowOverflow = false;\n  /** Whether to focus the first focusable element in the popover when it is opened. */\n  @Input() autoFocus = false;\n  /** Whether to restore focus to the previously-focused element when the popover is closed. */\n  @Input() restoreFocus = true;\n  /**\n   * If you have a popover, that should usually be displayed above or below its anchor,\n   * and this anchor is in a scrollable container, you should set this to true.\n   * SatPopover will open this popover in the direction where there is enough space,\n   * so its position might differ from the horizontalAlign and verticalAlign values.\n   * In this case we rely on the SatPopover::_classList property to get the computed\n   * position of the popover after opening.\n   */\n  @Input() adaptMarginsForViewportAlignChange = false;\n\n  /** Event emitted when the popover is opened. */\n  @Output() opened = new EventEmitter<void>();\n  /** Event emitted when the popover is closed. */\n  @Output() closed = new EventEmitter<void>();\n\n  /** @internal */\n  @ViewChild(SatPopoverComponent, { static: true }) satPopover!: SatPopoverComponent;\n  /** @internal */\n  @ViewChild('implicitContent', { static: true }) implicitContent!: TemplateRef<any>;\n\n  /** @internal */\n  @ContentChild(PopoverContentDirective, { read: TemplateRef, static: true }) explicitContent?: TemplateRef<any>;\n\n  /** @internal */\n  marginClasses!: string;\n\n  get content() {\n    return this.explicitContent || this.implicitContent;\n  }\n\n  get isOpen() {\n    return this._isOpen;\n  }\n  private _isOpen = false;\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['horizontalAlign'] && changes['verticalAlign']) {\n      this.marginClasses = this.getDefaultMarginClasses(this.horizontalAlign, this.verticalAlign);\n    }\n  }\n\n  /** @internal */\n  open() {\n    this.satPopover.open();\n  }\n\n  /** @internal */\n  close() {\n    this.satPopover.close();\n  }\n\n  /** @internal */\n  onOpen() {\n    this._isOpen = true;\n    this.opened.emit();\n  }\n\n  /** @internal */\n  onAfterOpen() {\n    if (this.adaptMarginsForViewportAlignChange) {\n      this.marginClasses = this.getMarginClassesForClassList(this.satPopover._classList);\n    }\n  }\n\n  /** @internal */\n  onClose() {\n    this._isOpen = false;\n    this.closed.emit();\n  }\n\n  /**\n   * SatPopover::_classList will contain a map of alignment CSS classes, once the popover was opened.\n   * These alignment classes can be different from what you would expect from the horizontal- and verticalAlign inputs,\n   * because there might not be enough space above the anchor to meet the verticalAlign='above' criteria,\n   * so it will be displayed below the anchor instead.\n   */\n  private getMarginClassesForClassList(satPopoverClassList: { [className: string]: boolean }): string {\n    if (this.noMargin) {\n      return '';\n    }\n\n    if (satPopoverClassList['sat-popover-above']) {\n      return this.marginClasses.includes('top') ? this.marginClasses : 'top';\n    }\n\n    if (satPopoverClassList['sat-popover-below']) {\n      return this.marginClasses.includes('bottom') ? this.marginClasses : 'bottom';\n    }\n\n    if (satPopoverClassList['sat-popover-before']) {\n      return this.marginClasses.includes('left') ? this.marginClasses : 'left';\n    }\n\n    if (satPopoverClassList['sat-popover-after']) {\n      return this.marginClasses.includes('right') ? this.marginClasses : 'right';\n    }\n\n    if (satPopoverClassList['sat-popover-center']) {\n      return '';\n    }\n    return '';\n  }\n\n  private getDefaultMarginClasses(horizontalAlign: SatPopoverHorizontalAlign, verticalAlign: SatPopoverVerticalAlign): string {\n    if (this.noMargin) {\n      return '';\n    }\n\n    if (horizontalAlign === 'after') {\n      if (verticalAlign === 'center' || verticalAlign === 'start' || verticalAlign === 'end') {\n        return 'right';\n      } else if (verticalAlign === 'above') {\n        return 'right top';\n      } else if (verticalAlign === 'below') {\n        return 'right bottom';\n      }\n    }\n\n    if (horizontalAlign === 'before') {\n      if (verticalAlign === 'center' || verticalAlign === 'start' || verticalAlign === 'end') {\n        return 'left';\n      } else if (verticalAlign === 'above') {\n        return 'left top';\n      } else if (verticalAlign === 'below') {\n        return 'left bottom';\n      }\n    }\n\n    if (horizontalAlign === 'center' || horizontalAlign === 'start' || horizontalAlign === 'end') {\n      if (verticalAlign === 'above') {\n        return 'top';\n      } else if (verticalAlign === 'below') {\n        return 'bottom';\n      }\n    }\n    return '';\n  }\n}\n","<sat-popover\n  [anchor]=\"trigger.anchor\"\n  [horizontalAlign]=\"horizontalAlign\"\n  [verticalAlign]=\"verticalAlign\"\n  [restoreFocus]=\"restoreFocus\"\n  [lockAlignment]=\"true\"\n  [autoFocus]=\"autoFocus\"\n  openTransition=\"0ms\"\n  closeTransition=\"0ms\"\n  (opened)=\"onOpen()\"\n  (afterOpen)=\"onAfterOpen()\"\n  (closed)=\"onClose()\"\n>\n  <div\n    class=\"popoverContainer\"\n    [ngClass]=\"marginClasses\"\n    [class.overflowHidden]=\"!allowOverflow\"\n    (mouseenter)=\"trigger.showPopover(true)\"\n    (mouseleave)=\"trigger.closePopover(true)\"\n    (keydown.escape)=\"$event.stopPropagation(); trigger.closePopover(true)\"\n  >\n    <ng-container *ngIf=\"isOpen\">\n      <ng-container *ngTemplateOutlet=\"content\" />\n    </ng-container>\n  </div>\n</sat-popover>\n<ng-template #implicitContent>\n  <ng-content />\n</ng-template>\n"]}
|