CORE-POS/IS4C

View on GitHub
fannie/modules/plugins2.0/WfcHoursTracking/WfcHtViewEmpPage.php

Summary

Maintainability
C
1 day
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_once(__DIR__ . '/../../../classlib2.0/FannieAPI.php');
}
if (!class_exists('WfcHtLib')) {
    require(dirname(__FILE__).'/WfcHtLib.php');
}

class WfcHtViewEmpPage extends FanniePage
{
    protected $must_authenticate = true;

    public $page_set = 'Plugin :: WFC Hours Tracking';
    public $description = '[View Hourly] shows information for a single hourly employee.';
    public $themed = true;

    protected $title = 'View Employee';
    protected $header = '';

    private $empID = 0;

    public function preprocess()
    {
        $this->empID = FormLib::get('id');

        if ($this->empID === '' || !is_numeric($this->empID)) {
            $this->empID = FannieAuth::getUID($this->current_user);
        }

        if (!FannieAuth::validateUserQuiet('view_all_hours')) {
            /* see if logged in user has access to any
               department. if so, see if the selected employee
               is in that department
            */
            $validated = false;
            $sql = WfcHtLib::hours_dbconnect();
            $depts = array(10,11,12,13,20,21,30,40,41,50,60,998);
            $checkQ = $sql->prepare("select department from employees where empID=?");
            $checkR = $sql->execute($checkQ, array($this->empID));
            $checkW = $sql->fetch_row($checkR);
            if (FannieAuth::validateUserQuiet('view_all_hours', $checkW['department'])){
                $validated = true;
            }

            /* no access permissions found, so only allow the
               logged in user to see themself
            */
            if (!$validated) {
                $this->empID = FannieAuth::getUID($this->current_user);
            }
        }

        $sql = WfcHtLib::hours_dbconnect();
        $deptQ = $sql->prepare("select department from employees where empID=?");
        $deptR = $sql->execute($deptQ, array($this->empID));
        $deptW = $sql->fetch_row($deptR);
        if ($deptW['department'] >= 998){
            header("Location: WfcHtViewSalaryPage.php?id=".$this->empID);
            return false;
        }

        return true;
    }

    public function body_content()
    {
        global $FANNIE_URL;

        $sql = WfcHtLib::hours_dbconnect();

        ob_start();
        echo "<style type=text/css>
            #payperiods {
            margin-top: 50px;
        }

        #payperiods td {
            text-align: right;
        }

        #payperiods th {
            text-align: center;
        }

        #payperiods td.left {
            text-align: left;
        }

        #payperiods th.left {
            text-align: left;
        }

        #payperiods th.right {
            text-align: right;
        }

        tr.one td {
            background: #ffffcc;
        }
        tr.one th {
            background: #ffffcc;
            text-align: right;
        }

        tr.two td {
            background: #ffffff;
        }
        tr.two th {
            background: #ffffff;
            text-align: right;
        }
        a {
            color: blue;
        }

        #temptable th {
            text-align: left;
        }
        #temptable td {
            text-align: right;
            padding-left: 2em;
        }

        #temptable {
            font-size: 125%;
        }

        #newtable th{
            text-align: left;
        }
        #newtable td{
            text-align: right;
        }

        </style>";

        echo "<h3>Employee Total Hours Worked and PTO Status</h3>";

        $infoQ = $sql->prepare("select e.name,e.PTOLevel,p.dateStr,
            l.HoursWorked - h.totalHours as remaining,
            o.PTOremaining,o.totalPTO,h.totalHours,u.hours
            from employees as e left join PayPeriods as p on e.PTOCutoff = p.periodID
            left join hoursalltime as h on e.empID=h.empID
            left join PTOLevels as l on e.PTOLevel+1 = l.levelID
            left join pto as o on e.empID=o.empID
            left join uto as u on e.empID=u.empID
            where e.empID=?");
        $infoR = $sql->execute($infoQ, array($this->empID));
        $infoW = $sql->fetch_row($infoR);

        $startdate = $infoW['dateStr'];
        if (preg_match("/(\d+?.\d+?.\d+)$/",$startdate,$matches) > 0) 
            $startdate = $matches[1];
        if (preg_match("/(\d\d?).(\d\d?).(\d\d\d?\d?)/",$startdate,$matches) > 0) {
            $month = $matches[1];
            $day = $matches[2];
            $year = $matches[3];

            $timestamp = mktime(0,0,0,$month,$day,$year);
            $startdate = strftime("%D",$timestamp+(24*60*60));
        }

        echo "<h2>{$infoW['name']} [ <a href={$FANNIE_URL}auth/ui/loginform.php?logout=yes>Logout</a> ]</h2>";
        echo "<table class=\"table\" id=newtable>";
        echo "<tr class=one><th>Consecutive Hours Worked</th><td>{$infoW['totalHours']}</td></tr>";
        echo "<tr class=two><th>Current PTO Level</th><td>{$infoW['PTOLevel']}</td></tr>";
        echo "<tr class=one><th>Starting PTO Allocation</th><td>{$infoW['totalPTO']}</td></tr>";
        echo "<tr class=two><th>PTO Hours Remaining</th><td>{$infoW['PTOremaining']}</td></tr>";
        echo "<tr class=one><th>Effective Since</th><td>$startdate</td></tr>";
        printf("<tr class=two><th>Hours to Next Level</th><td>%.2f</td></tr>",$infoW['remaining']);
        echo "<tr class=one><th>UTO Hours Remaining</th><td>{$infoW['hours']}</td></tr>";
        echo "</tr></table>";

        $periodsQ = $sql->prepare("select min(p.dateStr),sum(i.hours),sum(i.OTHours),sum(i.PTOHours),
            sum(i.UTOHours),sum(i.SecondRateHours),i.periodID
            from ImportedHoursData as i left join PayPeriods as p on i.periodID=p.periodID
            where i.empID=? group by i.periodID order by i.periodID desc");
        $periodsR = $sql->execute($periodsQ, array($this->empID));
        $sums = array(0,0,0,0,0,0);
        $class = array("one","two");
        $prev_hours = 0;
        $c = 0;
        echo "<table id=payperiods class=\"table\">";
        echo "<tr><th>Pay Period</th><th>Reg. Hours</th><th>OT Hours</th><th>PTO Taken</th>";
        echo "<th>UTO Taken</th><th>Alt. Position Hours</th><th>Total Hours*</th></tr>";
        while ($row = $sql->fetch_row($periodsR)) {
            if ($row[6] < 5){
                $prev_hours += $row[1];
                $sums[0] += $row[1];
                $sums[5] += $row[1];
                continue;
            }
    
            echo "<tr class=$class[$c]>";
            $total = $row[1]+$row[2]+$row[5];
            echo "<td class=left>$row[0]</td>";
            for ($i=1; $i<6;$i++) echo "<td>$row[$i]</td>";
            echo "<td>$total</td>";
            echo "</tr>";
            for ($i=1; $i<6;$i++) {
                $sums[$i-1]+=$row[$i];
            }
            $sums[5]+=$total;
            $c = ($c+1)%2;
        }

        echo "<tr class=$class[$c]><td class=left>Previous hours</td>";
        echo "<td>$prev_hours</td>";
        for ($i=0;$i<4;$i++) {
            echo "<td>0</td>";
        }
        echo "<td>$prev_hours</td></tr>";
        $c = ($c+1)%2;


        echo "<tr class=$class[$c]>";
        echo "<th class=left>Total</th>";
        foreach ($sums as $s) echo "<th class=right>$s</th>";
        echo "</tr>";
        echo "</table>";
        echo "<i>* Total does not include PTO & UTO hours taken. These hours do not count towards
        consecutive hours worked.</i>";
        echo "<p />";
        echo "<div class=\"well\">
        <u>Please Note</u>: This web-base PTO Access Page is new. If you notice any problems,
        please contact Colleen or Andy.
        </div>";

        return ob_get_clean();
    }
}

FannieDispatch::conditionalExec();