@hmcts/ccpay-web-component 6.5.14 → 6.5.15-beta1
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/hmcts-ccpay-web-component.mjs +5 -0
- package/esm2022/lib/components/add-remission/add-remission.component.mjs +1276 -0
- package/esm2022/lib/components/allocate-payments/allocate-payments.component.mjs +423 -0
- package/esm2022/lib/components/card-details/card-details.component.mjs +32 -0
- package/esm2022/lib/components/case-transactions/case-transactions.component.mjs +885 -0
- package/esm2022/lib/components/contact-details/contact-details.component.mjs +338 -0
- package/esm2022/lib/components/error-banner/error-banner.component.mjs +18 -0
- package/esm2022/lib/components/fee-summary/fee-summary.component.mjs +280 -0
- package/esm2022/lib/components/mark-unidentified-payment/mark-unidentified-payment.component.mjs +195 -0
- package/esm2022/lib/components/mark-unsolicited-payment/mark-unsolicited-payment.component.mjs +275 -0
- package/esm2022/lib/components/notification-preview/notification-preview.component.mjs +79 -0
- package/esm2022/lib/components/page-not-found.component.mjs +17 -0
- package/esm2022/lib/components/payment-list/payment-list.component.mjs +36 -0
- package/esm2022/lib/components/payment-view/payment-view.component.mjs +467 -0
- package/esm2022/lib/components/pba-details/pba-details.component.mjs +18 -0
- package/esm2022/lib/components/pba-payment/pba-payment.component.mjs +163 -0
- package/esm2022/lib/components/process-refund/process-refund.component.mjs +417 -0
- package/esm2022/lib/components/processed-payments/processed-payments.component.mjs +37 -0
- package/esm2022/lib/components/refund-list/refund-list.component.mjs +73 -0
- package/esm2022/lib/components/refund-status/refund-status.component.mjs +481 -0
- package/esm2022/lib/components/reports/reports.component.mjs +337 -0
- package/esm2022/lib/components/service-request/service-request.component.mjs +516 -0
- package/esm2022/lib/components/status-history/status-history.component.mjs +33 -0
- package/esm2022/lib/components/table/table.component.mjs +127 -0
- package/esm2022/lib/components/unprocessed-payments/unprocessed-payments.component.mjs +236 -0
- package/esm2022/lib/interfaces/AddRemissionRequest.mjs +17 -0
- package/esm2022/lib/interfaces/AddRetroRemissionRequest.mjs +9 -0
- package/esm2022/lib/interfaces/AllocatePaymentRequest.mjs +41 -0
- package/esm2022/lib/interfaces/IAllocationPaymentsRequest.mjs +20 -0
- package/esm2022/lib/interfaces/IBSPayments.mjs +2 -0
- package/esm2022/lib/interfaces/ICardDetails.mjs +2 -0
- package/esm2022/lib/interfaces/IFee.mjs +2 -0
- package/esm2022/lib/interfaces/INotificationPreview.mjs +2 -0
- package/esm2022/lib/interfaces/IOrderReferenceFee.mjs +2 -0
- package/esm2022/lib/interfaces/IPatchRefundAction.mjs +2 -0
- package/esm2022/lib/interfaces/IPayment.mjs +2 -0
- package/esm2022/lib/interfaces/IPaymentFailure.mjs +2 -0
- package/esm2022/lib/interfaces/IPaymentGroup.mjs +2 -0
- package/esm2022/lib/interfaces/IPaymentStatus.mjs +12 -0
- package/esm2022/lib/interfaces/IPaymentView.mjs +2 -0
- package/esm2022/lib/interfaces/IPayments.mjs +2 -0
- package/esm2022/lib/interfaces/IPutNotificationRequest.mjs +13 -0
- package/esm2022/lib/interfaces/IRefundAction.mjs +2 -0
- package/esm2022/lib/interfaces/IRefundContactDetails.mjs +2 -0
- package/esm2022/lib/interfaces/IRefundFee.mjs +2 -0
- package/esm2022/lib/interfaces/IRefundList.mjs +2 -0
- package/esm2022/lib/interfaces/IRefundReasons.mjs +2 -0
- package/esm2022/lib/interfaces/IRefundRejectReason.mjs +2 -0
- package/esm2022/lib/interfaces/IRefundStatus.mjs +2 -0
- package/esm2022/lib/interfaces/IRefundStatusHistory.mjs +2 -0
- package/esm2022/lib/interfaces/IRefundsNotifications.mjs +2 -0
- package/esm2022/lib/interfaces/IRemission.mjs +2 -0
- package/esm2022/lib/interfaces/IResubmitRefundRequest.mjs +13 -0
- package/esm2022/lib/interfaces/IStatusHistories.mjs +2 -0
- package/esm2022/lib/interfaces/IStatusHistory.mjs +2 -0
- package/esm2022/lib/interfaces/IserviceRequestCardPayment.mjs +11 -0
- package/esm2022/lib/interfaces/IserviceRequestPbaPayment.mjs +15 -0
- package/esm2022/lib/interfaces/IssueRefundRequest.mjs +11 -0
- package/esm2022/lib/interfaces/NotificationPreviewRequest.mjs +46 -0
- package/esm2022/lib/interfaces/PayhubAntennaRequest.mjs +14 -0
- package/esm2022/lib/interfaces/PaymentToPayhubRequest.mjs +17 -0
- package/esm2022/lib/interfaces/PostIssueRefundRetroRemission.mjs +9 -0
- package/esm2022/lib/interfaces/PostRefundRetroRemission.mjs +18 -0
- package/esm2022/lib/interfaces/RefundsRequest.mjs +9 -0
- package/esm2022/lib/interfaces/UnidentifiedPaymentsRequest.mjs +16 -0
- package/esm2022/lib/interfaces/UnsolicitedPaymentsRequest.mjs +22 -0
- package/esm2022/lib/payment-lib.component.mjs +430 -0
- package/esm2022/lib/payment-lib.module.mjs +181 -0
- package/esm2022/lib/payment-lib.service.mjs +49 -0
- package/esm2022/lib/pipes/capitalize.pipe.mjs +18 -0
- package/esm2022/lib/pipes/ccd-hyphens.pipe.mjs +22 -0
- package/esm2022/lib/pipes/key-value.pipe.mjs +23 -0
- package/esm2022/lib/pipes/sanitize-html.pipe.mjs +20 -0
- package/esm2022/lib/services/bulk-scaning-payment/bulk-scaning-payment.service.mjs +87 -0
- package/esm2022/lib/services/card-details/card-details.service.mjs +39 -0
- package/esm2022/lib/services/case-transactions/case-transactions.service.mjs +39 -0
- package/esm2022/lib/services/notification/notification.service.mjs +70 -0
- package/esm2022/lib/services/orderslist.service.mjs +154 -0
- package/esm2022/lib/services/payment-list/payment-list.service.mjs +40 -0
- package/esm2022/lib/services/payment-view/payment-view.service.mjs +156 -0
- package/esm2022/lib/services/refunds/refunds.service.mjs +120 -0
- package/esm2022/lib/services/shared/error-handler.service.mjs +76 -0
- package/esm2022/lib/services/shared/httpclient/webcomponent.http.client.mjs +64 -0
- package/esm2022/lib/services/shared/logger/console-logger.service.mjs +43 -0
- package/esm2022/lib/services/shared/logger/logger.service.mjs +23 -0
- package/esm2022/lib/services/status-history/status-history.service.mjs +41 -0
- package/esm2022/lib/services/xl-file/xl-file.service.mjs +197 -0
- package/esm2022/public_api.mjs +7 -0
- package/fesm2022/hmcts-ccpay-web-component.mjs +217 -262
- package/fesm2022/hmcts-ccpay-web-component.mjs.map +1 -1
- package/index.d.ts +5 -2340
- package/lib/components/add-remission/add-remission.component.d.ts +208 -0
- package/lib/components/allocate-payments/allocate-payments.component.d.ts +115 -0
- package/lib/components/card-details/card-details.component.d.ts +18 -0
- package/lib/components/case-transactions/case-transactions.component.d.ts +143 -0
- package/lib/components/contact-details/contact-details.component.d.ts +54 -0
- package/lib/components/error-banner/error-banner.component.d.ts +9 -0
- package/lib/components/fee-summary/fee-summary.component.d.ts +72 -0
- package/lib/components/mark-unidentified-payment/mark-unidentified-payment.component.d.ts +52 -0
- package/lib/components/mark-unsolicited-payment/mark-unsolicited-payment.component.d.ts +63 -0
- package/lib/components/notification-preview/notification-preview.component.d.ts +30 -0
- package/lib/components/page-not-found.component.d.ts +5 -0
- package/lib/components/payment-list/payment-list.component.d.ts +19 -0
- package/lib/components/payment-view/payment-view.component.d.ts +110 -0
- package/lib/components/pba-details/pba-details.component.d.ts +10 -0
- package/lib/components/pba-payment/pba-payment.component.d.ts +41 -0
- package/lib/components/process-refund/process-refund.component.d.ts +82 -0
- package/lib/components/processed-payments/processed-payments.component.d.ts +17 -0
- package/lib/components/refund-list/refund-list.component.d.ts +26 -0
- package/lib/components/refund-status/refund-status.component.d.ts +119 -0
- package/lib/components/reports/reports.component.d.ts +49 -0
- package/lib/components/service-request/service-request.component.d.ts +141 -0
- package/lib/components/status-history/status-history.component.d.ts +19 -0
- package/lib/components/table/table.component.d.ts +45 -0
- package/lib/components/unprocessed-payments/unprocessed-payments.component.d.ts +61 -0
- package/lib/interfaces/AddRemissionRequest.d.ts +11 -0
- package/lib/interfaces/AddRetroRemissionRequest.d.ts +5 -0
- package/lib/interfaces/AllocatePaymentRequest.d.ts +31 -0
- package/lib/interfaces/IAllocationPaymentsRequest.d.ts +9 -0
- package/lib/interfaces/IBSPayments.d.ts +19 -0
- package/lib/interfaces/ICardDetails.d.ts +7 -0
- package/lib/interfaces/IFee.d.ts +29 -0
- package/lib/interfaces/INotificationPreview.d.ts +27 -0
- package/lib/interfaces/IOrderReferenceFee.d.ts +9 -0
- package/lib/interfaces/IPatchRefundAction.d.ts +4 -0
- package/lib/interfaces/IPayment.d.ts +35 -0
- package/lib/interfaces/IPaymentFailure.d.ts +13 -0
- package/lib/interfaces/IPaymentGroup.d.ts +11 -0
- package/lib/interfaces/IPaymentStatus.d.ts +11 -0
- package/lib/interfaces/IPaymentView.d.ts +5 -0
- package/lib/interfaces/IPayments.d.ts +4 -0
- package/lib/interfaces/IPutNotificationRequest.d.ts +6 -0
- package/lib/interfaces/IRefundAction.d.ts +4 -0
- package/lib/interfaces/IRefundContactDetails.d.ts +9 -0
- package/lib/interfaces/IRefundFee.d.ts +7 -0
- package/lib/interfaces/IRefundList.d.ts +20 -0
- package/lib/interfaces/IRefundReasons.d.ts +6 -0
- package/lib/interfaces/IRefundRejectReason.d.ts +4 -0
- package/lib/interfaces/IRefundStatus.d.ts +8 -0
- package/lib/interfaces/IRefundStatusHistory.d.ts +5 -0
- package/lib/interfaces/IRefundsNotifications.d.ts +16 -0
- package/lib/interfaces/IRemission.d.ts +14 -0
- package/lib/interfaces/IResubmitRefundRequest.d.ts +9 -0
- package/lib/interfaces/IStatusHistories.d.ts +7 -0
- package/lib/interfaces/IStatusHistory.d.ts +7 -0
- package/lib/interfaces/IserviceRequestCardPayment.d.ts +6 -0
- package/lib/interfaces/IserviceRequestPbaPayment.d.ts +8 -0
- package/lib/interfaces/IssueRefundRequest.d.ts +6 -0
- package/lib/interfaces/NotificationPreviewRequest.d.ts +25 -0
- package/lib/interfaces/PayhubAntennaRequest.d.ts +8 -0
- package/lib/interfaces/PaymentToPayhubRequest.d.ts +11 -0
- package/lib/interfaces/PostIssueRefundRetroRemission.d.ts +6 -0
- package/lib/interfaces/PostRefundRetroRemission.d.ts +11 -0
- package/lib/interfaces/RefundsRequest.d.ts +5 -0
- package/lib/interfaces/UnidentifiedPaymentsRequest.d.ts +7 -0
- package/lib/interfaces/UnsolicitedPaymentsRequest.d.ts +10 -0
- package/lib/payment-lib.component.d.ts +156 -0
- package/lib/payment-lib.module.d.ts +42 -0
- package/lib/payment-lib.service.d.ts +21 -0
- package/lib/pipes/capitalize.pipe.d.ts +8 -0
- package/lib/pipes/ccd-hyphens.pipe.d.ts +8 -0
- package/lib/pipes/key-value.pipe.d.ts +8 -0
- package/lib/pipes/sanitize-html.pipe.d.ts +10 -0
- package/lib/services/bulk-scaning-payment/bulk-scaning-payment.service.d.ts +27 -0
- package/lib/services/card-details/card-details.service.d.ts +17 -0
- package/lib/services/case-transactions/case-transactions.service.d.ts +17 -0
- package/lib/services/notification/notification.service.d.ts +21 -0
- package/lib/services/orderslist.service.d.ts +77 -0
- package/lib/services/payment-list/payment-list.service.d.ts +18 -0
- package/lib/services/payment-view/payment-view.service.d.ts +61 -0
- package/lib/services/refunds/refunds.service.d.ts +36 -0
- package/lib/services/shared/error-handler.service.d.ts +14 -0
- package/lib/services/shared/httpclient/webcomponent.http.client.d.ts +17 -0
- package/lib/services/shared/logger/console-logger.service.d.ts +11 -0
- package/lib/services/shared/logger/logger.service.d.ts +14 -0
- package/lib/services/status-history/status-history.service.d.ts +17 -0
- package/lib/services/xl-file/xl-file.service.d.ts +16 -0
- package/package.json +5 -3
- package/public_api.d.ts +3 -0
|
@@ -0,0 +1,423 @@
|
|
|
1
|
+
import { Component, Input, Inject, EventEmitter, Output } from '@angular/core';
|
|
2
|
+
import { FormBuilder, Validators, FormControl } from '@angular/forms';
|
|
3
|
+
import { PaymentViewService } from '../../services/payment-view/payment-view.service';
|
|
4
|
+
import { CaseTransactionsService } from '../../services/case-transactions/case-transactions.service';
|
|
5
|
+
import { BulkScaningPaymentService } from '../../services/bulk-scaning-payment/bulk-scaning-payment.service';
|
|
6
|
+
import { ErrorHandlerService } from '../../services/shared/error-handler.service';
|
|
7
|
+
import { AllocatePaymentRequest } from '../../interfaces/AllocatePaymentRequest';
|
|
8
|
+
import { IAllocationPaymentsRequest } from '../../interfaces/IAllocationPaymentsRequest';
|
|
9
|
+
import { OrderslistService } from '../../services/orderslist.service';
|
|
10
|
+
import * as i0 from "@angular/core";
|
|
11
|
+
import * as i1 from "../../services/shared/error-handler.service";
|
|
12
|
+
import * as i2 from "../../services/case-transactions/case-transactions.service";
|
|
13
|
+
import * as i3 from "@angular/forms";
|
|
14
|
+
import * as i4 from "../../services/payment-view/payment-view.service";
|
|
15
|
+
import * as i5 from "../../services/bulk-scaning-payment/bulk-scaning-payment.service";
|
|
16
|
+
import * as i6 from "../../services/orderslist.service";
|
|
17
|
+
import * as i7 from "@angular/common";
|
|
18
|
+
import * as i8 from "../error-banner/error-banner.component";
|
|
19
|
+
import * as i9 from "../../pipes/key-value.pipe";
|
|
20
|
+
export class AllocatePaymentsComponent {
|
|
21
|
+
errorHandlerService;
|
|
22
|
+
caseTransactionsService;
|
|
23
|
+
formBuilder;
|
|
24
|
+
paymentViewService;
|
|
25
|
+
paymentLibComponent;
|
|
26
|
+
bulkScaningPaymentService;
|
|
27
|
+
OrderslistService;
|
|
28
|
+
isTurnOff;
|
|
29
|
+
caseType;
|
|
30
|
+
reasonEventEmitter = new EventEmitter();
|
|
31
|
+
explanationEventEmitter = new EventEmitter();
|
|
32
|
+
overUnderPaymentForm;
|
|
33
|
+
viewStatus;
|
|
34
|
+
ccdCaseNumber;
|
|
35
|
+
bspaymentdcn;
|
|
36
|
+
recordId;
|
|
37
|
+
feedbackUrlLabel;
|
|
38
|
+
unAllocatedPayment = {
|
|
39
|
+
amount: 0
|
|
40
|
+
};
|
|
41
|
+
siteID = null;
|
|
42
|
+
// errorMessage = this.errorHandlerService.getServerErrorMessage(false, false, '');
|
|
43
|
+
errorMessage = null;
|
|
44
|
+
paymentGroup;
|
|
45
|
+
paymentGroups = [];
|
|
46
|
+
remainingAmount;
|
|
47
|
+
isRemainingAmountGtZero;
|
|
48
|
+
isMoreDetailsBoxHide = true;
|
|
49
|
+
isRemainingAmountLtZero;
|
|
50
|
+
afterFeeAllocateOutstanding;
|
|
51
|
+
amountForAllocation;
|
|
52
|
+
isConfirmButtondisabled = false;
|
|
53
|
+
isContinueButtondisabled = true;
|
|
54
|
+
otherPaymentExplanation = null;
|
|
55
|
+
selectedOption = null;
|
|
56
|
+
isFeeAmountZero = false;
|
|
57
|
+
paymentReasonHasError = false;
|
|
58
|
+
paymentExplanationHasError = false;
|
|
59
|
+
isPaymentDetailsEmpty = false;
|
|
60
|
+
isPaymentDetailsInvalid = false;
|
|
61
|
+
paymentDetailsMinHasError = false;
|
|
62
|
+
paymentDetailsMaxHasError = false;
|
|
63
|
+
isUserNameEmpty = false;
|
|
64
|
+
isUserNameInvalid = false;
|
|
65
|
+
ccdReference = null;
|
|
66
|
+
exceptionReference = null;
|
|
67
|
+
paymentReason = null;
|
|
68
|
+
paymentExplanation = null;
|
|
69
|
+
userName = null;
|
|
70
|
+
paymentSectionLabel;
|
|
71
|
+
paymentRef = null;
|
|
72
|
+
isStrategicFixEnable = true;
|
|
73
|
+
orderLevelFees = [];
|
|
74
|
+
cookieUserName = [];
|
|
75
|
+
enCookieUserName;
|
|
76
|
+
userNameField = null;
|
|
77
|
+
reasonList = {
|
|
78
|
+
overPayment: {
|
|
79
|
+
hwfReward: 'Help with Fees (HWF) awarded. Please include the HWF reference number in the explanatory note',
|
|
80
|
+
wrongFee: 'Incorrect payment received',
|
|
81
|
+
notIssueCase: 'Unable to issue case',
|
|
82
|
+
otherDeduction: 'Other'
|
|
83
|
+
},
|
|
84
|
+
shortFall: {
|
|
85
|
+
helpWithFee: 'Help with Fees (HWF) application declined',
|
|
86
|
+
wrongFee: 'Incorrect payment received',
|
|
87
|
+
other: 'Other'
|
|
88
|
+
}
|
|
89
|
+
};
|
|
90
|
+
explanationList = {
|
|
91
|
+
overPayment: {
|
|
92
|
+
referRefund: 'Details in case notes. Refund due',
|
|
93
|
+
noRefund: 'Details in case notes. No refund due',
|
|
94
|
+
noCase: 'No case created. Refund due',
|
|
95
|
+
other: 'Other'
|
|
96
|
+
},
|
|
97
|
+
shortFall: {
|
|
98
|
+
holdCase: 'I have put a stop on the case and contacted the applicant requesting the balance of payment',
|
|
99
|
+
heldCase: 'I have put a stop on the case. The applicant needs to be contacted to request the balance of payment',
|
|
100
|
+
other: 'Other'
|
|
101
|
+
}
|
|
102
|
+
};
|
|
103
|
+
refund = {
|
|
104
|
+
reason: {
|
|
105
|
+
duplicate: 'Duplicate payment',
|
|
106
|
+
humanerror: 'Human error',
|
|
107
|
+
caseWithdrawn: 'Case withdrawn',
|
|
108
|
+
other: 'Other'
|
|
109
|
+
}
|
|
110
|
+
};
|
|
111
|
+
constructor(errorHandlerService, caseTransactionsService, formBuilder, paymentViewService, paymentLibComponent, bulkScaningPaymentService, OrderslistService) {
|
|
112
|
+
this.errorHandlerService = errorHandlerService;
|
|
113
|
+
this.caseTransactionsService = caseTransactionsService;
|
|
114
|
+
this.formBuilder = formBuilder;
|
|
115
|
+
this.paymentViewService = paymentViewService;
|
|
116
|
+
this.paymentLibComponent = paymentLibComponent;
|
|
117
|
+
this.bulkScaningPaymentService = bulkScaningPaymentService;
|
|
118
|
+
this.OrderslistService = OrderslistService;
|
|
119
|
+
}
|
|
120
|
+
ngOnInit() {
|
|
121
|
+
this.viewStatus = 'mainForm';
|
|
122
|
+
if (this.paymentLibComponent.paymentGroupReference !== null) {
|
|
123
|
+
this.viewStatus = 'allocatePaymentConfirmation';
|
|
124
|
+
}
|
|
125
|
+
this.ccdCaseNumber = this.paymentLibComponent.CCD_CASE_NUMBER;
|
|
126
|
+
this.bspaymentdcn = this.paymentLibComponent.bspaymentdcn;
|
|
127
|
+
this.paymentRef = this.paymentLibComponent.paymentGroupReference;
|
|
128
|
+
this.selectedOption = this.paymentLibComponent.SELECTED_OPTION;
|
|
129
|
+
this.isStrategicFixEnable = this.paymentLibComponent.ISSFENABLE;
|
|
130
|
+
this.isTurnOff = this.paymentLibComponent.isTurnOff;
|
|
131
|
+
this.overUnderPaymentForm = this.formBuilder.group({
|
|
132
|
+
moreDetails: new FormControl('', Validators.compose([
|
|
133
|
+
Validators.required,
|
|
134
|
+
Validators.minLength(3),
|
|
135
|
+
Validators.maxLength(255),
|
|
136
|
+
Validators.pattern('^([a-zA-Z0-9\\s,\\.]*)$')
|
|
137
|
+
])),
|
|
138
|
+
userName: new FormControl('', Validators.compose([
|
|
139
|
+
Validators.required,
|
|
140
|
+
Validators.pattern('^([a-zA-Z0-9\\s]*)$')
|
|
141
|
+
])),
|
|
142
|
+
});
|
|
143
|
+
this.OrderslistService.getOrdersList().subscribe((data) => this.orderLevelFees = data.filter(data => data.orderStatus !== 'Paid'));
|
|
144
|
+
this.OrderslistService.getCaseType().subscribe((data) => this.caseType = data);
|
|
145
|
+
this.getUnassignedPayment();
|
|
146
|
+
}
|
|
147
|
+
getGroupOutstandingAmount(paymentGroup) {
|
|
148
|
+
return this.bulkScaningPaymentService.calculateOutStandingAmount(paymentGroup);
|
|
149
|
+
}
|
|
150
|
+
getExplanationValue(inputValue) {
|
|
151
|
+
this.paymentExplanation = inputValue;
|
|
152
|
+
this.explanationEventEmitter.emit(this.paymentExplanation);
|
|
153
|
+
}
|
|
154
|
+
;
|
|
155
|
+
getReasonValue(inputValue) {
|
|
156
|
+
this.paymentReason = inputValue;
|
|
157
|
+
this.reasonEventEmitter.emit(this.paymentReason);
|
|
158
|
+
}
|
|
159
|
+
;
|
|
160
|
+
getPaymentGroupDetails() {
|
|
161
|
+
if (!this.isTurnOff) {
|
|
162
|
+
this.paymentViewService.getPaymentGroupDetails(this.paymentRef).subscribe(paymentGroup => {
|
|
163
|
+
this.errorMessage = this.errorHandlerService.getServerErrorMessage(false, false, '');
|
|
164
|
+
this.paymentGroup = paymentGroup;
|
|
165
|
+
this.saveAndContinue();
|
|
166
|
+
}, (error) => {
|
|
167
|
+
this.errorMessage = this.errorHandlerService.getServerErrorMessage(true, false, '');
|
|
168
|
+
});
|
|
169
|
+
}
|
|
170
|
+
else {
|
|
171
|
+
this.caseTransactionsService.getPaymentGroups(this.ccdCaseNumber).subscribe(paymentGroups => {
|
|
172
|
+
this.errorMessage = this.errorHandlerService.getServerErrorMessage(false, false, '');
|
|
173
|
+
this.paymentGroups = paymentGroups['payment_groups'].filter(paymentGroup => {
|
|
174
|
+
paymentGroup.fees.forEach(fee => {
|
|
175
|
+
if (fee.calculated_amount === 0) {
|
|
176
|
+
this.isFeeAmountZero = true;
|
|
177
|
+
}
|
|
178
|
+
});
|
|
179
|
+
let fstCon = this.getGroupOutstandingAmount(paymentGroup), scndCn = fstCon > 0 || (fstCon == 0 && this.isFeeAmountZero) && paymentGroup.payment_group_reference === this.paymentRef;
|
|
180
|
+
return this.paymentRef ? scndCn : fstCon > 0 || (fstCon == 0 && this.isFeeAmountZero);
|
|
181
|
+
});
|
|
182
|
+
}, (error) => {
|
|
183
|
+
this.errorMessage = this.errorHandlerService.getServerErrorMessage(true, false, '');
|
|
184
|
+
});
|
|
185
|
+
}
|
|
186
|
+
}
|
|
187
|
+
selectedPaymentGroup(paymentGroup) {
|
|
188
|
+
this.isContinueButtondisabled = false;
|
|
189
|
+
this.paymentGroup = paymentGroup;
|
|
190
|
+
}
|
|
191
|
+
gotoCasetransationPage() {
|
|
192
|
+
this.paymentLibComponent.viewName = 'case-transactions';
|
|
193
|
+
this.paymentLibComponent.isTurnOff = this.isTurnOff;
|
|
194
|
+
this.paymentLibComponent.TAKEPAYMENT = true;
|
|
195
|
+
this.paymentLibComponent.ISBSENABLE = true;
|
|
196
|
+
}
|
|
197
|
+
gotoSummaryPage(event) {
|
|
198
|
+
event.preventDefault();
|
|
199
|
+
this.paymentLibComponent.viewName = 'fee-summary';
|
|
200
|
+
this.paymentLibComponent.isTurnOff = this.isTurnOff;
|
|
201
|
+
this.paymentLibComponent.TAKEPAYMENT = true;
|
|
202
|
+
this.paymentLibComponent.ISBSENABLE = true;
|
|
203
|
+
}
|
|
204
|
+
cancelAllocatePayment(event) {
|
|
205
|
+
event.preventDefault();
|
|
206
|
+
this.resetForm([false, false, false, false, false, false, false, false], 'all');
|
|
207
|
+
if (!this.isTurnOff) {
|
|
208
|
+
this.paymentLibComponent.viewName = 'fee-summary';
|
|
209
|
+
this.paymentLibComponent.isTurnOff = this.isTurnOff;
|
|
210
|
+
this.paymentLibComponent.TAKEPAYMENT = true;
|
|
211
|
+
this.paymentLibComponent.ISBSENABLE = true;
|
|
212
|
+
}
|
|
213
|
+
else {
|
|
214
|
+
this.viewStatus = 'mainForm';
|
|
215
|
+
}
|
|
216
|
+
}
|
|
217
|
+
confirmAllocatePayement() {
|
|
218
|
+
this.enCookieUserName = document.cookie.split(";").find(row => row.includes("user-info")).split("=")[1].split(";");
|
|
219
|
+
this.cookieUserName = JSON.parse(decodeURIComponent(this.enCookieUserName));
|
|
220
|
+
const fullName = this.cookieUserName['forename'] + ' ' + this.cookieUserName['surname'];
|
|
221
|
+
const paymentDetailsField = this.overUnderPaymentForm.controls.moreDetails, paymentFormError = this.overUnderPaymentForm.controls.moreDetails.errors, userNameField = fullName, isEmptyCondtion = this.paymentReason && this.paymentExplanation, isOtherOptionSelected = this.paymentExplanation === 'Other';
|
|
222
|
+
this.resetForm([false, false, false, false, false, false, false, false], 'all');
|
|
223
|
+
if ((!this.isRemainingAmountGtZero && !this.isRemainingAmountLtZero) || isEmptyCondtion && (!isOtherOptionSelected && userNameField.length > 0 || isOtherOptionSelected && userNameField.length > 0 && paymentDetailsField.valid)) {
|
|
224
|
+
this.isConfirmButtondisabled = true;
|
|
225
|
+
this.otherPaymentExplanation = this.paymentExplanation === 'Other' ? paymentDetailsField.value : this.paymentExplanation;
|
|
226
|
+
this.userName = userNameField;
|
|
227
|
+
this.finalServiceCall();
|
|
228
|
+
}
|
|
229
|
+
else {
|
|
230
|
+
if (!this.paymentReason) {
|
|
231
|
+
this.resetForm([true, false, false, false, false, false, false, false], 'reason');
|
|
232
|
+
}
|
|
233
|
+
if (!this.paymentExplanation) {
|
|
234
|
+
this.resetForm([false, true, false, false, false, false, false, false], 'explanation');
|
|
235
|
+
}
|
|
236
|
+
if (this.paymentExplanation && isOtherOptionSelected) {
|
|
237
|
+
if (paymentDetailsField.value == '') {
|
|
238
|
+
this.resetForm([false, false, true, false, false, false, false, false], 'other');
|
|
239
|
+
}
|
|
240
|
+
if (paymentDetailsField.value != '' && paymentDetailsField.invalid) {
|
|
241
|
+
this.resetForm([false, false, false, true, false, false, false, false], 'other');
|
|
242
|
+
}
|
|
243
|
+
if (paymentFormError && paymentFormError.minlength && paymentFormError.minlength.actualLength < 3) {
|
|
244
|
+
this.resetForm([false, false, false, false, true, false, false, false], 'other');
|
|
245
|
+
}
|
|
246
|
+
if (paymentFormError && paymentFormError.maxlength && paymentFormError.maxlength.actualLength > 255) {
|
|
247
|
+
this.resetForm([false, false, false, false, false, true, false, false], 'other');
|
|
248
|
+
}
|
|
249
|
+
}
|
|
250
|
+
if (userNameField.length === 0) {
|
|
251
|
+
this.resetForm([false, false, false, false, false, false, true, false], 'username');
|
|
252
|
+
}
|
|
253
|
+
}
|
|
254
|
+
}
|
|
255
|
+
resetForm(vals, field) {
|
|
256
|
+
if (field === 'reason' || field === 'all') {
|
|
257
|
+
this.paymentReasonHasError = vals[0];
|
|
258
|
+
}
|
|
259
|
+
if (field === 'explanation' || field === 'all') {
|
|
260
|
+
this.paymentExplanationHasError = vals[1];
|
|
261
|
+
}
|
|
262
|
+
if (field === 'other' || field === 'all') {
|
|
263
|
+
this.isPaymentDetailsEmpty = vals[2];
|
|
264
|
+
this.isPaymentDetailsInvalid = vals[3];
|
|
265
|
+
this.paymentDetailsMinHasError = vals[4];
|
|
266
|
+
this.paymentDetailsMaxHasError = vals[5];
|
|
267
|
+
}
|
|
268
|
+
if (field === 'username' || field === 'all') {
|
|
269
|
+
this.isUserNameEmpty = vals[6];
|
|
270
|
+
this.isUserNameInvalid = vals[7];
|
|
271
|
+
}
|
|
272
|
+
}
|
|
273
|
+
finalServiceCall() {
|
|
274
|
+
if (!this.isStrategicFixEnable) {
|
|
275
|
+
let allocatedRequest = {
|
|
276
|
+
reason: this.paymentReason,
|
|
277
|
+
allocation_status: 'Allocated',
|
|
278
|
+
explanation: this.otherPaymentExplanation,
|
|
279
|
+
payment_allocation_status: {
|
|
280
|
+
description: '',
|
|
281
|
+
name: 'Allocated'
|
|
282
|
+
},
|
|
283
|
+
payment_group_reference: this.paymentGroup.payment_group_reference,
|
|
284
|
+
case_type: this.caseType,
|
|
285
|
+
user_name: this.userName
|
|
286
|
+
};
|
|
287
|
+
const postStrategicBody = new AllocatePaymentRequest(this.ccdReference, this.unAllocatedPayment, this.caseType, this.exceptionReference, allocatedRequest);
|
|
288
|
+
this.bulkScaningPaymentService.postBSPaymentStrategic(postStrategicBody, this.paymentGroup.payment_group_reference).subscribe(res => {
|
|
289
|
+
this.errorMessage = this.errorHandlerService.getServerErrorMessage(false, false, '');
|
|
290
|
+
let response = JSON.parse(res);
|
|
291
|
+
if (response.success) {
|
|
292
|
+
this.gotoCasetransationPage();
|
|
293
|
+
}
|
|
294
|
+
}, (error) => {
|
|
295
|
+
this.errorMessage = this.errorHandlerService.getServerErrorMessage(true, false, '');
|
|
296
|
+
window.scrollTo(0, 0);
|
|
297
|
+
this.isConfirmButtondisabled = false;
|
|
298
|
+
});
|
|
299
|
+
}
|
|
300
|
+
else {
|
|
301
|
+
this.bulkScaningPaymentService.patchBSChangeStatus(this.unAllocatedPayment.dcn_reference, 'PROCESSED').subscribe(res1 => {
|
|
302
|
+
this.errorMessage = this.errorHandlerService.getServerErrorMessage(false, false, '');
|
|
303
|
+
let response1 = JSON.parse(res1);
|
|
304
|
+
if (response1.success) {
|
|
305
|
+
const requestBody = new AllocatePaymentRequest(this.ccdReference, this.unAllocatedPayment, this.siteID, this.exceptionReference);
|
|
306
|
+
this.bulkScaningPaymentService.postBSAllocatePayment(requestBody, this.paymentGroup.payment_group_reference).subscribe(res2 => {
|
|
307
|
+
this.errorMessage = this.errorHandlerService.getServerErrorMessage(false, false, '');
|
|
308
|
+
let response2 = JSON.parse(res2);
|
|
309
|
+
const reqBody = new IAllocationPaymentsRequest(response2['data'].payment_group_reference, response2['data'].reference, this.paymentReason, this.otherPaymentExplanation, this.userName);
|
|
310
|
+
if (response2.success) {
|
|
311
|
+
this.paymentViewService.postBSAllocationPayments(reqBody).subscribe(res3 => {
|
|
312
|
+
this.errorMessage = this.errorHandlerService.getServerErrorMessage(false, false, '');
|
|
313
|
+
let response3 = JSON.parse(res3);
|
|
314
|
+
if (response3.success) {
|
|
315
|
+
this.gotoCasetransationPage();
|
|
316
|
+
}
|
|
317
|
+
}, (error) => {
|
|
318
|
+
this.bulkScaningPaymentService.patchBSChangeStatus(this.unAllocatedPayment.dcn_reference, 'COMPLETE').subscribe();
|
|
319
|
+
this.errorMessage = this.errorHandlerService.getServerErrorMessage(true, false, '');
|
|
320
|
+
window.scrollTo(0, 0);
|
|
321
|
+
this.isConfirmButtondisabled = false;
|
|
322
|
+
});
|
|
323
|
+
}
|
|
324
|
+
}, (error) => {
|
|
325
|
+
this.bulkScaningPaymentService.patchBSChangeStatus(this.unAllocatedPayment.dcn_reference, 'COMPLETE').subscribe();
|
|
326
|
+
this.errorMessage = this.errorHandlerService.getServerErrorMessage(true, false, '');
|
|
327
|
+
window.scrollTo(0, 0);
|
|
328
|
+
this.isConfirmButtondisabled = false;
|
|
329
|
+
});
|
|
330
|
+
}
|
|
331
|
+
}, (error) => {
|
|
332
|
+
this.errorMessage = this.errorHandlerService.getServerErrorMessage(true, false, '');
|
|
333
|
+
window.scrollTo(0, 0);
|
|
334
|
+
this.isConfirmButtondisabled = false;
|
|
335
|
+
});
|
|
336
|
+
}
|
|
337
|
+
}
|
|
338
|
+
saveAndContinue() {
|
|
339
|
+
if (this.paymentGroup) {
|
|
340
|
+
this.isMoreDetailsBoxHide = true;
|
|
341
|
+
this.overUnderPaymentForm.get('moreDetails').reset();
|
|
342
|
+
this.overUnderPaymentForm.get('moreDetails').setValue('');
|
|
343
|
+
this.overUnderPaymentForm.get('userName').reset();
|
|
344
|
+
this.overUnderPaymentForm.get('userName').setValue('');
|
|
345
|
+
this.paymentReason = '';
|
|
346
|
+
this.paymentExplanation = '';
|
|
347
|
+
let GroupOutstandingAmount = this.getGroupOutstandingAmount(this.paymentGroup);
|
|
348
|
+
const remainingToBeAssigned = this.unAllocatedPayment.amount - GroupOutstandingAmount;
|
|
349
|
+
this.isRemainingAmountGtZero = remainingToBeAssigned > 0;
|
|
350
|
+
this.isRemainingAmountLtZero = remainingToBeAssigned < 0;
|
|
351
|
+
this.paymentSectionLabel = this.isRemainingAmountGtZero ? {
|
|
352
|
+
title: 'There is an Over payment of',
|
|
353
|
+
reason: 'Provide a reason. This will be used in the Refund process.',
|
|
354
|
+
} : this.isRemainingAmountLtZero ? {
|
|
355
|
+
title: 'There is an Under payment of',
|
|
356
|
+
reason: 'Provide a reason',
|
|
357
|
+
} : {
|
|
358
|
+
title: 'Amount left to be allocated',
|
|
359
|
+
reason: '',
|
|
360
|
+
};
|
|
361
|
+
this.feedbackUrlLabel = this.isRemainingAmountGtZero ? 'CONFIRMALLOCATION_SURPLUS' : this.isRemainingAmountLtZero ? 'CONFIRMALLOCATION_SHORTFALL' : 'CONFIRMALLOCATION';
|
|
362
|
+
this.remainingAmount = this.isRemainingAmountGtZero ? remainingToBeAssigned : this.isRemainingAmountLtZero ? remainingToBeAssigned * -1 : 0;
|
|
363
|
+
this.afterFeeAllocateOutstanding = remainingToBeAssigned >= 0 ? 0 : (remainingToBeAssigned * -1);
|
|
364
|
+
this.amountForAllocation = GroupOutstandingAmount >= this.unAllocatedPayment.amount ? this.unAllocatedPayment.amount : GroupOutstandingAmount;
|
|
365
|
+
if (this.isTurnOff) {
|
|
366
|
+
this.viewStatus = 'allocatePaymentConfirmation';
|
|
367
|
+
}
|
|
368
|
+
}
|
|
369
|
+
}
|
|
370
|
+
getUnassignedPayment() {
|
|
371
|
+
this.bulkScaningPaymentService.getBSPaymentsByDCN(this.bspaymentdcn).subscribe(unassignedPayments => {
|
|
372
|
+
this.errorMessage = this.errorHandlerService.getServerErrorMessage(false, false, '');
|
|
373
|
+
this.unAllocatedPayment = unassignedPayments['data'].payments.filter(payment => {
|
|
374
|
+
return payment && payment.dcn_reference == this.bspaymentdcn;
|
|
375
|
+
})[0];
|
|
376
|
+
this.siteID = unassignedPayments['data'].responsible_service_id;
|
|
377
|
+
const beCcdNumber = unassignedPayments['data'].ccd_reference, beExceptionNumber = unassignedPayments['data'].exception_record_reference, exceptionReference = beCcdNumber ? beCcdNumber === this.ccdCaseNumber ? null : this.ccdCaseNumber : this.ccdCaseNumber;
|
|
378
|
+
this.ccdReference = beCcdNumber ? beCcdNumber : null;
|
|
379
|
+
this.exceptionReference = beExceptionNumber ? beExceptionNumber : exceptionReference;
|
|
380
|
+
this.getPaymentGroupDetails();
|
|
381
|
+
}, (error) => {
|
|
382
|
+
this.errorMessage = this.errorHandlerService.getServerErrorMessage(true, false, '');
|
|
383
|
+
});
|
|
384
|
+
}
|
|
385
|
+
selectRadioButton(key, type) {
|
|
386
|
+
this.isMoreDetailsBoxHide = true;
|
|
387
|
+
if (type === 'explanation' && key === 'other') {
|
|
388
|
+
this.isPaymentDetailsEmpty = false;
|
|
389
|
+
this.isPaymentDetailsInvalid = false;
|
|
390
|
+
this.paymentDetailsMinHasError = false;
|
|
391
|
+
this.paymentDetailsMaxHasError = false;
|
|
392
|
+
this.isMoreDetailsBoxHide = false;
|
|
393
|
+
}
|
|
394
|
+
}
|
|
395
|
+
OrderListSelectEvent(orderef) {
|
|
396
|
+
this.isContinueButtondisabled = false;
|
|
397
|
+
this.recordId = orderef;
|
|
398
|
+
}
|
|
399
|
+
redirectToOrderFeeSearchPage() {
|
|
400
|
+
// this.paymentLibComponent.bspaymentdcn = null;
|
|
401
|
+
this.paymentLibComponent.paymentGroupReference = this.recordId;
|
|
402
|
+
this.paymentLibComponent.isTurnOff = this.isTurnOff;
|
|
403
|
+
this.paymentLibComponent.viewName = 'fee-summary';
|
|
404
|
+
}
|
|
405
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AllocatePaymentsComponent, deps: [{ token: i1.ErrorHandlerService }, { token: i2.CaseTransactionsService }, { token: i3.FormBuilder }, { token: i4.PaymentViewService }, { token: 'PAYMENT_LIB' }, { token: i5.BulkScaningPaymentService }, { token: i6.OrderslistService }], target: i0.ɵɵFactoryTarget.Component });
|
|
406
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: AllocatePaymentsComponent, selector: "app-allocate-payments", inputs: { isTurnOff: "isTurnOff", caseType: "caseType" }, outputs: { reasonEventEmitter: "reasonEventEmitter", explanationEventEmitter: "explanationEventEmitter" }, ngImport: i0, template: "<div class=\"allocate-payments\">\n <ng-container *ngIf=\"viewStatus === 'mainForm' && !isTurnOff\">\n\n <div class=\"govuk-breadcrumbs\">\n <ol class=\"govuk-breadcrumbs__list\">\n <li class=\"govuk-breadcrumbs__list-item\">\n <a (click)=\"gotoCasetransationPage()\" class=\"govuk-back-link govuk-label\">Back</a>\n </li>\n </ol>\n </div>\n\n <div class=\"paymentrequest\">\n <h1 class=\"govuk-heading-xl govuk-!-margin-top-3 govuk-!-margin-bottom-4\">Select payment request</h1>\n <p class=\"govuk-!-margin-top-5 casererf\">Case reference: {{ccdReference}}</p>\n </div>\n\n <div *ngFor=\"let orderRef of orderLevelFees; let i = index;\" class=\"multiple-choice unprocessed-payments--radio-button\">\n <input id=\"'orderfee'+i+''\"\n aria-label=\"orderLevelRecord\"\n name=\"orderLevelRecord\"\n\n (click)=\"OrderListSelectEvent(orderRef.orderRefId)\"\n type=\"radio\"\n value=\"{{orderRef.orderTotalFees}}\" />\n <label for=\"radio-inline-1\"> {{orderRef.orderTotalFees | currency :'GBP':'symbol':'1.2-2'}}({{orderRef.orderStatus}})</label>\n </div>\n\n <div class=\"paymentrequest\">\n <button [disabled]=\"isContinueButtondisabled\" type=\"submit\" (click)=\"redirectToOrderFeeSearchPage()\" class=\"button allbtb button--disabled govuk-!-margin-right-1\">\n Continue\n </button>\n </div>\n\n </ng-container>\n\n <div *ngIf=\"viewStatus==='mainForm' && isTurnOff\">\n <input #myInput type='hidden' class='iFrameDrivenImageValue' value='ALLOCATEPAYMENTS'>\n <div class=\"govuk-breadcrumbs\" *ngIf=\"paymentRef\">\n <ol class=\"govuk-breadcrumbs__list\">\n <li class=\"govuk-breadcrumbs__list-item\">\n <a href=\"#\" (click)=\"gotoSummaryPage($event)\" class=\"govuk-back-link\">Back</a>\n </li>\n </ol>\n </div>\n <div class=\"govuk-heading-section\">\n <h1 class=\"govuk-heading-xl\">Allocate payment to fee group</h1>\n <h2 class=\"govuk-heading-l\">Amount left to be allocated:\n {{ unAllocatedPayment.amount | currency:'GBP':'symbol-narrow':'1.2-2' }}</h2>\n </div>\n <div class=\"payment-group-section\" *ngFor=\"let paymentGroup of paymentGroups\">\n <h3 class=\"govuk-heading-m\">Group reference: {{paymentGroup.payment_group_reference}}</h3>\n <table class=\"govuk-table\">\n <thead class=\"govuk-table__head\">\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__header\" scope=\"col\"></td>\n <td class=\"govuk-table__header\" scope=\"col\">Code</td>\n <td class=\"govuk-table__header\" scope=\"col\">Description</td>\n <td class=\"govuk-table__header\" scope=\"col\">Volume</td>\n <td class=\"govuk-table__header\" scope=\"col\">Fee amount</td>\n <td class=\"govuk-table__header\" scope=\"col\">Calculated amount</td>\n <td class=\"govuk-table__header\" scope=\"col\">Group amount outstanding</td>\n </tr>\n </thead>\n <tbody class=\"govuk-table__body\">\n <tr class=\"govuk-table__row\" *ngFor=\"let fee of paymentGroup.fees; let i = index;\">\n <td class=\"govuk-table__cell govuk-table__cell--col1 govuk-table__custom--col1\"\n [attr.rowspan]=\"paymentGroup.fees.length\" *ngIf=\"i==0\">\n <div class=\"multiple-choice\">\n <input id=\"unpaiedFee-{{i}}\" name=\"unassignedRecord\" type=\"radio\"\n (click)=\"selectedPaymentGroup(paymentGroup)\" />\n <label for=\"unpaiedFee-{{i}}\"></label>\n </div>\n </td>\n <td class=\"govuk-table__cell govuk-table__cell--col1\">{{fee.code}}</td>\n <td class=\"govuk-table__cell govuk-table__cell--col2\"> {{fee.description}} </td>\n <td class=\"govuk-table__cell govuk-table__cell--col3\"> {{fee.volume? fee.volume : '-'}} </td>\n <td class=\"govuk-table__cell govuk-table__cell--col4\">\n {{ fee.fee_amount | currency:'GBP':'symbol-narrow':'1.2-2' }} </td>\n <td class=\"govuk-table__cell govuk-table__cell--col5\">\n {{fee.calculated_amount | currency:'GBP':'symbol-narrow':'1.2-2' }} </td>\n <td class=\"govuk-table__cell govuk-table__cell--col6 govuk-table__custom--col6\"\n [attr.rowspan]=\"paymentGroup.fees.length\" *ngIf=\"i==0\">\n {{getGroupOutstandingAmount(paymentGroup) | currency:'GBP':'symbol-narrow':'1.2-2' }} </td>\n\n </tr>\n\n </tbody>\n <tbody class=\"govuk-table__body\" *ngIf=\"paymentGroup.fees.length==0\">\n <td class=\"govuk-table__cell\" colspan=\"6\">No payments recorded</td>\n </tbody>\n </table>\n </div>\n <div class=\"govuk-button-group-allocate\">\n <button type=\"button\" class=\"button govuk-!-margin-right-1\" [disabled]=\"isContinueButtondisabled\"\n (click)=\"saveAndContinue()\">\n Continue\n </button>\n <button type=\"button\" class=\"button govuk-button--secondary\" (click)=\"gotoCasetransationPage()\">\n Cancel\n </button>\n </div>\n </div>\n\n <ng-container *ngIf=\"(viewStatus === 'mainForm' && isTurnOff) || viewStatus === 'allocatePaymentConfirmation'\">\n <ccpay-error-banner *ngIf=\"errorMessage.showError\" [errorMessage]=\"errorMessage\"></ccpay-error-banner>\n <input #myInput type='hidden' class='iFrameDrivenImageValue' value='{{feedbackUrlLabel}}'>\n <h1 class=\"govuk-heading-xl\">Confirm allocation</h1>\n <h2 class=\"govuk-heading-l govuk-heading-l--custom\">\n Amount to be allocated: {{amountForAllocation | currency:'GBP':'symbol-narrow':'1.2-2'}}\n </h2>\n <div class=\"payment-group-section\" *ngIf=\"paymentGroup\">\n <h3 class=\"govuk-heading-m--custom\" *ngIf=\"isTurnOff\">Group reference: {{paymentGroup.payment_group_reference}}\n </h3>\n <table class=\"govuk-table\">\n <thead class=\"govuk-table__head\">\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__header\" scope=\"col\">Code</td>\n <td class=\"govuk-table__header\" scope=\"col\">Description</td>\n <td class=\"govuk-table__header\" scope=\"col\">Volume</td>\n <td class=\"govuk-table__header\" scope=\"col\">Fee amount</td>\n <td class=\"govuk-table__header\" scope=\"col\">Calculated amount</td>\n <td class=\"govuk-table__header\" scope=\"col\">Amount Due</td>\n </tr>\n </thead>\n <tbody class=\"govuk-table__body\">\n <tr class=\"govuk-table__row\" *ngFor=\"let fee of paymentGroup.fees; let i = index;\">\n <td class=\"govuk-table__cell govuk-table__cell--col1\">{{fee.code}}</td>\n <td class=\"govuk-table__cell govuk-table__cell--col2\"> {{fee.description}} </td>\n <td class=\"govuk-table__cell govuk-table__cell--col3\"> {{fee.volume? fee.volume : '-'}} </td>\n <td class=\"govuk-table__cell govuk-table__cell--col4\">\n {{ fee.fee_amount | currency:'GBP':'symbol-narrow':'1.2-2' }} </td>\n <td class=\"govuk-table__cell govuk-table__cell--col5\">\n {{fee.calculated_amount | currency:'GBP':'symbol-narrow':'1.2-2'}} </td>\n <td class=\"govuk-table__cell govuk-table__cell--col6\" [attr.rowspan]=\"paymentGroup.fees.length\"\n *ngIf=\"i==0\"> {{afterFeeAllocateOutstanding | currency:'GBP':'symbol-narrow':'1.2-2'}} </td>\n </tr>\n </tbody>\n <tbody class=\"govuk-table__body\" *ngIf=\"paymentGroup.fees.length == 0\">\n <td class=\"govuk-table__cell\" colspan=\"6\">No payments recorded</td>\n </tbody>\n </table>\n </div>\n <div class=\"govuk-warning-text\" *ngIf=\"isRemainingAmountGtZero || isRemainingAmountLtZero || remainingAmount === 0\">\n <span class=\"govuk-warning-text__icon\" aria-hidden=\"true\">!</span>\n <strong class=\"govuk-warning-text__text govuk-warning-text__custom\">\n <span class=\"govuk-warning-text__assistive\">Warning</span>\n {{paymentSectionLabel.title}} {{ remainingAmount | currency:'GBP':'symbol-narrow':'1.2-2' }}\n </strong>\n </div>\n <div class=\"govuk-form-group\" *ngIf=\"isRemainingAmountGtZero || isRemainingAmountLtZero\">\n <div class=\"govuk-form-group\">\n <fieldset class=\"govuk-fieldset\" aria-describedby=\"how-contacted-conditional-hint\">\n <span id=\"how-contacted-conditional-hint\" class=\"govuk-hint\"\n [ngClass]=\"{'inline-error-message': paymentReasonHasError}\">\n {{paymentSectionLabel.reason}}\n </span>\n <div\n [ngClass]=\"paymentReasonHasError ? 'govuk-radios govuk-radios--conditional form-group-error' : 'govuk-radios govuk-radios--conditional'\"\n data-module=\"govuk-radios\" *ngIf=\"isRemainingAmountGtZero\">\n <div class=\"govuk-radios__item\" *ngFor=\"let reason of reasonList.overPayment | keyValue\">\n <input class=\"govuk-radios__input\" id=\"{{reason.key}}\" name=\"paymentReason\" type=\"radio\"\n [value]=\"reason.key\" (input)=\"getReasonValue(reason.value)\"/>\n <label class=\"govuk-label govuk-radios__label govuk-font__custom\" for=\"how-contacted-conditional\">\n {{reason.value}}\n </label>\n </div>\n </div>\n <div\n [ngClass]=\"paymentReasonHasError ? 'govuk-radios govuk-radios--conditional form-group-error' : 'govuk-radios govuk-radios--conditional'\"\n data-module=\"govuk-radios\" *ngIf=\"isRemainingAmountLtZero\">\n <div class=\"govuk-radios__item\" *ngFor=\"let reason of reasonList.shortFall | keyValue\">\n <input class=\"govuk-radios__input\" id=\"{{reason.key}}\" name=\"paymentReason\" type=\"radio\"\n [value]=\"reason.key\" (input)=\"getReasonValue(reason.value)\"/>\n <label class=\"govuk-label govuk-radios__label govuk-font__custom\" for=\"how-contacted-conditional\">\n {{reason.value}}\n </label>\n </div>\n </div>\n </fieldset>\n </div>\n <div class=\"govuk-form-group\">\n <fieldset class=\"govuk-fieldset\" aria-describedby=\"how-contacted-conditional-hint\">\n <span id=\"how-contacted-conditional-hint\" class=\"govuk-hint\"\n [ngClass]=\"{'inline-error-message': paymentExplanationHasError}\">\n Provide an explanatory note\n </span>\n <div\n [ngClass]=\"paymentExplanationHasError ? 'govuk-radios govuk-radios--conditional form-group-error' : 'govuk-radios govuk-radios--conditional'\"\n data-module=\"govuk-radios\" *ngIf=\"isRemainingAmountGtZero\">\n <div class=\"govuk-radios__item\" *ngFor=\"let explanation of explanationList.overPayment | keyValue\">\n <input class=\"govuk-radios__input\" id=\"{{explanation.key}}\" name=\"paymentExplanation\" type=\"radio\"\n [value]=\"explanation.key\" (input)=\"getExplanationValue(explanation.value)\"\n (click)=\"selectRadioButton(explanation.key, 'explanation')\"/>\n <label class=\"govuk-label govuk-radios__label govuk-font__custom\" for=\"how-contacted-conditional\">\n {{explanation.value}}\n </label>\n </div>\n </div>\n <div\n [ngClass]=\"paymentExplanationHasError ? 'govuk-radios govuk-radios--conditional form-group-error' : 'govuk-radios govuk-radios--conditional'\"\n data-module=\"govuk-radios\" *ngIf=\"isRemainingAmountLtZero\">\n <div class=\"govuk-radios__item\" *ngFor=\"let explanation of explanationList.shortFall | keyValue\">\n <input class=\"govuk-radios__input\" id=\"{{explanation.key}}\" name=\"paymentExplanation\" type=\"radio\"\n [value]=\"explanation.key\" (input)=\"getExplanationValue(explanation.value)\"\n (click)=\"selectRadioButton(explanation.key, 'explanation')\"/>\n <label class=\"govuk-label govuk-radios__label govuk-font__custom\" for=\"how-contacted-conditional\">\n {{explanation.value}}\n </label>\n </div>\n </div>\n </fieldset>\n </div>\n </div>\n\n <form [formGroup]=\"overUnderPaymentForm\" novalidate>\n <div\n [ngClass]=\"isMoreDetailsBoxHide ? 'govuk-radios__conditional govuk-radios__conditional--hidden' : isPaymentDetailsEmpty || isPaymentDetailsInvalid || paymentDetailsMinHasError || paymentDetailsMaxHasError ? 'govuk-radios__conditional inline-error-border' : 'govuk-radios__conditional'\"\n id=\"conditional-how-contacted-conditional-3\">\n <div class=\"govuk-form-group\">\n <span id=\"more-detail-hint\" class=\"govuk-hint govuk-font__custom\">\n Please enter details\n </span>\n <textarea class=\"govuk-textarea\"\n [ngClass]=\"{'inline-error-class': isPaymentDetailsEmpty || isPaymentDetailsInvalid || paymentDetailsMinHasError || paymentDetailsMaxHasError}\"\n id=\"moreDetails\" name=\"moreDetails\" rows=\"5\" formControlName=\"moreDetails\">\n </textarea>\n <p class=\"inline-error-message\"\n *ngIf=\"isPaymentDetailsEmpty || isPaymentDetailsInvalid || paymentDetailsMinHasError || paymentDetailsMaxHasError\">\n <span *ngIf=\"isPaymentDetailsEmpty\">Enter a explanation</span>\n <span *ngIf=\"isPaymentDetailsInvalid\">Enter a valid explanation</span>\n <span *ngIf=\"paymentDetailsMinHasError\">Explanation should be at least 3 characters.</span>\n <span *ngIf=\"paymentDetailsMaxHasError\">Explanation should be 255 characters or under.</span>\n </p>\n </div>\n </div>\n <div class=\"govuk-button--group\">\n <button type=\"submit\" [disabled]=\"isConfirmButtondisabled\"\n [ngClass]=\"isConfirmButtondisabled ? 'button button--disabled' : 'button'\"\n (click)=\"confirmAllocatePayement()\">\n Confirm\n </button>\n <button type=\"button\" class=\"button govuk-button--secondary\" (click)=\"cancelAllocatePayment($event)\">\n Cancel\n </button>\n </div>\n </form>\n </ng-container>\n</div>\n", styles: [".allocate-payments{margin:20px 0}.allocate-payments .govuk-table__cell--col1,.allocate-payments .govuk-table__cell--col3{width:10%}.allocate-payments .govuk-table__cell--col2,.allocate-payments .govuk-table__cell--col6{width:25%}.allocate-payments .govuk-table__cell--col4,.allocate-payments .govuk-table__cell--col5{width:15%}.allocate-payments .govuk-button-group-allocate{display:flex;justify-content:flex-start}.allocate-payments .govuk-button--secondary{margin-left:10px;background-color:#b3b8bdf2}.allocate-payments .govuk-custom-warning__message{font-size:30px;position:relative;top:12px;font-weight:700}.allocate-payments .govuk-warning-text-custom{margin-bottom:0!important;padding:10px 0 5px}.allocate-payments .govuk-table__custom--col1{padding-top:0;padding-bottom:20px;padding-left:15px}.allocate-payments .govuk-table__custom--col6{text-align:center}.allocate-payments .govuk-list__custom{padding-left:20px}.allocate-payments .govuk-warning-text__custom,.allocate-payments .govuk-list__custom,.allocate-payments .govuk-heading-m--custom,.allocate-payments .govuk-label--m,.allocate-payments .govuk-radios__item,.allocate-payments .govuk-hint,.allocate-payments .govuk-font__custom{font-size:19px}.allocate-payments .govuk-radios__conditional--hidden{display:none}.allocate-payments .form-group-error{border-left:5px solid #b10e1e;padding-left:15px}.allocate-payments .inline-error-class{outline:3px solid #a71414;outline-offset:0}.allocate-payments .inline-error-message{color:#a71414;font-weight:700;margin-top:10px}.allocate-payments .inline-error-border{border-color:#a71414}.allbtb{margin-top:2em}.govuk-back-link{font-size:1.5rem!important}.multiple-choice{font-size:19px}.casererf{align-self:flex-end;font-size:19px}.paymentrequest{display:flex;flex-direction:row;justify-content:space-between;width:960px}\n"], dependencies: [{ kind: "directive", type: i7.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i3.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i3.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: i8.ErrorBannerComponent, selector: "ccpay-error-banner", inputs: ["errorMessage"] }, { kind: "pipe", type: i7.CurrencyPipe, name: "currency" }, { kind: "pipe", type: i9.keyValuePipe, name: "keyValue" }] });
|
|
407
|
+
}
|
|
408
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AllocatePaymentsComponent, decorators: [{
|
|
409
|
+
type: Component,
|
|
410
|
+
args: [{ selector: 'app-allocate-payments', template: "<div class=\"allocate-payments\">\n <ng-container *ngIf=\"viewStatus === 'mainForm' && !isTurnOff\">\n\n <div class=\"govuk-breadcrumbs\">\n <ol class=\"govuk-breadcrumbs__list\">\n <li class=\"govuk-breadcrumbs__list-item\">\n <a (click)=\"gotoCasetransationPage()\" class=\"govuk-back-link govuk-label\">Back</a>\n </li>\n </ol>\n </div>\n\n <div class=\"paymentrequest\">\n <h1 class=\"govuk-heading-xl govuk-!-margin-top-3 govuk-!-margin-bottom-4\">Select payment request</h1>\n <p class=\"govuk-!-margin-top-5 casererf\">Case reference: {{ccdReference}}</p>\n </div>\n\n <div *ngFor=\"let orderRef of orderLevelFees; let i = index;\" class=\"multiple-choice unprocessed-payments--radio-button\">\n <input id=\"'orderfee'+i+''\"\n aria-label=\"orderLevelRecord\"\n name=\"orderLevelRecord\"\n\n (click)=\"OrderListSelectEvent(orderRef.orderRefId)\"\n type=\"radio\"\n value=\"{{orderRef.orderTotalFees}}\" />\n <label for=\"radio-inline-1\"> {{orderRef.orderTotalFees | currency :'GBP':'symbol':'1.2-2'}}({{orderRef.orderStatus}})</label>\n </div>\n\n <div class=\"paymentrequest\">\n <button [disabled]=\"isContinueButtondisabled\" type=\"submit\" (click)=\"redirectToOrderFeeSearchPage()\" class=\"button allbtb button--disabled govuk-!-margin-right-1\">\n Continue\n </button>\n </div>\n\n </ng-container>\n\n <div *ngIf=\"viewStatus==='mainForm' && isTurnOff\">\n <input #myInput type='hidden' class='iFrameDrivenImageValue' value='ALLOCATEPAYMENTS'>\n <div class=\"govuk-breadcrumbs\" *ngIf=\"paymentRef\">\n <ol class=\"govuk-breadcrumbs__list\">\n <li class=\"govuk-breadcrumbs__list-item\">\n <a href=\"#\" (click)=\"gotoSummaryPage($event)\" class=\"govuk-back-link\">Back</a>\n </li>\n </ol>\n </div>\n <div class=\"govuk-heading-section\">\n <h1 class=\"govuk-heading-xl\">Allocate payment to fee group</h1>\n <h2 class=\"govuk-heading-l\">Amount left to be allocated:\n {{ unAllocatedPayment.amount | currency:'GBP':'symbol-narrow':'1.2-2' }}</h2>\n </div>\n <div class=\"payment-group-section\" *ngFor=\"let paymentGroup of paymentGroups\">\n <h3 class=\"govuk-heading-m\">Group reference: {{paymentGroup.payment_group_reference}}</h3>\n <table class=\"govuk-table\">\n <thead class=\"govuk-table__head\">\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__header\" scope=\"col\"></td>\n <td class=\"govuk-table__header\" scope=\"col\">Code</td>\n <td class=\"govuk-table__header\" scope=\"col\">Description</td>\n <td class=\"govuk-table__header\" scope=\"col\">Volume</td>\n <td class=\"govuk-table__header\" scope=\"col\">Fee amount</td>\n <td class=\"govuk-table__header\" scope=\"col\">Calculated amount</td>\n <td class=\"govuk-table__header\" scope=\"col\">Group amount outstanding</td>\n </tr>\n </thead>\n <tbody class=\"govuk-table__body\">\n <tr class=\"govuk-table__row\" *ngFor=\"let fee of paymentGroup.fees; let i = index;\">\n <td class=\"govuk-table__cell govuk-table__cell--col1 govuk-table__custom--col1\"\n [attr.rowspan]=\"paymentGroup.fees.length\" *ngIf=\"i==0\">\n <div class=\"multiple-choice\">\n <input id=\"unpaiedFee-{{i}}\" name=\"unassignedRecord\" type=\"radio\"\n (click)=\"selectedPaymentGroup(paymentGroup)\" />\n <label for=\"unpaiedFee-{{i}}\"></label>\n </div>\n </td>\n <td class=\"govuk-table__cell govuk-table__cell--col1\">{{fee.code}}</td>\n <td class=\"govuk-table__cell govuk-table__cell--col2\"> {{fee.description}} </td>\n <td class=\"govuk-table__cell govuk-table__cell--col3\"> {{fee.volume? fee.volume : '-'}} </td>\n <td class=\"govuk-table__cell govuk-table__cell--col4\">\n {{ fee.fee_amount | currency:'GBP':'symbol-narrow':'1.2-2' }} </td>\n <td class=\"govuk-table__cell govuk-table__cell--col5\">\n {{fee.calculated_amount | currency:'GBP':'symbol-narrow':'1.2-2' }} </td>\n <td class=\"govuk-table__cell govuk-table__cell--col6 govuk-table__custom--col6\"\n [attr.rowspan]=\"paymentGroup.fees.length\" *ngIf=\"i==0\">\n {{getGroupOutstandingAmount(paymentGroup) | currency:'GBP':'symbol-narrow':'1.2-2' }} </td>\n\n </tr>\n\n </tbody>\n <tbody class=\"govuk-table__body\" *ngIf=\"paymentGroup.fees.length==0\">\n <td class=\"govuk-table__cell\" colspan=\"6\">No payments recorded</td>\n </tbody>\n </table>\n </div>\n <div class=\"govuk-button-group-allocate\">\n <button type=\"button\" class=\"button govuk-!-margin-right-1\" [disabled]=\"isContinueButtondisabled\"\n (click)=\"saveAndContinue()\">\n Continue\n </button>\n <button type=\"button\" class=\"button govuk-button--secondary\" (click)=\"gotoCasetransationPage()\">\n Cancel\n </button>\n </div>\n </div>\n\n <ng-container *ngIf=\"(viewStatus === 'mainForm' && isTurnOff) || viewStatus === 'allocatePaymentConfirmation'\">\n <ccpay-error-banner *ngIf=\"errorMessage.showError\" [errorMessage]=\"errorMessage\"></ccpay-error-banner>\n <input #myInput type='hidden' class='iFrameDrivenImageValue' value='{{feedbackUrlLabel}}'>\n <h1 class=\"govuk-heading-xl\">Confirm allocation</h1>\n <h2 class=\"govuk-heading-l govuk-heading-l--custom\">\n Amount to be allocated: {{amountForAllocation | currency:'GBP':'symbol-narrow':'1.2-2'}}\n </h2>\n <div class=\"payment-group-section\" *ngIf=\"paymentGroup\">\n <h3 class=\"govuk-heading-m--custom\" *ngIf=\"isTurnOff\">Group reference: {{paymentGroup.payment_group_reference}}\n </h3>\n <table class=\"govuk-table\">\n <thead class=\"govuk-table__head\">\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__header\" scope=\"col\">Code</td>\n <td class=\"govuk-table__header\" scope=\"col\">Description</td>\n <td class=\"govuk-table__header\" scope=\"col\">Volume</td>\n <td class=\"govuk-table__header\" scope=\"col\">Fee amount</td>\n <td class=\"govuk-table__header\" scope=\"col\">Calculated amount</td>\n <td class=\"govuk-table__header\" scope=\"col\">Amount Due</td>\n </tr>\n </thead>\n <tbody class=\"govuk-table__body\">\n <tr class=\"govuk-table__row\" *ngFor=\"let fee of paymentGroup.fees; let i = index;\">\n <td class=\"govuk-table__cell govuk-table__cell--col1\">{{fee.code}}</td>\n <td class=\"govuk-table__cell govuk-table__cell--col2\"> {{fee.description}} </td>\n <td class=\"govuk-table__cell govuk-table__cell--col3\"> {{fee.volume? fee.volume : '-'}} </td>\n <td class=\"govuk-table__cell govuk-table__cell--col4\">\n {{ fee.fee_amount | currency:'GBP':'symbol-narrow':'1.2-2' }} </td>\n <td class=\"govuk-table__cell govuk-table__cell--col5\">\n {{fee.calculated_amount | currency:'GBP':'symbol-narrow':'1.2-2'}} </td>\n <td class=\"govuk-table__cell govuk-table__cell--col6\" [attr.rowspan]=\"paymentGroup.fees.length\"\n *ngIf=\"i==0\"> {{afterFeeAllocateOutstanding | currency:'GBP':'symbol-narrow':'1.2-2'}} </td>\n </tr>\n </tbody>\n <tbody class=\"govuk-table__body\" *ngIf=\"paymentGroup.fees.length == 0\">\n <td class=\"govuk-table__cell\" colspan=\"6\">No payments recorded</td>\n </tbody>\n </table>\n </div>\n <div class=\"govuk-warning-text\" *ngIf=\"isRemainingAmountGtZero || isRemainingAmountLtZero || remainingAmount === 0\">\n <span class=\"govuk-warning-text__icon\" aria-hidden=\"true\">!</span>\n <strong class=\"govuk-warning-text__text govuk-warning-text__custom\">\n <span class=\"govuk-warning-text__assistive\">Warning</span>\n {{paymentSectionLabel.title}} {{ remainingAmount | currency:'GBP':'symbol-narrow':'1.2-2' }}\n </strong>\n </div>\n <div class=\"govuk-form-group\" *ngIf=\"isRemainingAmountGtZero || isRemainingAmountLtZero\">\n <div class=\"govuk-form-group\">\n <fieldset class=\"govuk-fieldset\" aria-describedby=\"how-contacted-conditional-hint\">\n <span id=\"how-contacted-conditional-hint\" class=\"govuk-hint\"\n [ngClass]=\"{'inline-error-message': paymentReasonHasError}\">\n {{paymentSectionLabel.reason}}\n </span>\n <div\n [ngClass]=\"paymentReasonHasError ? 'govuk-radios govuk-radios--conditional form-group-error' : 'govuk-radios govuk-radios--conditional'\"\n data-module=\"govuk-radios\" *ngIf=\"isRemainingAmountGtZero\">\n <div class=\"govuk-radios__item\" *ngFor=\"let reason of reasonList.overPayment | keyValue\">\n <input class=\"govuk-radios__input\" id=\"{{reason.key}}\" name=\"paymentReason\" type=\"radio\"\n [value]=\"reason.key\" (input)=\"getReasonValue(reason.value)\"/>\n <label class=\"govuk-label govuk-radios__label govuk-font__custom\" for=\"how-contacted-conditional\">\n {{reason.value}}\n </label>\n </div>\n </div>\n <div\n [ngClass]=\"paymentReasonHasError ? 'govuk-radios govuk-radios--conditional form-group-error' : 'govuk-radios govuk-radios--conditional'\"\n data-module=\"govuk-radios\" *ngIf=\"isRemainingAmountLtZero\">\n <div class=\"govuk-radios__item\" *ngFor=\"let reason of reasonList.shortFall | keyValue\">\n <input class=\"govuk-radios__input\" id=\"{{reason.key}}\" name=\"paymentReason\" type=\"radio\"\n [value]=\"reason.key\" (input)=\"getReasonValue(reason.value)\"/>\n <label class=\"govuk-label govuk-radios__label govuk-font__custom\" for=\"how-contacted-conditional\">\n {{reason.value}}\n </label>\n </div>\n </div>\n </fieldset>\n </div>\n <div class=\"govuk-form-group\">\n <fieldset class=\"govuk-fieldset\" aria-describedby=\"how-contacted-conditional-hint\">\n <span id=\"how-contacted-conditional-hint\" class=\"govuk-hint\"\n [ngClass]=\"{'inline-error-message': paymentExplanationHasError}\">\n Provide an explanatory note\n </span>\n <div\n [ngClass]=\"paymentExplanationHasError ? 'govuk-radios govuk-radios--conditional form-group-error' : 'govuk-radios govuk-radios--conditional'\"\n data-module=\"govuk-radios\" *ngIf=\"isRemainingAmountGtZero\">\n <div class=\"govuk-radios__item\" *ngFor=\"let explanation of explanationList.overPayment | keyValue\">\n <input class=\"govuk-radios__input\" id=\"{{explanation.key}}\" name=\"paymentExplanation\" type=\"radio\"\n [value]=\"explanation.key\" (input)=\"getExplanationValue(explanation.value)\"\n (click)=\"selectRadioButton(explanation.key, 'explanation')\"/>\n <label class=\"govuk-label govuk-radios__label govuk-font__custom\" for=\"how-contacted-conditional\">\n {{explanation.value}}\n </label>\n </div>\n </div>\n <div\n [ngClass]=\"paymentExplanationHasError ? 'govuk-radios govuk-radios--conditional form-group-error' : 'govuk-radios govuk-radios--conditional'\"\n data-module=\"govuk-radios\" *ngIf=\"isRemainingAmountLtZero\">\n <div class=\"govuk-radios__item\" *ngFor=\"let explanation of explanationList.shortFall | keyValue\">\n <input class=\"govuk-radios__input\" id=\"{{explanation.key}}\" name=\"paymentExplanation\" type=\"radio\"\n [value]=\"explanation.key\" (input)=\"getExplanationValue(explanation.value)\"\n (click)=\"selectRadioButton(explanation.key, 'explanation')\"/>\n <label class=\"govuk-label govuk-radios__label govuk-font__custom\" for=\"how-contacted-conditional\">\n {{explanation.value}}\n </label>\n </div>\n </div>\n </fieldset>\n </div>\n </div>\n\n <form [formGroup]=\"overUnderPaymentForm\" novalidate>\n <div\n [ngClass]=\"isMoreDetailsBoxHide ? 'govuk-radios__conditional govuk-radios__conditional--hidden' : isPaymentDetailsEmpty || isPaymentDetailsInvalid || paymentDetailsMinHasError || paymentDetailsMaxHasError ? 'govuk-radios__conditional inline-error-border' : 'govuk-radios__conditional'\"\n id=\"conditional-how-contacted-conditional-3\">\n <div class=\"govuk-form-group\">\n <span id=\"more-detail-hint\" class=\"govuk-hint govuk-font__custom\">\n Please enter details\n </span>\n <textarea class=\"govuk-textarea\"\n [ngClass]=\"{'inline-error-class': isPaymentDetailsEmpty || isPaymentDetailsInvalid || paymentDetailsMinHasError || paymentDetailsMaxHasError}\"\n id=\"moreDetails\" name=\"moreDetails\" rows=\"5\" formControlName=\"moreDetails\">\n </textarea>\n <p class=\"inline-error-message\"\n *ngIf=\"isPaymentDetailsEmpty || isPaymentDetailsInvalid || paymentDetailsMinHasError || paymentDetailsMaxHasError\">\n <span *ngIf=\"isPaymentDetailsEmpty\">Enter a explanation</span>\n <span *ngIf=\"isPaymentDetailsInvalid\">Enter a valid explanation</span>\n <span *ngIf=\"paymentDetailsMinHasError\">Explanation should be at least 3 characters.</span>\n <span *ngIf=\"paymentDetailsMaxHasError\">Explanation should be 255 characters or under.</span>\n </p>\n </div>\n </div>\n <div class=\"govuk-button--group\">\n <button type=\"submit\" [disabled]=\"isConfirmButtondisabled\"\n [ngClass]=\"isConfirmButtondisabled ? 'button button--disabled' : 'button'\"\n (click)=\"confirmAllocatePayement()\">\n Confirm\n </button>\n <button type=\"button\" class=\"button govuk-button--secondary\" (click)=\"cancelAllocatePayment($event)\">\n Cancel\n </button>\n </div>\n </form>\n </ng-container>\n</div>\n", styles: [".allocate-payments{margin:20px 0}.allocate-payments .govuk-table__cell--col1,.allocate-payments .govuk-table__cell--col3{width:10%}.allocate-payments .govuk-table__cell--col2,.allocate-payments .govuk-table__cell--col6{width:25%}.allocate-payments .govuk-table__cell--col4,.allocate-payments .govuk-table__cell--col5{width:15%}.allocate-payments .govuk-button-group-allocate{display:flex;justify-content:flex-start}.allocate-payments .govuk-button--secondary{margin-left:10px;background-color:#b3b8bdf2}.allocate-payments .govuk-custom-warning__message{font-size:30px;position:relative;top:12px;font-weight:700}.allocate-payments .govuk-warning-text-custom{margin-bottom:0!important;padding:10px 0 5px}.allocate-payments .govuk-table__custom--col1{padding-top:0;padding-bottom:20px;padding-left:15px}.allocate-payments .govuk-table__custom--col6{text-align:center}.allocate-payments .govuk-list__custom{padding-left:20px}.allocate-payments .govuk-warning-text__custom,.allocate-payments .govuk-list__custom,.allocate-payments .govuk-heading-m--custom,.allocate-payments .govuk-label--m,.allocate-payments .govuk-radios__item,.allocate-payments .govuk-hint,.allocate-payments .govuk-font__custom{font-size:19px}.allocate-payments .govuk-radios__conditional--hidden{display:none}.allocate-payments .form-group-error{border-left:5px solid #b10e1e;padding-left:15px}.allocate-payments .inline-error-class{outline:3px solid #a71414;outline-offset:0}.allocate-payments .inline-error-message{color:#a71414;font-weight:700;margin-top:10px}.allocate-payments .inline-error-border{border-color:#a71414}.allbtb{margin-top:2em}.govuk-back-link{font-size:1.5rem!important}.multiple-choice{font-size:19px}.casererf{align-self:flex-end;font-size:19px}.paymentrequest{display:flex;flex-direction:row;justify-content:space-between;width:960px}\n"] }]
|
|
411
|
+
}], ctorParameters: () => [{ type: i1.ErrorHandlerService }, { type: i2.CaseTransactionsService }, { type: i3.FormBuilder }, { type: i4.PaymentViewService }, { type: undefined, decorators: [{
|
|
412
|
+
type: Inject,
|
|
413
|
+
args: ['PAYMENT_LIB']
|
|
414
|
+
}] }, { type: i5.BulkScaningPaymentService }, { type: i6.OrderslistService }], propDecorators: { isTurnOff: [{
|
|
415
|
+
type: Input
|
|
416
|
+
}], caseType: [{
|
|
417
|
+
type: Input
|
|
418
|
+
}], reasonEventEmitter: [{
|
|
419
|
+
type: Output
|
|
420
|
+
}], explanationEventEmitter: [{
|
|
421
|
+
type: Output
|
|
422
|
+
}] } });
|
|
423
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"allocate-payments.component.js","sourceRoot":"","sources":["../../../../../../projects/payment-lib/src/lib/components/allocate-payments/allocate-payments.component.ts","../../../../../../projects/payment-lib/src/lib/components/allocate-payments/allocate-payments.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, Inject, AfterViewInit, EventEmitter, Output } from '@angular/core';\nimport { FormBuilder, FormGroup, Validators, FormControl } from '@angular/forms';\nimport type { PaymentLibComponent } from '../../payment-lib.component';\nimport { PaymentViewService } from '../../services/payment-view/payment-view.service';\nimport { CaseTransactionsService } from '../../services/case-transactions/case-transactions.service';\nimport { BulkScaningPaymentService } from '../../services/bulk-scaning-payment/bulk-scaning-payment.service';\nimport { ErrorHandlerService } from '../../services/shared/error-handler.service';\nimport { IPaymentGroup } from '../../interfaces/IPaymentGroup';\nimport { IBSPayments } from '../../interfaces/IBSPayments';\nimport { AllocatePaymentRequest } from '../../interfaces/AllocatePaymentRequest';\nimport { IAllocationPaymentsRequest } from '../../interfaces/IAllocationPaymentsRequest';\nimport { IOrderReferenceFee } from '../../interfaces/IOrderReferenceFee';\nimport { OrderslistService } from '../../services/orderslist.service';\ntype PaymentLibAlias = PaymentLibComponent;\n\n\n\n@Component({\n  selector: 'app-allocate-payments',\n  templateUrl: './allocate-payments.component.html',\n  styleUrls: ['./allocate-payments.component.scss']\n})\nexport class AllocatePaymentsComponent implements OnInit {\n  @Input() isTurnOff: boolean;\n  @Input() caseType: string;\n  @Output() public reasonEventEmitter: EventEmitter<string> = new EventEmitter<string>();\n  @Output() public explanationEventEmitter: EventEmitter<string> = new EventEmitter<string>();\n  overUnderPaymentForm: FormGroup;\n  viewStatus: string;\n  ccdCaseNumber: string;\n  bspaymentdcn: string;\n  recordId: string;\n  feedbackUrlLabel: string;\n  unAllocatedPayment: IBSPayments = {\n    amount: 0\n  };\n  siteID: string = null;\n  // errorMessage = this.errorHandlerService.getServerErrorMessage(false, false, '');\n  errorMessage = null\n  paymentGroup: IPaymentGroup;\n  paymentGroups: IPaymentGroup[] = [];\n  remainingAmount: number;\n  isRemainingAmountGtZero: boolean;\n  isMoreDetailsBoxHide: boolean = true;\n  isRemainingAmountLtZero: boolean;\n  afterFeeAllocateOutstanding: number;\n  amountForAllocation: number;\n  isConfirmButtondisabled: boolean = false;\n  isContinueButtondisabled: boolean = true;\n  otherPaymentExplanation: string = null;\n  selectedOption: string = null;\n  isFeeAmountZero: boolean = false;\n\n  paymentReasonHasError: boolean = false;\n  paymentExplanationHasError: boolean = false;\n  isPaymentDetailsEmpty: boolean = false;\n  isPaymentDetailsInvalid: boolean = false;\n  paymentDetailsMinHasError: boolean = false;\n  paymentDetailsMaxHasError: boolean = false;\n  isUserNameEmpty: boolean = false;\n  isUserNameInvalid: boolean = false;\n  ccdReference: string = null;\n  exceptionReference: string = null;\n  paymentReason: string = null;\n  paymentExplanation: string = null;\n  userName: string = null;\n  paymentSectionLabel: any;\n  paymentRef: string = null;\n  isStrategicFixEnable: boolean = true;\n  orderLevelFees: IOrderReferenceFee[] = [];\n  cookieUserName: string[] = [];\n  enCookieUserName: any;\n  userNameField: string = null;\n\n  reasonList: { [key: string]: { [key: string]: string } } = {\n    overPayment: {\n      hwfReward: 'Help with Fees (HWF) awarded.  Please include the HWF reference number in the explanatory note',\n      wrongFee: 'Incorrect payment received',\n      notIssueCase: 'Unable to issue case',\n      otherDeduction: 'Other'\n    },\n    shortFall: {\n      helpWithFee: 'Help with Fees (HWF) application declined',\n      wrongFee: 'Incorrect payment received',\n      other: 'Other'\n    }\n  }\n  explanationList = {\n    overPayment: {\n      referRefund: 'Details in case notes.  Refund due',\n      noRefund: 'Details in case notes. No refund due',\n      noCase: 'No case created.  Refund due',\n      other: 'Other'\n    },\n    shortFall: {\n      holdCase: 'I have put a stop on the case and contacted the applicant requesting the balance of payment',\n      heldCase: 'I have put a stop on the case.  The applicant needs to be contacted to request the balance of payment',\n      other: 'Other'\n    }\n  }\n\n  refund = {\n    reason: {\n      duplicate: 'Duplicate payment',\n      humanerror: 'Human error',\n      caseWithdrawn: 'Case withdrawn',\n      other: 'Other'\n    }\n  }\n\n\n  constructor(\n    private errorHandlerService: ErrorHandlerService,\n    private caseTransactionsService: CaseTransactionsService,\n    private formBuilder: FormBuilder,\n    private paymentViewService: PaymentViewService,\n    @Inject('PAYMENT_LIB') private paymentLibComponent: PaymentLibAlias,\n    private bulkScaningPaymentService: BulkScaningPaymentService,\n    private OrderslistService: OrderslistService) { }\n\n  ngOnInit() {\n    this.viewStatus = 'mainForm';\n    if (this.paymentLibComponent.paymentGroupReference !== null) {\n      this.viewStatus = 'allocatePaymentConfirmation';\n    }\n\n    this.ccdCaseNumber = this.paymentLibComponent.CCD_CASE_NUMBER;\n    this.bspaymentdcn = this.paymentLibComponent.bspaymentdcn;\n    this.paymentRef = this.paymentLibComponent.paymentGroupReference;\n    this.selectedOption = this.paymentLibComponent.SELECTED_OPTION;\n    this.isStrategicFixEnable = this.paymentLibComponent.ISSFENABLE;\n    this.isTurnOff = this.paymentLibComponent.isTurnOff;\n    this.overUnderPaymentForm = this.formBuilder.group({\n      moreDetails: new FormControl('', Validators.compose([\n        Validators.required,\n        Validators.minLength(3),\n        Validators.maxLength(255),\n        Validators.pattern('^([a-zA-Z0-9\\\\s,\\\\.]*)$')\n      ])),\n      userName: new FormControl('', Validators.compose([\n        Validators.required,\n        Validators.pattern('^([a-zA-Z0-9\\\\s]*)$')\n      ])),\n    });\n    this.OrderslistService.getOrdersList().subscribe((data) =>\n      this.orderLevelFees = data.filter(data => data.orderStatus !== 'Paid'));\n    this.OrderslistService.getCaseType().subscribe((data) => this.caseType = data);\n    this.getUnassignedPayment();\n  }\n  getGroupOutstandingAmount(paymentGroup: IPaymentGroup): number {\n    return this.bulkScaningPaymentService.calculateOutStandingAmount(paymentGroup);\n  }\n\n\n  getExplanationValue(inputValue: string):void{\n    this.paymentExplanation = inputValue;\n    this.explanationEventEmitter.emit(this.paymentExplanation);\n  };\n\n  getReasonValue(inputValue: string):void{\n    this.paymentReason = inputValue;\n    this.reasonEventEmitter.emit(this.paymentReason);\n  };\n\n  getPaymentGroupDetails() {\n\n    if (!this.isTurnOff) {\n      this.paymentViewService.getPaymentGroupDetails(this.paymentRef).subscribe(\n        paymentGroup => {\n          this.errorMessage = this.errorHandlerService.getServerErrorMessage(false, false, '');\n          this.paymentGroup = paymentGroup;\n          this.saveAndContinue();\n        },\n        (error: any) => {\n          this.errorMessage = this.errorHandlerService.getServerErrorMessage(true, false, '');\n        }\n      );\n    } else {\n      this.caseTransactionsService.getPaymentGroups(this.ccdCaseNumber).subscribe(\n        paymentGroups => {\n          this.errorMessage = this.errorHandlerService.getServerErrorMessage(false, false, '');\n          this.paymentGroups = paymentGroups['payment_groups'].filter(paymentGroup => {\n            paymentGroup.fees.forEach(fee => {\n              if (fee.calculated_amount === 0) {\n                this.isFeeAmountZero = true\n              }\n            });\n            let fstCon = this.getGroupOutstandingAmount(<IPaymentGroup>paymentGroup),\n              scndCn = fstCon > 0 || (fstCon == 0 && this.isFeeAmountZero) && paymentGroup.payment_group_reference === this.paymentRef;\n            return this.paymentRef ? scndCn : fstCon > 0 || (fstCon == 0 && this.isFeeAmountZero);\n          });\n        },\n        (error: any) => {\n          this.errorMessage = this.errorHandlerService.getServerErrorMessage(true, false, '');\n        }\n      );\n    }\n\n  }\n\n  selectedPaymentGroup(paymentGroup: IPaymentGroup) {\n    this.isContinueButtondisabled = false;\n    this.paymentGroup = paymentGroup;\n  }\n\n  gotoCasetransationPage() {\n    this.paymentLibComponent.viewName = 'case-transactions';\n    this.paymentLibComponent.isTurnOff = this.isTurnOff;\n    this.paymentLibComponent.TAKEPAYMENT = true;\n    this.paymentLibComponent.ISBSENABLE = true;\n  }\n\n  gotoSummaryPage(event: any) {\n    event.preventDefault();\n    this.paymentLibComponent.viewName = 'fee-summary';\n    this.paymentLibComponent.isTurnOff = this.isTurnOff;\n    this.paymentLibComponent.TAKEPAYMENT = true;\n    this.paymentLibComponent.ISBSENABLE = true;\n  }\n\n  cancelAllocatePayment(event: any) {\n    event.preventDefault();\n    this.resetForm([false, false, false, false, false, false, false, false], 'all');\n    if (!this.isTurnOff) {\n      this.paymentLibComponent.viewName = 'fee-summary';\n      this.paymentLibComponent.isTurnOff = this.isTurnOff;\n      this.paymentLibComponent.TAKEPAYMENT = true;\n      this.paymentLibComponent.ISBSENABLE = true;\n    } else {\n      this.viewStatus = 'mainForm';\n    }\n  }\n  confirmAllocatePayement() {\n    this.enCookieUserName = document.cookie.split(\";\").find(row => row.includes(\"user-info\")).split(\"=\")[1].split(\";\");\n    this.cookieUserName = JSON.parse(decodeURIComponent(this.enCookieUserName));\n\n    const fullName = this.cookieUserName['forename'] + ' ' + this.cookieUserName['surname'];\n\n    const paymentDetailsField = this.overUnderPaymentForm.controls.moreDetails,\n      paymentFormError = this.overUnderPaymentForm.controls.moreDetails.errors,\n      userNameField = fullName,\n      isEmptyCondtion = this.paymentReason && this.paymentExplanation,\n      isOtherOptionSelected = this.paymentExplanation === 'Other';\n\n    this.resetForm([false, false, false, false, false, false, false, false], 'all');\n    if ((!this.isRemainingAmountGtZero && !this.isRemainingAmountLtZero) || isEmptyCondtion && (!isOtherOptionSelected && userNameField.length > 0 || isOtherOptionSelected && userNameField.length > 0 && paymentDetailsField.valid)) {\n      this.isConfirmButtondisabled = true;\n      this.otherPaymentExplanation = this.paymentExplanation === 'Other' ? paymentDetailsField.value : this.paymentExplanation;\n      this.userName = userNameField;\n      this.finalServiceCall();\n    } else {\n      if (!this.paymentReason) {\n        this.resetForm([true, false, false, false, false, false, false, false], 'reason');\n      }\n      if (!this.paymentExplanation) {\n        this.resetForm([false, true, false, false, false, false, false, false], 'explanation');\n      }\n      if (this.paymentExplanation && isOtherOptionSelected) {\n        if (paymentDetailsField.value == '') {\n          this.resetForm([false, false, true, false, false, false, false, false], 'other');\n        }\n        if (paymentDetailsField.value != '' && paymentDetailsField.invalid) {\n          this.resetForm([false, false, false, true, false, false, false, false], 'other');\n        }\n        if (paymentFormError && paymentFormError.minlength && paymentFormError.minlength.actualLength < 3) {\n          this.resetForm([false, false, false, false, true, false, false, false], 'other');\n        }\n        if (paymentFormError && paymentFormError.maxlength && paymentFormError.maxlength.actualLength > 255) {\n          this.resetForm([false, false, false, false, false, true, false, false], 'other');\n        }\n      }\n      if (userNameField.length === 0) {\n        this.resetForm([false, false, false, false, false, false, true, false], 'username');\n      }\n    }\n  }\n  resetForm(vals, field) {\n    if (field === 'reason' || field === 'all') {\n      this.paymentReasonHasError = vals[0];\n    }\n    if (field === 'explanation' || field === 'all') {\n      this.paymentExplanationHasError = vals[1];\n    }\n    if (field === 'other' || field === 'all') {\n      this.isPaymentDetailsEmpty = vals[2];\n      this.isPaymentDetailsInvalid = vals[3];\n      this.paymentDetailsMinHasError = vals[4];\n      this.paymentDetailsMaxHasError = vals[5];\n    }\n    if (field === 'username' || field === 'all') {\n      this.isUserNameEmpty = vals[6];\n      this.isUserNameInvalid = vals[7];\n    }\n  }\n  finalServiceCall() {\n    if (!this.isStrategicFixEnable) {\n      let allocatedRequest = {\n        reason: this.paymentReason,\n        allocation_status: 'Allocated',\n        explanation: this.otherPaymentExplanation,\n        payment_allocation_status: {\n          description: '',\n          name: 'Allocated'\n        },\n        payment_group_reference: this.paymentGroup.payment_group_reference,\n        case_type: this.caseType,\n        user_name: this.userName\n      }\n      const postStrategicBody = new AllocatePaymentRequest\n        (this.ccdReference, this.unAllocatedPayment, this.caseType, this.exceptionReference, allocatedRequest);\n      this.bulkScaningPaymentService.postBSPaymentStrategic(postStrategicBody, this.paymentGroup.payment_group_reference).subscribe(\n        res => {\n          this.errorMessage = this.errorHandlerService.getServerErrorMessage(false, false, '');\n          let response = JSON.parse(res);\n          if (response.success) {\n            this.gotoCasetransationPage();\n          }\n        },\n        (error: any) => {\n          this.errorMessage = this.errorHandlerService.getServerErrorMessage(true, false, '');\n          window.scrollTo(0, 0);\n          this.isConfirmButtondisabled = false;\n        });\n\n    } else {\n      this.bulkScaningPaymentService.patchBSChangeStatus(this.unAllocatedPayment.dcn_reference, 'PROCESSED').subscribe(\n        res1 => {\n          this.errorMessage = this.errorHandlerService.getServerErrorMessage(false, false, '');\n          let response1 = JSON.parse(res1);\n          if (response1.success) {\n            const requestBody = new AllocatePaymentRequest\n              (this.ccdReference, this.unAllocatedPayment, this.siteID, this.exceptionReference);\n            this.bulkScaningPaymentService.postBSAllocatePayment(requestBody, this.paymentGroup.payment_group_reference).subscribe(\n              res2 => {\n                this.errorMessage = this.errorHandlerService.getServerErrorMessage(false, false, '');\n                let response2 = JSON.parse(res2);\n                const reqBody = new IAllocationPaymentsRequest\n                  (response2['data'].payment_group_reference, response2['data'].reference, this.paymentReason, this.otherPaymentExplanation, this.userName);\n                if (response2.success) {\n                  this.paymentViewService.postBSAllocationPayments(reqBody).subscribe(\n\n                    res3 => {\n                      this.errorMessage = this.errorHandlerService.getServerErrorMessage(false, false, '');\n                      let response3 = JSON.parse(res3);\n                      if (response3.success) {\n                        this.gotoCasetransationPage();\n                      }\n                    },\n                    (error: any) => {\n                      this.bulkScaningPaymentService.patchBSChangeStatus(this.unAllocatedPayment.dcn_reference, 'COMPLETE').subscribe();\n                      this.errorMessage = this.errorHandlerService.getServerErrorMessage(true, false, '');\n                      window.scrollTo(0, 0);\n                      this.isConfirmButtondisabled = false;\n                    }\n                  );\n                }\n              },\n              (error: any) => {\n                this.bulkScaningPaymentService.patchBSChangeStatus(this.unAllocatedPayment.dcn_reference, 'COMPLETE').subscribe();\n                this.errorMessage = this.errorHandlerService.getServerErrorMessage(true, false, '');\n                window.scrollTo(0, 0);\n                this.isConfirmButtondisabled = false;\n              }\n            );\n          }\n        },\n        (error: any) => {\n          this.errorMessage = this.errorHandlerService.getServerErrorMessage(true, false, '');\n          window.scrollTo(0, 0);\n          this.isConfirmButtondisabled = false;\n        }\n      );\n    }\n  }\n\n  saveAndContinue() {\n    if (this.paymentGroup) {\n      this.isMoreDetailsBoxHide = true;\n      this.overUnderPaymentForm.get('moreDetails').reset();\n      this.overUnderPaymentForm.get('moreDetails').setValue('');\n      this.overUnderPaymentForm.get('userName').reset();\n      this.overUnderPaymentForm.get('userName').setValue('');\n      this.paymentReason = '';\n      this.paymentExplanation = '';\n      let GroupOutstandingAmount = this.getGroupOutstandingAmount(this.paymentGroup);\n      const remainingToBeAssigned = this.unAllocatedPayment.amount - GroupOutstandingAmount;\n      this.isRemainingAmountGtZero = remainingToBeAssigned > 0;\n      this.isRemainingAmountLtZero = remainingToBeAssigned < 0;\n      this.paymentSectionLabel = this.isRemainingAmountGtZero ? {\n        title: 'There is an Over payment of',\n        reason: 'Provide a reason. This will be used in the Refund process.',\n      } : this.isRemainingAmountLtZero ? {\n        title: 'There is an Under payment of',\n        reason: 'Provide a reason',\n      } : {\n        title: 'Amount left to be allocated',\n        reason: '',\n      };\n      this.feedbackUrlLabel = this.isRemainingAmountGtZero ? 'CONFIRMALLOCATION_SURPLUS' : this.isRemainingAmountLtZero ? 'CONFIRMALLOCATION_SHORTFALL' : 'CONFIRMALLOCATION';\n      this.remainingAmount = this.isRemainingAmountGtZero ? remainingToBeAssigned : this.isRemainingAmountLtZero ? remainingToBeAssigned * -1 : 0;\n      this.afterFeeAllocateOutstanding = remainingToBeAssigned >= 0 ? 0 : (remainingToBeAssigned * -1);\n      this.amountForAllocation = GroupOutstandingAmount >= this.unAllocatedPayment.amount ? this.unAllocatedPayment.amount : GroupOutstandingAmount;\n      if (this.isTurnOff) {\n        this.viewStatus = 'allocatePaymentConfirmation';\n      }\n    }\n  }\n  getUnassignedPayment() {\n    this.bulkScaningPaymentService.getBSPaymentsByDCN(this.bspaymentdcn).subscribe(\n      unassignedPayments => {\n        this.errorMessage = this.errorHandlerService.getServerErrorMessage(false, false, '');\n        this.unAllocatedPayment = unassignedPayments['data'].payments.filter(payment => {\n          return payment && payment.dcn_reference == this.bspaymentdcn;\n        })[0];\n        this.siteID = unassignedPayments['data'].responsible_service_id;\n        const beCcdNumber = unassignedPayments['data'].ccd_reference,\n          beExceptionNumber = unassignedPayments['data'].exception_record_reference,\n          exceptionReference = beCcdNumber ? beCcdNumber === this.ccdCaseNumber ? null : this.ccdCaseNumber : this.ccdCaseNumber;\n        this.ccdReference = beCcdNumber ? beCcdNumber : null;\n        this.exceptionReference = beExceptionNumber ? beExceptionNumber : exceptionReference;\n        this.getPaymentGroupDetails();\n      },\n      (error: any) => {\n        this.errorMessage = this.errorHandlerService.getServerErrorMessage(true, false, '');\n      }\n    );\n  }\n  selectRadioButton(key, type) {\n    this.isMoreDetailsBoxHide = true;\n    if (type === 'explanation' && key === 'other') {\n      this.isPaymentDetailsEmpty = false;\n      this.isPaymentDetailsInvalid = false;\n      this.paymentDetailsMinHasError = false;\n      this.paymentDetailsMaxHasError = false;\n      this.isMoreDetailsBoxHide = false;\n    }\n  }\n  OrderListSelectEvent(orderef: any) {\n    this.isContinueButtondisabled = false;\n    this.recordId = orderef;\n  }\n\n  redirectToOrderFeeSearchPage() {\n    // this.paymentLibComponent.bspaymentdcn = null;\n    this.paymentLibComponent.paymentGroupReference = this.recordId;\n    this.paymentLibComponent.isTurnOff = this.isTurnOff;\n    this.paymentLibComponent.viewName = 'fee-summary';\n  }\n}\n","<div class=\"allocate-payments\">\n  <ng-container *ngIf=\"viewStatus === 'mainForm' && !isTurnOff\">\n\n      <div class=\"govuk-breadcrumbs\">\n          <ol class=\"govuk-breadcrumbs__list\">\n            <li class=\"govuk-breadcrumbs__list-item\">\n              <a (click)=\"gotoCasetransationPage()\" class=\"govuk-back-link govuk-label\">Back</a>\n            </li>\n          </ol>\n        </div>\n\n    <div class=\"paymentrequest\">\n        <h1 class=\"govuk-heading-xl govuk-!-margin-top-3 govuk-!-margin-bottom-4\">Select payment request</h1>\n        <p class=\"govuk-!-margin-top-5 casererf\">Case reference: {{ccdReference}}</p>\n    </div>\n\n    <div  *ngFor=\"let orderRef of orderLevelFees; let i = index;\" class=\"multiple-choice unprocessed-payments--radio-button\">\n      <input id=\"'orderfee'+i+''\"\n      aria-label=\"orderLevelRecord\"\n      name=\"orderLevelRecord\"\n\n      (click)=\"OrderListSelectEvent(orderRef.orderRefId)\"\n      type=\"radio\"\n      value=\"{{orderRef.orderTotalFees}}\" />\n      <label for=\"radio-inline-1\"> {{orderRef.orderTotalFees | currency :'GBP':'symbol':'1.2-2'}}({{orderRef.orderStatus}})</label>\n    </div>\n\n    <div class=\"paymentrequest\">\n        <button [disabled]=\"isContinueButtondisabled\" type=\"submit\" (click)=\"redirectToOrderFeeSearchPage()\" class=\"button allbtb button--disabled govuk-!-margin-right-1\">\n          Continue\n        </button>\n      </div>\n\n  </ng-container>\n\n   <div *ngIf=\"viewStatus==='mainForm' && isTurnOff\">\n    <input #myInput type='hidden' class='iFrameDrivenImageValue' value='ALLOCATEPAYMENTS'>\n    <div class=\"govuk-breadcrumbs\" *ngIf=\"paymentRef\">\n      <ol class=\"govuk-breadcrumbs__list\">\n        <li class=\"govuk-breadcrumbs__list-item\">\n          <a href=\"#\" (click)=\"gotoSummaryPage($event)\" class=\"govuk-back-link\">Back</a>\n        </li>\n      </ol>\n    </div>\n    <div class=\"govuk-heading-section\">\n      <h1 class=\"govuk-heading-xl\">Allocate payment to fee group</h1>\n      <h2 class=\"govuk-heading-l\">Amount left to be allocated:\n        {{ unAllocatedPayment.amount | currency:'GBP':'symbol-narrow':'1.2-2' }}</h2>\n    </div>\n    <div class=\"payment-group-section\" *ngFor=\"let paymentGroup of paymentGroups\">\n      <h3 class=\"govuk-heading-m\">Group reference: {{paymentGroup.payment_group_reference}}</h3>\n      <table class=\"govuk-table\">\n        <thead class=\"govuk-table__head\">\n          <tr class=\"govuk-table__row\">\n            <td class=\"govuk-table__header\" scope=\"col\"></td>\n            <td class=\"govuk-table__header\" scope=\"col\">Code</td>\n            <td class=\"govuk-table__header\" scope=\"col\">Description</td>\n            <td class=\"govuk-table__header\" scope=\"col\">Volume</td>\n            <td class=\"govuk-table__header\" scope=\"col\">Fee amount</td>\n            <td class=\"govuk-table__header\" scope=\"col\">Calculated amount</td>\n            <td class=\"govuk-table__header\" scope=\"col\">Group amount outstanding</td>\n          </tr>\n        </thead>\n        <tbody class=\"govuk-table__body\">\n          <tr class=\"govuk-table__row\" *ngFor=\"let fee of paymentGroup.fees;  let i = index;\">\n            <td class=\"govuk-table__cell govuk-table__cell--col1 govuk-table__custom--col1\"\n              [attr.rowspan]=\"paymentGroup.fees.length\" *ngIf=\"i==0\">\n              <div class=\"multiple-choice\">\n                <input id=\"unpaiedFee-{{i}}\" name=\"unassignedRecord\" type=\"radio\"\n                  (click)=\"selectedPaymentGroup(paymentGroup)\" />\n                <label for=\"unpaiedFee-{{i}}\"></label>\n              </div>\n            </td>\n            <td class=\"govuk-table__cell govuk-table__cell--col1\">{{fee.code}}</td>\n            <td class=\"govuk-table__cell govuk-table__cell--col2\"> {{fee.description}} </td>\n            <td class=\"govuk-table__cell govuk-table__cell--col3\"> {{fee.volume? fee.volume : '-'}} </td>\n            <td class=\"govuk-table__cell govuk-table__cell--col4\">\n              {{ fee.fee_amount | currency:'GBP':'symbol-narrow':'1.2-2' }} </td>\n            <td class=\"govuk-table__cell govuk-table__cell--col5\">\n              {{fee.calculated_amount | currency:'GBP':'symbol-narrow':'1.2-2' }} </td>\n            <td class=\"govuk-table__cell govuk-table__cell--col6 govuk-table__custom--col6\"\n              [attr.rowspan]=\"paymentGroup.fees.length\" *ngIf=\"i==0\">\n              {{getGroupOutstandingAmount(paymentGroup) | currency:'GBP':'symbol-narrow':'1.2-2' }} </td>\n\n          </tr>\n\n        </tbody>\n        <tbody class=\"govuk-table__body\" *ngIf=\"paymentGroup.fees.length==0\">\n          <td class=\"govuk-table__cell\" colspan=\"6\">No payments recorded</td>\n        </tbody>\n      </table>\n    </div>\n    <div class=\"govuk-button-group-allocate\">\n      <button type=\"button\" class=\"button govuk-!-margin-right-1\" [disabled]=\"isContinueButtondisabled\"\n        (click)=\"saveAndContinue()\">\n        Continue\n      </button>\n      <button type=\"button\" class=\"button govuk-button--secondary\" (click)=\"gotoCasetransationPage()\">\n        Cancel\n      </button>\n    </div>\n  </div>\n\n  <ng-container *ngIf=\"(viewStatus === 'mainForm' && isTurnOff) || viewStatus === 'allocatePaymentConfirmation'\">\n    <ccpay-error-banner *ngIf=\"errorMessage.showError\" [errorMessage]=\"errorMessage\"></ccpay-error-banner>\n    <input #myInput type='hidden' class='iFrameDrivenImageValue' value='{{feedbackUrlLabel}}'>\n    <h1 class=\"govuk-heading-xl\">Confirm allocation</h1>\n    <h2 class=\"govuk-heading-l govuk-heading-l--custom\">\n      Amount to be allocated: {{amountForAllocation | currency:'GBP':'symbol-narrow':'1.2-2'}}\n    </h2>\n    <div class=\"payment-group-section\" *ngIf=\"paymentGroup\">\n      <h3 class=\"govuk-heading-m--custom\" *ngIf=\"isTurnOff\">Group reference: {{paymentGroup.payment_group_reference}}\n      </h3>\n      <table class=\"govuk-table\">\n        <thead class=\"govuk-table__head\">\n          <tr class=\"govuk-table__row\">\n            <td class=\"govuk-table__header\" scope=\"col\">Code</td>\n            <td class=\"govuk-table__header\" scope=\"col\">Description</td>\n            <td class=\"govuk-table__header\" scope=\"col\">Volume</td>\n            <td class=\"govuk-table__header\" scope=\"col\">Fee amount</td>\n            <td class=\"govuk-table__header\" scope=\"col\">Calculated amount</td>\n            <td class=\"govuk-table__header\" scope=\"col\">Amount Due</td>\n          </tr>\n        </thead>\n        <tbody class=\"govuk-table__body\">\n          <tr class=\"govuk-table__row\" *ngFor=\"let fee of paymentGroup.fees; let i = index;\">\n            <td class=\"govuk-table__cell govuk-table__cell--col1\">{{fee.code}}</td>\n            <td class=\"govuk-table__cell govuk-table__cell--col2\"> {{fee.description}} </td>\n            <td class=\"govuk-table__cell govuk-table__cell--col3\"> {{fee.volume? fee.volume : '-'}} </td>\n            <td class=\"govuk-table__cell govuk-table__cell--col4\">\n              {{ fee.fee_amount | currency:'GBP':'symbol-narrow':'1.2-2' }} </td>\n            <td class=\"govuk-table__cell govuk-table__cell--col5\">\n              {{fee.calculated_amount | currency:'GBP':'symbol-narrow':'1.2-2'}} </td>\n            <td class=\"govuk-table__cell govuk-table__cell--col6\" [attr.rowspan]=\"paymentGroup.fees.length\"\n              *ngIf=\"i==0\"> {{afterFeeAllocateOutstanding | currency:'GBP':'symbol-narrow':'1.2-2'}} </td>\n          </tr>\n        </tbody>\n        <tbody class=\"govuk-table__body\" *ngIf=\"paymentGroup.fees.length == 0\">\n          <td class=\"govuk-table__cell\" colspan=\"6\">No payments recorded</td>\n        </tbody>\n      </table>\n    </div>\n    <div class=\"govuk-warning-text\" *ngIf=\"isRemainingAmountGtZero || isRemainingAmountLtZero || remainingAmount === 0\">\n      <span class=\"govuk-warning-text__icon\" aria-hidden=\"true\">!</span>\n      <strong class=\"govuk-warning-text__text govuk-warning-text__custom\">\n        <span class=\"govuk-warning-text__assistive\">Warning</span>\n        {{paymentSectionLabel.title}} {{ remainingAmount | currency:'GBP':'symbol-narrow':'1.2-2' }}\n      </strong>\n    </div>\n    <div class=\"govuk-form-group\" *ngIf=\"isRemainingAmountGtZero || isRemainingAmountLtZero\">\n      <div class=\"govuk-form-group\">\n        <fieldset class=\"govuk-fieldset\" aria-describedby=\"how-contacted-conditional-hint\">\n          <span id=\"how-contacted-conditional-hint\" class=\"govuk-hint\"\n            [ngClass]=\"{'inline-error-message': paymentReasonHasError}\">\n            {{paymentSectionLabel.reason}}\n          </span>\n          <div\n            [ngClass]=\"paymentReasonHasError ? 'govuk-radios govuk-radios--conditional form-group-error' : 'govuk-radios govuk-radios--conditional'\"\n            data-module=\"govuk-radios\" *ngIf=\"isRemainingAmountGtZero\">\n            <div class=\"govuk-radios__item\" *ngFor=\"let reason of reasonList.overPayment | keyValue\">\n              <input class=\"govuk-radios__input\" id=\"{{reason.key}}\" name=\"paymentReason\" type=\"radio\"\n                     [value]=\"reason.key\" (input)=\"getReasonValue(reason.value)\"/>\n              <label class=\"govuk-label govuk-radios__label govuk-font__custom\" for=\"how-contacted-conditional\">\n                {{reason.value}}\n              </label>\n            </div>\n          </div>\n          <div\n            [ngClass]=\"paymentReasonHasError ? 'govuk-radios govuk-radios--conditional form-group-error' : 'govuk-radios govuk-radios--conditional'\"\n            data-module=\"govuk-radios\" *ngIf=\"isRemainingAmountLtZero\">\n            <div class=\"govuk-radios__item\" *ngFor=\"let reason of reasonList.shortFall | keyValue\">\n              <input class=\"govuk-radios__input\" id=\"{{reason.key}}\" name=\"paymentReason\" type=\"radio\"\n                     [value]=\"reason.key\" (input)=\"getReasonValue(reason.value)\"/>\n              <label class=\"govuk-label govuk-radios__label govuk-font__custom\" for=\"how-contacted-conditional\">\n                {{reason.value}}\n              </label>\n            </div>\n          </div>\n        </fieldset>\n      </div>\n      <div class=\"govuk-form-group\">\n        <fieldset class=\"govuk-fieldset\" aria-describedby=\"how-contacted-conditional-hint\">\n          <span id=\"how-contacted-conditional-hint\" class=\"govuk-hint\"\n            [ngClass]=\"{'inline-error-message': paymentExplanationHasError}\">\n            Provide an explanatory note\n          </span>\n          <div\n            [ngClass]=\"paymentExplanationHasError ? 'govuk-radios govuk-radios--conditional form-group-error' : 'govuk-radios govuk-radios--conditional'\"\n            data-module=\"govuk-radios\" *ngIf=\"isRemainingAmountGtZero\">\n            <div class=\"govuk-radios__item\" *ngFor=\"let explanation of explanationList.overPayment | keyValue\">\n              <input class=\"govuk-radios__input\" id=\"{{explanation.key}}\" name=\"paymentExplanation\" type=\"radio\"\n                     [value]=\"explanation.key\" (input)=\"getExplanationValue(explanation.value)\"\n                (click)=\"selectRadioButton(explanation.key, 'explanation')\"/>\n              <label class=\"govuk-label govuk-radios__label govuk-font__custom\" for=\"how-contacted-conditional\">\n                {{explanation.value}}\n              </label>\n            </div>\n          </div>\n          <div\n            [ngClass]=\"paymentExplanationHasError ? 'govuk-radios govuk-radios--conditional form-group-error' : 'govuk-radios govuk-radios--conditional'\"\n            data-module=\"govuk-radios\" *ngIf=\"isRemainingAmountLtZero\">\n            <div class=\"govuk-radios__item\" *ngFor=\"let explanation of explanationList.shortFall | keyValue\">\n              <input class=\"govuk-radios__input\" id=\"{{explanation.key}}\" name=\"paymentExplanation\" type=\"radio\"\n                     [value]=\"explanation.key\" (input)=\"getExplanationValue(explanation.value)\"\n                (click)=\"selectRadioButton(explanation.key, 'explanation')\"/>\n              <label class=\"govuk-label govuk-radios__label govuk-font__custom\" for=\"how-contacted-conditional\">\n                {{explanation.value}}\n              </label>\n            </div>\n          </div>\n        </fieldset>\n      </div>\n    </div>\n\n    <form [formGroup]=\"overUnderPaymentForm\" novalidate>\n      <div\n        [ngClass]=\"isMoreDetailsBoxHide ? 'govuk-radios__conditional govuk-radios__conditional--hidden' : isPaymentDetailsEmpty || isPaymentDetailsInvalid || paymentDetailsMinHasError || paymentDetailsMaxHasError ? 'govuk-radios__conditional inline-error-border' : 'govuk-radios__conditional'\"\n        id=\"conditional-how-contacted-conditional-3\">\n        <div class=\"govuk-form-group\">\n          <span id=\"more-detail-hint\" class=\"govuk-hint govuk-font__custom\">\n            Please enter details\n          </span>\n          <textarea class=\"govuk-textarea\"\n            [ngClass]=\"{'inline-error-class': isPaymentDetailsEmpty || isPaymentDetailsInvalid || paymentDetailsMinHasError || paymentDetailsMaxHasError}\"\n            id=\"moreDetails\" name=\"moreDetails\" rows=\"5\" formControlName=\"moreDetails\">\n          </textarea>\n          <p class=\"inline-error-message\"\n            *ngIf=\"isPaymentDetailsEmpty || isPaymentDetailsInvalid || paymentDetailsMinHasError || paymentDetailsMaxHasError\">\n            <span *ngIf=\"isPaymentDetailsEmpty\">Enter a explanation</span>\n            <span *ngIf=\"isPaymentDetailsInvalid\">Enter a valid explanation</span>\n            <span *ngIf=\"paymentDetailsMinHasError\">Explanation should be at least 3 characters.</span>\n            <span *ngIf=\"paymentDetailsMaxHasError\">Explanation should be 255 characters or under.</span>\n          </p>\n        </div>\n      </div>\n      <div class=\"govuk-button--group\">\n        <button type=\"submit\" [disabled]=\"isConfirmButtondisabled\"\n          [ngClass]=\"isConfirmButtondisabled ? 'button button--disabled' : 'button'\"\n          (click)=\"confirmAllocatePayement()\">\n          Confirm\n        </button>\n        <button type=\"button\" class=\"button govuk-button--secondary\" (click)=\"cancelAllocatePayment($event)\">\n          Cancel\n        </button>\n      </div>\n    </form>\n  </ng-container>\n</div>\n"]}
|