Skip to content

Nef10/SwiftBeanCountTax

Repository files navigation

SwiftBeanCountTax

CI Status Documentation percentage License: MIT Latest version platforms supported: linux | macOS | iOS | watchOS | tvOS SPM compatible

This project is part for SwiftBeanCount, please check out the main documentation here.

What

This is a library to help you during tax season. Right now it can list taxable sales and generate expected tax slips based on your beancount file. This allows you to easily verify your received tax slips to check for errors on either the providers side or your tracking.

Beancount meta data

The library relies on meta data and custom directives in your Beancount file for configuration.

Taxable Sales

On the account you are selling from, add the "tax-sale" meta data, specifing the name the sales should show be grouped by, usually the brokers name.

Tax Slips

Basic Configuration

  • You first must configure the names of the slips you want to generate, and set a currency for each one
  • Afterwards, add meta data to the account in the form of tax slip name: Box name + number
  • Optionally, you can add a tax slip issuer, e.g. if you receive the same slip from multiple institutions - if no issuer is set, all amounts for the same slip and box will be added together

Example:

2020-01-01 custom "tax-slip-settings" "slip-names" "t3" "t5"
2020-01-01 custom "tax-slip-settings" "slip-currency" "t3" "CAD"
2020-01-01 custom "tax-slip-settings" "slip-currency" "t5" "CAD"

2020-01-01 open Income:Interest:Taxable:BankABC CAD
  t5: "Interest from Canadian sources (Box 13)"
  tax-slip-issuer: "BankABC"

Split Slips by Symbol

Some tax slips are split up by individual stock / ETF. To configure this, either the last or second last part of the account name must match a configured commodity or you add tax-symbol meta-data to the account.

Aditionally to the symbol, you can add a description. For a commodity add name or on an account the tax-description meta data.

Example:

2020-01-01 commodity ETFABC
  name: "ETF ABC @ Exchange"

2020-01-01 open Income:Dividend:Taxable:ETFABC:ForeignNonBusinessIncome CAD
  t3: "Foreign Non-Business Income (Box 25)"

2020-01-01 open Income:Dividend:Taxable:Portfolio:Other CAD
  t3: "Other Income (Box 26)"
  tax-symbol: "StockTicker"
  tax-description: "Stock @ Exchange"

If your account has the name matching to a commodity, but you don't want to treat it as one, add tax-symbol: "" to it.

Split accounts

Sometimes, if you split up your slip by stock, you don't want to create a separate account for everything. E.g. you track the dividends via different income accounts, but don't want to create separate expense accounts per stock for tax paid. To do this:

  1. Configure the tax slip and box via a customs directive instead of account meta data, as shown below
  2. Make sure the transaction with the posting to this account has another posting from an account configured via meta data for the same tax slip
  3. Make sure the other account has a symbol configured (Note: This also works on slips not split by symbol. E.g. When you share a tax expense account across the whole ledger, you can still add it to your employment slip this way)

Example:

2020-01-01 custom "tax-slip-settings" "account" "t3" "Foreign Non-Business Income Tax paid (Box 34)" "Expenses:Tax:ForeignNonBusiness"

2020-01-01 * "" ""
  Income:Dividend:Taxable:ETFABC:ForeignNonBusinessIncome 10.00 CAD
  Expenses:Tax:ForeignNonBusiness -2.50 CAD
  Assets:Portfolio 7.50 CAD

If multiple custom directives for the same setting exist, the latest one up until the end of the tax year is used. E.g. when generating tax slips for 2021, the latest directive up until 2021-12-31 is used.

Special Characters

Tax Slips only support letters and numbers. The only exceptions are round brackets (). To use them, add them into the slip-names meta data:

2020-01-01 custom "tax-slip-settings" "slip-names" "t4a(p)"

At all other places used, remove the brackets, e.g. use t4ap:

2020-01-01 open Income:CPP CAD
  t4ap: "Taxable CPP benefits (Box 20)"

Dates

Sometimes income is earned in one year, but only paid in another; or a sale is performed in one year but only settled in the next. You can change the year a transaction should count towards via the tax-year meta data on a transaction, e.g. tax-year: "2022".

How

  1. Load your ledger, e.g. via SwiftBeanCountParser
  2. Call one of the public functions on TaxCalculator, for example:
    1. TaxCalculator.generateTaxSlips(from ledger: Ledger, for year: Int)
    2. TaxCalculator.getTaxableSales(from ledger: Ledger, for year: Int)

Please also check out the complete documentation here.

Usage

The library supports the Swift Package Manger, so simply add a dependency in your Package.swift:

.package(url: "https://github.com/Nef10/SwiftBeanCountTax.git", .exact(from: "X.Y.Z")),

Note: as per semantic versioning all versions changes < 1.0.0 can be breaking, so please use .exact for now