CORE-POS/IS4C

View on GitHub
fannie/mem/MemberSearchPage.php

Summary

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

    Copyright 2010 Whole Foods Co-op, Duluth, MN

    This file is part of CORE-POS.

    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');
}

class MemberSearchPage extends FanniePage {
    protected $title = "Fannie :: Find Member";
    protected $header = "Find Members";

    public $description = '[Member Search] finds a member account by name, number, or contact info.';

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

    private $mode = 'search';
    private $country;
    private $results = array();

    function preprocess()
    {
        global $FANNIE_COUNTRY,$FANNIE_MEMBER_MODULES,$FANNIE_OP_DB;
        $this->country = (isset($FANNIE_COUNTRY)&&!empty($FANNIE_COUNTRY))?$FANNIE_COUNTRY:"US";

        /* do search */
        if (FormLib::get('doSearch',False) !== False){
            $dbc = FannieDB::get($FANNIE_OP_DB);
            $num = FormLib::get('memNum','');

            /* if member number is provided and exists, go
               directly to the result */
            if ($num !== '') {
                $account = \COREPOS\Fannie\API\member\MemberREST::get($num);
                if ($account != false) {
                    header("Location: MemberEditor.php?memNum=".$num);
                    return False;
                }
            }

            /* process each available search and merge the
               results */
            FannieAPI::listModules('COREPOS\Fannie\API\member\MemberModule');
            foreach($FANNIE_MEMBER_MODULES as $mm){
                if (class_exists($mm)) {
                    $instance = new $mm();
                    if ($instance->hasSearch()) {
                        $tmp = $instance->getSearchResults();
                        foreach ($tmp as $id => $label) {
                            if (!isset($this->results[$id])) {
                                $this->results[$id] = $label;
                            }
                        }
                    }
                }
            }

            /* if modules find exactly one member, go directly to
               the result */
            if (count($this->results) == 1){
                $mem = array_pop($this->results);
                header("Location: MemberEditor.php?memNum=".$mem['cardNo']);
                return False;
            }

            /* search returned either zero or multiple results */
            $this->mode = 'results';
        }

        return true;
    }

    function body_content()
    {
        $ret = '';
        if ($this->mode == 'search') {
            $this->add_onload_command("\$('input#mn').focus();");
        } elseif ($this->mode == 'results') {
            $ret .= $this->results_content();
        }
        $ret .= $this->form_content();

        return $ret;
    }

    function form_content()
    {
        $ret = '';

        $review = FormLib::get('review',False);
        if ($review !== false) {
            $ret .= '<fieldset><legend>Review</legend>';
            $dbc = FannieDB::get($this->config->get('OP_DB'));
            $account = \COREPOS\Fannie\API\member\MemberREST::get($review);
            $ret .= 'Saved Member #'.$review.' (';
            if ($account) {
                foreach ($account['customers'] as $row) {
                    if ($row['accountHolder']) {
                        $ret .= $row['firstName'].' '.$row['lastName'];
                        break;
                    }
                }
            }
            $ret .= ')';
            $ret .= '<br /><a href="MemberEditor.php?memNum='.$review.'">Edit Again</a>';
            $list = FormLib::get('l');
            if (!class_exists('MemberEditor')) {
                include(dirname(__FILE__) . '/MemberEditor.php');
            }
            $links = MemberEditor::memLinksPrevNext($review, $list);
            if (!empty($links[0])) {
                $ret .= '&nbsp;&nbsp;&nbsp;' . $links[0];
            }
            if (!empty($links[1])) {
                $ret .= '&nbsp;&nbsp;&nbsp;' . $links[1];
            }
            $ret .= '</fieldset>';
        }

        $ret .= '<div class="well">
            Enter criteria to find one member or a list members from which to choose.</div>';
        $ret .= '<form action="MemberSearchPage.php" method="get">';
        $ret .= '<div class="container-fluid">';
        $ret .= '<div class="form-group form-inline row">
            <label>Member Number</label>
            <input type="text" name="memNum" id="mn" class="form-control" />
            </div>';
        $searchJS = '';
        $load = array();
        FannieAPI::listModules('COREPOS\Fannie\API\member\MemberModule');
        foreach ($this->config->get('MEMBER_MODULES') as $mm) {
            if (class_exists($mm)) {
                $instance = new $mm();
                if ($instance->hasSearch()) {
                    $ret .= $instance->showSearchForm($this->country);
                    $searchJS .= $instance->getSearchJavascript();
                    foreach ($instance->getSearchLoadCommands() as $cmd) {
                        $load[] = $cmd;
                    }
                }
            }
        }
        $ret .= '</div>';
        $ret .= '<p><button type="submit" value="Search" name="doSearch" 
            class="btn btn-default">Search</button></p>';
        $ret .= '</form>';

        $ret .= '<script type="text/javascript" src="../item/autocomplete.js"></script>';
        if ($searchJS != '') {
            $ret .= '<script type="text/javascript">' . $searchJS . '</script>';
        }

        foreach ($load as $cmd) {
            $this->add_onload_command($cmd);
        }

        return $ret;
    }
    
    function results_content()
    {
        $ret = '';
        if (empty($this->results)) {
            $ret .= "<div class=\"alert alert-danger\">Error: No matching member found</div>";
        } else {
            $list = '';
            foreach ($this->results as $cn => $name) {
                if (strlen($list) > 1900) break; // avoid excessively long URLs
                $list .= '&l[]='.$cn;
            }
            $ret .= '<div class="panel panel-default">
                <div class="panel-heading">Multiple Results</div>
                <div class="panel-body">';
            $ret .= '<table class="tablesorter"><thead>';
            $ret .= '<tr><th>Mem#</th><th>Last Name</th><th>First Name</th>
                <th>Address</th><th>City</th><th>State</th><th>Zip</th></tr>
                </thead><tbody>';
            foreach ($this->results as $account) {
                foreach ($account['customers'] as $name) {
                    $ret .= sprintf('<tr>
                            <td><a href="MemberEditor.php?memNum=%s%s">%d</a></td>
                            <td>%s</td>
                            <td>%s</td>
                            <td>%s</td>
                            <td>%s</td>
                            <td>%s</td>
                            <td>%s</td>
                            </tr>',
                            $account['cardNo'], $list, $account['cardNo'],
                            $name['lastName'],
                            $name['firstName'],
                            $account['addressFirstLine'],
                            $account['city'],
                            $account['state'],
                            $account['zip']
                        );
                }
            }
            $ret .= "</tbody></table>";
            $ret .= "</div></div>";
            $this->addCssFile('../src/javascript/tablesorter/themes/blue/style.css');
            $this->addScript('../src/javascript/tablesorter/jquery.tablesorter.js');
            $this->addOnloadCommand('$(\'.tablesorter\').tablesorter();');
        }

        return $ret;
    }

    public function helpContent()
    {
        return '<p>Search for member accounts. Member number should always
            yield a single match or not found. Other kinds of searches may
            return multiple members. If there are multiple results, click
            the one you want to view.</p>';
    }

    public function unitTest($phpunit)
    {
        $this->config->set('FANNIE_MEMBER_MODULES', array('ContactInfo', 'MemCard'));
        $phpunit->assertNotEquals(0, strlen($this->body_content()));
    }
}

FannieDispatch::conditionalExec();