@evotor-dev/ui-kit 8.7.1 → 8.8.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/evo-modal/classes/EvoConfiguredComponentModalDrawingStrategy.mjs +8 -0
- package/esm2022/lib/components/evo-modal/classes/EvoConfiguredModalDrawingStrategy.mjs +14 -0
- package/esm2022/lib/components/evo-modal/classes/EvoConfiguredTemplateModalDrawingStrategy.mjs +11 -0
- package/esm2022/lib/components/evo-modal/classes/EvoDynamicModalDrawingStrategy.mjs +9 -0
- package/esm2022/lib/components/evo-modal/classes/EvoModalDrawingStrategy.mjs +3 -0
- package/esm2022/lib/components/evo-modal/enums.mjs +8 -0
- package/esm2022/lib/components/evo-modal/evo-modal-buttons/evo-modal-buttons.component.mjs +17 -0
- package/esm2022/lib/components/evo-modal/evo-modal-portal.mjs +29 -0
- package/esm2022/lib/components/evo-modal/evo-modal.component.mjs +128 -103
- package/esm2022/lib/components/evo-modal/evo-modal.provider.mjs +18 -0
- package/esm2022/lib/components/evo-modal/evo-modal.service.mjs +47 -12
- package/esm2022/lib/components/evo-modal/interfaces.mjs +2 -0
- package/esm2022/lib/components/evo-modal/public-api.mjs +7 -1
- package/esm2022/lib/components/evo-modal/tokens.mjs +12 -0
- package/esm2022/lib/components/evo-modal/utils.mjs +21 -0
- package/fesm2022/evotor-dev-ui-kit.mjs +420 -237
- package/fesm2022/evotor-dev-ui-kit.mjs.map +1 -1
- package/lib/components/evo-modal/classes/EvoConfiguredComponentModalDrawingStrategy.d.ts +6 -0
- package/lib/components/evo-modal/classes/EvoConfiguredModalDrawingStrategy.d.ts +6 -0
- package/lib/components/evo-modal/classes/EvoConfiguredTemplateModalDrawingStrategy.d.ts +6 -0
- package/lib/components/evo-modal/classes/EvoDynamicModalDrawingStrategy.d.ts +6 -0
- package/lib/components/evo-modal/classes/EvoModalDrawingStrategy.d.ts +5 -0
- package/lib/components/evo-modal/enums.d.ts +6 -0
- package/lib/components/evo-modal/evo-modal-buttons/evo-modal-buttons.component.d.ts +6 -0
- package/lib/components/evo-modal/evo-modal-portal.d.ts +16 -0
- package/lib/components/evo-modal/evo-modal.component.d.ts +48 -32
- package/lib/components/evo-modal/evo-modal.provider.d.ts +3 -0
- package/lib/components/evo-modal/evo-modal.service.d.ts +13 -12
- package/lib/components/evo-modal/interfaces.d.ts +47 -0
- package/lib/components/evo-modal/public-api.d.ts +6 -0
- package/lib/components/evo-modal/tokens.d.ts +7 -0
- package/lib/components/evo-modal/utils.d.ts +5 -0
- package/package.json +1 -1
package/esm2022/lib/components/evo-modal/classes/EvoConfiguredComponentModalDrawingStrategy.mjs
ADDED
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { EvoConfiguredModalDrawingStrategy } from './EvoConfiguredModalDrawingStrategy';
|
|
2
|
+
export class EvoConfiguredComponentModalDrawingStrategy extends EvoConfiguredModalDrawingStrategy {
|
|
3
|
+
draw(params) {
|
|
4
|
+
super.draw(params);
|
|
5
|
+
this.insertComponent(params, 'content');
|
|
6
|
+
}
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiRXZvQ29uZmlndXJlZENvbXBvbmVudE1vZGFsRHJhd2luZ1N0cmF0ZWd5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZXZvLXVpLWtpdC9zcmMvbGliL2NvbXBvbmVudHMvZXZvLW1vZGFsL2NsYXNzZXMvRXZvQ29uZmlndXJlZENvbXBvbmVudE1vZGFsRHJhd2luZ1N0cmF0ZWd5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxpQ0FBaUMsRUFBQyxNQUFNLHFDQUFxQyxDQUFDO0FBSXRGLE1BQU0sT0FBTywwQ0FBMkMsU0FBUSxpQ0FBaUM7SUFDcEYsSUFBSSxDQUEwQixNQUFrRDtRQUNyRixLQUFLLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQ25CLElBQUksQ0FBQyxlQUFlLENBQUMsTUFBTSxFQUFFLFNBQVMsQ0FBQyxDQUFDO0lBQzVDLENBQUM7Q0FDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7RXZvQ29uZmlndXJlZE1vZGFsRHJhd2luZ1N0cmF0ZWd5fSBmcm9tICcuL0V2b0NvbmZpZ3VyZWRNb2RhbERyYXdpbmdTdHJhdGVneSc7XG5pbXBvcnQge0V2b0NvbmZpZ3VyZWRDb21wb25lbnRNb2RhbFBhcmFtc30gZnJvbSAnLi4vaW50ZXJmYWNlcyc7XG5pbXBvcnQge0V2b01vZGFsQ29tcG9uZW50fSBmcm9tICcuLi9ldm8tbW9kYWwuY29tcG9uZW50JztcblxuZXhwb3J0IGNsYXNzIEV2b0NvbmZpZ3VyZWRDb21wb25lbnRNb2RhbERyYXdpbmdTdHJhdGVneSBleHRlbmRzIEV2b0NvbmZpZ3VyZWRNb2RhbERyYXdpbmdTdHJhdGVneSB7XG4gICAgb3ZlcnJpZGUgZHJhdyh0aGlzOiBFdm9Nb2RhbENvbXBvbmVudCwgcGFyYW1zOiBFdm9Db25maWd1cmVkQ29tcG9uZW50TW9kYWxQYXJhbXM8dW5rbm93bj4pOiB2b2lkIHtcbiAgICAgICAgc3VwZXIuZHJhdyhwYXJhbXMpO1xuICAgICAgICB0aGlzLmluc2VydENvbXBvbmVudChwYXJhbXMsICdjb250ZW50Jyk7XG4gICAgfVxufVxuIl19
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { EvoModalDrawingStrategy } from './EvoModalDrawingStrategy';
|
|
2
|
+
export class EvoConfiguredModalDrawingStrategy extends EvoModalDrawingStrategy {
|
|
3
|
+
draw(params) {
|
|
4
|
+
this.titleText.set(params.titleText);
|
|
5
|
+
this.acceptText.set(params.acceptText);
|
|
6
|
+
this.declineText.set(params.declineText);
|
|
7
|
+
this.acceptButtonColor.update((color) => params.acceptButtonColor || color);
|
|
8
|
+
this.acceptButtonTheme.update((theme) => params.acceptButtonTheme || theme);
|
|
9
|
+
this.declineButtonColor.update((color) => params.acceptButtonColor || color);
|
|
10
|
+
this.declineButtonTheme.update((theme) => params.acceptButtonTheme || theme);
|
|
11
|
+
this.asyncAccept.set(params.asyncAccept);
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiRXZvQ29uZmlndXJlZE1vZGFsRHJhd2luZ1N0cmF0ZWd5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZXZvLXVpLWtpdC9zcmMvbGliL2NvbXBvbmVudHMvZXZvLW1vZGFsL2NsYXNzZXMvRXZvQ29uZmlndXJlZE1vZGFsRHJhd2luZ1N0cmF0ZWd5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyx1QkFBdUIsRUFBQyxNQUFNLDJCQUEyQixDQUFDO0FBSWxFLE1BQU0sT0FBZ0IsaUNBQWtDLFNBQVEsdUJBQXVCO0lBQ25GLElBQUksQ0FBMEIsTUFBZ0M7UUFDMUQsSUFBSSxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsTUFBTSxDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBQ3JDLElBQUksQ0FBQyxVQUFVLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxVQUFVLENBQUMsQ0FBQztRQUN2QyxJQUFJLENBQUMsV0FBVyxDQUFDLEdBQUcsQ0FBQyxNQUFNLENBQUMsV0FBVyxDQUFDLENBQUM7UUFDekMsSUFBSSxDQUFDLGlCQUFpQixDQUFDLE1BQU0sQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsTUFBTSxDQUFDLGlCQUFpQixJQUFJLEtBQUssQ0FBQyxDQUFDO1FBQzVFLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxNQUFNLENBQUMsQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLE1BQU0sQ0FBQyxpQkFBaUIsSUFBSSxLQUFLLENBQUMsQ0FBQztRQUM1RSxJQUFJLENBQUMsa0JBQWtCLENBQUMsTUFBTSxDQUFDLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxNQUFNLENBQUMsaUJBQWlCLElBQUksS0FBSyxDQUFDLENBQUM7UUFDN0UsSUFBSSxDQUFDLGtCQUFrQixDQUFDLE1BQU0sQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsTUFBTSxDQUFDLGlCQUFpQixJQUFJLEtBQUssQ0FBQyxDQUFDO1FBQzdFLElBQUksQ0FBQyxXQUFXLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxXQUFXLENBQUMsQ0FBQztJQUM3QyxDQUFDO0NBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0V2b01vZGFsRHJhd2luZ1N0cmF0ZWd5fSBmcm9tICcuL0V2b01vZGFsRHJhd2luZ1N0cmF0ZWd5JztcbmltcG9ydCB7RXZvQ29uZmlndXJlZE1vZGFsUGFyYW1zfSBmcm9tICcuLi9pbnRlcmZhY2VzJztcbmltcG9ydCB7RXZvTW9kYWxDb21wb25lbnR9IGZyb20gJy4uL2V2by1tb2RhbC5jb21wb25lbnQnO1xuXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgRXZvQ29uZmlndXJlZE1vZGFsRHJhd2luZ1N0cmF0ZWd5IGV4dGVuZHMgRXZvTW9kYWxEcmF3aW5nU3RyYXRlZ3kge1xuICAgIGRyYXcodGhpczogRXZvTW9kYWxDb21wb25lbnQsIHBhcmFtczogRXZvQ29uZmlndXJlZE1vZGFsUGFyYW1zKTogdm9pZCB7XG4gICAgICAgIHRoaXMudGl0bGVUZXh0LnNldChwYXJhbXMudGl0bGVUZXh0KTtcbiAgICAgICAgdGhpcy5hY2NlcHRUZXh0LnNldChwYXJhbXMuYWNjZXB0VGV4dCk7XG4gICAgICAgIHRoaXMuZGVjbGluZVRleHQuc2V0KHBhcmFtcy5kZWNsaW5lVGV4dCk7XG4gICAgICAgIHRoaXMuYWNjZXB0QnV0dG9uQ29sb3IudXBkYXRlKChjb2xvcikgPT4gcGFyYW1zLmFjY2VwdEJ1dHRvbkNvbG9yIHx8IGNvbG9yKTtcbiAgICAgICAgdGhpcy5hY2NlcHRCdXR0b25UaGVtZS51cGRhdGUoKHRoZW1lKSA9PiBwYXJhbXMuYWNjZXB0QnV0dG9uVGhlbWUgfHwgdGhlbWUpO1xuICAgICAgICB0aGlzLmRlY2xpbmVCdXR0b25Db2xvci51cGRhdGUoKGNvbG9yKSA9PiBwYXJhbXMuYWNjZXB0QnV0dG9uQ29sb3IgfHwgY29sb3IpO1xuICAgICAgICB0aGlzLmRlY2xpbmVCdXR0b25UaGVtZS51cGRhdGUoKHRoZW1lKSA9PiBwYXJhbXMuYWNjZXB0QnV0dG9uVGhlbWUgfHwgdGhlbWUpO1xuICAgICAgICB0aGlzLmFzeW5jQWNjZXB0LnNldChwYXJhbXMuYXN5bmNBY2NlcHQpO1xuICAgIH1cbn1cbiJdfQ==
|
package/esm2022/lib/components/evo-modal/classes/EvoConfiguredTemplateModalDrawingStrategy.mjs
ADDED
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { EvoConfiguredModalDrawingStrategy } from './EvoConfiguredModalDrawingStrategy';
|
|
2
|
+
export class EvoConfiguredTemplateModalDrawingStrategy extends EvoConfiguredModalDrawingStrategy {
|
|
3
|
+
draw(params) {
|
|
4
|
+
super.draw(params);
|
|
5
|
+
this.modalContent.set({
|
|
6
|
+
template: params.template,
|
|
7
|
+
context: params.data,
|
|
8
|
+
});
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiRXZvQ29uZmlndXJlZFRlbXBsYXRlTW9kYWxEcmF3aW5nU3RyYXRlZ3kuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9ldm8tdWkta2l0L3NyYy9saWIvY29tcG9uZW50cy9ldm8tbW9kYWwvY2xhc3Nlcy9Fdm9Db25maWd1cmVkVGVtcGxhdGVNb2RhbERyYXdpbmdTdHJhdGVneS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsaUNBQWlDLEVBQUMsTUFBTSxxQ0FBcUMsQ0FBQztBQUl0RixNQUFNLE9BQU8seUNBQTBDLFNBQVEsaUNBQWlDO0lBQ25GLElBQUksQ0FBMEIsTUFBaUQ7UUFDcEYsS0FBSyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUNuQixJQUFJLENBQUMsWUFBWSxDQUFDLEdBQUcsQ0FBQztZQUNsQixRQUFRLEVBQUUsTUFBTSxDQUFDLFFBQVE7WUFDekIsT0FBTyxFQUFFLE1BQU0sQ0FBQyxJQUFJO1NBQ3ZCLENBQUMsQ0FBQztJQUNQLENBQUM7Q0FDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7RXZvQ29uZmlndXJlZE1vZGFsRHJhd2luZ1N0cmF0ZWd5fSBmcm9tICcuL0V2b0NvbmZpZ3VyZWRNb2RhbERyYXdpbmdTdHJhdGVneSc7XG5pbXBvcnQge0V2b0NvbmZpZ3VyZWRUZW1wbGF0ZU1vZGFsUGFyYW1zfSBmcm9tICcuLi9pbnRlcmZhY2VzJztcbmltcG9ydCB7RXZvTW9kYWxDb21wb25lbnR9IGZyb20gJy4uL2V2by1tb2RhbC5jb21wb25lbnQnO1xuXG5leHBvcnQgY2xhc3MgRXZvQ29uZmlndXJlZFRlbXBsYXRlTW9kYWxEcmF3aW5nU3RyYXRlZ3kgZXh0ZW5kcyBFdm9Db25maWd1cmVkTW9kYWxEcmF3aW5nU3RyYXRlZ3kge1xuICAgIG92ZXJyaWRlIGRyYXcodGhpczogRXZvTW9kYWxDb21wb25lbnQsIHBhcmFtczogRXZvQ29uZmlndXJlZFRlbXBsYXRlTW9kYWxQYXJhbXM8dW5rbm93bj4pOiB2b2lkIHtcbiAgICAgICAgc3VwZXIuZHJhdyhwYXJhbXMpO1xuICAgICAgICB0aGlzLm1vZGFsQ29udGVudC5zZXQoe1xuICAgICAgICAgICAgdGVtcGxhdGU6IHBhcmFtcy50ZW1wbGF0ZSxcbiAgICAgICAgICAgIGNvbnRleHQ6IHBhcmFtcy5kYXRhLFxuICAgICAgICB9KTtcbiAgICB9XG59XG4iXX0=
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { EvoModalDrawingStrategy } from './EvoModalDrawingStrategy';
|
|
2
|
+
export class EvoDynamicModalDrawingStrategy extends EvoModalDrawingStrategy {
|
|
3
|
+
draw(params) {
|
|
4
|
+
this.isDynamicContent.set(true);
|
|
5
|
+
this.clearView();
|
|
6
|
+
this.insertComponent(params);
|
|
7
|
+
}
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiRXZvRHluYW1pY01vZGFsRHJhd2luZ1N0cmF0ZWd5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZXZvLXVpLWtpdC9zcmMvbGliL2NvbXBvbmVudHMvZXZvLW1vZGFsL2NsYXNzZXMvRXZvRHluYW1pY01vZGFsRHJhd2luZ1N0cmF0ZWd5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyx1QkFBdUIsRUFBQyxNQUFNLDJCQUEyQixDQUFDO0FBSWxFLE1BQU0sT0FBTyw4QkFBK0IsU0FBUSx1QkFBdUI7SUFDdkUsSUFBSSxDQUEwQixNQUE2QjtRQUN2RCxJQUFJLENBQUMsZ0JBQWdCLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ2hDLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQztRQUNqQixJQUFJLENBQUMsZUFBZSxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQ2pDLENBQUM7Q0FDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7RXZvTW9kYWxEcmF3aW5nU3RyYXRlZ3l9IGZyb20gJy4vRXZvTW9kYWxEcmF3aW5nU3RyYXRlZ3knO1xuaW1wb3J0IHtFdm9EeW5hbWljTW9kYWxQYXJhbXN9IGZyb20gJy4uL2ludGVyZmFjZXMnO1xuaW1wb3J0IHtFdm9Nb2RhbENvbXBvbmVudH0gZnJvbSAnLi4vZXZvLW1vZGFsLmNvbXBvbmVudCc7XG5cbmV4cG9ydCBjbGFzcyBFdm9EeW5hbWljTW9kYWxEcmF3aW5nU3RyYXRlZ3kgZXh0ZW5kcyBFdm9Nb2RhbERyYXdpbmdTdHJhdGVneSB7XG4gICAgZHJhdyh0aGlzOiBFdm9Nb2RhbENvbXBvbmVudCwgcGFyYW1zOiBFdm9EeW5hbWljTW9kYWxQYXJhbXMpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5pc0R5bmFtaWNDb250ZW50LnNldCh0cnVlKTtcbiAgICAgICAgdGhpcy5jbGVhclZpZXcoKTtcbiAgICAgICAgdGhpcy5pbnNlcnRDb21wb25lbnQocGFyYW1zKTtcbiAgICB9XG59XG4iXX0=
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export class EvoModalDrawingStrategy {
|
|
2
|
+
}
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiRXZvTW9kYWxEcmF3aW5nU3RyYXRlZ3kuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9ldm8tdWkta2l0L3NyYy9saWIvY29tcG9uZW50cy9ldm8tbW9kYWwvY2xhc3Nlcy9Fdm9Nb2RhbERyYXdpbmdTdHJhdGVneS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFHQSxNQUFNLE9BQWdCLHVCQUF1QjtDQUU1QyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7RXZvTW9kYWxDb21iaW5lZFBhcmFtc30gZnJvbSAnLi4vaW50ZXJmYWNlcyc7XG5pbXBvcnQge0V2b01vZGFsQ29tcG9uZW50fSBmcm9tICcuLi9ldm8tbW9kYWwuY29tcG9uZW50JztcblxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEV2b01vZGFsRHJhd2luZ1N0cmF0ZWd5IHtcbiAgICBhYnN0cmFjdCBkcmF3KHRoaXM6IEV2b01vZGFsQ29tcG9uZW50LCBwYXJhbXM6IEV2b01vZGFsQ29tYmluZWRQYXJhbXMpOiB2b2lkO1xufVxuIl19
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export var EvoModalCloseTargets;
|
|
2
|
+
(function (EvoModalCloseTargets) {
|
|
3
|
+
EvoModalCloseTargets["BACKGROUND"] = "background";
|
|
4
|
+
EvoModalCloseTargets["BUTTON"] = "button";
|
|
5
|
+
EvoModalCloseTargets["DEFAULT"] = "default";
|
|
6
|
+
EvoModalCloseTargets["ESC"] = "escape";
|
|
7
|
+
})(EvoModalCloseTargets || (EvoModalCloseTargets = {}));
|
|
8
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW51bXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9ldm8tdWkta2l0L3NyYy9saWIvY29tcG9uZW50cy9ldm8tbW9kYWwvZW51bXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFOLElBQVksb0JBS1g7QUFMRCxXQUFZLG9CQUFvQjtJQUM1QixpREFBeUIsQ0FBQTtJQUN6Qix5Q0FBaUIsQ0FBQTtJQUNqQiwyQ0FBbUIsQ0FBQTtJQUNuQixzQ0FBYyxDQUFBO0FBQ2xCLENBQUMsRUFMVyxvQkFBb0IsS0FBcEIsb0JBQW9CLFFBSy9CIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGVudW0gRXZvTW9kYWxDbG9zZVRhcmdldHMge1xuICAgIEJBQ0tHUk9VTkQgPSAnYmFja2dyb3VuZCcsXG4gICAgQlVUVE9OID0gJ2J1dHRvbicsXG4gICAgREVGQVVMVCA9ICdkZWZhdWx0JyxcbiAgICBFU0MgPSAnZXNjYXBlJyxcbn1cbiJdfQ==
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { Component, input, ViewEncapsulation } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class EvoModalButtonsComponent {
|
|
4
|
+
constructor() {
|
|
5
|
+
this.single = input(false);
|
|
6
|
+
}
|
|
7
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: EvoModalButtonsComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
8
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "17.3.10", type: EvoModalButtonsComponent, isStandalone: true, selector: "evo-modal-buttons, [evo-modal-buttons]", inputs: { single: { classPropertyName: "single", publicName: "single", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "class.evo-modal-buttons_single-btn": "single()" }, classAttribute: "evo-modal-buttons" }, ngImport: i0, template: '<ng-content select="[evoButton]"/>', isInline: true, styles: [".evo-modal-buttons{display:flex;flex-shrink:0;flex-direction:column-reverse;justify-content:center;align-items:center;width:100%;margin-top:32px;gap:16px}@media (min-width: 768px){.evo-modal-buttons{display:grid;width:auto;grid-template-columns:repeat(2,minmax(140px,1fr));gap:32px;margin:32px auto 0}.evo-modal-buttons_single-btn{grid-template-columns:minmax(140px,1fr)}}.evo-modal-buttons button{display:block;width:100%}@media (min-width: 768px){.evo-modal-buttons button{width:auto}}\n"], encapsulation: i0.ViewEncapsulation.None }); }
|
|
9
|
+
}
|
|
10
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: EvoModalButtonsComponent, decorators: [{
|
|
11
|
+
type: Component,
|
|
12
|
+
args: [{ selector: 'evo-modal-buttons, [evo-modal-buttons]', standalone: true, imports: [], template: '<ng-content select="[evoButton]"/>', host: {
|
|
13
|
+
class: 'evo-modal-buttons',
|
|
14
|
+
'[class.evo-modal-buttons_single-btn]': 'single()',
|
|
15
|
+
}, encapsulation: ViewEncapsulation.None, styles: [".evo-modal-buttons{display:flex;flex-shrink:0;flex-direction:column-reverse;justify-content:center;align-items:center;width:100%;margin-top:32px;gap:16px}@media (min-width: 768px){.evo-modal-buttons{display:grid;width:auto;grid-template-columns:repeat(2,minmax(140px,1fr));gap:32px;margin:32px auto 0}.evo-modal-buttons_single-btn{grid-template-columns:minmax(140px,1fr)}}.evo-modal-buttons button{display:block;width:100%}@media (min-width: 768px){.evo-modal-buttons button{width:auto}}\n"] }]
|
|
16
|
+
}] });
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZvLW1vZGFsLWJ1dHRvbnMuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZXZvLXVpLWtpdC9zcmMvbGliL2NvbXBvbmVudHMvZXZvLW1vZGFsL2V2by1tb2RhbC1idXR0b25zL2V2by1tb2RhbC1idXR0b25zLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLEtBQUssRUFBRSxpQkFBaUIsRUFBQyxNQUFNLGVBQWUsQ0FBQzs7QUFlbEUsTUFBTSxPQUFPLHdCQUF3QjtJQWJyQztRQWVJLFdBQU0sR0FBRyxLQUFLLENBQVUsS0FBSyxDQUFDLENBQUM7S0FDbEM7K0dBSFksd0JBQXdCO21HQUF4Qix3QkFBd0IsMFZBVHZCLG9DQUFvQzs7NEZBU3JDLHdCQUF3QjtrQkFicEMsU0FBUzsrQkFDSSx3Q0FBd0MsY0FDdEMsSUFBSSxXQUNQLEVBQUUsWUFDRCxvQ0FBb0MsUUFHeEM7d0JBQ0YsS0FBSyxFQUFFLG1CQUFtQjt3QkFDMUIsc0NBQXNDLEVBQUUsVUFBVTtxQkFDckQsaUJBQ2MsaUJBQWlCLENBQUMsSUFBSSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50LCBpbnB1dCwgVmlld0VuY2Fwc3VsYXRpb259IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2V2by1tb2RhbC1idXR0b25zLCBbZXZvLW1vZGFsLWJ1dHRvbnNdJyxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIGltcG9ydHM6IFtdLFxuICAgIHRlbXBsYXRlOiAnPG5nLWNvbnRlbnQgc2VsZWN0PVwiW2V2b0J1dHRvbl1cIi8+JyxcbiAgICBzdHlsZVVybDogJy4vZXZvLW1vZGFsLWJ1dHRvbnMuY29tcG9uZW50LnNjc3MnLFxuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAYW5ndWxhci1lc2xpbnQvbm8taG9zdC1tZXRhZGF0YS1wcm9wZXJ0eVxuICAgIGhvc3Q6IHtcbiAgICAgICAgY2xhc3M6ICdldm8tbW9kYWwtYnV0dG9ucycsXG4gICAgICAgICdbY2xhc3MuZXZvLW1vZGFsLWJ1dHRvbnNfc2luZ2xlLWJ0bl0nOiAnc2luZ2xlKCknLFxuICAgIH0sXG4gICAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbn0pXG5leHBvcnQgY2xhc3MgRXZvTW9kYWxCdXR0b25zQ29tcG9uZW50IHtcblxuICAgIHNpbmdsZSA9IGlucHV0PGJvb2xlYW4+KGZhbHNlKTtcbn1cbiJdfQ==
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { EvoPortalService } from '../evo-portal';
|
|
3
|
+
import { EvoModalComponent } from './evo-modal.component';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export class EvoModalPortal extends EvoPortalService {
|
|
6
|
+
constructor(appRef, injector, cfr) {
|
|
7
|
+
super(appRef, injector, cfr);
|
|
8
|
+
this.appRef = appRef;
|
|
9
|
+
this.injector = injector;
|
|
10
|
+
this.cfr = cfr;
|
|
11
|
+
}
|
|
12
|
+
attach(host) {
|
|
13
|
+
this.attachedPortal = this.attachComponent(EvoModalComponent, host, this.injector);
|
|
14
|
+
this.attachedPortal.changeDetectorRef.detectChanges();
|
|
15
|
+
}
|
|
16
|
+
detach() {
|
|
17
|
+
super.detach(this.attachedPortal);
|
|
18
|
+
this.attachedPortal = null;
|
|
19
|
+
}
|
|
20
|
+
hasAttachedPortal() {
|
|
21
|
+
return !!this.attachedPortal;
|
|
22
|
+
}
|
|
23
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: EvoModalPortal, deps: [{ token: i0.ApplicationRef }, { token: i0.Injector }, { token: i0.ComponentFactoryResolver }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
24
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: EvoModalPortal }); }
|
|
25
|
+
}
|
|
26
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: EvoModalPortal, decorators: [{
|
|
27
|
+
type: Injectable
|
|
28
|
+
}], ctorParameters: () => [{ type: i0.ApplicationRef }, { type: i0.Injector }, { type: i0.ComponentFactoryResolver }] });
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZvLW1vZGFsLXBvcnRhbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2V2by11aS1raXQvc3JjL2xpYi9jb21wb25lbnRzL2V2by1tb2RhbC9ldm8tbW9kYWwtcG9ydGFsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBeUQsVUFBVSxFQUFXLE1BQU0sZUFBZSxDQUFDO0FBQzNHLE9BQU8sRUFBb0IsZ0JBQWdCLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDbEUsT0FBTyxFQUFDLGlCQUFpQixFQUFDLE1BQU0sdUJBQXVCLENBQUM7O0FBR3hELE1BQU0sT0FBTyxjQUFlLFNBQVEsZ0JBQWdCO0lBSWhELFlBQ1csTUFBc0IsRUFDdEIsUUFBa0IsRUFDbEIsR0FBNkI7UUFFcEMsS0FBSyxDQUFDLE1BQU0sRUFBRSxRQUFRLEVBQUUsR0FBRyxDQUFDLENBQUM7UUFKdEIsV0FBTSxHQUFOLE1BQU0sQ0FBZ0I7UUFDdEIsYUFBUSxHQUFSLFFBQVEsQ0FBVTtRQUNsQixRQUFHLEdBQUgsR0FBRyxDQUEwQjtJQUd4QyxDQUFDO0lBRUQsTUFBTSxDQUFDLElBQVk7UUFDZixJQUFJLENBQUMsY0FBYyxHQUFHLElBQUksQ0FBQyxlQUFlLENBQUMsaUJBQWlCLEVBQUUsSUFBSSxFQUFFLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUNuRixJQUFJLENBQUMsY0FBYyxDQUFDLGlCQUFpQixDQUFDLGFBQWEsRUFBRSxDQUFDO0lBQzFELENBQUM7SUFFRCxNQUFNO1FBQ0YsS0FBSyxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsY0FBYyxDQUFDLENBQUM7UUFDbEMsSUFBSSxDQUFDLGNBQWMsR0FBRyxJQUFJLENBQUM7SUFDL0IsQ0FBQztJQUVELGlCQUFpQjtRQUNiLE9BQU8sQ0FBQyxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUM7SUFDakMsQ0FBQzsrR0F4QlEsY0FBYzttSEFBZCxjQUFjOzs0RkFBZCxjQUFjO2tCQUQxQixVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtBcHBsaWNhdGlvblJlZiwgQ29tcG9uZW50RmFjdG9yeVJlc29sdmVyLCBDb21wb25lbnRSZWYsIEluamVjdGFibGUsIEluamVjdG9yfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7RXZvQWJzdHJhY3RQb3J0YWwsIEV2b1BvcnRhbFNlcnZpY2V9IGZyb20gJy4uL2V2by1wb3J0YWwnO1xuaW1wb3J0IHtFdm9Nb2RhbENvbXBvbmVudH0gZnJvbSAnLi9ldm8tbW9kYWwuY29tcG9uZW50JztcblxuQEluamVjdGFibGUoKVxuZXhwb3J0IGNsYXNzIEV2b01vZGFsUG9ydGFsIGV4dGVuZHMgRXZvUG9ydGFsU2VydmljZSBpbXBsZW1lbnRzIEV2b0Fic3RyYWN0UG9ydGFsIHtcblxuICAgIGF0dGFjaGVkUG9ydGFsOiBDb21wb25lbnRSZWY8RXZvTW9kYWxDb21wb25lbnQ+O1xuXG4gICAgY29uc3RydWN0b3IoXG4gICAgICAgIHB1YmxpYyBhcHBSZWY6IEFwcGxpY2F0aW9uUmVmLFxuICAgICAgICBwdWJsaWMgaW5qZWN0b3I6IEluamVjdG9yLFxuICAgICAgICBwdWJsaWMgY2ZyOiBDb21wb25lbnRGYWN0b3J5UmVzb2x2ZXIsXG4gICAgKSB7XG4gICAgICAgIHN1cGVyKGFwcFJlZiwgaW5qZWN0b3IsIGNmcik7XG4gICAgfVxuXG4gICAgYXR0YWNoKGhvc3Q6IHN0cmluZykge1xuICAgICAgICB0aGlzLmF0dGFjaGVkUG9ydGFsID0gdGhpcy5hdHRhY2hDb21wb25lbnQoRXZvTW9kYWxDb21wb25lbnQsIGhvc3QsIHRoaXMuaW5qZWN0b3IpO1xuICAgICAgICB0aGlzLmF0dGFjaGVkUG9ydGFsLmNoYW5nZURldGVjdG9yUmVmLmRldGVjdENoYW5nZXMoKTtcbiAgICB9XG5cbiAgICBkZXRhY2goKSB7XG4gICAgICAgIHN1cGVyLmRldGFjaCh0aGlzLmF0dGFjaGVkUG9ydGFsKTtcbiAgICAgICAgdGhpcy5hdHRhY2hlZFBvcnRhbCA9IG51bGw7XG4gICAgfVxuXG4gICAgaGFzQXR0YWNoZWRQb3J0YWwoKSB7XG4gICAgICAgIHJldHVybiAhIXRoaXMuYXR0YWNoZWRQb3J0YWw7XG4gICAgfVxufVxuIl19
|
|
@@ -1,127 +1,152 @@
|
|
|
1
|
-
import { Component,
|
|
2
|
-
import { fromEvent } from 'rxjs';
|
|
1
|
+
import { ChangeDetectionStrategy, Component, computed, createComponent, DestroyRef, ElementRef, EnvironmentInjector, inject, Injector, model, signal, viewChild, ViewContainerRef } from '@angular/core';
|
|
2
|
+
import { filter, finalize, fromEvent } from 'rxjs';
|
|
3
3
|
import { takeWhile } from 'rxjs/operators';
|
|
4
|
-
import {
|
|
5
|
-
import {
|
|
6
|
-
import {
|
|
4
|
+
import { EvoButtonComponent } from '../evo-button';
|
|
5
|
+
import { EvoUiClassDirective } from "../../directives";
|
|
6
|
+
import { takeUntilDestroyed, toObservable } from '@angular/core/rxjs-interop';
|
|
7
|
+
import { EVO_MODAL_DATA, EVO_MODAL_ROOT_ID } from './tokens';
|
|
8
|
+
import { NgIf, NgTemplateOutlet } from '@angular/common';
|
|
9
|
+
import { EvoModalService } from './evo-modal.service';
|
|
10
|
+
import { isConfiguredComponentModalParams, isConfiguredTemplateModalParams, isDynamicModalParams } from './utils';
|
|
11
|
+
import { EvoModalCloseTargets } from './enums';
|
|
12
|
+
import { EvoDynamicModalDrawingStrategy } from './classes/EvoDynamicModalDrawingStrategy';
|
|
13
|
+
import { EvoConfiguredComponentModalDrawingStrategy } from './classes/EvoConfiguredComponentModalDrawingStrategy';
|
|
14
|
+
import { EvoConfiguredTemplateModalDrawingStrategy } from './classes/EvoConfiguredTemplateModalDrawingStrategy';
|
|
15
|
+
import { EvoModalButtonsComponent } from './evo-modal-buttons/evo-modal-buttons.component';
|
|
7
16
|
import * as i0 from "@angular/core";
|
|
8
|
-
import * as i1 from "./evo-modal.service";
|
|
9
|
-
export var EvoModalCloseTargets;
|
|
10
|
-
(function (EvoModalCloseTargets) {
|
|
11
|
-
EvoModalCloseTargets["BACKGROUND"] = "background";
|
|
12
|
-
EvoModalCloseTargets["BUTTON"] = "button";
|
|
13
|
-
EvoModalCloseTargets["DEFAULT"] = "default";
|
|
14
|
-
EvoModalCloseTargets["ESC"] = "escape";
|
|
15
|
-
})(EvoModalCloseTargets || (EvoModalCloseTargets = {}));
|
|
16
17
|
export class EvoModalComponent {
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
this.
|
|
31
|
-
this.
|
|
32
|
-
this.
|
|
33
|
-
this.
|
|
34
|
-
this.
|
|
35
|
-
this.
|
|
36
|
-
this.
|
|
18
|
+
constructor() {
|
|
19
|
+
// eslint-disable-next-line @typescript-eslint/member-ordering
|
|
20
|
+
this.evoModalRootId = inject(EVO_MODAL_ROOT_ID);
|
|
21
|
+
this.acceptText = model('');
|
|
22
|
+
this.acceptButtonColor = model(`success`);
|
|
23
|
+
this.acceptButtonTheme = model(`rounded-solid`);
|
|
24
|
+
this.asyncAccept = model(null);
|
|
25
|
+
this.declineText = model('');
|
|
26
|
+
this.declineButtonColor = model('secondary');
|
|
27
|
+
this.declineButtonTheme = model('rounded-outline');
|
|
28
|
+
this.id = model(this.evoModalRootId);
|
|
29
|
+
this.titleText = model('');
|
|
30
|
+
this.contentContainer = viewChild('contentContainer', { read: ViewContainerRef });
|
|
31
|
+
this.contentContainer$ = toObservable(this.contentContainer);
|
|
32
|
+
this.drawingStrategy = signal(null);
|
|
33
|
+
this.isDynamicContent = signal(false);
|
|
34
|
+
this.isLoading = signal(false);
|
|
35
|
+
this.isVisible = computed(() => this.modalState()?.isOpen || false);
|
|
36
|
+
this.modalContainer = viewChild('modalContainer', { read: ViewContainerRef });
|
|
37
|
+
this.modalContainer$ = toObservable(this.modalContainer);
|
|
38
|
+
this.modalContent = signal(null);
|
|
39
|
+
this.modalElement = viewChild('modal', { read: ElementRef });
|
|
40
|
+
this.modalState = signal(null);
|
|
41
|
+
this.showButtons = computed(() => this.acceptText() || this.declineText());
|
|
37
42
|
this.closeTargets = EvoModalCloseTargets;
|
|
38
|
-
this.
|
|
43
|
+
this.destroyRef = inject(DestroyRef);
|
|
44
|
+
this.environmentInjector = inject(EnvironmentInjector);
|
|
45
|
+
this.evoModalService = inject(EvoModalService);
|
|
39
46
|
}
|
|
40
47
|
ngOnInit() {
|
|
48
|
+
this.evoModalService.register(this.id());
|
|
41
49
|
this.subscribeModalEvents();
|
|
42
50
|
}
|
|
43
51
|
ngOnDestroy() {
|
|
44
|
-
this.
|
|
52
|
+
this.evoModalService.unregister(this.id());
|
|
45
53
|
}
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
!this.elRef.nativeElement.querySelector('.evo-modal').contains($event.target) &&
|
|
51
|
-
this.modalState.isOpen) {
|
|
52
|
-
this.handleOnClose(false, this.closeTargets.BACKGROUND);
|
|
54
|
+
onAcceptClick() {
|
|
55
|
+
const asyncAcceptAction = this.asyncAccept()?.();
|
|
56
|
+
if (!asyncAcceptAction) {
|
|
57
|
+
return this.close(true, EvoModalCloseTargets.BUTTON);
|
|
53
58
|
}
|
|
59
|
+
this.isLoading.set(true);
|
|
60
|
+
asyncAcceptAction.pipe(finalize(() => this.isLoading.set(false)), takeUntilDestroyed(this.destroyRef)).subscribe(() => this.close(true, EvoModalCloseTargets.BUTTON));
|
|
54
61
|
}
|
|
55
|
-
|
|
56
|
-
this.
|
|
57
|
-
|
|
58
|
-
return;
|
|
62
|
+
onBackgroundClick(event) {
|
|
63
|
+
if (this.canCloseByBackground(event)) {
|
|
64
|
+
this.close(false, EvoModalCloseTargets.BACKGROUND);
|
|
59
65
|
}
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
};
|
|
65
|
-
setAsyncStates(true);
|
|
66
|
-
return this.asyncAccept().subscribe(() => {
|
|
67
|
-
setAsyncStates(false);
|
|
68
|
-
this.modalService.close(this.id, agreement, {
|
|
69
|
-
closeTarget: this.closeTarget,
|
|
70
|
-
});
|
|
71
|
-
}, () => {
|
|
72
|
-
setAsyncStates(false);
|
|
73
|
-
});
|
|
66
|
+
}
|
|
67
|
+
onDeclineClick() {
|
|
68
|
+
if (this.isLoading()) {
|
|
69
|
+
return;
|
|
74
70
|
}
|
|
75
|
-
this.
|
|
76
|
-
closeTarget: this.closeTarget,
|
|
77
|
-
});
|
|
71
|
+
this.close(false, EvoModalCloseTargets.BUTTON);
|
|
78
72
|
}
|
|
79
|
-
|
|
80
|
-
this.
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
73
|
+
clearView() {
|
|
74
|
+
this.modalContainer()?.clear();
|
|
75
|
+
}
|
|
76
|
+
insertComponent({ data, injector, component }, target = 'modal') {
|
|
77
|
+
const dynamicComponentRef = createComponent(component, {
|
|
78
|
+
environmentInjector: this.environmentInjector,
|
|
79
|
+
elementInjector: Injector.create({
|
|
80
|
+
providers: [
|
|
81
|
+
{
|
|
82
|
+
provide: EVO_MODAL_DATA,
|
|
83
|
+
useValue: data,
|
|
84
|
+
},
|
|
85
|
+
],
|
|
86
|
+
parent: injector,
|
|
87
|
+
}),
|
|
89
88
|
});
|
|
89
|
+
this.getInsertionContainer(target).pipe(filter((container) => !!container), takeUntilDestroyed(this.destroyRef)).subscribe((container) => {
|
|
90
|
+
container.insert(dynamicComponentRef.hostView);
|
|
91
|
+
dynamicComponentRef.changeDetectorRef.markForCheck();
|
|
92
|
+
});
|
|
93
|
+
}
|
|
94
|
+
canCloseByBackground(event) {
|
|
95
|
+
return (this.declineText() || this.isDynamicContent()) &&
|
|
96
|
+
!this.isLoading() &&
|
|
97
|
+
this.modalState().isOpen &&
|
|
98
|
+
event?.target &&
|
|
99
|
+
!this.modalElement().nativeElement.contains(event.target);
|
|
100
|
+
}
|
|
101
|
+
close(agreement, closeTarget) {
|
|
102
|
+
this.evoModalService.close(this.id(), agreement, { closeTarget });
|
|
103
|
+
this.clearView();
|
|
104
|
+
if (this.id() !== this.evoModalRootId) {
|
|
105
|
+
return;
|
|
106
|
+
}
|
|
107
|
+
this.evoModalService.unregister(this.evoModalRootId);
|
|
108
|
+
this.evoModalService.cleanupDefaultHost();
|
|
109
|
+
}
|
|
110
|
+
getInsertionContainer(target) {
|
|
111
|
+
return target === 'modal' ? this.modalContainer$ : this.contentContainer$;
|
|
90
112
|
}
|
|
91
113
|
initKeyboardListener() {
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
114
|
+
fromEvent(document.body, 'keydown').pipe(takeWhile(() => this.modalState().isOpen), filter((event) => (this.declineText() || this.isDynamicContent()) && event.key === 'Escape'), takeUntilDestroyed(this.destroyRef)).subscribe(() => this.close(false, this.closeTargets.ESC));
|
|
115
|
+
}
|
|
116
|
+
setDrawingStrategy(params) {
|
|
117
|
+
switch (true) {
|
|
118
|
+
case isDynamicModalParams(params):
|
|
119
|
+
return this.drawingStrategy.set(new EvoDynamicModalDrawingStrategy());
|
|
120
|
+
case isConfiguredComponentModalParams(params):
|
|
121
|
+
return this.drawingStrategy.set(new EvoConfiguredComponentModalDrawingStrategy());
|
|
122
|
+
case isConfiguredTemplateModalParams(params):
|
|
123
|
+
return this.drawingStrategy.set(new EvoConfiguredTemplateModalDrawingStrategy());
|
|
124
|
+
default:
|
|
125
|
+
return;
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
subscribeModalEvents() {
|
|
129
|
+
this.evoModalService.getEventsSubscription(this.id()).pipe(takeUntilDestroyed(this.destroyRef)).subscribe((modalState) => {
|
|
130
|
+
this.modalState.set(modalState);
|
|
131
|
+
if (!modalState.isOpen) {
|
|
132
|
+
return;
|
|
99
133
|
}
|
|
134
|
+
this.initKeyboardListener();
|
|
135
|
+
this.setDrawingStrategy(modalState.params);
|
|
136
|
+
this.drawingStrategy()?.draw.call(this, modalState.params);
|
|
100
137
|
});
|
|
101
138
|
}
|
|
102
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: EvoModalComponent, deps: [
|
|
103
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.10", type: EvoModalComponent, isStandalone: true, selector: "evo-modal", inputs: {
|
|
139
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: EvoModalComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
140
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.10", type: EvoModalComponent, isStandalone: true, selector: "evo-modal", inputs: { acceptText: { classPropertyName: "acceptText", publicName: "acceptText", isSignal: true, isRequired: false, transformFunction: null }, acceptButtonColor: { classPropertyName: "acceptButtonColor", publicName: "acceptButtonColor", isSignal: true, isRequired: false, transformFunction: null }, acceptButtonTheme: { classPropertyName: "acceptButtonTheme", publicName: "acceptButtonTheme", isSignal: true, isRequired: false, transformFunction: null }, asyncAccept: { classPropertyName: "asyncAccept", publicName: "asyncAccept", isSignal: true, isRequired: false, transformFunction: null }, declineText: { classPropertyName: "declineText", publicName: "declineText", isSignal: true, isRequired: false, transformFunction: null }, declineButtonColor: { classPropertyName: "declineButtonColor", publicName: "declineButtonColor", isSignal: true, isRequired: false, transformFunction: null }, declineButtonTheme: { classPropertyName: "declineButtonTheme", publicName: "declineButtonTheme", isSignal: true, isRequired: false, transformFunction: null }, id: { classPropertyName: "id", publicName: "id", isSignal: true, isRequired: false, transformFunction: null }, titleText: { classPropertyName: "titleText", publicName: "titleText", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { acceptText: "acceptTextChange", acceptButtonColor: "acceptButtonColorChange", acceptButtonTheme: "acceptButtonThemeChange", asyncAccept: "asyncAcceptChange", declineText: "declineTextChange", declineButtonColor: "declineButtonColorChange", declineButtonTheme: "declineButtonThemeChange", id: "idChange", titleText: "titleTextChange" }, viewQueries: [{ propertyName: "contentContainer", first: true, predicate: ["contentContainer"], descendants: true, read: ViewContainerRef, isSignal: true }, { propertyName: "modalContainer", first: true, predicate: ["modalContainer"], descendants: true, read: ViewContainerRef, isSignal: true }, { propertyName: "modalElement", first: true, predicate: ["modal"], descendants: true, read: ElementRef, isSignal: true }], ngImport: i0, template: "@if (isVisible()) {\n <div class=\"evo-modal__background\" (click)=\"onBackgroundClick($event)\"></div>\n\n <div class=\"evo-modal__wrapper\" (click)=\"onBackgroundClick($event)\">\n <div class=\"evo-modal\" #modal>\n @if (isDynamicContent()) {\n <ng-template #modalContainer/>\n } @else {\n <div class=\"evo-modal__icon\">\n <ng-content select=\"evo-icon\"/>\n </div>\n\n @if (titleText()) {\n <h2 class=\"evo-modal__title\">{{ titleText() }}</h2>\n }\n\n <div class=\"evo-modal__content\">\n <ng-content/>\n\n <ng-container *ngTemplateOutlet=\"modalContent()?.template; context: {data: modalContent()?.context}\"/>\n\n <ng-template #contentContainer/>\n </div>\n\n @if (showButtons()) {\n <evo-modal-buttons [single]=\"!declineText() || !acceptText()\">\n @if (declineText()) {\n <button\n class=\"evo-modal__button_decline\"\n evoButton\n [color]=\"declineButtonColor()\"\n [theme]=\"declineButtonTheme()\"\n [disabled]=\"isLoading()\"\n (click)=\"onDeclineClick()\"\n >{{ declineText() }}</button>\n }\n\n @if (acceptText()) {\n <button\n class=\"evo-modal__button_accept\"\n evoButton\n [color]=\"acceptButtonColor()\"\n [theme]=\"acceptButtonTheme()\"\n [loading]=\"isLoading()\"\n (click)=\"onAcceptClick()\"\n >{{ acceptText() }}</button>\n }\n </evo-modal-buttons>\n }\n }\n </div>\n </div>\n}\n", styles: ["@keyframes appearance{0%{opacity:0}to{opacity:1}}.evo-modal{display:flex;flex-direction:column;justify-content:flex-start;align-items:center;width:100%;max-width:752px;height:auto;max-height:100%;padding:16px;overflow:hidden;text-align:center;background-color:#fff;border-radius:16px;box-shadow:0 0 12px 2px #0000004d;animation:appearance .25s linear}@media (min-width: 768px){.evo-modal{width:752px;height:auto;padding:32px}}.evo-modal__title{margin-top:0;margin-bottom:0;font-weight:700;font-size:16px;line-height:24px}@media (min-width: 768px){.evo-modal__title{width:674px;font-size:24px;line-height:32px}}.evo-modal__icon{margin-bottom:8px}.evo-modal__icon ::ng-deep evo-icon{display:block;width:64px;height:64px}@media (min-width: 768px){.evo-modal__icon{margin-bottom:32px}}.evo-modal__icon:empty{display:none}.evo-modal__content{width:100%;margin-top:32px;overflow:auto;font-size:14px;line-height:22px}.evo-modal__content:empty{display:none;margin-top:0}.evo-modal__content ::ng-deep *:last-child{margin-bottom:0}.evo-modal__background{position:fixed;inset:0;z-index:1010;display:flex;justify-content:center;width:100%;height:100%;background:#00000080}.evo-modal__wrapper{position:fixed;inset:0;z-index:1011;display:flex;justify-content:center;align-items:center;width:100%;padding:16px}@media (min-width: 768px){.evo-modal__wrapper{width:auto}}\n"], dependencies: [{ kind: "component", type: EvoButtonComponent, selector: "button[evoButton], a[evoButton]", inputs: ["size", "color", "theme", "disabled", "loading"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: EvoModalButtonsComponent, selector: "evo-modal-buttons, [evo-modal-buttons]", inputs: ["single"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
104
141
|
}
|
|
105
142
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: EvoModalComponent, decorators: [{
|
|
106
143
|
type: Component,
|
|
107
|
-
args: [{ selector: 'evo-modal', standalone: true, imports: [
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
type: Input
|
|
116
|
-
}], acceptButtonTheme: [{
|
|
117
|
-
type: Input
|
|
118
|
-
}], declineText: [{
|
|
119
|
-
type: Input
|
|
120
|
-
}], declineButtonColor: [{
|
|
121
|
-
type: Input
|
|
122
|
-
}], declineButtonTheme: [{
|
|
123
|
-
type: Input
|
|
124
|
-
}], asyncAccept: [{
|
|
125
|
-
type: Input
|
|
126
|
-
}] } });
|
|
127
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"evo-modal.component.js","sourceRoot":"","sources":["../../../../../../projects/evo-ui-kit/src/lib/components/evo-modal/evo-modal.component.ts","../../../../../../projects/evo-ui-kit/src/lib/components/evo-modal/evo-modal.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, ElementRef, Input, OnDestroy, OnInit} from '@angular/core';\nimport {EvoModalService, EvoModalState} from './evo-modal.service';\nimport {fromEvent, Observable, Subscription} from 'rxjs';\nimport {takeWhile} from 'rxjs/operators';\nimport {Key} from 'ts-keycode-enum';\nimport {EvoButtonColor, EvoButtonTheme} from '../evo-button';\nimport {EvoButtonComponent} from '../evo-button/components/evo-button/evo-button.component';\nimport {NgClass} from '@angular/common';\n\nexport enum EvoModalCloseTargets {\n    BACKGROUND = 'background',\n    BUTTON = 'button',\n    DEFAULT = 'default',\n    ESC = 'escape',\n}\n\n@Component({\n    selector: 'evo-modal',\n    templateUrl: './evo-modal.component.html',\n    styleUrls: ['./evo-modal.component.scss'],\n    standalone: true,\n    imports: [NgClass, EvoButtonComponent],\n})\nexport class EvoModalComponent implements OnInit, OnDestroy {\n    get id(): string {\n        return this._id;\n    }\n\n    @Input() set id(id: string) {\n        if (id) {\n            this._id = id;\n            this.modalService.register(id);\n        } else {\n            throw new Error(\"EvoModal. Can't be registered, wrong id passed\");\n        }\n    }\n\n    @Input() titleText: string;\n    @Input() acceptText: string;\n    @Input() acceptButtonColor: EvoButtonColor;\n    @Input() acceptButtonTheme: EvoButtonTheme;\n    @Input() declineText: string;\n    @Input() declineButtonColor: EvoButtonColor = 'secondary';\n    @Input() declineButtonTheme: EvoButtonTheme = 'rounded-outline';\n    // eslint-disable-next-line\n    @Input() asyncAccept: () => Observable<any>;\n\n    modalState: EvoModalState;\n    isAcceptLoading = false;\n    isDeclineDisabled = false;\n    isVisible = false;\n\n    readonly closeTargets = EvoModalCloseTargets;\n    private _id: string;\n    private closeTarget: EvoModalCloseTargets = EvoModalCloseTargets.DEFAULT;\n\n    constructor(\n        private readonly modalService: EvoModalService,\n        private readonly elRef: ElementRef,\n    ) {}\n\n    ngOnInit(): void {\n        this.subscribeModalEvents();\n    }\n\n    ngOnDestroy(): void {\n        this.modalService.unregister(this.id);\n    }\n\n    onBackgroundClick($event): void {\n        if (\n            this.declineText &&\n            $event &&\n            $event.target &&\n            !this.elRef.nativeElement.querySelector('.evo-modal').contains($event.target) &&\n            this.modalState.isOpen\n        ) {\n            this.handleOnClose(false, this.closeTargets.BACKGROUND);\n        }\n    }\n\n    handleOnClose(agreement: boolean, closeTarget: EvoModalCloseTargets): Subscription {\n        this.closeTarget = closeTarget;\n\n        if (agreement === false && this.isDeclineDisabled) {\n            return;\n        }\n        if (agreement && typeof this.asyncAccept === 'function') {\n            const setAsyncStates = (isLoading = false) => {\n                this.isDeclineDisabled = isLoading;\n                this.isAcceptLoading = isLoading;\n            };\n\n            setAsyncStates(true);\n            return this.asyncAccept().subscribe(\n                () => {\n                    setAsyncStates(false);\n                    this.modalService.close(this.id, agreement, {\n                        closeTarget: this.closeTarget,\n                    });\n                },\n                () => {\n                    setAsyncStates(false);\n                },\n            );\n        }\n        this.modalService.close(this.id, agreement, {\n            closeTarget: this.closeTarget,\n        });\n    }\n\n    private subscribeModalEvents(): void {\n        this.modalService.getEventsSubscription(this.id).subscribe((modalState: EvoModalState) => {\n            this.modalState = modalState;\n            // timeout for modal animation support\n            setTimeout(() => {\n                this.isVisible = modalState.isOpen;\n            });\n            if (modalState.isOpen) {\n                this.initKeyboardListener();\n            }\n        });\n    }\n\n    private initKeyboardListener(): Subscription {\n        return fromEvent(document.body, 'keydown')\n            .pipe(\n                takeWhile(() => {\n                    return this.modalState.isOpen;\n                }),\n            )\n            .subscribe((event: KeyboardEvent) => {\n                if (this.declineText && event.keyCode === Key.Escape) {\n                    this.handleOnClose(false, this.closeTargets.ESC);\n                }\n            });\n    }\n}\n","@if (modalState?.isOpen) {\n    <div\n        class=\"evo-modal__background\"\n        [ngClass]=\"{'evo-modal__background_visible': isVisible}\"\n        (click)=\"onBackgroundClick($event)\"\n    ></div>\n\n    <div class=\"evo-modal__wrapper\" [ngClass]=\"{'evo-modal_visible': isVisible}\" (click)=\"onBackgroundClick($event)\">\n        <div class=\"evo-modal\">\n            <div class=\"evo-modal__icon\">\n                <ng-content select=\"evo-icon\" />\n            </div>\n\n            @if (titleText !== undefined) {\n                <h2 class=\"evo-modal__title\">{{ titleText }}</h2>\n            }\n\n            <div class=\"evo-modal__content\">\n                <ng-content />\n            </div>\n            <div class=\"evo-modal__buttons\" [ngClass]=\"{'evo-modal__buttons_single-btn': !declineText || !acceptText}\">\n                @if (declineText) {\n                    <button\n                        evoButton\n                        class=\"evo-modal__button evo-modal__button_decline\"\n                        [color]=\"declineButtonColor\"\n                        [theme]=\"declineButtonTheme\"\n                        [disabled]=\"isDeclineDisabled\"\n                        (click)=\"handleOnClose(false, closeTargets.BUTTON)\"\n                    >\n                        {{ declineText }}\n                    </button>\n                }\n\n                @if (acceptText) {\n                    <button\n                        evoButton\n                        class=\"evo-modal__button evo-modal__button_accept\"\n                        [color]=\"acceptButtonColor\"\n                        [theme]=\"acceptButtonTheme\"\n                        [loading]=\"isAcceptLoading\"\n                        (click)=\"handleOnClose(true, closeTargets.BUTTON)\"\n                    >\n                        {{ acceptText }}\n                    </button>\n                }\n            </div>\n        </div>\n    </div>\n}\n"]}
|
|
144
|
+
args: [{ selector: 'evo-modal', standalone: true, imports: [
|
|
145
|
+
EvoButtonComponent,
|
|
146
|
+
EvoUiClassDirective,
|
|
147
|
+
NgIf,
|
|
148
|
+
NgTemplateOutlet,
|
|
149
|
+
EvoModalButtonsComponent,
|
|
150
|
+
], changeDetection: ChangeDetectionStrategy.OnPush, template: "@if (isVisible()) {\n <div class=\"evo-modal__background\" (click)=\"onBackgroundClick($event)\"></div>\n\n <div class=\"evo-modal__wrapper\" (click)=\"onBackgroundClick($event)\">\n <div class=\"evo-modal\" #modal>\n @if (isDynamicContent()) {\n <ng-template #modalContainer/>\n } @else {\n <div class=\"evo-modal__icon\">\n <ng-content select=\"evo-icon\"/>\n </div>\n\n @if (titleText()) {\n <h2 class=\"evo-modal__title\">{{ titleText() }}</h2>\n }\n\n <div class=\"evo-modal__content\">\n <ng-content/>\n\n <ng-container *ngTemplateOutlet=\"modalContent()?.template; context: {data: modalContent()?.context}\"/>\n\n <ng-template #contentContainer/>\n </div>\n\n @if (showButtons()) {\n <evo-modal-buttons [single]=\"!declineText() || !acceptText()\">\n @if (declineText()) {\n <button\n class=\"evo-modal__button_decline\"\n evoButton\n [color]=\"declineButtonColor()\"\n [theme]=\"declineButtonTheme()\"\n [disabled]=\"isLoading()\"\n (click)=\"onDeclineClick()\"\n >{{ declineText() }}</button>\n }\n\n @if (acceptText()) {\n <button\n class=\"evo-modal__button_accept\"\n evoButton\n [color]=\"acceptButtonColor()\"\n [theme]=\"acceptButtonTheme()\"\n [loading]=\"isLoading()\"\n (click)=\"onAcceptClick()\"\n >{{ acceptText() }}</button>\n }\n </evo-modal-buttons>\n }\n }\n </div>\n </div>\n}\n", styles: ["@keyframes appearance{0%{opacity:0}to{opacity:1}}.evo-modal{display:flex;flex-direction:column;justify-content:flex-start;align-items:center;width:100%;max-width:752px;height:auto;max-height:100%;padding:16px;overflow:hidden;text-align:center;background-color:#fff;border-radius:16px;box-shadow:0 0 12px 2px #0000004d;animation:appearance .25s linear}@media (min-width: 768px){.evo-modal{width:752px;height:auto;padding:32px}}.evo-modal__title{margin-top:0;margin-bottom:0;font-weight:700;font-size:16px;line-height:24px}@media (min-width: 768px){.evo-modal__title{width:674px;font-size:24px;line-height:32px}}.evo-modal__icon{margin-bottom:8px}.evo-modal__icon ::ng-deep evo-icon{display:block;width:64px;height:64px}@media (min-width: 768px){.evo-modal__icon{margin-bottom:32px}}.evo-modal__icon:empty{display:none}.evo-modal__content{width:100%;margin-top:32px;overflow:auto;font-size:14px;line-height:22px}.evo-modal__content:empty{display:none;margin-top:0}.evo-modal__content ::ng-deep *:last-child{margin-bottom:0}.evo-modal__background{position:fixed;inset:0;z-index:1010;display:flex;justify-content:center;width:100%;height:100%;background:#00000080}.evo-modal__wrapper{position:fixed;inset:0;z-index:1011;display:flex;justify-content:center;align-items:center;width:100%;padding:16px}@media (min-width: 768px){.evo-modal__wrapper{width:auto}}\n"] }]
|
|
151
|
+
}] });
|
|
152
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"evo-modal.component.js","sourceRoot":"","sources":["../../../../../../projects/evo-ui-kit/src/lib/components/evo-modal/evo-modal.component.ts","../../../../../../projects/evo-ui-kit/src/lib/components/evo-modal/evo-modal.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    computed,\n    createComponent,\n    DestroyRef,\n    ElementRef,\n    EnvironmentInjector,\n    inject,\n    Injector,\n    model,\n    OnDestroy,\n    OnInit,\n    signal,\n    TemplateRef,\n    viewChild,\n    ViewContainerRef\n} from '@angular/core';\nimport {filter, finalize, fromEvent, Observable} from 'rxjs';\nimport {takeWhile} from 'rxjs/operators';\nimport {EvoButtonColor, EvoButtonTheme} from '../evo-button';\nimport {EvoButtonComponent} from '../evo-button';\nimport {EvoUiClassDirective} from \"../../directives\";\nimport {takeUntilDestroyed, toObservable} from '@angular/core/rxjs-interop';\nimport {EVO_MODAL_DATA, EVO_MODAL_ROOT_ID} from './tokens';\nimport {NgIf, NgTemplateOutlet} from '@angular/common';\nimport {EvoDynamicModalParams, EvoModalCombinedParams, EvoModalState} from './interfaces';\nimport {EvoModalService} from './evo-modal.service';\nimport {isConfiguredComponentModalParams, isConfiguredTemplateModalParams, isDynamicModalParams} from './utils';\nimport {EvoModalCloseTargets} from './enums';\nimport {EvoModalDrawingStrategy} from './classes/EvoModalDrawingStrategy';\nimport {EvoDynamicModalDrawingStrategy} from './classes/EvoDynamicModalDrawingStrategy';\nimport {EvoConfiguredComponentModalDrawingStrategy} from './classes/EvoConfiguredComponentModalDrawingStrategy';\nimport {EvoConfiguredTemplateModalDrawingStrategy} from './classes/EvoConfiguredTemplateModalDrawingStrategy';\nimport {EvoModalButtonsComponent} from './evo-modal-buttons/evo-modal-buttons.component';\n\ntype InsertionContainerType = 'modal' | 'content';\n\n@Component({\n    selector: 'evo-modal',\n    templateUrl: './evo-modal.component.html',\n    styleUrls: ['./evo-modal.component.scss'],\n    standalone: true,\n    imports: [\n        EvoButtonComponent,\n        EvoUiClassDirective,\n        NgIf,\n        NgTemplateOutlet,\n        EvoModalButtonsComponent,\n    ],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class EvoModalComponent implements OnInit, OnDestroy {\n\n    // eslint-disable-next-line @typescript-eslint/member-ordering\n    private readonly evoModalRootId = inject(EVO_MODAL_ROOT_ID);\n\n    acceptText = model<string>('');\n    acceptButtonColor = model<EvoButtonColor>(`success`);\n    acceptButtonTheme = model<EvoButtonTheme>(`rounded-solid`);\n    asyncAccept = model<() => Observable<unknown> | null>(null);\n    declineText = model<string>('');\n    declineButtonColor = model<EvoButtonColor>('secondary');\n    declineButtonTheme = model<EvoButtonTheme>('rounded-outline');\n    id = model<string>(this.evoModalRootId);\n    titleText = model<string>('');\n\n    readonly contentContainer = viewChild('contentContainer', {read: ViewContainerRef});\n    readonly contentContainer$ = toObservable(this.contentContainer);\n    readonly drawingStrategy = signal<EvoModalDrawingStrategy | null>(null);\n    readonly isDynamicContent = signal<boolean>(false);\n    readonly isLoading = signal<boolean>(false);\n    readonly isVisible = computed((): boolean => this.modalState()?.isOpen || false);\n    readonly modalContainer = viewChild('modalContainer', {read: ViewContainerRef});\n    readonly modalContainer$ = toObservable(this.modalContainer);\n    readonly modalContent = signal<{template: TemplateRef<{data: unknown}>, context: unknown} | null>(null);\n    readonly modalElement = viewChild('modal', {read: ElementRef});\n    readonly modalState = signal<EvoModalState | null>(null);\n    readonly showButtons = computed((): string => this.acceptText() || this.declineText());\n\n    readonly closeTargets = EvoModalCloseTargets;\n\n    private readonly destroyRef = inject(DestroyRef);\n    private readonly environmentInjector = inject(EnvironmentInjector);\n    private readonly evoModalService = inject(EvoModalService);\n\n    ngOnInit(): void {\n        this.evoModalService.register(this.id());\n        this.subscribeModalEvents();\n    }\n\n    ngOnDestroy(): void {\n        this.evoModalService.unregister(this.id());\n    }\n\n    onAcceptClick(): void {\n        const asyncAcceptAction = this.asyncAccept()?.();\n\n        if (!asyncAcceptAction) {\n            return this.close(true, EvoModalCloseTargets.BUTTON);\n        }\n\n        this.isLoading.set(true);\n\n        asyncAcceptAction.pipe(\n            finalize((): void => this.isLoading.set(false)),\n            takeUntilDestroyed(this.destroyRef),\n        ).subscribe((): void => this.close(true, EvoModalCloseTargets.BUTTON));\n    }\n\n    onBackgroundClick(event: Event): void {\n        if (this.canCloseByBackground(event)) {\n            this.close(false, EvoModalCloseTargets.BACKGROUND);\n        }\n    }\n\n    onDeclineClick(): void {\n        if (this.isLoading()) {\n            return;\n        }\n\n        this.close(false, EvoModalCloseTargets.BUTTON);\n    }\n\n    protected clearView(): void {\n        this.modalContainer()?.clear();\n    }\n\n    protected insertComponent(\n        {data, injector, component}: Pick<EvoDynamicModalParams, 'data' | 'component' | 'injector'>,\n        target: InsertionContainerType = 'modal',\n    ): void {\n        const dynamicComponentRef = createComponent(component, {\n            environmentInjector: this.environmentInjector,\n            elementInjector: Injector.create({\n                providers: [\n                    {\n                        provide: EVO_MODAL_DATA,\n                        useValue: data,\n                    },\n                ],\n                parent: injector,\n            }),\n        });\n\n        this.getInsertionContainer(target).pipe(\n            filter((container): container is ViewContainerRef => !!container),\n            takeUntilDestroyed(this.destroyRef),\n        ).subscribe((container): void => {\n            container.insert(dynamicComponentRef.hostView);\n            dynamicComponentRef.changeDetectorRef.markForCheck();\n        });\n    }\n\n    private canCloseByBackground(event: Event): boolean {\n        return (this.declineText() || this.isDynamicContent()) &&\n            !this.isLoading() &&\n            this.modalState().isOpen &&\n            event?.target &&\n            !this.modalElement().nativeElement.contains(event.target);\n    }\n\n    private close(agreement: boolean, closeTarget: EvoModalCloseTargets): void {\n        this.evoModalService.close(this.id(), agreement, {closeTarget});\n        this.clearView();\n\n        if (this.id() !== this.evoModalRootId) {\n            return;\n        }\n\n        this.evoModalService.unregister(this.evoModalRootId);\n        this.evoModalService.cleanupDefaultHost();\n    }\n\n    private getInsertionContainer(target: InsertionContainerType): Observable<ViewContainerRef> {\n        return target === 'modal' ? this.modalContainer$ : this.contentContainer$;\n    }\n\n    private initKeyboardListener(): void {\n        fromEvent(document.body, 'keydown').pipe(\n            takeWhile((): boolean => this.modalState().isOpen),\n            filter((event: KeyboardEvent): boolean => (this.declineText() || this.isDynamicContent()) && event.key === 'Escape'),\n            takeUntilDestroyed(this.destroyRef),\n        ).subscribe((): void => this.close(false, this.closeTargets.ESC));\n    }\n\n    private setDrawingStrategy(params: EvoModalCombinedParams): void {\n        switch (true) {\n            case isDynamicModalParams(params):\n                return this.drawingStrategy.set(new EvoDynamicModalDrawingStrategy());\n            case isConfiguredComponentModalParams(params):\n                return this.drawingStrategy.set(new EvoConfiguredComponentModalDrawingStrategy());\n            case isConfiguredTemplateModalParams(params):\n                return this.drawingStrategy.set(new EvoConfiguredTemplateModalDrawingStrategy());\n            default:\n                return;\n        }\n    }\n\n    private subscribeModalEvents(): void {\n        this.evoModalService.getEventsSubscription(this.id()).pipe(\n            takeUntilDestroyed(this.destroyRef),\n        ).subscribe((modalState: EvoModalState): void => {\n            this.modalState.set(modalState);\n\n            if (!modalState.isOpen) {\n                return;\n            }\n\n            this.initKeyboardListener();\n            this.setDrawingStrategy(modalState.params);\n            this.drawingStrategy()?.draw.call(this, modalState.params);\n        });\n    }\n}\n","@if (isVisible()) {\n    <div class=\"evo-modal__background\" (click)=\"onBackgroundClick($event)\"></div>\n\n    <div class=\"evo-modal__wrapper\" (click)=\"onBackgroundClick($event)\">\n        <div class=\"evo-modal\" #modal>\n            @if (isDynamicContent()) {\n                <ng-template #modalContainer/>\n            } @else {\n                <div class=\"evo-modal__icon\">\n                    <ng-content select=\"evo-icon\"/>\n                </div>\n\n                @if (titleText()) {\n                    <h2 class=\"evo-modal__title\">{{ titleText() }}</h2>\n                }\n\n                <div class=\"evo-modal__content\">\n                    <ng-content/>\n\n                    <ng-container *ngTemplateOutlet=\"modalContent()?.template; context: {data: modalContent()?.context}\"/>\n\n                    <ng-template #contentContainer/>\n                </div>\n\n                @if (showButtons()) {\n                    <evo-modal-buttons [single]=\"!declineText() || !acceptText()\">\n                        @if (declineText()) {\n                            <button\n                                class=\"evo-modal__button_decline\"\n                                evoButton\n                                [color]=\"declineButtonColor()\"\n                                [theme]=\"declineButtonTheme()\"\n                                [disabled]=\"isLoading()\"\n                                (click)=\"onDeclineClick()\"\n                            >{{ declineText() }}</button>\n                        }\n\n                        @if (acceptText()) {\n                            <button\n                                class=\"evo-modal__button_accept\"\n                                evoButton\n                                [color]=\"acceptButtonColor()\"\n                                [theme]=\"acceptButtonTheme()\"\n                                [loading]=\"isLoading()\"\n                                (click)=\"onAcceptClick()\"\n                            >{{ acceptText() }}</button>\n                        }\n                    </evo-modal-buttons>\n                }\n            }\n        </div>\n    </div>\n}\n"]}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { makeEnvironmentProviders } from "@angular/core";
|
|
2
|
+
import { EvoModalPortal } from './evo-modal-portal';
|
|
3
|
+
import { EVO_MODAL_CONFIG, EVO_MODAL_DEFAULT_CONFIG, EVO_MODAL_DEFAULT_ROOT_ID, EVO_MODAL_ROOT_ID } from './tokens';
|
|
4
|
+
import { merge } from 'lodash-es';
|
|
5
|
+
export function provideModal(config = {}) {
|
|
6
|
+
return makeEnvironmentProviders([
|
|
7
|
+
EvoModalPortal,
|
|
8
|
+
{
|
|
9
|
+
provide: EVO_MODAL_ROOT_ID,
|
|
10
|
+
useValue: EVO_MODAL_DEFAULT_ROOT_ID,
|
|
11
|
+
},
|
|
12
|
+
{
|
|
13
|
+
provide: EVO_MODAL_CONFIG,
|
|
14
|
+
useValue: merge(EVO_MODAL_DEFAULT_CONFIG, config),
|
|
15
|
+
},
|
|
16
|
+
]);
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZvLW1vZGFsLnByb3ZpZGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZXZvLXVpLWtpdC9zcmMvbGliL2NvbXBvbmVudHMvZXZvLW1vZGFsL2V2by1tb2RhbC5wcm92aWRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQXVCLHdCQUF3QixFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQzdFLE9BQU8sRUFBQyxjQUFjLEVBQUMsTUFBTSxvQkFBb0IsQ0FBQztBQUNsRCxPQUFPLEVBQUMsZ0JBQWdCLEVBQUUsd0JBQXdCLEVBQUUseUJBQXlCLEVBQUUsaUJBQWlCLEVBQUMsTUFBTSxVQUFVLENBQUM7QUFFbEgsT0FBTyxFQUFDLEtBQUssRUFBQyxNQUFNLFdBQVcsQ0FBQztBQUVoQyxNQUFNLFVBQVUsWUFBWSxDQUFDLFNBQXlCLEVBQUU7SUFDcEQsT0FBTyx3QkFBd0IsQ0FBQztRQUM1QixjQUFjO1FBQ2Q7WUFDSSxPQUFPLEVBQUUsaUJBQWlCO1lBQzFCLFFBQVEsRUFBRSx5QkFBeUI7U0FDdEM7UUFDRDtZQUNJLE9BQU8sRUFBRSxnQkFBZ0I7WUFDekIsUUFBUSxFQUFFLEtBQUssQ0FBQyx3QkFBd0IsRUFBRSxNQUFNLENBQUM7U0FDcEQ7S0FDSixDQUFDLENBQUM7QUFDUCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtFbnZpcm9ubWVudFByb3ZpZGVycywgbWFrZUVudmlyb25tZW50UHJvdmlkZXJzfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuaW1wb3J0IHtFdm9Nb2RhbFBvcnRhbH0gZnJvbSAnLi9ldm8tbW9kYWwtcG9ydGFsJztcbmltcG9ydCB7RVZPX01PREFMX0NPTkZJRywgRVZPX01PREFMX0RFRkFVTFRfQ09ORklHLCBFVk9fTU9EQUxfREVGQVVMVF9ST09UX0lELCBFVk9fTU9EQUxfUk9PVF9JRH0gZnJvbSAnLi90b2tlbnMnO1xuaW1wb3J0IHtFdm9Nb2RhbENvbmZpZ30gZnJvbSAnLi9pbnRlcmZhY2VzJztcbmltcG9ydCB7bWVyZ2V9IGZyb20gJ2xvZGFzaC1lcyc7XG5cbmV4cG9ydCBmdW5jdGlvbiBwcm92aWRlTW9kYWwoY29uZmlnOiBFdm9Nb2RhbENvbmZpZyA9IHt9KTogRW52aXJvbm1lbnRQcm92aWRlcnMge1xuICAgIHJldHVybiBtYWtlRW52aXJvbm1lbnRQcm92aWRlcnMoW1xuICAgICAgICBFdm9Nb2RhbFBvcnRhbCxcbiAgICAgICAge1xuICAgICAgICAgICAgcHJvdmlkZTogRVZPX01PREFMX1JPT1RfSUQsXG4gICAgICAgICAgICB1c2VWYWx1ZTogRVZPX01PREFMX0RFRkFVTFRfUk9PVF9JRCxcbiAgICAgICAgfSxcbiAgICAgICAge1xuICAgICAgICAgICAgcHJvdmlkZTogRVZPX01PREFMX0NPTkZJRyxcbiAgICAgICAgICAgIHVzZVZhbHVlOiBtZXJnZShFVk9fTU9EQUxfREVGQVVMVF9DT05GSUcsIGNvbmZpZyksXG4gICAgICAgIH0sXG4gICAgXSk7XG59XG4iXX0=
|