@kirbydesign/designsystem 6.0.2 → 6.1.2-rc.ionic

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (46) hide show
  1. package/esm2020/lib/components/button/button.component.mjs +2 -2
  2. package/esm2020/lib/components/card/card-footer/card-footer.component.mjs +2 -2
  3. package/esm2020/lib/components/dropdown/dropdown.component.mjs +26 -18
  4. package/esm2020/lib/components/fab-sheet/fab-sheet.component.mjs +3 -3
  5. package/esm2020/lib/components/form-field/input/input.component.mjs +2 -2
  6. package/esm2020/lib/components/form-field/textarea/textarea.component.mjs +2 -2
  7. package/esm2020/lib/components/icon/icon.component.mjs +1 -1
  8. package/esm2020/lib/components/item/item.component.mjs +1 -1
  9. package/esm2020/lib/components/list/list-item/list-item.component.mjs +2 -2
  10. package/esm2020/lib/components/list/list.component.mjs +2 -2
  11. package/esm2020/lib/components/modal/footer/modal-footer.component.mjs +14 -9
  12. package/esm2020/lib/components/modal/modal-wrapper/modal-elements-mover.delegate.mjs +62 -0
  13. package/esm2020/lib/components/modal/modal-wrapper/modal-wrapper.component.mjs +73 -123
  14. package/esm2020/lib/components/modal/services/action-sheet.helper.mjs +4 -1
  15. package/esm2020/lib/components/modal/services/modal-animation-builder.service.mjs +62 -50
  16. package/esm2020/lib/components/modal/services/modal.helper.mjs +12 -11
  17. package/esm2020/lib/components/modal/services/modal.interfaces.mjs +39 -1
  18. package/esm2020/lib/components/page/page.component.mjs +31 -21
  19. package/esm2020/lib/components/range/range.component.mjs +1 -1
  20. package/esm2020/lib/components/segmented-control/segmented-control.component.mjs +1 -1
  21. package/esm2020/lib/components/slide-button/slide-button.component.mjs +2 -2
  22. package/esm2020/lib/components/toggle/toggle.component.mjs +1 -1
  23. package/fesm2015/kirbydesign-designsystem.mjs +321 -232
  24. package/fesm2015/kirbydesign-designsystem.mjs.map +1 -1
  25. package/fesm2020/kirbydesign-designsystem.mjs +314 -232
  26. package/fesm2020/kirbydesign-designsystem.mjs.map +1 -1
  27. package/lib/components/avatar/avatar.component.d.ts +1 -1
  28. package/lib/components/dropdown/dropdown.component.d.ts +6 -5
  29. package/lib/components/modal/footer/modal-footer.component.d.ts +5 -2
  30. package/lib/components/modal/modal-wrapper/modal-elements-mover.delegate.d.ts +14 -0
  31. package/lib/components/modal/modal-wrapper/modal-wrapper.component.d.ts +14 -16
  32. package/lib/components/modal/services/modal-animation-builder.service.d.ts +14 -3
  33. package/lib/components/modal/services/modal.interfaces.d.ts +22 -0
  34. package/lib/components/page/page.component.d.ts +7 -5
  35. package/package.json +8 -8
  36. package/scss/base/_link.scss +1 -0
  37. package/scss/interaction-state/_active.scss +1 -0
  38. package/scss/interaction-state/_focus.scss +1 -0
  39. package/scss/interaction-state/_hover.scss +1 -0
  40. package/scss/interaction-state/_index.scss +1 -0
  41. package/scss/interaction-state/_interaction-state.utilities.scss +1 -0
  42. package/scss/interaction-state/_layer.scss +1 -0
  43. package/scss/opt-out/_index.scss +1 -0
  44. package/scss/opt-out/_link.scss +1 -0
  45. package/src/lib/components/icon/README.md +16 -0
  46. package/README.md +0 -7
@@ -1,4 +1,4 @@
1
- import { Component, ComponentFactoryResolver, ElementRef, HostBinding, HostListener, Injector, Input, NgZone, QueryList, Renderer2, RendererStyleFlags2, ViewChild, ViewChildren, } from '@angular/core';
1
+ import { ChangeDetectorRef, Component, ComponentFactoryResolver, ElementRef, HostBinding, HostListener, Injector, Input, NgZone, QueryList, Renderer2, RendererStyleFlags2, ViewChild, ViewChildren, } from '@angular/core';
2
2
  import { RouterOutlet } from '@angular/router';
3
3
  import { IonContent, IonHeader, IonTitle, IonToolbar } from '@ionic/angular';
4
4
  import { merge, Subject } from 'rxjs';
@@ -8,8 +8,9 @@ import { PlatformService } from '../../../helpers/platform.service';
8
8
  import { WindowRef } from '../../../types/window-ref';
9
9
  import { ButtonComponent } from '../../button/button.component';
10
10
  import { ResizeObserverService } from '../../shared/resize-observer/resize-observer.service';
11
- import { Modal } from '../services/modal.interfaces';
11
+ import { Modal, ModalElementsAdvertiser, ModalElementType } from '../services/modal.interfaces';
12
12
  import { COMPONENT_PROPS } from './config/modal-config.helper';
13
+ import { ModalElementsMoverDelegate } from './modal-elements-mover.delegate';
13
14
  import * as i0 from "@angular/core";
14
15
  import * as i1 from "../../shared/resize-observer/resize-observer.service";
15
16
  import * as i2 from "../../../types/window-ref";
@@ -20,7 +21,8 @@ import * as i6 from "../../icon/icon.component";
20
21
  import * as i7 from "@angular/common";
21
22
  import * as i8 from "@angular/router";
22
23
  export class ModalWrapperComponent {
23
- constructor(injector, elementRef, renderer, zone, resizeObserverService, componentFactoryResolver, windowRef, platform) {
24
+ constructor(changeDetector, injector, elementRef, renderer, zone, resizeObserverService, componentFactoryResolver, windowRef, platform) {
25
+ this.changeDetector = changeDetector;
24
26
  this.injector = injector;
25
27
  this.elementRef = elementRef;
26
28
  this.renderer = renderer;
@@ -45,13 +47,10 @@ export class ModalWrapperComponent {
45
47
  .pipe(debounceTime(this.VIEWPORT_RESIZE_DEBOUNCE_TIME));
46
48
  this.destroy$ = new Subject();
47
49
  this.willClose$ = this.ionModalWillDismiss.pipe(first());
48
- this.elementToParentMap = {
49
- 'KIRBY-MODAL-FOOTER': () => [this.elementRef.nativeElement],
50
- 'KIRBY-PAGE-TITLE': () => [this.ionTitleElement.nativeElement, this.contentTitle?.nativeElement].filter((element) => element !== undefined),
51
- 'KIRBY-PAGE-PROGRESS': () => [this.ionToolbarElement.nativeElement],
52
- };
50
+ this._currentFooter = null;
53
51
  this.setViewportHeight();
54
52
  this.observeViewportResize();
53
+ this.modalElementsMoverDelegate = new ModalElementsMoverDelegate(renderer, elementRef);
55
54
  }
56
55
  get _hasCollapsibleTitle() {
57
56
  return !!this.config?.collapseTitle;
@@ -59,11 +58,15 @@ export class ModalWrapperComponent {
59
58
  set scrollDisabled(disabled) {
60
59
  this.ionContent.scrollY = !disabled;
61
60
  }
62
- get mutationObserver() {
63
- if (!this._mutationObserver) {
64
- this._mutationObserver = this.createEmbeddedElementsMutationObserver();
61
+ get contentTitleElement() {
62
+ /*
63
+ contentTitleElement has ngIf directive dependent on _hasCollapsibleTitle; trigger CD to make sure element has been queried.
64
+ Solution taken from: https://danieleyassu.com/angular-viewchild-and-ngif/
65
+ */
66
+ if (!this._contentTitleElement && this._hasCollapsibleTitle) {
67
+ this.changeDetector.detectChanges();
65
68
  }
66
- return this._mutationObserver;
69
+ return this._contentTitleElement;
67
70
  }
68
71
  get intersectionObserver() {
69
72
  if (!this._intersectionObserver) {
@@ -86,6 +89,43 @@ export class ModalWrapperComponent {
86
89
  parent: this.injector,
87
90
  });
88
91
  }
92
+ set currentFooter(footer) {
93
+ if (footer !== null) {
94
+ this.resizeObserverService.observe(footer, (entry) => {
95
+ const [property, pixelValue] = [
96
+ '--footer-height',
97
+ `${Math.floor(entry.contentRect.height)}px`,
98
+ ];
99
+ this.setCssVar(this.elementRef.nativeElement, property, pixelValue);
100
+ });
101
+ }
102
+ this._currentFooter = footer;
103
+ }
104
+ get currentFooter() {
105
+ return this._currentFooter;
106
+ }
107
+ addModalElement(type, modalElement) {
108
+ const addModalElementFn = {
109
+ [ModalElementType.FOOTER]: () => {
110
+ this.modalElementsMoverDelegate.addFooter(modalElement);
111
+ this.currentFooter = modalElement.nativeElement;
112
+ },
113
+ [ModalElementType.TITLE]: () => this.modalElementsMoverDelegate.addTitle(modalElement, this.contentTitleElement, this._hasCollapsibleTitle, this.ionTitleElement),
114
+ [ModalElementType.PAGE_PROGRESS]: () => this.modalElementsMoverDelegate.addPageProgress(modalElement, this.ionToolbarElement),
115
+ }[type];
116
+ addModalElementFn();
117
+ }
118
+ removeModalElement(type, modalElement) {
119
+ const removeModalElementFn = {
120
+ [ModalElementType.FOOTER]: () => {
121
+ this.modalElementsMoverDelegate.removeFooter(modalElement);
122
+ this.currentFooter = null;
123
+ },
124
+ [ModalElementType.TITLE]: () => this.modalElementsMoverDelegate.removeTitle(modalElement, this._hasCollapsibleTitle, this.contentTitleElement),
125
+ [ModalElementType.PAGE_PROGRESS]: () => this.modalElementsMoverDelegate.removePageProgress(modalElement),
126
+ }[type];
127
+ removeModalElementFn();
128
+ }
89
129
  initializeResizeModalToModalWrapper() {
90
130
  if (this.config.flavor === 'drawer' && this.config.interactWithBackground) {
91
131
  merge(this.ionModalDidPresent, this.viewportResize$)
@@ -122,12 +162,9 @@ export class ModalWrapperComponent {
122
162
  return;
123
163
  siblingModalRouteActivated$.pipe(takeUntil(this.willClose$)).subscribe((route) => {
124
164
  if (this.routerOutlet.isActivated) {
125
- this.mutationObserver.disconnect();
126
165
  this.routerOutlet.deactivate();
127
- this.clearEmbeddedElements();
128
166
  }
129
167
  this.routerOutlet.activateWith(route, this.componentFactoryResolver);
130
- this.checkForEmbeddedElements();
131
168
  });
132
169
  }
133
170
  patchScrollElementSize() {
@@ -143,7 +180,7 @@ export class ModalWrapperComponent {
143
180
  });
144
181
  }
145
182
  observeModalFullHeight() {
146
- const ionModalWrapper = this.elementRef.nativeElement.closest('.modal-wrapper');
183
+ const ionModalWrapper = this.getIonModalWrapperElement();
147
184
  if (!ionModalWrapper)
148
185
  return;
149
186
  // Start observing when modal has finished animating:
@@ -151,15 +188,14 @@ export class ModalWrapperComponent {
151
188
  this.intersectionObserver.observe(ionModalWrapper);
152
189
  });
153
190
  }
191
+ // Extracted into function for ease of testing
192
+ getIonModalWrapperElement() {
193
+ return this.ionModalElement.shadowRoot.querySelector('.modal-wrapper');
194
+ }
154
195
  ngAfterViewInit() {
155
196
  if (this.toolbarButtonsQuery) {
156
197
  this.toolbarButtons = this.toolbarButtonsQuery.map((buttonRef) => buttonRef.nativeElement);
157
198
  }
158
- this.checkForEmbeddedElements();
159
- }
160
- checkForEmbeddedElements() {
161
- this.moveEmbeddedElements();
162
- this.observeEmbeddedElements();
163
199
  }
164
200
  observeHeaderResize() {
165
201
  this.resizeObserverService.observe(this.ionHeaderElement.nativeElement, (entry) => {
@@ -167,17 +203,6 @@ export class ModalWrapperComponent {
167
203
  this.setCssVar(this.elementRef.nativeElement, property, pixelValue);
168
204
  });
169
205
  }
170
- moveEmbeddedElements() {
171
- const parentElement = this.getEmbeddedComponentElement();
172
- if (parentElement) {
173
- Object.entries(this.elementToParentMap).forEach(([tagName, getNewParent]) => {
174
- const embeddedElement = parentElement.querySelector(tagName);
175
- if (embeddedElement) {
176
- this.moveChild(embeddedElement, getNewParent());
177
- }
178
- });
179
- }
180
- }
181
206
  listenForIonModalDidPresent() {
182
207
  if (this.ionModalElement) {
183
208
  this.ionModalElement.addEventListener('ionModalDidPresent', () => {
@@ -274,7 +299,7 @@ export class ModalWrapperComponent {
274
299
  this.toggleCssClass(this.elementRef.nativeElement, 'keyboard-visible', keyboardHeight > 0);
275
300
  const keyboardOverlap = this.getKeyboardOverlap(keyboardHeight, this.elementRef.nativeElement);
276
301
  let snapFooterToKeyboard = false;
277
- const embeddedFooterElement = this.getEmbeddedFooterElement();
302
+ const embeddedFooterElement = this.currentFooter;
278
303
  if (embeddedFooterElement) {
279
304
  this.setCssVar(embeddedFooterElement, '--keyboard-offset', `${keyboardOverlap}px`);
280
305
  snapFooterToKeyboard = embeddedFooterElement.classList.contains('snap-to-keyboard');
@@ -333,95 +358,15 @@ export class ModalWrapperComponent {
333
358
  }
334
359
  }
335
360
  }
336
- clearEmbeddedElements() {
337
- Object.entries(this.elementToParentMap).forEach(([tagName, getParents]) => {
338
- const newParents = getParents();
339
- newParents.forEach((newParent) => {
340
- const embeddedElement = newParent.querySelector(`:scope > ${tagName}`);
341
- this.removeChild(embeddedElement);
342
- });
343
- });
344
- }
345
- /* TODO: Rewrite to make this function independent of element order.
346
- See: https://github.com/kirbydesign/designsystem/issues/2096
347
- */
348
- getEmbeddedComponentElement() {
349
- const contentElementChildren = Array.from(this.ionContentElement.nativeElement.children).reverse(); // Reverse makes it easier to retrieve the last children in the list
350
- const embeddedComponentElement = !!this.config.modalRoute
351
- ? contentElementChildren[0]
352
- : contentElementChildren[1];
353
- /*
354
- As ModalConfig.component has type 'any' all values are valid for component;
355
- explicitly handle the case where no embedded component element is found due to
356
- this.
357
- */
358
- if (!embeddedComponentElement)
359
- return null;
360
- return embeddedComponentElement;
361
- }
362
- getEmbeddedFooterElement() {
363
- return this.elementRef.nativeElement.querySelector('kirby-modal-footer');
364
- }
365
- moveChild(child, newParents) {
366
- this.renderer.removeChild(child.parentElement, child);
367
- newParents.forEach((newParent, index) => {
368
- const childToAppend = index > 0 ? child.cloneNode(true) : child;
369
- this.renderer.appendChild(newParent, childToAppend);
370
- // Append adds child as last element of parent; therefore retrieve with lastElementChild
371
- const childElement = newParent.lastElementChild;
372
- if (childElement.tagName === 'KIRBY-MODAL-FOOTER') {
373
- this.resizeObserverService.observe(childElement, (entry) => {
374
- const [property, pixelValue] = [
375
- '--footer-height',
376
- `${Math.floor(entry.contentRect.height)}px`,
377
- ];
378
- this.setCssVar(this.elementRef.nativeElement, property, pixelValue);
379
- });
380
- }
381
- });
382
- }
383
- removeChild(child) {
384
- if (!!child) {
385
- this.renderer.removeChild(child.parentElement, child);
386
- }
387
- }
388
- observeEmbeddedElements() {
389
- const parentElement = this.getEmbeddedComponentElement();
390
- if (parentElement === null)
391
- return; // Mute observe warning when parentElement is null
392
- this.mutationObserver.observe(parentElement, {
393
- childList: true, // Listen for addition or removal of child nodes
394
- });
395
- }
396
- createEmbeddedElementsMutationObserver() {
397
- const observedElements = Object.keys(this.elementToParentMap);
398
- const callback = (mutations) => {
399
- const addedNodes = mutations
400
- .filter((mutation) => mutation.type === 'childList') // Filter for mutation to the tree of nodes
401
- .map((mutation) => {
402
- // Only check for addedNodes as removal is handled by the Angular renderer:
403
- return Array.from(mutation.addedNodes).filter((node) => observedElements.includes(node.nodeName));
404
- });
405
- const addedElements = Array.prototype
406
- .concat(...addedNodes)
407
- .filter((node) => node instanceof HTMLElement);
408
- addedElements.forEach((addedElement) => {
409
- const newParentElement = this.elementToParentMap[addedElement.nodeName]();
410
- // Move embedded element out of content and append to new parent:
411
- this.moveChild(addedElement, newParentElement);
412
- });
413
- };
414
- return new MutationObserver(callback);
415
- }
416
361
  createModalWrapperIntersectionObserver() {
417
362
  const callback = (entries) => {
418
363
  const entry = entries[0];
419
364
  const isTouchingViewport = entry.intersectionRatio < 1;
420
365
  if (isTouchingViewport) {
421
- this.renderer.addClass(entry.target, 'full-height');
366
+ this.ionModalElement.classList.add('full-height');
422
367
  }
423
368
  else {
424
- this.renderer.removeClass(entry.target, 'full-height');
369
+ this.ionModalElement.classList.remove('full-height');
425
370
  }
426
371
  };
427
372
  // Set explicit viewport root if within iframe:
@@ -440,26 +385,31 @@ export class ModalWrapperComponent {
440
385
  this.routerOutlet.deactivate();
441
386
  }
442
387
  //clean up the observer
443
- this.mutationObserver.disconnect();
444
388
  delete this._mutationObserver;
445
389
  this.intersectionObserver.disconnect();
446
390
  delete this._intersectionObserver;
447
391
  if (this.resizeObserverService) {
448
392
  this.resizeObserverService.unobserve(this.windowRef.nativeWindow.document.body);
449
393
  this.resizeObserverService.unobserve(this.ionHeaderElement.nativeElement);
450
- this.resizeObserverService.unobserve(this.getEmbeddedFooterElement());
394
+ this.resizeObserverService.unobserve(this.currentFooter);
451
395
  }
452
396
  this.destroy$.next();
453
397
  this.destroy$.complete();
454
398
  }
455
399
  }
456
400
  ModalWrapperComponent.KEYBOARD_HIDE_DELAY_IN_MS = 100;
457
- /** @nocollapse */ ModalWrapperComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.9", ngImport: i0, type: ModalWrapperComponent, deps: [{ token: i0.Injector }, { token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i0.NgZone }, { token: i1.ResizeObserverService }, { token: i0.ComponentFactoryResolver }, { token: i2.WindowRef }, { token: i3.PlatformService }], target: i0.ɵɵFactoryTarget.Component });
458
- /** @nocollapse */ ModalWrapperComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.9", type: ModalWrapperComponent, selector: "kirby-modal-wrapper", inputs: { config: "config" }, host: { listeners: { "window:focus": "onFocusChange()", "window:focusout": "onFocusChange()", "window:ionKeyboardDidShow": "_onKeyboardShow($event.detail.keyboardHeight)", "window:keyboardWillShow": "_onKeyboardShow($event.keyboardHeight)", "window:ionKeyboardDidHide": "_onKeyboardHide()", "window:keyboardWillHide": "_onKeyboardHide()", "window:resize": "_onWindowResize()" }, properties: { "class.collapsible-title": "this._hasCollapsibleTitle", "class.drawer": "this._isDrawer" } }, providers: [{ provide: Modal, useExisting: ModalWrapperComponent }], viewQueries: [{ propertyName: "ionContent", first: true, predicate: IonContent, descendants: true, static: true }, { propertyName: "ionContentElement", first: true, predicate: IonContent, descendants: true, read: ElementRef, static: true }, { propertyName: "ionHeaderElement", first: true, predicate: IonHeader, descendants: true, read: ElementRef, static: true }, { propertyName: "ionToolbarElement", first: true, predicate: IonToolbar, descendants: true, read: ElementRef, static: true }, { propertyName: "ionTitleElement", first: true, predicate: IonTitle, descendants: true, read: ElementRef, static: true }, { propertyName: "routerOutlet", first: true, predicate: RouterOutlet, descendants: true, static: true }, { propertyName: "contentTitle", first: true, predicate: ["contentTitle"], descendants: true, read: ElementRef }, { propertyName: "toolbarButtonsQuery", predicate: ButtonComponent, descendants: true, read: ElementRef }], ngImport: i0, template: "<ion-header (touchstart)=\"onHeaderTouchStart($event)\">\n <ion-toolbar>\n <ion-title></ion-title>\n <ion-buttons slot=\"start\" *ngIf=\"config.flavor === 'drawer'\">\n <ng-container *ngTemplateOutlet=\"closeButton; context: { icon: 'arrow-down' }\"></ng-container>\n </ion-buttons>\n <ion-buttons slot=\"end\" *ngIf=\"config.flavor === 'modal'\">\n <ng-container *ngTemplateOutlet=\"closeButton; context: { icon: 'close' }\"></ng-container>\n </ion-buttons>\n <ion-buttons slot=\"end\" *ngIf=\"config.flavor === 'drawer' && config.drawerSupplementaryAction\">\n <ng-container\n *ngTemplateOutlet=\"supplementaryButton; context: { btn: config.drawerSupplementaryAction }\"\n ></ng-container>\n </ion-buttons>\n </ion-toolbar>\n</ion-header>\n\n<ion-content [scrollEvents]=\"true\">\n <ion-header *ngIf=\"_hasCollapsibleTitle\" collapse=\"condense\">\n <ion-toolbar>\n <span class=\"kirby-text-large\" #contentTitle></span>\n </ion-toolbar>\n </ion-header>\n <ng-container\n *ngComponentOutlet=\"config.component; injector: componentPropsInjector\"\n ></ng-container>\n <router-outlet\n name=\"kirbyModalWrapperOutlet\"\n [style.visibility]=\"config.modalRoute ? 'visible' : 'hidden'\"\n ></router-outlet>\n</ion-content>\n\n<ng-template #closeButton let-icon=\"icon\">\n <button kirby-button attentionLevel=\"4\" size=\"md\" (click)=\"close()\">\n <kirby-icon [name]=\"icon\"></kirby-icon>\n </button>\n</ng-template>\n\n<ng-template #supplementaryButton let-btn=\"btn\">\n <button kirby-button attentionLevel=\"2\" size=\"md\" (click)=\"btn.action($event)\">\n <kirby-icon [name]=\"btn.iconName\"></kirby-icon>\n </button>\n</ng-template>\n", styles: ["ion-header ion-toolbar{--padding-start: 16px;--padding-end: 16px;--padding-bottom: 12px;--padding-top: 12px;--border-width: 0;--background: transparent;--color: var(--kirby-modal-color, var(--kirby-black))}ion-header ion-toolbar button{color:var(--color)}@media (min-width: 721px){ion-header ion-toolbar{padding-top:8px}}:host{--vh100: var(--vh, 1vh) * 100;--header-height: 0px;--footer-height: 0px}:host.drawer ion-header ion-toolbar:first-of-type{padding-top:0}@media (min-width: 721px){:host-context(ion-modal:not(.kirby-modal-full-height)){padding-top:0;position:relative;contain:inherit;min-height:min(var(--min-height),var(--vh100) - var(--kirby-modal-padding-top, 0px))}:host-context(ion-modal:not(.kirby-modal-full-height)) ion-content{contain:content;max-height:calc(var(--vh100) - var(--kirby-modal-padding-top, 0px) - var(--header-height) - var(--footer-height))}:host-context(ion-modal:not(.kirby-modal-full-height)) ion-content::part(scroll){height:\"100%\";position:relative}:host-context(ion-modal:not(.kirby-modal-full-height)).drawer ion-content::part(scroll){transition:padding-bottom .15s ease-out}:host-context(ion-modal:not(.kirby-modal-full-height)).drawer.keyboard-visible ion-content::part(scroll){transition:padding-bottom .25s ease-out 1ms}}:host-context(ion-modal:not(.kirby-modal-full-height)).drawer{padding-top:0;position:relative;contain:inherit;min-height:min(var(--min-height),var(--vh100) - var(--kirby-modal-padding-top, 0px))}:host-context(ion-modal:not(.kirby-modal-full-height)).drawer ion-content{contain:content;max-height:calc(var(--vh100) - var(--kirby-modal-padding-top, 0px) - var(--header-height) - var(--footer-height))}:host-context(ion-modal:not(.kirby-modal-full-height)).drawer ion-content::part(scroll){height:\"100%\";position:relative}:host-context(ion-modal:not(.kirby-modal-full-height)).drawer.drawer ion-content::part(scroll){transition:padding-bottom .15s ease-out}:host-context(ion-modal:not(.kirby-modal-full-height)).drawer.drawer.keyboard-visible ion-content::part(scroll){transition:padding-bottom .25s ease-out 1ms}:host-context(ion-modal.modal-card:not(.kirby-drawer)) ion-header ion-toolbar:first-of-type{padding-top:var(--kirby-safe-area-top, 0)}@media (min-width: 721px){:host-context(ion-modal.modal-card:not(.kirby-drawer)) ion-header ion-toolbar:first-of-type{padding-top:8px}}ion-title{box-sizing:border-box;padding-inline-start:calc(48px + var(--padding-start));padding-inline-end:calc(48px + var(--padding-end));font-size:22px;font-weight:700}:host(.drawer) ion-title{font-size:18px}ion-content{--background: transparent;--color: var(--kirby-modal-color, var(--kirby-black));display:flex;flex-direction:column;--padding-top: 24px;--padding-bottom: 24px;--padding-start: 16px;--padding-end: 16px}ion-content ::ng-deep>*{box-sizing:border-box;display:block}@media (min-width: 721px){ion-content{--padding-start: 56px;--padding-end: 56px}}:host(.collapsible-title) ion-content{--padding-top: 0px}:host(.collapsible-title) ion-content ion-header ion-toolbar:first-of-type{padding-top:0;--padding-top: 0px;--padding-bottom: 0px;--padding-start: 0px;--padding-end: 0px}:host(.collapsible-title) ion-title{font-size:16px;font-weight:700}\n"], components: [{ type: i4.IonHeader, selector: "ion-header", inputs: ["collapse", "mode", "translucent"] }, { type: i4.IonToolbar, selector: "ion-toolbar", inputs: ["color", "mode"] }, { type: i4.IonTitle, selector: "ion-title", inputs: ["color", "size"] }, { type: i4.IonButtons, selector: "ion-buttons", inputs: ["collapse"] }, { type: i4.IonContent, selector: "ion-content", inputs: ["color", "forceOverscroll", "fullscreen", "scrollEvents", "scrollX", "scrollY"] }, { type: i5.ButtonComponent, selector: "button[kirby-button],Button[kirby-button]", inputs: ["attentionLevel", "isDestructive", "themeColor", "expand", "isFloating", "size"] }, { type: i6.IconComponent, selector: "kirby-icon", inputs: ["size", "name", "customName"] }], directives: [{ type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i7.NgComponentOutlet, selector: "[ngComponentOutlet]", inputs: ["ngComponentOutlet", "ngComponentOutletInjector", "ngComponentOutletContent", "ngComponentOutletNgModuleFactory"] }, { type: i8.RouterOutlet, selector: "router-outlet", outputs: ["activate", "deactivate", "attach", "detach"], exportAs: ["outlet"] }] });
401
+ /** @nocollapse */ ModalWrapperComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.9", ngImport: i0, type: ModalWrapperComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.Injector }, { token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i0.NgZone }, { token: i1.ResizeObserverService }, { token: i0.ComponentFactoryResolver }, { token: i2.WindowRef }, { token: i3.PlatformService }], target: i0.ɵɵFactoryTarget.Component });
402
+ /** @nocollapse */ ModalWrapperComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.9", type: ModalWrapperComponent, selector: "kirby-modal-wrapper", inputs: { config: "config" }, host: { listeners: { "window:focus": "onFocusChange()", "window:focusout": "onFocusChange()", "window:ionKeyboardDidShow": "_onKeyboardShow($event.detail.keyboardHeight)", "window:keyboardWillShow": "_onKeyboardShow($event.keyboardHeight)", "window:ionKeyboardDidHide": "_onKeyboardHide()", "window:keyboardWillHide": "_onKeyboardHide()", "window:resize": "_onWindowResize()" }, properties: { "class.collapsible-title": "this._hasCollapsibleTitle", "class.drawer": "this._isDrawer" } }, providers: [
403
+ { provide: Modal, useExisting: ModalWrapperComponent },
404
+ { provide: ModalElementsAdvertiser, useExisting: ModalWrapperComponent },
405
+ ], viewQueries: [{ propertyName: "ionContent", first: true, predicate: IonContent, descendants: true, static: true }, { propertyName: "ionContentElement", first: true, predicate: IonContent, descendants: true, read: ElementRef, static: true }, { propertyName: "ionHeaderElement", first: true, predicate: IonHeader, descendants: true, read: ElementRef, static: true }, { propertyName: "ionToolbarElement", first: true, predicate: IonToolbar, descendants: true, read: ElementRef, static: true }, { propertyName: "ionTitleElement", first: true, predicate: IonTitle, descendants: true, read: ElementRef, static: true }, { propertyName: "routerOutlet", first: true, predicate: RouterOutlet, descendants: true, static: true }, { propertyName: "_contentTitleElement", first: true, predicate: ["contentTitle"], descendants: true, read: ElementRef }, { propertyName: "toolbarButtonsQuery", predicate: ButtonComponent, descendants: true, read: ElementRef }], ngImport: i0, template: "<ion-header (touchstart)=\"onHeaderTouchStart($event)\">\n <ion-toolbar>\n <ion-title></ion-title>\n <ion-buttons slot=\"start\" *ngIf=\"config.flavor === 'drawer'\">\n <ng-container *ngTemplateOutlet=\"closeButton; context: { icon: 'arrow-down' }\"></ng-container>\n </ion-buttons>\n <ion-buttons slot=\"end\" *ngIf=\"config.flavor === 'modal'\">\n <ng-container *ngTemplateOutlet=\"closeButton; context: { icon: 'close' }\"></ng-container>\n </ion-buttons>\n <ion-buttons slot=\"end\" *ngIf=\"config.flavor === 'drawer' && config.drawerSupplementaryAction\">\n <ng-container\n *ngTemplateOutlet=\"supplementaryButton; context: { btn: config.drawerSupplementaryAction }\"\n ></ng-container>\n </ion-buttons>\n </ion-toolbar>\n</ion-header>\n\n<ion-content [scrollEvents]=\"true\">\n <ion-header *ngIf=\"_hasCollapsibleTitle\" collapse=\"condense\">\n <ion-toolbar>\n <span class=\"kirby-text-large\" #contentTitle></span>\n </ion-toolbar>\n </ion-header>\n <ng-container\n *ngComponentOutlet=\"config.component; injector: componentPropsInjector\"\n ></ng-container>\n <router-outlet\n name=\"kirbyModalWrapperOutlet\"\n [style.visibility]=\"config.modalRoute ? 'visible' : 'hidden'\"\n ></router-outlet>\n</ion-content>\n\n<ng-template #closeButton let-icon=\"icon\">\n <button kirby-button attentionLevel=\"4\" size=\"md\" (click)=\"close()\">\n <kirby-icon [name]=\"icon\"></kirby-icon>\n </button>\n</ng-template>\n\n<ng-template #supplementaryButton let-btn=\"btn\">\n <button kirby-button attentionLevel=\"2\" size=\"md\" (click)=\"btn.action($event)\">\n <kirby-icon [name]=\"btn.iconName\"></kirby-icon>\n </button>\n</ng-template>\n", styles: ["ion-header{box-sizing:border-box}ion-header ion-toolbar{--padding-start: 16px;--padding-end: 16px;--padding-bottom: 12px;--padding-top: 12px;--border-width: 0;--background: transparent;--color: var(--kirby-modal-color, var(--kirby-black))}ion-header ion-toolbar button{color:var(--color)}@media (min-width: 721px){ion-header ion-toolbar{padding-top:8px}}:host{--vh100: var(--vh, 1vh) * 100;--header-height: 0px;--footer-height: 0px}:host.drawer ion-header ion-toolbar:first-of-type{padding-top:0}@media (min-width: 721px){:host-context(ion-modal:not(.kirby-modal-full-height)){padding-top:0;position:relative;contain:inherit;min-height:min(var(--min-height),var(--vh100) - var(--kirby-modal-padding-top, 0px))}:host-context(ion-modal:not(.kirby-modal-full-height)) ion-content{contain:content;max-height:calc(var(--vh100) - var(--kirby-modal-padding-top, 0px) - var(--header-height) - var(--footer-height))}:host-context(ion-modal:not(.kirby-modal-full-height)) ion-content::part(scroll){height:\"100%\";position:relative}:host-context(ion-modal:not(.kirby-modal-full-height)).drawer ion-content::part(scroll){transition:padding-bottom .15s ease-out}:host-context(ion-modal:not(.kirby-modal-full-height)).drawer.keyboard-visible ion-content::part(scroll){transition:padding-bottom .25s ease-out 1ms}}:host-context(ion-modal:not(.kirby-modal-full-height)).drawer{padding-top:0;position:relative;contain:inherit;min-height:min(var(--min-height),var(--vh100) - var(--kirby-modal-padding-top, 0px))}:host-context(ion-modal:not(.kirby-modal-full-height)).drawer ion-content{contain:content;max-height:calc(var(--vh100) - var(--kirby-modal-padding-top, 0px) - var(--header-height) - var(--footer-height))}:host-context(ion-modal:not(.kirby-modal-full-height)).drawer ion-content::part(scroll){height:\"100%\";position:relative}:host-context(ion-modal:not(.kirby-modal-full-height)).drawer.drawer ion-content::part(scroll){transition:padding-bottom .15s ease-out}:host-context(ion-modal:not(.kirby-modal-full-height)).drawer.drawer.keyboard-visible ion-content::part(scroll){transition:padding-bottom .25s ease-out 1ms}:host-context(ion-modal.modal-card:not(.kirby-drawer)) ion-header ion-toolbar:first-of-type{padding-top:var(--kirby-safe-area-top, 0)}@media (min-width: 721px){:host-context(ion-modal.modal-card:not(.kirby-drawer)) ion-header ion-toolbar:first-of-type{padding-top:8px}}ion-title{box-sizing:border-box;padding-inline-start:calc(48px + var(--padding-start));padding-inline-end:calc(48px + var(--padding-end));font-size:22px;font-weight:700}:host(.drawer) ion-title{font-size:18px}ion-content{--background: transparent;--color: var(--kirby-modal-color, var(--kirby-black));display:flex;flex-direction:column;--padding-top: 24px;--padding-bottom: 24px;--padding-start: 16px;--padding-end: 16px}ion-content ::ng-deep>*{box-sizing:border-box;display:block}@media (min-width: 721px){ion-content{--padding-start: 56px;--padding-end: 56px}}:host(.collapsible-title) ion-content{--padding-top: 0px}:host(.collapsible-title) ion-content ion-header ion-toolbar:first-of-type{padding-top:0;--padding-top: 0px;--padding-bottom: 0px;--padding-start: 0px;--padding-end: 0px}:host(.collapsible-title) ion-title{font-size:16px;font-weight:700}\n"], components: [{ type: i4.IonHeader, selector: "ion-header", inputs: ["collapse", "mode", "translucent"] }, { type: i4.IonToolbar, selector: "ion-toolbar", inputs: ["color", "mode"] }, { type: i4.IonTitle, selector: "ion-title", inputs: ["color", "size"] }, { type: i4.IonButtons, selector: "ion-buttons", inputs: ["collapse"] }, { type: i4.IonContent, selector: "ion-content", inputs: ["color", "forceOverscroll", "fullscreen", "scrollEvents", "scrollX", "scrollY"] }, { type: i5.ButtonComponent, selector: "button[kirby-button],Button[kirby-button]", inputs: ["attentionLevel", "isDestructive", "themeColor", "expand", "isFloating", "size"] }, { type: i6.IconComponent, selector: "kirby-icon", inputs: ["size", "name", "customName"] }], directives: [{ type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i7.NgComponentOutlet, selector: "[ngComponentOutlet]", inputs: ["ngComponentOutlet", "ngComponentOutletInjector", "ngComponentOutletContent", "ngComponentOutletNgModuleFactory"] }, { type: i8.RouterOutlet, selector: "router-outlet", outputs: ["activate", "deactivate", "attach", "detach"], exportAs: ["outlet"] }] });
459
406
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.9", ngImport: i0, type: ModalWrapperComponent, decorators: [{
460
407
  type: Component,
461
- args: [{ selector: 'kirby-modal-wrapper', providers: [{ provide: Modal, useExisting: ModalWrapperComponent }], template: "<ion-header (touchstart)=\"onHeaderTouchStart($event)\">\n <ion-toolbar>\n <ion-title></ion-title>\n <ion-buttons slot=\"start\" *ngIf=\"config.flavor === 'drawer'\">\n <ng-container *ngTemplateOutlet=\"closeButton; context: { icon: 'arrow-down' }\"></ng-container>\n </ion-buttons>\n <ion-buttons slot=\"end\" *ngIf=\"config.flavor === 'modal'\">\n <ng-container *ngTemplateOutlet=\"closeButton; context: { icon: 'close' }\"></ng-container>\n </ion-buttons>\n <ion-buttons slot=\"end\" *ngIf=\"config.flavor === 'drawer' && config.drawerSupplementaryAction\">\n <ng-container\n *ngTemplateOutlet=\"supplementaryButton; context: { btn: config.drawerSupplementaryAction }\"\n ></ng-container>\n </ion-buttons>\n </ion-toolbar>\n</ion-header>\n\n<ion-content [scrollEvents]=\"true\">\n <ion-header *ngIf=\"_hasCollapsibleTitle\" collapse=\"condense\">\n <ion-toolbar>\n <span class=\"kirby-text-large\" #contentTitle></span>\n </ion-toolbar>\n </ion-header>\n <ng-container\n *ngComponentOutlet=\"config.component; injector: componentPropsInjector\"\n ></ng-container>\n <router-outlet\n name=\"kirbyModalWrapperOutlet\"\n [style.visibility]=\"config.modalRoute ? 'visible' : 'hidden'\"\n ></router-outlet>\n</ion-content>\n\n<ng-template #closeButton let-icon=\"icon\">\n <button kirby-button attentionLevel=\"4\" size=\"md\" (click)=\"close()\">\n <kirby-icon [name]=\"icon\"></kirby-icon>\n </button>\n</ng-template>\n\n<ng-template #supplementaryButton let-btn=\"btn\">\n <button kirby-button attentionLevel=\"2\" size=\"md\" (click)=\"btn.action($event)\">\n <kirby-icon [name]=\"btn.iconName\"></kirby-icon>\n </button>\n</ng-template>\n", styles: ["ion-header ion-toolbar{--padding-start: 16px;--padding-end: 16px;--padding-bottom: 12px;--padding-top: 12px;--border-width: 0;--background: transparent;--color: var(--kirby-modal-color, var(--kirby-black))}ion-header ion-toolbar button{color:var(--color)}@media (min-width: 721px){ion-header ion-toolbar{padding-top:8px}}:host{--vh100: var(--vh, 1vh) * 100;--header-height: 0px;--footer-height: 0px}:host.drawer ion-header ion-toolbar:first-of-type{padding-top:0}@media (min-width: 721px){:host-context(ion-modal:not(.kirby-modal-full-height)){padding-top:0;position:relative;contain:inherit;min-height:min(var(--min-height),var(--vh100) - var(--kirby-modal-padding-top, 0px))}:host-context(ion-modal:not(.kirby-modal-full-height)) ion-content{contain:content;max-height:calc(var(--vh100) - var(--kirby-modal-padding-top, 0px) - var(--header-height) - var(--footer-height))}:host-context(ion-modal:not(.kirby-modal-full-height)) ion-content::part(scroll){height:\"100%\";position:relative}:host-context(ion-modal:not(.kirby-modal-full-height)).drawer ion-content::part(scroll){transition:padding-bottom .15s ease-out}:host-context(ion-modal:not(.kirby-modal-full-height)).drawer.keyboard-visible ion-content::part(scroll){transition:padding-bottom .25s ease-out 1ms}}:host-context(ion-modal:not(.kirby-modal-full-height)).drawer{padding-top:0;position:relative;contain:inherit;min-height:min(var(--min-height),var(--vh100) - var(--kirby-modal-padding-top, 0px))}:host-context(ion-modal:not(.kirby-modal-full-height)).drawer ion-content{contain:content;max-height:calc(var(--vh100) - var(--kirby-modal-padding-top, 0px) - var(--header-height) - var(--footer-height))}:host-context(ion-modal:not(.kirby-modal-full-height)).drawer ion-content::part(scroll){height:\"100%\";position:relative}:host-context(ion-modal:not(.kirby-modal-full-height)).drawer.drawer ion-content::part(scroll){transition:padding-bottom .15s ease-out}:host-context(ion-modal:not(.kirby-modal-full-height)).drawer.drawer.keyboard-visible ion-content::part(scroll){transition:padding-bottom .25s ease-out 1ms}:host-context(ion-modal.modal-card:not(.kirby-drawer)) ion-header ion-toolbar:first-of-type{padding-top:var(--kirby-safe-area-top, 0)}@media (min-width: 721px){:host-context(ion-modal.modal-card:not(.kirby-drawer)) ion-header ion-toolbar:first-of-type{padding-top:8px}}ion-title{box-sizing:border-box;padding-inline-start:calc(48px + var(--padding-start));padding-inline-end:calc(48px + var(--padding-end));font-size:22px;font-weight:700}:host(.drawer) ion-title{font-size:18px}ion-content{--background: transparent;--color: var(--kirby-modal-color, var(--kirby-black));display:flex;flex-direction:column;--padding-top: 24px;--padding-bottom: 24px;--padding-start: 16px;--padding-end: 16px}ion-content ::ng-deep>*{box-sizing:border-box;display:block}@media (min-width: 721px){ion-content{--padding-start: 56px;--padding-end: 56px}}:host(.collapsible-title) ion-content{--padding-top: 0px}:host(.collapsible-title) ion-content ion-header ion-toolbar:first-of-type{padding-top:0;--padding-top: 0px;--padding-bottom: 0px;--padding-start: 0px;--padding-end: 0px}:host(.collapsible-title) ion-title{font-size:16px;font-weight:700}\n"] }]
462
- }], ctorParameters: function () { return [{ type: i0.Injector }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.NgZone }, { type: i1.ResizeObserverService }, { type: i0.ComponentFactoryResolver }, { type: i2.WindowRef }, { type: i3.PlatformService }]; }, propDecorators: { _hasCollapsibleTitle: [{
408
+ args: [{ selector: 'kirby-modal-wrapper', providers: [
409
+ { provide: Modal, useExisting: ModalWrapperComponent },
410
+ { provide: ModalElementsAdvertiser, useExisting: ModalWrapperComponent },
411
+ ], template: "<ion-header (touchstart)=\"onHeaderTouchStart($event)\">\n <ion-toolbar>\n <ion-title></ion-title>\n <ion-buttons slot=\"start\" *ngIf=\"config.flavor === 'drawer'\">\n <ng-container *ngTemplateOutlet=\"closeButton; context: { icon: 'arrow-down' }\"></ng-container>\n </ion-buttons>\n <ion-buttons slot=\"end\" *ngIf=\"config.flavor === 'modal'\">\n <ng-container *ngTemplateOutlet=\"closeButton; context: { icon: 'close' }\"></ng-container>\n </ion-buttons>\n <ion-buttons slot=\"end\" *ngIf=\"config.flavor === 'drawer' && config.drawerSupplementaryAction\">\n <ng-container\n *ngTemplateOutlet=\"supplementaryButton; context: { btn: config.drawerSupplementaryAction }\"\n ></ng-container>\n </ion-buttons>\n </ion-toolbar>\n</ion-header>\n\n<ion-content [scrollEvents]=\"true\">\n <ion-header *ngIf=\"_hasCollapsibleTitle\" collapse=\"condense\">\n <ion-toolbar>\n <span class=\"kirby-text-large\" #contentTitle></span>\n </ion-toolbar>\n </ion-header>\n <ng-container\n *ngComponentOutlet=\"config.component; injector: componentPropsInjector\"\n ></ng-container>\n <router-outlet\n name=\"kirbyModalWrapperOutlet\"\n [style.visibility]=\"config.modalRoute ? 'visible' : 'hidden'\"\n ></router-outlet>\n</ion-content>\n\n<ng-template #closeButton let-icon=\"icon\">\n <button kirby-button attentionLevel=\"4\" size=\"md\" (click)=\"close()\">\n <kirby-icon [name]=\"icon\"></kirby-icon>\n </button>\n</ng-template>\n\n<ng-template #supplementaryButton let-btn=\"btn\">\n <button kirby-button attentionLevel=\"2\" size=\"md\" (click)=\"btn.action($event)\">\n <kirby-icon [name]=\"btn.iconName\"></kirby-icon>\n </button>\n</ng-template>\n", styles: ["ion-header{box-sizing:border-box}ion-header ion-toolbar{--padding-start: 16px;--padding-end: 16px;--padding-bottom: 12px;--padding-top: 12px;--border-width: 0;--background: transparent;--color: var(--kirby-modal-color, var(--kirby-black))}ion-header ion-toolbar button{color:var(--color)}@media (min-width: 721px){ion-header ion-toolbar{padding-top:8px}}:host{--vh100: var(--vh, 1vh) * 100;--header-height: 0px;--footer-height: 0px}:host.drawer ion-header ion-toolbar:first-of-type{padding-top:0}@media (min-width: 721px){:host-context(ion-modal:not(.kirby-modal-full-height)){padding-top:0;position:relative;contain:inherit;min-height:min(var(--min-height),var(--vh100) - var(--kirby-modal-padding-top, 0px))}:host-context(ion-modal:not(.kirby-modal-full-height)) ion-content{contain:content;max-height:calc(var(--vh100) - var(--kirby-modal-padding-top, 0px) - var(--header-height) - var(--footer-height))}:host-context(ion-modal:not(.kirby-modal-full-height)) ion-content::part(scroll){height:\"100%\";position:relative}:host-context(ion-modal:not(.kirby-modal-full-height)).drawer ion-content::part(scroll){transition:padding-bottom .15s ease-out}:host-context(ion-modal:not(.kirby-modal-full-height)).drawer.keyboard-visible ion-content::part(scroll){transition:padding-bottom .25s ease-out 1ms}}:host-context(ion-modal:not(.kirby-modal-full-height)).drawer{padding-top:0;position:relative;contain:inherit;min-height:min(var(--min-height),var(--vh100) - var(--kirby-modal-padding-top, 0px))}:host-context(ion-modal:not(.kirby-modal-full-height)).drawer ion-content{contain:content;max-height:calc(var(--vh100) - var(--kirby-modal-padding-top, 0px) - var(--header-height) - var(--footer-height))}:host-context(ion-modal:not(.kirby-modal-full-height)).drawer ion-content::part(scroll){height:\"100%\";position:relative}:host-context(ion-modal:not(.kirby-modal-full-height)).drawer.drawer ion-content::part(scroll){transition:padding-bottom .15s ease-out}:host-context(ion-modal:not(.kirby-modal-full-height)).drawer.drawer.keyboard-visible ion-content::part(scroll){transition:padding-bottom .25s ease-out 1ms}:host-context(ion-modal.modal-card:not(.kirby-drawer)) ion-header ion-toolbar:first-of-type{padding-top:var(--kirby-safe-area-top, 0)}@media (min-width: 721px){:host-context(ion-modal.modal-card:not(.kirby-drawer)) ion-header ion-toolbar:first-of-type{padding-top:8px}}ion-title{box-sizing:border-box;padding-inline-start:calc(48px + var(--padding-start));padding-inline-end:calc(48px + var(--padding-end));font-size:22px;font-weight:700}:host(.drawer) ion-title{font-size:18px}ion-content{--background: transparent;--color: var(--kirby-modal-color, var(--kirby-black));display:flex;flex-direction:column;--padding-top: 24px;--padding-bottom: 24px;--padding-start: 16px;--padding-end: 16px}ion-content ::ng-deep>*{box-sizing:border-box;display:block}@media (min-width: 721px){ion-content{--padding-start: 56px;--padding-end: 56px}}:host(.collapsible-title) ion-content{--padding-top: 0px}:host(.collapsible-title) ion-content ion-header ion-toolbar:first-of-type{padding-top:0;--padding-top: 0px;--padding-bottom: 0px;--padding-start: 0px;--padding-end: 0px}:host(.collapsible-title) ion-title{font-size:16px;font-weight:700}\n"] }]
412
+ }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i0.Injector }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.NgZone }, { type: i1.ResizeObserverService }, { type: i0.ComponentFactoryResolver }, { type: i2.WindowRef }, { type: i3.PlatformService }]; }, propDecorators: { _hasCollapsibleTitle: [{
463
413
  type: HostBinding,
464
414
  args: ['class.collapsible-title']
465
415
  }], config: [{
@@ -485,7 +435,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.9", ngImpor
485
435
  }], routerOutlet: [{
486
436
  type: ViewChild,
487
437
  args: [RouterOutlet, { static: true }]
488
- }], contentTitle: [{
438
+ }], _contentTitleElement: [{
489
439
  type: ViewChild,
490
440
  args: ['contentTitle', { read: ElementRef }]
491
441
  }], _isDrawer: [{
@@ -513,4 +463,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.9", ngImpor
513
463
  type: HostListener,
514
464
  args: ['window:resize']
515
465
  }] } });
516
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal-wrapper.component.js","sourceRoot":"","sources":["../../../../../../../../libs/designsystem/src/lib/components/modal/modal-wrapper/modal-wrapper.component.ts","../../../../../../../../libs/designsystem/src/lib/components/modal/modal-wrapper/modal-wrapper.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ComponentFactoryResolver,\n  ElementRef,\n  HostBinding,\n  HostListener,\n  Injector,\n  Input,\n  NgZone,\n  OnDestroy,\n  OnInit,\n  QueryList,\n  Renderer2,\n  RendererStyleFlags2,\n  ViewChild,\n  ViewChildren,\n} from '@angular/core';\nimport { ActivatedRoute, RouterOutlet } from '@angular/router';\nimport { IonContent, IonHeader, IonTitle, IonToolbar } from '@ionic/angular';\nimport { merge, Observable, Subject } from 'rxjs';\nimport { debounceTime, first, takeUntil } from 'rxjs/operators';\n\nimport { DesignTokenHelper } from '@kirbydesign/core';\n\nimport { KirbyAnimation } from '../../../animation/kirby-animation';\nimport { PlatformService } from '../../../helpers/platform.service';\nimport { WindowRef } from '../../../types/window-ref';\nimport { ButtonComponent } from '../../button/button.component';\nimport { ResizeObserverService } from '../../shared/resize-observer/resize-observer.service';\nimport { ResizeObserverEntry } from '../../shared/resize-observer/types/resize-observer-entry';\nimport { Modal } from '../services/modal.interfaces';\n\nimport { ModalConfig } from './config/modal-config';\nimport { COMPONENT_PROPS } from './config/modal-config.helper';\n\n@Component({\n  selector: 'kirby-modal-wrapper',\n  templateUrl: './modal-wrapper.component.html',\n  styleUrls: ['./modal-wrapper.component.scss'],\n  providers: [{ provide: Modal, useExisting: ModalWrapperComponent }],\n})\nexport class ModalWrapperComponent implements Modal, AfterViewInit, OnInit, OnDestroy {\n  @HostBinding('class.collapsible-title')\n  get _hasCollapsibleTitle() {\n    return !!this.config?.collapseTitle;\n  }\n\n  static readonly KEYBOARD_HIDE_DELAY_IN_MS = 100;\n\n  scrollY: number = Math.abs(this.windowRef.nativeWindow.scrollY);\n  private readonly VIEWPORT_RESIZE_DEBOUNCE_TIME = 100;\n\n  set scrollDisabled(disabled: boolean) {\n    this.ionContent.scrollY = !disabled;\n  }\n\n  @Input() config: ModalConfig;\n  componentPropsInjector: Injector;\n\n  @ViewChildren(ButtonComponent, { read: ElementRef }) private toolbarButtonsQuery: QueryList<\n    ElementRef<HTMLButtonElement>\n  >;\n  @ViewChild(IonContent, { static: true }) private ionContent: IonContent;\n  @ViewChild(IonContent, { static: true, read: ElementRef })\n  private ionContentElement: ElementRef<HTMLIonContentElement>;\n  @ViewChild(IonHeader, { static: true, read: ElementRef })\n  private ionHeaderElement: ElementRef<HTMLIonHeaderElement>;\n  @ViewChild(IonToolbar, { static: true, read: ElementRef })\n  private ionToolbarElement: ElementRef<HTMLIonToolbarElement>;\n  @ViewChild(IonTitle, { static: true, read: ElementRef })\n  private ionTitleElement: ElementRef<HTMLIonTitleElement>;\n  @ViewChild(RouterOutlet, { static: true }) private routerOutlet: RouterOutlet;\n\n  @ViewChild('contentTitle', { read: ElementRef })\n  private contentTitle: ElementRef<HTMLElement>;\n\n  private keyboardVisible = false;\n  private toolbarButtons: HTMLButtonElement[] = [];\n  private delayedClose = () => {};\n  private delayedCloseTimeoutId;\n  private initialViewportHeight: number;\n  private viewportResized = false;\n  private ionModalElement?: HTMLIonModalElement;\n  private readonly ionModalDidPresent = new Subject<void>();\n  readonly didPresent = this.ionModalDidPresent.toPromise();\n  private readonly ionModalWillDismiss = new Subject<void>();\n  readonly willClose = this.ionModalWillDismiss.toPromise();\n  private viewportResize = new Subject<void>();\n  private viewportResize$ = this.viewportResize\n    .asObservable()\n    .pipe(debounceTime(this.VIEWPORT_RESIZE_DEBOUNCE_TIME));\n  private _mutationObserver: MutationObserver;\n  private get mutationObserver(): MutationObserver {\n    if (!this._mutationObserver) {\n      this._mutationObserver = this.createEmbeddedElementsMutationObserver();\n    }\n    return this._mutationObserver;\n  }\n  private _intersectionObserver: IntersectionObserver;\n  private get intersectionObserver(): IntersectionObserver {\n    if (!this._intersectionObserver) {\n      this._intersectionObserver = this.createModalWrapperIntersectionObserver();\n    }\n    return this._intersectionObserver;\n  }\n  private destroy$ = new Subject();\n\n  @HostBinding('class.drawer')\n  get _isDrawer() {\n    return this.config.flavor === 'drawer';\n  }\n\n  willClose$ = this.ionModalWillDismiss.pipe(first());\n\n  constructor(\n    private injector: Injector,\n    private elementRef: ElementRef<HTMLElement>,\n    private renderer: Renderer2,\n    private zone: NgZone,\n    private resizeObserverService: ResizeObserverService,\n    private componentFactoryResolver: ComponentFactoryResolver,\n    private windowRef: WindowRef,\n    private platform: PlatformService\n  ) {\n    this.setViewportHeight();\n    this.observeViewportResize();\n  }\n\n  ngOnInit(): void {\n    this.ionModalElement = this.elementRef.nativeElement.closest('ion-modal');\n    this.initializeSizing();\n    this.initializeModalRoute();\n    this.listenForIonModalDidPresent();\n    this.listenForIonModalWillDismiss();\n    this.initializeResizeModalToModalWrapper();\n    this.componentPropsInjector = Injector.create({\n      providers: [{ provide: COMPONENT_PROPS, useValue: this.config.componentProps }],\n      parent: this.injector,\n    });\n  }\n\n  private initializeResizeModalToModalWrapper() {\n    if (this.config.flavor === 'drawer' && this.config.interactWithBackground) {\n      merge(this.ionModalDidPresent, this.viewportResize$)\n        .pipe(takeUntil(this.destroy$))\n        .subscribe(() => {\n          // wait for template to render\n          setTimeout(() => {\n            const domRect = this.elementRef.nativeElement.getBoundingClientRect();\n            const document = this.windowRef.nativeWindow.document.documentElement;\n            const right = document.clientWidth - domRect.right;\n            this.renderer.setStyle(this.ionModalElement, 'top', `${domRect.top}px`);\n            this.renderer.setStyle(this.ionModalElement, 'left', `${domRect.left}px`);\n            this.renderer.setStyle(this.ionModalElement, 'right', `${right}px`);\n          });\n        });\n    }\n  }\n\n  private initializeSizing() {\n    if (this.config.size === 'full-height') return;\n    this.patchScrollElementSize();\n    this.observeHeaderResize();\n    this.observeModalFullHeight();\n  }\n\n  private initializeModalRoute() {\n    if (this.config.modalRoute) {\n      this.onSiblingModalRouteActivated(this.config.siblingModalRouteActivated$);\n      // Load component from modal-route inside router-outlet:\n      this.routerOutlet.activateWith(this.config.modalRoute, this.componentFactoryResolver);\n    }\n  }\n\n  private onSiblingModalRouteActivated(siblingModalRouteActivated$?: Observable<ActivatedRoute>) {\n    if (!siblingModalRouteActivated$) return;\n    siblingModalRouteActivated$.pipe(takeUntil(this.willClose$)).subscribe((route) => {\n      if (this.routerOutlet.isActivated) {\n        this.mutationObserver.disconnect();\n        this.routerOutlet.deactivate();\n        this.clearEmbeddedElements();\n      }\n      this.routerOutlet.activateWith(route, this.componentFactoryResolver);\n      this.checkForEmbeddedElements();\n    });\n  }\n\n  private patchScrollElementSize(): void {\n    const supportsCssShadowParts = 'part' in HTMLElement.prototype;\n    if (supportsCssShadowParts) return;\n    this.ionContent.getScrollElement().then((scrollElement) => {\n      this.renderer.setStyle(scrollElement, 'height', '100%');\n      this.renderer.setStyle(scrollElement, 'position', 'relative');\n      if (this.config.flavor === 'drawer') {\n        this.renderer.setStyle(\n          scrollElement,\n          'transition',\n          'padding-bottom ' + DesignTokenHelper.softKeyboardTransitionLeave\n        );\n      }\n    });\n  }\n\n  private observeModalFullHeight() {\n    const ionModalWrapper = this.elementRef.nativeElement.closest<HTMLElement>('.modal-wrapper');\n    if (!ionModalWrapper) return;\n    // Start observing when modal has finished animating:\n    this.didPresent.then(() => {\n      this.intersectionObserver.observe(ionModalWrapper);\n    });\n  }\n\n  ngAfterViewInit(): void {\n    if (this.toolbarButtonsQuery) {\n      this.toolbarButtons = this.toolbarButtonsQuery.map((buttonRef) => buttonRef.nativeElement);\n    }\n    this.checkForEmbeddedElements();\n  }\n\n  private checkForEmbeddedElements() {\n    this.moveEmbeddedElements();\n    this.observeEmbeddedElements();\n  }\n\n  private observeHeaderResize() {\n    this.resizeObserverService.observe(this.ionHeaderElement.nativeElement, (entry) => {\n      const [property, pixelValue] = ['--header-height', `${entry.contentRect.height}px`];\n      this.setCssVar(this.elementRef.nativeElement, property, pixelValue);\n    });\n  }\n\n  private moveEmbeddedElements() {\n    const parentElement = this.getEmbeddedComponentElement();\n    if (parentElement) {\n      Object.entries(this.elementToParentMap).forEach(([tagName, getNewParent]) => {\n        const embeddedElement = parentElement.querySelector<HTMLElement>(tagName);\n        if (embeddedElement) {\n          this.moveChild(embeddedElement, getNewParent());\n        }\n      });\n    }\n  }\n\n  private listenForIonModalDidPresent() {\n    if (this.ionModalElement) {\n      this.ionModalElement.addEventListener('ionModalDidPresent', () => {\n        this.ionModalDidPresent.next();\n        this.ionModalDidPresent.complete();\n      });\n    }\n  }\n\n  private listenForIonModalWillDismiss() {\n    if (this.ionModalElement) {\n      this.ionModalElement.addEventListener('ionModalWillDismiss', () => {\n        this.ionModalWillDismiss.next();\n        this.ionModalWillDismiss.complete();\n      });\n    }\n  }\n\n  scrollToTop(scrollDuration?: KirbyAnimation.Duration) {\n    this.ionContent.scrollToTop(scrollDuration || 0);\n  }\n\n  scrollToBottom(scrollDuration?: KirbyAnimation.Duration) {\n    this.ionContent.scrollToBottom(scrollDuration || 0);\n  }\n\n  async close(data?: any): Promise<void> {\n    if (!this.ionModalElement) {\n      return;\n    }\n    if (!this.keyboardVisible || !this.viewportResized) {\n      // No keyboard visible or viewport not resized:\n      // Dismiss modal and return:\n      clearTimeout(this.delayedCloseTimeoutId);\n      await this.ionModalElement.dismiss(data);\n      return;\n    }\n\n    // Keyboard visible:\n    // Blur active element and wait for keyboard to hide,\n    // then dismiss modal and return:\n    this.blurActiveElement();\n    return new Promise<void>((resolve) => {\n      this.delayedClose = async () => {\n        await this.ionModalElement.dismiss(data);\n        resolve();\n      };\n      this.delayedCloseTimeoutId = setTimeout(\n        this.delayedClose,\n        ModalWrapperComponent.KEYBOARD_HIDE_DELAY_IN_MS\n      );\n    });\n  }\n\n  @HostListener('window:focus')\n  @HostListener('window:focusout')\n  onFocusChange() {\n    // This fixes an undesired scroll behaviour occurring on keyboard-tabbing backwards (with shift+tab):\n    this.windowRef.nativeWindow.scrollTo({ top: this.scrollY });\n  }\n\n  @HostListener('window:ionKeyboardDidShow', ['$event.detail.keyboardHeight'])\n  @HostListener('window:keyboardWillShow', ['$event.keyboardHeight'])\n  _onKeyboardShow(keyboardHeight: number) {\n    this.setKeyboardVisibility(keyboardHeight);\n  }\n\n  @HostListener('window:ionKeyboardDidHide')\n  @HostListener('window:keyboardWillHide')\n  _onKeyboardHide() {\n    this.setKeyboardVisibility(0);\n  }\n\n  private toggleContentMaxHeight(freeze: boolean) {\n    const shouldToggleMaxHeight =\n      this.config.flavor === 'modal' && this.platform.isPhabletOrBigger();\n    if (!shouldToggleMaxHeight) return;\n    const style = 'max-height';\n    const contentElement = this.ionContentElement.nativeElement;\n    this.zone.run(() => {\n      if (freeze) {\n        const contentHeight = contentElement.offsetHeight;\n        this.renderer.setStyle(contentElement, style, `${contentHeight}px`);\n      } else {\n        this.renderer.removeStyle(contentElement, style);\n      }\n    });\n  }\n\n  private setKeyboardVisibility(keyboardHeight: number) {\n    const keyboardAlreadyVisible = keyboardHeight > 0 && this.keyboardVisible;\n    const keyboardAlreadyHidden = keyboardHeight === 0 && !this.keyboardVisible;\n    if (keyboardAlreadyVisible || keyboardAlreadyHidden) return;\n    this.keyboardVisible = keyboardHeight > 0;\n    this.toggleContentMaxHeight(this.keyboardVisible);\n    this.setKeyboardOverlap(keyboardHeight);\n  }\n\n  private getKeyboardOverlap(keyboardHeight: number, element: Element) {\n    if (keyboardHeight <= 0 || !element) return 0;\n    const distanceFromViewportBottomToElement = Math.floor(\n      this.windowRef.nativeWindow.innerHeight - element.getBoundingClientRect().bottom\n    );\n    return Math.max(keyboardHeight - distanceFromViewportBottomToElement, 0);\n  }\n\n  private setCssVar(element: Element, property: string, value: string) {\n    this.zone.run(() =>\n      this.renderer.setStyle(element, property, value, RendererStyleFlags2.DashCase)\n    );\n  }\n\n  private toggleCssClass(element: Element, klass: string, condition: boolean) {\n    this.zone.run(() =>\n      condition ? this.renderer.addClass(element, klass) : this.renderer.removeClass(element, klass)\n    );\n  }\n\n  private setKeyboardOverlap(keyboardHeight: number) {\n    this.toggleCssClass(this.elementRef.nativeElement, 'keyboard-visible', keyboardHeight > 0);\n    const keyboardOverlap = this.getKeyboardOverlap(keyboardHeight, this.elementRef.nativeElement);\n    let snapFooterToKeyboard = false;\n    const embeddedFooterElement = this.getEmbeddedFooterElement();\n    if (embeddedFooterElement) {\n      this.setCssVar(embeddedFooterElement, '--keyboard-offset', `${keyboardOverlap}px`);\n      snapFooterToKeyboard = embeddedFooterElement.classList.contains('snap-to-keyboard');\n    }\n\n    const contentElement = this.ionContentElement.nativeElement;\n    const contentKeyboardOffset = snapFooterToKeyboard\n      ? keyboardOverlap\n      : this.getKeyboardOverlap(keyboardHeight, contentElement);\n    this.setCssVar(contentElement, '--keyboard-offset', `${contentKeyboardOffset}px`);\n  }\n\n  onHeaderTouchStart(event: TouchEvent) {\n    if (this.keyboardVisible) {\n      const isToolbarButtonTouch = this.toolbarButtons.some((button) => {\n        return (\n          event.target instanceof HTMLElement &&\n          (event.target === button || button.contains(event.target))\n        );\n      });\n      // Prevent blur if event target is a toolbar button\n      // (to allow tap event to fire):\n      if (!isToolbarButtonTouch) {\n        this.blurActiveElement();\n      }\n    }\n  }\n\n  @HostListener('window:resize')\n  _onWindowResize() {\n    this.setViewportHeight();\n  }\n\n  private setViewportHeight() {\n    const vh = (this.windowRef.nativeWindow.innerHeight * 0.01).toFixed(2);\n    this.setCssVar(this.elementRef.nativeElement, '--vh', `${vh}px`);\n  }\n\n  private observeViewportResize() {\n    this.resizeObserverService.observe(this.windowRef.nativeWindow.document.body, (entry) =>\n      this.onViewportResize(entry)\n    );\n  }\n\n  private onViewportResize(entry: ResizeObserverEntry) {\n    if (!this.initialViewportHeight) {\n      // Initial observe callback, register initial height:\n      this.initialViewportHeight = entry.contentRect.height;\n      return;\n    }\n    this.viewportResized = entry.contentRect.height !== this.initialViewportHeight;\n    if (!this.viewportResized) {\n      // We are back to initial view port height, check for pending close func:\n      if (this.delayedCloseTimeoutId) {\n        clearTimeout(this.delayedCloseTimeoutId);\n        this.delayedClose();\n      }\n    }\n    this.viewportResize.next();\n  }\n\n  blurActiveElement() {\n    const BLUR_TARGET_SELECTOR = 'input, textarea';\n    if (this.keyboardVisible) {\n      if (\n        document.activeElement instanceof HTMLElement &&\n        document.activeElement.matches(BLUR_TARGET_SELECTOR)\n      ) {\n        document.activeElement.blur();\n      }\n    }\n  }\n\n  private readonly elementToParentMap: { [key: string]: () => HTMLElement[] } = {\n    'KIRBY-MODAL-FOOTER': () => [this.elementRef.nativeElement],\n    'KIRBY-PAGE-TITLE': () =>\n      [this.ionTitleElement.nativeElement, this.contentTitle?.nativeElement].filter(\n        (element) => element !== undefined\n      ),\n    'KIRBY-PAGE-PROGRESS': () => [this.ionToolbarElement.nativeElement],\n  };\n\n  private clearEmbeddedElements() {\n    Object.entries(this.elementToParentMap).forEach(([tagName, getParents]) => {\n      const newParents = getParents();\n      newParents.forEach((newParent) => {\n        const embeddedElement = newParent.querySelector<HTMLElement>(`:scope > ${tagName}`);\n        this.removeChild(embeddedElement);\n      });\n    });\n  }\n\n  /* TODO: Rewrite to make this function independent of element order. \n     See: https://github.com/kirbydesign/designsystem/issues/2096\n  */\n  private getEmbeddedComponentElement(): null | Element {\n    const contentElementChildren = Array.from(\n      this.ionContentElement.nativeElement.children\n    ).reverse(); // Reverse makes it easier to retrieve the last children in the list\n\n    const embeddedComponentElement = !!this.config.modalRoute\n      ? contentElementChildren[0]\n      : contentElementChildren[1];\n\n    /* \n      As ModalConfig.component has type 'any' all values are valid for component; \n      explicitly handle the case where no embedded component element is found due to \n      this.\n    */\n    if (!embeddedComponentElement) return null;\n    return embeddedComponentElement;\n  }\n\n  private getEmbeddedFooterElement() {\n    return this.elementRef.nativeElement.querySelector<HTMLElement>('kirby-modal-footer');\n  }\n\n  private moveChild(child: Element, newParents: Element[]) {\n    this.renderer.removeChild(child.parentElement, child);\n\n    newParents.forEach((newParent, index) => {\n      const childToAppend = index > 0 ? child.cloneNode(true) : child;\n      this.renderer.appendChild(newParent, childToAppend);\n      // Append adds child as last element of parent; therefore retrieve with lastElementChild\n      const childElement = newParent.lastElementChild;\n\n      if (childElement.tagName === 'KIRBY-MODAL-FOOTER') {\n        this.resizeObserverService.observe(childElement, (entry) => {\n          const [property, pixelValue] = [\n            '--footer-height',\n            `${Math.floor(entry.contentRect.height)}px`,\n          ];\n          this.setCssVar(this.elementRef.nativeElement, property, pixelValue);\n        });\n      }\n    });\n  }\n\n  private removeChild(child?: Element) {\n    if (!!child) {\n      this.renderer.removeChild(child.parentElement, child);\n    }\n  }\n\n  private observeEmbeddedElements() {\n    const parentElement = this.getEmbeddedComponentElement();\n    if (parentElement === null) return; // Mute observe warning when parentElement is null\n\n    this.mutationObserver.observe(parentElement, {\n      childList: true, // Listen for addition or removal of child nodes\n    });\n  }\n\n  private createEmbeddedElementsMutationObserver(): MutationObserver {\n    const observedElements = Object.keys(this.elementToParentMap);\n    const callback = (mutations: MutationRecord[]) => {\n      const addedNodes = mutations\n        .filter((mutation) => mutation.type === 'childList') // Filter for mutation to the tree of nodes\n        .map((mutation) => {\n          // Only check for addedNodes as removal is handled by the Angular renderer:\n          return Array.from(mutation.addedNodes).filter((node) =>\n            observedElements.includes(node.nodeName)\n          );\n        });\n\n      const addedElements = Array.prototype\n        .concat(...addedNodes)\n        .filter((node): node is HTMLElement => node instanceof HTMLElement);\n\n      addedElements.forEach((addedElement) => {\n        const newParentElement = this.elementToParentMap[addedElement.nodeName]();\n        // Move embedded element out of content and append to new parent:\n        this.moveChild(addedElement, newParentElement);\n      });\n    };\n    return new MutationObserver(callback);\n  }\n\n  private createModalWrapperIntersectionObserver(): IntersectionObserver {\n    const callback: IntersectionObserverCallback = (entries) => {\n      const entry = entries[0];\n      const isTouchingViewport = entry.intersectionRatio < 1;\n      if (isTouchingViewport) {\n        this.renderer.addClass(entry.target, 'full-height');\n      } else {\n        this.renderer.removeClass(entry.target, 'full-height');\n      }\n    };\n\n    // Set explicit viewport root if within iframe:\n    const root = this.windowRef.nativeWindow.frameElement\n      ? (this.windowRef.nativeWindow.document as any) // Cast to `any` as Typescript lib.d.ts doesnt support Document type yet\n      : undefined;\n    const options: IntersectionObserverInit = {\n      rootMargin: '0px 0px -1px 0px', // `bottom: -1px` allows checking when the modal bottom is touching the viewport\n      root,\n      threshold: [0.99, 1],\n    };\n\n    return new IntersectionObserver(callback, options);\n  }\n\n  ngOnDestroy() {\n    if (this.routerOutlet.isActivated) {\n      this.routerOutlet.deactivate();\n    }\n    //clean up the observer\n    this.mutationObserver.disconnect();\n    delete this._mutationObserver;\n    this.intersectionObserver.disconnect();\n    delete this._intersectionObserver;\n    if (this.resizeObserverService) {\n      this.resizeObserverService.unobserve(this.windowRef.nativeWindow.document.body);\n      this.resizeObserverService.unobserve(this.ionHeaderElement.nativeElement);\n      this.resizeObserverService.unobserve(this.getEmbeddedFooterElement());\n    }\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n}\n","<ion-header (touchstart)=\"onHeaderTouchStart($event)\">\n  <ion-toolbar>\n    <ion-title></ion-title>\n    <ion-buttons slot=\"start\" *ngIf=\"config.flavor === 'drawer'\">\n      <ng-container *ngTemplateOutlet=\"closeButton; context: { icon: 'arrow-down' }\"></ng-container>\n    </ion-buttons>\n    <ion-buttons slot=\"end\" *ngIf=\"config.flavor === 'modal'\">\n      <ng-container *ngTemplateOutlet=\"closeButton; context: { icon: 'close' }\"></ng-container>\n    </ion-buttons>\n    <ion-buttons slot=\"end\" *ngIf=\"config.flavor === 'drawer' && config.drawerSupplementaryAction\">\n      <ng-container\n        *ngTemplateOutlet=\"supplementaryButton; context: { btn: config.drawerSupplementaryAction }\"\n      ></ng-container>\n    </ion-buttons>\n  </ion-toolbar>\n</ion-header>\n\n<ion-content [scrollEvents]=\"true\">\n  <ion-header *ngIf=\"_hasCollapsibleTitle\" collapse=\"condense\">\n    <ion-toolbar>\n      <span class=\"kirby-text-large\" #contentTitle></span>\n    </ion-toolbar>\n  </ion-header>\n  <ng-container\n    *ngComponentOutlet=\"config.component; injector: componentPropsInjector\"\n  ></ng-container>\n  <router-outlet\n    name=\"kirbyModalWrapperOutlet\"\n    [style.visibility]=\"config.modalRoute ? 'visible' : 'hidden'\"\n  ></router-outlet>\n</ion-content>\n\n<ng-template #closeButton let-icon=\"icon\">\n  <button kirby-button attentionLevel=\"4\" size=\"md\" (click)=\"close()\">\n    <kirby-icon [name]=\"icon\"></kirby-icon>\n  </button>\n</ng-template>\n\n<ng-template #supplementaryButton let-btn=\"btn\">\n  <button kirby-button attentionLevel=\"2\" size=\"md\" (click)=\"btn.action($event)\">\n    <kirby-icon [name]=\"btn.iconName\"></kirby-icon>\n  </button>\n</ng-template>\n"]}
466
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal-wrapper.component.js","sourceRoot":"","sources":["../../../../../../../../libs/designsystem/src/lib/components/modal/modal-wrapper/modal-wrapper.component.ts","../../../../../../../../libs/designsystem/src/lib/components/modal/modal-wrapper/modal-wrapper.component.html"],"names":[],"mappings":"AAAA,OAAO,EAEL,iBAAiB,EACjB,SAAS,EACT,wBAAwB,EACxB,UAAU,EACV,WAAW,EACX,YAAY,EACZ,QAAQ,EACR,KAAK,EACL,MAAM,EAGN,SAAS,EACT,SAAS,EACT,mBAAmB,EACnB,SAAS,EACT,YAAY,GACb,MAAM,eAAe,CAAC;AACvB,OAAO,EAAkB,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/D,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,QAAQ,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAC7E,OAAO,EAAE,KAAK,EAAc,OAAO,EAAE,MAAM,MAAM,CAAC;AAClD,OAAO,EAAE,YAAY,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAEhE,OAAO,EAAE,iBAAiB,EAAE,MAAM,mBAAmB,CAAC;AAGtD,OAAO,EAAE,eAAe,EAAE,MAAM,mCAAmC,CAAC;AACpE,OAAO,EAAE,SAAS,EAAE,MAAM,2BAA2B,CAAC;AACtD,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAC;AAChE,OAAO,EAAE,qBAAqB,EAAE,MAAM,sDAAsD,CAAC;AAE7F,OAAO,EAAE,KAAK,EAAE,uBAAuB,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAC;AAGhG,OAAO,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAC;AAC/D,OAAO,EAAE,0BAA0B,EAAE,MAAM,iCAAiC,CAAC;;;;;;;;;;AAW7E,MAAM,OAAO,qBAAqB;IAkFhC,YACU,cAAiC,EACjC,QAAkB,EAClB,UAAmC,EACnC,QAAmB,EACnB,IAAY,EACZ,qBAA4C,EAC5C,wBAAkD,EAClD,SAAoB,EACpB,QAAyB;QARzB,mBAAc,GAAd,cAAc,CAAmB;QACjC,aAAQ,GAAR,QAAQ,CAAU;QAClB,eAAU,GAAV,UAAU,CAAyB;QACnC,aAAQ,GAAR,QAAQ,CAAW;QACnB,SAAI,GAAJ,IAAI,CAAQ;QACZ,0BAAqB,GAArB,qBAAqB,CAAuB;QAC5C,6BAAwB,GAAxB,wBAAwB,CAA0B;QAClD,cAAS,GAAT,SAAS,CAAW;QACpB,aAAQ,GAAR,QAAQ,CAAiB;QAjFnC,YAAO,GAAW,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC;QAC/C,kCAA6B,GAAG,GAAG,CAAC;QAqC7C,oBAAe,GAAG,KAAK,CAAC;QACxB,mBAAc,GAAwB,EAAE,CAAC;QACzC,iBAAY,GAAG,GAAG,EAAE,GAAE,CAAC,CAAC;QAGxB,oBAAe,GAAG,KAAK,CAAC;QAEf,uBAAkB,GAAG,IAAI,OAAO,EAAQ,CAAC;QACjD,eAAU,GAAG,IAAI,CAAC,kBAAkB,CAAC,SAAS,EAAE,CAAC;QACzC,wBAAmB,GAAG,IAAI,OAAO,EAAQ,CAAC;QAClD,cAAS,GAAG,IAAI,CAAC,mBAAmB,CAAC,SAAS,EAAE,CAAC;QAClD,mBAAc,GAAG,IAAI,OAAO,EAAQ,CAAC;QACrC,oBAAe,GAAG,IAAI,CAAC,cAAc;aAC1C,YAAY,EAAE;aACd,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,6BAA6B,CAAC,CAAC,CAAC;QASlD,aAAQ,GAAG,IAAI,OAAO,EAAE,CAAC;QAOjC,eAAU,GAAG,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;QAiC5C,mBAAc,GAAuB,IAAI,CAAC;QAlBhD,IAAI,CAAC,iBAAiB,EAAE,CAAC;QACzB,IAAI,CAAC,qBAAqB,EAAE,CAAC;QAC7B,IAAI,CAAC,0BAA0B,GAAG,IAAI,0BAA0B,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAC;IACzF,CAAC;IA7FD,IACI,oBAAoB;QACtB,OAAO,CAAC,CAAC,IAAI,CAAC,MAAM,EAAE,aAAa,CAAC;IACtC,CAAC;IAOD,IAAI,cAAc,CAAC,QAAiB;QAClC,IAAI,CAAC,UAAU,CAAC,OAAO,GAAG,CAAC,QAAQ,CAAC;IACtC,CAAC;IAsBD,IAAI,mBAAmB;QACrB;;;YAGI;QACJ,IAAI,CAAC,IAAI,CAAC,oBAAoB,IAAI,IAAI,CAAC,oBAAoB,EAAE;YAC3D,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,CAAC;SACrC;QACD,OAAO,IAAI,CAAC,oBAAoB,CAAC;IACnC,CAAC;IAmBD,IAAY,oBAAoB;QAC9B,IAAI,CAAC,IAAI,CAAC,qBAAqB,EAAE;YAC/B,IAAI,CAAC,qBAAqB,GAAG,IAAI,CAAC,sCAAsC,EAAE,CAAC;SAC5E;QACD,OAAO,IAAI,CAAC,qBAAqB,CAAC;IACpC,CAAC;IAGD,IACI,SAAS;QACX,OAAO,IAAI,CAAC,MAAM,CAAC,MAAM,KAAK,QAAQ,CAAC;IACzC,CAAC;IAsBD,QAAQ;QACN,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;QAC1E,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACxB,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC5B,IAAI,CAAC,2BAA2B,EAAE,CAAC;QACnC,IAAI,CAAC,4BAA4B,EAAE,CAAC;QACpC,IAAI,CAAC,mCAAmC,EAAE,CAAC;QAC3C,IAAI,CAAC,sBAAsB,GAAG,QAAQ,CAAC,MAAM,CAAC;YAC5C,SAAS,EAAE,CAAC,EAAE,OAAO,EAAE,eAAe,EAAE,QAAQ,EAAE,IAAI,CAAC,MAAM,CAAC,cAAc,EAAE,CAAC;YAC/E,MAAM,EAAE,IAAI,CAAC,QAAQ;SACtB,CAAC,CAAC;IACL,CAAC;IAID,IAAY,aAAa,CAAC,MAA0B;QAClD,IAAI,MAAM,KAAK,IAAI,EAAE;YACnB,IAAI,CAAC,qBAAqB,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC,KAAK,EAAE,EAAE;gBACnD,MAAM,CAAC,QAAQ,EAAE,UAAU,CAAC,GAAG;oBAC7B,iBAAiB;oBACjB,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,WAAW,CAAC,MAAM,CAAC,IAAI;iBAC5C,CAAC;gBACF,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,QAAQ,EAAE,UAAU,CAAC,CAAC;YACtE,CAAC,CAAC,CAAC;SACJ;QAED,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC;IAC/B,CAAC;IAED,IAAY,aAAa;QACvB,OAAO,IAAI,CAAC,cAAc,CAAC;IAC7B,CAAC;IAEM,eAAe,CAAC,IAAsB,EAAE,YAAqC;QAClF,MAAM,iBAAiB,GAAG;YACxB,CAAC,gBAAgB,CAAC,MAAM,CAAC,EAAE,GAAG,EAAE;gBAC9B,IAAI,CAAC,0BAA0B,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC;gBACxD,IAAI,CAAC,aAAa,GAAG,YAAY,CAAC,aAAa,CAAC;YAClD,CAAC;YACD,CAAC,gBAAgB,CAAC,KAAK,CAAC,EAAE,GAAG,EAAE,CAC7B,IAAI,CAAC,0BAA0B,CAAC,QAAQ,CACtC,YAAY,EACZ,IAAI,CAAC,mBAAmB,EACxB,IAAI,CAAC,oBAAoB,EACzB,IAAI,CAAC,eAAe,CACrB;YACH,CAAC,gBAAgB,CAAC,aAAa,CAAC,EAAE,GAAG,EAAE,CACrC,IAAI,CAAC,0BAA0B,CAAC,eAAe,CAAC,YAAY,EAAE,IAAI,CAAC,iBAAiB,CAAC;SACxF,CAAC,IAAI,CAAC,CAAC;QAER,iBAAiB,EAAE,CAAC;IACtB,CAAC;IAEM,kBAAkB,CAAC,IAAsB,EAAE,YAAqC;QACrF,MAAM,oBAAoB,GAAG;YAC3B,CAAC,gBAAgB,CAAC,MAAM,CAAC,EAAE,GAAG,EAAE;gBAC9B,IAAI,CAAC,0BAA0B,CAAC,YAAY,CAAC,YAAY,CAAC,CAAC;gBAC3D,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;YAC5B,CAAC;YACD,CAAC,gBAAgB,CAAC,KAAK,CAAC,EAAE,GAAG,EAAE,CAC7B,IAAI,CAAC,0BAA0B,CAAC,WAAW,CACzC,YAAY,EACZ,IAAI,CAAC,oBAAoB,EACzB,IAAI,CAAC,mBAAmB,CACzB;YACH,CAAC,gBAAgB,CAAC,aAAa,CAAC,EAAE,GAAG,EAAE,CACrC,IAAI,CAAC,0BAA0B,CAAC,kBAAkB,CAAC,YAAY,CAAC;SACnE,CAAC,IAAI,CAAC,CAAC;QAER,oBAAoB,EAAE,CAAC;IACzB,CAAC;IAEO,mCAAmC;QACzC,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,KAAK,QAAQ,IAAI,IAAI,CAAC,MAAM,CAAC,sBAAsB,EAAE;YACzE,KAAK,CAAC,IAAI,CAAC,kBAAkB,EAAE,IAAI,CAAC,eAAe,CAAC;iBACjD,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;iBAC9B,SAAS,CAAC,GAAG,EAAE;gBACd,8BAA8B;gBAC9B,UAAU,CAAC,GAAG,EAAE;oBACd,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC;oBACtE,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,QAAQ,CAAC,eAAe,CAAC;oBACtE,MAAM,KAAK,GAAG,QAAQ,CAAC,WAAW,GAAG,OAAO,CAAC,KAAK,CAAC;oBACnD,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,eAAe,EAAE,KAAK,EAAE,GAAG,OAAO,CAAC,GAAG,IAAI,CAAC,CAAC;oBACxE,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,eAAe,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,IAAI,IAAI,CAAC,CAAC;oBAC1E,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,eAAe,EAAE,OAAO,EAAE,GAAG,KAAK,IAAI,CAAC,CAAC;gBACtE,CAAC,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;SACN;IACH,CAAC;IAEO,gBAAgB;QACtB,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,KAAK,aAAa;YAAE,OAAO;QAC/C,IAAI,CAAC,sBAAsB,EAAE,CAAC;QAC9B,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAC3B,IAAI,CAAC,sBAAsB,EAAE,CAAC;IAChC,CAAC;IAEO,oBAAoB;QAC1B,IAAI,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE;YAC1B,IAAI,CAAC,4BAA4B,CAAC,IAAI,CAAC,MAAM,CAAC,2BAA2B,CAAC,CAAC;YAC3E,wDAAwD;YACxD,IAAI,CAAC,YAAY,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE,IAAI,CAAC,wBAAwB,CAAC,CAAC;SACvF;IACH,CAAC;IAEO,4BAA4B,CAAC,2BAAwD;QAC3F,IAAI,CAAC,2BAA2B;YAAE,OAAO;QACzC,2BAA2B,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;YAC/E,IAAI,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE;gBACjC,IAAI,CAAC,YAAY,CAAC,UAAU,EAAE,CAAC;aAChC;YACD,IAAI,CAAC,YAAY,CAAC,YAAY,CAAC,KAAK,EAAE,IAAI,CAAC,wBAAwB,CAAC,CAAC;QACvE,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,sBAAsB;QAC5B,MAAM,sBAAsB,GAAG,MAAM,IAAI,WAAW,CAAC,SAAS,CAAC;QAC/D,IAAI,sBAAsB;YAAE,OAAO;QACnC,IAAI,CAAC,UAAU,CAAC,gBAAgB,EAAE,CAAC,IAAI,CAAC,CAAC,aAAa,EAAE,EAAE;YACxD,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,aAAa,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAC;YACxD,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,aAAa,EAAE,UAAU,EAAE,UAAU,CAAC,CAAC;YAC9D,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,KAAK,QAAQ,EAAE;gBACnC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CACpB,aAAa,EACb,YAAY,EACZ,iBAAiB,GAAG,iBAAiB,CAAC,2BAA2B,CAClE,CAAC;aACH;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,sBAAsB;QAC5B,MAAM,eAAe,GAAG,IAAI,CAAC,yBAAyB,EAAE,CAAC;QAEzD,IAAI,CAAC,eAAe;YAAE,OAAO;QAC7B,qDAAqD;QACrD,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,GAAG,EAAE;YACxB,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,eAAe,CAAC,CAAC;QACrD,CAAC,CAAC,CAAC;IACL,CAAC;IAED,8CAA8C;IACtC,yBAAyB;QAC/B,OAAO,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,aAAa,CAAC,gBAAgB,CAAC,CAAC;IACzE,CAAC;IAED,eAAe;QACb,IAAI,IAAI,CAAC,mBAAmB,EAAE;YAC5B,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,mBAAmB,CAAC,GAAG,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC;SAC5F;IACH,CAAC;IAEO,mBAAmB;QACzB,IAAI,CAAC,qBAAqB,CAAC,OAAO,CAAC,IAAI,CAAC,gBAAgB,CAAC,aAAa,EAAE,CAAC,KAAK,EAAE,EAAE;YAChF,MAAM,CAAC,QAAQ,EAAE,UAAU,CAAC,GAAG,CAAC,iBAAiB,EAAE,GAAG,KAAK,CAAC,WAAW,CAAC,MAAM,IAAI,CAAC,CAAC;YACpF,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,QAAQ,EAAE,UAAU,CAAC,CAAC;QACtE,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,2BAA2B;QACjC,IAAI,IAAI,CAAC,eAAe,EAAE;YACxB,IAAI,CAAC,eAAe,CAAC,gBAAgB,CAAC,oBAAoB,EAAE,GAAG,EAAE;gBAC/D,IAAI,CAAC,kBAAkB,CAAC,IAAI,EAAE,CAAC;gBAC/B,IAAI,CAAC,kBAAkB,CAAC,QAAQ,EAAE,CAAC;YACrC,CAAC,CAAC,CAAC;SACJ;IACH,CAAC;IAEO,4BAA4B;QAClC,IAAI,IAAI,CAAC,eAAe,EAAE;YACxB,IAAI,CAAC,eAAe,CAAC,gBAAgB,CAAC,qBAAqB,EAAE,GAAG,EAAE;gBAChE,IAAI,CAAC,mBAAmB,CAAC,IAAI,EAAE,CAAC;gBAChC,IAAI,CAAC,mBAAmB,CAAC,QAAQ,EAAE,CAAC;YACtC,CAAC,CAAC,CAAC;SACJ;IACH,CAAC;IAED,WAAW,CAAC,cAAwC;QAClD,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,cAAc,IAAI,CAAC,CAAC,CAAC;IACnD,CAAC;IAED,cAAc,CAAC,cAAwC;QACrD,IAAI,CAAC,UAAU,CAAC,cAAc,CAAC,cAAc,IAAI,CAAC,CAAC,CAAC;IACtD,CAAC;IAED,KAAK,CAAC,KAAK,CAAC,IAAU;QACpB,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE;YACzB,OAAO;SACR;QACD,IAAI,CAAC,IAAI,CAAC,eAAe,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE;YAClD,+CAA+C;YAC/C,4BAA4B;YAC5B,YAAY,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC;YACzC,MAAM,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;YACzC,OAAO;SACR;QAED,oBAAoB;QACpB,qDAAqD;QACrD,iCAAiC;QACjC,IAAI,CAAC,iBAAiB,EAAE,CAAC;QACzB,OAAO,IAAI,OAAO,CAAO,CAAC,OAAO,EAAE,EAAE;YACnC,IAAI,CAAC,YAAY,GAAG,KAAK,IAAI,EAAE;gBAC7B,MAAM,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;gBACzC,OAAO,EAAE,CAAC;YACZ,CAAC,CAAC;YACF,IAAI,CAAC,qBAAqB,GAAG,UAAU,CACrC,IAAI,CAAC,YAAY,EACjB,qBAAqB,CAAC,yBAAyB,CAChD,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC;IAID,aAAa;QACX,qGAAqG;QACrG,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,QAAQ,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;IAC9D,CAAC;IAID,eAAe,CAAC,cAAsB;QACpC,IAAI,CAAC,qBAAqB,CAAC,cAAc,CAAC,CAAC;IAC7C,CAAC;IAID,eAAe;QACb,IAAI,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;IAChC,CAAC;IAEO,sBAAsB,CAAC,MAAe;QAC5C,MAAM,qBAAqB,GACzB,IAAI,CAAC,MAAM,CAAC,MAAM,KAAK,OAAO,IAAI,IAAI,CAAC,QAAQ,CAAC,iBAAiB,EAAE,CAAC;QACtE,IAAI,CAAC,qBAAqB;YAAE,OAAO;QACnC,MAAM,KAAK,GAAG,YAAY,CAAC;QAC3B,MAAM,cAAc,GAAG,IAAI,CAAC,iBAAiB,CAAC,aAAa,CAAC;QAC5D,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE;YACjB,IAAI,MAAM,EAAE;gBACV,MAAM,aAAa,GAAG,cAAc,CAAC,YAAY,CAAC;gBAClD,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,cAAc,EAAE,KAAK,EAAE,GAAG,aAAa,IAAI,CAAC,CAAC;aACrE;iBAAM;gBACL,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,cAAc,EAAE,KAAK,CAAC,CAAC;aAClD;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,qBAAqB,CAAC,cAAsB;QAClD,MAAM,sBAAsB,GAAG,cAAc,GAAG,CAAC,IAAI,IAAI,CAAC,eAAe,CAAC;QAC1E,MAAM,qBAAqB,GAAG,cAAc,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC;QAC5E,IAAI,sBAAsB,IAAI,qBAAqB;YAAE,OAAO;QAC5D,IAAI,CAAC,eAAe,GAAG,cAAc,GAAG,CAAC,CAAC;QAC1C,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;QAClD,IAAI,CAAC,kBAAkB,CAAC,cAAc,CAAC,CAAC;IAC1C,CAAC;IAEO,kBAAkB,CAAC,cAAsB,EAAE,OAAgB;QACjE,IAAI,cAAc,IAAI,CAAC,IAAI,CAAC,OAAO;YAAE,OAAO,CAAC,CAAC;QAC9C,MAAM,mCAAmC,GAAG,IAAI,CAAC,KAAK,CACpD,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,WAAW,GAAG,OAAO,CAAC,qBAAqB,EAAE,CAAC,MAAM,CACjF,CAAC;QACF,OAAO,IAAI,CAAC,GAAG,CAAC,cAAc,GAAG,mCAAmC,EAAE,CAAC,CAAC,CAAC;IAC3E,CAAC;IAEO,SAAS,CAAC,OAAgB,EAAE,QAAgB,EAAE,KAAa;QACjE,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,CACjB,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,mBAAmB,CAAC,QAAQ,CAAC,CAC/E,CAAC;IACJ,CAAC;IAEO,cAAc,CAAC,OAAgB,EAAE,KAAa,EAAE,SAAkB;QACxE,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,CACjB,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,OAAO,EAAE,KAAK,CAAC,CAC/F,CAAC;IACJ,CAAC;IAEO,kBAAkB,CAAC,cAAsB;QAC/C,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,kBAAkB,EAAE,cAAc,GAAG,CAAC,CAAC,CAAC;QAC3F,MAAM,eAAe,GAAG,IAAI,CAAC,kBAAkB,CAAC,cAAc,EAAE,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC;QAC/F,IAAI,oBAAoB,GAAG,KAAK,CAAC;QACjC,MAAM,qBAAqB,GAAG,IAAI,CAAC,aAAa,CAAC;QACjD,IAAI,qBAAqB,EAAE;YACzB,IAAI,CAAC,SAAS,CAAC,qBAAqB,EAAE,mBAAmB,EAAE,GAAG,eAAe,IAAI,CAAC,CAAC;YACnF,oBAAoB,GAAG,qBAAqB,CAAC,SAAS,CAAC,QAAQ,CAAC,kBAAkB,CAAC,CAAC;SACrF;QAED,MAAM,cAAc,GAAG,IAAI,CAAC,iBAAiB,CAAC,aAAa,CAAC;QAC5D,MAAM,qBAAqB,GAAG,oBAAoB;YAChD,CAAC,CAAC,eAAe;YACjB,CAAC,CAAC,IAAI,CAAC,kBAAkB,CAAC,cAAc,EAAE,cAAc,CAAC,CAAC;QAC5D,IAAI,CAAC,SAAS,CAAC,cAAc,EAAE,mBAAmB,EAAE,GAAG,qBAAqB,IAAI,CAAC,CAAC;IACpF,CAAC;IAED,kBAAkB,CAAC,KAAiB;QAClC,IAAI,IAAI,CAAC,eAAe,EAAE;YACxB,MAAM,oBAAoB,GAAG,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE;gBAC/D,OAAO,CACL,KAAK,CAAC,MAAM,YAAY,WAAW;oBACnC,CAAC,KAAK,CAAC,MAAM,KAAK,MAAM,IAAI,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAC3D,CAAC;YACJ,CAAC,CAAC,CAAC;YACH,mDAAmD;YACnD,gCAAgC;YAChC,IAAI,CAAC,oBAAoB,EAAE;gBACzB,IAAI,CAAC,iBAAiB,EAAE,CAAC;aAC1B;SACF;IACH,CAAC;IAGD,eAAe;QACb,IAAI,CAAC,iBAAiB,EAAE,CAAC;IAC3B,CAAC;IAEO,iBAAiB;QACvB,MAAM,EAAE,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,WAAW,GAAG,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;QACvE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,MAAM,EAAE,GAAG,EAAE,IAAI,CAAC,CAAC;IACnE,CAAC;IAEO,qBAAqB;QAC3B,IAAI,CAAC,qBAAqB,CAAC,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC,KAAK,EAAE,EAAE,CACtF,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAC7B,CAAC;IACJ,CAAC;IAEO,gBAAgB,CAAC,KAA0B;QACjD,IAAI,CAAC,IAAI,CAAC,qBAAqB,EAAE;YAC/B,qDAAqD;YACrD,IAAI,CAAC,qBAAqB,GAAG,KAAK,CAAC,WAAW,CAAC,MAAM,CAAC;YACtD,OAAO;SACR;QACD,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC,WAAW,CAAC,MAAM,KAAK,IAAI,CAAC,qBAAqB,CAAC;QAC/E,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE;YACzB,yEAAyE;YACzE,IAAI,IAAI,CAAC,qBAAqB,EAAE;gBAC9B,YAAY,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC;gBACzC,IAAI,CAAC,YAAY,EAAE,CAAC;aACrB;SACF;QACD,IAAI,CAAC,cAAc,CAAC,IAAI,EAAE,CAAC;IAC7B,CAAC;IAED,iBAAiB;QACf,MAAM,oBAAoB,GAAG,iBAAiB,CAAC;QAC/C,IAAI,IAAI,CAAC,eAAe,EAAE;YACxB,IACE,QAAQ,CAAC,aAAa,YAAY,WAAW;gBAC7C,QAAQ,CAAC,aAAa,CAAC,OAAO,CAAC,oBAAoB,CAAC,EACpD;gBACA,QAAQ,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;aAC/B;SACF;IACH,CAAC;IAEO,sCAAsC;QAC5C,MAAM,QAAQ,GAAiC,CAAC,OAAO,EAAE,EAAE;YACzD,MAAM,KAAK,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;YACzB,MAAM,kBAAkB,GAAG,KAAK,CAAC,iBAAiB,GAAG,CAAC,CAAC;YACvD,IAAI,kBAAkB,EAAE;gBACtB,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC;aACnD;iBAAM;gBACL,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;aACtD;QACH,CAAC,CAAC;QAEF,+CAA+C;QAC/C,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,YAAY;YACnD,CAAC,CAAE,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,QAAgB,CAAC,wEAAwE;YACxH,CAAC,CAAC,SAAS,CAAC;QACd,MAAM,OAAO,GAA6B;YACxC,UAAU,EAAE,kBAAkB;YAC9B,IAAI;YACJ,SAAS,EAAE,CAAC,IAAI,EAAE,CAAC,CAAC;SACrB,CAAC;QAEF,OAAO,IAAI,oBAAoB,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;IACrD,CAAC;IAED,WAAW;QACT,IAAI,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE;YACjC,IAAI,CAAC,YAAY,CAAC,UAAU,EAAE,CAAC;SAChC;QACD,uBAAuB;QACvB,OAAO,IAAI,CAAC,iBAAiB,CAAC;QAC9B,IAAI,CAAC,oBAAoB,CAAC,UAAU,EAAE,CAAC;QACvC,OAAO,IAAI,CAAC,qBAAqB,CAAC;QAClC,IAAI,IAAI,CAAC,qBAAqB,EAAE;YAC9B,IAAI,CAAC,qBAAqB,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;YAChF,IAAI,CAAC,qBAAqB,CAAC,SAAS,CAAC,IAAI,CAAC,gBAAgB,CAAC,aAAa,CAAC,CAAC;YAC1E,IAAI,CAAC,qBAAqB,CAAC,SAAS,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;SAC1D;QACD,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QACrB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;IAC3B,CAAC;;AApee,+CAAyB,GAAG,GAAI,CAAA;qIARrC,qBAAqB;yHAArB,qBAAqB,mjBALrB;QACT,EAAE,OAAO,EAAE,KAAK,EAAE,WAAW,EAAE,qBAAqB,EAAE;QACtD,EAAE,OAAO,EAAE,uBAAuB,EAAE,WAAW,EAAE,qBAAqB,EAAE;KACzE,sEAyBU,UAAU,kGACV,UAAU,2BAAwB,UAAU,8EAE5C,SAAS,2BAAwB,UAAU,+EAE3C,UAAU,2BAAwB,UAAU,6EAE5C,QAAQ,2BAAwB,UAAU,0EAE1C,YAAY,gJAEY,UAAU,sDAd/B,eAAe,2BAAU,UAAU,6BCnEnD,isDA2CA;2FDIa,qBAAqB;kBATjC,SAAS;+BACE,qBAAqB,aAGpB;wBACT,EAAE,OAAO,EAAE,KAAK,EAAE,WAAW,uBAAuB,EAAE;wBACtD,EAAE,OAAO,EAAE,uBAAuB,EAAE,WAAW,uBAAuB,EAAE;qBACzE;sUAMG,oBAAoB;sBADvB,WAAW;uBAAC,yBAAyB;gBAc7B,MAAM;sBAAd,KAAK;gBAGuD,mBAAmB;sBAA/E,YAAY;uBAAC,eAAe,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE;gBAGF,UAAU;sBAA1D,SAAS;uBAAC,UAAU,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAE/B,iBAAiB;sBADxB,SAAS;uBAAC,UAAU,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,UAAU,EAAE;gBAGjD,gBAAgB;sBADvB,SAAS;uBAAC,SAAS,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,UAAU,EAAE;gBAGhD,iBAAiB;sBADxB,SAAS;uBAAC,UAAU,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,UAAU,EAAE;gBAGjD,eAAe;sBADtB,SAAS;uBAAC,QAAQ,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,UAAU,EAAE;gBAEJ,YAAY;sBAA9D,SAAS;uBAAC,YAAY,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAGjC,oBAAoB;sBAD3B,SAAS;uBAAC,cAAc,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE;gBAwC3C,SAAS;sBADZ,WAAW;uBAAC,cAAc;gBAgP3B,aAAa;sBAFZ,YAAY;uBAAC,cAAc;;sBAC3B,YAAY;uBAAC,iBAAiB;gBAQ/B,eAAe;sBAFd,YAAY;uBAAC,2BAA2B,EAAE,CAAC,8BAA8B,CAAC;;sBAC1E,YAAY;uBAAC,yBAAyB,EAAE,CAAC,uBAAuB,CAAC;gBAOlE,eAAe;sBAFd,YAAY;uBAAC,2BAA2B;;sBACxC,YAAY;uBAAC,yBAAyB;gBAoFvC,eAAe;sBADd,YAAY;uBAAC,eAAe","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  ComponentFactoryResolver,\n  ElementRef,\n  HostBinding,\n  HostListener,\n  Injector,\n  Input,\n  NgZone,\n  OnDestroy,\n  OnInit,\n  QueryList,\n  Renderer2,\n  RendererStyleFlags2,\n  ViewChild,\n  ViewChildren,\n} from '@angular/core';\nimport { ActivatedRoute, RouterOutlet } from '@angular/router';\nimport { IonContent, IonHeader, IonTitle, IonToolbar } from '@ionic/angular';\nimport { merge, Observable, Subject } from 'rxjs';\nimport { debounceTime, first, takeUntil } from 'rxjs/operators';\n\nimport { DesignTokenHelper } from '@kirbydesign/core';\n\nimport { KirbyAnimation } from '../../../animation/kirby-animation';\nimport { PlatformService } from '../../../helpers/platform.service';\nimport { WindowRef } from '../../../types/window-ref';\nimport { ButtonComponent } from '../../button/button.component';\nimport { ResizeObserverService } from '../../shared/resize-observer/resize-observer.service';\nimport { ResizeObserverEntry } from '../../shared/resize-observer/types/resize-observer-entry';\nimport { Modal, ModalElementsAdvertiser, ModalElementType } from '../services/modal.interfaces';\n\nimport { ModalConfig } from './config/modal-config';\nimport { COMPONENT_PROPS } from './config/modal-config.helper';\nimport { ModalElementsMoverDelegate } from './modal-elements-mover.delegate';\n\n@Component({\n  selector: 'kirby-modal-wrapper',\n  templateUrl: './modal-wrapper.component.html',\n  styleUrls: ['./modal-wrapper.component.scss'],\n  providers: [\n    { provide: Modal, useExisting: ModalWrapperComponent },\n    { provide: ModalElementsAdvertiser, useExisting: ModalWrapperComponent },\n  ],\n})\nexport class ModalWrapperComponent\n  implements Modal, AfterViewInit, OnInit, OnDestroy, ModalElementsAdvertiser\n{\n  @HostBinding('class.collapsible-title')\n  get _hasCollapsibleTitle() {\n    return !!this.config?.collapseTitle;\n  }\n\n  static readonly KEYBOARD_HIDE_DELAY_IN_MS = 100;\n\n  scrollY: number = Math.abs(this.windowRef.nativeWindow.scrollY);\n  private readonly VIEWPORT_RESIZE_DEBOUNCE_TIME = 100;\n\n  set scrollDisabled(disabled: boolean) {\n    this.ionContent.scrollY = !disabled;\n  }\n\n  @Input() config: ModalConfig;\n  componentPropsInjector: Injector;\n\n  @ViewChildren(ButtonComponent, { read: ElementRef }) private toolbarButtonsQuery: QueryList<\n    ElementRef<HTMLButtonElement>\n  >;\n  @ViewChild(IonContent, { static: true }) private ionContent: IonContent;\n  @ViewChild(IonContent, { static: true, read: ElementRef })\n  private ionContentElement: ElementRef<HTMLIonContentElement>;\n  @ViewChild(IonHeader, { static: true, read: ElementRef })\n  private ionHeaderElement: ElementRef<HTMLIonHeaderElement>;\n  @ViewChild(IonToolbar, { static: true, read: ElementRef })\n  private ionToolbarElement: ElementRef<HTMLIonToolbarElement>;\n  @ViewChild(IonTitle, { static: true, read: ElementRef })\n  private ionTitleElement: ElementRef<HTMLIonTitleElement>;\n  @ViewChild(RouterOutlet, { static: true }) private routerOutlet: RouterOutlet;\n\n  @ViewChild('contentTitle', { read: ElementRef })\n  private _contentTitleElement: ElementRef<HTMLElement>;\n\n  get contentTitleElement(): ElementRef<HTMLElement> {\n    /* \n        contentTitleElement has ngIf directive dependent on _hasCollapsibleTitle; trigger CD to make sure element has been queried. \n        Solution taken from: https://danieleyassu.com/angular-viewchild-and-ngif/\n      */\n    if (!this._contentTitleElement && this._hasCollapsibleTitle) {\n      this.changeDetector.detectChanges();\n    }\n    return this._contentTitleElement;\n  }\n\n  private keyboardVisible = false;\n  private toolbarButtons: HTMLButtonElement[] = [];\n  private delayedClose = () => {};\n  private delayedCloseTimeoutId;\n  private initialViewportHeight: number;\n  private viewportResized = false;\n  private ionModalElement?: HTMLIonModalElement;\n  private readonly ionModalDidPresent = new Subject<void>();\n  readonly didPresent = this.ionModalDidPresent.toPromise();\n  private readonly ionModalWillDismiss = new Subject<void>();\n  readonly willClose = this.ionModalWillDismiss.toPromise();\n  private viewportResize = new Subject<void>();\n  private viewportResize$ = this.viewportResize\n    .asObservable()\n    .pipe(debounceTime(this.VIEWPORT_RESIZE_DEBOUNCE_TIME));\n  private _mutationObserver: MutationObserver;\n  private _intersectionObserver: IntersectionObserver;\n  private get intersectionObserver(): IntersectionObserver {\n    if (!this._intersectionObserver) {\n      this._intersectionObserver = this.createModalWrapperIntersectionObserver();\n    }\n    return this._intersectionObserver;\n  }\n  private destroy$ = new Subject();\n\n  @HostBinding('class.drawer')\n  get _isDrawer() {\n    return this.config.flavor === 'drawer';\n  }\n\n  willClose$ = this.ionModalWillDismiss.pipe(first());\n\n  private modalElementsMoverDelegate: ModalElementsMoverDelegate;\n\n  constructor(\n    private changeDetector: ChangeDetectorRef,\n    private injector: Injector,\n    private elementRef: ElementRef<HTMLElement>,\n    private renderer: Renderer2,\n    private zone: NgZone,\n    private resizeObserverService: ResizeObserverService,\n    private componentFactoryResolver: ComponentFactoryResolver,\n    private windowRef: WindowRef,\n    private platform: PlatformService\n  ) {\n    this.setViewportHeight();\n    this.observeViewportResize();\n    this.modalElementsMoverDelegate = new ModalElementsMoverDelegate(renderer, elementRef);\n  }\n\n  ngOnInit(): void {\n    this.ionModalElement = this.elementRef.nativeElement.closest('ion-modal');\n    this.initializeSizing();\n    this.initializeModalRoute();\n    this.listenForIonModalDidPresent();\n    this.listenForIonModalWillDismiss();\n    this.initializeResizeModalToModalWrapper();\n    this.componentPropsInjector = Injector.create({\n      providers: [{ provide: COMPONENT_PROPS, useValue: this.config.componentProps }],\n      parent: this.injector,\n    });\n  }\n\n  private _currentFooter: HTMLElement | null = null;\n\n  private set currentFooter(footer: HTMLElement | null) {\n    if (footer !== null) {\n      this.resizeObserverService.observe(footer, (entry) => {\n        const [property, pixelValue] = [\n          '--footer-height',\n          `${Math.floor(entry.contentRect.height)}px`,\n        ];\n        this.setCssVar(this.elementRef.nativeElement, property, pixelValue);\n      });\n    }\n\n    this._currentFooter = footer;\n  }\n\n  private get currentFooter(): HTMLElement | null {\n    return this._currentFooter;\n  }\n\n  public addModalElement(type: ModalElementType, modalElement: ElementRef<HTMLElement>) {\n    const addModalElementFn = {\n      [ModalElementType.FOOTER]: () => {\n        this.modalElementsMoverDelegate.addFooter(modalElement);\n        this.currentFooter = modalElement.nativeElement;\n      },\n      [ModalElementType.TITLE]: () =>\n        this.modalElementsMoverDelegate.addTitle(\n          modalElement,\n          this.contentTitleElement,\n          this._hasCollapsibleTitle,\n          this.ionTitleElement\n        ),\n      [ModalElementType.PAGE_PROGRESS]: () =>\n        this.modalElementsMoverDelegate.addPageProgress(modalElement, this.ionToolbarElement),\n    }[type];\n\n    addModalElementFn();\n  }\n\n  public removeModalElement(type: ModalElementType, modalElement: ElementRef<HTMLElement>) {\n    const removeModalElementFn = {\n      [ModalElementType.FOOTER]: () => {\n        this.modalElementsMoverDelegate.removeFooter(modalElement);\n        this.currentFooter = null;\n      },\n      [ModalElementType.TITLE]: () =>\n        this.modalElementsMoverDelegate.removeTitle(\n          modalElement,\n          this._hasCollapsibleTitle,\n          this.contentTitleElement\n        ),\n      [ModalElementType.PAGE_PROGRESS]: () =>\n        this.modalElementsMoverDelegate.removePageProgress(modalElement),\n    }[type];\n\n    removeModalElementFn();\n  }\n\n  private initializeResizeModalToModalWrapper() {\n    if (this.config.flavor === 'drawer' && this.config.interactWithBackground) {\n      merge(this.ionModalDidPresent, this.viewportResize$)\n        .pipe(takeUntil(this.destroy$))\n        .subscribe(() => {\n          // wait for template to render\n          setTimeout(() => {\n            const domRect = this.elementRef.nativeElement.getBoundingClientRect();\n            const document = this.windowRef.nativeWindow.document.documentElement;\n            const right = document.clientWidth - domRect.right;\n            this.renderer.setStyle(this.ionModalElement, 'top', `${domRect.top}px`);\n            this.renderer.setStyle(this.ionModalElement, 'left', `${domRect.left}px`);\n            this.renderer.setStyle(this.ionModalElement, 'right', `${right}px`);\n          });\n        });\n    }\n  }\n\n  private initializeSizing() {\n    if (this.config.size === 'full-height') return;\n    this.patchScrollElementSize();\n    this.observeHeaderResize();\n    this.observeModalFullHeight();\n  }\n\n  private initializeModalRoute() {\n    if (this.config.modalRoute) {\n      this.onSiblingModalRouteActivated(this.config.siblingModalRouteActivated$);\n      // Load component from modal-route inside router-outlet:\n      this.routerOutlet.activateWith(this.config.modalRoute, this.componentFactoryResolver);\n    }\n  }\n\n  private onSiblingModalRouteActivated(siblingModalRouteActivated$?: Observable<ActivatedRoute>) {\n    if (!siblingModalRouteActivated$) return;\n    siblingModalRouteActivated$.pipe(takeUntil(this.willClose$)).subscribe((route) => {\n      if (this.routerOutlet.isActivated) {\n        this.routerOutlet.deactivate();\n      }\n      this.routerOutlet.activateWith(route, this.componentFactoryResolver);\n    });\n  }\n\n  private patchScrollElementSize(): void {\n    const supportsCssShadowParts = 'part' in HTMLElement.prototype;\n    if (supportsCssShadowParts) return;\n    this.ionContent.getScrollElement().then((scrollElement) => {\n      this.renderer.setStyle(scrollElement, 'height', '100%');\n      this.renderer.setStyle(scrollElement, 'position', 'relative');\n      if (this.config.flavor === 'drawer') {\n        this.renderer.setStyle(\n          scrollElement,\n          'transition',\n          'padding-bottom ' + DesignTokenHelper.softKeyboardTransitionLeave\n        );\n      }\n    });\n  }\n\n  private observeModalFullHeight() {\n    const ionModalWrapper = this.getIonModalWrapperElement();\n\n    if (!ionModalWrapper) return;\n    // Start observing when modal has finished animating:\n    this.didPresent.then(() => {\n      this.intersectionObserver.observe(ionModalWrapper);\n    });\n  }\n\n  // Extracted into function for ease of testing\n  private getIonModalWrapperElement(): HTMLElement {\n    return this.ionModalElement.shadowRoot.querySelector('.modal-wrapper');\n  }\n\n  ngAfterViewInit(): void {\n    if (this.toolbarButtonsQuery) {\n      this.toolbarButtons = this.toolbarButtonsQuery.map((buttonRef) => buttonRef.nativeElement);\n    }\n  }\n\n  private observeHeaderResize() {\n    this.resizeObserverService.observe(this.ionHeaderElement.nativeElement, (entry) => {\n      const [property, pixelValue] = ['--header-height', `${entry.contentRect.height}px`];\n      this.setCssVar(this.elementRef.nativeElement, property, pixelValue);\n    });\n  }\n\n  private listenForIonModalDidPresent() {\n    if (this.ionModalElement) {\n      this.ionModalElement.addEventListener('ionModalDidPresent', () => {\n        this.ionModalDidPresent.next();\n        this.ionModalDidPresent.complete();\n      });\n    }\n  }\n\n  private listenForIonModalWillDismiss() {\n    if (this.ionModalElement) {\n      this.ionModalElement.addEventListener('ionModalWillDismiss', () => {\n        this.ionModalWillDismiss.next();\n        this.ionModalWillDismiss.complete();\n      });\n    }\n  }\n\n  scrollToTop(scrollDuration?: KirbyAnimation.Duration) {\n    this.ionContent.scrollToTop(scrollDuration || 0);\n  }\n\n  scrollToBottom(scrollDuration?: KirbyAnimation.Duration) {\n    this.ionContent.scrollToBottom(scrollDuration || 0);\n  }\n\n  async close(data?: any): Promise<void> {\n    if (!this.ionModalElement) {\n      return;\n    }\n    if (!this.keyboardVisible || !this.viewportResized) {\n      // No keyboard visible or viewport not resized:\n      // Dismiss modal and return:\n      clearTimeout(this.delayedCloseTimeoutId);\n      await this.ionModalElement.dismiss(data);\n      return;\n    }\n\n    // Keyboard visible:\n    // Blur active element and wait for keyboard to hide,\n    // then dismiss modal and return:\n    this.blurActiveElement();\n    return new Promise<void>((resolve) => {\n      this.delayedClose = async () => {\n        await this.ionModalElement.dismiss(data);\n        resolve();\n      };\n      this.delayedCloseTimeoutId = setTimeout(\n        this.delayedClose,\n        ModalWrapperComponent.KEYBOARD_HIDE_DELAY_IN_MS\n      );\n    });\n  }\n\n  @HostListener('window:focus')\n  @HostListener('window:focusout')\n  onFocusChange() {\n    // This fixes an undesired scroll behaviour occurring on keyboard-tabbing backwards (with shift+tab):\n    this.windowRef.nativeWindow.scrollTo({ top: this.scrollY });\n  }\n\n  @HostListener('window:ionKeyboardDidShow', ['$event.detail.keyboardHeight'])\n  @HostListener('window:keyboardWillShow', ['$event.keyboardHeight'])\n  _onKeyboardShow(keyboardHeight: number) {\n    this.setKeyboardVisibility(keyboardHeight);\n  }\n\n  @HostListener('window:ionKeyboardDidHide')\n  @HostListener('window:keyboardWillHide')\n  _onKeyboardHide() {\n    this.setKeyboardVisibility(0);\n  }\n\n  private toggleContentMaxHeight(freeze: boolean) {\n    const shouldToggleMaxHeight =\n      this.config.flavor === 'modal' && this.platform.isPhabletOrBigger();\n    if (!shouldToggleMaxHeight) return;\n    const style = 'max-height';\n    const contentElement = this.ionContentElement.nativeElement;\n    this.zone.run(() => {\n      if (freeze) {\n        const contentHeight = contentElement.offsetHeight;\n        this.renderer.setStyle(contentElement, style, `${contentHeight}px`);\n      } else {\n        this.renderer.removeStyle(contentElement, style);\n      }\n    });\n  }\n\n  private setKeyboardVisibility(keyboardHeight: number) {\n    const keyboardAlreadyVisible = keyboardHeight > 0 && this.keyboardVisible;\n    const keyboardAlreadyHidden = keyboardHeight === 0 && !this.keyboardVisible;\n    if (keyboardAlreadyVisible || keyboardAlreadyHidden) return;\n    this.keyboardVisible = keyboardHeight > 0;\n    this.toggleContentMaxHeight(this.keyboardVisible);\n    this.setKeyboardOverlap(keyboardHeight);\n  }\n\n  private getKeyboardOverlap(keyboardHeight: number, element: Element) {\n    if (keyboardHeight <= 0 || !element) return 0;\n    const distanceFromViewportBottomToElement = Math.floor(\n      this.windowRef.nativeWindow.innerHeight - element.getBoundingClientRect().bottom\n    );\n    return Math.max(keyboardHeight - distanceFromViewportBottomToElement, 0);\n  }\n\n  private setCssVar(element: Element, property: string, value: string) {\n    this.zone.run(() =>\n      this.renderer.setStyle(element, property, value, RendererStyleFlags2.DashCase)\n    );\n  }\n\n  private toggleCssClass(element: Element, klass: string, condition: boolean) {\n    this.zone.run(() =>\n      condition ? this.renderer.addClass(element, klass) : this.renderer.removeClass(element, klass)\n    );\n  }\n\n  private setKeyboardOverlap(keyboardHeight: number) {\n    this.toggleCssClass(this.elementRef.nativeElement, 'keyboard-visible', keyboardHeight > 0);\n    const keyboardOverlap = this.getKeyboardOverlap(keyboardHeight, this.elementRef.nativeElement);\n    let snapFooterToKeyboard = false;\n    const embeddedFooterElement = this.currentFooter;\n    if (embeddedFooterElement) {\n      this.setCssVar(embeddedFooterElement, '--keyboard-offset', `${keyboardOverlap}px`);\n      snapFooterToKeyboard = embeddedFooterElement.classList.contains('snap-to-keyboard');\n    }\n\n    const contentElement = this.ionContentElement.nativeElement;\n    const contentKeyboardOffset = snapFooterToKeyboard\n      ? keyboardOverlap\n      : this.getKeyboardOverlap(keyboardHeight, contentElement);\n    this.setCssVar(contentElement, '--keyboard-offset', `${contentKeyboardOffset}px`);\n  }\n\n  onHeaderTouchStart(event: TouchEvent) {\n    if (this.keyboardVisible) {\n      const isToolbarButtonTouch = this.toolbarButtons.some((button) => {\n        return (\n          event.target instanceof HTMLElement &&\n          (event.target === button || button.contains(event.target))\n        );\n      });\n      // Prevent blur if event target is a toolbar button\n      // (to allow tap event to fire):\n      if (!isToolbarButtonTouch) {\n        this.blurActiveElement();\n      }\n    }\n  }\n\n  @HostListener('window:resize')\n  _onWindowResize() {\n    this.setViewportHeight();\n  }\n\n  private setViewportHeight() {\n    const vh = (this.windowRef.nativeWindow.innerHeight * 0.01).toFixed(2);\n    this.setCssVar(this.elementRef.nativeElement, '--vh', `${vh}px`);\n  }\n\n  private observeViewportResize() {\n    this.resizeObserverService.observe(this.windowRef.nativeWindow.document.body, (entry) =>\n      this.onViewportResize(entry)\n    );\n  }\n\n  private onViewportResize(entry: ResizeObserverEntry) {\n    if (!this.initialViewportHeight) {\n      // Initial observe callback, register initial height:\n      this.initialViewportHeight = entry.contentRect.height;\n      return;\n    }\n    this.viewportResized = entry.contentRect.height !== this.initialViewportHeight;\n    if (!this.viewportResized) {\n      // We are back to initial view port height, check for pending close func:\n      if (this.delayedCloseTimeoutId) {\n        clearTimeout(this.delayedCloseTimeoutId);\n        this.delayedClose();\n      }\n    }\n    this.viewportResize.next();\n  }\n\n  blurActiveElement() {\n    const BLUR_TARGET_SELECTOR = 'input, textarea';\n    if (this.keyboardVisible) {\n      if (\n        document.activeElement instanceof HTMLElement &&\n        document.activeElement.matches(BLUR_TARGET_SELECTOR)\n      ) {\n        document.activeElement.blur();\n      }\n    }\n  }\n\n  private createModalWrapperIntersectionObserver(): IntersectionObserver {\n    const callback: IntersectionObserverCallback = (entries) => {\n      const entry = entries[0];\n      const isTouchingViewport = entry.intersectionRatio < 1;\n      if (isTouchingViewport) {\n        this.ionModalElement.classList.add('full-height');\n      } else {\n        this.ionModalElement.classList.remove('full-height');\n      }\n    };\n\n    // Set explicit viewport root if within iframe:\n    const root = this.windowRef.nativeWindow.frameElement\n      ? (this.windowRef.nativeWindow.document as any) // Cast to `any` as Typescript lib.d.ts doesnt support Document type yet\n      : undefined;\n    const options: IntersectionObserverInit = {\n      rootMargin: '0px 0px -1px 0px', // `bottom: -1px` allows checking when the modal bottom is touching the viewport\n      root,\n      threshold: [0.99, 1],\n    };\n\n    return new IntersectionObserver(callback, options);\n  }\n\n  ngOnDestroy() {\n    if (this.routerOutlet.isActivated) {\n      this.routerOutlet.deactivate();\n    }\n    //clean up the observer\n    delete this._mutationObserver;\n    this.intersectionObserver.disconnect();\n    delete this._intersectionObserver;\n    if (this.resizeObserverService) {\n      this.resizeObserverService.unobserve(this.windowRef.nativeWindow.document.body);\n      this.resizeObserverService.unobserve(this.ionHeaderElement.nativeElement);\n      this.resizeObserverService.unobserve(this.currentFooter);\n    }\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n}\n","<ion-header (touchstart)=\"onHeaderTouchStart($event)\">\n  <ion-toolbar>\n    <ion-title></ion-title>\n    <ion-buttons slot=\"start\" *ngIf=\"config.flavor === 'drawer'\">\n      <ng-container *ngTemplateOutlet=\"closeButton; context: { icon: 'arrow-down' }\"></ng-container>\n    </ion-buttons>\n    <ion-buttons slot=\"end\" *ngIf=\"config.flavor === 'modal'\">\n      <ng-container *ngTemplateOutlet=\"closeButton; context: { icon: 'close' }\"></ng-container>\n    </ion-buttons>\n    <ion-buttons slot=\"end\" *ngIf=\"config.flavor === 'drawer' && config.drawerSupplementaryAction\">\n      <ng-container\n        *ngTemplateOutlet=\"supplementaryButton; context: { btn: config.drawerSupplementaryAction }\"\n      ></ng-container>\n    </ion-buttons>\n  </ion-toolbar>\n</ion-header>\n\n<ion-content [scrollEvents]=\"true\">\n  <ion-header *ngIf=\"_hasCollapsibleTitle\" collapse=\"condense\">\n    <ion-toolbar>\n      <span class=\"kirby-text-large\" #contentTitle></span>\n    </ion-toolbar>\n  </ion-header>\n  <ng-container\n    *ngComponentOutlet=\"config.component; injector: componentPropsInjector\"\n  ></ng-container>\n  <router-outlet\n    name=\"kirbyModalWrapperOutlet\"\n    [style.visibility]=\"config.modalRoute ? 'visible' : 'hidden'\"\n  ></router-outlet>\n</ion-content>\n\n<ng-template #closeButton let-icon=\"icon\">\n  <button kirby-button attentionLevel=\"4\" size=\"md\" (click)=\"close()\">\n    <kirby-icon [name]=\"icon\"></kirby-icon>\n  </button>\n</ng-template>\n\n<ng-template #supplementaryButton let-btn=\"btn\">\n  <button kirby-button attentionLevel=\"2\" size=\"md\" (click)=\"btn.action($event)\">\n    <kirby-icon [name]=\"btn.iconName\"></kirby-icon>\n  </button>\n</ng-template>\n"]}