mirror of
https://github.com/actualbudget/actual.git
synced 2026-03-10 20:23:07 -05:00
[Bug]: Merging transactions does not prevent reimport as duplicate #2827
Open
opened 2026-02-28 20:29:44 -06:00 by GiteaMirror
·
5 comments
No Branch/Tag Specified
master
matiss/oxlint-no-floating-promises-require-array-sort-compare
ai/custom-theme-dual-prefs
claude/fix-simplefin-batch-sync-O8LcD
matiss/fix-6804
claude/fix-simplefin-ssrf-T31gX
claude/release-notes-validation-X7rvR
add-claude-github-actions-1772738270730
react-query-rules
react-query-useSchedules
matiss/separate-lint-format
dependabot/npm_and_yarn/ajv-6.14.0
cursor/sync-performance-notification-9899
react-query-prefs
matiss/chunked-sync-and-progress-ux
v26.2.1
copilot/sub-pr-6880
fix-react-query-clear-on-close-budget
copilot/sub-pr-6140
feat/auto-note
feat/scoped-bank-sync
cursor/desktop-transactions-react-table-1d0c
fix-exhaustive-deps-App
copilot/fix-find-replace-bug
release/v26.2.0-pre
matiss/browser-tests
mobile-fix-drag-and-drop-across-groups
budget-table-v2
PayeeAutocomplete2
pglite
bugfix/plugins/fix-plugins-sw
feat/plugins/plugins-core-package
prerelease
matiss/unicode-minus-fix
cursor/fix-actual-github-issue-6206-gemini-3-pro-preview-9c37
TransactionFormPage
cursor/implement-mortgage-and-loan-account-type-78ca
tests-update-fill-with-pressSequentially
mobile/link-modal
deps/25.11
cursor/fix-update-vrt-apply-ci-job-dispatch-b324
sync-server-plugins
cursor/propose-patch-for-github-issue-5680-2a18
fix/compiler-preserve-inner-dollar-escapes
cursor/analyze-actual-budget-issue-and-propose-fix-5b70
coderabbitai/docstrings/0c070e5
cursor/add-wip-prefix-and-comment-to-prs-d78d
jfdoming/08-21-auto-focus-on-navigate-in-all-browsers
show-totals-on-mobile-budget-banners
allow-child-transactions-make-transfer
mobile-calculator-keyboard
payee-geolocation
enhance/restore_scroll_position
dm-fix-second-click-on-mobile-new-transaction-2
scrollToLocationBudget
alert-autofix-38
tsconfig-composite
mobile-fix-uncategorized-transactions-on-tracking-budgets
server-budget-handlers
fix-sql-injection-in-cleanup-template
non-chrome-draggable-workaround
mobile-budget-page-swipe-navigation
ts-db-all
stable
dark-theme-with-brand-colors
fix-mobile-delete-group
ts-db-select
UnderKoen/reconcile-context-menu
master-before-server-merge
v25.2.1
ts-runQuery
rename-redux-hooks
UnderKoen/3557-persist-state-in-history
remove-redux-CLOSE_BUDGET
fix-exhaustive-deps-errors-FinancesApp
redux-toolkit-createSlice-backup
accounts-function-component
ts-useSplitsExpanded
loot-core-server-package
useTransactios-in-TransactionEdit
react-aria-input
move-redux-to-desktop-client
QueryState-type
fix-themes-applied-late
mobile-vrts
revert-3295-spendingCardFix
react-aria-button-4
split-payee-on-mobile
twk3/pin-apis-crdt
notes-tag-autocomplete
ts-LoadBackup
dnd-kit
package-upgrades
v26.3.0
v26.2.1
v26.2.0
v26.1.0
v25.12.0
v25.11.0
v25.10.0
v25.9.0
v25.8.0
v25.7.1
v25.7.0
v25.6.1
v25.6.0
v25.5.0
v25.4.0
v25.3.1
v25.3.0
v25.2.1
v25.2.0
v25.1.0
v24.12.0
v24.11.0
v24.10.1
v24.10.0
v24.9.0
v24.8.0
v24.7.0
v24.6.0
v24.5.0
v24.4.0
v24.3.0
v24.2.0
v24.1.0
v23.12.0
v23.11.0
v23.10.0
v23.9.0
v23.8.1
v23.8.0
v23.7.2
v23.7.1
v23.7.0
v23.6.0
v23.5.0
v23.4.2
v23.4.1
v23.4.0
v23.3.2
v23.3.0
v23.2.9
v23.2.5
v23.1.12
v22.12.9
Labels
Clear labels
AI generated
API
bank sync
budgeting
bug
can’t replicate
dependencies
docker
documentation
electron
experimental feature
feature
feedback
goal templates
good first issue
help wanted
importers
maintenance
needs info
needs testing
needs triage
needs votes
openid
payees
pull-request
regression
reports
responsive
rules
schedules
server
✨ merged
split transactions
tech debt
theme
transaction import
transaction reconciliation
transactions
translations
upstream
user interface
✅ approved
wontfix
Mirrored from GitHub Pull Request
Milestone
No items
No Milestone
Projects
Clear projects
No project
No Assignees
Notifications
Due Date
No due date set.
Dependencies
No dependencies set.
Reference: github-starred/actual#2827
Reference in New Issue
Block a user
Blocking a user prevents them from interacting with repositories, such as opening or commenting on pull requests or issues. Learn more about blocking a user.
Delete Branch "%!s()"
Deleting a branch is permanent. Although the deleted branch may continue to exist for a short time before it actually gets removed, it CANNOT be undone in most cases. Continue?
Originally created by @junalmeida on GitHub (Jan 16, 2026).
Verified issue does not already exist?
What happened?
If I have a duplicated transaction imported via Actual API, given one of them is already marked as a transfer, if I merge the duplicated with the transfer one, once I reimport it duplicates again.
It seems like Actual does not save the
imported_idwhen a merge operation happens, allowing it to come back.How can we reproduce the issue?
Simulating a day 1 import: have a transaction imported with
imported_idset to1234.On the UI, mark it as a transfer to another account.
On day 2, have the same transaction above reimported now with
imported_id=12345, with the same amount. Date posted could be different.See the duplicated transaction on the UI, merge it with the first one that is already a transfer.
Import the day 2 again - same transaction with
imported_id=12345See the duplicated transaction coming back instead of being ignored because it was merged.
test-day1.txt
test-day2.txt
Where are you hosting Actual?
Docker
What browsers are you seeing the problem on?
Chrome
Operating System
Linux
@totallynotjon commented on GitHub (Jan 17, 2026):
I am encountering a similar issue, which I would venture is related. Occasionally, using bank sync, tranfers won't properly deduplicate when changing payees with rules . Merging the transfers won't stick and the import/resync will recreate the duplicate. I am going to take a looksy and will update if I think I can make the merge stick
@totallynotjon commented on GitHub (Jan 17, 2026):
@junalmeida, as a workaround, you can likely disable the setting "Reimport deleted transactions" within bank sync settings, if you are close to reconciled.
Since the merged item is "deleted", if you do this then on re-sync or reimport the item shouldn't be brought in again. This approach also fixed my issue.
Though I do see this as a potential issue with local accounts that do not have a bank sync.
For a local account, I was able to link a bank sync to an unrelated account, toggle the setting, and then unlink the account. After this the preference to not Reimport deleted transactions stuck for file import.
This is cumbersome, and there should probably be some change to make this easier to manage for local accounts.
Separately, while this workaround address this issue for me. I can see the upside in having a separate mechanism to track merged transactions beyond standard delete 'tombstone' column. As surely some people won't want no-reimport enabled for bank sync accounts, and will want their merges to stick.
@junalmeida commented on GitHub (Jan 20, 2026):
@totallynotjon I'm not using bank sync, I don't have it to enable this UI I guess
@totallynotjon commented on GitHub (Feb 10, 2026):
@junalmeida try out the pr I linked and let me know if that doesn't address your issue.
@junalmeida commented on GitHub (Feb 20, 2026):
@totallynotjon I just tested the DEMO of your PR and it seems the setting in the import dialog box works as expected.