@sebgroup/green-angular 1.8.4 → 1.9.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/context-menu/context-menu.component.mjs +8 -7
- package/esm2020/lib/context-menu/context-menu.constants.mjs +3 -0
- package/esm2020/lib/modal/index.mjs +3 -1
- package/esm2020/lib/modal/modal-footer.directive.mjs +16 -0
- package/esm2020/lib/modal/modal-header.directive.mjs +16 -0
- package/esm2020/lib/modal/modal.component.mjs +22 -5
- package/esm2020/lib/modal/modal.module.mjs +13 -3
- package/fesm2015/sebgroup-green-angular.mjs +66 -12
- package/fesm2015/sebgroup-green-angular.mjs.map +1 -1
- package/fesm2020/sebgroup-green-angular.mjs +66 -12
- package/fesm2020/sebgroup-green-angular.mjs.map +1 -1
- package/lib/context-menu/context-menu.component.d.ts +3 -3
- package/lib/context-menu/context-menu.constants.d.ts +2 -0
- package/lib/modal/index.d.ts +2 -0
- package/lib/modal/modal-footer.directive.d.ts +8 -0
- package/lib/modal/modal-header.directive.d.ts +8 -0
- package/lib/modal/modal.component.d.ts +7 -1
- package/lib/modal/modal.module.d.ts +5 -3
- package/package.json +3 -3
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { ChangeDetectorRef, Component, ElementRef, EventEmitter, HostListener, Inject, Input, Optional, Output, ViewChild, } from '@angular/core';
|
|
2
2
|
import { Subject } from 'rxjs';
|
|
3
3
|
import { ON_SCROLL_TOKEN } from '../shared/on-scroll.directive';
|
|
4
|
+
import { CONTEXT_MENU_LEFT, CONTEXT_MENU_TOP } from './context-menu.constants';
|
|
4
5
|
import * as i0 from "@angular/core";
|
|
5
6
|
import * as i1 from "@angular/common";
|
|
6
7
|
import * as i2 from "rxjs";
|
|
@@ -16,15 +17,14 @@ export class NggContextMenuComponent {
|
|
|
16
17
|
this.closeOnScroll = false;
|
|
17
18
|
this.contextMenuItemClicked = new EventEmitter();
|
|
18
19
|
this.isActive = false;
|
|
19
|
-
this.top =
|
|
20
|
-
this.left =
|
|
20
|
+
this.top = CONTEXT_MENU_TOP;
|
|
21
|
+
this.left = CONTEXT_MENU_LEFT;
|
|
21
22
|
}
|
|
22
23
|
onDocumentClick(target) {
|
|
23
24
|
if (!this.isActive) {
|
|
24
25
|
return;
|
|
25
26
|
}
|
|
26
|
-
|
|
27
|
-
if (!contextMenuElement.contains(target)) {
|
|
27
|
+
if (!this.elementRef.nativeElement.contains(target)) {
|
|
28
28
|
this.close();
|
|
29
29
|
}
|
|
30
30
|
}
|
|
@@ -48,8 +48,7 @@ export class NggContextMenuComponent {
|
|
|
48
48
|
this.close();
|
|
49
49
|
return;
|
|
50
50
|
}
|
|
51
|
-
const
|
|
52
|
-
const buttonRect = anchor.getBoundingClientRect();
|
|
51
|
+
const buttonRect = this.anchor?.nativeElement.getBoundingClientRect();
|
|
53
52
|
const gapBetweenButtonAndPopover = 3;
|
|
54
53
|
const left = this.calculateLeft(this.direction, buttonRect);
|
|
55
54
|
const top = buttonRect.bottom + gapBetweenButtonAndPopover;
|
|
@@ -59,6 +58,8 @@ export class NggContextMenuComponent {
|
|
|
59
58
|
}
|
|
60
59
|
close() {
|
|
61
60
|
this.isActive = false;
|
|
61
|
+
this.top = CONTEXT_MENU_TOP;
|
|
62
|
+
this.left = CONTEXT_MENU_LEFT;
|
|
62
63
|
this.changeDetectorRef.markForCheck();
|
|
63
64
|
}
|
|
64
65
|
onItemClick(item) {
|
|
@@ -124,4 +125,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
124
125
|
type: HostListener,
|
|
125
126
|
args: ['document:click', ['$event.target']]
|
|
126
127
|
}] } });
|
|
127
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"context-menu.component.js","sourceRoot":"","sources":["../../../../../../libs/angular/src/lib/context-menu/context-menu.component.ts","../../../../../../libs/angular/src/lib/context-menu/context-menu.component.html"],"names":[],"mappings":"AAAA,OAAO,EAEL,iBAAiB,EACjB,SAAS,EACT,UAAU,EACV,YAAY,EACZ,YAAY,EACZ,MAAM,EACN,KAAK,EAGL,QAAQ,EACR,MAAM,EAEN,SAAS,GACV,MAAM,eAAe,CAAA;AAEtB,OAAO,EAAE,OAAO,EAAgB,MAAM,MAAM,CAAA;AAC5C,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAA;;;;AAM/D,MAAM,OAAO,uBAAuB;IAuBlC,YACU,iBAAoC,EACpC,UAAsB,EAGvB,gBAA+B;QAJ9B,sBAAiB,GAAjB,iBAAiB,CAAmB;QACpC,eAAU,GAAV,UAAU,CAAY;QAGvB,qBAAgB,GAAhB,gBAAgB,CAAe;QAzB/B,cAAS,GAAkB,KAAK,CAAA;QAChC,cAAS,GAAqB,EAAE,CAAA;QAChC,qBAAgB,GAAgC,IAAI,CAAA;QACpD,uBAAkB,GAAgC,IAAI,CAAA;QACtD,kBAAa,GAAG,KAAK,CAAA;QAEpB,2BAAsB,GAC9B,IAAI,YAAY,EAAkB,CAAA;QAMpC,aAAQ,GAAG,KAAK,CAAA;QAChB,QAAG,GAAG,KAAK,CAAA;QACX,SAAI,GAAG,KAAK,CAAA;IAWT,CAAC;IAGJ,eAAe,CAAC,MAAmB;QACjC,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAClB,OAAM;SACP;QACD,MAAM,kBAAkB,GAAG,IAAI,CAAC,UAAU,CAAC,aAA4B,CAAA;QAEvE,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE;YACxC,IAAI,CAAC,KAAK,EAAE,CAAA;SACb;IACH,CAAC;IAEM,QAAQ;QACb,IAAI,CAAC,cAAc,GAAG,IAAI,cAAc,CAAC,GAAG,EAAE;YAC5C,IAAI,CAAC,KAAK,EAAE,CAAA;QACd,CAAC,CAAC,CAAA;QACF,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAA;IAC5C,CAAC;IAEM,eAAe;QACpB,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,IAAI,CAAC,qBAAqB,GAAG,IAAI,CAAC,gBAAgB,EAAE,SAAS,CAAC,GAAG,EAAE,CACjE,IAAI,CAAC,KAAK,EAAE,CACb,CAAA;SACF;IACH,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,cAAc,EAAE,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAA;QAC7C,IAAI,CAAC,qBAAqB,EAAE,WAAW,EAAE,CAAA;IAC3C,CAAC;IAED,IAAI;QACF,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,IAAI,CAAC,KAAK,EAAE,CAAA;YACZ,OAAM;SACP;QAED,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,EAAE,aAA4B,CAAA;QACxD,MAAM,UAAU,GAAG,MAAM,CAAC,qBAAqB,EAAE,CAAA;QAEjD,MAAM,0BAA0B,GAAG,CAAC,CAAA;QACpC,MAAM,IAAI,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,SAAS,EAAE,UAAU,CAAC,CAAA;QAC3D,MAAM,GAAG,GAAG,UAAU,CAAC,MAAM,GAAG,0BAA0B,CAAC;QAE3D,IAAI,CAAC,IAAI,GAAG,GAAG,IAAI,IAAI,CAAA;QACvB,IAAI,CAAC,GAAG,GAAG,GAAG,GAAG,IAAI,CAAA;QACrB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAA;IACtB,CAAC;IAED,KAAK;QACH,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAA;QACrB,IAAI,CAAC,iBAAiB,CAAC,YAAY,EAAE,CAAA;IACvC,CAAC;IAED,WAAW,CAAC,IAAoB;QAC9B,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;QACtC,IAAI,CAAC,KAAK,EAAE,CAAA;IACd,CAAC;IAED,iBAAiB,CAAC,KAAoB,EAAE,QAAwB;QAC9D,QAAQ,KAAK,CAAC,GAAG,EAAE;YACjB,KAAK,OAAO,CAAC;YACb,KAAK,GAAG;gBACN,KAAK,CAAC,cAAc,EAAE,CAAA;gBACtB,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAA;gBAC1B,MAAK;YACP;gBACE,MAAK;SACR;IACH,CAAC;IAED,aAAa,CAAC,SAAiB,EAAE,UAAmB;QAClD,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,EAAE,aAA4B,CAAA;QAC1D,MAAM,YAAY,GAAG,OAAO,EAAE,WAAW,IAAI,CAAC,CAAA;QAE9C,QAAQ,SAAS,EAAE;YACjB,KAAK,KAAK;gBACR,OAAO,YAAY,IAAI,UAAU,CAAC,IAAI;oBACpC,CAAC,CAAC,UAAU,CAAC,KAAK,GAAG,YAAY;oBACjC,CAAC,CAAC,UAAU,CAAC,IAAI,CAAA;YACrB,KAAK,KAAK,CAAC;YACX;gBACE,OAAO,UAAU,CAAC,KAAK,GAAG,YAAY,IAAI,MAAM,CAAC,UAAU;oBACzD,CAAC,CAAC,UAAU,CAAC,IAAI;oBACjB,CAAC,CAAC,UAAU,CAAC,KAAK,GAAG,YAAY,CAAA;SACtC;IACH,CAAC;;oHAtHU,uBAAuB,6EA2BxB,eAAe;wGA3Bd,uBAAuB,6jBCxBpC,onCA4CA;2FDpBa,uBAAuB;kBAJnC,SAAS;+BACE,kBAAkB;;0BA6BzB,QAAQ;;0BACR,MAAM;2BAAC,eAAe;4CAxBhB,SAAS;sBAAjB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBACG,kBAAkB;sBAA1B,KAAK;gBACG,aAAa;sBAArB,KAAK;gBAEI,sBAAsB;sBAA/B,MAAM;gBAG0B,OAAO;sBAAvC,SAAS;uBAAC,oBAAoB;gBAEC,MAAM;sBAArC,SAAS;uBAAC,mBAAmB;gBAkB9B,eAAe;sBADd,YAAY;uBAAC,gBAAgB,EAAE,CAAC,eAAe,CAAC","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  Inject,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core'\nimport { DropdownOption } from '@sebgroup/extract'\nimport { Subject, Subscription } from 'rxjs'\nimport { ON_SCROLL_TOKEN } from '../shared/on-scroll.directive'\n\n@Component({\n  selector: 'ngg-context-menu',\n  templateUrl: './context-menu.component.html',\n})\nexport class NggContextMenuComponent\n  implements AfterViewInit, OnDestroy, OnInit\n{\n  @Input() direction: 'ltr' | 'rtl' = 'ltr'\n  @Input() menuItems: DropdownOption[] = []\n  @Input() menuItemTemplate: TemplateRef<unknown> | null = null\n  @Input() menuAnchorTemplate: TemplateRef<unknown> | null = null\n  @Input() closeOnScroll = false\n\n  @Output() contextMenuItemClicked: EventEmitter<DropdownOption> =\n    new EventEmitter<DropdownOption>()\n\n  @ViewChild('contextMenuPopover') popover: ElementRef | undefined\n\n  @ViewChild('contextMenuAnchor') anchor: ElementRef | undefined\n\n  isActive = false\n  top = '0px'\n  left = '0px'\n\n  resizeObserver?: ResizeObserver\n  menuCloseSubscription?: Subscription\n\n  constructor(\n    private changeDetectorRef: ChangeDetectorRef,\n    private elementRef: ElementRef,\n    @Optional()\n    @Inject(ON_SCROLL_TOKEN)\n    public closeContextMenu: Subject<void>\n  ) {}\n\n  @HostListener('document:click', ['$event.target'])\n  onDocumentClick(target: HTMLElement): void {\n    if (!this.isActive) {\n      return\n    }\n    const contextMenuElement = this.elementRef.nativeElement as HTMLElement\n\n    if (!contextMenuElement.contains(target)) {\n      this.close()\n    }\n  }\n\n  public ngOnInit(): void {\n    this.resizeObserver = new ResizeObserver(() => {\n      this.close()\n    })\n    this.resizeObserver.observe(document.body)\n  }\n\n  public ngAfterViewInit(): void {\n    if (this.closeOnScroll) {\n      this.menuCloseSubscription = this.closeContextMenu?.subscribe(() =>\n        this.close()\n      )\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.resizeObserver?.unobserve(document.body)\n    this.menuCloseSubscription?.unsubscribe()\n  }\n\n  open(): void {\n    if (this.isActive) {\n      this.close()\n      return\n    }\n\n    const anchor = this.anchor?.nativeElement as HTMLElement\n    const buttonRect = anchor.getBoundingClientRect()\n\n    const gapBetweenButtonAndPopover = 3\n    const left = this.calculateLeft(this.direction, buttonRect)\n    const top = buttonRect.bottom + gapBetweenButtonAndPopover;\n\n    this.left = `${left}px`\n    this.top = `${top}px`\n    this.isActive = true\n  }\n\n  close(): void {\n    this.isActive = false\n    this.changeDetectorRef.markForCheck()\n  }\n\n  onItemClick(item: DropdownOption): void {\n    this.contextMenuItemClicked.emit(item)\n    this.close()\n  }\n\n  onMenuItemKeyDown(event: KeyboardEvent, menuItem: DropdownOption): void {\n    switch (event.key) {\n      case 'Enter':\n      case ' ':\n        event.preventDefault()\n        this.onItemClick(menuItem)\n        break\n      default:\n        break\n    }\n  }\n\n  calculateLeft(direction: string, buttonRect: DOMRect): number {\n    const popover = this.popover?.nativeElement as HTMLElement\n    const popoverWidth = popover?.offsetWidth || 0\n\n    switch (direction) {\n      case 'rtl':\n        return popoverWidth <= buttonRect.left\n          ? buttonRect.right - popoverWidth\n          : buttonRect.left\n      case 'ltr':\n      default:\n        return buttonRect.right + popoverWidth <= window.innerWidth\n          ? buttonRect.left\n          : buttonRect.right - popoverWidth\n    }\n  }\n}\n","<button\n  #contextMenuAnchor\n  class=\"ghost small px-3\"\n  [class.active]=\"isActive\"\n  (click)=\"open()\"\n>\n  <ng-container\n    [ngTemplateOutlet]=\"menuAnchorTemplate ?? defaultButtonTemplate\"\n  >\n  </ng-container>\n</button>\n\n<div class=\"context-menu-overlay\">\n  <div\n    class=\"popover popover-context-menu\"\n    [class.active]=\"isActive\"\n    [style.top]=\"top\"\n    [style.left]=\"left\"\n    #contextMenuPopover\n  >\n    <ul role=\"listbox\">\n      <li\n        *ngFor=\"let menuItem of menuItems\"\n        (click)=\"onItemClick(menuItem)\"\n        tabindex=\"0\"\n        (keydown)=\"onMenuItemKeyDown($event, menuItem)\"\n      >\n        <ng-container\n          [ngTemplateOutlet]=\"menuItemTemplate ?? defaultMenuItemTemplate\"\n          [ngTemplateOutletContext]=\"{ $implicit: menuItem }\"\n        >\n        </ng-container>\n      </li>\n    </ul>\n  </div>\n</div>\n\n<ng-template #defaultMenuItemTemplate let-menuItem>\n  <span>{{ menuItem.label }}</span>\n</ng-template>\n\n<ng-template #defaultButtonTemplate>\n  <i class=\"sg-icon sg-icon-ellipsis\">Open context menu</i>\n</ng-template>\n"]}
|
|
128
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"context-menu.component.js","sourceRoot":"","sources":["../../../../../../libs/angular/src/lib/context-menu/context-menu.component.ts","../../../../../../libs/angular/src/lib/context-menu/context-menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  Inject,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core'\nimport { DropdownOption } from '@sebgroup/extract'\nimport { Subject, Subscription } from 'rxjs'\nimport { ON_SCROLL_TOKEN } from '../shared/on-scroll.directive'\nimport { CONTEXT_MENU_LEFT, CONTEXT_MENU_TOP } from './context-menu.constants'\n\n@Component({\n  selector: 'ngg-context-menu',\n  templateUrl: './context-menu.component.html',\n})\nexport class NggContextMenuComponent\n  implements AfterViewInit, OnDestroy, OnInit\n{\n  @Input() direction: 'ltr' | 'rtl' = 'ltr'\n  @Input() menuItems: DropdownOption[] = []\n  @Input() menuItemTemplate: TemplateRef<unknown> | null = null\n  @Input() menuAnchorTemplate: TemplateRef<unknown> | null = null\n  @Input() closeOnScroll = false\n\n  @Output() contextMenuItemClicked: EventEmitter<DropdownOption> =\n    new EventEmitter<DropdownOption>()\n\n  @ViewChild('contextMenuPopover') popover!: ElementRef<HTMLElement>\n\n  @ViewChild('contextMenuAnchor') anchor!: ElementRef<HTMLElement>\n\n  isActive = false\n  top = CONTEXT_MENU_TOP\n  left = CONTEXT_MENU_LEFT\n\n  resizeObserver?: ResizeObserver\n  menuCloseSubscription?: Subscription\n\n  constructor(\n    private changeDetectorRef: ChangeDetectorRef,\n    private elementRef: ElementRef<HTMLElement>,\n    @Optional()\n    @Inject(ON_SCROLL_TOKEN)\n    public closeContextMenu: Subject<void>\n  ) {}\n\n  @HostListener('document:click', ['$event.target'])\n  onDocumentClick(target: HTMLElement): void {\n    if (!this.isActive) {\n      return\n    }\n\n    if (!this.elementRef.nativeElement.contains(target)) {\n      this.close()\n    }\n  }\n\n  public ngOnInit(): void {\n    this.resizeObserver = new ResizeObserver(() => {\n      this.close()\n    })\n    this.resizeObserver.observe(document.body)\n  }\n\n  public ngAfterViewInit(): void {\n    if (this.closeOnScroll) {\n      this.menuCloseSubscription = this.closeContextMenu?.subscribe(() =>\n        this.close()\n      )\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.resizeObserver?.unobserve(document.body)\n    this.menuCloseSubscription?.unsubscribe()\n  }\n\n  open(): void {\n    if (this.isActive) {\n      this.close()\n      return\n    }\n\n    const buttonRect = this.anchor?.nativeElement.getBoundingClientRect()\n\n    const gapBetweenButtonAndPopover = 3\n    const left = this.calculateLeft(this.direction, buttonRect)\n    const top = buttonRect.bottom + gapBetweenButtonAndPopover;\n\n    this.left = `${left}px`\n    this.top = `${top}px`\n    this.isActive = true\n  }\n\n  close(): void {\n    this.isActive = false\n    this.top = CONTEXT_MENU_TOP\n    this.left = CONTEXT_MENU_LEFT\n    this.changeDetectorRef.markForCheck()\n  }\n\n  onItemClick(item: DropdownOption): void {\n    this.contextMenuItemClicked.emit(item)\n    this.close()\n  }\n\n  onMenuItemKeyDown(event: KeyboardEvent, menuItem: DropdownOption): void {\n    switch (event.key) {\n      case 'Enter':\n      case ' ':\n        event.preventDefault()\n        this.onItemClick(menuItem)\n        break\n      default:\n        break\n    }\n  }\n\n  calculateLeft(direction: string, buttonRect: DOMRect): number {\n    const popover = this.popover?.nativeElement as HTMLElement\n    const popoverWidth = popover?.offsetWidth || 0\n\n    switch (direction) {\n      case 'rtl':\n        return popoverWidth <= buttonRect.left\n          ? buttonRect.right - popoverWidth\n          : buttonRect.left\n      case 'ltr':\n      default:\n        return buttonRect.right + popoverWidth <= window.innerWidth\n          ? buttonRect.left\n          : buttonRect.right - popoverWidth\n    }\n  }\n}\n","<button\n  #contextMenuAnchor\n  class=\"ghost small px-3\"\n  [class.active]=\"isActive\"\n  (click)=\"open()\"\n>\n  <ng-container\n    [ngTemplateOutlet]=\"menuAnchorTemplate ?? defaultButtonTemplate\"\n  >\n  </ng-container>\n</button>\n\n<div class=\"context-menu-overlay\">\n  <div\n    class=\"popover popover-context-menu\"\n    [class.active]=\"isActive\"\n    [style.top]=\"top\"\n    [style.left]=\"left\"\n    #contextMenuPopover\n  >\n    <ul role=\"listbox\">\n      <li\n        *ngFor=\"let menuItem of menuItems\"\n        (click)=\"onItemClick(menuItem)\"\n        tabindex=\"0\"\n        (keydown)=\"onMenuItemKeyDown($event, menuItem)\"\n      >\n        <ng-container\n          [ngTemplateOutlet]=\"menuItemTemplate ?? defaultMenuItemTemplate\"\n          [ngTemplateOutletContext]=\"{ $implicit: menuItem }\"\n        >\n        </ng-container>\n      </li>\n    </ul>\n  </div>\n</div>\n\n<ng-template #defaultMenuItemTemplate let-menuItem>\n  <span>{{ menuItem.label }}</span>\n</ng-template>\n\n<ng-template #defaultButtonTemplate>\n  <i class=\"sg-icon sg-icon-ellipsis\">Open context menu</i>\n</ng-template>\n"]}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export const CONTEXT_MENU_TOP = '0px';
|
|
2
|
+
export const CONTEXT_MENU_LEFT = '0px';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGV4dC1tZW51LmNvbnN0YW50cy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvYW5ndWxhci9zcmMvbGliL2NvbnRleHQtbWVudS9jb250ZXh0LW1lbnUuY29uc3RhbnRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBQyxNQUFNLGdCQUFnQixHQUFHLEtBQUssQ0FBQztBQUV0QyxNQUFNLENBQUMsTUFBTSxpQkFBaUIsR0FBRyxLQUFLLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgQ09OVEVYVF9NRU5VX1RPUCA9ICcwcHgnO1xuXG5leHBvcnQgY29uc3QgQ09OVEVYVF9NRU5VX0xFRlQgPSAnMHB4JzsiXX0=
|
|
@@ -1,3 +1,5 @@
|
|
|
1
1
|
export * from './modal.component';
|
|
2
2
|
export * from './modal.module';
|
|
3
|
-
|
|
3
|
+
export * from './modal-header.directive';
|
|
4
|
+
export * from './modal-footer.directive';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvc3JjL2xpYi9tb2RhbC9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLG1CQUFtQixDQUFBO0FBQ2pDLGNBQWMsZ0JBQWdCLENBQUE7QUFDOUIsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLDBCQUEwQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9tb2RhbC5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL21vZGFsLm1vZHVsZSdcbmV4cG9ydCAqIGZyb20gJy4vbW9kYWwtaGVhZGVyLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL21vZGFsLWZvb3Rlci5kaXJlY3RpdmUnO1xuIl19
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { Directive, ViewContainerRef } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class NggModalFooterDirective {
|
|
4
|
+
constructor(viewContainerRef) {
|
|
5
|
+
this.viewContainerRef = viewContainerRef;
|
|
6
|
+
}
|
|
7
|
+
}
|
|
8
|
+
NggModalFooterDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: NggModalFooterDirective, deps: [{ token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
9
|
+
NggModalFooterDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.3.0", type: NggModalFooterDirective, selector: "[nggModalFooter]", ngImport: i0 });
|
|
10
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: NggModalFooterDirective, decorators: [{
|
|
11
|
+
type: Directive,
|
|
12
|
+
args: [{
|
|
13
|
+
selector: '[nggModalFooter]'
|
|
14
|
+
}]
|
|
15
|
+
}], ctorParameters: function () { return [{ type: i0.ViewContainerRef }]; } });
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwtZm9vdGVyLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvYW5ndWxhci9zcmMvbGliL21vZGFsL21vZGFsLWZvb3Rlci5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFLNUQsTUFBTSxPQUFPLHVCQUF1QjtJQUNsQyxZQUFtQixnQkFBa0M7UUFBbEMscUJBQWdCLEdBQWhCLGdCQUFnQixDQUFrQjtJQUFHLENBQUM7O29IQUQ5Qyx1QkFBdUI7d0dBQXZCLHVCQUF1QjsyRkFBdkIsdUJBQXVCO2tCQUhuQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxrQkFBa0I7aUJBQzdCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBWaWV3Q29udGFpbmVyUmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ1tuZ2dNb2RhbEZvb3Rlcl0nXG59KVxuZXhwb3J0IGNsYXNzIE5nZ01vZGFsRm9vdGVyRGlyZWN0aXZlIHtcbiAgY29uc3RydWN0b3IocHVibGljIHZpZXdDb250YWluZXJSZWY6IFZpZXdDb250YWluZXJSZWYpIHt9XG59XG4iXX0=
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { Directive, ViewContainerRef } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class NggModalHeaderDirective {
|
|
4
|
+
constructor(viewContainerRef) {
|
|
5
|
+
this.viewContainerRef = viewContainerRef;
|
|
6
|
+
}
|
|
7
|
+
}
|
|
8
|
+
NggModalHeaderDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: NggModalHeaderDirective, deps: [{ token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
9
|
+
NggModalHeaderDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.3.0", type: NggModalHeaderDirective, selector: "[nggModalHeader]", ngImport: i0 });
|
|
10
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: NggModalHeaderDirective, decorators: [{
|
|
11
|
+
type: Directive,
|
|
12
|
+
args: [{
|
|
13
|
+
selector: '[nggModalHeader]'
|
|
14
|
+
}]
|
|
15
|
+
}], ctorParameters: function () { return [{ type: i0.ViewContainerRef }]; } });
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwtaGVhZGVyLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvYW5ndWxhci9zcmMvbGliL21vZGFsL21vZGFsLWhlYWRlci5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFLNUQsTUFBTSxPQUFPLHVCQUF1QjtJQUNsQyxZQUFtQixnQkFBa0M7UUFBbEMscUJBQWdCLEdBQWhCLGdCQUFnQixDQUFrQjtJQUFHLENBQUM7O29IQUQ5Qyx1QkFBdUI7d0dBQXZCLHVCQUF1QjsyRkFBdkIsdUJBQXVCO2tCQUhuQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxrQkFBa0I7aUJBQzdCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBWaWV3Q29udGFpbmVyUmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ1tuZ2dNb2RhbEhlYWRlcl0nXG59KVxuZXhwb3J0IGNsYXNzIE5nZ01vZGFsSGVhZGVyRGlyZWN0aXZlIHtcbiAgY29uc3RydWN0b3IocHVibGljIHZpZXdDb250YWluZXJSZWY6IFZpZXdDb250YWluZXJSZWYpIHt9XG59XG4iXX0=
|
|
@@ -1,6 +1,8 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, ElementRef, EventEmitter, HostBinding, Input, Output, ViewChild } from '@angular/core';
|
|
1
|
+
import { ChangeDetectionStrategy, Component, ContentChild, ElementRef, EventEmitter, HostBinding, Input, Output, ViewChild } from '@angular/core';
|
|
2
2
|
import { ConfigurableFocusTrapFactory } from '@angular/cdk/a11y';
|
|
3
3
|
import { disableBodyScroll, enableBodyScroll, } from "body-scroll-lock";
|
|
4
|
+
import { NggModalHeaderDirective } from './modal-header.directive';
|
|
5
|
+
import { NggModalFooterDirective } from './modal-footer.directive';
|
|
4
6
|
import * as i0 from "@angular/core";
|
|
5
7
|
import * as i1 from "@angular/cdk/a11y";
|
|
6
8
|
import * as i2 from "@angular/common";
|
|
@@ -37,7 +39,12 @@ export class NggModalComponent {
|
|
|
37
39
|
if (this.trapFocus) {
|
|
38
40
|
this.enableFocusTrap();
|
|
39
41
|
}
|
|
40
|
-
disableBodyScroll(this.ref.nativeElement
|
|
42
|
+
disableBodyScroll(this.ref.nativeElement, {
|
|
43
|
+
allowTouchMove: (el) => {
|
|
44
|
+
// Allow touchmove for elements inside modal, its required for scroll to work on iOS devices
|
|
45
|
+
return this.ref.nativeElement.contains(el);
|
|
46
|
+
}
|
|
47
|
+
});
|
|
41
48
|
}
|
|
42
49
|
else {
|
|
43
50
|
this.disableFocusTrap();
|
|
@@ -90,10 +97,10 @@ export class NggModalComponent {
|
|
|
90
97
|
}
|
|
91
98
|
}
|
|
92
99
|
NggModalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: NggModalComponent, deps: [{ token: i0.ElementRef }, { token: i1.ConfigurableFocusTrapFactory }], target: i0.ɵɵFactoryTarget.Component });
|
|
93
|
-
NggModalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: NggModalComponent, selector: "ngg-modal", inputs: { modalType: "modalType", header: "header", confirmLabel: "confirmLabel", dismissLabel: "dismissLabel", size: "size", trapFocus: "trapFocus", isOpen: "isOpen" }, outputs: { isOpenChange: "isOpenChange", closed: "closed", confirm: "confirm", dismiss: "dismiss" }, host: { properties: { "class.open": "this.open" } }, viewQueries: [{ propertyName: "backdropRef", first: true, predicate: ["backdrop"], descendants: true }], ngImport: i0, template: "<ng-container *ngIf=\"isOpen\" [ngSwitch]=\"modalType\">\n <aside data-testid=\"modal\" *ngSwitchCase=\"'slideout'\" role=\"dialog\" aria-modal=\"true\" [class.small]=\"size === 'sm'\" [class.medium]=\"size === 'md'\" [class.large]=\"size === 'lg'\">\n <
|
|
100
|
+
NggModalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: NggModalComponent, selector: "ngg-modal", inputs: { modalType: "modalType", header: "header", confirmLabel: "confirmLabel", dismissLabel: "dismissLabel", size: "size", hideHeader: "hideHeader", hideFooter: "hideFooter", trapFocus: "trapFocus", isOpen: "isOpen" }, outputs: { isOpenChange: "isOpenChange", closed: "closed", confirm: "confirm", dismiss: "dismiss" }, host: { properties: { "class.open": "this.open" } }, queries: [{ propertyName: "modalHeaderContent", first: true, predicate: NggModalHeaderDirective, descendants: true }, { propertyName: "modalFooterContent", first: true, predicate: NggModalFooterDirective, descendants: true }], viewQueries: [{ propertyName: "backdropRef", first: true, predicate: ["backdrop"], descendants: true }], ngImport: i0, template: "<ng-container *ngIf=\"isOpen\" [ngSwitch]=\"modalType\">\n <aside data-testid=\"modal\" *ngSwitchCase=\"'slideout'\" role=\"dialog\" aria-modal=\"true\" [class.small]=\"size === 'sm'\" [class.medium]=\"size === 'md'\" [class.large]=\"size === 'lg'\">\n <ng-container *ngTemplateOutlet=\"contentTemplate\"></ng-container>\n </aside>\n <main data-testid=\"modal\" *ngSwitchCase=\"'takeover'\" role=\"dialog\" aria-modal=\"true\">\n <ng-container *ngTemplateOutlet=\"contentTemplate\"></ng-container>\n </main>\n <section data-testid=\"modal\" *ngSwitchDefault role=\"dialog\" aria-modal=\"true\" [class.small]=\"size === 'sm'\" [class.medium]=\"size === 'md'\" [class.large]=\"size === 'lg'\">\n <ng-container *ngTemplateOutlet=\"contentTemplate\"></ng-container>\n </section>\n <ng-template #contentTemplate>\n <ng-container *ngIf=\"!hideHeader\">\n <header *ngIf=\"!modalHeaderContent; else headerContentTemplate\" ngg-modal-header data-testid=\"modal-header\" [header]=\"header\" (closed)=\"this.handleCloseClick($event)\"></header>\n </ng-container>\n <div ngg-modal-body data-testid=\"modal-body\" class=\"body\">\n <ng-container *ngTemplateOutlet=\"bodyContentTemplate\"></ng-container>\n </div>\n <ng-container *ngIf=\"!hideFooter && (dismissLabel || confirmLabel)\">\n <footer *ngIf=\"!modalFooterContent; else footerContentTemplate\" ngg-modal-footer data-testid=\"modal-footer\" [dismissLabel]=\"dismissLabel\" [confirmLabel]=\"confirmLabel\" (dismiss)=\"this.handleDismiss($event)\" (confirm)=\"this.handleConfirm($event)\"></footer>\n </ng-container>\n </ng-template>\n <ng-template #headerContentTemplate>\n <header data-testid=\"modal-header\">\n <ng-content select=\"[nggModalHeader]\"></ng-content>\n </header>\n </ng-template>\n <ng-template #bodyContentTemplate>\n <ng-content></ng-content>\n </ng-template>\n <ng-template #footerContentTemplate>\n <footer data-testid=\"modal-footer\">\n <ng-content select=\"[nggModalFooter]\"></ng-content>\n </footer>\n </ng-template>\n <div #backdrop data-testid=\"modal-backdrop\" class=\"backdrop\" (click)=\"this.handleBackdropClick($event)\" [attr.aria-hidden]=\"true\"></div>\n</ng-container>\n", styles: [":host.open{height:100vh;left:0;overflow:hidden;position:fixed;top:0;width:100%;z-index:var(--sg-z-index-modal-backdrop)}:host.open>section[role=dialog]{left:50%;top:50%;transform:translate(-50%,-50%)}.body::-webkit-scrollbar{background-color:#f8f8f8;height:10px;width:10px}.body::-webkit-scrollbar-thumb{background-color:#cecece}.body::-webkit-scrollbar-track{background-color:#f8f8f8;box-shadow:inset 0 0 10px #00000040}\n"], dependencies: [{ kind: "directive", type: i0.forwardRef(function () { return i2.NgIf; }), selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i0.forwardRef(function () { return i2.NgTemplateOutlet; }), selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i0.forwardRef(function () { return i2.NgSwitch; }), selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i0.forwardRef(function () { return i2.NgSwitchCase; }), selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i0.forwardRef(function () { return i2.NgSwitchDefault; }), selector: "[ngSwitchDefault]" }, { kind: "component", type: i0.forwardRef(function () { return NggModalHeaderComponent; }), selector: "[ngg-modal-header]", inputs: ["header"], outputs: ["closed"] }, { kind: "component", type: i0.forwardRef(function () { return NggModalBodyComponent; }), selector: "[ngg-modal-body]" }, { kind: "component", type: i0.forwardRef(function () { return NggModalFooterComponent; }), selector: "[ngg-modal-footer]", inputs: ["dismissLabel", "confirmLabel"], outputs: ["dismiss", "confirm"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
94
101
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: NggModalComponent, decorators: [{
|
|
95
102
|
type: Component,
|
|
96
|
-
args: [{ selector: 'ngg-modal', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"isOpen\" [ngSwitch]=\"modalType\">\n <aside data-testid=\"modal\" *ngSwitchCase=\"'slideout'\" role=\"dialog\" aria-modal=\"true\" [class.small]=\"size === 'sm'\" [class.medium]=\"size === 'md'\" [class.large]=\"size === 'lg'\">\n <
|
|
103
|
+
args: [{ selector: 'ngg-modal', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"isOpen\" [ngSwitch]=\"modalType\">\n <aside data-testid=\"modal\" *ngSwitchCase=\"'slideout'\" role=\"dialog\" aria-modal=\"true\" [class.small]=\"size === 'sm'\" [class.medium]=\"size === 'md'\" [class.large]=\"size === 'lg'\">\n <ng-container *ngTemplateOutlet=\"contentTemplate\"></ng-container>\n </aside>\n <main data-testid=\"modal\" *ngSwitchCase=\"'takeover'\" role=\"dialog\" aria-modal=\"true\">\n <ng-container *ngTemplateOutlet=\"contentTemplate\"></ng-container>\n </main>\n <section data-testid=\"modal\" *ngSwitchDefault role=\"dialog\" aria-modal=\"true\" [class.small]=\"size === 'sm'\" [class.medium]=\"size === 'md'\" [class.large]=\"size === 'lg'\">\n <ng-container *ngTemplateOutlet=\"contentTemplate\"></ng-container>\n </section>\n <ng-template #contentTemplate>\n <ng-container *ngIf=\"!hideHeader\">\n <header *ngIf=\"!modalHeaderContent; else headerContentTemplate\" ngg-modal-header data-testid=\"modal-header\" [header]=\"header\" (closed)=\"this.handleCloseClick($event)\"></header>\n </ng-container>\n <div ngg-modal-body data-testid=\"modal-body\" class=\"body\">\n <ng-container *ngTemplateOutlet=\"bodyContentTemplate\"></ng-container>\n </div>\n <ng-container *ngIf=\"!hideFooter && (dismissLabel || confirmLabel)\">\n <footer *ngIf=\"!modalFooterContent; else footerContentTemplate\" ngg-modal-footer data-testid=\"modal-footer\" [dismissLabel]=\"dismissLabel\" [confirmLabel]=\"confirmLabel\" (dismiss)=\"this.handleDismiss($event)\" (confirm)=\"this.handleConfirm($event)\"></footer>\n </ng-container>\n </ng-template>\n <ng-template #headerContentTemplate>\n <header data-testid=\"modal-header\">\n <ng-content select=\"[nggModalHeader]\"></ng-content>\n </header>\n </ng-template>\n <ng-template #bodyContentTemplate>\n <ng-content></ng-content>\n </ng-template>\n <ng-template #footerContentTemplate>\n <footer data-testid=\"modal-footer\">\n <ng-content select=\"[nggModalFooter]\"></ng-content>\n </footer>\n </ng-template>\n <div #backdrop data-testid=\"modal-backdrop\" class=\"backdrop\" (click)=\"this.handleBackdropClick($event)\" [attr.aria-hidden]=\"true\"></div>\n</ng-container>\n", styles: [":host.open{height:100vh;left:0;overflow:hidden;position:fixed;top:0;width:100%;z-index:var(--sg-z-index-modal-backdrop)}:host.open>section[role=dialog]{left:50%;top:50%;transform:translate(-50%,-50%)}.body::-webkit-scrollbar{background-color:#f8f8f8;height:10px;width:10px}.body::-webkit-scrollbar-thumb{background-color:#cecece}.body::-webkit-scrollbar-track{background-color:#f8f8f8;box-shadow:inset 0 0 10px #00000040}\n"] }]
|
|
97
104
|
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.ConfigurableFocusTrapFactory }]; }, propDecorators: { modalType: [{
|
|
98
105
|
type: Input
|
|
99
106
|
}], header: [{
|
|
@@ -104,6 +111,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
104
111
|
type: Input
|
|
105
112
|
}], size: [{
|
|
106
113
|
type: Input
|
|
114
|
+
}], hideHeader: [{
|
|
115
|
+
type: Input
|
|
116
|
+
}], hideFooter: [{
|
|
117
|
+
type: Input
|
|
107
118
|
}], trapFocus: [{
|
|
108
119
|
type: Input
|
|
109
120
|
}], isOpen: [{
|
|
@@ -122,6 +133,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
122
133
|
}], backdropRef: [{
|
|
123
134
|
type: ViewChild,
|
|
124
135
|
args: ['backdrop']
|
|
136
|
+
}], modalHeaderContent: [{
|
|
137
|
+
type: ContentChild,
|
|
138
|
+
args: [NggModalHeaderDirective]
|
|
139
|
+
}], modalFooterContent: [{
|
|
140
|
+
type: ContentChild,
|
|
141
|
+
args: [NggModalFooterDirective]
|
|
125
142
|
}] } });
|
|
126
143
|
export class NggModalHeaderComponent {
|
|
127
144
|
constructor() {
|
|
@@ -193,4 +210,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
193
210
|
}], confirm: [{
|
|
194
211
|
type: Output
|
|
195
212
|
}] } });
|
|
196
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.component.js","sourceRoot":"","sources":["../../../../../../libs/angular/src/lib/modal/modal.component.ts","../../../../../../libs/angular/src/lib/modal/modal.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, ElementRef, EventEmitter, HostBinding, Input, OnDestroy, OnInit, Output, ViewChild } from '@angular/core';\nimport { ModalType, Size } from '@sebgroup/extract';\nimport { ConfigurableFocusTrap, ConfigurableFocusTrapFactory } from '@angular/cdk/a11y';\nimport {\n    disableBodyScroll,\n    enableBodyScroll,\n} from \"body-scroll-lock\";\n\n@Component({\n    selector: 'ngg-modal',\n    styleUrls: ['./modal.component.scss'],\n    templateUrl: './modal.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class NggModalComponent implements OnDestroy, OnInit {\n    @Input() public modalType?: ModalType\n    @Input() public header?: string\n    @Input() public confirmLabel?: string\n    @Input() public dismissLabel?: string\n    @Input() public size?: Size\n    @Input() public get trapFocus(): boolean | undefined {\n        return this._trapFocus;\n    }\n    public set trapFocus(value: boolean | undefined) {\n        this._trapFocus = value;\n        \n        if (value) {\n            if (this._isOpen) {\n                this.enableFocusTrap();\n            }\n        } else {\n            this.disableFocusTrap();\n        }\n    }\n\n    @Input()\n    public get isOpen(): boolean | undefined {\n        return this._isOpen;\n    }\n    public set isOpen(value: boolean | undefined) {\n        this._isOpen = value;\n\n        if (value) {\n            if (this.trapFocus) {\n                this.enableFocusTrap();\n            }\n\n            disableBodyScroll(this.ref.nativeElement);\n        } else {\n            this.disableFocusTrap();\n            enableBodyScroll(this.ref.nativeElement);\n        }\n    }\n\n    @Output() public isOpenChange: EventEmitter<boolean> = new EventEmitter<boolean>();\n    @Output() public closed: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\n    @Output() public confirm: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\n    @Output() public dismiss: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\n\n    @HostBinding('class.open') get open() { return this.isOpen; }\n    @ViewChild('backdrop') private backdropRef?: ElementRef<HTMLInputElement>;\n    private _isOpen?: boolean;\n    private _trapFocus?: boolean;\n    private configurableFocusTrap: ConfigurableFocusTrap;\n\n    constructor(private ref: ElementRef<HTMLElement>, private configurableFocusTrapFactory: ConfigurableFocusTrapFactory) {\n        this.configurableFocusTrap = this.configurableFocusTrapFactory.create(this.ref.nativeElement);\n    }\n\n    ngOnInit(): void {\n        if (this._isOpen && this.trapFocus) \n           this.enableFocusTrap(); \n        else\n            this.disableFocusTrap();\n    }\n\n    public handleCloseClick(event: MouseEvent) {\n        this.closeModal(event);\n    }\n\n    public handleBackdropClick(event: MouseEvent) {\n        if (event.target == this.backdropRef?.nativeElement)\n            this.closeModal(event);\n    }\n\n    public handleDismiss(event: MouseEvent) {\n        this.dismiss.emit(event);\n    }\n\n    public handleConfirm(event: MouseEvent) {\n        this.confirm.emit(event);\n    }\n\n    private closeModal(event: MouseEvent) {\n        if (this.closed.observers.length > 0) {\n            this.closed.emit(event);\n        }\n        else {\n            this.isOpen = false;\n            this.isOpenChange.emit(this.isOpen);\n        }\n    }\n\n    private enableFocusTrap() {\n        if (this.configurableFocusTrap) {\n            this.configurableFocusTrap.enabled = true;\n            this.configurableFocusTrap.focusInitialElementWhenReady();\n        }\n    }\n    \n    private disableFocusTrap() {\n        if (this.configurableFocusTrap) {\n            this.configurableFocusTrap.enabled = false;\n        }\n    }\n\n    ngOnDestroy(): void {\n        this.configurableFocusTrap?.destroy();\n        enableBodyScroll(this.ref.nativeElement);\n    }\n}\n\n@Component({\n    // eslint-disable-next-line @angular-eslint/component-selector\n    selector: '[ngg-modal-header]',\n    styleUrls: ['./modal.component.scss'],\n    template: `\n    <h3 data-testid=\"modal-header-text\">{{header}}</h3>\n    <button data-testid=\"modal-close-button\" class=\"close\" (click)=\"this.handleClose($event)\">\n        <span className=\"sr-only\">Close</span>\n        <i></i>\n    </button>\n    `\n})\nexport class NggModalHeaderComponent {\n    @Input() header?: string;\n    @Output() closed: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\n\n    handleClose(event: MouseEvent) {\n        this.closed.emit(event);\n    }\n\n}\n\n@Component({\n    // eslint-disable-next-line @angular-eslint/component-selector\n    selector: '[ngg-modal-body]',\n    styleUrls: ['./modal.component.scss'],\n    template: `<ng-content></ng-content>`\n})\nexport class NggModalBodyComponent {\n}\n\n@Component({\n    // eslint-disable-next-line @angular-eslint/component-selector\n    selector: '[ngg-modal-footer]',\n    styleUrls: ['./modal.component.scss'],\n    template: `\n    <button data-testid=\"modal-dismiss-button\" *ngIf=\"dismissLabel\" class=\"secondary\" (click)=\"this.handleDismiss($event)\">{{dismissLabel}}</button>\n    <button data-testid=\"modal-confirm-button\" *ngIf=\"confirmLabel\" class=\"primary\" (click)=\"this.handleConfirm($event)\">{{confirmLabel}}</button>\n    `\n})\nexport class NggModalFooterComponent {\n    @Input() dismissLabel?: string;\n    @Input() confirmLabel?: string;\n    @Output() dismiss: EventEmitter<MouseEvent> = new EventEmitter();\n    @Output() confirm: EventEmitter<MouseEvent> = new EventEmitter();\n\n    handleDismiss(event: MouseEvent) {\n        this.dismiss.emit(event);\n    }\n\n    handleConfirm(event: MouseEvent) {\n        this.confirm.emit(event);\n    }\n}","<ng-container *ngIf=\"isOpen\" [ngSwitch]=\"modalType\">\n    <aside data-testid=\"modal\" *ngSwitchCase=\"'slideout'\" role=\"dialog\" aria-modal=\"true\" [class.small]=\"size === 'sm'\" [class.medium]=\"size === 'md'\" [class.large]=\"size === 'lg'\">\n        <header ngg-modal-header data-testid=\"modal-header\" [header]=\"header\" (closed)=\"this.handleCloseClick($event)\"></header>\n        <div ngg-modal-body data-testid=\"modal-body\" class=\"body\">\n            <ng-container *ngTemplateOutlet=\"contentTpl\"></ng-container> \n        </div>\n        <footer ngg-modal-footer data-testid=\"modal-footer\" *ngIf=\"dismissLabel || confirmLabel\" [dismissLabel]=\"dismissLabel\" [confirmLabel]=\"confirmLabel\" (dismiss)=\"this.handleDismiss($event)\" (confirm)=\"this.handleConfirm($event)\"></footer>\n    </aside>\n    <main data-testid=\"modal\" *ngSwitchCase=\"'takeover'\" role=\"dialog\" aria-modal=\"true\">\n        <header ngg-modal-header data-testid=\"modal-header\" [header]=\"header\" (closed)=\"this.handleCloseClick($event)\"></header>\n        <div ngg-modal-body data-testid=\"modal-body\" class=\"body\">\n            <ng-container *ngTemplateOutlet=\"contentTpl\"></ng-container> \n        </div>\n        <footer ngg-modal-footer data-testid=\"modal-footer\" *ngIf=\"dismissLabel || confirmLabel\" [dismissLabel]=\"dismissLabel\" [confirmLabel]=\"confirmLabel\" (dismiss)=\"this.handleDismiss($event)\" (confirm)=\"this.handleConfirm($event)\"></footer>\n    </main>\n    <section data-testid=\"modal\" *ngSwitchDefault role=\"dialog\" aria-modal=\"true\" [class.small]=\"size === 'sm'\" [class.medium]=\"size === 'md'\" [class.large]=\"size === 'lg'\">\n        <header ngg-modal-header data-testid=\"modal-header\" [header]=\"header\" (closed)=\"this.handleCloseClick($event)\"></header>\n        <div ngg-modal-body data-testid=\"modal-body\" class=\"body\">\n            <ng-container *ngTemplateOutlet=\"contentTpl\"></ng-container> \n        </div>\n        <footer ngg-modal-footer data-testid=\"modal-footer\" *ngIf=\"dismissLabel || confirmLabel\" [dismissLabel]=\"dismissLabel\" [confirmLabel]=\"confirmLabel\" (dismiss)=\"this.handleDismiss($event)\" (confirm)=\"this.handleConfirm($event)\"></footer>\n    </section>\n    <ng-template #contentTpl>\n            <ng-content></ng-content>\n    </ng-template>\n    <div #backdrop data-testid=\"modal-backdrop\" class=\"backdrop\" (click)=\"this.handleBackdropClick($event)\" [attr.aria-hidden]=\"true\"></div>\n</ng-container>"]}
|
|
213
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.component.js","sourceRoot":"","sources":["../../../../../../libs/angular/src/lib/modal/modal.component.ts","../../../../../../libs/angular/src/lib/modal/modal.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, ContentChild, ElementRef, EventEmitter, HostBinding, Input, OnDestroy, OnInit, Output, ViewChild } from '@angular/core';\nimport { ModalType, Size } from '@sebgroup/extract';\nimport { ConfigurableFocusTrap, ConfigurableFocusTrapFactory } from '@angular/cdk/a11y';\nimport {\n    disableBodyScroll,\n    enableBodyScroll,\n} from \"body-scroll-lock\";\nimport { NggModalHeaderDirective } from './modal-header.directive';\nimport { NggModalFooterDirective } from './modal-footer.directive';\n\n@Component({\n    selector: 'ngg-modal',\n    styleUrls: ['./modal.component.scss'],\n    templateUrl: './modal.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class NggModalComponent implements OnDestroy, OnInit {\n    @Input() public modalType?: ModalType\n    @Input() public header?: string\n    @Input() public confirmLabel?: string\n    @Input() public dismissLabel?: string\n    @Input() public size?: Size\n    @Input() public hideHeader?: boolean;\n    @Input() public hideFooter?: boolean;\n    @Input() public get trapFocus(): boolean | undefined {\n        return this._trapFocus;\n    }\n    public set trapFocus(value: boolean | undefined) {\n        this._trapFocus = value;\n\n        if (value) {\n            if (this._isOpen) {\n                this.enableFocusTrap();\n            }\n        } else {\n            this.disableFocusTrap();\n        }\n    }\n\n    @Input()\n    public get isOpen(): boolean | undefined {\n        return this._isOpen;\n    }\n    public set isOpen(value: boolean | undefined) {\n        this._isOpen = value;\n\n        if (value) {\n            if (this.trapFocus) {\n                this.enableFocusTrap();\n            }\n\n            disableBodyScroll(this.ref.nativeElement, {\n                allowTouchMove: (el) => {\n                    // Allow touchmove for elements inside modal, its required for scroll to work on iOS devices\n                    return this.ref.nativeElement.contains(el);\n                }\n            });\n        } else {\n            this.disableFocusTrap();\n            enableBodyScroll(this.ref.nativeElement);\n        }\n    }\n\n    @Output() public isOpenChange: EventEmitter<boolean> = new EventEmitter<boolean>();\n    @Output() public closed: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\n    @Output() public confirm: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\n    @Output() public dismiss: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\n\n    @HostBinding('class.open') get open() { return this.isOpen; }\n    @ViewChild('backdrop') private backdropRef?: ElementRef<HTMLInputElement>;\n    @ContentChild(NggModalHeaderDirective) public modalHeaderContent?: NggModalHeaderDirective;\n    @ContentChild(NggModalFooterDirective) public modalFooterContent?: NggModalFooterDirective;\n    private _isOpen?: boolean;\n    private _trapFocus?: boolean;\n    private configurableFocusTrap: ConfigurableFocusTrap;\n\n    constructor(private ref: ElementRef<HTMLElement>, private configurableFocusTrapFactory: ConfigurableFocusTrapFactory) {\n        this.configurableFocusTrap = this.configurableFocusTrapFactory.create(this.ref.nativeElement);\n    }\n\n    ngOnInit(): void {\n        if (this._isOpen && this.trapFocus)\n            this.enableFocusTrap();\n        else\n            this.disableFocusTrap();\n    }\n\n    public handleCloseClick(event: MouseEvent) {\n        this.closeModal(event);\n    }\n\n    public handleBackdropClick(event: MouseEvent) {\n        if (event.target == this.backdropRef?.nativeElement)\n            this.closeModal(event);\n    }\n\n    public handleDismiss(event: MouseEvent) {\n        this.dismiss.emit(event);\n    }\n\n    public handleConfirm(event: MouseEvent) {\n        this.confirm.emit(event);\n    }\n\n    private closeModal(event: MouseEvent) {\n        if (this.closed.observers.length > 0) {\n            this.closed.emit(event);\n        }\n        else {\n            this.isOpen = false;\n            this.isOpenChange.emit(this.isOpen);\n        }\n    }\n\n    private enableFocusTrap() {\n        if (this.configurableFocusTrap) {\n            this.configurableFocusTrap.enabled = true;\n            this.configurableFocusTrap.focusInitialElementWhenReady();\n        }\n    }\n\n    private disableFocusTrap() {\n        if (this.configurableFocusTrap) {\n            this.configurableFocusTrap.enabled = false;\n        }\n    }\n\n    ngOnDestroy(): void {\n        this.configurableFocusTrap?.destroy();\n        enableBodyScroll(this.ref.nativeElement);\n    }\n}\n\n@Component({\n    // eslint-disable-next-line @angular-eslint/component-selector\n    selector: '[ngg-modal-header]',\n    styleUrls: ['./modal.component.scss'],\n    template: `\n    <h3 data-testid=\"modal-header-text\">{{header}}</h3>\n    <button data-testid=\"modal-close-button\" class=\"close\" (click)=\"this.handleClose($event)\">\n        <span className=\"sr-only\">Close</span>\n        <i></i>\n    </button>\n    `\n})\nexport class NggModalHeaderComponent {\n    @Input() header?: string;\n    @Output() closed: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\n\n    handleClose(event: MouseEvent) {\n        this.closed.emit(event);\n    }\n\n}\n\n@Component({\n    // eslint-disable-next-line @angular-eslint/component-selector\n    selector: '[ngg-modal-body]',\n    styleUrls: ['./modal.component.scss'],\n    template: `<ng-content></ng-content>`\n})\nexport class NggModalBodyComponent {\n}\n\n@Component({\n    // eslint-disable-next-line @angular-eslint/component-selector\n    selector: '[ngg-modal-footer]',\n    styleUrls: ['./modal.component.scss'],\n    template: `\n    <button data-testid=\"modal-dismiss-button\" *ngIf=\"dismissLabel\" class=\"secondary\" (click)=\"this.handleDismiss($event)\">{{dismissLabel}}</button>\n    <button data-testid=\"modal-confirm-button\" *ngIf=\"confirmLabel\" class=\"primary\" (click)=\"this.handleConfirm($event)\">{{confirmLabel}}</button>\n    `\n})\nexport class NggModalFooterComponent {\n    @Input() dismissLabel?: string;\n    @Input() confirmLabel?: string;\n    @Output() dismiss: EventEmitter<MouseEvent> = new EventEmitter();\n    @Output() confirm: EventEmitter<MouseEvent> = new EventEmitter();\n\n    handleDismiss(event: MouseEvent) {\n        this.dismiss.emit(event);\n    }\n\n    handleConfirm(event: MouseEvent) {\n        this.confirm.emit(event);\n    }\n}\n","<ng-container *ngIf=\"isOpen\" [ngSwitch]=\"modalType\">\n    <aside data-testid=\"modal\" *ngSwitchCase=\"'slideout'\" role=\"dialog\" aria-modal=\"true\" [class.small]=\"size === 'sm'\" [class.medium]=\"size === 'md'\" [class.large]=\"size === 'lg'\">\n        <ng-container *ngTemplateOutlet=\"contentTemplate\"></ng-container>\n    </aside>\n    <main data-testid=\"modal\" *ngSwitchCase=\"'takeover'\" role=\"dialog\" aria-modal=\"true\">\n        <ng-container *ngTemplateOutlet=\"contentTemplate\"></ng-container>\n    </main>\n    <section data-testid=\"modal\" *ngSwitchDefault role=\"dialog\" aria-modal=\"true\" [class.small]=\"size === 'sm'\" [class.medium]=\"size === 'md'\" [class.large]=\"size === 'lg'\">\n        <ng-container *ngTemplateOutlet=\"contentTemplate\"></ng-container>\n    </section>\n    <ng-template #contentTemplate>\n        <ng-container *ngIf=\"!hideHeader\">\n            <header *ngIf=\"!modalHeaderContent; else headerContentTemplate\" ngg-modal-header data-testid=\"modal-header\" [header]=\"header\" (closed)=\"this.handleCloseClick($event)\"></header>\n        </ng-container>\n        <div ngg-modal-body data-testid=\"modal-body\" class=\"body\">\n            <ng-container *ngTemplateOutlet=\"bodyContentTemplate\"></ng-container>\n        </div>\n        <ng-container *ngIf=\"!hideFooter && (dismissLabel || confirmLabel)\">\n            <footer *ngIf=\"!modalFooterContent; else footerContentTemplate\" ngg-modal-footer data-testid=\"modal-footer\" [dismissLabel]=\"dismissLabel\" [confirmLabel]=\"confirmLabel\" (dismiss)=\"this.handleDismiss($event)\" (confirm)=\"this.handleConfirm($event)\"></footer>\n        </ng-container>\n    </ng-template>\n    <ng-template #headerContentTemplate>\n        <header data-testid=\"modal-header\">\n            <ng-content select=\"[nggModalHeader]\"></ng-content>\n        </header>\n    </ng-template>\n    <ng-template #bodyContentTemplate>\n        <ng-content></ng-content>\n    </ng-template>\n    <ng-template #footerContentTemplate>\n        <footer data-testid=\"modal-footer\">\n            <ng-content select=\"[nggModalFooter]\"></ng-content>\n        </footer>\n    </ng-template>\n    <div #backdrop data-testid=\"modal-backdrop\" class=\"backdrop\" (click)=\"this.handleBackdropClick($event)\" [attr.aria-hidden]=\"true\"></div>\n</ng-container>\n"]}
|
|
@@ -2,15 +2,21 @@ import { CommonModule } from '@angular/common';
|
|
|
2
2
|
import { NgModule } from '@angular/core';
|
|
3
3
|
import { A11yModule } from '@angular/cdk/a11y';
|
|
4
4
|
import { NggModalBodyComponent, NggModalComponent, NggModalFooterComponent, NggModalHeaderComponent } from './modal.component';
|
|
5
|
+
import { NggModalHeaderDirective } from './modal-header.directive';
|
|
6
|
+
import { NggModalFooterDirective } from './modal-footer.directive';
|
|
5
7
|
import * as i0 from "@angular/core";
|
|
6
8
|
const DECLARATIONS = [
|
|
7
9
|
NggModalComponent,
|
|
8
10
|
NggModalHeaderComponent,
|
|
9
11
|
NggModalBodyComponent,
|
|
10
|
-
NggModalFooterComponent
|
|
12
|
+
NggModalFooterComponent,
|
|
13
|
+
NggModalHeaderDirective,
|
|
14
|
+
NggModalFooterDirective
|
|
11
15
|
];
|
|
12
16
|
const EXPORTS = [
|
|
13
17
|
NggModalComponent,
|
|
18
|
+
NggModalHeaderDirective,
|
|
19
|
+
NggModalFooterDirective
|
|
14
20
|
];
|
|
15
21
|
export class NggModalModule {
|
|
16
22
|
}
|
|
@@ -18,7 +24,11 @@ NggModalModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version:
|
|
|
18
24
|
NggModalModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.3.0", ngImport: i0, type: NggModalModule, declarations: [NggModalComponent,
|
|
19
25
|
NggModalHeaderComponent,
|
|
20
26
|
NggModalBodyComponent,
|
|
21
|
-
NggModalFooterComponent
|
|
27
|
+
NggModalFooterComponent,
|
|
28
|
+
NggModalHeaderDirective,
|
|
29
|
+
NggModalFooterDirective], imports: [A11yModule, CommonModule], exports: [NggModalComponent,
|
|
30
|
+
NggModalHeaderDirective,
|
|
31
|
+
NggModalFooterDirective] });
|
|
22
32
|
NggModalModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: NggModalModule, imports: [A11yModule, CommonModule] });
|
|
23
33
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: NggModalModule, decorators: [{
|
|
24
34
|
type: NgModule,
|
|
@@ -28,4 +38,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
28
38
|
declarations: DECLARATIONS,
|
|
29
39
|
}]
|
|
30
40
|
}] });
|
|
31
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
41
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyL3NyYy9saWIvbW9kYWwvbW9kYWwubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUscUJBQXFCLEVBQUUsaUJBQWlCLEVBQUUsdUJBQXVCLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUMvSCxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUNuRSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQzs7QUFFbkUsTUFBTSxZQUFZLEdBQUc7SUFDakIsaUJBQWlCO0lBQ2pCLHVCQUF1QjtJQUN2QixxQkFBcUI7SUFDckIsdUJBQXVCO0lBQ3ZCLHVCQUF1QjtJQUN2Qix1QkFBdUI7Q0FDMUIsQ0FBQztBQUVGLE1BQU0sT0FBTyxHQUFHO0lBQ1osaUJBQWlCO0lBQ2pCLHVCQUF1QjtJQUN2Qix1QkFBdUI7Q0FDMUIsQ0FBQztBQU9GLE1BQU0sT0FBTyxjQUFjOzsyR0FBZCxjQUFjOzRHQUFkLGNBQWMsaUJBbkJ2QixpQkFBaUI7UUFDakIsdUJBQXVCO1FBQ3ZCLHFCQUFxQjtRQUNyQix1QkFBdUI7UUFDdkIsdUJBQXVCO1FBQ3ZCLHVCQUF1QixhQVVaLFVBQVUsRUFBRSxZQUFZLGFBTm5DLGlCQUFpQjtRQUNqQix1QkFBdUI7UUFDdkIsdUJBQXVCOzRHQVFkLGNBQWMsWUFKWixVQUFVLEVBQUUsWUFBWTsyRkFJMUIsY0FBYztrQkFMMUIsUUFBUTttQkFBQztvQkFDTixPQUFPLEVBQUUsQ0FBRSxVQUFVLEVBQUUsWUFBWSxDQUFFO29CQUNyQyxPQUFPLEVBQUUsT0FBTztvQkFDaEIsWUFBWSxFQUFFLFlBQVk7aUJBQzdCIiwic291cmNlc0NvbnRlbnQiOlsiXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEExMXlNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jZGsvYTExeSc7XG5pbXBvcnQgeyBOZ2dNb2RhbEJvZHlDb21wb25lbnQsIE5nZ01vZGFsQ29tcG9uZW50LCBOZ2dNb2RhbEZvb3RlckNvbXBvbmVudCwgTmdnTW9kYWxIZWFkZXJDb21wb25lbnQgfSBmcm9tICcuL21vZGFsLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBOZ2dNb2RhbEhlYWRlckRpcmVjdGl2ZSB9IGZyb20gJy4vbW9kYWwtaGVhZGVyLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBOZ2dNb2RhbEZvb3RlckRpcmVjdGl2ZSB9IGZyb20gJy4vbW9kYWwtZm9vdGVyLmRpcmVjdGl2ZSc7XG5cbmNvbnN0IERFQ0xBUkFUSU9OUyA9IFtcbiAgICBOZ2dNb2RhbENvbXBvbmVudCxcbiAgICBOZ2dNb2RhbEhlYWRlckNvbXBvbmVudCxcbiAgICBOZ2dNb2RhbEJvZHlDb21wb25lbnQsXG4gICAgTmdnTW9kYWxGb290ZXJDb21wb25lbnQsXG4gICAgTmdnTW9kYWxIZWFkZXJEaXJlY3RpdmUsXG4gICAgTmdnTW9kYWxGb290ZXJEaXJlY3RpdmVcbl07XG5cbmNvbnN0IEVYUE9SVFMgPSBbXG4gICAgTmdnTW9kYWxDb21wb25lbnQsXG4gICAgTmdnTW9kYWxIZWFkZXJEaXJlY3RpdmUsXG4gICAgTmdnTW9kYWxGb290ZXJEaXJlY3RpdmVcbl07XG5cbkBOZ01vZHVsZSh7XG4gICAgaW1wb3J0czogWyBBMTF5TW9kdWxlLCBDb21tb25Nb2R1bGUgXSxcbiAgICBleHBvcnRzOiBFWFBPUlRTLFxuICAgIGRlY2xhcmF0aW9uczogREVDTEFSQVRJT05TLFxufSlcbmV4cG9ydCBjbGFzcyBOZ2dNb2RhbE1vZHVsZSB7IH1cbiJdfQ==
|
|
@@ -316,6 +316,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
316
316
|
}]
|
|
317
317
|
}], ctorParameters: function () { return [{ type: i0.ElementRef }]; } });
|
|
318
318
|
|
|
319
|
+
const CONTEXT_MENU_TOP = '0px';
|
|
320
|
+
const CONTEXT_MENU_LEFT = '0px';
|
|
321
|
+
|
|
319
322
|
class NggContextMenuComponent {
|
|
320
323
|
constructor(changeDetectorRef, elementRef, closeContextMenu) {
|
|
321
324
|
this.changeDetectorRef = changeDetectorRef;
|
|
@@ -328,15 +331,14 @@ class NggContextMenuComponent {
|
|
|
328
331
|
this.closeOnScroll = false;
|
|
329
332
|
this.contextMenuItemClicked = new EventEmitter();
|
|
330
333
|
this.isActive = false;
|
|
331
|
-
this.top =
|
|
332
|
-
this.left =
|
|
334
|
+
this.top = CONTEXT_MENU_TOP;
|
|
335
|
+
this.left = CONTEXT_MENU_LEFT;
|
|
333
336
|
}
|
|
334
337
|
onDocumentClick(target) {
|
|
335
338
|
if (!this.isActive) {
|
|
336
339
|
return;
|
|
337
340
|
}
|
|
338
|
-
|
|
339
|
-
if (!contextMenuElement.contains(target)) {
|
|
341
|
+
if (!this.elementRef.nativeElement.contains(target)) {
|
|
340
342
|
this.close();
|
|
341
343
|
}
|
|
342
344
|
}
|
|
@@ -363,8 +365,7 @@ class NggContextMenuComponent {
|
|
|
363
365
|
this.close();
|
|
364
366
|
return;
|
|
365
367
|
}
|
|
366
|
-
const
|
|
367
|
-
const buttonRect = anchor.getBoundingClientRect();
|
|
368
|
+
const buttonRect = (_a = this.anchor) === null || _a === void 0 ? void 0 : _a.nativeElement.getBoundingClientRect();
|
|
368
369
|
const gapBetweenButtonAndPopover = 3;
|
|
369
370
|
const left = this.calculateLeft(this.direction, buttonRect);
|
|
370
371
|
const top = buttonRect.bottom + gapBetweenButtonAndPopover;
|
|
@@ -374,6 +375,8 @@ class NggContextMenuComponent {
|
|
|
374
375
|
}
|
|
375
376
|
close() {
|
|
376
377
|
this.isActive = false;
|
|
378
|
+
this.top = CONTEXT_MENU_TOP;
|
|
379
|
+
this.left = CONTEXT_MENU_LEFT;
|
|
377
380
|
this.changeDetectorRef.markForCheck();
|
|
378
381
|
}
|
|
379
382
|
onItemClick(item) {
|
|
@@ -966,6 +969,34 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
966
969
|
}]
|
|
967
970
|
}] });
|
|
968
971
|
|
|
972
|
+
class NggModalHeaderDirective {
|
|
973
|
+
constructor(viewContainerRef) {
|
|
974
|
+
this.viewContainerRef = viewContainerRef;
|
|
975
|
+
}
|
|
976
|
+
}
|
|
977
|
+
NggModalHeaderDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: NggModalHeaderDirective, deps: [{ token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
978
|
+
NggModalHeaderDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.3.0", type: NggModalHeaderDirective, selector: "[nggModalHeader]", ngImport: i0 });
|
|
979
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: NggModalHeaderDirective, decorators: [{
|
|
980
|
+
type: Directive,
|
|
981
|
+
args: [{
|
|
982
|
+
selector: '[nggModalHeader]'
|
|
983
|
+
}]
|
|
984
|
+
}], ctorParameters: function () { return [{ type: i0.ViewContainerRef }]; } });
|
|
985
|
+
|
|
986
|
+
class NggModalFooterDirective {
|
|
987
|
+
constructor(viewContainerRef) {
|
|
988
|
+
this.viewContainerRef = viewContainerRef;
|
|
989
|
+
}
|
|
990
|
+
}
|
|
991
|
+
NggModalFooterDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: NggModalFooterDirective, deps: [{ token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
992
|
+
NggModalFooterDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.3.0", type: NggModalFooterDirective, selector: "[nggModalFooter]", ngImport: i0 });
|
|
993
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: NggModalFooterDirective, decorators: [{
|
|
994
|
+
type: Directive,
|
|
995
|
+
args: [{
|
|
996
|
+
selector: '[nggModalFooter]'
|
|
997
|
+
}]
|
|
998
|
+
}], ctorParameters: function () { return [{ type: i0.ViewContainerRef }]; } });
|
|
999
|
+
|
|
969
1000
|
class NggModalComponent {
|
|
970
1001
|
constructor(ref, configurableFocusTrapFactory) {
|
|
971
1002
|
this.ref = ref;
|
|
@@ -999,7 +1030,12 @@ class NggModalComponent {
|
|
|
999
1030
|
if (this.trapFocus) {
|
|
1000
1031
|
this.enableFocusTrap();
|
|
1001
1032
|
}
|
|
1002
|
-
disableBodyScroll(this.ref.nativeElement
|
|
1033
|
+
disableBodyScroll(this.ref.nativeElement, {
|
|
1034
|
+
allowTouchMove: (el) => {
|
|
1035
|
+
// Allow touchmove for elements inside modal, its required for scroll to work on iOS devices
|
|
1036
|
+
return this.ref.nativeElement.contains(el);
|
|
1037
|
+
}
|
|
1038
|
+
});
|
|
1003
1039
|
}
|
|
1004
1040
|
else {
|
|
1005
1041
|
this.disableFocusTrap();
|
|
@@ -1054,10 +1090,10 @@ class NggModalComponent {
|
|
|
1054
1090
|
}
|
|
1055
1091
|
}
|
|
1056
1092
|
NggModalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: NggModalComponent, deps: [{ token: i0.ElementRef }, { token: i1$1.ConfigurableFocusTrapFactory }], target: i0.ɵɵFactoryTarget.Component });
|
|
1057
|
-
NggModalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: NggModalComponent, selector: "ngg-modal", inputs: { modalType: "modalType", header: "header", confirmLabel: "confirmLabel", dismissLabel: "dismissLabel", size: "size", trapFocus: "trapFocus", isOpen: "isOpen" }, outputs: { isOpenChange: "isOpenChange", closed: "closed", confirm: "confirm", dismiss: "dismiss" }, host: { properties: { "class.open": "this.open" } }, viewQueries: [{ propertyName: "backdropRef", first: true, predicate: ["backdrop"], descendants: true }], ngImport: i0, template: "<ng-container *ngIf=\"isOpen\" [ngSwitch]=\"modalType\">\n <aside data-testid=\"modal\" *ngSwitchCase=\"'slideout'\" role=\"dialog\" aria-modal=\"true\" [class.small]=\"size === 'sm'\" [class.medium]=\"size === 'md'\" [class.large]=\"size === 'lg'\">\n <
|
|
1093
|
+
NggModalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: NggModalComponent, selector: "ngg-modal", inputs: { modalType: "modalType", header: "header", confirmLabel: "confirmLabel", dismissLabel: "dismissLabel", size: "size", hideHeader: "hideHeader", hideFooter: "hideFooter", trapFocus: "trapFocus", isOpen: "isOpen" }, outputs: { isOpenChange: "isOpenChange", closed: "closed", confirm: "confirm", dismiss: "dismiss" }, host: { properties: { "class.open": "this.open" } }, queries: [{ propertyName: "modalHeaderContent", first: true, predicate: NggModalHeaderDirective, descendants: true }, { propertyName: "modalFooterContent", first: true, predicate: NggModalFooterDirective, descendants: true }], viewQueries: [{ propertyName: "backdropRef", first: true, predicate: ["backdrop"], descendants: true }], ngImport: i0, template: "<ng-container *ngIf=\"isOpen\" [ngSwitch]=\"modalType\">\n <aside data-testid=\"modal\" *ngSwitchCase=\"'slideout'\" role=\"dialog\" aria-modal=\"true\" [class.small]=\"size === 'sm'\" [class.medium]=\"size === 'md'\" [class.large]=\"size === 'lg'\">\n <ng-container *ngTemplateOutlet=\"contentTemplate\"></ng-container>\n </aside>\n <main data-testid=\"modal\" *ngSwitchCase=\"'takeover'\" role=\"dialog\" aria-modal=\"true\">\n <ng-container *ngTemplateOutlet=\"contentTemplate\"></ng-container>\n </main>\n <section data-testid=\"modal\" *ngSwitchDefault role=\"dialog\" aria-modal=\"true\" [class.small]=\"size === 'sm'\" [class.medium]=\"size === 'md'\" [class.large]=\"size === 'lg'\">\n <ng-container *ngTemplateOutlet=\"contentTemplate\"></ng-container>\n </section>\n <ng-template #contentTemplate>\n <ng-container *ngIf=\"!hideHeader\">\n <header *ngIf=\"!modalHeaderContent; else headerContentTemplate\" ngg-modal-header data-testid=\"modal-header\" [header]=\"header\" (closed)=\"this.handleCloseClick($event)\"></header>\n </ng-container>\n <div ngg-modal-body data-testid=\"modal-body\" class=\"body\">\n <ng-container *ngTemplateOutlet=\"bodyContentTemplate\"></ng-container>\n </div>\n <ng-container *ngIf=\"!hideFooter && (dismissLabel || confirmLabel)\">\n <footer *ngIf=\"!modalFooterContent; else footerContentTemplate\" ngg-modal-footer data-testid=\"modal-footer\" [dismissLabel]=\"dismissLabel\" [confirmLabel]=\"confirmLabel\" (dismiss)=\"this.handleDismiss($event)\" (confirm)=\"this.handleConfirm($event)\"></footer>\n </ng-container>\n </ng-template>\n <ng-template #headerContentTemplate>\n <header data-testid=\"modal-header\">\n <ng-content select=\"[nggModalHeader]\"></ng-content>\n </header>\n </ng-template>\n <ng-template #bodyContentTemplate>\n <ng-content></ng-content>\n </ng-template>\n <ng-template #footerContentTemplate>\n <footer data-testid=\"modal-footer\">\n <ng-content select=\"[nggModalFooter]\"></ng-content>\n </footer>\n </ng-template>\n <div #backdrop data-testid=\"modal-backdrop\" class=\"backdrop\" (click)=\"this.handleBackdropClick($event)\" [attr.aria-hidden]=\"true\"></div>\n</ng-container>\n", styles: [":host.open{height:100vh;left:0;overflow:hidden;position:fixed;top:0;width:100%;z-index:var(--sg-z-index-modal-backdrop)}:host.open>section[role=dialog]{left:50%;top:50%;transform:translate(-50%,-50%)}.body::-webkit-scrollbar{background-color:#f8f8f8;height:10px;width:10px}.body::-webkit-scrollbar-thumb{background-color:#cecece}.body::-webkit-scrollbar-track{background-color:#f8f8f8;box-shadow:inset 0 0 10px #00000040}\n"], dependencies: [{ kind: "directive", type: i0.forwardRef(function () { return i1.NgIf; }), selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i0.forwardRef(function () { return i1.NgTemplateOutlet; }), selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i0.forwardRef(function () { return i1.NgSwitch; }), selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i0.forwardRef(function () { return i1.NgSwitchCase; }), selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i0.forwardRef(function () { return i1.NgSwitchDefault; }), selector: "[ngSwitchDefault]" }, { kind: "component", type: i0.forwardRef(function () { return NggModalHeaderComponent; }), selector: "[ngg-modal-header]", inputs: ["header"], outputs: ["closed"] }, { kind: "component", type: i0.forwardRef(function () { return NggModalBodyComponent; }), selector: "[ngg-modal-body]" }, { kind: "component", type: i0.forwardRef(function () { return NggModalFooterComponent; }), selector: "[ngg-modal-footer]", inputs: ["dismissLabel", "confirmLabel"], outputs: ["dismiss", "confirm"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
1058
1094
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: NggModalComponent, decorators: [{
|
|
1059
1095
|
type: Component,
|
|
1060
|
-
args: [{ selector: 'ngg-modal', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"isOpen\" [ngSwitch]=\"modalType\">\n <aside data-testid=\"modal\" *ngSwitchCase=\"'slideout'\" role=\"dialog\" aria-modal=\"true\" [class.small]=\"size === 'sm'\" [class.medium]=\"size === 'md'\" [class.large]=\"size === 'lg'\">\n <
|
|
1096
|
+
args: [{ selector: 'ngg-modal', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"isOpen\" [ngSwitch]=\"modalType\">\n <aside data-testid=\"modal\" *ngSwitchCase=\"'slideout'\" role=\"dialog\" aria-modal=\"true\" [class.small]=\"size === 'sm'\" [class.medium]=\"size === 'md'\" [class.large]=\"size === 'lg'\">\n <ng-container *ngTemplateOutlet=\"contentTemplate\"></ng-container>\n </aside>\n <main data-testid=\"modal\" *ngSwitchCase=\"'takeover'\" role=\"dialog\" aria-modal=\"true\">\n <ng-container *ngTemplateOutlet=\"contentTemplate\"></ng-container>\n </main>\n <section data-testid=\"modal\" *ngSwitchDefault role=\"dialog\" aria-modal=\"true\" [class.small]=\"size === 'sm'\" [class.medium]=\"size === 'md'\" [class.large]=\"size === 'lg'\">\n <ng-container *ngTemplateOutlet=\"contentTemplate\"></ng-container>\n </section>\n <ng-template #contentTemplate>\n <ng-container *ngIf=\"!hideHeader\">\n <header *ngIf=\"!modalHeaderContent; else headerContentTemplate\" ngg-modal-header data-testid=\"modal-header\" [header]=\"header\" (closed)=\"this.handleCloseClick($event)\"></header>\n </ng-container>\n <div ngg-modal-body data-testid=\"modal-body\" class=\"body\">\n <ng-container *ngTemplateOutlet=\"bodyContentTemplate\"></ng-container>\n </div>\n <ng-container *ngIf=\"!hideFooter && (dismissLabel || confirmLabel)\">\n <footer *ngIf=\"!modalFooterContent; else footerContentTemplate\" ngg-modal-footer data-testid=\"modal-footer\" [dismissLabel]=\"dismissLabel\" [confirmLabel]=\"confirmLabel\" (dismiss)=\"this.handleDismiss($event)\" (confirm)=\"this.handleConfirm($event)\"></footer>\n </ng-container>\n </ng-template>\n <ng-template #headerContentTemplate>\n <header data-testid=\"modal-header\">\n <ng-content select=\"[nggModalHeader]\"></ng-content>\n </header>\n </ng-template>\n <ng-template #bodyContentTemplate>\n <ng-content></ng-content>\n </ng-template>\n <ng-template #footerContentTemplate>\n <footer data-testid=\"modal-footer\">\n <ng-content select=\"[nggModalFooter]\"></ng-content>\n </footer>\n </ng-template>\n <div #backdrop data-testid=\"modal-backdrop\" class=\"backdrop\" (click)=\"this.handleBackdropClick($event)\" [attr.aria-hidden]=\"true\"></div>\n</ng-container>\n", styles: [":host.open{height:100vh;left:0;overflow:hidden;position:fixed;top:0;width:100%;z-index:var(--sg-z-index-modal-backdrop)}:host.open>section[role=dialog]{left:50%;top:50%;transform:translate(-50%,-50%)}.body::-webkit-scrollbar{background-color:#f8f8f8;height:10px;width:10px}.body::-webkit-scrollbar-thumb{background-color:#cecece}.body::-webkit-scrollbar-track{background-color:#f8f8f8;box-shadow:inset 0 0 10px #00000040}\n"] }]
|
|
1061
1097
|
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1$1.ConfigurableFocusTrapFactory }]; }, propDecorators: { modalType: [{
|
|
1062
1098
|
type: Input
|
|
1063
1099
|
}], header: [{
|
|
@@ -1068,6 +1104,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
1068
1104
|
type: Input
|
|
1069
1105
|
}], size: [{
|
|
1070
1106
|
type: Input
|
|
1107
|
+
}], hideHeader: [{
|
|
1108
|
+
type: Input
|
|
1109
|
+
}], hideFooter: [{
|
|
1110
|
+
type: Input
|
|
1071
1111
|
}], trapFocus: [{
|
|
1072
1112
|
type: Input
|
|
1073
1113
|
}], isOpen: [{
|
|
@@ -1086,6 +1126,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
1086
1126
|
}], backdropRef: [{
|
|
1087
1127
|
type: ViewChild,
|
|
1088
1128
|
args: ['backdrop']
|
|
1129
|
+
}], modalHeaderContent: [{
|
|
1130
|
+
type: ContentChild,
|
|
1131
|
+
args: [NggModalHeaderDirective]
|
|
1132
|
+
}], modalFooterContent: [{
|
|
1133
|
+
type: ContentChild,
|
|
1134
|
+
args: [NggModalFooterDirective]
|
|
1089
1135
|
}] } });
|
|
1090
1136
|
class NggModalHeaderComponent {
|
|
1091
1137
|
constructor() {
|
|
@@ -1162,10 +1208,14 @@ const DECLARATIONS = [
|
|
|
1162
1208
|
NggModalComponent,
|
|
1163
1209
|
NggModalHeaderComponent,
|
|
1164
1210
|
NggModalBodyComponent,
|
|
1165
|
-
NggModalFooterComponent
|
|
1211
|
+
NggModalFooterComponent,
|
|
1212
|
+
NggModalHeaderDirective,
|
|
1213
|
+
NggModalFooterDirective
|
|
1166
1214
|
];
|
|
1167
1215
|
const EXPORTS = [
|
|
1168
1216
|
NggModalComponent,
|
|
1217
|
+
NggModalHeaderDirective,
|
|
1218
|
+
NggModalFooterDirective
|
|
1169
1219
|
];
|
|
1170
1220
|
class NggModalModule {
|
|
1171
1221
|
}
|
|
@@ -1173,7 +1223,11 @@ NggModalModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version:
|
|
|
1173
1223
|
NggModalModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.3.0", ngImport: i0, type: NggModalModule, declarations: [NggModalComponent,
|
|
1174
1224
|
NggModalHeaderComponent,
|
|
1175
1225
|
NggModalBodyComponent,
|
|
1176
|
-
NggModalFooterComponent
|
|
1226
|
+
NggModalFooterComponent,
|
|
1227
|
+
NggModalHeaderDirective,
|
|
1228
|
+
NggModalFooterDirective], imports: [A11yModule, CommonModule], exports: [NggModalComponent,
|
|
1229
|
+
NggModalHeaderDirective,
|
|
1230
|
+
NggModalFooterDirective] });
|
|
1177
1231
|
NggModalModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: NggModalModule, imports: [A11yModule, CommonModule] });
|
|
1178
1232
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: NggModalModule, decorators: [{
|
|
1179
1233
|
type: NgModule,
|
|
@@ -1652,5 +1706,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
1652
1706
|
* Generated bundle index. Do not edit.
|
|
1653
1707
|
*/
|
|
1654
1708
|
|
|
1655
|
-
export { NggAccordionComponent, NggAccordionListItemComponent, NggAccordionModule, NggBadgeComponent, NggBadgeModule, NggButtonComponent, NggButtonModule, NggContextMenuComponent, NggContextMenuModule, NggDatepickerComponent, NggDatepickerModule, NggDropdownButtonDirective, NggDropdownComponent, NggDropdownModule, NggDropdownOptionDirective, NggInPageWizardModule, NggInPageWizardStepCardComponent, NggModalBodyComponent, NggModalComponent, NggModalFooterComponent, NggModalHeaderComponent, NggModalModule, NggModule, NggOnScrollDirective, NggPaginationComponent, NggPaginationModule, NggProgressCircleComponent, NggProgressCircleModule, NggSegmentedControlComponent, NggSegmentedControlModule, NggSharedModule, NggSliderComponent, NggSliderModule, ON_SCROLL_TOKEN, dateValidator };
|
|
1709
|
+
export { NggAccordionComponent, NggAccordionListItemComponent, NggAccordionModule, NggBadgeComponent, NggBadgeModule, NggButtonComponent, NggButtonModule, NggContextMenuComponent, NggContextMenuModule, NggDatepickerComponent, NggDatepickerModule, NggDropdownButtonDirective, NggDropdownComponent, NggDropdownModule, NggDropdownOptionDirective, NggInPageWizardModule, NggInPageWizardStepCardComponent, NggModalBodyComponent, NggModalComponent, NggModalFooterComponent, NggModalFooterDirective, NggModalHeaderComponent, NggModalHeaderDirective, NggModalModule, NggModule, NggOnScrollDirective, NggPaginationComponent, NggPaginationModule, NggProgressCircleComponent, NggProgressCircleModule, NggSegmentedControlComponent, NggSegmentedControlModule, NggSharedModule, NggSliderComponent, NggSliderModule, ON_SCROLL_TOKEN, dateValidator };
|
|
1656
1710
|
//# sourceMappingURL=sebgroup-green-angular.mjs.map
|