Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

reworking template docs #606

Merged
merged 12 commits into from
Jan 13, 2025
216 changes: 193 additions & 23 deletions docs/experimental/goal-templates.md
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
# Budget Goal Templates
# Budget Templates

:::warning
This is an **experimental feature**. That means we’re still working on finishing it. There may be bugs, missing functionality or incomplete documentation, and we may decide to remove the feature in a future release. If you have any feedback, please [open an issue](https://github.com/actualbudget/actual/issues) or post a message in the Discord.
Expand All @@ -7,17 +7,112 @@
All functionality described here may not be available in the latest stable release. Use the `edge` images for the latest implementation.
:::

Budget templates allow you to automate your budgeting step every month.
For example, a template like `#template 100` in a Food category will automatically budget $ 100 in your Food category when templates are run.
With budget templates there is no need to manually fill in each category each month.
With one click you can fill in your entire budget based on the templates you have added.
Create a template by adding a note to a category and adding a line that begins with `#template` or `#goal`.

![](/img/goal-template/goal-template-1.png)

You are welcome to have other lines in your note, but the `#template`/`#goal` line must match the syntax.
You are welcome to have other lines in your note, but the `#template`/`#goal` line must match the template syntax.

## Apply the Templates

There are a few ways to apply your templates.

### Apply all templates

In the budget month menu you will see the following options:

![](/img/goal-template/goal-template-2.png)

**Check templates** will test all `#template\#goal` lines for proper syntax.

**Apply budget template** will run all templates in categories that currently have 0 budgeted.
This will leave any existing budget amounts intact.

**Overwrite with budget template** will fill in all budget cells using the templates and ignore any already existing budget amounts.
This is the recommended method if you are using template priorities.

### Apply only specific templates

You can also apply selections of templates if you want.

**Single Category**: Use the option shown below from the budget field drop down to apply templates to just that category.
This will overwrite any existing budgeted amount.

# ADD Picture here

**Apply templates to a single category group**: Use the option shown below from the category group drop down to apply all templates to categories in a specific group.
This will overwrite any existing budgets in the categories in the group.

# ADD Picture here

### Goal Indicators
After having run the templates in a given month and category, the status of a respective category goal will be indicated as a text color of the category balance.
The image below shows an example of categories in the following states: normal (no goal set), empty (no goal set), goal met(green), goal not met(orange), and a negative balance(red).

![](/img/goal-template/templates-colors.png)

#### Goal Indicator Information
If you hover over the balance value in a templated category, a tooltip will appear with info on the status us that category with respect to its template.

# ADD Picture here

## Available Templates

:::note
Currency symbols are not required for setting templates. If you do want to use a currency symbol, the only one supported is `$`. Any other symbol added to the `#template` line will cause it to be treated as standard text, and fail to apply the template to your budget. Other requirements and limitations can be seen below this list, in the [Notes](#notes) section.
:::
There are many types of templates you can use to tailor how categories get filled to match your personal budgeting needs.

### Simple Type
The simple template type is the most basic type of template.
The base template will budget the amount you ask it to.
Simple!
This template also has a few variations making it likely the most used template out of the available options.

Below is an example of how it works.
The template budgets just what you ask, no matter how much the respective category has in its balance.

<!-- prettier-ignore -->
|Syntax|Budgeted Amount|
|---|:---:|
|#template 50| $ 50 |

There is also a useful variation of a simple template.
This varation will put a **limit** on how much the balance of a category can be that month.
Fixed Show fixed Hide fixed
Here are some examples of how this is used

<!-- prettier-ignore -->
|Syntax| Previous Balance | Budgeted Amount | New Balance |
|---|:---:| :---: |:---:|
|#template 50 up to 100| $ 80 | $ 20 | $ 100 |
|#template 50 up to 100| $ 20 | $ 50 | $ 70 |
Isn't that neat!
This is especially useful for budget categories that have month to month variation in spending such as groceries.
You can budget the same amount per month, but save up from one month to the next without having to worry about building up more funds than you need.

The last variation of the simple template is sometimes referred to as a "refill".
With this style the template budgets whatever it takes to hit a "full" amount.
Here is how it works:

<!-- prettier-ignore -->
|Syntax| Previous Balance | Budgeted Amount | New Balance |
|---|:---:| :---: |:---:|
|#template up to 150| $ 10 | $ 140 | $ 150 |
|#template up to 150| $ -20 | $ 170 | $ 150 |
Cool, right! This is another way to gracefully handle categories that have month to month variation.
This will always give you the same amount available each month no matter what you spend the previous month and not ever build up more funds than you need.
This variation along with the previous variation, are probably the most used templates.
They are simple enough to use easily, but are robust enough to make budgeting much simpler.


#### All Variations
There is more flexibility with the limit part of the template.
By default, the limit (the "up to" part of the template) is based per month.
You can modify the limit to be per week or per day if that matches your needs better.
You can also modify the limit to not ever remove funds over your limit.
This can be useful if you get refunds or reimbursements that you would like to have remain inside a category even if over your limit.
Below is examples of these different variations of simple templates.

<!-- prettier-ignore -->
|Syntax|Description|Example Application|
Expand All @@ -28,17 +123,108 @@
|#template up to 150 hold|Budget up to 150 each month, but retain any funds over 150 |Variable expenses that may get refunds or reimbursements|
|#template up to 5 per day |Budget up to 5 per day that month, and remove extra funds | Setting a daily coffee budget|
|#template up to 100 per week starting 2024-10-07 |Budget 100 per week starting on Mondays, and remove extra funds| Setting a weekly grocery budget |
|#template 500 by 2025-03|Break down large, less-frequent expenses into manageable monthly expenses|Saving for a replacement car in a few years

### By Type

The **By** type of template is for saving up funds _by_ a certain month.
For example, it is January and you are trying to save for a new car by the end of the year.
If the new car will cost $ 10,000 and you plan to buy it in December, you will use something like the following:

<!-- prettier-ignore -->
|Syntax| Budgeted Amount |
|---|:---:|
|#template 10000 by 2025-12 | $ 833.33 |
Thats example is pretty basic.
The by template is smarter than just 10000/12.
Lets say the example is the same, but you already have $ 1,500 saved.
In that case you get this.

<!-- prettier-ignore -->
|Syntax| Previous Balance | Budgeted Amount | New Balance |
|---|:---:| :---: |:---:|
|#template 10000 by 2025-12 |$ 1,500 | $ 708.33 | $ 2,208.33 |

Nice!
This even works if you add more funds later.
The template will always divide up the remaining amount you need by the remaining number of months.
If you need to pull funds away from your car savings to cover an emergency house repair, the template will budget more in the coming months to say on track.
If you have extra funds one month and add that to your car savings, the template will budget less in the coming months since you need less.

**Note**: The date must be in YYYY-MM format.

#### Repeated savings
The By template can also repeat if your savings is cyclical, such as yearly taxes or insurance.
The repeat period can be both a number of months or number of years.
If you need to repeat based on a number of weeks, use the Week template.
In that case use the following variation:
<!-- prettier-ignore -->
|Syntax| Budgeted Amount | Note |
|---|:---:| --- |
|#template 500 by 2025-03 repeat every year | $ 166.66 | Assuming starting in January 2025 |
|#template 500 by 2025-03 repeat every year | $ 41.66 | All months after March 2025 |

#### By Spend
The By template can be extended to allow some of the funds to be spent along the way.
This is most commonly used for holiday savings where you will spend some of the money in the months leading up to the holiday.
An example of this is buying Christmas gifts in November and December.
The table below shows how this works.
<!-- prettier-ignore -->
|Syntax| Budgeted Amount | Spent so far| New Balance| Note |
|---|:---:| :---: | --- | --- |
|#template 500 by 2025-12 spend from 2025-11| $ 41.66 | 0 | previous + $ 41.66| Assuming starting in January 2025, all months before December |
|#template 500 by 2025-12 spend from 2025-11| $ 41.66 | $ 100 | $ 400 | Assuming the beginning of December, but have not spent anything in December yet |

#### Available Variations
Below is a table of the varations of the By template.
Fixed Show fixed Hide fixed

<!-- prettier-ignore -->
|Syntax|Description|Example Application|
|---|---|---|
|#template 500 by 2027-03|Break down large, less-frequent expenses into manageable monthly expenses|Saving for a replacement car in a few years
|#template 500 by 2025-03 repeat every 6 months|Break down large, less-frequent expenses into manageable monthly expenses|Biannual credit card fees
|#template 500 by 2025-03 repeat every year|Break down large, less-frequent expenses into manageable monthly expenses|Annual insurance premium
|#template 500 by 2025-03 repeat every 2 years|Break down large, less-frequent expenses into manageable monthly expenses|Domain name renewal|
|#template 500 by 2024-12 spend from 2024-03|Budget 500 by December. Any spending between March and December is OK.|Christmas presents, overseas holiday, or any other expenses that I will be partially paying for before the target period ends.|
|#template 500 by 2024-12 spend from 2024-03 repeat every year| |
|#template 500 by 2024-12 spend from 2024-03 repeat every 2 years| |

### Week Type
If you have bills that cycle weekly, or like to base your budget on weeks, this is the template for you!
This template is like the simple template but it uses weeks instead of months.
You set the start day, and every 7 days starting from that day, you will get the requested amount budgetd.
Fixed Show fixed Hide fixed
See the table below for examples.

<!-- prettier-ignore -->
|Syntax| Budgeted Amount | Note |
|---|:---:| :---: |
|#template 10 repeat every week starting 2025-01-06 | $ 40 | When budgeting in January 2025 |
|#template 10 repeat every week starting 2025-01-06 | $ 50 | When budgeting in March 2025 |

As you can see, the template will budget based on the number of weeks that start on the desired day, starting on your start date.

The Week tempalte also supports limits the same way the simple template does.
Fixed Show fixed Hide fixed
For example if you budget in January with limited template:
<!-- prettier-ignore -->
|Syntax| Previous Balance | Budgeted Amount | New Balance |
|---|:---:| :---: |:---:|
|#template 10 repeat every week starting 2025-01-06 up to 55 | $ 20 | $ 35 | $ 55 |

**Note**: The date must be in YYYY-MM-DD format.

#### Available Variations
Below is a table of the varations of the Week template.
Fixed Show fixed Hide fixed
<!-- prettier-ignore -->
|Syntax|Description|Example Application|
|---|---|---|
|#template 10 repeat every week starting 2025-01-03|Budget 10 a week|
|#template 10 repeat every week starting 2025-01-03 up to 80|Budget 10 a week, up to a maximum of 80|
|#template 10 repeat every 2 weeks starting 2025-01-04|Budget 10 fortnightly|
|#template 10 repeat every 9 weeks starting 2025-01-04 up to 30|Budget 10 every 9 weeks, up to a maximum of 30|
|#template 10 repeat every week starting 2025-01-04 up to 20 per week starting 2025-01-04 |Budget 10 every week, up to a maximum of 20 for each week|

## Old Table
<!-- prettier-ignore -->
|Syntax|Description|Example Application|
|---|---|---|
|#template 15% of all income|Budget 15% of all income categories| Using a "pay yourself first" strategy|
|#template 10% of Paycheck|Budget 10% of the "Paycheck" income category| Using a "pay yourself first" strategy, but have income categories you want to ignore|
|#template 15% of previous all income|Budget 15% of all income categories using last month's income|Using a "pay yourself first" strategy in conjunction with a "month ahead" strategy |
Expand Down Expand Up @@ -206,19 +392,3 @@
| `#template 50` `#goal 500` | 100 | 500(green) |


## Apply the Templates

To apply the goal templates you create, enable the feature in the Settings experimental section. When the feature is on, three new options will appear in the monthly budget actions list.

![](/img/goal-template/goal-template-2.png)

**Check templates** will test all `#template` lines for proper syntax.

**Apply budget template** will only fill empty cells using the templates.

**Overwrite with budget template** will fill in all budget cells using the templates.

### Goal Indicators
After having run the templates in a given month the status of a respective category goal will be indicated as a text color of the category balance. The image below shows an example of categories in the following states: normal (no goal set), zero (no goal set), goal met, goal not met, and a negative balance.

![](/img/goal-template/templates-colors.png)
Loading