CORE-POS/IS4C

View on GitHub
fannie/modules/plugins2.0/GiveUsMoneyPlugin/reports/GumBothReport.php

Summary

Maintainability
A
2 hrs
Test Coverage
<?php
/*******************************************************************************

    Copyright 2013 Whole Foods Co-op

    This file is part of IT CORE.

    IT CORE is free software; you can redistribute it and/or modify
    it under the terms of the GNU General Public License as published by
    the Free Software Foundation; either version 2 of the License, or
    (at your option) any later version.

    IT CORE is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    GNU General Public License for more details.

    You should have received a copy of the GNU General Public License
    in the file license.txt along with IT CORE; if not, write to the Free Software
    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA

*********************************************************************************/

include(dirname(__FILE__).'/../../../../config.php');
if (!class_exists('FannieAPI')) {
    include(__DIR__ . '/../../../../classlib2.0/FannieAPI.php');
}

/**
*/
class GumBothReport extends FannieReportPage 
{
    public $discoverable = false; // access is very restricted; no need to list
                                  // as an available report

    protected $multi_report_mode = true;

    protected $must_authenticate = true;
    protected $auth_classes = array('GiveUsMoney');

    protected $required_fields = array();
    protected $report_headers = array('Term (Months)', 'Total Principal', 'Avg. Rate (%)', 'Approx. Maturity Value', 'Nearest Due Date', 'Farthest Due Date');

    public function preprocess()
    {
        $this->header = 'Active Loan Report';
        $this->title = 'Active Loan Report';

        return parent::preprocess();
    }
    
    public function fetch_report_data()
    {
        global $FANNIE_PLUGIN_SETTINGS;
        $dbc = FannieDB::get($FANNIE_PLUGIN_SETTINGS['GiveUsMoneyDB']);

        // compound interest calculation is MySQL-specific
        $query = 'SELECT termInMonths, 
                    SUM(principal) as totalP,
                    AVG(interestRate) as avgR,
                    SUM(principal * POW(1+interestRate, DATEDIFF(DATE_ADD(loanDate, INTERVAL termInMonths MONTH), loanDate)/365.25)) as totalM,
                    MIN(loanDate) AS nearest,
                    MAX(loanDate) as farthest
                  FROM GumLoanAccounts
                  WHERE gumLoanAccountID NOT IN (
                    SELECT m.gumLoanAccountID
                    FROM GumLoanPayoffMap AS m
                      INNER JOIN GumPayoffs AS p ON m.gumPayoffID=p.gumPayoffID
                      WHERE p.checkIssued=1
                  )
                  GROUP BY termInMonths
                  ORDER BY termInMonths';
        $result = $dbc->query($query);

        $report1 = array();
        while($row = $dbc->fetch_row($result)) {
            $record = array(
               $row['termInMonths'],
               sprintf('%.2f', $row['totalP']), 
               sprintf('%.2f', $row['avgR'] * 100), 
               sprintf('%.2f', $row['totalM']), 
               date('Y-m-d', strtotime($row['nearest'])),
               date('Y-m-d', strtotime($row['farthest'])),
            );
            $report1[] = $record;
        }

        // compound interest calculation is MySQL-specific
        $query = 'SELECT 
                    CASE WHEN shares > 0 THEN \'PURCHASE\' ELSE \'PAYOFF\' END as stype,
                    SUM(shares) AS totalS,
                    SUM(value) AS totalV
                  FROM GumEquityShares
                  GROUP BY CASE WHEN shares > 0 THEN \'PURCHASE\' ELSE \'PAYOFF\' END 
                  ORDER BY CASE WHEN shares > 0 THEN \'PURCHASE\' ELSE \'PAYOFF\' END DESC';
        $result = $dbc->query($query);

        $report2 = array();
        while($row = $dbc->fetch_row($result)) {
            $record = array(
               $row['stype'],
               sprintf('%d', $row['totalS']), 
               sprintf('%.2f', $row['totalV']), 
            );
            $report2[] = $record;
        }

        return array($report1, $report2);
    }

    public function calculate_footers($data)
    {
        if ($this->multi_counter == 1) {
            $sum = 0.0;
            $due = 0.0;
            foreach($data as $row) {
                $sum += $row[1];
                $due += $row[3];
            }
            $this->report_headers = array('Term (Months)', 'Total Principal', 'Avg. Rate (%)', 'Approx. Maturity Value', 'Nearest Due Date', 'Farthest Due Date');

            return array('Total', sprintf('%.2f', $sum), '', sprintf('%.2f', $due), '', '');
        } else {
            $sumS = 0;
            $sumV = 0;
            foreach($data as $row) {
                $sumS += $row[1];
                $sumV += $row[2];
            }
            $this->report_headers = array('Type', '# of Shares', 'Value');

            return array('Balance', $sumS, sprintf('%.2f', $sumV));
        }
    }

    public function form_content()
    {
        return '<!-- no need -->';
    }

}

FannieDispatch::conditionalExec();