@abp/ng.theme.shared 8.2.1 → 8.3.0-rc.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/modal/modal.component.mjs +57 -106
- package/esm2022/lib/providers/index.mjs +2 -1
- package/esm2022/lib/providers/theme-shared-config.provider.mjs +117 -0
- package/esm2022/lib/theme-shared.module.mjs +10 -62
- package/esm2022/lib/tokens/index.mjs +2 -1
- package/fesm2022/abp-ng.theme.shared.mjs +230 -212
- package/fesm2022/abp-ng.theme.shared.mjs.map +1 -1
- package/lib/components/modal/modal.component.d.ts +22 -32
- package/lib/providers/index.d.ts +1 -0
- package/lib/providers/theme-shared-config.provider.d.ts +22 -0
- package/lib/theme-shared.module.d.ts +3 -0
- package/lib/tokens/index.d.ts +1 -0
- package/package.json +2 -2
|
@@ -1,64 +1,55 @@
|
|
|
1
1
|
import { SubscriptionService, uuid } from '@abp/ng.core';
|
|
2
|
-
import { Component,
|
|
2
|
+
import { Component, DestroyRef, contentChild, effect, inject, input, model, output, viewChild, } from '@angular/core';
|
|
3
|
+
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
3
4
|
import { NgbModal } from '@ng-bootstrap/ng-bootstrap';
|
|
4
|
-
import { fromEvent
|
|
5
|
-
import { debounceTime,
|
|
5
|
+
import { fromEvent } from 'rxjs';
|
|
6
|
+
import { debounceTime, filter } from 'rxjs/operators';
|
|
6
7
|
import { Confirmation } from '../../models/confirmation';
|
|
7
8
|
import { ConfirmationService } from '../../services/confirmation.service';
|
|
8
9
|
import { SUPPRESS_UNSAVED_CHANGES_WARNING } from '../../tokens/suppress-unsaved-changes-warning.token';
|
|
9
10
|
import { ButtonComponent } from '../button/button.component';
|
|
10
11
|
import { ModalRefService } from './modal-ref.service';
|
|
11
12
|
import * as i0 from "@angular/core";
|
|
12
|
-
import * as i1 from "
|
|
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";
|
|
13
|
+
import * as i1 from "@angular/common";
|
|
17
14
|
export class ModalComponent {
|
|
18
|
-
get visible() {
|
|
19
|
-
return this._visible;
|
|
20
|
-
}
|
|
21
|
-
set visible(value) {
|
|
22
|
-
if (typeof value !== 'boolean')
|
|
23
|
-
return;
|
|
24
|
-
this.toggle$.next(value);
|
|
25
|
-
}
|
|
26
|
-
get busy() {
|
|
27
|
-
return this._busy;
|
|
28
|
-
}
|
|
29
|
-
set busy(value) {
|
|
30
|
-
if (this.abpSubmit && this.abpSubmit instanceof ButtonComponent) {
|
|
31
|
-
this.abpSubmit.loading = value;
|
|
32
|
-
}
|
|
33
|
-
this._busy = value;
|
|
34
|
-
}
|
|
35
15
|
get modalWindowRef() {
|
|
36
16
|
return document.querySelector(`ngb-modal-window.${this.modalIdentifier}`);
|
|
37
17
|
}
|
|
38
18
|
get isFormDirty() {
|
|
39
19
|
return Boolean(this.modalWindowRef?.querySelector('.ng-dirty'));
|
|
40
20
|
}
|
|
41
|
-
constructor(
|
|
42
|
-
this.confirmationService =
|
|
43
|
-
this.
|
|
44
|
-
this.
|
|
45
|
-
this.
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
this.
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
21
|
+
constructor() {
|
|
22
|
+
this.confirmationService = inject(ConfirmationService);
|
|
23
|
+
this.modal = inject(NgbModal);
|
|
24
|
+
this.modalRefService = inject(ModalRefService);
|
|
25
|
+
this.suppressUnsavedChangesWarningToken = inject(SUPPRESS_UNSAVED_CHANGES_WARNING, {
|
|
26
|
+
optional: true,
|
|
27
|
+
});
|
|
28
|
+
this.destroyRef = inject(DestroyRef);
|
|
29
|
+
this.visible = model(false);
|
|
30
|
+
this.busy = input(false, {
|
|
31
|
+
transform: (value) => {
|
|
32
|
+
if (this.abpSubmit() && this.abpSubmit() instanceof ButtonComponent) {
|
|
33
|
+
this.abpSubmit().loading = value;
|
|
34
|
+
}
|
|
35
|
+
return value;
|
|
36
|
+
},
|
|
37
|
+
});
|
|
38
|
+
this.options = input({ keyboard: true });
|
|
39
|
+
this.suppressUnsavedChangesWarning = input(this.suppressUnsavedChangesWarningToken);
|
|
40
|
+
this.modalContent = viewChild('modalContent');
|
|
41
|
+
this.abpHeader = contentChild('abpHeader');
|
|
42
|
+
this.abpBody = contentChild('abpBody');
|
|
43
|
+
this.abpFooter = contentChild('abpFooter');
|
|
44
|
+
this.abpSubmit = contentChild(ButtonComponent, { read: ButtonComponent });
|
|
45
|
+
this.init = output();
|
|
46
|
+
this.appear = output();
|
|
47
|
+
this.disappear = output();
|
|
57
48
|
this.isConfirmationOpen = false;
|
|
58
|
-
this.destroy$ = new Subject();
|
|
59
49
|
this.modalIdentifier = `modal-${uuid()}`;
|
|
60
|
-
|
|
61
|
-
|
|
50
|
+
effect(() => {
|
|
51
|
+
this.toggle(this.visible());
|
|
52
|
+
});
|
|
62
53
|
}
|
|
63
54
|
ngOnInit() {
|
|
64
55
|
this.modalRefService.register(this);
|
|
@@ -66,7 +57,7 @@ export class ModalComponent {
|
|
|
66
57
|
dismiss(mode) {
|
|
67
58
|
switch (mode) {
|
|
68
59
|
case 'hard':
|
|
69
|
-
this.visible
|
|
60
|
+
this.visible.set(false);
|
|
70
61
|
break;
|
|
71
62
|
case 'soft':
|
|
72
63
|
this.close();
|
|
@@ -75,116 +66,76 @@ export class ModalComponent {
|
|
|
75
66
|
break;
|
|
76
67
|
}
|
|
77
68
|
}
|
|
78
|
-
initToggleStream() {
|
|
79
|
-
this.subscription.addOne(this.toggle$.pipe(debounceTime(0), distinctUntilChanged()), value => this.toggle(value));
|
|
80
|
-
}
|
|
81
69
|
toggle(value) {
|
|
82
|
-
this.
|
|
83
|
-
this.visibleChange.emit(value);
|
|
70
|
+
this.visible.set(value);
|
|
84
71
|
if (!value) {
|
|
85
72
|
this.modalRef?.dismiss();
|
|
86
73
|
this.disappear.emit();
|
|
87
|
-
this.destroy$.next();
|
|
88
74
|
return;
|
|
89
75
|
}
|
|
90
76
|
setTimeout(() => this.listen(), 0);
|
|
91
|
-
this.modalRef = this.modal.open(this.modalContent, {
|
|
77
|
+
this.modalRef = this.modal.open(this.modalContent(), {
|
|
92
78
|
size: 'md',
|
|
93
79
|
centered: false,
|
|
94
80
|
keyboard: false,
|
|
95
81
|
scrollable: true,
|
|
96
82
|
beforeDismiss: () => {
|
|
97
|
-
if (!this.visible)
|
|
83
|
+
if (!this.visible())
|
|
98
84
|
return true;
|
|
99
85
|
this.close();
|
|
100
|
-
return !this.visible;
|
|
86
|
+
return !this.visible();
|
|
101
87
|
},
|
|
102
|
-
...this.options,
|
|
103
|
-
windowClass: `${this.options.windowClass || ''} ${this.modalIdentifier}`,
|
|
88
|
+
...this.options(),
|
|
89
|
+
windowClass: `${this.options().windowClass || ''} ${this.modalIdentifier}`,
|
|
104
90
|
});
|
|
105
91
|
this.appear.emit();
|
|
106
92
|
}
|
|
107
93
|
ngOnDestroy() {
|
|
108
94
|
this.modalRefService.unregister(this);
|
|
109
95
|
this.toggle(false);
|
|
110
|
-
this.destroy$.next();
|
|
111
96
|
}
|
|
112
97
|
close() {
|
|
113
|
-
if (this.busy)
|
|
98
|
+
if (this.busy())
|
|
114
99
|
return;
|
|
115
|
-
if (this.isFormDirty && !this.suppressUnsavedChangesWarning) {
|
|
100
|
+
if (this.isFormDirty && !this.suppressUnsavedChangesWarning()) {
|
|
116
101
|
if (this.isConfirmationOpen)
|
|
117
102
|
return;
|
|
118
103
|
this.isConfirmationOpen = true;
|
|
119
104
|
this.confirmationService
|
|
120
|
-
.warn('AbpUi::AreYouSureYouWantToCancelEditingWarningMessage', 'AbpUi::AreYouSure', {
|
|
105
|
+
.warn('AbpUi::AreYouSureYouWantToCancelEditingWarningMessage', 'AbpUi::AreYouSure', {
|
|
106
|
+
dismissible: false,
|
|
107
|
+
})
|
|
121
108
|
.subscribe((status) => {
|
|
122
109
|
this.isConfirmationOpen = false;
|
|
123
110
|
if (status === Confirmation.Status.confirm) {
|
|
124
|
-
this.visible
|
|
111
|
+
this.visible.set(false);
|
|
125
112
|
}
|
|
126
113
|
});
|
|
127
114
|
}
|
|
128
115
|
else {
|
|
129
|
-
this.visible
|
|
116
|
+
this.visible.set(false);
|
|
130
117
|
}
|
|
131
118
|
}
|
|
132
119
|
listen() {
|
|
133
120
|
if (this.modalWindowRef) {
|
|
134
121
|
fromEvent(this.modalWindowRef, 'keyup')
|
|
135
|
-
.pipe(
|
|
122
|
+
.pipe(takeUntilDestroyed(this.destroyRef), debounceTime(150), filter((key) => key && key.key === 'Escape' && this.options().keyboard))
|
|
136
123
|
.subscribe(() => this.close());
|
|
137
124
|
}
|
|
138
125
|
fromEvent(window, 'beforeunload')
|
|
139
|
-
.pipe(
|
|
126
|
+
.pipe(takeUntilDestroyed(this.destroyRef))
|
|
140
127
|
.subscribe(event => {
|
|
141
|
-
if (this.isFormDirty && !this.suppressUnsavedChangesWarning) {
|
|
128
|
+
if (this.isFormDirty && !this.suppressUnsavedChangesWarning()) {
|
|
142
129
|
event.preventDefault();
|
|
143
130
|
}
|
|
144
131
|
});
|
|
145
132
|
this.init.emit();
|
|
146
133
|
}
|
|
147
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ModalComponent, deps: [
|
|
148
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: ModalComponent, selector: "abp-modal", inputs: { visible: "visible", busy: "busy", options: "options", suppressUnsavedChangesWarning: "suppressUnsavedChangesWarning" }, outputs: {
|
|
134
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ModalComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
135
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: ModalComponent, selector: "abp-modal", inputs: { visible: { classPropertyName: "visible", publicName: "visible", isSignal: true, isRequired: false, transformFunction: null }, busy: { classPropertyName: "busy", publicName: "busy", isSignal: true, isRequired: false, transformFunction: null }, options: { classPropertyName: "options", publicName: "options", isSignal: true, isRequired: false, transformFunction: null }, suppressUnsavedChangesWarning: { classPropertyName: "suppressUnsavedChangesWarning", publicName: "suppressUnsavedChangesWarning", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { visible: "visibleChange", init: "init", appear: "appear", disappear: "disappear" }, providers: [SubscriptionService], queries: [{ propertyName: "abpHeader", first: true, predicate: ["abpHeader"], descendants: true, isSignal: true }, { propertyName: "abpBody", first: true, predicate: ["abpBody"], descendants: true, isSignal: true }, { propertyName: "abpFooter", first: true, predicate: ["abpFooter"], descendants: true, isSignal: true }, { propertyName: "abpSubmit", first: true, predicate: ButtonComponent, descendants: true, read: ButtonComponent, isSignal: true }], viewQueries: [{ propertyName: "modalContent", first: true, predicate: ["modalContent"], descendants: true, isSignal: true }], ngImport: i0, template: "<ng-content></ng-content>\r\n\r\n<ng-template #modalContent let-modal>\r\n @if (abpHeader()) {\r\n <div id=\"abp-modal-header\" class=\"modal-header abp-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 }\r\n @if (abpBody()) {\r\n <div id=\"abp-modal-body\" class=\"modal-body\">\r\n <ng-container *ngTemplateOutlet=\"abpBody()\"></ng-container>\r\n </div>\r\n }\r\n @if (abpFooter()) {\r\n <div id=\"abp-modal-footer\" class=\"modal-footer\">\r\n <ng-container *ngTemplateOutlet=\"abpFooter()\"></ng-container>\r\n </div>\r\n }\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"], dependencies: [{ kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }] }); }
|
|
149
136
|
}
|
|
150
137
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ModalComponent, decorators: [{
|
|
151
138
|
type: Component,
|
|
152
|
-
args: [{ selector: 'abp-modal', providers: [SubscriptionService], template: "<ng-content></ng-content>\r\n\r\n<ng-template #modalContent let-modal>\r\n @if (abpHeader) {\r\n <div id=\"abp-modal-header\" class=\"modal-header abp-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 }\r\n @if (abpBody) {\r\n <div id=\"abp-modal-body\" class=\"modal-body\">\r\n <ng-container *ngTemplateOutlet=\"abpBody\"></ng-container>\r\n </div>\r\n }\r\n @if (abpFooter) {\r\n <div id=\"abp-modal-footer\" class=\"modal-footer\">\r\n <ng-container *ngTemplateOutlet=\"abpFooter\"></ng-container>\r\n </div>\r\n }\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"] }]
|
|
153
|
-
}], ctorParameters: () => [
|
|
154
|
-
type: Optional
|
|
155
|
-
}, {
|
|
156
|
-
type: Inject,
|
|
157
|
-
args: [SUPPRESS_UNSAVED_CHANGES_WARNING]
|
|
158
|
-
}] }, { type: i3.NgbModal }, { type: i4.ModalRefService }], propDecorators: { visible: [{
|
|
159
|
-
type: Input
|
|
160
|
-
}], busy: [{
|
|
161
|
-
type: Input
|
|
162
|
-
}], options: [{
|
|
163
|
-
type: Input
|
|
164
|
-
}], suppressUnsavedChangesWarning: [{
|
|
165
|
-
type: Input
|
|
166
|
-
}], modalContent: [{
|
|
167
|
-
type: ViewChild,
|
|
168
|
-
args: ['modalContent']
|
|
169
|
-
}], abpHeader: [{
|
|
170
|
-
type: ContentChild,
|
|
171
|
-
args: ['abpHeader', { static: false }]
|
|
172
|
-
}], abpBody: [{
|
|
173
|
-
type: ContentChild,
|
|
174
|
-
args: ['abpBody', { static: false }]
|
|
175
|
-
}], abpFooter: [{
|
|
176
|
-
type: ContentChild,
|
|
177
|
-
args: ['abpFooter', { static: false }]
|
|
178
|
-
}], abpSubmit: [{
|
|
179
|
-
type: ContentChild,
|
|
180
|
-
args: [ButtonComponent, { static: false, read: ButtonComponent }]
|
|
181
|
-
}], visibleChange: [{
|
|
182
|
-
type: Output
|
|
183
|
-
}], init: [{
|
|
184
|
-
type: Output
|
|
185
|
-
}], appear: [{
|
|
186
|
-
type: Output
|
|
187
|
-
}], disappear: [{
|
|
188
|
-
type: Output
|
|
189
|
-
}] } });
|
|
190
|
-
//# 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    keyboard: true,\r\n  };\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' && this.options.keyboard),\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        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  @if (abpHeader) {\r\n    <div id=\"abp-modal-header\" class=\"modal-header abp-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  }\r\n  @if (abpBody) {\r\n    <div id=\"abp-modal-body\" class=\"modal-body\">\r\n      <ng-container *ngTemplateOutlet=\"abpBody\"></ng-container>\r\n    </div>\r\n  }\r\n  @if (abpFooter) {\r\n    <div id=\"abp-modal-footer\" class=\"modal-footer\">\r\n      <ng-container *ngTemplateOutlet=\"abpFooter\"></ng-container>\r\n    </div>\r\n  }\r\n</ng-template>\r\n"]}
|
|
139
|
+
args: [{ selector: 'abp-modal', providers: [SubscriptionService], template: "<ng-content></ng-content>\r\n\r\n<ng-template #modalContent let-modal>\r\n @if (abpHeader()) {\r\n <div id=\"abp-modal-header\" class=\"modal-header abp-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 }\r\n @if (abpBody()) {\r\n <div id=\"abp-modal-body\" class=\"modal-body\">\r\n <ng-container *ngTemplateOutlet=\"abpBody()\"></ng-container>\r\n </div>\r\n }\r\n @if (abpFooter()) {\r\n <div id=\"abp-modal-footer\" class=\"modal-footer\">\r\n <ng-container *ngTemplateOutlet=\"abpFooter()\"></ng-container>\r\n </div>\r\n }\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"] }]
|
|
140
|
+
}], ctorParameters: () => [] });
|
|
141
|
+
//# 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  DestroyRef,\r\n  OnDestroy,\r\n  OnInit,\r\n  TemplateRef,\r\n  contentChild,\r\n  effect,\r\n  inject,\r\n  input,\r\n  model,\r\n  output,\r\n  viewChild,\r\n} from '@angular/core';\r\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\r\nimport { NgbModal, NgbModalOptions, NgbModalRef } from '@ng-bootstrap/ng-bootstrap';\r\nimport { fromEvent } from 'rxjs';\r\nimport { debounceTime, filter } 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  protected readonly confirmationService = inject(ConfirmationService);\r\n  protected readonly modal = inject(NgbModal);\r\n  protected readonly modalRefService = inject(ModalRefService);\r\n  protected readonly suppressUnsavedChangesWarningToken = inject(SUPPRESS_UNSAVED_CHANGES_WARNING, {\r\n    optional: true,\r\n  });\r\n  protected readonly destroyRef = inject(DestroyRef);\r\n\r\n  visible = model<boolean>(false);\r\n\r\n  busy = input(false, {\r\n    transform: (value: boolean) => {\r\n      if (this.abpSubmit() && this.abpSubmit() instanceof ButtonComponent) {\r\n        this.abpSubmit().loading = value;\r\n      }\r\n      return value;\r\n    },\r\n  });\r\n\r\n  options = input<NgbModalOptions>({ keyboard: true });\r\n\r\n  suppressUnsavedChangesWarning = input(this.suppressUnsavedChangesWarningToken);\r\n\r\n  modalContent = viewChild<TemplateRef<any>>('modalContent');\r\n\r\n  abpHeader = contentChild<TemplateRef<any>>('abpHeader');\r\n\r\n  abpBody = contentChild<TemplateRef<any>>('abpBody');\r\n\r\n  abpFooter = contentChild<TemplateRef<any>>('abpFooter');\r\n\r\n  abpSubmit = contentChild(ButtonComponent, { read: ButtonComponent });\r\n\r\n  readonly init = output();\r\n\r\n  readonly appear = output();\r\n\r\n  readonly disappear = output();\r\n\r\n  modalRef!: NgbModalRef;\r\n\r\n  isConfirmationOpen = false;\r\n\r\n  modalIdentifier = `modal-${uuid()}`;\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    effect(() => {\r\n      this.toggle(this.visible());\r\n    });\r\n  }\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.set(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  protected toggle(value: boolean) {\r\n    this.visible.set(value);\r\n\r\n    if (!value) {\r\n      this.modalRef?.dismiss();\r\n      this.disappear.emit();\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  }\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('AbpUi::AreYouSureYouWantToCancelEditingWarningMessage', '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.set(false);\r\n          }\r\n        });\r\n    } else {\r\n      this.visible.set(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          takeUntilDestroyed(this.destroyRef),\r\n          debounceTime(150),\r\n          filter((key: KeyboardEvent) => key && key.key === 'Escape' && this.options().keyboard),\r\n        )\r\n        .subscribe(() => this.close());\r\n    }\r\n\r\n    fromEvent(window, 'beforeunload')\r\n      .pipe(takeUntilDestroyed(this.destroyRef))\r\n      .subscribe(event => {\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  @if (abpHeader()) {\r\n    <div id=\"abp-modal-header\" class=\"modal-header abp-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  }\r\n  @if (abpBody()) {\r\n    <div id=\"abp-modal-body\" class=\"modal-body\">\r\n      <ng-container *ngTemplateOutlet=\"abpBody()\"></ng-container>\r\n    </div>\r\n  }\r\n  @if (abpFooter()) {\r\n    <div id=\"abp-modal-footer\" class=\"modal-footer\">\r\n      <ng-container *ngTemplateOutlet=\"abpFooter()\"></ng-container>\r\n    </div>\r\n  }\r\n</ng-template>\r\n"]}
|
|
@@ -2,4 +2,5 @@ export * from './ng-bootstrap-config.provider';
|
|
|
2
2
|
export * from './route.provider';
|
|
3
3
|
export * from './tenant-not-found.provider';
|
|
4
4
|
export * from './error-handlers.provider';
|
|
5
|
-
|
|
5
|
+
export * from './theme-shared-config.provider';
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy90aGVtZS1zaGFyZWQvc3JjL2xpYi9wcm92aWRlcnMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxnQ0FBZ0MsQ0FBQztBQUMvQyxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsNkJBQTZCLENBQUM7QUFDNUMsY0FBYywyQkFBMkIsQ0FBQztBQUMxQyxjQUFjLGdDQUFnQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9uZy1ib290c3RyYXAtY29uZmlnLnByb3ZpZGVyJztcclxuZXhwb3J0ICogZnJvbSAnLi9yb3V0ZS5wcm92aWRlcic7XHJcbmV4cG9ydCAqIGZyb20gJy4vdGVuYW50LW5vdC1mb3VuZC5wcm92aWRlcic7XHJcbmV4cG9ydCAqIGZyb20gJy4vZXJyb3ItaGFuZGxlcnMucHJvdmlkZXInO1xyXG5leHBvcnQgKiBmcm9tICcuL3RoZW1lLXNoYXJlZC1jb25maWcucHJvdmlkZXInO1xyXG4iXX0=
|
|
@@ -0,0 +1,117 @@
|
|
|
1
|
+
import { APP_INITIALIZER, makeEnvironmentProviders } from '@angular/core';
|
|
2
|
+
import { noop } from '@abp/ng.core';
|
|
3
|
+
import { NgbDateParserFormatter } from '@ng-bootstrap/ng-bootstrap';
|
|
4
|
+
import { VALIDATION_BLUEPRINTS, VALIDATION_MAP_ERRORS_FN, defaultMapErrorsFn, VALIDATION_VALIDATE_ON_SUBMIT, } from '@ngx-validate/core';
|
|
5
|
+
import { DEFAULT_VALIDATION_BLUEPRINTS } from '../constants';
|
|
6
|
+
import { DocumentDirHandlerService, ErrorHandler } from '../handlers';
|
|
7
|
+
import { THEME_SHARED_APPEND_CONTENT, HTTP_ERROR_CONFIG, CONFIRMATION_ICONS, DEFAULT_CONFIRMATION_ICONS, } from '../tokens';
|
|
8
|
+
import { DateParserFormatter } from '../utils';
|
|
9
|
+
import { DEFAULT_HANDLERS_PROVIDERS, NG_BOOTSTRAP_CONFIG_PROVIDERS, THEME_SHARED_ROUTE_PROVIDERS, tenantNotFoundProvider, } from './';
|
|
10
|
+
export var ThemeSharedFeatureKind;
|
|
11
|
+
(function (ThemeSharedFeatureKind) {
|
|
12
|
+
ThemeSharedFeatureKind[ThemeSharedFeatureKind["HttpErrorConfig"] = 0] = "HttpErrorConfig";
|
|
13
|
+
ThemeSharedFeatureKind[ThemeSharedFeatureKind["ValidationBluePrint"] = 1] = "ValidationBluePrint";
|
|
14
|
+
ThemeSharedFeatureKind[ThemeSharedFeatureKind["ValidationErrorsFn"] = 2] = "ValidationErrorsFn";
|
|
15
|
+
ThemeSharedFeatureKind[ThemeSharedFeatureKind["ValidateOnSubmit"] = 3] = "ValidateOnSubmit";
|
|
16
|
+
ThemeSharedFeatureKind[ThemeSharedFeatureKind["Validation"] = 4] = "Validation";
|
|
17
|
+
ThemeSharedFeatureKind[ThemeSharedFeatureKind["ConfirmationIcons"] = 5] = "ConfirmationIcons";
|
|
18
|
+
})(ThemeSharedFeatureKind || (ThemeSharedFeatureKind = {}));
|
|
19
|
+
function makeThemeSharedFeature(kind, providers) {
|
|
20
|
+
return {
|
|
21
|
+
ɵkind: kind,
|
|
22
|
+
ɵproviders: providers,
|
|
23
|
+
};
|
|
24
|
+
}
|
|
25
|
+
export function withHttpErrorConfig(httpErrorConfig) {
|
|
26
|
+
return makeThemeSharedFeature(ThemeSharedFeatureKind.HttpErrorConfig, [
|
|
27
|
+
{
|
|
28
|
+
provide: HTTP_ERROR_CONFIG,
|
|
29
|
+
useValue: httpErrorConfig,
|
|
30
|
+
},
|
|
31
|
+
]);
|
|
32
|
+
}
|
|
33
|
+
export function withValidationBluePrint(bluePrints) {
|
|
34
|
+
return makeThemeSharedFeature(ThemeSharedFeatureKind.ValidationBluePrint, [
|
|
35
|
+
{
|
|
36
|
+
provide: VALIDATION_BLUEPRINTS,
|
|
37
|
+
useValue: {
|
|
38
|
+
...DEFAULT_VALIDATION_BLUEPRINTS,
|
|
39
|
+
...(bluePrints || {}),
|
|
40
|
+
},
|
|
41
|
+
},
|
|
42
|
+
]);
|
|
43
|
+
}
|
|
44
|
+
export function withValidationMapErrorsFn(mapErrorsFn) {
|
|
45
|
+
return makeThemeSharedFeature(ThemeSharedFeatureKind.ValidationErrorsFn, [
|
|
46
|
+
{
|
|
47
|
+
provide: VALIDATION_MAP_ERRORS_FN,
|
|
48
|
+
useValue: mapErrorsFn || defaultMapErrorsFn,
|
|
49
|
+
},
|
|
50
|
+
]);
|
|
51
|
+
}
|
|
52
|
+
export function withValidateOnSubmit(validateOnSubmit) {
|
|
53
|
+
return makeThemeSharedFeature(ThemeSharedFeatureKind.ValidateOnSubmit, [
|
|
54
|
+
{
|
|
55
|
+
provide: VALIDATION_VALIDATE_ON_SUBMIT,
|
|
56
|
+
useValue: validateOnSubmit,
|
|
57
|
+
},
|
|
58
|
+
]);
|
|
59
|
+
}
|
|
60
|
+
export function withConfirmationIcon(confirmationIcons) {
|
|
61
|
+
return makeThemeSharedFeature(ThemeSharedFeatureKind.HttpErrorConfig, [
|
|
62
|
+
{
|
|
63
|
+
provide: CONFIRMATION_ICONS,
|
|
64
|
+
useValue: { ...DEFAULT_CONFIRMATION_ICONS, ...(confirmationIcons || {}) },
|
|
65
|
+
},
|
|
66
|
+
]);
|
|
67
|
+
}
|
|
68
|
+
export function provideAbpThemeShared(...features) {
|
|
69
|
+
const providers = [
|
|
70
|
+
{
|
|
71
|
+
provide: APP_INITIALIZER,
|
|
72
|
+
multi: true,
|
|
73
|
+
deps: [ErrorHandler],
|
|
74
|
+
useFactory: noop,
|
|
75
|
+
},
|
|
76
|
+
THEME_SHARED_ROUTE_PROVIDERS,
|
|
77
|
+
{
|
|
78
|
+
provide: APP_INITIALIZER,
|
|
79
|
+
multi: true,
|
|
80
|
+
deps: [THEME_SHARED_APPEND_CONTENT],
|
|
81
|
+
useFactory: noop,
|
|
82
|
+
},
|
|
83
|
+
{ provide: HTTP_ERROR_CONFIG, useValue: undefined },
|
|
84
|
+
{ provide: NgbDateParserFormatter, useClass: DateParserFormatter },
|
|
85
|
+
NG_BOOTSTRAP_CONFIG_PROVIDERS,
|
|
86
|
+
{
|
|
87
|
+
provide: VALIDATION_BLUEPRINTS,
|
|
88
|
+
useValue: { ...DEFAULT_VALIDATION_BLUEPRINTS },
|
|
89
|
+
},
|
|
90
|
+
{
|
|
91
|
+
provide: VALIDATION_MAP_ERRORS_FN,
|
|
92
|
+
useValue: defaultMapErrorsFn,
|
|
93
|
+
},
|
|
94
|
+
{
|
|
95
|
+
provide: VALIDATION_VALIDATE_ON_SUBMIT,
|
|
96
|
+
useValue: undefined,
|
|
97
|
+
},
|
|
98
|
+
DocumentDirHandlerService,
|
|
99
|
+
{
|
|
100
|
+
provide: APP_INITIALIZER,
|
|
101
|
+
useFactory: noop,
|
|
102
|
+
multi: true,
|
|
103
|
+
deps: [DocumentDirHandlerService],
|
|
104
|
+
},
|
|
105
|
+
{
|
|
106
|
+
provide: CONFIRMATION_ICONS,
|
|
107
|
+
useValue: { ...DEFAULT_CONFIRMATION_ICONS },
|
|
108
|
+
},
|
|
109
|
+
tenantNotFoundProvider,
|
|
110
|
+
DEFAULT_HANDLERS_PROVIDERS,
|
|
111
|
+
];
|
|
112
|
+
for (const feature of features) {
|
|
113
|
+
providers.push(...feature.ɵproviders);
|
|
114
|
+
}
|
|
115
|
+
return makeEnvironmentProviders(providers);
|
|
116
|
+
}
|
|
117
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"theme-shared-config.provider.js","sourceRoot":"","sources":["../../../../../../packages/theme-shared/src/lib/providers/theme-shared-config.provider.ts"],"names":[],"mappings":"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","sourcesContent":["import { APP_INITIALIZER, Provider, makeEnvironmentProviders } from '@angular/core';\r\nimport { noop } from '@abp/ng.core';\r\nimport { NgbDateParserFormatter } from '@ng-bootstrap/ng-bootstrap';\r\nimport {\r\n  VALIDATION_BLUEPRINTS,\r\n  VALIDATION_MAP_ERRORS_FN,\r\n  defaultMapErrorsFn,\r\n  VALIDATION_VALIDATE_ON_SUBMIT,\r\n  Validation,\r\n} from '@ngx-validate/core';\r\nimport { DEFAULT_VALIDATION_BLUEPRINTS } from '../constants';\r\nimport { DocumentDirHandlerService, ErrorHandler } from '../handlers';\r\nimport { HttpErrorConfig } from '../models';\r\nimport {\r\n  THEME_SHARED_APPEND_CONTENT,\r\n  HTTP_ERROR_CONFIG,\r\n  CONFIRMATION_ICONS,\r\n  ConfirmationIcons,\r\n  DEFAULT_CONFIRMATION_ICONS,\r\n} from '../tokens';\r\nimport { DateParserFormatter } from '../utils';\r\nimport {\r\n  DEFAULT_HANDLERS_PROVIDERS,\r\n  NG_BOOTSTRAP_CONFIG_PROVIDERS,\r\n  THEME_SHARED_ROUTE_PROVIDERS,\r\n  tenantNotFoundProvider,\r\n} from './';\r\n\r\nexport enum ThemeSharedFeatureKind {\r\n  HttpErrorConfig,\r\n  ValidationBluePrint,\r\n  ValidationErrorsFn,\r\n  ValidateOnSubmit,\r\n  Validation,\r\n  ConfirmationIcons,\r\n}\r\n\r\nexport interface ThemeSharedFeature<KindT extends ThemeSharedFeatureKind> {\r\n  ɵkind: KindT;\r\n  ɵproviders: Provider[];\r\n}\r\n\r\nfunction makeThemeSharedFeature<KindT extends ThemeSharedFeatureKind>(\r\n  kind: KindT,\r\n  providers: Provider[],\r\n): ThemeSharedFeature<KindT> {\r\n  return {\r\n    ɵkind: kind,\r\n    ɵproviders: providers,\r\n  };\r\n}\r\n\r\nexport function withHttpErrorConfig(\r\n  httpErrorConfig: HttpErrorConfig,\r\n): ThemeSharedFeature<ThemeSharedFeatureKind.HttpErrorConfig> {\r\n  return makeThemeSharedFeature(ThemeSharedFeatureKind.HttpErrorConfig, [\r\n    {\r\n      provide: HTTP_ERROR_CONFIG,\r\n      useValue: httpErrorConfig,\r\n    },\r\n  ]);\r\n}\r\n\r\nexport function withValidationBluePrint(\r\n  bluePrints: Validation.Blueprints,\r\n): ThemeSharedFeature<ThemeSharedFeatureKind.ValidationBluePrint> {\r\n  return makeThemeSharedFeature(ThemeSharedFeatureKind.ValidationBluePrint, [\r\n    {\r\n      provide: VALIDATION_BLUEPRINTS,\r\n      useValue: {\r\n        ...DEFAULT_VALIDATION_BLUEPRINTS,\r\n        ...(bluePrints || {}),\r\n      },\r\n    },\r\n  ]);\r\n}\r\n\r\nexport function withValidationMapErrorsFn(\r\n  mapErrorsFn: Validation.MapErrorsFn,\r\n): ThemeSharedFeature<ThemeSharedFeatureKind.ValidationErrorsFn> {\r\n  return makeThemeSharedFeature(ThemeSharedFeatureKind.ValidationErrorsFn, [\r\n    {\r\n      provide: VALIDATION_MAP_ERRORS_FN,\r\n      useValue: mapErrorsFn || defaultMapErrorsFn,\r\n    },\r\n  ]);\r\n}\r\n\r\nexport function withValidateOnSubmit(\r\n  validateOnSubmit: boolean,\r\n): ThemeSharedFeature<ThemeSharedFeatureKind.ValidateOnSubmit> {\r\n  return makeThemeSharedFeature(ThemeSharedFeatureKind.ValidateOnSubmit, [\r\n    {\r\n      provide: VALIDATION_VALIDATE_ON_SUBMIT,\r\n      useValue: validateOnSubmit,\r\n    },\r\n  ]);\r\n}\r\n\r\nexport function withConfirmationIcon(\r\n  confirmationIcons: Partial<ConfirmationIcons>,\r\n): ThemeSharedFeature<ThemeSharedFeatureKind.HttpErrorConfig> {\r\n  return makeThemeSharedFeature(ThemeSharedFeatureKind.HttpErrorConfig, [\r\n    {\r\n      provide: CONFIRMATION_ICONS,\r\n      useValue: { ...DEFAULT_CONFIRMATION_ICONS, ...(confirmationIcons || {}) },\r\n    },\r\n  ]);\r\n}\r\n\r\nexport function provideAbpThemeShared(...features: ThemeSharedFeature<ThemeSharedFeatureKind>[]) {\r\n  const providers = [\r\n    {\r\n      provide: APP_INITIALIZER,\r\n      multi: true,\r\n      deps: [ErrorHandler],\r\n      useFactory: noop,\r\n    },\r\n    THEME_SHARED_ROUTE_PROVIDERS,\r\n    {\r\n      provide: APP_INITIALIZER,\r\n      multi: true,\r\n      deps: [THEME_SHARED_APPEND_CONTENT],\r\n      useFactory: noop,\r\n    },\r\n    { provide: HTTP_ERROR_CONFIG, useValue: undefined },\r\n    { provide: NgbDateParserFormatter, useClass: DateParserFormatter },\r\n    NG_BOOTSTRAP_CONFIG_PROVIDERS,\r\n    {\r\n      provide: VALIDATION_BLUEPRINTS,\r\n      useValue: { ...DEFAULT_VALIDATION_BLUEPRINTS },\r\n    },\r\n    {\r\n      provide: VALIDATION_MAP_ERRORS_FN,\r\n      useValue: defaultMapErrorsFn,\r\n    },\r\n    {\r\n      provide: VALIDATION_VALIDATE_ON_SUBMIT,\r\n      useValue: undefined,\r\n    },\r\n    DocumentDirHandlerService,\r\n    {\r\n      provide: APP_INITIALIZER,\r\n      useFactory: noop,\r\n      multi: true,\r\n      deps: [DocumentDirHandlerService],\r\n    },\r\n    {\r\n      provide: CONFIRMATION_ICONS,\r\n      useValue: { ...DEFAULT_CONFIRMATION_ICONS },\r\n    },\r\n    tenantNotFoundProvider,\r\n    DEFAULT_HANDLERS_PROVIDERS,\r\n  ];\r\n\r\n  for (const feature of features) {\r\n    providers.push(...feature.ɵproviders);\r\n  }\r\n\r\n  return makeEnvironmentProviders(providers);\r\n}\r\n"]}
|