@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,1276 @@
|
|
|
1
|
+
import { ChangeDetectorRef, Component, EventEmitter, forwardRef, Inject, Input, Output } from '@angular/core';
|
|
2
|
+
import { FormBuilder, FormControl, FormsModule, ReactiveFormsModule, Validators } from '@angular/forms';
|
|
3
|
+
import { Router } from '@angular/router';
|
|
4
|
+
import { AddRemissionRequest } from '../../interfaces/AddRemissionRequest';
|
|
5
|
+
import { PaymentViewService } from '../../services/payment-view/payment-view.service';
|
|
6
|
+
import { RefundsService } from '../../services/refunds/refunds.service';
|
|
7
|
+
import { NotificationService } from '../../services/notification/notification.service';
|
|
8
|
+
import { AddRetroRemissionRequest } from '../../interfaces/AddRetroRemissionRequest';
|
|
9
|
+
import { PostRefundRetroRemission } from '../../interfaces/PostRefundRetroRemission';
|
|
10
|
+
import { PostIssueRefundRetroRemission } from '../../interfaces/PostIssueRefundRetroRemission';
|
|
11
|
+
import { OrderslistService } from '../../services/orderslist.service';
|
|
12
|
+
import { PaymentViewComponent } from '../payment-view/payment-view.component';
|
|
13
|
+
import { CommonModule } from '@angular/common';
|
|
14
|
+
import { ServiceRequestComponent } from '../service-request/service-request.component';
|
|
15
|
+
import { NotificationPreviewComponent } from '../notification-preview/notification-preview.component';
|
|
16
|
+
import { CcdHyphensPipe } from '../../pipes/ccd-hyphens.pipe';
|
|
17
|
+
import { CapitalizePipe } from '../../pipes/capitalize.pipe';
|
|
18
|
+
import { ContactDetailsComponent } from '../contact-details/contact-details.component';
|
|
19
|
+
import { RpxTranslationModule } from 'rpx-xui-translation';
|
|
20
|
+
import * as i0 from "@angular/core";
|
|
21
|
+
import * as i1 from "@angular/forms";
|
|
22
|
+
import * as i2 from "@angular/router";
|
|
23
|
+
import * as i3 from "../../services/payment-view/payment-view.service";
|
|
24
|
+
import * as i4 from "../../services/notification/notification.service";
|
|
25
|
+
import * as i5 from "../../services/refunds/refunds.service";
|
|
26
|
+
import * as i6 from "../../services/orderslist.service";
|
|
27
|
+
import * as i7 from "@angular/common";
|
|
28
|
+
import * as i8 from "rpx-xui-translation";
|
|
29
|
+
const BS_ENABLE_FLAG = 'bulk-scan-enabling-fe';
|
|
30
|
+
const resolvedPromise = Promise.resolve(null);
|
|
31
|
+
export class AddRemissionComponent {
|
|
32
|
+
formBuilder;
|
|
33
|
+
router;
|
|
34
|
+
paymentViewService;
|
|
35
|
+
notificationService;
|
|
36
|
+
paymentLibComponent;
|
|
37
|
+
refundService;
|
|
38
|
+
cd;
|
|
39
|
+
OrderslistService;
|
|
40
|
+
fee;
|
|
41
|
+
fees;
|
|
42
|
+
payment;
|
|
43
|
+
remission;
|
|
44
|
+
ccdCaseNumber;
|
|
45
|
+
caseType;
|
|
46
|
+
viewCompStatus;
|
|
47
|
+
paymentGroupRef;
|
|
48
|
+
isTurnOff;
|
|
49
|
+
isRefundRemission;
|
|
50
|
+
isStrategicFixEnable;
|
|
51
|
+
paidAmount;
|
|
52
|
+
isFromRefundListPage;
|
|
53
|
+
isFromPaymentDetailPage;
|
|
54
|
+
isFromServiceRequestPage;
|
|
55
|
+
isFullyRefund;
|
|
56
|
+
feeamount;
|
|
57
|
+
refundPaymentReference;
|
|
58
|
+
isFromRefundStatusPage;
|
|
59
|
+
changeRefundReason;
|
|
60
|
+
isServiceRequest;
|
|
61
|
+
LOGGEDINUSERROLES;
|
|
62
|
+
orderDetail;
|
|
63
|
+
orderRef;
|
|
64
|
+
orderStatus;
|
|
65
|
+
orderParty;
|
|
66
|
+
orderCreated;
|
|
67
|
+
orderCCDEvent;
|
|
68
|
+
takePayment;
|
|
69
|
+
orderFeesTotal;
|
|
70
|
+
orderTotalPayments;
|
|
71
|
+
orderRemissionTotal;
|
|
72
|
+
cancelRemission = new EventEmitter();
|
|
73
|
+
//@Output() refundListReason: EventEmitter<any> = new EventEmitter({reason:string, code:string});
|
|
74
|
+
refundListReason = new EventEmitter();
|
|
75
|
+
refundListAmount = new EventEmitter();
|
|
76
|
+
refundFees = new EventEmitter();
|
|
77
|
+
refund = {
|
|
78
|
+
reason: {
|
|
79
|
+
duplicate: 'Duplicate payment',
|
|
80
|
+
humanerror: 'Human error',
|
|
81
|
+
caseWithdrawn: 'Case withdrawn',
|
|
82
|
+
other: 'Other'
|
|
83
|
+
}
|
|
84
|
+
};
|
|
85
|
+
contactDetailsObj;
|
|
86
|
+
notification;
|
|
87
|
+
remissionForm;
|
|
88
|
+
hasErrors = false;
|
|
89
|
+
viewStatus = 'main';
|
|
90
|
+
errorMessage = null;
|
|
91
|
+
option = null;
|
|
92
|
+
isConfirmationBtnDisabled = false;
|
|
93
|
+
bsPaymentDcnNumber;
|
|
94
|
+
selectedValue = 'yes';
|
|
95
|
+
amount;
|
|
96
|
+
retroRemission = false;
|
|
97
|
+
remissionReference = '';
|
|
98
|
+
refundReference;
|
|
99
|
+
refundAmount;
|
|
100
|
+
paymentExplanationHasError = false;
|
|
101
|
+
refundReason;
|
|
102
|
+
selectedRefundReason;
|
|
103
|
+
selectedRefundReasonCode;
|
|
104
|
+
displayRefundReason;
|
|
105
|
+
refundCode;
|
|
106
|
+
remessionPayment;
|
|
107
|
+
isRemissionCodeEmpty = false;
|
|
108
|
+
remissionCodeHasError = false;
|
|
109
|
+
isAmountEmpty = false;
|
|
110
|
+
isReasonEmpty = false;
|
|
111
|
+
amountHasError = false;
|
|
112
|
+
isRemissionLessThanFeeError = false;
|
|
113
|
+
refundHasError = false;
|
|
114
|
+
isPaymentSuccess = false;
|
|
115
|
+
isRemissionApplied = false;
|
|
116
|
+
remissionamt;
|
|
117
|
+
elementId;
|
|
118
|
+
// refundReasons: any[] = [];
|
|
119
|
+
commonRefundReasons = [];
|
|
120
|
+
showReasonText;
|
|
121
|
+
isRefundReasonsSelected;
|
|
122
|
+
default;
|
|
123
|
+
reasonLength;
|
|
124
|
+
refundReasons;
|
|
125
|
+
pattern1;
|
|
126
|
+
pattern2;
|
|
127
|
+
sendOrderDetail;
|
|
128
|
+
sendOrderRef;
|
|
129
|
+
paymentReference;
|
|
130
|
+
class = '';
|
|
131
|
+
errorMsg = new Array();
|
|
132
|
+
totalRefundAmount;
|
|
133
|
+
quantityUpdated;
|
|
134
|
+
fullRefund;
|
|
135
|
+
allowedRefundAmount;
|
|
136
|
+
isRemissionsMatch;
|
|
137
|
+
paymentFees;
|
|
138
|
+
paymentGroup;
|
|
139
|
+
isStatusAllocated;
|
|
140
|
+
isFromCheckAnsPage;
|
|
141
|
+
refundAmtForFeeVolumes;
|
|
142
|
+
paymentObj;
|
|
143
|
+
templateInstructionType;
|
|
144
|
+
notificationPreview;
|
|
145
|
+
component;
|
|
146
|
+
constructor(formBuilder, router, paymentViewService, notificationService, paymentLibComponent, refundService, cd, OrderslistService) {
|
|
147
|
+
this.formBuilder = formBuilder;
|
|
148
|
+
this.router = router;
|
|
149
|
+
this.paymentViewService = paymentViewService;
|
|
150
|
+
this.notificationService = notificationService;
|
|
151
|
+
this.paymentLibComponent = paymentLibComponent;
|
|
152
|
+
this.refundService = refundService;
|
|
153
|
+
this.cd = cd;
|
|
154
|
+
this.OrderslistService = OrderslistService;
|
|
155
|
+
}
|
|
156
|
+
ngOnInit() {
|
|
157
|
+
this.errorMessage = '';
|
|
158
|
+
this.errorMsg = [];
|
|
159
|
+
this.default = 'Select a different reason';
|
|
160
|
+
this.pattern1 = '^([a-zA-Z0-9]{3})-([a-zA-Z0-9]{3})-([a-zA-Z0-9]{3})$';
|
|
161
|
+
this.pattern2 = '^([A-Za-z]{2}[0-9]{2})-([0-9]{6})$';
|
|
162
|
+
if (this.viewCompStatus !== '' && this.viewCompStatus !== undefined) {
|
|
163
|
+
this.viewStatus = '';
|
|
164
|
+
}
|
|
165
|
+
if (this.remission) {
|
|
166
|
+
}
|
|
167
|
+
if (this.fee) {
|
|
168
|
+
this.amount = (this.fee.volume * this.fee.calculated_amount);
|
|
169
|
+
}
|
|
170
|
+
if (this.payment) {
|
|
171
|
+
this.paymentReference = this.payment.reference;
|
|
172
|
+
this.remessionPayment = this.payment;
|
|
173
|
+
if (this.payment.status === 'Success') {
|
|
174
|
+
this.isPaymentSuccess = true;
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
this.option = this.paymentLibComponent.SELECTED_OPTION;
|
|
178
|
+
this.bsPaymentDcnNumber = this.paymentLibComponent.bspaymentdcn;
|
|
179
|
+
this.remissionForm = this.formBuilder.group({
|
|
180
|
+
remissionCode: new FormControl('', Validators.compose([
|
|
181
|
+
Validators.required,
|
|
182
|
+
Validators.pattern(`(${this.pattern1})|(${this.pattern2})`)
|
|
183
|
+
])),
|
|
184
|
+
amount: new FormControl('', Validators.compose([
|
|
185
|
+
Validators.required,
|
|
186
|
+
Validators.pattern('^[0-9]+(\.[0-9]{1,2})?$')
|
|
187
|
+
])),
|
|
188
|
+
refundReason: new FormControl('', Validators.compose([Validators.required])),
|
|
189
|
+
refundDDReason: new FormControl('', Validators.compose([Validators.required])),
|
|
190
|
+
reason: new FormControl(),
|
|
191
|
+
feeAmount: new FormControl(),
|
|
192
|
+
feesList: this.formBuilder.array([])
|
|
193
|
+
});
|
|
194
|
+
const remissionctrls = this.remissionForm.controls;
|
|
195
|
+
remissionctrls['refundDDReason'].setValue('Select a different reason', { onlySelf: true });
|
|
196
|
+
if (this.refundPaymentReference !== undefined && this.refundPaymentReference.length > 0) {
|
|
197
|
+
this.paymentReference = this.refundPaymentReference;
|
|
198
|
+
}
|
|
199
|
+
else {
|
|
200
|
+
this.paymentReference = (this.payment !== undefined) ? this.payment.reference : '';
|
|
201
|
+
}
|
|
202
|
+
// PAY-7956: Refresh paymentGroup if this.paymentReference is known.
|
|
203
|
+
// this call was originally based on if (this.isFromServiceRequestPage) {
|
|
204
|
+
if (this.paymentReference) {
|
|
205
|
+
this.paymentViewService.getApportionPaymentDetails(this.paymentReference).subscribe(paymentGroup => {
|
|
206
|
+
let fees = [];
|
|
207
|
+
paymentGroup.fees.forEach(fee => {
|
|
208
|
+
this.isRemissionsMatch = false;
|
|
209
|
+
paymentGroup.remissions.forEach(rem => {
|
|
210
|
+
if (rem.fee_code === fee.code) {
|
|
211
|
+
this.isRemissionsMatch = true;
|
|
212
|
+
fee['remissions'] = rem;
|
|
213
|
+
fees.push(fee);
|
|
214
|
+
}
|
|
215
|
+
});
|
|
216
|
+
if (!this.isRemissionsMatch) {
|
|
217
|
+
fees.push(fee);
|
|
218
|
+
}
|
|
219
|
+
});
|
|
220
|
+
paymentGroup.fees = fees;
|
|
221
|
+
this.paymentFees = fees;
|
|
222
|
+
this.fees = fees;
|
|
223
|
+
this.paymentGroup = paymentGroup;
|
|
224
|
+
this.paymentGroup.payments = this.paymentGroup.payments.filter(paymentGroupObj => paymentGroupObj['reference'].includes(this.paymentLibComponent.paymentReference));
|
|
225
|
+
// const paymentAllocation = this.paymentGroup.payments[0].payment_allocation;
|
|
226
|
+
// this.isStatusAllocated = paymentAllocation.length > 0 && paymentAllocation[0].allocation_status === 'Allocated' || paymentAllocation.length === 0;
|
|
227
|
+
this.paymentLibComponent.addPaymentGroup(this.paymentGroup);
|
|
228
|
+
this.refundFeesList();
|
|
229
|
+
}, (error) => this.errorMessage = error);
|
|
230
|
+
}
|
|
231
|
+
if (this.viewCompStatus === '') {
|
|
232
|
+
this.viewStatus = 'main';
|
|
233
|
+
}
|
|
234
|
+
if (this.viewCompStatus === 'issuerefundpage1') {
|
|
235
|
+
this.refundService.getRefundReasons().subscribe(refundReasons => {
|
|
236
|
+
this.refundReasons = refundReasons.filter((data) => data.recently_used === false);
|
|
237
|
+
this.refundReasons = this.refundReasons.filter((data) => data.name !== 'Retrospective remission' && data.name !== 'Overpayment');
|
|
238
|
+
this.cd.detectChanges();
|
|
239
|
+
this.commonRefundReasons = refundReasons.filter((data) => data.recently_used === true);
|
|
240
|
+
this.commonRefundReasons.sort((a, b) => a.toString().localeCompare(b));
|
|
241
|
+
this.cd.detectChanges();
|
|
242
|
+
});
|
|
243
|
+
this.refundReason = this.changeRefundReason;
|
|
244
|
+
}
|
|
245
|
+
if (this.viewCompStatus === 'processretroremissonpage' && this.isFromRefundListPage) {
|
|
246
|
+
this.viewStatus = 'processretroremissonpage';
|
|
247
|
+
}
|
|
248
|
+
if (this.orderDetail !== undefined) {
|
|
249
|
+
this.paymentViewService.getApportionPaymentDetails(this.orderDetail[0].payments[0].reference).subscribe(paymentGroup => {
|
|
250
|
+
this.fees = paymentGroup.fees;
|
|
251
|
+
this.paymentReference = paymentGroup.payments[0].reference;
|
|
252
|
+
}, (error) => this.errorMessage = error);
|
|
253
|
+
}
|
|
254
|
+
}
|
|
255
|
+
goToPaymentViewComponent() {
|
|
256
|
+
this.paymentLibComponent.paymentMethod = this.payment.method;
|
|
257
|
+
this.paymentLibComponent.paymentGroupReference = this.paymentGroupRef;
|
|
258
|
+
this.paymentLibComponent.paymentReference = this.paymentReference;
|
|
259
|
+
//this.PaymentViewComponent.viewCompStatus = 'overpayment';
|
|
260
|
+
this.paymentLibComponent.viewName = 'payment-view';
|
|
261
|
+
}
|
|
262
|
+
refundFeesList() {
|
|
263
|
+
const creds = this.remissionForm.controls.feesList;
|
|
264
|
+
// if(creds.controls.length > 0) {
|
|
265
|
+
for (var i = 0; i < this.fees.length; i++) {
|
|
266
|
+
creds.push(this.formBuilder.group({
|
|
267
|
+
id: this.fees[i].id,
|
|
268
|
+
code: this.fees[i].code,
|
|
269
|
+
volume: this.fees[i].volume,
|
|
270
|
+
calculated_amount: this.fees[i].calculated_amount,
|
|
271
|
+
apportion_amount: this.fees[i].apportion_amount,
|
|
272
|
+
ccd_case_number: this.fees[i].ccd_case_number,
|
|
273
|
+
description: this.fees[i].description,
|
|
274
|
+
net_amount: this.fees[i].net_amount,
|
|
275
|
+
version: this.fees[i].version,
|
|
276
|
+
refund_amount: [''],
|
|
277
|
+
selected: [''],
|
|
278
|
+
updated_volume: this.fees[i].volume
|
|
279
|
+
}));
|
|
280
|
+
}
|
|
281
|
+
this.cd.detectChanges();
|
|
282
|
+
//}
|
|
283
|
+
}
|
|
284
|
+
get feesList() {
|
|
285
|
+
const dd = this.remissionForm.get('feesList');
|
|
286
|
+
return this.remissionForm.get('feesList');
|
|
287
|
+
}
|
|
288
|
+
noneSelected() {
|
|
289
|
+
if (this.isFullyRefund) {
|
|
290
|
+
return false;
|
|
291
|
+
}
|
|
292
|
+
else {
|
|
293
|
+
if (!this.feesList.controls.some(item => item.get('selected').value === true)) {
|
|
294
|
+
this.errorMsg = [];
|
|
295
|
+
[].forEach.call(document.querySelectorAll('input'), function (el) {
|
|
296
|
+
el.classList.remove('inline-error-class');
|
|
297
|
+
});
|
|
298
|
+
}
|
|
299
|
+
return !this.feesList.controls.some(item => item.get('selected').value === true);
|
|
300
|
+
}
|
|
301
|
+
}
|
|
302
|
+
calculateRefundAmount(index, AppAmt) {
|
|
303
|
+
const formArray = this.remissionForm.controls.feesList;
|
|
304
|
+
if (this.isRemissionEnabled(formArray.value.at(index).code)) {
|
|
305
|
+
let remission = this.getRemissions(formArray.value.at(index).code);
|
|
306
|
+
let feeAmount = this.paymentLibComponent.paymentGroup.fees.at(index).calculated_amount;
|
|
307
|
+
return this.getNetAmountFee(remission.hwf_amount, feeAmount);
|
|
308
|
+
}
|
|
309
|
+
else {
|
|
310
|
+
return AppAmt;
|
|
311
|
+
}
|
|
312
|
+
}
|
|
313
|
+
check_en(i, v1, AppAmt, Volume) {
|
|
314
|
+
const ele = document.getElementById(v1);
|
|
315
|
+
const formArray = this.remissionForm.controls.feesList;
|
|
316
|
+
if (ele.checked) {
|
|
317
|
+
// Checkbox checked at index: 0, v1: 6012667, AppAmt: 100, Volume: 1
|
|
318
|
+
let refundAmount = this.calculateRefundAmount(i, AppAmt);
|
|
319
|
+
formArray.at(i).get('refund_amount').setValue(refundAmount);
|
|
320
|
+
formArray.at(i).get('volume').setValue(Volume);
|
|
321
|
+
formArray.at(i).get('selected').setValue(true);
|
|
322
|
+
formArray.at(i).get('updated_volume').setValue(Volume);
|
|
323
|
+
document.getElementById('feeAmount_' + v1).value = refundAmount;
|
|
324
|
+
document.getElementById('feeAmount_' + v1).removeAttribute("disabled");
|
|
325
|
+
if (Volume === 1) {
|
|
326
|
+
document.getElementById('VolumeUpdated_' + v1).value = Volume;
|
|
327
|
+
}
|
|
328
|
+
else {
|
|
329
|
+
document.getElementById('feeVolumeUpdated_' + v1).value = Volume;
|
|
330
|
+
}
|
|
331
|
+
if (document.getElementById('feeVolumeUpdated_' + v1) !== null) {
|
|
332
|
+
document.getElementById('feeAmount_' + v1).removeAttribute("disabled");
|
|
333
|
+
document.getElementById('feeVolumeUpdated_' + v1).removeAttribute("disabled");
|
|
334
|
+
}
|
|
335
|
+
this.cd.detectChanges();
|
|
336
|
+
}
|
|
337
|
+
else {
|
|
338
|
+
this.errorMsg = [];
|
|
339
|
+
document.getElementById('feeAmount_' + v1).setAttribute("disabled", "true");
|
|
340
|
+
this.remissionForm.value.feesList[i]["refund_amount"] = '';
|
|
341
|
+
this.remissionForm.value.feesList[i]["volume"] = '';
|
|
342
|
+
this.remissionForm.value.feesList[i]["selected"] = false;
|
|
343
|
+
document.getElementById('feeAmount_' + v1).value = '';
|
|
344
|
+
if (Volume > 1) {
|
|
345
|
+
this.remissionForm.value.feesList[i]["volume"] = '';
|
|
346
|
+
document.getElementById('feeVolumeUpdated_' + v1).value = '';
|
|
347
|
+
}
|
|
348
|
+
if (document.getElementById('feeVolumeUpdated_' + v1) !== null) {
|
|
349
|
+
document.getElementById('feeVolumeUpdated_' + v1).removeAttribute("disabled");
|
|
350
|
+
}
|
|
351
|
+
this.cd.detectChanges();
|
|
352
|
+
}
|
|
353
|
+
}
|
|
354
|
+
addRemission() {
|
|
355
|
+
this.resetRemissionForm([false, false, false, false, false, false], 'All');
|
|
356
|
+
const remissionctrls = this.remissionForm.controls, isRemissionLessThanFee = this.fee.calculated_amount > remissionctrls.amount.value;
|
|
357
|
+
this.remissionForm.controls['refundReason'].setErrors(null);
|
|
358
|
+
this.remissionForm.controls['refundDDReason'].setErrors(null);
|
|
359
|
+
if (this.remissionForm.dirty && this.remissionForm.valid && isRemissionLessThanFee) {
|
|
360
|
+
this.viewStatus = 'confirmation';
|
|
361
|
+
}
|
|
362
|
+
else {
|
|
363
|
+
if (remissionctrls['remissionCode'].value == '') {
|
|
364
|
+
this.resetRemissionForm([true, false, false, false, false, false], 'remissionCode');
|
|
365
|
+
}
|
|
366
|
+
if (remissionctrls['remissionCode'].value != '' && remissionctrls['remissionCode'].invalid) {
|
|
367
|
+
this.resetRemissionForm([false, true, false, false, false, false], 'remissionCode');
|
|
368
|
+
}
|
|
369
|
+
if (remissionctrls['amount'].value == '') {
|
|
370
|
+
this.resetRemissionForm([false, false, true, false, false, false], 'amount');
|
|
371
|
+
}
|
|
372
|
+
if (remissionctrls['amount'].value != '' && remissionctrls['amount'].invalid) {
|
|
373
|
+
this.resetRemissionForm([false, true, false, true, false, false], 'amount');
|
|
374
|
+
}
|
|
375
|
+
if (remissionctrls.amount.valid && !isRemissionLessThanFee) {
|
|
376
|
+
this.resetRemissionForm([false, false, false, false, true, false], 'amount');
|
|
377
|
+
}
|
|
378
|
+
}
|
|
379
|
+
}
|
|
380
|
+
confirmRemission() {
|
|
381
|
+
this.isConfirmationBtnDisabled = true;
|
|
382
|
+
const newNetAmount = this.remissionForm.controls.amount.value, remissionAmount = parseFloat((this.fee.net_amount - newNetAmount).toFixed(2)), requestBody = new AddRemissionRequest(this.ccdCaseNumber, this.fee, remissionAmount, this.remissionForm.controls.remissionCode.value, this.caseType);
|
|
383
|
+
this.paymentViewService.postPaymentGroupWithRemissions(decodeURIComponent(this.paymentGroupRef).trim(), this.fee.id, requestBody).subscribe(response => {
|
|
384
|
+
if (JSON.parse(response).success) {
|
|
385
|
+
let LDUrl = this.isTurnOff ? '&isTurnOff=Enable' : '&isTurnOff=Disable';
|
|
386
|
+
LDUrl += `&caseType=${this.caseType}`;
|
|
387
|
+
if (this.paymentLibComponent.bspaymentdcn) {
|
|
388
|
+
this.router.routeReuseStrategy.shouldReuseRoute = () => false;
|
|
389
|
+
this.router.onSameUrlNavigation = 'reload';
|
|
390
|
+
this.router.navigateByUrl(`/payment-history/${this.ccdCaseNumber}?view=fee-summary&selectedOption=${this.option}&paymentGroupRef=${this.paymentGroupRef}&dcn=${this.paymentLibComponent.bspaymentdcn}${LDUrl}`);
|
|
391
|
+
}
|
|
392
|
+
else {
|
|
393
|
+
this.gotoCasetransationPage();
|
|
394
|
+
}
|
|
395
|
+
}
|
|
396
|
+
}, (error) => {
|
|
397
|
+
this.errorMessage = error;
|
|
398
|
+
this.isConfirmationBtnDisabled = false;
|
|
399
|
+
});
|
|
400
|
+
}
|
|
401
|
+
resetRemissionForm(val, field) {
|
|
402
|
+
if (field === 'All') {
|
|
403
|
+
this.isRemissionCodeEmpty = val[0];
|
|
404
|
+
this.remissionCodeHasError = val[1];
|
|
405
|
+
this.isAmountEmpty = val[2];
|
|
406
|
+
this.amountHasError = val[3];
|
|
407
|
+
this.isRemissionLessThanFeeError = val[4];
|
|
408
|
+
this.isReasonEmpty = val[5];
|
|
409
|
+
}
|
|
410
|
+
else if (field === 'remissionCode' || field === 'All') {
|
|
411
|
+
this.isRemissionCodeEmpty = val[0];
|
|
412
|
+
this.remissionCodeHasError = val[1];
|
|
413
|
+
}
|
|
414
|
+
else if (field === 'amount' || field === 'All') {
|
|
415
|
+
this.isAmountEmpty = val[2];
|
|
416
|
+
this.amountHasError = val[3];
|
|
417
|
+
this.isRemissionLessThanFeeError = val[4];
|
|
418
|
+
}
|
|
419
|
+
else if (field === 'reason' || field === 'All') {
|
|
420
|
+
this.isReasonEmpty = val[5];
|
|
421
|
+
}
|
|
422
|
+
}
|
|
423
|
+
// Add retro remission changes
|
|
424
|
+
addRemissionCode() {
|
|
425
|
+
this.errorMessage = false;
|
|
426
|
+
// this.isFromCheckAnsPage = true;
|
|
427
|
+
this.errorMsg = [];
|
|
428
|
+
this.viewStatus = '';
|
|
429
|
+
this.isRefundRemission = false;
|
|
430
|
+
this.resetRemissionForm([false, false, false, false, false, false], 'All');
|
|
431
|
+
const remissionctrls = this.remissionForm.controls;
|
|
432
|
+
// isRemissionLessThanFee = this.fee.calculated_amount >= remissionctrls.amount.value;
|
|
433
|
+
this.remissionForm.controls['refundReason'].setErrors(null);
|
|
434
|
+
this.remissionForm.controls['refundDDReason'].setErrors(null);
|
|
435
|
+
this.remissionForm.controls['amount'].setErrors(null);
|
|
436
|
+
if (this.remissionForm.dirty && this.remissionForm.valid) {
|
|
437
|
+
if (!this.isFromCheckAnsPage) {
|
|
438
|
+
this.viewCompStatus = '';
|
|
439
|
+
this.viewStatus = "processretroremissonpage";
|
|
440
|
+
}
|
|
441
|
+
else {
|
|
442
|
+
this.viewCompStatus = '';
|
|
443
|
+
this.viewStatus = 'checkretroremissionpage';
|
|
444
|
+
}
|
|
445
|
+
}
|
|
446
|
+
else {
|
|
447
|
+
if (remissionctrls['remissionCode'].value == '') {
|
|
448
|
+
this.resetRemissionForm([true, false, false, false, false], 'remissionCode');
|
|
449
|
+
}
|
|
450
|
+
if (remissionctrls['remissionCode'].value != '' && remissionctrls['remissionCode'].invalid) {
|
|
451
|
+
this.resetRemissionForm([false, true, false, false, false], 'remissionCode');
|
|
452
|
+
}
|
|
453
|
+
if (remissionctrls['amount'].value == '') {
|
|
454
|
+
this.resetRemissionForm([false, false, true, false, false], 'amount');
|
|
455
|
+
}
|
|
456
|
+
if (remissionctrls['amount'].value != '' && remissionctrls['amount'].invalid) {
|
|
457
|
+
this.resetRemissionForm([false, true, false, true, false], 'amount');
|
|
458
|
+
}
|
|
459
|
+
if (remissionctrls['reason'].value == '') {
|
|
460
|
+
this.resetRemissionForm([false, false, false, true, false, true], 'reason');
|
|
461
|
+
}
|
|
462
|
+
if (remissionctrls.amount.valid) {
|
|
463
|
+
this.resetRemissionForm([false, false, false, false, true], 'amount');
|
|
464
|
+
}
|
|
465
|
+
}
|
|
466
|
+
}
|
|
467
|
+
gotoAddRetroRemissionCodePage() {
|
|
468
|
+
this.errorMessage = false;
|
|
469
|
+
this.isFromCheckAnsPage = false;
|
|
470
|
+
this.errorMsg = [];
|
|
471
|
+
if (this.isRefundRemission) {
|
|
472
|
+
this.refundListAmount.emit();
|
|
473
|
+
this.paymentLibComponent.isFromRefundStatusPage = true;
|
|
474
|
+
return;
|
|
475
|
+
}
|
|
476
|
+
if (this.isFromRefundListPage) {
|
|
477
|
+
this.paymentLibComponent.iscancelClicked = true;
|
|
478
|
+
this.refundListReason.emit({ reason: this.selectedRefundReason, code: this.refundReason });
|
|
479
|
+
this.paymentLibComponent.isFromRefundStatusPage = true;
|
|
480
|
+
return;
|
|
481
|
+
}
|
|
482
|
+
this.viewStatus = '';
|
|
483
|
+
this.selectedValue = 'yes';
|
|
484
|
+
this.viewCompStatus = "addremission";
|
|
485
|
+
this.isRefundRemission = true;
|
|
486
|
+
this.errorMessage = '';
|
|
487
|
+
this.errorMsg = [];
|
|
488
|
+
if (this.isFromPaymentDetailPage) {
|
|
489
|
+
this.paymentLibComponent.viewName = 'payment-view';
|
|
490
|
+
}
|
|
491
|
+
}
|
|
492
|
+
gotoCheckRetroRemissionPage(payment) {
|
|
493
|
+
this.paymentLibComponent.iscancelClicked = false;
|
|
494
|
+
this.errorMessage = '';
|
|
495
|
+
this.resetRemissionForm([false, false, false, false, false], 'All');
|
|
496
|
+
if (!this.isRefundRemission) {
|
|
497
|
+
var remissionctrls = this.remissionForm.controls, isRemissionLessThanFee = this.fee.calculated_amount >= remissionctrls.amount.value;
|
|
498
|
+
if (this.remissionForm.dirty) {
|
|
499
|
+
if (remissionctrls['amount'].value == '' || remissionctrls['amount'].value < 0) {
|
|
500
|
+
this.resetRemissionForm([false, false, true, false, false], 'amount');
|
|
501
|
+
}
|
|
502
|
+
else if (remissionctrls['amount'].value != '' && remissionctrls['amount'].invalid) {
|
|
503
|
+
this.resetRemissionForm([false, false, false, true, false], 'amount');
|
|
504
|
+
}
|
|
505
|
+
else if (remissionctrls.amount.valid && !isRemissionLessThanFee) {
|
|
506
|
+
this.resetRemissionForm([false, false, false, false, true], 'amount');
|
|
507
|
+
}
|
|
508
|
+
else {
|
|
509
|
+
this.viewCompStatus = '';
|
|
510
|
+
this.viewStatus = "checkretroremissionpage";
|
|
511
|
+
}
|
|
512
|
+
}
|
|
513
|
+
}
|
|
514
|
+
else {
|
|
515
|
+
var remissionctrls = this.remissionForm.controls;
|
|
516
|
+
//if (this.remissionForm.dirty ) {
|
|
517
|
+
if (remissionctrls['amount'].value == '' || remissionctrls['amount'].value < 0) {
|
|
518
|
+
this.resetRemissionForm([false, false, true, false, false], 'amount');
|
|
519
|
+
}
|
|
520
|
+
else {
|
|
521
|
+
this.viewCompStatus = '';
|
|
522
|
+
this.viewStatus = "checkretroremissionpage";
|
|
523
|
+
this.refundListAmount.emit(remissionctrls['amount'].value);
|
|
524
|
+
}
|
|
525
|
+
//}
|
|
526
|
+
}
|
|
527
|
+
this.paymentLibComponent.addPaymentGroup(this.paymentGroup);
|
|
528
|
+
}
|
|
529
|
+
gotoAmountRetroRemission() {
|
|
530
|
+
this.isFromCheckAnsPage = false;
|
|
531
|
+
this.viewStatus = 'processretroremissonpage';
|
|
532
|
+
this.viewCompStatus = '';
|
|
533
|
+
// this.isRefundRemission = true;
|
|
534
|
+
this.errorMessage = '';
|
|
535
|
+
}
|
|
536
|
+
gotoProcessRetroRemissionPage() {
|
|
537
|
+
this.isFromCheckAnsPage = true;
|
|
538
|
+
this.viewStatus = '';
|
|
539
|
+
this.viewCompStatus = 'addremission';
|
|
540
|
+
this.isRefundRemission = true;
|
|
541
|
+
this.errorMessage = '';
|
|
542
|
+
this.errorMsg = [];
|
|
543
|
+
}
|
|
544
|
+
gotoProcessRetroRemission(note) {
|
|
545
|
+
if (note) {
|
|
546
|
+
this.notification = { contact_details: note, notification_type: note.notification_type };
|
|
547
|
+
}
|
|
548
|
+
this.isFromCheckAnsPage = true;
|
|
549
|
+
this.viewStatus = 'remissionAddressPage';
|
|
550
|
+
this.viewCompStatus = '';
|
|
551
|
+
this.isRefundRemission = true;
|
|
552
|
+
this.errorMessage = '';
|
|
553
|
+
this.isConfirmationBtnDisabled = false;
|
|
554
|
+
this.paymentLibComponent.addPaymentGroup(this.paymentGroup);
|
|
555
|
+
}
|
|
556
|
+
confirmRetroRemission() {
|
|
557
|
+
this.paymentLibComponent.addPaymentGroup(this.paymentGroup);
|
|
558
|
+
this.isConfirmationBtnDisabled = true;
|
|
559
|
+
this.retroRemission = true;
|
|
560
|
+
this.remissionamt = this.remissionForm.controls.amount.value;
|
|
561
|
+
const requestBody = new AddRetroRemissionRequest(this.remissionamt, this.remissionForm.controls.remissionCode.value);
|
|
562
|
+
this.paymentViewService.postPaymentGroupWithRetroRemissions(decodeURIComponent(this.paymentGroupRef).trim(), this.fee.id, requestBody).subscribe(response => {
|
|
563
|
+
if (JSON.parse(response)) {
|
|
564
|
+
this.isRemissionApplied = true;
|
|
565
|
+
this.viewCompStatus = '';
|
|
566
|
+
this.viewStatus = 'retroremissionconfirmationpage';
|
|
567
|
+
this.remissionReference = JSON.parse(response).remission_reference;
|
|
568
|
+
this.paymentLibComponent.addRemission(requestBody);
|
|
569
|
+
}
|
|
570
|
+
}, (error) => {
|
|
571
|
+
this.errorMessage = error;
|
|
572
|
+
this.isConfirmationBtnDisabled = false;
|
|
573
|
+
this.cd.detectChanges();
|
|
574
|
+
});
|
|
575
|
+
}
|
|
576
|
+
processRefund() {
|
|
577
|
+
this.errorMessage = '';
|
|
578
|
+
this.errorMsg = [];
|
|
579
|
+
this.isConfirmationBtnDisabled = true;
|
|
580
|
+
if (this.isRefundRemission) {
|
|
581
|
+
this.retroRemission = true;
|
|
582
|
+
}
|
|
583
|
+
if (this.remissionReference === undefined || this.remissionReference === '') {
|
|
584
|
+
this.remissionReference = this.remission.remission_reference;
|
|
585
|
+
}
|
|
586
|
+
const requestBody = new PostIssueRefundRetroRemission(this.remissionReference, this.contactDetailsObj);
|
|
587
|
+
this.paymentViewService.postRefundRetroRemission(requestBody).subscribe(response => {
|
|
588
|
+
if (JSON.parse(response)) {
|
|
589
|
+
this.viewCompStatus = '';
|
|
590
|
+
this.viewStatus = 'refundconfirmationpage';
|
|
591
|
+
this.refundReference = JSON.parse(response).refund_reference;
|
|
592
|
+
this.refundAmount = JSON.parse(response).refund_amount;
|
|
593
|
+
}
|
|
594
|
+
}, (error) => {
|
|
595
|
+
this.errorMessage = error;
|
|
596
|
+
this.isConfirmationBtnDisabled = false;
|
|
597
|
+
});
|
|
598
|
+
}
|
|
599
|
+
// Issue Refund changes
|
|
600
|
+
gotoIssueRefundConfirmation(payment) {
|
|
601
|
+
this.paymentLibComponent.iscancelClicked = false;
|
|
602
|
+
if (this.paymentLibComponent.REFUNDLIST === "true") {
|
|
603
|
+
this.isFromRefundListPage = true;
|
|
604
|
+
}
|
|
605
|
+
this.totalRefundAmount = this.remissionForm.value.feesList.reduce((a, c) => a + c.refund_amount * c.selected, 0);
|
|
606
|
+
this.errorMessage = '';
|
|
607
|
+
this.errorMsg = [];
|
|
608
|
+
this.refundReason = this.remissionForm.controls['refundReason'].value === null ? this.remissionForm.controls['refundDDReason'].value : this.remissionForm.controls['refundReason'].value;
|
|
609
|
+
if (!this.refundReason || this.refundReason === 'Select a different reason') {
|
|
610
|
+
this.refundHasError = true;
|
|
611
|
+
}
|
|
612
|
+
else if (this.selectedRefundReason.includes('Other') && (this.remissionForm.controls['reason'].value == '' || this.remissionForm.controls['reason'].value == null)) {
|
|
613
|
+
this.resetRemissionForm([false, false, false, true, false, true], 'reason');
|
|
614
|
+
}
|
|
615
|
+
else if (this.selectedRefundReason.includes('Other') && this.remissionForm.controls['reason'].value !== '') {
|
|
616
|
+
this.refundHasError = false;
|
|
617
|
+
this.refundReason += '-' + this.remissionForm.controls['reason'].value;
|
|
618
|
+
this.displayRefundReason = this.selectedRefundReason + '-' + this.remissionForm.controls['reason'].value;
|
|
619
|
+
if (this.isFromRefundListPage) {
|
|
620
|
+
this.refundListReason.emit({ reason: this.displayRefundReason, code: this.refundReason });
|
|
621
|
+
}
|
|
622
|
+
else {
|
|
623
|
+
if (this.isFromCheckAnsPage) {
|
|
624
|
+
this.totalRefundAmount = this.remissionForm.value.feesList.reduce((a, c) => a + c.refund_amount * c.selected, 0);
|
|
625
|
+
this.isFromCheckAnsPage = false;
|
|
626
|
+
this.viewStatus = 'checkissuerefundpage';
|
|
627
|
+
this.viewCompStatus = '';
|
|
628
|
+
this.notificationPreview = false;
|
|
629
|
+
return;
|
|
630
|
+
}
|
|
631
|
+
this.viewCompStatus = '';
|
|
632
|
+
this.viewStatus = 'contactDetailsPage';
|
|
633
|
+
}
|
|
634
|
+
}
|
|
635
|
+
else {
|
|
636
|
+
this.displayRefundReason = this.selectedRefundReason;
|
|
637
|
+
if (this.isFromCheckAnsPage) {
|
|
638
|
+
this.totalRefundAmount = this.remissionForm.value.feesList.reduce((a, c) => a + c.refund_amount * c.selected, 0);
|
|
639
|
+
this.isFromCheckAnsPage = false;
|
|
640
|
+
this.viewStatus = 'checkissuerefundpage';
|
|
641
|
+
this.viewCompStatus = '';
|
|
642
|
+
this.notificationPreview = false;
|
|
643
|
+
return;
|
|
644
|
+
}
|
|
645
|
+
if (this.isFromRefundListPage) {
|
|
646
|
+
this.paymentLibComponent.isFromRefundStatusPage = true;
|
|
647
|
+
this.refundListReason.emit({ reason: this.selectedRefundReason, code: this.refundReason });
|
|
648
|
+
}
|
|
649
|
+
else {
|
|
650
|
+
this.viewCompStatus = '';
|
|
651
|
+
this.viewStatus = 'contactDetailsPage';
|
|
652
|
+
}
|
|
653
|
+
}
|
|
654
|
+
}
|
|
655
|
+
gotoIssueRefundPage() {
|
|
656
|
+
this.errorMessage = '';
|
|
657
|
+
this.viewCompStatus = 'issuerefund';
|
|
658
|
+
this.viewStatus = '';
|
|
659
|
+
this.isRefundRemission = true;
|
|
660
|
+
this.errorMessage = false;
|
|
661
|
+
this.errorMsg = [];
|
|
662
|
+
this.refundHasError = false;
|
|
663
|
+
this.isReasonEmpty = false;
|
|
664
|
+
}
|
|
665
|
+
gotoIssuePage(isFullyRefund) {
|
|
666
|
+
if (isFullyRefund) {
|
|
667
|
+
this.viewCompStatus = 'issuerefundpage1';
|
|
668
|
+
this.getRefundReasons();
|
|
669
|
+
}
|
|
670
|
+
else {
|
|
671
|
+
[].forEach.call(document.querySelectorAll('input'), function (el) {
|
|
672
|
+
el.classList.remove('inline-error-class');
|
|
673
|
+
});
|
|
674
|
+
var checkboxs = document.getElementsByTagName('input');
|
|
675
|
+
this.errorMessage = '';
|
|
676
|
+
this.totalRefundAmount = 0;
|
|
677
|
+
this.errorMsg = [];
|
|
678
|
+
for (var j = 0; j < checkboxs.length; j++) {
|
|
679
|
+
if (checkboxs[j].checked) {
|
|
680
|
+
this.fullRefund = false;
|
|
681
|
+
let quantity = +document.getElementById('feeVolume_' + checkboxs[j].value).value;
|
|
682
|
+
let amountToRefund = +document.getElementById('feeAmount_' + checkboxs[j].value).value;
|
|
683
|
+
let apportionAmount = +document.getElementById('feeApportionAmount_' + checkboxs[j].value).value;
|
|
684
|
+
let calculatedAmount = +document.getElementById('calculatedAmount_' + checkboxs[j].value).value;
|
|
685
|
+
if (amountToRefund === apportionAmount) {
|
|
686
|
+
this.fullRefund = true;
|
|
687
|
+
}
|
|
688
|
+
if (amountToRefund === 0) {
|
|
689
|
+
this.elementId = 'feeAmount_' + checkboxs[j].value;
|
|
690
|
+
this.errorMsg.push('You need to enter a refund amount');
|
|
691
|
+
this.getErrorClass(this.elementId);
|
|
692
|
+
}
|
|
693
|
+
if (quantity === 1) {
|
|
694
|
+
if (amountToRefund > 0 && amountToRefund > apportionAmount) {
|
|
695
|
+
this.elementId = 'feeAmount_' + checkboxs[j].value;
|
|
696
|
+
this.errorMsg.push('The amount you want to refund is more than the amount paid');
|
|
697
|
+
this.getErrorClass(this.elementId);
|
|
698
|
+
}
|
|
699
|
+
}
|
|
700
|
+
if (quantity > 1) {
|
|
701
|
+
this.quantityUpdated = +document.getElementById('feeVolumeUpdated_' + checkboxs[j].value).value;
|
|
702
|
+
if (this.quantityUpdated === 0) {
|
|
703
|
+
this.elementId = 'feeVolumeUpdated_' + checkboxs[j].value;
|
|
704
|
+
this.errorMsg.push('You need to enter quantity');
|
|
705
|
+
this.getErrorClass(this.elementId);
|
|
706
|
+
}
|
|
707
|
+
if (this.fullRefund && quantity !== this.quantityUpdated) {
|
|
708
|
+
this.elementId = 'feeVolumeUpdated_' + checkboxs[j].value;
|
|
709
|
+
this.errorMsg.push('The quantity you want to refund should be maximun available quantity');
|
|
710
|
+
this.getErrorClass(this.elementId);
|
|
711
|
+
}
|
|
712
|
+
if (!this.fullRefund && this.quantityUpdated > 0 && amountToRefund > 0) {
|
|
713
|
+
this.refundAmtForFeeVolumes = +document.getElementById('feeVOl_' + checkboxs[j].value).innerText;
|
|
714
|
+
this.allowedRefundAmount = this.quantityUpdated * this.refundAmtForFeeVolumes;
|
|
715
|
+
if (this.allowedRefundAmount !== amountToRefund) {
|
|
716
|
+
this.elementId = 'feeAmount_' + checkboxs[j].value;
|
|
717
|
+
this.errorMsg.push('The Amount to Refund should be equal to the product of Fee Amount and quantity');
|
|
718
|
+
this.getErrorClass(this.elementId);
|
|
719
|
+
}
|
|
720
|
+
}
|
|
721
|
+
if (!this.fullRefund && amountToRefund > apportionAmount) {
|
|
722
|
+
this.elementId = 'feeAmount_' + checkboxs[j].value;
|
|
723
|
+
this.errorMsg.push('The amount you want to refund is more than the amount paid');
|
|
724
|
+
this.getErrorClass(this.elementId);
|
|
725
|
+
}
|
|
726
|
+
if (!this.fullRefund && this.quantityUpdated > 0 && this.quantityUpdated > quantity) {
|
|
727
|
+
this.elementId = 'feeVolumeUpdated_' + checkboxs[j].value;
|
|
728
|
+
this.errorMsg.push('The quantity you want to refund is more than the available quantity');
|
|
729
|
+
this.getErrorClass(this.elementId);
|
|
730
|
+
}
|
|
731
|
+
}
|
|
732
|
+
//this.remissionForm.value.feesList.find(id=>id=checkboxs[j].value)['refund_amount'] = apportionAmount;
|
|
733
|
+
}
|
|
734
|
+
}
|
|
735
|
+
if (this.errorMsg.length === 0) {
|
|
736
|
+
if (this.isFromCheckAnsPage) {
|
|
737
|
+
this.isFromCheckAnsPage = false;
|
|
738
|
+
this.totalRefundAmount = this.remissionForm.value.feesList.reduce((a, c) => a + c.refund_amount * c.selected, 0);
|
|
739
|
+
this.fees = this.remissionForm.value.feesList.filter(value => value.selected === true);
|
|
740
|
+
this.viewStatus = 'checkissuerefundpage';
|
|
741
|
+
this.viewCompStatus = '';
|
|
742
|
+
this.notificationPreview = false;
|
|
743
|
+
return;
|
|
744
|
+
}
|
|
745
|
+
else if (this.isFromRefundStatusPage) {
|
|
746
|
+
var remissionctrls = this.remissionForm.controls;
|
|
747
|
+
this.totalRefundAmount = this.remissionForm.value.feesList.reduce((a, c) => a + c.refund_amount * c.selected, 0);
|
|
748
|
+
this.refundListAmount.emit(this.totalRefundAmount.toString());
|
|
749
|
+
this.fees = this.remissionForm.value.feesList.filter(value => value.selected === true);
|
|
750
|
+
this.refundFees.emit(this.fees);
|
|
751
|
+
return;
|
|
752
|
+
}
|
|
753
|
+
this.viewCompStatus = 'issuerefundpage1';
|
|
754
|
+
this.getRefundReasons();
|
|
755
|
+
}
|
|
756
|
+
}
|
|
757
|
+
}
|
|
758
|
+
calAmtToRefund(value, amount, volume, i) {
|
|
759
|
+
const volumeFee = amount / volume;
|
|
760
|
+
const amtToRefund = value * volumeFee;
|
|
761
|
+
const formArray = this.remissionForm.controls.feesList;
|
|
762
|
+
formArray.at(i).get('refund_amount').setValue(amtToRefund);
|
|
763
|
+
// formArray.at(i).get('volume').setValue(value);
|
|
764
|
+
// (<HTMLInputElement>document.getElementById('feeAmount_'+i)).value = +amtToRefund;
|
|
765
|
+
// const formControl = this.remissionForm.controls.feesList['volume'].at(i);
|
|
766
|
+
// formControl.setValue(value);
|
|
767
|
+
}
|
|
768
|
+
gotoContactDetailsPage(note) {
|
|
769
|
+
if (note) {
|
|
770
|
+
this.notification = { contact_details: note, notification_type: note.notification_type };
|
|
771
|
+
}
|
|
772
|
+
this.errorMessage = '';
|
|
773
|
+
this.viewCompStatus = '';
|
|
774
|
+
this.viewStatus = 'contactDetailsPage';
|
|
775
|
+
this.isRefundRemission = true;
|
|
776
|
+
this.errorMessage = false;
|
|
777
|
+
}
|
|
778
|
+
getRefundReasons() {
|
|
779
|
+
if (this.viewCompStatus === 'issuerefundpage1') {
|
|
780
|
+
this.refundService.getRefundReasons().subscribe(refundReasons => {
|
|
781
|
+
this.refundReasons = refundReasons.filter((data) => data.recently_used === false);
|
|
782
|
+
this.refundReasons = this.refundReasons.filter((data) => data.name !== 'Retrospective remission');
|
|
783
|
+
this.cd.detectChanges();
|
|
784
|
+
this.commonRefundReasons = refundReasons.filter((data) => data.recently_used === true);
|
|
785
|
+
this.commonRefundReasons.sort((a, b) => a.toString().localeCompare(b));
|
|
786
|
+
this.cd.detectChanges();
|
|
787
|
+
});
|
|
788
|
+
}
|
|
789
|
+
}
|
|
790
|
+
getErrorClass(elementId) {
|
|
791
|
+
if (this.errorMsg.length > 0) {
|
|
792
|
+
const ele = document.getElementById(elementId);
|
|
793
|
+
ele.classList.add('inline-error-class');
|
|
794
|
+
}
|
|
795
|
+
}
|
|
796
|
+
changeIssueRefundReason() {
|
|
797
|
+
this.isFromCheckAnsPage = true;
|
|
798
|
+
this.errorMessage = '';
|
|
799
|
+
this.errorMsg = [];
|
|
800
|
+
this.refundHasError = false;
|
|
801
|
+
this.isReasonEmpty = false;
|
|
802
|
+
this.viewCompStatus = 'issuerefundpage1';
|
|
803
|
+
this.viewStatus = '';
|
|
804
|
+
this.isRefundRemission = true;
|
|
805
|
+
}
|
|
806
|
+
confirmIssueRefund(isFullyRefund) {
|
|
807
|
+
this.isConfirmationBtnDisabled = true;
|
|
808
|
+
this.errorMessage = '';
|
|
809
|
+
this.errorMsg = [];
|
|
810
|
+
if (this.isRefundRemission) {
|
|
811
|
+
this.retroRemission = true;
|
|
812
|
+
}
|
|
813
|
+
if (isFullyRefund) {
|
|
814
|
+
this.totalRefundAmount = this.payment.amount;
|
|
815
|
+
}
|
|
816
|
+
if (!isFullyRefund) {
|
|
817
|
+
this.fees = this.remissionForm.value.feesList.filter(value => value.selected === true);
|
|
818
|
+
}
|
|
819
|
+
this.fees = this.fees.map(obj => ({
|
|
820
|
+
id: obj.id,
|
|
821
|
+
code: obj.code,
|
|
822
|
+
version: obj.version,
|
|
823
|
+
apportion_amount: obj.apportion_amount,
|
|
824
|
+
calculated_amount: obj.calculated_amount,
|
|
825
|
+
updated_volume: obj.updated_volume ? obj.updated_volume : obj.volume,
|
|
826
|
+
refund_amount: obj.refund_amount ? obj.refund_amount : this.totalRefundAmount
|
|
827
|
+
}));
|
|
828
|
+
const requestBody = new PostRefundRetroRemission(this.contactDetailsObj, this.fees, this.payment.reference, this.refundReason, this.totalRefundAmount, 'op');
|
|
829
|
+
this.paymentViewService.postRefundsReason(requestBody).subscribe(response => {
|
|
830
|
+
if (JSON.parse(response)) {
|
|
831
|
+
this.viewCompStatus = '';
|
|
832
|
+
this.viewStatus = 'refundconfirmationpage';
|
|
833
|
+
this.refundReference = JSON.parse(response).refund_reference;
|
|
834
|
+
if (JSON.parse(response).refund_amount) {
|
|
835
|
+
this.refundAmount = JSON.parse(response).refund_amount;
|
|
836
|
+
}
|
|
837
|
+
}
|
|
838
|
+
}, (error) => {
|
|
839
|
+
this.errorMessage = error;
|
|
840
|
+
this.isConfirmationBtnDisabled = false;
|
|
841
|
+
this.cd.detectChanges();
|
|
842
|
+
});
|
|
843
|
+
}
|
|
844
|
+
gotoRefundReasonPage() {
|
|
845
|
+
this.viewStatus = '';
|
|
846
|
+
this.viewCompStatus = 'issuerefundpage1';
|
|
847
|
+
}
|
|
848
|
+
// Retro Refund
|
|
849
|
+
// confirmRetroRefund() {
|
|
850
|
+
// this.isConfirmationBtnDisabled = true;
|
|
851
|
+
// this.errorMessage = '';
|
|
852
|
+
// this.errorMsg = [];
|
|
853
|
+
// if( this.isRefundRemission) {
|
|
854
|
+
// this.retroRemission = true;
|
|
855
|
+
// }
|
|
856
|
+
// const requestBody = new PostRefundRetroRemission(this.payment.reference,'RR004-Retrospective remission', this.contactDetailsObj);
|
|
857
|
+
// this.paymentViewService.postRefundsReason(requestBody).subscribe(
|
|
858
|
+
// response => {
|
|
859
|
+
// if (JSON.parse(response)) {
|
|
860
|
+
// this.viewCompStatus = '';
|
|
861
|
+
// this.viewStatus = 'retrorefundconfirmationpage';
|
|
862
|
+
// this.refundReference =JSON.parse(response).refund_reference;
|
|
863
|
+
// if(JSON.parse(response).refund_amount) {
|
|
864
|
+
// this.refundAmount = JSON.parse(response).refund_amount;
|
|
865
|
+
// }
|
|
866
|
+
// }
|
|
867
|
+
// },
|
|
868
|
+
// (error: any) => {
|
|
869
|
+
// this.errorMessage = error;
|
|
870
|
+
// this.isConfirmationBtnDisabled = false;
|
|
871
|
+
// });
|
|
872
|
+
// }
|
|
873
|
+
selectRadioButton(key, value) {
|
|
874
|
+
localStorage.setItem("myradio", value);
|
|
875
|
+
const remissionctrls = this.remissionForm.controls;
|
|
876
|
+
remissionctrls['refundDDReason'].setValue('Select a different reason', { onlySelf: true });
|
|
877
|
+
remissionctrls['reason'].reset();
|
|
878
|
+
this.isRefundReasonsSelected = true;
|
|
879
|
+
this.errorMessage = false;
|
|
880
|
+
this.errorMsg = [];
|
|
881
|
+
this.isReasonEmpty = false;
|
|
882
|
+
this.showReasonText = false;
|
|
883
|
+
this.refundHasError = false;
|
|
884
|
+
this.selectedRefundReason = value;
|
|
885
|
+
this.selectedRefundReasonCode = key;
|
|
886
|
+
if (this.selectedRefundReason.includes('Other')) {
|
|
887
|
+
this.showReasonText = true;
|
|
888
|
+
this.refundHasError = false;
|
|
889
|
+
this.refundReason = value;
|
|
890
|
+
}
|
|
891
|
+
}
|
|
892
|
+
selectchange(args) {
|
|
893
|
+
const remissionctrls = this.remissionForm.controls;
|
|
894
|
+
remissionctrls['refundReason'].reset();
|
|
895
|
+
remissionctrls['reason'].reset();
|
|
896
|
+
this.isRefundReasonsSelected = false;
|
|
897
|
+
this.showReasonText = false;
|
|
898
|
+
this.refundHasError = false;
|
|
899
|
+
this.selectedRefundReason = args.target.options[args.target.options.selectedIndex].id;
|
|
900
|
+
this.selectedRefundReasonCode = args.target.options[args.target.options.selectedIndex].value;
|
|
901
|
+
this.reasonLength = (29 - this.selectedRefundReason.split('- ')[1].length);
|
|
902
|
+
if (this.selectedRefundReason.includes('Other')) {
|
|
903
|
+
this.showReasonText = true;
|
|
904
|
+
this.refundHasError = false;
|
|
905
|
+
this.refundReason = args.target.options[args.target.options.selectedIndex].id;
|
|
906
|
+
}
|
|
907
|
+
}
|
|
908
|
+
getContactDetails(obj, type) {
|
|
909
|
+
this.contactDetailsObj = obj;
|
|
910
|
+
this.viewCompStatus = '';
|
|
911
|
+
this.notificationPreview = false;
|
|
912
|
+
if (type == 'checkaddRefundpage') {
|
|
913
|
+
this.getTemplateInstructionType(this.remessionPayment.reference, this.remessionPayment);
|
|
914
|
+
}
|
|
915
|
+
else if (type == 'checkissuerefundpage') {
|
|
916
|
+
this.getTemplateInstructionType(this.payment.reference, this.payment);
|
|
917
|
+
}
|
|
918
|
+
else if (type == 'addrefundcheckandanswer') {
|
|
919
|
+
this.getTemplateInstructionType(this.paymentReference, this.paymentObj);
|
|
920
|
+
}
|
|
921
|
+
this.paymentLibComponent.addPaymentGroup(this.paymentGroup);
|
|
922
|
+
this.viewStatus = type;
|
|
923
|
+
}
|
|
924
|
+
gotoPartialFeeRefundScreen() {
|
|
925
|
+
if (this.isFromRefundStatusPage) {
|
|
926
|
+
var remissionctrls = this.remissionForm.controls;
|
|
927
|
+
this.refundListReason.emit({ reason: this.displayRefundReason, code: this.refundReason });
|
|
928
|
+
return;
|
|
929
|
+
}
|
|
930
|
+
this.refundHasError = false;
|
|
931
|
+
this.viewCompStatus = 'issuerefund';
|
|
932
|
+
this.viewStatus = '';
|
|
933
|
+
}
|
|
934
|
+
gotoServiceRequestPage(event) {
|
|
935
|
+
this.errorMessage = '';
|
|
936
|
+
this.errorMsg = [];
|
|
937
|
+
this.isFromCheckAnsPage = false;
|
|
938
|
+
event.preventDefault();
|
|
939
|
+
if (this.isFromRefundStatusPage) {
|
|
940
|
+
var remissionctrls = this.remissionForm.controls;
|
|
941
|
+
this.totalRefundAmount = 0;
|
|
942
|
+
this.refundListAmount.emit(this.totalRefundAmount.toString());
|
|
943
|
+
return;
|
|
944
|
+
}
|
|
945
|
+
if (this.isFromServiceRequestPage && !this.isFromPaymentDetailPage) {
|
|
946
|
+
this.viewStatus = 'order-full-view';
|
|
947
|
+
this.viewCompStatus = '';
|
|
948
|
+
}
|
|
949
|
+
else if (this.isFromRefundListPage) {
|
|
950
|
+
this.paymentLibComponent.iscancelClicked = true;
|
|
951
|
+
this.refundListReason.emit({ reason: this.selectedRefundReason, code: this.refundReason });
|
|
952
|
+
this.paymentLibComponent.isFromRefundStatusPage = true;
|
|
953
|
+
}
|
|
954
|
+
else {
|
|
955
|
+
this.paymentLibComponent.paymentMethod = this.payment.method;
|
|
956
|
+
this.paymentLibComponent.paymentGroupReference = this.paymentLibComponent.paymentGroupReference;
|
|
957
|
+
this.paymentLibComponent.paymentReference = this.payment.reference;
|
|
958
|
+
this.paymentLibComponent.viewName = 'payment-view';
|
|
959
|
+
this.OrderslistService.setOrderRef(this.orderRef);
|
|
960
|
+
this.OrderslistService.setorderCCDEvent(this.orderCCDEvent);
|
|
961
|
+
this.OrderslistService.setorderCreated(this.orderCreated);
|
|
962
|
+
this.OrderslistService.setorderDetail(this.orderDetail);
|
|
963
|
+
this.OrderslistService.setorderParty(this.orderParty);
|
|
964
|
+
this.OrderslistService.setorderTotalPayments(this.orderTotalPayments);
|
|
965
|
+
this.OrderslistService.setorderRemissionTotal(this.orderRemissionTotal);
|
|
966
|
+
this.OrderslistService.setorderFeesTotal(this.orderFeesTotal);
|
|
967
|
+
this.viewStatus = 'payment-view';
|
|
968
|
+
this.sendOrderDetail = this.orderDetail;
|
|
969
|
+
this.sendOrderRef = this.orderRef;
|
|
970
|
+
if (this.LOGGEDINUSERROLES === undefined) {
|
|
971
|
+
this.OrderslistService.getUserRolesList().subscribe((data) => this.LOGGEDINUSERROLES = data);
|
|
972
|
+
}
|
|
973
|
+
this.viewCompStatus = '';
|
|
974
|
+
}
|
|
975
|
+
}
|
|
976
|
+
gotoAddressPage(note) {
|
|
977
|
+
if (note) {
|
|
978
|
+
this.notification = { contact_details: note, notification_type: note.notification_type };
|
|
979
|
+
}
|
|
980
|
+
this.errorMessage = '';
|
|
981
|
+
this.viewCompStatus = 'addrefundforremission';
|
|
982
|
+
this.viewStatus = '';
|
|
983
|
+
this.isRefundRemission = true;
|
|
984
|
+
this.errorMessage = false;
|
|
985
|
+
}
|
|
986
|
+
gotoRemissionSuccess(event) {
|
|
987
|
+
event.preventDefault();
|
|
988
|
+
this.errorMessage = '';
|
|
989
|
+
this.viewCompStatus = '';
|
|
990
|
+
this.viewStatus = 'retroremissionconfirmationpage';
|
|
991
|
+
this.isRefundRemission = true;
|
|
992
|
+
this.errorMessage = false;
|
|
993
|
+
}
|
|
994
|
+
gotoCasetransationPage() {
|
|
995
|
+
this.OrderslistService.setnavigationPage('casetransactions');
|
|
996
|
+
this.errorMessage = '';
|
|
997
|
+
this.errorMsg = [];
|
|
998
|
+
this.paymentLibComponent.viewName = 'case-transactions';
|
|
999
|
+
this.paymentLibComponent.VIEW = 'case-transactions';
|
|
1000
|
+
this.paymentLibComponent.ISTURNOFF = this.isTurnOff;
|
|
1001
|
+
this.paymentLibComponent.isFromServiceRequestPage = true;
|
|
1002
|
+
this.resetOrderData();
|
|
1003
|
+
let partUrl = this.bsPaymentDcnNumber ? `&dcn=${this.bsPaymentDcnNumber}` : '';
|
|
1004
|
+
partUrl += this.paymentLibComponent.ISBSENABLE ? '&isBulkScanning=Enable' : '&isBulkScanning=Disable';
|
|
1005
|
+
partUrl += this.paymentLibComponent.ISTURNOFF ? '&isTurnOff=Enable' : '&isTurnOff=Disable';
|
|
1006
|
+
partUrl += this.isStrategicFixEnable ? '&isStFixEnable=Enable' : '&isStFixEnable=Disable';
|
|
1007
|
+
partUrl += `&caseType=${this.caseType}`;
|
|
1008
|
+
const url = `/payment-history/${this.ccdCaseNumber}?view=case-transactions&takePayment=${this.paymentLibComponent.TAKEPAYMENT}&selectedOption=${this.option}${partUrl}`;
|
|
1009
|
+
this.router.routeReuseStrategy.shouldReuseRoute = () => false;
|
|
1010
|
+
this.router.onSameUrlNavigation = 'reload';
|
|
1011
|
+
this.router.navigateByUrl(url);
|
|
1012
|
+
}
|
|
1013
|
+
gotoCasetransationPageCancelBtnClicked(event) {
|
|
1014
|
+
event.preventDefault();
|
|
1015
|
+
this.errorMsg = [];
|
|
1016
|
+
if (this.paymentLibComponent.isFromServiceRequestPage !== undefined && !this.paymentLibComponent.isFromServiceRequestPage) {
|
|
1017
|
+
this.OrderslistService.setnavigationPage('casetransactions');
|
|
1018
|
+
this.OrderslistService.setisFromServiceRequestPage(false);
|
|
1019
|
+
this.paymentLibComponent.VIEW = 'case-transactions';
|
|
1020
|
+
this.paymentLibComponent.viewName = 'case-transactions';
|
|
1021
|
+
this.paymentLibComponent.ISBSENABLE = true;
|
|
1022
|
+
this.paymentLibComponent.isRefundStatusView = false;
|
|
1023
|
+
}
|
|
1024
|
+
else {
|
|
1025
|
+
if (this.paymentLibComponent.REFUNDLIST) {
|
|
1026
|
+
this.paymentLibComponent.viewName = 'refund-list';
|
|
1027
|
+
return;
|
|
1028
|
+
}
|
|
1029
|
+
if (this.paymentLibComponent.TAKEPAYMENT === undefined && this.paymentLibComponent.SERVICEREQUEST === undefined) {
|
|
1030
|
+
this.paymentLibComponent.SERVICEREQUEST = 'false';
|
|
1031
|
+
}
|
|
1032
|
+
this.OrderslistService.setisFromServiceRequestPage(false);
|
|
1033
|
+
this.OrderslistService.setpaymentPageView({ method: '', payment_group_reference: '', reference: '' });
|
|
1034
|
+
this.OrderslistService.setnavigationPage('casetransactions');
|
|
1035
|
+
this.errorMessage = '';
|
|
1036
|
+
this.paymentLibComponent.viewName = 'case-transactions';
|
|
1037
|
+
this.paymentLibComponent.ISTURNOFF = this.isTurnOff;
|
|
1038
|
+
this.paymentLibComponent.isFromServiceRequestPage = true;
|
|
1039
|
+
this.paymentLibComponent.ISBSENABLE = true;
|
|
1040
|
+
let partUrl = this.bsPaymentDcnNumber ? `&dcn=${this.bsPaymentDcnNumber}` : '';
|
|
1041
|
+
partUrl += this.paymentLibComponent.ISBSENABLE ? '&isBulkScanning=Enable' : '&isBulkScanning=Disable';
|
|
1042
|
+
partUrl += this.paymentLibComponent.ISTURNOFF ? '&isTurnOff=Enable' : '&isTurnOff=Disable';
|
|
1043
|
+
partUrl += this.isStrategicFixEnable ? '&isStFixEnable=Enable' : '&isStFixEnable=Disable';
|
|
1044
|
+
partUrl += `&caseType=${this.caseType}`;
|
|
1045
|
+
if (this.isFromPaymentDetailPage) {
|
|
1046
|
+
partUrl += this.paymentLibComponent.isFromPaymentDetailPage;
|
|
1047
|
+
}
|
|
1048
|
+
if (!this.paymentLibComponent.SERVICEREQUEST) {
|
|
1049
|
+
const url = `/payment-history/${this.ccdCaseNumber}?view=case-transactions&takePayment=${this.paymentLibComponent.TAKEPAYMENT}&selectedOption=${this.option}${partUrl}`;
|
|
1050
|
+
this.router.routeReuseStrategy.shouldReuseRoute = () => false;
|
|
1051
|
+
this.router.onSameUrlNavigation = 'reload';
|
|
1052
|
+
this.router.navigateByUrl(url);
|
|
1053
|
+
}
|
|
1054
|
+
else {
|
|
1055
|
+
const url = `/payment-history/${this.ccdCaseNumber}?selectedOption=${this.option}${partUrl}`;
|
|
1056
|
+
this.router.routeReuseStrategy.shouldReuseRoute = () => false;
|
|
1057
|
+
this.router.onSameUrlNavigation = 'reload';
|
|
1058
|
+
this.router.navigateByUrl(url);
|
|
1059
|
+
}
|
|
1060
|
+
}
|
|
1061
|
+
}
|
|
1062
|
+
canRefundBeApplied() {
|
|
1063
|
+
if (this.remissionamt == null || this.fee.fee_amount == null || this.payment.amount == null) {
|
|
1064
|
+
return true;
|
|
1065
|
+
}
|
|
1066
|
+
if (this.fee.fee_amount - this.payment.amount == this.remissionamt) {
|
|
1067
|
+
return false;
|
|
1068
|
+
}
|
|
1069
|
+
return true;
|
|
1070
|
+
}
|
|
1071
|
+
resetOrderData() {
|
|
1072
|
+
this.OrderslistService.setOrderRef(null);
|
|
1073
|
+
this.OrderslistService.setorderCCDEvent(null);
|
|
1074
|
+
this.OrderslistService.setorderCreated(null);
|
|
1075
|
+
this.OrderslistService.setorderDetail(null);
|
|
1076
|
+
this.OrderslistService.setorderParty(null);
|
|
1077
|
+
this.OrderslistService.setorderTotalPayments(null);
|
|
1078
|
+
this.OrderslistService.setorderRemissionTotal(null);
|
|
1079
|
+
this.OrderslistService.setorderFeesTotal(null);
|
|
1080
|
+
}
|
|
1081
|
+
changeRefundAmount() {
|
|
1082
|
+
this.isFromCheckAnsPage = true;
|
|
1083
|
+
this.viewCompStatus = 'issuerefund';
|
|
1084
|
+
this.viewStatus = '';
|
|
1085
|
+
}
|
|
1086
|
+
getFormattedCurrency(currency) {
|
|
1087
|
+
if (currency.toString().includes(".")) {
|
|
1088
|
+
return currency;
|
|
1089
|
+
}
|
|
1090
|
+
return currency.toString().concat(".00");
|
|
1091
|
+
}
|
|
1092
|
+
showNotificationPreview() {
|
|
1093
|
+
this.notificationPreview = true;
|
|
1094
|
+
}
|
|
1095
|
+
hideNotificationPreview() {
|
|
1096
|
+
this.notificationPreview = false;
|
|
1097
|
+
}
|
|
1098
|
+
getTemplateInstructionType(paymentReference, payment) {
|
|
1099
|
+
if (payment == undefined || payment == null || payment.reference != paymentReference) {
|
|
1100
|
+
this.paymentViewService.getPaymentDetails(paymentReference).subscribe(payment => {
|
|
1101
|
+
this.paymentObj = payment;
|
|
1102
|
+
this.paymentObj.reference = paymentReference;
|
|
1103
|
+
this.templateInstructionType = this.notificationService.getNotificationInstructionType(this.paymentObj.channel, this.paymentObj.method);
|
|
1104
|
+
}, (error) => {
|
|
1105
|
+
this.templateInstructionType = 'Template';
|
|
1106
|
+
});
|
|
1107
|
+
}
|
|
1108
|
+
else {
|
|
1109
|
+
this.templateInstructionType = this.notificationService.getNotificationInstructionType(payment.channel, payment.method);
|
|
1110
|
+
}
|
|
1111
|
+
}
|
|
1112
|
+
getRefundAmountToBeDisplayed(remission) {
|
|
1113
|
+
if (remission !== null && remission !== undefined) {
|
|
1114
|
+
if (remission.overall_balance > 0 && remission.acollection_of_fess == false) {
|
|
1115
|
+
return remission.overall_balance.toString();
|
|
1116
|
+
}
|
|
1117
|
+
else {
|
|
1118
|
+
return this.paymentLibComponent.overPaymentAmount.toString();
|
|
1119
|
+
}
|
|
1120
|
+
}
|
|
1121
|
+
return "undefined";
|
|
1122
|
+
}
|
|
1123
|
+
getRefundAmountToBeDisplayedForContinueJourney() {
|
|
1124
|
+
return Math.abs(((this.paymentLibComponent.getTotalFees() - this.paymentLibComponent.getTotalRemission())
|
|
1125
|
+
- this.paymentLibComponent.getTotalPayments())).toString();
|
|
1126
|
+
}
|
|
1127
|
+
getRemissionAmountToBeDisplayed(remission) {
|
|
1128
|
+
if (remission !== null && remission !== undefined) {
|
|
1129
|
+
return remission.hwf_amount.toString();
|
|
1130
|
+
}
|
|
1131
|
+
return "undefined";
|
|
1132
|
+
}
|
|
1133
|
+
isRemissionEnabled(feeCode) {
|
|
1134
|
+
if (this.paymentLibComponent.paymentGroup.remissions != null &&
|
|
1135
|
+
this.paymentLibComponent.paymentGroup.remissions.length > 0 && this.isRemissionEnabledForFeeCode(feeCode)) {
|
|
1136
|
+
return true;
|
|
1137
|
+
}
|
|
1138
|
+
return false;
|
|
1139
|
+
}
|
|
1140
|
+
isRemissionEnabledForFeeCode(feeCode) {
|
|
1141
|
+
let result = this.getRemissions(feeCode);
|
|
1142
|
+
if (result === null) {
|
|
1143
|
+
return false;
|
|
1144
|
+
}
|
|
1145
|
+
return true;
|
|
1146
|
+
}
|
|
1147
|
+
getRemissions(feeCode) {
|
|
1148
|
+
let myRemission = this.paymentLibComponent.paymentGroup.remissions.filter(remission => remission.fee_code === feeCode);
|
|
1149
|
+
if (myRemission.length == 0) {
|
|
1150
|
+
return null;
|
|
1151
|
+
}
|
|
1152
|
+
// We can have one remission per case, only
|
|
1153
|
+
return myRemission.at(0);
|
|
1154
|
+
}
|
|
1155
|
+
getRemissionsHwfAmount(feeCode) {
|
|
1156
|
+
let myRemission = this.getRemissions(feeCode);
|
|
1157
|
+
if (myRemission === null) {
|
|
1158
|
+
return this.getRemissionValueForFullyRefund().toString();
|
|
1159
|
+
}
|
|
1160
|
+
else {
|
|
1161
|
+
return myRemission.hwf_amount.toString();
|
|
1162
|
+
}
|
|
1163
|
+
}
|
|
1164
|
+
getNetAmountFee(hwfAmount, feeAmount) {
|
|
1165
|
+
return feeAmount - hwfAmount;
|
|
1166
|
+
}
|
|
1167
|
+
getRemissionValueForFullyRefund() {
|
|
1168
|
+
return 0;
|
|
1169
|
+
}
|
|
1170
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AddRemissionComponent, deps: [{ token: i1.FormBuilder }, { token: i2.Router }, { token: i3.PaymentViewService }, { token: i4.NotificationService }, { token: 'PAYMENT_LIB' }, { token: i5.RefundsService }, { token: i0.ChangeDetectorRef }, { token: i6.OrderslistService }], target: i0.ɵɵFactoryTarget.Component });
|
|
1171
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: AddRemissionComponent, isStandalone: true, selector: "ccpay-add-remission", inputs: { fee: "fee", fees: "fees", payment: "payment", remission: "remission", ccdCaseNumber: "ccdCaseNumber", caseType: "caseType", viewCompStatus: "viewCompStatus", paymentGroupRef: "paymentGroupRef", isTurnOff: "isTurnOff", isRefundRemission: "isRefundRemission", isStrategicFixEnable: "isStrategicFixEnable", paidAmount: "paidAmount", isFromRefundListPage: "isFromRefundListPage", isFromPaymentDetailPage: "isFromPaymentDetailPage", isFromServiceRequestPage: "isFromServiceRequestPage", isFullyRefund: "isFullyRefund", feeamount: "feeamount", refundPaymentReference: "refundPaymentReference", isFromRefundStatusPage: "isFromRefundStatusPage", changeRefundReason: "changeRefundReason", isServiceRequest: "isServiceRequest", LOGGEDINUSERROLES: "LOGGEDINUSERROLES", orderDetail: "orderDetail", orderRef: "orderRef", orderStatus: "orderStatus", orderParty: "orderParty", orderCreated: "orderCreated", orderCCDEvent: "orderCCDEvent", takePayment: ["takepayment", "takePayment"], orderFeesTotal: "orderFeesTotal", orderTotalPayments: "orderTotalPayments", orderRemissionTotal: "orderRemissionTotal" }, outputs: { cancelRemission: "cancelRemission", refundListReason: "refundListReason", refundListAmount: "refundListAmount", refundFees: "refundFees" }, providers: [{ provide: 'ADD_REMISSION', useExisting: AddRemissionComponent }], ngImport: i0, template: "<div class=\"add-remission pagesize\">\n <div *ngIf=\"errorMessage\">\n <div class=\"error-summary\" role=\"group\" aria-labelledby=\"failure-error-summary-heading\" tabindex=\"-1\">\n <h2 class=\"heading-medium error-summary-heading\" id=\"failure-error-summary-heading\">\n {{ \"Error in processing the request\" | rpxTranslate }}\n </h2>\n <div class=\"govuk-error-summary__body\">\n {{ errorMessage | rpxTranslate }}\n </div>\n </div>\n </div>\n <div *ngIf=\"errorMsg.length > 0\">\n <div class=\"error-summary\" role=\"group\" aria-labelledby=\"failure-error-summary-heading\" tabindex=\"-1\">\n <h2 class=\"heading-medium error-summary-heading\" id=\"failure-error-summary-heading\">\n {{ \"Error in processing the request\" | rpxTranslate }}\n </h2>\n <div *ngFor=\"let err of errorMsg; let i = index\" class=\"govuk-error-summary__body\">\n\n <li>{{ err | rpxTranslate }}</li>\n </div>\n </div>\n </div>\n\n<ng-container *ngIf=\"viewStatus === 'main' && !isRefundRemission \">\n <input #myInput type='hidden' id='iFrameDrivenImageValue' value='ADDREMISSION'>\n <h1 class=\"heading-large\">{{ \"Add remission\" | rpxTranslate }} </h1>\n <form novalidate>\n <div class=\"govuk-form-group\">\n <form [formGroup]=\"remissionForm\" novalidate>\n <div class=\"govuk-form-group\">\n <label class=\"govuk-label govuk-label--s\" for=\"remission-code\">\n {{ \"Add remission to\" | rpxTranslate }} {{ fee?.code }}: {{ fee?.description | rpxTranslate }}\n <span class=\"form-hint\">{{ \"Enter remission for reference\" | rpxTranslate }}. {{ \"For example\" | rpxTranslate }}: HWF-A1B-23C OR PA21-123456</span>\n </label>\n <input [ngClass]=\"{'inline-error-class': isRemissionCodeEmpty || remissionCodeHasError}\" class=\"govuk-input govuk-input--width-20 govuk-!-margin-right-1\" id=\"remissionCode\" aria-label=\"remissionCode\" name=\"remissionCode\" type=\"text\" formControlName=\"remissionCode\">\n <p class=\"inline-error-message\" *ngIf=\"isRemissionCodeEmpty || remissionCodeHasError\">\n <span *ngIf=\"isRemissionCodeEmpty\">{{ \"Enter a remission code\" | rpxTranslate }}</span>\n <span *ngIf=\"remissionCodeHasError\">{{ \"Enter a vaild remission code\" | rpxTranslate }}</span>\n </p>\n </div>\n <div class=\"govuk-form-group\">\n <label class=\"govuk-label govuk-label--s\" for=\"amount\">\n {{ \"How much does the applicant need to pay\" | rpxTranslate }}?\n </label>\n\n <div id=\"amount-currency\" class=\"govuk-visually-hidden\">{{ \"in pounds\" | rpxTranslate }}</div>\n <div class=\"hmcts-currency-input\">\n <div class=\"hmcts-currency-input__symbol\" aria-hidden=\"true\">\u00A3</div>\n <input class=\"govuk-input govuk-input-width-10-left\" [ngClass]=\"{'inline-error-class': isAmountEmpty || amountHasError || isRemissionLessThanFeeError}\" id=\"amount\" aria-label=\"amount\" name=\"amount\" type=\"text\" aria-describedby=\"amount-currency\" formControlName=\"amount\">\n <p class=\"inline-error-message\" *ngIf=\"isAmountEmpty || amountHasError || isRemissionLessThanFeeError\">\n <span *ngIf=\"isAmountEmpty\">{{ \"Enter a amount\" | rpxTranslate }}</span>\n <span *ngIf=\"amountHasError\">{{ \"Enter a vaild amount\" | rpxTranslate }}</span>\n <span *ngIf=\"isRemissionLessThanFeeError\">{{ \"The remission amount must be less than the total fee\" | rpxTranslate }}</span>\n </p>\n </div>\n </div>\n </form>\n <button class=\"button\" type=\"submit\" (click)=\"addRemission()\">\n {{ \"Submit\" | rpxTranslate }}\n </button>\n </div>\n </form>\n</ng-container>\n\n<ng-container *ngIf=\"viewStatus === 'confirmation'\">\n <input #myInput type='hidden' id='iFrameDrivenImageValue' value='ADDREMISSIONCONFIRMATION'>\n <div class=\"govuk-warning-text\">\n <span class=\"govuk-warning-text__icon\" aria-hidden=\"true\">!</span>\n <strong class=\"govuk-warning-text__text\">\n <span class=\"govuk-warning-text__assistive\">{{ \"Warning\" | rpxTranslate }}</span>\n {{ \"Are you sure you want to add remission to this fee\" | rpxTranslate }}?\n </strong>\n </div>\n <table class=\"govuk-table\">\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Remission code\" | rpxTranslate }}:</td>\n <td class=\"govuk-table__cell\">{{ remissionForm.controls.remissionCode.value }}</td>\n </tr>\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Fee code\" | rpxTranslate }}:</td>\n <td class=\"govuk-table__cell\">{{ fee.code }}</td>\n </tr>\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Fee description\" | rpxTranslate }}:</td>\n <td class=\"govuk-table__cell\">{{ fee.description | rpxTranslate }}</td>\n </tr>\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Amount the applicant must pay\" | rpxTranslate }}:</td>\n <td class=\"govuk-table__cell\">{{ remissionForm.controls.amount.value | currency:'GBP':'symbol-narrow':'1.2-2' }}</td>\n </tr>\n </table>\n\n <button type=\"submit\" class=\"button govuk-button--secondary\" (click)=\"cancelRemission.emit()\">\n {{ \"Cancel\" | rpxTranslate }}\n </button>\n <button type=\"submit\"\n [disabled]=\"isConfirmationBtnDisabled\"\n [ngClass]='isConfirmationBtnDisabled ? \"button button--disabled govuk-!-margin-right-1\" : \"button govuk-!-margin-right-1\"'\n (click)=\"confirmRemission()\">\n {{ \"Confirm\" | rpxTranslate }}\n </button>\n\n</ng-container>\n\n<!-- Add retro remission changes-->\n\n<ng-container *ngIf=\"viewCompStatus === 'addremission'\">\n <input #myInput type='hidden' id='iFrameDrivenImageValue' value='PROCESSADDRETROREMISSIONPAGE'>\n <h1 class=\"heading-large\">{{ \"Process remission\" | rpxTranslate }}</h1>\n <h1 class=\"heading-medium\">#{{ccdCaseNumber | ccdHyphens}}</h1>\n <h1 class=\"heading-large\">{{ \"Enter help with fees or remission reference\" | rpxTranslate }}</h1>\n <form novalidate>\n <div class=\"govuk-form-group\">\n <form [formGroup]=\"remissionForm\" novalidate>\n <div class=\"govuk-form-group\">\n <label class=\"govuk-label govuk-label--s\" for=\"remission-code\">\n <span class=\"form-hint\">{{ \"For example\" | rpxTranslate }}: HWF-A1B-23C OR PA21-123456</span>\n </label>\n <p class=\"inline-error-message\" *ngIf=\"isRemissionCodeEmpty || remissionCodeHasError\">\n <span *ngIf=\"isRemissionCodeEmpty\">{{ \"Enter a remission code\" | rpxTranslate }}</span>\n <span *ngIf=\"remissionCodeHasError\">{{ \"Enter a vaild remission code\" | rpxTranslate }}</span>\n </p>\n <input [ngClass]=\"{'inline-error-class': isRemissionCodeEmpty || remissionCodeHasError}\" class=\"govuk-input govuk-input--width-20 govuk-!-margin-right-1\" id=\"remissionCode\" aria-label=\"remissionCode\" name=\"remissionCode\" type=\"text\" formControlName=\"remissionCode\">\n\n </div>\n\n </form>\n <div class=\"govuk-button-group\">\n <button (click)=\"gotoServiceRequestPage($event)\" class=\"govuk-button govuk-button--secondary\"> {{ \"Previous\" | rpxTranslate }}</button>\n <button (click)=\"addRemissionCode()\" class=\"govuk-button\"> {{ \"Continue\" | rpxTranslate }}</button>\n </div>\n <p><a href=\"javascript:void(0)\" (click)=\"gotoCasetransationPageCancelBtnClicked($event)\" class=\"govuk-link pointer\" data-module=\"govuk-button\">{{ \"Cancel\" | rpxTranslate }}</a></p>\n </div>\n </form>\n\n</ng-container>\n\n<ng-container *ngIf=\"viewStatus === 'processretroremissonpage'\" >\n <input #myInput type='hidden' id='iFrameDrivenImageValue' value='PROCESSRETROREMISSIONPAGE'>\n <h1 class=\"heading-large\">{{ \"Process remission\" | rpxTranslate }}</h1>\n <h1 class=\"heading-medium\">#{{ccdCaseNumber | ccdHyphens }}</h1>\n <div class=\"govuk-form-group\">\n <form novalidate>\n <div class=\"govuk-form-group\">\n <form [formGroup]=\"remissionForm\" novalidate>\n <fieldset class=\"govuk-fieldset\">\n <legend class=\"govuk-fieldset__legend govuk-fieldset__legend--m\">\n <h1 *ngIf=\"remessionPayment?.status === 'Success' || isFromRefundListPage\" class=\"heading-medium\">\n {{ \"Enter the HWF or remission amount\" | rpxTranslate }}\n </h1>\n <h1 *ngIf=\"remessionPayment?.status !== 'Success' && !isFromRefundListPage\" class=\"heading-medium\">\n {{ \"Enter the remission amount\" | rpxTranslate }}\n </h1>\n <h1 *ngIf=\"remessionPayment?.status === 'undefined'\" class=\"heading-medium\">\n {{ \"Enter the amount\" | rpxTranslate }}\n </h1>\n </legend>\n <div id=\"amount-currency\" class=\"govuk-visually-hidden\">{{ \"in pounds\" | rpxTranslate }}</div>\n <p class=\"inline-error-message\" *ngIf=\"isAmountEmpty || amountHasError || isRemissionLessThanFeeError\">\n <span *ngIf=\"isAmountEmpty\">{{ \"Enter a amount\" | rpxTranslate }}</span>\n <span *ngIf=\"amountHasError\">{{ \"Enter a vaild amount\" | rpxTranslate }}</span>\n <span *ngIf=\"isRemissionLessThanFeeError\">{{ \"You cannot add a remission that's more than the fee amount\" | rpxTranslate }}.</span>\n </p>\n <div class=\"hmcts-currency-input\">\n\n <div class=\"hmcts-currency-input__symbol\" aria-hidden=\"true\">\u00A3</div>\n <input class=\"govuk-input govuk-input-width-10-left\" [ngClass]=\"{'inline-error-class': isAmountEmpty || amountHasError || isRemissionLessThanFeeError}\" id=\"amount\" aria-label=\"amount\" name=\"amount\" type=\"number\" aria-describedby=\"amount-currency\" formControlName=\"amount\">\n\n\n </div>\n </fieldset>\n </form>\n\n <div class=\"govuk-button-group\">\n <button (click)=\"gotoAddRetroRemissionCodePage()\" class=\"govuk-button govuk-button--secondary\"> {{ \"Previous\" | rpxTranslate }}</button>\n <button (click)=\"gotoCheckRetroRemissionPage(payment)\" class=\"govuk-button\"> {{ \"Continue\" | rpxTranslate }}</button>\n\n </div>\n <p>\n <a href=\"javascript:void(0)\" (click)=\"gotoCasetransationPageCancelBtnClicked($event)\" class=\"govuk-link\" data-module=\"govuk-button\">{{ \"Cancel\" | rpxTranslate }}</a>\n </p>\n </div>\n\n </form>\n </div>\n</ng-container>\n<ng-container *ngIf=\"viewStatus === 'checkretroremissionpage'\">\n <input #myInput type='hidden' id='iFrameDrivenImageValue' value='CHECKRETROREMISSIONCONFIRMATION'>\n <div class=\"govuk-warning-text\">\n <h1 class=\"heading-large\"> {{ \"Check your answers\" | rpxTranslate }}</h1>\n </div>\n <table class=\"govuk-table\">\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Payment reference\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{remessionPayment ? remessionPayment.reference: ' '}}</td>\n </tr>\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Payment amount\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">\u00A3{{ remessionPayment ? getFormattedCurrency(remessionPayment.amount): ' ' | currency :'GBP':'symbol':'1.2-2'}} </td>\n </tr>\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Payment status\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{remessionPayment ? remessionPayment.status: ''}}</td>\n </tr>\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Fee\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{ fee.code }} - {{ fee.description | rpxTranslate }} </td>\n </tr>\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Fee amount\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{ fee.calculated_amount/fee.volume| currency:'GBP':'symbol-narrow':'1.2-2' }}</td>\n </tr>\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Help with fees or remission reference\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{ remissionForm.controls.remissionCode.value?.trim() }}\n <a (click)=\"gotoProcessRetroRemissionPage()\" class=\"govuk-link right\" >{{ \"Change\" | rpxTranslate }}</a>\n </td>\n </tr>\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Remission amount\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{remissionForm.controls.amount.value | currency:'GBP':'symbol-narrow':'1.2-2' }}\n <a (click)=\"gotoAmountRetroRemission()\" class=\"govuk-link right\" >{{ \"Change\" | rpxTranslate }}</a>\n </td>\n </tr>\n </table>\n\n <button type=\"submit\" class=\"button govuk-button--secondary\" (click)=\"gotoAmountRetroRemission()\">{{ \"Previous\" | rpxTranslate }}</button>\n <button type=\"submit\" [disabled]=\"isConfirmationBtnDisabled\" [ngClass]='isConfirmationBtnDisabled ? \"button button--disabled govuk-!-margin-right-1\" : \"button govuk-!-margin-right-1\"' (click)=\"confirmRetroRemission()\"> {{ \"Add remission\" | rpxTranslate }} </button>\n <p> <a href=\"javascript:void(0)\" (click)=\"gotoCasetransationPageCancelBtnClicked($event)\" class=\"govuk-link\" data-module=\"govuk-button\"> {{ \"Cancel\" | rpxTranslate }}</a> </p>\n\n</ng-container>\n\n<ng-container *ngIf=\"viewStatus === 'retroremissionconfirmationpage'\">\n <input #myInput type='hidden' id='iFrameDrivenImageValue' value='RETROREMISSIONCONFIRMATIONPAGE'>\n <div class=\"govuk-grid-row\">\n <div >\n <div class=\"govuk-panel govuk-panel-border--confirmation\">\n <h1 class=\"govuk-panel__title\">\n {{ \"Remission added\" | rpxTranslate }}\n </h1>\n <div *ngIf=\"remessionPayment.status === 'Success'\" class=\"govuk-panel__body\">\n <p class=\"govuk-body\"><strong>{{ \"The amount to be refunded should be\" | rpxTranslate }} {{remissionForm.controls.amount.value | currency:'GBP':'symbol-narrow':'1.2-2' }}</strong></p>\n\n </div>\n </div>\n <div *ngIf=\"remessionPayment.status === 'Success'\" >\n <button type=\"submit\" [disabled]=\"!canRefundBeApplied()\" [ngClass]='isConfirmationBtnDisabled ? \"button button--disabled govuk-!-margin-right-1\" : \"button govuk-!-margin-right-1\"' (click)=\"gotoProcessRetroRemission()\">{{ \"Continue\" | rpxTranslate }} </button>\n </div>\n <p class=\"govuk-body\">\n <a href=\"javascript:void(0)\" (click)=\"gotoCasetransationPageCancelBtnClicked($event)\" class=\"govuk-link pointer\" data-module=\"govuk-button\">\n {{ \"Return to case\" | rpxTranslate }}\n </a>\n </p>\n </div>\n </div>\n</ng-container>\n\n\n<ng-container *ngIf=\"viewStatus === 'remissionAddressPage'\">\n <input #myInput type='hidden' id='iFrameDrivenImageValue' value='ADDRESSDETAILSRETROREMISSIONPAGE'>\n <h1 class=\"govuk-heading-l\">{{ \"Process refund\" | rpxTranslate }}</h1>\n <h2 class=\"govuk-heading-m govuk-font19px\">{{ \"Case reference\" | rpxTranslate }}: {{ccdCaseNumber | ccdHyphens }}</h2>\n <ccpay-contact-details\n [addressObj] = notification\n (assignContactDetails)=\"getContactDetails($event, 'checkaddRefundpage')\"\n (redirectToIssueRefund)=\"gotoRemissionSuccess($event)\" ></ccpay-contact-details>\n <p>\n <a (click)=\"gotoCasetransationPageCancelBtnClicked($event)\" class=\"govuk-link\" data-module=\"govuk-button\">\n {{ \"Cancel\" | rpxTranslate }}\n </a>\n </p>\n\n</ng-container>\n\n<ng-container *ngIf=\"viewStatus === 'checkaddRefundpage'\">\n <input #myInput type='hidden' id='iFrameDrivenImageValue' value='CHECKRETROREMISSIONCONFIRMATION'>\n <div class=\"govuk-warning-text\">\n <h1 class=\"heading-large\"> {{ \"Check your answers\" | rpxTranslate }}</h1>\n </div>\n <table class=\"govuk-table\">\n\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Reason for refund\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{ \"Retrospective remission\" | rpxTranslate }}</td>\n </tr>\n\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Payment reference\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{remessionPayment ? remessionPayment.reference: ' '}}</td>\n </tr>\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Payment amount\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">\u00A3{{ remessionPayment ? getFormattedCurrency(remessionPayment.amount): ' ' | currency :'GBP':'symbol':'1.2-2'}} </td>\n </tr>\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Payment status\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{remessionPayment ? remessionPayment.status: '' | rpxTranslate}}</td>\n </tr>\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Fee\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{ fee.code }} - {{ fee.description | rpxTranslate }} ({{ fee.calculated_amount/fee.volume| currency:'GBP':'symbol-narrow':'1.2-2' }}) </td>\n </tr>\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Help with fees or remission reference\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{ remissionForm.controls.remissionCode.value?.trim() }}\n </td>\n </tr>\n\n <tr class=\"govuk-table__row\">\n <td *ngIf=\"remessionPayment.status === 'Success'\" class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Remission amount\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{remissionForm.controls.amount.value | currency:'GBP':'symbol-narrow':'1.2-2' }}\n </td>\n </tr>\n\n <tr class=\"govuk-table__row\">\n <td *ngIf=\"remessionPayment.status === 'Success'\" class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Refund amount\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{ getRefundAmountToBeDisplayedForContinueJourney()| currency:'GBP':'symbol-narrow':'1.2-2' }}\n </td>\n </tr>\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Send to\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{orderParty}}</td>\n </tr>\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Send via\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell whitespace-inherit\">\n <div *ngIf=\"contactDetailsObj?.notification_type === 'EMAIL'\" class=\"contactDetails-width\">\n <strong>{{ \"Email\" | rpxTranslate }}</strong>\n <br/>\n {{contactDetailsObj?.email?.trim()}}\n </div>\n <div *ngIf=\"contactDetailsObj?.notification_type === 'LETTER'\" class=\"contactDetails-width\">\n <strong>{{ \"Post\" | rpxTranslate }}</strong>\n <br/>\n {{contactDetailsObj?.address_line?.trim()}} {{contactDetailsObj?.city?.trim()}} {{contactDetailsObj?.county?.trim()}} {{contactDetailsObj?.country?.trim()}} {{contactDetailsObj?.postal_code?.trim()}}\n </div>\n <a (click)=\"gotoProcessRetroRemission(contactDetailsObj)\" class=\"govuk-link right\" >{{ \"Change\" | rpxTranslate }}</a>\n </td>\n </tr>\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Notification\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{templateInstructionType}}\n <a *ngIf=\"!notificationPreview\" href=\"Javascript:void(0)\" class=\"govuk-link right\" (click)=\"showNotificationPreview()\">\n {{ \"Preview\" | rpxTranslate }}\n </a>\n <a *ngIf=\"notificationPreview\" href=\"Javascript:void(0)\" class=\"govuk-link right\" (click)=\"hideNotificationPreview()\">\n {{ \"Hide Preview\" | rpxTranslate }}\n </a>\n </td>\n </tr>\n </table>\n\n <app-notification-preview *ngIf=\"notificationPreview\"\n [payment]=\"remessionPayment\"\n [contactDetails]=\"contactDetailsObj\"\n [refundReason]=\"'RR036'\"\n [refundAmount]=\"remissionForm.controls.amount.value\"></app-notification-preview>\n\n <button type=\"submit\" class=\"button govuk-button--secondary\" (click)=\"gotoProcessRetroRemission(contactDetailsObj)\">{{ \"Previous\" | rpxTranslate }}</button>\n <button type=\"submit\" [disabled]=\"isConfirmationBtnDisabled\" [ngClass]='isConfirmationBtnDisabled ? \"button button--disabled govuk-!-margin-right-1\" : \"button govuk-!-margin-right-1\"' (click)=\"processRefund()\"> {{ \"Submit refund\" | rpxTranslate }} </button>\n <p> <a href=\"javascript:void(0)\" (click)=\"gotoCasetransationPageCancelBtnClicked($event)\" class=\"govuk-link\" data-module=\"govuk-button\"> {{ \"Cancel\" | rpxTranslate }}</a> </p>\n\n</ng-container>\n\n<ng-container *ngIf=\"viewStatus === 'refundconfirmationpage'\">\n <input #myInput type='hidden' id='iFrameDrivenImageValue' value='RETROREMISSIONREFUNDCONFIRMATIONPAGE'>\n <div class=\"govuk-grid-row\">\n <div >\n <div class=\"govuk-panel govuk-panel--confirmation\">\n <h1 class=\"govuk-panel_remission_title\">\n {{ \"Refund submitted\" | rpxTranslate }}\n </h1>\n\n <div class=\"govuk-panel__body\">\n <p class=\"govuk-body white\"><strong class=\"white\">{{ \"Refund reference\" | rpxTranslate }}: {{refundReference}}</strong></p>\n </div>\n\n </div>\n <div *ngIf=\"isPaymentSuccess\">\n <h2 class=\"govuk-heading-l\">{{ \"What happens next\" | rpxTranslate }}</h2>\n <p class=\"govuk-body\">\n {{ \"A refund request for\" | rpxTranslate }} {{refundAmount | currency:'GBP':'symbol-narrow':'1.2-2' }} {{ \"has been created and will be passed to a team leader to approve\" | rpxTranslate }}.\n </p>\n </div>\n <p class=\"govuk-body\">\n <a href=\"javascript:void(0)\" (click)=\"gotoCasetransationPageCancelBtnClicked($event)\" class=\"govuk-link pointer\" data-module=\"govuk-button\">\n {{ \"Return to case\" | rpxTranslate }}\n </a>\n </p>\n </div>\n </div>\n\n</ng-container>\n\n<!-- Issue Refund Section -->\n<ng-container *ngIf=\"viewCompStatus === 'issuerefund' && isRefundRemission\">\n <div class=\"govuk-form-group\">\n <form [formGroup]=\"remissionForm\" novalidate>\n <h1 class=\"heading-large\">{{ \"Process refund\" | rpxTranslate }}</h1>\n <h2 class=\"heading-medium\">{{ \"Case reference\" | rpxTranslate }}:{{ccdCaseNumber | ccdHyphens }}</h2>\n <span id=\"how-contacted-conditional-hint\" class=\"form-hint govuk-font19px\">\n {{ \"Payment reference\" | rpxTranslate }}: {{paymentReference}}\n </span>\n <h3 class=\"heading-small\">{{ \"Select fees to be refunded\" | rpxTranslate }}</h3>\n <!--TABLE-->\n <div>\n <table class=\"govuk-table\">\n <thead class=\"govuk-table__head\">\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__header col-1\" scope=\"col\">{{ \"Select\" | rpxTranslate }}</td>\n <td class=\"govuk-table__header col-18\" scope=\"col\">{{ \"Fee description\" | rpxTranslate }}</td>\n <td class=\"govuk-table__header col-6\" scope=\"col\">{{ \"Fee amount\" | rpxTranslate }}</td>\n <td class=\"govuk-table__header col-6\" scope=\"col\">{{ \"Total paid\" | rpxTranslate }}</td>\n <td class=\"govuk-table__header col-6\" scope=\"col\">{{ \"Remission amount\" | rpxTranslate }}</td>\n <td class=\"govuk-table__header col-6\" scope=\"col\">{{ \"Quantity\" | rpxTranslate }}</td>\n <td class=\"govuk-table__header col-8\" scope=\"col\">{{ \"Amount to refund\" | rpxTranslate }}</td>\n <td class=\"govuk-table__header\" scope=\"col\"></td>\n </tr>\n </thead>\n <tbody class=\"govuk-table__body\" *ngIf=\"!isFullyRefund\">\n <tr class=\"govuk-table__row\" formArrayName=\"feesList\" *ngFor=\"let fee of feesList?.controls; let i = index\">\n <td class=\"govuk-table__cell\">\n <div [formGroupName]=\"i\" class=\"govuk-checkboxes govuk-checkboxes--large\" data-module=\"govuk-checkboxes\">\n <div class=\"govuk-checkboxes__item\">\n <input\n class=\"govuk-checkboxes__input\"\n (click)=\"check_en(i,fee.controls['id'].value,fee.controls['apportion_amount'].value,fee.controls['volume'].value)\"\n id=\"{{fee.controls['id'].value}}\"\n name=\"organisation\"\n type=\"checkbox\"\n value=\"{{fee.controls['id'].value}}\"\n formControlName=\"selected\" >\n <label class=\"govuk-label govuk-checkboxes__label\" for=\"{{fee.controls['id'].value}}\">\n <span style=\"display:none\">{{ \"Select\" | rpxTranslate }}</span>\n </label>\n </div>\n </div>\n </td>\n <td class=\"govuk-table__cell whitespace-inherit\">{{fee.controls['description'].value}} </td>\n <td class=\"govuk-table__cell whitespace-inherit left\" >\n <div type=\"hidden\" style=\"display:none;background-color:white;\" id=\"feeVOl_{{fee.controls['id'].value}}\">{{ fee.controls['calculated_amount'].value / fee.controls['volume'].value }}</div>\n {{ fee.controls['calculated_amount'].value / fee.controls['volume'].value | currency:'GBP':'symbol-narrow':'1.2-2' }}\n </td>\n <td class=\"govuk-table__cell whitespace-inherit left\" >{{ fee.controls['apportion_amount'].value | currency:'GBP':'symbol-narrow':'1.2-2'}} </td>\n <td class=\"govuk-table__cell whitespace-inherit left\" >\n <div type=\"hidden\" style=\"display:none;background-color:white;\" id=\"feeVOl_{{fee.controls['id'].value}}\">{{ this.getRemissionsHwfAmount(fee.controls['code'].value)}}</div>\n {{ this.getRemissionsHwfAmount(fee.controls['code'].value) | currency:'GBP':'symbol-narrow':'1.2-2' }}\n </td>\n <td class=\"govuk-table__cell whitespace-inherit left\" *ngIf=\"fee.controls['volume'].value ===1\">\n <input disabled=\"disabled\" class=\"govuk-input govuk-input--width-4 center\" id=\"VolumeUpdated_{{fee.controls['id'].value}}\" name=\"VolumeUpdated_{{fee.controls['id'].value}}\" type=\"text\" value=\"{{fee.controls['volume'].value}}\">\n </td>\n <td class=\"govuk-table__cell whitespace-inherit left\" *ngIf=\"fee.controls['volume'].value >1\">\n <div [formGroupName]=\"i\">\n <input disabled=\"disabled\" class=\"govuk-input govuk-input--width-4 center\" id=\"feeVolumeUpdated_{{fee.controls['id'].value}}\" (keyup)=\"calAmtToRefund($event.target.value,fee.controls['calculated_amount'].value,fee.controls['volume'].value,i)\" value=\"{{fee.controls['updated_volume'].value}}\" name=\"feeVolumeUpdated_{{fee.controls['id'].value}}\" formControlName=\"updated_volume\" type=\"text\" >\n </div>\n </td>\n <td class=\"govuk-table__cell whitespace-inherit center\" scope=\"row\">\n <div [formGroupName]=\"i\" class=\"hmcts-currency-input\">\n <div class=\"hmcts-currency-input__symbol\" aria-hidden=\"true\">\u00A3</div>\n <input disabled=\"disabled\" class=\"govuk-input govuk-input--width-small\" id=\"feeAmount_{{fee.controls['id'].value}}\" name=\"feeAmount_{{fee.controls['id'].value}}\" type=\"text\" aria-describedby=\"amount-currency \" pattern=\"[0-9]*\" formControlName=\"refund_amount\">\n <input id=\"feeVolume_{{fee.controls['id'].value}}\" name=\"feeVolume_{{fee.controls['id'].value}}\" value= \"{{fee.controls['volume'].value}}\" type=\"hidden\" formControlName=\"volume\">\n <input id=\"feeApportionAmount_{{fee.controls['id'].value}}\" name=\"feeApportionAmount_{{fee.controls['id'].value}}\" value= \"{{fee.controls['apportion_amount'].value}}\" type=\"hidden\" formControlName=\"apportion_amount\">\n <input id=\"calculatedAmount_{{fee.controls['id'].value}}\" name=\"calculatedAmount_{{fee.controls['id'].value}}\" value= \"{{fee.controls['calculated_amount'].value}}\" type=\"hidden\" formControlName=\"calculated_amount\">\n </div>\n </td>\n </tr>\n </tbody>\n <tbody class=\"govuk-table__body\" *ngIf=\"isFullyRefund\">\n <tr class=\"govuk-table__row\" *ngFor=\"let fee of fees; let i = index\">\n <td class=\"govuk-table__cell\">\n <div class=\"govuk-checkboxes govuk-checkboxes--large\" data-module=\"govuk-checkboxes\">\n <div class=\"govuk-checkboxes__item\">\n <input\n class=\"govuk-checkboxes__input\"\n\n id=\"{{fee.id}}\"\n name=\"organisation\"\n type=\"checkbox\"\n value=\"{{fee.id}}\"\n disabled=\"disabled\"\n [checked]=\"true\" >\n <label class=\"govuk-label govuk-checkboxes__label\" for=\"{{fee.id}}\">\n <span style=\"display:none\">{{ \"Select\" | rpxTranslate }}</span>\n </label>\n </div>\n </div>\n </td>\n <td class=\"govuk-table__cell whitespace-inherit\">{{ fee.description | rpxTranslate }} </td>\n <td class=\"govuk-table__cell whitespace-inherit left\" >\n <div type=\"hidden\" style=\"display:none;background-color:white;\" id=\"feeVOl_{{fee.id}}\">{{ fee.calculated_amount / fee.volume }}</div>\n {{ fee.calculated_amount / fee.volume| currency:'GBP':'symbol-narrow':'1.2-2' }}\n </td>\n <td class=\"govuk-table__cell whitespace-inherit left\" >{{ payment.amount | currency:'GBP':'symbol-narrow':'1.2-2'}} </td>\n\n <td class=\"govuk-table__cell whitespace-inherit left\" >\n <div type=\"hidden\" style=\"display:none;background-color:white;\" id=\"feeRemission_{{fee.id}}\">{{ this.getRemissionValueForFullyRefund()}}</div>\n {{ this.getRemissionsHwfAmount(fee.code) | currency:'GBP':'symbol-narrow':'1.2-2' }}\n\n </td>\n\n <td class=\"govuk-table__cell whitespace-inherit left\">\n <div >\n <input disabled=\"disabled\" class=\"govuk-input govuk-input--width-4 center\" id=\"feeVolumeUpdated_{{fee.id}}\" value=\"{{fee.volume}}\" name=\"feeVolumeUpdated_{{fee.id}}\" type=\"text\" >\n </div>\n </td>\n\n <td class=\"govuk-table__cell whitespace-inherit center\" scope=\"row\">\n\n <div class=\"hmcts-currency-input\">\n\n <div class=\"hmcts-currency-input__symbol\" aria-hidden=\"true\">\u00A3</div>\n <input disabled=\"disabled\" class=\"govuk-input govuk-input-width-10-left\" id=\"feeAmount_{{fee.id}}\" name=\"feeAmount_{{fee.id}}\" type=\"text\" aria-describedby=\"amount-currency \" value=\"{{ payment.amount}}\" pattern=\"[0-9]*\" >\n </div>\n\n </td>\n </tr>\n </tbody>\n <tbody class=\"govuk-table__body\" *ngIf=\"fees?.length === 0\">\n <td class=\"govuk-table__cell\" colspan=\"6\">{{ \"No fees recorded\" | rpxTranslate }}</td>\n </tbody>\n </table>\n </div>\n <div class=\"govuk-button-group\">\n\n\n <a (click)=\"gotoServiceRequestPage($event)\" *ngIf=\"!isFullyRefund\" draggable=\"false\" class=\"govuk-button govuk-button--secondary\" data-module=\"govuk-button\">\n {{ \"Previous\" | rpxTranslate }}\n </a>\n <a (click)=\"goToPaymentViewComponent()\" *ngIf=\"isFullyRefund\" draggable=\"false\" class=\"govuk-button govuk-button--secondary\" data-module=\"govuk-button\">\n {{ \"Previous\" | rpxTranslate }}\n </a>\n\n <button [disabled] = \"noneSelected()\" (click)=\"gotoIssuePage(isFullyRefund)\" class=\"govuk-button\">\n {{ \"Continue\" | rpxTranslate }}\n </button>\n\n </div>\n <p>\n <a (click)=\"gotoCasetransationPageCancelBtnClicked($event)\" class=\"govuk-link\" data-module=\"govuk-button\">{{ \"Cancel\" | rpxTranslate }}</a>\n </p>\n </form>\n </div>\n</ng-container>\n\n<ng-container *ngIf=\"viewCompStatus === 'issuerefundpage1' && isRefundRemission\">\n\n <input #myInput type='hidden' id='iFrameDrivenImageValue' value='ISSUEREFUNDPAGE'>\n <h1 class=\"heading-large\">{{ \"Process refund\" | rpxTranslate }}</h1>\n <h1 class=\"heading-medium\">{{ \"Case reference\" | rpxTranslate }}: {{ccdCaseNumber | ccdHyphens }}</h1>\n <span id=\"how-contacted-conditional-hint govuk-font19px\" *ngIf=\"payment\" class=\"form-hint\">\n {{ \"Payment reference\" | rpxTranslate }}: {{paymentReference}}\n </span>\n <span id=\"how-contacted-conditional-hint govuk-font19px\" *ngIf=\"refundPaymentReference\" class=\"form-hint\">\n {{ \"Payment reference\" | rpxTranslate }}: {{refundPaymentReference}}\n </span>\n <h1 class=\"heading-large\">{{ \"Why are you making this refund\" | rpxTranslate }}?\n </h1>\n\n\n <div class=\"govuk-form-group\">\n <form novalidate>\n <div class=\"govuk-form-group\">\n <form [formGroup]=\"remissionForm\" novalidate>\n <fieldset class=\"govuk-fieldset\" aria-describedby=\"how-contacted-conditional-hint\">\n\n <div\n [ngClass]=\"refundHasError ? 'govuk-radios govuk-radios--conditional form-group-error' : 'govuk-radios govuk-radios--conditional'\"\n data-module=\"govuk-radios\" >\n <p class=\"inline-error-message\" *ngIf=\"refundHasError\">\n <span *ngIf=\"refundHasError\">{{ \"Select a reason why you\u2019re making this refund\" | rpxTranslate }}</span>\n </p>\n\n\n\n <div class = \"container-fluid\">\n <div class=\"row\">\n <div class=\"govuk-radios__item col-md-4\" *ngFor=\"let refund of commonRefundReasons; let i = index;\">\n <!-- <div *ngIf = \"{{refund.name}} !== 'Retrospective remission'\"> -->\n <input class=\"govuk-radios__input\" id=\"{{refund.name}}\" name=\"refundReason\" type=\"radio\"\n formControlName=\"refundReason\" value={{refund.code}}\n (change)=\"selectRadioButton(refund.code, refund.name)\">\n <label class=\"govuk-label--s govuk-radios__label govuk-font__custom\" for=\"how-contacted-conditional\">\n {{refund.name}}\n </label>\n\n <div class=\"govuk-radios__conditional\" *ngIf=\"isRefundReasonsSelected && showReasonText && selectedRefundReason === refund.name \" >\n <label class=\"govuk-label govuk-label--m\" for=\"{{refund.name}}\">\n {{ \"Enter reason\" | rpxTranslate }}\n </label>\n <div [ngClass]=\"{'form-group-error': isReasonEmpty}\">\n <p class=\"inline-error-message\" *ngIf=\"isReasonEmpty\">\n <span *ngIf=\"isReasonEmpty\">{{ \"Enter a reason why you\u2019re making this refund\" | rpxTranslate }}</span>\n </p>\n\n <input class=\"govuk-input govuk-input--width-10\" [ngClass]=\"{'inline-error-class': isReasonEmpty}\" id=\"reason\" aria-label=\"reason\" name=\"reason\" type=\"text\" aria-describedby=\"reason\" maxlength=\"30\" formControlName=\"reason\">\n </div>\n </div>\n <!-- </div> -->\n </div>\n </div>\n </div>\n <br/>\n <div>\n <select formControlName=\"refundDDReason\" class=\"govuk-select\" id=\"sort\" (change)=\"selectchange($event)\">\n <option selected='selected' [defaultSelected]=true [value]=\"default\" >{{default}}</option>\n <!-- <option value=\"\" selected='selected'>Select a different reason</option> -->\n <option *ngFor=\"let refund of refundReasons;\" id=\"{{refund.name}}\" value=\"{{refund.code}}\">{{refund.name}}</option>\n </select>\n\n </div>\n <br/>\n <div class=\"govuk-radios__conditional\" *ngIf=\"showReasonText && !isRefundReasonsSelected\" >\n <div [ngClass]=\"{'form-group-error': isReasonEmpty}\">\n <label class=\"govuk-label govuk-label--m\" for=\"amount\">\n {{ \"Enter reason\" | rpxTranslate }}\n </label>\n <p class=\"inline-error-message\" *ngIf=\"isReasonEmpty\">\n <span *ngIf=\"isReasonEmpty\">{{ \"Enter a reason why you\u2019re making this refund\" | rpxTranslate }}</span>\n </p>\n <input class=\"govuk-input govuk-input--width-10\" [ngClass]=\"{'inline-error-class': isReasonEmpty}\" id=\"reason\" aria-label=\"reason\" name=\"reason\" type=\"text\" aria-describedby=\"reason\" maxlength=\"{{reasonLength}}\" formControlName=\"reason\">\n </div>\n </div>\n\n\n </div>\n </fieldset>\n </form>\n </div>\n </form>\n </div>\n <div class=\"govuk-button-group\">\n <button (click)=\"gotoPartialFeeRefundScreen()\" class=\"govuk-button govuk-button--secondary\"> {{ \"Previous\" | rpxTranslate }}</button>\n <button (click)=\"gotoIssueRefundConfirmation(payment)\" class=\"govuk-button\"> {{ \"Continue\" | rpxTranslate }}</button>\n </div>\n <p>\n <a href=\"javascript:void(0)\" (click)=\"gotoCasetransationPageCancelBtnClicked($event)\" class=\"govuk-link\" data-module=\"govuk-button\">\n {{ \"Cancel\" | rpxTranslate }}\n </a>\n </p>\n\n</ng-container>\n<ng-container *ngIf=\"viewStatus === 'contactDetailsPage'\">\n <input #myInput type='hidden' id='iFrameDrivenImageValue' value='CAPTUREADDRESSDETAILSPAGE'>\n <h1 class=\"govuk-heading-l\">{{ \"Process refund\" | rpxTranslate }}</h1>\n <h2 class=\"govuk-heading-m govuk-font19px\">{{ \"Case reference\" | rpxTranslate }}: {{ccdCaseNumber | ccdHyphens }}</h2>\n <span id=\"how-contacted-conditional-hint\" class=\"govuk-hint govuk-font19px\">\n {{ \"Payment reference\" | rpxTranslate }}: {{paymentReference}}\n </span>\n <ccpay-contact-details\n [addressObj] = notification\n (assignContactDetails)=\"getContactDetails($event, 'checkissuerefundpage')\"\n (redirectToIssueRefund)=\"gotoRefundReasonPage()\" ></ccpay-contact-details>\n <p>\n <a (click)=\"gotoCasetransationPageCancelBtnClicked($event)\" class=\"govuk-link\" data-module=\"govuk-button\">\n {{ \"Cancel\" | rpxTranslate }}\n </a>\n </p>\n\n</ng-container>\n\n<ng-container *ngIf=\"viewStatus === 'checkissuerefundpage'\">\n <input #myInput type='hidden' id='iFrameDrivenImageValue' value='CHECKISSUEREFUNDPAGE'>\n <div class=\"govuk-warning-text\">\n\n <h1 class=\"heading-large\"> {{ \"Check your answers\" | rpxTranslate }}</h1>\n </div>\n <table class=\"govuk-table\">\n\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Payment reference\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{paymentReference}}</td>\n </tr>\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Payment amount\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{payment.amount | currency:'GBP':'symbol-narrow':'1.2-2'}}</td>\n </tr>\n <tr>\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Reason for refund\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{ displayRefundReason?.trim() }}\n <a (click)=\"changeIssueRefundReason()\" class=\"govuk-link right\" >{{ \"Change\" | rpxTranslate }}</a>\n </td>\n </tr>\n <tr class=\"govuk-table__row\" *ngIf=\"!isFullyRefund\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Refund amount\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{totalRefundAmount | currency:'GBP':'symbol-narrow':'1.2-2'}}\n <a (click)=\"changeRefundAmount()\" class=\"govuk-link right\" >{{ \"Change\" | rpxTranslate }}</a>\n </td>\n </tr>\n <tr class=\"govuk-table__row\" *ngIf=\"isFullyRefund\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Refund amount\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{payment.amount | currency:'GBP':'symbol-narrow':'1.2-2'}}</td>\n </tr>\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Send to\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{orderParty}}</td>\n </tr>\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Send via\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell whitespace-inherit\">\n <div *ngIf=\"contactDetailsObj?.notification_type === 'EMAIL'\" class=\"contactDetails-width\">\n <strong>{{ \"Email\" | rpxTranslate }}</strong>\n <br/>\n {{contactDetailsObj?.email?.trim()}}\n </div>\n <div *ngIf=\"contactDetailsObj?.notification_type === 'LETTER'\" class=\"contactDetails-width\">\n <strong>{{ \"Post\" | rpxTranslate }}</strong>\n <br/>\n {{contactDetailsObj?.address_line?.trim()}} {{contactDetailsObj?.city?.trim()}} {{contactDetailsObj?.county?.trim()}} {{contactDetailsObj?.country?.trim()}} {{contactDetailsObj?.postal_code?.trim()}}\n </div>\n <a (click)=\"gotoContactDetailsPage(contactDetailsObj)\" class=\"govuk-link right\" >{{ \"Change\" | rpxTranslate }}</a>\n </td>\n </tr>\n\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Notification\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{templateInstructionType}}\n <a *ngIf=\"!notificationPreview\" href=\"Javascript:void(0)\" class=\"govuk-link right\" (click)=\"showNotificationPreview()\">\n {{ \"Preview\" | rpxTranslate }}\n </a>\n <a *ngIf=\"notificationPreview\" href=\"Javascript:void(0)\" class=\"govuk-link right\" (click)=\"hideNotificationPreview()\">\n {{ \"Hide Preview\" | rpxTranslate }}\n </a>\n </td>\n </tr>\n </table>\n\n <app-notification-preview *ngIf=\"notificationPreview\"\n [payment]=\"payment\"\n [contactDetails]=\"contactDetailsObj\"\n [refundReason]=\"selectedRefundReasonCode\"\n [refundAmount]=\"isFullyRefund ? payment.amount : totalRefundAmount\"></app-notification-preview>\n\n\n <div class=\"govuk-button-group\">\n <button type=\"submit\" class=\"button govuk-button--secondary\" (click)=\"gotoContactDetailsPage(contactDetailsObj)\"> {{ \"Previous\" | rpxTranslate }} </button>\n <button type=\"submit\"\n [disabled]=\"isConfirmationBtnDisabled\"\n [ngClass]='isConfirmationBtnDisabled ? \"button button--disabled govuk-!-margin-right-1\" : \"button govuk-!-margin-right-1\"'\n (click)=\"confirmIssueRefund(isFullyRefund)\">\n {{ \"Submit refund\" | rpxTranslate }}\n </button>\n </div>\n <p>\n <a (click)=\"gotoCasetransationPageCancelBtnClicked($event)\" class=\"govuk-link\" data-module=\"govuk-button\">\n {{ \"Cancel\" | rpxTranslate }}\n </a>\n </p>\n\n</ng-container>\n\n<!--Retro Refund-->\n<ng-container *ngIf=\"viewCompStatus === 'addrefundforremission'\">\n <input #myInput type='hidden' id='iFrameDrivenImageValue' value='ADDRESSDETAILSRETROREMISSIONPAGE'>\n <h1 class=\"govuk-heading-l\">{{ \"Process refund\" | rpxTranslate }}</h1>\n <h2 class=\"govuk-heading-m govuk-font19px\">{{ \"Case reference\" | rpxTranslate }}: {{ccdCaseNumber | ccdHyphens }}</h2>\n <span id=\"how-contacted-conditional-hint\" class=\"govuk-hint govuk-font19px\">\n {{ \"Payment reference\" | rpxTranslate }}: {{paymentReference}}\n </span>\n<ccpay-contact-details\n[addressObj] = notification\n(assignContactDetails)=\"getContactDetails($event, 'addrefundcheckandanswer')\"\n(redirectToIssueRefund)=\"gotoServiceRequestPage($event)\" ></ccpay-contact-details>\n<p>\n <a (click)=\"gotoCasetransationPageCancelBtnClicked($event)\" class=\"govuk-link\" data-module=\"govuk-button\">\n {{ \"Cancel\" | rpxTranslate }}\n </a>\n</p>\n</ng-container>\n<ng-container *ngIf=\"viewStatus === 'addrefundcheckandanswer'\">\n <input #myInput type='hidden' id='iFrameDrivenImageValue' value='ADDREFUNDFORREMISSION'>\n <div class=\"govuk-warning-text\">\n\n <h1 class=\"heading-large\"> {{ \"Check your answers\" | rpxTranslate }}</h1>\n </div>\n <table class=\"govuk-table\">\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Reason for refund\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{ \"Retrospective remission\" | rpxTranslate }}</td>\n </tr>\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Payment reference\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{paymentReference}}</td>\n </tr>\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Refund amount\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{getRefundAmountToBeDisplayed(remission)| currency:'GBP':'symbol-narrow':'1.2-2'}}</td>\n </tr>\n\n <tr class=\"govuk-table__row\">\n <td *ngIf=\"remessionPayment.status === 'Success'\" class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Remission amount\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{getRemissionAmountToBeDisplayed(remission)| currency:'GBP':'symbol-narrow':'1.2-2' }}\n </td>\n </tr>\n\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Fee code\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{remission.fee_code}}</td>\n </tr>\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Fee amount\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{feeamount | currency:'GBP':'symbol-narrow':'1.2-2'}}</td>\n </tr>\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Send to\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{orderParty}}</td>\n </tr>\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Send via\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell whitespace-inherit\">\n <div *ngIf=\"contactDetailsObj?.notification_type === 'EMAIL'\" class=\"contactDetails-width\">\n <strong>{{ \"Email\" | rpxTranslate }}</strong>\n <br/>\n {{contactDetailsObj?.email?.trim()}}\n </div>\n <div *ngIf=\"contactDetailsObj?.notification_type === 'LETTER'\" class=\"contactDetails-width\">\n <strong>{{ \"Post\" | rpxTranslate }}</strong>\n <br/>\n {{contactDetailsObj?.address_line?.trim()}} {{contactDetailsObj?.city?.trim()}} {{contactDetailsObj?.county?.trim()}} {{contactDetailsObj?.country?.trim()}} {{contactDetailsObj?.postal_code?.trim()}}\n </div>\n <a (click)=\"gotoAddressPage(contactDetailsObj)\" class=\"govuk-link right\" >{{ \"Change\" | rpxTranslate }}</a>\n </td>\n </tr>\n\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Notification\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{templateInstructionType}}\n <a *ngIf=\"!notificationPreview\" href=\"Javascript:void(0)\" class=\"govuk-link right\" (click)=\"showNotificationPreview()\">\n {{ \"Preview\" | rpxTranslate }}\n </a>\n <a *ngIf=\"notificationPreview\" href=\"Javascript:void(0)\" class=\"govuk-link right\" (click)=\"hideNotificationPreview()\">\n {{ \"Hide Preview\" | rpxTranslate }}\n </a>\n </td>\n </tr>\n </table>\n\n <app-notification-preview *ngIf=\"notificationPreview\"\n [contactDetails]=\"contactDetailsObj\"\n [paymentReference]=\"paymentReference\"\n [payment]=\"paymentObj\"\n [refundReason]=\"'RR036'\"\n [refundAmount]=\"remission.hwf_amount\"></app-notification-preview>\n\n <div class=\"govuk-button-group\">\n <button type=\"submit\" class=\"button govuk-button--secondary\" (click)=\"gotoAddressPage(contactDetailsObj)\">{{ \"Previous\" | rpxTranslate }}</button>\n <button type=\"submit\"\n [disabled]=\"isConfirmationBtnDisabled\"\n [ngClass]='isConfirmationBtnDisabled ? \"button button--disabled govuk-!-margin-right-1\" : \"button govuk-!-margin-right-1\"'\n (click)=\"processRefund()\">\n {{ \"Submit refund\" | rpxTranslate }}\n </button>\n </div>\n <p>\n <a href=\"javascript:void(0)\" (click)=\"gotoCasetransationPageCancelBtnClicked($event)\" class=\"govuk-link\" data-module=\"govuk-button\">\n {{ \"Cancel\" | rpxTranslate }}\n </a>\n </p>\n\n</ng-container>\n\n<ng-container *ngIf=\"viewStatus === 'retrorefundconfirmationpage'\">\n <div class=\"govuk-grid-row\">\n <div >\n <div class=\"govuk-panel govuk-panel--confirmation\">\n <h1 class=\"govuk-panel_remission_title\">\n {{ \"Refund submitted\" | rpxTranslate }}\n </h1>\n\n <div class=\"govuk-panel__body\">\n <p class=\"govuk-body white\"><strong class=\"white\">{{ \"Refund reference\" | rpxTranslate }}: {{refundReference}}</strong></p>\n </div>\n\n </div>\n <div *ngIf=\"isPaymentSuccess\">\n <h2 class=\"govuk-heading-l\">{{ \"What happens next\" | rpxTranslate }}</h2>\n <p class=\"govuk-body\">\n {{ \"A refund request for\" | rpxTranslate }} {{ refundAmount| currency:'GBP':'symbol-narrow':'1.2-2'}} {{ \"has been passed to a team leader to approve\" | rpxTranslate }}.\n </p>\n </div>\n <p class=\"govuk-body\">\n <a href=\"javascript:void(0)\" (click)=\"gotoCasetransationPageCancelBtnClicked($event)\" class=\"govuk-link pointer\" data-module=\"govuk-button\">\n {{ \"Return to case\" | rpxTranslate }}\n </a>\n </p>\n </div>\n </div>\n</ng-container>\n\n<ng-container *ngIf=\"viewStatus === 'order-full-view'\">\n <ccpay-service-request\n [viewStatus] = \"viewStatus\"\n [orderRef] = \"orderRef\"\n [isServiceRequest]=\"isServiceRequest\"\n [orderStatus] = \"orderStatus\"\n [orderCreated] = \"orderCreated\"\n [orderParty] = \"orderParty\"\n [orderCCDEvent] = \"orderCCDEvent\"\n [orderDetail] = \"orderDetail\"\n [LOGGEDINUSERROLES] = \"LOGGEDINUSERROLES\"\n [takePayment] = \"takePayment\"\n [ccdCaseNumber] = \"ccdCaseNumber\"\n [orderFeesTotal] = \"orderFeesTotal\"\n [orderTotalPayments] = \"orderTotalPayments\"\n [orderRemissionTotal] = \"orderRemissionTotal\">\n</ccpay-service-request>\n</ng-container>\n\n<ng-container *ngIf=\"viewStatus === 'payment-view'\">\n <ccpay-payment-view\n [LOGGEDINUSERROLES] = \"LOGGEDINUSERROLES\"\n [isTurnOff] = \"isTurnOff\"\n [isTakePayment] = \"takePayment\"\n [caseType] = \"caseType\"\n [isServiceRequest]=\"isServiceRequest\"\n [orderRef] = \"orderRef\"\n [orderStatus] = \"orderStatus\"\n [orderCreated] = \"orderCreated\"\n [orderParty] = \"orderParty\"\n [orderCCDEvent] = \"orderCCDEvent\"\n [orderDetail] = \"orderDetail\"\n [orderFeesTotal] = \"orderFeesTotal\"\n [orderTotalPayments] = \"orderTotalPayments\"\n [orderRemissionTotal] = \"orderRemissionTotal\"\n >\n</ccpay-payment-view>\n</ng-container>\n\n</div>\n", styles: [".add-remission .button{margin:20px 2px;padding:.5em;font-size:19px;font-weight:200}.add-remission td.govuk-table__cell{width:50%}.add-remission .govuk-button--secondary{background-color:#dee0e2;box-shadow:0 2px #858688;color:#0b0c0c;margin-right:.5em}.add-remission .govuk-warning-text__text,.add-remission .govuk-label--s,.add-remission .label_remission__symbol{font-size:19px;font-weight:400}.add-remission .inline-error-class{outline:3px solid #a71414;outline-offset:0;border-color:#a71414}.add-remission .inline-error-message{color:#a71414;border-color:#a71414;font-weight:700;margin-top:10px;font-size:20px}.add-remission .govuk-button,.add-remission .govuk-link{margin-right:1em;font-size:19px;font-weight:200}.add-remission .govuk-button-group{padding-top:2em}.add-remission .heading-medium{margin-top:.875em}.add-remission .heading-large{margin-top:.25em}.add-remission .govuk-panel--confirmation{color:#fff;background:#00703c}.add-remission .govuk-panel__title{font-size:5rem}.add-remission .govuk-body-m,.add-remission .govuk-body{font-size:2.1875rem}.add-remission .govuk-radios__item{clear:initial!important;display:inline-block;width:45%!important}.add-remission .govuk-radios__conditional{padding-top:12px!important}.add-remission .right{float:right;cursor:pointer}.add-remission .radio{float:right}.govuk-input,.govuk-font19px{font-size:19px}.govuk-select{font-size:19px;font-weight:400}.govuk-input--width-10{max-width:50ex}.govuk-input--width-small{max-width:110px}.govuk-input-width-10-left{max-width:50ex;padding-left:40px}.govuk-label--m{font-size:19px;font-weight:400}.govuk-error-summary__body{font-size:19px!important}.govuk-error-summary__title{font-size:24px!important}.govuk-panel_remission_title{margin-top:0;margin-bottom:30px;color:#fff;font-family:nta,Arial,sans-serif;-webkit-font-smoothing:antialiased;font-weight:700;font-size:48px}.white{color:#fff}.pagesize{margin:2em;width:97%}.pointer{cursor:pointer}.col-18{min-width:18em}.col-6{min-width:6em}.col-8{min-width:8em}.col-1{min-width:1em}.col-25{width:25%!important}.col-24{width:24%!important}.left{text-align:left}.center{text-align:center}.col-60{width:60%;text-align:left}.margin-top--size{margin-top:-30px}.contactDetails-width{width:70%}.right{cursor:pointer}.form-hint{font-size:19px!important}.govuk-panel-border--confirmation{color:#0b0c0c;border:5px solid #00703C}.whitespace-inherit{white-space:inherit!important}.govuk-link{cursor:pointer}.hmcts-currency-input__symbol{font-family:nta,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px;line-height:initial;position:absolute;font-weight:200;padding:8px 10px;height:40px;box-sizing:border-box;background-color:#dee0e2;border:2px solid #0b0c0c}\n"], dependencies: [{ kind: "component", type: i0.forwardRef(() => PaymentViewComponent), selector: "ccpay-payment-view", inputs: ["isTurnOff", "isTakePayment", "caseType", "orderRef", "orderStatus", "orderTotalPayments", "payment", "LOGGEDINUSERROLES", "ISPAYMENTSTATUSENABLED", "orderParty", "orderCreated", "orderCCDEvent", "orderFeesTotal", "orderRemissionTotal", "orderDetail", "isServiceRequest"] }, { kind: "ngmodule", type: i0.forwardRef(() => CommonModule) }, { kind: "directive", type: i0.forwardRef(() => i7.NgClass), selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i0.forwardRef(() => i7.NgForOf), selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i0.forwardRef(() => i7.NgIf), selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i0.forwardRef(() => i7.CurrencyPipe), name: "currency" }, { kind: "component", type: i0.forwardRef(() => ServiceRequestComponent), selector: "ccpay-service-request", inputs: ["LOGGEDINUSERROLES", "viewStatus", "orderDetail", "orderRef", "orderStatus", "orderParty", "orderCreated", "orderCCDEvent", "orderFeesTotal", "orderTotalPayments", "orderRemissionTotal", "paymentGroupList", "takePayment", "ccdCaseNumber", "isServiceRequest"], outputs: ["goToServiceRquestComponent"] }, { kind: "component", type: i0.forwardRef(() => NotificationPreviewComponent), selector: "app-notification-preview", inputs: ["payment", "contactDetails", "refundReason", "refundAmount", "paymentReference", "refundReference", "previewJourney", "notificationSent"], outputs: ["notificationPreviewEvent"] }, { kind: "component", type: i0.forwardRef(() => ContactDetailsComponent), selector: "ccpay-contact-details", inputs: ["isEditOperation", "isEditOperationInRefundList", "addressObj"], outputs: ["assignContactDetails", "assignContactDetailsInFefundsList", "redirectToIssueRefund"] }, { kind: "pipe", type: i0.forwardRef(() => CcdHyphensPipe), name: "ccdHyphens" }, { kind: "ngmodule", type: i0.forwardRef(() => FormsModule) }, { kind: "directive", type: i0.forwardRef(() => i1.ɵNgNoValidate), selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i0.forwardRef(() => i1.NgSelectOption), selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i0.forwardRef(() => i1.ɵNgSelectMultipleOption), selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i0.forwardRef(() => i1.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: i0.forwardRef(() => i1.NumberValueAccessor), selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }, { kind: "directive", type: i0.forwardRef(() => i1.CheckboxControlValueAccessor), selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i0.forwardRef(() => i1.SelectControlValueAccessor), selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i0.forwardRef(() => i1.RadioControlValueAccessor), selector: "input[type=radio][formControlName],input[type=radio][formControl],input[type=radio][ngModel]", inputs: ["name", "formControlName", "value"] }, { kind: "directive", type: i0.forwardRef(() => i1.NgControlStatus), selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i0.forwardRef(() => i1.NgControlStatusGroup), selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i0.forwardRef(() => i1.MaxLengthValidator), selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { kind: "directive", type: i0.forwardRef(() => i1.PatternValidator), selector: "[pattern][formControlName],[pattern][formControl],[pattern][ngModel]", inputs: ["pattern"] }, { kind: "directive", type: i0.forwardRef(() => i1.NgForm), selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: i0.forwardRef(() => ReactiveFormsModule) }, { kind: "directive", type: i0.forwardRef(() => i1.FormGroupDirective), selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i0.forwardRef(() => i1.FormControlName), selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i0.forwardRef(() => i1.FormGroupName), selector: "[formGroupName]", inputs: ["formGroupName"] }, { kind: "directive", type: i0.forwardRef(() => i1.FormArrayName), selector: "[formArrayName]", inputs: ["formArrayName"] }, { kind: "ngmodule", type: i0.forwardRef(() => RpxTranslationModule) }, { kind: "pipe", type: i0.forwardRef(() => i8.RpxTranslatePipe), name: "rpxTranslate" }] });
|
|
1172
|
+
}
|
|
1173
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AddRemissionComponent, decorators: [{
|
|
1174
|
+
type: Component,
|
|
1175
|
+
args: [{ selector: 'ccpay-add-remission', providers: [{ provide: 'ADD_REMISSION', useExisting: AddRemissionComponent }], imports: [
|
|
1176
|
+
forwardRef(() => PaymentViewComponent),
|
|
1177
|
+
CommonModule,
|
|
1178
|
+
forwardRef(() => ServiceRequestComponent),
|
|
1179
|
+
forwardRef(() => NotificationPreviewComponent),
|
|
1180
|
+
forwardRef(() => ContactDetailsComponent),
|
|
1181
|
+
CcdHyphensPipe,
|
|
1182
|
+
CapitalizePipe,
|
|
1183
|
+
FormsModule,
|
|
1184
|
+
ReactiveFormsModule,
|
|
1185
|
+
RpxTranslationModule
|
|
1186
|
+
], standalone: true, template: "<div class=\"add-remission pagesize\">\n <div *ngIf=\"errorMessage\">\n <div class=\"error-summary\" role=\"group\" aria-labelledby=\"failure-error-summary-heading\" tabindex=\"-1\">\n <h2 class=\"heading-medium error-summary-heading\" id=\"failure-error-summary-heading\">\n {{ \"Error in processing the request\" | rpxTranslate }}\n </h2>\n <div class=\"govuk-error-summary__body\">\n {{ errorMessage | rpxTranslate }}\n </div>\n </div>\n </div>\n <div *ngIf=\"errorMsg.length > 0\">\n <div class=\"error-summary\" role=\"group\" aria-labelledby=\"failure-error-summary-heading\" tabindex=\"-1\">\n <h2 class=\"heading-medium error-summary-heading\" id=\"failure-error-summary-heading\">\n {{ \"Error in processing the request\" | rpxTranslate }}\n </h2>\n <div *ngFor=\"let err of errorMsg; let i = index\" class=\"govuk-error-summary__body\">\n\n <li>{{ err | rpxTranslate }}</li>\n </div>\n </div>\n </div>\n\n<ng-container *ngIf=\"viewStatus === 'main' && !isRefundRemission \">\n <input #myInput type='hidden' id='iFrameDrivenImageValue' value='ADDREMISSION'>\n <h1 class=\"heading-large\">{{ \"Add remission\" | rpxTranslate }} </h1>\n <form novalidate>\n <div class=\"govuk-form-group\">\n <form [formGroup]=\"remissionForm\" novalidate>\n <div class=\"govuk-form-group\">\n <label class=\"govuk-label govuk-label--s\" for=\"remission-code\">\n {{ \"Add remission to\" | rpxTranslate }} {{ fee?.code }}: {{ fee?.description | rpxTranslate }}\n <span class=\"form-hint\">{{ \"Enter remission for reference\" | rpxTranslate }}. {{ \"For example\" | rpxTranslate }}: HWF-A1B-23C OR PA21-123456</span>\n </label>\n <input [ngClass]=\"{'inline-error-class': isRemissionCodeEmpty || remissionCodeHasError}\" class=\"govuk-input govuk-input--width-20 govuk-!-margin-right-1\" id=\"remissionCode\" aria-label=\"remissionCode\" name=\"remissionCode\" type=\"text\" formControlName=\"remissionCode\">\n <p class=\"inline-error-message\" *ngIf=\"isRemissionCodeEmpty || remissionCodeHasError\">\n <span *ngIf=\"isRemissionCodeEmpty\">{{ \"Enter a remission code\" | rpxTranslate }}</span>\n <span *ngIf=\"remissionCodeHasError\">{{ \"Enter a vaild remission code\" | rpxTranslate }}</span>\n </p>\n </div>\n <div class=\"govuk-form-group\">\n <label class=\"govuk-label govuk-label--s\" for=\"amount\">\n {{ \"How much does the applicant need to pay\" | rpxTranslate }}?\n </label>\n\n <div id=\"amount-currency\" class=\"govuk-visually-hidden\">{{ \"in pounds\" | rpxTranslate }}</div>\n <div class=\"hmcts-currency-input\">\n <div class=\"hmcts-currency-input__symbol\" aria-hidden=\"true\">\u00A3</div>\n <input class=\"govuk-input govuk-input-width-10-left\" [ngClass]=\"{'inline-error-class': isAmountEmpty || amountHasError || isRemissionLessThanFeeError}\" id=\"amount\" aria-label=\"amount\" name=\"amount\" type=\"text\" aria-describedby=\"amount-currency\" formControlName=\"amount\">\n <p class=\"inline-error-message\" *ngIf=\"isAmountEmpty || amountHasError || isRemissionLessThanFeeError\">\n <span *ngIf=\"isAmountEmpty\">{{ \"Enter a amount\" | rpxTranslate }}</span>\n <span *ngIf=\"amountHasError\">{{ \"Enter a vaild amount\" | rpxTranslate }}</span>\n <span *ngIf=\"isRemissionLessThanFeeError\">{{ \"The remission amount must be less than the total fee\" | rpxTranslate }}</span>\n </p>\n </div>\n </div>\n </form>\n <button class=\"button\" type=\"submit\" (click)=\"addRemission()\">\n {{ \"Submit\" | rpxTranslate }}\n </button>\n </div>\n </form>\n</ng-container>\n\n<ng-container *ngIf=\"viewStatus === 'confirmation'\">\n <input #myInput type='hidden' id='iFrameDrivenImageValue' value='ADDREMISSIONCONFIRMATION'>\n <div class=\"govuk-warning-text\">\n <span class=\"govuk-warning-text__icon\" aria-hidden=\"true\">!</span>\n <strong class=\"govuk-warning-text__text\">\n <span class=\"govuk-warning-text__assistive\">{{ \"Warning\" | rpxTranslate }}</span>\n {{ \"Are you sure you want to add remission to this fee\" | rpxTranslate }}?\n </strong>\n </div>\n <table class=\"govuk-table\">\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Remission code\" | rpxTranslate }}:</td>\n <td class=\"govuk-table__cell\">{{ remissionForm.controls.remissionCode.value }}</td>\n </tr>\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Fee code\" | rpxTranslate }}:</td>\n <td class=\"govuk-table__cell\">{{ fee.code }}</td>\n </tr>\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Fee description\" | rpxTranslate }}:</td>\n <td class=\"govuk-table__cell\">{{ fee.description | rpxTranslate }}</td>\n </tr>\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Amount the applicant must pay\" | rpxTranslate }}:</td>\n <td class=\"govuk-table__cell\">{{ remissionForm.controls.amount.value | currency:'GBP':'symbol-narrow':'1.2-2' }}</td>\n </tr>\n </table>\n\n <button type=\"submit\" class=\"button govuk-button--secondary\" (click)=\"cancelRemission.emit()\">\n {{ \"Cancel\" | rpxTranslate }}\n </button>\n <button type=\"submit\"\n [disabled]=\"isConfirmationBtnDisabled\"\n [ngClass]='isConfirmationBtnDisabled ? \"button button--disabled govuk-!-margin-right-1\" : \"button govuk-!-margin-right-1\"'\n (click)=\"confirmRemission()\">\n {{ \"Confirm\" | rpxTranslate }}\n </button>\n\n</ng-container>\n\n<!-- Add retro remission changes-->\n\n<ng-container *ngIf=\"viewCompStatus === 'addremission'\">\n <input #myInput type='hidden' id='iFrameDrivenImageValue' value='PROCESSADDRETROREMISSIONPAGE'>\n <h1 class=\"heading-large\">{{ \"Process remission\" | rpxTranslate }}</h1>\n <h1 class=\"heading-medium\">#{{ccdCaseNumber | ccdHyphens}}</h1>\n <h1 class=\"heading-large\">{{ \"Enter help with fees or remission reference\" | rpxTranslate }}</h1>\n <form novalidate>\n <div class=\"govuk-form-group\">\n <form [formGroup]=\"remissionForm\" novalidate>\n <div class=\"govuk-form-group\">\n <label class=\"govuk-label govuk-label--s\" for=\"remission-code\">\n <span class=\"form-hint\">{{ \"For example\" | rpxTranslate }}: HWF-A1B-23C OR PA21-123456</span>\n </label>\n <p class=\"inline-error-message\" *ngIf=\"isRemissionCodeEmpty || remissionCodeHasError\">\n <span *ngIf=\"isRemissionCodeEmpty\">{{ \"Enter a remission code\" | rpxTranslate }}</span>\n <span *ngIf=\"remissionCodeHasError\">{{ \"Enter a vaild remission code\" | rpxTranslate }}</span>\n </p>\n <input [ngClass]=\"{'inline-error-class': isRemissionCodeEmpty || remissionCodeHasError}\" class=\"govuk-input govuk-input--width-20 govuk-!-margin-right-1\" id=\"remissionCode\" aria-label=\"remissionCode\" name=\"remissionCode\" type=\"text\" formControlName=\"remissionCode\">\n\n </div>\n\n </form>\n <div class=\"govuk-button-group\">\n <button (click)=\"gotoServiceRequestPage($event)\" class=\"govuk-button govuk-button--secondary\"> {{ \"Previous\" | rpxTranslate }}</button>\n <button (click)=\"addRemissionCode()\" class=\"govuk-button\"> {{ \"Continue\" | rpxTranslate }}</button>\n </div>\n <p><a href=\"javascript:void(0)\" (click)=\"gotoCasetransationPageCancelBtnClicked($event)\" class=\"govuk-link pointer\" data-module=\"govuk-button\">{{ \"Cancel\" | rpxTranslate }}</a></p>\n </div>\n </form>\n\n</ng-container>\n\n<ng-container *ngIf=\"viewStatus === 'processretroremissonpage'\" >\n <input #myInput type='hidden' id='iFrameDrivenImageValue' value='PROCESSRETROREMISSIONPAGE'>\n <h1 class=\"heading-large\">{{ \"Process remission\" | rpxTranslate }}</h1>\n <h1 class=\"heading-medium\">#{{ccdCaseNumber | ccdHyphens }}</h1>\n <div class=\"govuk-form-group\">\n <form novalidate>\n <div class=\"govuk-form-group\">\n <form [formGroup]=\"remissionForm\" novalidate>\n <fieldset class=\"govuk-fieldset\">\n <legend class=\"govuk-fieldset__legend govuk-fieldset__legend--m\">\n <h1 *ngIf=\"remessionPayment?.status === 'Success' || isFromRefundListPage\" class=\"heading-medium\">\n {{ \"Enter the HWF or remission amount\" | rpxTranslate }}\n </h1>\n <h1 *ngIf=\"remessionPayment?.status !== 'Success' && !isFromRefundListPage\" class=\"heading-medium\">\n {{ \"Enter the remission amount\" | rpxTranslate }}\n </h1>\n <h1 *ngIf=\"remessionPayment?.status === 'undefined'\" class=\"heading-medium\">\n {{ \"Enter the amount\" | rpxTranslate }}\n </h1>\n </legend>\n <div id=\"amount-currency\" class=\"govuk-visually-hidden\">{{ \"in pounds\" | rpxTranslate }}</div>\n <p class=\"inline-error-message\" *ngIf=\"isAmountEmpty || amountHasError || isRemissionLessThanFeeError\">\n <span *ngIf=\"isAmountEmpty\">{{ \"Enter a amount\" | rpxTranslate }}</span>\n <span *ngIf=\"amountHasError\">{{ \"Enter a vaild amount\" | rpxTranslate }}</span>\n <span *ngIf=\"isRemissionLessThanFeeError\">{{ \"You cannot add a remission that's more than the fee amount\" | rpxTranslate }}.</span>\n </p>\n <div class=\"hmcts-currency-input\">\n\n <div class=\"hmcts-currency-input__symbol\" aria-hidden=\"true\">\u00A3</div>\n <input class=\"govuk-input govuk-input-width-10-left\" [ngClass]=\"{'inline-error-class': isAmountEmpty || amountHasError || isRemissionLessThanFeeError}\" id=\"amount\" aria-label=\"amount\" name=\"amount\" type=\"number\" aria-describedby=\"amount-currency\" formControlName=\"amount\">\n\n\n </div>\n </fieldset>\n </form>\n\n <div class=\"govuk-button-group\">\n <button (click)=\"gotoAddRetroRemissionCodePage()\" class=\"govuk-button govuk-button--secondary\"> {{ \"Previous\" | rpxTranslate }}</button>\n <button (click)=\"gotoCheckRetroRemissionPage(payment)\" class=\"govuk-button\"> {{ \"Continue\" | rpxTranslate }}</button>\n\n </div>\n <p>\n <a href=\"javascript:void(0)\" (click)=\"gotoCasetransationPageCancelBtnClicked($event)\" class=\"govuk-link\" data-module=\"govuk-button\">{{ \"Cancel\" | rpxTranslate }}</a>\n </p>\n </div>\n\n </form>\n </div>\n</ng-container>\n<ng-container *ngIf=\"viewStatus === 'checkretroremissionpage'\">\n <input #myInput type='hidden' id='iFrameDrivenImageValue' value='CHECKRETROREMISSIONCONFIRMATION'>\n <div class=\"govuk-warning-text\">\n <h1 class=\"heading-large\"> {{ \"Check your answers\" | rpxTranslate }}</h1>\n </div>\n <table class=\"govuk-table\">\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Payment reference\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{remessionPayment ? remessionPayment.reference: ' '}}</td>\n </tr>\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Payment amount\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">\u00A3{{ remessionPayment ? getFormattedCurrency(remessionPayment.amount): ' ' | currency :'GBP':'symbol':'1.2-2'}} </td>\n </tr>\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Payment status\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{remessionPayment ? remessionPayment.status: ''}}</td>\n </tr>\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Fee\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{ fee.code }} - {{ fee.description | rpxTranslate }} </td>\n </tr>\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Fee amount\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{ fee.calculated_amount/fee.volume| currency:'GBP':'symbol-narrow':'1.2-2' }}</td>\n </tr>\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Help with fees or remission reference\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{ remissionForm.controls.remissionCode.value?.trim() }}\n <a (click)=\"gotoProcessRetroRemissionPage()\" class=\"govuk-link right\" >{{ \"Change\" | rpxTranslate }}</a>\n </td>\n </tr>\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Remission amount\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{remissionForm.controls.amount.value | currency:'GBP':'symbol-narrow':'1.2-2' }}\n <a (click)=\"gotoAmountRetroRemission()\" class=\"govuk-link right\" >{{ \"Change\" | rpxTranslate }}</a>\n </td>\n </tr>\n </table>\n\n <button type=\"submit\" class=\"button govuk-button--secondary\" (click)=\"gotoAmountRetroRemission()\">{{ \"Previous\" | rpxTranslate }}</button>\n <button type=\"submit\" [disabled]=\"isConfirmationBtnDisabled\" [ngClass]='isConfirmationBtnDisabled ? \"button button--disabled govuk-!-margin-right-1\" : \"button govuk-!-margin-right-1\"' (click)=\"confirmRetroRemission()\"> {{ \"Add remission\" | rpxTranslate }} </button>\n <p> <a href=\"javascript:void(0)\" (click)=\"gotoCasetransationPageCancelBtnClicked($event)\" class=\"govuk-link\" data-module=\"govuk-button\"> {{ \"Cancel\" | rpxTranslate }}</a> </p>\n\n</ng-container>\n\n<ng-container *ngIf=\"viewStatus === 'retroremissionconfirmationpage'\">\n <input #myInput type='hidden' id='iFrameDrivenImageValue' value='RETROREMISSIONCONFIRMATIONPAGE'>\n <div class=\"govuk-grid-row\">\n <div >\n <div class=\"govuk-panel govuk-panel-border--confirmation\">\n <h1 class=\"govuk-panel__title\">\n {{ \"Remission added\" | rpxTranslate }}\n </h1>\n <div *ngIf=\"remessionPayment.status === 'Success'\" class=\"govuk-panel__body\">\n <p class=\"govuk-body\"><strong>{{ \"The amount to be refunded should be\" | rpxTranslate }} {{remissionForm.controls.amount.value | currency:'GBP':'symbol-narrow':'1.2-2' }}</strong></p>\n\n </div>\n </div>\n <div *ngIf=\"remessionPayment.status === 'Success'\" >\n <button type=\"submit\" [disabled]=\"!canRefundBeApplied()\" [ngClass]='isConfirmationBtnDisabled ? \"button button--disabled govuk-!-margin-right-1\" : \"button govuk-!-margin-right-1\"' (click)=\"gotoProcessRetroRemission()\">{{ \"Continue\" | rpxTranslate }} </button>\n </div>\n <p class=\"govuk-body\">\n <a href=\"javascript:void(0)\" (click)=\"gotoCasetransationPageCancelBtnClicked($event)\" class=\"govuk-link pointer\" data-module=\"govuk-button\">\n {{ \"Return to case\" | rpxTranslate }}\n </a>\n </p>\n </div>\n </div>\n</ng-container>\n\n\n<ng-container *ngIf=\"viewStatus === 'remissionAddressPage'\">\n <input #myInput type='hidden' id='iFrameDrivenImageValue' value='ADDRESSDETAILSRETROREMISSIONPAGE'>\n <h1 class=\"govuk-heading-l\">{{ \"Process refund\" | rpxTranslate }}</h1>\n <h2 class=\"govuk-heading-m govuk-font19px\">{{ \"Case reference\" | rpxTranslate }}: {{ccdCaseNumber | ccdHyphens }}</h2>\n <ccpay-contact-details\n [addressObj] = notification\n (assignContactDetails)=\"getContactDetails($event, 'checkaddRefundpage')\"\n (redirectToIssueRefund)=\"gotoRemissionSuccess($event)\" ></ccpay-contact-details>\n <p>\n <a (click)=\"gotoCasetransationPageCancelBtnClicked($event)\" class=\"govuk-link\" data-module=\"govuk-button\">\n {{ \"Cancel\" | rpxTranslate }}\n </a>\n </p>\n\n</ng-container>\n\n<ng-container *ngIf=\"viewStatus === 'checkaddRefundpage'\">\n <input #myInput type='hidden' id='iFrameDrivenImageValue' value='CHECKRETROREMISSIONCONFIRMATION'>\n <div class=\"govuk-warning-text\">\n <h1 class=\"heading-large\"> {{ \"Check your answers\" | rpxTranslate }}</h1>\n </div>\n <table class=\"govuk-table\">\n\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Reason for refund\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{ \"Retrospective remission\" | rpxTranslate }}</td>\n </tr>\n\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Payment reference\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{remessionPayment ? remessionPayment.reference: ' '}}</td>\n </tr>\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Payment amount\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">\u00A3{{ remessionPayment ? getFormattedCurrency(remessionPayment.amount): ' ' | currency :'GBP':'symbol':'1.2-2'}} </td>\n </tr>\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Payment status\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{remessionPayment ? remessionPayment.status: '' | rpxTranslate}}</td>\n </tr>\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Fee\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{ fee.code }} - {{ fee.description | rpxTranslate }} ({{ fee.calculated_amount/fee.volume| currency:'GBP':'symbol-narrow':'1.2-2' }}) </td>\n </tr>\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Help with fees or remission reference\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{ remissionForm.controls.remissionCode.value?.trim() }}\n </td>\n </tr>\n\n <tr class=\"govuk-table__row\">\n <td *ngIf=\"remessionPayment.status === 'Success'\" class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Remission amount\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{remissionForm.controls.amount.value | currency:'GBP':'symbol-narrow':'1.2-2' }}\n </td>\n </tr>\n\n <tr class=\"govuk-table__row\">\n <td *ngIf=\"remessionPayment.status === 'Success'\" class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Refund amount\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{ getRefundAmountToBeDisplayedForContinueJourney()| currency:'GBP':'symbol-narrow':'1.2-2' }}\n </td>\n </tr>\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Send to\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{orderParty}}</td>\n </tr>\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Send via\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell whitespace-inherit\">\n <div *ngIf=\"contactDetailsObj?.notification_type === 'EMAIL'\" class=\"contactDetails-width\">\n <strong>{{ \"Email\" | rpxTranslate }}</strong>\n <br/>\n {{contactDetailsObj?.email?.trim()}}\n </div>\n <div *ngIf=\"contactDetailsObj?.notification_type === 'LETTER'\" class=\"contactDetails-width\">\n <strong>{{ \"Post\" | rpxTranslate }}</strong>\n <br/>\n {{contactDetailsObj?.address_line?.trim()}} {{contactDetailsObj?.city?.trim()}} {{contactDetailsObj?.county?.trim()}} {{contactDetailsObj?.country?.trim()}} {{contactDetailsObj?.postal_code?.trim()}}\n </div>\n <a (click)=\"gotoProcessRetroRemission(contactDetailsObj)\" class=\"govuk-link right\" >{{ \"Change\" | rpxTranslate }}</a>\n </td>\n </tr>\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Notification\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{templateInstructionType}}\n <a *ngIf=\"!notificationPreview\" href=\"Javascript:void(0)\" class=\"govuk-link right\" (click)=\"showNotificationPreview()\">\n {{ \"Preview\" | rpxTranslate }}\n </a>\n <a *ngIf=\"notificationPreview\" href=\"Javascript:void(0)\" class=\"govuk-link right\" (click)=\"hideNotificationPreview()\">\n {{ \"Hide Preview\" | rpxTranslate }}\n </a>\n </td>\n </tr>\n </table>\n\n <app-notification-preview *ngIf=\"notificationPreview\"\n [payment]=\"remessionPayment\"\n [contactDetails]=\"contactDetailsObj\"\n [refundReason]=\"'RR036'\"\n [refundAmount]=\"remissionForm.controls.amount.value\"></app-notification-preview>\n\n <button type=\"submit\" class=\"button govuk-button--secondary\" (click)=\"gotoProcessRetroRemission(contactDetailsObj)\">{{ \"Previous\" | rpxTranslate }}</button>\n <button type=\"submit\" [disabled]=\"isConfirmationBtnDisabled\" [ngClass]='isConfirmationBtnDisabled ? \"button button--disabled govuk-!-margin-right-1\" : \"button govuk-!-margin-right-1\"' (click)=\"processRefund()\"> {{ \"Submit refund\" | rpxTranslate }} </button>\n <p> <a href=\"javascript:void(0)\" (click)=\"gotoCasetransationPageCancelBtnClicked($event)\" class=\"govuk-link\" data-module=\"govuk-button\"> {{ \"Cancel\" | rpxTranslate }}</a> </p>\n\n</ng-container>\n\n<ng-container *ngIf=\"viewStatus === 'refundconfirmationpage'\">\n <input #myInput type='hidden' id='iFrameDrivenImageValue' value='RETROREMISSIONREFUNDCONFIRMATIONPAGE'>\n <div class=\"govuk-grid-row\">\n <div >\n <div class=\"govuk-panel govuk-panel--confirmation\">\n <h1 class=\"govuk-panel_remission_title\">\n {{ \"Refund submitted\" | rpxTranslate }}\n </h1>\n\n <div class=\"govuk-panel__body\">\n <p class=\"govuk-body white\"><strong class=\"white\">{{ \"Refund reference\" | rpxTranslate }}: {{refundReference}}</strong></p>\n </div>\n\n </div>\n <div *ngIf=\"isPaymentSuccess\">\n <h2 class=\"govuk-heading-l\">{{ \"What happens next\" | rpxTranslate }}</h2>\n <p class=\"govuk-body\">\n {{ \"A refund request for\" | rpxTranslate }} {{refundAmount | currency:'GBP':'symbol-narrow':'1.2-2' }} {{ \"has been created and will be passed to a team leader to approve\" | rpxTranslate }}.\n </p>\n </div>\n <p class=\"govuk-body\">\n <a href=\"javascript:void(0)\" (click)=\"gotoCasetransationPageCancelBtnClicked($event)\" class=\"govuk-link pointer\" data-module=\"govuk-button\">\n {{ \"Return to case\" | rpxTranslate }}\n </a>\n </p>\n </div>\n </div>\n\n</ng-container>\n\n<!-- Issue Refund Section -->\n<ng-container *ngIf=\"viewCompStatus === 'issuerefund' && isRefundRemission\">\n <div class=\"govuk-form-group\">\n <form [formGroup]=\"remissionForm\" novalidate>\n <h1 class=\"heading-large\">{{ \"Process refund\" | rpxTranslate }}</h1>\n <h2 class=\"heading-medium\">{{ \"Case reference\" | rpxTranslate }}:{{ccdCaseNumber | ccdHyphens }}</h2>\n <span id=\"how-contacted-conditional-hint\" class=\"form-hint govuk-font19px\">\n {{ \"Payment reference\" | rpxTranslate }}: {{paymentReference}}\n </span>\n <h3 class=\"heading-small\">{{ \"Select fees to be refunded\" | rpxTranslate }}</h3>\n <!--TABLE-->\n <div>\n <table class=\"govuk-table\">\n <thead class=\"govuk-table__head\">\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__header col-1\" scope=\"col\">{{ \"Select\" | rpxTranslate }}</td>\n <td class=\"govuk-table__header col-18\" scope=\"col\">{{ \"Fee description\" | rpxTranslate }}</td>\n <td class=\"govuk-table__header col-6\" scope=\"col\">{{ \"Fee amount\" | rpxTranslate }}</td>\n <td class=\"govuk-table__header col-6\" scope=\"col\">{{ \"Total paid\" | rpxTranslate }}</td>\n <td class=\"govuk-table__header col-6\" scope=\"col\">{{ \"Remission amount\" | rpxTranslate }}</td>\n <td class=\"govuk-table__header col-6\" scope=\"col\">{{ \"Quantity\" | rpxTranslate }}</td>\n <td class=\"govuk-table__header col-8\" scope=\"col\">{{ \"Amount to refund\" | rpxTranslate }}</td>\n <td class=\"govuk-table__header\" scope=\"col\"></td>\n </tr>\n </thead>\n <tbody class=\"govuk-table__body\" *ngIf=\"!isFullyRefund\">\n <tr class=\"govuk-table__row\" formArrayName=\"feesList\" *ngFor=\"let fee of feesList?.controls; let i = index\">\n <td class=\"govuk-table__cell\">\n <div [formGroupName]=\"i\" class=\"govuk-checkboxes govuk-checkboxes--large\" data-module=\"govuk-checkboxes\">\n <div class=\"govuk-checkboxes__item\">\n <input\n class=\"govuk-checkboxes__input\"\n (click)=\"check_en(i,fee.controls['id'].value,fee.controls['apportion_amount'].value,fee.controls['volume'].value)\"\n id=\"{{fee.controls['id'].value}}\"\n name=\"organisation\"\n type=\"checkbox\"\n value=\"{{fee.controls['id'].value}}\"\n formControlName=\"selected\" >\n <label class=\"govuk-label govuk-checkboxes__label\" for=\"{{fee.controls['id'].value}}\">\n <span style=\"display:none\">{{ \"Select\" | rpxTranslate }}</span>\n </label>\n </div>\n </div>\n </td>\n <td class=\"govuk-table__cell whitespace-inherit\">{{fee.controls['description'].value}} </td>\n <td class=\"govuk-table__cell whitespace-inherit left\" >\n <div type=\"hidden\" style=\"display:none;background-color:white;\" id=\"feeVOl_{{fee.controls['id'].value}}\">{{ fee.controls['calculated_amount'].value / fee.controls['volume'].value }}</div>\n {{ fee.controls['calculated_amount'].value / fee.controls['volume'].value | currency:'GBP':'symbol-narrow':'1.2-2' }}\n </td>\n <td class=\"govuk-table__cell whitespace-inherit left\" >{{ fee.controls['apportion_amount'].value | currency:'GBP':'symbol-narrow':'1.2-2'}} </td>\n <td class=\"govuk-table__cell whitespace-inherit left\" >\n <div type=\"hidden\" style=\"display:none;background-color:white;\" id=\"feeVOl_{{fee.controls['id'].value}}\">{{ this.getRemissionsHwfAmount(fee.controls['code'].value)}}</div>\n {{ this.getRemissionsHwfAmount(fee.controls['code'].value) | currency:'GBP':'symbol-narrow':'1.2-2' }}\n </td>\n <td class=\"govuk-table__cell whitespace-inherit left\" *ngIf=\"fee.controls['volume'].value ===1\">\n <input disabled=\"disabled\" class=\"govuk-input govuk-input--width-4 center\" id=\"VolumeUpdated_{{fee.controls['id'].value}}\" name=\"VolumeUpdated_{{fee.controls['id'].value}}\" type=\"text\" value=\"{{fee.controls['volume'].value}}\">\n </td>\n <td class=\"govuk-table__cell whitespace-inherit left\" *ngIf=\"fee.controls['volume'].value >1\">\n <div [formGroupName]=\"i\">\n <input disabled=\"disabled\" class=\"govuk-input govuk-input--width-4 center\" id=\"feeVolumeUpdated_{{fee.controls['id'].value}}\" (keyup)=\"calAmtToRefund($event.target.value,fee.controls['calculated_amount'].value,fee.controls['volume'].value,i)\" value=\"{{fee.controls['updated_volume'].value}}\" name=\"feeVolumeUpdated_{{fee.controls['id'].value}}\" formControlName=\"updated_volume\" type=\"text\" >\n </div>\n </td>\n <td class=\"govuk-table__cell whitespace-inherit center\" scope=\"row\">\n <div [formGroupName]=\"i\" class=\"hmcts-currency-input\">\n <div class=\"hmcts-currency-input__symbol\" aria-hidden=\"true\">\u00A3</div>\n <input disabled=\"disabled\" class=\"govuk-input govuk-input--width-small\" id=\"feeAmount_{{fee.controls['id'].value}}\" name=\"feeAmount_{{fee.controls['id'].value}}\" type=\"text\" aria-describedby=\"amount-currency \" pattern=\"[0-9]*\" formControlName=\"refund_amount\">\n <input id=\"feeVolume_{{fee.controls['id'].value}}\" name=\"feeVolume_{{fee.controls['id'].value}}\" value= \"{{fee.controls['volume'].value}}\" type=\"hidden\" formControlName=\"volume\">\n <input id=\"feeApportionAmount_{{fee.controls['id'].value}}\" name=\"feeApportionAmount_{{fee.controls['id'].value}}\" value= \"{{fee.controls['apportion_amount'].value}}\" type=\"hidden\" formControlName=\"apportion_amount\">\n <input id=\"calculatedAmount_{{fee.controls['id'].value}}\" name=\"calculatedAmount_{{fee.controls['id'].value}}\" value= \"{{fee.controls['calculated_amount'].value}}\" type=\"hidden\" formControlName=\"calculated_amount\">\n </div>\n </td>\n </tr>\n </tbody>\n <tbody class=\"govuk-table__body\" *ngIf=\"isFullyRefund\">\n <tr class=\"govuk-table__row\" *ngFor=\"let fee of fees; let i = index\">\n <td class=\"govuk-table__cell\">\n <div class=\"govuk-checkboxes govuk-checkboxes--large\" data-module=\"govuk-checkboxes\">\n <div class=\"govuk-checkboxes__item\">\n <input\n class=\"govuk-checkboxes__input\"\n\n id=\"{{fee.id}}\"\n name=\"organisation\"\n type=\"checkbox\"\n value=\"{{fee.id}}\"\n disabled=\"disabled\"\n [checked]=\"true\" >\n <label class=\"govuk-label govuk-checkboxes__label\" for=\"{{fee.id}}\">\n <span style=\"display:none\">{{ \"Select\" | rpxTranslate }}</span>\n </label>\n </div>\n </div>\n </td>\n <td class=\"govuk-table__cell whitespace-inherit\">{{ fee.description | rpxTranslate }} </td>\n <td class=\"govuk-table__cell whitespace-inherit left\" >\n <div type=\"hidden\" style=\"display:none;background-color:white;\" id=\"feeVOl_{{fee.id}}\">{{ fee.calculated_amount / fee.volume }}</div>\n {{ fee.calculated_amount / fee.volume| currency:'GBP':'symbol-narrow':'1.2-2' }}\n </td>\n <td class=\"govuk-table__cell whitespace-inherit left\" >{{ payment.amount | currency:'GBP':'symbol-narrow':'1.2-2'}} </td>\n\n <td class=\"govuk-table__cell whitespace-inherit left\" >\n <div type=\"hidden\" style=\"display:none;background-color:white;\" id=\"feeRemission_{{fee.id}}\">{{ this.getRemissionValueForFullyRefund()}}</div>\n {{ this.getRemissionsHwfAmount(fee.code) | currency:'GBP':'symbol-narrow':'1.2-2' }}\n\n </td>\n\n <td class=\"govuk-table__cell whitespace-inherit left\">\n <div >\n <input disabled=\"disabled\" class=\"govuk-input govuk-input--width-4 center\" id=\"feeVolumeUpdated_{{fee.id}}\" value=\"{{fee.volume}}\" name=\"feeVolumeUpdated_{{fee.id}}\" type=\"text\" >\n </div>\n </td>\n\n <td class=\"govuk-table__cell whitespace-inherit center\" scope=\"row\">\n\n <div class=\"hmcts-currency-input\">\n\n <div class=\"hmcts-currency-input__symbol\" aria-hidden=\"true\">\u00A3</div>\n <input disabled=\"disabled\" class=\"govuk-input govuk-input-width-10-left\" id=\"feeAmount_{{fee.id}}\" name=\"feeAmount_{{fee.id}}\" type=\"text\" aria-describedby=\"amount-currency \" value=\"{{ payment.amount}}\" pattern=\"[0-9]*\" >\n </div>\n\n </td>\n </tr>\n </tbody>\n <tbody class=\"govuk-table__body\" *ngIf=\"fees?.length === 0\">\n <td class=\"govuk-table__cell\" colspan=\"6\">{{ \"No fees recorded\" | rpxTranslate }}</td>\n </tbody>\n </table>\n </div>\n <div class=\"govuk-button-group\">\n\n\n <a (click)=\"gotoServiceRequestPage($event)\" *ngIf=\"!isFullyRefund\" draggable=\"false\" class=\"govuk-button govuk-button--secondary\" data-module=\"govuk-button\">\n {{ \"Previous\" | rpxTranslate }}\n </a>\n <a (click)=\"goToPaymentViewComponent()\" *ngIf=\"isFullyRefund\" draggable=\"false\" class=\"govuk-button govuk-button--secondary\" data-module=\"govuk-button\">\n {{ \"Previous\" | rpxTranslate }}\n </a>\n\n <button [disabled] = \"noneSelected()\" (click)=\"gotoIssuePage(isFullyRefund)\" class=\"govuk-button\">\n {{ \"Continue\" | rpxTranslate }}\n </button>\n\n </div>\n <p>\n <a (click)=\"gotoCasetransationPageCancelBtnClicked($event)\" class=\"govuk-link\" data-module=\"govuk-button\">{{ \"Cancel\" | rpxTranslate }}</a>\n </p>\n </form>\n </div>\n</ng-container>\n\n<ng-container *ngIf=\"viewCompStatus === 'issuerefundpage1' && isRefundRemission\">\n\n <input #myInput type='hidden' id='iFrameDrivenImageValue' value='ISSUEREFUNDPAGE'>\n <h1 class=\"heading-large\">{{ \"Process refund\" | rpxTranslate }}</h1>\n <h1 class=\"heading-medium\">{{ \"Case reference\" | rpxTranslate }}: {{ccdCaseNumber | ccdHyphens }}</h1>\n <span id=\"how-contacted-conditional-hint govuk-font19px\" *ngIf=\"payment\" class=\"form-hint\">\n {{ \"Payment reference\" | rpxTranslate }}: {{paymentReference}}\n </span>\n <span id=\"how-contacted-conditional-hint govuk-font19px\" *ngIf=\"refundPaymentReference\" class=\"form-hint\">\n {{ \"Payment reference\" | rpxTranslate }}: {{refundPaymentReference}}\n </span>\n <h1 class=\"heading-large\">{{ \"Why are you making this refund\" | rpxTranslate }}?\n </h1>\n\n\n <div class=\"govuk-form-group\">\n <form novalidate>\n <div class=\"govuk-form-group\">\n <form [formGroup]=\"remissionForm\" novalidate>\n <fieldset class=\"govuk-fieldset\" aria-describedby=\"how-contacted-conditional-hint\">\n\n <div\n [ngClass]=\"refundHasError ? 'govuk-radios govuk-radios--conditional form-group-error' : 'govuk-radios govuk-radios--conditional'\"\n data-module=\"govuk-radios\" >\n <p class=\"inline-error-message\" *ngIf=\"refundHasError\">\n <span *ngIf=\"refundHasError\">{{ \"Select a reason why you\u2019re making this refund\" | rpxTranslate }}</span>\n </p>\n\n\n\n <div class = \"container-fluid\">\n <div class=\"row\">\n <div class=\"govuk-radios__item col-md-4\" *ngFor=\"let refund of commonRefundReasons; let i = index;\">\n <!-- <div *ngIf = \"{{refund.name}} !== 'Retrospective remission'\"> -->\n <input class=\"govuk-radios__input\" id=\"{{refund.name}}\" name=\"refundReason\" type=\"radio\"\n formControlName=\"refundReason\" value={{refund.code}}\n (change)=\"selectRadioButton(refund.code, refund.name)\">\n <label class=\"govuk-label--s govuk-radios__label govuk-font__custom\" for=\"how-contacted-conditional\">\n {{refund.name}}\n </label>\n\n <div class=\"govuk-radios__conditional\" *ngIf=\"isRefundReasonsSelected && showReasonText && selectedRefundReason === refund.name \" >\n <label class=\"govuk-label govuk-label--m\" for=\"{{refund.name}}\">\n {{ \"Enter reason\" | rpxTranslate }}\n </label>\n <div [ngClass]=\"{'form-group-error': isReasonEmpty}\">\n <p class=\"inline-error-message\" *ngIf=\"isReasonEmpty\">\n <span *ngIf=\"isReasonEmpty\">{{ \"Enter a reason why you\u2019re making this refund\" | rpxTranslate }}</span>\n </p>\n\n <input class=\"govuk-input govuk-input--width-10\" [ngClass]=\"{'inline-error-class': isReasonEmpty}\" id=\"reason\" aria-label=\"reason\" name=\"reason\" type=\"text\" aria-describedby=\"reason\" maxlength=\"30\" formControlName=\"reason\">\n </div>\n </div>\n <!-- </div> -->\n </div>\n </div>\n </div>\n <br/>\n <div>\n <select formControlName=\"refundDDReason\" class=\"govuk-select\" id=\"sort\" (change)=\"selectchange($event)\">\n <option selected='selected' [defaultSelected]=true [value]=\"default\" >{{default}}</option>\n <!-- <option value=\"\" selected='selected'>Select a different reason</option> -->\n <option *ngFor=\"let refund of refundReasons;\" id=\"{{refund.name}}\" value=\"{{refund.code}}\">{{refund.name}}</option>\n </select>\n\n </div>\n <br/>\n <div class=\"govuk-radios__conditional\" *ngIf=\"showReasonText && !isRefundReasonsSelected\" >\n <div [ngClass]=\"{'form-group-error': isReasonEmpty}\">\n <label class=\"govuk-label govuk-label--m\" for=\"amount\">\n {{ \"Enter reason\" | rpxTranslate }}\n </label>\n <p class=\"inline-error-message\" *ngIf=\"isReasonEmpty\">\n <span *ngIf=\"isReasonEmpty\">{{ \"Enter a reason why you\u2019re making this refund\" | rpxTranslate }}</span>\n </p>\n <input class=\"govuk-input govuk-input--width-10\" [ngClass]=\"{'inline-error-class': isReasonEmpty}\" id=\"reason\" aria-label=\"reason\" name=\"reason\" type=\"text\" aria-describedby=\"reason\" maxlength=\"{{reasonLength}}\" formControlName=\"reason\">\n </div>\n </div>\n\n\n </div>\n </fieldset>\n </form>\n </div>\n </form>\n </div>\n <div class=\"govuk-button-group\">\n <button (click)=\"gotoPartialFeeRefundScreen()\" class=\"govuk-button govuk-button--secondary\"> {{ \"Previous\" | rpxTranslate }}</button>\n <button (click)=\"gotoIssueRefundConfirmation(payment)\" class=\"govuk-button\"> {{ \"Continue\" | rpxTranslate }}</button>\n </div>\n <p>\n <a href=\"javascript:void(0)\" (click)=\"gotoCasetransationPageCancelBtnClicked($event)\" class=\"govuk-link\" data-module=\"govuk-button\">\n {{ \"Cancel\" | rpxTranslate }}\n </a>\n </p>\n\n</ng-container>\n<ng-container *ngIf=\"viewStatus === 'contactDetailsPage'\">\n <input #myInput type='hidden' id='iFrameDrivenImageValue' value='CAPTUREADDRESSDETAILSPAGE'>\n <h1 class=\"govuk-heading-l\">{{ \"Process refund\" | rpxTranslate }}</h1>\n <h2 class=\"govuk-heading-m govuk-font19px\">{{ \"Case reference\" | rpxTranslate }}: {{ccdCaseNumber | ccdHyphens }}</h2>\n <span id=\"how-contacted-conditional-hint\" class=\"govuk-hint govuk-font19px\">\n {{ \"Payment reference\" | rpxTranslate }}: {{paymentReference}}\n </span>\n <ccpay-contact-details\n [addressObj] = notification\n (assignContactDetails)=\"getContactDetails($event, 'checkissuerefundpage')\"\n (redirectToIssueRefund)=\"gotoRefundReasonPage()\" ></ccpay-contact-details>\n <p>\n <a (click)=\"gotoCasetransationPageCancelBtnClicked($event)\" class=\"govuk-link\" data-module=\"govuk-button\">\n {{ \"Cancel\" | rpxTranslate }}\n </a>\n </p>\n\n</ng-container>\n\n<ng-container *ngIf=\"viewStatus === 'checkissuerefundpage'\">\n <input #myInput type='hidden' id='iFrameDrivenImageValue' value='CHECKISSUEREFUNDPAGE'>\n <div class=\"govuk-warning-text\">\n\n <h1 class=\"heading-large\"> {{ \"Check your answers\" | rpxTranslate }}</h1>\n </div>\n <table class=\"govuk-table\">\n\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Payment reference\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{paymentReference}}</td>\n </tr>\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Payment amount\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{payment.amount | currency:'GBP':'symbol-narrow':'1.2-2'}}</td>\n </tr>\n <tr>\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Reason for refund\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{ displayRefundReason?.trim() }}\n <a (click)=\"changeIssueRefundReason()\" class=\"govuk-link right\" >{{ \"Change\" | rpxTranslate }}</a>\n </td>\n </tr>\n <tr class=\"govuk-table__row\" *ngIf=\"!isFullyRefund\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Refund amount\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{totalRefundAmount | currency:'GBP':'symbol-narrow':'1.2-2'}}\n <a (click)=\"changeRefundAmount()\" class=\"govuk-link right\" >{{ \"Change\" | rpxTranslate }}</a>\n </td>\n </tr>\n <tr class=\"govuk-table__row\" *ngIf=\"isFullyRefund\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Refund amount\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{payment.amount | currency:'GBP':'symbol-narrow':'1.2-2'}}</td>\n </tr>\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Send to\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{orderParty}}</td>\n </tr>\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Send via\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell whitespace-inherit\">\n <div *ngIf=\"contactDetailsObj?.notification_type === 'EMAIL'\" class=\"contactDetails-width\">\n <strong>{{ \"Email\" | rpxTranslate }}</strong>\n <br/>\n {{contactDetailsObj?.email?.trim()}}\n </div>\n <div *ngIf=\"contactDetailsObj?.notification_type === 'LETTER'\" class=\"contactDetails-width\">\n <strong>{{ \"Post\" | rpxTranslate }}</strong>\n <br/>\n {{contactDetailsObj?.address_line?.trim()}} {{contactDetailsObj?.city?.trim()}} {{contactDetailsObj?.county?.trim()}} {{contactDetailsObj?.country?.trim()}} {{contactDetailsObj?.postal_code?.trim()}}\n </div>\n <a (click)=\"gotoContactDetailsPage(contactDetailsObj)\" class=\"govuk-link right\" >{{ \"Change\" | rpxTranslate }}</a>\n </td>\n </tr>\n\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Notification\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{templateInstructionType}}\n <a *ngIf=\"!notificationPreview\" href=\"Javascript:void(0)\" class=\"govuk-link right\" (click)=\"showNotificationPreview()\">\n {{ \"Preview\" | rpxTranslate }}\n </a>\n <a *ngIf=\"notificationPreview\" href=\"Javascript:void(0)\" class=\"govuk-link right\" (click)=\"hideNotificationPreview()\">\n {{ \"Hide Preview\" | rpxTranslate }}\n </a>\n </td>\n </tr>\n </table>\n\n <app-notification-preview *ngIf=\"notificationPreview\"\n [payment]=\"payment\"\n [contactDetails]=\"contactDetailsObj\"\n [refundReason]=\"selectedRefundReasonCode\"\n [refundAmount]=\"isFullyRefund ? payment.amount : totalRefundAmount\"></app-notification-preview>\n\n\n <div class=\"govuk-button-group\">\n <button type=\"submit\" class=\"button govuk-button--secondary\" (click)=\"gotoContactDetailsPage(contactDetailsObj)\"> {{ \"Previous\" | rpxTranslate }} </button>\n <button type=\"submit\"\n [disabled]=\"isConfirmationBtnDisabled\"\n [ngClass]='isConfirmationBtnDisabled ? \"button button--disabled govuk-!-margin-right-1\" : \"button govuk-!-margin-right-1\"'\n (click)=\"confirmIssueRefund(isFullyRefund)\">\n {{ \"Submit refund\" | rpxTranslate }}\n </button>\n </div>\n <p>\n <a (click)=\"gotoCasetransationPageCancelBtnClicked($event)\" class=\"govuk-link\" data-module=\"govuk-button\">\n {{ \"Cancel\" | rpxTranslate }}\n </a>\n </p>\n\n</ng-container>\n\n<!--Retro Refund-->\n<ng-container *ngIf=\"viewCompStatus === 'addrefundforremission'\">\n <input #myInput type='hidden' id='iFrameDrivenImageValue' value='ADDRESSDETAILSRETROREMISSIONPAGE'>\n <h1 class=\"govuk-heading-l\">{{ \"Process refund\" | rpxTranslate }}</h1>\n <h2 class=\"govuk-heading-m govuk-font19px\">{{ \"Case reference\" | rpxTranslate }}: {{ccdCaseNumber | ccdHyphens }}</h2>\n <span id=\"how-contacted-conditional-hint\" class=\"govuk-hint govuk-font19px\">\n {{ \"Payment reference\" | rpxTranslate }}: {{paymentReference}}\n </span>\n<ccpay-contact-details\n[addressObj] = notification\n(assignContactDetails)=\"getContactDetails($event, 'addrefundcheckandanswer')\"\n(redirectToIssueRefund)=\"gotoServiceRequestPage($event)\" ></ccpay-contact-details>\n<p>\n <a (click)=\"gotoCasetransationPageCancelBtnClicked($event)\" class=\"govuk-link\" data-module=\"govuk-button\">\n {{ \"Cancel\" | rpxTranslate }}\n </a>\n</p>\n</ng-container>\n<ng-container *ngIf=\"viewStatus === 'addrefundcheckandanswer'\">\n <input #myInput type='hidden' id='iFrameDrivenImageValue' value='ADDREFUNDFORREMISSION'>\n <div class=\"govuk-warning-text\">\n\n <h1 class=\"heading-large\"> {{ \"Check your answers\" | rpxTranslate }}</h1>\n </div>\n <table class=\"govuk-table\">\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Reason for refund\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{ \"Retrospective remission\" | rpxTranslate }}</td>\n </tr>\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Payment reference\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{paymentReference}}</td>\n </tr>\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Refund amount\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{getRefundAmountToBeDisplayed(remission)| currency:'GBP':'symbol-narrow':'1.2-2'}}</td>\n </tr>\n\n <tr class=\"govuk-table__row\">\n <td *ngIf=\"remessionPayment.status === 'Success'\" class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Remission amount\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{getRemissionAmountToBeDisplayed(remission)| currency:'GBP':'symbol-narrow':'1.2-2' }}\n </td>\n </tr>\n\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Fee code\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{remission.fee_code}}</td>\n </tr>\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Fee amount\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{feeamount | currency:'GBP':'symbol-narrow':'1.2-2'}}</td>\n </tr>\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Send to\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{orderParty}}</td>\n </tr>\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Send via\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell whitespace-inherit\">\n <div *ngIf=\"contactDetailsObj?.notification_type === 'EMAIL'\" class=\"contactDetails-width\">\n <strong>{{ \"Email\" | rpxTranslate }}</strong>\n <br/>\n {{contactDetailsObj?.email?.trim()}}\n </div>\n <div *ngIf=\"contactDetailsObj?.notification_type === 'LETTER'\" class=\"contactDetails-width\">\n <strong>{{ \"Post\" | rpxTranslate }}</strong>\n <br/>\n {{contactDetailsObj?.address_line?.trim()}} {{contactDetailsObj?.city?.trim()}} {{contactDetailsObj?.county?.trim()}} {{contactDetailsObj?.country?.trim()}} {{contactDetailsObj?.postal_code?.trim()}}\n </div>\n <a (click)=\"gotoAddressPage(contactDetailsObj)\" class=\"govuk-link right\" >{{ \"Change\" | rpxTranslate }}</a>\n </td>\n </tr>\n\n <tr class=\"govuk-table__row\">\n <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Notification\" | rpxTranslate }}</td>\n <td class=\"govuk-table__cell\">{{templateInstructionType}}\n <a *ngIf=\"!notificationPreview\" href=\"Javascript:void(0)\" class=\"govuk-link right\" (click)=\"showNotificationPreview()\">\n {{ \"Preview\" | rpxTranslate }}\n </a>\n <a *ngIf=\"notificationPreview\" href=\"Javascript:void(0)\" class=\"govuk-link right\" (click)=\"hideNotificationPreview()\">\n {{ \"Hide Preview\" | rpxTranslate }}\n </a>\n </td>\n </tr>\n </table>\n\n <app-notification-preview *ngIf=\"notificationPreview\"\n [contactDetails]=\"contactDetailsObj\"\n [paymentReference]=\"paymentReference\"\n [payment]=\"paymentObj\"\n [refundReason]=\"'RR036'\"\n [refundAmount]=\"remission.hwf_amount\"></app-notification-preview>\n\n <div class=\"govuk-button-group\">\n <button type=\"submit\" class=\"button govuk-button--secondary\" (click)=\"gotoAddressPage(contactDetailsObj)\">{{ \"Previous\" | rpxTranslate }}</button>\n <button type=\"submit\"\n [disabled]=\"isConfirmationBtnDisabled\"\n [ngClass]='isConfirmationBtnDisabled ? \"button button--disabled govuk-!-margin-right-1\" : \"button govuk-!-margin-right-1\"'\n (click)=\"processRefund()\">\n {{ \"Submit refund\" | rpxTranslate }}\n </button>\n </div>\n <p>\n <a href=\"javascript:void(0)\" (click)=\"gotoCasetransationPageCancelBtnClicked($event)\" class=\"govuk-link\" data-module=\"govuk-button\">\n {{ \"Cancel\" | rpxTranslate }}\n </a>\n </p>\n\n</ng-container>\n\n<ng-container *ngIf=\"viewStatus === 'retrorefundconfirmationpage'\">\n <div class=\"govuk-grid-row\">\n <div >\n <div class=\"govuk-panel govuk-panel--confirmation\">\n <h1 class=\"govuk-panel_remission_title\">\n {{ \"Refund submitted\" | rpxTranslate }}\n </h1>\n\n <div class=\"govuk-panel__body\">\n <p class=\"govuk-body white\"><strong class=\"white\">{{ \"Refund reference\" | rpxTranslate }}: {{refundReference}}</strong></p>\n </div>\n\n </div>\n <div *ngIf=\"isPaymentSuccess\">\n <h2 class=\"govuk-heading-l\">{{ \"What happens next\" | rpxTranslate }}</h2>\n <p class=\"govuk-body\">\n {{ \"A refund request for\" | rpxTranslate }} {{ refundAmount| currency:'GBP':'symbol-narrow':'1.2-2'}} {{ \"has been passed to a team leader to approve\" | rpxTranslate }}.\n </p>\n </div>\n <p class=\"govuk-body\">\n <a href=\"javascript:void(0)\" (click)=\"gotoCasetransationPageCancelBtnClicked($event)\" class=\"govuk-link pointer\" data-module=\"govuk-button\">\n {{ \"Return to case\" | rpxTranslate }}\n </a>\n </p>\n </div>\n </div>\n</ng-container>\n\n<ng-container *ngIf=\"viewStatus === 'order-full-view'\">\n <ccpay-service-request\n [viewStatus] = \"viewStatus\"\n [orderRef] = \"orderRef\"\n [isServiceRequest]=\"isServiceRequest\"\n [orderStatus] = \"orderStatus\"\n [orderCreated] = \"orderCreated\"\n [orderParty] = \"orderParty\"\n [orderCCDEvent] = \"orderCCDEvent\"\n [orderDetail] = \"orderDetail\"\n [LOGGEDINUSERROLES] = \"LOGGEDINUSERROLES\"\n [takePayment] = \"takePayment\"\n [ccdCaseNumber] = \"ccdCaseNumber\"\n [orderFeesTotal] = \"orderFeesTotal\"\n [orderTotalPayments] = \"orderTotalPayments\"\n [orderRemissionTotal] = \"orderRemissionTotal\">\n</ccpay-service-request>\n</ng-container>\n\n<ng-container *ngIf=\"viewStatus === 'payment-view'\">\n <ccpay-payment-view\n [LOGGEDINUSERROLES] = \"LOGGEDINUSERROLES\"\n [isTurnOff] = \"isTurnOff\"\n [isTakePayment] = \"takePayment\"\n [caseType] = \"caseType\"\n [isServiceRequest]=\"isServiceRequest\"\n [orderRef] = \"orderRef\"\n [orderStatus] = \"orderStatus\"\n [orderCreated] = \"orderCreated\"\n [orderParty] = \"orderParty\"\n [orderCCDEvent] = \"orderCCDEvent\"\n [orderDetail] = \"orderDetail\"\n [orderFeesTotal] = \"orderFeesTotal\"\n [orderTotalPayments] = \"orderTotalPayments\"\n [orderRemissionTotal] = \"orderRemissionTotal\"\n >\n</ccpay-payment-view>\n</ng-container>\n\n</div>\n", styles: [".add-remission .button{margin:20px 2px;padding:.5em;font-size:19px;font-weight:200}.add-remission td.govuk-table__cell{width:50%}.add-remission .govuk-button--secondary{background-color:#dee0e2;box-shadow:0 2px #858688;color:#0b0c0c;margin-right:.5em}.add-remission .govuk-warning-text__text,.add-remission .govuk-label--s,.add-remission .label_remission__symbol{font-size:19px;font-weight:400}.add-remission .inline-error-class{outline:3px solid #a71414;outline-offset:0;border-color:#a71414}.add-remission .inline-error-message{color:#a71414;border-color:#a71414;font-weight:700;margin-top:10px;font-size:20px}.add-remission .govuk-button,.add-remission .govuk-link{margin-right:1em;font-size:19px;font-weight:200}.add-remission .govuk-button-group{padding-top:2em}.add-remission .heading-medium{margin-top:.875em}.add-remission .heading-large{margin-top:.25em}.add-remission .govuk-panel--confirmation{color:#fff;background:#00703c}.add-remission .govuk-panel__title{font-size:5rem}.add-remission .govuk-body-m,.add-remission .govuk-body{font-size:2.1875rem}.add-remission .govuk-radios__item{clear:initial!important;display:inline-block;width:45%!important}.add-remission .govuk-radios__conditional{padding-top:12px!important}.add-remission .right{float:right;cursor:pointer}.add-remission .radio{float:right}.govuk-input,.govuk-font19px{font-size:19px}.govuk-select{font-size:19px;font-weight:400}.govuk-input--width-10{max-width:50ex}.govuk-input--width-small{max-width:110px}.govuk-input-width-10-left{max-width:50ex;padding-left:40px}.govuk-label--m{font-size:19px;font-weight:400}.govuk-error-summary__body{font-size:19px!important}.govuk-error-summary__title{font-size:24px!important}.govuk-panel_remission_title{margin-top:0;margin-bottom:30px;color:#fff;font-family:nta,Arial,sans-serif;-webkit-font-smoothing:antialiased;font-weight:700;font-size:48px}.white{color:#fff}.pagesize{margin:2em;width:97%}.pointer{cursor:pointer}.col-18{min-width:18em}.col-6{min-width:6em}.col-8{min-width:8em}.col-1{min-width:1em}.col-25{width:25%!important}.col-24{width:24%!important}.left{text-align:left}.center{text-align:center}.col-60{width:60%;text-align:left}.margin-top--size{margin-top:-30px}.contactDetails-width{width:70%}.right{cursor:pointer}.form-hint{font-size:19px!important}.govuk-panel-border--confirmation{color:#0b0c0c;border:5px solid #00703C}.whitespace-inherit{white-space:inherit!important}.govuk-link{cursor:pointer}.hmcts-currency-input__symbol{font-family:nta,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px;line-height:initial;position:absolute;font-weight:200;padding:8px 10px;height:40px;box-sizing:border-box;background-color:#dee0e2;border:2px solid #0b0c0c}\n"] }]
|
|
1187
|
+
}], ctorParameters: () => [{ type: i1.FormBuilder }, { type: i2.Router }, { type: i3.PaymentViewService }, { type: i4.NotificationService }, { type: undefined, decorators: [{
|
|
1188
|
+
type: Inject,
|
|
1189
|
+
args: ['PAYMENT_LIB']
|
|
1190
|
+
}] }, { type: i5.RefundsService }, { type: i0.ChangeDetectorRef }, { type: i6.OrderslistService }], propDecorators: { fee: [{
|
|
1191
|
+
type: Input
|
|
1192
|
+
}], fees: [{
|
|
1193
|
+
type: Input
|
|
1194
|
+
}], payment: [{
|
|
1195
|
+
type: Input
|
|
1196
|
+
}], remission: [{
|
|
1197
|
+
type: Input
|
|
1198
|
+
}], ccdCaseNumber: [{
|
|
1199
|
+
type: Input
|
|
1200
|
+
}], caseType: [{
|
|
1201
|
+
type: Input
|
|
1202
|
+
}], viewCompStatus: [{
|
|
1203
|
+
type: Input
|
|
1204
|
+
}], paymentGroupRef: [{
|
|
1205
|
+
type: Input
|
|
1206
|
+
}], isTurnOff: [{
|
|
1207
|
+
type: Input
|
|
1208
|
+
}], isRefundRemission: [{
|
|
1209
|
+
type: Input
|
|
1210
|
+
}], isStrategicFixEnable: [{
|
|
1211
|
+
type: Input
|
|
1212
|
+
}], paidAmount: [{
|
|
1213
|
+
type: Input
|
|
1214
|
+
}], isFromRefundListPage: [{
|
|
1215
|
+
type: Input
|
|
1216
|
+
}], isFromPaymentDetailPage: [{
|
|
1217
|
+
type: Input
|
|
1218
|
+
}], isFromServiceRequestPage: [{
|
|
1219
|
+
type: Input
|
|
1220
|
+
}], isFullyRefund: [{
|
|
1221
|
+
type: Input,
|
|
1222
|
+
args: ['isFullyRefund']
|
|
1223
|
+
}], feeamount: [{
|
|
1224
|
+
type: Input
|
|
1225
|
+
}], refundPaymentReference: [{
|
|
1226
|
+
type: Input
|
|
1227
|
+
}], isFromRefundStatusPage: [{
|
|
1228
|
+
type: Input
|
|
1229
|
+
}], changeRefundReason: [{
|
|
1230
|
+
type: Input
|
|
1231
|
+
}], isServiceRequest: [{
|
|
1232
|
+
type: Input,
|
|
1233
|
+
args: ["isServiceRequest"]
|
|
1234
|
+
}], LOGGEDINUSERROLES: [{
|
|
1235
|
+
type: Input,
|
|
1236
|
+
args: ['LOGGEDINUSERROLES']
|
|
1237
|
+
}], orderDetail: [{
|
|
1238
|
+
type: Input,
|
|
1239
|
+
args: ['orderDetail']
|
|
1240
|
+
}], orderRef: [{
|
|
1241
|
+
type: Input,
|
|
1242
|
+
args: ['orderRef']
|
|
1243
|
+
}], orderStatus: [{
|
|
1244
|
+
type: Input,
|
|
1245
|
+
args: ['orderStatus']
|
|
1246
|
+
}], orderParty: [{
|
|
1247
|
+
type: Input,
|
|
1248
|
+
args: ['orderParty']
|
|
1249
|
+
}], orderCreated: [{
|
|
1250
|
+
type: Input,
|
|
1251
|
+
args: ['orderCreated']
|
|
1252
|
+
}], orderCCDEvent: [{
|
|
1253
|
+
type: Input,
|
|
1254
|
+
args: ['orderCCDEvent']
|
|
1255
|
+
}], takePayment: [{
|
|
1256
|
+
type: Input,
|
|
1257
|
+
args: ['takepayment']
|
|
1258
|
+
}], orderFeesTotal: [{
|
|
1259
|
+
type: Input,
|
|
1260
|
+
args: ['orderFeesTotal']
|
|
1261
|
+
}], orderTotalPayments: [{
|
|
1262
|
+
type: Input,
|
|
1263
|
+
args: ['orderTotalPayments']
|
|
1264
|
+
}], orderRemissionTotal: [{
|
|
1265
|
+
type: Input,
|
|
1266
|
+
args: ['orderRemissionTotal']
|
|
1267
|
+
}], cancelRemission: [{
|
|
1268
|
+
type: Output
|
|
1269
|
+
}], refundListReason: [{
|
|
1270
|
+
type: Output
|
|
1271
|
+
}], refundListAmount: [{
|
|
1272
|
+
type: Output
|
|
1273
|
+
}], refundFees: [{
|
|
1274
|
+
type: Output
|
|
1275
|
+
}] } });
|
|
1276
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"add-remission.component.js","sourceRoot":"","sources":["../../../../../../projects/payment-lib/src/lib/components/add-remission/add-remission.component.ts","../../../../../../projects/payment-lib/src/lib/components/add-remission/add-remission.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectorRef, Component, EventEmitter, forwardRef, Inject, Input, OnInit, Output} from '@angular/core';\nimport {\n  FormArray,\n  FormBuilder,\n  FormControl,\n  FormGroup,\n  FormsModule,\n  ReactiveFormsModule,\n  Validators\n} from '@angular/forms';\nimport {IFee} from '../../interfaces/IFee';\nimport {Router} from '@angular/router';\nimport {AddRemissionRequest} from '../../interfaces/AddRemissionRequest';\nimport {PaymentViewService} from '../../services/payment-view/payment-view.service';\n\nimport {IPayment} from '../../interfaces/IPayment';\nimport {RefundsService} from '../../services/refunds/refunds.service';\nimport {NotificationService} from '../../services/notification/notification.service';\nimport {IRefundReasons} from '../../interfaces/IRefundReasons';\nimport {AddRetroRemissionRequest} from '../../interfaces/AddRetroRemissionRequest';\nimport {IRefundContactDetails} from '../../interfaces/IRefundContactDetails';\nimport {PostRefundRetroRemission} from '../../interfaces/PostRefundRetroRemission';\nimport {PostIssueRefundRetroRemission} from '../../interfaces/PostIssueRefundRetroRemission';\nimport {IRemission} from '../../interfaces/IRemission';\nimport {OrderslistService} from '../../services/orderslist.service';\nimport {IPaymentGroup} from '../../interfaces/IPaymentGroup';\nimport {PaymentViewComponent} from '../payment-view/payment-view.component';\nimport {CommonModule} from '@angular/common';\nimport {ServiceRequestComponent} from '../service-request/service-request.component';\nimport {NotificationPreviewComponent} from '../notification-preview/notification-preview.component';\nimport {CcdHyphensPipe} from '../../pipes/ccd-hyphens.pipe';\nimport {CapitalizePipe} from '../../pipes/capitalize.pipe';\nimport {ContactDetailsComponent} from '../contact-details/contact-details.component';\nimport {RpxTranslationModule} from 'rpx-xui-translation';\nimport type { PaymentLibComponent } from '../../payment-lib.component';\n\ntype PaymentLibAlias = PaymentLibComponent;\n\nconst BS_ENABLE_FLAG = 'bulk-scan-enabling-fe';\nconst resolvedPromise = Promise.resolve(null);\n\n@Component({\n  selector: 'ccpay-add-remission',\n  templateUrl: './add-remission.component.html',\n  styleUrls: ['./add-remission.component.scss'],\n  providers: [{ provide: 'ADD_REMISSION', useExisting: AddRemissionComponent }],\n  imports: [\n    forwardRef(() => PaymentViewComponent),\n    CommonModule,\n    forwardRef(() => ServiceRequestComponent),\n    forwardRef(() => NotificationPreviewComponent),\n    forwardRef(() => ContactDetailsComponent),\n    CcdHyphensPipe,\n    CapitalizePipe,\n    FormsModule,\n    ReactiveFormsModule,\n    RpxTranslationModule\n  ],\n  standalone: true\n})\nexport class AddRemissionComponent implements OnInit {\n  @Input() fee: IFee;\n  @Input() fees: any[];\n  @Input() payment: IPayment;\n  @Input() remission: IRemission;\n  @Input() ccdCaseNumber: string;\n  @Input() caseType: string;\n  @Input() viewCompStatus: string;\n  @Input() paymentGroupRef: string;\n  @Input() isTurnOff: boolean;\n  @Input() isRefundRemission: boolean;\n  @Input() isStrategicFixEnable: boolean;\n  @Input() paidAmount: any;\n  @Input() isFromRefundListPage: boolean;\n  @Input() isFromPaymentDetailPage: boolean;\n  @Input() isFromServiceRequestPage: boolean;\n  @Input('isFullyRefund') isFullyRefund: boolean;\n  @Input() feeamount: number;\n  @Input() refundPaymentReference: string;\n  @Input() isFromRefundStatusPage: boolean;\n  @Input() changeRefundReason: string;\n  @Input(\"isServiceRequest\") isServiceRequest: string;\n  @Input('LOGGEDINUSERROLES') LOGGEDINUSERROLES: string[];\n  @Input('orderDetail') orderDetail: any[];\n  @Input('orderRef') orderRef: string;\n  @Input('orderStatus') orderStatus: string;\n  @Input('orderParty') orderParty: string;\n  @Input('orderCreated') orderCreated: Date;\n  @Input('orderCCDEvent') orderCCDEvent: string;\n  @Input('takepayment') takePayment: boolean;\n  @Input('orderFeesTotal') orderFeesTotal: number;\n  @Input('orderTotalPayments') orderTotalPayments: number;\n  @Input('orderRemissionTotal') orderRemissionTotal: number;\n  @Output() cancelRemission: EventEmitter<void> = new EventEmitter();\n  //@Output() refundListReason: EventEmitter<any> = new EventEmitter({reason:string, code:string});\n  @Output() refundListReason = new EventEmitter<{ reason: string, code: string }>();\n  @Output() refundListAmount: EventEmitter<string> = new EventEmitter();\n  @Output() refundFees: EventEmitter<IFee[]> = new EventEmitter<IFee[]>();\n  refund = {\n    reason: {\n      duplicate: 'Duplicate payment',\n      humanerror: 'Human error',\n      caseWithdrawn: 'Case withdrawn',\n      other: 'Other'\n    }\n  }\n  contactDetailsObj: IRefundContactDetails;\n  notification: any;\n  remissionForm: FormGroup;\n  hasErrors = false;\n  viewStatus = 'main';\n  errorMessage = null;\n  option: string = null;\n  isConfirmationBtnDisabled: boolean = false;\n  bsPaymentDcnNumber: string;\n  selectedValue = 'yes';\n  amount: any;\n  retroRemission: boolean = false;\n  remissionReference: string = '';\n  refundReference: string;\n  refundAmount: string;\n  paymentExplanationHasError: boolean = false;\n  refundReason: string;\n  selectedRefundReason: string;\n  selectedRefundReasonCode: string;\n  displayRefundReason: string;\n  refundCode: string;\n  remessionPayment: IPayment;\n  isRemissionCodeEmpty: boolean = false;\n  remissionCodeHasError: boolean = false;\n  isAmountEmpty: boolean = false;\n  isReasonEmpty: boolean = false;\n  amountHasError: boolean = false;\n  isRemissionLessThanFeeError: boolean = false;\n  refundHasError: boolean = false;\n  isPaymentSuccess: boolean = false;\n  isRemissionApplied: boolean = false;\n  remissionamt: number;\n  elementId: any;\n  // refundReasons: any[] = [];\n  commonRefundReasons: any[] = [];\n  showReasonText: boolean;\n  isRefundReasonsSelected: boolean;\n  default: string;\n  reasonLength: number;\n  refundReasons: IRefundReasons[];\n  pattern1: string;\n  pattern2: string;\n  sendOrderDetail: any[];\n  sendOrderRef: string;\n  paymentReference: string;\n  class = '';\n  errorMsg = new Array();\n  totalRefundAmount: number;\n  quantityUpdated: number;\n  fullRefund: boolean;\n  allowedRefundAmount: number;\n  isRemissionsMatch: boolean;\n  paymentFees: IFee[];\n  paymentGroup: IPaymentGroup;\n  isStatusAllocated: boolean;\n  isFromCheckAnsPage: boolean;\n  refundAmtForFeeVolumes: number;\n  paymentObj: IPayment;\n  templateInstructionType: string;\n  notificationPreview: boolean;\n\n  component: { account_number: string; amount: number; case_reference: string; ccd_case_number: string; channel: string; currency: string; customer_reference: string; date_created: string; date_updated: string; description: string; method: string; organisation_name: string; payment_allocation: any[]; reference: string; service_name: string; site_id: string; status: string; };\n\n  constructor(private formBuilder: FormBuilder,\n    private router: Router,\n    private paymentViewService: PaymentViewService,\n    private notificationService: NotificationService,\n    @Inject('PAYMENT_LIB') private paymentLibComponent: PaymentLibAlias,\n    private refundService: RefundsService,\n    private cd: ChangeDetectorRef,\n    private OrderslistService: OrderslistService) { }\n\n  ngOnInit() {\n    this.errorMessage = '';\n    this.errorMsg = [];\n    this.default = 'Select a different reason';\n    this.pattern1 = '^([a-zA-Z0-9]{3})-([a-zA-Z0-9]{3})-([a-zA-Z0-9]{3})$';\n    this.pattern2 = '^([A-Za-z]{2}[0-9]{2})-([0-9]{6})$';\n    if (this.viewCompStatus !== '' && this.viewCompStatus !== undefined) {\n      this.viewStatus = '';\n    }\n    if (this.remission) {\n    }\n    if (this.fee) {\n      this.amount = (this.fee.volume * this.fee.calculated_amount);\n    }\n\n    if (this.payment) {\n      this.paymentReference = this.payment.reference;\n      this.remessionPayment = this.payment;\n      if (this.payment.status === 'Success') {\n        this.isPaymentSuccess = true;\n      }\n    }\n    this.option = this.paymentLibComponent.SELECTED_OPTION;\n    this.bsPaymentDcnNumber = this.paymentLibComponent.bspaymentdcn;\n    this.remissionForm = this.formBuilder.group({\n      remissionCode: new FormControl('',\n        Validators.compose([\n          Validators.required,\n          Validators.pattern(`(${this.pattern1})|(${this.pattern2})`)\n        ])\n      ),\n      amount: new FormControl('', Validators.compose([\n        Validators.required,\n        Validators.pattern('^[0-9]+(\\.[0-9]{1,2})?$')\n      ])),\n      refundReason: new FormControl('', Validators.compose([Validators.required])),\n      refundDDReason: new FormControl('', Validators.compose([Validators.required])),\n      reason: new FormControl(),\n      feeAmount: new FormControl(),\n      feesList: this.formBuilder.array([])\n    });\n    const remissionctrls = this.remissionForm.controls;\n    remissionctrls['refundDDReason'].setValue('Select a different reason', { onlySelf: true });\n    if (this.refundPaymentReference !== undefined && this.refundPaymentReference.length > 0) {\n      this.paymentReference = this.refundPaymentReference\n    } else {\n      this.paymentReference = (this.payment !== undefined) ? this.payment.reference : '';\n    }\n\n    // PAY-7956: Refresh paymentGroup if this.paymentReference is known.\n    // this call was originally based on if (this.isFromServiceRequestPage) {\n    if (this.paymentReference) {\n      this.paymentViewService.getApportionPaymentDetails(this.paymentReference).subscribe(\n        paymentGroup => {\n          let fees = [];\n          paymentGroup.fees.forEach(fee => {\n            this.isRemissionsMatch = false;\n            paymentGroup.remissions.forEach(rem => {\n              if (rem.fee_code === fee.code) {\n                this.isRemissionsMatch = true;\n                fee['remissions'] = rem;\n                fees.push(fee);\n              }\n            });\n            if (!this.isRemissionsMatch) {\n              fees.push(fee);\n            }\n          });\n          paymentGroup.fees = fees\n          this.paymentFees = fees;\n          this.fees = fees;\n          this.paymentGroup = paymentGroup;\n          this.paymentGroup.payments = this.paymentGroup.payments.filter\n            (paymentGroupObj => paymentGroupObj['reference'].includes(this.paymentLibComponent.paymentReference));\n          // const paymentAllocation = this.paymentGroup.payments[0].payment_allocation;\n          // this.isStatusAllocated = paymentAllocation.length > 0 && paymentAllocation[0].allocation_status === 'Allocated' || paymentAllocation.length === 0;\n          this.paymentLibComponent.addPaymentGroup(this.paymentGroup);\n          this.refundFeesList();\n        },\n        (error: any) => this.errorMessage = error\n      );\n    }\n\n    if (this.viewCompStatus === '') {\n      this.viewStatus = 'main';\n    }\n\n    if (this.viewCompStatus === 'issuerefundpage1') {\n      this.refundService.getRefundReasons().subscribe(\n        refundReasons => {\n          this.refundReasons = refundReasons.filter((data) => data.recently_used === false);\n          this.refundReasons = this.refundReasons.filter((data) => data.name !== 'Retrospective remission' && data.name !== 'Overpayment');\n          this.cd.detectChanges();\n          this.commonRefundReasons = refundReasons.filter((data) => data.recently_used === true);\n          this.commonRefundReasons.sort((a, b) => a.toString().localeCompare(b));\n          this.cd.detectChanges();\n        });\n      this.refundReason = this.changeRefundReason;\n    }\n\n    if (this.viewCompStatus === 'processretroremissonpage' && this.isFromRefundListPage) {\n      this.viewStatus = 'processretroremissonpage';\n    }\n    if (this.orderDetail !== undefined) {\n      this.paymentViewService.getApportionPaymentDetails(this.orderDetail[0].payments[0].reference).subscribe(\n        paymentGroup => {\n          this.fees = paymentGroup.fees;\n          this.paymentReference = paymentGroup.payments[0].reference;\n        },\n        (error: any) => this.errorMessage = error\n      );\n    }\n\n  }\n  goToPaymentViewComponent() {\n    this.paymentLibComponent.paymentMethod = this.payment.method;\n    this.paymentLibComponent.paymentGroupReference = this.paymentGroupRef;\n    this.paymentLibComponent.paymentReference = this.paymentReference;\n    //this.PaymentViewComponent.viewCompStatus = 'overpayment';\n    this.paymentLibComponent.viewName = 'payment-view';\n  }\n  refundFeesList() {\n    const creds = this.remissionForm.controls.feesList as FormArray;\n    // if(creds.controls.length > 0) {\n    for (var i = 0; i < this.fees.length; i++) {\n      creds.push(this.formBuilder.group({\n        id: this.fees[i].id,\n        code: this.fees[i].code,\n        volume: this.fees[i].volume,\n        calculated_amount: this.fees[i].calculated_amount,\n        apportion_amount: this.fees[i].apportion_amount,\n        ccd_case_number: this.fees[i].ccd_case_number,\n        description: this.fees[i].description,\n        net_amount: this.fees[i].net_amount,\n        version: this.fees[i].version,\n        refund_amount: [''],\n        selected: [''],\n        updated_volume: this.fees[i].volume\n      }));\n    }\n    this.cd.detectChanges();\n    //}\n  }\n\n  get feesList() {\n    const dd = this.remissionForm.get('feesList') as FormArray;\n    return this.remissionForm.get('feesList') as FormArray;\n  }\n\n  noneSelected() {\n    if (this.isFullyRefund) {\n      return false;\n    } else {\n      if (!this.feesList.controls.some(item => item.get('selected').value === true)) {\n        this.errorMsg = [];\n        [].forEach.call(document.querySelectorAll('input'), function (el) {\n          el.classList.remove('inline-error-class');\n        });\n      }\n      return !this.feesList.controls.some(item => item.get('selected').value === true);\n    }\n  }\n\n  calculateRefundAmount(index, AppAmt) {\n    const formArray = this.remissionForm.controls.feesList as FormArray;\n    if (this.isRemissionEnabled(formArray.value.at(index).code)) {\n      let remission = this.getRemissions(formArray.value.at(index).code);\n      let feeAmount = this.paymentLibComponent.paymentGroup.fees.at(index).calculated_amount;\n      return this.getNetAmountFee(remission.hwf_amount, feeAmount);\n    } else {\n      return AppAmt;\n    }\n  }\n\n  check_en(i, v1: any, AppAmt, Volume) {\n    const ele = document.getElementById(v1) as HTMLInputElement;\n    const formArray = this.remissionForm.controls.feesList as FormArray;\n\n    if (ele.checked) {\n      // Checkbox checked at index: 0, v1: 6012667, AppAmt: 100, Volume: 1\n      let refundAmount = this.calculateRefundAmount(i, AppAmt);\n      formArray.at(i).get('refund_amount').setValue(refundAmount);\n      formArray.at(i).get('volume').setValue(Volume);\n      formArray.at(i).get('selected').setValue(true);\n      formArray.at(i).get('updated_volume').setValue(Volume);\n      (<HTMLInputElement>document.getElementById('feeAmount_' + v1)).value = refundAmount;\n      document.getElementById('feeAmount_' + v1).removeAttribute(\"disabled\");\n      if (Volume === 1) {\n        (<HTMLInputElement>document.getElementById('VolumeUpdated_' + v1)).value = Volume;\n      } else {\n        (<HTMLInputElement>document.getElementById('feeVolumeUpdated_' + v1)).value = Volume;\n      }\n\n      if (document.getElementById('feeVolumeUpdated_' + v1) !== null) {\n        document.getElementById('feeAmount_' + v1).removeAttribute(\"disabled\");\n        document.getElementById('feeVolumeUpdated_' + v1).removeAttribute(\"disabled\");\n      }\n      this.cd.detectChanges();\n    } else {\n      this.errorMsg = [];\n      document.getElementById('feeAmount_' + v1).setAttribute(\"disabled\", \"true\");\n      this.remissionForm.value.feesList[i][\"refund_amount\"] = '';\n      this.remissionForm.value.feesList[i][\"volume\"] = '';\n      this.remissionForm.value.feesList[i][\"selected\"] = false;\n      (<HTMLInputElement>document.getElementById('feeAmount_' + v1)).value = '';\n      if (Volume > 1) {\n        this.remissionForm.value.feesList[i][\"volume\"] = '';\n        (<HTMLInputElement>document.getElementById('feeVolumeUpdated_' + v1)).value = '';\n      }\n\n      if (document.getElementById('feeVolumeUpdated_' + v1) !== null) {\n        document.getElementById('feeVolumeUpdated_' + v1).removeAttribute(\"disabled\");\n      }\n      this.cd.detectChanges();\n    }\n  }\n\n\n  addRemission() {\n    this.resetRemissionForm([false, false, false, false, false, false], 'All');\n    const remissionctrls = this.remissionForm.controls,\n      isRemissionLessThanFee = this.fee.calculated_amount > remissionctrls.amount.value;\n    this.remissionForm.controls['refundReason'].setErrors(null);\n    this.remissionForm.controls['refundDDReason'].setErrors(null);\n    if (this.remissionForm.dirty && this.remissionForm.valid && isRemissionLessThanFee) {\n      this.viewStatus = 'confirmation';\n    } else {\n\n      if (remissionctrls['remissionCode'].value == '') {\n        this.resetRemissionForm([true, false, false, false, false, false], 'remissionCode');\n      }\n      if (remissionctrls['remissionCode'].value != '' && remissionctrls['remissionCode'].invalid) {\n        this.resetRemissionForm([false, true, false, false, false, false], 'remissionCode');\n      }\n      if (remissionctrls['amount'].value == '') {\n        this.resetRemissionForm([false, false, true, false, false, false], 'amount');\n      }\n      if (remissionctrls['amount'].value != '' && remissionctrls['amount'].invalid) {\n        this.resetRemissionForm([false, true, false, true, false, false], 'amount');\n      }\n      if (remissionctrls.amount.valid && !isRemissionLessThanFee) {\n        this.resetRemissionForm([false, false, false, false, true, false], 'amount');\n      }\n    }\n  }\n\n  confirmRemission() {\n    this.isConfirmationBtnDisabled = true;\n    const newNetAmount = this.remissionForm.controls.amount.value,\n      remissionAmount = parseFloat((this.fee.net_amount - newNetAmount).toFixed(2)),\n      requestBody = new AddRemissionRequest\n        (this.ccdCaseNumber, this.fee, remissionAmount, this.remissionForm.controls.remissionCode.value, this.caseType);\n    this.paymentViewService.postPaymentGroupWithRemissions(decodeURIComponent(this.paymentGroupRef).trim(), this.fee.id, requestBody).subscribe(\n      response => {\n        if (JSON.parse(response).success) {\n          let LDUrl = this.isTurnOff ? '&isTurnOff=Enable' : '&isTurnOff=Disable'\n          LDUrl += `&caseType=${this.caseType}`\n          if (this.paymentLibComponent.bspaymentdcn) {\n            this.router.routeReuseStrategy.shouldReuseRoute = () => false;\n            this.router.onSameUrlNavigation = 'reload';\n            this.router.navigateByUrl(`/payment-history/${this.ccdCaseNumber}?view=fee-summary&selectedOption=${this.option}&paymentGroupRef=${this.paymentGroupRef}&dcn=${this.paymentLibComponent.bspaymentdcn}${LDUrl}`);\n          } else {\n            this.gotoCasetransationPage();\n          }\n        }\n      },\n      (error: any) => {\n        this.errorMessage = error;\n        this.isConfirmationBtnDisabled = false;\n      }\n    );\n  }\n\n  resetRemissionForm(val, field) {\n    if (field === 'All') {\n      this.isRemissionCodeEmpty = val[0];\n      this.remissionCodeHasError = val[1];\n      this.isAmountEmpty = val[2];\n      this.amountHasError = val[3];\n      this.isRemissionLessThanFeeError = val[4];\n      this.isReasonEmpty = val[5];\n    } else if (field === 'remissionCode' || field === 'All') {\n      this.isRemissionCodeEmpty = val[0];\n      this.remissionCodeHasError = val[1];\n    } else if (field === 'amount' || field === 'All') {\n      this.isAmountEmpty = val[2];\n      this.amountHasError = val[3];\n      this.isRemissionLessThanFeeError = val[4];\n    } else if (field === 'reason' || field === 'All') {\n      this.isReasonEmpty = val[5];\n    }\n  }\n\n  // Add retro remission changes\n  addRemissionCode() {\n    this.errorMessage = false;\n    // this.isFromCheckAnsPage = true;\n    this.errorMsg = [];\n    this.viewStatus = '';\n    this.isRefundRemission = false;\n    this.resetRemissionForm([false, false, false, false, false, false], 'All');\n    const remissionctrls = this.remissionForm.controls\n    // isRemissionLessThanFee = this.fee.calculated_amount >= remissionctrls.amount.value;\n    this.remissionForm.controls['refundReason'].setErrors(null);\n    this.remissionForm.controls['refundDDReason'].setErrors(null);\n    this.remissionForm.controls['amount'].setErrors(null);\n    if (this.remissionForm.dirty && this.remissionForm.valid) {\n      if (!this.isFromCheckAnsPage) {\n        this.viewCompStatus = '';\n        this.viewStatus = \"processretroremissonpage\";\n      } else {\n        this.viewCompStatus = '';\n        this.viewStatus = 'checkretroremissionpage';\n      }\n\n    } else {\n\n      if (remissionctrls['remissionCode'].value == '') {\n        this.resetRemissionForm([true, false, false, false, false], 'remissionCode');\n      }\n      if (remissionctrls['remissionCode'].value != '' && remissionctrls['remissionCode'].invalid) {\n        this.resetRemissionForm([false, true, false, false, false], 'remissionCode');\n      }\n      if (remissionctrls['amount'].value == '') {\n        this.resetRemissionForm([false, false, true, false, false], 'amount');\n      }\n      if (remissionctrls['amount'].value != '' && remissionctrls['amount'].invalid) {\n        this.resetRemissionForm([false, true, false, true, false], 'amount');\n      }\n      if (remissionctrls['reason'].value == '') {\n        this.resetRemissionForm([false, false, false, true, false, true], 'reason');\n      }\n      if (remissionctrls.amount.valid) {\n        this.resetRemissionForm([false, false, false, false, true], 'amount');\n      }\n\n    }\n  }\n\n\n  gotoAddRetroRemissionCodePage() {\n    this.errorMessage = false;\n    this.isFromCheckAnsPage = false;\n    this.errorMsg = [];\n    if (this.isRefundRemission) {\n      this.refundListAmount.emit();\n      this.paymentLibComponent.isFromRefundStatusPage = true;\n      return;\n    }\n    if (this.isFromRefundListPage) {\n      this.paymentLibComponent.iscancelClicked = true;\n      this.refundListReason.emit({ reason: this.selectedRefundReason, code: this.refundReason });\n      this.paymentLibComponent.isFromRefundStatusPage = true;\n      return;\n    }\n    this.viewStatus = '';\n    this.selectedValue = 'yes';\n    this.viewCompStatus = \"addremission\";\n    this.isRefundRemission = true;\n    this.errorMessage = '';\n    this.errorMsg = [];\n    if (this.isFromPaymentDetailPage) {\n      this.paymentLibComponent.viewName = 'payment-view';\n    }\n  }\n\n  gotoCheckRetroRemissionPage(payment: IPayment) {\n    this.paymentLibComponent.iscancelClicked = false;\n    this.errorMessage = '';\n    this.resetRemissionForm([false, false, false, false, false], 'All');\n    if (!this.isRefundRemission) {\n      var remissionctrls = this.remissionForm.controls,\n        isRemissionLessThanFee = this.fee.calculated_amount >= remissionctrls.amount.value;\n      if (this.remissionForm.dirty) {\n        if (remissionctrls['amount'].value == '' || remissionctrls['amount'].value < 0) {\n          this.resetRemissionForm([false, false, true, false, false], 'amount');\n        } else if (remissionctrls['amount'].value != '' && remissionctrls['amount'].invalid) {\n          this.resetRemissionForm([false, false, false, true, false], 'amount');\n        } else if (remissionctrls.amount.valid && !isRemissionLessThanFee) {\n          this.resetRemissionForm([false, false, false, false, true], 'amount');\n        } else {\n          this.viewCompStatus = '';\n          this.viewStatus = \"checkretroremissionpage\";\n        }\n      }\n    } else {\n      var remissionctrls = this.remissionForm.controls;\n      //if (this.remissionForm.dirty ) {\n      if (remissionctrls['amount'].value == '' || remissionctrls['amount'].value < 0) {\n        this.resetRemissionForm([false, false, true, false, false], 'amount');\n      } else {\n        this.viewCompStatus = '';\n        this.viewStatus = \"checkretroremissionpage\";\n        this.refundListAmount.emit(remissionctrls['amount'].value);\n      }\n      //}\n\n    }\n    this.paymentLibComponent.addPaymentGroup(this.paymentGroup);\n  }\n  gotoAmountRetroRemission() {\n    this.isFromCheckAnsPage = false;\n    this.viewStatus = 'processretroremissonpage';\n    this.viewCompStatus = '';\n    // this.isRefundRemission = true;\n    this.errorMessage = '';\n  }\n  gotoProcessRetroRemissionPage() {\n    this.isFromCheckAnsPage = true;\n    this.viewStatus = '';\n    this.viewCompStatus = 'addremission';\n    this.isRefundRemission = true;\n    this.errorMessage = '';\n    this.errorMsg = [];\n  }\n\n  gotoProcessRetroRemission(note?: IRefundContactDetails) {\n    if (note) {\n      this.notification = { contact_details: note, notification_type: note.notification_type };\n    }\n    this.isFromCheckAnsPage = true;\n    this.viewStatus = 'remissionAddressPage';\n    this.viewCompStatus = '';\n    this.isRefundRemission = true;\n    this.errorMessage = '';\n    this.isConfirmationBtnDisabled = false;\n    this.paymentLibComponent.addPaymentGroup(this.paymentGroup);\n  }\n\n  confirmRetroRemission() {\n    this.paymentLibComponent.addPaymentGroup(this.paymentGroup);\n    this.isConfirmationBtnDisabled = true;\n    this.retroRemission = true;\n    this.remissionamt = this.remissionForm.controls.amount.value;\n    const requestBody = new AddRetroRemissionRequest(this.remissionamt, this.remissionForm.controls.remissionCode.value)\n    this.paymentViewService.postPaymentGroupWithRetroRemissions(decodeURIComponent(this.paymentGroupRef).trim(), this.fee.id, requestBody).subscribe(\n      response => {\n        if (JSON.parse(response)) {\n          this.isRemissionApplied = true;\n          this.viewCompStatus = '';\n          this.viewStatus = 'retroremissionconfirmationpage';\n          this.remissionReference = JSON.parse(response).remission_reference;\n          this.paymentLibComponent.addRemission(requestBody);\n        }\n      },\n      (error: any) => {\n        this.errorMessage = error;\n        this.isConfirmationBtnDisabled = false;\n        this.cd.detectChanges();\n      }\n    );\n\n  }\n\n  processRefund() {\n    this.errorMessage = '';\n    this.errorMsg = [];\n    this.isConfirmationBtnDisabled = true;\n    if (this.isRefundRemission) {\n      this.retroRemission = true;\n    }\n    if (this.remissionReference === undefined || this.remissionReference === '') {\n      this.remissionReference = this.remission.remission_reference;\n    }\n    const requestBody = new PostIssueRefundRetroRemission(this.remissionReference, this.contactDetailsObj);\n    this.paymentViewService.postRefundRetroRemission(requestBody).subscribe(\n      response => {\n        if (JSON.parse(response)) {\n          this.viewCompStatus = '';\n          this.viewStatus = 'refundconfirmationpage';\n          this.refundReference = JSON.parse(response).refund_reference;\n          this.refundAmount = JSON.parse(response).refund_amount;\n        }\n      },\n      (error: any) => {\n        this.errorMessage = error;\n        this.isConfirmationBtnDisabled = false;\n      })\n  }\n\n  // Issue Refund changes\n\n  gotoIssueRefundConfirmation(payment: IPayment) {\n\n    this.paymentLibComponent.iscancelClicked = false;\n    if (this.paymentLibComponent.REFUNDLIST === \"true\") {\n      this.isFromRefundListPage = true;\n    }\n\n    this.totalRefundAmount = this.remissionForm.value.feesList.reduce((a, c) => a + c.refund_amount * c.selected, 0);\n\n\n    this.errorMessage = '';\n    this.errorMsg = [];\n    this.refundReason = this.remissionForm.controls['refundReason'].value === null ? this.remissionForm.controls['refundDDReason'].value : this.remissionForm.controls['refundReason'].value;\n    if (!this.refundReason || this.refundReason === 'Select a different reason') {\n      this.refundHasError = true;\n    } else if (this.selectedRefundReason.includes('Other') && (this.remissionForm.controls['reason'].value == '' || this.remissionForm.controls['reason'].value == null)) {\n      this.resetRemissionForm([false, false, false, true, false, true], 'reason');\n    } else if (this.selectedRefundReason.includes('Other') && this.remissionForm.controls['reason'].value !== '') {\n      this.refundHasError = false;\n      this.refundReason += '-' + this.remissionForm.controls['reason'].value;\n      this.displayRefundReason = this.selectedRefundReason + '-' + this.remissionForm.controls['reason'].value;\n      if (this.isFromRefundListPage) {\n        this.refundListReason.emit({ reason: this.displayRefundReason, code: this.refundReason });\n      } else {\n        if (this.isFromCheckAnsPage) {\n          this.totalRefundAmount = this.remissionForm.value.feesList.reduce((a, c) => a + c.refund_amount * c.selected, 0);\n          this.isFromCheckAnsPage = false;\n          this.viewStatus = 'checkissuerefundpage';\n          this.viewCompStatus = '';\n          this.notificationPreview = false;\n          return;\n        }\n        this.viewCompStatus = '';\n        this.viewStatus = 'contactDetailsPage';\n      }\n\n    } else {\n      this.displayRefundReason = this.selectedRefundReason;\n      if (this.isFromCheckAnsPage) {\n        this.totalRefundAmount = this.remissionForm.value.feesList.reduce((a, c) => a + c.refund_amount * c.selected, 0);\n        this.isFromCheckAnsPage = false;\n        this.viewStatus = 'checkissuerefundpage';\n        this.viewCompStatus = '';\n        this.notificationPreview = false;\n        return;\n      }\n      if (this.isFromRefundListPage) {\n        this.paymentLibComponent.isFromRefundStatusPage = true;\n        this.refundListReason.emit({ reason: this.selectedRefundReason, code: this.refundReason });\n      } else {\n        this.viewCompStatus = '';\n        this.viewStatus = 'contactDetailsPage';\n      }\n\n    }\n  }\n\n  gotoIssueRefundPage() {\n    this.errorMessage = '';\n    this.viewCompStatus = 'issuerefund';\n    this.viewStatus = '';\n    this.isRefundRemission = true;\n    this.errorMessage = false;\n    this.errorMsg = [];\n    this.refundHasError = false;\n    this.isReasonEmpty = false;\n  }\n\n  gotoIssuePage(isFullyRefund: any) {\n    if (isFullyRefund) {\n      this.viewCompStatus = 'issuerefundpage1';\n      this.getRefundReasons();\n    } else {\n      [].forEach.call(document.querySelectorAll('input'), function (el) {\n        el.classList.remove('inline-error-class');\n      });\n\n      var checkboxs = document.getElementsByTagName('input');\n      this.errorMessage = '';\n      this.totalRefundAmount = 0;\n      this.errorMsg = [];\n      for (var j = 0; j < checkboxs.length; j++) {\n        if (checkboxs[j].checked) {\n          this.fullRefund = false;\n          let quantity: number = +(<HTMLInputElement>document.getElementById('feeVolume_' + checkboxs[j].value)).value;\n          let amountToRefund: number = +(<HTMLInputElement>document.getElementById('feeAmount_' + checkboxs[j].value)).value;\n          let apportionAmount: number = +(<HTMLInputElement>document.getElementById('feeApportionAmount_' + checkboxs[j].value)).value;\n          let calculatedAmount: number = +(<HTMLInputElement>document.getElementById('calculatedAmount_' + checkboxs[j].value)).value;\n\n          if (amountToRefund === apportionAmount) {\n            this.fullRefund = true;\n          }\n\n          if (amountToRefund === 0) {\n            this.elementId = 'feeAmount_' + checkboxs[j].value;\n            this.errorMsg.push('You need to enter a refund amount');\n            this.getErrorClass(this.elementId);\n          }\n\n\n\n          if (quantity === 1) {\n            if (amountToRefund > 0 && amountToRefund > apportionAmount) {\n              this.elementId = 'feeAmount_' + checkboxs[j].value;\n              this.errorMsg.push('The amount you want to refund is more than the amount paid');\n              this.getErrorClass(this.elementId);\n            }\n          }\n\n          if (quantity > 1) {\n\n            this.quantityUpdated = +(<HTMLInputElement>document.getElementById('feeVolumeUpdated_' + checkboxs[j].value)).value;\n\n            if (this.quantityUpdated === 0) {\n              this.elementId = 'feeVolumeUpdated_' + checkboxs[j].value;\n              this.errorMsg.push('You need to enter quantity')\n              this.getErrorClass(this.elementId);\n            }\n\n            if (this.fullRefund && quantity !== this.quantityUpdated) {\n              this.elementId = 'feeVolumeUpdated_' + checkboxs[j].value;\n              this.errorMsg.push('The quantity you want to refund should be maximun available quantity');\n              this.getErrorClass(this.elementId);\n            }\n\n            if (!this.fullRefund && this.quantityUpdated > 0 && amountToRefund > 0) {\n              this.refundAmtForFeeVolumes = +(<HTMLInputElement>document.getElementById('feeVOl_' + checkboxs[j].value)).innerText;\n              this.allowedRefundAmount = this.quantityUpdated * this.refundAmtForFeeVolumes;\n              if (this.allowedRefundAmount !== amountToRefund) {\n                this.elementId = 'feeAmount_' + checkboxs[j].value;\n                this.errorMsg.push('The Amount to Refund should be equal to the product of Fee Amount and quantity');\n                this.getErrorClass(this.elementId);\n              }\n            }\n\n            if (!this.fullRefund && amountToRefund > apportionAmount) {\n              this.elementId = 'feeAmount_' + checkboxs[j].value;\n              this.errorMsg.push('The amount you want to refund is more than the amount paid');\n              this.getErrorClass(this.elementId);\n            }\n\n            if (!this.fullRefund && this.quantityUpdated > 0 && this.quantityUpdated > quantity) {\n              this.elementId = 'feeVolumeUpdated_' + checkboxs[j].value;\n              this.errorMsg.push('The quantity you want to refund is more than the available quantity');\n              this.getErrorClass(this.elementId);\n            }\n          }\n          //this.remissionForm.value.feesList.find(id=>id=checkboxs[j].value)['refund_amount'] = apportionAmount;\n        }\n      }\n\n      if (this.errorMsg.length === 0) {\n        if (this.isFromCheckAnsPage) {\n          this.isFromCheckAnsPage = false;\n          this.totalRefundAmount = this.remissionForm.value.feesList.reduce((a, c) => a + c.refund_amount * c.selected, 0);\n          this.fees = this.remissionForm.value.feesList.filter(value => value.selected === true);\n          this.viewStatus = 'checkissuerefundpage'\n          this.viewCompStatus = '';\n          this.notificationPreview = false;\n          return;\n        } else if (this.isFromRefundStatusPage) {\n          var remissionctrls = this.remissionForm.controls;\n          this.totalRefundAmount = this.remissionForm.value.feesList.reduce((a, c) => a + c.refund_amount * c.selected, 0);\n          this.refundListAmount.emit(this.totalRefundAmount.toString());\n          this.fees = this.remissionForm.value.feesList.filter(value => value.selected === true);\n          this.refundFees.emit(this.fees);\n          return;\n        }\n        this.viewCompStatus = 'issuerefundpage1';\n        this.getRefundReasons();\n      }\n    }\n  }\n\n  calAmtToRefund(value, amount, volume, i: any) {\n    const volumeFee = amount / volume;\n    const amtToRefund = value * volumeFee;\n    const formArray = this.remissionForm.controls.feesList as FormArray;\n    formArray.at(i).get('refund_amount').setValue(amtToRefund);\n    // formArray.at(i).get('volume').setValue(value);\n    //  (<HTMLInputElement>document.getElementById('feeAmount_'+i)).value = +amtToRefund;\n    //  const formControl = this.remissionForm.controls.feesList['volume'].at(i);\n    //  formControl.setValue(value);\n\n  }\n  gotoContactDetailsPage(note?: IRefundContactDetails) {\n    if (note) {\n      this.notification = { contact_details: note, notification_type: note.notification_type };\n    }\n    this.errorMessage = '';\n    this.viewCompStatus = '';\n    this.viewStatus = 'contactDetailsPage';\n    this.isRefundRemission = true;\n    this.errorMessage = false;\n  }\n\n  getRefundReasons() {\n    if (this.viewCompStatus === 'issuerefundpage1') {\n      this.refundService.getRefundReasons().subscribe(\n        refundReasons => {\n          this.refundReasons = refundReasons.filter((data) => data.recently_used === false);\n          this.refundReasons = this.refundReasons.filter((data) => data.name !== 'Retrospective remission');\n          this.cd.detectChanges();\n          this.commonRefundReasons = refundReasons.filter((data) => data.recently_used === true);\n          this.commonRefundReasons.sort((a, b) => a.toString().localeCompare(b));\n          this.cd.detectChanges();\n        });\n    }\n  }\n  getErrorClass(elementId) {\n    if (this.errorMsg.length > 0) {\n      const ele = document.getElementById(elementId);\n      ele.classList.add('inline-error-class');\n    }\n\n  }\n\n  changeIssueRefundReason() {\n    this.isFromCheckAnsPage = true;\n    this.errorMessage = '';\n    this.errorMsg = [];\n    this.refundHasError = false;\n    this.isReasonEmpty = false;\n    this.viewCompStatus = 'issuerefundpage1';\n    this.viewStatus = '';\n    this.isRefundRemission = true;\n  }\n\n  confirmIssueRefund(isFullyRefund: any) {\n    this.isConfirmationBtnDisabled = true;\n    this.errorMessage = '';\n    this.errorMsg = [];\n    if (this.isRefundRemission) {\n      this.retroRemission = true;\n    }\n    if (isFullyRefund) {\n      this.totalRefundAmount = this.payment.amount;\n    }\n    if (!isFullyRefund) {\n      this.fees = this.remissionForm.value.feesList.filter(value => value.selected === true);\n    }\n    this.fees = this.fees.map(obj => ({\n      id: obj.id,\n      code: obj.code,\n      version: obj.version,\n      apportion_amount: obj.apportion_amount,\n      calculated_amount: obj.calculated_amount,\n      updated_volume: obj.updated_volume ? obj.updated_volume : obj.volume,\n      refund_amount: obj.refund_amount ? obj.refund_amount : this.totalRefundAmount\n    }));\n\n\n    const requestBody = new PostRefundRetroRemission(this.contactDetailsObj, this.fees, this.payment.reference, this.refundReason,\n      this.totalRefundAmount, 'op');\n    this.paymentViewService.postRefundsReason(requestBody).subscribe(\n      response => {\n        if (JSON.parse(response)) {\n          this.viewCompStatus = '';\n          this.viewStatus = 'refundconfirmationpage';\n          this.refundReference = JSON.parse(response).refund_reference;\n          if (JSON.parse(response).refund_amount) {\n            this.refundAmount = JSON.parse(response).refund_amount;\n          }\n        }\n      },\n      (error: any) => {\n        this.errorMessage = error;\n        this.isConfirmationBtnDisabled = false;\n        this.cd.detectChanges();\n      })\n  }\n\n  gotoRefundReasonPage() {\n    this.viewStatus = '';\n    this.viewCompStatus = 'issuerefundpage1';\n\n  }\n\n  // Retro Refund\n\n  // confirmRetroRefund() {\n  //   this.isConfirmationBtnDisabled = true;\n  //   this.errorMessage = '';\n  //   this.errorMsg = [];\n  //   if( this.isRefundRemission) {\n  //     this.retroRemission = true;\n  //   }\n\n  //   const requestBody = new PostRefundRetroRemission(this.payment.reference,'RR004-Retrospective remission', this.contactDetailsObj);\n  //   this.paymentViewService.postRefundsReason(requestBody).subscribe(\n  //     response => {\n  //         if (JSON.parse(response)) {\n  //           this.viewCompStatus  = '';\n  //           this.viewStatus = 'retrorefundconfirmationpage';\n  //           this.refundReference =JSON.parse(response).refund_reference;\n  //           if(JSON.parse(response).refund_amount) {\n  //             this.refundAmount = JSON.parse(response).refund_amount;\n  //             }\n  //         }\n  //     },\n  //     (error: any) => {\n  //       this.errorMessage = error;\n  //       this.isConfirmationBtnDisabled = false;\n  //     });\n  // }\n\n  selectRadioButton(key, value) {\n    localStorage.setItem(\"myradio\", value);\n    const remissionctrls = this.remissionForm.controls;\n    remissionctrls['refundDDReason'].setValue('Select a different reason', { onlySelf: true });\n    remissionctrls['reason'].reset();\n    this.isRefundReasonsSelected = true;\n    this.errorMessage = false;\n    this.errorMsg = [];\n    this.isReasonEmpty = false;\n    this.showReasonText = false;\n    this.refundHasError = false;\n    this.selectedRefundReason = value;\n    this.selectedRefundReasonCode = key;\n    if (this.selectedRefundReason.includes('Other')) {\n      this.showReasonText = true;\n      this.refundHasError = false;\n      this.refundReason = value;\n    }\n  }\n\n  selectchange(args) {\n    const remissionctrls = this.remissionForm.controls;\n    remissionctrls['refundReason'].reset();\n    remissionctrls['reason'].reset();\n    this.isRefundReasonsSelected = false;\n    this.showReasonText = false;\n    this.refundHasError = false;\n    this.selectedRefundReason = args.target.options[args.target.options.selectedIndex].id;\n    this.selectedRefundReasonCode = args.target.options[args.target.options.selectedIndex].value;\n    this.reasonLength = (29 - this.selectedRefundReason.split('- ')[1].length);\n\n    if (this.selectedRefundReason.includes('Other')) {\n      this.showReasonText = true;\n      this.refundHasError = false;\n      this.refundReason = args.target.options[args.target.options.selectedIndex].id;\n    }\n\n\n  }\n  getContactDetails(obj: IRefundContactDetails, type) {\n    this.contactDetailsObj = obj;\n    this.viewCompStatus = '';\n    this.notificationPreview = false;\n    if (type == 'checkaddRefundpage') {\n      this.getTemplateInstructionType(this.remessionPayment.reference, this.remessionPayment);\n    } else if (type == 'checkissuerefundpage') {\n      this.getTemplateInstructionType(this.payment.reference, this.payment);\n    } else if (type == 'addrefundcheckandanswer') {\n      this.getTemplateInstructionType(this.paymentReference, this.paymentObj);\n    }\n    this.paymentLibComponent.addPaymentGroup(this.paymentGroup);\n    this.viewStatus = type;\n  }\n\n  gotoPartialFeeRefundScreen() {\n\n    if (this.isFromRefundStatusPage) {\n      var remissionctrls = this.remissionForm.controls;\n      this.refundListReason.emit({ reason: this.displayRefundReason, code: this.refundReason });\n      return;\n    }\n    this.refundHasError = false;\n    this.viewCompStatus = 'issuerefund';\n    this.viewStatus = '';\n  }\n\n\n\n  gotoServiceRequestPage(event: any) {\n    this.errorMessage = '';\n    this.errorMsg = [];\n    this.isFromCheckAnsPage = false;\n    event.preventDefault();\n\n    if (this.isFromRefundStatusPage) {\n      var remissionctrls = this.remissionForm.controls;\n      this.totalRefundAmount = 0;\n      this.refundListAmount.emit(this.totalRefundAmount.toString());\n      return;\n    }\n    if (this.isFromServiceRequestPage && !this.isFromPaymentDetailPage) {\n      this.viewStatus = 'order-full-view';\n      this.viewCompStatus = '';\n    } else if (this.isFromRefundListPage) {\n      this.paymentLibComponent.iscancelClicked = true;\n      this.refundListReason.emit({ reason: this.selectedRefundReason, code: this.refundReason });\n      this.paymentLibComponent.isFromRefundStatusPage = true;\n    } else {\n      this.paymentLibComponent.paymentMethod = this.payment.method;\n      this.paymentLibComponent.paymentGroupReference = this.paymentLibComponent.paymentGroupReference\n      this.paymentLibComponent.paymentReference = this.payment.reference;\n      this.paymentLibComponent.viewName = 'payment-view';\n      this.OrderslistService.setOrderRef(this.orderRef);\n      this.OrderslistService.setorderCCDEvent(this.orderCCDEvent);\n      this.OrderslistService.setorderCreated(this.orderCreated);\n      this.OrderslistService.setorderDetail(this.orderDetail);\n      this.OrderslistService.setorderParty(this.orderParty);\n      this.OrderslistService.setorderTotalPayments(this.orderTotalPayments);\n      this.OrderslistService.setorderRemissionTotal(this.orderRemissionTotal);\n      this.OrderslistService.setorderFeesTotal(this.orderFeesTotal);\n      this.viewStatus = 'payment-view';\n      this.sendOrderDetail = this.orderDetail;\n      this.sendOrderRef = this.orderRef;\n      if (this.LOGGEDINUSERROLES === undefined) {\n        this.OrderslistService.getUserRolesList().subscribe((data) => this.LOGGEDINUSERROLES = data);\n      }\n      this.viewCompStatus = '';\n    }\n\n  }\n  gotoAddressPage(note?: IRefundContactDetails) {\n    if (note) {\n      this.notification = { contact_details: note, notification_type: note.notification_type };\n    }\n    this.errorMessage = '';\n    this.viewCompStatus = 'addrefundforremission';\n    this.viewStatus = '';\n    this.isRefundRemission = true;\n    this.errorMessage = false;\n  }\n  gotoRemissionSuccess(event: Event) {\n    event.preventDefault();\n    this.errorMessage = '';\n    this.viewCompStatus = '';\n    this.viewStatus = 'retroremissionconfirmationpage';\n    this.isRefundRemission = true;\n    this.errorMessage = false;\n  }\n\n  gotoCasetransationPage() {\n    this.OrderslistService.setnavigationPage('casetransactions');\n    this.errorMessage = '';\n    this.errorMsg = [];\n    this.paymentLibComponent.viewName = 'case-transactions';\n    this.paymentLibComponent.VIEW = 'case-transactions';\n    this.paymentLibComponent.ISTURNOFF = this.isTurnOff;\n    this.paymentLibComponent.isFromServiceRequestPage = true;\n    this.resetOrderData();\n    let partUrl = this.bsPaymentDcnNumber ? `&dcn=${this.bsPaymentDcnNumber}` : '';\n    partUrl += this.paymentLibComponent.ISBSENABLE ? '&isBulkScanning=Enable' : '&isBulkScanning=Disable';\n    partUrl += this.paymentLibComponent.ISTURNOFF ? '&isTurnOff=Enable' : '&isTurnOff=Disable';\n    partUrl += this.isStrategicFixEnable ? '&isStFixEnable=Enable' : '&isStFixEnable=Disable';\n    partUrl += `&caseType=${this.caseType}`;\n    const url = `/payment-history/${this.ccdCaseNumber}?view=case-transactions&takePayment=${this.paymentLibComponent.TAKEPAYMENT}&selectedOption=${this.option}${partUrl}`;\n    this.router.routeReuseStrategy.shouldReuseRoute = () => false;\n    this.router.onSameUrlNavigation = 'reload';\n    this.router.navigateByUrl(url);\n  }\n\n  gotoCasetransationPageCancelBtnClicked(event: Event) {\n    event.preventDefault();\n    this.errorMsg = [];\n    if (this.paymentLibComponent.isFromServiceRequestPage !== undefined && !this.paymentLibComponent.isFromServiceRequestPage) {\n      this.OrderslistService.setnavigationPage('casetransactions');\n      this.OrderslistService.setisFromServiceRequestPage(false);\n      this.paymentLibComponent.VIEW = 'case-transactions';\n      this.paymentLibComponent.viewName = 'case-transactions';\n      this.paymentLibComponent.ISBSENABLE = true;\n      this.paymentLibComponent.isRefundStatusView = false;\n    } else {\n\n      if (this.paymentLibComponent.REFUNDLIST) {\n        this.paymentLibComponent.viewName = 'refund-list';\n        return;\n      }\n      if (this.paymentLibComponent.TAKEPAYMENT === undefined && this.paymentLibComponent.SERVICEREQUEST === undefined) {\n        this.paymentLibComponent.SERVICEREQUEST = 'false';\n      }\n      this.OrderslistService.setisFromServiceRequestPage(false);\n      this.OrderslistService.setpaymentPageView({ method: '', payment_group_reference: '', reference: '' });\n      this.OrderslistService.setnavigationPage('casetransactions');\n      this.errorMessage = '';\n      this.paymentLibComponent.viewName = 'case-transactions';\n      this.paymentLibComponent.ISTURNOFF = this.isTurnOff;\n      this.paymentLibComponent.isFromServiceRequestPage = true;\n      this.paymentLibComponent.ISBSENABLE = true;\n      let partUrl = this.bsPaymentDcnNumber ? `&dcn=${this.bsPaymentDcnNumber}` : '';\n      partUrl += this.paymentLibComponent.ISBSENABLE ? '&isBulkScanning=Enable' : '&isBulkScanning=Disable';\n      partUrl += this.paymentLibComponent.ISTURNOFF ? '&isTurnOff=Enable' : '&isTurnOff=Disable';\n      partUrl += this.isStrategicFixEnable ? '&isStFixEnable=Enable' : '&isStFixEnable=Disable';\n      partUrl += `&caseType=${this.caseType}`;\n      if (this.isFromPaymentDetailPage) {\n        partUrl += this.paymentLibComponent.isFromPaymentDetailPage\n      }\n\n      if (!this.paymentLibComponent.SERVICEREQUEST) {\n        const url = `/payment-history/${this.ccdCaseNumber}?view=case-transactions&takePayment=${this.paymentLibComponent.TAKEPAYMENT}&selectedOption=${this.option}${partUrl}`;\n        this.router.routeReuseStrategy.shouldReuseRoute = () => false;\n        this.router.onSameUrlNavigation = 'reload';\n        this.router.navigateByUrl(url);\n      } else {\n        const url = `/payment-history/${this.ccdCaseNumber}?selectedOption=${this.option}${partUrl}`;\n        this.router.routeReuseStrategy.shouldReuseRoute = () => false;\n        this.router.onSameUrlNavigation = 'reload';\n        this.router.navigateByUrl(url);\n      }\n    }\n\n  }\n\n  canRefundBeApplied(){\n\n    if(this.remissionamt == null || this.fee.fee_amount == null || this.payment.amount ==null ){\n      return true;\n    }\n\n    if ( this.fee.fee_amount-this.payment.amount == this.remissionamt){\n      return false;\n    }\n    return true;\n\n  }\n\n  resetOrderData() {\n    this.OrderslistService.setOrderRef(null);\n    this.OrderslistService.setorderCCDEvent(null);\n    this.OrderslistService.setorderCreated(null);\n    this.OrderslistService.setorderDetail(null);\n    this.OrderslistService.setorderParty(null);\n    this.OrderslistService.setorderTotalPayments(null);\n    this.OrderslistService.setorderRemissionTotal(null);\n    this.OrderslistService.setorderFeesTotal(null);\n  }\n\n  changeRefundAmount() {\n    this.isFromCheckAnsPage = true;\n    this.viewCompStatus = 'issuerefund';\n    this.viewStatus = '';\n  }\n\n  getFormattedCurrency(currency: number) {\n    if (currency.toString().includes(\".\")) {\n      return currency\n    }\n    return currency.toString().concat(\".00\");\n  }\n\n  showNotificationPreview(): void {\n    this.notificationPreview = true;\n  }\n\n  hideNotificationPreview(): void {\n    this.notificationPreview = false;\n  }\n\n  getTemplateInstructionType(paymentReference: string, payment?: IPayment): void {\n\n    if (payment == undefined || payment == null || payment.reference != paymentReference) {\n      this.paymentViewService.getPaymentDetails(paymentReference).subscribe(\n        payment => {\n          this.paymentObj = payment;\n          this.paymentObj.reference = paymentReference;\n          this.templateInstructionType = this.notificationService.getNotificationInstructionType(this.paymentObj.channel, this.paymentObj.method);\n        },\n        (error: any) => {\n          this.templateInstructionType = 'Template';\n        })\n    } else {\n      this.templateInstructionType = this.notificationService.getNotificationInstructionType(payment.channel, payment.method);\n    }\n  }\n\n  getRefundAmountToBeDisplayed(remission: IRemission): string {\n\n    if (remission !== null && remission !== undefined) {\n      if (remission.overall_balance > 0 && remission.acollection_of_fess == false) {\n        return remission.overall_balance.toString();\n      }else{\n        return this.paymentLibComponent.overPaymentAmount.toString();\n      }\n    }\n    return \"undefined\";\n  }\n\n  getRefundAmountToBeDisplayedForContinueJourney(): string {\n\n    return Math.abs(((this.paymentLibComponent.getTotalFees() - this.paymentLibComponent.getTotalRemission())\n      - this.paymentLibComponent.getTotalPayments())).toString();\n  }\n\n  getRemissionAmountToBeDisplayed(remission: IRemission): string {\n    if (remission !== null && remission !== undefined) {\n      return remission.hwf_amount.toString();\n    }\n    return \"undefined\";\n  }\n\n  isRemissionEnabled(feeCode: string): boolean {\n    if (this.paymentLibComponent.paymentGroup.remissions != null &&\n      this.paymentLibComponent.paymentGroup.remissions.length > 0 && this.isRemissionEnabledForFeeCode(feeCode)) {\n\n      return true;\n    }\n    return false;\n  }\n\n  isRemissionEnabledForFeeCode(feeCode: string): boolean {\n    let result = this.getRemissions(feeCode);\n    if (result === null) {\n      return false;\n    }\n    return true;\n  }\n\n  getRemissions(feeCode: string): IRemission {\n    let myRemission = this.paymentLibComponent.paymentGroup.remissions.filter(remission => remission.fee_code === feeCode);\n    if (myRemission.length == 0) {\n      return null;\n    }\n    // We  can have one remission per case, only\n    return myRemission.at(0);\n  }\n\n  getRemissionsHwfAmount(feeCode: string): string {\n    let myRemission = this.getRemissions(feeCode);\n    if (myRemission === null) {\n      return this.getRemissionValueForFullyRefund().toString();\n    } else {\n      return myRemission.hwf_amount.toString();\n    }\n  }\n\n  getNetAmountFee(hwfAmount: number, feeAmount: number){\n    return feeAmount - hwfAmount;\n  }\n\n  getRemissionValueForFullyRefund(){\n    return 0;\n  }\n}\n","<div class=\"add-remission pagesize\">\n  <div *ngIf=\"errorMessage\">\n    <div class=\"error-summary\" role=\"group\" aria-labelledby=\"failure-error-summary-heading\" tabindex=\"-1\">\n      <h2 class=\"heading-medium error-summary-heading\" id=\"failure-error-summary-heading\">\n       {{ \"Error in processing the request\" | rpxTranslate }}\n      </h2>\n      <div  class=\"govuk-error-summary__body\">\n        {{ errorMessage | rpxTranslate }}\n      </div>\n    </div>\n  </div>\n  <div *ngIf=\"errorMsg.length > 0\">\n    <div class=\"error-summary\" role=\"group\" aria-labelledby=\"failure-error-summary-heading\" tabindex=\"-1\">\n      <h2 class=\"heading-medium error-summary-heading\" id=\"failure-error-summary-heading\">\n        {{ \"Error in processing the request\" | rpxTranslate }}\n      </h2>\n      <div *ngFor=\"let err of errorMsg; let i = index\" class=\"govuk-error-summary__body\">\n\n        <li>{{ err | rpxTranslate }}</li>\n      </div>\n    </div>\n  </div>\n\n<ng-container *ngIf=\"viewStatus === 'main' && !isRefundRemission \">\n    <input #myInput type='hidden' id='iFrameDrivenImageValue' value='ADDREMISSION'>\n    <h1 class=\"heading-large\">{{ \"Add remission\" | rpxTranslate }} </h1>\n    <form novalidate>\n      <div class=\"govuk-form-group\">\n        <form [formGroup]=\"remissionForm\" novalidate>\n          <div class=\"govuk-form-group\">\n            <label class=\"govuk-label govuk-label--s\" for=\"remission-code\">\n                {{ \"Add remission to\" | rpxTranslate }} {{ fee?.code }}: {{ fee?.description | rpxTranslate }}\n              <span class=\"form-hint\">{{ \"Enter remission for reference\" | rpxTranslate }}. {{ \"For example\" | rpxTranslate }}: HWF-A1B-23C OR PA21-123456</span>\n            </label>\n            <input [ngClass]=\"{'inline-error-class': isRemissionCodeEmpty || remissionCodeHasError}\" class=\"govuk-input govuk-input--width-20 govuk-!-margin-right-1\" id=\"remissionCode\" aria-label=\"remissionCode\"  name=\"remissionCode\" type=\"text\" formControlName=\"remissionCode\">\n            <p class=\"inline-error-message\" *ngIf=\"isRemissionCodeEmpty || remissionCodeHasError\">\n              <span *ngIf=\"isRemissionCodeEmpty\">{{ \"Enter a remission code\" | rpxTranslate }}</span>\n              <span *ngIf=\"remissionCodeHasError\">{{ \"Enter a vaild remission code\" | rpxTranslate }}</span>\n            </p>\n          </div>\n          <div class=\"govuk-form-group\">\n            <label class=\"govuk-label govuk-label--s\" for=\"amount\">\n              {{ \"How much does the applicant need to pay\" | rpxTranslate }}?\n            </label>\n\n            <div id=\"amount-currency\" class=\"govuk-visually-hidden\">{{ \"in pounds\" | rpxTranslate }}</div>\n              <div class=\"hmcts-currency-input\">\n              <div class=\"hmcts-currency-input__symbol\" aria-hidden=\"true\">£</div>\n              <input class=\"govuk-input govuk-input-width-10-left\" [ngClass]=\"{'inline-error-class': isAmountEmpty || amountHasError || isRemissionLessThanFeeError}\" id=\"amount\" aria-label=\"amount\"  name=\"amount\" type=\"text\" aria-describedby=\"amount-currency\" formControlName=\"amount\">\n              <p class=\"inline-error-message\" *ngIf=\"isAmountEmpty || amountHasError || isRemissionLessThanFeeError\">\n                <span *ngIf=\"isAmountEmpty\">{{ \"Enter a amount\" | rpxTranslate }}</span>\n                <span *ngIf=\"amountHasError\">{{ \"Enter a vaild amount\" | rpxTranslate }}</span>\n                <span *ngIf=\"isRemissionLessThanFeeError\">{{ \"The remission amount must be less than the total fee\" | rpxTranslate }}</span>\n              </p>\n            </div>\n          </div>\n        </form>\n        <button class=\"button\" type=\"submit\" (click)=\"addRemission()\">\n            {{ \"Submit\" | rpxTranslate }}\n          </button>\n      </div>\n    </form>\n</ng-container>\n\n<ng-container *ngIf=\"viewStatus === 'confirmation'\">\n    <input #myInput type='hidden' id='iFrameDrivenImageValue' value='ADDREMISSIONCONFIRMATION'>\n    <div class=\"govuk-warning-text\">\n      <span class=\"govuk-warning-text__icon\" aria-hidden=\"true\">!</span>\n      <strong class=\"govuk-warning-text__text\">\n        <span class=\"govuk-warning-text__assistive\">{{ \"Warning\" | rpxTranslate }}</span>\n        {{ \"Are you sure you want to add remission to this fee\" | rpxTranslate }}?\n      </strong>\n    </div>\n    <table class=\"govuk-table\">\n      <tr class=\"govuk-table__row\">\n          <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Remission code\" | rpxTranslate }}:</td>\n          <td class=\"govuk-table__cell\">{{ remissionForm.controls.remissionCode.value }}</td>\n      </tr>\n      <tr class=\"govuk-table__row\">\n          <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Fee code\" | rpxTranslate }}:</td>\n          <td class=\"govuk-table__cell\">{{ fee.code }}</td>\n      </tr>\n      <tr class=\"govuk-table__row\">\n          <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Fee description\" | rpxTranslate }}:</td>\n          <td class=\"govuk-table__cell\">{{ fee.description | rpxTranslate }}</td>\n      </tr>\n      <tr class=\"govuk-table__row\">\n          <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Amount the applicant must pay\" | rpxTranslate }}:</td>\n          <td class=\"govuk-table__cell\">{{  remissionForm.controls.amount.value  | currency:'GBP':'symbol-narrow':'1.2-2' }}</td>\n      </tr>\n    </table>\n\n    <button type=\"submit\" class=\"button govuk-button--secondary\" (click)=\"cancelRemission.emit()\">\n      {{ \"Cancel\" | rpxTranslate }}\n    </button>\n    <button type=\"submit\"\n    [disabled]=\"isConfirmationBtnDisabled\"\n    [ngClass]='isConfirmationBtnDisabled ? \"button button--disabled govuk-!-margin-right-1\" : \"button govuk-!-margin-right-1\"'\n    (click)=\"confirmRemission()\">\n      {{ \"Confirm\" | rpxTranslate }}\n    </button>\n\n</ng-container>\n\n<!-- Add retro remission changes-->\n\n<ng-container *ngIf=\"viewCompStatus === 'addremission'\">\n    <input #myInput type='hidden' id='iFrameDrivenImageValue' value='PROCESSADDRETROREMISSIONPAGE'>\n    <h1 class=\"heading-large\">{{ \"Process remission\" | rpxTranslate }}</h1>\n    <h1 class=\"heading-medium\">#{{ccdCaseNumber | ccdHyphens}}</h1>\n    <h1 class=\"heading-large\">{{ \"Enter help with fees or remission reference\" | rpxTranslate }}</h1>\n    <form novalidate>\n        <div class=\"govuk-form-group\">\n          <form [formGroup]=\"remissionForm\" novalidate>\n            <div class=\"govuk-form-group\">\n              <label class=\"govuk-label govuk-label--s\" for=\"remission-code\">\n                <span class=\"form-hint\">{{ \"For example\" | rpxTranslate }}: HWF-A1B-23C OR PA21-123456</span>\n              </label>\n              <p class=\"inline-error-message\" *ngIf=\"isRemissionCodeEmpty || remissionCodeHasError\">\n                <span *ngIf=\"isRemissionCodeEmpty\">{{ \"Enter a remission code\" | rpxTranslate }}</span>\n                <span *ngIf=\"remissionCodeHasError\">{{ \"Enter a vaild remission code\" | rpxTranslate }}</span>\n              </p>\n              <input [ngClass]=\"{'inline-error-class': isRemissionCodeEmpty || remissionCodeHasError}\" class=\"govuk-input govuk-input--width-20 govuk-!-margin-right-1\" id=\"remissionCode\" aria-label=\"remissionCode\"  name=\"remissionCode\" type=\"text\" formControlName=\"remissionCode\">\n\n            </div>\n\n          </form>\n          <div class=\"govuk-button-group\">\n              <button (click)=\"gotoServiceRequestPage($event)\" class=\"govuk-button govuk-button--secondary\"> {{ \"Previous\" | rpxTranslate }}</button>\n              <button (click)=\"addRemissionCode()\" class=\"govuk-button\"> {{ \"Continue\" | rpxTranslate }}</button>\n          </div>\n          <p><a href=\"javascript:void(0)\" (click)=\"gotoCasetransationPageCancelBtnClicked($event)\" class=\"govuk-link pointer\" data-module=\"govuk-button\">{{ \"Cancel\" | rpxTranslate }}</a></p>\n        </div>\n    </form>\n\n</ng-container>\n\n<ng-container *ngIf=\"viewStatus === 'processretroremissonpage'\" >\n    <input #myInput type='hidden' id='iFrameDrivenImageValue' value='PROCESSRETROREMISSIONPAGE'>\n    <h1 class=\"heading-large\">{{ \"Process remission\" | rpxTranslate }}</h1>\n    <h1 class=\"heading-medium\">#{{ccdCaseNumber | ccdHyphens }}</h1>\n    <div class=\"govuk-form-group\">\n        <form novalidate>\n            <div class=\"govuk-form-group\">\n                <form [formGroup]=\"remissionForm\" novalidate>\n                    <fieldset class=\"govuk-fieldset\">\n                      <legend class=\"govuk-fieldset__legend govuk-fieldset__legend--m\">\n                          <h1 *ngIf=\"remessionPayment?.status === 'Success' ||   isFromRefundListPage\" class=\"heading-medium\">\n                              {{ \"Enter the HWF or remission amount\" | rpxTranslate }}\n                          </h1>\n                          <h1 *ngIf=\"remessionPayment?.status !== 'Success' && !isFromRefundListPage\" class=\"heading-medium\">\n                              {{ \"Enter the remission amount\" | rpxTranslate }}\n                          </h1>\n                          <h1 *ngIf=\"remessionPayment?.status === 'undefined'\" class=\"heading-medium\">\n                              {{ \"Enter the  amount\" | rpxTranslate }}\n                          </h1>\n                        </legend>\n                     <div id=\"amount-currency\" class=\"govuk-visually-hidden\">{{ \"in pounds\" | rpxTranslate }}</div>\n                     <p class=\"inline-error-message\" *ngIf=\"isAmountEmpty || amountHasError || isRemissionLessThanFeeError\">\n                      <span *ngIf=\"isAmountEmpty\">{{ \"Enter a amount\" | rpxTranslate }}</span>\n                      <span *ngIf=\"amountHasError\">{{ \"Enter a vaild amount\" | rpxTranslate }}</span>\n                      <span *ngIf=\"isRemissionLessThanFeeError\">{{ \"You cannot add a remission that's more than the fee amount\" | rpxTranslate }}.</span>\n                    </p>\n                        <div class=\"hmcts-currency-input\">\n\n                            <div class=\"hmcts-currency-input__symbol\" aria-hidden=\"true\">£</div>\n                            <input class=\"govuk-input govuk-input-width-10-left\" [ngClass]=\"{'inline-error-class': isAmountEmpty || amountHasError || isRemissionLessThanFeeError}\" id=\"amount\" aria-label=\"amount\"  name=\"amount\"  type=\"number\" aria-describedby=\"amount-currency\" formControlName=\"amount\">\n\n\n                      </div>\n                    </fieldset>\n                </form>\n\n                <div class=\"govuk-button-group\">\n                    <button (click)=\"gotoAddRetroRemissionCodePage()\" class=\"govuk-button govuk-button--secondary\"> {{ \"Previous\" | rpxTranslate }}</button>\n                    <button (click)=\"gotoCheckRetroRemissionPage(payment)\" class=\"govuk-button\"> {{ \"Continue\" | rpxTranslate }}</button>\n\n                </div>\n                <p>\n                  <a href=\"javascript:void(0)\" (click)=\"gotoCasetransationPageCancelBtnClicked($event)\" class=\"govuk-link\" data-module=\"govuk-button\">{{ \"Cancel\" | rpxTranslate }}</a>\n              </p>\n            </div>\n\n        </form>\n    </div>\n</ng-container>\n<ng-container *ngIf=\"viewStatus === 'checkretroremissionpage'\">\n    <input #myInput type='hidden' id='iFrameDrivenImageValue' value='CHECKRETROREMISSIONCONFIRMATION'>\n    <div class=\"govuk-warning-text\">\n        <h1 class=\"heading-large\"> {{ \"Check your answers\" | rpxTranslate }}</h1>\n    </div>\n    <table class=\"govuk-table\">\n        <tr class=\"govuk-table__row\">\n            <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Payment reference\" | rpxTranslate }}</td>\n            <td class=\"govuk-table__cell\">{{remessionPayment ? remessionPayment.reference: ' '}}</td>\n        </tr>\n        <tr class=\"govuk-table__row\">\n            <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Payment amount\" | rpxTranslate }}</td>\n            <td class=\"govuk-table__cell\">£{{ remessionPayment ? getFormattedCurrency(remessionPayment.amount): ' ' | currency :'GBP':'symbol':'1.2-2'}} </td>\n        </tr>\n        <tr class=\"govuk-table__row\">\n            <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Payment status\" | rpxTranslate }}</td>\n            <td class=\"govuk-table__cell\">{{remessionPayment ? remessionPayment.status: ''}}</td>\n        </tr>\n        <tr class=\"govuk-table__row\">\n            <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Fee\" | rpxTranslate }}</td>\n            <td class=\"govuk-table__cell\">{{ fee.code }} - {{ fee.description | rpxTranslate }} </td>\n        </tr>\n        <tr class=\"govuk-table__row\">\n          <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Fee amount\" | rpxTranslate }}</td>\n          <td class=\"govuk-table__cell\">{{ fee.calculated_amount/fee.volume| currency:'GBP':'symbol-narrow':'1.2-2' }}</td>\n      </tr>\n        <tr class=\"govuk-table__row\">\n            <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Help with fees or remission reference\" | rpxTranslate }}</td>\n            <td class=\"govuk-table__cell\">{{ remissionForm.controls.remissionCode.value?.trim() }}\n             <a (click)=\"gotoProcessRetroRemissionPage()\" class=\"govuk-link right\" >{{ \"Change\" | rpxTranslate }}</a>\n            </td>\n        </tr>\n        <tr class=\"govuk-table__row\">\n            <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Remission amount\" | rpxTranslate }}</td>\n            <td class=\"govuk-table__cell\">{{remissionForm.controls.amount.value  | currency:'GBP':'symbol-narrow':'1.2-2' }}\n                <a (click)=\"gotoAmountRetroRemission()\" class=\"govuk-link right\" >{{ \"Change\" | rpxTranslate }}</a>\n            </td>\n        </tr>\n    </table>\n\n    <button type=\"submit\" class=\"button govuk-button--secondary\" (click)=\"gotoAmountRetroRemission()\">{{ \"Previous\" | rpxTranslate }}</button>\n    <button type=\"submit\" [disabled]=\"isConfirmationBtnDisabled\" [ngClass]='isConfirmationBtnDisabled ? \"button button--disabled govuk-!-margin-right-1\" : \"button govuk-!-margin-right-1\"' (click)=\"confirmRetroRemission()\"> {{ \"Add remission\" | rpxTranslate }} </button>\n    <p> <a href=\"javascript:void(0)\" (click)=\"gotoCasetransationPageCancelBtnClicked($event)\" class=\"govuk-link\" data-module=\"govuk-button\"> {{ \"Cancel\" | rpxTranslate }}</a> </p>\n\n</ng-container>\n\n<ng-container *ngIf=\"viewStatus === 'retroremissionconfirmationpage'\">\n    <input #myInput type='hidden' id='iFrameDrivenImageValue' value='RETROREMISSIONCONFIRMATIONPAGE'>\n  <div class=\"govuk-grid-row\">\n    <div >\n      <div class=\"govuk-panel govuk-panel-border--confirmation\">\n        <h1 class=\"govuk-panel__title\">\n          {{ \"Remission added\" | rpxTranslate }}\n        </h1>\n        <div *ngIf=\"remessionPayment.status === 'Success'\" class=\"govuk-panel__body\">\n            <p class=\"govuk-body\"><strong>{{ \"The amount to be refunded should be\" | rpxTranslate }} {{remissionForm.controls.amount.value | currency:'GBP':'symbol-narrow':'1.2-2' }}</strong></p>\n\n          </div>\n        </div>\n        <div *ngIf=\"remessionPayment.status === 'Success'\" >\n            <button type=\"submit\" [disabled]=\"!canRefundBeApplied()\" [ngClass]='isConfirmationBtnDisabled ? \"button button--disabled govuk-!-margin-right-1\" : \"button govuk-!-margin-right-1\"' (click)=\"gotoProcessRetroRemission()\">{{ \"Continue\" | rpxTranslate }} </button>\n          </div>\n          <p class=\"govuk-body\">\n          <a href=\"javascript:void(0)\" (click)=\"gotoCasetransationPageCancelBtnClicked($event)\" class=\"govuk-link pointer\" data-module=\"govuk-button\">\n            {{ \"Return to case\" | rpxTranslate }}\n        </a>\n          </p>\n    </div>\n  </div>\n</ng-container>\n\n\n<ng-container *ngIf=\"viewStatus === 'remissionAddressPage'\">\n  <input #myInput type='hidden' id='iFrameDrivenImageValue' value='ADDRESSDETAILSRETROREMISSIONPAGE'>\n    <h1 class=\"govuk-heading-l\">{{ \"Process refund\" | rpxTranslate }}</h1>\n    <h2 class=\"govuk-heading-m govuk-font19px\">{{ \"Case reference\" | rpxTranslate }}: {{ccdCaseNumber | ccdHyphens }}</h2>\n  <ccpay-contact-details\n  [addressObj] = notification\n  (assignContactDetails)=\"getContactDetails($event, 'checkaddRefundpage')\"\n  (redirectToIssueRefund)=\"gotoRemissionSuccess($event)\" ></ccpay-contact-details>\n  <p>\n      <a (click)=\"gotoCasetransationPageCancelBtnClicked($event)\" class=\"govuk-link\" data-module=\"govuk-button\">\n          {{ \"Cancel\" | rpxTranslate }}\n      </a>\n  </p>\n\n</ng-container>\n\n<ng-container *ngIf=\"viewStatus === 'checkaddRefundpage'\">\n    <input #myInput type='hidden' id='iFrameDrivenImageValue' value='CHECKRETROREMISSIONCONFIRMATION'>\n    <div class=\"govuk-warning-text\">\n        <h1 class=\"heading-large\"> {{ \"Check your answers\" | rpxTranslate }}</h1>\n    </div>\n    <table class=\"govuk-table\">\n\n      <tr class=\"govuk-table__row\">\n        <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Reason for refund\" | rpxTranslate }}</td>\n        <td class=\"govuk-table__cell\">{{ \"Retrospective remission\" | rpxTranslate }}</td>\n      </tr>\n\n        <tr class=\"govuk-table__row\">\n            <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Payment reference\" | rpxTranslate }}</td>\n            <td class=\"govuk-table__cell\">{{remessionPayment ? remessionPayment.reference: ' '}}</td>\n        </tr>\n        <tr class=\"govuk-table__row\">\n            <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Payment amount\" | rpxTranslate }}</td>\n            <td class=\"govuk-table__cell\">£{{ remessionPayment ? getFormattedCurrency(remessionPayment.amount): ' ' | currency :'GBP':'symbol':'1.2-2'}} </td>\n        </tr>\n        <tr class=\"govuk-table__row\">\n            <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Payment status\" | rpxTranslate }}</td>\n            <td class=\"govuk-table__cell\">{{remessionPayment ? remessionPayment.status: '' | rpxTranslate}}</td>\n        </tr>\n        <tr class=\"govuk-table__row\">\n            <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Fee\" | rpxTranslate }}</td>\n            <td class=\"govuk-table__cell\">{{ fee.code }} - {{ fee.description | rpxTranslate }} ({{ fee.calculated_amount/fee.volume| currency:'GBP':'symbol-narrow':'1.2-2' }}) </td>\n        </tr>\n        <tr class=\"govuk-table__row\">\n            <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Help with fees or remission reference\" | rpxTranslate }}</td>\n            <td class=\"govuk-table__cell\">{{ remissionForm.controls.remissionCode.value?.trim() }}\n            </td>\n        </tr>\n\n        <tr class=\"govuk-table__row\">\n          <td *ngIf=\"remessionPayment.status === 'Success'\" class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Remission amount\" | rpxTranslate }}</td>\n          <td class=\"govuk-table__cell\">{{remissionForm.controls.amount.value  | currency:'GBP':'symbol-narrow':'1.2-2' }}\n          </td>\n        </tr>\n\n        <tr class=\"govuk-table__row\">\n            <td *ngIf=\"remessionPayment.status === 'Success'\" class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Refund amount\" | rpxTranslate }}</td>\n            <td class=\"govuk-table__cell\">{{ getRefundAmountToBeDisplayedForContinueJourney()| currency:'GBP':'symbol-narrow':'1.2-2' }}\n            </td>\n        </tr>\n        <tr class=\"govuk-table__row\">\n          <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Send to\" | rpxTranslate }}</td>\n          <td class=\"govuk-table__cell\">{{orderParty}}</td>\n      </tr>\n      <tr class=\"govuk-table__row\">\n        <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Send via\" | rpxTranslate }}</td>\n        <td class=\"govuk-table__cell whitespace-inherit\">\n          <div *ngIf=\"contactDetailsObj?.notification_type === 'EMAIL'\" class=\"contactDetails-width\">\n            <strong>{{ \"Email\" | rpxTranslate }}</strong>\n            <br/>\n            {{contactDetailsObj?.email?.trim()}}\n          </div>\n          <div *ngIf=\"contactDetailsObj?.notification_type === 'LETTER'\" class=\"contactDetails-width\">\n            <strong>{{ \"Post\" | rpxTranslate }}</strong>\n            <br/>\n            {{contactDetailsObj?.address_line?.trim()}}&nbsp;{{contactDetailsObj?.city?.trim()}}&nbsp;{{contactDetailsObj?.county?.trim()}}&nbsp;{{contactDetailsObj?.country?.trim()}}&nbsp;{{contactDetailsObj?.postal_code?.trim()}}\n          </div>\n          <a (click)=\"gotoProcessRetroRemission(contactDetailsObj)\" class=\"govuk-link right\" >{{ \"Change\" | rpxTranslate }}</a>\n        </td>\n      </tr>\n      <tr class=\"govuk-table__row\">\n        <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Notification\" | rpxTranslate }}</td>\n        <td class=\"govuk-table__cell\">{{templateInstructionType}}\n            <a *ngIf=\"!notificationPreview\" href=\"Javascript:void(0)\" class=\"govuk-link right\" (click)=\"showNotificationPreview()\">\n              {{ \"Preview\" | rpxTranslate }}\n            </a>\n            <a *ngIf=\"notificationPreview\" href=\"Javascript:void(0)\" class=\"govuk-link right\" (click)=\"hideNotificationPreview()\">\n              {{ \"Hide Preview\" | rpxTranslate }}\n            </a>\n        </td>\n      </tr>\n    </table>\n\n    <app-notification-preview *ngIf=\"notificationPreview\"\n    [payment]=\"remessionPayment\"\n    [contactDetails]=\"contactDetailsObj\"\n    [refundReason]=\"'RR036'\"\n    [refundAmount]=\"remissionForm.controls.amount.value\"></app-notification-preview>\n\n    <button type=\"submit\" class=\"button govuk-button--secondary\" (click)=\"gotoProcessRetroRemission(contactDetailsObj)\">{{ \"Previous\" | rpxTranslate }}</button>\n    <button type=\"submit\" [disabled]=\"isConfirmationBtnDisabled\" [ngClass]='isConfirmationBtnDisabled ? \"button button--disabled govuk-!-margin-right-1\" : \"button govuk-!-margin-right-1\"' (click)=\"processRefund()\"> {{ \"Submit refund\" | rpxTranslate }} </button>\n    <p> <a href=\"javascript:void(0)\" (click)=\"gotoCasetransationPageCancelBtnClicked($event)\" class=\"govuk-link\" data-module=\"govuk-button\"> {{ \"Cancel\" | rpxTranslate }}</a> </p>\n\n</ng-container>\n\n<ng-container *ngIf=\"viewStatus === 'refundconfirmationpage'\">\n    <input #myInput type='hidden' id='iFrameDrivenImageValue' value='RETROREMISSIONREFUNDCONFIRMATIONPAGE'>\n    <div class=\"govuk-grid-row\">\n      <div >\n        <div class=\"govuk-panel govuk-panel--confirmation\">\n          <h1 class=\"govuk-panel_remission_title\">\n            {{ \"Refund submitted\" | rpxTranslate }}\n          </h1>\n\n          <div class=\"govuk-panel__body\">\n            <p class=\"govuk-body white\"><strong class=\"white\">{{ \"Refund reference\" | rpxTranslate }}: {{refundReference}}</strong></p>\n          </div>\n\n        </div>\n        <div *ngIf=\"isPaymentSuccess\">\n        <h2 class=\"govuk-heading-l\">{{ \"What happens next\" | rpxTranslate }}</h2>\n        <p class=\"govuk-body\">\n          {{ \"A refund request for\" | rpxTranslate }} {{refundAmount  | currency:'GBP':'symbol-narrow':'1.2-2' }} {{ \"has been created and will be passed to a team leader to approve\" | rpxTranslate }}.\n        </p>\n      </div>\n      <p class=\"govuk-body\">\n      <a href=\"javascript:void(0)\" (click)=\"gotoCasetransationPageCancelBtnClicked($event)\" class=\"govuk-link pointer\" data-module=\"govuk-button\">\n        {{ \"Return to case\" | rpxTranslate }}\n    </a>\n      </p>\n      </div>\n    </div>\n\n</ng-container>\n\n<!-- Issue Refund Section -->\n<ng-container *ngIf=\"viewCompStatus === 'issuerefund' && isRefundRemission\">\n  <div class=\"govuk-form-group\">\n    <form [formGroup]=\"remissionForm\" novalidate>\n    <h1 class=\"heading-large\">{{ \"Process refund\" | rpxTranslate }}</h1>\n    <h2 class=\"heading-medium\">{{ \"Case reference\" | rpxTranslate }}:{{ccdCaseNumber | ccdHyphens }}</h2>\n    <span id=\"how-contacted-conditional-hint\" class=\"form-hint govuk-font19px\">\n      {{ \"Payment reference\" | rpxTranslate }}: {{paymentReference}}\n    </span>\n    <h3 class=\"heading-small\">{{ \"Select fees to be refunded\" | rpxTranslate }}</h3>\n    <!--TABLE-->\n    <div>\n      <table class=\"govuk-table\">\n        <thead class=\"govuk-table__head\">\n          <tr class=\"govuk-table__row\">\n            <td class=\"govuk-table__header  col-1\" scope=\"col\">{{ \"Select\" | rpxTranslate }}</td>\n            <td class=\"govuk-table__header col-18\" scope=\"col\">{{ \"Fee description\" | rpxTranslate }}</td>\n            <td class=\"govuk-table__header col-6\" scope=\"col\">{{ \"Fee amount\" | rpxTranslate }}</td>\n            <td class=\"govuk-table__header col-6\" scope=\"col\">{{ \"Total paid\" | rpxTranslate }}</td>\n            <td class=\"govuk-table__header col-6\" scope=\"col\">{{ \"Remission amount\" | rpxTranslate }}</td>\n            <td class=\"govuk-table__header col-6\" scope=\"col\">{{ \"Quantity\" | rpxTranslate }}</td>\n            <td class=\"govuk-table__header col-8\" scope=\"col\">{{ \"Amount to refund\" | rpxTranslate }}</td>\n            <td class=\"govuk-table__header\" scope=\"col\"></td>\n          </tr>\n        </thead>\n        <tbody class=\"govuk-table__body\" *ngIf=\"!isFullyRefund\">\n          <tr class=\"govuk-table__row\" formArrayName=\"feesList\" *ngFor=\"let fee of feesList?.controls; let i = index\">\n            <td class=\"govuk-table__cell\">\n              <div  [formGroupName]=\"i\" class=\"govuk-checkboxes govuk-checkboxes--large\" data-module=\"govuk-checkboxes\">\n                <div class=\"govuk-checkboxes__item\">\n                  <input\n                  class=\"govuk-checkboxes__input\"\n                  (click)=\"check_en(i,fee.controls['id'].value,fee.controls['apportion_amount'].value,fee.controls['volume'].value)\"\n                  id=\"{{fee.controls['id'].value}}\"\n                  name=\"organisation\"\n                  type=\"checkbox\"\n                  value=\"{{fee.controls['id'].value}}\"\n                  formControlName=\"selected\" >\n                  <label class=\"govuk-label govuk-checkboxes__label\" for=\"{{fee.controls['id'].value}}\">\n                    <span style=\"display:none\">{{ \"Select\" | rpxTranslate }}</span>\n                  </label>\n                </div>\n              </div>\n            </td>\n            <td class=\"govuk-table__cell  whitespace-inherit\">{{fee.controls['description'].value}} </td>\n            <td class=\"govuk-table__cell  whitespace-inherit left\" >\n              <div type=\"hidden\" style=\"display:none;background-color:white;\" id=\"feeVOl_{{fee.controls['id'].value}}\">{{ fee.controls['calculated_amount'].value / fee.controls['volume'].value }}</div>\n              {{ fee.controls['calculated_amount'].value / fee.controls['volume'].value | currency:'GBP':'symbol-narrow':'1.2-2' }}\n            </td>\n            <td class=\"govuk-table__cell  whitespace-inherit left\" >{{ fee.controls['apportion_amount'].value | currency:'GBP':'symbol-narrow':'1.2-2'}} </td>\n            <td class=\"govuk-table__cell  whitespace-inherit left\" >\n              <div type=\"hidden\" style=\"display:none;background-color:white;\" id=\"feeVOl_{{fee.controls['id'].value}}\">{{ this.getRemissionsHwfAmount(fee.controls['code'].value)}}</div>\n              {{ this.getRemissionsHwfAmount(fee.controls['code'].value) | currency:'GBP':'symbol-narrow':'1.2-2' }}\n            </td>\n            <td class=\"govuk-table__cell  whitespace-inherit left\"  *ngIf=\"fee.controls['volume'].value ===1\">\n              <input disabled=\"disabled\"  class=\"govuk-input govuk-input--width-4 center\"  id=\"VolumeUpdated_{{fee.controls['id'].value}}\" name=\"VolumeUpdated_{{fee.controls['id'].value}}\" type=\"text\"   value=\"{{fee.controls['volume'].value}}\">\n            </td>\n            <td class=\"govuk-table__cell  whitespace-inherit left\"  *ngIf=\"fee.controls['volume'].value >1\">\n              <div [formGroupName]=\"i\">\n                <input disabled=\"disabled\"  class=\"govuk-input govuk-input--width-4 center\"  id=\"feeVolumeUpdated_{{fee.controls['id'].value}}\" (keyup)=\"calAmtToRefund($event.target.value,fee.controls['calculated_amount'].value,fee.controls['volume'].value,i)\" value=\"{{fee.controls['updated_volume'].value}}\"  name=\"feeVolumeUpdated_{{fee.controls['id'].value}}\" formControlName=\"updated_volume\" type=\"text\" >\n              </div>\n            </td>\n            <td class=\"govuk-table__cell  whitespace-inherit center\" scope=\"row\">\n                <div  [formGroupName]=\"i\"  class=\"hmcts-currency-input\">\n                  <div class=\"hmcts-currency-input__symbol\" aria-hidden=\"true\">£</div>\n                  <input disabled=\"disabled\" class=\"govuk-input govuk-input--width-small\" id=\"feeAmount_{{fee.controls['id'].value}}\" name=\"feeAmount_{{fee.controls['id'].value}}\" type=\"text\" aria-describedby=\"amount-currency \"  pattern=\"[0-9]*\" formControlName=\"refund_amount\">\n                  <input id=\"feeVolume_{{fee.controls['id'].value}}\" name=\"feeVolume_{{fee.controls['id'].value}}\" value= \"{{fee.controls['volume'].value}}\" type=\"hidden\" formControlName=\"volume\">\n                  <input id=\"feeApportionAmount_{{fee.controls['id'].value}}\" name=\"feeApportionAmount_{{fee.controls['id'].value}}\" value= \"{{fee.controls['apportion_amount'].value}}\" type=\"hidden\" formControlName=\"apportion_amount\">\n                  <input id=\"calculatedAmount_{{fee.controls['id'].value}}\" name=\"calculatedAmount_{{fee.controls['id'].value}}\" value= \"{{fee.controls['calculated_amount'].value}}\" type=\"hidden\" formControlName=\"calculated_amount\">\n               </div>\n            </td>\n          </tr>\n        </tbody>\n        <tbody class=\"govuk-table__body\" *ngIf=\"isFullyRefund\">\n          <tr class=\"govuk-table__row\" *ngFor=\"let fee of fees; let i = index\">\n            <td class=\"govuk-table__cell\">\n              <div  class=\"govuk-checkboxes govuk-checkboxes--large\" data-module=\"govuk-checkboxes\">\n                <div class=\"govuk-checkboxes__item\">\n                  <input\n                  class=\"govuk-checkboxes__input\"\n\n                  id=\"{{fee.id}}\"\n                  name=\"organisation\"\n                  type=\"checkbox\"\n                  value=\"{{fee.id}}\"\n                  disabled=\"disabled\"\n                  [checked]=\"true\" >\n                  <label class=\"govuk-label govuk-checkboxes__label\" for=\"{{fee.id}}\">\n                    <span style=\"display:none\">{{ \"Select\" | rpxTranslate }}</span>\n                  </label>\n                </div>\n              </div>\n            </td>\n            <td class=\"govuk-table__cell  whitespace-inherit\">{{ fee.description | rpxTranslate }} </td>\n            <td class=\"govuk-table__cell  whitespace-inherit left\" >\n              <div type=\"hidden\" style=\"display:none;background-color:white;\" id=\"feeVOl_{{fee.id}}\">{{ fee.calculated_amount / fee.volume }}</div>\n              {{ fee.calculated_amount / fee.volume| currency:'GBP':'symbol-narrow':'1.2-2' }}\n            </td>\n            <td class=\"govuk-table__cell  whitespace-inherit left\" >{{ payment.amount | currency:'GBP':'symbol-narrow':'1.2-2'}} </td>\n\n            <td class=\"govuk-table__cell  whitespace-inherit left\" >\n              <div type=\"hidden\" style=\"display:none;background-color:white;\" id=\"feeRemission_{{fee.id}}\">{{ this.getRemissionValueForFullyRefund()}}</div>\n              {{ this.getRemissionsHwfAmount(fee.code) | currency:'GBP':'symbol-narrow':'1.2-2' }}\n\n            </td>\n\n            <td class=\"govuk-table__cell  whitespace-inherit left\">\n              <div >\n              <input disabled=\"disabled\"  class=\"govuk-input govuk-input--width-4 center\"  id=\"feeVolumeUpdated_{{fee.id}}\"  value=\"{{fee.volume}}\"  name=\"feeVolumeUpdated_{{fee.id}}\" type=\"text\" >\n            </div>\n            </td>\n\n            <td class=\"govuk-table__cell  whitespace-inherit center\" scope=\"row\">\n\n                <div class=\"hmcts-currency-input\">\n\n                  <div class=\"hmcts-currency-input__symbol\" aria-hidden=\"true\">£</div>\n                  <input disabled=\"disabled\" class=\"govuk-input govuk-input-width-10-left\" id=\"feeAmount_{{fee.id}}\" name=\"feeAmount_{{fee.id}}\" type=\"text\" aria-describedby=\"amount-currency \"  value=\"{{ payment.amount}}\" pattern=\"[0-9]*\" >\n                </div>\n\n            </td>\n          </tr>\n        </tbody>\n        <tbody class=\"govuk-table__body\" *ngIf=\"fees?.length === 0\">\n          <td class=\"govuk-table__cell\" colspan=\"6\">{{ \"No fees recorded\" | rpxTranslate }}</td>\n        </tbody>\n      </table>\n    </div>\n    <div class=\"govuk-button-group\">\n\n\n  <a  (click)=\"gotoServiceRequestPage($event)\"  *ngIf=\"!isFullyRefund\" draggable=\"false\" class=\"govuk-button govuk-button--secondary\" data-module=\"govuk-button\">\n    {{ \"Previous\" | rpxTranslate }}\n  </a>\n  <a  (click)=\"goToPaymentViewComponent()\"  *ngIf=\"isFullyRefund\" draggable=\"false\" class=\"govuk-button govuk-button--secondary\" data-module=\"govuk-button\">\n    {{ \"Previous\" | rpxTranslate }}\n  </a>\n\n  <button [disabled] = \"noneSelected()\" (click)=\"gotoIssuePage(isFullyRefund)\" class=\"govuk-button\">\n    {{ \"Continue\" | rpxTranslate }}\n  </button>\n\n    </div>\n    <p>\n      <a  (click)=\"gotoCasetransationPageCancelBtnClicked($event)\" class=\"govuk-link\" data-module=\"govuk-button\">{{ \"Cancel\" | rpxTranslate }}</a>\n    </p>\n  </form>\n  </div>\n</ng-container>\n\n<ng-container *ngIf=\"viewCompStatus === 'issuerefundpage1' && isRefundRemission\">\n\n    <input #myInput type='hidden' id='iFrameDrivenImageValue' value='ISSUEREFUNDPAGE'>\n    <h1 class=\"heading-large\">{{ \"Process refund\" | rpxTranslate }}</h1>\n    <h1 class=\"heading-medium\">{{ \"Case reference\" | rpxTranslate }}: {{ccdCaseNumber | ccdHyphens }}</h1>\n    <span id=\"how-contacted-conditional-hint govuk-font19px\" *ngIf=\"payment\" class=\"form-hint\">\n      {{ \"Payment reference\" | rpxTranslate }}: {{paymentReference}}\n    </span>\n    <span id=\"how-contacted-conditional-hint govuk-font19px\" *ngIf=\"refundPaymentReference\" class=\"form-hint\">\n      {{ \"Payment reference\" | rpxTranslate }}: {{refundPaymentReference}}\n    </span>\n    <h1 class=\"heading-large\">{{ \"Why are you making this refund\" | rpxTranslate }}?\n      </h1>\n\n\n      <div class=\"govuk-form-group\">\n          <form novalidate>\n              <div class=\"govuk-form-group\">\n                <form [formGroup]=\"remissionForm\" novalidate>\n                  <fieldset class=\"govuk-fieldset\" aria-describedby=\"how-contacted-conditional-hint\">\n\n                        <div\n                          [ngClass]=\"refundHasError ? 'govuk-radios govuk-radios--conditional form-group-error' : 'govuk-radios govuk-radios--conditional'\"\n                          data-module=\"govuk-radios\" >\n                          <p class=\"inline-error-message\" *ngIf=\"refundHasError\">\n                            <span *ngIf=\"refundHasError\">{{ \"Select a reason why you’re making this refund\" | rpxTranslate }}</span>\n                          </p>\n\n\n\n                          <div class = \"container-fluid\">\n                            <div class=\"row\">\n                            <div class=\"govuk-radios__item col-md-4\" *ngFor=\"let refund of commonRefundReasons; let i = index;\">\n                              <!-- <div *ngIf = \"{{refund.name}} !== 'Retrospective remission'\"> -->\n                                <input   class=\"govuk-radios__input\" id=\"{{refund.name}}\" name=\"refundReason\" type=\"radio\"\n                                formControlName=\"refundReason\" value={{refund.code}}\n                                  (change)=\"selectRadioButton(refund.code, refund.name)\">\n                                <label class=\"govuk-label--s govuk-radios__label govuk-font__custom\" for=\"how-contacted-conditional\">\n                                  {{refund.name}}\n                                </label>\n\n                                <div class=\"govuk-radios__conditional\" *ngIf=\"isRefundReasonsSelected && showReasonText && selectedRefundReason === refund.name \" >\n                                    <label class=\"govuk-label govuk-label--m\" for=\"{{refund.name}}\">\n                                        {{ \"Enter reason\" | rpxTranslate }}\n                                    </label>\n                                    <div [ngClass]=\"{'form-group-error': isReasonEmpty}\">\n                                    <p  class=\"inline-error-message\" *ngIf=\"isReasonEmpty\">\n                                        <span *ngIf=\"isReasonEmpty\">{{ \"Enter a reason why you’re making this refund\" | rpxTranslate }}</span>\n                                      </p>\n\n                                  <input class=\"govuk-input govuk-input--width-10\" [ngClass]=\"{'inline-error-class': isReasonEmpty}\" id=\"reason\" aria-label=\"reason\"  name=\"reason\" type=\"text\" aria-describedby=\"reason\" maxlength=\"30\" formControlName=\"reason\">\n                                </div>\n                                </div>\n                              <!-- </div> -->\n                            </div>\n                            </div>\n                          </div>\n                          <br/>\n                          <div>\n                              <select formControlName=\"refundDDReason\" class=\"govuk-select\" id=\"sort\"  (change)=\"selectchange($event)\">\n                                <option selected='selected' [defaultSelected]=true [value]=\"default\" >{{default}}</option>\n                                <!-- <option value=\"\" selected='selected'>Select a different reason</option> -->\n                                  <option  *ngFor=\"let refund of refundReasons;\" id=\"{{refund.name}}\"  value=\"{{refund.code}}\">{{refund.name}}</option>\n                                </select>\n\n                          </div>\n                              <br/>\n                              <div class=\"govuk-radios__conditional\" *ngIf=\"showReasonText &&  !isRefundReasonsSelected\" >\n                                <div [ngClass]=\"{'form-group-error': isReasonEmpty}\">\n                                  <label class=\"govuk-label govuk-label--m\" for=\"amount\">\n                                      {{ \"Enter reason\" | rpxTranslate }}\n                                  </label>\n                                  <p class=\"inline-error-message\" *ngIf=\"isReasonEmpty\">\n                                      <span *ngIf=\"isReasonEmpty\">{{ \"Enter a reason why you’re making this refund\" | rpxTranslate }}</span>\n                                    </p>\n                                <input class=\"govuk-input govuk-input--width-10\" [ngClass]=\"{'inline-error-class': isReasonEmpty}\" id=\"reason\" aria-label=\"reason\"  name=\"reason\" type=\"text\" aria-describedby=\"reason\" maxlength=\"{{reasonLength}}\"  formControlName=\"reason\">\n                                </div>\n                              </div>\n\n\n                        </div>\n                  </fieldset>\n                </form>\n             </div>\n             </form>\n      </div>\n      <div class=\"govuk-button-group\">\n          <button  (click)=\"gotoPartialFeeRefundScreen()\" class=\"govuk-button govuk-button--secondary\"> {{ \"Previous\" | rpxTranslate }}</button>\n          <button (click)=\"gotoIssueRefundConfirmation(payment)\" class=\"govuk-button\"> {{ \"Continue\" | rpxTranslate }}</button>\n      </div>\n      <p>\n        <a href=\"javascript:void(0)\" (click)=\"gotoCasetransationPageCancelBtnClicked($event)\" class=\"govuk-link\" data-module=\"govuk-button\">\n            {{ \"Cancel\" | rpxTranslate }}\n        </a>\n    </p>\n\n</ng-container>\n<ng-container *ngIf=\"viewStatus === 'contactDetailsPage'\">\n  <input #myInput type='hidden' id='iFrameDrivenImageValue' value='CAPTUREADDRESSDETAILSPAGE'>\n    <h1 class=\"govuk-heading-l\">{{ \"Process refund\" | rpxTranslate }}</h1>\n    <h2 class=\"govuk-heading-m govuk-font19px\">{{ \"Case reference\" | rpxTranslate }}: {{ccdCaseNumber | ccdHyphens }}</h2>\n    <span id=\"how-contacted-conditional-hint\" class=\"govuk-hint govuk-font19px\">\n      {{ \"Payment reference\" | rpxTranslate }}: {{paymentReference}}\n    </span>\n  <ccpay-contact-details\n  [addressObj] = notification\n  (assignContactDetails)=\"getContactDetails($event, 'checkissuerefundpage')\"\n  (redirectToIssueRefund)=\"gotoRefundReasonPage()\" ></ccpay-contact-details>\n  <p>\n      <a (click)=\"gotoCasetransationPageCancelBtnClicked($event)\" class=\"govuk-link\" data-module=\"govuk-button\">\n          {{ \"Cancel\" | rpxTranslate }}\n      </a>\n  </p>\n\n</ng-container>\n\n<ng-container *ngIf=\"viewStatus === 'checkissuerefundpage'\">\n    <input #myInput type='hidden' id='iFrameDrivenImageValue' value='CHECKISSUEREFUNDPAGE'>\n    <div class=\"govuk-warning-text\">\n\n        <h1 class=\"heading-large\"> {{ \"Check your answers\" | rpxTranslate }}</h1>\n    </div>\n    <table class=\"govuk-table\">\n\n        <tr class=\"govuk-table__row\">\n            <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Payment reference\" | rpxTranslate }}</td>\n            <td class=\"govuk-table__cell\">{{paymentReference}}</td>\n        </tr>\n        <tr class=\"govuk-table__row\">\n            <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Payment amount\" | rpxTranslate }}</td>\n            <td class=\"govuk-table__cell\">{{payment.amount | currency:'GBP':'symbol-narrow':'1.2-2'}}</td>\n        </tr>\n        <tr>\n        <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Reason for refund\" | rpxTranslate }}</td>\n        <td class=\"govuk-table__cell\">{{ displayRefundReason?.trim()  }}\n         <a (click)=\"changeIssueRefundReason()\" class=\"govuk-link right\" >{{ \"Change\" | rpxTranslate }}</a>\n        </td>\n      </tr>\n      <tr class=\"govuk-table__row\" *ngIf=\"!isFullyRefund\">\n        <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Refund amount\" | rpxTranslate }}</td>\n        <td class=\"govuk-table__cell\">{{totalRefundAmount | currency:'GBP':'symbol-narrow':'1.2-2'}}\n        <a (click)=\"changeRefundAmount()\" class=\"govuk-link right\" >{{ \"Change\" | rpxTranslate }}</a>\n        </td>\n      </tr>\n      <tr class=\"govuk-table__row\" *ngIf=\"isFullyRefund\">\n        <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Refund amount\" | rpxTranslate }}</td>\n        <td class=\"govuk-table__cell\">{{payment.amount | currency:'GBP':'symbol-narrow':'1.2-2'}}</td>\n      </tr>\n      <tr class=\"govuk-table__row\">\n          <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Send to\" | rpxTranslate }}</td>\n          <td class=\"govuk-table__cell\">{{orderParty}}</td>\n      </tr>\n      <tr class=\"govuk-table__row\">\n        <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Send via\" | rpxTranslate }}</td>\n        <td class=\"govuk-table__cell whitespace-inherit\">\n          <div *ngIf=\"contactDetailsObj?.notification_type === 'EMAIL'\" class=\"contactDetails-width\">\n            <strong>{{ \"Email\" | rpxTranslate }}</strong>\n            <br/>\n            {{contactDetailsObj?.email?.trim()}}\n          </div>\n          <div *ngIf=\"contactDetailsObj?.notification_type === 'LETTER'\" class=\"contactDetails-width\">\n            <strong>{{ \"Post\" | rpxTranslate }}</strong>\n            <br/>\n            {{contactDetailsObj?.address_line?.trim()}}&nbsp;{{contactDetailsObj?.city?.trim()}}&nbsp;{{contactDetailsObj?.county?.trim()}}&nbsp;{{contactDetailsObj?.country?.trim()}}&nbsp;{{contactDetailsObj?.postal_code?.trim()}}\n          </div>\n          <a (click)=\"gotoContactDetailsPage(contactDetailsObj)\" class=\"govuk-link right\" >{{ \"Change\" | rpxTranslate }}</a>\n        </td>\n      </tr>\n\n      <tr class=\"govuk-table__row\">\n        <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Notification\" | rpxTranslate }}</td>\n        <td class=\"govuk-table__cell\">{{templateInstructionType}}\n            <a *ngIf=\"!notificationPreview\" href=\"Javascript:void(0)\" class=\"govuk-link right\" (click)=\"showNotificationPreview()\">\n              {{ \"Preview\" | rpxTranslate }}\n            </a>\n            <a *ngIf=\"notificationPreview\" href=\"Javascript:void(0)\" class=\"govuk-link right\" (click)=\"hideNotificationPreview()\">\n              {{ \"Hide Preview\" | rpxTranslate }}\n            </a>\n        </td>\n      </tr>\n    </table>\n\n    <app-notification-preview *ngIf=\"notificationPreview\"\n    [payment]=\"payment\"\n    [contactDetails]=\"contactDetailsObj\"\n    [refundReason]=\"selectedRefundReasonCode\"\n    [refundAmount]=\"isFullyRefund ? payment.amount : totalRefundAmount\"></app-notification-preview>\n\n\n    <div class=\"govuk-button-group\">\n    <button type=\"submit\" class=\"button govuk-button--secondary\" (click)=\"gotoContactDetailsPage(contactDetailsObj)\"> {{ \"Previous\" | rpxTranslate }} </button>\n    <button type=\"submit\"\n    [disabled]=\"isConfirmationBtnDisabled\"\n    [ngClass]='isConfirmationBtnDisabled ? \"button button--disabled govuk-!-margin-right-1\" : \"button govuk-!-margin-right-1\"'\n    (click)=\"confirmIssueRefund(isFullyRefund)\">\n      {{ \"Submit refund\" | rpxTranslate }}\n    </button>\n    </div>\n    <p>\n        <a (click)=\"gotoCasetransationPageCancelBtnClicked($event)\" class=\"govuk-link\" data-module=\"govuk-button\">\n            {{ \"Cancel\" | rpxTranslate }}\n        </a>\n    </p>\n\n</ng-container>\n\n<!--Retro Refund-->\n<ng-container *ngIf=\"viewCompStatus === 'addrefundforremission'\">\n  <input #myInput type='hidden' id='iFrameDrivenImageValue' value='ADDRESSDETAILSRETROREMISSIONPAGE'>\n  <h1 class=\"govuk-heading-l\">{{ \"Process refund\" | rpxTranslate }}</h1>\n  <h2 class=\"govuk-heading-m govuk-font19px\">{{ \"Case reference\" | rpxTranslate }}: {{ccdCaseNumber | ccdHyphens }}</h2>\n  <span id=\"how-contacted-conditional-hint\" class=\"govuk-hint govuk-font19px\">\n    {{ \"Payment reference\" | rpxTranslate }}: {{paymentReference}}\n  </span>\n<ccpay-contact-details\n[addressObj] = notification\n(assignContactDetails)=\"getContactDetails($event, 'addrefundcheckandanswer')\"\n(redirectToIssueRefund)=\"gotoServiceRequestPage($event)\" ></ccpay-contact-details>\n<p>\n    <a (click)=\"gotoCasetransationPageCancelBtnClicked($event)\" class=\"govuk-link\" data-module=\"govuk-button\">\n        {{ \"Cancel\" | rpxTranslate }}\n    </a>\n</p>\n</ng-container>\n<ng-container *ngIf=\"viewStatus === 'addrefundcheckandanswer'\">\n    <input #myInput type='hidden' id='iFrameDrivenImageValue' value='ADDREFUNDFORREMISSION'>\n    <div class=\"govuk-warning-text\">\n\n        <h1 class=\"heading-large\"> {{ \"Check your answers\" | rpxTranslate }}</h1>\n    </div>\n    <table class=\"govuk-table\">\n        <tr class=\"govuk-table__row\">\n            <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Reason for refund\" | rpxTranslate }}</td>\n            <td class=\"govuk-table__cell\">{{ \"Retrospective remission\" | rpxTranslate }}</td>\n        </tr>\n        <tr class=\"govuk-table__row\">\n            <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Payment reference\" | rpxTranslate }}</td>\n            <td class=\"govuk-table__cell\">{{paymentReference}}</td>\n        </tr>\n        <tr class=\"govuk-table__row\">\n            <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Refund amount\" | rpxTranslate }}</td>\n            <td class=\"govuk-table__cell\">{{getRefundAmountToBeDisplayed(remission)| currency:'GBP':'symbol-narrow':'1.2-2'}}</td>\n        </tr>\n\n        <tr class=\"govuk-table__row\">\n          <td *ngIf=\"remessionPayment.status === 'Success'\" class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Remission amount\" | rpxTranslate }}</td>\n          <td class=\"govuk-table__cell\">{{getRemissionAmountToBeDisplayed(remission)| currency:'GBP':'symbol-narrow':'1.2-2' }}\n          </td>\n        </tr>\n\n        <tr class=\"govuk-table__row\">\n            <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Fee code\" | rpxTranslate }}</td>\n            <td class=\"govuk-table__cell\">{{remission.fee_code}}</td>\n        </tr>\n        <tr class=\"govuk-table__row\">\n            <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Fee amount\" | rpxTranslate }}</td>\n            <td class=\"govuk-table__cell\">{{feeamount | currency:'GBP':'symbol-narrow':'1.2-2'}}</td>\n        </tr>\n        <tr class=\"govuk-table__row\">\n          <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Send to\" | rpxTranslate }}</td>\n          <td class=\"govuk-table__cell\">{{orderParty}}</td>\n      </tr>\n      <tr class=\"govuk-table__row\">\n        <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Send via\" | rpxTranslate }}</td>\n        <td class=\"govuk-table__cell whitespace-inherit\">\n          <div *ngIf=\"contactDetailsObj?.notification_type === 'EMAIL'\" class=\"contactDetails-width\">\n            <strong>{{ \"Email\" | rpxTranslate }}</strong>\n            <br/>\n            {{contactDetailsObj?.email?.trim()}}\n          </div>\n          <div *ngIf=\"contactDetailsObj?.notification_type === 'LETTER'\" class=\"contactDetails-width\">\n            <strong>{{ \"Post\" | rpxTranslate }}</strong>\n            <br/>\n            {{contactDetailsObj?.address_line?.trim()}}&nbsp;{{contactDetailsObj?.city?.trim()}}&nbsp;{{contactDetailsObj?.county?.trim()}}&nbsp;{{contactDetailsObj?.country?.trim()}}&nbsp;{{contactDetailsObj?.postal_code?.trim()}}\n          </div>\n          <a (click)=\"gotoAddressPage(contactDetailsObj)\" class=\"govuk-link right\" >{{ \"Change\" | rpxTranslate }}</a>\n        </td>\n      </tr>\n\n      <tr class=\"govuk-table__row\">\n        <td class=\"govuk-table__cell govuk-!-font-weight-bold\">{{ \"Notification\" | rpxTranslate }}</td>\n        <td class=\"govuk-table__cell\">{{templateInstructionType}}\n            <a *ngIf=\"!notificationPreview\" href=\"Javascript:void(0)\" class=\"govuk-link right\" (click)=\"showNotificationPreview()\">\n              {{ \"Preview\" | rpxTranslate }}\n            </a>\n            <a *ngIf=\"notificationPreview\" href=\"Javascript:void(0)\" class=\"govuk-link right\" (click)=\"hideNotificationPreview()\">\n              {{ \"Hide Preview\" | rpxTranslate }}\n            </a>\n        </td>\n      </tr>\n    </table>\n\n    <app-notification-preview *ngIf=\"notificationPreview\"\n    [contactDetails]=\"contactDetailsObj\"\n    [paymentReference]=\"paymentReference\"\n    [payment]=\"paymentObj\"\n    [refundReason]=\"'RR036'\"\n    [refundAmount]=\"remission.hwf_amount\"></app-notification-preview>\n\n    <div class=\"govuk-button-group\">\n    <button type=\"submit\" class=\"button govuk-button--secondary\" (click)=\"gotoAddressPage(contactDetailsObj)\">{{ \"Previous\" | rpxTranslate }}</button>\n    <button type=\"submit\"\n    [disabled]=\"isConfirmationBtnDisabled\"\n    [ngClass]='isConfirmationBtnDisabled ? \"button button--disabled govuk-!-margin-right-1\" : \"button govuk-!-margin-right-1\"'\n    (click)=\"processRefund()\">\n      {{ \"Submit refund\" | rpxTranslate }}\n    </button>\n    </div>\n    <p>\n        <a href=\"javascript:void(0)\"  (click)=\"gotoCasetransationPageCancelBtnClicked($event)\" class=\"govuk-link\" data-module=\"govuk-button\">\n            {{ \"Cancel\" | rpxTranslate }}\n        </a>\n    </p>\n\n</ng-container>\n\n<ng-container *ngIf=\"viewStatus === 'retrorefundconfirmationpage'\">\n  <div class=\"govuk-grid-row\">\n    <div >\n      <div class=\"govuk-panel govuk-panel--confirmation\">\n        <h1 class=\"govuk-panel_remission_title\">\n          {{ \"Refund submitted\" | rpxTranslate }}\n        </h1>\n\n        <div class=\"govuk-panel__body\">\n          <p class=\"govuk-body white\"><strong class=\"white\">{{ \"Refund reference\" | rpxTranslate }}: {{refundReference}}</strong></p>\n        </div>\n\n      </div>\n      <div *ngIf=\"isPaymentSuccess\">\n      <h2 class=\"govuk-heading-l\">{{ \"What happens next\" | rpxTranslate }}</h2>\n      <p class=\"govuk-body\">\n        {{ \"A refund request for\" | rpxTranslate }} {{ refundAmount| currency:'GBP':'symbol-narrow':'1.2-2'}} {{ \"has been passed to a team leader to approve\" | rpxTranslate }}.\n      </p>\n    </div>\n    <p class=\"govuk-body\">\n    <a href=\"javascript:void(0)\" (click)=\"gotoCasetransationPageCancelBtnClicked($event)\" class=\"govuk-link pointer\" data-module=\"govuk-button\">\n      {{ \"Return to case\" | rpxTranslate }}\n  </a>\n    </p>\n    </div>\n  </div>\n</ng-container>\n\n<ng-container *ngIf=\"viewStatus === 'order-full-view'\">\n  <ccpay-service-request\n  [viewStatus] = \"viewStatus\"\n  [orderRef] = \"orderRef\"\n  [isServiceRequest]=\"isServiceRequest\"\n  [orderStatus] = \"orderStatus\"\n  [orderCreated] = \"orderCreated\"\n  [orderParty] = \"orderParty\"\n  [orderCCDEvent] = \"orderCCDEvent\"\n  [orderDetail] = \"orderDetail\"\n  [LOGGEDINUSERROLES] = \"LOGGEDINUSERROLES\"\n  [takePayment] = \"takePayment\"\n  [ccdCaseNumber] = \"ccdCaseNumber\"\n  [orderFeesTotal] = \"orderFeesTotal\"\n  [orderTotalPayments] = \"orderTotalPayments\"\n  [orderRemissionTotal] = \"orderRemissionTotal\">\n</ccpay-service-request>\n</ng-container>\n\n<ng-container *ngIf=\"viewStatus === 'payment-view'\">\n  <ccpay-payment-view\n  [LOGGEDINUSERROLES] = \"LOGGEDINUSERROLES\"\n  [isTurnOff] = \"isTurnOff\"\n  [isTakePayment] = \"takePayment\"\n  [caseType] = \"caseType\"\n  [isServiceRequest]=\"isServiceRequest\"\n  [orderRef] = \"orderRef\"\n  [orderStatus] = \"orderStatus\"\n  [orderCreated] = \"orderCreated\"\n  [orderParty] = \"orderParty\"\n  [orderCCDEvent] = \"orderCCDEvent\"\n  [orderDetail] = \"orderDetail\"\n  [orderFeesTotal] = \"orderFeesTotal\"\n  [orderTotalPayments] = \"orderTotalPayments\"\n  [orderRemissionTotal] = \"orderRemissionTotal\"\n  >\n</ccpay-payment-view>\n</ng-container>\n\n</div>\n"]}
|