mirror of
https://github.com/actualbudget/actual.git
synced 2026-05-05 22:52:20 -05:00
[GH-ISSUE #6997] [Bug]: Linking or merging manual and scheduled transactions results in duplicates and incorrect “Due” status #9876
Open
opened 2026-04-10 20:13:01 -05:00 by GiteaMirror
·
7 comments
No Branch/Tag Specified
master
claude/hide-default-categories-1cwBZ
matiss/crdt-source-loading
youngcw/unlock-duplicates
matiss/crdt-protobuf
release/26.5.0
claude/update-issue-template-ykMNn
claude/fix-issue-7667-DPXi3
cursor/formula-feedback-improvements-4223
cursor/resolve-pr-7449-ee11
claude/fix-typescript-build-error-JPtZ5
jfdoming/api-tokens-part-3
jfdoming/api-tokens-part-2
jfdoming/api-tokens-part-1
claude/speed-up-vrt-workflow-ZAyI5
claude/crdt-version-auto-publish-Ph1BH
copilot/add-repository-configs-to-packages
worktree-compressed-drifting-ritchie
worktree-mellow-strolling-dawn
matiss/browser-api
claude/api-consumer-verification-kfz1K
feature/enable-banking
cursor/transaction-table-rewrite-f077
pr-7454
claude/fix-issue-7410-LLLQ4
release/v100.0.0
revert-7350-trim-deps
revert-7220-sankey-report
revert-7242-fix/split-parent-update-corruption
revert-7281-generate-icons
claude/electron-to-tauri-migration-LjBN8
worktree-remotion
release/vv26.4.0-pre
claude/browser-compatible-api-QbhHh
claude/improve-cli-transactions-waTUY
claude/publish-react-native-ios-j8qoT
js-proxy
claude/fix-flaky-ci-job-5gDdz
react-query-rules
react-query-useSchedules
claude/nightly-theme-validation-scan-DzOGD
claude/debug-simplefin-error-ZuKzB
matiss/desktop-client-subpath-imports
claude/fix-simplefin-ssrf-T31gX
claude/release-notes-validation-X7rvR
add-claude-github-actions-1772738270730
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.5.0
v26.4.0
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#9876
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 @jeremyj on GitHub (Feb 16, 2026).
Original GitHub issue: https://github.com/actualbudget/actual/issues/6997
What happened?
What happened?
I was trying to reconcile a manually added transaction with an automatically created scheduled transaction for the same payment.
Expected behavior:
Linking or merging the two should result in a single transaction associated with the schedule.
Actual behavior:
Two transactions remain:
If I link the manual transaction to the scheduled one → I end up with two transactions instead of one.
If I merge them → the automatically created scheduled transaction is marked as “Due”, and there are still two transactions present.
This makes it unclear which transaction is the correct one and breaks the expected reconciliation workflow.
How can we reproduce the issue?
How can we reproduce the issue?
Create a scheduled transaction that is automatically added to the ledger.
Manually add a transaction representing the same payment.
Attempt to reconcile them:
Option A: Link the manual transaction to the scheduled transaction.
Option B: Merge the two transactions.
Observe the results.
Expected:
A single transaction remains, correctly associated with the schedule and marked as Paid
.
Actual:
Two transactions remain. In the merge case, the scheduled one is also marked as Due.
Where are you hosting Actual?
Docker
What browsers are you seeing the problem on?
Chrome
Operating System
Linux
@RegalMonkey commented on GitHub (Mar 9, 2026):
I wonder if this is related to one I was just observing here, if you go to an upcoming transaction and use the 'Post transaction today' option it fails to remove the upcoming transaction from the schedule. Similarly if you post the transaction, then change the date to today, it'll actually put it back on the upcoming schedule.
In short, it seems the schedule matching is demanding the criteria be met exactly rather than accepting the scheduled item as complete once it's entered. So far I've just been telling it to skip the next scheduled date to bypass it, but for auto-matching perhaps it could be read the date as a by-or-before.
@Triscal commented on GitHub (Mar 11, 2026):
@RegalMonkey currently schedules only match a transaction if they are within 2 days of the scheduled transaction. For example if today is Tuesday and I have scheduled transaction for Friday, if I post it today, it will not match the schedule. Because it is too many days away. This is noted here: https://actualbudget.org/docs/schedules/#how-actual-finds-schedules
Is this what is you are running into?
To be clear as well, I'm stating the behaviour not defending it, I am not sure why it is exists and I'm hoping I can convince someone to change it in the future.
@Triscal commented on GitHub (Mar 11, 2026):
@jeremyj, I think I've been able to reproduce this. It seems to depend on which order you select the two transactions. If I select the already linked transaction first then merge it is unlinked but if I select the unlinked transaction first then merge it works. Can you confirm if this is what you are seeing?
If so I'll take a look at fixing this issue.
On other 'reconciliation step' it sounds like you are expecting
link scheduleto link and then merge the two transactions. If that is what you are expecting I think that is more of a feature request, because imagining a schedule that occurs every 3 days (or daily) and you manually need to link those transactions you would NOT want to lose the other transactions you would only want to associate them with the schedule. Or am I misunderstanding you?@Triscal commented on GitHub (Mar 11, 2026):
Forgot to attach the video of me reproducing (I think).
https://github.com/user-attachments/assets/6dc13556-e7f8-41b0-b400-991c3e0c470c
@RegalMonkey commented on GitHub (Mar 11, 2026):
That does seem to fit, just created a couple dummy schedules and while the 2 day out test cleared the schedule the 3 day out one didn't.
I would say that a solid bit of logic would be to match based on the time the user sets as the 'upcoming length'. I expect people generally use that as things they expect to pay this pay cycle so posting things within that window matching the schedule would makes sense to clear the event.
@Triscal commented on GitHub (Mar 12, 2026):
@RegalMonkey I agree. After taking a stab at solving this issue, I feel like my next goal will be: https://github.com/actualbudget/actual/issues/1957 which I see you commented on and is the "same" two day issue. I'm not sure if there is a secret reason why this hasn't been changed in the past or why it was noted in the docs that it is 2 days, but we will see what happens, when the time comes.
@Triscal commented on GitHub (Mar 21, 2026):
@matt-fidd feels like this issue should be closed now that #7177 is merged. It looks like it didn't auto-close because the commit mentioned this issue not the MR description.