@abp/ng.theme.shared 5.0.1 → 5.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (210) hide show
  1. package/README.md +3 -3
  2. package/abp-ng.theme.shared.d.ts +5 -5
  3. package/bundles/abp-ng.theme.shared-extensions.umd.js +1749 -1748
  4. package/bundles/abp-ng.theme.shared-extensions.umd.js.map +1 -1
  5. package/bundles/abp-ng.theme.shared-testing.umd.js +41 -41
  6. package/bundles/abp-ng.theme.shared-testing.umd.js.map +1 -1
  7. package/bundles/abp-ng.theme.shared.umd.js +2316 -2316
  8. package/bundles/abp-ng.theme.shared.umd.js.map +1 -1
  9. package/esm2015/abp-ng.theme.shared.js +4 -4
  10. package/esm2015/extensions/abp-ng.theme.shared-extensions.js +4 -4
  11. package/esm2015/extensions/lib/adapters/date-time.adapter.js +34 -34
  12. package/esm2015/extensions/lib/adapters/date.adapter.js +41 -41
  13. package/esm2015/extensions/lib/adapters/time.adapter.js +36 -36
  14. package/esm2015/extensions/lib/components/abstract-actions/abstract-actions.component.js +25 -25
  15. package/esm2015/extensions/lib/components/date-time-picker/date-time-picker.component.js +109 -109
  16. package/esm2015/extensions/lib/components/extensible-form/extensible-form-prop.component.js +164 -164
  17. package/esm2015/extensions/lib/components/extensible-form/extensible-form.component.js +70 -70
  18. package/esm2015/extensions/lib/components/extensible-table/extensible-table.component.js +134 -134
  19. package/esm2015/extensions/lib/components/grid-actions/grid-actions.component.js +45 -45
  20. package/esm2015/extensions/lib/components/page-toolbar/page-toolbar.component.js +46 -46
  21. package/esm2015/extensions/lib/constants/extra-properties.js +2 -2
  22. package/esm2015/extensions/lib/directives/disabled.directive.js +29 -29
  23. package/esm2015/extensions/lib/directives/prop-data.directive.js +41 -41
  24. package/esm2015/extensions/lib/enums/props.enum.js +2 -2
  25. package/esm2015/extensions/lib/models/actions.js +46 -46
  26. package/esm2015/extensions/lib/models/entity-actions.js +29 -29
  27. package/esm2015/extensions/lib/models/entity-props.js +36 -34
  28. package/esm2015/extensions/lib/models/form-props.js +52 -52
  29. package/esm2015/extensions/lib/models/internal/object-extensions.js +2 -2
  30. package/esm2015/extensions/lib/models/object-extensions.js +3 -3
  31. package/esm2015/extensions/lib/models/props.js +50 -50
  32. package/esm2015/extensions/lib/models/toolbar-actions.js +41 -41
  33. package/esm2015/extensions/lib/services/extensions.service.js +24 -24
  34. package/esm2015/extensions/lib/tokens/extensions.token.js +7 -7
  35. package/esm2015/extensions/lib/ui-extensions.module.js +92 -92
  36. package/esm2015/extensions/lib/utils/actions.util.js +9 -9
  37. package/esm2015/extensions/lib/utils/enum.util.js +42 -42
  38. package/esm2015/extensions/lib/utils/factory.util.js +4 -4
  39. package/esm2015/extensions/lib/utils/form-props.util.js +51 -51
  40. package/esm2015/extensions/lib/utils/localization.util.js +13 -13
  41. package/esm2015/extensions/lib/utils/props.util.js +14 -14
  42. package/esm2015/extensions/lib/utils/state.util.js +124 -124
  43. package/esm2015/extensions/lib/utils/typeahead.util.js +52 -52
  44. package/esm2015/extensions/lib/utils/validation.util.js +11 -11
  45. package/esm2015/extensions/public-api.js +28 -28
  46. package/esm2015/lib/animations/bounce.animations.js +17 -17
  47. package/esm2015/lib/animations/collapse.animations.js +50 -50
  48. package/esm2015/lib/animations/fade.animations.js +38 -38
  49. package/esm2015/lib/animations/index.js +7 -7
  50. package/esm2015/lib/animations/modal.animations.js +11 -11
  51. package/esm2015/lib/animations/slide.animations.js +8 -8
  52. package/esm2015/lib/animations/toast.animations.js +13 -13
  53. package/esm2015/lib/components/breadcrumb/breadcrumb.component.js +49 -49
  54. package/esm2015/lib/components/breadcrumb-items/breadcrumb-items.component.js +22 -22
  55. package/esm2015/lib/components/button/button.component.js +98 -98
  56. package/esm2015/lib/components/confirmation/confirmation.component.js +40 -40
  57. package/esm2015/lib/components/http-error-wrapper/http-error-wrapper.component.js +65 -65
  58. package/esm2015/lib/components/index.js +13 -13
  59. package/esm2015/lib/components/loader-bar/loader-bar.component.js +126 -126
  60. package/esm2015/lib/components/loading/loading.component.js +47 -47
  61. package/esm2015/lib/components/modal/modal-close.directive.js +28 -28
  62. package/esm2015/lib/components/modal/modal-ref.service.js +26 -26
  63. package/esm2015/lib/components/modal/modal.component.js +188 -188
  64. package/esm2015/lib/components/toast/toast.component.js +61 -61
  65. package/esm2015/lib/components/toast-container/toast-container.component.js +49 -49
  66. package/esm2015/lib/constants/styles.js +182 -182
  67. package/esm2015/lib/constants/validation.js +15 -15
  68. package/esm2015/lib/directives/ellipsis.directive.js +63 -63
  69. package/esm2015/lib/directives/index.js +5 -5
  70. package/esm2015/lib/directives/loading.directive.js +90 -90
  71. package/esm2015/lib/directives/ngx-datatable-default.directive.js +75 -75
  72. package/esm2015/lib/directives/ngx-datatable-list.directive.js +94 -94
  73. package/esm2015/lib/enums/index.js +2 -2
  74. package/esm2015/lib/enums/route-names.js +2 -2
  75. package/esm2015/lib/handlers/document-dir.handler.js +33 -33
  76. package/esm2015/lib/handlers/error.handler.js +292 -292
  77. package/esm2015/lib/handlers/index.js +3 -3
  78. package/esm2015/lib/models/common.js +2 -2
  79. package/esm2015/lib/models/confirmation.js +10 -10
  80. package/esm2015/lib/models/index.js +6 -6
  81. package/esm2015/lib/models/nav-item.js +7 -7
  82. package/esm2015/lib/models/statistics.js +2 -2
  83. package/esm2015/lib/models/toaster.js +2 -2
  84. package/esm2015/lib/providers/index.js +3 -3
  85. package/esm2015/lib/providers/ng-bootstrap-config.provider.js +17 -17
  86. package/esm2015/lib/providers/route.provider.js +18 -18
  87. package/esm2015/lib/services/confirmation.service.js +68 -68
  88. package/esm2015/lib/services/index.js +5 -5
  89. package/esm2015/lib/services/nav-items.service.js +51 -51
  90. package/esm2015/lib/services/page-alert.service.js +26 -26
  91. package/esm2015/lib/services/toaster.service.js +103 -103
  92. package/esm2015/lib/theme-shared.module.js +165 -165
  93. package/esm2015/lib/tokens/append-content.token.js +11 -11
  94. package/esm2015/lib/tokens/http-error.token.js +10 -10
  95. package/esm2015/lib/tokens/index.js +5 -5
  96. package/esm2015/lib/tokens/ngx-datatable-messages.token.js +8 -8
  97. package/esm2015/lib/tokens/suppress-unsaved-changes-warning.token.js +3 -3
  98. package/esm2015/lib/utils/date-parser-formatter.js +59 -59
  99. package/esm2015/lib/utils/index.js +3 -3
  100. package/esm2015/lib/utils/validation-utils.js +33 -33
  101. package/esm2015/public-api.js +16 -16
  102. package/esm2015/testing/abp-ng.theme.shared-testing.js +4 -4
  103. package/esm2015/testing/lib/models/config.js +2 -2
  104. package/esm2015/testing/lib/models/index.js +2 -2
  105. package/esm2015/testing/lib/theme-shared-testing.module.js +43 -43
  106. package/esm2015/testing/public-api.js +4 -4
  107. package/extensions/abp-ng.theme.shared-extensions.d.ts +5 -5
  108. package/extensions/lib/adapters/date-time.adapter.d.ts +11 -11
  109. package/extensions/lib/adapters/date.adapter.d.ts +9 -9
  110. package/extensions/lib/adapters/time.adapter.d.ts +8 -8
  111. package/extensions/lib/components/abstract-actions/abstract-actions.component.d.ts +14 -14
  112. package/extensions/lib/components/date-time-picker/date-time-picker.component.d.ts +16 -16
  113. package/extensions/lib/components/extensible-form/extensible-form-prop.component.d.ts +37 -37
  114. package/extensions/lib/components/extensible-form/extensible-form.component.d.ts +24 -24
  115. package/extensions/lib/components/extensible-table/extensible-table.component.d.ts +35 -35
  116. package/extensions/lib/components/grid-actions/grid-actions.component.d.ts +13 -13
  117. package/extensions/lib/components/page-toolbar/page-toolbar.component.d.ts +12 -12
  118. package/extensions/lib/constants/extra-properties.d.ts +1 -1
  119. package/extensions/lib/directives/disabled.directive.d.ts +11 -11
  120. package/extensions/lib/directives/prop-data.directive.d.ts +19 -19
  121. package/extensions/lib/enums/props.enum.d.ts +15 -15
  122. package/extensions/lib/models/actions.d.ts +35 -35
  123. package/extensions/lib/models/entity-actions.d.ts +22 -22
  124. package/extensions/lib/models/entity-props.d.ts +29 -29
  125. package/extensions/lib/models/form-props.d.ts +42 -42
  126. package/extensions/lib/models/internal/object-extensions.d.ts +85 -85
  127. package/extensions/lib/models/object-extensions.d.ts +2 -2
  128. package/extensions/lib/models/props.d.ts +39 -39
  129. package/extensions/lib/models/toolbar-actions.d.ts +29 -29
  130. package/extensions/lib/services/extensions.service.d.ts +14 -14
  131. package/extensions/lib/tokens/extensions.token.d.ts +14 -14
  132. package/extensions/lib/ui-extensions.module.d.ts +23 -23
  133. package/extensions/lib/utils/actions.util.d.ts +7 -7
  134. package/extensions/lib/utils/enum.util.d.ts +7 -7
  135. package/extensions/lib/utils/factory.util.d.ts +1 -1
  136. package/extensions/lib/utils/form-props.util.d.ts +3 -3
  137. package/extensions/lib/utils/localization.util.d.ts +3 -3
  138. package/extensions/lib/utils/props.util.d.ts +8 -8
  139. package/extensions/lib/utils/state.util.d.ts +5 -5
  140. package/extensions/lib/utils/typeahead.util.d.ts +11 -11
  141. package/extensions/lib/utils/validation.util.d.ts +3 -3
  142. package/extensions/public-api.d.ts +27 -27
  143. package/fesm2015/abp-ng.theme.shared-extensions.js +1263 -1262
  144. package/fesm2015/abp-ng.theme.shared-extensions.js.map +1 -1
  145. package/fesm2015/abp-ng.theme.shared-testing.js +37 -37
  146. package/fesm2015/abp-ng.theme.shared-testing.js.map +1 -1
  147. package/fesm2015/abp-ng.theme.shared.js +2117 -2117
  148. package/fesm2015/abp-ng.theme.shared.js.map +1 -1
  149. package/lib/animations/bounce.animations.d.ts +1 -1
  150. package/lib/animations/collapse.animations.d.ts +9 -9
  151. package/lib/animations/fade.animations.d.ts +10 -10
  152. package/lib/animations/index.d.ts +6 -6
  153. package/lib/animations/modal.animations.d.ts +2 -2
  154. package/lib/animations/slide.animations.d.ts +1 -1
  155. package/lib/animations/toast.animations.d.ts +1 -1
  156. package/lib/components/breadcrumb/breadcrumb.component.d.ts +16 -16
  157. package/lib/components/breadcrumb-items/breadcrumb-items.component.d.ts +7 -7
  158. package/lib/components/button/button.component.d.ts +25 -25
  159. package/lib/components/confirmation/confirmation.component.d.ts +14 -14
  160. package/lib/components/http-error-wrapper/http-error-wrapper.component.d.ts +27 -27
  161. package/lib/components/index.d.ts +12 -12
  162. package/lib/components/loader-bar/loader-bar.component.d.ts +33 -33
  163. package/lib/components/loading/loading.component.d.ts +5 -5
  164. package/lib/components/modal/modal-close.directive.d.ts +9 -9
  165. package/lib/components/modal/modal-ref.service.d.ts +13 -13
  166. package/lib/components/modal/modal.component.d.ts +50 -50
  167. package/lib/components/toast/toast.component.d.ts +14 -14
  168. package/lib/components/toast-container/toast-container.component.d.ts +18 -18
  169. package/lib/constants/styles.d.ts +2 -2
  170. package/lib/constants/validation.d.ts +14 -14
  171. package/lib/directives/ellipsis.directive.d.ts +21 -21
  172. package/lib/directives/index.d.ts +4 -4
  173. package/lib/directives/loading.directive.d.ts +25 -25
  174. package/lib/directives/ngx-datatable-default.directive.d.ts +30 -30
  175. package/lib/directives/ngx-datatable-list.directive.d.ts +24 -24
  176. package/lib/enums/index.d.ts +1 -1
  177. package/lib/enums/route-names.d.ts +3 -3
  178. package/lib/handlers/document-dir.handler.d.ts +13 -13
  179. package/lib/handlers/error.handler.d.ts +82 -82
  180. package/lib/handlers/index.d.ts +2 -2
  181. package/lib/models/common.d.ts +19 -19
  182. package/lib/models/confirmation.d.ts +25 -25
  183. package/lib/models/index.d.ts +5 -5
  184. package/lib/models/nav-item.d.ts +11 -11
  185. package/lib/models/statistics.d.ts +12 -12
  186. package/lib/models/toaster.d.ts +30 -30
  187. package/lib/providers/index.d.ts +2 -2
  188. package/lib/providers/ng-bootstrap-config.provider.d.ts +8 -8
  189. package/lib/providers/route.provider.d.ts +8 -8
  190. package/lib/services/confirmation.service.d.ts +21 -21
  191. package/lib/services/index.d.ts +4 -4
  192. package/lib/services/nav-items.service.d.ts +13 -13
  193. package/lib/services/page-alert.service.d.ts +18 -18
  194. package/lib/services/toaster.service.d.ts +60 -60
  195. package/lib/theme-shared.module.d.ts +33 -33
  196. package/lib/tokens/append-content.token.d.ts +2 -2
  197. package/lib/tokens/http-error.token.d.ts +5 -5
  198. package/lib/tokens/index.d.ts +4 -4
  199. package/lib/tokens/ngx-datatable-messages.token.d.ts +12 -12
  200. package/lib/tokens/suppress-unsaved-changes-warning.token.d.ts +2 -2
  201. package/lib/utils/date-parser-formatter.d.ts +12 -12
  202. package/lib/utils/index.d.ts +2 -2
  203. package/lib/utils/validation-utils.d.ts +3 -3
  204. package/package.json +2 -2
  205. package/public-api.d.ts +12 -12
  206. package/testing/abp-ng.theme.shared-testing.d.ts +5 -5
  207. package/testing/lib/models/config.d.ts +4 -4
  208. package/testing/lib/models/index.d.ts +1 -1
  209. package/testing/lib/theme-shared-testing.module.d.ts +14 -14
  210. package/testing/public-api.d.ts +3 -3
@@ -1,188 +1,188 @@
1
- import { SubscriptionService, uuid } from '@abp/ng.core';
2
- import { Component, ContentChild, EventEmitter, Inject, Input, Optional, Output, TemplateRef, ViewChild, } from '@angular/core';
3
- import { NgbModal } from '@ng-bootstrap/ng-bootstrap';
4
- import { fromEvent, Subject } from 'rxjs';
5
- import { debounceTime, distinctUntilChanged, filter, takeUntil } from 'rxjs/operators';
6
- import { Confirmation } from '../../models/confirmation';
7
- import { ConfirmationService } from '../../services/confirmation.service';
8
- import { SUPPRESS_UNSAVED_CHANGES_WARNING } from '../../tokens/suppress-unsaved-changes-warning.token';
9
- import { ButtonComponent } from '../button/button.component';
10
- import { ModalRefService } from './modal-ref.service';
11
- import * as i0 from "@angular/core";
12
- import * as i1 from "../../services/confirmation.service";
13
- import * as i2 from "@abp/ng.core";
14
- import * as i3 from "@ng-bootstrap/ng-bootstrap";
15
- import * as i4 from "./modal-ref.service";
16
- import * as i5 from "@angular/common";
17
- export class ModalComponent {
18
- constructor(confirmationService, subscription, suppressUnsavedChangesWarningToken, modal, modalRefService) {
19
- this.confirmationService = confirmationService;
20
- this.subscription = subscription;
21
- this.suppressUnsavedChangesWarningToken = suppressUnsavedChangesWarningToken;
22
- this.modal = modal;
23
- this.modalRefService = modalRefService;
24
- this.options = {};
25
- this.suppressUnsavedChangesWarning = this.suppressUnsavedChangesWarningToken;
26
- this.visibleChange = new EventEmitter();
27
- this.init = new EventEmitter();
28
- this.appear = new EventEmitter();
29
- this.disappear = new EventEmitter();
30
- this._visible = false;
31
- this._busy = false;
32
- this.isConfirmationOpen = false;
33
- this.destroy$ = new Subject();
34
- this.modalIdentifier = `modal-${uuid()}`;
35
- this.toggle$ = new Subject();
36
- this.initToggleStream();
37
- }
38
- get visible() {
39
- return this._visible;
40
- }
41
- set visible(value) {
42
- if (typeof value !== 'boolean')
43
- return;
44
- this.toggle$.next(value);
45
- }
46
- get busy() {
47
- return this._busy;
48
- }
49
- set busy(value) {
50
- if (this.abpSubmit && this.abpSubmit instanceof ButtonComponent) {
51
- this.abpSubmit.loading = value;
52
- }
53
- this._busy = value;
54
- }
55
- get modalWindowRef() {
56
- return document.querySelector(`ngb-modal-window.${this.modalIdentifier}`);
57
- }
58
- get isFormDirty() {
59
- var _a;
60
- return Boolean((_a = this.modalWindowRef) === null || _a === void 0 ? void 0 : _a.querySelector('.ng-dirty'));
61
- }
62
- ngOnInit() {
63
- this.modalRefService.register(this);
64
- }
65
- dismiss(mode) {
66
- switch (mode) {
67
- case 'hard':
68
- this.visible = false;
69
- break;
70
- case 'soft':
71
- this.close();
72
- break;
73
- default:
74
- break;
75
- }
76
- }
77
- initToggleStream() {
78
- this.subscription.addOne(this.toggle$.pipe(debounceTime(0), distinctUntilChanged()), value => this.toggle(value));
79
- }
80
- toggle(value) {
81
- var _a;
82
- this._visible = value;
83
- this.visibleChange.emit(value);
84
- if (!value) {
85
- (_a = this.modalRef) === null || _a === void 0 ? void 0 : _a.dismiss();
86
- this.disappear.emit();
87
- this.destroy$.next();
88
- return;
89
- }
90
- setTimeout(() => this.listen(), 0);
91
- this.modalRef = this.modal.open(this.modalContent, Object.assign(Object.assign({ size: 'md', centered: false, keyboard: false, scrollable: true, beforeDismiss: () => {
92
- if (!this.visible)
93
- return true;
94
- this.close();
95
- return !this.visible;
96
- } }, this.options), { windowClass: `${this.options.windowClass || ''} ${this.modalIdentifier}` }));
97
- this.appear.emit();
98
- }
99
- ngOnDestroy() {
100
- this.modalRefService.unregister(this);
101
- this.toggle(false);
102
- this.destroy$.next();
103
- }
104
- close() {
105
- if (this.busy)
106
- return;
107
- if (this.isFormDirty && !this.suppressUnsavedChangesWarning) {
108
- if (this.isConfirmationOpen)
109
- return;
110
- this.isConfirmationOpen = true;
111
- this.confirmationService
112
- .warn('AbpUi::AreYouSureYouWantToCancelEditingWarningMessage', 'AbpUi::AreYouSure', { dismissible: false })
113
- .subscribe((status) => {
114
- this.isConfirmationOpen = false;
115
- if (status === Confirmation.Status.confirm) {
116
- this.visible = false;
117
- }
118
- });
119
- }
120
- else {
121
- this.visible = false;
122
- }
123
- }
124
- listen() {
125
- if (this.modalWindowRef) {
126
- fromEvent(this.modalWindowRef, 'keyup')
127
- .pipe(takeUntil(this.destroy$), debounceTime(150), filter((key) => key && key.key === 'Escape'))
128
- .subscribe(() => this.close());
129
- }
130
- fromEvent(window, 'beforeunload')
131
- .pipe(takeUntil(this.destroy$))
132
- .subscribe(event => {
133
- // TODO: check this
134
- if (!this.isFormDirty || this.suppressUnsavedChangesWarning) {
135
- event.preventDefault();
136
- }
137
- });
138
- this.init.emit();
139
- }
140
- }
141
- ModalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.13", ngImport: i0, type: ModalComponent, deps: [{ token: i1.ConfirmationService }, { token: i2.SubscriptionService }, { token: SUPPRESS_UNSAVED_CHANGES_WARNING, optional: true }, { token: i3.NgbModal }, { token: i4.ModalRefService }], target: i0.ɵɵFactoryTarget.Component });
142
- ModalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.13", type: ModalComponent, selector: "abp-modal", inputs: { visible: "visible", busy: "busy", options: "options", suppressUnsavedChangesWarning: "suppressUnsavedChangesWarning" }, outputs: { visibleChange: "visibleChange", init: "init", appear: "appear", disappear: "disappear" }, providers: [SubscriptionService], queries: [{ propertyName: "abpHeader", first: true, predicate: ["abpHeader"], descendants: true }, { propertyName: "abpBody", first: true, predicate: ["abpBody"], descendants: true }, { propertyName: "abpFooter", first: true, predicate: ["abpFooter"], descendants: true }, { propertyName: "abpSubmit", first: true, predicate: ButtonComponent, descendants: true, read: ButtonComponent }], viewQueries: [{ propertyName: "modalContent", first: true, predicate: ["modalContent"], descendants: true }], ngImport: i0, template: "<ng-content></ng-content>\r\n\r\n<ng-template #modalContent let-modal>\r\n <div *ngIf=\"abpHeader\" id=\"abp-modal-header\" class=\"modal-header\">\r\n <ng-container *ngTemplateOutlet=\"abpHeader\"></ng-container>\r\n \u200B\r\n <button\r\n id=\"abp-modal-close-button\"\r\n type=\"button\"\r\n class=\"btn-sm btn-close\"\r\n aria-label=\"Close\"\r\n (click)=\"modal.dismiss()\"\r\n ></button>\r\n </div>\r\n <div *ngIf=\"abpBody\" id=\"abp-modal-body\" class=\"modal-body\">\r\n <ng-container *ngTemplateOutlet=\"abpBody\"></ng-container>\r\n </div>\r\n <div *ngIf=\"abpFooter\" id=\"abp-modal-footer\" class=\"modal-footer\">\r\n <ng-container *ngTemplateOutlet=\"abpFooter\"></ng-container>\r\n </div>\r\n</ng-template>\r\n", styles: [".modal.show{display:block!important}.modal-backdrop{opacity:.8}.modal::-webkit-scrollbar{width:7px}.modal::-webkit-scrollbar-track{background:#ddd}.modal::-webkit-scrollbar-thumb{background:#8a8686}.modal-dialog{z-index:1050}\n"], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }] });
143
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.13", ngImport: i0, type: ModalComponent, decorators: [{
144
- type: Component,
145
- args: [{
146
- selector: 'abp-modal',
147
- templateUrl: './modal.component.html',
148
- styleUrls: ['./modal.component.scss'],
149
- providers: [SubscriptionService],
150
- }]
151
- }], ctorParameters: function () { return [{ type: i1.ConfirmationService }, { type: i2.SubscriptionService }, { type: undefined, decorators: [{
152
- type: Optional
153
- }, {
154
- type: Inject,
155
- args: [SUPPRESS_UNSAVED_CHANGES_WARNING]
156
- }] }, { type: i3.NgbModal }, { type: i4.ModalRefService }]; }, propDecorators: { visible: [{
157
- type: Input
158
- }], busy: [{
159
- type: Input
160
- }], options: [{
161
- type: Input
162
- }], suppressUnsavedChangesWarning: [{
163
- type: Input
164
- }], modalContent: [{
165
- type: ViewChild,
166
- args: ['modalContent']
167
- }], abpHeader: [{
168
- type: ContentChild,
169
- args: ['abpHeader', { static: false }]
170
- }], abpBody: [{
171
- type: ContentChild,
172
- args: ['abpBody', { static: false }]
173
- }], abpFooter: [{
174
- type: ContentChild,
175
- args: ['abpFooter', { static: false }]
176
- }], abpSubmit: [{
177
- type: ContentChild,
178
- args: [ButtonComponent, { static: false, read: ButtonComponent }]
179
- }], visibleChange: [{
180
- type: Output
181
- }], init: [{
182
- type: Output
183
- }], appear: [{
184
- type: Output
185
- }], disappear: [{
186
- type: Output
187
- }] } });
188
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.component.js","sourceRoot":"","sources":["../../../../../../../packages/theme-shared/src/lib/components/modal/modal.component.ts","../../../../../../../packages/theme-shared/src/lib/components/modal/modal.component.html"],"names":[],"mappings":"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","sourcesContent":["import { SubscriptionService, uuid } from '@abp/ng.core';\r\nimport {\r\n  Component,\r\n  ContentChild,\r\n  EventEmitter,\r\n  Inject,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  Optional,\r\n  Output,\r\n  TemplateRef,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport { NgbModal, NgbModalOptions, NgbModalRef } from '@ng-bootstrap/ng-bootstrap';\r\nimport { fromEvent, Subject } from 'rxjs';\r\nimport { debounceTime, distinctUntilChanged, filter, takeUntil } from 'rxjs/operators';\r\nimport { Confirmation } from '../../models/confirmation';\r\nimport { ConfirmationService } from '../../services/confirmation.service';\r\nimport { SUPPRESS_UNSAVED_CHANGES_WARNING } from '../../tokens/suppress-unsaved-changes-warning.token';\r\nimport { ButtonComponent } from '../button/button.component';\r\nimport { DismissableModal, ModalDismissMode, ModalRefService } from './modal-ref.service';\r\n\r\nexport type ModalSize = 'sm' | 'md' | 'lg' | 'xl';\r\n\r\n@Component({\r\n  selector: 'abp-modal',\r\n  templateUrl: './modal.component.html',\r\n  styleUrls: ['./modal.component.scss'],\r\n  providers: [SubscriptionService],\r\n})\r\nexport class ModalComponent implements OnInit, OnDestroy, DismissableModal {\r\n  @Input()\r\n  get visible(): boolean {\r\n    return this._visible;\r\n  }\r\n  set visible(value: boolean) {\r\n    if (typeof value !== 'boolean') return;\r\n    this.toggle$.next(value);\r\n  }\r\n\r\n  @Input()\r\n  get busy(): boolean {\r\n    return this._busy;\r\n  }\r\n  set busy(value: boolean) {\r\n    if (this.abpSubmit && this.abpSubmit instanceof ButtonComponent) {\r\n      this.abpSubmit.loading = value;\r\n    }\r\n\r\n    this._busy = value;\r\n  }\r\n\r\n  @Input() options: NgbModalOptions = {};\r\n\r\n  @Input() suppressUnsavedChangesWarning = this.suppressUnsavedChangesWarningToken;\r\n\r\n  @ViewChild('modalContent') modalContent?: TemplateRef<any>;\r\n\r\n  @ContentChild('abpHeader', { static: false }) abpHeader?: TemplateRef<any>;\r\n\r\n  @ContentChild('abpBody', { static: false }) abpBody?: TemplateRef<any>;\r\n\r\n  @ContentChild('abpFooter', { static: false }) abpFooter?: TemplateRef<any>;\r\n\r\n  @ContentChild(ButtonComponent, { static: false, read: ButtonComponent })\r\n  abpSubmit?: ButtonComponent;\r\n\r\n  @Output() readonly visibleChange = new EventEmitter<boolean>();\r\n\r\n  @Output() readonly init = new EventEmitter<void>();\r\n\r\n  @Output() readonly appear = new EventEmitter<void>();\r\n\r\n  @Output() readonly disappear = new EventEmitter<void>();\r\n\r\n  _visible = false;\r\n\r\n  _busy = false;\r\n\r\n  modalRef!: NgbModalRef;\r\n\r\n  isConfirmationOpen = false;\r\n\r\n  destroy$ = new Subject<void>();\r\n\r\n  modalIdentifier = `modal-${uuid()}`;\r\n\r\n  private toggle$ = new Subject<boolean>();\r\n\r\n  get modalWindowRef() {\r\n    return document.querySelector(`ngb-modal-window.${this.modalIdentifier}`);\r\n  }\r\n\r\n  get isFormDirty(): boolean {\r\n    return Boolean(this.modalWindowRef?.querySelector('.ng-dirty'));\r\n  }\r\n\r\n  constructor(\r\n    private confirmationService: ConfirmationService,\r\n    private subscription: SubscriptionService,\r\n    @Optional()\r\n    @Inject(SUPPRESS_UNSAVED_CHANGES_WARNING)\r\n    private suppressUnsavedChangesWarningToken: boolean,\r\n    private modal: NgbModal,\r\n    private modalRefService: ModalRefService,\r\n  ) {\r\n    this.initToggleStream();\r\n  }\r\n  ngOnInit(): void {\r\n    this.modalRefService.register(this);\r\n  }\r\n\r\n  dismiss(mode: ModalDismissMode) {\r\n    switch (mode) {\r\n      case 'hard':\r\n        this.visible = false;\r\n        break;\r\n      case 'soft':\r\n        this.close();\r\n        break;\r\n      default:\r\n        break;\r\n    }\r\n  }\r\n\r\n  private initToggleStream() {\r\n    this.subscription.addOne(this.toggle$.pipe(debounceTime(0), distinctUntilChanged()), value =>\r\n      this.toggle(value),\r\n    );\r\n  }\r\n\r\n  private toggle(value: boolean) {\r\n    this._visible = value;\r\n    this.visibleChange.emit(value);\r\n\r\n    if (!value) {\r\n      this.modalRef?.dismiss();\r\n      this.disappear.emit();\r\n      this.destroy$.next();\r\n      return;\r\n    }\r\n\r\n    setTimeout(() => this.listen(), 0);\r\n    this.modalRef = this.modal.open(this.modalContent, {\r\n      size: 'md',\r\n      centered: false,\r\n      keyboard: false,\r\n      scrollable: true,\r\n      beforeDismiss: () => {\r\n        if (!this.visible) return true;\r\n\r\n        this.close();\r\n        return !this.visible;\r\n      },\r\n      ...this.options,\r\n      windowClass: `${this.options.windowClass || ''} ${this.modalIdentifier}`,\r\n    });\r\n\r\n    this.appear.emit();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.modalRefService.unregister(this);\r\n    this.toggle(false);\r\n    this.destroy$.next();\r\n  }\r\n\r\n  close() {\r\n    if (this.busy) return;\r\n\r\n    if (this.isFormDirty && !this.suppressUnsavedChangesWarning) {\r\n      if (this.isConfirmationOpen) return;\r\n\r\n      this.isConfirmationOpen = true;\r\n      this.confirmationService\r\n        .warn(\r\n          'AbpUi::AreYouSureYouWantToCancelEditingWarningMessage',\r\n          'AbpUi::AreYouSure',\r\n          { dismissible: false },\r\n        )\r\n        .subscribe((status: Confirmation.Status) => {\r\n          this.isConfirmationOpen = false;\r\n          if (status === Confirmation.Status.confirm) {\r\n            this.visible = false;\r\n          }\r\n        });\r\n    } else {\r\n      this.visible = false;\r\n    }\r\n  }\r\n\r\n  listen() {\r\n    if (this.modalWindowRef) {\r\n      fromEvent<KeyboardEvent>(this.modalWindowRef, 'keyup')\r\n        .pipe(\r\n          takeUntil(this.destroy$),\r\n          debounceTime(150),\r\n          filter((key: KeyboardEvent) => key && key.key === 'Escape'),\r\n        )\r\n        .subscribe(() => this.close());\r\n    }\r\n\r\n    fromEvent(window, 'beforeunload')\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe(event => {\r\n        // TODO: check this\r\n        if (!this.isFormDirty || this.suppressUnsavedChangesWarning) {\r\n          event.preventDefault();\r\n        }\r\n      });\r\n\r\n    this.init.emit();\r\n  }\r\n}\r\n","<ng-content></ng-content>\r\n\r\n<ng-template #modalContent let-modal>\r\n  <div *ngIf=\"abpHeader\" id=\"abp-modal-header\" class=\"modal-header\">\r\n    <ng-container *ngTemplateOutlet=\"abpHeader\"></ng-container>\r\n    ​\r\n    <button\r\n      id=\"abp-modal-close-button\"\r\n      type=\"button\"\r\n      class=\"btn-sm btn-close\"\r\n      aria-label=\"Close\"\r\n      (click)=\"modal.dismiss()\"\r\n    ></button>\r\n  </div>\r\n  <div *ngIf=\"abpBody\" id=\"abp-modal-body\" class=\"modal-body\">\r\n    <ng-container *ngTemplateOutlet=\"abpBody\"></ng-container>\r\n  </div>\r\n  <div *ngIf=\"abpFooter\" id=\"abp-modal-footer\" class=\"modal-footer\">\r\n    <ng-container *ngTemplateOutlet=\"abpFooter\"></ng-container>\r\n  </div>\r\n</ng-template>\r\n"]}
1
+ import { SubscriptionService, uuid } from '@abp/ng.core';
2
+ import { Component, ContentChild, EventEmitter, Inject, Input, Optional, Output, TemplateRef, ViewChild, } from '@angular/core';
3
+ import { NgbModal } from '@ng-bootstrap/ng-bootstrap';
4
+ import { fromEvent, Subject } from 'rxjs';
5
+ import { debounceTime, distinctUntilChanged, filter, takeUntil } from 'rxjs/operators';
6
+ import { Confirmation } from '../../models/confirmation';
7
+ import { ConfirmationService } from '../../services/confirmation.service';
8
+ import { SUPPRESS_UNSAVED_CHANGES_WARNING } from '../../tokens/suppress-unsaved-changes-warning.token';
9
+ import { ButtonComponent } from '../button/button.component';
10
+ import { ModalRefService } from './modal-ref.service';
11
+ import * as i0 from "@angular/core";
12
+ import * as i1 from "../../services/confirmation.service";
13
+ import * as i2 from "@abp/ng.core";
14
+ import * as i3 from "@ng-bootstrap/ng-bootstrap";
15
+ import * as i4 from "./modal-ref.service";
16
+ import * as i5 from "@angular/common";
17
+ export class ModalComponent {
18
+ constructor(confirmationService, subscription, suppressUnsavedChangesWarningToken, modal, modalRefService) {
19
+ this.confirmationService = confirmationService;
20
+ this.subscription = subscription;
21
+ this.suppressUnsavedChangesWarningToken = suppressUnsavedChangesWarningToken;
22
+ this.modal = modal;
23
+ this.modalRefService = modalRefService;
24
+ this.options = {};
25
+ this.suppressUnsavedChangesWarning = this.suppressUnsavedChangesWarningToken;
26
+ this.visibleChange = new EventEmitter();
27
+ this.init = new EventEmitter();
28
+ this.appear = new EventEmitter();
29
+ this.disappear = new EventEmitter();
30
+ this._visible = false;
31
+ this._busy = false;
32
+ this.isConfirmationOpen = false;
33
+ this.destroy$ = new Subject();
34
+ this.modalIdentifier = `modal-${uuid()}`;
35
+ this.toggle$ = new Subject();
36
+ this.initToggleStream();
37
+ }
38
+ get visible() {
39
+ return this._visible;
40
+ }
41
+ set visible(value) {
42
+ if (typeof value !== 'boolean')
43
+ return;
44
+ this.toggle$.next(value);
45
+ }
46
+ get busy() {
47
+ return this._busy;
48
+ }
49
+ set busy(value) {
50
+ if (this.abpSubmit && this.abpSubmit instanceof ButtonComponent) {
51
+ this.abpSubmit.loading = value;
52
+ }
53
+ this._busy = value;
54
+ }
55
+ get modalWindowRef() {
56
+ return document.querySelector(`ngb-modal-window.${this.modalIdentifier}`);
57
+ }
58
+ get isFormDirty() {
59
+ var _a;
60
+ return Boolean((_a = this.modalWindowRef) === null || _a === void 0 ? void 0 : _a.querySelector('.ng-dirty'));
61
+ }
62
+ ngOnInit() {
63
+ this.modalRefService.register(this);
64
+ }
65
+ dismiss(mode) {
66
+ switch (mode) {
67
+ case 'hard':
68
+ this.visible = false;
69
+ break;
70
+ case 'soft':
71
+ this.close();
72
+ break;
73
+ default:
74
+ break;
75
+ }
76
+ }
77
+ initToggleStream() {
78
+ this.subscription.addOne(this.toggle$.pipe(debounceTime(0), distinctUntilChanged()), value => this.toggle(value));
79
+ }
80
+ toggle(value) {
81
+ var _a;
82
+ this._visible = value;
83
+ this.visibleChange.emit(value);
84
+ if (!value) {
85
+ (_a = this.modalRef) === null || _a === void 0 ? void 0 : _a.dismiss();
86
+ this.disappear.emit();
87
+ this.destroy$.next();
88
+ return;
89
+ }
90
+ setTimeout(() => this.listen(), 0);
91
+ this.modalRef = this.modal.open(this.modalContent, Object.assign(Object.assign({ size: 'md', centered: false, keyboard: false, scrollable: true, beforeDismiss: () => {
92
+ if (!this.visible)
93
+ return true;
94
+ this.close();
95
+ return !this.visible;
96
+ } }, this.options), { windowClass: `${this.options.windowClass || ''} ${this.modalIdentifier}` }));
97
+ this.appear.emit();
98
+ }
99
+ ngOnDestroy() {
100
+ this.modalRefService.unregister(this);
101
+ this.toggle(false);
102
+ this.destroy$.next();
103
+ }
104
+ close() {
105
+ if (this.busy)
106
+ return;
107
+ if (this.isFormDirty && !this.suppressUnsavedChangesWarning) {
108
+ if (this.isConfirmationOpen)
109
+ return;
110
+ this.isConfirmationOpen = true;
111
+ this.confirmationService
112
+ .warn('AbpUi::AreYouSureYouWantToCancelEditingWarningMessage', 'AbpUi::AreYouSure', { dismissible: false })
113
+ .subscribe((status) => {
114
+ this.isConfirmationOpen = false;
115
+ if (status === Confirmation.Status.confirm) {
116
+ this.visible = false;
117
+ }
118
+ });
119
+ }
120
+ else {
121
+ this.visible = false;
122
+ }
123
+ }
124
+ listen() {
125
+ if (this.modalWindowRef) {
126
+ fromEvent(this.modalWindowRef, 'keyup')
127
+ .pipe(takeUntil(this.destroy$), debounceTime(150), filter((key) => key && key.key === 'Escape'))
128
+ .subscribe(() => this.close());
129
+ }
130
+ fromEvent(window, 'beforeunload')
131
+ .pipe(takeUntil(this.destroy$))
132
+ .subscribe(event => {
133
+ // TODO: check this
134
+ if (!this.isFormDirty || this.suppressUnsavedChangesWarning) {
135
+ event.preventDefault();
136
+ }
137
+ });
138
+ this.init.emit();
139
+ }
140
+ }
141
+ ModalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.13", ngImport: i0, type: ModalComponent, deps: [{ token: i1.ConfirmationService }, { token: i2.SubscriptionService }, { token: SUPPRESS_UNSAVED_CHANGES_WARNING, optional: true }, { token: i3.NgbModal }, { token: i4.ModalRefService }], target: i0.ɵɵFactoryTarget.Component });
142
+ ModalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.13", type: ModalComponent, selector: "abp-modal", inputs: { visible: "visible", busy: "busy", options: "options", suppressUnsavedChangesWarning: "suppressUnsavedChangesWarning" }, outputs: { visibleChange: "visibleChange", init: "init", appear: "appear", disappear: "disappear" }, providers: [SubscriptionService], queries: [{ propertyName: "abpHeader", first: true, predicate: ["abpHeader"], descendants: true }, { propertyName: "abpBody", first: true, predicate: ["abpBody"], descendants: true }, { propertyName: "abpFooter", first: true, predicate: ["abpFooter"], descendants: true }, { propertyName: "abpSubmit", first: true, predicate: ButtonComponent, descendants: true, read: ButtonComponent }], viewQueries: [{ propertyName: "modalContent", first: true, predicate: ["modalContent"], descendants: true }], ngImport: i0, template: "<ng-content></ng-content>\n\n<ng-template #modalContent let-modal>\n <div *ngIf=\"abpHeader\" id=\"abp-modal-header\" class=\"modal-header\">\n <ng-container *ngTemplateOutlet=\"abpHeader\"></ng-container>\n \u200B\n <button\n id=\"abp-modal-close-button\"\n type=\"button\"\n class=\"btn-sm btn-close\"\n aria-label=\"Close\"\n (click)=\"modal.dismiss()\"\n ></button>\n </div>\n <div *ngIf=\"abpBody\" id=\"abp-modal-body\" class=\"modal-body\">\n <ng-container *ngTemplateOutlet=\"abpBody\"></ng-container>\n </div>\n <div *ngIf=\"abpFooter\" id=\"abp-modal-footer\" class=\"modal-footer\">\n <ng-container *ngTemplateOutlet=\"abpFooter\"></ng-container>\n </div>\n</ng-template>\n", styles: [".modal.show{display:block!important}.modal-backdrop{opacity:.8}.modal::-webkit-scrollbar{width:7px}.modal::-webkit-scrollbar-track{background:#ddd}.modal::-webkit-scrollbar-thumb{background:#8a8686}.modal-dialog{z-index:1050}\n"], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }] });
143
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.13", ngImport: i0, type: ModalComponent, decorators: [{
144
+ type: Component,
145
+ args: [{
146
+ selector: 'abp-modal',
147
+ templateUrl: './modal.component.html',
148
+ styleUrls: ['./modal.component.scss'],
149
+ providers: [SubscriptionService],
150
+ }]
151
+ }], ctorParameters: function () { return [{ type: i1.ConfirmationService }, { type: i2.SubscriptionService }, { type: undefined, decorators: [{
152
+ type: Optional
153
+ }, {
154
+ type: Inject,
155
+ args: [SUPPRESS_UNSAVED_CHANGES_WARNING]
156
+ }] }, { type: i3.NgbModal }, { type: i4.ModalRefService }]; }, propDecorators: { visible: [{
157
+ type: Input
158
+ }], busy: [{
159
+ type: Input
160
+ }], options: [{
161
+ type: Input
162
+ }], suppressUnsavedChangesWarning: [{
163
+ type: Input
164
+ }], modalContent: [{
165
+ type: ViewChild,
166
+ args: ['modalContent']
167
+ }], abpHeader: [{
168
+ type: ContentChild,
169
+ args: ['abpHeader', { static: false }]
170
+ }], abpBody: [{
171
+ type: ContentChild,
172
+ args: ['abpBody', { static: false }]
173
+ }], abpFooter: [{
174
+ type: ContentChild,
175
+ args: ['abpFooter', { static: false }]
176
+ }], abpSubmit: [{
177
+ type: ContentChild,
178
+ args: [ButtonComponent, { static: false, read: ButtonComponent }]
179
+ }], visibleChange: [{
180
+ type: Output
181
+ }], init: [{
182
+ type: Output
183
+ }], appear: [{
184
+ type: Output
185
+ }], disappear: [{
186
+ type: Output
187
+ }] } });
188
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.component.js","sourceRoot":"","sources":["../../../../../../../packages/theme-shared/src/lib/components/modal/modal.component.ts","../../../../../../../packages/theme-shared/src/lib/components/modal/modal.component.html"],"names":[],"mappings":"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","sourcesContent":["import { SubscriptionService, uuid } from '@abp/ng.core';\nimport {\n  Component,\n  ContentChild,\n  EventEmitter,\n  Inject,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core';\nimport { NgbModal, NgbModalOptions, NgbModalRef } from '@ng-bootstrap/ng-bootstrap';\nimport { fromEvent, Subject } from 'rxjs';\nimport { debounceTime, distinctUntilChanged, filter, takeUntil } from 'rxjs/operators';\nimport { Confirmation } from '../../models/confirmation';\nimport { ConfirmationService } from '../../services/confirmation.service';\nimport { SUPPRESS_UNSAVED_CHANGES_WARNING } from '../../tokens/suppress-unsaved-changes-warning.token';\nimport { ButtonComponent } from '../button/button.component';\nimport { DismissableModal, ModalDismissMode, ModalRefService } from './modal-ref.service';\n\nexport type ModalSize = 'sm' | 'md' | 'lg' | 'xl';\n\n@Component({\n  selector: 'abp-modal',\n  templateUrl: './modal.component.html',\n  styleUrls: ['./modal.component.scss'],\n  providers: [SubscriptionService],\n})\nexport class ModalComponent implements OnInit, OnDestroy, DismissableModal {\n  @Input()\n  get visible(): boolean {\n    return this._visible;\n  }\n  set visible(value: boolean) {\n    if (typeof value !== 'boolean') return;\n    this.toggle$.next(value);\n  }\n\n  @Input()\n  get busy(): boolean {\n    return this._busy;\n  }\n  set busy(value: boolean) {\n    if (this.abpSubmit && this.abpSubmit instanceof ButtonComponent) {\n      this.abpSubmit.loading = value;\n    }\n\n    this._busy = value;\n  }\n\n  @Input() options: NgbModalOptions = {};\n\n  @Input() suppressUnsavedChangesWarning = this.suppressUnsavedChangesWarningToken;\n\n  @ViewChild('modalContent') modalContent?: TemplateRef<any>;\n\n  @ContentChild('abpHeader', { static: false }) abpHeader?: TemplateRef<any>;\n\n  @ContentChild('abpBody', { static: false }) abpBody?: TemplateRef<any>;\n\n  @ContentChild('abpFooter', { static: false }) abpFooter?: TemplateRef<any>;\n\n  @ContentChild(ButtonComponent, { static: false, read: ButtonComponent })\n  abpSubmit?: ButtonComponent;\n\n  @Output() readonly visibleChange = new EventEmitter<boolean>();\n\n  @Output() readonly init = new EventEmitter<void>();\n\n  @Output() readonly appear = new EventEmitter<void>();\n\n  @Output() readonly disappear = new EventEmitter<void>();\n\n  _visible = false;\n\n  _busy = false;\n\n  modalRef!: NgbModalRef;\n\n  isConfirmationOpen = false;\n\n  destroy$ = new Subject<void>();\n\n  modalIdentifier = `modal-${uuid()}`;\n\n  private toggle$ = new Subject<boolean>();\n\n  get modalWindowRef() {\n    return document.querySelector(`ngb-modal-window.${this.modalIdentifier}`);\n  }\n\n  get isFormDirty(): boolean {\n    return Boolean(this.modalWindowRef?.querySelector('.ng-dirty'));\n  }\n\n  constructor(\n    private confirmationService: ConfirmationService,\n    private subscription: SubscriptionService,\n    @Optional()\n    @Inject(SUPPRESS_UNSAVED_CHANGES_WARNING)\n    private suppressUnsavedChangesWarningToken: boolean,\n    private modal: NgbModal,\n    private modalRefService: ModalRefService,\n  ) {\n    this.initToggleStream();\n  }\n  ngOnInit(): void {\n    this.modalRefService.register(this);\n  }\n\n  dismiss(mode: ModalDismissMode) {\n    switch (mode) {\n      case 'hard':\n        this.visible = false;\n        break;\n      case 'soft':\n        this.close();\n        break;\n      default:\n        break;\n    }\n  }\n\n  private initToggleStream() {\n    this.subscription.addOne(this.toggle$.pipe(debounceTime(0), distinctUntilChanged()), value =>\n      this.toggle(value),\n    );\n  }\n\n  private toggle(value: boolean) {\n    this._visible = value;\n    this.visibleChange.emit(value);\n\n    if (!value) {\n      this.modalRef?.dismiss();\n      this.disappear.emit();\n      this.destroy$.next();\n      return;\n    }\n\n    setTimeout(() => this.listen(), 0);\n    this.modalRef = this.modal.open(this.modalContent, {\n      size: 'md',\n      centered: false,\n      keyboard: false,\n      scrollable: true,\n      beforeDismiss: () => {\n        if (!this.visible) return true;\n\n        this.close();\n        return !this.visible;\n      },\n      ...this.options,\n      windowClass: `${this.options.windowClass || ''} ${this.modalIdentifier}`,\n    });\n\n    this.appear.emit();\n  }\n\n  ngOnDestroy(): void {\n    this.modalRefService.unregister(this);\n    this.toggle(false);\n    this.destroy$.next();\n  }\n\n  close() {\n    if (this.busy) return;\n\n    if (this.isFormDirty && !this.suppressUnsavedChangesWarning) {\n      if (this.isConfirmationOpen) return;\n\n      this.isConfirmationOpen = true;\n      this.confirmationService\n        .warn(\n          'AbpUi::AreYouSureYouWantToCancelEditingWarningMessage',\n          'AbpUi::AreYouSure',\n          { dismissible: false },\n        )\n        .subscribe((status: Confirmation.Status) => {\n          this.isConfirmationOpen = false;\n          if (status === Confirmation.Status.confirm) {\n            this.visible = false;\n          }\n        });\n    } else {\n      this.visible = false;\n    }\n  }\n\n  listen() {\n    if (this.modalWindowRef) {\n      fromEvent<KeyboardEvent>(this.modalWindowRef, 'keyup')\n        .pipe(\n          takeUntil(this.destroy$),\n          debounceTime(150),\n          filter((key: KeyboardEvent) => key && key.key === 'Escape'),\n        )\n        .subscribe(() => this.close());\n    }\n\n    fromEvent(window, 'beforeunload')\n      .pipe(takeUntil(this.destroy$))\n      .subscribe(event => {\n        // TODO: check this\n        if (!this.isFormDirty || this.suppressUnsavedChangesWarning) {\n          event.preventDefault();\n        }\n      });\n\n    this.init.emit();\n  }\n}\n","<ng-content></ng-content>\n\n<ng-template #modalContent let-modal>\n  <div *ngIf=\"abpHeader\" id=\"abp-modal-header\" class=\"modal-header\">\n    <ng-container *ngTemplateOutlet=\"abpHeader\"></ng-container>\n    ​\n    <button\n      id=\"abp-modal-close-button\"\n      type=\"button\"\n      class=\"btn-sm btn-close\"\n      aria-label=\"Close\"\n      (click)=\"modal.dismiss()\"\n    ></button>\n  </div>\n  <div *ngIf=\"abpBody\" id=\"abp-modal-body\" class=\"modal-body\">\n    <ng-container *ngTemplateOutlet=\"abpBody\"></ng-container>\n  </div>\n  <div *ngIf=\"abpFooter\" id=\"abp-modal-footer\" class=\"modal-footer\">\n    <ng-container *ngTemplateOutlet=\"abpFooter\"></ng-container>\n  </div>\n</ng-template>\n"]}
@@ -1,61 +1,61 @@
1
- import { Component, EventEmitter, Input, Output } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- import * as i1 from "@angular/common";
4
- import * as i2 from "@abp/ng.core";
5
- export class ToastComponent {
6
- constructor() {
7
- this.remove = new EventEmitter();
8
- }
9
- get severityClass() {
10
- if (!this.toast || !this.toast.severity)
11
- return '';
12
- return `abp-toast-${this.toast.severity}`;
13
- }
14
- get iconClass() {
15
- switch (this.toast.severity) {
16
- case 'success':
17
- return 'fa-check-circle';
18
- case 'info':
19
- return 'fa-info-circle';
20
- case 'warning':
21
- return 'fa-exclamation-triangle';
22
- case 'error':
23
- return 'fa-times-circle';
24
- default:
25
- return 'fa-exclamation-circle';
26
- }
27
- }
28
- ngOnInit() {
29
- const { sticky, life } = this.toast.options || {};
30
- if (sticky)
31
- return;
32
- const timeout = life || 5000;
33
- setTimeout(() => {
34
- this.close();
35
- }, timeout);
36
- }
37
- close() {
38
- var _a;
39
- this.remove.emit((_a = this.toast.options) === null || _a === void 0 ? void 0 : _a.id);
40
- }
41
- tap() {
42
- var _a;
43
- if ((_a = this.toast.options) === null || _a === void 0 ? void 0 : _a.tapToDismiss)
44
- this.close();
45
- }
46
- }
47
- ToastComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.13", ngImport: i0, type: ToastComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
48
- ToastComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.13", type: ToastComponent, selector: "abp-toast", inputs: { toast: "toast" }, outputs: { remove: "remove" }, ngImport: i0, template: "<div class=\"abp-toast\" [ngClass]=\"severityClass\" (click)=\"tap()\">\r\n <div class=\"abp-toast-icon\">\r\n <i class=\"fa icon\" [ngClass]=\"iconClass\"></i>\r\n </div>\r\n <div class=\"abp-toast-content\">\r\n <button class=\"abp-toast-close-button\" (click)=\"close()\" *ngIf=\"toast.options?.closable\">\r\n <i class=\"fa fa-times\"></i>\r\n </button>\r\n <div class=\"abp-toast-title\">\r\n {{ toast.title | abpLocalization: toast.options?.titleLocalizationParams }}\r\n </div>\r\n <p\r\n class=\"abp-toast-message\"\r\n [innerHTML]=\"toast.message | abpLocalization: toast.options?.messageLocalizationParams\"\r\n ></p>\r\n </div>\r\n</div>\r\n", styles: [".abp-toast{display:grid;grid-template-columns:50px 1fr;grid-gap:10px;gap:10px;margin:5px 0;padding:10px;border-radius:0;width:350px;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;z-index:9999;border:2px solid #f0f0f0;background-color:#f0f0f0;color:#000;box-shadow:0 0 10px -5px #0006;opacity:1}.abp-toast:hover{border:2px solid #e3e3e3;background-color:#e3e3e3;box-shadow:0 0 15px -5px #0006}.abp-toast.abp-toast-success{border:2px solid #51a351;background-color:#51a351;color:#fff;box-shadow:0 0 10px -5px #0006}.abp-toast.abp-toast-success:hover{border:2px solid #499249;background-color:#499249;box-shadow:0 0 15px -5px #0006}.abp-toast.abp-toast-info{border:2px solid #2f96b4;background-color:#2f96b4;color:#fff;box-shadow:0 0 10px -5px #0006}.abp-toast.abp-toast-info:hover{border:2px solid #2a85a0;background-color:#2a85a0;box-shadow:0 0 15px -5px #0006}.abp-toast.abp-toast-warning{border:2px solid #f89406;background-color:#f89406;color:#fff;box-shadow:0 0 10px -5px #0006}.abp-toast.abp-toast-warning:hover{border:2px solid #df8505;background-color:#df8505;box-shadow:0 0 15px -5px #0006}.abp-toast.abp-toast-error{border:2px solid #bd362f;background-color:#bd362f;color:#fff;box-shadow:0 0 10px -5px #0006}.abp-toast.abp-toast-error:hover{border:2px solid #a9302a;background-color:#a9302a;box-shadow:0 0 15px -5px #0006}.abp-toast .abp-toast-icon{display:flex;align-items:center;justify-content:center}.abp-toast .abp-toast-icon .icon{font-size:36px}.abp-toast .abp-toast-content{position:relative}.abp-toast .abp-toast-content .abp-toast-close-button{position:absolute;top:0;right:0;display:flex;align-items:center;justify-content:center;margin:0;padding:0 5px 0 0;width:25px;height:25px;border:none;border-radius:50%;background:transparent;color:inherit}.abp-toast .abp-toast-content .abp-toast-close-button:focus{outline:none}.abp-toast .abp-toast-content .abp-toast-title{margin:0;padding:0;font-size:1rem;font-weight:600}.abp-toast .abp-toast-content .abp-toast-message{margin:0;padding:0;max-width:240px}\n"], directives: [{ type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "abpLocalization": i2.LocalizationPipe } });
49
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.13", ngImport: i0, type: ToastComponent, decorators: [{
50
- type: Component,
51
- args: [{
52
- selector: 'abp-toast',
53
- templateUrl: './toast.component.html',
54
- styleUrls: ['./toast.component.scss'],
55
- }]
56
- }], propDecorators: { toast: [{
57
- type: Input
58
- }], remove: [{
59
- type: Output
60
- }] } });
61
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9hc3QuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvdGhlbWUtc2hhcmVkL3NyYy9saWIvY29tcG9uZW50cy90b2FzdC90b2FzdC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy90aGVtZS1zaGFyZWQvc3JjL2xpYi9jb21wb25lbnRzL3RvYXN0L3RvYXN0LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBVSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7Ozs7QUFPL0UsTUFBTSxPQUFPLGNBQWM7SUFMM0I7UUFTWSxXQUFNLEdBQUcsSUFBSSxZQUFZLEVBQVUsQ0FBQztLQXVDL0M7SUFyQ0MsSUFBSSxhQUFhO1FBQ2YsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVE7WUFBRSxPQUFPLEVBQUUsQ0FBQztRQUNuRCxPQUFPLGFBQWEsSUFBSSxDQUFDLEtBQUssQ0FBQyxRQUFRLEVBQUUsQ0FBQztJQUM1QyxDQUFDO0lBRUQsSUFBSSxTQUFTO1FBQ1gsUUFBUSxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsRUFBRTtZQUMzQixLQUFLLFNBQVM7Z0JBQ1osT0FBTyxpQkFBaUIsQ0FBQztZQUMzQixLQUFLLE1BQU07Z0JBQ1QsT0FBTyxnQkFBZ0IsQ0FBQztZQUMxQixLQUFLLFNBQVM7Z0JBQ1osT0FBTyx5QkFBeUIsQ0FBQztZQUNuQyxLQUFLLE9BQU87Z0JBQ1YsT0FBTyxpQkFBaUIsQ0FBQztZQUMzQjtnQkFDRSxPQUFPLHVCQUF1QixDQUFDO1NBQ2xDO0lBQ0gsQ0FBQztJQUVELFFBQVE7UUFDTixNQUFNLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxJQUFJLEVBQUUsQ0FBQztRQUVsRCxJQUFJLE1BQU07WUFBRSxPQUFPO1FBQ25CLE1BQU0sT0FBTyxHQUFHLElBQUksSUFBSSxJQUFJLENBQUM7UUFDN0IsVUFBVSxDQUFDLEdBQUcsRUFBRTtZQUNkLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUNmLENBQUMsRUFBRSxPQUFPLENBQUMsQ0FBQztJQUNkLENBQUM7SUFFRCxLQUFLOztRQUNILElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLE1BQUEsSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLDBDQUFFLEVBQUUsQ0FBQyxDQUFDO0lBQzNDLENBQUM7SUFFRCxHQUFHOztRQUNELElBQUksTUFBQSxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sMENBQUUsWUFBWTtZQUFFLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQztJQUNyRCxDQUFDOzs0R0ExQ1UsY0FBYztnR0FBZCxjQUFjLDRHQ1AzQiwyckJBaUJBOzRGRFZhLGNBQWM7a0JBTDFCLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLFdBQVc7b0JBQ3JCLFdBQVcsRUFBRSx3QkFBd0I7b0JBQ3JDLFNBQVMsRUFBRSxDQUFDLHdCQUF3QixDQUFDO2lCQUN0Qzs4QkFHQyxLQUFLO3NCQURKLEtBQUs7Z0JBR0ksTUFBTTtzQkFBZixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPbkluaXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBUb2FzdGVyIH0gZnJvbSAnLi4vLi4vbW9kZWxzL3RvYXN0ZXInO1xyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2FicC10b2FzdCcsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL3RvYXN0LmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi90b2FzdC5jb21wb25lbnQuc2NzcyddLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgVG9hc3RDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xyXG4gIEBJbnB1dCgpXHJcbiAgdG9hc3QhOiBUb2FzdGVyLlRvYXN0O1xyXG5cclxuICBAT3V0cHV0KCkgcmVtb3ZlID0gbmV3IEV2ZW50RW1pdHRlcjxudW1iZXI+KCk7XHJcblxyXG4gIGdldCBzZXZlcml0eUNsYXNzKCk6IHN0cmluZyB7XHJcbiAgICBpZiAoIXRoaXMudG9hc3QgfHwgIXRoaXMudG9hc3Quc2V2ZXJpdHkpIHJldHVybiAnJztcclxuICAgIHJldHVybiBgYWJwLXRvYXN0LSR7dGhpcy50b2FzdC5zZXZlcml0eX1gO1xyXG4gIH1cclxuXHJcbiAgZ2V0IGljb25DbGFzcygpOiBzdHJpbmcge1xyXG4gICAgc3dpdGNoICh0aGlzLnRvYXN0LnNldmVyaXR5KSB7XHJcbiAgICAgIGNhc2UgJ3N1Y2Nlc3MnOlxyXG4gICAgICAgIHJldHVybiAnZmEtY2hlY2stY2lyY2xlJztcclxuICAgICAgY2FzZSAnaW5mbyc6XHJcbiAgICAgICAgcmV0dXJuICdmYS1pbmZvLWNpcmNsZSc7XHJcbiAgICAgIGNhc2UgJ3dhcm5pbmcnOlxyXG4gICAgICAgIHJldHVybiAnZmEtZXhjbGFtYXRpb24tdHJpYW5nbGUnO1xyXG4gICAgICBjYXNlICdlcnJvcic6XHJcbiAgICAgICAgcmV0dXJuICdmYS10aW1lcy1jaXJjbGUnO1xyXG4gICAgICBkZWZhdWx0OlxyXG4gICAgICAgIHJldHVybiAnZmEtZXhjbGFtYXRpb24tY2lyY2xlJztcclxuICAgIH1cclxuICB9XHJcblxyXG4gIG5nT25Jbml0KCkge1xyXG4gICAgY29uc3QgeyBzdGlja3ksIGxpZmUgfSA9IHRoaXMudG9hc3Qub3B0aW9ucyB8fCB7fTtcclxuXHJcbiAgICBpZiAoc3RpY2t5KSByZXR1cm47XHJcbiAgICBjb25zdCB0aW1lb3V0ID0gbGlmZSB8fCA1MDAwO1xyXG4gICAgc2V0VGltZW91dCgoKSA9PiB7XHJcbiAgICAgIHRoaXMuY2xvc2UoKTtcclxuICAgIH0sIHRpbWVvdXQpO1xyXG4gIH1cclxuXHJcbiAgY2xvc2UoKSB7XHJcbiAgICB0aGlzLnJlbW92ZS5lbWl0KHRoaXMudG9hc3Qub3B0aW9ucz8uaWQpO1xyXG4gIH1cclxuXHJcbiAgdGFwKCkge1xyXG4gICAgaWYgKHRoaXMudG9hc3Qub3B0aW9ucz8udGFwVG9EaXNtaXNzKSB0aGlzLmNsb3NlKCk7XHJcbiAgfVxyXG59XHJcbiIsIjxkaXYgY2xhc3M9XCJhYnAtdG9hc3RcIiBbbmdDbGFzc109XCJzZXZlcml0eUNsYXNzXCIgKGNsaWNrKT1cInRhcCgpXCI+XHJcbiAgPGRpdiBjbGFzcz1cImFicC10b2FzdC1pY29uXCI+XHJcbiAgICA8aSBjbGFzcz1cImZhIGljb25cIiBbbmdDbGFzc109XCJpY29uQ2xhc3NcIj48L2k+XHJcbiAgPC9kaXY+XHJcbiAgPGRpdiBjbGFzcz1cImFicC10b2FzdC1jb250ZW50XCI+XHJcbiAgICA8YnV0dG9uIGNsYXNzPVwiYWJwLXRvYXN0LWNsb3NlLWJ1dHRvblwiIChjbGljayk9XCJjbG9zZSgpXCIgKm5nSWY9XCJ0b2FzdC5vcHRpb25zPy5jbG9zYWJsZVwiPlxyXG4gICAgICA8aSBjbGFzcz1cImZhIGZhLXRpbWVzXCI+PC9pPlxyXG4gICAgPC9idXR0b24+XHJcbiAgICA8ZGl2IGNsYXNzPVwiYWJwLXRvYXN0LXRpdGxlXCI+XHJcbiAgICAgIHt7IHRvYXN0LnRpdGxlIHwgYWJwTG9jYWxpemF0aW9uOiB0b2FzdC5vcHRpb25zPy50aXRsZUxvY2FsaXphdGlvblBhcmFtcyB9fVxyXG4gICAgPC9kaXY+XHJcbiAgICA8cFxyXG4gICAgICBjbGFzcz1cImFicC10b2FzdC1tZXNzYWdlXCJcclxuICAgICAgW2lubmVySFRNTF09XCJ0b2FzdC5tZXNzYWdlIHwgYWJwTG9jYWxpemF0aW9uOiB0b2FzdC5vcHRpb25zPy5tZXNzYWdlTG9jYWxpemF0aW9uUGFyYW1zXCJcclxuICAgID48L3A+XHJcbiAgPC9kaXY+XHJcbjwvZGl2PlxyXG4iXX0=
1
+ import { Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "@angular/common";
4
+ import * as i2 from "@abp/ng.core";
5
+ export class ToastComponent {
6
+ constructor() {
7
+ this.remove = new EventEmitter();
8
+ }
9
+ get severityClass() {
10
+ if (!this.toast || !this.toast.severity)
11
+ return '';
12
+ return `abp-toast-${this.toast.severity}`;
13
+ }
14
+ get iconClass() {
15
+ switch (this.toast.severity) {
16
+ case 'success':
17
+ return 'fa-check-circle';
18
+ case 'info':
19
+ return 'fa-info-circle';
20
+ case 'warning':
21
+ return 'fa-exclamation-triangle';
22
+ case 'error':
23
+ return 'fa-times-circle';
24
+ default:
25
+ return 'fa-exclamation-circle';
26
+ }
27
+ }
28
+ ngOnInit() {
29
+ const { sticky, life } = this.toast.options || {};
30
+ if (sticky)
31
+ return;
32
+ const timeout = life || 5000;
33
+ setTimeout(() => {
34
+ this.close();
35
+ }, timeout);
36
+ }
37
+ close() {
38
+ var _a;
39
+ this.remove.emit((_a = this.toast.options) === null || _a === void 0 ? void 0 : _a.id);
40
+ }
41
+ tap() {
42
+ var _a;
43
+ if ((_a = this.toast.options) === null || _a === void 0 ? void 0 : _a.tapToDismiss)
44
+ this.close();
45
+ }
46
+ }
47
+ ToastComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.13", ngImport: i0, type: ToastComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
48
+ ToastComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.13", type: ToastComponent, selector: "abp-toast", inputs: { toast: "toast" }, outputs: { remove: "remove" }, ngImport: i0, template: "<div class=\"abp-toast\" [ngClass]=\"severityClass\" (click)=\"tap()\">\n <div class=\"abp-toast-icon\">\n <i class=\"fa icon\" [ngClass]=\"iconClass\"></i>\n </div>\n <div class=\"abp-toast-content\">\n <button class=\"abp-toast-close-button\" (click)=\"close()\" *ngIf=\"toast.options?.closable\">\n <i class=\"fa fa-times\"></i>\n </button>\n <div class=\"abp-toast-title\">\n {{ toast.title | abpLocalization: toast.options?.titleLocalizationParams }}\n </div>\n <p\n class=\"abp-toast-message\"\n [innerHTML]=\"toast.message | abpLocalization: toast.options?.messageLocalizationParams\"\n ></p>\n </div>\n</div>\n", styles: [".abp-toast{display:grid;grid-template-columns:50px 1fr;grid-gap:10px;gap:10px;margin:5px 0;padding:10px;border-radius:0;width:350px;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;z-index:9999;border:2px solid #f0f0f0;background-color:#f0f0f0;color:#000;box-shadow:0 0 10px -5px #0006;opacity:1}.abp-toast:hover{border:2px solid #e3e3e3;background-color:#e3e3e3;box-shadow:0 0 15px -5px #0006}.abp-toast.abp-toast-success{border:2px solid #51a351;background-color:#51a351;color:#fff;box-shadow:0 0 10px -5px #0006}.abp-toast.abp-toast-success:hover{border:2px solid #499249;background-color:#499249;box-shadow:0 0 15px -5px #0006}.abp-toast.abp-toast-info{border:2px solid #2f96b4;background-color:#2f96b4;color:#fff;box-shadow:0 0 10px -5px #0006}.abp-toast.abp-toast-info:hover{border:2px solid #2a85a0;background-color:#2a85a0;box-shadow:0 0 15px -5px #0006}.abp-toast.abp-toast-warning{border:2px solid #f89406;background-color:#f89406;color:#fff;box-shadow:0 0 10px -5px #0006}.abp-toast.abp-toast-warning:hover{border:2px solid #df8505;background-color:#df8505;box-shadow:0 0 15px -5px #0006}.abp-toast.abp-toast-error{border:2px solid #bd362f;background-color:#bd362f;color:#fff;box-shadow:0 0 10px -5px #0006}.abp-toast.abp-toast-error:hover{border:2px solid #a9302a;background-color:#a9302a;box-shadow:0 0 15px -5px #0006}.abp-toast .abp-toast-icon{display:flex;align-items:center;justify-content:center}.abp-toast .abp-toast-icon .icon{font-size:36px}.abp-toast .abp-toast-content{position:relative}.abp-toast .abp-toast-content .abp-toast-close-button{position:absolute;top:0;right:0;display:flex;align-items:center;justify-content:center;margin:0;padding:0 5px 0 0;width:25px;height:25px;border:none;border-radius:50%;background:transparent;color:inherit}.abp-toast .abp-toast-content .abp-toast-close-button:focus{outline:none}.abp-toast .abp-toast-content .abp-toast-title{margin:0;padding:0;font-size:1rem;font-weight:600}.abp-toast .abp-toast-content .abp-toast-message{margin:0;padding:0;max-width:240px}\n"], directives: [{ type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "abpLocalization": i2.LocalizationPipe } });
49
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.13", ngImport: i0, type: ToastComponent, decorators: [{
50
+ type: Component,
51
+ args: [{
52
+ selector: 'abp-toast',
53
+ templateUrl: './toast.component.html',
54
+ styleUrls: ['./toast.component.scss'],
55
+ }]
56
+ }], propDecorators: { toast: [{
57
+ type: Input
58
+ }], remove: [{
59
+ type: Output
60
+ }] } });
61
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9hc3QuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvdGhlbWUtc2hhcmVkL3NyYy9saWIvY29tcG9uZW50cy90b2FzdC90b2FzdC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy90aGVtZS1zaGFyZWQvc3JjL2xpYi9jb21wb25lbnRzL3RvYXN0L3RvYXN0LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBVSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7Ozs7QUFPL0UsTUFBTSxPQUFPLGNBQWM7SUFMM0I7UUFTWSxXQUFNLEdBQUcsSUFBSSxZQUFZLEVBQVUsQ0FBQztLQXVDL0M7SUFyQ0MsSUFBSSxhQUFhO1FBQ2YsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVE7WUFBRSxPQUFPLEVBQUUsQ0FBQztRQUNuRCxPQUFPLGFBQWEsSUFBSSxDQUFDLEtBQUssQ0FBQyxRQUFRLEVBQUUsQ0FBQztJQUM1QyxDQUFDO0lBRUQsSUFBSSxTQUFTO1FBQ1gsUUFBUSxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsRUFBRTtZQUMzQixLQUFLLFNBQVM7Z0JBQ1osT0FBTyxpQkFBaUIsQ0FBQztZQUMzQixLQUFLLE1BQU07Z0JBQ1QsT0FBTyxnQkFBZ0IsQ0FBQztZQUMxQixLQUFLLFNBQVM7Z0JBQ1osT0FBTyx5QkFBeUIsQ0FBQztZQUNuQyxLQUFLLE9BQU87Z0JBQ1YsT0FBTyxpQkFBaUIsQ0FBQztZQUMzQjtnQkFDRSxPQUFPLHVCQUF1QixDQUFDO1NBQ2xDO0lBQ0gsQ0FBQztJQUVELFFBQVE7UUFDTixNQUFNLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxJQUFJLEVBQUUsQ0FBQztRQUVsRCxJQUFJLE1BQU07WUFBRSxPQUFPO1FBQ25CLE1BQU0sT0FBTyxHQUFHLElBQUksSUFBSSxJQUFJLENBQUM7UUFDN0IsVUFBVSxDQUFDLEdBQUcsRUFBRTtZQUNkLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUNmLENBQUMsRUFBRSxPQUFPLENBQUMsQ0FBQztJQUNkLENBQUM7SUFFRCxLQUFLOztRQUNILElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLE1BQUEsSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLDBDQUFFLEVBQUUsQ0FBQyxDQUFDO0lBQzNDLENBQUM7SUFFRCxHQUFHOztRQUNELElBQUksTUFBQSxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sMENBQUUsWUFBWTtZQUFFLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQztJQUNyRCxDQUFDOzs0R0ExQ1UsY0FBYztnR0FBZCxjQUFjLDRHQ1AzQix5cEJBaUJBOzRGRFZhLGNBQWM7a0JBTDFCLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLFdBQVc7b0JBQ3JCLFdBQVcsRUFBRSx3QkFBd0I7b0JBQ3JDLFNBQVMsRUFBRSxDQUFDLHdCQUF3QixDQUFDO2lCQUN0Qzs4QkFHQyxLQUFLO3NCQURKLEtBQUs7Z0JBR0ksTUFBTTtzQkFBZixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPbkluaXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgVG9hc3RlciB9IGZyb20gJy4uLy4uL21vZGVscy90b2FzdGVyJztcbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2FicC10b2FzdCcsXG4gIHRlbXBsYXRlVXJsOiAnLi90b2FzdC5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL3RvYXN0LmNvbXBvbmVudC5zY3NzJ10sXG59KVxuZXhwb3J0IGNsYXNzIFRvYXN0Q29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgQElucHV0KClcbiAgdG9hc3QhOiBUb2FzdGVyLlRvYXN0O1xuXG4gIEBPdXRwdXQoKSByZW1vdmUgPSBuZXcgRXZlbnRFbWl0dGVyPG51bWJlcj4oKTtcblxuICBnZXQgc2V2ZXJpdHlDbGFzcygpOiBzdHJpbmcge1xuICAgIGlmICghdGhpcy50b2FzdCB8fCAhdGhpcy50b2FzdC5zZXZlcml0eSkgcmV0dXJuICcnO1xuICAgIHJldHVybiBgYWJwLXRvYXN0LSR7dGhpcy50b2FzdC5zZXZlcml0eX1gO1xuICB9XG5cbiAgZ2V0IGljb25DbGFzcygpOiBzdHJpbmcge1xuICAgIHN3aXRjaCAodGhpcy50b2FzdC5zZXZlcml0eSkge1xuICAgICAgY2FzZSAnc3VjY2Vzcyc6XG4gICAgICAgIHJldHVybiAnZmEtY2hlY2stY2lyY2xlJztcbiAgICAgIGNhc2UgJ2luZm8nOlxuICAgICAgICByZXR1cm4gJ2ZhLWluZm8tY2lyY2xlJztcbiAgICAgIGNhc2UgJ3dhcm5pbmcnOlxuICAgICAgICByZXR1cm4gJ2ZhLWV4Y2xhbWF0aW9uLXRyaWFuZ2xlJztcbiAgICAgIGNhc2UgJ2Vycm9yJzpcbiAgICAgICAgcmV0dXJuICdmYS10aW1lcy1jaXJjbGUnO1xuICAgICAgZGVmYXVsdDpcbiAgICAgICAgcmV0dXJuICdmYS1leGNsYW1hdGlvbi1jaXJjbGUnO1xuICAgIH1cbiAgfVxuXG4gIG5nT25Jbml0KCkge1xuICAgIGNvbnN0IHsgc3RpY2t5LCBsaWZlIH0gPSB0aGlzLnRvYXN0Lm9wdGlvbnMgfHwge307XG5cbiAgICBpZiAoc3RpY2t5KSByZXR1cm47XG4gICAgY29uc3QgdGltZW91dCA9IGxpZmUgfHwgNTAwMDtcbiAgICBzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgIHRoaXMuY2xvc2UoKTtcbiAgICB9LCB0aW1lb3V0KTtcbiAgfVxuXG4gIGNsb3NlKCkge1xuICAgIHRoaXMucmVtb3ZlLmVtaXQodGhpcy50b2FzdC5vcHRpb25zPy5pZCk7XG4gIH1cblxuICB0YXAoKSB7XG4gICAgaWYgKHRoaXMudG9hc3Qub3B0aW9ucz8udGFwVG9EaXNtaXNzKSB0aGlzLmNsb3NlKCk7XG4gIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJhYnAtdG9hc3RcIiBbbmdDbGFzc109XCJzZXZlcml0eUNsYXNzXCIgKGNsaWNrKT1cInRhcCgpXCI+XG4gIDxkaXYgY2xhc3M9XCJhYnAtdG9hc3QtaWNvblwiPlxuICAgIDxpIGNsYXNzPVwiZmEgaWNvblwiIFtuZ0NsYXNzXT1cImljb25DbGFzc1wiPjwvaT5cbiAgPC9kaXY+XG4gIDxkaXYgY2xhc3M9XCJhYnAtdG9hc3QtY29udGVudFwiPlxuICAgIDxidXR0b24gY2xhc3M9XCJhYnAtdG9hc3QtY2xvc2UtYnV0dG9uXCIgKGNsaWNrKT1cImNsb3NlKClcIiAqbmdJZj1cInRvYXN0Lm9wdGlvbnM/LmNsb3NhYmxlXCI+XG4gICAgICA8aSBjbGFzcz1cImZhIGZhLXRpbWVzXCI+PC9pPlxuICAgIDwvYnV0dG9uPlxuICAgIDxkaXYgY2xhc3M9XCJhYnAtdG9hc3QtdGl0bGVcIj5cbiAgICAgIHt7IHRvYXN0LnRpdGxlIHwgYWJwTG9jYWxpemF0aW9uOiB0b2FzdC5vcHRpb25zPy50aXRsZUxvY2FsaXphdGlvblBhcmFtcyB9fVxuICAgIDwvZGl2PlxuICAgIDxwXG4gICAgICBjbGFzcz1cImFicC10b2FzdC1tZXNzYWdlXCJcbiAgICAgIFtpbm5lckhUTUxdPVwidG9hc3QubWVzc2FnZSB8IGFicExvY2FsaXphdGlvbjogdG9hc3Qub3B0aW9ucz8ubWVzc2FnZUxvY2FsaXphdGlvblBhcmFtc1wiXG4gICAgPjwvcD5cbiAgPC9kaXY+XG48L2Rpdj5cbiJdfQ==