Metadata-Version: 2.1
Name: budgetcli
Version: 2.0.0
Summary: A simple async budgeting app to manage expenses and budgets in google spreadsheets
Author: Code Rustle
Author-email: coderustle@gmail.com
License: MIT
Classifier: Topic :: Utilities
Classifier: Intended Audience :: End Users/Desktop
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python :: 3.11
Description-Content-Type: text/markdown
License-File: LICENSE

# Budget CLI

[![Build](https://github.com/madalinpopa/budgetcli/actions/workflows/build.yaml/badge.svg)](https://github.com/madalinpopa/budgetcli/actions/workflows/build.yaml) [![Test](https://github.com/coderustle/budgetcli/actions/workflows/test.yaml/badge.svg)](https://github.com/coderustle/budgetcli/actions/workflows/test.yaml) [![License](https://img.shields.io/pypi/l/budgetcli)](https://img.shields.io/pypi/l/budgetcli)

A simple terminal app written in Python to manage budgets and expenses in Google Sheet.

## Features

- Add income transactions 
- Add outcome transactions
- Add spending categories
- Add budget for category
- List spending categories
- List transactions by month

## Installation

```
pip install budgetcli
```

In order to use the app you need first to enable Google Spreadsheet API. Please follow this link for more details: [Authorize credentials for a desktop application](https://developers.google.com/sheets/api/quickstart/python)

## Configuration
Before start adding transactions and data, you need to do the following steps:

**Provide Google spreadsheet id**

The spreadsheet id can be found in the browser url, for example `https://docs.google.com/spreadsheets/d/SPREADSHEET_ID/edit#gid=2121817768`. 
```
budgetcli config spreadsheet-id ID
```

**Copy the client_secret_XXX.json to app config**
```bash
budgetcli config credentials-file-path /path/to/client_secret.json
```

**Authorize the app access to spreadsheet data**
```bash
budgetcli auth
```

**Init sheets and tables**
```bash
budgetcli init
```

## Usage

The commands follow the below structure.
```bash
budgetcli <VERB> <OBJECT> <OPTIONS>
```
### Incomes
To add an income you need to provide only an amount and a category. By default, all the income transactions are added
with default today date and without no description.

**Add an income**
```bash
budgetcli add income 5000 salary
```

**Add an income with description**
```bash
budgetcli add income 5000 projects --description "Project A"
```

**Add an income with date and description**
```bash
budgetcli add income 500 projects --description "Project A" --date 2023-04-01
```

### Outcomes
Same for outcome transactions, you need to provide only an amount and a category. By default, all the outcome transactions are added
with default today date and without no description.

**Add an outcome**
```bash
budgetcli add outcome 400 rent
```

**Add an outcome with description**
```bash
budgetcli add 400 rent --date 2023-05-01 --description "Rent for May"
```

### List transactions

**List first 100 transactions**
```bash
budgetcli list transactions
```

**List only first 10 transactions**
```bash
budgetcli list transaction --rows 10
```

**List transactions for a specific month**
```bash
budgetcli list transactions --month April 
```
### Budget

**Add budget for category**
```bash
budgetcli add budget 400 rent
```
