CORE-POS/IS4C

View on GitHub
pos/is4c-nf/lib/ReceiptBuilding/TenderReports/WfcTenderReport.php

Summary

Maintainability
D
1 day
Test Coverage
D
68%
<?php
/*******************************************************************************

    Copyright 2001, 2004 Wedge Community 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

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

namespace COREPOS\pos\lib\ReceiptBuilding\TenderReports;
use COREPOS\pos\lib\Database;
use COREPOS\pos\lib\ReceiptLib;

/**
  @class TenderReport
  Generate a tender report
*/
class WfcTenderReport extends TenderReport {

/** 
 Print a tender report
 
 This tender report is based on a single tender tape view
 rather than multiple views (e.g. ckTenders, ckTenderTotal, etc)
 adding a new tender is mostly just a matter of adding it
 to the $DESIRED_TENDERS array (exception being if you want
 special handling in the tender tape view (e.g., three
 tender types are actually compined under EBT)
 */
static public function get($session){

    $DESIRED_TENDERS = array("CK"=>"CHECK TENDERS",
                 "CC"=>"CREDIT CARD TENDERS",
                 "CA"=>"CASH TENDERS",
                 "GD"=>"GIFT CARD TENDERS",
                 "TC"=>"GIFT CERT TENDERS",
                 "MI"=>"STORE CHARGE TENDERS",
                 "IC"=>"INSTORE COUPONS TENDERED",
                 "EF"=>"EBT CARD TENDERS",
                 "CP"=>"COUPONS TENDERED",
                 "AR"=>"AR PAYMENTS",
                 "EQ"=>"EQUITY SALES",
                 "SN"=>"SANDWICH CARD",
                 "CF"=>"COFFEE CARD",
                 "SC"=>"STORE CREDIT"
             );

    $dba = Database::mDataConnect();
    if ($dba === false) {
        return '';
    }

    $blank = "             ";
    $fieldNames = "  ".substr("Time".$blank, 0, 13)
            .substr("Lane".$blank, 0, 9)
            .substr("Trans #".$blank, 0, 12)
            .substr("Change".$blank, 0, 14)
            .substr("Amount".$blank, 0, 14)."\n";
    $ref = ReceiptLib::centerString(trim($session->get("CashierNo"))." ".trim($session->get("cashier"))." ".ReceiptLib::build_time(time()))."\n\n";
    $receipt = "";

    $itemize = 0;
    foreach($DESIRED_TENDERS as $tender_code => $header){ 
        $query = "select tdate,register_no,trans_no,-total AS tender
                   from dlog where emp_no=".$session->get("CashierNo").
            " and trans_type='T' AND trans_subtype='".$tender_code."'
              ORDER BY tdate";
        switch($tender_code){
        case 'CC':
            $query = "select tdate,register_no,trans_no,-total AS tender
                from dlog where emp_no=".$session->get("CashierNo").
                " and trans_type='T' AND trans_subtype IN ('CC','AX')
                  ORDER BY tdate";
            break;
        case 'CA':
            $query = "select tdate,register_no,trans_no,-total AS tender
                from dlog where emp_no=".$session->get("CashierNo").
                " and trans_type='T' AND trans_subtype='CA' AND total <> 0
                  ORDER BY tdate";
            break;
        case 'CK':
            $query = "select tdate,register_no,trans_no,-total AS tender
                from dlog where emp_no=".$session->get("CashierNo").
                " and trans_type='T' AND trans_subtype IN ('CK','TK', 'RC')
                  ORDER BY tdate";
            break;
        case 'EF':
            $query = "select tdate,register_no,trans_no,-total AS tender
                from dlog where emp_no=".$session->get("CashierNo").
                " and trans_type='T' AND trans_subtype IN ('EF','EC')
                  ORDER BY tdate";
            break;
        case 'CP':
            $query = "select tdate,register_no,trans_no,-total AS tender
                from dlog where emp_no=".$session->get("CashierNo").
                " and trans_type='T' AND trans_subtype ='CP' AND
                  upc NOT LIKE '%MAD%' ORDER BY tdate";
            break;
        case 'IC':
            $query = "select tdate,register_no,trans_no,-total AS tender
                from dlog where emp_no=".$session->get("CashierNo").
                " and trans_type='T' AND trans_subtype ='IC' AND
                  upc NOT IN ('0049999900001', '0049999900002') ORDER BY tdate";
            break;
        case 'SC':
            $query = "select tdate,register_no,trans_no,-total AS tender
                from dlog where emp_no=".$session->get("CashierNo").
                " and trans_type='T' AND trans_subtype ='SC' AND
                  total<0 ORDER BY tdate";
            break;
        case 'AR':
            $query = "select tdate,register_no,trans_no,total AS tender
                from dlog where emp_no=".$session->get("CashierNo").
                " and trans_type='D' AND department = 990
                  ORDER BY tdate";
            break;
        case 'EQ':
            $query = "select tdate,register_no,trans_no,total AS tender
                from dlog where emp_no=".$session->get("CashierNo").
                " and trans_type='D' AND department IN (991,992)
                  ORDER BY tdate";
            break;
        case 'SN':
            $query = "select tdate,register_no,trans_no,total AS tender
                from dlog where emp_no=".$session->get("CashierNo").
                " and trans_type='I' AND upc LIKE '002001000%'
                  ORDER BY tdate";
            break;
        case 'CF':
            $query = "select tdate,register_no,trans_no,total AS tender
                from dlog where emp_no=".$session->get("CashierNo").
                " and trans_type='I' AND upc LIKE '002000600%'
                  ORDER BY tdate";
            break;
        }
        $result = $dba->query($query);
        $numRows = $dba->numRows($result);
        if ($numRows <= 0) continue;

        //$receipt .= chr(27).chr(33).chr(5);

        $titleStr = "";
        for ($i = 0; $i < strlen($header); $i++)
            $titleStr .= $header[$i]." ";
        $titleStr = substr($titleStr,0,strlen($titleStr)-1);
        $receipt .= ReceiptLib::centerString($titleStr)."\n";

        $receipt .= $ref;
        if ($itemize == 1) $receipt .=    ReceiptLib::centerString("------------------------------------------------------");

        if ($session->get("store") == "wfc") $itemize=1;
        
        if ($itemize == 1) $receipt .= $fieldNames;
        $sum = 0;

        for ($i = 0; $i < $numRows; $i++) {
            $itemize = 0;
            if (($session->get("store") == "harvest-cb") && ($tender_code == "PE" || $tender_code == "BU" || $tender_code == "EL" || $tender_code == "PY" || $tender_code == "TV")) $itemize = 1;
            elseif ($session->get("store") == "wfc") $itemize=1;
            $row = $dba->fetchRow($result);
            $timeStamp = self::timeStamp($row["tdate"]);
            if ($itemize == 1) {
                $receipt .= "  ".substr($timeStamp.$blank, 0, 13)
                .substr($row["register_no"].$blank, 0, 9)
                .substr($row["trans_no"].$blank, 0, 8)
                .substr($blank.number_format("0", 2), -10)
                .substr($blank.number_format($row["tender"], 2), -14)."\n";
            }
            $sum += $row["tender"];
        }
        
        $receipt.= ReceiptLib::centerString("------------------------------------------------------");

        $receipt .= substr($blank.$blank.$blank."Count: ".$numRows."  Total: ".number_format($sum,2), -56)."\n";
        $receipt .= str_repeat("\n", 4);

        // cut was commented out for non-wfc
        if ($session->get("store") == "wfc") 
            $receipt .= chr(27).chr(105);
    }

    return $receipt.chr(27).chr(105);
}

}