Library to manage cashflow

v2.0.1 2022-05-17 08:19 UTC

This package is auto-updated.

Last update: 2024-04-23 01:29:59 UTC


README

Cashflow library is a set of php classes useful for manage cashflow operation as income, outcome and recurrent entries.

<?php

require_once __DIR__.'/../vendor/autoload.php';

use Cashflow\Cashflow;
use Cashflow\Outcome;
use Cashflow\Income;

$entries = [
    [new \Cashflow\Income(),  new \DateTime(date('Y/06/10')), 'Balance', 1000],
    [new \Cashflow\Expense(), new \DateTime(date('Y/06/11')), 'Credit card', 100],
    [new \Cashflow\Recurrent(new \Cashflow\Income()),  new \DateTime(date('Y/1/10')), 'Salary', 1500, new \DateInterval('P1M'), new \DateTime(date('Y/12/31'))],
    [new \Cashflow\Recurrent(new \Cashflow\Expense()),  new \DateTime(date('Y/1/12')), 'Rent', 500, new \DateInterval('P1M'), new \DateTime(date('Y/12/31'))],
];

$cashflow = new Cashflow(new \DateTime(date('Y/1/1')), new \DateTime(date('Y/12/30')));
$cashflow->import($entries);
$cashflow->order();
    
$mask = "|%-10.10s |%-30.30s |%15s |%15s |\n";

$output = sprintf($mask, 'Date', 'Name', 'Flow', 'Balance');

foreach($cashflow->getRows() as $row){
    $cashflow->updateAmount($row, $row->getSign());
    $output .= sprintf(
        $mask, 
        $row->getDate()->format('Y-m-d'), 
        $row->getName(), 
        $row->getSign()*$row->getAmount(), 
        $cashflow->getAmount()
    );
}

$output .= PHP_EOL.
  sprintf('Total income: %s'.PHP_EOL, money_format('%.2n', $cashflow->getTotaleIncome())).
  sprintf('Total expense: %s'.PHP_EOL, money_format('%.2n', $cashflow->getTotalExpense())).
  sprintf('Profit: %s'.PHP_EOL, money_format('%.2n', $cashflow->getBalance()));

echo $output;