Seditio Source
Root |
./othercms/ips_4.3.4/applications/nexus/modules/admin/customers/search.php
<?php
/**
 * @brief        Customer Search
 * @author        <a href='https://www.invisioncommunity.com'>Invision Power Services, Inc.</a>
 * @copyright    (c) Invision Power Services, Inc.
 * @license        https://www.invisioncommunity.com/legal/standards/
 * @package        Invision Community
 * @subpackage    Nexus
 * @since        12 May 2014
 */

namespace IPS\nexus\modules\admin\customers;

/* To prevent PHP errors (extending class does not exist) revealing path */
if ( !defined( '\IPS\SUITE_UNIQUE_KEY' ) )
{
   
header( ( isset( $_SERVER['SERVER_PROTOCOL'] ) ? $_SERVER['SERVER_PROTOCOL'] : 'HTTP/1.0' ) . ' 403 Forbidden' );
    exit;
}

/**
 * Customer Search
 */
class _search extends \IPS\Dispatcher\Controller
{
   
/**
     * Execute
     *
     * @return    void
     */
   
public function execute()
    {
        \
IPS\Dispatcher::i()->checkAcpPermission( 'customers_view' );
       
parent::execute();
    }

   
/**
     * View Customers
     *
     * @return    void
     */
   
protected function manage()
    {
       
$table = new \IPS\Helpers\Table\Db( 'core_members', \IPS\Http\Url::internal('app=nexus&module=customers&controller=search') );
       
$table->langPrefix = 'customerTable_';
       
$table->joins = array(
            array(
               
'select'    => 'nexus_customers.cm_first_name, nexus_customers.cm_last_name',
               
'from'        => 'nexus_customers',
               
'where'        => 'core_members.member_id=nexus_customers.member_id'
           
),
            array(
               
'select'    => 'address',
               
'from'        => 'nexus_customer_addresses',
               
'where'        => 'nexus_customer_addresses.member=nexus_customers.member_id AND primary_billing=1'
           
)
        );
       
$table->include = array( 'photo', 'name', 'cm_last_name', 'cm_first_name', 'email', 'address' );
       
$table->parsers = array(
           
'photo'    => function( $val, $row )
            {
                return \
IPS\Theme::i()->getTemplate('customers')->rowPhoto( \IPS\Member::constructFromData( $row ) );
            },
           
'address'        => function( $val )
            {
                return \
IPS\GeoLocation::buildFromJson( $val );
            }
        );
       
$table->noSort = array( 'photo', 'address' );
       
$table->quickSearch = 'email';
       
$table->rowClasses = array( 'address' => array( 'ipsTable_wrap' ) );
       
       
$table->advancedSearch = array(
           
'cm_first_name'        => \IPS\Helpers\Table\SEARCH_CONTAINS_TEXT,
           
'cm_last_name'        => \IPS\Helpers\Table\SEARCH_CONTAINS_TEXT,
           
'email'                => \IPS\Helpers\Table\SEARCH_CONTAINS_TEXT,
           
'name'                => \IPS\Helpers\Table\SEARCH_CONTAINS_TEXT
       
);
        foreach ( \
IPS\nexus\Customer\CustomField::roots() as $field )
        {
            switch (
$field->type )
            {
                case
'Checkbox':
                case
'YesNo':
                   
$table->advancedSearch[ $field->column ] = \IPS\Helpers\Table\SEARCH_BOOL;
                    break;
                   
                case
'CheckboxSet':
                case
'Select':
                case
'Radio':
                   
$table->advancedSearch[ $field->column ] = array( \IPS\Helpers\Table\SEARCH_SELECT, array( 'options' => json_decode( $field->extra ), 'multiple' => $field->multiple ) );
                    break;
                   
                case
'Date':
                   
$table->advancedSearch[ $field->column ] = \IPS\Helpers\Table\SEARCH_DATE_RANGE;
                    break;
                   
                case
'Member':
                   
$table->advancedSearch[ $field->column ] = array( \IPS\Helpers\Table\SEARCH_MEMBER, array( 'multiple' => $field->multiple ) );
                    break;
                   
                case
'Number':
                   
$table->advancedSearch[ $field->column ] = \IPS\Helpers\Table\SEARCH_NUMERIC;
                    break;
               
                default:
                   
$table->advancedSearch[ $field->column ] = \IPS\Helpers\Table\SEARCH_CONTAINS_TEXT;
                    break;
            }
           
            \
IPS\Member::loggedIn()->language()->words[ 'customerTable_field_' . $field->id ] = $field->_title;
           
           
$table->parsers[ $field->column ] = array( $field, 'displayValue' );
        }
       
       
$table->rowButtons = function( $row )
        {
            return array(
               
'view'    => array(
                   
'icon'    => 'search',
                   
'title'    => 'view',
                   
'link'    => \IPS\Http\Url::internal("app=core&module=members&controller=members&do=view&tab=nexus_Main&id={$row['member_id']}"),
                ),
            );
        };
       
        \
IPS\Output::i()->title = \IPS\Member::loggedIn()->language()->addToStack('menu__nexus_customers');
        \
IPS\Output::i()->output = (string) $table;
    }
}