@impartner/design-components 1.0.2 → 1.0.4

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.
@@ -46,7 +46,6 @@ export class DropdownComponent {
46
46
  */
47
47
  this.buttonClick = new EventEmitter();
48
48
  this.classBtnGroup = true;
49
- this._interactableId = this._interactionService.add(this);
50
49
  }
51
50
  get classDropdown() {
52
51
  return this.position === 'down';
@@ -77,6 +76,9 @@ export class DropdownComponent {
77
76
  get shown() {
78
77
  return this.valid && this.show;
79
78
  }
79
+ ngOnInit() {
80
+ this._interactableId = this._interactionService.add(this);
81
+ }
80
82
  ngOnDestroy() {
81
83
  this._interactionService.remove(this.interactableId);
82
84
  this._interactableId = 0;
@@ -137,4 +139,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
137
139
  type: HostListener,
138
140
  args: ['document:click']
139
141
  }] } });
140
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.component.js","sourceRoot":"","sources":["../../../../../../projects/design-components/src/lib/dropdown/dropdown.component.ts","../../../../../../projects/design-components/src/lib/dropdown/dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  HostListener,\n  Output,\n  EventEmitter,\n  HostBinding,\n  QueryList,\n  ContentChildren,\n  OnDestroy\n} from '@angular/core';\nimport { InteractionService } from '../../services';\nimport { ButtonTheme } from '../button';\nimport { DropdownItemComponent } from './components';\nimport { DropdownPosition } from './types';\n\n/**\n * The `DropdownComponent` (`<impdc-dropdown` or `<any impdc-dropdown`) contains a button that toggles a dropdown where a user\n * can select various actions. Items within must be wrapped with `DropdownItemComponent` (`<impdc-dropdown-item`).\n * To use, import `DropdownModule` or another module that imports and exports that module from `@impartner/design-components`.\n * `DropdownModule` imports and exports [ButtonModule](./?path=/docs/design-components-button).\n */\n@Component({\n  selector: 'impdc-dropdown, [impdc-dropdown]',\n  templateUrl: './dropdown.component.html',\n  styleUrls: ['./dropdown.component.scss']\n})\nexport class DropdownComponent implements OnDestroy {\n  private _interactableId = 0;\n\n  /**\n   * Whether or not the dropdown list is showing.\n   */\n  @Input()\n  show = false;\n\n  /**\n   * The content projected `DropdownItemComponent` children.\n   */\n  @ContentChildren(DropdownItemComponent)\n  items!: QueryList<DropdownItemComponent>;\n\n  /**\n   * The theme of the button affecting text, icons, backgrounds, and borders.\n   */\n  @Input()\n  buttonTheme: ButtonTheme = 'primary';\n\n  /**\n   * The text of the button.\n   */\n  @Input()\n  buttonText = '';\n\n  // we don't want headerText to be available right now\n  // @Input()\n  //headerText: string = '';\n\n  /**\n   * Where the list shows relative to the button when it is showing.\n   */\n  @Input()\n  position: DropdownPosition = 'down';\n\n  /**\n   * If true, the icon is split from the button and only clicking the icon triggers the list showing/hiding.\n   */\n  @Input()\n  split = false;\n\n  /**\n   * Emitted when the dropdown is toggled.\n   */\n  @Output()\n  toggle = new EventEmitter<boolean>();\n\n  /**\n   * Emitted when the button is clicked.\n   */\n  @Output()\n  public buttonClick = new EventEmitter<MouseEvent>();\n\n  @HostBinding('class.btn-group') private classBtnGroup = true;\n\n  @HostBinding('class.dropdown') private get classDropdown() {\n    return this.position === 'down';\n  }\n\n  @HostBinding('class.dropend') private get classDropend() {\n    return this.position === 'right';\n  }\n\n  @HostBinding('class.dropstart') private get classDropstart() {\n    return this.position === 'left';\n  }\n\n  @HostBinding('class.dropup') private get classDropup() {\n    return this.position === 'up';\n  }\n\n  @HostListener('click')\n  handleHostClick($event: MouseEvent): void {\n    $event.stopPropagation();\n  }\n\n  @HostListener('document:click')\n  handleDocumentClick(): void {\n    if (this.show) {\n      this.hide();\n    }\n  }\n\n  get interactableId(): number {\n    return this._interactableId;\n  }\n\n  get valid(): boolean {\n    return this.interactableId > 0;\n  }\n\n  get shown(): boolean {\n    return this.valid && this.show;\n  }\n\n  constructor(private _interactionService: InteractionService) {\n    this._interactableId = this._interactionService.add(this);\n  }\n\n  ngOnDestroy(): void {\n    this._interactionService.remove(this.interactableId);\n    this._interactableId = 0;\n  }\n\n  handleToggle(): void {\n    this.show = this._interactionService.toggle(this);\n    this.toggle.emit(this.show);\n  }\n\n  handleButtonClick(event: MouseEvent): void {\n    this.buttonClick.emit(event);\n  }\n\n  hide(): void {\n    this.show = false;\n    this.toggle.emit(this.show);\n  }\n}\n","<ng-container *ngIf=\"!linkEl.children.length\">\n  <button\n    *ngIf=\"!split; else splitTemplate\"\n    impdcButton\n    [theme]=\"buttonTheme\"\n    [text]=\"buttonText\"\n    class=\"dropdown-toggle\"\n    [class.show]=\"show\"\n    data-bs-toggle=\"dropdown\"\n    [attr.aria-expanded]=\"show\"\n    (click)=\"handleToggle(); $event.stopPropagation()\"></button>\n\n  <ng-template #splitTemplate>\n    <button\n      impdcButton\n      [theme]=\"buttonTheme\"\n      [text]=\"buttonText\"\n      (click)=\"handleButtonClick($event)\"></button>\n    <button\n      impdcButton\n      [theme]=\"buttonTheme\"\n      class=\"dropdown-toggle dropdown-toggle-split\"\n      [class.show]=\"show\"\n      [attr.aria-expanded]=\"show\"\n      (click)=\"handleToggle(); $event.stopPropagation()\">\n      <span class=\"visually-hidden\">Toggle Dropdown</span>\n    </button>\n  </ng-template>\n</ng-container>\n\n<ul\n  class=\"dropdown-menu\"\n  [class.dropdown-menu-end]=\"false\"\n  [class.show]=\"show\"\n  (click)=\"$event.stopPropagation()\">\n  <!-- <li *ngIf=\"headerText\">\n    <h6 class=\"dropdown-header\">{{ headerText }}</h6>\n  </li> -->\n  <li *ngFor=\"let item of items\">\n    <span *ngIf=\"!item.divider; else dividerTemplate\" class=\"dropdown-item\">\n      <ng-content *ngTemplateOutlet=\"item.template\"></ng-content>\n    </span>\n  </li>\n</ul>\n\n<ng-template #dividerTemplate>\n  <hr class=\"dropdown-divider\" />\n</ng-template>\n\n<a\n  #linkEl\n  class=\"impdc-dropdown-link\"\n  [class.hide]=\"!linkEl.children.length\"\n  [class.impdc-dropdown-open]=\"show\"\n  data-bs-toggle=\"dropdown\"\n  [attr.aria-expanded]=\"show\"\n  (click)=\"handleToggle(); $event.stopPropagation()\">\n  <ng-content select=\"[toggle]\"></ng-content>\n</a>\n"]}
142
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.component.js","sourceRoot":"","sources":["../../../../../../projects/design-components/src/lib/dropdown/dropdown.component.ts","../../../../../../projects/design-components/src/lib/dropdown/dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  HostListener,\n  Output,\n  EventEmitter,\n  HostBinding,\n  QueryList,\n  ContentChildren,\n  OnInit,\n  OnDestroy\n} from '@angular/core';\nimport { InteractionService } from '../../services';\nimport { ButtonTheme } from '../button';\nimport { DropdownItemComponent } from './components';\nimport { DropdownPosition } from './types';\n\n/**\n * The `DropdownComponent` (`<impdc-dropdown` or `<any impdc-dropdown`) contains a button that toggles a dropdown where a user\n * can select various actions. Items within must be wrapped with `DropdownItemComponent` (`<impdc-dropdown-item`).\n * To use, import `DropdownModule` or another module that imports and exports that module from `@impartner/design-components`.\n * `DropdownModule` imports and exports [ButtonModule](./?path=/docs/design-components-button).\n */\n@Component({\n  selector: 'impdc-dropdown, [impdc-dropdown]',\n  templateUrl: './dropdown.component.html',\n  styleUrls: ['./dropdown.component.scss']\n})\nexport class DropdownComponent implements OnInit, OnDestroy {\n  private _interactableId = 0;\n\n  /**\n   * Whether or not the dropdown list is showing.\n   */\n  @Input()\n  show = false;\n\n  /**\n   * The content projected `DropdownItemComponent` children.\n   */\n  @ContentChildren(DropdownItemComponent)\n  items!: QueryList<DropdownItemComponent>;\n\n  /**\n   * The theme of the button affecting text, icons, backgrounds, and borders.\n   */\n  @Input()\n  buttonTheme: ButtonTheme = 'primary';\n\n  /**\n   * The text of the button.\n   */\n  @Input()\n  buttonText = '';\n\n  // we don't want headerText to be available right now\n  // @Input()\n  //headerText: string = '';\n\n  /**\n   * Where the list shows relative to the button when it is showing.\n   */\n  @Input()\n  position: DropdownPosition = 'down';\n\n  /**\n   * If true, the icon is split from the button and only clicking the icon triggers the list showing/hiding.\n   */\n  @Input()\n  split = false;\n\n  /**\n   * Emitted when the dropdown is toggled.\n   */\n  @Output()\n  toggle = new EventEmitter<boolean>();\n\n  /**\n   * Emitted when the button is clicked.\n   */\n  @Output()\n  public buttonClick = new EventEmitter<MouseEvent>();\n\n  @HostBinding('class.btn-group') private classBtnGroup = true;\n\n  @HostBinding('class.dropdown') private get classDropdown() {\n    return this.position === 'down';\n  }\n\n  @HostBinding('class.dropend') private get classDropend() {\n    return this.position === 'right';\n  }\n\n  @HostBinding('class.dropstart') private get classDropstart() {\n    return this.position === 'left';\n  }\n\n  @HostBinding('class.dropup') private get classDropup() {\n    return this.position === 'up';\n  }\n\n  @HostListener('click')\n  handleHostClick($event: MouseEvent): void {\n    $event.stopPropagation();\n  }\n\n  @HostListener('document:click')\n  handleDocumentClick(): void {\n    if (this.show) {\n      this.hide();\n    }\n  }\n\n  constructor(private _interactionService: InteractionService) {}\n\n  get interactableId(): number {\n    return this._interactableId;\n  }\n\n  get valid(): boolean {\n    return this.interactableId > 0;\n  }\n\n  get shown(): boolean {\n    return this.valid && this.show;\n  }\n\n  ngOnInit(): void {\n    this._interactableId = this._interactionService.add(this);\n  }\n\n  ngOnDestroy(): void {\n    this._interactionService.remove(this.interactableId);\n    this._interactableId = 0;\n  }\n\n  handleToggle(): void {\n    this.show = this._interactionService.toggle(this);\n    this.toggle.emit(this.show);\n  }\n\n  handleButtonClick(event: MouseEvent): void {\n    this.buttonClick.emit(event);\n  }\n\n  hide(): void {\n    this.show = false;\n    this.toggle.emit(this.show);\n  }\n}\n","<ng-container *ngIf=\"!linkEl.children.length\">\n  <button\n    *ngIf=\"!split; else splitTemplate\"\n    impdcButton\n    [theme]=\"buttonTheme\"\n    [text]=\"buttonText\"\n    class=\"dropdown-toggle\"\n    [class.show]=\"show\"\n    data-bs-toggle=\"dropdown\"\n    [attr.aria-expanded]=\"show\"\n    (click)=\"handleToggle(); $event.stopPropagation()\"></button>\n\n  <ng-template #splitTemplate>\n    <button\n      impdcButton\n      [theme]=\"buttonTheme\"\n      [text]=\"buttonText\"\n      (click)=\"handleButtonClick($event)\"></button>\n    <button\n      impdcButton\n      [theme]=\"buttonTheme\"\n      class=\"dropdown-toggle dropdown-toggle-split\"\n      [class.show]=\"show\"\n      [attr.aria-expanded]=\"show\"\n      (click)=\"handleToggle(); $event.stopPropagation()\">\n      <span class=\"visually-hidden\">Toggle Dropdown</span>\n    </button>\n  </ng-template>\n</ng-container>\n\n<ul\n  class=\"dropdown-menu\"\n  [class.dropdown-menu-end]=\"false\"\n  [class.show]=\"show\"\n  (click)=\"$event.stopPropagation()\">\n  <!-- <li *ngIf=\"headerText\">\n    <h6 class=\"dropdown-header\">{{ headerText }}</h6>\n  </li> -->\n  <li *ngFor=\"let item of items\">\n    <span *ngIf=\"!item.divider; else dividerTemplate\" class=\"dropdown-item\">\n      <ng-content *ngTemplateOutlet=\"item.template\"></ng-content>\n    </span>\n  </li>\n</ul>\n\n<ng-template #dividerTemplate>\n  <hr class=\"dropdown-divider\" />\n</ng-template>\n\n<a\n  #linkEl\n  class=\"impdc-dropdown-link\"\n  [class.hide]=\"!linkEl.children.length\"\n  [class.impdc-dropdown-open]=\"show\"\n  data-bs-toggle=\"dropdown\"\n  [attr.aria-expanded]=\"show\"\n  (click)=\"handleToggle(); $event.stopPropagation()\">\n  <ng-content select=\"[toggle]\"></ng-content>\n</a>\n"]}
@@ -58,13 +58,17 @@ export class ModalComponent {
58
58
  * Event emitted when the Modal content is accepted.
59
59
  */
60
60
  this.accept = new EventEmitter();
61
- this._interactableId = this._interactionService.add(this);
62
61
  }
63
62
  /**
64
63
  * Determines if the Modal should be shown immediately.
65
64
  */
66
65
  set show(show) {
67
- this._show = show;
66
+ if (show) {
67
+ this.open();
68
+ }
69
+ else {
70
+ this.close();
71
+ }
68
72
  }
69
73
  get interactableId() {
70
74
  return this._interactableId;
@@ -88,6 +92,7 @@ export class ModalComponent {
88
92
  return !this.titleText && !this.dismissable;
89
93
  }
90
94
  ngOnInit() {
95
+ this._interactableId = this._interactionService.add(this);
91
96
  if (this.dismissable === undefined && this.theme === ModalTheme.Working) {
92
97
  this.dismissable = true;
93
98
  }
@@ -104,35 +109,38 @@ export class ModalComponent {
104
109
  !!this.dismissEl?.nativeElement?.firstChild?.disabled) {
105
110
  return;
106
111
  }
107
- this._show = false;
112
+ this.close();
108
113
  this.dismiss.emit(event);
109
114
  }
110
115
  handleDeny(event) {
111
116
  if (!!this.denyEl?.nativeElement?.firstChild?.disabled) {
112
117
  return;
113
118
  }
114
- this._show = false;
119
+ this.close();
115
120
  this.deny.emit(event);
116
121
  }
117
122
  handleAccept(event) {
118
- console.log('this.acceptEl', this.acceptEl);
119
123
  if (!!this.acceptEl?.nativeElement?.firstChild?.disabled) {
120
124
  return;
121
125
  }
122
- this._show = false;
126
+ this.close();
123
127
  this.accept.emit(event);
124
128
  }
125
129
  /**
126
- * Opens/shows the modal programmatically.
130
+ * Opens/shows the modal. Can be used programmatically.
127
131
  */
128
132
  open() {
133
+ if (this.backdrop) {
134
+ this._interactionService.queueBackdrop(this.interactableId);
135
+ }
129
136
  this._show = true;
130
137
  }
131
138
  /**
132
- * Closes/hides the modal programmatically.
139
+ * Closes/hides the modal. Can be used programmatically.
133
140
  */
134
141
  close() {
135
142
  this._show = false;
143
+ this._interactionService.dequeueBackdrop(this.interactableId);
136
144
  }
137
145
  }
138
146
  ModalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: ModalComponent, deps: [{ token: i1.InteractionService }], target: i0.ɵɵFactoryTarget.Component });
@@ -176,4 +184,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
176
184
  }], accept: [{
177
185
  type: Output
178
186
  }] } });
179
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.component.js","sourceRoot":"","sources":["../../../../../../projects/design-components/src/lib/modal/modal.component.ts","../../../../../../projects/design-components/src/lib/modal/modal.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewChild\n} from '@angular/core';\nimport { FontAwesomeIcon, FontAwesomeIconTheme } from '../../constants';\nimport { InteractionService } from '../../services';\nimport { ComponentSize } from '../../types';\nimport { ButtonTheme } from '../button';\nimport { ModalComponentSizes, ModalTheme, ModalThemes } from './types';\n\n/**\n * The `ModalComponent` (`<impdc-modal`) displays over the content of the page when a user action is required.\n * To use, import `ModalModule` or another module that imports and exports that module from `@impartner/design-components`.\n * `ModalModule` imports and exports BackdropModule, [ButtonModule](./?path=/docs/design-components-button),\n * and [IconModule](./?path=/docs/design-components-icon).\n */\n@Component({\n  selector: 'impdc-modal',\n  templateUrl: './modal.component.html',\n  styleUrls: ['./modal.component.scss']\n})\nexport class ModalComponent implements OnInit, OnDestroy {\n  private _interactableId = 0;\n  private _show = false;\n\n  /**\n   * Determines if the Modal should be shown immediately.\n   */\n  @Input()\n  set show(show: boolean) {\n    this._show = show;\n  }\n\n  /**\n   * The theme of the Modal. Affects the layout of the Modal as well as some colors.\n   */\n  @Input()\n  theme: ModalThemes = ModalTheme.Simple;\n\n  /**\n   * The size of the Modal.\n   */\n  @Input()\n  size: ModalComponentSizes = ComponentSize.Medium;\n\n  /**\n   * The Font Awesome 5 icon name. Only supported when the theme is Working or Destructive.\n   */\n  @Input()\n  iconName?: FontAwesomeIcon;\n\n  /**\n   * The Font Awesome 5 icon style. Fewer icons support the Regular theme and will fallback to Solid\n   * if not supported.\n   */\n  @Input()\n  iconTheme: FontAwesomeIconTheme = 'light';\n\n  /**\n   * The subject text of the Modal.\n   */\n  @Input()\n  titleText = '';\n\n  /**\n   * The fallback button text to accept the Modal. This is bypassed if you content-project the accept button.\n   */\n  @Input()\n  acceptText = 'OK';\n\n  /**\n   * Allows the Modal to be dismissed. This is different from `accept` and `deny`. If a Modal is meant to be re-opened frequently it should be dismissable.\n   */\n  @Input()\n  dismissable?: boolean;\n\n  /**\n   * Determines if the Modal should fade in/out.\n   */\n  @Input()\n  fade = true;\n\n  /**\n   * Shows a backdrop behind the Modal.\n   */\n  @Input()\n  backdrop = true;\n\n  /**\n   * Contains the dismiss button content projection.\n   */\n  @ViewChild('dismissEl', { static: false })\n  dismissEl!: ElementRef;\n\n  /**\n   * Contains the deny button content projection.\n   */\n  @ViewChild('denyEl', { static: false })\n  denyEl!: ElementRef;\n\n  /**\n   * Contains the accept button content projection.\n   */\n  @ViewChild('acceptEl', { static: false })\n  acceptEl!: ElementRef;\n\n  /**\n   * Event emitted when the Modal content is dismissed.\n   */\n  @Output()\n  dismiss = new EventEmitter<MouseEvent | Event>();\n\n  /**\n   * Event emitted when the Modal content is denied.\n   */\n  @Output()\n  deny = new EventEmitter<MouseEvent | Event>();\n\n  /**\n   * Event emitted when the Modal content is accepted.\n   */\n  @Output()\n  accept = new EventEmitter<MouseEvent | Event>();\n\n  constructor(private _interactionService: InteractionService) {\n    this._interactableId = this._interactionService.add(this);\n  }\n\n  get interactableId(): number {\n    return this._interactableId;\n  }\n\n  get valid(): boolean {\n    return this.interactableId > 0;\n  }\n\n  get shown(): boolean {\n    return this.valid && this._show;\n  }\n\n  get showWorkingIcon(): boolean {\n    return !!this.iconName && this.theme === ModalTheme.Working;\n  }\n\n  get showDestructiveIcon(): boolean {\n    return !!this.iconName && this.theme === ModalTheme.Destructive;\n  }\n\n  get acceptFallbackTheme(): ButtonTheme {\n    return this.theme === ModalTheme.Destructive ? 'danger' : 'primary';\n  }\n\n  get hideHeader(): boolean {\n    return !this.titleText && !this.dismissable;\n  }\n\n  ngOnInit(): void {\n    if (this.dismissable === undefined && this.theme === ModalTheme.Working) {\n      this.dismissable = true;\n    }\n\n    if (this.iconName === undefined && this.theme === ModalTheme.Destructive) {\n      this.iconName = 'exclamation-triangle';\n    }\n  }\n\n  ngOnDestroy(): void {\n    this._interactionService.remove(this.interactableId);\n    this._interactableId = 0;\n  }\n\n  protected handleDismiss(event: MouseEvent | Event): void {\n    if (\n      !this.dismissable ||\n      !!this.dismissEl?.nativeElement?.firstChild?.disabled\n    ) {\n      return;\n    }\n    this._show = false;\n    this.dismiss.emit(event);\n  }\n\n  protected handleDeny(event: MouseEvent | Event): void {\n    if (!!this.denyEl?.nativeElement?.firstChild?.disabled) {\n      return;\n    }\n    this._show = false;\n    this.deny.emit(event);\n  }\n\n  protected handleAccept(event: MouseEvent | Event): void {\n    console.log('this.acceptEl', this.acceptEl);\n    if (!!this.acceptEl?.nativeElement?.firstChild?.disabled) {\n      return;\n    }\n    this._show = false;\n    this.accept.emit(event);\n  }\n\n  /**\n   * Opens/shows the modal programmatically.\n   */\n  open(): void {\n    this._show = true;\n  }\n\n  /**\n   * Closes/hides the modal programmatically.\n   */\n  close(): void {\n    this._show = false;\n  }\n}\n","<div\n  *ngIf=\"valid\"\n  class=\"impdc modal\"\n  [class.fade]=\"fade\"\n  [class.in]=\"fade && shown\"\n  [class.show]=\"shown\"\n  [class.dismissable]=\"dismissable\"\n  tabindex=\"-1\"\n  (click)=\"handleDismiss($event); $event.stopPropagation()\"\n  (keydown.escape)=\"handleDismiss($event); $event.stopPropagation()\"\n  (keydown.enter)=\"handleAccept($event); $event.stopPropagation()\">\n  <div\n    class=\"modal-dialog modal-dialog-centered modal-dialog-scrollable modal-theme-{{\n      theme\n    }}\"\n    [class.modal-sm]=\"size === 'sm'\"\n    [class.modal-lg]=\"size === 'lg'\"\n    [class.modal-xl]=\"size === 'xl'\"\n    [class.modal-fullscreen]=\"size === 'fs'\"\n    [class.modal-fullscreen-lg-down]=\"size !== 'fs'\"\n    (click)=\"$event.stopPropagation()\">\n    <div class=\"modal-content\">\n      <div *ngIf=\"showDestructiveIcon\" class=\"modal-icon\">\n        <span impdc-icon [name]=\"iconName\" [theme]=\"iconTheme\"></span>\n      </div>\n      <div #header class=\"modal-header\" [class.hide]=\"hideHeader\">\n        <h3 class=\"modal-title\">\n          <span *ngIf=\"showWorkingIcon\" class=\"modal-icon\">\n            <span impdc-icon [name]=\"iconName\" [theme]=\"iconTheme\"></span>\n          </span>\n          <span>{{ titleText }}</span>\n        </h3>\n        <button\n          impdcButton\n          *ngIf=\"dismissable\"\n          theme=\"close\"\n          (click)=\"handleDismiss($event); $event.stopPropagation()\"></button>\n      </div>\n      <div #bodyEl class=\"modal-body\">\n        <ng-content></ng-content>\n      </div>\n      <div #footer class=\"modal-footer\">\n        <span\n          #dismissEl\n          *ngIf=\"dismissable\"\n          [class.hide]=\"!dismissEl.children.length\"\n          (click)=\"handleDismiss($event); $event.stopPropagation()\">\n          <ng-content select=\"[dismiss]\"></ng-content>\n        </span>\n        <span\n          #denyEl\n          [class.hide]=\"!denyEl.children.length\"\n          (click)=\"handleDeny($event); $event.stopPropagation()\">\n          <ng-content select=\"[deny]\"></ng-content>\n        </span>\n        <span\n          #acceptEl\n          [class.hide]=\"!acceptEl.children.length\"\n          (click)=\"handleAccept($event); $event.stopPropagation()\">\n          <ng-content select=\"[accept]\"></ng-content>\n        </span>\n        <span\n          #acceptFallbackEl\n          *ngIf=\"!acceptEl.children.length\"\n          (click)=\"handleAccept($event); $event.stopPropagation()\">\n          <button\n            impdcButton\n            [text]=\"acceptText\"\n            [theme]=\"acceptFallbackTheme\"></button>\n        </span>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
187
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.component.js","sourceRoot":"","sources":["../../../../../../projects/design-components/src/lib/modal/modal.component.ts","../../../../../../projects/design-components/src/lib/modal/modal.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewChild\n} from '@angular/core';\nimport { FontAwesomeIcon, FontAwesomeIconTheme } from '../../constants';\nimport { InteractionService } from '../../services';\nimport { ComponentSize } from '../../types';\nimport { ButtonTheme } from '../button';\nimport { ModalComponentSizes, ModalTheme, ModalThemes } from './types';\n\n/**\n * The `ModalComponent` (`<impdc-modal`) displays over the content of the page when a user action is required.\n * To use, import `ModalModule` or another module that imports and exports that module from `@impartner/design-components`.\n * `ModalModule` imports and exports BackdropModule, [ButtonModule](./?path=/docs/design-components-button),\n * and [IconModule](./?path=/docs/design-components-icon).\n */\n@Component({\n  selector: 'impdc-modal',\n  templateUrl: './modal.component.html',\n  styleUrls: ['./modal.component.scss']\n})\nexport class ModalComponent implements OnInit, OnDestroy {\n  private _interactableId = 0;\n  private _show = false;\n\n  /**\n   * Determines if the Modal should be shown immediately.\n   */\n  @Input()\n  set show(show: boolean) {\n    if (show) {\n      this.open();\n    } else {\n      this.close();\n    }\n  }\n\n  /**\n   * The theme of the Modal. Affects the layout of the Modal as well as some colors.\n   */\n  @Input()\n  theme: ModalThemes = ModalTheme.Simple;\n\n  /**\n   * The size of the Modal.\n   */\n  @Input()\n  size: ModalComponentSizes = ComponentSize.Medium;\n\n  /**\n   * The Font Awesome 5 icon name. Only supported when the theme is Working or Destructive.\n   */\n  @Input()\n  iconName?: FontAwesomeIcon;\n\n  /**\n   * The Font Awesome 5 icon style. Fewer icons support the Regular theme and will fallback to Solid\n   * if not supported.\n   */\n  @Input()\n  iconTheme: FontAwesomeIconTheme = 'light';\n\n  /**\n   * The subject text of the Modal.\n   */\n  @Input()\n  titleText = '';\n\n  /**\n   * The fallback button text to accept the Modal. This is bypassed if you content-project the accept button.\n   */\n  @Input()\n  acceptText = 'OK';\n\n  /**\n   * Allows the Modal to be dismissed. This is different from `accept` and `deny`. If a Modal is meant to be re-opened frequently it should be dismissable.\n   */\n  @Input()\n  dismissable?: boolean;\n\n  /**\n   * Determines if the Modal should fade in/out.\n   */\n  @Input()\n  fade = true;\n\n  /**\n   * Shows a backdrop behind the Modal.\n   */\n  @Input()\n  backdrop = true;\n\n  /**\n   * Contains the dismiss button content projection.\n   */\n  @ViewChild('dismissEl', { static: false })\n  dismissEl!: ElementRef;\n\n  /**\n   * Contains the deny button content projection.\n   */\n  @ViewChild('denyEl', { static: false })\n  denyEl!: ElementRef;\n\n  /**\n   * Contains the accept button content projection.\n   */\n  @ViewChild('acceptEl', { static: false })\n  acceptEl!: ElementRef;\n\n  /**\n   * Event emitted when the Modal content is dismissed.\n   */\n  @Output()\n  dismiss = new EventEmitter<MouseEvent | Event>();\n\n  /**\n   * Event emitted when the Modal content is denied.\n   */\n  @Output()\n  deny = new EventEmitter<MouseEvent | Event>();\n\n  /**\n   * Event emitted when the Modal content is accepted.\n   */\n  @Output()\n  accept = new EventEmitter<MouseEvent | Event>();\n\n  constructor(private _interactionService: InteractionService) {}\n\n  get interactableId(): number {\n    return this._interactableId;\n  }\n\n  get valid(): boolean {\n    return this.interactableId > 0;\n  }\n\n  get shown(): boolean {\n    return this.valid && this._show;\n  }\n\n  get showWorkingIcon(): boolean {\n    return !!this.iconName && this.theme === ModalTheme.Working;\n  }\n\n  get showDestructiveIcon(): boolean {\n    return !!this.iconName && this.theme === ModalTheme.Destructive;\n  }\n\n  get acceptFallbackTheme(): ButtonTheme {\n    return this.theme === ModalTheme.Destructive ? 'danger' : 'primary';\n  }\n\n  get hideHeader(): boolean {\n    return !this.titleText && !this.dismissable;\n  }\n\n  ngOnInit(): void {\n    this._interactableId = this._interactionService.add(this);\n\n    if (this.dismissable === undefined && this.theme === ModalTheme.Working) {\n      this.dismissable = true;\n    }\n\n    if (this.iconName === undefined && this.theme === ModalTheme.Destructive) {\n      this.iconName = 'exclamation-triangle';\n    }\n  }\n\n  ngOnDestroy(): void {\n    this._interactionService.remove(this.interactableId);\n    this._interactableId = 0;\n  }\n\n  protected handleDismiss(event: MouseEvent | Event): void {\n    if (\n      !this.dismissable ||\n      !!this.dismissEl?.nativeElement?.firstChild?.disabled\n    ) {\n      return;\n    }\n    this.close();\n    this.dismiss.emit(event);\n  }\n\n  protected handleDeny(event: MouseEvent | Event): void {\n    if (!!this.denyEl?.nativeElement?.firstChild?.disabled) {\n      return;\n    }\n    this.close();\n    this.deny.emit(event);\n  }\n\n  protected handleAccept(event: MouseEvent | Event): void {\n    if (!!this.acceptEl?.nativeElement?.firstChild?.disabled) {\n      return;\n    }\n    this.close();\n    this.accept.emit(event);\n  }\n\n  /**\n   * Opens/shows the modal. Can be used programmatically.\n   */\n  open(): void {\n    if (this.backdrop) {\n      this._interactionService.queueBackdrop(this.interactableId);\n    }\n    this._show = true;\n  }\n\n  /**\n   * Closes/hides the modal. Can be used programmatically.\n   */\n  close(): void {\n    this._show = false;\n    this._interactionService.dequeueBackdrop(this.interactableId);\n  }\n}\n","<div\n  *ngIf=\"valid\"\n  class=\"impdc modal\"\n  [class.fade]=\"fade\"\n  [class.in]=\"fade && shown\"\n  [class.show]=\"shown\"\n  [class.dismissable]=\"dismissable\"\n  tabindex=\"-1\"\n  (click)=\"handleDismiss($event); $event.stopPropagation()\"\n  (keydown.escape)=\"handleDismiss($event); $event.stopPropagation()\"\n  (keydown.enter)=\"handleAccept($event); $event.stopPropagation()\">\n  <div\n    class=\"modal-dialog modal-dialog-centered modal-dialog-scrollable modal-theme-{{\n      theme\n    }}\"\n    [class.modal-sm]=\"size === 'sm'\"\n    [class.modal-lg]=\"size === 'lg'\"\n    [class.modal-xl]=\"size === 'xl'\"\n    [class.modal-fullscreen]=\"size === 'fs'\"\n    [class.modal-fullscreen-lg-down]=\"size !== 'fs'\"\n    (click)=\"$event.stopPropagation()\">\n    <div class=\"modal-content\">\n      <div *ngIf=\"showDestructiveIcon\" class=\"modal-icon\">\n        <span impdc-icon [name]=\"iconName\" [theme]=\"iconTheme\"></span>\n      </div>\n      <div #header class=\"modal-header\" [class.hide]=\"hideHeader\">\n        <h3 class=\"modal-title\">\n          <span *ngIf=\"showWorkingIcon\" class=\"modal-icon\">\n            <span impdc-icon [name]=\"iconName\" [theme]=\"iconTheme\"></span>\n          </span>\n          <span>{{ titleText }}</span>\n        </h3>\n        <button\n          impdcButton\n          *ngIf=\"dismissable\"\n          theme=\"close\"\n          (click)=\"handleDismiss($event); $event.stopPropagation()\"></button>\n      </div>\n      <div #bodyEl class=\"modal-body\">\n        <ng-content></ng-content>\n      </div>\n      <div #footer class=\"modal-footer\">\n        <span\n          #dismissEl\n          *ngIf=\"dismissable\"\n          [class.hide]=\"!dismissEl.children.length\"\n          (click)=\"handleDismiss($event); $event.stopPropagation()\">\n          <ng-content select=\"[dismiss]\"></ng-content>\n        </span>\n        <span\n          #denyEl\n          [class.hide]=\"!denyEl.children.length\"\n          (click)=\"handleDeny($event); $event.stopPropagation()\">\n          <ng-content select=\"[deny]\"></ng-content>\n        </span>\n        <span\n          #acceptEl\n          [class.hide]=\"!acceptEl.children.length\"\n          (click)=\"handleAccept($event); $event.stopPropagation()\">\n          <ng-content select=\"[accept]\"></ng-content>\n        </span>\n        <span\n          #acceptFallbackEl\n          *ngIf=\"!acceptEl.children.length\"\n          (click)=\"handleAccept($event); $event.stopPropagation()\">\n          <button\n            impdcButton\n            [text]=\"acceptText\"\n            [theme]=\"acceptFallbackTheme\"></button>\n        </span>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
@@ -1,12 +1,13 @@
1
1
  import { Injectable } from '@angular/core';
2
- import { DropdownComponent, ModalComponent } from '../lib';
2
+ import { DropdownComponent } from '../lib';
3
3
  import * as i0 from "@angular/core";
4
4
  export class InteractionService {
5
5
  constructor() {
6
6
  this._interactables = [];
7
+ this._backdropQueue = [];
7
8
  }
8
9
  get showBackdrop() {
9
- return this._interactables.some(i => i instanceof ModalComponent && i.shown && i.backdrop);
10
+ return this._backdropQueue.length > 0;
10
11
  }
11
12
  registerBackdrop(modalBackdrop) {
12
13
  // WARNING: there should only be 1 backdrop component, preferably loaded in the body
@@ -28,8 +29,12 @@ export class InteractionService {
28
29
  }
29
30
  }
30
31
  add(interactable) {
31
- if (interactable.interactableId > 0) {
32
- return interactable.interactableId;
32
+ const interactableId = interactable.interactableId;
33
+ if (interactableId > 0) {
34
+ if (!this._interactables.some(i => i.interactableId === interactableId)) {
35
+ this._interactables.push(interactable);
36
+ }
37
+ return interactableId;
33
38
  }
34
39
  this._interactables.push(interactable);
35
40
  return this._interactables.length;
@@ -39,6 +44,7 @@ export class InteractionService {
39
44
  return;
40
45
  }
41
46
  this._interactables.splice(interactableId - 1, 1);
47
+ this.dequeueBackdrop(interactableId);
42
48
  }
43
49
  toggle(interactable) {
44
50
  if (interactable.interactableId <= 0 || interactable.show) {
@@ -52,6 +58,17 @@ export class InteractionService {
52
58
  }
53
59
  return true;
54
60
  }
61
+ queueBackdrop(interactableId) {
62
+ if (!this._backdropQueue.includes(interactableId)) {
63
+ this._backdropQueue.push(interactableId);
64
+ }
65
+ }
66
+ dequeueBackdrop(interactableId) {
67
+ const interactableIdIndex = this._backdropQueue.indexOf(interactableId);
68
+ if (interactableIdIndex !== -1) {
69
+ this._backdropQueue.splice(interactableIdIndex, 1);
70
+ }
71
+ }
55
72
  }
56
73
  InteractionService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: InteractionService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
57
74
  InteractionService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: InteractionService, providedIn: 'root' });
@@ -61,4 +78,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
61
78
  providedIn: 'root'
62
79
  }]
63
80
  }] });
64
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZXJhY3Rpb24uc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Rlc2lnbi1jb21wb25lbnRzL3NyYy9zZXJ2aWNlcy9pbnRlcmFjdGlvbi5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDM0MsT0FBTyxFQUFxQixpQkFBaUIsRUFBRSxjQUFjLEVBQUUsTUFBTSxRQUFRLENBQUM7O0FBTzlFLE1BQU0sT0FBTyxrQkFBa0I7SUFIL0I7UUFLVSxtQkFBYyxHQUE0QixFQUFFLENBQUM7S0F1RHREO0lBckRDLElBQUksWUFBWTtRQUNkLE9BQU8sSUFBSSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQzdCLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxZQUFZLGNBQWMsSUFBSSxDQUFDLENBQUMsS0FBSyxJQUFJLENBQUMsQ0FBQyxRQUFRLENBQzFELENBQUM7SUFDSixDQUFDO0lBRUQsZ0JBQWdCLENBQUMsYUFBZ0M7UUFDL0Msb0ZBQW9GO1FBQ3BGLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxFQUFFO1lBQ25CLElBQUksQ0FBQyxTQUFTLEdBQUcsYUFBYSxDQUFDO1NBQ2hDO2FBQU0sSUFBSSxJQUFJLENBQUMsU0FBUyxLQUFLLGFBQWEsRUFBRTtZQUMzQyxJQUFJLENBQUMsU0FBUyxDQUFDLFVBQVUsRUFBRSxDQUFDO1lBQzVCLElBQUksQ0FBQyxTQUFTLEdBQUcsYUFBYSxDQUFDO1lBQy9CLElBQUksQ0FBQyxhQUFhLENBQUMsS0FBSyxFQUFFO2dCQUN4Qix1REFBdUQ7Z0JBQ3ZELGFBQWEsQ0FBQyxRQUFRLEVBQUUsQ0FBQzthQUMxQjtTQUNGO0lBQ0gsQ0FBQztJQUVELGtCQUFrQixDQUFDLGFBQWdDO1FBQ2pELElBQUksSUFBSSxDQUFDLFNBQVMsS0FBSyxhQUFhLEVBQUU7WUFDcEMsSUFBSSxDQUFDLFNBQVMsR0FBRyxTQUFTLENBQUM7U0FDNUI7SUFDSCxDQUFDO0lBRUQsR0FBRyxDQUFDLFlBQW1DO1FBQ3JDLElBQUksWUFBWSxDQUFDLGNBQWMsR0FBRyxDQUFDLEVBQUU7WUFDbkMsT0FBTyxZQUFZLENBQUMsY0FBYyxDQUFDO1NBQ3BDO1FBQ0QsSUFBSSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUM7UUFDdkMsT0FBTyxJQUFJLENBQUMsY0FBYyxDQUFDLE1BQU0sQ0FBQztJQUNwQyxDQUFDO0lBRUQsTUFBTSxDQUFDLGNBQXNCO1FBQzNCLElBQUksY0FBYyxJQUFJLENBQUMsSUFBSSxjQUFjLEdBQUcsSUFBSSxDQUFDLGNBQWMsQ0FBQyxNQUFNLEVBQUU7WUFDdEUsT0FBTztTQUNSO1FBQ0QsSUFBSSxDQUFDLGNBQWMsQ0FBQyxNQUFNLENBQUMsY0FBYyxHQUFHLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztJQUNwRCxDQUFDO0lBRUQsTUFBTSxDQUFDLFlBQW1DO1FBQ3hDLElBQUksWUFBWSxDQUFDLGNBQWMsSUFBSSxDQUFDLElBQUksWUFBWSxDQUFDLElBQUksRUFBRTtZQUN6RCx3REFBd0Q7WUFDeEQsT0FBTyxLQUFLLENBQUM7U0FDZDtRQUNELEtBQUssTUFBTSxpQkFBaUIsSUFBSSxJQUFJLENBQUMsY0FBYyxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsRUFBRTtZQUN6RSxJQUFJLGlCQUFpQixZQUFZLGlCQUFpQixFQUFFO2dCQUNsRCxpQkFBaUIsQ0FBQyxJQUFJLEVBQUUsQ0FBQzthQUMxQjtTQUNGO1FBQ0QsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDOztnSEF4RFUsa0JBQWtCO29IQUFsQixrQkFBa0IsY0FGakIsTUFBTTs0RkFFUCxrQkFBa0I7a0JBSDlCLFVBQVU7bUJBQUM7b0JBQ1YsVUFBVSxFQUFFLE1BQU07aUJBQ25CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQmFja2Ryb3BDb21wb25lbnQsIERyb3Bkb3duQ29tcG9uZW50LCBNb2RhbENvbXBvbmVudCB9IGZyb20gJy4uL2xpYic7XG5cbmV4cG9ydCB0eXBlIEludGVyYWN0YWJsZUNvbXBvbmVudCA9IE1vZGFsQ29tcG9uZW50IHwgRHJvcGRvd25Db21wb25lbnQ7XG5cbkBJbmplY3RhYmxlKHtcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnXG59KVxuZXhwb3J0IGNsYXNzIEludGVyYWN0aW9uU2VydmljZSB7XG4gIHByaXZhdGUgX2JhY2tkcm9wPzogQmFja2Ryb3BDb21wb25lbnQ7XG4gIHByaXZhdGUgX2ludGVyYWN0YWJsZXM6IEludGVyYWN0YWJsZUNvbXBvbmVudFtdID0gW107XG5cbiAgZ2V0IHNob3dCYWNrZHJvcCgpOiBib29sZWFuIHtcbiAgICByZXR1cm4gdGhpcy5faW50ZXJhY3RhYmxlcy5zb21lKFxuICAgICAgaSA9PiBpIGluc3RhbmNlb2YgTW9kYWxDb21wb25lbnQgJiYgaS5zaG93biAmJiBpLmJhY2tkcm9wXG4gICAgKTtcbiAgfVxuXG4gIHJlZ2lzdGVyQmFja2Ryb3AobW9kYWxCYWNrZHJvcDogQmFja2Ryb3BDb21wb25lbnQpIHtcbiAgICAvLyBXQVJOSU5HOiB0aGVyZSBzaG91bGQgb25seSBiZSAxIGJhY2tkcm9wIGNvbXBvbmVudCwgcHJlZmVyYWJseSBsb2FkZWQgaW4gdGhlIGJvZHlcbiAgICBpZiAoIXRoaXMuX2JhY2tkcm9wKSB7XG4gICAgICB0aGlzLl9iYWNrZHJvcCA9IG1vZGFsQmFja2Ryb3A7XG4gICAgfSBlbHNlIGlmICh0aGlzLl9iYWNrZHJvcCAhPT0gbW9kYWxCYWNrZHJvcCkge1xuICAgICAgdGhpcy5fYmFja2Ryb3AuaW52YWxpZGF0ZSgpO1xuICAgICAgdGhpcy5fYmFja2Ryb3AgPSBtb2RhbEJhY2tkcm9wO1xuICAgICAgaWYgKCFtb2RhbEJhY2tkcm9wLnZhbGlkKSB7XG4gICAgICAgIC8vIHdlIGludmFsaWRhdGVkIGFuZCBzZXQgYmFja2Ryb3AgdG8gdGhlIHNhbWUgYmFja2Ryb3BcbiAgICAgICAgbW9kYWxCYWNrZHJvcC52YWxpZGF0ZSgpO1xuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIHVucmVnaXN0ZXJCYWNrZHJvcChtb2RhbEJhY2tkcm9wOiBCYWNrZHJvcENvbXBvbmVudCkge1xuICAgIGlmICh0aGlzLl9iYWNrZHJvcCA9PT0gbW9kYWxCYWNrZHJvcCkge1xuICAgICAgdGhpcy5fYmFja2Ryb3AgPSB1bmRlZmluZWQ7XG4gICAgfVxuICB9XG5cbiAgYWRkKGludGVyYWN0YWJsZTogSW50ZXJhY3RhYmxlQ29tcG9uZW50KTogbnVtYmVyIHtcbiAgICBpZiAoaW50ZXJhY3RhYmxlLmludGVyYWN0YWJsZUlkID4gMCkge1xuICAgICAgcmV0dXJuIGludGVyYWN0YWJsZS5pbnRlcmFjdGFibGVJZDtcbiAgICB9XG4gICAgdGhpcy5faW50ZXJhY3RhYmxlcy5wdXNoKGludGVyYWN0YWJsZSk7XG4gICAgcmV0dXJuIHRoaXMuX2ludGVyYWN0YWJsZXMubGVuZ3RoO1xuICB9XG5cbiAgcmVtb3ZlKGludGVyYWN0YWJsZUlkOiBudW1iZXIpOiB2b2lkIHtcbiAgICBpZiAoaW50ZXJhY3RhYmxlSWQgPD0gMCB8fCBpbnRlcmFjdGFibGVJZCA+IHRoaXMuX2ludGVyYWN0YWJsZXMubGVuZ3RoKSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuICAgIHRoaXMuX2ludGVyYWN0YWJsZXMuc3BsaWNlKGludGVyYWN0YWJsZUlkIC0gMSwgMSk7XG4gIH1cblxuICB0b2dnbGUoaW50ZXJhY3RhYmxlOiBJbnRlcmFjdGFibGVDb21wb25lbnQpOiBib29sZWFuIHtcbiAgICBpZiAoaW50ZXJhY3RhYmxlLmludGVyYWN0YWJsZUlkIDw9IDAgfHwgaW50ZXJhY3RhYmxlLnNob3cpIHtcbiAgICAgIC8vIG90aGVyIGludGVyYWN0YWJsZXMgZG9uJ3QgbmVlZCB0byBiZSBhbHRlcmVkL25vdGlmaWVkXG4gICAgICByZXR1cm4gZmFsc2U7XG4gICAgfVxuICAgIGZvciAoY29uc3Qgb3RoZXJJbnRlcmFjdGFibGUgb2YgdGhpcy5faW50ZXJhY3RhYmxlcy5maWx0ZXIob2kgPT4gb2kuc2hvdykpIHtcbiAgICAgIGlmIChvdGhlckludGVyYWN0YWJsZSBpbnN0YW5jZW9mIERyb3Bkb3duQ29tcG9uZW50KSB7XG4gICAgICAgIG90aGVySW50ZXJhY3RhYmxlLmhpZGUoKTtcbiAgICAgIH1cbiAgICB9XG4gICAgcmV0dXJuIHRydWU7XG4gIH1cbn1cbiJdfQ==
81
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZXJhY3Rpb24uc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Rlc2lnbi1jb21wb25lbnRzL3NyYy9zZXJ2aWNlcy9pbnRlcmFjdGlvbi5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDM0MsT0FBTyxFQUFxQixpQkFBaUIsRUFBa0IsTUFBTSxRQUFRLENBQUM7O0FBTzlFLE1BQU0sT0FBTyxrQkFBa0I7SUFIL0I7UUFLVSxtQkFBYyxHQUE0QixFQUFFLENBQUM7UUFDN0MsbUJBQWMsR0FBYSxFQUFFLENBQUM7S0F1RXZDO0lBckVDLElBQUksWUFBWTtRQUNkLE9BQU8sSUFBSSxDQUFDLGNBQWMsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDO0lBQ3hDLENBQUM7SUFFRCxnQkFBZ0IsQ0FBQyxhQUFnQztRQUMvQyxvRkFBb0Y7UUFDcEYsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUU7WUFDbkIsSUFBSSxDQUFDLFNBQVMsR0FBRyxhQUFhLENBQUM7U0FDaEM7YUFBTSxJQUFJLElBQUksQ0FBQyxTQUFTLEtBQUssYUFBYSxFQUFFO1lBQzNDLElBQUksQ0FBQyxTQUFTLENBQUMsVUFBVSxFQUFFLENBQUM7WUFDNUIsSUFBSSxDQUFDLFNBQVMsR0FBRyxhQUFhLENBQUM7WUFDL0IsSUFBSSxDQUFDLGFBQWEsQ0FBQyxLQUFLLEVBQUU7Z0JBQ3hCLHVEQUF1RDtnQkFDdkQsYUFBYSxDQUFDLFFBQVEsRUFBRSxDQUFDO2FBQzFCO1NBQ0Y7SUFDSCxDQUFDO0lBRUQsa0JBQWtCLENBQUMsYUFBZ0M7UUFDakQsSUFBSSxJQUFJLENBQUMsU0FBUyxLQUFLLGFBQWEsRUFBRTtZQUNwQyxJQUFJLENBQUMsU0FBUyxHQUFHLFNBQVMsQ0FBQztTQUM1QjtJQUNILENBQUM7SUFFRCxHQUFHLENBQUMsWUFBbUM7UUFDckMsTUFBTSxjQUFjLEdBQUcsWUFBWSxDQUFDLGNBQWMsQ0FBQztRQUNuRCxJQUFJLGNBQWMsR0FBRyxDQUFDLEVBQUU7WUFDdEIsSUFBSSxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLGNBQWMsS0FBSyxjQUFjLENBQUMsRUFBRTtnQkFDdkUsSUFBSSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUM7YUFDeEM7WUFDRCxPQUFPLGNBQWMsQ0FBQztTQUN2QjtRQUNELElBQUksQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDO1FBQ3ZDLE9BQU8sSUFBSSxDQUFDLGNBQWMsQ0FBQyxNQUFNLENBQUM7SUFDcEMsQ0FBQztJQUVELE1BQU0sQ0FBQyxjQUFzQjtRQUMzQixJQUFJLGNBQWMsSUFBSSxDQUFDLElBQUksY0FBYyxHQUFHLElBQUksQ0FBQyxjQUFjLENBQUMsTUFBTSxFQUFFO1lBQ3RFLE9BQU87U0FDUjtRQUNELElBQUksQ0FBQyxjQUFjLENBQUMsTUFBTSxDQUFDLGNBQWMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFDbEQsSUFBSSxDQUFDLGVBQWUsQ0FBQyxjQUFjLENBQUMsQ0FBQztJQUN2QyxDQUFDO0lBRUQsTUFBTSxDQUFDLFlBQW1DO1FBQ3hDLElBQUksWUFBWSxDQUFDLGNBQWMsSUFBSSxDQUFDLElBQUksWUFBWSxDQUFDLElBQUksRUFBRTtZQUN6RCx3REFBd0Q7WUFDeEQsT0FBTyxLQUFLLENBQUM7U0FDZDtRQUNELEtBQUssTUFBTSxpQkFBaUIsSUFBSSxJQUFJLENBQUMsY0FBYyxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsRUFBRTtZQUN6RSxJQUFJLGlCQUFpQixZQUFZLGlCQUFpQixFQUFFO2dCQUNsRCxpQkFBaUIsQ0FBQyxJQUFJLEVBQUUsQ0FBQzthQUMxQjtTQUNGO1FBQ0QsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0lBRUQsYUFBYSxDQUFDLGNBQXNCO1FBQ2xDLElBQUksQ0FBQyxJQUFJLENBQUMsY0FBYyxDQUFDLFFBQVEsQ0FBQyxjQUFjLENBQUMsRUFBRTtZQUNqRCxJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsQ0FBQztTQUMxQztJQUNILENBQUM7SUFFRCxlQUFlLENBQUMsY0FBc0I7UUFDcEMsTUFBTSxtQkFBbUIsR0FBRyxJQUFJLENBQUMsY0FBYyxDQUFDLE9BQU8sQ0FBQyxjQUFjLENBQUMsQ0FBQztRQUN4RSxJQUFJLG1CQUFtQixLQUFLLENBQUMsQ0FBQyxFQUFFO1lBQzlCLElBQUksQ0FBQyxjQUFjLENBQUMsTUFBTSxDQUFDLG1CQUFtQixFQUFFLENBQUMsQ0FBQyxDQUFDO1NBQ3BEO0lBQ0gsQ0FBQzs7Z0hBekVVLGtCQUFrQjtvSEFBbEIsa0JBQWtCLGNBRmpCLE1BQU07NEZBRVAsa0JBQWtCO2tCQUg5QixVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEJhY2tkcm9wQ29tcG9uZW50LCBEcm9wZG93bkNvbXBvbmVudCwgTW9kYWxDb21wb25lbnQgfSBmcm9tICcuLi9saWInO1xuXG5leHBvcnQgdHlwZSBJbnRlcmFjdGFibGVDb21wb25lbnQgPSBNb2RhbENvbXBvbmVudCB8IERyb3Bkb3duQ29tcG9uZW50O1xuXG5ASW5qZWN0YWJsZSh7XG4gIHByb3ZpZGVkSW46ICdyb290J1xufSlcbmV4cG9ydCBjbGFzcyBJbnRlcmFjdGlvblNlcnZpY2Uge1xuICBwcml2YXRlIF9iYWNrZHJvcD86IEJhY2tkcm9wQ29tcG9uZW50O1xuICBwcml2YXRlIF9pbnRlcmFjdGFibGVzOiBJbnRlcmFjdGFibGVDb21wb25lbnRbXSA9IFtdO1xuICBwcml2YXRlIF9iYWNrZHJvcFF1ZXVlOiBudW1iZXJbXSA9IFtdO1xuXG4gIGdldCBzaG93QmFja2Ryb3AoKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIHRoaXMuX2JhY2tkcm9wUXVldWUubGVuZ3RoID4gMDtcbiAgfVxuXG4gIHJlZ2lzdGVyQmFja2Ryb3AobW9kYWxCYWNrZHJvcDogQmFja2Ryb3BDb21wb25lbnQpIHtcbiAgICAvLyBXQVJOSU5HOiB0aGVyZSBzaG91bGQgb25seSBiZSAxIGJhY2tkcm9wIGNvbXBvbmVudCwgcHJlZmVyYWJseSBsb2FkZWQgaW4gdGhlIGJvZHlcbiAgICBpZiAoIXRoaXMuX2JhY2tkcm9wKSB7XG4gICAgICB0aGlzLl9iYWNrZHJvcCA9IG1vZGFsQmFja2Ryb3A7XG4gICAgfSBlbHNlIGlmICh0aGlzLl9iYWNrZHJvcCAhPT0gbW9kYWxCYWNrZHJvcCkge1xuICAgICAgdGhpcy5fYmFja2Ryb3AuaW52YWxpZGF0ZSgpO1xuICAgICAgdGhpcy5fYmFja2Ryb3AgPSBtb2RhbEJhY2tkcm9wO1xuICAgICAgaWYgKCFtb2RhbEJhY2tkcm9wLnZhbGlkKSB7XG4gICAgICAgIC8vIHdlIGludmFsaWRhdGVkIGFuZCBzZXQgYmFja2Ryb3AgdG8gdGhlIHNhbWUgYmFja2Ryb3BcbiAgICAgICAgbW9kYWxCYWNrZHJvcC52YWxpZGF0ZSgpO1xuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIHVucmVnaXN0ZXJCYWNrZHJvcChtb2RhbEJhY2tkcm9wOiBCYWNrZHJvcENvbXBvbmVudCkge1xuICAgIGlmICh0aGlzLl9iYWNrZHJvcCA9PT0gbW9kYWxCYWNrZHJvcCkge1xuICAgICAgdGhpcy5fYmFja2Ryb3AgPSB1bmRlZmluZWQ7XG4gICAgfVxuICB9XG5cbiAgYWRkKGludGVyYWN0YWJsZTogSW50ZXJhY3RhYmxlQ29tcG9uZW50KTogbnVtYmVyIHtcbiAgICBjb25zdCBpbnRlcmFjdGFibGVJZCA9IGludGVyYWN0YWJsZS5pbnRlcmFjdGFibGVJZDtcbiAgICBpZiAoaW50ZXJhY3RhYmxlSWQgPiAwKSB7XG4gICAgICBpZiAoIXRoaXMuX2ludGVyYWN0YWJsZXMuc29tZShpID0+IGkuaW50ZXJhY3RhYmxlSWQgPT09IGludGVyYWN0YWJsZUlkKSkge1xuICAgICAgICB0aGlzLl9pbnRlcmFjdGFibGVzLnB1c2goaW50ZXJhY3RhYmxlKTtcbiAgICAgIH1cbiAgICAgIHJldHVybiBpbnRlcmFjdGFibGVJZDtcbiAgICB9XG4gICAgdGhpcy5faW50ZXJhY3RhYmxlcy5wdXNoKGludGVyYWN0YWJsZSk7XG4gICAgcmV0dXJuIHRoaXMuX2ludGVyYWN0YWJsZXMubGVuZ3RoO1xuICB9XG5cbiAgcmVtb3ZlKGludGVyYWN0YWJsZUlkOiBudW1iZXIpOiB2b2lkIHtcbiAgICBpZiAoaW50ZXJhY3RhYmxlSWQgPD0gMCB8fCBpbnRlcmFjdGFibGVJZCA+IHRoaXMuX2ludGVyYWN0YWJsZXMubGVuZ3RoKSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuICAgIHRoaXMuX2ludGVyYWN0YWJsZXMuc3BsaWNlKGludGVyYWN0YWJsZUlkIC0gMSwgMSk7XG4gICAgdGhpcy5kZXF1ZXVlQmFja2Ryb3AoaW50ZXJhY3RhYmxlSWQpO1xuICB9XG5cbiAgdG9nZ2xlKGludGVyYWN0YWJsZTogSW50ZXJhY3RhYmxlQ29tcG9uZW50KTogYm9vbGVhbiB7XG4gICAgaWYgKGludGVyYWN0YWJsZS5pbnRlcmFjdGFibGVJZCA8PSAwIHx8IGludGVyYWN0YWJsZS5zaG93KSB7XG4gICAgICAvLyBvdGhlciBpbnRlcmFjdGFibGVzIGRvbid0IG5lZWQgdG8gYmUgYWx0ZXJlZC9ub3RpZmllZFxuICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cbiAgICBmb3IgKGNvbnN0IG90aGVySW50ZXJhY3RhYmxlIG9mIHRoaXMuX2ludGVyYWN0YWJsZXMuZmlsdGVyKG9pID0+IG9pLnNob3cpKSB7XG4gICAgICBpZiAob3RoZXJJbnRlcmFjdGFibGUgaW5zdGFuY2VvZiBEcm9wZG93bkNvbXBvbmVudCkge1xuICAgICAgICBvdGhlckludGVyYWN0YWJsZS5oaWRlKCk7XG4gICAgICB9XG4gICAgfVxuICAgIHJldHVybiB0cnVlO1xuICB9XG5cbiAgcXVldWVCYWNrZHJvcChpbnRlcmFjdGFibGVJZDogbnVtYmVyKTogdm9pZCB7XG4gICAgaWYgKCF0aGlzLl9iYWNrZHJvcFF1ZXVlLmluY2x1ZGVzKGludGVyYWN0YWJsZUlkKSkge1xuICAgICAgdGhpcy5fYmFja2Ryb3BRdWV1ZS5wdXNoKGludGVyYWN0YWJsZUlkKTtcbiAgICB9XG4gIH1cblxuICBkZXF1ZXVlQmFja2Ryb3AoaW50ZXJhY3RhYmxlSWQ6IG51bWJlcik6IHZvaWQge1xuICAgIGNvbnN0IGludGVyYWN0YWJsZUlkSW5kZXggPSB0aGlzLl9iYWNrZHJvcFF1ZXVlLmluZGV4T2YoaW50ZXJhY3RhYmxlSWQpO1xuICAgIGlmIChpbnRlcmFjdGFibGVJZEluZGV4ICE9PSAtMSkge1xuICAgICAgdGhpcy5fYmFja2Ryb3BRdWV1ZS5zcGxpY2UoaW50ZXJhY3RhYmxlSWRJbmRleCwgMSk7XG4gICAgfVxuICB9XG59XG4iXX0=
@@ -3561,13 +3561,17 @@ class ModalComponent {
3561
3561
  * Event emitted when the Modal content is accepted.
3562
3562
  */
3563
3563
  this.accept = new EventEmitter();
3564
- this._interactableId = this._interactionService.add(this);
3565
3564
  }
3566
3565
  /**
3567
3566
  * Determines if the Modal should be shown immediately.
3568
3567
  */
3569
3568
  set show(show) {
3570
- this._show = show;
3569
+ if (show) {
3570
+ this.open();
3571
+ }
3572
+ else {
3573
+ this.close();
3574
+ }
3571
3575
  }
3572
3576
  get interactableId() {
3573
3577
  return this._interactableId;
@@ -3591,6 +3595,7 @@ class ModalComponent {
3591
3595
  return !this.titleText && !this.dismissable;
3592
3596
  }
3593
3597
  ngOnInit() {
3598
+ this._interactableId = this._interactionService.add(this);
3594
3599
  if (this.dismissable === undefined && this.theme === ModalTheme.Working) {
3595
3600
  this.dismissable = true;
3596
3601
  }
@@ -3608,7 +3613,7 @@ class ModalComponent {
3608
3613
  !!((_c = (_b = (_a = this.dismissEl) === null || _a === void 0 ? void 0 : _a.nativeElement) === null || _b === void 0 ? void 0 : _b.firstChild) === null || _c === void 0 ? void 0 : _c.disabled)) {
3609
3614
  return;
3610
3615
  }
3611
- this._show = false;
3616
+ this.close();
3612
3617
  this.dismiss.emit(event);
3613
3618
  }
3614
3619
  handleDeny(event) {
@@ -3616,29 +3621,32 @@ class ModalComponent {
3616
3621
  if (!!((_c = (_b = (_a = this.denyEl) === null || _a === void 0 ? void 0 : _a.nativeElement) === null || _b === void 0 ? void 0 : _b.firstChild) === null || _c === void 0 ? void 0 : _c.disabled)) {
3617
3622
  return;
3618
3623
  }
3619
- this._show = false;
3624
+ this.close();
3620
3625
  this.deny.emit(event);
3621
3626
  }
3622
3627
  handleAccept(event) {
3623
3628
  var _a, _b, _c;
3624
- console.log('this.acceptEl', this.acceptEl);
3625
3629
  if (!!((_c = (_b = (_a = this.acceptEl) === null || _a === void 0 ? void 0 : _a.nativeElement) === null || _b === void 0 ? void 0 : _b.firstChild) === null || _c === void 0 ? void 0 : _c.disabled)) {
3626
3630
  return;
3627
3631
  }
3628
- this._show = false;
3632
+ this.close();
3629
3633
  this.accept.emit(event);
3630
3634
  }
3631
3635
  /**
3632
- * Opens/shows the modal programmatically.
3636
+ * Opens/shows the modal. Can be used programmatically.
3633
3637
  */
3634
3638
  open() {
3639
+ if (this.backdrop) {
3640
+ this._interactionService.queueBackdrop(this.interactableId);
3641
+ }
3635
3642
  this._show = true;
3636
3643
  }
3637
3644
  /**
3638
- * Closes/hides the modal programmatically.
3645
+ * Closes/hides the modal. Can be used programmatically.
3639
3646
  */
3640
3647
  close() {
3641
3648
  this._show = false;
3649
+ this._interactionService.dequeueBackdrop(this.interactableId);
3642
3650
  }
3643
3651
  }
3644
3652
  ModalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: ModalComponent, deps: [{ token: InteractionService }], target: i0.ɵɵFactoryTarget.Component });
@@ -3872,7 +3880,6 @@ class DropdownComponent {
3872
3880
  */
3873
3881
  this.buttonClick = new EventEmitter();
3874
3882
  this.classBtnGroup = true;
3875
- this._interactableId = this._interactionService.add(this);
3876
3883
  }
3877
3884
  get classDropdown() {
3878
3885
  return this.position === 'down';
@@ -3903,6 +3910,9 @@ class DropdownComponent {
3903
3910
  get shown() {
3904
3911
  return this.valid && this.show;
3905
3912
  }
3913
+ ngOnInit() {
3914
+ this._interactableId = this._interactionService.add(this);
3915
+ }
3906
3916
  ngOnDestroy() {
3907
3917
  this._interactionService.remove(this.interactableId);
3908
3918
  this._interactableId = 0;
@@ -8423,9 +8433,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
8423
8433
  class InteractionService {
8424
8434
  constructor() {
8425
8435
  this._interactables = [];
8436
+ this._backdropQueue = [];
8426
8437
  }
8427
8438
  get showBackdrop() {
8428
- return this._interactables.some(i => i instanceof ModalComponent && i.shown && i.backdrop);
8439
+ return this._backdropQueue.length > 0;
8429
8440
  }
8430
8441
  registerBackdrop(modalBackdrop) {
8431
8442
  // WARNING: there should only be 1 backdrop component, preferably loaded in the body
@@ -8447,8 +8458,12 @@ class InteractionService {
8447
8458
  }
8448
8459
  }
8449
8460
  add(interactable) {
8450
- if (interactable.interactableId > 0) {
8451
- return interactable.interactableId;
8461
+ const interactableId = interactable.interactableId;
8462
+ if (interactableId > 0) {
8463
+ if (!this._interactables.some(i => i.interactableId === interactableId)) {
8464
+ this._interactables.push(interactable);
8465
+ }
8466
+ return interactableId;
8452
8467
  }
8453
8468
  this._interactables.push(interactable);
8454
8469
  return this._interactables.length;
@@ -8458,6 +8473,7 @@ class InteractionService {
8458
8473
  return;
8459
8474
  }
8460
8475
  this._interactables.splice(interactableId - 1, 1);
8476
+ this.dequeueBackdrop(interactableId);
8461
8477
  }
8462
8478
  toggle(interactable) {
8463
8479
  if (interactable.interactableId <= 0 || interactable.show) {
@@ -8471,6 +8487,17 @@ class InteractionService {
8471
8487
  }
8472
8488
  return true;
8473
8489
  }
8490
+ queueBackdrop(interactableId) {
8491
+ if (!this._backdropQueue.includes(interactableId)) {
8492
+ this._backdropQueue.push(interactableId);
8493
+ }
8494
+ }
8495
+ dequeueBackdrop(interactableId) {
8496
+ const interactableIdIndex = this._backdropQueue.indexOf(interactableId);
8497
+ if (interactableIdIndex !== -1) {
8498
+ this._backdropQueue.splice(interactableIdIndex, 1);
8499
+ }
8500
+ }
8474
8501
  }
8475
8502
  InteractionService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: InteractionService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
8476
8503
  InteractionService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: InteractionService, providedIn: 'root' });