|
287 | 287 | for (const card of enabledCardTypes) {
|
288 | 288 | if (cardTypes[card].code === cardData?.cybsCardType) {
|
289 | 289 | setCardTypeNotEnabled(false);
|
290 |
| - updateState('creditCardNumberData', data); |
291 |
| - setSelectedCardType(cardTypes[card].value); |
| 290 | + setCardData(data,cardTypes[card].value) |
292 | 291 | break;
|
293 | 292 | }
|
294 | 293 | else {
|
295 |
| - setSelectedCardType(''); |
296 |
| - updateState('creditCardNumberData', null); |
| 294 | + setDefaultCardType(data,cardData) |
297 | 295 | }
|
298 | 296 | }
|
299 | 297 | }
|
| 298 | + else{ |
| 299 | + setDefaultCardType(data,cardData) |
| 300 | + } |
300 | 301 | }
|
| 302 | + |
| 303 | + const setDefaultCardType = (data,cardData) => { |
| 304 | + if (cardData && cardData.couldBeValid) { |
| 305 | + setCardTypeNotEnabled(false); |
| 306 | + if (cardData.valid) { |
| 307 | + setCardData(data,cardData?.cybsCardType,) |
| 308 | + } |
| 309 | + else{ |
| 310 | + resetCardData(); |
| 311 | + } |
| 312 | + } |
| 313 | + else{ |
| 314 | + resetCardData(); |
| 315 | + } |
| 316 | + }; |
| 317 | + |
| 318 | + const setCardData = (data,cardType) => { |
| 319 | + updateState('creditCardNumberData', data); |
| 320 | + setSelectedCardType(cardType); |
| 321 | + }; |
| 322 | + const resetCardData = () => { |
| 323 | + setSelectedCardType(''); |
| 324 | + updateState('creditCardNumberData', null); |
| 325 | + }; |
301 | 326 | const onSecurityCodeChange = data => {
|
302 | 327 | updateState('securityCodeData', data);
|
303 | 328 | };
|
|
0 commit comments