From fc0c44a84feab91df136f3d123352711dc83aef1 Mon Sep 17 00:00:00 2001 From: Joel Jeremy Marquez Date: Fri, 5 Apr 2024 10:42:04 -0700 Subject: [PATCH 1/2] [Maintenance] Update onEdit to use serialized transactions --- .../mobile/transactions/TransactionEdit.jsx | 66 ++++++------------- 1 file changed, 19 insertions(+), 47 deletions(-) diff --git a/packages/desktop-client/src/components/mobile/transactions/TransactionEdit.jsx b/packages/desktop-client/src/components/mobile/transactions/TransactionEdit.jsx index 98b02cd0e9e..42be12c67ea 100644 --- a/packages/desktop-client/src/components/mobile/transactions/TransactionEdit.jsx +++ b/packages/desktop-client/src/components/mobile/transactions/TransactionEdit.jsx @@ -495,10 +495,10 @@ const TransactionEditInner = memo(function TransactionEditInner({ }; const onSave = async () => { - const [transaction] = unserializedTransactions; + const [unserializedTransaction] = unserializedTransactions; const onConfirmSave = async () => { - const { account: accountId } = transaction; + const { account: accountId } = unserializedTransaction; const account = accountsById[accountId]; if (unserializedTransactions.find(t => t.account == null)) { @@ -516,7 +516,7 @@ const TransactionEditInner = memo(function TransactionEditInner({ navigate(`/accounts/${account.id}`, { replace: true }); }; - if (transaction.reconciled) { + if (unserializedTransaction.reconciled) { // On mobile any save gives the warning. // On the web only certain changes trigger a warning. // Should we bring that here as well? Or does the nature of the editing form @@ -536,31 +536,22 @@ const TransactionEditInner = memo(function TransactionEditInner({ onSave(); }; - const onEdit = async (transaction, name, value) => { - const newTransaction = { ...transaction, [name]: value }; + const onEdit = async (serializedTransaction, name, value) => { + const newTransaction = { ...serializedTransaction, [name]: value }; await props.onEdit(newTransaction); onClearActiveEdit(); }; const onClick = (transactionId, name) => { onRequestActiveEdit?.(getFieldName(transaction.id, name), () => { - const transaction = unserializedTransactions.find( - t => t.id === transactionId, - ); + const transactionToEdit = transactions.find(t => t.id === transactionId); switch (name) { case 'category': dispatch( pushModal('category-autocomplete', { categoryGroups, onSelect: categoryId => { - // This is a deficiency of this API, need to fix. It - // assumes that it receives a serialized transaction, - // but we only have access to the raw transaction - onEdit( - serializeTransaction(transaction, dateFormat), - name, - categoryId, - ); + onEdit(transactionToEdit, name, categoryId); }, onClose: () => { onClearActiveEdit(); @@ -572,14 +563,7 @@ const TransactionEditInner = memo(function TransactionEditInner({ dispatch( pushModal('account-autocomplete', { onSelect: accountId => { - // This is a deficiency of this API, need to fix. It - // assumes that it receives a serialized transaction, - // but we only have access to the raw transaction - onEdit( - serializeTransaction(transaction, dateFormat), - name, - accountId, - ); + onEdit(transactionToEdit, name, accountId); }, onClose: () => { onClearActiveEdit(); @@ -591,14 +575,7 @@ const TransactionEditInner = memo(function TransactionEditInner({ dispatch( pushModal('payee-autocomplete', { onSelect: payeeId => { - // This is a deficiency of this API, need to fix. It - // assumes that it receives a serialized transaction, - // but we only have access to the raw transaction - onEdit( - serializeTransaction(transaction, dateFormat), - name, - payeeId, - ); + onEdit(transactionToEdit, name, payeeId); }, onClose: () => { onClearActiveEdit(); @@ -611,14 +588,7 @@ const TransactionEditInner = memo(function TransactionEditInner({ pushModal('edit-field', { name, onSubmit: (name, value) => { - // This is a deficiency of this API, need to fix. It - // assumes that it receives a serialized transaction, - // but we only have access to the raw transaction - onEdit( - serializeTransaction(transaction, dateFormat), - name, - value, - ); + onEdit(transactionToEdit, name, value); }, onClose: () => { onClearActiveEdit(); @@ -631,18 +601,18 @@ const TransactionEditInner = memo(function TransactionEditInner({ }; const onDelete = id => { - const [transaction, ..._childTransactions] = unserializedTransactions; + const [unserializedTransaction] = unserializedTransactions; const onConfirmDelete = () => { props.onDelete(id); - if (transaction.id !== id) { + if (unserializedTransaction.id !== id) { // Only a child transaction was deleted. onClearActiveEdit(); return; } - const { account: accountId } = transaction; + const { account: accountId } = unserializedTransaction; if (accountId) { navigate(`/accounts/${accountId}`, { replace: true }); } else { @@ -650,7 +620,7 @@ const TransactionEditInner = memo(function TransactionEditInner({ } }; - if (transaction.reconciled) { + if (unserializedTransaction.reconciled) { dispatch( pushModal('confirm-transaction-edit', { onConfirm: onConfirmDelete, @@ -683,9 +653,11 @@ const TransactionEditInner = memo(function TransactionEditInner({ }; useEffect(() => { - const noAmountTransaction = childTransactions.find(t => t.amount === 0); - if (noAmountTransaction) { - scrollChildTransactionIntoView(noAmountTransaction.id); + const noAmountChildTransaction = childTransactions.find( + t => t.amount === 0, + ); + if (noAmountChildTransaction) { + scrollChildTransactionIntoView(noAmountChildTransaction.id); } }, [childTransactions]); From 9c8e372a587dad1f1dbea8026988abd58f510fad Mon Sep 17 00:00:00 2001 From: Joel Jeremy Marquez Date: Fri, 5 Apr 2024 10:43:43 -0700 Subject: [PATCH 2/2] Release notes --- upcoming-release-notes/2555.md | 6 ++++++ 1 file changed, 6 insertions(+) create mode 100644 upcoming-release-notes/2555.md diff --git a/upcoming-release-notes/2555.md b/upcoming-release-notes/2555.md new file mode 100644 index 00000000000..49af4a717b6 --- /dev/null +++ b/upcoming-release-notes/2555.md @@ -0,0 +1,6 @@ +--- +category: Maintenance +authors: [joel-jeremy] +--- + +Update TransactionEdit component onEdit function to use serialized transactions.