From 9492d49f3188eec079e9def528134c3be07a941b Mon Sep 17 00:00:00 2001 From: SebinSong Date: Thu, 26 Oct 2023 12:36:07 +0900 Subject: [PATCH 1/2] correct the check for payment status --- frontend/views/containers/payments/RecordPayment.vue | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/frontend/views/containers/payments/RecordPayment.vue b/frontend/views/containers/payments/RecordPayment.vue index 9bff51d256..5c8b0744d9 100644 --- a/frontend/views/containers/payments/RecordPayment.vue +++ b/frontend/views/containers/payments/RecordPayment.vue @@ -131,7 +131,7 @@ export default ({ ]), paymentsList () { return this.todoItems.map(item => { - return item.status === PAYMENT_NOT_RECEIVED // if not received item, re-format the obj + return item.data && item.data.status === PAYMENT_NOT_RECEIVED // if not received item, re-format the obj ? { hash: item.hash, data: item.data, From d28dbb0aa6f496424a18d16b60b2cc8b7370112a Mon Sep 17 00:00:00 2001 From: SebinSong Date: Wed, 8 Nov 2023 13:09:18 +0900 Subject: [PATCH 2/2] fix the issue where dismissing payment works incorrectly --- .../containers/payments/RecordPayment.vue | 51 ++++++++++++------- 1 file changed, 34 insertions(+), 17 deletions(-) diff --git a/frontend/views/containers/payments/RecordPayment.vue b/frontend/views/containers/payments/RecordPayment.vue index 5c8b0744d9..1e15635505 100644 --- a/frontend/views/containers/payments/RecordPayment.vue +++ b/frontend/views/containers/payments/RecordPayment.vue @@ -136,11 +136,11 @@ export default ({ hash: item.hash, data: item.data, meta: item.meta, - username: item.toUser, - displayName: this.userDisplayName(item.toUser), + username: item.data.toUser, + displayName: this.userDisplayName(item.data.toUser), date: item.meta.createdDate, - monthstamp: dateToMonthstamp(item.createdDate), - amount: item.amount + monthstamp: dateToMonthstamp(item.meta.createdDate), + amount: item.data.amount } : item }) @@ -172,6 +172,7 @@ export default ({ for (const pRecord of paymentsToRecord) { const payment = this.paymentsList[pRecord.index] + const isStatusNotReceived = payment.data && payment.data.status === PAYMENT_NOT_RECEIVED if (pRecord.amount > payment.amount) { // TODO/REVIEW - Should we show a warning? @@ -199,20 +200,36 @@ export default ({ paymentType: PAYMENT_TYPE_MANUAL, ...(memo ? { memo } : {}) // TODO/BUG with flowTyper validation. Empty string '' fails. } - const msg = await sbp('gi.actions/group/payment', { - contractID: this.currentGroupId, data: paymentInfo - }) - // TODO: hack until /payment supports sending completed payment - // (and "uncompleting" a payment) - await sbp('gi.actions/group/paymentUpdate', { - contractID: this.currentGroupId, - data: { - paymentHash: msg.hash(), - updatedProperties: { - status: PAYMENT_COMPLETED + + if (isStatusNotReceived) { + // If it's re-sending the payment that has been marked as 'not-recieved' by the receiver, + // only update the details of the existing payment item so that it doesn't lead to duplication bug in the payment UI. + await sbp('gi.actions/group/paymentUpdate', { + contractID: this.currentGroupId, + data: { + paymentHash: payment.hash, + updatedProperties: { + ...paymentInfo, + status: PAYMENT_COMPLETED + } } - } - }) + }) + } else { + const msg = await sbp('gi.actions/group/payment', { + contractID: this.currentGroupId, data: paymentInfo + }) + // TODO: hack until /payment supports sending completed payment + // (and "uncompleting" a payment) + await sbp('gi.actions/group/paymentUpdate', { + contractID: this.currentGroupId, + data: { + paymentHash: msg.hash(), + updatedProperties: { + status: PAYMENT_COMPLETED + } + } + }) + } } catch (e) { hasError = true console.error('RecordPayment submit() error:', e)