CORE-POS/IS4C

View on GitHub
pos/is4c-nf/plugins/InactiveMemLookup/InactiveMemSearch.php

Summary

Maintainability
A
0 mins
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

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

use COREPOS\pos\lib\MemberLookup;
use COREPOS\pos\lib\Database;

class InactiveMemSearch extends MemberLookup {

    public function lookup_by_number($num)
    {
        $dbc = Database::pDataConnect();
        $query = $dbc->prepare('SELECT CardNo, personNum,
            LastName, FirstName FROM custdata
            WHERE CardNo=? 
            AND Type=\'INACT\'
            ORDER BY personNum');
        $result = $dbc->execute($query, array($num));

        return $this->resultToArray($dbc, $result);;
    }

    public function lookup_by_text($text)
    {
        $dbc = Database::pDataConnect();
        $query = $dbc->prepare('SELECT CardNo, personNum,
            LastName, FirstName FROM custdata
            WHERE LastName LIKE ? 
            AND Type = \'INACT\'
            ORDER BY LastName, FirstName');
        $result = $dbc->execute($query, array($text.'%'));    

        return $this->resultToArray($dbc, $result);;
    }

    private function resultToArray($dbc, $result)
    {
        $ret = $this->default_value();
        $inactives = array();
        $count=1;
        while ($row = $dbc->fetch_row($result)) {
            if (CoreLocal::get('InactiveMemUsage') == 1) {
                $key = CoreLocal::get('defaultNonMem').'::'.$count;
            } else {
                $key = $row['CardNo'].'::'.$row['personNum'];
                $inactives[] = $row['CardNo'];
            }
            $val = $row['CardNo'].'(CSC) '.$row['LastName'].', '.$row['FirstName'];
            $ret['results'][$key] = $val;
            $count++;
        }
        CoreLocal::set('InactiveMemList', $inactives);
        
        return $ret;
    }

}