From 2afdcf736b45590a5ad36f6ccfe8cafc16449e2f Mon Sep 17 00:00:00 2001 From: Arush Date: Wed, 29 Nov 2023 03:35:20 +0530 Subject: [PATCH] feat: HS-132: Passing Card Holder Name in Saved Cards Flow --- src/Components/DynamicFields.res | 21 ++++++++++++++++++++- src/Components/SavedMethods.res | 2 +- src/Payments/CardPayment.res | 3 +-- src/Payments/PaymentMethodsRecord.res | 4 ++-- src/Types/PaymentType.res | 12 ++++++++++++ 5 files changed, 36 insertions(+), 6 deletions(-) diff --git a/src/Components/DynamicFields.res b/src/Components/DynamicFields.res index e730a46f9..637d3157c 100644 --- a/src/Components/DynamicFields.res +++ b/src/Components/DynamicFields.res @@ -7,6 +7,7 @@ let make = ( ~paymentMethodType, ~setRequiredFieldsBody, ~isSavedCardFlow=false, + ~savedCards=[]: array, ) => { React.useEffect1(() => { setRequiredFieldsBody(_ => Js.Dict.empty()) @@ -44,12 +45,17 @@ let make = ( Js.Json.null } + let isAllStoredCardsHaveName = React.useMemo1(() => { + PaymentType.getIsAllStoredCardsHaveName(savedCards) + }, [savedCards]) + //<...>// let fieldsArr = PaymentMethodsRecord.getPaymentMethodFields( paymentMethodType, requiredFields, ~isSavedCardFlow, + ~isAllStoredCardsHaveName, (), ) ->Utils.removeDuplicate @@ -388,7 +394,20 @@ let make = ( | InfoElement | None => "" } - acc->Js.Dict.set(item.required_field, value->Js.Json.string) + if ( + isSavedCardFlow && + item.display_name === "card_holder_name" && + (item.field_type === BillingName || item.field_type === FullName) + ) { + if !isAllStoredCardsHaveName { + acc->Js.Dict.set( + "payment_method_data.card_token.card_holder_name", + value->Js.Json.string, + ) + } + } else { + acc->Js.Dict.set(item.required_field, value->Js.Json.string) + } acc }, Js.Dict.empty()) diff --git a/src/Components/SavedMethods.res b/src/Components/SavedMethods.res index ff0ad9c7e..f92f84c22 100644 --- a/src/Components/SavedMethods.res +++ b/src/Components/SavedMethods.res @@ -73,7 +73,7 @@ let make = ( }} Js.Array.length !== 0}> diff --git a/src/Payments/CardPayment.res b/src/Payments/CardPayment.res index b9d072b38..2ea6304a0 100644 --- a/src/Payments/CardPayment.res +++ b/src/Payments/CardPayment.res @@ -222,8 +222,7 @@ let make = ( ->Js.Json.object_ ->OrcaUtils.flattenObject(true) ->OrcaUtils.mergeTwoFlattenedJsonDicts(requiredFieldsBody) - ->OrcaUtils.getArrayOfTupleFromDict - ->Js.Array2.filter(((key, _)) => key !== "payment_method_data"), + ->OrcaUtils.getArrayOfTupleFromDict, ~confirmParam=confirm.confirmParams, ~handleUserError=false, (), diff --git a/src/Payments/PaymentMethodsRecord.res b/src/Payments/PaymentMethodsRecord.res index 276276179..e0da60f2b 100644 --- a/src/Payments/PaymentMethodsRecord.res +++ b/src/Payments/PaymentMethodsRecord.res @@ -528,14 +528,14 @@ let getRequiredFieldsFromJson = dict => { let dynamicFieldsEnabledPaymentMethods = ["crypto_currency", "debit", "credit", "blik"] -let getPaymentMethodFields = (paymentMethod, requiredFields, ~isSavedCardFlow=false, ()) => { +let getPaymentMethodFields = (paymentMethod, requiredFields, ~isSavedCardFlow=false, ~isAllStoredCardsHaveName=false, ()) => { let requiredFieldsArr = requiredFields ->Utils.getDictFromJson ->Js.Dict.values ->Js.Array2.map(item => { let val = item->Utils.getDictFromJson->getRequiredFieldsFromJson - if isSavedCardFlow && val.display_name === "card_holder_name" { + if isSavedCardFlow && val.display_name === "card_holder_name" && isAllStoredCardsHaveName { None } else { val.field_type diff --git a/src/Types/PaymentType.res b/src/Types/PaymentType.res index 791351ce5..804f50a80 100644 --- a/src/Types/PaymentType.res +++ b/src/Types/PaymentType.res @@ -856,3 +856,15 @@ let itemToObjMapper = (dict, logger) => { } type loadType = Loading | Loaded(Js.Json.t) | SemiLoaded | LoadError(Js.Json.t) + +let getIsAllStoredCardsHaveName = (savedCards: array) => { + savedCards + ->Js.Array2.filter(savedCard => { + switch savedCard.card.cardHolderName { + | None + | Some("") => false + | _ => true + } + }) + ->Belt.Array.length > 0 +}