mirror of
https://github.com/actualbudget/actual.git
synced 2026-03-11 04:32:39 -05:00
[Bug]: Budget goal "#template up to" does not always remove extra funds #1669
Closed
opened 2026-02-28 19:50:32 -06:00 by GiteaMirror
·
4 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#1669
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 @Arnoud-B on GitHub (Dec 12, 2024).
Verified issue does not already exist?
What happened?
When applying a budget template
#template up to 0, it does not always remove extra funds.In the sample budget, it removes the money spent in December, but not in November.
Where are you hosting Actual?
Docker
What browsers are you seeing the problem on?
Firefox, Safari
Operating System
Mac OSX
@youngcw commented on GitHub (Dec 14, 2024):
I looked into this. Its essentially the same thing as the other issue. An up to template doesn't consider spending when setting the budget value.
So what you are seeing in that example budget is that in November the rollover from the previous month was 0, so when you run "up to 0" its already at zero since leftover(0)+budgeted(0)=0 so the template is met. The "spend" then comes after getting the balance to 50.
For December its removing 50, not from December, but the leftover from November. So its seeing leftover(50)+budgeted(-50)=0. Then after that there is the $50 "spend" that leaves the balance at 50 even after the -50 budgeted amount.
If you run the template for January, it removes the last 50 and the balance is at 0 again.
@Arnoud-B commented on GitHub (Dec 14, 2024):
I'm finding it hard to follow the new logic. The current behavior seems to differ from the documentation:
The documentation refers to "extra funds", which seems to correspond to the category balance in the app (as there is no impact on "Available Funds"). When applying the template to a specific month, I'd expect it to adjust that month's category balance to 0 (like in the example where the category balance reaches 50). The goal is to immediately allocate available money to envelopes. Leaving category balances unused until next month doesn't seem to align with zero-based budgeting principles.
Could you clarify the reasoning behind this change?
@youngcw commented on GitHub (Dec 14, 2024):
Like I mentioned in the other ticket, the templates should always attempt the same thing no matter when they are run in the month. In other words, the templates act as if they are run on the first of the month when there aren't any transactions. So the only balance available at the start of the month is what was carried over from the previous month.
The intended workflow for templates is that they get run at or near the first of the month to set up the budget initially, and for future months. Then after the initial month start further changes are manual as the month goes along.
The other flow that works is if someone is paycheck to paycheck they can use priorities to continuously fill in their categories in the current month as money is available.
You may be more interested in the cleanup templates if you want to be removing funds through the month. I could see those being extended to be more flexible as well, but they don't come up very often.
@Arnoud-B commented on GitHub (Dec 14, 2024):
I've been experimenting a bit with the cleanup templates (this was new to me), and they may be able to do the job together with the assumption to start each month fresh. It's a different approach, but it makes sense. Thanks!