@kirbydesign/designsystem 6.1.2-rc.ionic → 6.2.1

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 (47) hide show
  1. package/README.md +7 -0
  2. package/esm2020/lib/components/button/button.component.mjs +2 -2
  3. package/esm2020/lib/components/card/card-footer/card-footer.component.mjs +2 -2
  4. package/esm2020/lib/components/dropdown/dropdown.component.mjs +10 -2
  5. package/esm2020/lib/components/fab-sheet/fab-sheet.component.mjs +13 -8
  6. package/esm2020/lib/components/form-field/input/input.component.mjs +2 -2
  7. package/esm2020/lib/components/form-field/textarea/textarea.component.mjs +2 -2
  8. package/esm2020/lib/components/icon/icon.component.mjs +1 -1
  9. package/esm2020/lib/components/icon/kirby-icon-settings.mjs +6 -1
  10. package/esm2020/lib/components/item/item.component.mjs +1 -1
  11. package/esm2020/lib/components/list/list-item/list-item.component.mjs +2 -2
  12. package/esm2020/lib/components/list/list.component.mjs +2 -2
  13. package/esm2020/lib/components/modal/footer/modal-footer.component.mjs +2 -2
  14. package/esm2020/lib/components/modal/modal-wrapper/modal-wrapper.component.mjs +6 -10
  15. package/esm2020/lib/components/modal/services/action-sheet.helper.mjs +1 -4
  16. package/esm2020/lib/components/modal/services/modal-animation-builder.service.mjs +50 -62
  17. package/esm2020/lib/components/modal/services/modal.helper.mjs +11 -12
  18. package/esm2020/lib/components/page/page.component.mjs +1 -1
  19. package/esm2020/lib/components/range/range.component.mjs +1 -1
  20. package/esm2020/lib/components/segmented-control/segmented-control.component.mjs +10 -5
  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 +117 -115
  24. package/fesm2015/kirbydesign-designsystem.mjs.map +1 -1
  25. package/fesm2020/kirbydesign-designsystem.mjs +117 -115
  26. package/fesm2020/kirbydesign-designsystem.mjs.map +1 -1
  27. package/icons/svg/car.svg +5 -0
  28. package/icons/svg/coinstack.svg +5 -0
  29. package/icons/svg/contact.svg +5 -0
  30. package/icons/svg/recurring.svg +5 -0
  31. package/icons/svg/salary.svg +5 -0
  32. package/lib/components/dropdown/dropdown.component.d.ts +1 -0
  33. package/lib/components/fab-sheet/fab-sheet.component.d.ts +3 -2
  34. package/lib/components/modal/modal-wrapper/modal-wrapper.component.d.ts +0 -1
  35. package/lib/components/modal/services/modal-animation-builder.service.d.ts +3 -14
  36. package/lib/components/segmented-control/segmented-control.component.d.ts +5 -1
  37. package/package.json +8 -8
  38. package/scss/base/_link.scss +0 -1
  39. package/scss/interaction-state/_active.scss +0 -1
  40. package/scss/interaction-state/_focus.scss +0 -1
  41. package/scss/interaction-state/_hover.scss +0 -1
  42. package/scss/interaction-state/_index.scss +0 -1
  43. package/scss/interaction-state/_interaction-state.utilities.scss +0 -1
  44. package/scss/interaction-state/_layer.scss +0 -1
  45. package/scss/opt-out/_index.scss +0 -1
  46. package/scss/opt-out/_link.scss +0 -1
  47. package/src/lib/components/icon/README.md +0 -16
@@ -1,11 +1,13 @@
1
1
  import { Injectable } from '@angular/core';
2
- import { createAnimation } from '@ionic/angular';
2
+ import { AnimationController } from '@ionic/angular';
3
3
  import { KirbyAnimation } from '../../../animation/kirby-animation';
4
4
  import { PlatformService } from '../../../helpers/platform.service';
5
5
  import * as i0 from "@angular/core";
6
- import * as i1 from "../../../helpers/platform.service";
6
+ import * as i1 from "@ionic/angular";
7
+ import * as i2 from "../../../helpers/platform.service";
7
8
  export class ModalAnimationBuilderService {
8
- constructor(platform) {
9
+ constructor(animationCtrl, platform) {
10
+ this.animationCtrl = animationCtrl;
9
11
  this.platform = platform;
10
12
  this.easingEnter = KirbyAnimation.Easing.modal.enter;
11
13
  this.easingLeave = KirbyAnimation.Easing.modal.exit;
@@ -13,51 +15,32 @@ export class ModalAnimationBuilderService {
13
15
  this.SwipeToCloseDefaults = {
14
16
  MIN_PRESENTING_SCALE: 0.93,
15
17
  };
16
- this.createEnterAnimation = () => {
17
- const backdropAnimation = createAnimation()
18
+ }
19
+ enterAnimation(currentBackdrop) {
20
+ return (baseEl, presentingEl) => {
21
+ const backdropAnimation = this.animationCtrl
22
+ .create()
23
+ .addElement(baseEl.querySelector('ion-backdrop'))
18
24
  .fromTo('opacity', 0.01, 'var(--backdrop-opacity)')
19
25
  .beforeStyles({
20
26
  'pointer-events': 'none',
21
27
  })
22
28
  .afterClearStyles(['pointer-events']);
23
- const wrapperAnimation = createAnimation().fromTo('transform', 'translateY(100vh)', 'translateY(0vh)');
24
- return { backdropAnimation, wrapperAnimation };
25
- };
26
- this.createLeaveAnimation = () => {
27
- const backdropAnimation = createAnimation().fromTo('opacity', 'var(--backdrop-opacity)', 0);
28
- const wrapperAnimation = createAnimation().fromTo('transform', 'translateY(0vh)', 'translateY(100vh)');
29
- return { backdropAnimation, wrapperAnimation };
30
- };
31
- /**
32
- * Gets the root context of a shadow dom element
33
- * On newer browsers this will be the shadowRoot,
34
- * but for older browser this may just be the
35
- * element itself.
36
- *
37
- * Useful for whenever you need to explicitly
38
- * do "myElement.shadowRoot!.querySelector(...)".
39
- */
40
- this.getElementRoot = (el, fallback = el) => {
41
- return el.shadowRoot || fallback;
42
- };
43
- }
44
- enterAnimation(currentBackdrop) {
45
- return (baseEl, opts) => {
46
- const { presentingEl } = opts;
47
- const root = this.getElementRoot(baseEl);
48
- const { wrapperAnimation, backdropAnimation } = this.createEnterAnimation();
49
- backdropAnimation.addElement(root.querySelector('ion-backdrop'));
50
- wrapperAnimation
51
- .addElement(root.querySelectorAll('.modal-wrapper, .modal-shadow'))
52
- .beforeStyles({ opacity: 1 });
53
- const baseAnimation = createAnimation('entering-base')
29
+ const wrapperAnimation = this.animationCtrl
30
+ .create()
31
+ .addElement(baseEl.querySelectorAll('.modal-wrapper, .modal-shadow'))
32
+ .beforeStyles({ opacity: 1 })
33
+ .fromTo('transform', 'translateY(100vh)', 'translateY(0vh)');
34
+ const baseAnimation = this.animationCtrl
35
+ .create()
54
36
  .addElement(baseEl)
55
37
  .easing(this.easingEnter)
56
38
  .duration(this.duration)
57
39
  .addAnimation(wrapperAnimation);
58
40
  let currentBackdropAnimation;
59
41
  if (currentBackdrop) {
60
- currentBackdropAnimation = createAnimation()
42
+ currentBackdropAnimation = this.animationCtrl
43
+ .create()
61
44
  .addElement(currentBackdrop)
62
45
  .fromTo('opacity', 'var(--backdrop-opacity)', 0.01);
63
46
  }
@@ -65,8 +48,7 @@ export class ModalAnimationBuilderService {
65
48
  const isMobile = !this.platform.isPhabletOrBigger();
66
49
  const hasCardModal = presentingEl.tagName === 'ION-MODAL' &&
67
50
  presentingEl.presentingElement !== undefined;
68
- const presentingElRoot = this.getElementRoot(presentingEl);
69
- const presentingAnimation = createAnimation().beforeStyles({
51
+ const presentingAnimation = this.animationCtrl.create().beforeStyles({
70
52
  transform: 'translateY(0)',
71
53
  'transform-origin': 'top center',
72
54
  overflow: 'hidden',
@@ -76,7 +58,7 @@ export class ModalAnimationBuilderService {
76
58
  /**
77
59
  * Fallback for browsers that does not support `max()` (ex: Firefox)
78
60
  * No need to worry about statusbar padding since engines like Gecko
79
- * are not used as the engine for standalone Cordova/Capacitor apps
61
+ * are not used as the engine for standlone Cordova/Capacitor apps
80
62
  */
81
63
  const transformOffset = !CSS.supports('width', 'max(0px, 1px)')
82
64
  ? '30px'
@@ -123,16 +105,17 @@ export class ModalAnimationBuilderService {
123
105
  .afterStyles({
124
106
  transform: finalTransform,
125
107
  })
126
- .addElement(presentingElRoot.querySelector('.modal-wrapper'))
108
+ .addElement(presentingEl.querySelector('.modal-wrapper'))
127
109
  .keyframes([
128
110
  { offset: 0, filter: 'contrast(1)', transform: 'translateY(0) scale(1)' },
129
111
  { offset: 1, filter: 'contrast(0.85)', transform: finalTransform },
130
112
  ]);
131
- const shadowAnimation = createAnimation()
113
+ const shadowAnimation = this.animationCtrl
114
+ .create()
132
115
  .afterStyles({
133
116
  transform: finalTransform,
134
117
  })
135
- .addElement(presentingElRoot.querySelector('.modal-shadow'))
118
+ .addElement(presentingEl.querySelector('.modal-shadow'))
136
119
  .keyframes([
137
120
  { offset: 0, opacity: '1', transform: 'translateY(0) scale(1)' },
138
121
  { offset: 1, opacity: '0', transform: finalTransform },
@@ -151,22 +134,26 @@ export class ModalAnimationBuilderService {
151
134
  };
152
135
  }
153
136
  leaveAnimation(currentBackdrop) {
154
- return (baseEl, opts, duration = this.duration) => {
155
- const { presentingEl } = opts;
156
- const root = this.getElementRoot(baseEl);
157
- const { wrapperAnimation, backdropAnimation } = this.createLeaveAnimation();
158
- backdropAnimation.addElement(root.querySelector('ion-backdrop'));
159
- wrapperAnimation
160
- .addElement(root.querySelectorAll('.modal-wrapper, .modal-shadow'))
161
- .beforeStyles({ opacity: 1 });
162
- const baseAnimation = createAnimation('leaving-base')
137
+ return (baseEl, presentingEl) => {
138
+ const backdropAnimation = this.animationCtrl
139
+ .create()
140
+ .addElement(baseEl.querySelector('ion-backdrop'))
141
+ .fromTo('opacity', 'var(--backdrop-opacity)', 0.0);
142
+ const wrapperAnimation = this.animationCtrl
143
+ .create()
144
+ .addElement(baseEl.querySelectorAll('.modal-wrapper, .modal-shadow'))
145
+ .beforeStyles({ opacity: 1 })
146
+ .fromTo('transform', 'translateY(0vh)', 'translateY(100vh)');
147
+ const baseAnimation = this.animationCtrl
148
+ .create()
163
149
  .addElement(baseEl)
164
150
  .easing(this.easingLeave)
165
- .duration(duration)
151
+ .duration(this.duration)
166
152
  .addAnimation(wrapperAnimation);
167
153
  let currentBackdropAnimation;
168
154
  if (currentBackdrop) {
169
- currentBackdropAnimation = createAnimation()
155
+ currentBackdropAnimation = this.animationCtrl
156
+ .create()
170
157
  .addElement(currentBackdrop)
171
158
  .fromTo('opacity', 0.01, 'var(--backdrop-opacity)')
172
159
  .afterStyles({ opacity: 'var(--backdrop-opacity)' }); //Ensures backdrop is reset to default opacity after swipe to close
@@ -175,8 +162,8 @@ export class ModalAnimationBuilderService {
175
162
  const isMobile = !this.platform.isPhabletOrBigger();
176
163
  const hasCardModal = presentingEl.tagName === 'ION-MODAL' &&
177
164
  presentingEl.presentingElement !== undefined;
178
- const presentingElRoot = this.getElementRoot(presentingEl);
179
- const presentingAnimation = createAnimation()
165
+ const presentingAnimation = this.animationCtrl
166
+ .create()
180
167
  .beforeClearStyles(['transform'])
181
168
  .afterClearStyles(['transform'])
182
169
  .onFinish((currentStep) => {
@@ -228,7 +215,7 @@ export class ModalAnimationBuilderService {
228
215
  : 1;
229
216
  const finalTransform = `translateY(-10px) scale(${toPresentingScale})`;
230
217
  presentingAnimation
231
- .addElement(presentingElRoot.querySelector('.modal-wrapper'))
218
+ .addElement(presentingEl.querySelector('.modal-wrapper'))
232
219
  .afterStyles({
233
220
  transform: 'translate3d(0, 0, 0)',
234
221
  })
@@ -236,8 +223,9 @@ export class ModalAnimationBuilderService {
236
223
  { offset: 0, filter: 'contrast(0.85)', transform: finalTransform },
237
224
  { offset: 1, filter: 'contrast(1)', transform: 'translateY(0) scale(1)' },
238
225
  ]);
239
- const shadowAnimation = createAnimation()
240
- .addElement(presentingElRoot.querySelector('.modal-shadow'))
226
+ const shadowAnimation = this.animationCtrl
227
+ .create()
228
+ .addElement(presentingEl.querySelector('.modal-shadow'))
241
229
  .afterStyles({
242
230
  transform: 'translateY(0) scale(1)',
243
231
  })
@@ -259,10 +247,10 @@ export class ModalAnimationBuilderService {
259
247
  };
260
248
  }
261
249
  }
262
- /** @nocollapse */ ModalAnimationBuilderService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.9", ngImport: i0, type: ModalAnimationBuilderService, deps: [{ token: i1.PlatformService }], target: i0.ɵɵFactoryTarget.Injectable });
250
+ /** @nocollapse */ ModalAnimationBuilderService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.9", ngImport: i0, type: ModalAnimationBuilderService, deps: [{ token: i1.AnimationController }, { token: i2.PlatformService }], target: i0.ɵɵFactoryTarget.Injectable });
263
251
  /** @nocollapse */ ModalAnimationBuilderService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.3.9", ngImport: i0, type: ModalAnimationBuilderService, providedIn: 'root' });
264
252
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.9", ngImport: i0, type: ModalAnimationBuilderService, decorators: [{
265
253
  type: Injectable,
266
254
  args: [{ providedIn: 'root' }]
267
- }], ctorParameters: function () { return [{ type: i1.PlatformService }]; } });
268
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal-animation-builder.service.js","sourceRoot":"","sources":["../../../../../../../../libs/designsystem/src/lib/components/modal/services/modal-animation-builder.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { Animation, AnimationBuilder, createAnimation } from '@ionic/angular';\nimport { ModalAnimationOptions } from '@ionic/core';\n\nimport { KirbyAnimation } from '../../../animation/kirby-animation';\nimport { PlatformService } from '../../../helpers/platform.service';\n\n@Injectable({ providedIn: 'root' })\nexport class ModalAnimationBuilderService {\n  constructor(private platform: PlatformService) {}\n\n  private readonly easingEnter = KirbyAnimation.Easing.modal.enter;\n  private readonly easingLeave = KirbyAnimation.Easing.modal.exit;\n  private readonly duration = KirbyAnimation.Duration.LONG;\n  private readonly SwipeToCloseDefaults = {\n    MIN_PRESENTING_SCALE: 0.93,\n  };\n\n  public enterAnimation(currentBackdrop?: HTMLIonBackdropElement): AnimationBuilder {\n    return (baseEl: HTMLElement, opts: ModalAnimationOptions): Animation => {\n      const { presentingEl } = opts;\n      const root = this.getElementRoot(baseEl);\n      const { wrapperAnimation, backdropAnimation } = this.createEnterAnimation();\n\n      backdropAnimation.addElement(root.querySelector('ion-backdrop')!);\n\n      wrapperAnimation\n        .addElement(root.querySelectorAll('.modal-wrapper, .modal-shadow')!)\n        .beforeStyles({ opacity: 1 });\n\n      const baseAnimation = createAnimation('entering-base')\n        .addElement(baseEl)\n        .easing(this.easingEnter)\n        .duration(this.duration)\n        .addAnimation(wrapperAnimation);\n\n      let currentBackdropAnimation: Animation;\n      if (currentBackdrop) {\n        currentBackdropAnimation = createAnimation()\n          .addElement(currentBackdrop)\n          .fromTo('opacity', 'var(--backdrop-opacity)', 0.01);\n      }\n\n      if (presentingEl) {\n        const isMobile = !this.platform.isPhabletOrBigger();\n        const hasCardModal =\n          presentingEl.tagName === 'ION-MODAL' &&\n          (presentingEl as HTMLIonModalElement).presentingElement !== undefined;\n        const presentingElRoot = this.getElementRoot(presentingEl);\n\n        const presentingAnimation = createAnimation().beforeStyles({\n          transform: 'translateY(0)',\n          'transform-origin': 'top center',\n          overflow: 'hidden',\n        });\n\n        const bodyEl = document.body;\n\n        if (isMobile) {\n          /**\n           * Fallback for browsers that does not support `max()` (ex: Firefox)\n           * No need to worry about statusbar padding since engines like Gecko\n           * are not used as the engine for standalone Cordova/Capacitor apps\n           */\n          const transformOffset = !CSS.supports('width', 'max(0px, 1px)')\n            ? '30px'\n            : 'max(30px, var(--ion-safe-area-top))';\n          const modalTransform = hasCardModal ? '-10px' : transformOffset;\n          const toPresentingScale = this.SwipeToCloseDefaults.MIN_PRESENTING_SCALE;\n          const finalTransform = `translateY(${modalTransform}) scale(${toPresentingScale})`;\n\n          presentingAnimation\n            .afterStyles({\n              transform: finalTransform,\n            })\n            .beforeAddWrite(() => bodyEl.style.setProperty('background-color', 'black'))\n            .addElement(presentingEl)\n            .keyframes([\n              {\n                offset: 0,\n                filter: 'contrast(1)',\n                transform: 'translateY(0px) scale(1)',\n                borderRadius: '0px',\n              },\n              {\n                offset: 1,\n                filter: 'contrast(0.85)',\n                transform: finalTransform,\n                borderRadius: '10px 10px 0 0',\n              },\n            ]);\n\n          baseAnimation.addAnimation(presentingAnimation);\n        } else {\n          baseAnimation.addAnimation(backdropAnimation);\n\n          if (currentBackdropAnimation) {\n            baseAnimation.addAnimation(currentBackdropAnimation);\n          }\n\n          if (!hasCardModal) {\n            wrapperAnimation.fromTo('opacity', '0', '1');\n          } else {\n            const toPresentingScale = hasCardModal\n              ? this.SwipeToCloseDefaults.MIN_PRESENTING_SCALE\n              : 1;\n            const finalTransform = `translateY(-10px) scale(${toPresentingScale})`;\n\n            presentingAnimation\n              .afterStyles({\n                transform: finalTransform,\n              })\n              .addElement(presentingElRoot.querySelector('.modal-wrapper')!)\n              .keyframes([\n                { offset: 0, filter: 'contrast(1)', transform: 'translateY(0) scale(1)' },\n                { offset: 1, filter: 'contrast(0.85)', transform: finalTransform },\n              ]);\n\n            const shadowAnimation = createAnimation()\n              .afterStyles({\n                transform: finalTransform,\n              })\n              .addElement(presentingElRoot.querySelector('.modal-shadow')!)\n              .keyframes([\n                { offset: 0, opacity: '1', transform: 'translateY(0) scale(1)' },\n                { offset: 1, opacity: '0', transform: finalTransform },\n              ]);\n\n            baseAnimation.addAnimation([presentingAnimation, shadowAnimation]);\n          }\n        }\n      } else {\n        baseAnimation.addAnimation(backdropAnimation);\n        if (currentBackdropAnimation) {\n          baseAnimation.addAnimation(currentBackdropAnimation);\n        }\n      }\n\n      return baseAnimation;\n    };\n  }\n\n  public leaveAnimation(currentBackdrop?: HTMLIonBackdropElement): AnimationBuilder {\n    return (\n      baseEl: HTMLElement,\n      opts: ModalAnimationOptions,\n      duration = this.duration\n    ): Animation => {\n      const { presentingEl } = opts;\n      const root = this.getElementRoot(baseEl);\n      const { wrapperAnimation, backdropAnimation } = this.createLeaveAnimation();\n\n      backdropAnimation.addElement(root.querySelector('ion-backdrop')!);\n\n      wrapperAnimation\n        .addElement(root.querySelectorAll('.modal-wrapper, .modal-shadow')!)\n        .beforeStyles({ opacity: 1 });\n\n      const baseAnimation = createAnimation('leaving-base')\n        .addElement(baseEl)\n        .easing(this.easingLeave)\n        .duration(duration)\n        .addAnimation(wrapperAnimation);\n\n      let currentBackdropAnimation: Animation;\n      if (currentBackdrop) {\n        currentBackdropAnimation = createAnimation()\n          .addElement(currentBackdrop)\n          .fromTo('opacity', 0.01, 'var(--backdrop-opacity)')\n          .afterStyles({ opacity: 'var(--backdrop-opacity)' }); //Ensures backdrop is reset to default opacity after swipe to close\n      }\n\n      if (presentingEl) {\n        const isMobile = !this.platform.isPhabletOrBigger();\n        const hasCardModal =\n          presentingEl.tagName === 'ION-MODAL' &&\n          (presentingEl as HTMLIonModalElement).presentingElement !== undefined;\n        const presentingElRoot = this.getElementRoot(presentingEl);\n\n        const presentingAnimation = createAnimation()\n          .beforeClearStyles(['transform'])\n          .afterClearStyles(['transform'])\n          .onFinish((currentStep) => {\n            // only reset background color if this is the last card-style modal\n            if (currentStep !== 1) {\n              return;\n            }\n\n            presentingEl.style.setProperty('overflow', '');\n\n            const numModals = Array.from(bodyEl.querySelectorAll('ion-modal')).filter(\n              (m) => m.presentingElement !== undefined\n            ).length;\n            if (numModals <= 1) {\n              bodyEl.style.setProperty('background-color', '');\n            }\n          });\n\n        const bodyEl = document.body;\n\n        if (isMobile) {\n          const transformOffset = !CSS.supports('width', 'max(0px, 1px)')\n            ? '30px'\n            : 'max(30px, var(--ion-safe-area-top))';\n          const modalTransform = hasCardModal ? '-10px' : transformOffset;\n          const toPresentingScale = this.SwipeToCloseDefaults.MIN_PRESENTING_SCALE;\n          const finalTransform = `translateY(${modalTransform}) scale(${toPresentingScale})`;\n\n          presentingAnimation.addElement(presentingEl).keyframes([\n            {\n              offset: 0,\n              filter: 'contrast(0.85)',\n              transform: finalTransform,\n              borderRadius: '10px 10px 0 0',\n            },\n            {\n              offset: 1,\n              filter: 'contrast(1)',\n              transform: 'translateY(0px) scale(1)',\n              borderRadius: '0px',\n            },\n          ]);\n\n          baseAnimation.addAnimation(presentingAnimation);\n        } else {\n          baseAnimation.addAnimation(backdropAnimation);\n          if (currentBackdropAnimation) {\n            baseAnimation.addAnimation(currentBackdropAnimation);\n          }\n\n          if (!hasCardModal) {\n            wrapperAnimation.fromTo('opacity', '1', '0');\n          } else {\n            const toPresentingScale = hasCardModal\n              ? this.SwipeToCloseDefaults.MIN_PRESENTING_SCALE\n              : 1;\n            const finalTransform = `translateY(-10px) scale(${toPresentingScale})`;\n\n            presentingAnimation\n              .addElement(presentingElRoot.querySelector('.modal-wrapper')!)\n              .afterStyles({\n                transform: 'translate3d(0, 0, 0)',\n              })\n              .keyframes([\n                { offset: 0, filter: 'contrast(0.85)', transform: finalTransform },\n                { offset: 1, filter: 'contrast(1)', transform: 'translateY(0) scale(1)' },\n              ]);\n\n            const shadowAnimation = createAnimation()\n              .addElement(presentingElRoot.querySelector('.modal-shadow')!)\n              .afterStyles({\n                transform: 'translateY(0) scale(1)',\n              })\n              .keyframes([\n                { offset: 0, opacity: '0', transform: finalTransform },\n                { offset: 1, opacity: '1', transform: 'translateY(0) scale(1)' },\n              ]);\n\n            baseAnimation.addAnimation([presentingAnimation, shadowAnimation]);\n          }\n        }\n      } else {\n        baseAnimation.addAnimation(backdropAnimation);\n        if (currentBackdropAnimation) {\n          baseAnimation.addAnimation(currentBackdropAnimation);\n        }\n      }\n\n      return baseAnimation;\n    };\n  }\n\n  private createEnterAnimation = () => {\n    const backdropAnimation = createAnimation()\n      .fromTo('opacity', 0.01, 'var(--backdrop-opacity)')\n      .beforeStyles({\n        'pointer-events': 'none',\n      })\n      .afterClearStyles(['pointer-events']);\n\n    const wrapperAnimation = createAnimation().fromTo(\n      'transform',\n      'translateY(100vh)',\n      'translateY(0vh)'\n    );\n\n    return { backdropAnimation, wrapperAnimation };\n  };\n\n  private createLeaveAnimation = () => {\n    const backdropAnimation = createAnimation().fromTo('opacity', 'var(--backdrop-opacity)', 0);\n\n    const wrapperAnimation = createAnimation().fromTo(\n      'transform',\n      'translateY(0vh)',\n      'translateY(100vh)'\n    );\n\n    return { backdropAnimation, wrapperAnimation };\n  };\n\n  /**\n   * Gets the root context of a shadow dom element\n   * On newer browsers this will be the shadowRoot,\n   * but for older browser this may just be the\n   * element itself.\n   *\n   * Useful for whenever you need to explicitly\n   * do \"myElement.shadowRoot!.querySelector(...)\".\n   */\n  private getElementRoot = (el: HTMLElement, fallback: HTMLElement = el) => {\n    return el.shadowRoot || fallback;\n  };\n}\n"]}
255
+ }], ctorParameters: function () { return [{ type: i1.AnimationController }, { type: i2.PlatformService }]; } });
256
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal-animation-builder.service.js","sourceRoot":"","sources":["../../../../../../../../libs/designsystem/src/lib/components/modal/services/modal-animation-builder.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { Animation, AnimationBuilder, AnimationController } from '@ionic/angular';\n\nimport { KirbyAnimation } from '../../../animation/kirby-animation';\nimport { PlatformService } from '../../../helpers/platform.service';\n\n@Injectable({ providedIn: 'root' })\nexport class ModalAnimationBuilderService {\n  constructor(private animationCtrl: AnimationController, private platform: PlatformService) {}\n\n  private readonly easingEnter = KirbyAnimation.Easing.modal.enter;\n  private readonly easingLeave = KirbyAnimation.Easing.modal.exit;\n  private readonly duration = KirbyAnimation.Duration.LONG;\n  private readonly SwipeToCloseDefaults = {\n    MIN_PRESENTING_SCALE: 0.93,\n  };\n\n  public enterAnimation(currentBackdrop?: HTMLIonBackdropElement): AnimationBuilder {\n    return (baseEl: HTMLElement, presentingEl?: HTMLElement): Animation => {\n      const backdropAnimation = this.animationCtrl\n        .create()\n        .addElement(baseEl.querySelector('ion-backdrop')!)\n        .fromTo('opacity', 0.01, 'var(--backdrop-opacity)')\n        .beforeStyles({\n          'pointer-events': 'none',\n        })\n        .afterClearStyles(['pointer-events']);\n\n      const wrapperAnimation = this.animationCtrl\n        .create()\n        .addElement(baseEl.querySelectorAll('.modal-wrapper, .modal-shadow')!)\n        .beforeStyles({ opacity: 1 })\n        .fromTo('transform', 'translateY(100vh)', 'translateY(0vh)');\n\n      const baseAnimation = this.animationCtrl\n        .create()\n        .addElement(baseEl)\n        .easing(this.easingEnter)\n        .duration(this.duration)\n        .addAnimation(wrapperAnimation);\n\n      let currentBackdropAnimation: Animation;\n      if (currentBackdrop) {\n        currentBackdropAnimation = this.animationCtrl\n          .create()\n          .addElement(currentBackdrop)\n          .fromTo('opacity', 'var(--backdrop-opacity)', 0.01);\n      }\n\n      if (presentingEl) {\n        const isMobile = !this.platform.isPhabletOrBigger();\n        const hasCardModal =\n          presentingEl.tagName === 'ION-MODAL' &&\n          (presentingEl as HTMLIonModalElement).presentingElement !== undefined;\n\n        const presentingAnimation = this.animationCtrl.create().beforeStyles({\n          transform: 'translateY(0)',\n          'transform-origin': 'top center',\n          overflow: 'hidden',\n        });\n\n        const bodyEl = document.body;\n\n        if (isMobile) {\n          /**\n           * Fallback for browsers that does not support `max()` (ex: Firefox)\n           * No need to worry about statusbar padding since engines like Gecko\n           * are not used as the engine for standlone Cordova/Capacitor apps\n           */\n          const transformOffset = !CSS.supports('width', 'max(0px, 1px)')\n            ? '30px'\n            : 'max(30px, var(--ion-safe-area-top))';\n          const modalTransform = hasCardModal ? '-10px' : transformOffset;\n          const toPresentingScale = this.SwipeToCloseDefaults.MIN_PRESENTING_SCALE;\n          const finalTransform = `translateY(${modalTransform}) scale(${toPresentingScale})`;\n\n          presentingAnimation\n            .afterStyles({\n              transform: finalTransform,\n            })\n            .beforeAddWrite(() => bodyEl.style.setProperty('background-color', 'black'))\n            .addElement(presentingEl)\n            .keyframes([\n              {\n                offset: 0,\n                filter: 'contrast(1)',\n                transform: 'translateY(0px) scale(1)',\n                borderRadius: '0px',\n              },\n              {\n                offset: 1,\n                filter: 'contrast(0.85)',\n                transform: finalTransform,\n                borderRadius: '10px 10px 0 0',\n              },\n            ]);\n          baseAnimation.addAnimation(presentingAnimation);\n        } else {\n          baseAnimation.addAnimation(backdropAnimation);\n          if (currentBackdropAnimation) {\n            baseAnimation.addAnimation(currentBackdropAnimation);\n          }\n\n          if (!hasCardModal) {\n            wrapperAnimation.fromTo('opacity', '0', '1');\n          } else {\n            const toPresentingScale = hasCardModal\n              ? this.SwipeToCloseDefaults.MIN_PRESENTING_SCALE\n              : 1;\n            const finalTransform = `translateY(-10px) scale(${toPresentingScale})`;\n\n            presentingAnimation\n              .afterStyles({\n                transform: finalTransform,\n              })\n              .addElement(presentingEl.querySelector('.modal-wrapper')!)\n              .keyframes([\n                { offset: 0, filter: 'contrast(1)', transform: 'translateY(0) scale(1)' },\n                { offset: 1, filter: 'contrast(0.85)', transform: finalTransform },\n              ]);\n\n            const shadowAnimation = this.animationCtrl\n              .create()\n              .afterStyles({\n                transform: finalTransform,\n              })\n              .addElement(presentingEl.querySelector('.modal-shadow')!)\n              .keyframes([\n                { offset: 0, opacity: '1', transform: 'translateY(0) scale(1)' },\n                { offset: 1, opacity: '0', transform: finalTransform },\n              ]);\n\n            baseAnimation.addAnimation([presentingAnimation, shadowAnimation]);\n          }\n        }\n      } else {\n        baseAnimation.addAnimation(backdropAnimation);\n        if (currentBackdropAnimation) {\n          baseAnimation.addAnimation(currentBackdropAnimation);\n        }\n      }\n\n      return baseAnimation;\n    };\n  }\n\n  public leaveAnimation(currentBackdrop?: HTMLIonBackdropElement): AnimationBuilder {\n    return (baseEl: HTMLElement, presentingEl?: HTMLElement): Animation => {\n      const backdropAnimation = this.animationCtrl\n        .create()\n        .addElement(baseEl.querySelector('ion-backdrop')!)\n        .fromTo('opacity', 'var(--backdrop-opacity)', 0.0);\n\n      const wrapperAnimation = this.animationCtrl\n        .create()\n        .addElement(baseEl.querySelectorAll('.modal-wrapper, .modal-shadow')!)\n        .beforeStyles({ opacity: 1 })\n        .fromTo('transform', 'translateY(0vh)', 'translateY(100vh)');\n\n      const baseAnimation = this.animationCtrl\n        .create()\n        .addElement(baseEl)\n        .easing(this.easingLeave)\n        .duration(this.duration)\n        .addAnimation(wrapperAnimation);\n\n      let currentBackdropAnimation: Animation;\n      if (currentBackdrop) {\n        currentBackdropAnimation = this.animationCtrl\n          .create()\n          .addElement(currentBackdrop)\n          .fromTo('opacity', 0.01, 'var(--backdrop-opacity)')\n          .afterStyles({ opacity: 'var(--backdrop-opacity)' }); //Ensures backdrop is reset to default opacity after swipe to close\n      }\n\n      if (presentingEl) {\n        const isMobile = !this.platform.isPhabletOrBigger();\n        const hasCardModal =\n          presentingEl.tagName === 'ION-MODAL' &&\n          (presentingEl as HTMLIonModalElement).presentingElement !== undefined;\n\n        const presentingAnimation = this.animationCtrl\n          .create()\n          .beforeClearStyles(['transform'])\n          .afterClearStyles(['transform'])\n          .onFinish((currentStep) => {\n            // only reset background color if this is the last card-style modal\n            if (currentStep !== 1) {\n              return;\n            }\n\n            presentingEl.style.setProperty('overflow', '');\n\n            const numModals = Array.from(bodyEl.querySelectorAll('ion-modal')).filter(\n              (m) => m.presentingElement !== undefined\n            ).length;\n            if (numModals <= 1) {\n              bodyEl.style.setProperty('background-color', '');\n            }\n          });\n\n        const bodyEl = document.body;\n\n        if (isMobile) {\n          const transformOffset = !CSS.supports('width', 'max(0px, 1px)')\n            ? '30px'\n            : 'max(30px, var(--ion-safe-area-top))';\n          const modalTransform = hasCardModal ? '-10px' : transformOffset;\n          const toPresentingScale = this.SwipeToCloseDefaults.MIN_PRESENTING_SCALE;\n          const finalTransform = `translateY(${modalTransform}) scale(${toPresentingScale})`;\n\n          presentingAnimation.addElement(presentingEl).keyframes([\n            {\n              offset: 0,\n              filter: 'contrast(0.85)',\n              transform: finalTransform,\n              borderRadius: '10px 10px 0 0',\n            },\n            {\n              offset: 1,\n              filter: 'contrast(1)',\n              transform: 'translateY(0px) scale(1)',\n              borderRadius: '0px',\n            },\n          ]);\n\n          baseAnimation.addAnimation(presentingAnimation);\n        } else {\n          baseAnimation.addAnimation(backdropAnimation);\n          if (currentBackdropAnimation) {\n            baseAnimation.addAnimation(currentBackdropAnimation);\n          }\n\n          if (!hasCardModal) {\n            wrapperAnimation.fromTo('opacity', '1', '0');\n          } else {\n            const toPresentingScale = hasCardModal\n              ? this.SwipeToCloseDefaults.MIN_PRESENTING_SCALE\n              : 1;\n            const finalTransform = `translateY(-10px) scale(${toPresentingScale})`;\n\n            presentingAnimation\n              .addElement(presentingEl.querySelector('.modal-wrapper')!)\n              .afterStyles({\n                transform: 'translate3d(0, 0, 0)',\n              })\n              .keyframes([\n                { offset: 0, filter: 'contrast(0.85)', transform: finalTransform },\n                { offset: 1, filter: 'contrast(1)', transform: 'translateY(0) scale(1)' },\n              ]);\n\n            const shadowAnimation = this.animationCtrl\n              .create()\n              .addElement(presentingEl.querySelector('.modal-shadow')!)\n              .afterStyles({\n                transform: 'translateY(0) scale(1)',\n              })\n              .keyframes([\n                { offset: 0, opacity: '0', transform: finalTransform },\n                { offset: 1, opacity: '1', transform: 'translateY(0) scale(1)' },\n              ]);\n\n            baseAnimation.addAnimation([presentingAnimation, shadowAnimation]);\n          }\n        }\n      } else {\n        baseAnimation.addAnimation(backdropAnimation);\n        if (currentBackdropAnimation) {\n          baseAnimation.addAnimation(currentBackdropAnimation);\n        }\n      }\n\n      return baseAnimation;\n    };\n  }\n}\n"]}
@@ -17,6 +17,13 @@ export class ModalHelper {
17
17
  async showModalWindow(config) {
18
18
  config.flavor = config.flavor || 'modal';
19
19
  const modalPresentingElement = await this.getPresentingElement(config.flavor);
20
+ let currentBackdrop;
21
+ const topMostModal = await this.ionicModalController.getTop();
22
+ if (topMostModal) {
23
+ currentBackdrop = topMostModal.querySelector('ion-backdrop');
24
+ }
25
+ const enterAnimation = this.modalAnimationBuilder.enterAnimation(currentBackdrop);
26
+ const leaveAnimation = this.modalAnimationBuilder.leaveAnimation(currentBackdrop);
20
27
  const defaultModalSize = config.flavor === 'modal' ? 'medium' : null;
21
28
  const modalSize = config.size || defaultModalSize;
22
29
  const allow_scroll_class = 'allow-background-scroll';
@@ -27,14 +34,6 @@ export class ModalHelper {
27
34
  if (config.interactWithBackground) {
28
35
  this.windowRef.nativeWindow.document.body.classList.add(allow_scroll_class);
29
36
  }
30
- let currentBackdrop;
31
- const topMostModal = await this.ionicModalController.getTop();
32
- if (topMostModal) {
33
- currentBackdrop =
34
- topMostModal.shadowRoot.querySelector('ion-backdrop');
35
- }
36
- const enterAnimation = this.modalAnimationBuilder.enterAnimation(currentBackdrop);
37
- const leaveAnimation = this.modalAnimationBuilder.leaveAnimation(currentBackdrop);
38
37
  const ionModal = await this.ionicModalController.create({
39
38
  component: config.flavor === 'compact' ? ModalCompactWrapperComponent : ModalWrapperComponent,
40
39
  cssClass: [
@@ -42,7 +41,7 @@ export class ModalHelper {
42
41
  'kirby-modal',
43
42
  config.flavor === 'drawer' ? 'kirby-drawer' : null,
44
43
  config.flavor === 'compact' ? 'kirby-modal-compact' : null,
45
- modalSize ? 'kirby-modal-' + modalSize : null,
44
+ 'kirby-modal-' + modalSize,
46
45
  config.interactWithBackground ? 'interact-with-background' : null,
47
46
  ...customCssClasses,
48
47
  ],
@@ -52,8 +51,8 @@ export class ModalHelper {
52
51
  swipeToClose: config.flavor != 'compact',
53
52
  presentingElement: modalPresentingElement,
54
53
  keyboardClose: false,
55
- enterAnimation: enterAnimation,
56
- leaveAnimation: leaveAnimation,
54
+ enterAnimation,
55
+ leaveAnimation,
57
56
  });
58
57
  if (config.interactWithBackground) {
59
58
  ionModal.onDidDismiss().then(() => {
@@ -107,4 +106,4 @@ ModalHelper.presentingElement = undefined;
107
106
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.9", ngImport: i0, type: ModalHelper, decorators: [{
108
107
  type: Injectable
109
108
  }], ctorParameters: function () { return [{ type: i1.ModalController }, { type: i2.ModalAnimationBuilderService }, { type: i3.WindowRef }]; } });
110
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.helper.js","sourceRoot":"","sources":["../../../../../../../../libs/designsystem/src/lib/components/modal/services/modal.helper.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { ModalController } from '@ionic/angular';\n\nimport { KirbyAnimation } from '../../../animation/kirby-animation';\nimport { WindowRef } from '../../../types/window-ref';\nimport { ModalCompactWrapperComponent } from '../modal-wrapper/compact/modal-compact-wrapper.component';\nimport { ModalConfig, ModalFlavor, ModalSize } from '../modal-wrapper/config/modal-config';\nimport { ModalWrapperComponent } from '../modal-wrapper/modal-wrapper.component';\n\nimport { ModalAnimationBuilderService } from './modal-animation-builder.service';\nimport { Overlay } from './modal.interfaces';\n\n@Injectable()\nexport class ModalHelper {\n  // TODO: Make presentingElement an instance field when\n  // forRoot()/singleton services has been solved:\n  private static presentingElement: HTMLElement = undefined;\n\n  constructor(\n    private ionicModalController: ModalController,\n    private modalAnimationBuilder: ModalAnimationBuilderService,\n    private windowRef: WindowRef\n  ) {}\n\n  public async showModalWindow(config: ModalConfig): Promise<Overlay> {\n    config.flavor = config.flavor || 'modal';\n    const modalPresentingElement = await this.getPresentingElement(config.flavor);\n\n    const defaultModalSize: ModalSize = config.flavor === 'modal' ? 'medium' : null;\n    const modalSize = config.size || defaultModalSize;\n    const allow_scroll_class = 'allow-background-scroll';\n\n    let customCssClasses = [];\n    if (config.cssClass) {\n      customCssClasses = Array.isArray(config.cssClass) ? config.cssClass : [config.cssClass];\n    }\n\n    if (config.interactWithBackground) {\n      this.windowRef.nativeWindow.document.body.classList.add(allow_scroll_class);\n    }\n\n    let currentBackdrop: HTMLIonBackdropElement;\n    const topMostModal = await this.ionicModalController.getTop();\n    if (topMostModal) {\n      currentBackdrop =\n        topMostModal.shadowRoot.querySelector<HTMLIonBackdropElement>('ion-backdrop');\n    }\n\n    const enterAnimation = this.modalAnimationBuilder.enterAnimation(currentBackdrop);\n    const leaveAnimation = this.modalAnimationBuilder.leaveAnimation(currentBackdrop);\n\n    const ionModal = await this.ionicModalController.create({\n      component: config.flavor === 'compact' ? ModalCompactWrapperComponent : ModalWrapperComponent,\n      cssClass: [\n        'kirby-overlay',\n        'kirby-modal',\n        config.flavor === 'drawer' ? 'kirby-drawer' : null,\n        config.flavor === 'compact' ? 'kirby-modal-compact' : null,\n        modalSize ? 'kirby-modal-' + modalSize : null,\n        config.interactWithBackground ? 'interact-with-background' : null,\n        ...customCssClasses,\n      ],\n      backdropDismiss: config.flavor === 'compact' || config.interactWithBackground ? false : true,\n      showBackdrop: !config.interactWithBackground,\n      componentProps: { config: config },\n      swipeToClose: config.flavor != 'compact',\n      presentingElement: modalPresentingElement,\n      keyboardClose: false,\n      enterAnimation: enterAnimation,\n      leaveAnimation: leaveAnimation,\n    });\n\n    if (config.interactWithBackground) {\n      ionModal.onDidDismiss().then(() => {\n        this.windowRef.nativeWindow.document.body.classList.remove(allow_scroll_class);\n      });\n    }\n\n    await ionModal.present();\n\n    return {\n      dismiss: ionModal.dismiss.bind(ionModal),\n      onWillDismiss: ionModal.onWillDismiss(),\n      onDidDismiss: ionModal.onDidDismiss(),\n    };\n  }\n\n  public registerPresentingElement(element: HTMLElement) {\n    ModalHelper.presentingElement = element;\n  }\n\n  private async getPresentingElement(flavor?: ModalFlavor) {\n    let modalPresentingElement: HTMLElement = undefined;\n    if (!flavor || flavor === 'modal') {\n      const topMostModal = await this.ionicModalController.getTop();\n      if (!topMostModal) {\n        modalPresentingElement = ModalHelper.presentingElement;\n      } else if (\n        !topMostModal.classList.contains('kirby-drawer') &&\n        !topMostModal.classList.contains('kirby-modal-compact')\n      ) {\n        modalPresentingElement = topMostModal;\n      }\n    }\n    return modalPresentingElement;\n  }\n\n  public async scrollToTop(\n    noModalRegisteredErrorMessage: string,\n    duration?: KirbyAnimation.Duration\n  ) {\n    const modal = await this.ionicModalController.getTop();\n    if (!modal || !(modal.component instanceof ModalWrapperComponent)) {\n      throw new Error(noModalRegisteredErrorMessage);\n    }\n    modal.component.scrollToTop(duration);\n  }\n\n  public async scrollToBottom(\n    noModalRegisteredErrorMessage: string,\n    duration?: KirbyAnimation.Duration\n  ) {\n    const modal = await this.ionicModalController.getTop();\n    if (!modal || !(modal.component instanceof ModalWrapperComponent)) {\n      throw new Error(noModalRegisteredErrorMessage);\n    }\n    modal.component.scrollToBottom(duration);\n  }\n}\n"]}
109
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.helper.js","sourceRoot":"","sources":["../../../../../../../../libs/designsystem/src/lib/components/modal/services/modal.helper.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { ModalController } from '@ionic/angular';\n\nimport { KirbyAnimation } from '../../../animation/kirby-animation';\nimport { WindowRef } from '../../../types/window-ref';\nimport { ModalCompactWrapperComponent } from '../modal-wrapper/compact/modal-compact-wrapper.component';\nimport { ModalConfig, ModalFlavor, ModalSize } from '../modal-wrapper/config/modal-config';\nimport { ModalWrapperComponent } from '../modal-wrapper/modal-wrapper.component';\n\nimport { ModalAnimationBuilderService } from './modal-animation-builder.service';\nimport { Overlay } from './modal.interfaces';\n\n@Injectable()\nexport class ModalHelper {\n  // TODO: Make presentingElement an instance field when\n  // forRoot()/singleton services has been solved:\n  private static presentingElement: HTMLElement = undefined;\n\n  constructor(\n    private ionicModalController: ModalController,\n    private modalAnimationBuilder: ModalAnimationBuilderService,\n    private windowRef: WindowRef\n  ) {}\n\n  public async showModalWindow(config: ModalConfig): Promise<Overlay> {\n    config.flavor = config.flavor || 'modal';\n    const modalPresentingElement = await this.getPresentingElement(config.flavor);\n\n    let currentBackdrop: HTMLIonBackdropElement;\n    const topMostModal = await this.ionicModalController.getTop();\n    if (topMostModal) {\n      currentBackdrop = topMostModal.querySelector<HTMLIonBackdropElement>('ion-backdrop');\n    }\n\n    const enterAnimation = this.modalAnimationBuilder.enterAnimation(currentBackdrop);\n    const leaveAnimation = this.modalAnimationBuilder.leaveAnimation(currentBackdrop);\n\n    const defaultModalSize: ModalSize = config.flavor === 'modal' ? 'medium' : null;\n    const modalSize = config.size || defaultModalSize;\n    const allow_scroll_class = 'allow-background-scroll';\n\n    let customCssClasses = [];\n    if (config.cssClass) {\n      customCssClasses = Array.isArray(config.cssClass) ? config.cssClass : [config.cssClass];\n    }\n\n    if (config.interactWithBackground) {\n      this.windowRef.nativeWindow.document.body.classList.add(allow_scroll_class);\n    }\n\n    const ionModal = await this.ionicModalController.create({\n      component: config.flavor === 'compact' ? ModalCompactWrapperComponent : ModalWrapperComponent,\n      cssClass: [\n        'kirby-overlay',\n        'kirby-modal',\n        config.flavor === 'drawer' ? 'kirby-drawer' : null,\n        config.flavor === 'compact' ? 'kirby-modal-compact' : null,\n        'kirby-modal-' + modalSize,\n        config.interactWithBackground ? 'interact-with-background' : null,\n        ...customCssClasses,\n      ],\n      backdropDismiss: config.flavor === 'compact' || config.interactWithBackground ? false : true,\n      showBackdrop: !config.interactWithBackground,\n      componentProps: { config: config },\n      swipeToClose: config.flavor != 'compact',\n      presentingElement: modalPresentingElement,\n      keyboardClose: false,\n      enterAnimation,\n      leaveAnimation,\n    });\n\n    if (config.interactWithBackground) {\n      ionModal.onDidDismiss().then(() => {\n        this.windowRef.nativeWindow.document.body.classList.remove(allow_scroll_class);\n      });\n    }\n\n    await ionModal.present();\n\n    return {\n      dismiss: ionModal.dismiss.bind(ionModal),\n      onWillDismiss: ionModal.onWillDismiss(),\n      onDidDismiss: ionModal.onDidDismiss(),\n    };\n  }\n\n  public registerPresentingElement(element: HTMLElement) {\n    ModalHelper.presentingElement = element;\n  }\n\n  private async getPresentingElement(flavor?: ModalFlavor) {\n    let modalPresentingElement: HTMLElement = undefined;\n    if (!flavor || flavor === 'modal') {\n      const topMostModal = await this.ionicModalController.getTop();\n      if (!topMostModal) {\n        modalPresentingElement = ModalHelper.presentingElement;\n      } else if (\n        !topMostModal.classList.contains('kirby-drawer') &&\n        !topMostModal.classList.contains('kirby-modal-compact')\n      ) {\n        modalPresentingElement = topMostModal;\n      }\n    }\n    return modalPresentingElement;\n  }\n\n  public async scrollToTop(\n    noModalRegisteredErrorMessage: string,\n    duration?: KirbyAnimation.Duration\n  ) {\n    const modal = await this.ionicModalController.getTop();\n    if (!modal || !(modal.component instanceof ModalWrapperComponent)) {\n      throw new Error(noModalRegisteredErrorMessage);\n    }\n    modal.component.scrollToTop(duration);\n  }\n\n  public async scrollToBottom(\n    noModalRegisteredErrorMessage: string,\n    duration?: KirbyAnimation.Duration\n  ) {\n    const modal = await this.ionicModalController.getTop();\n    if (!modal || !(modal.component instanceof ModalWrapperComponent)) {\n      throw new Error(noModalRegisteredErrorMessage);\n    }\n    modal.component.scrollToBottom(duration);\n  }\n}\n"]}
@@ -361,7 +361,7 @@ export class PageComponent {
361
361
  }
362
362
  }
363
363
  /** @nocollapse */ PageComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.9", ngImport: i0, type: PageComponent, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i3.Router }, { token: i0.ChangeDetectorRef }, { token: i4.WindowRef }, { token: i5.ModalNavigationService }, { token: i6.TabsComponent, optional: true, skipSelf: true }], target: i0.ɵɵFactoryTarget.Component });
364
- /** @nocollapse */ PageComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.9", type: PageComponent, selector: "kirby-page", inputs: { title: "title", subtitle: "subtitle", toolbarTitle: "toolbarTitle", titleAlignment: "titleAlignment", defaultBackHref: "defaultBackHref", hideBackButton: "hideBackButton", titleMaxLines: "titleMaxLines", tabBarBottomHidden: "tabBarBottomHidden" }, outputs: { enter: "enter", leave: "leave", refresh: "refresh", backButtonClick: "backButtonClick" }, host: { listeners: { "window:keyboardWillShow": "_onKeyboardWillShow($event)", "window:keyboardWillHide": "_onKeyboardWillHide()" } }, queries: [{ propertyName: "customToolbarTitleTemplate", first: true, predicate: PageToolbarTitleDirective, descendants: true, read: TemplateRef }, { propertyName: "customTitleTemplate", first: true, predicate: PageTitleDirective, descendants: true, read: TemplateRef }, { propertyName: "customSubtitleTemplate", first: true, predicate: PageSubtitleDirective, descendants: true, read: TemplateRef }, { propertyName: "customActions", predicate: PageActionsDirective }, { propertyName: "customContent", predicate: PageContentDirective }], viewQueries: [{ propertyName: "content", 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: "ionFooterElement", first: true, predicate: IonFooter, descendants: true, read: ElementRef, static: true }, { propertyName: "backButtonDelegate", first: true, predicate: IonBackButtonDelegate, descendants: true }, { propertyName: "pageTitle", first: true, predicate: ["pageTitle"], descendants: true, read: ElementRef }, { propertyName: "simpleTitleTemplate", first: true, predicate: ["simpleTitleTemplate"], descendants: true, read: TemplateRef, static: true }, { propertyName: "simpleToolbarTitleTemplate", first: true, predicate: ["simpleToolbarTitleTemplate"], descendants: true, read: TemplateRef, static: true }], usesOnChanges: true, ngImport: i0, template: "<ion-header>\n <ion-toolbar>\n <ion-buttons slot=\"start\">\n <ion-back-button\n text=\"\"\n [defaultHref]=\"defaultBackHref\"\n icon=\"assets/kirby/icons/svg/arrow-back.svg\"\n [style.visibility]=\"hideBackButton ? 'hidden' : null\"\n ></ion-back-button>\n </ion-buttons>\n <ion-title>\n <div class=\"toolbar-title hide\" [class.fade-in]=\"toolbarTitleVisible\">\n <ng-container *ngTemplateOutlet=\"toolbarTitleTemplate\"></ng-container>\n </div>\n </ion-title>\n <ion-buttons\n class=\"hide\"\n slot=\"primary\"\n [class.fade-in]=\"toolbarStickyActionsVisible && stickyActionsTemplate\"\n >\n <ng-container *ngTemplateOutlet=\"stickyActionsTemplate\"></ng-container>\n </ion-buttons>\n <ion-buttons\n class=\"hide\"\n slot=\"secondary\"\n [class.fade-in]=\"toolbarFixedActionsVisible && fixedActionsTemplate\"\n >\n <ng-container *ngTemplateOutlet=\"fixedActionsTemplate\"></ng-container>\n </ion-buttons>\n </ion-toolbar>\n</ion-header>\n\n<ion-content scrollEvents=\"true\" forceOverscroll=\"false\">\n <ion-refresher\n *ngIf=\"refresh.observers.length > 0\"\n (ionRefresh)=\"delegateRefreshEvent($event)\"\n slot=\"fixed\"\n >\n <kirby-spinner></kirby-spinner>\n </ion-refresher>\n\n <div class=\"content-inner\">\n <div\n class=\"page-header\"\n *ngIf=\"hasPageTitle\"\n [ngClass]=\"{\n 'text-center': titleAlignment === 'center',\n 'text-right': titleAlignment === 'right'\n }\"\n >\n <div #pageTitle class=\"page-title\" [class.has-actions]=\"hasActionsInPage\">\n <ng-container\n *ngTemplateOutlet=\"customTitleTemplate || defaultPageTitleTemplate\"\n ></ng-container>\n <ng-container\n *ngTemplateOutlet=\"pageActionsTemplate || defaultPageActionsTemplate\"\n ></ng-container>\n </div>\n <div *ngIf=\"hasPageSubtitle\" class=\"page-subtitle\">\n <ng-container\n *ngTemplateOutlet=\"customSubtitleTemplate || defaultPageSubtitleTemplate\"\n ></ng-container>\n </div>\n </div>\n\n <!-- Content -->\n <ng-container\n *ngTemplateOutlet=\"customContentTemplate || defaultContentTemplate\"\n ></ng-container>\n </div>\n\n <div slot=\"fixed\" class=\"fixed-content\" *ngIf=\"fixedContentTemplate\">\n <div class=\"content-inner\">\n <ng-container *ngTemplateOutlet=\"fixedContentTemplate\"></ng-container>\n </div>\n </div>\n</ion-content>\n\n<ion-footer>\n <ng-content select=\"kirby-page-footer\"></ng-content>\n</ion-footer>\n\n<ng-template #defaultPageTitleTemplate>\n <h1 [kirbyFitHeading]=\"fitHeadingConfig\">\n <ng-container *ngTemplateOutlet=\"simpleTitleTemplate\"></ng-container>\n </h1>\n</ng-template>\n<ng-template #defaultPageSubtitleTemplate>\n <ng-container *ngTemplateOutlet=\"simpleSubtitleTemplate\"></ng-container>\n</ng-template>\n<ng-template #defaultPageActionsTemplate>\n <ng-content select=\"kirby-page-actions\"></ng-content>\n</ng-template>\n\n<ng-template #defaultContentTemplate>\n <ng-content select=\"kirby-page-content\"></ng-content>\n</ng-template>\n\n<ng-template #simpleTitleTemplate>{{ title }}</ng-template>\n<ng-template #simpleSubtitleTemplate>{{ subtitle }}</ng-template>\n<ng-template #simpleToolbarTitleTemplate>{{ toolbarTitle }}</ng-template>\n", styles: ["ion-header,ion-toolbar{--background: var(--kirby-background-color);margin:0 auto}@media (min-width: 1025px) and (hover: hover) and (pointer: fine){ion-header,ion-toolbar{max-width:768px}}ion-toolbar{--border-width: 0 !important;--padding-start: 4px;--padding-end: 4px;--padding-top: 0;--padding-bottom: 0}ion-toolbar ion-buttons[slot=secondary]{order:6}ion-toolbar ion-title .toolbar-title{text-overflow:ellipsis;white-space:nowrap;pointer-events:auto;overflow:hidden}ion-toolbar ion-title .toolbar-title ::ng-deep>*{text-overflow:ellipsis;white-space:nowrap;pointer-events:auto;overflow:hidden}.hide{visibility:hidden;opacity:0;transition:opacity .1s linear}.hide.fade-in{visibility:inherit;opacity:1}ion-title{box-sizing:border-box;font-size:16px;font-weight:400}ion-back-button{--color: var(--kirby-black);--icon-font-size: 24px;height:44px;width:44px}.page-header{margin-left:16px;margin-top:8px;margin-bottom:var(--kirby-page-title-margin-bottom, 40px)}.page-header .page-title.has-actions{display:flex;justify-content:space-between;align-items:flex-start}.page-header .page-title h1,.page-header .page-title h2,.page-header .page-title h3,.page-header .page-title h4,.page-header .page-title h5,.page-header .page-title h6{margin:0}.page-header .page-subtitle{margin-top:8px}.page-header.text-center{text-align:center;margin-left:0}.page-header.text-right{text-align:right}ion-content{--padding-start: var(--page-content-padding-start, 16px);--padding-end: var(--page-content-padding-end, 16px);--background: var(--kirby-background-color)}ion-content .content-inner{max-width:var(--page-content-max-width, 720px);margin:0 auto;padding-bottom:40px}ion-content .fixed-content{width:100%;position:absolute;bottom:0}ion-content .fixed-content .content-inner{position:relative}\n"], components: [{ type: i7.IonHeader, selector: "ion-header", inputs: ["collapse", "mode", "translucent"] }, { type: i7.IonToolbar, selector: "ion-toolbar", inputs: ["color", "mode"] }, { type: i7.IonButtons, selector: "ion-buttons", inputs: ["collapse"] }, { type: i7.IonBackButton, selector: "ion-back-button", inputs: ["color", "defaultHref", "disabled", "icon", "mode", "routerAnimation", "text", "type"] }, { type: i7.IonTitle, selector: "ion-title", inputs: ["color", "size"] }, { type: i7.IonContent, selector: "ion-content", inputs: ["color", "forceOverscroll", "fullscreen", "scrollEvents", "scrollX", "scrollY"] }, { type: i7.IonRefresher, selector: "ion-refresher", inputs: ["closeDuration", "disabled", "pullFactor", "pullMax", "pullMin", "snapbackDuration"] }, { type: i8.SpinnerComponent, selector: "kirby-spinner" }, { type: i7.IonFooter, selector: "ion-footer", inputs: ["collapse", "mode", "translucent"] }], directives: [{ type: i7.IonBackButtonDelegate, selector: "ion-back-button", inputs: ["defaultHref", "routerAnimation"] }, { type: i9.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i9.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i9.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i10.FitHeadingDirective, selector: "h1[kirbyFitHeading],h2[kirbyFitHeading],h3[kirbyFitHeading]", inputs: ["kirbyFitHeading"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
364
+ /** @nocollapse */ PageComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.9", type: PageComponent, selector: "kirby-page", inputs: { title: "title", subtitle: "subtitle", toolbarTitle: "toolbarTitle", titleAlignment: "titleAlignment", defaultBackHref: "defaultBackHref", hideBackButton: "hideBackButton", titleMaxLines: "titleMaxLines", tabBarBottomHidden: "tabBarBottomHidden" }, outputs: { enter: "enter", leave: "leave", refresh: "refresh", backButtonClick: "backButtonClick" }, host: { listeners: { "window:keyboardWillShow": "_onKeyboardWillShow($event)", "window:keyboardWillHide": "_onKeyboardWillHide()" } }, queries: [{ propertyName: "customToolbarTitleTemplate", first: true, predicate: PageToolbarTitleDirective, descendants: true, read: TemplateRef }, { propertyName: "customTitleTemplate", first: true, predicate: PageTitleDirective, descendants: true, read: TemplateRef }, { propertyName: "customSubtitleTemplate", first: true, predicate: PageSubtitleDirective, descendants: true, read: TemplateRef }, { propertyName: "customActions", predicate: PageActionsDirective }, { propertyName: "customContent", predicate: PageContentDirective }], viewQueries: [{ propertyName: "content", 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: "ionFooterElement", first: true, predicate: IonFooter, descendants: true, read: ElementRef, static: true }, { propertyName: "backButtonDelegate", first: true, predicate: IonBackButtonDelegate, descendants: true }, { propertyName: "pageTitle", first: true, predicate: ["pageTitle"], descendants: true, read: ElementRef }, { propertyName: "simpleTitleTemplate", first: true, predicate: ["simpleTitleTemplate"], descendants: true, read: TemplateRef, static: true }, { propertyName: "simpleToolbarTitleTemplate", first: true, predicate: ["simpleToolbarTitleTemplate"], descendants: true, read: TemplateRef, static: true }], usesOnChanges: true, ngImport: i0, template: "<ion-header>\n <ion-toolbar>\n <ion-buttons slot=\"start\">\n <ion-back-button\n text=\"\"\n [defaultHref]=\"defaultBackHref\"\n icon=\"assets/kirby/icons/svg/arrow-back.svg\"\n [style.visibility]=\"hideBackButton ? 'hidden' : null\"\n ></ion-back-button>\n </ion-buttons>\n <ion-title>\n <div class=\"toolbar-title hide\" [class.fade-in]=\"toolbarTitleVisible\">\n <ng-container *ngTemplateOutlet=\"toolbarTitleTemplate\"></ng-container>\n </div>\n </ion-title>\n <ion-buttons\n class=\"hide\"\n slot=\"primary\"\n [class.fade-in]=\"toolbarStickyActionsVisible && stickyActionsTemplate\"\n >\n <ng-container *ngTemplateOutlet=\"stickyActionsTemplate\"></ng-container>\n </ion-buttons>\n <ion-buttons\n class=\"hide\"\n slot=\"secondary\"\n [class.fade-in]=\"toolbarFixedActionsVisible && fixedActionsTemplate\"\n >\n <ng-container *ngTemplateOutlet=\"fixedActionsTemplate\"></ng-container>\n </ion-buttons>\n </ion-toolbar>\n</ion-header>\n\n<ion-content scrollEvents=\"true\" forceOverscroll=\"false\">\n <ion-refresher\n *ngIf=\"refresh.observers.length > 0\"\n (ionRefresh)=\"delegateRefreshEvent($event)\"\n slot=\"fixed\"\n >\n <kirby-spinner></kirby-spinner>\n </ion-refresher>\n\n <div class=\"content-inner\">\n <div\n class=\"page-header\"\n *ngIf=\"hasPageTitle\"\n [ngClass]=\"{\n 'text-center': titleAlignment === 'center',\n 'text-right': titleAlignment === 'right'\n }\"\n >\n <div #pageTitle class=\"page-title\" [class.has-actions]=\"hasActionsInPage\">\n <ng-container\n *ngTemplateOutlet=\"customTitleTemplate || defaultPageTitleTemplate\"\n ></ng-container>\n <ng-container\n *ngTemplateOutlet=\"pageActionsTemplate || defaultPageActionsTemplate\"\n ></ng-container>\n </div>\n <div *ngIf=\"hasPageSubtitle\" class=\"page-subtitle\">\n <ng-container\n *ngTemplateOutlet=\"customSubtitleTemplate || defaultPageSubtitleTemplate\"\n ></ng-container>\n </div>\n </div>\n\n <!-- Content -->\n <ng-container\n *ngTemplateOutlet=\"customContentTemplate || defaultContentTemplate\"\n ></ng-container>\n </div>\n\n <div slot=\"fixed\" class=\"fixed-content\" *ngIf=\"fixedContentTemplate\">\n <div class=\"content-inner\">\n <ng-container *ngTemplateOutlet=\"fixedContentTemplate\"></ng-container>\n </div>\n </div>\n</ion-content>\n\n<ion-footer>\n <ng-content select=\"kirby-page-footer\"></ng-content>\n</ion-footer>\n\n<ng-template #defaultPageTitleTemplate>\n <h1 [kirbyFitHeading]=\"fitHeadingConfig\">\n <ng-container *ngTemplateOutlet=\"simpleTitleTemplate\"></ng-container>\n </h1>\n</ng-template>\n<ng-template #defaultPageSubtitleTemplate>\n <ng-container *ngTemplateOutlet=\"simpleSubtitleTemplate\"></ng-container>\n</ng-template>\n<ng-template #defaultPageActionsTemplate>\n <ng-content select=\"kirby-page-actions\"></ng-content>\n</ng-template>\n\n<ng-template #defaultContentTemplate>\n <ng-content select=\"kirby-page-content\"></ng-content>\n</ng-template>\n\n<ng-template #simpleTitleTemplate>{{ title }}</ng-template>\n<ng-template #simpleSubtitleTemplate>{{ subtitle }}</ng-template>\n<ng-template #simpleToolbarTitleTemplate>{{ toolbarTitle }}</ng-template>\n", styles: ["ion-header,ion-toolbar{--background: var(--kirby-background-color);margin:0 auto}@media (min-width: 1025px) and (hover: hover) and (pointer: fine){ion-header,ion-toolbar{max-width:768px}}ion-toolbar{--border-width: 0 !important;--padding-start: 4px;--padding-end: 4px;--padding-top: 0;--padding-bottom: 0}ion-toolbar ion-buttons[slot=secondary]{order:6}ion-toolbar ion-title .toolbar-title{text-overflow:ellipsis;white-space:nowrap;pointer-events:auto;overflow:hidden}ion-toolbar ion-title .toolbar-title ::ng-deep>*{text-overflow:ellipsis;white-space:nowrap;pointer-events:auto;overflow:hidden}.hide{visibility:hidden;opacity:0;transition:opacity .1s linear}.hide.fade-in{visibility:inherit;opacity:1}ion-title{box-sizing:border-box;font-size:16px;font-weight:400}ion-back-button{--color: var(--kirby-black);--icon-font-size: 24px;height:44px;width:44px}.page-header{margin-left:16px;margin-top:8px;margin-bottom:var(--kirby-page-title-margin-bottom, 40px)}.page-header .page-title.has-actions{display:flex;justify-content:space-between;align-items:flex-start}.page-header .page-title h1,.page-header .page-title h2,.page-header .page-title h3,.page-header .page-title h4,.page-header .page-title h5,.page-header .page-title h6{margin:0}.page-header .page-subtitle{margin-top:8px}.page-header.text-center{text-align:center;margin-left:0}.page-header.text-right{text-align:right}ion-content{--padding-start: var(--page-content-padding-start, 16px);--padding-end: var(--page-content-padding-end, 16px);--background: var(--kirby-background-color)}ion-content .content-inner{max-width:var(--page-content-max-width, 720px);margin:0 auto;padding-bottom:40px}ion-content .fixed-content{width:100%;position:absolute;bottom:0}ion-content .fixed-content .content-inner{position:relative}\n"], components: [{ type: i7.IonHeader, selector: "ion-header", inputs: ["collapse", "mode", "translucent"] }, { type: i7.IonToolbar, selector: "ion-toolbar", inputs: ["color", "mode"] }, { type: i7.IonButtons, selector: "ion-buttons", inputs: ["collapse"] }, { type: i7.IonBackButton, selector: "ion-back-button", inputs: ["color", "defaultHref", "disabled", "icon", "mode", "routerAnimation", "text", "type"] }, { type: i7.IonTitle, selector: "ion-title", inputs: ["color", "size"] }, { type: i7.IonContent, selector: "ion-content", inputs: ["color", "forceOverscroll", "fullscreen", "scrollEvents", "scrollX", "scrollY"] }, { type: i7.IonRefresher, selector: "ion-refresher", inputs: ["closeDuration", "disabled", "pullFactor", "pullMax", "pullMin", "snapbackDuration"] }, { type: i8.SpinnerComponent, selector: "kirby-spinner" }, { type: i7.IonFooter, selector: "ion-footer", inputs: ["mode", "translucent"] }], directives: [{ type: i7.IonBackButtonDelegate, selector: "ion-back-button", inputs: ["defaultHref", "routerAnimation"] }, { type: i9.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i9.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i9.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i10.FitHeadingDirective, selector: "h1[kirbyFitHeading],h2[kirbyFitHeading],h3[kirbyFitHeading]", inputs: ["kirbyFitHeading"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
365
365
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.9", ngImport: i0, type: PageComponent, decorators: [{
366
366
  type: Component,
367
367
  args: [{ selector: 'kirby-page', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ion-header>\n <ion-toolbar>\n <ion-buttons slot=\"start\">\n <ion-back-button\n text=\"\"\n [defaultHref]=\"defaultBackHref\"\n icon=\"assets/kirby/icons/svg/arrow-back.svg\"\n [style.visibility]=\"hideBackButton ? 'hidden' : null\"\n ></ion-back-button>\n </ion-buttons>\n <ion-title>\n <div class=\"toolbar-title hide\" [class.fade-in]=\"toolbarTitleVisible\">\n <ng-container *ngTemplateOutlet=\"toolbarTitleTemplate\"></ng-container>\n </div>\n </ion-title>\n <ion-buttons\n class=\"hide\"\n slot=\"primary\"\n [class.fade-in]=\"toolbarStickyActionsVisible && stickyActionsTemplate\"\n >\n <ng-container *ngTemplateOutlet=\"stickyActionsTemplate\"></ng-container>\n </ion-buttons>\n <ion-buttons\n class=\"hide\"\n slot=\"secondary\"\n [class.fade-in]=\"toolbarFixedActionsVisible && fixedActionsTemplate\"\n >\n <ng-container *ngTemplateOutlet=\"fixedActionsTemplate\"></ng-container>\n </ion-buttons>\n </ion-toolbar>\n</ion-header>\n\n<ion-content scrollEvents=\"true\" forceOverscroll=\"false\">\n <ion-refresher\n *ngIf=\"refresh.observers.length > 0\"\n (ionRefresh)=\"delegateRefreshEvent($event)\"\n slot=\"fixed\"\n >\n <kirby-spinner></kirby-spinner>\n </ion-refresher>\n\n <div class=\"content-inner\">\n <div\n class=\"page-header\"\n *ngIf=\"hasPageTitle\"\n [ngClass]=\"{\n 'text-center': titleAlignment === 'center',\n 'text-right': titleAlignment === 'right'\n }\"\n >\n <div #pageTitle class=\"page-title\" [class.has-actions]=\"hasActionsInPage\">\n <ng-container\n *ngTemplateOutlet=\"customTitleTemplate || defaultPageTitleTemplate\"\n ></ng-container>\n <ng-container\n *ngTemplateOutlet=\"pageActionsTemplate || defaultPageActionsTemplate\"\n ></ng-container>\n </div>\n <div *ngIf=\"hasPageSubtitle\" class=\"page-subtitle\">\n <ng-container\n *ngTemplateOutlet=\"customSubtitleTemplate || defaultPageSubtitleTemplate\"\n ></ng-container>\n </div>\n </div>\n\n <!-- Content -->\n <ng-container\n *ngTemplateOutlet=\"customContentTemplate || defaultContentTemplate\"\n ></ng-container>\n </div>\n\n <div slot=\"fixed\" class=\"fixed-content\" *ngIf=\"fixedContentTemplate\">\n <div class=\"content-inner\">\n <ng-container *ngTemplateOutlet=\"fixedContentTemplate\"></ng-container>\n </div>\n </div>\n</ion-content>\n\n<ion-footer>\n <ng-content select=\"kirby-page-footer\"></ng-content>\n</ion-footer>\n\n<ng-template #defaultPageTitleTemplate>\n <h1 [kirbyFitHeading]=\"fitHeadingConfig\">\n <ng-container *ngTemplateOutlet=\"simpleTitleTemplate\"></ng-container>\n </h1>\n</ng-template>\n<ng-template #defaultPageSubtitleTemplate>\n <ng-container *ngTemplateOutlet=\"simpleSubtitleTemplate\"></ng-container>\n</ng-template>\n<ng-template #defaultPageActionsTemplate>\n <ng-content select=\"kirby-page-actions\"></ng-content>\n</ng-template>\n\n<ng-template #defaultContentTemplate>\n <ng-content select=\"kirby-page-content\"></ng-content>\n</ng-template>\n\n<ng-template #simpleTitleTemplate>{{ title }}</ng-template>\n<ng-template #simpleSubtitleTemplate>{{ subtitle }}</ng-template>\n<ng-template #simpleToolbarTitleTemplate>{{ toolbarTitle }}</ng-template>\n", styles: ["ion-header,ion-toolbar{--background: var(--kirby-background-color);margin:0 auto}@media (min-width: 1025px) and (hover: hover) and (pointer: fine){ion-header,ion-toolbar{max-width:768px}}ion-toolbar{--border-width: 0 !important;--padding-start: 4px;--padding-end: 4px;--padding-top: 0;--padding-bottom: 0}ion-toolbar ion-buttons[slot=secondary]{order:6}ion-toolbar ion-title .toolbar-title{text-overflow:ellipsis;white-space:nowrap;pointer-events:auto;overflow:hidden}ion-toolbar ion-title .toolbar-title ::ng-deep>*{text-overflow:ellipsis;white-space:nowrap;pointer-events:auto;overflow:hidden}.hide{visibility:hidden;opacity:0;transition:opacity .1s linear}.hide.fade-in{visibility:inherit;opacity:1}ion-title{box-sizing:border-box;font-size:16px;font-weight:400}ion-back-button{--color: var(--kirby-black);--icon-font-size: 24px;height:44px;width:44px}.page-header{margin-left:16px;margin-top:8px;margin-bottom:var(--kirby-page-title-margin-bottom, 40px)}.page-header .page-title.has-actions{display:flex;justify-content:space-between;align-items:flex-start}.page-header .page-title h1,.page-header .page-title h2,.page-header .page-title h3,.page-header .page-title h4,.page-header .page-title h5,.page-header .page-title h6{margin:0}.page-header .page-subtitle{margin-top:8px}.page-header.text-center{text-align:center;margin-left:0}.page-header.text-right{text-align:right}ion-content{--padding-start: var(--page-content-padding-start, 16px);--padding-end: var(--page-content-padding-end, 16px);--background: var(--kirby-background-color)}ion-content .content-inner{max-width:var(--page-content-max-width, 720px);margin:0 auto;padding-bottom:40px}ion-content .fixed-content{width:100%;position:absolute;bottom:0}ion-content .fixed-content .content-inner{position:relative}\n"] }]
@@ -70,7 +70,7 @@ export class RangeComponent {
70
70
  multi: true,
71
71
  useExisting: forwardRef((() => RangeComponent)),
72
72
  },
73
- ], usesOnChanges: true, ngImport: i0, template: "<ion-range\n (ionChange)=\"_onRangeValueChange($event)\"\n [min]=\"min\"\n [max]=\"max\"\n [step]=\"step\"\n [value]=\"value\"\n [pin]=\"pin\"\n [snaps]=\"ticks\"\n [ticks]=\"ticks\"\n [debounce]=\"debounce\"\n [disabled]=\"disabled\"\n>\n</ion-range>\n\n<label *ngIf=\"minLabel\" class=\"min-label\">{{ minLabel }}</label>\n<label *ngIf=\"maxLabel\" class=\"max-label\">{{ maxLabel }}</label>\n", styles: [":host{display:flex;justify-content:space-between;flex-wrap:wrap}ion-range{--knob-background: var(--kirby-white);--knob-box-shadow: 0 5px 10px 0 rgb(28 28 28 / 30%), 0 0 5px 0 rgb(28 28 28 / 8%);--knob-size: 24px;--pin-color: var(--kirby-text-color-black);--pin-background: var(--kirby-semi-light);--bar-background: var(--kirby-medium);--bar-background-active: var(--kirby-dark);--bar-border-radius: 4px;--bar-height: 2px;flex:1 1 100%;padding:0}ion-range.range-disabled{--knob-background: var(--kirby-semi-light);--knob-box-shadow: none;--bar-background: var(--kirby-semi-light);--bar-background-active: var(--kirby-semi-light)}ion-range.range-disabled::part(tick){background:var(--kirby-semi-light)}ion-range.range-has-pin{padding:0 3px}ion-range::part(pin){font-size:12px;color:var(--pin-color);background-color:var(--pin-background);padding:2px 4px;border-radius:4px;min-width:40px;position:relative}ion-range::part(pin):before{content:\"\";position:absolute;top:100%;left:50%;transform:translate(-50%);display:block;border:solid transparent 6px;border-top-color:var(--pin-background)}ion-range::part(tick),ion-range::part(tick-active){border-radius:50%;width:6px;height:6px;z-index:1;margin-inline-start:-3px}ion-range::part(tick){background:var(--kirby-medium)}label{font-size:12px;line-height:16px;color:var(--kirby-text-color-semi-dark);margin-top:-4px}\n"], components: [{ type: i1.IonRange, selector: "ion-range", inputs: ["activeBarStart", "color", "debounce", "disabled", "dualKnobs", "max", "min", "mode", "name", "pin", "pinFormatter", "snaps", "step", "ticks", "value"] }], directives: [{ type: i1.SelectValueAccessor, selector: "ion-range, ion-select, ion-radio-group, ion-segment, ion-datetime" }, { type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
73
+ ], usesOnChanges: true, ngImport: i0, template: "<ion-range\n (ionChange)=\"_onRangeValueChange($event)\"\n [min]=\"min\"\n [max]=\"max\"\n [step]=\"step\"\n [value]=\"value\"\n [pin]=\"pin\"\n [snaps]=\"ticks\"\n [ticks]=\"ticks\"\n [debounce]=\"debounce\"\n [disabled]=\"disabled\"\n>\n</ion-range>\n\n<label *ngIf=\"minLabel\" class=\"min-label\">{{ minLabel }}</label>\n<label *ngIf=\"maxLabel\" class=\"max-label\">{{ maxLabel }}</label>\n", styles: [":host{display:flex;justify-content:space-between;flex-wrap:wrap}ion-range{--knob-background: var(--kirby-white);--knob-box-shadow: 0 5px 10px 0 rgb(28 28 28 / 30%), 0 0 5px 0 rgb(28 28 28 / 8%);--knob-size: 24px;--pin-color: var(--kirby-text-color-black);--pin-background: var(--kirby-semi-light);--bar-background: var(--kirby-medium);--bar-background-active: var(--kirby-dark);--bar-border-radius: 4px;--bar-height: 2px;flex:1 1 100%;padding:0}ion-range.range-disabled{--knob-background: var(--kirby-semi-light);--knob-box-shadow: none;--bar-background: var(--kirby-semi-light);--bar-background-active: var(--kirby-semi-light)}ion-range.range-disabled::part(tick){background:var(--kirby-semi-light)}ion-range.range-has-pin{padding:0 3px}ion-range::part(pin){font-size:12px;color:var(--pin-color);background-color:var(--pin-background);padding:2px 4px;border-radius:4px;min-width:40px;position:relative}ion-range::part(pin):before{content:\"\";position:absolute;top:100%;left:50%;transform:translate(-50%);display:block;border:solid transparent 6px;border-top-color:var(--pin-background)}ion-range::part(tick),ion-range::part(tick-active){border-radius:50%;width:6px;height:6px;z-index:1;margin-inline-start:-3px}ion-range::part(tick){background:var(--kirby-medium)}label{font-size:12px;line-height:16px;color:var(--kirby-text-color-semi-dark);margin-top:-4px}\n"], components: [{ type: i1.IonRange, selector: "ion-range", inputs: ["color", "debounce", "disabled", "dualKnobs", "max", "min", "mode", "name", "pin", "snaps", "step", "ticks", "value"] }], directives: [{ type: i1.SelectValueAccessor, selector: "ion-range, ion-select, ion-radio-group, ion-segment, ion-datetime" }, { type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
74
74
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.9", ngImport: i0, type: RangeComponent, decorators: [{
75
75
  type: Component,
76
76
  args: [{ selector: 'kirby-range', providers: [