bpm-core 0.0.31 → 0.0.33
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/app/app.component.mjs +2 -2
- package/esm2022/lib/components/app-component-sections/faq-sidenav/faq-sidenav.component.mjs +1 -5
- package/esm2022/lib/components/app-component-sections/faqs/faqs.component.mjs +4 -9
- package/esm2022/lib/components/app-component-sections/form-section/form-section.component.mjs +140 -72
- package/esm2022/lib/components/app-component-sections/index.mjs +1 -2
- package/esm2022/lib/components/app-component-sections/main-request-details/main-request-details.component.mjs +5 -7
- package/esm2022/lib/components/app-component-sections/service-header/service-header.component.mjs +155 -61
- package/esm2022/lib/components/shared-components/form-field/control-value-accessor.directive.mjs +5 -6
- package/esm2022/lib/components/shared-components/form-field/custom-searchable-autocomplete/custom-searchable.component.mjs +3 -3
- package/esm2022/lib/components/shared-components/form-field/date-picker/date-picker.component.mjs +8 -46
- package/esm2022/lib/components/shared-components/form-field/date-range-picker/date-range-picker.component.mjs +161 -14
- package/esm2022/lib/components/shared-components/form-field/input/input.component.mjs +10 -12
- package/esm2022/lib/components/shared-components/form-field/input-currency/input-currency.component.mjs +11 -4
- package/esm2022/lib/components/shared-components/form-field/input-email/input-email.component.mjs +12 -4
- package/esm2022/lib/components/shared-components/form-field/input-mask/input-mask.component.mjs +3 -3
- package/esm2022/lib/components/shared-components/form-field/input-number/input-number.component.mjs +9 -5
- package/esm2022/lib/components/shared-components/form-field/validation-errors/validation-errors.component.mjs +5 -1
- package/esm2022/lib/{validators → directives}/ar.directive.mjs +4 -3
- package/esm2022/lib/{validators → directives}/currency.directive.mjs +4 -3
- package/esm2022/lib/{validators → directives}/en.directive.mjs +4 -3
- package/esm2022/lib/directives/number.directive.mjs +68 -0
- package/esm2022/lib/i18n/ar.mjs +3 -2
- package/esm2022/lib/i18n/en.mjs +2 -1
- package/esm2022/lib/regex/regex-patterns.mjs +4 -0
- package/esm2022/lib/services/core.service.ts.mjs +18 -3
- package/esm2022/lib/testComponent/general-approver-section/general-approver-section.component.mjs +2 -2
- package/esm2022/lib/testComponent/request-details-section/request-details-section.component.mjs +13 -6
- package/esm2022/lib/validators/index.mjs +4 -4
- package/fesm2022/bpm-core.mjs +807 -511
- package/fesm2022/bpm-core.mjs.map +1 -1
- package/lib/components/app-component-sections/approvals-workflow/approvals-workflow.component.d.ts +1 -1
- package/lib/components/app-component-sections/faq-sidenav/faq-sidenav.component.d.ts +2 -4
- package/lib/components/app-component-sections/faqs/faqs.component.d.ts +1 -3
- package/lib/components/app-component-sections/form-section/form-section.component.d.ts +92 -7
- package/lib/components/app-component-sections/index.d.ts +0 -1
- package/lib/components/app-component-sections/service-header/service-header.component.d.ts +97 -7
- package/lib/components/shared-components/dialogs/submit-dialog/submit-dialog.component.d.ts +1 -1
- package/lib/components/shared-components/form-field/control-value-accessor.directive.d.ts +2 -1
- package/lib/components/shared-components/form-field/date-picker/date-picker.component.d.ts +0 -4
- package/lib/components/shared-components/form-field/date-range-picker/date-range-picker.component.d.ts +22 -6
- package/lib/components/shared-components/form-field/input/input.component.d.ts +1 -3
- package/lib/components/shared-components/form-field/input-email/input-email.component.d.ts +1 -0
- package/lib/{validators → directives}/ar.directive.d.ts +1 -1
- package/lib/{validators → directives}/currency.directive.d.ts +1 -1
- package/lib/{validators → directives}/en.directive.d.ts +1 -1
- package/lib/directives/number.directive.d.ts +14 -0
- package/lib/i18n/ar.d.ts +1 -0
- package/lib/i18n/en.d.ts +1 -0
- package/lib/regex/regex-patterns.d.ts +3 -0
- package/lib/services/core.service.ts.d.ts +1 -0
- package/lib/validators/index.d.ts +0 -3
- package/package.json +2 -2
- package/src/lib/assets/scss/_custom-popover.scss +3 -0
- package/src/lib/assets/scss/_settings.scss +5 -2
- package/esm2022/lib/components/app-component-sections/comment-section/comment-section.component.mjs +0 -66
- package/lib/components/app-component-sections/comment-section/comment-section.component.d.ts +0 -19
package/esm2022/lib/components/app-component-sections/form-section/form-section.component.mjs
CHANGED
|
@@ -5,18 +5,26 @@ import { MatExpansionModule, MatExpansionPanel } from '@angular/material/expansi
|
|
|
5
5
|
import { SatPopoverModule } from '@ncstate/sat-popover';
|
|
6
6
|
import { ProfileInfoDrop } from '../../../interfaces';
|
|
7
7
|
import * as Constants from '../../../constants';
|
|
8
|
-
import * as moment from 'moment';
|
|
9
8
|
import { ProfileSectionComponent } from "../profile-section/profile-section.component";
|
|
9
|
+
import { format } from 'date-fns';
|
|
10
10
|
import * as i0 from "@angular/core";
|
|
11
11
|
import * as i1 from "../../../services";
|
|
12
12
|
import * as i2 from "@angular/material/expansion";
|
|
13
13
|
import * as i3 from "ng-dynamic-component";
|
|
14
|
+
const StatusMap = {
|
|
15
|
+
[Constants.FORM_STATUS_REJECTED]: { class: 'danger', icon: 'close' },
|
|
16
|
+
[Constants.FORM_STATUS_CANCELLED]: { class: 'danger', icon: 'close' },
|
|
17
|
+
[Constants.FORM_STATUS_REJECT]: { class: 'danger', icon: 'close' },
|
|
18
|
+
[Constants.SECTION_STATUS_UNSATISFIED]: { class: 'danger', icon: 'close' },
|
|
19
|
+
[Constants.FORM_STATUS_CANCEL]: { class: 'danger', icon: 'close' },
|
|
20
|
+
[Constants.FORM_STATUS_PENDING]: { class: 'warning', icon: 'clock' },
|
|
21
|
+
'default': { class: 'success', icon: 'check' }
|
|
22
|
+
};
|
|
14
23
|
export class FormSectionComponent {
|
|
15
24
|
i18n;
|
|
16
25
|
coreService;
|
|
17
26
|
sidenavService;
|
|
18
27
|
userType = 'recipient';
|
|
19
|
-
// @ViewChild('popover') popover?: any;
|
|
20
28
|
popoverType = 'recipient';
|
|
21
29
|
requestDetails;
|
|
22
30
|
userPopoverInfo = {};
|
|
@@ -24,14 +32,10 @@ export class FormSectionComponent {
|
|
|
24
32
|
form;
|
|
25
33
|
lov;
|
|
26
34
|
isReadOnly;
|
|
27
|
-
// @Input() isOpen: boolean;
|
|
28
|
-
// @Input() isFinalApproval: boolean;
|
|
29
35
|
controllers;
|
|
30
36
|
segmentDynamicLoaderService;
|
|
31
37
|
sectionFormComponent = null;
|
|
32
38
|
sectionName = 'SECTION_NAME.requestDetails';
|
|
33
|
-
sectionNumber;
|
|
34
|
-
sectionStatusValue;
|
|
35
39
|
sectionStatusKey;
|
|
36
40
|
recipient = {
|
|
37
41
|
isShowing: false,
|
|
@@ -42,114 +46,178 @@ export class FormSectionComponent {
|
|
|
42
46
|
profile: null
|
|
43
47
|
};
|
|
44
48
|
input;
|
|
45
|
-
// highlightFlag: boolean;
|
|
46
49
|
processingDate;
|
|
47
|
-
randomID = Math.floor(Math.random() * (999999 - 100000)) + 100000;
|
|
48
50
|
constructor(i18n, coreService, sidenavService) {
|
|
49
51
|
this.i18n = i18n;
|
|
50
52
|
this.coreService = coreService;
|
|
51
53
|
this.sidenavService = sidenavService;
|
|
52
|
-
// this.highlightFlag = false;
|
|
53
54
|
}
|
|
55
|
+
/**
|
|
56
|
+
* Method to initialize various components when the component is initialized.
|
|
57
|
+
*
|
|
58
|
+
* @return {void}
|
|
59
|
+
*/
|
|
54
60
|
ngOnInit() {
|
|
61
|
+
this.initSectionFormComponent();
|
|
62
|
+
this.initSectionName();
|
|
63
|
+
this.initInput();
|
|
64
|
+
this.initProcessingDate();
|
|
65
|
+
}
|
|
66
|
+
/**
|
|
67
|
+
* Initializes the section form component by fetching it from the segment dynamic loader service.
|
|
68
|
+
*
|
|
69
|
+
* @return {void}
|
|
70
|
+
*/
|
|
71
|
+
initSectionFormComponent() {
|
|
55
72
|
this.sectionFormComponent = this.segmentDynamicLoaderService.getComponent(this.section.id);
|
|
56
|
-
|
|
57
|
-
|
|
73
|
+
}
|
|
74
|
+
/**
|
|
75
|
+
* Initializes the section name based on the provided section data.
|
|
76
|
+
* If the section's body contains a 'stageName' property, the section name is set to the value of that property.
|
|
77
|
+
* Otherwise, the section name is retrieved using the segmentDynamicLoaderService based on the section ID.
|
|
78
|
+
*
|
|
79
|
+
* @return {void}
|
|
80
|
+
*/
|
|
81
|
+
initSectionName() {
|
|
82
|
+
if (this.section.body.details?.['stageName']) {
|
|
83
|
+
this.sectionName = this.section.body.details['stageName'];
|
|
58
84
|
}
|
|
59
85
|
else {
|
|
60
86
|
this.sectionName = this.segmentDynamicLoaderService.getSectionName(this.section.id);
|
|
61
87
|
}
|
|
88
|
+
}
|
|
89
|
+
/**
|
|
90
|
+
* Initializes the input object with the provided values for read-only status, list of values, section, and form.
|
|
91
|
+
*
|
|
92
|
+
* @return {void}
|
|
93
|
+
*/
|
|
94
|
+
initInput() {
|
|
62
95
|
this.input = {
|
|
63
96
|
isReadOnly: this.isReadOnly,
|
|
64
97
|
lov: this.lov,
|
|
65
98
|
section: this.section,
|
|
66
|
-
// controllers: this.controllers,
|
|
67
|
-
// requestDetails: this.requestDetails,
|
|
68
99
|
form: this.form
|
|
69
100
|
};
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
101
|
+
}
|
|
102
|
+
/**
|
|
103
|
+
* Initializes the processing date based on the section's header processing date.
|
|
104
|
+
* If the processing date is available in the section header, it formats the processing date
|
|
105
|
+
* and assigns it to the processingDate property of the instance.
|
|
106
|
+
*
|
|
107
|
+
* @return {void}
|
|
108
|
+
*/
|
|
109
|
+
initProcessingDate() {
|
|
110
|
+
if (this.section?.header?.processingDate) {
|
|
111
|
+
this.processingDate = format(new Date(this.section.header.processingDate), "dd/MM/yyyy hh:mm:ss");
|
|
79
112
|
}
|
|
80
113
|
}
|
|
114
|
+
/**
|
|
115
|
+
* Check if the section is expanded.
|
|
116
|
+
*
|
|
117
|
+
* @return {boolean} Returns true if the section is expanded, false otherwise.
|
|
118
|
+
*/
|
|
81
119
|
get isExpanded() {
|
|
82
|
-
const
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
return this.section?.body?.details?.expandStage === 'true';
|
|
86
|
-
}
|
|
87
|
-
sectionId() {
|
|
88
|
-
return this.section.id.split(' ').join('') + this.randomID;
|
|
120
|
+
const hasSections = Boolean(this.form?.sections?.length);
|
|
121
|
+
const isAnySectionExpandable = hasSections && this.form.sections.some(section => 'expandStage' in (section?.body?.details || {}));
|
|
122
|
+
return isAnySectionExpandable ? (this.section?.body?.details?.['expandStage'] === 'true') : true;
|
|
89
123
|
}
|
|
124
|
+
/**
|
|
125
|
+
* Create a ProfileInfoDrop object from the response object.
|
|
126
|
+
*
|
|
127
|
+
* @param {any} response - The response object containing user profile information.
|
|
128
|
+
*
|
|
129
|
+
* @return {ProfileInfoDrop} A ProfileInfoDrop object created from the response data.
|
|
130
|
+
*/
|
|
90
131
|
createUserProfileFromResponse(response) {
|
|
91
|
-
|
|
132
|
+
const user = response?.["Users"][0];
|
|
133
|
+
return new ProfileInfoDrop(false, user?.employeeNumber, user?.email, user?.name, user?.generalDepartment?.name, user?.position?.name, user?.sector?.name, user?.department?.name, user?.generalDepartment?.code, user?.location, user?.nationality?.desc, user?.contact?.mobile, user?.manager?.name, user?.seniorSectorName?.name);
|
|
92
134
|
}
|
|
135
|
+
/**
|
|
136
|
+
* Method to open or create a user profile.
|
|
137
|
+
*
|
|
138
|
+
* @param {ProfileInfoDrop} userData - The user profile data to open or create.
|
|
139
|
+
* @param {string} personType - The type of person this profile belongs to.
|
|
140
|
+
*
|
|
141
|
+
* @return {void}
|
|
142
|
+
*/
|
|
93
143
|
openOrCreateUserProfile(userData, personType) {
|
|
94
144
|
this.sidenavService.data = userData;
|
|
95
145
|
this.userPopoverInfo = userData;
|
|
96
146
|
this[personType].profile = userData;
|
|
97
147
|
this.sidenavService.publish('open', ProfileSectionComponent);
|
|
98
148
|
}
|
|
149
|
+
/**
|
|
150
|
+
* Toggles the display of small profile information for a given person type
|
|
151
|
+
*
|
|
152
|
+
* @param {any} event - The event that triggered the toggle
|
|
153
|
+
* @param {string} personType - The type of person for which to display the profile information
|
|
154
|
+
*
|
|
155
|
+
* @return {void}
|
|
156
|
+
*/
|
|
99
157
|
toggleSmallProfileInfo(event, personType) {
|
|
100
158
|
this.userType = personType;
|
|
101
159
|
event.stopPropagation();
|
|
102
160
|
let userInfo = this[personType];
|
|
103
|
-
if (userInfo.profile
|
|
161
|
+
if (!userInfo.profile) {
|
|
104
162
|
this.popoverType = personType;
|
|
105
|
-
let userEmail =
|
|
106
|
-
this.
|
|
107
|
-
if (response) {
|
|
108
|
-
let userData = this.createUserProfileFromResponse(response);
|
|
109
|
-
this.openOrCreateUserProfile(userData, personType);
|
|
110
|
-
}
|
|
111
|
-
});
|
|
163
|
+
let userEmail = this.getUserEmail(personType);
|
|
164
|
+
this.fetchAndSetUserProfile(userEmail, personType);
|
|
112
165
|
}
|
|
113
166
|
else {
|
|
114
|
-
this.openOrCreateUserProfile(
|
|
167
|
+
this.openOrCreateUserProfile(userInfo.profile, personType);
|
|
115
168
|
}
|
|
116
169
|
}
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
170
|
+
/**
|
|
171
|
+
* Retrieves the email of the user based on the personType parameter.
|
|
172
|
+
*
|
|
173
|
+
* @param {string} personType - Type of the person ('recipient' or others).
|
|
174
|
+
* @return {string} - The email address of the user.
|
|
175
|
+
*/
|
|
176
|
+
getUserEmail(personType) {
|
|
177
|
+
return (personType === 'recipient'
|
|
178
|
+
? this.section.header.personToThumbnail.split('=')[1]
|
|
179
|
+
: this?.section?.header?.delegatedToThumbnail.split('=')[1]);
|
|
180
|
+
}
|
|
181
|
+
/**
|
|
182
|
+
* Fetches the user profile using the provided user email and person type, then sets the profile.
|
|
183
|
+
*
|
|
184
|
+
* @param {string} userEmail - The email of the user whose profile is to be fetched and set.
|
|
185
|
+
* @param {string} personType - The type of person (e.g., employee, customer) for whom the profile is being fetched.
|
|
186
|
+
*
|
|
187
|
+
* @return {void}
|
|
188
|
+
*/
|
|
189
|
+
fetchAndSetUserProfile(userEmail, personType) {
|
|
190
|
+
this.coreService.employeeProfile(userEmail).subscribe((response) => {
|
|
191
|
+
if (response) {
|
|
192
|
+
let userData = this.createUserProfileFromResponse(response);
|
|
193
|
+
this.openOrCreateUserProfile(userData, personType);
|
|
128
194
|
}
|
|
129
|
-
}
|
|
130
|
-
else {
|
|
131
|
-
return 'success';
|
|
132
|
-
}
|
|
195
|
+
});
|
|
133
196
|
}
|
|
197
|
+
/**
|
|
198
|
+
* Returns the CSS class associated with the input status.
|
|
199
|
+
*
|
|
200
|
+
* @param {string} status - The status for which the CSS class is needed.
|
|
201
|
+
* @return {string} - The CSS class corresponding to the given status.
|
|
202
|
+
*/
|
|
203
|
+
statusClass(status) {
|
|
204
|
+
status = status ? status.toLowerCase() : '';
|
|
205
|
+
let statusStrategy = StatusMap[status] || StatusMap['default'];
|
|
206
|
+
return statusStrategy.class;
|
|
207
|
+
}
|
|
208
|
+
/**
|
|
209
|
+
* Returns the icon associated with the provided status.
|
|
210
|
+
*
|
|
211
|
+
* @param {string} status - The status for which to retrieve the icon.
|
|
212
|
+
* @return {string} The icon corresponding to the provided status.
|
|
213
|
+
*/
|
|
134
214
|
statusIcon(status) {
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
return 'close';
|
|
139
|
-
}
|
|
140
|
-
else if (status === Constants.FORM_STATUS_PENDING || status.toLowerCase() === 'pending') {
|
|
141
|
-
return 'clock';
|
|
142
|
-
}
|
|
143
|
-
else {
|
|
144
|
-
return 'check';
|
|
145
|
-
}
|
|
146
|
-
}
|
|
147
|
-
else {
|
|
148
|
-
return 'check';
|
|
149
|
-
}
|
|
215
|
+
status = status ? status.toLowerCase() : '';
|
|
216
|
+
let statusStrategy = StatusMap[status] || StatusMap['default'];
|
|
217
|
+
return statusStrategy.icon;
|
|
150
218
|
}
|
|
151
219
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: FormSectionComponent, deps: [{ token: i1.CoreI18nService }, { token: i1.CoreService }, { token: i1.SidenavService }], target: i0.ɵɵFactoryTarget.Component });
|
|
152
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
220
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.8", type: FormSectionComponent, isStandalone: true, selector: "app-form-section", inputs: { requestDetails: "requestDetails", section: "section", form: "form", lov: "lov", isReadOnly: "isReadOnly", controllers: "controllers", segmentDynamicLoaderService: "segmentDynamicLoaderService", sectionFormComponent: "sectionFormComponent", sectionName: "sectionName" }, ngImport: i0, template: "<mat-expansion-panel class=\"mb-4\" [expanded]=\"isExpanded\" hideToggle #approvalPanel=\"matExpansionPanel\">\r\n <mat-expansion-panel-header>\r\n\r\n <div class=\"approval-panel-container\">\r\n <div class=\"d-flex gap-2 flex-grow-1 approval-panel-title\">\r\n <ds-status\r\n status=\"{{statusClass(sectionStatusKey)}}\" no-opacity icon\r\n class=\"circle-status d-none d-sm-inline-block\">\r\n <ds-icon icon=\"{{statusIcon(sectionStatusKey)}}\"></ds-icon>\r\n </ds-status>\r\n <div class=\"d-flex flex-column flex-grow-1\">\r\n <span class=\"fs-16 fw-medium m-0\"> {{ sectionName }}</span>\r\n @if (section.header?.processedBy) {\r\n <bdi class=\"fs-12 fc-dark-gray fw-normal line-height-1 d-block mt-1\">\r\n {{ processingDate }}\r\n </bdi>\r\n }\r\n </div>\r\n </div>\r\n <div class=\"approval-panel-details gap-1\">\r\n @if (!section?.body?.details?.['stage0']?.['isStage0'] || section?.body?.details?.['stage0']?.['isStage0'] === 'false') {\r\n <ng-container>\r\n @if (section?.header?.personTo) {\r\n <div\r\n class=\"d-flex align-items-center gap-3\"\r\n (click)=\"$event.stopImmediatePropagation();\">\r\n <div\r\n (click)=\"toggleSmallProfileInfo($event, 'recipient')\"\r\n class=\"d-flex align-items-center gap-2 radius-3 h-40\"\r\n [ngClass]=\"{'user-avatar-name px-0 px-md-2': !section?.header?.delegatedTo, 'p-0': section?.header?.delegatedTo}\">\r\n <ds-avatar image=\"{{section?.header?.personToThumbnail}}\" size=\"small\" class=\"user-avatar\"></ds-avatar>\r\n @if (!section?.header?.delegatedTo) {\r\n <span\r\n class=\"fs-14 fw-medium d-inline-block panel-user-name text-truncate\"\r\n [ngClass]=\"{'panel-user-only': !section?.header?.delegatedTo}\"\r\n >{{ section?.header?.personTo }}</span>\r\n }\r\n </div>\r\n @if (section?.header?.delegatedTo) {\r\n <div\r\n class=\"d-flex align-items-center gap-3\"\r\n (click)=\"toggleSmallProfileInfo($event, 'delegate')\">\r\n <img\r\n class=\"rotate-arrow\"\r\n alt=\"\"\r\n src=\"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMSIgaGVpZ2h0PSIxMyIgdmlld0JveD0iMCAwIDIxIDEzIj48cGF0aCBkPSJNMjEsNy43NjNhMS42MjEsMS42MjEsMCwwLDEtLjQ0Ny41OTMsMS4zMDYsMS4zMDYsMCwwLDEtLjc1LjE5NGMtNy4yODQsMC04LjU2OCwwLTE1Ljg1MywwSDMuNjY5TDMuNjMsOC42Yy4wNzcuMDY0LjE1OC4xMjQuMjI5LjE5NHExLjcxLDEuNjksMy40MiwzLjM4MWExLjAyMywxLjAyMywwLDAsMSwuMjkxLDEuMDc5Ljk5Mi45OTIsMCwwLDEtLjguNzE5LDEuMDUzLDEuMDUzLDAsMCwxLTEtLjMzMVEzLjgzMSwxMS43MTksMS44ODYsOS44Yy0uNDQyLS40MzctLjg3OS0uODgxLTEuMzMtMS4zMDlBNC41NzIsNC41NzIsMCwwLDEsMCw3LjgxNFY3LjE4NUEzMC43ODMsMzAuNzgzLDAsMCwxLDIuNzMsNC4zNzFjMS0xLjAyNywyLjAzOC0yLjAyNSwzLjA2My0zLjAzMkExLjA0OSwxLjA0OSwwLDEsMSw3LjI3NywyLjgyQzYuNCwzLjcsNS41MDksNC41Nyw0LjYyNSw1LjQ0NmMtLjMyMy4zMjEtLjY0NC42NDUtLjk3My45NzYuMDg0LjA1OS4xODEuMDI3LjI3LjAyNyw3LjI1OCwwLDguNTE2LDAsMTUuNzc1LDBBMS4xMjksMS4xMjksMCwwLDEsMjEsNy4yOXYuNDcyWiIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoMCAtMC45OTkpIiBmaWxsPSIjYTU0ZWUxIi8+PC9zdmc+\"/>\r\n <div class=\"d-flex align-items-center gap-2 px-0 px-md-2 radius-3 user-avatar-name h-40\">\r\n <ds-avatar image=\"{{section?.header?.delegatedToThumbnail}}\" size=\"small\" class=\"user-avatar\"></ds-avatar>\r\n <span\r\n class=\"fs-14 fw-medium d-inline-block panel-user-name text-truncate\">{{ section?.header?.delegatedTo }}</span>\r\n </div>\r\n </div>\r\n }\r\n </div>\r\n }\r\n </ng-container>\r\n }\r\n\r\n @if (section?.body?.details?.['decision']?.key) {\r\n <ds-status\r\n class=\"main-status\"\r\n status=\"{{statusClass(section?.body?.details?.['decision']?.key)}}\">{{ section?.body?.details?.['decision']?.value }}\r\n </ds-status>\r\n }\r\n </div>\r\n\r\n <div class=\"approval-panel-toggle\">\r\n @if (approvalPanel.expanded) {\r\n <ds-icon icon=\"minus\" class=\"fs-20 fc-dark-gray\"></ds-icon>\r\n } @else {\r\n <ds-icon icon=\"plus-1\" class=\"fs-20 fc-coral\"></ds-icon>\r\n }\r\n </div>\r\n\r\n </div>\r\n </mat-expansion-panel-header>\r\n <section class=\"border-top pt-4\">\r\n <ng-container *ngComponentOutlet=\"sectionFormComponent; ndcDynamicInputs: input\"></ng-container>\r\n </section>\r\n\r\n</mat-expansion-panel>\r\n", styles: [":host ::ng-deep .mat-expansion-panel-content{background:#fff!important}:host .mat-expansion-panel-content{background:#fff!important}:host .approval-panel-container{display:grid;grid-template-columns:40% calc(60% - 45px) 20px;grid-template-areas:\"title details toggle\";gap:.75rem;place-content:space-between;align-items:center;flex-grow:1;width:100%}@media (max-width: 991px){:host .approval-panel-container{grid-template-columns:calc(100% - 45px) 20px;grid-template-areas:\"title toggle\" \"details details\"}}:host .approval-panel-container .approval-panel-title{grid-area:title}:host .approval-panel-container .panel-user-name{max-width:120px}@media (max-width: 768px){:host .approval-panel-container .panel-user-name.panel-ueser-only{max-width:140px}:host .approval-panel-container .panel-user-name:not(.panel-ueser-only){max-width:90px}}:host .approval-panel-container .approval-panel-details{display:flex;align-items:center;justify-content:space-between;grid-area:details}:host .approval-panel-container .approval-panel-toggle{grid-area:toggle;display:flex;align-items:center;justify-content:center;width:20px}:host ::ng-deep ds-avatar.user-avatar .avatar{--default-size: 25px}@media (min-width: 768px){:host ::ng-deep ds-avatar.user-avatar .avatar{--default-size: 31px;--avatar-border: 3px solid var(--light-gray)}}@media (min-width: 768px){:host ::ng-deep .user-avatar-name{padding-inline-end:1rem!important}}:host .circle-status::part(base){--status-radius: 50%;--status-size: 18px;--status-fs: 80% }:host .panel-title{min-width:40%;width:40%}@media (max-width: 576px){:host .panel-title{min-width:100%!important;width:100%!important}}:host .panel-user-status{min-width:60%;width:60%;display:flex;align-items:center;justify-content:space-between}@media (max-width: 576px){:host .panel-user-status{min-width:100%!important;width:100%!important}:host .panel-user-status .user-delegate{min-width:auto}:host .panel-user-status .main-status::part(base){--status-width: 50px}}\n"], dependencies: [{ kind: "ngmodule", type: MatExpansionModule }, { kind: "component", type: i2.MatExpansionPanel, selector: "mat-expansion-panel", inputs: ["hideToggle", "togglePosition"], outputs: ["afterExpand", "afterCollapse"], exportAs: ["matExpansionPanel"] }, { kind: "component", type: i2.MatExpansionPanelHeader, selector: "mat-expansion-panel-header", inputs: ["expandedHeight", "collapsedHeight", "tabIndex"] }, { kind: "directive", type: NgComponentOutlet, selector: "[ngComponentOutlet]", inputs: ["ngComponentOutlet", "ngComponentOutletInputs", "ngComponentOutletInjector", "ngComponentOutletContent", "ngComponentOutletNgModule", "ngComponentOutletNgModuleFactory"] }, { kind: "directive", type: ComponentOutletIoDirective, selector: "[ngComponentOutletNdcDynamicInputs],[ngComponentOutletNdcDynamicOutputs]", inputs: ["ngComponentOutletNdcDynamicInputs", "ngComponentOutletNdcDynamicOutputs"], exportAs: ["ndcDynamicIo"] }, { kind: "ngmodule", type: SatPopoverModule }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "ngmodule", type: DynamicModule }, { kind: "directive", type: i3.ComponentOutletInjectorDirective, selector: "[ngComponentOutlet]", exportAs: ["ndcComponentOutletInjector"] }] });
|
|
153
221
|
}
|
|
154
222
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: FormSectionComponent, decorators: [{
|
|
155
223
|
type: Component,
|
|
@@ -162,7 +230,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
|
|
|
162
230
|
SatPopoverModule,
|
|
163
231
|
NgClass,
|
|
164
232
|
DynamicModule
|
|
165
|
-
], schemas: [CUSTOM_ELEMENTS_SCHEMA], template: "<mat-expansion-panel
|
|
233
|
+
], schemas: [CUSTOM_ELEMENTS_SCHEMA], template: "<mat-expansion-panel class=\"mb-4\" [expanded]=\"isExpanded\" hideToggle #approvalPanel=\"matExpansionPanel\">\r\n <mat-expansion-panel-header>\r\n\r\n <div class=\"approval-panel-container\">\r\n <div class=\"d-flex gap-2 flex-grow-1 approval-panel-title\">\r\n <ds-status\r\n status=\"{{statusClass(sectionStatusKey)}}\" no-opacity icon\r\n class=\"circle-status d-none d-sm-inline-block\">\r\n <ds-icon icon=\"{{statusIcon(sectionStatusKey)}}\"></ds-icon>\r\n </ds-status>\r\n <div class=\"d-flex flex-column flex-grow-1\">\r\n <span class=\"fs-16 fw-medium m-0\"> {{ sectionName }}</span>\r\n @if (section.header?.processedBy) {\r\n <bdi class=\"fs-12 fc-dark-gray fw-normal line-height-1 d-block mt-1\">\r\n {{ processingDate }}\r\n </bdi>\r\n }\r\n </div>\r\n </div>\r\n <div class=\"approval-panel-details gap-1\">\r\n @if (!section?.body?.details?.['stage0']?.['isStage0'] || section?.body?.details?.['stage0']?.['isStage0'] === 'false') {\r\n <ng-container>\r\n @if (section?.header?.personTo) {\r\n <div\r\n class=\"d-flex align-items-center gap-3\"\r\n (click)=\"$event.stopImmediatePropagation();\">\r\n <div\r\n (click)=\"toggleSmallProfileInfo($event, 'recipient')\"\r\n class=\"d-flex align-items-center gap-2 radius-3 h-40\"\r\n [ngClass]=\"{'user-avatar-name px-0 px-md-2': !section?.header?.delegatedTo, 'p-0': section?.header?.delegatedTo}\">\r\n <ds-avatar image=\"{{section?.header?.personToThumbnail}}\" size=\"small\" class=\"user-avatar\"></ds-avatar>\r\n @if (!section?.header?.delegatedTo) {\r\n <span\r\n class=\"fs-14 fw-medium d-inline-block panel-user-name text-truncate\"\r\n [ngClass]=\"{'panel-user-only': !section?.header?.delegatedTo}\"\r\n >{{ section?.header?.personTo }}</span>\r\n }\r\n </div>\r\n @if (section?.header?.delegatedTo) {\r\n <div\r\n class=\"d-flex align-items-center gap-3\"\r\n (click)=\"toggleSmallProfileInfo($event, 'delegate')\">\r\n <img\r\n class=\"rotate-arrow\"\r\n alt=\"\"\r\n src=\"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMSIgaGVpZ2h0PSIxMyIgdmlld0JveD0iMCAwIDIxIDEzIj48cGF0aCBkPSJNMjEsNy43NjNhMS42MjEsMS42MjEsMCwwLDEtLjQ0Ny41OTMsMS4zMDYsMS4zMDYsMCwwLDEtLjc1LjE5NGMtNy4yODQsMC04LjU2OCwwLTE1Ljg1MywwSDMuNjY5TDMuNjMsOC42Yy4wNzcuMDY0LjE1OC4xMjQuMjI5LjE5NHExLjcxLDEuNjksMy40MiwzLjM4MWExLjAyMywxLjAyMywwLDAsMSwuMjkxLDEuMDc5Ljk5Mi45OTIsMCwwLDEtLjguNzE5LDEuMDUzLDEuMDUzLDAsMCwxLTEtLjMzMVEzLjgzMSwxMS43MTksMS44ODYsOS44Yy0uNDQyLS40MzctLjg3OS0uODgxLTEuMzMtMS4zMDlBNC41NzIsNC41NzIsMCwwLDEsMCw3LjgxNFY3LjE4NUEzMC43ODMsMzAuNzgzLDAsMCwxLDIuNzMsNC4zNzFjMS0xLjAyNywyLjAzOC0yLjAyNSwzLjA2My0zLjAzMkExLjA0OSwxLjA0OSwwLDEsMSw3LjI3NywyLjgyQzYuNCwzLjcsNS41MDksNC41Nyw0LjYyNSw1LjQ0NmMtLjMyMy4zMjEtLjY0NC42NDUtLjk3My45NzYuMDg0LjA1OS4xODEuMDI3LjI3LjAyNyw3LjI1OCwwLDguNTE2LDAsMTUuNzc1LDBBMS4xMjksMS4xMjksMCwwLDEsMjEsNy4yOXYuNDcyWiIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoMCAtMC45OTkpIiBmaWxsPSIjYTU0ZWUxIi8+PC9zdmc+\"/>\r\n <div class=\"d-flex align-items-center gap-2 px-0 px-md-2 radius-3 user-avatar-name h-40\">\r\n <ds-avatar image=\"{{section?.header?.delegatedToThumbnail}}\" size=\"small\" class=\"user-avatar\"></ds-avatar>\r\n <span\r\n class=\"fs-14 fw-medium d-inline-block panel-user-name text-truncate\">{{ section?.header?.delegatedTo }}</span>\r\n </div>\r\n </div>\r\n }\r\n </div>\r\n }\r\n </ng-container>\r\n }\r\n\r\n @if (section?.body?.details?.['decision']?.key) {\r\n <ds-status\r\n class=\"main-status\"\r\n status=\"{{statusClass(section?.body?.details?.['decision']?.key)}}\">{{ section?.body?.details?.['decision']?.value }}\r\n </ds-status>\r\n }\r\n </div>\r\n\r\n <div class=\"approval-panel-toggle\">\r\n @if (approvalPanel.expanded) {\r\n <ds-icon icon=\"minus\" class=\"fs-20 fc-dark-gray\"></ds-icon>\r\n } @else {\r\n <ds-icon icon=\"plus-1\" class=\"fs-20 fc-coral\"></ds-icon>\r\n }\r\n </div>\r\n\r\n </div>\r\n </mat-expansion-panel-header>\r\n <section class=\"border-top pt-4\">\r\n <ng-container *ngComponentOutlet=\"sectionFormComponent; ndcDynamicInputs: input\"></ng-container>\r\n </section>\r\n\r\n</mat-expansion-panel>\r\n", styles: [":host ::ng-deep .mat-expansion-panel-content{background:#fff!important}:host .mat-expansion-panel-content{background:#fff!important}:host .approval-panel-container{display:grid;grid-template-columns:40% calc(60% - 45px) 20px;grid-template-areas:\"title details toggle\";gap:.75rem;place-content:space-between;align-items:center;flex-grow:1;width:100%}@media (max-width: 991px){:host .approval-panel-container{grid-template-columns:calc(100% - 45px) 20px;grid-template-areas:\"title toggle\" \"details details\"}}:host .approval-panel-container .approval-panel-title{grid-area:title}:host .approval-panel-container .panel-user-name{max-width:120px}@media (max-width: 768px){:host .approval-panel-container .panel-user-name.panel-ueser-only{max-width:140px}:host .approval-panel-container .panel-user-name:not(.panel-ueser-only){max-width:90px}}:host .approval-panel-container .approval-panel-details{display:flex;align-items:center;justify-content:space-between;grid-area:details}:host .approval-panel-container .approval-panel-toggle{grid-area:toggle;display:flex;align-items:center;justify-content:center;width:20px}:host ::ng-deep ds-avatar.user-avatar .avatar{--default-size: 25px}@media (min-width: 768px){:host ::ng-deep ds-avatar.user-avatar .avatar{--default-size: 31px;--avatar-border: 3px solid var(--light-gray)}}@media (min-width: 768px){:host ::ng-deep .user-avatar-name{padding-inline-end:1rem!important}}:host .circle-status::part(base){--status-radius: 50%;--status-size: 18px;--status-fs: 80% }:host .panel-title{min-width:40%;width:40%}@media (max-width: 576px){:host .panel-title{min-width:100%!important;width:100%!important}}:host .panel-user-status{min-width:60%;width:60%;display:flex;align-items:center;justify-content:space-between}@media (max-width: 576px){:host .panel-user-status{min-width:100%!important;width:100%!important}:host .panel-user-status .user-delegate{min-width:auto}:host .panel-user-status .main-status::part(base){--status-width: 50px}}\n"] }]
|
|
166
234
|
}], ctorParameters: () => [{ type: i1.CoreI18nService }, { type: i1.CoreService }, { type: i1.SidenavService }], propDecorators: { requestDetails: [{
|
|
167
235
|
type: Input
|
|
168
236
|
}], section: [{
|
|
@@ -182,4 +250,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
|
|
|
182
250
|
}], sectionName: [{
|
|
183
251
|
type: Input
|
|
184
252
|
}] } });
|
|
185
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-section.component.js","sourceRoot":"","sources":["../../../../../../../projects/bpm-core/src/lib/components/app-component-sections/form-section/form-section.component.ts","../../../../../../../projects/bpm-core/src/lib/components/app-component-sections/form-section/form-section.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAkC,SAAS,EAAE,sBAAsB,EAAE,KAAK,EAAoB,MAAM,eAAe,CAAC;AAE3H,OAAO,EAAC,0BAA0B,EAAE,aAAa,EAAC,MAAM,sBAAsB,CAAC;AAC/E,OAAO,EAAC,OAAO,EAAE,iBAAiB,EAAE,IAAI,EAAC,MAAM,iBAAiB,CAAC;AACjE,OAAO,EAAC,kBAAkB,EAAE,iBAAiB,EAAC,MAAM,6BAA6B,CAAC;AAClF,OAAO,EAAC,gBAAgB,EAAC,MAAM,sBAAsB,CAAC;AACtD,OAAO,EAAO,eAAe,EAAU,MAAM,qBAAqB,CAAC;AACnE,OAAO,KAAK,SAAS,MAAM,oBAAoB,CAAC;AAChD,OAAO,KAAK,MAAM,MAAM,QAAQ,CAAA;AAChC,OAAO,EAAC,uBAAuB,EAAC,MAAM,8CAA8C,CAAC;;;;;AAmBrF,MAAM,OAAO,oBAAoB;IAoCtB;IACU;IACA;IApCnB,QAAQ,GAAG,WAAW,CAAC;IACvB,uCAAuC;IACvC,WAAW,GAAG,WAAW,CAAC;IACjB,cAAc,CAAU;IACjC,eAAe,GAAQ,EAAE,CAAC;IACjB,OAAO,CAAU;IACjB,IAAI,CAAO;IACX,GAAG,CAAM;IACT,UAAU,CAAU;IAC7B,4BAA4B;IAC5B,qCAAqC;IAC5B,WAAW,CAAM;IACjB,2BAA2B,CAAM;IACjC,oBAAoB,GAAQ,IAAI,CAAC;IACjC,WAAW,GAAG,6BAA6B,CAAC;IACrD,aAAa,CAAS;IACtB,kBAAkB,CAAS;IAC3B,gBAAgB,CAAS;IACzB,SAAS,GAAG;QACV,SAAS,EAAE,KAAK;QAChB,OAAO,EAAE,IAAI;KACd,CAAC;IACF,QAAQ,GAAG;QACT,SAAS,EAAE,KAAK;QAChB,OAAO,EAAE,IAAI;KACd,CAAC;IACK,KAAK,CAAC;IACb,0BAA0B;IAE1B,cAAc,CAAS;IAChB,QAAQ,GACb,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,CAAC,MAAM,GAAG,MAAM,CAAC,CAAC,GAAG,MAAM,CAAC;IAEzD,YACS,IAAqB,EACX,WAAwB,EACxB,cAA8B;QAFxC,SAAI,GAAJ,IAAI,CAAiB;QACX,gBAAW,GAAX,WAAW,CAAa;QACxB,mBAAc,GAAd,cAAc,CAAgB;QAE/C,8BAA8B;IAChC,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,2BAA2B,CAAC,YAAY,CACvE,IAAI,CAAC,OAAO,CAAC,EAAE,CAChB,CAAC;QACF,IAAI,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,CAAC;YACxC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC;QACzD,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,2BAA2B,CAAC,cAAc,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QACtF,CAAC;QAED,IAAI,CAAC,KAAK,GAAG;YACX,UAAU,EAAE,IAAI,CAAC,UAAU;YAC3B,GAAG,EAAE,IAAI,CAAC,GAAG;YACb,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,iCAAiC;YACjC,uCAAuC;YACvC,IAAI,EAAC,IAAI,CAAC,IAAI;SACf,CAAC;QACF,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,cAAc,EAAE,CAAC;YAC9D,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,cAAc,CAAC;iBAC7D,MAAM,CAAC,OAAO,CAAC;iBACf,MAAM,CAAC,qBAAqB,CAAC,CAAC;QACnC,CAAC;QAED,oCAAoC;QACpC,MAAM,CAAC,GAAG,QAAQ,CAAC,gBAAgB,CAAC,WAAW,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC;QACpE,IAAI,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACjB,IAAI,CAAC,aAAa,GAAG,CAAC,CAAC,MAAM,CAAC;QAChC,CAAC;IACH,CAAC;IAGD,IAAI,UAAU;QACZ,MAAM,uBAAuB,GAAG,IAAI,CAAC,IAAI,EAAE,QAAQ,EAAE,MAAM,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,aAAa,IAAI,OAAO,EAAE,IAAI,EAAE,OAAO,CAAC,CAAC;QAC3I,IAAI,CAAC,uBAAuB;YAAE,OAAO,IAAI,CAAC;QAC1C,OAAO,IAAI,CAAC,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,WAAW,KAAK,MAAM,CAAC;IAC7D,CAAC;IAED,SAAS;QACP,OAAO,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC;IAC7D,CAAC;IAEO,6BAA6B,CAAC,QAAa;QACjD,OAAO,IAAI,eAAe,CACxB,KAAK,EACL,QAAQ,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,cAAc,EACtC,QAAQ,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,KAAK,EAC7B,QAAQ,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,IAAI,EAC5B,QAAQ,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,iBAAiB,EAAE,IAAI,EAC/C,QAAQ,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,QAAQ,EAAE,IAAI,EACtC,QAAQ,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,MAAM,EAAE,IAAI,EACpC,QAAQ,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,UAAU,EAAE,IAAI,EACxC,QAAQ,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,iBAAiB,EAAE,IAAI,EAC/C,QAAQ,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,QAAQ,EAChC,QAAQ,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,WAAW,EAAE,IAAI,EACzC,QAAQ,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,OAAO,EAAE,MAAM,EACvC,QAAQ,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,OAAO,EAAE,IAAI,EACrC,QAAQ,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,gBAAgB,EAAE,IAAI,CAC/C,CAAC;IACJ,CAAC;IAEO,uBAAuB,CAAC,QAAyB,EAAE,UAAkB;QAC3E,IAAI,CAAC,cAAc,CAAC,IAAI,GAAG,QAAQ,CAAC;QACpC,IAAI,CAAC,eAAe,GAAG,QAAQ,CAAC;QAChC,IAAI,CAAC,UAAU,CAAC,CAAC,OAAO,GAAG,QAAQ,CAAC;QACpC,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,MAAM,EAAE,uBAAuB,CAAC,CAAC;IAC/D,CAAC;IAED,sBAAsB,CAAC,KAAK,EAAE,UAAU;QACtC,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC;QAC3B,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,QAAQ,GAAG,IAAI,CAAC,UAAU,CAAC,CAAC;QAChC,IAAI,QAAQ,CAAC,OAAO,KAAK,IAAI,EAAE,CAAC;YAC9B,IAAI,CAAC,WAAW,GAAG,UAAU,CAAC;YAC9B,IAAI,SAAS,GAAG,CAAC,UAAU,KAAK,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,iBAAiB,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE,oBAAoB,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAC/J,IAAI,CAAC,WAAW,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC,SAAS,CAAC,CAAC,QAAa,EAAE,EAAE;gBACtE,IAAI,QAAQ,EAAE,CAAC;oBACb,IAAI,QAAQ,GAAG,IAAI,CAAC,6BAA6B,CAAC,QAAQ,CAAC,CAAC;oBAC5D,IAAI,CAAC,uBAAuB,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAC;gBACrD,CAAC;YACH,CAAC,CAAC,CAAC;QACL,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,uBAAuB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,OAAO,EAAE,UAAU,CAAC,CAAC;QACrE,CAAC;IACH,CAAC;IAED,WAAW,CAAC,MAAc;QACxB,IAAI,MAAM,EAAE,CAAC;YACX,IACE,MAAM,KAAK,SAAS,CAAC,oBAAoB,IAAI,MAAM,KAAK,SAAS,CAAC,qBAAqB;mBACpF,MAAM,CAAC,WAAW,EAAE,KAAK,QAAQ,IAAI,MAAM,CAAC,WAAW,EAAE,KAAK,aAAa,IAAI,MAAM,CAAC,WAAW,EAAE,KAAK,QAAQ,EACnH,CAAC;gBACD,OAAO,QAAQ,CAAC;YAClB,CAAC;iBAAM,IAAI,MAAM,KAAK,SAAS,CAAC,mBAAmB,IAAI,MAAM,CAAC,WAAW,EAAE,KAAK,SAAS,EAAE,CAAC;gBAC1F,OAAO,SAAS,CAAC;YACnB,CAAC;iBAAM,CAAC;gBACN,OAAO,SAAS,CAAC;YACnB,CAAC;QACH,CAAC;aAAM,CAAC;YACN,OAAO,SAAS,CAAC;QACnB,CAAC;IACH,CAAC;IAED,UAAU,CAAC,MAAc;QACvB,IAAI,MAAM,EAAE,CAAC;YACX,IACE,MAAM,KAAK,SAAS,CAAC,oBAAoB,IAAI,MAAM,KAAK,SAAS,CAAC,qBAAqB;mBACpF,MAAM,CAAC,WAAW,EAAE,KAAK,QAAQ,IAAI,MAAM,CAAC,WAAW,EAAE,KAAK,aAAa,IAAI,MAAM,CAAC,WAAW,EAAE,KAAK,QAAQ,EACnH,CAAC;gBACD,OAAO,OAAO,CAAC;YACjB,CAAC;iBAAM,IAAI,MAAM,KAAK,SAAS,CAAC,mBAAmB,IAAI,MAAM,CAAC,WAAW,EAAE,KAAK,SAAS,EAAE,CAAC;gBAC1F,OAAO,OAAO,CAAC;YACjB,CAAC;iBAAM,CAAC;gBACN,OAAO,OAAO,CAAC;YACjB,CAAC;QACH,CAAC;aAAM,CAAC;YACN,OAAO,OAAO,CAAC;QACjB,CAAC;IACH,CAAC;uGAjKU,oBAAoB;2FAApB,oBAAoB,oWC5BjC,0sJAwEA,u/DDvDI,kBAAkB,qYAElB,IAAI,6FACJ,iBAAiB,oPACjB,0BAA0B,qOAC1B,gBAAgB,+BAChB,OAAO,mFACP,aAAa;;2FAIJ,oBAAoB;kBAjBhC,SAAS;+BACE,kBAAkB,cAGhB,IAAI,WACP;wBACP,kBAAkB;wBAClB,iBAAiB;wBACjB,IAAI;wBACJ,iBAAiB;wBACjB,0BAA0B;wBAC1B,gBAAgB;wBAChB,OAAO;wBACP,aAAa;qBACd,WACQ,CAAC,sBAAsB,CAAC;2IAOxB,cAAc;sBAAtB,KAAK;gBAEG,OAAO;sBAAf,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,GAAG;sBAAX,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBAGG,WAAW;sBAAnB,KAAK;gBACG,2BAA2B;sBAAnC,KAAK;gBACG,oBAAoB;sBAA5B,KAAK;gBACG,WAAW;sBAAnB,KAAK","sourcesContent":["import {AfterViewChecked, AfterViewInit, Component, CUSTOM_ELEMENTS_SCHEMA, Input, OnInit, ViewChild} from '@angular/core';\r\nimport {CoreI18nService, CoreService, SidenavService} from '../../../services';\r\nimport {ComponentOutletIoDirective, DynamicModule} from 'ng-dynamic-component';\r\nimport {NgClass, NgComponentOutlet, NgIf} from '@angular/common';\r\nimport {MatExpansionModule, MatExpansionPanel} from '@angular/material/expansion';\r\nimport {SatPopoverModule} from '@ncstate/sat-popover';\r\nimport {Form, ProfileInfoDrop, Section} from '../../../interfaces';\r\nimport * as Constants from '../../../constants';\r\nimport * as moment from 'moment'\r\nimport {ProfileSectionComponent} from \"../profile-section/profile-section.component\";\r\n\r\n@Component({\r\n  selector: 'app-form-section',\r\n  templateUrl: './form-section.component.html',\r\n  styleUrls: ['./form-section.component.scss'],\r\n  standalone: true,\r\n  imports: [\r\n    MatExpansionModule,\r\n    MatExpansionPanel,\r\n    NgIf,\r\n    NgComponentOutlet,\r\n    ComponentOutletIoDirective,\r\n    SatPopoverModule,\r\n    NgClass,\r\n    DynamicModule\r\n  ],\r\n  schemas: [CUSTOM_ELEMENTS_SCHEMA]\r\n})\r\nexport class FormSectionComponent\r\n  implements OnInit {\r\n  userType = 'recipient';\r\n  // @ViewChild('popover') popover?: any;\r\n  popoverType = 'recipient';\r\n  @Input() requestDetails: Section;\r\n  userPopoverInfo: any = {};\r\n  @Input() section: Section;\r\n  @Input() form: Form;\r\n  @Input() lov: any;\r\n  @Input() isReadOnly: boolean;\r\n  // @Input() isOpen: boolean;\r\n  // @Input() isFinalApproval: boolean;\r\n  @Input() controllers: any;\r\n  @Input() segmentDynamicLoaderService: any;\r\n  @Input() sectionFormComponent: any = null;\r\n  @Input() sectionName = 'SECTION_NAME.requestDetails';\r\n  sectionNumber: number;\r\n  sectionStatusValue: string;\r\n  sectionStatusKey: string;\r\n  recipient = {\r\n    isShowing: false,\r\n    profile: null\r\n  };\r\n  delegate = {\r\n    isShowing: false,\r\n    profile: null\r\n  };\r\n  public input;\r\n  // highlightFlag: boolean;\r\n\r\n  processingDate: string;\r\n  public randomID: number =\r\n    Math.floor(Math.random() * (999999 - 100000)) + 100000;\r\n\r\n  constructor(\r\n    public i18n: CoreI18nService,\r\n    private readonly coreService: CoreService,\r\n    private readonly sidenavService: SidenavService\r\n  ) {\r\n    // this.highlightFlag = false;\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.sectionFormComponent = this.segmentDynamicLoaderService.getComponent(\r\n      this.section.id\r\n    );\r\n    if (this.section.body.details.stageName) {\r\n      this.sectionName = this.section.body.details.stageName;\r\n    } else {\r\n      this.sectionName = this.segmentDynamicLoaderService.getSectionName(this.section.id);\r\n    }\r\n\r\n    this.input = {\r\n      isReadOnly: this.isReadOnly,\r\n      lov: this.lov,\r\n      section: this.section,\r\n      // controllers: this.controllers,\r\n      // requestDetails: this.requestDetails,\r\n      form:this.form\r\n    };\r\n    if (this.section.header && this.section.header.processingDate) {\r\n      this.processingDate = moment(this.section.header.processingDate)\r\n        .locale('en-US')\r\n        .format('DD/MM/YYYY HH:mm:ss');\r\n    }\r\n\r\n    // this.highlightFlag = this.isOpen;\r\n    const x = document.querySelectorAll('#collapse' + this.sectionId());\r\n    if (x.length > 0) {\r\n      this.sectionNumber = x.length;\r\n    }\r\n  }\r\n\r\n\r\n  get isExpanded(): boolean {\r\n    const isExpandableFromBackend = this.form?.sections?.length && this.form.sections.some(section => 'expandStage' in section?.body?.details);\r\n    if (!isExpandableFromBackend) return true;\r\n    return this.section?.body?.details?.expandStage === 'true';\r\n  }\r\n\r\n  sectionId() {\r\n    return this.section.id.split(' ').join('') + this.randomID;\r\n  }\r\n\r\n  private createUserProfileFromResponse(response: any): ProfileInfoDrop {\r\n    return new ProfileInfoDrop(\r\n      false,\r\n      response?.[\"Users\"][0]?.employeeNumber,\r\n      response?.[\"Users\"][0]?.email,\r\n      response?.[\"Users\"][0]?.name,\r\n      response?.[\"Users\"][0]?.generalDepartment?.name,\r\n      response?.[\"Users\"][0]?.position?.name,\r\n      response?.[\"Users\"][0]?.sector?.name,\r\n      response?.[\"Users\"][0]?.department?.name,\r\n      response?.[\"Users\"][0]?.generalDepartment?.code,\r\n      response?.[\"Users\"][0]?.location,\r\n      response?.[\"Users\"][0]?.nationality?.desc,\r\n      response?.[\"Users\"][0]?.contact?.mobile,\r\n      response?.[\"Users\"][0]?.manager?.name,\r\n      response?.[\"Users\"][0]?.seniorSectorName?.name\r\n    );\r\n  }\r\n\r\n  private openOrCreateUserProfile(userData: ProfileInfoDrop, personType: string) {\r\n    this.sidenavService.data = userData;\r\n    this.userPopoverInfo = userData;\r\n    this[personType].profile = userData;\r\n    this.sidenavService.publish('open', ProfileSectionComponent);\r\n  }\r\n\r\n  toggleSmallProfileInfo(event, personType) {\r\n    this.userType = personType;\r\n    event.stopPropagation();\r\n    let userInfo = this[personType];\r\n    if (userInfo.profile === null) {\r\n      this.popoverType = personType;\r\n      let userEmail = (personType === 'recipient' ? this.section.header.personToThumbnail.split('=')[1] : this?.section?.header?.delegatedToThumbnail.split('=')[1]);\r\n      this.coreService.employeeProfile(userEmail).subscribe((response: any) => {\r\n        if (response) {\r\n          let userData = this.createUserProfileFromResponse(response);\r\n          this.openOrCreateUserProfile(userData, personType);\r\n        }\r\n      });\r\n    } else {\r\n      this.openOrCreateUserProfile(this[personType].profile, personType);\r\n    }\r\n  }\r\n\r\n  statusClass(status: string) {\r\n    if (status) {\r\n      if (\r\n        status === Constants.FORM_STATUS_REJECTED || status === Constants.FORM_STATUS_CANCELLED\r\n        || status.toLowerCase() === 'reject' || status.toLowerCase() === 'unsatisfied' || status.toLowerCase() === 'cancel'\r\n      ) {\r\n        return 'danger';\r\n      } else if (status === Constants.FORM_STATUS_PENDING || status.toLowerCase() === 'pending') {\r\n        return 'warning';\r\n      } else {\r\n        return 'success';\r\n      }\r\n    } else {\r\n      return 'success';\r\n    }\r\n  }\r\n\r\n  statusIcon(status: string) {\r\n    if (status) {\r\n      if (\r\n        status === Constants.FORM_STATUS_REJECTED || status === Constants.FORM_STATUS_CANCELLED\r\n        || status.toLowerCase() === 'reject' || status.toLowerCase() === 'unsatisfied' || status.toLowerCase() === 'cancel'\r\n      ) {\r\n        return 'close';\r\n      } else if (status === Constants.FORM_STATUS_PENDING || status.toLowerCase() === 'pending') {\r\n        return 'clock';\r\n      } else {\r\n        return 'check';\r\n      }\r\n    } else {\r\n      return 'check';\r\n    }\r\n  }\r\n}\r\n","<mat-expansion-panel\r\n  class=\"mb-4\" [expanded]=\"isExpanded\" *ngIf=\"form?.header?.status?.['key'] !== 'NEW' \" hideToggle\r\n  #approvalPanel=\"matExpansionPanel\">\r\n  <mat-expansion-panel-header>\r\n\r\n    <div class=\"approval-panel-container\">\r\n      <div class=\"d-flex gap-2 flex-grow-1 approval-panel-title\">\r\n        <ds-status\r\n          status=\"{{statusClass(sectionStatusKey)}}\" no-opacity icon\r\n          class=\"circle-status d-none d-sm-inline-block\">\r\n          <ds-icon icon=\"{{statusIcon(sectionStatusKey)}}\"></ds-icon>\r\n        </ds-status>\r\n        <div class=\"d-flex flex-column flex-grow-1\">\r\n          <span class=\"fs-16 fw-medium m-0\"> {{ sectionName }}</span>\r\n          <bdi class=\"fs-12 fc-dark-gray fw-normal line-height-1 d-block mt-1\" *ngIf=\"section.header?.processedBy\">\r\n            {{ processingDate }}\r\n          </bdi>\r\n        </div>\r\n      </div>\r\n      <div class=\"approval-panel-details gap-1\">\r\n\r\n        <ng-container *ngIf=\"(!section?.body?.details?.['stage0']?.['isStage0'] || section?.body?.details?.['stage0']?.['isStage0'] === 'false')\">\r\n          <div\r\n            class=\"d-flex align-items-center gap-3\" *ngIf=\"section?.header?.personTo;\"\r\n            (click)=\"$event.stopImmediatePropagation();\">\r\n            <div\r\n              (click)=\"toggleSmallProfileInfo($event, 'recipient')\"\r\n              class=\"d-flex align-items-center gap-2 radius-3 h-40\"\r\n              [ngClass]=\"{'user-avatar-name px-0 px-md-2': !section?.header?.delegatedTo, 'p-0': section?.header?.delegatedTo}\">\r\n              <ds-avatar image=\"{{section?.header?.personToThumbnail}}\" size=\"small\" class=\"user-avatar\"></ds-avatar>\r\n              <span\r\n                class=\"fs-14 fw-medium d-inline-block panel-user-name text-truncate\" [ngClass]=\"{'panel-user-only': !section?.header?.delegatedTo}\"\r\n                *ngIf=\"!section?.header?.delegatedTo\">{{ section?.header?.personTo }}</span>\r\n            </div>\r\n\r\n            <div\r\n              *ngIf=\"section?.header?.delegatedTo\" class=\"d-flex align-items-center gap-3\"\r\n              (click)=\"toggleSmallProfileInfo($event, 'delegate')\">\r\n              <img\r\n                class=\"rotate-arrow\"\r\n                alt=\"\"\r\n                src=\"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMSIgaGVpZ2h0PSIxMyIgdmlld0JveD0iMCAwIDIxIDEzIj48cGF0aCBkPSJNMjEsNy43NjNhMS42MjEsMS42MjEsMCwwLDEtLjQ0Ny41OTMsMS4zMDYsMS4zMDYsMCwwLDEtLjc1LjE5NGMtNy4yODQsMC04LjU2OCwwLTE1Ljg1MywwSDMuNjY5TDMuNjMsOC42Yy4wNzcuMDY0LjE1OC4xMjQuMjI5LjE5NHExLjcxLDEuNjksMy40MiwzLjM4MWExLjAyMywxLjAyMywwLDAsMSwuMjkxLDEuMDc5Ljk5Mi45OTIsMCwwLDEtLjguNzE5LDEuMDUzLDEuMDUzLDAsMCwxLTEtLjMzMVEzLjgzMSwxMS43MTksMS44ODYsOS44Yy0uNDQyLS40MzctLjg3OS0uODgxLTEuMzMtMS4zMDlBNC41NzIsNC41NzIsMCwwLDEsMCw3LjgxNFY3LjE4NUEzMC43ODMsMzAuNzgzLDAsMCwxLDIuNzMsNC4zNzFjMS0xLjAyNywyLjAzOC0yLjAyNSwzLjA2My0zLjAzMkExLjA0OSwxLjA0OSwwLDEsMSw3LjI3NywyLjgyQzYuNCwzLjcsNS41MDksNC41Nyw0LjYyNSw1LjQ0NmMtLjMyMy4zMjEtLjY0NC42NDUtLjk3My45NzYuMDg0LjA1OS4xODEuMDI3LjI3LjAyNyw3LjI1OCwwLDguNTE2LDAsMTUuNzc1LDBBMS4xMjksMS4xMjksMCwwLDEsMjEsNy4yOXYuNDcyWiIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoMCAtMC45OTkpIiBmaWxsPSIjYTU0ZWUxIi8+PC9zdmc+\"/>\r\n              <div class=\"d-flex align-items-center gap-2 px-0 px-md-2 radius-3 user-avatar-name h-40\">\r\n                <ds-avatar image=\"{{section?.header?.delegatedToThumbnail}}\" size=\"small\" class=\"user-avatar\"></ds-avatar>\r\n                <span\r\n                  class=\"fs-14 fw-medium d-inline-block panel-user-name text-truncate\">{{ section?.header?.delegatedTo }}</span>\r\n              </div>\r\n\r\n            </div>\r\n          </div>\r\n        </ng-container>\r\n        <ds-status\r\n          class=\"main-status\" *ngIf=\"section?.body?.details?.['decision']?.key;\"\r\n          status=\"{{statusClass(section?.body?.details?.['decision']?.key)}}\">{{ section?.body?.details?.['decision']?.value }}\r\n        </ds-status>\r\n      </div>\r\n\r\n      <div class=\"approval-panel-toggle\">\r\n        <ds-icon icon=\"plus-1\" class=\"fs-20 fc-coral\" *ngIf=\"!approvalPanel.expanded\"></ds-icon>\r\n        <ds-icon icon=\"minus\" class=\"fs-20 fc-dark-gray\" *ngIf=\"approvalPanel.expanded\"></ds-icon>\r\n      </div>\r\n\r\n    </div>\r\n  </mat-expansion-panel-header>\r\n  <section class=\"border-top pt-4\">\r\n    <ng-container  *ngComponentOutlet=\"sectionFormComponent; ndcDynamicInputs: input\"></ng-container>\r\n  </section>\r\n\r\n</mat-expansion-panel>\r\n<ng-container *ngIf=\"form?.header?.status?.['key'] == 'NEW' \">\r\n  <ng-container *ngComponentOutlet=\"sectionFormComponent; ndcDynamicInputs: input\"></ng-container>\r\n</ng-container>\r\n"]}
|
|
253
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-section.component.js","sourceRoot":"","sources":["../../../../../../../projects/bpm-core/src/lib/components/app-component-sections/form-section/form-section.component.ts","../../../../../../../projects/bpm-core/src/lib/components/app-component-sections/form-section/form-section.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, CUSTOM_ELEMENTS_SCHEMA, Input, OnInit} from '@angular/core';\r\nimport {CoreI18nService, CoreService, SidenavService} from '../../../services';\r\nimport {ComponentOutletIoDirective, DynamicModule} from 'ng-dynamic-component';\r\nimport {NgClass, NgComponentOutlet, NgIf} from '@angular/common';\r\nimport {MatExpansionModule, MatExpansionPanel} from '@angular/material/expansion';\r\nimport {SatPopoverModule} from '@ncstate/sat-popover';\r\nimport {Form, ProfileInfoDrop, Section} from '../../../interfaces';\r\nimport * as Constants from '../../../constants';\r\nimport {ProfileSectionComponent} from \"../profile-section/profile-section.component\";\r\nimport {format} from 'date-fns';\r\n\r\nconst StatusMap = {\r\n  [Constants.FORM_STATUS_REJECTED]: {class: 'danger', icon: 'close'},\r\n  [Constants.FORM_STATUS_CANCELLED]: {class: 'danger', icon: 'close'},\r\n  [Constants.FORM_STATUS_REJECT]: {class: 'danger', icon: 'close'},\r\n  [Constants.SECTION_STATUS_UNSATISFIED]: {class: 'danger', icon: 'close'},\r\n  [Constants.FORM_STATUS_CANCEL]: {class: 'danger', icon: 'close'},\r\n  [Constants.FORM_STATUS_PENDING]: {class: 'warning', icon: 'clock'},\r\n  'default': {class: 'success', icon: 'check'}\r\n}\r\n\r\n@Component({\r\n  selector: 'app-form-section',\r\n  templateUrl: './form-section.component.html',\r\n  styleUrls: ['./form-section.component.scss'],\r\n  standalone: true,\r\n  imports: [\r\n    MatExpansionModule,\r\n    MatExpansionPanel,\r\n    NgIf,\r\n    NgComponentOutlet,\r\n    ComponentOutletIoDirective,\r\n    SatPopoverModule,\r\n    NgClass,\r\n    DynamicModule\r\n  ],\r\n  schemas: [CUSTOM_ELEMENTS_SCHEMA]\r\n})\r\nexport class FormSectionComponent\r\n  implements OnInit {\r\n  userType = 'recipient';\r\n  popoverType = 'recipient';\r\n  @Input() requestDetails: Section;\r\n  userPopoverInfo: any = {};\r\n  @Input() section: Section;\r\n  @Input() form: Form;\r\n  @Input() lov: any;\r\n  @Input() isReadOnly: boolean;\r\n  @Input() controllers: any;\r\n  @Input() segmentDynamicLoaderService: any;\r\n  @Input() sectionFormComponent: any = null;\r\n  @Input() sectionName = 'SECTION_NAME.requestDetails';\r\n  sectionStatusKey: string;\r\n  recipient = {\r\n    isShowing: false,\r\n    profile: null\r\n  };\r\n  delegate = {\r\n    isShowing: false,\r\n    profile: null\r\n  };\r\n  public input;\r\n  processingDate: string;\r\n\r\n  constructor(\r\n    public i18n: CoreI18nService,\r\n    private readonly coreService: CoreService,\r\n    private readonly sidenavService: SidenavService\r\n  ) {\r\n  }\r\n\r\n  /**\r\n   * Method to initialize various components when the component is initialized.\r\n   *\r\n   * @return {void}\r\n   */\r\n  ngOnInit() {\r\n    this.initSectionFormComponent();\r\n    this.initSectionName();\r\n    this.initInput();\r\n    this.initProcessingDate();\r\n  }\r\n\r\n  /**\r\n   * Initializes the section form component by fetching it from the segment dynamic loader service.\r\n   *\r\n   * @return {void}\r\n   */\r\n  private initSectionFormComponent() {\r\n    this.sectionFormComponent = this.segmentDynamicLoaderService.getComponent(\r\n      this.section.id\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Initializes the section name based on the provided section data.\r\n   * If the section's body contains a 'stageName' property, the section name is set to the value of that property.\r\n   * Otherwise, the section name is retrieved using the segmentDynamicLoaderService based on the section ID.\r\n   *\r\n   * @return {void}\r\n   */\r\n  private initSectionName() {\r\n    if (this.section.body.details?.['stageName']) {\r\n      this.sectionName = this.section.body.details['stageName'];\r\n    } else {\r\n      this.sectionName = this.segmentDynamicLoaderService.getSectionName(this.section.id);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Initializes the input object with the provided values for read-only status, list of values, section, and form.\r\n   *\r\n   * @return {void}\r\n   */\r\n  private initInput() {\r\n    this.input = {\r\n      isReadOnly: this.isReadOnly,\r\n      lov: this.lov,\r\n      section: this.section,\r\n      form: this.form\r\n    };\r\n  }\r\n\r\n  /**\r\n   * Initializes the processing date based on the section's header processing date.\r\n   * If the processing date is available in the section header, it formats the processing date\r\n   * and assigns it to the processingDate property of the instance.\r\n   *\r\n   * @return {void}\r\n   */\r\n  private initProcessingDate() {\r\n    if (this.section?.header?.processingDate) {\r\n      this.processingDate = format(new Date(this.section.header.processingDate), \"dd/MM/yyyy hh:mm:ss\");\r\n    }\r\n  }\r\n\r\n\r\n  /**\r\n   * Check if the section is expanded.\r\n   *\r\n   * @return {boolean} Returns true if the section is expanded, false otherwise.\r\n   */\r\n  get isExpanded(): boolean {\r\n    const hasSections = Boolean(this.form?.sections?.length);\r\n    const isAnySectionExpandable = hasSections && this.form.sections.some(section => 'expandStage' in (section?.body?.details || {}));\r\n    return isAnySectionExpandable ? (this.section?.body?.details?.['expandStage'] === 'true') : true;\r\n  }\r\n\r\n  /**\r\n   * Create a ProfileInfoDrop object from the response object.\r\n   *\r\n   * @param {any} response - The response object containing user profile information.\r\n   *\r\n   * @return {ProfileInfoDrop} A ProfileInfoDrop object created from the response data.\r\n   */\r\n  private createUserProfileFromResponse(response: any): ProfileInfoDrop {\r\n    const user = response?.[\"Users\"][0];\r\n    return new ProfileInfoDrop(\r\n      false,\r\n      user?.employeeNumber,\r\n      user?.email,\r\n      user?.name,\r\n      user?.generalDepartment?.name,\r\n      user?.position?.name,\r\n      user?.sector?.name,\r\n      user?.department?.name,\r\n      user?.generalDepartment?.code,\r\n      user?.location,\r\n      user?.nationality?.desc,\r\n      user?.contact?.mobile,\r\n      user?.manager?.name,\r\n      user?.seniorSectorName?.name\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Method to open or create a user profile.\r\n   *\r\n   * @param {ProfileInfoDrop} userData - The user profile data to open or create.\r\n   * @param {string} personType - The type of person this profile belongs to.\r\n   *\r\n   * @return {void}\r\n   */\r\n  private openOrCreateUserProfile(userData: ProfileInfoDrop, personType: string) {\r\n    this.sidenavService.data = userData;\r\n    this.userPopoverInfo = userData;\r\n    this[personType].profile = userData;\r\n    this.sidenavService.publish('open', ProfileSectionComponent);\r\n  }\r\n\r\n  /**\r\n   * Toggles the display of small profile information for a given person type\r\n   *\r\n   * @param {any} event - The event that triggered the toggle\r\n   * @param {string} personType - The type of person for which to display the profile information\r\n   *\r\n   * @return {void}\r\n   */\r\n  toggleSmallProfileInfo(event: any, personType: string): void {\r\n    this.userType = personType;\r\n    event.stopPropagation();\r\n    let userInfo = this[personType];\r\n    if (!userInfo.profile) {\r\n      this.popoverType = personType;\r\n      let userEmail = this.getUserEmail(personType);\r\n      this.fetchAndSetUserProfile(userEmail, personType);\r\n    } else {\r\n      this.openOrCreateUserProfile(userInfo.profile, personType);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Retrieves the email of the user based on the personType parameter.\r\n   *\r\n   * @param {string} personType - Type of the person ('recipient' or others).\r\n   * @return {string} - The email address of the user.\r\n   */\r\n  private getUserEmail(personType: string): string {\r\n    return (personType === 'recipient'\r\n        ? this.section.header.personToThumbnail.split('=')[1]\r\n        : this?.section?.header?.delegatedToThumbnail.split('=')[1]\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Fetches the user profile using the provided user email and person type, then sets the profile.\r\n   *\r\n   * @param {string} userEmail - The email of the user whose profile is to be fetched and set.\r\n   * @param {string} personType - The type of person (e.g., employee, customer) for whom the profile is being fetched.\r\n   *\r\n   * @return {void}\r\n   */\r\n  private fetchAndSetUserProfile(userEmail: string, personType: string): void {\r\n    this.coreService.employeeProfile(userEmail).subscribe((response: any) => {\r\n      if (response) {\r\n        let userData = this.createUserProfileFromResponse(response);\r\n        this.openOrCreateUserProfile(userData, personType);\r\n      }\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Returns the CSS class associated with the input status.\r\n   *\r\n   * @param {string} status - The status for which the CSS class is needed.\r\n   * @return {string} - The CSS class corresponding to the given status.\r\n   */\r\n  statusClass(status: string): string {\r\n    status = status ? status.toLowerCase() : '';\r\n    let statusStrategy = StatusMap[status] || StatusMap['default'];\r\n    return statusStrategy.class;\r\n  }\r\n\r\n  /**\r\n   * Returns the icon associated with the provided status.\r\n   *\r\n   * @param {string} status - The status for which to retrieve the icon.\r\n   * @return {string} The icon corresponding to the provided status.\r\n   */\r\n  statusIcon(status: string): string {\r\n    status = status ? status.toLowerCase() : '';\r\n    let statusStrategy = StatusMap[status] || StatusMap['default'];\r\n    return statusStrategy.icon;\r\n  }\r\n}\r\n","<mat-expansion-panel class=\"mb-4\" [expanded]=\"isExpanded\" hideToggle #approvalPanel=\"matExpansionPanel\">\r\n  <mat-expansion-panel-header>\r\n\r\n    <div class=\"approval-panel-container\">\r\n      <div class=\"d-flex gap-2 flex-grow-1 approval-panel-title\">\r\n        <ds-status\r\n          status=\"{{statusClass(sectionStatusKey)}}\" no-opacity icon\r\n          class=\"circle-status d-none d-sm-inline-block\">\r\n          <ds-icon icon=\"{{statusIcon(sectionStatusKey)}}\"></ds-icon>\r\n        </ds-status>\r\n        <div class=\"d-flex flex-column flex-grow-1\">\r\n          <span class=\"fs-16 fw-medium m-0\"> {{ sectionName }}</span>\r\n          @if (section.header?.processedBy) {\r\n            <bdi class=\"fs-12 fc-dark-gray fw-normal line-height-1 d-block mt-1\">\r\n              {{ processingDate }}\r\n            </bdi>\r\n          }\r\n        </div>\r\n      </div>\r\n      <div class=\"approval-panel-details gap-1\">\r\n        @if (!section?.body?.details?.['stage0']?.['isStage0'] || section?.body?.details?.['stage0']?.['isStage0'] === 'false') {\r\n          <ng-container>\r\n            @if (section?.header?.personTo) {\r\n              <div\r\n                class=\"d-flex align-items-center gap-3\"\r\n                (click)=\"$event.stopImmediatePropagation();\">\r\n                <div\r\n                  (click)=\"toggleSmallProfileInfo($event, 'recipient')\"\r\n                  class=\"d-flex align-items-center gap-2 radius-3 h-40\"\r\n                  [ngClass]=\"{'user-avatar-name px-0 px-md-2': !section?.header?.delegatedTo, 'p-0': section?.header?.delegatedTo}\">\r\n                  <ds-avatar image=\"{{section?.header?.personToThumbnail}}\" size=\"small\" class=\"user-avatar\"></ds-avatar>\r\n                  @if (!section?.header?.delegatedTo) {\r\n                    <span\r\n                      class=\"fs-14 fw-medium d-inline-block panel-user-name text-truncate\"\r\n                      [ngClass]=\"{'panel-user-only': !section?.header?.delegatedTo}\"\r\n                    >{{ section?.header?.personTo }}</span>\r\n                  }\r\n                </div>\r\n                @if (section?.header?.delegatedTo) {\r\n                  <div\r\n                    class=\"d-flex align-items-center gap-3\"\r\n                    (click)=\"toggleSmallProfileInfo($event, 'delegate')\">\r\n                    <img\r\n                      class=\"rotate-arrow\"\r\n                      alt=\"\"\r\n                      src=\"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMSIgaGVpZ2h0PSIxMyIgdmlld0JveD0iMCAwIDIxIDEzIj48cGF0aCBkPSJNMjEsNy43NjNhMS42MjEsMS42MjEsMCwwLDEtLjQ0Ny41OTMsMS4zMDYsMS4zMDYsMCwwLDEtLjc1LjE5NGMtNy4yODQsMC04LjU2OCwwLTE1Ljg1MywwSDMuNjY5TDMuNjMsOC42Yy4wNzcuMDY0LjE1OC4xMjQuMjI5LjE5NHExLjcxLDEuNjksMy40MiwzLjM4MWExLjAyMywxLjAyMywwLDAsMSwuMjkxLDEuMDc5Ljk5Mi45OTIsMCwwLDEtLjguNzE5LDEuMDUzLDEuMDUzLDAsMCwxLTEtLjMzMVEzLjgzMSwxMS43MTksMS44ODYsOS44Yy0uNDQyLS40MzctLjg3OS0uODgxLTEuMzMtMS4zMDlBNC41NzIsNC41NzIsMCwwLDEsMCw3LjgxNFY3LjE4NUEzMC43ODMsMzAuNzgzLDAsMCwxLDIuNzMsNC4zNzFjMS0xLjAyNywyLjAzOC0yLjAyNSwzLjA2My0zLjAzMkExLjA0OSwxLjA0OSwwLDEsMSw3LjI3NywyLjgyQzYuNCwzLjcsNS41MDksNC41Nyw0LjYyNSw1LjQ0NmMtLjMyMy4zMjEtLjY0NC42NDUtLjk3My45NzYuMDg0LjA1OS4xODEuMDI3LjI3LjAyNyw3LjI1OCwwLDguNTE2LDAsMTUuNzc1LDBBMS4xMjksMS4xMjksMCwwLDEsMjEsNy4yOXYuNDcyWiIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoMCAtMC45OTkpIiBmaWxsPSIjYTU0ZWUxIi8+PC9zdmc+\"/>\r\n                    <div class=\"d-flex align-items-center gap-2 px-0 px-md-2 radius-3 user-avatar-name h-40\">\r\n                      <ds-avatar image=\"{{section?.header?.delegatedToThumbnail}}\" size=\"small\" class=\"user-avatar\"></ds-avatar>\r\n                      <span\r\n                        class=\"fs-14 fw-medium d-inline-block panel-user-name text-truncate\">{{ section?.header?.delegatedTo }}</span>\r\n                    </div>\r\n                  </div>\r\n                }\r\n              </div>\r\n            }\r\n          </ng-container>\r\n        }\r\n\r\n        @if (section?.body?.details?.['decision']?.key) {\r\n          <ds-status\r\n            class=\"main-status\"\r\n            status=\"{{statusClass(section?.body?.details?.['decision']?.key)}}\">{{ section?.body?.details?.['decision']?.value }}\r\n          </ds-status>\r\n        }\r\n      </div>\r\n\r\n      <div class=\"approval-panel-toggle\">\r\n        @if (approvalPanel.expanded) {\r\n          <ds-icon icon=\"minus\" class=\"fs-20 fc-dark-gray\"></ds-icon>\r\n        } @else {\r\n          <ds-icon icon=\"plus-1\" class=\"fs-20 fc-coral\"></ds-icon>\r\n        }\r\n      </div>\r\n\r\n    </div>\r\n  </mat-expansion-panel-header>\r\n  <section class=\"border-top pt-4\">\r\n    <ng-container *ngComponentOutlet=\"sectionFormComponent; ndcDynamicInputs: input\"></ng-container>\r\n  </section>\r\n\r\n</mat-expansion-panel>\r\n"]}
|
|
@@ -5,6 +5,5 @@ export * from './form-section/form-section.component';
|
|
|
5
5
|
export * from './main-request-details/main-request-details.component';
|
|
6
6
|
export * from './feedback-section/feedback-section.component';
|
|
7
7
|
export * from './profile-section/profile-section.component';
|
|
8
|
-
export * from './comment-section/comment-section.component';
|
|
9
8
|
export * from './layout/layout.component';
|
|
10
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
9
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9icG0tY29yZS9zcmMvbGliL2NvbXBvbmVudHMvYXBwLWNvbXBvbmVudC1zZWN0aW9ucy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDJDQUEyQyxDQUFBO0FBQ3pELGNBQWMsMkJBQTJCLENBQUE7QUFDekMsY0FBYywrQ0FBK0MsQ0FBQTtBQUM3RCxjQUFjLHVDQUF1QyxDQUFBO0FBQ3JELGNBQWMsdURBQXVELENBQUM7QUFDdEUsY0FBYywrQ0FBK0MsQ0FBQTtBQUM3RCxjQUFjLDZDQUE2QyxDQUFBO0FBQzNELGNBQWMsMkJBQTJCLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3NlcnZpY2UtaGVhZGVyL3NlcnZpY2UtaGVhZGVyLmNvbXBvbmVudCdcclxuZXhwb3J0ICogZnJvbSAnLi9zdGF0dXMvc3RhdHVzLmNvbXBvbmVudCdcclxuZXhwb3J0ICogZnJvbSAnLi93b3JrZmxvdy1zZWN0aW9uL3dvcmtmbG93LXNlY3Rpb24uY29tcG9uZW50J1xyXG5leHBvcnQgKiBmcm9tICcuL2Zvcm0tc2VjdGlvbi9mb3JtLXNlY3Rpb24uY29tcG9uZW50J1xyXG5leHBvcnQgKiBmcm9tICcuL21haW4tcmVxdWVzdC1kZXRhaWxzL21haW4tcmVxdWVzdC1kZXRhaWxzLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vZmVlZGJhY2stc2VjdGlvbi9mZWVkYmFjay1zZWN0aW9uLmNvbXBvbmVudCdcclxuZXhwb3J0ICogZnJvbSAnLi9wcm9maWxlLXNlY3Rpb24vcHJvZmlsZS1zZWN0aW9uLmNvbXBvbmVudCdcclxuZXhwb3J0ICogZnJvbSAnLi9sYXlvdXQvbGF5b3V0LmNvbXBvbmVudCdcclxuIl19
|
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import { Component, CUSTOM_ELEMENTS_SCHEMA, Input } from '@angular/core';
|
|
2
2
|
import { MatAccordion, MatExpansionModule, MatExpansionPanel } from '@angular/material/expansion';
|
|
3
|
-
import { NgIf } from '@angular/common';
|
|
4
3
|
import * as i0 from "@angular/core";
|
|
5
4
|
import * as i1 from "../../../services";
|
|
6
5
|
import * as i2 from "@angular/material/expansion";
|
|
@@ -13,19 +12,18 @@ export class MainRequestDetailsComponent {
|
|
|
13
12
|
this.i18n = i18n;
|
|
14
13
|
}
|
|
15
14
|
get isExpanded() {
|
|
16
|
-
return this.section?.body?.details?.expandStage === 'true';
|
|
15
|
+
return this.section?.body?.details?.['expandStage'] === 'true';
|
|
17
16
|
}
|
|
18
17
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: MainRequestDetailsComponent, deps: [{ token: i1.CoreI18nService }], target: i0.ɵɵFactoryTarget.Component });
|
|
19
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
18
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.8", type: MainRequestDetailsComponent, isStandalone: true, selector: "app-main-request-details", inputs: { section: "section", lov: "lov", form: "form" }, ngImport: i0, template: "<mat-accordion class=\"primary-accordion main-request-accordion border-top\">\r\n <mat-expansion-panel [expanded]=\"isExpanded || (form?.sections?.length === 1 )\" class=\"mb-3\" hideToggle #requestPanel=\"matExpansionPanel\">\r\n <mat-expansion-panel-header>\r\n <h2 class=\"fs-16 fw-medium fc-coral m-0 flex-grow-1\">{{ i18n.translate('requestDetailsTitle') }}</h2>\r\n @if (requestPanel.expanded) {\r\n <div class=\"d-inline-flex align-items-center gap-2\">\r\n <ds-icon icon=\"minus\" class=\"fs-20 fc-dark-gray\"></ds-icon>\r\n </div>\r\n } @else {\r\n <div class=\"d-inline-flex align-items-center gap-2\">\r\n <ds-icon icon=\"plus-1\" class=\"fs-20 fc-coral\"></ds-icon>\r\n </div>\r\n }\r\n </mat-expansion-panel-header>\r\n <section class=\"default-box box-shadow p-4\">\r\n <ng-content></ng-content>\r\n </section>\r\n </mat-expansion-panel>\r\n</mat-accordion>\r\n", styles: [".main-request-accordion{--accordion-height: 65px;--accordion-radius: 0 0 4px 4px;--accordion-shadow: 0 7px 10px rgba(var(--rgb-black), 3%);--accordion-border: 1px solid var(--light-gray);--accordion-border-active: 1px solid var(--gray);--panel-padding: 0 1.5rem;--panel-body-padding: 0 0 1.5rem;position:relative;z-index:1}@media (max-width: 576px){.main-request-accordion{--accordion-height: 55px;--panel-padding: 0 1rem;--panel-body-padding: 0 1rem 1rem}}.main-request-accordion .inner-accordion{--accordion-height: 44px;--accordion-bc: var(--light-gray);--accordion-bc-active: var(--white);--accordion-border: 1px solid var(--light-gray);--accordion-border-active: 1px solid var(--light-gray);--panel-body-padding: 0;--accordion-shadow: none;--panel-padding: 0 1.5rem}\n"], dependencies: [{ kind: "ngmodule", type: MatExpansionModule }, { kind: "directive", type: i2.MatAccordion, selector: "mat-accordion", inputs: ["hideToggle", "displayMode", "togglePosition"], exportAs: ["matAccordion"] }, { kind: "component", type: i2.MatExpansionPanel, selector: "mat-expansion-panel", inputs: ["hideToggle", "togglePosition"], outputs: ["afterExpand", "afterCollapse"], exportAs: ["matExpansionPanel"] }, { kind: "component", type: i2.MatExpansionPanelHeader, selector: "mat-expansion-panel-header", inputs: ["expandedHeight", "collapsedHeight", "tabIndex"] }] });
|
|
20
19
|
}
|
|
21
20
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: MainRequestDetailsComponent, decorators: [{
|
|
22
21
|
type: Component,
|
|
23
22
|
args: [{ selector: 'app-main-request-details', standalone: true, schemas: [CUSTOM_ELEMENTS_SCHEMA], imports: [
|
|
24
23
|
MatExpansionModule,
|
|
25
24
|
MatAccordion,
|
|
26
|
-
MatExpansionPanel
|
|
27
|
-
|
|
28
|
-
], template: "<mat-accordion class=\"primary-accordion main-request-accordion border-top\">\r\n <mat-expansion-panel [expanded]=\"isExpanded || (form?.sections?.length === 1 )\" class=\"mb-3\" hideToggle #requestPanel=\"matExpansionPanel\">\r\n <mat-expansion-panel-header>\r\n <h2 class=\"fs-16 fw-medium fc-coral m-0 flex-grow-1\">{{i18n.translate('requestDetailsTitle')}}</h2>\r\n <div class=\"d-inline-flex align-items-center gap-2\" *ngIf=\"!requestPanel.expanded\">\r\n <ds-icon icon=\"plus-1\" class=\"fs-20 fc-coral\"></ds-icon>\r\n </div>\r\n <div class=\"d-inline-flex align-items-center gap-2\" *ngIf=\"requestPanel.expanded\">\r\n <ds-icon icon=\"minus\" class=\"fs-20 fc-dark-gray\"></ds-icon>\r\n </div>\r\n </mat-expansion-panel-header>\r\n <section class=\"default-box box-shadow p-4\">\r\n <ng-content ></ng-content>\r\n </section>\r\n </mat-expansion-panel>\r\n</mat-accordion>\r\n", styles: [".main-request-accordion{--accordion-height: 65px;--accordion-radius: 0 0 4px 4px;--accordion-shadow: 0 7px 10px rgba(var(--rgb-black), 3%);--accordion-border: 1px solid var(--light-gray);--accordion-border-active: 1px solid var(--gray);--panel-padding: 0 1.5rem;--panel-body-padding: 0 0 1.5rem;position:relative;z-index:1}@media (max-width: 576px){.main-request-accordion{--accordion-height: 55px;--panel-padding: 0 1rem;--panel-body-padding: 0 1rem 1rem}}.main-request-accordion .inner-accordion{--accordion-height: 44px;--accordion-bc: var(--light-gray);--accordion-bc-active: var(--white);--accordion-border: 1px solid var(--light-gray);--accordion-border-active: 1px solid var(--light-gray);--panel-body-padding: 0;--accordion-shadow: none;--panel-padding: 0 1.5rem}\n"] }]
|
|
25
|
+
MatExpansionPanel
|
|
26
|
+
], template: "<mat-accordion class=\"primary-accordion main-request-accordion border-top\">\r\n <mat-expansion-panel [expanded]=\"isExpanded || (form?.sections?.length === 1 )\" class=\"mb-3\" hideToggle #requestPanel=\"matExpansionPanel\">\r\n <mat-expansion-panel-header>\r\n <h2 class=\"fs-16 fw-medium fc-coral m-0 flex-grow-1\">{{ i18n.translate('requestDetailsTitle') }}</h2>\r\n @if (requestPanel.expanded) {\r\n <div class=\"d-inline-flex align-items-center gap-2\">\r\n <ds-icon icon=\"minus\" class=\"fs-20 fc-dark-gray\"></ds-icon>\r\n </div>\r\n } @else {\r\n <div class=\"d-inline-flex align-items-center gap-2\">\r\n <ds-icon icon=\"plus-1\" class=\"fs-20 fc-coral\"></ds-icon>\r\n </div>\r\n }\r\n </mat-expansion-panel-header>\r\n <section class=\"default-box box-shadow p-4\">\r\n <ng-content></ng-content>\r\n </section>\r\n </mat-expansion-panel>\r\n</mat-accordion>\r\n", styles: [".main-request-accordion{--accordion-height: 65px;--accordion-radius: 0 0 4px 4px;--accordion-shadow: 0 7px 10px rgba(var(--rgb-black), 3%);--accordion-border: 1px solid var(--light-gray);--accordion-border-active: 1px solid var(--gray);--panel-padding: 0 1.5rem;--panel-body-padding: 0 0 1.5rem;position:relative;z-index:1}@media (max-width: 576px){.main-request-accordion{--accordion-height: 55px;--panel-padding: 0 1rem;--panel-body-padding: 0 1rem 1rem}}.main-request-accordion .inner-accordion{--accordion-height: 44px;--accordion-bc: var(--light-gray);--accordion-bc-active: var(--white);--accordion-border: 1px solid var(--light-gray);--accordion-border-active: 1px solid var(--light-gray);--panel-body-padding: 0;--accordion-shadow: none;--panel-padding: 0 1.5rem}\n"] }]
|
|
29
27
|
}], ctorParameters: () => [{ type: i1.CoreI18nService }], propDecorators: { section: [{
|
|
30
28
|
type: Input
|
|
31
29
|
}], lov: [{
|
|
@@ -33,4 +31,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
|
|
|
33
31
|
}], form: [{
|
|
34
32
|
type: Input
|
|
35
33
|
}] } });
|
|
36
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFpbi1yZXF1ZXN0LWRldGFpbHMuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYnBtLWNvcmUvc3JjL2xpYi9jb21wb25lbnRzL2FwcC1jb21wb25lbnQtc2VjdGlvbnMvbWFpbi1yZXF1ZXN0LWRldGFpbHMvbWFpbi1yZXF1ZXN0LWRldGFpbHMuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYnBtLWNvcmUvc3JjL2xpYi9jb21wb25lbnRzL2FwcC1jb21wb25lbnQtc2VjdGlvbnMvbWFpbi1yZXF1ZXN0LWRldGFpbHMvbWFpbi1yZXF1ZXN0LWRldGFpbHMuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxzQkFBc0IsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFHekUsT0FBTyxFQUFDLFlBQVksRUFBRSxrQkFBa0IsRUFBRSxpQkFBaUIsRUFBQyxNQUFNLDZCQUE2QixDQUFDOzs7O0FBY2hHLE1BQU0sT0FBTywyQkFBMkI7SUFJbkI7SUFIVixPQUFPLENBQVU7SUFDakIsR0FBRyxDQUFNO0lBQ1QsSUFBSSxDQUFPO0lBQ3BCLFlBQW1CLElBQXFCO1FBQXJCLFNBQUksR0FBSixJQUFJLENBQWlCO0lBQUcsQ0FBQztJQUU1QyxJQUFJLFVBQVU7UUFDWixPQUFPLElBQUksQ0FBQyxPQUFPLEVBQUUsSUFBSSxFQUFFLE9BQU8sRUFBRSxDQUFDLGFBQWEsQ0FBQyxLQUFLLE1BQU0sQ0FBQztJQUNqRSxDQUFDO3VHQVJVLDJCQUEyQjsyRkFBM0IsMkJBQTJCLDhJQ2pCeEMsazhCQW1CQSw4ekJEUEksa0JBQWtCOzsyRkFLVCwyQkFBMkI7a0JBWnZDLFNBQVM7K0JBQ0UsMEJBQTBCLGNBR3hCLElBQUksV0FDUCxDQUFDLHNCQUFzQixDQUFDLFdBQ3hCO3dCQUNQLGtCQUFrQjt3QkFDbEIsWUFBWTt3QkFDWixpQkFBaUI7cUJBQ2xCO29GQUdRLE9BQU87c0JBQWYsS0FBSztnQkFDRyxHQUFHO3NCQUFYLEtBQUs7Z0JBQ0csSUFBSTtzQkFBWixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBDVVNUT01fRUxFTUVOVFNfU0NIRU1BLCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBDb3JlSTE4blNlcnZpY2UgfSBmcm9tICcuLi8uLi8uLi9zZXJ2aWNlcyc7XHJcbmltcG9ydCB7IEZvcm0sIFNlY3Rpb24gfSBmcm9tICcuLi8uLi8uLi9pbnRlcmZhY2VzJztcclxuaW1wb3J0IHtNYXRBY2NvcmRpb24sIE1hdEV4cGFuc2lvbk1vZHVsZSwgTWF0RXhwYW5zaW9uUGFuZWx9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2V4cGFuc2lvbic7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2FwcC1tYWluLXJlcXVlc3QtZGV0YWlscycsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL21haW4tcmVxdWVzdC1kZXRhaWxzLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9tYWluLXJlcXVlc3QtZGV0YWlscy5jb21wb25lbnQuc2NzcyddLFxyXG4gIHN0YW5kYWxvbmU6IHRydWUsXHJcbiAgc2NoZW1hczogW0NVU1RPTV9FTEVNRU5UU19TQ0hFTUFdLFxyXG4gIGltcG9ydHM6IFtcclxuICAgIE1hdEV4cGFuc2lvbk1vZHVsZSxcclxuICAgIE1hdEFjY29yZGlvbixcclxuICAgIE1hdEV4cGFuc2lvblBhbmVsXHJcbiAgXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgTWFpblJlcXVlc3REZXRhaWxzQ29tcG9uZW50IHtcclxuICBASW5wdXQoKSBzZWN0aW9uOiBTZWN0aW9uO1xyXG4gIEBJbnB1dCgpIGxvdjogYW55O1xyXG4gIEBJbnB1dCgpIGZvcm06IEZvcm07XHJcbiAgY29uc3RydWN0b3IocHVibGljIGkxOG46IENvcmVJMThuU2VydmljZSkge31cclxuXHJcbiAgZ2V0IGlzRXhwYW5kZWQoKTogYm9vbGVhbiB7XHJcbiAgICByZXR1cm4gdGhpcy5zZWN0aW9uPy5ib2R5Py5kZXRhaWxzPy5bJ2V4cGFuZFN0YWdlJ10gPT09ICd0cnVlJztcclxuICB9XHJcbn1cclxuIiwiPG1hdC1hY2NvcmRpb24gY2xhc3M9XCJwcmltYXJ5LWFjY29yZGlvbiBtYWluLXJlcXVlc3QtYWNjb3JkaW9uIGJvcmRlci10b3BcIj5cclxuICA8bWF0LWV4cGFuc2lvbi1wYW5lbCBbZXhwYW5kZWRdPVwiaXNFeHBhbmRlZCB8fCAoZm9ybT8uc2VjdGlvbnM/Lmxlbmd0aCA9PT0gMSApXCIgY2xhc3M9XCJtYi0zXCIgaGlkZVRvZ2dsZSAjcmVxdWVzdFBhbmVsPVwibWF0RXhwYW5zaW9uUGFuZWxcIj5cclxuICAgIDxtYXQtZXhwYW5zaW9uLXBhbmVsLWhlYWRlcj5cclxuICAgICAgPGgyIGNsYXNzPVwiZnMtMTYgZnctbWVkaXVtIGZjLWNvcmFsIG0tMCBmbGV4LWdyb3ctMVwiPnt7IGkxOG4udHJhbnNsYXRlKCdyZXF1ZXN0RGV0YWlsc1RpdGxlJykgfX08L2gyPlxyXG4gICAgICBAaWYgKHJlcXVlc3RQYW5lbC5leHBhbmRlZCkge1xyXG4gICAgICAgIDxkaXYgY2xhc3M9XCJkLWlubGluZS1mbGV4IGFsaWduLWl0ZW1zLWNlbnRlciBnYXAtMlwiPlxyXG4gICAgICAgICAgPGRzLWljb24gaWNvbj1cIm1pbnVzXCIgY2xhc3M9XCJmcy0yMCBmYy1kYXJrLWdyYXlcIj48L2RzLWljb24+XHJcbiAgICAgICAgPC9kaXY+XHJcbiAgICAgIH0gQGVsc2Uge1xyXG4gICAgICAgIDxkaXYgY2xhc3M9XCJkLWlubGluZS1mbGV4IGFsaWduLWl0ZW1zLWNlbnRlciBnYXAtMlwiPlxyXG4gICAgICAgICAgPGRzLWljb24gaWNvbj1cInBsdXMtMVwiIGNsYXNzPVwiZnMtMjAgZmMtY29yYWxcIj48L2RzLWljb24+XHJcbiAgICAgICAgPC9kaXY+XHJcbiAgICAgIH1cclxuICAgIDwvbWF0LWV4cGFuc2lvbi1wYW5lbC1oZWFkZXI+XHJcbiAgICA8c2VjdGlvbiBjbGFzcz1cImRlZmF1bHQtYm94IGJveC1zaGFkb3cgcC00XCI+XHJcbiAgICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cclxuICAgIDwvc2VjdGlvbj5cclxuICA8L21hdC1leHBhbnNpb24tcGFuZWw+XHJcbjwvbWF0LWFjY29yZGlvbj5cclxuIl19
|