@hmcts/ccpay-web-component 5.0.6 → 5.0.7-beta02

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (98) hide show
  1. package/bundles/hmcts-ccpay-web-component.umd.js +2306 -764
  2. package/bundles/hmcts-ccpay-web-component.umd.js.map +1 -1
  3. package/bundles/hmcts-ccpay-web-component.umd.min.js +1 -1
  4. package/bundles/hmcts-ccpay-web-component.umd.min.js.map +1 -1
  5. package/esm2015/hmcts-ccpay-web-component.js +33 -31
  6. package/esm2015/lib/components/add-remission/add-remission.component.js +695 -120
  7. package/esm2015/lib/components/case-transactions/case-transactions.component.js +31 -17
  8. package/esm2015/lib/components/contact-details/contact-details.component.js +447 -0
  9. package/esm2015/lib/components/fee-summary/fee-summary.component.js +18 -13
  10. package/esm2015/lib/components/payment-view/payment-view.component.js +241 -106
  11. package/esm2015/lib/components/process-refund/process-refund.component.js +49 -28
  12. package/esm2015/lib/components/refund-list/refund-list.component.js +3 -3
  13. package/esm2015/lib/components/refund-status/refund-status.component.js +211 -30
  14. package/esm2015/lib/components/reports/reports.component.js +13 -2
  15. package/esm2015/lib/components/service-request/service-request.component.js +237 -146
  16. package/esm2015/lib/components/table/table.component.js +24 -9
  17. package/esm2015/lib/interfaces/IFee.js +13 -1
  18. package/esm2015/lib/interfaces/IPayment.js +7 -1
  19. package/esm2015/lib/interfaces/IPaymentFailure.js +33 -0
  20. package/esm2015/lib/interfaces/IPutNotificationRequest.js +25 -0
  21. package/esm2015/lib/interfaces/IRefundContactDetails.js +25 -0
  22. package/esm2015/lib/interfaces/IRefundFee.js +21 -0
  23. package/esm2015/lib/interfaces/IRefundList.js +7 -1
  24. package/esm2015/lib/interfaces/IRefundsNotifications.js +21 -0
  25. package/esm2015/lib/interfaces/IRemission.js +7 -1
  26. package/esm2015/lib/interfaces/IResubmitRefundRequest.js +10 -2
  27. package/esm2015/lib/interfaces/PostIssueRefundRetroRemission.js +6 -2
  28. package/esm2015/lib/interfaces/PostRefundRetroRemission.js +20 -2
  29. package/esm2015/lib/payment-lib.component.js +13 -2
  30. package/esm2015/lib/payment-lib.module.js +3 -1
  31. package/esm2015/lib/payment-lib.service.js +16 -1
  32. package/esm2015/lib/services/notification/notification.service.js +85 -0
  33. package/esm2015/lib/services/payment-view/payment-view.service.js +20 -1
  34. package/esm2015/lib/services/refunds/refunds.service.js +10 -1
  35. package/esm2015/lib/services/shared/httpclient/webcomponent.http.client.js +1 -1
  36. package/esm5/hmcts-ccpay-web-component.js +33 -31
  37. package/esm5/lib/components/add-remission/add-remission.component.js +817 -125
  38. package/esm5/lib/components/case-transactions/case-transactions.component.js +31 -17
  39. package/esm5/lib/components/contact-details/contact-details.component.js +472 -0
  40. package/esm5/lib/components/fee-summary/fee-summary.component.js +18 -13
  41. package/esm5/lib/components/payment-view/payment-view.component.js +280 -124
  42. package/esm5/lib/components/process-refund/process-refund.component.js +52 -78
  43. package/esm5/lib/components/refund-list/refund-list.component.js +3 -3
  44. package/esm5/lib/components/refund-status/refund-status.component.js +247 -28
  45. package/esm5/lib/components/reports/reports.component.js +13 -2
  46. package/esm5/lib/components/service-request/service-request.component.js +278 -176
  47. package/esm5/lib/components/table/table.component.js +27 -9
  48. package/esm5/lib/interfaces/IFee.js +13 -1
  49. package/esm5/lib/interfaces/IPayment.js +7 -1
  50. package/esm5/lib/interfaces/IPaymentFailure.js +33 -0
  51. package/esm5/lib/interfaces/IPutNotificationRequest.js +23 -0
  52. package/esm5/lib/interfaces/IRefundContactDetails.js +25 -0
  53. package/esm5/lib/interfaces/IRefundFee.js +21 -0
  54. package/esm5/lib/interfaces/IRefundList.js +7 -1
  55. package/esm5/lib/interfaces/IRefundsNotifications.js +21 -0
  56. package/esm5/lib/interfaces/IRemission.js +7 -1
  57. package/esm5/lib/interfaces/IResubmitRefundRequest.js +8 -2
  58. package/esm5/lib/interfaces/PostIssueRefundRetroRemission.js +5 -2
  59. package/esm5/lib/interfaces/PostRefundRetroRemission.js +16 -2
  60. package/esm5/lib/payment-lib.component.js +12 -2
  61. package/esm5/lib/payment-lib.module.js +3 -1
  62. package/esm5/lib/payment-lib.service.js +23 -1
  63. package/esm5/lib/services/notification/notification.service.js +89 -0
  64. package/esm5/lib/services/payment-view/payment-view.service.js +29 -1
  65. package/esm5/lib/services/refunds/refunds.service.js +16 -1
  66. package/esm5/lib/services/shared/httpclient/webcomponent.http.client.js +1 -1
  67. package/fesm2015/hmcts-ccpay-web-component.js +1936 -532
  68. package/fesm2015/hmcts-ccpay-web-component.js.map +1 -1
  69. package/fesm5/hmcts-ccpay-web-component.js +2390 -804
  70. package/fesm5/hmcts-ccpay-web-component.js.map +1 -1
  71. package/hmcts-ccpay-web-component.d.ts +32 -30
  72. package/hmcts-ccpay-web-component.metadata.json +1 -1
  73. package/lib/components/add-remission/add-remission.component.d.ts +45 -3
  74. package/lib/components/case-transactions/case-transactions.component.d.ts +2 -1
  75. package/lib/components/contact-details/contact-details.component.d.ts +49 -0
  76. package/lib/components/payment-view/payment-view.component.d.ts +30 -6
  77. package/lib/components/process-refund/process-refund.component.d.ts +6 -1
  78. package/lib/components/refund-status/refund-status.component.d.ts +34 -6
  79. package/lib/components/service-request/service-request.component.d.ts +28 -9
  80. package/lib/components/table/table.component.d.ts +1 -0
  81. package/lib/interfaces/IFee.d.ts +6 -0
  82. package/lib/interfaces/IPayment.d.ts +3 -0
  83. package/lib/interfaces/IPaymentFailure.d.ts +13 -0
  84. package/lib/interfaces/IPutNotificationRequest.d.ts +6 -0
  85. package/lib/interfaces/IRefundContactDetails.d.ts +9 -0
  86. package/lib/interfaces/IRefundFee.d.ts +7 -0
  87. package/lib/interfaces/IRefundList.d.ts +4 -0
  88. package/lib/interfaces/IRefundsNotifications.d.ts +16 -0
  89. package/lib/interfaces/IRemission.d.ts +3 -0
  90. package/lib/interfaces/IResubmitRefundRequest.d.ts +5 -1
  91. package/lib/interfaces/PostIssueRefundRetroRemission.d.ts +3 -1
  92. package/lib/interfaces/PostRefundRetroRemission.d.ts +7 -1
  93. package/lib/payment-lib.component.d.ts +3 -0
  94. package/lib/payment-lib.service.d.ts +3 -0
  95. package/lib/services/notification/notification.service.d.ts +15 -0
  96. package/lib/services/payment-view/payment-view.service.d.ts +2 -0
  97. package/lib/services/refunds/refunds.service.d.ts +2 -0
  98. package/package.json +5 -1
@@ -0,0 +1,472 @@
1
+ /**
2
+ * @fileoverview added by tsickle
3
+ * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
4
+ */
5
+ import { Component, Output, EventEmitter, Input } from '@angular/core';
6
+ import { FormBuilder, Validators, FormControl } from '@angular/forms';
7
+ import { PaymentLibComponent } from '../../payment-lib.component';
8
+ import { NotificationService } from '../../services/notification/notification.service';
9
+ var ContactDetailsComponent = /** @class */ (function () {
10
+ function ContactDetailsComponent(formBuilder, notificationService, paymentLibComponent) {
11
+ this.formBuilder = formBuilder;
12
+ this.notificationService = notificationService;
13
+ this.paymentLibComponent = paymentLibComponent;
14
+ this.assignContactDetails = new EventEmitter();
15
+ this.assignContactDetailsInFefundsList = new EventEmitter();
16
+ this.redirectToIssueRefund = new EventEmitter();
17
+ this.pageTitle = 'Payment status history';
18
+ this.isEmailSAddressClicked = true;
19
+ this.isShowPickAddress = false;
20
+ this.isPostcodeClicked = false;
21
+ this.isManualAddressClicked = false;
22
+ this.addressPostcodeList = [];
23
+ this.isAddressBoxEmpty = false;
24
+ this.isEmailEmpty = false;
25
+ this.emailHasError = false;
26
+ this.isPostcodeEmpty = false;
27
+ this.postcodeHasError = false;
28
+ this.isaddressLine1Empty = false;
29
+ this.addressLine1HasError = false;
30
+ this.addressLine2HasError = false;
31
+ this.isTownOrCityEmpty = false;
32
+ this.townOrCityHasError = false;
33
+ this.isCountyEmpty = false;
34
+ this.countyHasError = false;
35
+ this.isMPostcodeEmpty = false;
36
+ this.mpostcodeHasError = false;
37
+ this.isCountryEmpty = false;
38
+ }
39
+ /**
40
+ * @return {?}
41
+ */
42
+ ContactDetailsComponent.prototype.ngOnInit = /**
43
+ * @return {?}
44
+ */
45
+ function () {
46
+ this.resetForm([false, false, false, false, false, false, false, false, false, false, false, false, false, false], 'all');
47
+ this.emailAddressForm = this.formBuilder.group({
48
+ email: new FormControl('', Validators.compose([
49
+ Validators.required,
50
+ Validators.pattern('^[a-z0-9._%+-]+@[a-z0-9-]+\\.[a-z]{2,4}$')
51
+ ]))
52
+ });
53
+ this.postCodeForm = this.formBuilder.group({
54
+ postcode: new FormControl('', Validators.compose([
55
+ Validators.required,
56
+ Validators.pattern('^([A-Za-z]{1,2}[0-9]{1,2}[A-Za-z]{0,1} ?[0-9][A-Za-z]{2})')
57
+ ]))
58
+ });
59
+ this.manualAddressForm = this.formBuilder.group({
60
+ addressl1: new FormControl('', Validators.compose([
61
+ Validators.required,
62
+ Validators.pattern('^[a-zA-Z0-9\\s,\'-]*$')
63
+ ])),
64
+ addressl2: new FormControl('', Validators.compose([
65
+ Validators.pattern('^[a-zA-Z0-9\\s,\'-]*$')
66
+ ])),
67
+ townorcity: new FormControl('', Validators.compose([
68
+ Validators.required,
69
+ Validators.pattern('^[a-zA-Z0-9\\s,\'-]*$')
70
+ ])),
71
+ county: new FormControl('', Validators.compose([
72
+ Validators.pattern('^[a-zA-Z0-9\\s,\'-]*$')
73
+ ])),
74
+ mpostcode: new FormControl('', Validators.compose([
75
+ Validators.required,
76
+ Validators.pattern('^([A-Za-z]{1,2}[0-9]{1,2}[A-Za-z]{0,1} ?[0-9][A-Za-z]{2})')
77
+ ])),
78
+ country: new FormControl('', Validators.compose([
79
+ Validators.required
80
+ ]))
81
+ });
82
+ if (this.addressObj !== undefined && this.addressObj !== '') {
83
+ this.setEditDetails();
84
+ }
85
+ if (this.isEditOperationInRefundList === undefined) {
86
+ this.isEditOperationInRefundList = false;
87
+ }
88
+ };
89
+ /**
90
+ * @return {?}
91
+ */
92
+ ContactDetailsComponent.prototype.setEditDetails = /**
93
+ * @return {?}
94
+ */
95
+ function () {
96
+ if (this.addressObj.notification_type === 'EMAIL') {
97
+ this.isEmailSAddressClicked = true;
98
+ this.isPostcodeClicked = false;
99
+ this.isManualAddressClicked = false;
100
+ this.emailAddressForm.setValue({ email: this.addressObj.contact_details.email });
101
+ }
102
+ else if (this.addressObj.notification_type === 'LETTER') {
103
+ this.isEmailSAddressClicked = false;
104
+ this.isPostcodeClicked = true;
105
+ this.isManualAddressClicked = true;
106
+ this.manualAddressForm.patchValue({
107
+ addressl1: this.addressObj.contact_details.address_line,
108
+ townorcity: this.addressObj.contact_details.city,
109
+ county: this.addressObj.contact_details.county,
110
+ country: this.addressObj.contact_details.country,
111
+ mpostcode: this.addressObj.contact_details.postal_code
112
+ });
113
+ }
114
+ };
115
+ /**
116
+ * @param {?} type
117
+ * @param {?} isLinkedClied
118
+ * @return {?}
119
+ */
120
+ ContactDetailsComponent.prototype.selectContactOption = /**
121
+ * @param {?} type
122
+ * @param {?} isLinkedClied
123
+ * @return {?}
124
+ */
125
+ function (type, isLinkedClied) {
126
+ this.resetForm([false, false, false, false, false, false, false, false, false, false, false, false, false, false, false], 'all');
127
+ if (type === 'Email' && isLinkedClied === 'false') {
128
+ this.isEmailSAddressClicked = true;
129
+ this.isPostcodeClicked = false;
130
+ this.isManualAddressClicked = false;
131
+ }
132
+ else if (type === 'Postcode' && isLinkedClied === 'false') {
133
+ this.isEmailSAddressClicked = false;
134
+ this.isPostcodeClicked = true;
135
+ this.isManualAddressClicked = false;
136
+ }
137
+ else if (type === 'Postcode' && isLinkedClied === 'true') {
138
+ this.isEmailSAddressClicked = false;
139
+ this.isPostcodeClicked = true;
140
+ this.isManualAddressClicked = true;
141
+ }
142
+ };
143
+ /**
144
+ * @return {?}
145
+ */
146
+ ContactDetailsComponent.prototype.finalFormSubmit = /**
147
+ * @return {?}
148
+ */
149
+ function () {
150
+ this.resetForm([false, false, false, false, false, false, false, false, false, false, false, false, false, false, false], 'all');
151
+ if (this.isEmailSAddressClicked) {
152
+ /** @type {?} */
153
+ var emailField = this.emailAddressForm.controls.email;
154
+ if (this.emailAddressForm.valid) {
155
+ if (!this.isEditOperationInRefundList) {
156
+ this.assignContactDetails.emit({
157
+ email: emailField.value,
158
+ notification_type: 'EMAIL'
159
+ });
160
+ }
161
+ else {
162
+ this.assignContactDetailsInFefundsList.emit({
163
+ email: emailField.value,
164
+ notification_type: 'EMAIL'
165
+ });
166
+ }
167
+ }
168
+ else {
169
+ if (emailField.value == '') {
170
+ this.resetForm([true, false, false, false, false, false, false, false, false, false, false, false, false, false], 'email');
171
+ }
172
+ if (emailField.value != '' && emailField.invalid) {
173
+ this.resetForm([false, true, false, false, false, false, false, false, false, false, false, false, false, false], 'email');
174
+ }
175
+ }
176
+ }
177
+ else if (this.isPostcodeClicked && !this.isManualAddressClicked) {
178
+ this.postcodeValidation('FS');
179
+ }
180
+ else if (this.isPostcodeClicked && this.isManualAddressClicked) {
181
+ /** @type {?} */
182
+ var fieldCtrls = this.manualAddressForm.controls;
183
+ if (this.manualAddressForm.valid) {
184
+ if (!this.isEditOperationInRefundList) {
185
+ this.assignContactDetails.emit({
186
+ address_line: fieldCtrls.addressl1.value + ' ' + fieldCtrls.addressl2.value,
187
+ city: fieldCtrls.townorcity.value,
188
+ county: fieldCtrls.county.value,
189
+ postal_code: fieldCtrls.mpostcode.value,
190
+ country: fieldCtrls.country.value,
191
+ notification_type: 'LETTER'
192
+ });
193
+ }
194
+ else {
195
+ this.assignContactDetailsInFefundsList.emit({
196
+ address_line: fieldCtrls.addressl1.value + ' ' + fieldCtrls.addressl2.value,
197
+ city: fieldCtrls.townorcity.value,
198
+ county: fieldCtrls.county.value,
199
+ postal_code: fieldCtrls.mpostcode.value,
200
+ country: fieldCtrls.country.value,
201
+ notification_type: 'LETTER'
202
+ });
203
+ }
204
+ }
205
+ else {
206
+ if (fieldCtrls.addressl1.value == '') {
207
+ this.resetForm([false, false, false, false, true, false, false, false, false, false, false, false, false, false], 'address1');
208
+ }
209
+ if (fieldCtrls.addressl1.value != '' && fieldCtrls.addressl1.invalid) {
210
+ this.resetForm([false, false, false, false, false, true, false, false, false, false, false, false, false, false], 'address1');
211
+ }
212
+ if (fieldCtrls.addressl2.value != '' && fieldCtrls.addressl2.invalid) {
213
+ this.resetForm([false, false, false, false, false, false, true, false, false, false, false, false, false, false], 'address2');
214
+ }
215
+ if (fieldCtrls.townorcity.value == '') {
216
+ this.resetForm([false, false, false, false, false, false, false, true, false, false, false, false, false, false], 'town');
217
+ }
218
+ if (fieldCtrls.townorcity.value != '' && fieldCtrls.townorcity.invalid) {
219
+ this.resetForm([false, false, false, false, false, false, false, false, true, false, false, false, false, false], 'town');
220
+ }
221
+ if (fieldCtrls.county.value == '') {
222
+ this.resetForm([false, false, false, false, false, false, false, false, false, true, false, false, false, false], 'county');
223
+ }
224
+ if (fieldCtrls.county.value != '' && fieldCtrls.county.invalid) {
225
+ this.resetForm([false, false, false, false, false, false, false, false, false, false, true, false, false, false], 'county');
226
+ }
227
+ if (fieldCtrls.mpostcode.value == '') {
228
+ this.resetForm([false, false, false, false, false, false, false, false, false, false, false, true, false, false], 'mpostcode');
229
+ }
230
+ if (fieldCtrls.mpostcode.value != '' && fieldCtrls.mpostcode.invalid) {
231
+ this.resetForm([false, false, false, false, false, false, false, false, false, false, false, false, true, false], 'mpostcode');
232
+ }
233
+ if (fieldCtrls.country.value == '') {
234
+ this.resetForm([false, false, false, false, false, false, false, false, false, false, false, false, false, true], 'country');
235
+ }
236
+ }
237
+ }
238
+ };
239
+ /**
240
+ * @param {?} str
241
+ * @return {?}
242
+ */
243
+ ContactDetailsComponent.prototype.postcodeValidation = /**
244
+ * @param {?} str
245
+ * @return {?}
246
+ */
247
+ function (str) {
248
+ var _this = this;
249
+ this.resetForm([false, false, false, false, false, false, false, false, false, false, false, false, false, false, false], 'all');
250
+ /** @type {?} */
251
+ var postcodeField = this.postCodeForm.controls.postcode;
252
+ if (this.postCodeForm.valid) {
253
+ if (str === 'FA') {
254
+ this.notificationService.getAddressByPostcode(postcodeField.value).subscribe((/**
255
+ * @param {?} refundsNotification
256
+ * @return {?}
257
+ */
258
+ function (refundsNotification) {
259
+ _this.addressPostcodeList = refundsNotification['data']['results'];
260
+ _this.isShowPickAddress = refundsNotification['data']['header'].totalresults > 0;
261
+ if (!_this.isShowPickAddress) {
262
+ _this.resetForm([false, false, false, true, false, false, false, false, false, false, false, false, false], 'postcode');
263
+ }
264
+ })),
265
+ (/**
266
+ * @param {?} error
267
+ * @return {?}
268
+ */
269
+ function (error) {
270
+ _this.isShowPickAddress = false;
271
+ _this.errorMessage = error.replace(/"/g, "");
272
+ });
273
+ }
274
+ else if (str === 'FS') {
275
+ if (this.postcodeAddress !== undefined && this.postcodeAddress) {
276
+ this.isAddressBoxEmpty = false;
277
+ /** @type {?} */
278
+ var addressLine = "";
279
+ /** @type {?} */
280
+ var addressArray = this.postcodeAddress.ADDRESS.split(",");
281
+ for (var i = 0; i < addressArray.length - 2; i++) {
282
+ addressLine += addressArray[i];
283
+ }
284
+ /** @type {?} */
285
+ var addressObject = {
286
+ address_line: addressLine,
287
+ city: this.postcodeAddress.POST_TOWN,
288
+ county: this.postcodeAddress.LOCAL_CUSTODIAN_CODE_DESCRIPTION,
289
+ postal_code: this.postcodeAddress.POSTCODE,
290
+ country: 'United Kingdom',
291
+ notification_type: 'LETTER'
292
+ };
293
+ if (!this.isEditOperationInRefundList) {
294
+ this.assignContactDetails.emit(addressObject);
295
+ }
296
+ else {
297
+ this.assignContactDetailsInFefundsList.emit(addressObject);
298
+ }
299
+ }
300
+ else {
301
+ this.isAddressBoxEmpty = true;
302
+ }
303
+ }
304
+ }
305
+ else {
306
+ if (postcodeField.value == '') {
307
+ this.resetForm([false, false, true, false, false, false, false, false, false, false, false, false, false], 'postcode');
308
+ }
309
+ if (postcodeField.value != '' && postcodeField.invalid) {
310
+ this.resetForm([false, false, false, true, false, false, false, false, false, false, false, false, false], 'postcode');
311
+ }
312
+ }
313
+ };
314
+ /**
315
+ * @param {?} event
316
+ * @return {?}
317
+ */
318
+ ContactDetailsComponent.prototype.redirection = /**
319
+ * @param {?} event
320
+ * @return {?}
321
+ */
322
+ function (event) {
323
+ this.redirectToIssueRefund.emit(event);
324
+ };
325
+ /**
326
+ * @param {?} val
327
+ * @param {?} field
328
+ * @return {?}
329
+ */
330
+ ContactDetailsComponent.prototype.resetForm = /**
331
+ * @param {?} val
332
+ * @param {?} field
333
+ * @return {?}
334
+ */
335
+ function (val, field) {
336
+ if (field === 'email' || field === 'all') {
337
+ this.isEmailEmpty = val[0];
338
+ this.emailHasError = val[1];
339
+ }
340
+ if (field === 'postcode' || field === 'all') {
341
+ this.isPostcodeEmpty = val[2];
342
+ this.postcodeHasError = val[3];
343
+ }
344
+ if (field === 'address1' || field === 'all') {
345
+ this.isaddressLine1Empty = val[4];
346
+ this.addressLine1HasError = val[5];
347
+ }
348
+ if (field === 'address2' || field === 'all') {
349
+ this.addressLine2HasError = val[6];
350
+ }
351
+ if (field === 'town' || field === 'all') {
352
+ this.isTownOrCityEmpty = val[7];
353
+ this.townOrCityHasError = val[8];
354
+ }
355
+ if (field === 'county' || field === 'all') {
356
+ this.isCountyEmpty = val[9];
357
+ this.countyHasError = val[10];
358
+ }
359
+ if (field === 'mpostcode' || field === 'all') {
360
+ this.isMPostcodeEmpty = val[11];
361
+ this.mpostcodeHasError = val[12];
362
+ }
363
+ if (field === 'country' || field === 'all') {
364
+ this.isCountryEmpty = val[13];
365
+ }
366
+ };
367
+ ContactDetailsComponent.decorators = [
368
+ { type: Component, args: [{
369
+ selector: 'ccpay-contact-details',
370
+ template: "<fieldset class=\"govuk-fieldset contact-details--size\">\n <hr class=\"govuk-section-break govuk-section-break--m govuk-section-break--visible\">\n <div class=\"govuk-form-group\">\n <legend class=\"govuk-fieldset__legend govuk-fieldset__legend--s govuk-font19px\">\n {{ isEditOperation ? 'Edit contact information' : 'Contact information' }}\n </legend>\n <div id=\"contact-hint\" class=\"govuk-hint govuk-font19px\">\n Notifications will be sent via email or post when this refund is issued or rejected. You can only choose one option.\n </div>\n <div class=\"govuk-form-group\">\n <fieldset class=\"govuk-fieldset\">\n <div class=\"govuk-radios govuk-radios--conditional\" data-module=\"govuk-radios\">\n <div class=\"govuk-radios__item\">\n <input class=\"govuk-radios__input\" id=\"contact\" name=\"contact\" (click)=\"selectContactOption('Email', 'false')\" type=\"radio\" value=\"email\" [checked]=\"isEmailSAddressClicked\" aria-controls=\"conditional-contact\" aria-expanded=\"true\">\n <label class=\"govuk-label govuk-radios__label govuk-font19px\" for=\"contact\">\n Email\n </label>\n </div>\n <div class=\"govuk-radios__conditional\" id=\"conditional-contact-email\" *ngIf=\"isEmailSAddressClicked\">\n <form [formGroup]=\"emailAddressForm\" novalidate>\n <div class=\"govuk-form-group\">\n <label class=\"govuk-label \" for=\"email\">\n <span class=\"govuk-hint govuk-font19px\">Information about this refund will be sent to this email address.</span>\n </label>\n\n <div id=\"email-hint\" class=\"govuk-hint\">\n </div>\n <input class=\"govuk-input govuk-font19px\" id=\"email\" name=\"\" type=\"email\" [ngClass]=\"{ 'inline-error-class': isEmailEmpty || emailHasError }\" value=\"{{addressObj?.contact_details?.email}}\" formControlName=\"email\" aria-describedby=\"email-hint\">\n <p class=\"inline-error-message\" *ngIf=\"isEmailEmpty || emailHasError\">\n <span *ngIf=\"isEmailEmpty\">Enter a email address.</span>\n <span *ngIf=\"emailHasError\">Enter a valid email address.</span>\n </p>\n </div>\n </form>\n </div>\n <div class=\"govuk-radios__item\">\n <input class=\"govuk-radios__input\" id=\"contact-2\" name=\"contact\" (click)=\"selectContactOption('Postcode', 'false')\" type=\"radio\" [checked]=\"isPostcodeClicked\" value=\"post\" aria-controls=\"conditional-contact-2\" aria-expanded=\"false\">\n <label class=\"govuk-label govuk-radios__label govuk-font19px\" for=\"contact-2\">\n Post\n </label>\n </div>\n <div class=\"govuk-radios__conditional govuk-radios__conditional--hidden\" id=\"conditional-contact-postcode\" *ngIf=\"isPostcodeClicked && !isManualAddressClicked\">\n <form [formGroup]=\"postCodeForm\" novalidate>\n <label class=\"govuk-label govuk-font19px\" for=\"address-postcode\">\n <span class=\"govuk-hint govuk-font19px\">Information about this refund will be sent to this address.</span>Postcode\n </label>\n <div class=\"postcode-align-css\">\n <div class=\"govuk-form-group govuk-margin-right-10px\">\n <input class=\"govuk-input govuk-input--width-10\" id=\"address-postcode\" name=\"address-postcode\" [ngClass]=\"{ 'inline-error-class': isPostcodeEmpty || postcodeHasError }\" formControlName=\"postcode\" type=\"text\" autocomplete=\"postal-code\">\n <p class=\"inline-error-message\" *ngIf=\"isPostcodeEmpty || postcodeHasError\">\n <span *ngIf=\"isPostcodeEmpty\">Enter a postcode.</span>\n <span *ngIf=\"postcodeHasError\">Enter a valid postcode.</span>\n </p>\n </div>\n <div class=\"govuk-button-group\">\n <button class=\"govuk-button govuk-button--secondary govuk-font19px\" (click)=\"postcodeValidation('FA')\" data-module=\"govuk-button\">\n Find address\n </button>\n </div>\n </div>\n </form>\n <div class=\"govuk-form-group govuk-margin-btm-20px\" *ngIf=\"isShowPickAddress\">\n <label class=\"govuk-label govuk-font19px\" for=\"country\">\n Pick an address\n </label>\n <select class=\"govuk-select govuk-font19px\" [(ngModel)]=\"postcodeAddress\" id=\"postcodeAddress\" [ngClass]=\"{ 'inline-error-class': isAddressBoxEmpty }\" name=\"postcodeAddress\">\n <option *ngFor=\"let address of addressPostcodeList;\" [ngValue]=\"address.DPA\" > {{address.DPA.ADDRESS}}</option>\n </select> \n <p class=\"inline-error-message\" *ngIf=\"isAddressBoxEmpty\">\n <span *ngIf=\"isAddressBoxEmpty\">Please select an address.</span>\n </p>\n </div>\n <details class=\"govuk-details\" data-module=\"govuk-details\">\n <summary class=\"govuk-details__summary\">\n <span class=\"govuk-details__summary-text govuk-font19px\">\n <a href=\"Javascript:void(0);\" (click)=\"selectContactOption('Postcode', 'true')\"> Enter address manually</a>\n </span>\n </summary>\n </details>\n </div>\n <div class=\"govuk-radios__conditional\" id=\"conditional-contact-manual\" *ngIf=\"isPostcodeClicked && isManualAddressClicked\">\n <form [formGroup]=\"manualAddressForm\" novalidate>\n\n <div class=\"govuk-form-group\">\n <label class=\"govuk-label govuk-font19px\" for=\"address-line-1\">\n <span class=\"govuk-hint govuk-font19px\">Information about this refund will be sent to this address.</span>Building and street <span class=\"govuk-visually-hidden\">line 1 of 2</span>\n </label>\n <input class=\"govuk-input govuk-font19px\" id=\"address-line-1\" name=\"address-line-1\" [ngClass]=\"{ 'inline-error-class': isaddressLine1Empty || addressLine1HasError }\" value=\"{{addressObj?.contact_details?.address_line}}\" formControlName=\"addressl1\" type=\"text\" autocomplete=\"address-line1\">\n <p class=\"inline-error-message\" *ngIf=\"isaddressLine1Empty || addressLine1HasError\">\n <span *ngIf=\"isaddressLine1Empty\">Enter a Building and street.</span>\n <span *ngIf=\"addressLine1HasError\">Enter a valid Building and street.</span>\n </p> \n </div>\n <div class=\"govuk-form-group\">\n <label class=\"govuk-label\" for=\"address-line-2\">\n <span class=\"govuk-visually-hidden govuk-font19px\">Building and street line 2 of 2</span>\n </label>\n <input class=\"govuk-input govuk-font19px\" id=\"address-line-2\" name=\"address-line-2\" [ngClass]=\"{ 'inline-error-class': addressLine2HasError}\" formControlName=\"addressl2\" type=\"text\" autocomplete=\"address-line2\">\n <p class=\"inline-error-message\" *ngIf=\"addressLine2HasError\">\n <span *ngIf=\"addressLine2HasError\">Enter a valid Building and street line 2 of 2.</span>\n </p> \n </div>\n <div class=\"govuk-form-group\">\n <label class=\"govuk-label govuk-font19px\" for=\"address-town\">\n Town or city\n </label>\n <input class=\"govuk-input govuk-!-width-two-thirds govuk-font19px\" id=\"address-town\" name=\"address-town\" [ngClass]=\"{ 'inline-error-class': isTownOrCityEmpty || townOrCityHasError}\" value=\"{{addressObj?.contact_details?.city}}\" formControlName=\"townorcity\" type=\"text\" autocomplete=\"address-level2\">\n <p class=\"inline-error-message\" *ngIf=\"isTownOrCityEmpty || townOrCityHasError\">\n <span *ngIf=\"isTownOrCityEmpty\">Enter a town or city.</span>\n <span *ngIf=\"townOrCityHasError\">Enter a town or city.</span>\n </p> \n </div>\n <div class=\"govuk-form-group\">\n <label class=\"govuk-label govuk-font19px\" for=\"address-county\">\n County\n </label>\n <input class=\"govuk-input govuk-!-width-two-thirds govuk-font19px\" id=\"address-county\" [ngClass]=\"{ 'inline-error-class': isCountyEmpty || countyHasError}\" value=\"{{addressObj?.contact_details?.county}}\" formControlName=\"county\" name=\"address-county\" type=\"text\">\n <p class=\"inline-error-message\" *ngIf=\"isCountyEmpty || countyHasError\">\n <span *ngIf=\"isCountyEmpty\">Enter a County.</span>\n <span *ngIf=\"countyHasError\">Enter a valid County.</span>\n </p> \n </div>\n <div class=\"govuk-form-group\">\n <label class=\"govuk-label govuk-font19px\" for=\"address-postcode\">\n Postcode\n </label>\n <input class=\"govuk-input govuk-input--width-10 govuk-font19px\" id=\"address-postcode\" formControlName=\"mpostcode\" name=\"address-postcode\" [ngClass]=\"{ 'inline-error-class': isMPostcodeEmpty || mpostcodeHasError}\" value=\"{{addressObj?.contact_details?.postal_code}}\" type=\"text\" autocomplete=\"postal-code\">\n <p class=\"inline-error-message\" *ngIf=\"isMPostcodeEmpty || mpostcodeHasError\">\n <span *ngIf=\"isMPostcodeEmpty\">Enter a postcode.</span>\n <span *ngIf=\"mpostcodeHasError\">Enter a valid postcode.</span>\n </p> \n </div>\n <div class=\"govuk-form-group\">\n <label class=\"govuk-label govuk-font19px\" for=\"country\">\n Country\n </label>\n <select class=\"govuk-select govuk-font19px\" id=\"country\" name=\"country\" [ngClass]=\"{'inline-error-class': isCountryEmpty}\" formControlName=\"country\">\n <option value=\"\" selected=\"selected\">Please select</option>\n <option value=\"United Kingdom\" selected=\"{{ addressObj?.contact_details?.country ? 'selected' : '' }}\">United Kingdom</option>\n </select>\n <p class=\"inline-error-message\" *ngIf=\"isCountryEmpty\">\n <span *ngIf=\"isCountryEmpty\">Select a Country.</span>\n </p> \n </div>\n </form>\n </div>\n </div>\n </fieldset>\n </div>\n <!---FORM--->\n </div>\n\n<hr class=\"govuk-section-break govuk-section-break--m govuk-section-break--visible\">\n</fieldset>\n<div class=\"govuk-button-group\">\n<button type=\"submit\" class=\"button govuk-button--secondary govuk-font19px\" (click)=\"redirection($event)\"> Previous </button>\n&nbsp;\n<button type=\"submit\" class=\"button govuk-button govuk-font19px\" (click)=\"finalFormSubmit()\">\n Continue\n</button>\n</div>",
371
+ styles: [".govuk-font19px{font-size:19px}.inline-error-class{outline:#a71414 solid 3px;outline-offset:0}.inline-error-message{color:#a71414;font-weight:700;margin-top:10px}.contact-details--size{width:50%}.postcode-align-css{display:flex;flex-direction:row}.govuk-margin-right-10px{margin-right:10px}.govuk-margin-btm-20px{margin-bottom:20px!important}"]
372
+ }] }
373
+ ];
374
+ /** @nocollapse */
375
+ ContactDetailsComponent.ctorParameters = function () { return [
376
+ { type: FormBuilder },
377
+ { type: NotificationService },
378
+ { type: PaymentLibComponent }
379
+ ]; };
380
+ ContactDetailsComponent.propDecorators = {
381
+ isEditOperation: [{ type: Input, args: ['isEditOperation',] }],
382
+ isEditOperationInRefundList: [{ type: Input, args: ['isEditOperationInRefundList',] }],
383
+ addressObj: [{ type: Input, args: ['addressObj',] }],
384
+ assignContactDetails: [{ type: Output }],
385
+ assignContactDetailsInFefundsList: [{ type: Output }],
386
+ redirectToIssueRefund: [{ type: Output }]
387
+ };
388
+ return ContactDetailsComponent;
389
+ }());
390
+ export { ContactDetailsComponent };
391
+ if (false) {
392
+ /** @type {?} */
393
+ ContactDetailsComponent.prototype.isEditOperation;
394
+ /** @type {?} */
395
+ ContactDetailsComponent.prototype.isEditOperationInRefundList;
396
+ /** @type {?} */
397
+ ContactDetailsComponent.prototype.addressObj;
398
+ /** @type {?} */
399
+ ContactDetailsComponent.prototype.assignContactDetails;
400
+ /** @type {?} */
401
+ ContactDetailsComponent.prototype.assignContactDetailsInFefundsList;
402
+ /** @type {?} */
403
+ ContactDetailsComponent.prototype.redirectToIssueRefund;
404
+ /** @type {?} */
405
+ ContactDetailsComponent.prototype.pageTitle;
406
+ /** @type {?} */
407
+ ContactDetailsComponent.prototype.errorMessage;
408
+ /** @type {?} */
409
+ ContactDetailsComponent.prototype.isEmailSAddressClicked;
410
+ /** @type {?} */
411
+ ContactDetailsComponent.prototype.isShowPickAddress;
412
+ /** @type {?} */
413
+ ContactDetailsComponent.prototype.isPostcodeClicked;
414
+ /** @type {?} */
415
+ ContactDetailsComponent.prototype.isManualAddressClicked;
416
+ /** @type {?} */
417
+ ContactDetailsComponent.prototype.emailAddressForm;
418
+ /** @type {?} */
419
+ ContactDetailsComponent.prototype.postCodeForm;
420
+ /** @type {?} */
421
+ ContactDetailsComponent.prototype.manualAddressForm;
422
+ /** @type {?} */
423
+ ContactDetailsComponent.prototype.addressPostcodeList;
424
+ /** @type {?} */
425
+ ContactDetailsComponent.prototype.postcodeAddress;
426
+ /** @type {?} */
427
+ ContactDetailsComponent.prototype.isAddressBoxEmpty;
428
+ /** @type {?} */
429
+ ContactDetailsComponent.prototype.isEmailEmpty;
430
+ /** @type {?} */
431
+ ContactDetailsComponent.prototype.emailHasError;
432
+ /** @type {?} */
433
+ ContactDetailsComponent.prototype.isPostcodeEmpty;
434
+ /** @type {?} */
435
+ ContactDetailsComponent.prototype.postcodeHasError;
436
+ /** @type {?} */
437
+ ContactDetailsComponent.prototype.isaddressLine1Empty;
438
+ /** @type {?} */
439
+ ContactDetailsComponent.prototype.addressLine1HasError;
440
+ /** @type {?} */
441
+ ContactDetailsComponent.prototype.addressLine2HasError;
442
+ /** @type {?} */
443
+ ContactDetailsComponent.prototype.isTownOrCityEmpty;
444
+ /** @type {?} */
445
+ ContactDetailsComponent.prototype.townOrCityHasError;
446
+ /** @type {?} */
447
+ ContactDetailsComponent.prototype.isCountyEmpty;
448
+ /** @type {?} */
449
+ ContactDetailsComponent.prototype.countyHasError;
450
+ /** @type {?} */
451
+ ContactDetailsComponent.prototype.isMPostcodeEmpty;
452
+ /** @type {?} */
453
+ ContactDetailsComponent.prototype.mpostcodeHasError;
454
+ /** @type {?} */
455
+ ContactDetailsComponent.prototype.isCountryEmpty;
456
+ /**
457
+ * @type {?}
458
+ * @private
459
+ */
460
+ ContactDetailsComponent.prototype.formBuilder;
461
+ /**
462
+ * @type {?}
463
+ * @private
464
+ */
465
+ ContactDetailsComponent.prototype.notificationService;
466
+ /**
467
+ * @type {?}
468
+ * @private
469
+ */
470
+ ContactDetailsComponent.prototype.paymentLibComponent;
471
+ }
472
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"contact-details.component.js","sourceRoot":"ng://@hmcts/ccpay-web-component/","sources":["lib/components/contact-details/contact-details.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Output, EventEmitter, Input } from '@angular/core';\nimport { FormBuilder, FormGroup, Validators, FormControl } from '@angular/forms';\nimport { PaymentLibComponent } from '../../payment-lib.component';\nimport { NotificationService } from '../../services/notification/notification.service';\n\n@Component({\n  selector: 'ccpay-contact-details',\n  templateUrl: './contact-details.component.html',\n  styleUrls: ['./contact-details.component.css']\n})\nexport class ContactDetailsComponent implements OnInit {\n  @Input('isEditOperation') isEditOperation: boolean;\n  @Input('isEditOperationInRefundList') isEditOperationInRefundList: boolean;\n  @Input('addressObj') addressObj: any;\n  @Output() assignContactDetails: EventEmitter<any> = new EventEmitter();\n  @Output() assignContactDetailsInFefundsList: EventEmitter<any> = new EventEmitter();\n  @Output() redirectToIssueRefund: EventEmitter<any> = new EventEmitter();\n  pageTitle: string = 'Payment status history';\n  errorMessage: string;\n  isEmailSAddressClicked: boolean = true;\n  isShowPickAddress:  boolean = false;\n  isPostcodeClicked: boolean = false;\n  isManualAddressClicked: boolean = false;\n  emailAddressForm: FormGroup;\n  postCodeForm: FormGroup;\n  manualAddressForm: FormGroup;\n  addressPostcodeList:any[] = [];\n  postcodeAddress:any;\n  isAddressBoxEmpty: boolean = false;\n\n  isEmailEmpty: boolean = false;\n  emailHasError: boolean = false;\n  isPostcodeEmpty: boolean = false;\n  postcodeHasError: boolean = false;\n  isaddressLine1Empty: boolean = false;\n  addressLine1HasError: boolean = false;\n  addressLine2HasError: boolean = false;\n  isTownOrCityEmpty: boolean = false;\n  townOrCityHasError: boolean = false;\n  isCountyEmpty: boolean = false;\n  countyHasError: boolean = false;\n  isMPostcodeEmpty: boolean = false;\n  mpostcodeHasError: boolean = false;\n  isCountryEmpty: boolean = false;\n\n  constructor(private formBuilder: FormBuilder,\n              private notificationService: NotificationService,\n              private paymentLibComponent: PaymentLibComponent) { }\n\n  ngOnInit() {\n    this.resetForm([false,false,false,false,false,false,false,false,false,false,false,false,false,false], 'all');\n\n    this.emailAddressForm = this.formBuilder.group({\n      email: new FormControl('', Validators.compose([\n        Validators.required,\n        Validators.pattern('^[a-z0-9._%+-]+@[a-z0-9-]+\\\\.[a-z]{2,4}$')\n      ]))\n    });\n    this.postCodeForm = this.formBuilder.group({\n      postcode: new FormControl('', Validators.compose([\n        Validators.required,\n        Validators.pattern('^([A-Za-z]{1,2}[0-9]{1,2}[A-Za-z]{0,1} ?[0-9][A-Za-z]{2})')\n      ]))\n    });\n    this.manualAddressForm = this.formBuilder.group({\n      addressl1: new FormControl('', Validators.compose([\n        Validators.required,\n        Validators.pattern('^[a-zA-Z0-9\\\\s,\\'-]*$')\n      ])),\n      addressl2: new FormControl('', Validators.compose([\n        Validators.pattern('^[a-zA-Z0-9\\\\s,\\'-]*$')\n      ])),\n      townorcity: new FormControl('', Validators.compose([\n        Validators.required,\n        Validators.pattern('^[a-zA-Z0-9\\\\s,\\'-]*$')\n      ])),\n      county: new FormControl('', Validators.compose([\n        Validators.pattern('^[a-zA-Z0-9\\\\s,\\'-]*$')\n      ])),\n      mpostcode: new FormControl('', Validators.compose([\n        Validators.required,\n        Validators.pattern('^([A-Za-z]{1,2}[0-9]{1,2}[A-Za-z]{0,1} ?[0-9][A-Za-z]{2})')\n      ])),\n      country: new FormControl('', Validators.compose([\n        Validators.required\n      ]))\n    });\n    if(this.addressObj !== undefined && this.addressObj !== '') {\n      this.setEditDetails();\n    }\n    if(this.isEditOperationInRefundList === undefined) {\n      this.isEditOperationInRefundList = false;\n    }\n  }\n  setEditDetails() {\n    if(this.addressObj.notification_type === 'EMAIL') {\n      this.isEmailSAddressClicked = true;\n      this.isPostcodeClicked = false;\n      this.isManualAddressClicked = false;\n      this.emailAddressForm.setValue({ email: this.addressObj.contact_details.email });\n    } else if(this.addressObj.notification_type === 'LETTER') {\n      this.isEmailSAddressClicked = false;\n      this.isPostcodeClicked = true;\n      this.isManualAddressClicked = true;\n      this.manualAddressForm.patchValue({ \n        addressl1: this.addressObj.contact_details.address_line,\n        townorcity: this.addressObj.contact_details.city,\n        county: this.addressObj.contact_details.county,\n        country: this.addressObj.contact_details.country,\n        mpostcode: this.addressObj.contact_details.postal_code\n      });\n    }\n  }\n\n  selectContactOption(type, isLinkedClied) {\n    this.resetForm([false,false,false,false,false,false,false,false,false,false,false,false,false,false,false], 'all');\n    if( type === 'Email' && isLinkedClied === 'false'){\n      this.isEmailSAddressClicked = true;\n      this.isPostcodeClicked = false;\n      this.isManualAddressClicked = false;\n    } else if(type === 'Postcode' && isLinkedClied === 'false') {\n      this.isEmailSAddressClicked = false;\n      this.isPostcodeClicked = true;\n      this.isManualAddressClicked = false;\n    } else if(type === 'Postcode' && isLinkedClied === 'true') {\n      this.isEmailSAddressClicked = false;\n      this.isPostcodeClicked = true;\n      this.isManualAddressClicked = true;\n\n    }\n  }\n\n  finalFormSubmit() {\n    this.resetForm([false,false,false,false,false,false,false,false,false,false,false,false,false,false,false], 'all');\n    if( this.isEmailSAddressClicked ){\n      const emailField = this.emailAddressForm.controls.email;\n      if (this.emailAddressForm.valid) {\n        if(!this.isEditOperationInRefundList) {\n        this.assignContactDetails.emit( {\n          email: emailField.value,\n          notification_type: 'EMAIL'\n        } );\n      } else {\n        this.assignContactDetailsInFefundsList.emit({\n          email: emailField.value,\n          notification_type: 'EMAIL'\n        } );\n      }\n      } else {\n        if( emailField.value == '' ) {\n          this.resetForm([true,false,false,false,false,false,false,false,false,false,false,false,false,false], 'email');\n        }\n        if(emailField.value != '' && emailField.invalid ) {\n          this.resetForm([false,true,false,false,false,false,false,false,false,false,false,false,false,false], 'email');\n        }\n      }\n    } else if( this.isPostcodeClicked && !this.isManualAddressClicked ) {\n      this.postcodeValidation('FS');\n    } else if(this.isPostcodeClicked && this.isManualAddressClicked) {\n      const fieldCtrls = this.manualAddressForm.controls;\n      if (this.manualAddressForm.valid) {\n        if(!this.isEditOperationInRefundList) {\n        this.assignContactDetails.emit({\n          address_line: fieldCtrls.addressl1.value+' '+fieldCtrls.addressl2.value,\n          city: fieldCtrls.townorcity.value,\n          county: fieldCtrls.county.value,\n          postal_code: fieldCtrls.mpostcode.value,\n          country: fieldCtrls.country.value,\n          notification_type: 'LETTER'\n        });\n      } else {\n        this.assignContactDetailsInFefundsList.emit({\n          address_line: fieldCtrls.addressl1.value+' '+fieldCtrls.addressl2.value,\n          city: fieldCtrls.townorcity.value,\n          county: fieldCtrls.county.value,\n          postal_code: fieldCtrls.mpostcode.value,\n          country: fieldCtrls.country.value,\n          notification_type: 'LETTER'\n        });\n      }\n      } else {\n        if( fieldCtrls.addressl1.value == '' ) {\n          this.resetForm([false,false,false,false,true,false,false,false,false,false,false,false,false,false], 'address1');\n        }\n        if(fieldCtrls.addressl1.value != '' && fieldCtrls.addressl1.invalid ) {\n          this.resetForm([false,false,false,false,false,true,false,false,false,false,false,false,false,false], 'address1');\n        }\n        if(fieldCtrls.addressl2.value != '' && fieldCtrls.addressl2.invalid ) {\n          this.resetForm([false,false,false,false,false,false,true,false,false,false,false,false,false,false], 'address2');\n        }\n        if( fieldCtrls.townorcity.value == '' ) {\n          this.resetForm([false,false,false,false,false,false,false,true,false,false,false,false,false,false], 'town');\n        }\n        if(fieldCtrls.townorcity.value != '' && fieldCtrls.townorcity.invalid ) {\n          this.resetForm([false,false,false,false,false,false,false,false,true,false,false,false,false,false], 'town');\n        }\n        if( fieldCtrls.county.value == '' ) {\n          this.resetForm([false,false,false,false,false,false,false,false,false,true,false,false,false,false], 'county');\n        }\n        if(fieldCtrls.county.value != '' && fieldCtrls.county.invalid ) {\n          this.resetForm([false,false,false,false,false,false,false,false,false,false,true,false,false,false], 'county');\n        }\n        if( fieldCtrls.mpostcode.value == '' ) {\n          this.resetForm([false,false,false,false,false,false,false,false,false,false,false,true,false,false], 'mpostcode');\n        }\n        if(fieldCtrls.mpostcode.value != '' && fieldCtrls.mpostcode.invalid ) {\n          this.resetForm([false,false,false,false,false,false,false,false,false,false,false,false,true,false], 'mpostcode');\n        }\n        if( fieldCtrls.country.value == '' ) {\n          this.resetForm([false,false,false,false,false,false,false,false,false,false,false,false,false,true], 'country');\n        }\n      }\n\n    }\n\n  }\n\n  postcodeValidation(str) {\n    this.resetForm([false,false,false,false,false,false,false,false,false,false,false,false,false,false,false], 'all');\n    const postcodeField = this.postCodeForm.controls.postcode;\n    if (this.postCodeForm.valid) {\n      if(str === 'FA') {\n        this.notificationService.getAddressByPostcode(postcodeField.value).subscribe(\n          refundsNotification => {\n            this.addressPostcodeList = refundsNotification['data']['results'];\n            this.isShowPickAddress = refundsNotification['data']['header'].totalresults > 0;\n            if(!this.isShowPickAddress) {\n              this.resetForm([false,false,false,true,false,false,false,false,false,false,false,false,false], 'postcode');\n            }\n          }\n        ),\n        (error: any) => {\n          this.isShowPickAddress = false;\n          this.errorMessage = error.replace(/\"/g,\"\");\n        }; \n      } else if (str === 'FS') {\n        if(this.postcodeAddress !== undefined && this.postcodeAddress) {\n          this.isAddressBoxEmpty = false;\n          let addressLine=\"\";\n          let addressArray = this.postcodeAddress.ADDRESS.split(\",\");\n          for( let i=0; i<addressArray.length-2; i++ ) {\n            addressLine +=addressArray[i]; \n          }\n          const addressObject = {\n            address_line: addressLine,\n            city: this.postcodeAddress.POST_TOWN,\n            county: this.postcodeAddress.LOCAL_CUSTODIAN_CODE_DESCRIPTION,\n            postal_code: this.postcodeAddress.POSTCODE,\n            country: 'United Kingdom',\n            notification_type: 'LETTER'\n          };\n          if(!this.isEditOperationInRefundList) {\n          this.assignContactDetails.emit(addressObject);\n        } else  {\n          this.assignContactDetailsInFefundsList.emit(addressObject);\n        }\n        } else {\n          this.isAddressBoxEmpty = true;\n        }\n      }\n    } else {\n      if( postcodeField.value == '' ) {\n        this.resetForm([false,false,true,false,false,false,false,false,false,false,false,false,false], 'postcode');\n      }\n      if(postcodeField.value != '' && postcodeField.invalid ) {\n        this.resetForm([false,false,false,true,false,false,false,false,false,false,false,false,false], 'postcode');\n      }\n    }\n  }\n  redirection(event:any) {\n    this.redirectToIssueRefund.emit(event);\n  }\n  resetForm(val, field) {\n    if(field==='email' || field==='all') {\n      this.isEmailEmpty = val[0];\n      this.emailHasError = val[1];\n    }\n    if(field==='postcode' || field==='all') {\n      this.isPostcodeEmpty = val[2];\n      this.postcodeHasError = val[3];\n    }\n    if(field==='address1' || field==='all') {\n      this.isaddressLine1Empty = val[4];\n      this.addressLine1HasError = val[5];\n    }\n    if(field==='address2' || field==='all') {\n      this.addressLine2HasError = val[6];\n    }\n    if(field==='town' || field==='all') {\n      this.isTownOrCityEmpty = val[7];\n      this.townOrCityHasError = val[8];\n    }\n    if(field==='county' || field==='all') {\n      this.isCountyEmpty = val[9];\n      this.countyHasError = val[10];\n    }\n    if(field==='mpostcode' || field==='all') {\n      this.isMPostcodeEmpty = val[11];\n      this.mpostcodeHasError = val[12];\n    }\n    if(field==='country' || field==='all') {\n      this.isCountryEmpty = val[13];\n    }\n  \n  }\n}\n"]}