@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.
- package/esm2020/lib/components/button/button.component.mjs +2 -2
- package/esm2020/lib/components/card/card-footer/card-footer.component.mjs +2 -2
- package/esm2020/lib/components/dropdown/dropdown.component.mjs +26 -18
- package/esm2020/lib/components/fab-sheet/fab-sheet.component.mjs +3 -3
- package/esm2020/lib/components/form-field/input/input.component.mjs +2 -2
- package/esm2020/lib/components/form-field/textarea/textarea.component.mjs +2 -2
- package/esm2020/lib/components/icon/icon.component.mjs +1 -1
- package/esm2020/lib/components/item/item.component.mjs +1 -1
- package/esm2020/lib/components/list/list-item/list-item.component.mjs +2 -2
- package/esm2020/lib/components/list/list.component.mjs +2 -2
- package/esm2020/lib/components/modal/footer/modal-footer.component.mjs +14 -9
- package/esm2020/lib/components/modal/modal-wrapper/modal-elements-mover.delegate.mjs +62 -0
- package/esm2020/lib/components/modal/modal-wrapper/modal-wrapper.component.mjs +73 -123
- package/esm2020/lib/components/modal/services/action-sheet.helper.mjs +4 -1
- package/esm2020/lib/components/modal/services/modal-animation-builder.service.mjs +62 -50
- package/esm2020/lib/components/modal/services/modal.helper.mjs +12 -11
- package/esm2020/lib/components/modal/services/modal.interfaces.mjs +39 -1
- package/esm2020/lib/components/page/page.component.mjs +31 -21
- package/esm2020/lib/components/range/range.component.mjs +1 -1
- package/esm2020/lib/components/segmented-control/segmented-control.component.mjs +1 -1
- package/esm2020/lib/components/slide-button/slide-button.component.mjs +2 -2
- package/esm2020/lib/components/toggle/toggle.component.mjs +1 -1
- package/fesm2015/kirbydesign-designsystem.mjs +321 -232
- package/fesm2015/kirbydesign-designsystem.mjs.map +1 -1
- package/fesm2020/kirbydesign-designsystem.mjs +314 -232
- package/fesm2020/kirbydesign-designsystem.mjs.map +1 -1
- package/lib/components/avatar/avatar.component.d.ts +1 -1
- package/lib/components/dropdown/dropdown.component.d.ts +6 -5
- package/lib/components/modal/footer/modal-footer.component.d.ts +5 -2
- package/lib/components/modal/modal-wrapper/modal-elements-mover.delegate.d.ts +14 -0
- package/lib/components/modal/modal-wrapper/modal-wrapper.component.d.ts +14 -16
- package/lib/components/modal/services/modal-animation-builder.service.d.ts +14 -3
- package/lib/components/modal/services/modal.interfaces.d.ts +22 -0
- package/lib/components/page/page.component.d.ts +7 -5
- package/package.json +8 -8
- package/scss/base/_link.scss +1 -0
- package/scss/interaction-state/_active.scss +1 -0
- package/scss/interaction-state/_focus.scss +1 -0
- package/scss/interaction-state/_hover.scss +1 -0
- package/scss/interaction-state/_index.scss +1 -0
- package/scss/interaction-state/_interaction-state.utilities.scss +1 -0
- package/scss/interaction-state/_layer.scss +1 -0
- package/scss/opt-out/_index.scss +1 -0
- package/scss/opt-out/_link.scss +1 -0
- package/src/lib/components/icon/README.md +16 -0
- package/README.md +0 -7
|
@@ -20,6 +20,9 @@ export class ActionSheetHelper {
|
|
|
20
20
|
},
|
|
21
21
|
backdropDismiss: true,
|
|
22
22
|
});
|
|
23
|
+
// Remove 'modal-shadow' element as we are no longer able to hide it with CSS in Ionic 6.
|
|
24
|
+
// We need to remove it so it does not obstruct the backdrop-click to dismiss functionality.
|
|
25
|
+
ionModal.shadowRoot.querySelector('.modal-shadow').remove();
|
|
23
26
|
const cancelSubscription = cancel.subscribe(() => ionModal.dismiss());
|
|
24
27
|
const itemSelectSubscription = itemSelect.subscribe((item) => ionModal.dismiss(item));
|
|
25
28
|
const onDidDismiss = ionModal.onDidDismiss();
|
|
@@ -40,4 +43,4 @@ export class ActionSheetHelper {
|
|
|
40
43
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.9", ngImport: i0, type: ActionSheetHelper, decorators: [{
|
|
41
44
|
type: Injectable
|
|
42
45
|
}], ctorParameters: function () { return [{ type: i1.ModalController }]; } });
|
|
43
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
46
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWN0aW9uLXNoZWV0LmhlbHBlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvZGVzaWduc3lzdGVtL3NyYy9saWIvY29tcG9uZW50cy9tb2RhbC9zZXJ2aWNlcy9hY3Rpb24tc2hlZXQuaGVscGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUdqRCxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSx3Q0FBd0MsQ0FBQzs7O0FBTzlFLE1BQU0sT0FBTyxpQkFBaUI7SUFDNUIsWUFBb0Isb0JBQXFDO1FBQXJDLHlCQUFvQixHQUFwQixvQkFBb0IsQ0FBaUI7SUFBRyxDQUFDO0lBRXRELEtBQUssQ0FBQyxlQUFlLENBQUMsTUFBeUI7UUFDcEQsTUFBTSxNQUFNLEdBQUcsSUFBSSxZQUFZLEVBQUUsQ0FBQztRQUNsQyxNQUFNLFVBQVUsR0FBRyxJQUFJLFlBQVksRUFBbUIsQ0FBQztRQUV2RCxNQUFNLFFBQVEsR0FBRyxNQUFNLElBQUksQ0FBQyxvQkFBb0IsQ0FBQyxNQUFNLENBQUM7WUFDdEQsU0FBUyxFQUFFLG9CQUFvQjtZQUMvQixRQUFRLEVBQUUsQ0FBQyxlQUFlLEVBQUUsb0JBQW9CLENBQUM7WUFDakQsY0FBYyxFQUFFO2dCQUNkLEdBQUcsTUFBTTtnQkFDVCxNQUFNLEVBQUUsTUFBTTtnQkFDZCxVQUFVLEVBQUUsVUFBVTthQUN2QjtZQUNELGVBQWUsRUFBRSxJQUFJO1NBQ3RCLENBQUMsQ0FBQztRQUVILHlGQUF5RjtRQUN6Riw0RkFBNEY7UUFDNUYsUUFBUSxDQUFDLFVBQVUsQ0FBQyxhQUFhLENBQUMsZUFBZSxDQUFDLENBQUMsTUFBTSxFQUFFLENBQUM7UUFFNUQsTUFBTSxrQkFBa0IsR0FBaUIsTUFBTSxDQUFDLFNBQVMsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxRQUFRLENBQUMsT0FBTyxFQUFFLENBQUMsQ0FBQztRQUNwRixNQUFNLHNCQUFzQixHQUFpQixVQUFVLENBQUMsU0FBUyxDQUFDLENBQUMsSUFBSSxFQUFFLEVBQUUsQ0FDekUsUUFBUSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FDdkIsQ0FBQztRQUNGLE1BQU0sWUFBWSxHQUFHLFFBQVEsQ0FBQyxZQUFZLEVBQUUsQ0FBQztRQUM3QyxZQUFZLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUU7WUFDdEIsa0JBQWtCLENBQUMsV0FBVyxFQUFFLENBQUM7WUFDakMsc0JBQXNCLENBQUMsV0FBVyxFQUFFLENBQUM7UUFDdkMsQ0FBQyxDQUFDLENBQUM7UUFFSCxNQUFNLFFBQVEsQ0FBQyxPQUFPLEVBQUUsQ0FBQztRQUN6QixPQUFPO1lBQ0wsT0FBTyxFQUFFLFFBQVEsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQztZQUN4QyxhQUFhLEVBQUUsUUFBUSxDQUFDLGFBQWEsRUFBRTtZQUN2QyxZQUFZLEVBQUUsUUFBUSxDQUFDLFlBQVksRUFBRTtTQUN0QyxDQUFDO0lBQ0osQ0FBQzs7aUlBdENVLGlCQUFpQjtxSUFBakIsaUJBQWlCOzJGQUFqQixpQkFBaUI7a0JBRDdCLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBFdmVudEVtaXR0ZXIsIEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE1vZGFsQ29udHJvbGxlciB9IGZyb20gJ0Bpb25pYy9hbmd1bGFyJztcbmltcG9ydCB7IFN1YnNjcmlwdGlvbiB9IGZyb20gJ3J4anMnO1xuXG5pbXBvcnQgeyBBY3Rpb25TaGVldENvbXBvbmVudCB9IGZyb20gJy4uL2FjdGlvbi1zaGVldC9hY3Rpb24tc2hlZXQuY29tcG9uZW50JztcbmltcG9ydCB7IEFjdGlvblNoZWV0Q29uZmlnIH0gZnJvbSAnLi4vYWN0aW9uLXNoZWV0L2NvbmZpZy9hY3Rpb24tc2hlZXQtY29uZmlnJztcbmltcG9ydCB7IEFjdGlvblNoZWV0SXRlbSB9IGZyb20gJy4uL2FjdGlvbi1zaGVldC9jb25maWcvYWN0aW9uLXNoZWV0LWl0ZW0nO1xuXG5pbXBvcnQgeyBPdmVybGF5IH0gZnJvbSAnLi9tb2RhbC5pbnRlcmZhY2VzJztcblxuQEluamVjdGFibGUoKVxuZXhwb3J0IGNsYXNzIEFjdGlvblNoZWV0SGVscGVyIHtcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBpb25pY01vZGFsQ29udHJvbGxlcjogTW9kYWxDb250cm9sbGVyKSB7fVxuXG4gIHB1YmxpYyBhc3luYyBzaG93QWN0aW9uU2hlZXQoY29uZmlnOiBBY3Rpb25TaGVldENvbmZpZyk6IFByb21pc2U8T3ZlcmxheT4ge1xuICAgIGNvbnN0IGNhbmNlbCA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcbiAgICBjb25zdCBpdGVtU2VsZWN0ID0gbmV3IEV2ZW50RW1pdHRlcjxBY3Rpb25TaGVldEl0ZW0+KCk7XG5cbiAgICBjb25zdCBpb25Nb2RhbCA9IGF3YWl0IHRoaXMuaW9uaWNNb2RhbENvbnRyb2xsZXIuY3JlYXRlKHtcbiAgICAgIGNvbXBvbmVudDogQWN0aW9uU2hlZXRDb21wb25lbnQsXG4gICAgICBjc3NDbGFzczogWydraXJieS1vdmVybGF5JywgJ2tpcmJ5LWFjdGlvbi1zaGVldCddLFxuICAgICAgY29tcG9uZW50UHJvcHM6IHtcbiAgICAgICAgLi4uY29uZmlnLFxuICAgICAgICBjYW5jZWw6IGNhbmNlbCxcbiAgICAgICAgaXRlbVNlbGVjdDogaXRlbVNlbGVjdCxcbiAgICAgIH0sXG4gICAgICBiYWNrZHJvcERpc21pc3M6IHRydWUsXG4gICAgfSk7XG5cbiAgICAvLyBSZW1vdmUgJ21vZGFsLXNoYWRvdycgZWxlbWVudCBhcyB3ZSBhcmUgbm8gbG9uZ2VyIGFibGUgdG8gaGlkZSBpdCB3aXRoIENTUyBpbiBJb25pYyA2LlxuICAgIC8vIFdlIG5lZWQgdG8gcmVtb3ZlIGl0IHNvIGl0IGRvZXMgbm90IG9ic3RydWN0IHRoZSBiYWNrZHJvcC1jbGljayB0byBkaXNtaXNzIGZ1bmN0aW9uYWxpdHkuXG4gICAgaW9uTW9kYWwuc2hhZG93Um9vdC5xdWVyeVNlbGVjdG9yKCcubW9kYWwtc2hhZG93JykucmVtb3ZlKCk7XG5cbiAgICBjb25zdCBjYW5jZWxTdWJzY3JpcHRpb246IFN1YnNjcmlwdGlvbiA9IGNhbmNlbC5zdWJzY3JpYmUoKCkgPT4gaW9uTW9kYWwuZGlzbWlzcygpKTtcbiAgICBjb25zdCBpdGVtU2VsZWN0U3Vic2NyaXB0aW9uOiBTdWJzY3JpcHRpb24gPSBpdGVtU2VsZWN0LnN1YnNjcmliZSgoaXRlbSkgPT5cbiAgICAgIGlvbk1vZGFsLmRpc21pc3MoaXRlbSlcbiAgICApO1xuICAgIGNvbnN0IG9uRGlkRGlzbWlzcyA9IGlvbk1vZGFsLm9uRGlkRGlzbWlzcygpO1xuICAgIG9uRGlkRGlzbWlzcy50aGVuKChfKSA9PiB7XG4gICAgICBjYW5jZWxTdWJzY3JpcHRpb24udW5zdWJzY3JpYmUoKTtcbiAgICAgIGl0ZW1TZWxlY3RTdWJzY3JpcHRpb24udW5zdWJzY3JpYmUoKTtcbiAgICB9KTtcblxuICAgIGF3YWl0IGlvbk1vZGFsLnByZXNlbnQoKTtcbiAgICByZXR1cm4ge1xuICAgICAgZGlzbWlzczogaW9uTW9kYWwuZGlzbWlzcy5iaW5kKGlvbk1vZGFsKSxcbiAgICAgIG9uV2lsbERpc21pc3M6IGlvbk1vZGFsLm9uV2lsbERpc21pc3MoKSxcbiAgICAgIG9uRGlkRGlzbWlzczogaW9uTW9kYWwub25EaWREaXNtaXNzKCksXG4gICAgfTtcbiAgfVxufVxuIl19
|
|
@@ -1,13 +1,11 @@
|
|
|
1
1
|
import { Injectable } from '@angular/core';
|
|
2
|
-
import {
|
|
2
|
+
import { createAnimation } 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 "
|
|
7
|
-
import * as i2 from "../../../helpers/platform.service";
|
|
6
|
+
import * as i1 from "../../../helpers/platform.service";
|
|
8
7
|
export class ModalAnimationBuilderService {
|
|
9
|
-
constructor(
|
|
10
|
-
this.animationCtrl = animationCtrl;
|
|
8
|
+
constructor(platform) {
|
|
11
9
|
this.platform = platform;
|
|
12
10
|
this.easingEnter = KirbyAnimation.Easing.modal.enter;
|
|
13
11
|
this.easingLeave = KirbyAnimation.Easing.modal.exit;
|
|
@@ -15,32 +13,51 @@ export class ModalAnimationBuilderService {
|
|
|
15
13
|
this.SwipeToCloseDefaults = {
|
|
16
14
|
MIN_PRESENTING_SCALE: 0.93,
|
|
17
15
|
};
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
return (baseEl, presentingEl) => {
|
|
21
|
-
const backdropAnimation = this.animationCtrl
|
|
22
|
-
.create()
|
|
23
|
-
.addElement(baseEl.querySelector('ion-backdrop'))
|
|
16
|
+
this.createEnterAnimation = () => {
|
|
17
|
+
const backdropAnimation = createAnimation()
|
|
24
18
|
.fromTo('opacity', 0.01, 'var(--backdrop-opacity)')
|
|
25
19
|
.beforeStyles({
|
|
26
20
|
'pointer-events': 'none',
|
|
27
21
|
})
|
|
28
22
|
.afterClearStyles(['pointer-events']);
|
|
29
|
-
const wrapperAnimation =
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
const
|
|
35
|
-
|
|
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')
|
|
36
54
|
.addElement(baseEl)
|
|
37
55
|
.easing(this.easingEnter)
|
|
38
56
|
.duration(this.duration)
|
|
39
57
|
.addAnimation(wrapperAnimation);
|
|
40
58
|
let currentBackdropAnimation;
|
|
41
59
|
if (currentBackdrop) {
|
|
42
|
-
currentBackdropAnimation =
|
|
43
|
-
.create()
|
|
60
|
+
currentBackdropAnimation = createAnimation()
|
|
44
61
|
.addElement(currentBackdrop)
|
|
45
62
|
.fromTo('opacity', 'var(--backdrop-opacity)', 0.01);
|
|
46
63
|
}
|
|
@@ -48,7 +65,8 @@ export class ModalAnimationBuilderService {
|
|
|
48
65
|
const isMobile = !this.platform.isPhabletOrBigger();
|
|
49
66
|
const hasCardModal = presentingEl.tagName === 'ION-MODAL' &&
|
|
50
67
|
presentingEl.presentingElement !== undefined;
|
|
51
|
-
const
|
|
68
|
+
const presentingElRoot = this.getElementRoot(presentingEl);
|
|
69
|
+
const presentingAnimation = createAnimation().beforeStyles({
|
|
52
70
|
transform: 'translateY(0)',
|
|
53
71
|
'transform-origin': 'top center',
|
|
54
72
|
overflow: 'hidden',
|
|
@@ -58,7 +76,7 @@ export class ModalAnimationBuilderService {
|
|
|
58
76
|
/**
|
|
59
77
|
* Fallback for browsers that does not support `max()` (ex: Firefox)
|
|
60
78
|
* No need to worry about statusbar padding since engines like Gecko
|
|
61
|
-
* are not used as the engine for
|
|
79
|
+
* are not used as the engine for standalone Cordova/Capacitor apps
|
|
62
80
|
*/
|
|
63
81
|
const transformOffset = !CSS.supports('width', 'max(0px, 1px)')
|
|
64
82
|
? '30px'
|
|
@@ -105,17 +123,16 @@ export class ModalAnimationBuilderService {
|
|
|
105
123
|
.afterStyles({
|
|
106
124
|
transform: finalTransform,
|
|
107
125
|
})
|
|
108
|
-
.addElement(
|
|
126
|
+
.addElement(presentingElRoot.querySelector('.modal-wrapper'))
|
|
109
127
|
.keyframes([
|
|
110
128
|
{ offset: 0, filter: 'contrast(1)', transform: 'translateY(0) scale(1)' },
|
|
111
129
|
{ offset: 1, filter: 'contrast(0.85)', transform: finalTransform },
|
|
112
130
|
]);
|
|
113
|
-
const shadowAnimation =
|
|
114
|
-
.create()
|
|
131
|
+
const shadowAnimation = createAnimation()
|
|
115
132
|
.afterStyles({
|
|
116
133
|
transform: finalTransform,
|
|
117
134
|
})
|
|
118
|
-
.addElement(
|
|
135
|
+
.addElement(presentingElRoot.querySelector('.modal-shadow'))
|
|
119
136
|
.keyframes([
|
|
120
137
|
{ offset: 0, opacity: '1', transform: 'translateY(0) scale(1)' },
|
|
121
138
|
{ offset: 1, opacity: '0', transform: finalTransform },
|
|
@@ -134,26 +151,22 @@ export class ModalAnimationBuilderService {
|
|
|
134
151
|
};
|
|
135
152
|
}
|
|
136
153
|
leaveAnimation(currentBackdrop) {
|
|
137
|
-
return (baseEl,
|
|
138
|
-
const
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
.
|
|
144
|
-
.
|
|
145
|
-
|
|
146
|
-
.fromTo('transform', 'translateY(0vh)', 'translateY(100vh)');
|
|
147
|
-
const baseAnimation = this.animationCtrl
|
|
148
|
-
.create()
|
|
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')
|
|
149
163
|
.addElement(baseEl)
|
|
150
164
|
.easing(this.easingLeave)
|
|
151
|
-
.duration(
|
|
165
|
+
.duration(duration)
|
|
152
166
|
.addAnimation(wrapperAnimation);
|
|
153
167
|
let currentBackdropAnimation;
|
|
154
168
|
if (currentBackdrop) {
|
|
155
|
-
currentBackdropAnimation =
|
|
156
|
-
.create()
|
|
169
|
+
currentBackdropAnimation = createAnimation()
|
|
157
170
|
.addElement(currentBackdrop)
|
|
158
171
|
.fromTo('opacity', 0.01, 'var(--backdrop-opacity)')
|
|
159
172
|
.afterStyles({ opacity: 'var(--backdrop-opacity)' }); //Ensures backdrop is reset to default opacity after swipe to close
|
|
@@ -162,8 +175,8 @@ export class ModalAnimationBuilderService {
|
|
|
162
175
|
const isMobile = !this.platform.isPhabletOrBigger();
|
|
163
176
|
const hasCardModal = presentingEl.tagName === 'ION-MODAL' &&
|
|
164
177
|
presentingEl.presentingElement !== undefined;
|
|
165
|
-
const
|
|
166
|
-
|
|
178
|
+
const presentingElRoot = this.getElementRoot(presentingEl);
|
|
179
|
+
const presentingAnimation = createAnimation()
|
|
167
180
|
.beforeClearStyles(['transform'])
|
|
168
181
|
.afterClearStyles(['transform'])
|
|
169
182
|
.onFinish((currentStep) => {
|
|
@@ -215,7 +228,7 @@ export class ModalAnimationBuilderService {
|
|
|
215
228
|
: 1;
|
|
216
229
|
const finalTransform = `translateY(-10px) scale(${toPresentingScale})`;
|
|
217
230
|
presentingAnimation
|
|
218
|
-
.addElement(
|
|
231
|
+
.addElement(presentingElRoot.querySelector('.modal-wrapper'))
|
|
219
232
|
.afterStyles({
|
|
220
233
|
transform: 'translate3d(0, 0, 0)',
|
|
221
234
|
})
|
|
@@ -223,9 +236,8 @@ export class ModalAnimationBuilderService {
|
|
|
223
236
|
{ offset: 0, filter: 'contrast(0.85)', transform: finalTransform },
|
|
224
237
|
{ offset: 1, filter: 'contrast(1)', transform: 'translateY(0) scale(1)' },
|
|
225
238
|
]);
|
|
226
|
-
const shadowAnimation =
|
|
227
|
-
.
|
|
228
|
-
.addElement(presentingEl.querySelector('.modal-shadow'))
|
|
239
|
+
const shadowAnimation = createAnimation()
|
|
240
|
+
.addElement(presentingElRoot.querySelector('.modal-shadow'))
|
|
229
241
|
.afterStyles({
|
|
230
242
|
transform: 'translateY(0) scale(1)',
|
|
231
243
|
})
|
|
@@ -247,10 +259,10 @@ export class ModalAnimationBuilderService {
|
|
|
247
259
|
};
|
|
248
260
|
}
|
|
249
261
|
}
|
|
250
|
-
/** @nocollapse */ ModalAnimationBuilderService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.9", ngImport: i0, type: ModalAnimationBuilderService, deps: [{ token: i1.
|
|
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 });
|
|
251
263
|
/** @nocollapse */ ModalAnimationBuilderService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.3.9", ngImport: i0, type: ModalAnimationBuilderService, providedIn: 'root' });
|
|
252
264
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.9", ngImport: i0, type: ModalAnimationBuilderService, decorators: [{
|
|
253
265
|
type: Injectable,
|
|
254
266
|
args: [{ providedIn: 'root' }]
|
|
255
|
-
}], ctorParameters: function () { return [{ type: i1.
|
|
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"]}
|
|
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"]}
|
|
@@ -17,13 +17,6 @@ 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);
|
|
27
20
|
const defaultModalSize = config.flavor === 'modal' ? 'medium' : null;
|
|
28
21
|
const modalSize = config.size || defaultModalSize;
|
|
29
22
|
const allow_scroll_class = 'allow-background-scroll';
|
|
@@ -34,6 +27,14 @@ export class ModalHelper {
|
|
|
34
27
|
if (config.interactWithBackground) {
|
|
35
28
|
this.windowRef.nativeWindow.document.body.classList.add(allow_scroll_class);
|
|
36
29
|
}
|
|
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);
|
|
37
38
|
const ionModal = await this.ionicModalController.create({
|
|
38
39
|
component: config.flavor === 'compact' ? ModalCompactWrapperComponent : ModalWrapperComponent,
|
|
39
40
|
cssClass: [
|
|
@@ -41,7 +42,7 @@ export class ModalHelper {
|
|
|
41
42
|
'kirby-modal',
|
|
42
43
|
config.flavor === 'drawer' ? 'kirby-drawer' : null,
|
|
43
44
|
config.flavor === 'compact' ? 'kirby-modal-compact' : null,
|
|
44
|
-
'kirby-modal-' + modalSize,
|
|
45
|
+
modalSize ? 'kirby-modal-' + modalSize : null,
|
|
45
46
|
config.interactWithBackground ? 'interact-with-background' : null,
|
|
46
47
|
...customCssClasses,
|
|
47
48
|
],
|
|
@@ -51,8 +52,8 @@ export class ModalHelper {
|
|
|
51
52
|
swipeToClose: config.flavor != 'compact',
|
|
52
53
|
presentingElement: modalPresentingElement,
|
|
53
54
|
keyboardClose: false,
|
|
54
|
-
enterAnimation,
|
|
55
|
-
leaveAnimation,
|
|
55
|
+
enterAnimation: enterAnimation,
|
|
56
|
+
leaveAnimation: leaveAnimation,
|
|
56
57
|
});
|
|
57
58
|
if (config.interactWithBackground) {
|
|
58
59
|
ionModal.onDidDismiss().then(() => {
|
|
@@ -106,4 +107,4 @@ ModalHelper.presentingElement = undefined;
|
|
|
106
107
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.9", ngImport: i0, type: ModalHelper, decorators: [{
|
|
107
108
|
type: Injectable
|
|
108
109
|
}], ctorParameters: function () { return [{ type: i1.ModalController }, { type: i2.ModalAnimationBuilderService }, { type: i3.WindowRef }]; } });
|
|
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":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAC3C,OAAO,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC;AAGjD,OAAO,EAAE,SAAS,EAAE,MAAM,2BAA2B,CAAC;AACtD,OAAO,EAAE,4BAA4B,EAAE,MAAM,0DAA0D,CAAC;AAExG,OAAO,EAAE,qBAAqB,EAAE,MAAM,0CAA0C,CAAC;AAEjF,OAAO,EAAE,4BAA4B,EAAE,MAAM,mCAAmC,CAAC;;;;;AAIjF,MAAM,OAAO,WAAW;IAKtB,YACU,oBAAqC,EACrC,qBAAmD,EACnD,SAAoB;QAFpB,yBAAoB,GAApB,oBAAoB,CAAiB;QACrC,0BAAqB,GAArB,qBAAqB,CAA8B;QACnD,cAAS,GAAT,SAAS,CAAW;IAC3B,CAAC;IAEG,KAAK,CAAC,eAAe,CAAC,MAAmB;QAC9C,MAAM,CAAC,MAAM,GAAG,MAAM,CAAC,MAAM,IAAI,OAAO,CAAC;QACzC,MAAM,sBAAsB,GAAG,MAAM,IAAI,CAAC,oBAAoB,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;QAE9E,IAAI,eAAuC,CAAC;QAC5C,MAAM,YAAY,GAAG,MAAM,IAAI,CAAC,oBAAoB,CAAC,MAAM,EAAE,CAAC;QAC9D,IAAI,YAAY,EAAE;YAChB,eAAe,GAAG,YAAY,CAAC,aAAa,CAAyB,cAAc,CAAC,CAAC;SACtF;QAED,MAAM,cAAc,GAAG,IAAI,CAAC,qBAAqB,CAAC,cAAc,CAAC,eAAe,CAAC,CAAC;QAClF,MAAM,cAAc,GAAG,IAAI,CAAC,qBAAqB,CAAC,cAAc,CAAC,eAAe,CAAC,CAAC;QAElF,MAAM,gBAAgB,GAAc,MAAM,CAAC,MAAM,KAAK,OAAO,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC;QAChF,MAAM,SAAS,GAAG,MAAM,CAAC,IAAI,IAAI,gBAAgB,CAAC;QAClD,MAAM,kBAAkB,GAAG,yBAAyB,CAAC;QAErD,IAAI,gBAAgB,GAAG,EAAE,CAAC;QAC1B,IAAI,MAAM,CAAC,QAAQ,EAAE;YACnB,gBAAgB,GAAG,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;SACzF;QAED,IAAI,MAAM,CAAC,sBAAsB,EAAE;YACjC,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,kBAAkB,CAAC,CAAC;SAC7E;QAED,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,oBAAoB,CAAC,MAAM,CAAC;YACtD,SAAS,EAAE,MAAM,CAAC,MAAM,KAAK,SAAS,CAAC,CAAC,CAAC,4BAA4B,CAAC,CAAC,CAAC,qBAAqB;YAC7F,QAAQ,EAAE;gBACR,eAAe;gBACf,aAAa;gBACb,MAAM,CAAC,MAAM,KAAK,QAAQ,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,IAAI;gBAClD,MAAM,CAAC,MAAM,KAAK,SAAS,CAAC,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,IAAI;gBAC1D,cAAc,GAAG,SAAS;gBAC1B,MAAM,CAAC,sBAAsB,CAAC,CAAC,CAAC,0BAA0B,CAAC,CAAC,CAAC,IAAI;gBACjE,GAAG,gBAAgB;aACpB;YACD,eAAe,EAAE,MAAM,CAAC,MAAM,KAAK,SAAS,IAAI,MAAM,CAAC,sBAAsB,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI;YAC5F,YAAY,EAAE,CAAC,MAAM,CAAC,sBAAsB;YAC5C,cAAc,EAAE,EAAE,MAAM,EAAE,MAAM,EAAE;YAClC,YAAY,EAAE,MAAM,CAAC,MAAM,IAAI,SAAS;YACxC,iBAAiB,EAAE,sBAAsB;YACzC,aAAa,EAAE,KAAK;YACpB,cAAc;YACd,cAAc;SACf,CAAC,CAAC;QAEH,IAAI,MAAM,CAAC,sBAAsB,EAAE;YACjC,QAAQ,CAAC,YAAY,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE;gBAChC,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,kBAAkB,CAAC,CAAC;YACjF,CAAC,CAAC,CAAC;SACJ;QAED,MAAM,QAAQ,CAAC,OAAO,EAAE,CAAC;QAEzB,OAAO;YACL,OAAO,EAAE,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC;YACxC,aAAa,EAAE,QAAQ,CAAC,aAAa,EAAE;YACvC,YAAY,EAAE,QAAQ,CAAC,YAAY,EAAE;SACtC,CAAC;IACJ,CAAC;IAEM,yBAAyB,CAAC,OAAoB;QACnD,WAAW,CAAC,iBAAiB,GAAG,OAAO,CAAC;IAC1C,CAAC;IAEO,KAAK,CAAC,oBAAoB,CAAC,MAAoB;QACrD,IAAI,sBAAsB,GAAgB,SAAS,CAAC;QACpD,IAAI,CAAC,MAAM,IAAI,MAAM,KAAK,OAAO,EAAE;YACjC,MAAM,YAAY,GAAG,MAAM,IAAI,CAAC,oBAAoB,CAAC,MAAM,EAAE,CAAC;YAC9D,IAAI,CAAC,YAAY,EAAE;gBACjB,sBAAsB,GAAG,WAAW,CAAC,iBAAiB,CAAC;aACxD;iBAAM,IACL,CAAC,YAAY,CAAC,SAAS,CAAC,QAAQ,CAAC,cAAc,CAAC;gBAChD,CAAC,YAAY,CAAC,SAAS,CAAC,QAAQ,CAAC,qBAAqB,CAAC,EACvD;gBACA,sBAAsB,GAAG,YAAY,CAAC;aACvC;SACF;QACD,OAAO,sBAAsB,CAAC;IAChC,CAAC;IAEM,KAAK,CAAC,WAAW,CACtB,6BAAqC,EACrC,QAAkC;QAElC,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,oBAAoB,CAAC,MAAM,EAAE,CAAC;QACvD,IAAI,CAAC,KAAK,IAAI,CAAC,CAAC,KAAK,CAAC,SAAS,YAAY,qBAAqB,CAAC,EAAE;YACjE,MAAM,IAAI,KAAK,CAAC,6BAA6B,CAAC,CAAC;SAChD;QACD,KAAK,CAAC,SAAS,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC;IACxC,CAAC;IAEM,KAAK,CAAC,cAAc,CACzB,6BAAqC,EACrC,QAAkC;QAElC,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,oBAAoB,CAAC,MAAM,EAAE,CAAC;QACvD,IAAI,CAAC,KAAK,IAAI,CAAC,CAAC,KAAK,CAAC,SAAS,YAAY,qBAAqB,CAAC,EAAE;YACjE,MAAM,IAAI,KAAK,CAAC,6BAA6B,CAAC,CAAC;SAChD;QACD,KAAK,CAAC,SAAS,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;IAC3C,CAAC;;AAhHD,sDAAsD;AACtD,gDAAgD;AACjC,6BAAiB,GAAgB,SAAU,CAAA;2HAH/C,WAAW;+HAAX,WAAW;2FAAX,WAAW;kBADvB,UAAU","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"]}
|
|
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"]}
|
|
@@ -1,3 +1,41 @@
|
|
|
1
|
+
import { Component, ElementRef, Optional } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
1
3
|
export class Modal {
|
|
2
4
|
}
|
|
3
|
-
|
|
5
|
+
export var ModalElementType;
|
|
6
|
+
(function (ModalElementType) {
|
|
7
|
+
ModalElementType[ModalElementType["PAGE_PROGRESS"] = 0] = "PAGE_PROGRESS";
|
|
8
|
+
ModalElementType[ModalElementType["FOOTER"] = 1] = "FOOTER";
|
|
9
|
+
ModalElementType[ModalElementType["TITLE"] = 2] = "TITLE";
|
|
10
|
+
})(ModalElementType || (ModalElementType = {}));
|
|
11
|
+
export class ModalElementsAdvertiser {
|
|
12
|
+
}
|
|
13
|
+
export class ModalElementComponent {
|
|
14
|
+
constructor(modalElementType, elementRef, modalElementsAdvertiser) {
|
|
15
|
+
this.modalElementType = modalElementType;
|
|
16
|
+
this.elementRef = elementRef;
|
|
17
|
+
this.modalElementsAdvertiser = modalElementsAdvertiser;
|
|
18
|
+
}
|
|
19
|
+
get isContainedInModal() {
|
|
20
|
+
return this.modalElementsAdvertiser !== null;
|
|
21
|
+
}
|
|
22
|
+
ngAfterViewInit() {
|
|
23
|
+
if (this.isContainedInModal) {
|
|
24
|
+
this.modalElementsAdvertiser.addModalElement(this.modalElementType, this.elementRef);
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
ngOnDestroy() {
|
|
28
|
+
if (this.isContainedInModal) {
|
|
29
|
+
this.modalElementsAdvertiser.removeModalElement(this.modalElementType, this.elementRef);
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
/** @nocollapse */ ModalElementComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.9", ngImport: i0, type: ModalElementComponent, deps: [{ token: ModalElementType }, { token: i0.ElementRef }, { token: ModalElementsAdvertiser, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
34
|
+
/** @nocollapse */ ModalElementComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.9", type: ModalElementComponent, selector: "ng-component", ngImport: i0, template: '', isInline: true });
|
|
35
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.9", ngImport: i0, type: ModalElementComponent, decorators: [{
|
|
36
|
+
type: Component,
|
|
37
|
+
args: [{ template: '' }]
|
|
38
|
+
}], ctorParameters: function () { return [{ type: ModalElementType }, { type: i0.ElementRef }, { type: ModalElementsAdvertiser, decorators: [{
|
|
39
|
+
type: Optional
|
|
40
|
+
}] }]; } });
|
|
41
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwuaW50ZXJmYWNlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvZGVzaWduc3lzdGVtL3NyYy9saWIvY29tcG9uZW50cy9tb2RhbC9zZXJ2aWNlcy9tb2RhbC5pbnRlcmZhY2VzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBaUIsU0FBUyxFQUFFLFVBQVUsRUFBYSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBcUIxRixNQUFNLE9BQWdCLEtBQUs7Q0FPMUI7QUFDRCxNQUFNLENBQU4sSUFBWSxnQkFJWDtBQUpELFdBQVksZ0JBQWdCO0lBQzFCLHlFQUFhLENBQUE7SUFDYiwyREFBTSxDQUFBO0lBQ04seURBQUssQ0FBQTtBQUNQLENBQUMsRUFKVyxnQkFBZ0IsS0FBaEIsZ0JBQWdCLFFBSTNCO0FBRUQsTUFBTSxPQUFnQix1QkFBdUI7Q0FHNUM7QUFHRCxNQUFNLE9BQWdCLHFCQUFxQjtJQUt6QyxZQUNVLGdCQUFrQyxFQUNsQyxVQUFtQyxFQUN2Qix1QkFBZ0Q7UUFGNUQscUJBQWdCLEdBQWhCLGdCQUFnQixDQUFrQjtRQUNsQyxlQUFVLEdBQVYsVUFBVSxDQUF5QjtRQUN2Qiw0QkFBdUIsR0FBdkIsdUJBQXVCLENBQXlCO0lBQ25FLENBQUM7SUFSSixJQUFZLGtCQUFrQjtRQUM1QixPQUFPLElBQUksQ0FBQyx1QkFBdUIsS0FBSyxJQUFJLENBQUM7SUFDL0MsQ0FBQztJQVFELGVBQWU7UUFDYixJQUFJLElBQUksQ0FBQyxrQkFBa0IsRUFBRTtZQUMzQixJQUFJLENBQUMsdUJBQXVCLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsRUFBRSxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUM7U0FDdEY7SUFDSCxDQUFDO0lBRUQsV0FBVztRQUNULElBQUksSUFBSSxDQUFDLGtCQUFrQixFQUFFO1lBQzNCLElBQUksQ0FBQyx1QkFBdUIsQ0FBQyxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLEVBQUUsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDO1NBQ3pGO0lBQ0gsQ0FBQzs7cUlBckJtQixxQkFBcUIsa0JBTWIsZ0JBQWdCLHVDQUVHLHVCQUF1Qjt5SEFSbEQscUJBQXFCLG9EQURwQixFQUFFOzJGQUNILHFCQUFxQjtrQkFEMUMsU0FBUzttQkFBQyxFQUFFLFFBQVEsRUFBRSxFQUFFLEVBQUU7MERBT0csZ0JBQWdCLHFDQUVHLHVCQUF1QjswQkFBbkUsUUFBUSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFmdGVyVmlld0luaXQsIENvbXBvbmVudCwgRWxlbWVudFJlZiwgT25EZXN0cm95LCBPcHRpb25hbCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQWN0aXZhdGVkUm91dGUgfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xuXG5pbXBvcnQgeyBLaXJieUFuaW1hdGlvbiB9IGZyb20gJy4uLy4uLy4uL2FuaW1hdGlvbi9raXJieS1hbmltYXRpb24nO1xuXG5leHBvcnQgaW50ZXJmYWNlIE92ZXJsYXlFdmVudERldGFpbDxUID0gYW55PiB7XG4gIGRhdGE/OiBUO1xuICByb2xlPzogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIE92ZXJsYXkge1xuICBkaXNtaXNzOiAoZGF0YT86IGFueSkgPT4gUHJvbWlzZTxib29sZWFuPjtcbiAgb25XaWxsRGlzbWlzczogUHJvbWlzZTxPdmVybGF5RXZlbnREZXRhaWw+O1xuICBvbkRpZERpc21pc3M6IFByb21pc2U8T3ZlcmxheUV2ZW50RGV0YWlsPjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBNb2RhbFJvdXRlQWN0aXZhdGlvbiB7XG4gIHJvdXRlOiBBY3RpdmF0ZWRSb3V0ZTtcbiAgaXNOZXdNb2RhbDogYm9vbGVhbjtcbn1cblxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIE1vZGFsIHtcbiAgZGlkUHJlc2VudDogUHJvbWlzZTx2b2lkPjtcbiAgd2lsbENsb3NlOiBQcm9taXNlPHZvaWQ+O1xuICBjbG9zZTogKGRhdGE/OiBhbnkpID0+IFByb21pc2U8dm9pZD47XG4gIHNjcm9sbFRvVG9wOiAoc2Nyb2xsRHVyYXRpb24/OiBLaXJieUFuaW1hdGlvbi5EdXJhdGlvbikgPT4gdm9pZDtcbiAgc2Nyb2xsVG9Cb3R0b206IChzY3JvbGxEdXJhdGlvbj86IEtpcmJ5QW5pbWF0aW9uLkR1cmF0aW9uKSA9PiB2b2lkO1xuICBzY3JvbGxEaXNhYmxlZDogYm9vbGVhbjtcbn1cbmV4cG9ydCBlbnVtIE1vZGFsRWxlbWVudFR5cGUge1xuICBQQUdFX1BST0dSRVNTLFxuICBGT09URVIsXG4gIFRJVExFLFxufVxuXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgTW9kYWxFbGVtZW50c0FkdmVydGlzZXIge1xuICBhZGRNb2RhbEVsZW1lbnQ6ICh0eXBlOiBNb2RhbEVsZW1lbnRUeXBlLCBlbGVtZW50UmVmOiBFbGVtZW50UmVmPEhUTUxFbGVtZW50PikgPT4gdm9pZDtcbiAgcmVtb3ZlTW9kYWxFbGVtZW50OiAodHlwZTogTW9kYWxFbGVtZW50VHlwZSwgZWxlbWVudFJlZjogRWxlbWVudFJlZjxIVE1MRWxlbWVudD4pID0+IHZvaWQ7XG59XG5cbkBDb21wb25lbnQoeyB0ZW1wbGF0ZTogJycgfSlcbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBNb2RhbEVsZW1lbnRDb21wb25lbnQgaW1wbGVtZW50cyBBZnRlclZpZXdJbml0LCBPbkRlc3Ryb3kge1xuICBwcml2YXRlIGdldCBpc0NvbnRhaW5lZEluTW9kYWwoKSB7XG4gICAgcmV0dXJuIHRoaXMubW9kYWxFbGVtZW50c0FkdmVydGlzZXIgIT09IG51bGw7XG4gIH1cblxuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIG1vZGFsRWxlbWVudFR5cGU6IE1vZGFsRWxlbWVudFR5cGUsXG4gICAgcHJpdmF0ZSBlbGVtZW50UmVmOiBFbGVtZW50UmVmPEhUTUxFbGVtZW50PixcbiAgICBAT3B0aW9uYWwoKSBwcml2YXRlIG1vZGFsRWxlbWVudHNBZHZlcnRpc2VyOiBNb2RhbEVsZW1lbnRzQWR2ZXJ0aXNlclxuICApIHt9XG5cbiAgbmdBZnRlclZpZXdJbml0KCkge1xuICAgIGlmICh0aGlzLmlzQ29udGFpbmVkSW5Nb2RhbCkge1xuICAgICAgdGhpcy5tb2RhbEVsZW1lbnRzQWR2ZXJ0aXNlci5hZGRNb2RhbEVsZW1lbnQodGhpcy5tb2RhbEVsZW1lbnRUeXBlLCB0aGlzLmVsZW1lbnRSZWYpO1xuICAgIH1cbiAgfVxuXG4gIG5nT25EZXN0cm95KCkge1xuICAgIGlmICh0aGlzLmlzQ29udGFpbmVkSW5Nb2RhbCkge1xuICAgICAgdGhpcy5tb2RhbEVsZW1lbnRzQWR2ZXJ0aXNlci5yZW1vdmVNb2RhbEVsZW1lbnQodGhpcy5tb2RhbEVsZW1lbnRUeXBlLCB0aGlzLmVsZW1lbnRSZWYpO1xuICAgIH1cbiAgfVxufVxuIl19
|