@bigbinary/neeto-payments-frontend 6.1.26 → 6.1.28

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 (170) hide show
  1. package/app/javascript/src/translations/en.json +15 -4
  2. package/dist/AccountsDashboard.js +7 -7
  3. package/dist/AccountsDashboard.js.map +1 -1
  4. package/dist/AdminCancelRecurringPaymentButton.js +1 -1
  5. package/dist/AdminCancelRecurringPaymentButton.js.map +1 -1
  6. package/dist/CashPaymentButton.js +2 -2
  7. package/dist/CashPaymentButton.js.map +1 -1
  8. package/dist/ConfirmCashPaymentButton.js +2 -2
  9. package/dist/ConfirmCashPaymentButton.js.map +1 -1
  10. package/dist/{CopyButtonWrapper-Bp5IVO76.js → CopyButtonWrapper-DkI2F6Ty.js} +2 -2
  11. package/dist/CopyButtonWrapper-DkI2F6Ty.js.map +1 -0
  12. package/dist/CustomerCancelRecurringPaymentForm.js +2 -2
  13. package/dist/CustomerCancelRecurringPaymentForm.js.map +1 -1
  14. package/dist/{ExportModal-KInsxpSb.js → ExportModal-ubjATdMC.js} +2 -2
  15. package/dist/{ExportModal-KInsxpSb.js.map → ExportModal-ubjATdMC.js.map} +1 -1
  16. package/dist/ManualUpiConnect.js +3 -3
  17. package/dist/ManualUpiConnect.js.map +1 -1
  18. package/dist/ManualUpiPayment.js +128 -22
  19. package/dist/ManualUpiPayment.js.map +1 -1
  20. package/dist/ManualUpiPaymentConfirmButton.js +3 -3
  21. package/dist/ManualUpiPaymentConfirmButton.js.map +1 -1
  22. package/dist/ManualUpiPaymentRejectButton.js +3 -3
  23. package/dist/ManualUpiPaymentRejectButton.js.map +1 -1
  24. package/dist/PaymentKindRestrictionAlert.js.map +1 -1
  25. package/dist/PaymentsDashboard.js +24 -13
  26. package/dist/PaymentsDashboard.js.map +1 -1
  27. package/dist/PayoutsDashboard.js +7 -7
  28. package/dist/PayoutsDashboard.js.map +1 -1
  29. package/dist/PayoutsPage.js +5 -5
  30. package/dist/PayoutsPage.js.map +1 -1
  31. package/dist/RazorpayConnect.js +4 -4
  32. package/dist/RazorpayConnect.js.map +1 -1
  33. package/dist/RazorpayLinkedAccountForm.js +3 -3
  34. package/dist/RazorpayLinkedAccountForm.js.map +1 -1
  35. package/dist/RazorpayPaymentButton.js +2 -2
  36. package/dist/RazorpayPaymentButton.js.map +1 -1
  37. package/dist/RecurringPaymentSettings.js +3 -3
  38. package/dist/RecurringPaymentSettings.js.map +1 -1
  39. package/dist/RefundsDashboard.js +8 -10
  40. package/dist/RefundsDashboard.js.map +1 -1
  41. package/dist/SplitTransfersDashboard.js +11 -11
  42. package/dist/SplitTransfersDashboard.js.map +1 -1
  43. package/dist/StripeCheckoutSetting.js +2 -2
  44. package/dist/StripeCheckoutSetting.js.map +1 -1
  45. package/dist/StripeConnect.js +6 -6
  46. package/dist/StripeConnect.js.map +1 -1
  47. package/dist/StripeManage.js +3 -3
  48. package/dist/TaxesDashboard.js +2 -2
  49. package/dist/TaxesDashboard.js.map +1 -1
  50. package/dist/buildStripeTransactionLink.js +1 -1
  51. package/dist/cjs/AccountsDashboard.js +4 -4
  52. package/dist/cjs/AccountsDashboard.js.map +1 -1
  53. package/dist/cjs/AdminCancelRecurringPaymentButton.js.map +1 -1
  54. package/dist/cjs/CashPaymentButton.js.map +1 -1
  55. package/dist/cjs/ConfirmCashPaymentButton.js.map +1 -1
  56. package/dist/cjs/{CopyButtonWrapper-I-kdKiiB.js → CopyButtonWrapper-DZ9rE5UR.js} +2 -2
  57. package/dist/cjs/CopyButtonWrapper-DZ9rE5UR.js.map +1 -0
  58. package/dist/cjs/CustomerCancelRecurringPaymentForm.js +1 -1
  59. package/dist/cjs/CustomerCancelRecurringPaymentForm.js.map +1 -1
  60. package/dist/cjs/ExportModal-BFe0tF5L.js.map +1 -1
  61. package/dist/cjs/ManualUpiConnect.js +1 -1
  62. package/dist/cjs/ManualUpiConnect.js.map +1 -1
  63. package/dist/cjs/ManualUpiPayment.js +125 -19
  64. package/dist/cjs/ManualUpiPayment.js.map +1 -1
  65. package/dist/cjs/ManualUpiPaymentConfirmButton.js +2 -2
  66. package/dist/cjs/ManualUpiPaymentConfirmButton.js.map +1 -1
  67. package/dist/cjs/ManualUpiPaymentRejectButton.js +2 -2
  68. package/dist/cjs/ManualUpiPaymentRejectButton.js.map +1 -1
  69. package/dist/cjs/PaymentKindRestrictionAlert.js.map +1 -1
  70. package/dist/cjs/PaymentsDashboard.js +18 -7
  71. package/dist/cjs/PaymentsDashboard.js.map +1 -1
  72. package/dist/cjs/PayoutsDashboard.js +4 -4
  73. package/dist/cjs/PayoutsDashboard.js.map +1 -1
  74. package/dist/cjs/PayoutsPage.js +4 -4
  75. package/dist/cjs/PayoutsPage.js.map +1 -1
  76. package/dist/cjs/RazorpayConnect.js +2 -2
  77. package/dist/cjs/RazorpayConnect.js.map +1 -1
  78. package/dist/cjs/RazorpayLinkedAccountForm.js +1 -1
  79. package/dist/cjs/RazorpayLinkedAccountForm.js.map +1 -1
  80. package/dist/cjs/RazorpayPaymentButton.js +1 -1
  81. package/dist/cjs/RazorpayPaymentButton.js.map +1 -1
  82. package/dist/cjs/RecurringPaymentSettings.js +1 -1
  83. package/dist/cjs/RecurringPaymentSettings.js.map +1 -1
  84. package/dist/cjs/RefundsDashboard.js +3 -5
  85. package/dist/cjs/RefundsDashboard.js.map +1 -1
  86. package/dist/cjs/SplitTransfersDashboard.js +6 -6
  87. package/dist/cjs/SplitTransfersDashboard.js.map +1 -1
  88. package/dist/cjs/StripeCheckoutSetting.js +1 -1
  89. package/dist/cjs/StripeCheckoutSetting.js.map +1 -1
  90. package/dist/cjs/StripeConnect.js +3 -3
  91. package/dist/cjs/StripeConnect.js.map +1 -1
  92. package/dist/cjs/StripeManage.js +1 -1
  93. package/dist/cjs/TaxesDashboard.js +1 -1
  94. package/dist/cjs/TaxesDashboard.js.map +1 -1
  95. package/dist/cjs/dashboard-BWh6P9BB.js.map +1 -1
  96. package/dist/cjs/exportChannel-BL2RGGhP.js.map +1 -1
  97. package/dist/cjs/index-vUzevy4J.js.map +1 -1
  98. package/dist/cjs/index.js +9 -8
  99. package/dist/cjs/index.js.map +1 -1
  100. package/dist/cjs/{queryConstants-Dc6wh21D.js → queryConstants-CGUF7zol.js} +1 -12
  101. package/dist/cjs/{queryConstants-Dc6wh21D.js.map → queryConstants-CGUF7zol.js.map} +1 -1
  102. package/dist/cjs/{renderFunctions-9r2F0DaL.js → renderFunctions-B61EfbIp.js} +2 -2
  103. package/dist/cjs/{renderFunctions-9r2F0DaL.js.map → renderFunctions-B61EfbIp.js.map} +1 -1
  104. package/dist/cjs/{stripe.esm-CrNYjPcC.js → stripe.esm-DCCiiIbR.js} +2 -8
  105. package/dist/cjs/{stripe.esm-CrNYjPcC.js.map → stripe.esm-DCCiiIbR.js.map} +1 -1
  106. package/dist/cjs/{useAccountsApi-FFJUTaYQ.js → useAccountsApi-B1riDzpb.js} +2 -2
  107. package/dist/cjs/{useAccountsApi-FFJUTaYQ.js.map → useAccountsApi-B1riDzpb.js.map} +1 -1
  108. package/dist/cjs/useExportsApi-FDe0ucYU.js.map +1 -1
  109. package/dist/cjs/{useIntegrationsApi-D7HNuBW7.js → useIntegrationsApi-Cqu9MBJR.js} +2 -2
  110. package/dist/cjs/{useIntegrationsApi-D7HNuBW7.js.map → useIntegrationsApi-Cqu9MBJR.js.map} +1 -1
  111. package/dist/cjs/usePaymentApi-B-L0nxtr.js.map +1 -1
  112. package/dist/cjs/{usePaymentApi-fBUnau7x.js → usePaymentApi-BoLmrCje.js} +2 -2
  113. package/dist/cjs/{usePaymentApi-fBUnau7x.js.map → usePaymentApi-BoLmrCje.js.map} +1 -1
  114. package/dist/cjs/{usePaymentApi-Bbtzf9ST.js → usePaymentApi-CgsZjRBj.js} +1 -9
  115. package/dist/cjs/{usePaymentApi-Bbtzf9ST.js.map → usePaymentApi-CgsZjRBj.js.map} +1 -1
  116. package/dist/cjs/{usePlatformApi-BEa-Cs3V.js → usePlatformApi-D3yfxsMP.js} +2 -2
  117. package/dist/cjs/{usePlatformApi-BEa-Cs3V.js.map → usePlatformApi-D3yfxsMP.js.map} +1 -1
  118. package/dist/cjs/useRazorpayPayment.js +1 -1
  119. package/dist/cjs/useRazorpayPayment.js.map +1 -1
  120. package/dist/cjs/useStripePromise.js +1 -1
  121. package/dist/cjs/useStripePromise.js.map +1 -1
  122. package/dist/constants.js +1 -1
  123. package/dist/{dashboard-Cr6UEj9o.js → dashboard-CZOZ1Oxi.js} +3 -3
  124. package/dist/{dashboard-Cr6UEj9o.js.map → dashboard-CZOZ1Oxi.js.map} +1 -1
  125. package/dist/exportChannel-Db0U5gc1.js.map +1 -1
  126. package/dist/getAddressElementOptions.js +1 -1
  127. package/dist/getAmountInLargestCurrencyUnit.js +1 -1
  128. package/dist/getAmountInSmallestCurrencyUnit.js +1 -1
  129. package/dist/getAmountWithAppliedTax.js +1 -1
  130. package/dist/getFormattedAmount.js +1 -1
  131. package/dist/getFormattedDiscountedAmount.js +1 -1
  132. package/dist/getFormattedDiscountedPercentage.js +1 -1
  133. package/dist/getFormattedTaxAmount.js +1 -1
  134. package/dist/getFormattedTipAmount.js +1 -1
  135. package/dist/getQrCodeValue.js +1 -1
  136. package/dist/getTaxAmount.js +1 -1
  137. package/dist/getTipAmount.js +1 -1
  138. package/dist/hasAmountToPay.js +1 -1
  139. package/dist/{index-DqpYJN4W.js → index-15RrM-W8.js} +4 -4
  140. package/dist/{index-DqpYJN4W.js.map → index-15RrM-W8.js.map} +1 -1
  141. package/dist/index.js +14 -13
  142. package/dist/index.js.map +1 -1
  143. package/dist/{queryConstants-C7AqdemO.js → queryConstants-8c7Nd8ML.js} +1 -12
  144. package/dist/queryConstants-8c7Nd8ML.js.map +1 -0
  145. package/dist/{renderFunctions-CmT7DuRQ.js → renderFunctions-C5m30W0E.js} +4 -4
  146. package/dist/{renderFunctions-CmT7DuRQ.js.map → renderFunctions-C5m30W0E.js.map} +1 -1
  147. package/dist/{stripe.esm-DuZ_gsAa.js → stripe.esm-CFEGjV29.js} +2 -8
  148. package/dist/{stripe.esm-DuZ_gsAa.js.map → stripe.esm-CFEGjV29.js.map} +1 -1
  149. package/dist/{useAccountsApi-Cxvp_Jcf.js → useAccountsApi-Cbfz0yG4.js} +3 -3
  150. package/dist/{useAccountsApi-Cxvp_Jcf.js.map → useAccountsApi-Cbfz0yG4.js.map} +1 -1
  151. package/dist/{useExportsApi-C_UN1GVL.js → useExportsApi-DBBXhnqr.js} +3 -3
  152. package/dist/{useExportsApi-C_UN1GVL.js.map → useExportsApi-DBBXhnqr.js.map} +1 -1
  153. package/dist/{useIntegrationsApi-v_nhBcdZ.js → useIntegrationsApi-C3K1aAvJ.js} +3 -3
  154. package/dist/{useIntegrationsApi-v_nhBcdZ.js.map → useIntegrationsApi-C3K1aAvJ.js.map} +1 -1
  155. package/dist/{usePaymentApi-DrpxsySj.js → usePaymentApi-BqNzxqL8.js} +2 -10
  156. package/dist/{usePaymentApi-DrpxsySj.js.map → usePaymentApi-BqNzxqL8.js.map} +1 -1
  157. package/dist/{usePaymentApi-D1xXtOAq.js → usePaymentApi-Cf_jWBQK.js} +2 -2
  158. package/dist/{usePaymentApi-D1xXtOAq.js.map → usePaymentApi-Cf_jWBQK.js.map} +1 -1
  159. package/dist/{usePaymentApi-D-8CnzxZ.js → usePaymentApi-DHDDzZkq.js} +3 -3
  160. package/dist/{usePaymentApi-D-8CnzxZ.js.map → usePaymentApi-DHDDzZkq.js.map} +1 -1
  161. package/dist/{usePlatformApi-BrtHM9LM.js → usePlatformApi-CCMB7CBj.js} +3 -3
  162. package/dist/{usePlatformApi-BrtHM9LM.js.map → usePlatformApi-CCMB7CBj.js.map} +1 -1
  163. package/dist/useRazorpayPayment.js +2 -2
  164. package/dist/useRazorpayPayment.js.map +1 -1
  165. package/dist/useStripePromise.js +1 -1
  166. package/dist/useStripePromise.js.map +1 -1
  167. package/package.json +11 -11
  168. package/dist/CopyButtonWrapper-Bp5IVO76.js.map +0 -1
  169. package/dist/cjs/CopyButtonWrapper-I-kdKiiB.js.map +0 -1
  170. package/dist/queryConstants-C7AqdemO.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"ManualUpiConnect.js","sources":["../app/javascript/src/apis/manual_upi/vpas.js","../app/javascript/src/hooks/reactQuery/manualUpi/useVpasApi.js","../app/javascript/src/components/ManualUpiConnect/constants.js","../app/javascript/src/components/ManualUpiConnect/Add.jsx","../app/javascript/src/components/ManualUpiConnect/utils.jsx","../app/javascript/src/components/ManualUpiConnect/List.jsx","../app/javascript/src/components/ManualUpiConnect/index.jsx"],"sourcesContent":["import axios from \"axios\";\n\nimport { BASE_URL } from \"src/constants\";\n\nconst list = holdableId =>\n axios.get(`${BASE_URL}/api/v1/manual_upi/vpas`, {\n params: { holdableId },\n });\n\nconst create = payload =>\n axios.post(`${BASE_URL}/api/v1/manual_upi/vpas`, payload);\n\nconst destroy = ({ id, holdableId }) =>\n axios.delete(`${BASE_URL}/api/v1/manual_upi/vpas/${id}`, {\n params: { holdableId },\n });\n\nconst vpasApi = { list, create, destroy };\n\nexport default vpasApi;\n","import { useQuery } from \"@tanstack/react-query\";\nimport { useMutationWithInvalidation } from \"neetocommons/react-utils\";\n\nimport vpasApi from \"apis/manual_upi/vpas\";\nimport { QUERY_KEYS } from \"src/common/queryConstants\";\n\nexport const useFetchVpas = (holdableId, options = {}) =>\n useQuery({\n queryKey: [QUERY_KEYS.VPAS_LIST, holdableId],\n queryFn: () => vpasApi.list(holdableId),\n ...options,\n });\n\nexport const useCreateVpa = (keysToInvalidateOnCreate = []) =>\n useMutationWithInvalidation(vpasApi.create, {\n keysToInvalidate: [[QUERY_KEYS.VPAS_LIST], ...keysToInvalidateOnCreate],\n });\n\nexport const useDestroyVpa = (keysToInvalidateOnDelete = []) =>\n useMutationWithInvalidation(vpasApi.destroy, {\n keysToInvalidate: [[QUERY_KEYS.VPAS_LIST], ...keysToInvalidateOnDelete],\n });\n","import { t } from \"i18next\";\nimport * as yup from \"yup\";\n\nexport const VALIDATION_SCHEMA = yup.object({\n upiId: yup\n .string()\n .matches(\n /^[a-zA-Z0-9][a-zA-Z0-9._-]{2,30}@[a-zA-Z][a-zA-Z0-9]{2,20}$/,\n t(\"neetoPayments.upi.form.validation.invalidUpi\")\n )\n .required(t(\"neetoPayments.upi.form.validation.required\")),\n});\n","import CardLayout from \"neetomolecules/CardLayout\";\nimport { ActionBlock, Form, Input } from \"neetoui/formik\";\nimport { useTranslation } from \"react-i18next\";\nimport { useHistory } from \"react-router-dom\";\n\nimport { useCreateVpa } from \"hooks/reactQuery/manualUpi/useVpasApi\";\n\nimport { VALIDATION_SCHEMA } from \"./constants\";\n\nconst Add = ({ holdableId, keysToInvalidateOnCreate }) => {\n const { t } = useTranslation();\n const history = useHistory();\n const { isPending: isCreatingVpa, mutate: createVpa } = useCreateVpa(\n keysToInvalidateOnCreate\n );\n\n return (\n <Form\n className=\"w-full\"\n formikProps={{\n initialValues: { upiId: \"\" },\n onSubmit: (values, { resetForm }) => {\n createVpa({ holdableId, address: values.upiId });\n resetForm();\n },\n validationSchema: VALIDATION_SCHEMA,\n }}\n >\n {({ dirty }) => (\n <CardLayout\n actionBlock={\n <ActionBlock\n cancelButtonProps={{ onClick: history.goBack }}\n isSubmitting={isCreatingVpa}\n submitButtonProps={{\n label: t(\"neetoPayments.upi.form.add\"),\n disabled: !dirty || isCreatingVpa,\n }}\n />\n }\n >\n <Input\n className=\"w-full\"\n label={t(\"neetoPayments.upi.form.enterUpi\")}\n name=\"upiId\"\n placeholder={t(\"neetoPayments.upi.form.enterUpi\")}\n />\n </CardLayout>\n )}\n </Form>\n );\n};\n\nexport default Add;\n","import { t } from \"i18next\";\n\nimport { dateFormat } from \"neetocommons/utils\";\nimport MoreDropdown from \"neetomolecules/MoreDropdown\";\nimport { Typography } from \"neetoui\";\n\nexport const getColumnData = handleDeleteClick => [\n {\n title: t(\"neetoPayments.common.upiId\"),\n dataIndex: \"address\",\n key: \"address\",\n width: 272,\n render: (_, upiId) => (\n <div className=\"flex items-center justify-between gap-3\">\n <Typography className=\"w-4/5\" style=\"body2\">\n {upiId.address}\n </Typography>\n <MoreDropdown\n dropdownButtonProps={{ \"data-testid\": \"upi-more-dropdown\" }}\n dropdownProps={{ strategy: \"fixed\" }}\n menuItems={[\n {\n key: \"delete-meeting\",\n label: t(\"neetoPayments.common.delete\"),\n onClick: () => handleDeleteClick(upiId),\n \"data-testid\": \"menu-dropdown-delete-btn\",\n },\n ]}\n />\n </div>\n ),\n },\n {\n title: t(\"neetoPayments.common.createdAt\"),\n dataIndex: \"createdAt\",\n key: \"createdAt\",\n render: dateFormat.dateTime,\n },\n];\n","import { useState } from \"react\";\n\nimport { Alert, Table } from \"neetoui\";\nimport { isEmpty } from \"ramda\";\nimport { Trans, useTranslation } from \"react-i18next\";\n\nimport { useDestroyVpa } from \"hooks/reactQuery/manualUpi/useVpasApi\";\n\nimport { getColumnData } from \"./utils\";\n\nconst List = ({ holdableId, upiIds, keysToInvalidateOnDelete }) => {\n const { t } = useTranslation();\n\n const [isAlertOpen, setIsAlertOpen] = useState(false);\n const [selectedUpiId, setSelectedUpiId] = useState({});\n\n const { mutate: deleteVpa } = useDestroyVpa(keysToInvalidateOnDelete);\n\n const handleOpenDeleteModal = id => {\n setSelectedUpiId(id);\n setIsAlertOpen(true);\n };\n\n const handleAlertClose = () => {\n setSelectedUpiId({});\n setIsAlertOpen(false);\n };\n\n const handleAlertSubmit = () => {\n deleteVpa({ id: selectedUpiId?.id, holdableId });\n setIsAlertOpen(false);\n };\n\n if (isEmpty(upiIds)) {\n return null;\n }\n\n return (\n <div className=\"w-full max-w-3xl mx-auto\">\n <Table\n columnData={getColumnData(handleOpenDeleteModal)}\n rowData={upiIds}\n />\n <Alert\n isOpen={isAlertOpen}\n title={t(\"neetoPayments.upi.alert.title\")}\n message={\n <Trans\n components={{ b: <strong /> }}\n i18nKey=\"neetoPayments.upi.alert.message\"\n values={{ upiId: selectedUpiId.address }}\n />\n }\n onClose={handleAlertClose}\n onSubmit={handleAlertSubmit}\n />\n </div>\n );\n};\n\nexport default List;\n","import { Spinner } from \"neetoui\";\n\nimport { useFetchVpas } from \"hooks/reactQuery/manualUpi/useVpasApi\";\n\nimport Add from \"./Add\";\nimport List from \"./List\";\n\nconst ManualUpiConnect = ({\n holdableId,\n keysToInvalidateOnDelete = [],\n keysToInvalidateOnCreate = [],\n}) => {\n const { data: { vpas: upiIds = [] } = {}, isLoading } =\n useFetchVpas(holdableId);\n\n if (isLoading) {\n return (\n <div className=\"flex items-center justify-center w-full h-full\">\n <Spinner />\n </div>\n );\n }\n\n return (\n <div className=\"flex flex-col items-start w-full\">\n {upiIds.length < 3 && (\n <Add {...{ holdableId, keysToInvalidateOnCreate }} />\n )}\n <List {...{ holdableId, keysToInvalidateOnDelete, upiIds }} />\n </div>\n );\n};\n\nexport default ManualUpiConnect;\n"],"names":["list","holdableId","axios","get","BASE_URL","params","create","payload","post","destroy","id","delete","vpasApi","useFetchVpas","options","useQuery","queryKey","QUERY_KEYS","VPAS_LIST","queryFn","useCreateVpa","keysToInvalidateOnCreate","useMutationWithInvalidation","keysToInvalidate","useDestroyVpa","keysToInvalidateOnDelete","VALIDATION_SCHEMA","yup","object","upiId","string","matches","t","required","Add","useTranslation","history","useHistory","isPending","isCreatingVpa","mutate","createVpa","_jsx","Form","className","formikProps","initialValues","onSubmit","values","resetForm","address","validationSchema","children","dirty","CardLayout","actionBlock","ActionBlock","cancelButtonProps","onClick","goBack","isSubmitting","submitButtonProps","label","disabled","Input","name","placeholder","getColumnData","handleDeleteClick","title","dataIndex","key","width","render","_","_jsxs","Typography","style","MoreDropdown","dropdownButtonProps","dropdownProps","strategy","menuItems","dateFormat","dateTime","List","upiIds","isAlertOpen","setIsAlertOpen","useState","selectedUpiId","setSelectedUpiId","deleteVpa","handleOpenDeleteModal","handleAlertClose","handleAlertSubmit","isEmpty","Table","columnData","rowData","Alert","isOpen","message","Trans","components","b","i18nKey","onClose","ManualUpiConnect","data","vpas","isLoading","Spinner","length"],"mappings":"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"}
1
+ {"version":3,"file":"ManualUpiConnect.js","sources":["../app/javascript/src/apis/manual_upi/vpas.js","../app/javascript/src/hooks/reactQuery/manualUpi/useVpasApi.js","../app/javascript/src/components/ManualUpiConnect/constants.js","../app/javascript/src/components/ManualUpiConnect/Add.jsx","../app/javascript/src/components/ManualUpiConnect/utils.jsx","../app/javascript/src/components/ManualUpiConnect/List.jsx","../app/javascript/src/components/ManualUpiConnect/index.jsx"],"sourcesContent":["import axios from \"axios\";\n\nimport { BASE_URL } from \"src/constants\";\n\nconst list = holdableId =>\n axios.get(`${BASE_URL}/api/v1/manual_upi/vpas`, {\n params: { holdableId },\n });\n\nconst create = payload =>\n axios.post(`${BASE_URL}/api/v1/manual_upi/vpas`, payload);\n\nconst destroy = ({ id, holdableId }) =>\n axios.delete(`${BASE_URL}/api/v1/manual_upi/vpas/${id}`, {\n params: { holdableId },\n });\n\nconst vpasApi = { list, create, destroy };\n\nexport default vpasApi;\n","import { useQuery } from \"@tanstack/react-query\";\nimport { useMutationWithInvalidation } from \"neetocommons/react-utils\";\n\nimport vpasApi from \"apis/manual_upi/vpas\";\nimport { QUERY_KEYS } from \"src/common/queryConstants\";\n\nexport const useFetchVpas = (holdableId, options = {}) =>\n useQuery({\n queryKey: [QUERY_KEYS.VPAS_LIST, holdableId],\n queryFn: () => vpasApi.list(holdableId),\n ...options,\n });\n\nexport const useCreateVpa = (keysToInvalidateOnCreate = []) =>\n useMutationWithInvalidation(vpasApi.create, {\n keysToInvalidate: [[QUERY_KEYS.VPAS_LIST], ...keysToInvalidateOnCreate],\n });\n\nexport const useDestroyVpa = (keysToInvalidateOnDelete = []) =>\n useMutationWithInvalidation(vpasApi.destroy, {\n keysToInvalidate: [[QUERY_KEYS.VPAS_LIST], ...keysToInvalidateOnDelete],\n });\n","import { t } from \"i18next\";\nimport * as yup from \"yup\";\n\nexport const VALIDATION_SCHEMA = yup.object({\n upiId: yup\n .string()\n .matches(\n /^[a-zA-Z0-9][a-zA-Z0-9._-]{2,30}@[a-zA-Z][a-zA-Z0-9]{2,20}$/,\n t(\"neetoPayments.upi.form.validation.invalidUpi\")\n )\n .required(t(\"neetoPayments.upi.form.validation.required\")),\n});\n","import CardLayout from \"neetomolecules/CardLayout\";\nimport { ActionBlock, Form, Input } from \"neetoui/formik\";\nimport { useTranslation } from \"react-i18next\";\nimport { useHistory } from \"react-router-dom\";\n\nimport { useCreateVpa } from \"hooks/reactQuery/manualUpi/useVpasApi\";\n\nimport { VALIDATION_SCHEMA } from \"./constants\";\n\nconst Add = ({ holdableId, keysToInvalidateOnCreate }) => {\n const { t } = useTranslation();\n const history = useHistory();\n const { isPending: isCreatingVpa, mutate: createVpa } = useCreateVpa(\n keysToInvalidateOnCreate\n );\n\n return (\n <Form\n className=\"w-full\"\n formikProps={{\n initialValues: { upiId: \"\" },\n onSubmit: (values, { resetForm }) => {\n createVpa({ holdableId, address: values.upiId });\n resetForm();\n },\n validationSchema: VALIDATION_SCHEMA,\n }}\n >\n {({ dirty }) => (\n <CardLayout\n actionBlock={\n <ActionBlock\n cancelButtonProps={{ onClick: history.goBack }}\n isSubmitting={isCreatingVpa}\n submitButtonProps={{\n label: t(\"neetoPayments.upi.form.add\"),\n disabled: !dirty || isCreatingVpa,\n }}\n />\n }\n >\n <Input\n className=\"w-full\"\n label={t(\"neetoPayments.upi.form.enterUpi\")}\n name=\"upiId\"\n placeholder={t(\"neetoPayments.upi.form.enterUpi\")}\n />\n </CardLayout>\n )}\n </Form>\n );\n};\n\nexport default Add;\n","import { t } from \"i18next\";\n\nimport { dateFormat } from \"neetocommons/utils\";\nimport MoreDropdown from \"neetomolecules/MoreDropdown\";\nimport { Typography } from \"neetoui\";\n\nexport const getColumnData = handleDeleteClick => [\n {\n title: t(\"neetoPayments.common.upiId\"),\n dataIndex: \"address\",\n key: \"address\",\n width: 272,\n render: (_, upiId) => (\n <div className=\"flex items-center justify-between gap-3\">\n <Typography className=\"w-4/5\" style=\"body2\">\n {upiId.address}\n </Typography>\n <MoreDropdown\n dropdownButtonProps={{ \"data-testid\": \"upi-more-dropdown\" }}\n dropdownProps={{ strategy: \"fixed\" }}\n menuItems={[\n {\n key: \"delete-meeting\",\n label: t(\"neetoPayments.common.delete\"),\n onClick: () => handleDeleteClick(upiId),\n \"data-testid\": \"menu-dropdown-delete-btn\",\n },\n ]}\n />\n </div>\n ),\n },\n {\n title: t(\"neetoPayments.common.createdAt\"),\n dataIndex: \"createdAt\",\n key: \"createdAt\",\n render: dateFormat.dateTime,\n },\n];\n","import { useState } from \"react\";\n\nimport { Alert, Table } from \"neetoui\";\nimport { isEmpty } from \"ramda\";\nimport { Trans, useTranslation } from \"react-i18next\";\n\nimport { useDestroyVpa } from \"hooks/reactQuery/manualUpi/useVpasApi\";\n\nimport { getColumnData } from \"./utils\";\n\nconst List = ({ holdableId, upiIds, keysToInvalidateOnDelete }) => {\n const { t } = useTranslation();\n\n const [isAlertOpen, setIsAlertOpen] = useState(false);\n const [selectedUpiId, setSelectedUpiId] = useState({});\n\n const { mutate: deleteVpa } = useDestroyVpa(keysToInvalidateOnDelete);\n\n const handleOpenDeleteModal = id => {\n setSelectedUpiId(id);\n setIsAlertOpen(true);\n };\n\n const handleAlertClose = () => {\n setSelectedUpiId({});\n setIsAlertOpen(false);\n };\n\n const handleAlertSubmit = () => {\n deleteVpa({ id: selectedUpiId?.id, holdableId });\n setIsAlertOpen(false);\n };\n\n if (isEmpty(upiIds)) {\n return null;\n }\n\n return (\n <div className=\"w-full max-w-3xl mx-auto\">\n <Table\n columnData={getColumnData(handleOpenDeleteModal)}\n rowData={upiIds}\n />\n <Alert\n isOpen={isAlertOpen}\n title={t(\"neetoPayments.upi.alert.title\")}\n message={\n <Trans\n components={{ b: <strong /> }}\n i18nKey=\"neetoPayments.upi.alert.message\"\n values={{ upiId: selectedUpiId.address }}\n />\n }\n onClose={handleAlertClose}\n onSubmit={handleAlertSubmit}\n />\n </div>\n );\n};\n\nexport default List;\n","import { Spinner } from \"neetoui\";\n\nimport { useFetchVpas } from \"hooks/reactQuery/manualUpi/useVpasApi\";\n\nimport Add from \"./Add\";\nimport List from \"./List\";\n\nconst ManualUpiConnect = ({\n holdableId,\n keysToInvalidateOnDelete = [],\n keysToInvalidateOnCreate = [],\n}) => {\n const { data: { vpas: upiIds = [] } = {}, isLoading } =\n useFetchVpas(holdableId);\n\n if (isLoading) {\n return (\n <div className=\"flex items-center justify-center w-full h-full\">\n <Spinner />\n </div>\n );\n }\n\n return (\n <div className=\"flex flex-col items-start w-full\">\n {upiIds.length < 3 && (\n <Add {...{ holdableId, keysToInvalidateOnCreate }} />\n )}\n <List {...{ holdableId, keysToInvalidateOnDelete, upiIds }} />\n </div>\n );\n};\n\nexport default ManualUpiConnect;\n"],"names":["list","holdableId","axios","get","BASE_URL","params","create","payload","post","destroy","id","delete","vpasApi","useFetchVpas","options","useQuery","queryKey","QUERY_KEYS","VPAS_LIST","queryFn","useCreateVpa","keysToInvalidateOnCreate","useMutationWithInvalidation","keysToInvalidate","useDestroyVpa","keysToInvalidateOnDelete","VALIDATION_SCHEMA","yup","object","upiId","string","matches","t","required","Add","useTranslation","history","useHistory","isPending","isCreatingVpa","mutate","createVpa","_jsx","Form","className","formikProps","initialValues","onSubmit","values","resetForm","address","validationSchema","children","dirty","CardLayout","actionBlock","ActionBlock","cancelButtonProps","onClick","goBack","isSubmitting","submitButtonProps","label","disabled","Input","name","placeholder","getColumnData","handleDeleteClick","title","dataIndex","key","width","render","_","_jsxs","Typography","style","MoreDropdown","dropdownButtonProps","dropdownProps","strategy","menuItems","dateFormat","dateTime","List","upiIds","isAlertOpen","setIsAlertOpen","useState","selectedUpiId","setSelectedUpiId","deleteVpa","handleOpenDeleteModal","handleAlertClose","handleAlertSubmit","isEmpty","Table","columnData","rowData","Alert","isOpen","message","Trans","components","b","i18nKey","onClose","ManualUpiConnect","data","vpas","isLoading","Spinner","length"],"mappings":"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"}
@@ -1,30 +1,39 @@
1
- import { isPresent, noop } from 'neetocist';
2
- import { Typography } from '@bigbinary/neetoui';
1
+ import { useRef, useState, useMemo, useEffect } from 'react';
2
+ import { DirectUpload } from '@rails/activestorage';
3
+ import { isPresent, isNotPresent, noop } from 'neetocist';
4
+ import { Close } from '@bigbinary/neeto-icons';
5
+ import { Typography, Button, Toastr } from '@bigbinary/neetoui';
3
6
  import { Form, Input, ActionBlock } from '@bigbinary/neetoui/formik';
4
7
  import QRCodeImage from 'qrcode.react';
5
8
  import { pluck } from 'ramda';
6
9
  import { useTranslation } from 'react-i18next';
7
- import { u as useCreateUpiPayment } from './usePaymentApi-D-8CnzxZ.js';
8
- import { k as getQrCodeValue } from './index-DqpYJN4W.js';
10
+ import { u as useCreateUpiPayment } from './usePaymentApi-DHDDzZkq.js';
11
+ import { k as getQrCodeValue } from './index-15RrM-W8.js';
9
12
  import { t } from 'i18next';
10
13
  import * as yup from 'yup';
11
14
  import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
12
15
  import '@tanstack/react-query';
13
16
  import 'neetocommons/react-utils';
14
17
  import 'axios';
15
- import './queryConstants-C7AqdemO.js';
18
+ import './queryConstants-8c7Nd8ML.js';
16
19
  import 'neetocommons/constants';
17
20
  import 'decimal.js';
18
21
  import 'neetocommons/utils';
19
22
 
20
- const VALIDATION_SCHEMA = yup.object({
23
+ const ACCEPTED_SCREENSHOT_FORMATS = "image/png,image/jpeg,image/jpg";
24
+ const MAX_SCREENSHOT_SIZE_MB = 5;
25
+ const DIRECT_UPLOAD_URL = "/rails/active_storage/direct_uploads";
26
+ const INITIAL_VALUES = {
27
+ identifier: ""
28
+ };
29
+ const buildValidationSchema = screenshotFile => yup.object({
21
30
  identifier: yup.number().typeError(t("neetoPayments.validations.invalidField", {
22
31
  entity: t("neetoPayments.common.transactionId")
23
- })).required(t("neetoPayments.upi.payment.transaction.required")).test("is-integer", t("neetoPayments.validations.invalidField", {
32
+ })).nullable().transform((value, originalValue) => originalValue === "" ? null : value).test("identifier-or-screenshot", t("neetoPayments.upi.payment.transaction.identifierOrScreenshot"), value => isPresent(value) || isPresent(screenshotFile)).test("is-integer", t("neetoPayments.validations.invalidField", {
24
33
  entity: t("neetoPayments.common.transactionId")
25
- }), value => Number.isInteger(value)).test("len", t("neetoPayments.validations.length", {
34
+ }), value => isNotPresent(value) || Number.isInteger(value)).test("len", t("neetoPayments.validations.length", {
26
35
  length: 12
27
- }), value => value?.toString().length === 12)
36
+ }), value => isNotPresent(value) || value?.toString().length === 12)
28
37
  });
29
38
 
30
39
  const ManualUpiPayment = ({
@@ -43,6 +52,13 @@ const ManualUpiPayment = ({
43
52
  const {
44
53
  t
45
54
  } = useTranslation();
55
+ const fileInputRef = useRef(null);
56
+ const [screenshotFile, setScreenshotFile] = useState(null);
57
+ const [isUploading, setIsUploading] = useState(false);
58
+ const screenshotPreview = useMemo(() => screenshotFile ? URL.createObjectURL(screenshotFile) : null, [screenshotFile]);
59
+ useEffect(() => () => {
60
+ if (screenshotPreview) URL.revokeObjectURL(screenshotPreview);
61
+ }, [screenshotPreview]);
46
62
  const vpaIds = pluck("address", fee?.vpas);
47
63
  const amountToUpi = customAmount || amount;
48
64
  const {
@@ -52,27 +68,58 @@ const ManualUpiPayment = ({
52
68
  onSuccess: onSuccessfulPayment,
53
69
  onError: onFailedPayment
54
70
  });
55
- const handleSubmit = values => {
71
+ const validationSchema = useMemo(() => buildValidationSchema(screenshotFile), [screenshotFile]);
72
+ const handleScreenshotSelect = event => {
73
+ const file = event.target.files[0];
74
+ if (!file) return;
75
+ if (file.size > MAX_SCREENSHOT_SIZE_MB * 1024 * 1024) {
76
+ Toastr.error(t("neetoPayments.upi.payment.screenshot.tooLarge", {
77
+ maxSize: MAX_SCREENSHOT_SIZE_MB
78
+ }));
79
+ return;
80
+ }
81
+ setScreenshotFile(file);
82
+ };
83
+ const handleRemoveScreenshot = () => {
84
+ setScreenshotFile(null);
85
+ if (fileInputRef.current) fileInputRef.current.value = "";
86
+ };
87
+ const uploadScreenshot = file => new Promise((resolve, reject) => {
88
+ const upload = new DirectUpload(file, DIRECT_UPLOAD_URL);
89
+ upload.create((error, blob) => {
90
+ if (error) reject(error);else resolve(blob.signed_id);
91
+ });
92
+ });
93
+ const handleSubmit = async values => {
56
94
  onBeforePayment();
57
- const payload = {
95
+ let paymentScreenshot = null;
96
+ if (screenshotFile) {
97
+ try {
98
+ setIsUploading(true);
99
+ paymentScreenshot = await uploadScreenshot(screenshotFile);
100
+ } catch {
101
+ onFailedPayment();
102
+ return;
103
+ } finally {
104
+ setIsUploading(false);
105
+ }
106
+ }
107
+ createPayment({
58
108
  ...values,
59
109
  payableId,
60
110
  customAmount,
61
111
  payableType,
62
112
  discountCode,
63
- tipAttributes: tip
64
- };
65
- createPayment(payload);
113
+ tipAttributes: tip,
114
+ paymentScreenshot
115
+ });
66
116
  };
67
117
  return /*#__PURE__*/jsx(Form, {
68
118
  className: "space-y-4",
69
119
  formikProps: {
70
120
  onSubmit: handleSubmit,
71
- initialValues: {
72
- identifier: ""
73
- },
74
- enableReinitialize: true,
75
- validationSchema: VALIDATION_SCHEMA
121
+ initialValues: INITIAL_VALUES,
122
+ validationSchema
76
123
  },
77
124
  children: ({
78
125
  dirty
@@ -100,11 +147,70 @@ const ManualUpiPayment = ({
100
147
  })]
101
148
  }, vpaId))
102
149
  }), /*#__PURE__*/jsx(Input, {
103
- required: true,
104
150
  label: t("neetoPayments.upi.payment.transaction.label"),
105
151
  name: "identifier",
106
152
  placeholder: t("neetoPayments.upi.payment.transaction.placeholder"),
107
153
  type: "number"
154
+ }), /*#__PURE__*/jsxs("div", {
155
+ className: "flex items-center gap-3",
156
+ children: [/*#__PURE__*/jsx("hr", {
157
+ className: "flex-1 border-gray-300"
158
+ }), /*#__PURE__*/jsx(Typography, {
159
+ className: "text-gray-500 uppercase",
160
+ style: "body2",
161
+ children: t("neetoPayments.common.or")
162
+ }), /*#__PURE__*/jsx("hr", {
163
+ className: "flex-1 border-gray-300"
164
+ })]
165
+ }), /*#__PURE__*/jsxs("div", {
166
+ children: [/*#__PURE__*/jsx(Typography, {
167
+ className: "mb-2",
168
+ style: "body2",
169
+ weight: "medium",
170
+ children: t("neetoPayments.upi.payment.screenshot.label")
171
+ }), screenshotPreview ? /*#__PURE__*/jsxs("div", {
172
+ className: "relative inline-block",
173
+ children: [/*#__PURE__*/jsx("img", {
174
+ alt: t("neetoPayments.upi.payment.screenshot.alt"),
175
+ className: "max-h-40 rounded border border-gray-200",
176
+ src: screenshotPreview
177
+ }), /*#__PURE__*/jsx(Button, {
178
+ className: "absolute -right-2 -top-2 neeto-ui-rounded-full neeto-ui-bg-white neeto-ui-shadow-sm",
179
+ icon: Close,
180
+ size: "small",
181
+ style: "text",
182
+ onClick: handleRemoveScreenshot
183
+ })]
184
+ }) : /*#__PURE__*/jsxs("div", {
185
+ className: "flex cursor-pointer flex-col items-center justify-center rounded border-2 border-dashed border-gray-300 p-6 transition-colors hover:border-gray-400",
186
+ role: "button",
187
+ tabIndex: 0,
188
+ onClick: () => fileInputRef.current?.click(),
189
+ onKeyDown: e => {
190
+ if (e.key === "Enter" || e.key === " ") {
191
+ fileInputRef.current?.click();
192
+ }
193
+ },
194
+ children: [/*#__PURE__*/jsx("i", {
195
+ className: "ri-upload-2-line text-2xl text-gray-400"
196
+ }), /*#__PURE__*/jsx(Typography, {
197
+ className: "mt-1 text-gray-500",
198
+ style: "body3",
199
+ children: t("neetoPayments.upi.payment.screenshot.uploadText")
200
+ }), /*#__PURE__*/jsx(Typography, {
201
+ className: "text-gray-400",
202
+ style: "nano",
203
+ children: t("neetoPayments.upi.payment.screenshot.formatHint", {
204
+ maxSize: MAX_SCREENSHOT_SIZE_MB
205
+ })
206
+ })]
207
+ }), /*#__PURE__*/jsx("input", {
208
+ accept: ACCEPTED_SCREENSHOT_FORMATS,
209
+ className: "hidden",
210
+ ref: fileInputRef,
211
+ type: "file",
212
+ onChange: handleScreenshotSelect
213
+ })]
108
214
  }), /*#__PURE__*/jsx(ActionBlock, {
109
215
  cancelButtonProps: {
110
216
  label: t("neetoPayments.upi.payment.buttons.back"),
@@ -113,8 +219,8 @@ const ManualUpiPayment = ({
113
219
  },
114
220
  submitButtonProps: {
115
221
  label: t("neetoPayments.upi.payment.buttons.submit"),
116
- disabled: !dirty || isPending,
117
- loading: isPending
222
+ disabled: !dirty && !screenshotFile || isPending || isUploading,
223
+ loading: isPending || isUploading
118
224
  }
119
225
  })]
120
226
  })
@@ -1 +1 @@
1
- {"version":3,"file":"ManualUpiPayment.js","sources":["../app/javascript/src/components/ManualUpiPayment/constants.js","../app/javascript/src/components/ManualUpiPayment/index.jsx"],"sourcesContent":["import { t } from \"i18next\";\nimport * as yup from \"yup\";\n\nexport const VALIDATION_SCHEMA = yup.object({\n identifier: yup\n .number()\n .typeError(\n t(\"neetoPayments.validations.invalidField\", {\n entity: t(\"neetoPayments.common.transactionId\"),\n })\n )\n .required(t(\"neetoPayments.upi.payment.transaction.required\"))\n .test(\n \"is-integer\",\n t(\"neetoPayments.validations.invalidField\", {\n entity: t(\"neetoPayments.common.transactionId\"),\n }),\n value => Number.isInteger(value)\n )\n .test(\n \"len\",\n t(\"neetoPayments.validations.length\", { length: 12 }),\n value => value?.toString().length === 12\n ),\n});\n","import { noop, isPresent } from \"neetocist\";\nimport { Typography } from \"neetoui\";\nimport { ActionBlock, Form, Input } from \"neetoui/formik\";\nimport QRCodeImage from \"qrcode.react\";\nimport { pluck } from \"ramda\";\nimport { useTranslation } from \"react-i18next\";\n\nimport { useCreateUpiPayment } from \"hooks/reactQuery/manualUpi/usePaymentApi\";\nimport { getQrCodeValue } from \"utils\";\n\nimport { VALIDATION_SCHEMA } from \"./constants\";\n\nconst ManualUpiPayment = ({\n fee,\n payableId,\n tip,\n amount,\n discountCode,\n customAmount,\n handleCancel,\n payableType = null,\n onBeforePayment = noop,\n onFailedPayment = noop,\n onSuccessfulPayment = noop,\n}) => {\n const { t } = useTranslation();\n\n const vpaIds = pluck(\"address\", fee?.vpas);\n const amountToUpi = customAmount || amount;\n\n const { isPending, mutate: createPayment } = useCreateUpiPayment({\n onSuccess: onSuccessfulPayment,\n onError: onFailedPayment,\n });\n\n const handleSubmit = values => {\n onBeforePayment();\n const payload = {\n ...values,\n payableId,\n customAmount,\n payableType,\n discountCode,\n tipAttributes: tip,\n };\n createPayment(payload);\n };\n\n return (\n <Form\n className=\"space-y-4\"\n formikProps={{\n onSubmit: handleSubmit,\n initialValues: { identifier: \"\" },\n enableReinitialize: true,\n validationSchema: VALIDATION_SCHEMA,\n }}\n >\n {({ dirty }) => (\n <>\n <Typography style=\"body1\">\n {t(\"neetoPayments.upi.payment.vpaText\", { count: vpaIds.length })}\n </Typography>\n {isPresent(vpaIds) && (\n <div className=\"grid grid-cols-1 gap-8 gap-y-4 sm:grid-cols-2\">\n {vpaIds.map(vpaId => (\n <div\n className=\"flex flex-col items-center justify-center\"\n key={vpaId}\n >\n <QRCodeImage\n size={256}\n style={{ width: 80, height: 80 }}\n value={getQrCodeValue(vpaId, amountToUpi)}\n />\n <Typography\n className=\"w-full mt-2 text-center wrap-break-word\"\n style=\"body2\"\n >\n {vpaId}\n </Typography>\n </div>\n ))}\n </div>\n )}\n <Input\n required\n label={t(\"neetoPayments.upi.payment.transaction.label\")}\n name=\"identifier\"\n placeholder={t(\"neetoPayments.upi.payment.transaction.placeholder\")}\n type=\"number\"\n />\n <ActionBlock\n cancelButtonProps={{\n label: t(\"neetoPayments.upi.payment.buttons.back\"),\n onClick: handleCancel,\n disabled: isPending,\n }}\n submitButtonProps={{\n label: t(\"neetoPayments.upi.payment.buttons.submit\"),\n disabled: !dirty || isPending,\n loading: isPending,\n }}\n />\n </>\n )}\n </Form>\n );\n};\n\nexport default ManualUpiPayment;\n"],"names":["VALIDATION_SCHEMA","yup","object","identifier","number","typeError","t","entity","required","test","value","Number","isInteger","length","toString","ManualUpiPayment","fee","payableId","tip","amount","discountCode","customAmount","handleCancel","payableType","onBeforePayment","noop","onFailedPayment","onSuccessfulPayment","useTranslation","vpaIds","pluck","vpas","amountToUpi","isPending","mutate","createPayment","useCreateUpiPayment","onSuccess","onError","handleSubmit","values","payload","tipAttributes","_jsx","Form","className","formikProps","onSubmit","initialValues","enableReinitialize","validationSchema","children","dirty","_jsxs","_Fragment","Typography","style","count","isPresent","map","vpaId","QRCodeImage","size","width","height","getQrCodeValue","Input","label","name","placeholder","type","ActionBlock","cancelButtonProps","onClick","disabled","submitButtonProps","loading"],"mappings":"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"}
1
+ {"version":3,"file":"ManualUpiPayment.js","sources":["../app/javascript/src/components/ManualUpiPayment/constants.js","../app/javascript/src/components/ManualUpiPayment/index.jsx"],"sourcesContent":["import { t } from \"i18next\";\nimport { isPresent, isNotPresent } from \"neetocist\";\nimport * as yup from \"yup\";\n\nexport const ACCEPTED_SCREENSHOT_FORMATS = \"image/png,image/jpeg,image/jpg\";\n\nexport const MAX_SCREENSHOT_SIZE_MB = 5;\n\nexport const DIRECT_UPLOAD_URL = \"/rails/active_storage/direct_uploads\";\n\nexport const INITIAL_VALUES = { identifier: \"\" };\n\nexport const buildValidationSchema = screenshotFile =>\n yup.object({\n identifier: yup\n .number()\n .typeError(\n t(\"neetoPayments.validations.invalidField\", {\n entity: t(\"neetoPayments.common.transactionId\"),\n })\n )\n .nullable()\n .transform((value, originalValue) =>\n originalValue === \"\" ? null : value\n )\n .test(\n \"identifier-or-screenshot\",\n t(\"neetoPayments.upi.payment.transaction.identifierOrScreenshot\"),\n value => isPresent(value) || isPresent(screenshotFile)\n )\n .test(\n \"is-integer\",\n t(\"neetoPayments.validations.invalidField\", {\n entity: t(\"neetoPayments.common.transactionId\"),\n }),\n value => isNotPresent(value) || Number.isInteger(value)\n )\n .test(\n \"len\",\n t(\"neetoPayments.validations.length\", { length: 12 }),\n value => isNotPresent(value) || value?.toString().length === 12\n ),\n });\n","import { useRef, useState, useMemo, useEffect } from \"react\";\n\nimport { DirectUpload } from \"@rails/activestorage\";\nimport { noop, isPresent } from \"neetocist\";\nimport { Close } from \"neetoicons\";\nimport { Button, Toastr, Typography } from \"neetoui\";\nimport { ActionBlock, Form, Input } from \"neetoui/formik\";\nimport QRCodeImage from \"qrcode.react\";\nimport { pluck } from \"ramda\";\nimport { useTranslation } from \"react-i18next\";\n\nimport { useCreateUpiPayment } from \"hooks/reactQuery/manualUpi/usePaymentApi\";\nimport { getQrCodeValue } from \"utils\";\n\nimport {\n buildValidationSchema,\n ACCEPTED_SCREENSHOT_FORMATS,\n MAX_SCREENSHOT_SIZE_MB,\n DIRECT_UPLOAD_URL,\n INITIAL_VALUES,\n} from \"./constants\";\n\nconst ManualUpiPayment = ({\n fee,\n payableId,\n tip,\n amount,\n discountCode,\n customAmount,\n handleCancel,\n payableType = null,\n onBeforePayment = noop,\n onFailedPayment = noop,\n onSuccessfulPayment = noop,\n}) => {\n const { t } = useTranslation();\n const fileInputRef = useRef(null);\n const [screenshotFile, setScreenshotFile] = useState(null);\n const [isUploading, setIsUploading] = useState(false);\n\n const screenshotPreview = useMemo(\n () => (screenshotFile ? URL.createObjectURL(screenshotFile) : null),\n [screenshotFile]\n );\n\n useEffect(\n () => () => {\n if (screenshotPreview) URL.revokeObjectURL(screenshotPreview);\n },\n [screenshotPreview]\n );\n\n const vpaIds = pluck(\"address\", fee?.vpas);\n const amountToUpi = customAmount || amount;\n\n const { isPending, mutate: createPayment } = useCreateUpiPayment({\n onSuccess: onSuccessfulPayment,\n onError: onFailedPayment,\n });\n\n const validationSchema = useMemo(\n () => buildValidationSchema(screenshotFile),\n [screenshotFile]\n );\n\n const handleScreenshotSelect = event => {\n const file = event.target.files[0];\n if (!file) return;\n\n if (file.size > MAX_SCREENSHOT_SIZE_MB * 1024 * 1024) {\n Toastr.error(\n t(\"neetoPayments.upi.payment.screenshot.tooLarge\", {\n maxSize: MAX_SCREENSHOT_SIZE_MB,\n })\n );\n\n return;\n }\n\n setScreenshotFile(file);\n };\n\n const handleRemoveScreenshot = () => {\n setScreenshotFile(null);\n if (fileInputRef.current) fileInputRef.current.value = \"\";\n };\n\n const uploadScreenshot = file =>\n new Promise((resolve, reject) => {\n const upload = new DirectUpload(file, DIRECT_UPLOAD_URL);\n upload.create((error, blob) => {\n if (error) reject(error);\n else resolve(blob.signed_id);\n });\n });\n\n const handleSubmit = async values => {\n onBeforePayment();\n\n let paymentScreenshot = null;\n if (screenshotFile) {\n try {\n setIsUploading(true);\n paymentScreenshot = await uploadScreenshot(screenshotFile);\n } catch {\n onFailedPayment();\n\n return;\n } finally {\n setIsUploading(false);\n }\n }\n\n createPayment({\n ...values,\n payableId,\n customAmount,\n payableType,\n discountCode,\n tipAttributes: tip,\n paymentScreenshot,\n });\n };\n\n return (\n <Form\n className=\"space-y-4\"\n formikProps={{\n onSubmit: handleSubmit,\n initialValues: INITIAL_VALUES,\n validationSchema,\n }}\n >\n {({ dirty }) => (\n <>\n <Typography style=\"body1\">\n {t(\"neetoPayments.upi.payment.vpaText\", { count: vpaIds.length })}\n </Typography>\n {isPresent(vpaIds) && (\n <div className=\"grid grid-cols-1 gap-8 gap-y-4 sm:grid-cols-2\">\n {vpaIds.map(vpaId => (\n <div\n className=\"flex flex-col items-center justify-center\"\n key={vpaId}\n >\n <QRCodeImage\n size={256}\n style={{ width: 80, height: 80 }}\n value={getQrCodeValue(vpaId, amountToUpi)}\n />\n <Typography\n className=\"w-full mt-2 text-center wrap-break-word\"\n style=\"body2\"\n >\n {vpaId}\n </Typography>\n </div>\n ))}\n </div>\n )}\n <Input\n label={t(\"neetoPayments.upi.payment.transaction.label\")}\n name=\"identifier\"\n placeholder={t(\"neetoPayments.upi.payment.transaction.placeholder\")}\n type=\"number\"\n />\n <div className=\"flex items-center gap-3\">\n <hr className=\"flex-1 border-gray-300\" />\n <Typography className=\"text-gray-500 uppercase\" style=\"body2\">\n {t(\"neetoPayments.common.or\")}\n </Typography>\n <hr className=\"flex-1 border-gray-300\" />\n </div>\n <div>\n <Typography className=\"mb-2\" style=\"body2\" weight=\"medium\">\n {t(\"neetoPayments.upi.payment.screenshot.label\")}\n </Typography>\n {screenshotPreview ? (\n <div className=\"relative inline-block\">\n <img\n alt={t(\"neetoPayments.upi.payment.screenshot.alt\")}\n className=\"max-h-40 rounded border border-gray-200\"\n src={screenshotPreview}\n />\n <Button\n className=\"absolute -right-2 -top-2 neeto-ui-rounded-full neeto-ui-bg-white neeto-ui-shadow-sm\"\n icon={Close}\n size=\"small\"\n style=\"text\"\n onClick={handleRemoveScreenshot}\n />\n </div>\n ) : (\n <div\n className=\"flex cursor-pointer flex-col items-center justify-center rounded border-2 border-dashed border-gray-300 p-6 transition-colors hover:border-gray-400\"\n role=\"button\"\n tabIndex={0}\n onClick={() => fileInputRef.current?.click()}\n onKeyDown={e => {\n if (e.key === \"Enter\" || e.key === \" \") {\n fileInputRef.current?.click();\n }\n }}\n >\n <i className=\"ri-upload-2-line text-2xl text-gray-400\" />\n <Typography className=\"mt-1 text-gray-500\" style=\"body3\">\n {t(\"neetoPayments.upi.payment.screenshot.uploadText\")}\n </Typography>\n <Typography className=\"text-gray-400\" style=\"nano\">\n {t(\"neetoPayments.upi.payment.screenshot.formatHint\", {\n maxSize: MAX_SCREENSHOT_SIZE_MB,\n })}\n </Typography>\n </div>\n )}\n <input\n accept={ACCEPTED_SCREENSHOT_FORMATS}\n className=\"hidden\"\n ref={fileInputRef}\n type=\"file\"\n onChange={handleScreenshotSelect}\n />\n </div>\n <ActionBlock\n cancelButtonProps={{\n label: t(\"neetoPayments.upi.payment.buttons.back\"),\n onClick: handleCancel,\n disabled: isPending,\n }}\n submitButtonProps={{\n label: t(\"neetoPayments.upi.payment.buttons.submit\"),\n disabled: (!dirty && !screenshotFile) || isPending || isUploading,\n loading: isPending || isUploading,\n }}\n />\n </>\n )}\n </Form>\n );\n};\n\nexport default ManualUpiPayment;\n"],"names":["ACCEPTED_SCREENSHOT_FORMATS","MAX_SCREENSHOT_SIZE_MB","DIRECT_UPLOAD_URL","INITIAL_VALUES","identifier","buildValidationSchema","screenshotFile","yup","object","number","typeError","t","entity","nullable","transform","value","originalValue","test","isPresent","isNotPresent","Number","isInteger","length","toString","ManualUpiPayment","fee","payableId","tip","amount","discountCode","customAmount","handleCancel","payableType","onBeforePayment","noop","onFailedPayment","onSuccessfulPayment","useTranslation","fileInputRef","useRef","setScreenshotFile","useState","isUploading","setIsUploading","screenshotPreview","useMemo","URL","createObjectURL","useEffect","revokeObjectURL","vpaIds","pluck","vpas","amountToUpi","isPending","mutate","createPayment","useCreateUpiPayment","onSuccess","onError","validationSchema","handleScreenshotSelect","event","file","target","files","size","Toastr","error","maxSize","handleRemoveScreenshot","current","uploadScreenshot","Promise","resolve","reject","upload","DirectUpload","create","blob","signed_id","handleSubmit","values","paymentScreenshot","tipAttributes","_jsx","Form","className","formikProps","onSubmit","initialValues","children","dirty","_jsxs","_Fragment","Typography","style","count","map","vpaId","QRCodeImage","width","height","getQrCodeValue","Input","label","name","placeholder","type","weight","alt","src","Button","icon","Close","onClick","role","tabIndex","click","onKeyDown","e","key","accept","ref","onChange","ActionBlock","cancelButtonProps","disabled","submitButtonProps","loading"],"mappings":"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"}
@@ -2,7 +2,7 @@ import { useState } from 'react';
2
2
  import { noop, findBy } from 'neetocist';
3
3
  import { mergeLeft } from 'ramda';
4
4
  import { useTranslation } from 'react-i18next';
5
- import { a as useUpdateUpiPayment } from './usePaymentApi-D-8CnzxZ.js';
5
+ import { a as useUpdateUpiPayment } from './usePaymentApi-DHDDzZkq.js';
6
6
  import { Button, Modal, Typography } from '@bigbinary/neetoui';
7
7
  import { Form, Select, Textarea, ActionBlock } from '@bigbinary/neetoui/formik';
8
8
  import { t } from 'i18next';
@@ -11,11 +11,11 @@ import { jsxs, Fragment, jsx } from 'react/jsx-runtime';
11
11
  import '@tanstack/react-query';
12
12
  import 'neetocommons/react-utils';
13
13
  import 'axios';
14
- import './index-DqpYJN4W.js';
14
+ import './index-15RrM-W8.js';
15
15
  import 'neetocommons/constants';
16
16
  import 'decimal.js';
17
17
  import 'neetocommons/utils';
18
- import './queryConstants-C7AqdemO.js';
18
+ import './queryConstants-8c7Nd8ML.js';
19
19
 
20
20
  const INITIAL_VALUE = {
21
21
  vpaId: "",
@@ -1 +1 @@
1
- {"version":3,"file":"ManualUpiPaymentConfirmButton.js","sources":["../app/javascript/src/components/ManualUpiPaymentConfirmButton/constants.js","../app/javascript/src/components/ManualUpiPaymentConfirmButton/index.jsx"],"sourcesContent":["import { t } from \"i18next\";\nimport * as yup from \"yup\";\n\nexport const INITIAL_VALUE = { vpaId: \"\", notes: \"\" };\n\nexport const VALIDATION_SCHEMA = yup.object({\n vpaId: yup\n .string()\n .required(t(\"neetoPayments.upi.confirmModal.vpasIdRequired\")),\n});\n","import { useState } from \"react\";\n\nimport { findBy, noop } from \"neetocist\";\nimport { mergeLeft } from \"ramda\";\nimport { useTranslation } from \"react-i18next\";\n\nimport { useUpdateUpiPayment } from \"hooks/reactQuery/manualUpi/usePaymentApi\";\nimport { Button, Modal, Typography } from \"neetoui\";\nimport { Form, Textarea, Select, ActionBlock } from \"neetoui/formik\";\n\nimport { INITIAL_VALUE, VALIDATION_SCHEMA } from \"./constants\";\n\nconst ManualUpiPaymentConfirmButton = ({\n vpas,\n identifier,\n paymentId,\n manualUpiId,\n payableId,\n onSuccess = noop,\n keysToInvalidate = [],\n children,\n}) => {\n const [isModalOpen, setIsModalOpen] = useState(false);\n\n const { t } = useTranslation();\n\n const onSuccessfulUpdate = () => {\n setIsModalOpen(false);\n onSuccess();\n };\n\n const { mutate: updateUpiPayment, isPending } = useUpdateUpiPayment({\n id: paymentId,\n manualUpiId,\n keysToInvalidate,\n options: { onSuccess: onSuccessfulUpdate },\n });\n\n const initialValues =\n vpas.length === 1\n ? mergeLeft({ vpaId: vpas[0].id }, INITIAL_VALUE)\n : INITIAL_VALUE;\n\n const onClose = () => setIsModalOpen(false);\n\n const handleSubmit = ({ vpaId, notes }) => {\n const vpa = findBy({ id: vpaId }, vpas);\n const payload = {\n notes,\n vpaId,\n payableId,\n upiId: vpa.upiId,\n status: \"successful\",\n };\n updateUpiPayment(payload);\n };\n\n return (\n <>\n <Button\n data-testid=\"confirm-payment-btn\"\n label={t(\"neetoPayments.upi.payment.buttons.confirmPayment\")}\n loading={isPending}\n size=\"small\"\n onClick={() => setIsModalOpen(true)}\n />\n <Modal {...{ onClose }} isOpen={isModalOpen} size=\"large\">\n <Modal.Header>\n <Typography style=\"h2\">\n {t(\"neetoPayments.upi.confirmModal.title\")}\n </Typography>\n </Modal.Header>\n <Form\n formikProps={{\n initialValues,\n enableReinitialize: true,\n onSubmit: handleSubmit,\n validationSchema: VALIDATION_SCHEMA,\n }}\n >\n {({ setFieldValue, dirty, isSubmitting }) => (\n <>\n <Modal.Body>\n {children}\n <div className=\"flex flex-col space-y-4\">\n <Typography lineHeight=\"normal\" style=\"body2\">\n {t(\"neetoPayments.upi.confirmModal.upiTransactionId\", {\n identifier,\n })}\n </Typography>\n <Select\n label={t(\"neetoPayments.upi.confirmModal.accountIdLabel\")}\n name=\"vpaId\"\n options={vpas?.map(({ address, id }) => ({\n label: address,\n value: id,\n }))}\n onChange={({ value }) => setFieldValue(\"vpaId\", value)}\n />\n <Textarea\n data-testid=\"confirm-booking-modal-input-textfield\"\n label={t(\"neetoPayments.upi.confirmModal.notes\")}\n name=\"notes\"\n placeholder={t(\n \"neetoPayments.upi.confirmModal.notesPlaceholder\"\n )}\n />\n </div>\n </Modal.Body>\n <Modal.Footer className=\"space-x-2\">\n <ActionBlock\n isSubmitting={isPending}\n position=\"right\"\n cancelButtonProps={{\n onClick: onClose,\n style: \"tertiary\",\n }}\n submitButtonProps={{\n disabled:\n isSubmitting ||\n isPending ||\n (vpas.length !== 1 && !dirty),\n label: t(\"neetoPayments.common.confirm\"),\n }}\n />\n </Modal.Footer>\n </>\n )}\n </Form>\n </Modal>\n </>\n );\n};\n\nexport default ManualUpiPaymentConfirmButton;\n"],"names":["INITIAL_VALUE","vpaId","notes","VALIDATION_SCHEMA","yup","object","string","required","t","ManualUpiPaymentConfirmButton","vpas","identifier","paymentId","manualUpiId","payableId","onSuccess","noop","keysToInvalidate","children","isModalOpen","setIsModalOpen","useState","useTranslation","onSuccessfulUpdate","mutate","updateUpiPayment","isPending","useUpdateUpiPayment","id","options","initialValues","length","mergeLeft","onClose","handleSubmit","vpa","findBy","payload","upiId","status","_jsxs","_Fragment","_jsx","Button","label","loading","size","onClick","Modal","isOpen","Header","Typography","style","Form","formikProps","enableReinitialize","onSubmit","validationSchema","setFieldValue","dirty","isSubmitting","Body","className","lineHeight","Select","name","map","address","value","onChange","Textarea","placeholder","Footer","ActionBlock","position","cancelButtonProps","submitButtonProps","disabled"],"mappings":"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"}
1
+ {"version":3,"file":"ManualUpiPaymentConfirmButton.js","sources":["../app/javascript/src/components/ManualUpiPaymentConfirmButton/constants.js","../app/javascript/src/components/ManualUpiPaymentConfirmButton/index.jsx"],"sourcesContent":["import { t } from \"i18next\";\nimport * as yup from \"yup\";\n\nexport const INITIAL_VALUE = { vpaId: \"\", notes: \"\" };\n\nexport const VALIDATION_SCHEMA = yup.object({\n vpaId: yup\n .string()\n .required(t(\"neetoPayments.upi.confirmModal.vpasIdRequired\")),\n});\n","import { useState } from \"react\";\n\nimport { findBy, noop } from \"neetocist\";\nimport { mergeLeft } from \"ramda\";\nimport { useTranslation } from \"react-i18next\";\n\nimport { useUpdateUpiPayment } from \"hooks/reactQuery/manualUpi/usePaymentApi\";\nimport { Button, Modal, Typography } from \"neetoui\";\nimport { Form, Textarea, Select, ActionBlock } from \"neetoui/formik\";\n\nimport { INITIAL_VALUE, VALIDATION_SCHEMA } from \"./constants\";\n\nconst ManualUpiPaymentConfirmButton = ({\n vpas,\n identifier,\n paymentId,\n manualUpiId,\n payableId,\n onSuccess = noop,\n keysToInvalidate = [],\n children,\n}) => {\n const [isModalOpen, setIsModalOpen] = useState(false);\n\n const { t } = useTranslation();\n\n const onSuccessfulUpdate = () => {\n setIsModalOpen(false);\n onSuccess();\n };\n\n const { mutate: updateUpiPayment, isPending } = useUpdateUpiPayment({\n id: paymentId,\n manualUpiId,\n keysToInvalidate,\n options: { onSuccess: onSuccessfulUpdate },\n });\n\n const initialValues =\n vpas.length === 1\n ? mergeLeft({ vpaId: vpas[0].id }, INITIAL_VALUE)\n : INITIAL_VALUE;\n\n const onClose = () => setIsModalOpen(false);\n\n const handleSubmit = ({ vpaId, notes }) => {\n const vpa = findBy({ id: vpaId }, vpas);\n const payload = {\n notes,\n vpaId,\n payableId,\n upiId: vpa.upiId,\n status: \"successful\",\n };\n updateUpiPayment(payload);\n };\n\n return (\n <>\n <Button\n data-testid=\"confirm-payment-btn\"\n label={t(\"neetoPayments.upi.payment.buttons.confirmPayment\")}\n loading={isPending}\n size=\"small\"\n onClick={() => setIsModalOpen(true)}\n />\n <Modal {...{ onClose }} isOpen={isModalOpen} size=\"large\">\n <Modal.Header>\n <Typography style=\"h2\">\n {t(\"neetoPayments.upi.confirmModal.title\")}\n </Typography>\n </Modal.Header>\n <Form\n formikProps={{\n initialValues,\n enableReinitialize: true,\n onSubmit: handleSubmit,\n validationSchema: VALIDATION_SCHEMA,\n }}\n >\n {({ setFieldValue, dirty, isSubmitting }) => (\n <>\n <Modal.Body>\n {children}\n <div className=\"flex flex-col space-y-4\">\n <Typography lineHeight=\"normal\" style=\"body2\">\n {t(\"neetoPayments.upi.confirmModal.upiTransactionId\", {\n identifier,\n })}\n </Typography>\n <Select\n label={t(\"neetoPayments.upi.confirmModal.accountIdLabel\")}\n name=\"vpaId\"\n options={vpas?.map(({ address, id }) => ({\n label: address,\n value: id,\n }))}\n onChange={({ value }) => setFieldValue(\"vpaId\", value)}\n />\n <Textarea\n data-testid=\"confirm-booking-modal-input-textfield\"\n label={t(\"neetoPayments.upi.confirmModal.notes\")}\n name=\"notes\"\n placeholder={t(\n \"neetoPayments.upi.confirmModal.notesPlaceholder\"\n )}\n />\n </div>\n </Modal.Body>\n <Modal.Footer className=\"space-x-2\">\n <ActionBlock\n isSubmitting={isPending}\n position=\"right\"\n cancelButtonProps={{\n onClick: onClose,\n style: \"tertiary\",\n }}\n submitButtonProps={{\n disabled:\n isSubmitting ||\n isPending ||\n (vpas.length !== 1 && !dirty),\n label: t(\"neetoPayments.common.confirm\"),\n }}\n />\n </Modal.Footer>\n </>\n )}\n </Form>\n </Modal>\n </>\n );\n};\n\nexport default ManualUpiPaymentConfirmButton;\n"],"names":["INITIAL_VALUE","vpaId","notes","VALIDATION_SCHEMA","yup","object","string","required","t","ManualUpiPaymentConfirmButton","vpas","identifier","paymentId","manualUpiId","payableId","onSuccess","noop","keysToInvalidate","children","isModalOpen","setIsModalOpen","useState","useTranslation","onSuccessfulUpdate","mutate","updateUpiPayment","isPending","useUpdateUpiPayment","id","options","initialValues","length","mergeLeft","onClose","handleSubmit","vpa","findBy","payload","upiId","status","_jsxs","_Fragment","_jsx","Button","label","loading","size","onClick","Modal","isOpen","Header","Typography","style","Form","formikProps","enableReinitialize","onSubmit","validationSchema","setFieldValue","dirty","isSubmitting","Body","className","lineHeight","Select","name","map","address","value","onChange","Textarea","placeholder","Footer","ActionBlock","position","cancelButtonProps","submitButtonProps","disabled"],"mappings":"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"}
@@ -1,20 +1,20 @@
1
1
  import { useState } from 'react';
2
2
  import { noop } from 'neetocist';
3
3
  import { useTranslation } from 'react-i18next';
4
- import { a as useUpdateUpiPayment } from './usePaymentApi-D-8CnzxZ.js';
4
+ import { a as useUpdateUpiPayment } from './usePaymentApi-DHDDzZkq.js';
5
5
  import { Button, Modal, Typography } from '@bigbinary/neetoui';
6
6
  import { Form, Textarea, ActionBlock } from '@bigbinary/neetoui/formik';
7
7
  import { jsxs, Fragment, jsx } from 'react/jsx-runtime';
8
8
  import '@tanstack/react-query';
9
9
  import 'neetocommons/react-utils';
10
10
  import 'axios';
11
- import './index-DqpYJN4W.js';
11
+ import './index-15RrM-W8.js';
12
12
  import 'i18next';
13
13
  import 'neetocommons/constants';
14
14
  import 'decimal.js';
15
15
  import 'neetocommons/utils';
16
16
  import 'ramda';
17
- import './queryConstants-C7AqdemO.js';
17
+ import './queryConstants-8c7Nd8ML.js';
18
18
 
19
19
  const INITIAL_VALUE = {
20
20
  notes: ""
@@ -1 +1 @@
1
- {"version":3,"file":"ManualUpiPaymentRejectButton.js","sources":["../app/javascript/src/components/ManualUpiPaymentRejectButton/constants.js","../app/javascript/src/components/ManualUpiPaymentRejectButton/index.jsx"],"sourcesContent":["export const INITIAL_VALUE = { notes: \"\" };\n","import { useState } from \"react\";\n\nimport { noop } from \"neetocist\";\nimport { useTranslation } from \"react-i18next\";\n\nimport { useUpdateUpiPayment } from \"hooks/reactQuery/manualUpi/usePaymentApi\";\nimport { Button, Modal, Typography } from \"neetoui\";\nimport { Form, Textarea, ActionBlock } from \"neetoui/formik\";\n\nimport { INITIAL_VALUE } from \"./constants\";\n\nconst ManualUpiPaymentRejectButton = ({\n identifier,\n paymentId,\n manualUpiId,\n payableId,\n onSuccess = noop,\n keysToInvalidate = [],\n}) => {\n const [isModalOpen, setIsModalOpen] = useState(false);\n\n const { t } = useTranslation();\n\n const onSuccessfulUpdate = () => {\n setIsModalOpen(false);\n onSuccess();\n };\n\n const { mutate: updateUpiPayment, isPending } = useUpdateUpiPayment({\n id: paymentId,\n manualUpiId,\n keysToInvalidate,\n options: { onSuccess: onSuccessfulUpdate },\n });\n\n const onClose = () => setIsModalOpen(false);\n\n const handleSubmit = ({ notes }) => {\n const payload = { notes, payableId, status: \"rejected\" };\n updateUpiPayment(payload);\n };\n\n return (\n <>\n <Button\n data-testid=\"reject-upi-payment-button\"\n label={t(\"neetoPayments.upi.payment.buttons.rejectPayment\")}\n loading={isPending}\n size=\"small\"\n style=\"danger\"\n onClick={() => setIsModalOpen(true)}\n />\n <Modal {...{ onClose }} isOpen={isModalOpen} size=\"large\">\n <Modal.Header>\n <Typography style=\"h2\">\n {t(\"neetoPayments.upi.rejectModal.title\")}\n </Typography>\n </Modal.Header>\n <Form\n formikProps={{\n initialValues: INITIAL_VALUE,\n enableReinitialize: true,\n onSubmit: handleSubmit,\n }}\n >\n {({ isSubmitting }) => (\n <>\n <Modal.Body>\n <div className=\"flex flex-col space-y-4\">\n <Typography lineHeight=\"normal\" style=\"body2\">\n {t(\"neetoPayments.upi.confirmModal.upiTransactionId\", {\n identifier,\n })}\n </Typography>\n <Textarea\n data-testid=\"reject-booking-modal-input-textfield\"\n label={t(\"neetoPayments.upi.confirmModal.notes\")}\n name=\"notes\"\n placeholder={t(\n \"neetoPayments.upi.confirmModal.notesPlaceholder\"\n )}\n />\n </div>\n </Modal.Body>\n <Modal.Footer className=\"space-x-2\">\n <ActionBlock\n isSubmitting={isPending}\n position=\"right\"\n cancelButtonProps={{\n onClick: onClose,\n style: \"tertiary\",\n }}\n submitButtonProps={{\n disabled: isSubmitting || isPending,\n label: t(\"neetoPayments.common.reject\"),\n style: \"danger\",\n }}\n />\n </Modal.Footer>\n </>\n )}\n </Form>\n </Modal>\n </>\n );\n};\n\nexport default ManualUpiPaymentRejectButton;\n"],"names":["INITIAL_VALUE","notes","ManualUpiPaymentRejectButton","identifier","paymentId","manualUpiId","payableId","onSuccess","noop","keysToInvalidate","isModalOpen","setIsModalOpen","useState","t","useTranslation","onSuccessfulUpdate","mutate","updateUpiPayment","isPending","useUpdateUpiPayment","id","options","onClose","handleSubmit","payload","status","_jsxs","_Fragment","children","_jsx","Button","label","loading","size","style","onClick","Modal","isOpen","Header","Typography","Form","formikProps","initialValues","enableReinitialize","onSubmit","isSubmitting","Body","className","lineHeight","Textarea","name","placeholder","Footer","ActionBlock","position","cancelButtonProps","submitButtonProps","disabled"],"mappings":"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"}
1
+ {"version":3,"file":"ManualUpiPaymentRejectButton.js","sources":["../app/javascript/src/components/ManualUpiPaymentRejectButton/constants.js","../app/javascript/src/components/ManualUpiPaymentRejectButton/index.jsx"],"sourcesContent":["export const INITIAL_VALUE = { notes: \"\" };\n","import { useState } from \"react\";\n\nimport { noop } from \"neetocist\";\nimport { useTranslation } from \"react-i18next\";\n\nimport { useUpdateUpiPayment } from \"hooks/reactQuery/manualUpi/usePaymentApi\";\nimport { Button, Modal, Typography } from \"neetoui\";\nimport { Form, Textarea, ActionBlock } from \"neetoui/formik\";\n\nimport { INITIAL_VALUE } from \"./constants\";\n\nconst ManualUpiPaymentRejectButton = ({\n identifier,\n paymentId,\n manualUpiId,\n payableId,\n onSuccess = noop,\n keysToInvalidate = [],\n}) => {\n const [isModalOpen, setIsModalOpen] = useState(false);\n\n const { t } = useTranslation();\n\n const onSuccessfulUpdate = () => {\n setIsModalOpen(false);\n onSuccess();\n };\n\n const { mutate: updateUpiPayment, isPending } = useUpdateUpiPayment({\n id: paymentId,\n manualUpiId,\n keysToInvalidate,\n options: { onSuccess: onSuccessfulUpdate },\n });\n\n const onClose = () => setIsModalOpen(false);\n\n const handleSubmit = ({ notes }) => {\n const payload = { notes, payableId, status: \"rejected\" };\n updateUpiPayment(payload);\n };\n\n return (\n <>\n <Button\n data-testid=\"reject-upi-payment-button\"\n label={t(\"neetoPayments.upi.payment.buttons.rejectPayment\")}\n loading={isPending}\n size=\"small\"\n style=\"danger\"\n onClick={() => setIsModalOpen(true)}\n />\n <Modal {...{ onClose }} isOpen={isModalOpen} size=\"large\">\n <Modal.Header>\n <Typography style=\"h2\">\n {t(\"neetoPayments.upi.rejectModal.title\")}\n </Typography>\n </Modal.Header>\n <Form\n formikProps={{\n initialValues: INITIAL_VALUE,\n enableReinitialize: true,\n onSubmit: handleSubmit,\n }}\n >\n {({ isSubmitting }) => (\n <>\n <Modal.Body>\n <div className=\"flex flex-col space-y-4\">\n <Typography lineHeight=\"normal\" style=\"body2\">\n {t(\"neetoPayments.upi.confirmModal.upiTransactionId\", {\n identifier,\n })}\n </Typography>\n <Textarea\n data-testid=\"reject-booking-modal-input-textfield\"\n label={t(\"neetoPayments.upi.confirmModal.notes\")}\n name=\"notes\"\n placeholder={t(\n \"neetoPayments.upi.confirmModal.notesPlaceholder\"\n )}\n />\n </div>\n </Modal.Body>\n <Modal.Footer className=\"space-x-2\">\n <ActionBlock\n isSubmitting={isPending}\n position=\"right\"\n cancelButtonProps={{\n onClick: onClose,\n style: \"tertiary\",\n }}\n submitButtonProps={{\n disabled: isSubmitting || isPending,\n label: t(\"neetoPayments.common.reject\"),\n style: \"danger\",\n }}\n />\n </Modal.Footer>\n </>\n )}\n </Form>\n </Modal>\n </>\n );\n};\n\nexport default ManualUpiPaymentRejectButton;\n"],"names":["INITIAL_VALUE","notes","ManualUpiPaymentRejectButton","identifier","paymentId","manualUpiId","payableId","onSuccess","noop","keysToInvalidate","isModalOpen","setIsModalOpen","useState","t","useTranslation","onSuccessfulUpdate","mutate","updateUpiPayment","isPending","useUpdateUpiPayment","id","options","onClose","handleSubmit","payload","status","_jsxs","_Fragment","children","_jsx","Button","label","loading","size","style","onClick","Modal","isOpen","Header","Typography","Form","formikProps","initialValues","enableReinitialize","onSubmit","isSubmitting","Body","className","lineHeight","Textarea","name","placeholder","Footer","ActionBlock","position","cancelButtonProps","submitButtonProps","disabled"],"mappings":";;;;;;;;;;;;;;;;;;AAAO,MAAMA,aAAa,GAAG;AAAEC,EAAAA,KAAK,EAAE;AAAG,CAAC;;ACW1C,MAAMC,4BAA4B,GAAGA,CAAC;EACpCC,UAAU;EACVC,SAAS;EACTC,WAAW;EACXC,SAAS;AACTC,EAAAA,SAAS,GAAGC,IAAI;AAChBC,EAAAA,gBAAgB,GAAG;AACrB,CAAC,KAAK;EACJ,MAAM,CAACC,WAAW,EAAEC,cAAc,CAAC,GAAGC,QAAQ,CAAC,KAAK,CAAC;EAErD,MAAM;AAAEC,IAAAA;GAAG,GAAGC,cAAc,EAAE;EAE9B,MAAMC,kBAAkB,GAAGA,MAAM;IAC/BJ,cAAc,CAAC,KAAK,CAAC;AACrBJ,IAAAA,SAAS,EAAE;EACb,CAAC;EAED,MAAM;AAAES,IAAAA,MAAM,EAAEC,gBAAgB;AAAEC,IAAAA;GAAW,GAAGC,mBAAmB,CAAC;AAClEC,IAAAA,EAAE,EAAEhB,SAAS;IACbC,WAAW;IACXI,gBAAgB;AAChBY,IAAAA,OAAO,EAAE;AAAEd,MAAAA,SAAS,EAAEQ;AAAmB;AAC3C,GAAC,CAAC;AAEF,EAAA,MAAMO,OAAO,GAAGA,MAAMX,cAAc,CAAC,KAAK,CAAC;EAE3C,MAAMY,YAAY,GAAGA,CAAC;AAAEtB,IAAAA;AAAM,GAAC,KAAK;AAClC,IAAA,MAAMuB,OAAO,GAAG;MAAEvB,KAAK;MAAEK,SAAS;AAAEmB,MAAAA,MAAM,EAAE;KAAY;IACxDR,gBAAgB,CAACO,OAAO,CAAC;EAC3B,CAAC;EAED,oBACEE,IAAA,CAAAC,QAAA,EAAA;IAAAC,QAAA,EAAA,cACEC,GAAA,CAACC,MAAM,EAAA;AACL,MAAA,aAAA,EAAY,2BAA2B;AACvCC,MAAAA,KAAK,EAAElB,CAAC,CAAC,iDAAiD,CAAE;AAC5DmB,MAAAA,OAAO,EAAEd,SAAU;AACnBe,MAAAA,IAAI,EAAC,OAAO;AACZC,MAAAA,KAAK,EAAC,QAAQ;AACdC,MAAAA,OAAO,EAAEA,MAAMxB,cAAc,CAAC,IAAI;AAAE,KACrC,CAAC,eACFe,IAAA,CAACU,KAAK,EAAA;MAAOd,OAAO;AAAIe,MAAAA,MAAM,EAAE3B,WAAY;AAACuB,MAAAA,IAAI,EAAC,OAAO;AAAAL,MAAAA,QAAA,EAAA,cACvDC,GAAA,CAACO,KAAK,CAACE,MAAM,EAAA;QAAAV,QAAA,eACXC,GAAA,CAACU,UAAU,EAAA;AAACL,UAAAA,KAAK,EAAC,IAAI;UAAAN,QAAA,EACnBf,CAAC,CAAC,qCAAqC;SAC9B;AAAC,OACD,CAAC,eACfgB,GAAA,CAACW,IAAI,EAAA;AACHC,QAAAA,WAAW,EAAE;AACXC,UAAAA,aAAa,EAAE1C,aAAa;AAC5B2C,UAAAA,kBAAkB,EAAE,IAAI;AACxBC,UAAAA,QAAQ,EAAErB;SACV;AAAAK,QAAAA,QAAA,EAEDA,CAAC;AAAEiB,UAAAA;SAAc,kBAChBnB,IAAA,CAAAC,QAAA,EAAA;AAAAC,UAAAA,QAAA,EAAA,cACEC,GAAA,CAACO,KAAK,CAACU,IAAI,EAAA;AAAAlB,YAAAA,QAAA,eACTF,IAAA,CAAA,KAAA,EAAA;AAAKqB,cAAAA,SAAS,EAAC,yBAAyB;cAAAnB,QAAA,EAAA,cACtCC,GAAA,CAACU,UAAU,EAAA;AAACS,gBAAAA,UAAU,EAAC,QAAQ;AAACd,gBAAAA,KAAK,EAAC,OAAO;AAAAN,gBAAAA,QAAA,EAC1Cf,CAAC,CAAC,iDAAiD,EAAE;AACpDV,kBAAAA;iBACD;AAAC,eACQ,CAAC,eACb0B,GAAA,CAACoB,QAAQ,EAAA;AACP,gBAAA,aAAA,EAAY,sCAAsC;AAClDlB,gBAAAA,KAAK,EAAElB,CAAC,CAAC,sCAAsC,CAAE;AACjDqC,gBAAAA,IAAI,EAAC,OAAO;gBACZC,WAAW,EAAEtC,CAAC,CACZ,iDACF;AAAE,eACH,CAAC;aACC;AAAC,WACI,CAAC,eACbgB,GAAA,CAACO,KAAK,CAACgB,MAAM,EAAA;AAACL,YAAAA,SAAS,EAAC,WAAW;YAAAnB,QAAA,eACjCC,GAAA,CAACwB,WAAW,EAAA;AACVR,cAAAA,YAAY,EAAE3B,SAAU;AACxBoC,cAAAA,QAAQ,EAAC,OAAO;AAChBC,cAAAA,iBAAiB,EAAE;AACjBpB,gBAAAA,OAAO,EAAEb,OAAO;AAChBY,gBAAAA,KAAK,EAAE;eACP;AACFsB,cAAAA,iBAAiB,EAAE;gBACjBC,QAAQ,EAAEZ,YAAY,IAAI3B,SAAS;AACnCa,gBAAAA,KAAK,EAAElB,CAAC,CAAC,6BAA6B,CAAC;AACvCqB,gBAAAA,KAAK,EAAE;AACT;aACD;AAAC,WACU,CAAC;SACf;AACH,OACG,CAAC;AAAA,KACF,CAAC;AAAA,GACR,CAAC;AAEP;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"PaymentKindRestrictionAlert.js","sources":["../app/javascript/src/components/PaymentKindRestrictionAlert/constants.js","../app/javascript/src/components/PaymentKindRestrictionAlert/index.jsx"],"sourcesContent":["import { t } from \"i18next\";\n\nexport const STRIPE_ALERT_PAYMENT_KIND_CONTENT = {\n standard: {\n title: t(\"neetoPayments.alert.stripe.connectRestrictionTitle\"),\n message: t(\"neetoPayments.alert.stripe.connectRestrictionMessage\"),\n },\n platform: {\n title: t(\"neetoPayments.alert.stripePlatform.connectRestrictionTitle\"),\n message: t(\"neetoPayments.alert.stripePlatform.connectRestrictionMessage\"),\n },\n};\n","import { noop } from \"neetocist\";\nimport { Alert } from \"neetoui\";\n\nimport { STRIPE_ALERT_PAYMENT_KIND_CONTENT } from \"./constants\";\n\nconst PaymentKindRestrictionAlert = ({\n isOpen = false,\n paymentKind = \"standard\",\n onClose = noop,\n ...otherProps\n}) => (\n <Alert\n {...{ isOpen, onClose }}\n message={STRIPE_ALERT_PAYMENT_KIND_CONTENT[paymentKind].message}\n title={STRIPE_ALERT_PAYMENT_KIND_CONTENT[paymentKind].title}\n {...otherProps}\n />\n);\n\nexport default PaymentKindRestrictionAlert;\n"],"names":["STRIPE_ALERT_PAYMENT_KIND_CONTENT","standard","title","t","message","platform","PaymentKindRestrictionAlert","isOpen","paymentKind","onClose","noop","otherProps","_jsx","Alert"],"mappings":";;;;;AAEO,MAAMA,iCAAiC,GAAG;AAC/CC,EAAAA,QAAQ,EAAE;AACRC,IAAAA,KAAK,EAAEC,CAAC,CAAC,oDAAoD,CAAC;IAC9DC,OAAO,EAAED,CAAC,CAAC,sDAAsD;GAClE;AACDE,EAAAA,QAAQ,EAAE;AACRH,IAAAA,KAAK,EAAEC,CAAC,CAAC,4DAA4D,CAAC;IACtEC,OAAO,EAAED,CAAC,CAAC,8DAA8D;AAC3E;AACF,CAAC;;ACNKG,MAAAA,2BAA2B,GAAGA,CAAC;AACnCC,EAAAA,MAAM,GAAG,KAAK;AACdC,EAAAA,WAAW,GAAG,UAAU;AACxBC,EAAAA,OAAO,GAAGC,IAAI;EACd,GAAGC;AACL,CAAC,kBACCC,GAAA,CAACC,KAAK,EAAA;EACEN,MAAM;EAAEE,OAAO;AACrBL,EAAAA,OAAO,EAAEJ,iCAAiC,CAACQ,WAAW,CAAC,CAACJ,OAAQ;AAChEF,EAAAA,KAAK,EAAEF,iCAAiC,CAACQ,WAAW,CAAC,CAACN,KAAM;EAAA,GACxDS;AAAU,CACf;;;;"}
1
+ {"version":3,"file":"PaymentKindRestrictionAlert.js","sources":["../app/javascript/src/components/PaymentKindRestrictionAlert/constants.js","../app/javascript/src/components/PaymentKindRestrictionAlert/index.jsx"],"sourcesContent":["import { t } from \"i18next\";\n\nexport const STRIPE_ALERT_PAYMENT_KIND_CONTENT = {\n standard: {\n title: t(\"neetoPayments.alert.stripe.connectRestrictionTitle\"),\n message: t(\"neetoPayments.alert.stripe.connectRestrictionMessage\"),\n },\n platform: {\n title: t(\"neetoPayments.alert.stripePlatform.connectRestrictionTitle\"),\n message: t(\"neetoPayments.alert.stripePlatform.connectRestrictionMessage\"),\n },\n};\n","import { noop } from \"neetocist\";\nimport { Alert } from \"neetoui\";\n\nimport { STRIPE_ALERT_PAYMENT_KIND_CONTENT } from \"./constants\";\n\nconst PaymentKindRestrictionAlert = ({\n isOpen = false,\n paymentKind = \"standard\",\n onClose = noop,\n ...otherProps\n}) => (\n <Alert\n {...{ isOpen, onClose }}\n message={STRIPE_ALERT_PAYMENT_KIND_CONTENT[paymentKind].message}\n title={STRIPE_ALERT_PAYMENT_KIND_CONTENT[paymentKind].title}\n {...otherProps}\n />\n);\n\nexport default PaymentKindRestrictionAlert;\n"],"names":["STRIPE_ALERT_PAYMENT_KIND_CONTENT","standard","title","t","message","platform","PaymentKindRestrictionAlert","isOpen","paymentKind","onClose","noop","otherProps","_jsx","Alert"],"mappings":";;;;;AAEO,MAAMA,iCAAiC,GAAG;AAC/CC,EAAAA,QAAQ,EAAE;AACRC,IAAAA,KAAK,EAAEC,CAAC,CAAC,oDAAoD,CAAC;IAC9DC,OAAO,EAAED,CAAC,CAAC,sDAAsD;GAClE;AACDE,EAAAA,QAAQ,EAAE;AACRH,IAAAA,KAAK,EAAEC,CAAC,CAAC,4DAA4D,CAAC;IACtEC,OAAO,EAAED,CAAC,CAAC,8DAA8D;AAC3E;AACF,CAAC;;ACND,MAAMG,2BAA2B,GAAGA,CAAC;AACnCC,EAAAA,MAAM,GAAG,KAAK;AACdC,EAAAA,WAAW,GAAG,UAAU;AACxBC,EAAAA,OAAO,GAAGC,IAAI;EACd,GAAGC;AACL,CAAC,kBACCC,GAAA,CAACC,KAAK,EAAA;EACEN,MAAM;EAAEE,OAAO;AACrBL,EAAAA,OAAO,EAAEJ,iCAAiC,CAACQ,WAAW,CAAC,CAACJ,OAAQ;AAChEF,EAAAA,KAAK,EAAEF,iCAAiC,CAACQ,WAAW,CAAC,CAACN,KAAM;EAAA,GACxDS;AAAU,CACf;;;;"}
@@ -1,24 +1,24 @@
1
1
  import { useMemo, useCallback, useState, startTransition, useEffect } from 'react';
2
- import { DEFAULT_PAGE_INDEX, DEFAULT_PAGE_SIZE } from 'neetocommons/constants';
2
+ import { DEFAULT_PAGE_SIZE, DEFAULT_PAGE_INDEX } from 'neetocommons/constants';
3
3
  import { getQueryParams, buildUrl } from 'neetocommons/utils';
4
4
  import { Bar, buildFiltersFromURL } from '@bigbinary/neeto-filters-frontend';
5
5
  import { Typography, Tooltip, Tag, Button, NoData, Table, Tab, Spinner } from '@bigbinary/neetoui';
6
- import { map, curry, concat, mergeDeepWith, mergeLeft, reject, isNil, prop, isEmpty, modify } from 'ramda';
6
+ import { map, curry, concat, reject, isNil, prop, mergeDeepWith, mergeLeft, isEmpty, modify } from 'ramda';
7
7
  import { useHistory } from 'react-router-dom';
8
- import { E as ExportModal } from './ExportModal-KInsxpSb.js';
8
+ import { E as ExportModal } from './ExportModal-ubjATdMC.js';
9
9
  import { useQuery } from '@tanstack/react-query';
10
10
  import axios from 'axios';
11
- import { B as BASE_URL, P as PAYMENT_PROVIDERS, j as DEFAULT_TAG_STYLE, l as formatAmount, m as formatCurrency, n as getUniquePaymentProviders, o as buildDefaultTableColumns, p as processDataIndex, S as SORT_DIRECTIONS, s as shouldTabsVisible, U as UN_HIDEABLE_COLUMNS, i as DEFAULT_PAGE_VALUES, q as DASHBOARD_KIND } from './index-DqpYJN4W.js';
12
- import { Q as QUERY_KEYS } from './queryConstants-C7AqdemO.js';
13
- import { m as mergeEnforcedFilters } from './dashboard-Cr6UEj9o.js';
11
+ import { B as BASE_URL, P as PAYMENT_PROVIDERS, j as DEFAULT_TAG_STYLE, l as formatAmount, m as formatCurrency, n as getUniquePaymentProviders, o as buildDefaultTableColumns, p as processDataIndex, S as SORT_DIRECTIONS, s as shouldTabsVisible, U as UN_HIDEABLE_COLUMNS, i as DEFAULT_PAGE_VALUES, q as DASHBOARD_KIND } from './index-15RrM-W8.js';
12
+ import { Q as QUERY_KEYS } from './queryConstants-8c7Nd8ML.js';
13
+ import { m as mergeEnforcedFilters } from './dashboard-CZOZ1Oxi.js';
14
14
  import { t } from 'i18next';
15
- import { toLabelAndValue, isNotPresent, snakeToCamelCase, humanize, isPresent, camelToSnakeCase } from 'neetocist';
15
+ import { toLabelAndValue, isNotPresent, humanize, snakeToCamelCase, isPresent, camelToSnakeCase } from 'neetocist';
16
16
  import { useTableConfigurations } from '@bigbinary/neeto-molecules/Columns';
17
17
  import TableWrapper from '@bigbinary/neeto-molecules/TableWrapper';
18
18
  import { useTranslation } from 'react-i18next';
19
19
  import { T as TABLE_KEYS } from './exportChannel-Db0U5gc1.js';
20
20
  import DateFormat from '@bigbinary/neeto-molecules/DateFormat';
21
- import { C as CopyButtonWrapper } from './CopyButtonWrapper-Bp5IVO76.js';
21
+ import { C as CopyButtonWrapper } from './CopyButtonWrapper-DkI2F6Ty.js';
22
22
  import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
23
23
  import Header from '@bigbinary/neeto-molecules/Header';
24
24
  import SubHeader from '@bigbinary/neeto-molecules/SubHeader';
@@ -96,7 +96,8 @@ const DEFAULT_SORT_PROPERTIES = {
96
96
  };
97
97
 
98
98
  const renderIdentifier = (identifier, {
99
- receiptUrl
99
+ receiptUrl,
100
+ paymentScreenshotUrl
100
101
  }) => {
101
102
  const isTemporaryIdentifier = identifier?.startsWith("temp_");
102
103
  if (isTemporaryIdentifier) {
@@ -112,6 +113,19 @@ const renderIdentifier = (identifier, {
112
113
  })
113
114
  });
114
115
  }
116
+ if (isNotPresent(identifier) && isPresent(paymentScreenshotUrl)) {
117
+ return /*#__PURE__*/jsx(Tooltip, {
118
+ content: t("neetoPayments.tooltipContent.screenshotUploadedByCustomer"),
119
+ position: "top",
120
+ children: /*#__PURE__*/jsx("div", {
121
+ className: "text-center",
122
+ children: /*#__PURE__*/jsx(Typography, {
123
+ style: "body2",
124
+ children: "-"
125
+ })
126
+ })
127
+ });
128
+ }
115
129
  return /*#__PURE__*/jsx(CopyButtonWrapper, {
116
130
  content: identifier,
117
131
  children: /*#__PURE__*/jsx(Button, {
@@ -318,7 +332,6 @@ const List = ({
318
332
  const defaultColumns = useMemo(() => getDefaultColumns(dashboardKind), [dashboardKind]);
319
333
  const allColumns = useMemo(() => buildDefaultTableColumns({
320
334
  payableEntityColumns,
321
- isMultipleProvidersExist,
322
335
  defaultColumns,
323
336
  isAllTab: tab === PAYMENT_DASHBOARD_TAB.all
324
337
  }), [payableEntityColumns, isMultipleProvidersExist, defaultColumns, tab]);
@@ -335,9 +348,7 @@ const List = ({
335
348
  }, [setSortProperties]);
336
349
  const rowData = useMemo(() => buildRowData({
337
350
  payments,
338
- pageProperties,
339
- tab
340
- }), [payments, pageProperties, tab]);
351
+ pageProperties}), [payments, pageProperties, tab]);
341
352
  if (isNotPresent(payments)) {
342
353
  return /*#__PURE__*/jsx("div", {
343
354
  className: "flex h-full w-full items-center justify-center",