2016-01-04 12:48:08 +01:00
< ? php
/*
2017-06-28 15:00:53 +02:00
* 2007 - 2011 PrestaShop
2016-01-04 12:48:08 +01:00
*
* NOTICE OF LICENSE
*
* This source file is subject to the Open Software License ( OSL 3.0 )
* that is bundled with this package in the file LICENSE . txt .
* It is also available through the world - wide - web at this URL :
* http :// opensource . org / licenses / osl - 3.0 . php
* If you did not receive a copy of the license and are unable to
* obtain it through the world - wide - web , please send an email
* to license @ prestashop . com so we can send you a copy immediately .
*
* DISCLAIMER
*
* Do not edit or add to this file if you wish to upgrade PrestaShop to newer
* versions in the future . If you wish to customize PrestaShop for your
* needs please refer to http :// www . prestashop . com for more information .
*
* @ author PrestaShop SA < contact @ prestashop . com >
* @ copyright 2007 - 2011 PrestaShop SA
* @ version Release : $Revision : 7556 $
* @ license http :// opensource . org / licenses / osl - 3.0 . php Open Software License ( OSL 3.0 )
* International Registered Trademark & Property of PrestaShop SA
*/
class AdminCustomers extends AdminTab
{
public function __construct ()
{
$this -> table = 'customer' ;
$this -> className = 'Customer' ;
$this -> lang = false ;
$this -> edit = true ;
$this -> view = true ;
$this -> delete = true ;
$this -> deleted = true ;
$this -> requiredDatabase = true ;
2017-06-28 15:00:53 +02:00
2016-01-04 12:48:08 +01:00
$this -> _select = '
IFNULL ( ci . `version` , " fr " ) AS `version`
' ;
$this -> _join = '
LEFT JOIN `'._DB_PREFIX_.'customer_version` ci ON ( ci . `id_customer` = a . `id_customer` )
' ;
// $this->_select = '(YEAR(CURRENT_DATE)-YEAR(`birthday`)) - (RIGHT(CURRENT_DATE, 5)<RIGHT(`birthday`, 5)) as age, (
// SELECT c.date_add FROM '._DB_PREFIX_.'guest g
// LEFT JOIN '._DB_PREFIX_.'connections c ON c.id_guest = g.id_guest
// WHERE g.id_customer = a.id_customer
// ORDER BY c.date_add DESC
// LIMIT 1
// ) as connect';
$genders = array ( 1 => $this -> l ( 'M' ), 2 => $this -> l ( 'F' ), 9 => $this -> l ( '?' ));
$versions = array ( 'fr' => 'FR' , 'es' => 'ES' );
$this -> fieldsDisplay = array (
'id_customer' => array ( 'title' => $this -> l ( 'ID' ), 'align' => 'center' , 'width' => 25 ),
'id_gender' => array ( 'title' => $this -> l ( 'Gender' ), 'width' => 25 , 'align' => 'center' , 'icon' => array ( 1 => 'male.gif' , 2 => 'female.gif' , 'default' => 'unknown.gif' ), 'orderby' => false , 'type' => 'select' , 'select' => $genders , 'filter_key' => 'a!id_gender' ),
'lastname' => array ( 'title' => $this -> l ( 'Last Name' ), 'width' => 80 ),
'firstname' => array ( 'title' => $this -> l ( 'First name' ), 'width' => 60 ),
'email' => array ( 'title' => $this -> l ( 'E-mail address' ), 'width' => 120 , 'maxlength' => 19 ),
// 'age' => array('title' => $this->l('Age'), 'width' => 30, 'search' => false),
'active' => array ( 'title' => $this -> l ( 'Enabled' ), 'width' => 25 , 'align' => 'center' , 'active' => 'status' , 'type' => 'bool' , 'orderby' => false ),
'newsletter' => array ( 'title' => $this -> l ( 'News.' ), 'width' => 25 , 'align' => 'center' , 'type' => 'bool' , 'callback' => 'printNewsIcon' , 'orderby' => false ),
'version' => array ( 'title' => $this -> l ( 'Version' ), 'callback' => 'printVersion' , 'type' => 'select' , 'select' => $versions , 'orderby' => false , 'filter_key' => 'ci!version' ),
'optin' => array ( 'title' => $this -> l ( 'Opt.' ), 'width' => 25 , 'align' => 'center' , 'type' => 'bool' , 'callback' => 'printOptinIcon' , 'orderby' => false ),
'date_add' => array ( 'title' => $this -> l ( 'Registration' ), 'width' => 30 , 'type' => 'date' , 'align' => 'right' ),
// 'connect' => array('title' => $this->l('Connection'), 'width' => 60, 'type' => 'datetime', 'search' => false)
);
$this -> optionTitle = $this -> l ( 'Customers options' );
$this -> _fieldsOptions = array (
'PS_PASSWD_TIME_FRONT' => array ( 'title' => $this -> l ( 'Regenerate password:' ), 'desc' => $this -> l ( 'Security minimum time to wait to regenerate the password' ), 'validation' => 'isUnsignedInt' , 'cast' => 'intval' , 'size' => 5 , 'type' => 'text' , 'suffix' => ' ' . $this -> l ( 'minutes' ))
);
parent :: __construct ();
}
2017-06-28 15:00:53 +02:00
2016-01-04 12:48:08 +01:00
public function postProcess ()
{
global $currentIndex ;
2017-06-28 15:00:53 +02:00
2016-01-04 12:48:08 +01:00
if ( Tools :: isSubmit ( 'submitDel' . $this -> table ) OR Tools :: isSubmit ( 'delete' . $this -> table ))
{
$deleteForm = '
< form action = " '.htmlentities( $_SERVER['REQUEST_URI'] ).' " method = " post " >
< fieldset >< legend > '.$this->l(' How do you want to delete your customer ( s ) ? ').' </ legend >
'.$this->l(' You have two ways to delete a customer , please choose what you want to do . ').'
< p >
< input type = " radio " name = " deleteMode " value = " real " id = " deleteMode_real " />
< label for = " deleteMode_real " style = " float:none " > '.$this->l(' I want to delete my customer ( s ) for real , all data will be removed from the database . A customer with the same e - mail address will be able to register again . ').' </ label >
</ p >
< p >
< input type = " radio " name = " deleteMode " value = " deleted " id = " deleteMode_deleted " />
< label for = " deleteMode_deleted " style = " float:none " > '.$this->l(' I don\ 't want my customer(s) to register again. The customer(s) will be removed from this list but all data will be kept in the database.' ) . ' </ label >
</ p > ' ;
foreach ( $_POST as $key => $value )
if ( is_array ( $value ))
foreach ( $value as $val )
$deleteForm .= '<input type="hidden" name="' . htmlentities ( $key ) . '[]" value="' . htmlentities ( $val ) . '" />' ;
else
$deleteForm .= '<input type="hidden" name="' . htmlentities ( $key ) . '" value="' . htmlentities ( $value ) . '" />' ;
$deleteForm .= ' <br /><input type="submit" class="button" value="' . $this -> l ( ' Delete ' ) . ' " />
</ fieldset >
</ form >
< div class = " clear " >& nbsp ; </ div > ' ;
}
2017-06-28 15:00:53 +02:00
2016-01-04 12:48:08 +01:00
if ( Tools :: getValue ( 'submitAdd' . $this -> table ))
{
$groupList = Tools :: getValue ( 'groupBox' );
2017-06-28 15:00:53 +02:00
2016-01-04 12:48:08 +01:00
/* Checking fields validity */
$this -> validateRules ();
if ( ! sizeof ( $this -> _errors ))
{
$id = ( int )( Tools :: getValue ( 'id_' . $this -> table ));
if ( isset ( $id ) AND ! empty ( $id ))
{
if ( $this -> tabAccess [ 'edit' ] !== '1' )
$this -> _errors [] = Tools :: displayError ( 'You do not have permission to edit here.' );
else
{
$object = new $this -> className ( $id );
if ( Validate :: isLoadedObject ( $object ))
{
$customer_email = strval ( Tools :: getValue ( 'email' ));
2017-06-28 15:00:53 +02:00
2016-01-04 12:48:08 +01:00
// check if e-mail already used
if ( $customer_email != $object -> email )
{
$customer = new Customer ();
$customer -> getByEmail ( $customer_email );
if ( $customer -> id )
$this -> _errors [] = Tools :: displayError ( 'An account already exists for this e-mail address:' ) . ' ' . $customer_email ;
}
2017-06-28 15:00:53 +02:00
2016-01-04 12:48:08 +01:00
if ( ! is_array ( $groupList ) OR sizeof ( $groupList ) == 0 )
$this -> _errors [] = Tools :: displayError ( 'Customer must be in at least one group.' );
else
if ( ! in_array ( Tools :: getValue ( 'id_default_group' ), $groupList ))
$this -> _errors [] = Tools :: displayError ( 'Default customer group must be selected in group box.' );
2017-06-28 15:00:53 +02:00
// Updating customer use credits
2016-01-04 12:48:08 +01:00
$sql = 'SELECT id_customer FROM `' . _DB_PREFIX_ . 'customer_credits` WHERE id_customer = ' . $object -> id ;
if ( Db :: getInstance () -> getValue ( $sql )){
// already present
if ( Tools :: getValue ( 'use_credits' ) == 1 ){
Db :: getInstance () -> execute ( 'DELETE FROM `' . _DB_PREFIX_ . 'customer_credits` WHERE id_customer = ' . $object -> id );
}
} else {
// add if necessary
if ( Tools :: getValue ( 'use_credits' ) == 0 ){
Db :: getInstance () -> execute ( 'INSERT INTO `' . _DB_PREFIX_ . 'customer_credits` VALUES (' . $object -> id . ')' );
}
}
2017-06-28 15:00:53 +02:00
2016-01-04 12:48:08 +01:00
// Updating customer's group
if ( ! sizeof ( $this -> _errors ))
{
$object -> cleanGroups ();
if ( is_array ( $groupList ) AND sizeof ( $groupList ) > 0 )
$object -> addGroups ( $groupList );
}
}
else
$this -> _errors [] = Tools :: displayError ( 'An error occurred while loading object.' ) . ' <b>' . $this -> table . '</b> ' . Tools :: displayError ( '(cannot load object)' );
}
}
else
{
if ( $this -> tabAccess [ 'add' ] === '1' )
{
$object = new $this -> className ();
$this -> copyFromPost ( $object , $this -> table );
if ( ! $object -> add ())
$this -> _errors [] = Tools :: displayError ( 'An error occurred while creating object.' ) . ' <b>' . $this -> table . ' (' . mysql_error () . ')</b>' ;
elseif (( $_POST [ $this -> identifier ] = $object -> id /* voluntary */ ) AND $this -> postImage ( $object -> id ) AND ! sizeof ( $this -> _errors ) AND $this -> _redirect )
{
// Add Associated groups
$group_list = Tools :: getValue ( 'groupBox' );
if ( is_array ( $group_list ) && sizeof ( $group_list ) > 0 )
$object -> addGroups ( $group_list , true );
$parent_id = ( int )( Tools :: getValue ( 'id_parent' , 1 ));
// Save and stay on same form
if ( Tools :: isSubmit ( 'submitAdd' . $this -> table . 'AndStay' ))
Tools :: redirectAdmin ( $currentIndex . '&' . $this -> identifier . '=' . $object -> id . '&conf=3&update' . $this -> table . '&token=' . $this -> token );
// Save and back to parent
if ( Tools :: isSubmit ( 'submitAdd' . $this -> table . 'AndBackToParent' ))
Tools :: redirectAdmin ( $currentIndex . '&' . $this -> identifier . '=' . $parent_id . '&conf=3&token=' . $this -> token );
// Default behavior (save and back)
Tools :: redirectAdmin ( $currentIndex . ( $parent_id ? '&' . $this -> identifier . '=' . $object -> id : '' ) . '&conf=3&token=' . $this -> token );
}
}
else
$this -> _errors [] = Tools :: displayError ( 'You do not have permission to add here.' );
}
}
}
elseif ( Tools :: isSubmit ( 'delete' . $this -> table ) AND $this -> tabAccess [ 'delete' ] === '1' )
{
switch ( Tools :: getValue ( 'deleteMode' ))
{
case 'real' :
$this -> deleted = false ;
Discount :: deleteByIdCustomer (( int )( Tools :: getValue ( 'id_customer' )));
2017-06-28 15:00:53 +02:00
Db :: getInstance () -> Execute ( 'UPDATE `' . _DB_PREFIX_ . 'customer_thread` SET `id_customer` = 0 WHERE `id_customer` = ' . ( int )( Tools :: getValue ( 'id_customer' )));
2016-01-04 12:48:08 +01:00
break ;
case 'deleted' :
$this -> deleted = true ;
break ;
default :
echo $deleteForm ;
if ( isset ( $_POST [ 'delete' . $this -> table ]))
unset ( $_POST [ 'delete' . $this -> table ]);
if ( isset ( $_GET [ 'delete' . $this -> table ]))
unset ( $_GET [ 'delete' . $this -> table ]);
break ;
}
}
elseif ( Tools :: isSubmit ( 'submitDel' . $this -> table ) AND $this -> tabAccess [ 'delete' ] === '1' )
{
switch ( Tools :: getValue ( 'deleteMode' ))
{
case 'real' :
$this -> deleted = false ;
2017-06-28 15:00:53 +02:00
foreach ( Tools :: getValue ( 'customerBox' ) as $id_customer ){
Db :: getInstance () -> Execute ( 'UPDATE `' . _DB_PREFIX_ . 'customer_thread` SET `id_customer` = 0 WHERE `id_customer` = ' . ( int ) $id_customer );
2016-01-04 12:48:08 +01:00
Discount :: deleteByIdCustomer (( int )( $id_customer ));
2017-06-28 15:00:53 +02:00
}
2016-01-04 12:48:08 +01:00
break ;
case 'deleted' :
$this -> deleted = true ;
break ;
default :
echo $deleteForm ;
if ( isset ( $_POST [ 'submitDel' . $this -> table ]))
unset ( $_POST [ 'submitDel' . $this -> table ]);
if ( isset ( $_GET [ 'submitDel' . $this -> table ]))
unset ( $_GET [ 'submitDel' . $this -> table ]);
break ;
}
}
elseif ( Tools :: isSubmit ( 'submitGuestToCustomer' ) AND Tools :: getValue ( 'id_customer' ))
{
if ( $this -> tabAccess [ 'edit' ] === '1' )
{
$customer = new Customer (( int ) Tools :: getValue ( 'id_customer' ));
if ( ! Validate :: isLoadedObject ( $customer ))
$this -> _errors [] = Tools :: displayError ( 'This customer does not exist.' );
if ( Customer :: customerExists ( $customer -> email ))
$this -> _errors [] = Tools :: displayError ( 'This customer already exist as non-guest.' );
elseif ( $customer -> transformToCustomer ( Tools :: getValue ( 'id_lang' , Configuration :: get ( 'PS_LANG_DEFAULT' ))))
Tools :: redirectAdmin ( $currentIndex . '&' . $this -> identifier . '=' . $customer -> id . '&conf=3&token=' . $this -> token );
else
$this -> _errors [] = Tools :: displayError ( 'An error occurred while updating customer.' );
}
else
$this -> _errors [] = Tools :: displayError ( 'You do not have permission to edit here.' );
} elseif ( Tools :: isSubmit ( 'changeNewsletterVal' ) AND Tools :: getValue ( 'id_customer' ))
{
$id_customer = ( int ) Tools :: getValue ( 'id_customer' );
$customer = new Customer ( $id_customer );
if ( ! Validate :: isLoadedObject ( $customer ))
$this -> _errors [] = Tools :: displayError ( 'An error occurred while updating customer.' );
$update = Db :: getInstance () -> Execute ( 'UPDATE `' . _DB_PREFIX_ . 'customer` SET newsletter = ' . ( $customer -> newsletter ? 0 : 1 ) . ' WHERE `id_customer` = ' . ( int )( $customer -> id ));
if ( ! $update )
$this -> _errors [] = Tools :: displayError ( 'An error occurred while updating customer.' );
2017-06-28 15:00:53 +02:00
Tools :: redirectAdmin ( $currentIndex . '&token=' . $this -> token );
2016-01-04 12:48:08 +01:00
} elseif ( Tools :: isSubmit ( 'changeOptinVal' ) AND Tools :: getValue ( 'id_customer' ))
{
$id_customer = ( int ) Tools :: getValue ( 'id_customer' );
$customer = new Customer ( $id_customer );
if ( ! Validate :: isLoadedObject ( $customer ))
$this -> _errors [] = Tools :: displayError ( 'An error occurred while updating customer.' );
$update = Db :: getInstance () -> Execute ( 'UPDATE `' . _DB_PREFIX_ . 'customer` SET optin = ' . ( $customer -> optin ? 0 : 1 ) . ' WHERE `id_customer` = ' . ( int )( $customer -> id ));
if ( ! $update )
$this -> _errors [] = Tools :: displayError ( 'An error occurred while updating customer.' );
Tools :: redirectAdmin ( $currentIndex . '&token=' . $this -> token );
}
2017-06-28 15:00:53 +02:00
2016-01-04 12:48:08 +01:00
return parent :: postProcess ();
}
public function viewcustomer ()
{
global $currentIndex , $cookie , $link ;
$irow = 0 ;
$configurations = Configuration :: getMultiple ( array ( 'PS_LANG_DEFAULT' , 'PS_CURRENCY_DEFAULT' ));
$defaultLanguage = ( int )( $configurations [ 'PS_LANG_DEFAULT' ]);
$defaultCurrency = ( int )( $configurations [ 'PS_CURRENCY_DEFAULT' ]);
if ( ! ( $customer = $this -> loadObject ()))
return ;
$customerStats = $customer -> getStats ();
$addresses = $customer -> getAddresses ( $defaultLanguage );
$products = $customer -> getBoughtProducts ();
$discounts = Discount :: getCustomerDiscounts ( $defaultLanguage , ( int ) $customer -> id , false , false );
$orders = Order :: getCustomerOrders (( int ) $customer -> id , true );
$carts = Cart :: getCustomerCarts (( int ) $customer -> id );
$groups = $customer -> getGroups ();
$messages = CustomerThread :: getCustomerMessages (( int ) $customer -> id );
$referrers = Referrer :: getReferrers (( int ) $customer -> id );
if ( $totalCustomer = Db :: getInstance () -> getValue ( 'SELECT SUM(total_paid_real) FROM ' . _DB_PREFIX_ . 'orders WHERE id_customer = ' . $customer -> id . ' AND valid = 1' ))
{
Db :: getInstance () -> getValue ( 'SELECT SQL_CALC_FOUND_ROWS COUNT(*) FROM ' . _DB_PREFIX_ . 'orders WHERE valid = 1 GROUP BY id_customer HAVING SUM(total_paid_real) > ' . $totalCustomer );
$countBetterCustomers = ( int ) Db :: getInstance () -> getValue ( 'SELECT FOUND_ROWS()' ) + 1 ;
}
else
$countBetterCustomers = '-' ;
echo '
< fieldset style = " width:400px;float: left " >< div style = " float: right " >< a href = " '. $currentIndex .'&addcustomer&id_customer='. $customer->id .'&token='. $this->token .' " >< img src = " ../img/admin/edit.gif " /></ a ></ div >
< span style = " font-weight: bold; font-size: 14px; " > '.$customer->firstname.' '.$customer->lastname.' </ span >
< img src = " ../img/admin/'.( $customer->id_gender == 2 ? 'female' : ( $customer->id_gender == 1 ? 'male' : 'unknown')).'.gif " style = " margin-bottom: 5px " />< br />
< a href = " mailto:'. $customer->email .' " style = " text-decoration: underline; color: blue " > '.$customer->email.' </ a >< br />< br />
'.$this->l(' ID : ').' '.sprintf(' % 06 d ', $customer->id).' < br />
'.$this->l(' Registration date : ').' '.Tools::displayDate($customer->date_add, (int)($cookie->id_lang), true).' < br />
'.$this->l(' Last visit : ').' '.($customerStats[' last_visit '] ? Tools::displayDate($customerStats[' last_visit '], (int)($cookie->id_lang), true) : $this->l(' never ')).' < br />
'.($countBetterCustomers != ' - ' ? $this->l(' Rank : #').' '.(int)$countBetterCustomers.'<br />' : '').'
</ fieldset >
< fieldset style = " width:300px;float:left;margin-left:50px " >
< div style = " float: right " >
< a href = " '. $currentIndex .'&addcustomer&id_customer='. $customer->id .'&token='. $this->token .' " >< img src = " ../img/admin/edit.gif " /></ a >
</ div >
'.$this->l(' Newsletter : ').' '.($customer->newsletter ? ' < img src = " ../img/admin/enabled.gif " /> ' : ' < img src = " ../img/admin/disabled.gif " /> ').' < br />
'.$this->l(' Opt - in : ').' '.($customer->optin ? ' < img src = " ../img/admin/enabled.gif " /> ' : ' < img src = " ../img/admin/disabled.gif " /> ').' < br />
'.$this->l(' Age : ').' '.$customerStats[' age '].' '.((!empty($customer->birthday[' age '])) ? ' ( '.Tools::displayDate($customer->birthday, (int)($cookie->id_lang)).' ) ' : $this->l(' unknown ')).' < br />< br />
'.$this->l(' Last update : ').' '.Tools::displayDate($customer->date_upd, (int)($cookie->id_lang), true).' < br />
'.$this->l(' Status : ').' '.($customer->active ? ' < img src = " ../img/admin/enabled.gif " /> ' : ' < img src = " ../img/admin/disabled.gif " /> ' );
if ( $customer -> isGuest ())
{
echo '
< div >
'.$this->l(' This customer is registered as ').' < b > '.$this->l(' guest ').' </ b > ' ;
if ( ! Customer :: customerExists ( $customer -> email ))
{
echo '
< form method = " POST " action = " index.php?tab=AdminCustomers&id_customer='.(int) $customer->id .'&token='.Tools::getAdminTokenLite('AdminCustomers').' " >
< input type = " hidden " name = " id_lang " value = " '.(int)(sizeof( $orders ) ? $orders[0] ['id_lang'] : Configuration::get('PS_LANG_DEFAULT')).' " />
< p class = " center " >< input class = " button " type = " submit " name = " submitGuestToCustomer " value = " '. $this->l ('Transform to customer').' " /></ p >
'.$this->l(' This feature generates a random password and sends an e - mail to the customer ').' </ form > ' ;
}
else
echo '</div><div><b style="color:red;">' . $this -> l ( 'A registered customer account exists with the same email address' ) . '</b>' ;
echo '
</ div >
' ;
}
echo '
</ fieldset >
< div class = " clear " >& nbsp ; </ div > ' ;
2017-06-28 15:00:53 +02:00
2016-01-04 12:48:08 +01:00
echo '<fieldset style="height:190px"><legend><img src="../img/admin/cms.gif" /> ' . $this -> l ( 'Add a private note' ) . ' </ legend >
< p > '.$this->l(' This note will be displayed to all the employees but not to the customer . ').' </ p >
< form action = " ajax.php " method = " post " onsubmit = " saveCustomerNote();return false; " id = " customer_note " >
< textarea name = " note " id = " noteContent " style = " width:600px;height:100px " onkeydown = " $ ( \ '#submitCustomerNote \ ').removeAttr( \ 'disabled \ '); " > '.Tools::htmlentitiesUTF8($customer->note).' </ textarea >< br />
< input type = " submit " id = " submitCustomerNote " class = " button " value = " '. $this->l (' Save ').' " style = " float:left;margin-top:5px " disabled = " disabled " />
< span id = " note_feedback " style = " float:left;margin:10px 0 0 10px " ></ span >
</ form >
</ fieldset >
< div class = " clear " >& nbsp ; </ div >
< script type = " text/javascript " >
function saveCustomerNote ()
{
$ ( " #note_feedback " ) . html ( " <img src= \" ../img/loader.gif \" /> " ) . show ();
var noteContent = $ ( " #noteContent " ) . val ();
$ . post ( " ajax.php " , { submitCustomerNote : 1 , id_customer : '.(int)$customer->id.' , note : noteContent }, function ( r ) {
$ ( " #note_feedback " ) . html ( " " ) . hide ();
if ( r == " ok " )
{
$ ( " #note_feedback " ) . html ( " <b style= \" color:green \" >'.addslashes( $this->l ('Your note has been saved')).'</b> " ) . fadeIn ( 400 );
$ ( " #submitCustomerNote " ) . attr ( " disabled " , " disabled " );
}
else if ( r == " error:validation " )
$ ( " #note_feedback " ) . html ( " <b style= \" color:red \" >'.addslashes( $this->l ('Error: your note is not valid')).'</b> " ) . fadeIn ( 400 );
else if ( r == " error:update " )
$ ( " #note_feedback " ) . html ( " <b style= \" color:red \" >'.addslashes( $this->l ('Error: cannot save your note')).'</b> " ) . fadeIn ( 400 );
$ ( " #note_feedback " ) . fadeOut ( 3000 );
});
}
</ script > ' ;
2017-06-28 15:00:53 +02:00
2016-01-04 12:48:08 +01:00
echo '<h2>' . $this -> l ( 'Messages' ) . ' (' . sizeof ( $messages ) . ')</h2>' ;
if ( sizeof ( $messages ))
{
echo '
< table cellspacing = " 0 " cellpadding = " 0 " class = " table " >
< tr >
< th class = " center " > '.$this->l(' Status ').' </ th >
< th class = " center " > '.$this->l(' Message ').' </ th >
< th class = " center " > '.$this->l(' Sent on ').' </ th >
</ tr > ' ;
foreach ( $messages AS $message )
echo ' < tr >
< td > '.$message[' status '].' </ td >
< td >< a href = " index.php?tab=AdminCustomerThreads&id_customer_thread='.(int)( $message['id_customer_thread'] ).'&viewcustomer_thread&token='.Tools::getAdminTokenLite('AdminCustomerThreads').' " > '.substr(strip_tags(html_entity_decode($message[' message '], ENT_NOQUOTES, ' UTF - 8 ')), 0, 75).' ...</ a ></ td >
< td > '.Tools::displayDate($message[' date_add '], (int)($cookie->id_lang), true).' </ td >
</ tr > ' ;
echo ' </ table >
< div class = " clear " >& nbsp ; </ div > ' ;
}
else
echo $customer -> firstname . ' ' . $customer -> lastname . ' ' . $this -> l ( 'has never contacted you.' );
2017-10-31 12:24:29 +01:00
2016-01-04 12:48:08 +01:00
// display hook specified to this page : AdminCustomers
if (( $hook = Module :: hookExec ( 'adminCustomers' , array ( 'id_customer' => $customer -> id ))) !== false )
echo '<div>' . $hook . '</div>' ;
echo '<div class="clear"> </div>' ;
echo '<h2>' . $this -> l ( 'Groups' ) . ' (' . sizeof ( $groups ) . ')</h2>' ;
if ( $groups AND sizeof ( $groups ))
{
echo '
< table cellspacing = " 0 " cellpadding = " 0 " class = " table " >
< tr >
< th class = " center " > '.$this->l(' ID ').' </ th >
< th class = " center " > '.$this->l(' Name ').' </ th >
< th class = " center " > '.$this->l(' Actions ').' </ th >
</ tr > ' ;
$tokenGroups = Tools :: getAdminToken ( 'AdminGroups' . ( int )( Tab :: getIdFromClassName ( 'AdminGroups' )) . ( int )( $cookie -> id_employee ));
foreach ( $groups AS $group )
{
$objGroup = new Group ( $group );
echo '
< tr '.($irow++ % 2 ? ' class = " alt_row " ' : ' ').' style = " cursor: pointer " onclick = " document.location = \ '?tab=AdminGroups&id_group='. $objGroup->id .'&viewgroup&token='. $tokenGroups .' \ ' " >
< td class = " center " > '.$objGroup->id.' </ td >
< td > '.$objGroup->name[$defaultLanguage].' </ td >
< td align = " center " >< a href = " ?tab=AdminGroups&id_group='. $objGroup->id .'&viewgroup&token='. $tokenGroups .' " >< img src = " ../img/admin/details.gif " /></ a ></ td >
</ tr > ' ;
}
echo '
</ table > ' ;
}
echo '<div class="clear"> </div>' ;
echo '<h2>' . $this -> l ( 'Orders' ) . ' (' . sizeof ( $orders ) . ')</h2>' ;
if ( $orders AND sizeof ( $orders ))
{
$totalOK = 0 ;
$ordersOK = array ();
$ordersKO = array ();
$tokenOrders = Tools :: getAdminToken ( 'AdminOrders' . ( int ) Tab :: getIdFromClassName ( 'AdminOrders' ) . ( int ) $cookie -> id_employee );
foreach ( $orders AS $order )
if ( $order [ 'valid' ])
{
$ordersOK [] = $order ;
$totalOK += $order [ 'total_paid_real' ];
}
else
$ordersKO [] = $order ;
$orderHead = '
< table cellspacing = " 0 " cellpadding = " 0 " class = " table float " >
< tr >
< th class = " center " > '.$this->l(' ID ').' </ th >
< th class = " center " > '.$this->l(' Date ').' </ th >
< th class = " center " > '.$this->l(' Products ').' </ th >
< th class = " center " > '.$this->l(' Total paid ').' </ th >
< th class = " center " > '.$this->l(' Payment ').' </ th >
< th class = " center " > '.$this->l(' State ').' </ th >
< th class = " center " > '.$this->l(' Actions ').' </ th >
</ tr > ' ;
$orderFoot = '</table>' ;
if ( $countOK = sizeof ( $ordersOK ))
{
echo '<div style="float:left;margin-right:20px"><h3 style="color:green;font-weight:700">' . $this -> l ( 'Valid orders:' ) . ' ' . $countOK . ' ' . $this -> l ( 'for' ) . ' ' . Tools :: displayPrice ( $totalOK , new Currency ( $defaultCurrency )) . '</h3>' . $orderHead ;
foreach ( $ordersOK AS $order )
echo '<tr ' . ( $irow ++ % 2 ? 'class="alt_row"' : '' ) . ' style="cursor: pointer" onclick="document.location = \'?tab=AdminOrders&id_order=' . $order [ 'id_order' ] . '&vieworder&token=' . $tokenOrders . ' \ ' " >
< td class = " center " > '.$order[' id_order '].' </ td >
< td > '.Tools::displayDate($order[' date_add '], (int)($cookie->id_lang)).' </ td >
< td align = " right " > '.$order[' nb_products '].' </ td >
< td align = " right " > '.Tools::displayPrice($order[' total_paid_real '], new Currency((int)($order[' id_currency ']))).' </ td >
< td > '.$order[' payment '].' </ td >
< td > '.$order[' order_state '].' </ td >
< td align = " center " >< a href = " ?tab=AdminOrders&id_order='. $order['id_order'] .'&vieworder&token='. $tokenOrders .' " >< img src = " ../img/admin/details.gif " /></ a ></ td >
</ tr > ' ;
echo $orderFoot . '</div>' ;
}
if ( $countKO = sizeof ( $ordersKO ))
{
echo '<div style="float:left;margin-right:20px"><h3 style="color:red;font-weight:700">' . $this -> l ( 'Invalid orders:' ) . ' ' . $countKO . '</h3>' . $orderHead ;
foreach ( $ordersKO AS $order )
echo '
< tr '.($irow++ % 2 ? ' class = " alt_row " ' : ' ').' style = " cursor: pointer " onclick = " document.location = \ '?tab=AdminOrders&id_order='. $order['id_order'] .'&vieworder&token='. $tokenOrders .' \ ' " >
< td class = " center " > '.$order[' id_order '].' </ td >
< td > '.Tools::displayDate($order[' date_add '], (int)($cookie->id_lang)).' </ td >
< td align = " right " > '.$order[' nb_products '].' </ td >
< td align = " right " > '.Tools::displayPrice($order[' total_paid_real '], new Currency((int)($order[' id_currency ']))).' </ td >
< td > '.$order[' payment '].' </ td >
< td > '.$order[' order_state '].' </ td >
< td align = " center " >< a href = " ?tab=AdminOrders&id_order='. $order['id_order'] .'&vieworder&token='. $tokenOrders .' " >< img src = " ../img/admin/details.gif " /></ a ></ td >
</ tr > ' ;
echo $orderFoot . '</div><div class="clear"> </div>' ;
}
}
else
echo $customer -> firstname . ' ' . $customer -> lastname . ' ' . $this -> l ( 'has not placed any orders yet' );
2017-06-28 15:00:53 +02:00
2016-01-04 12:48:08 +01:00
if ( $products AND sizeof ( $products ))
{
echo ' < div class = " clear " >& nbsp ; </ div >
< h2 > '.$this->l(' Products ').' ( '.sizeof($products).' ) </ h2 >
< table cellspacing = " 0 " cellpadding = " 0 " class = " table " >
< tr >
< th class = " center " > '.$this->l(' Date ').' </ th >
< th class = " center " > '.$this->l(' Name ').' </ th >
< th class = " center " > '.$this->l(' Quantity ').' </ th >
< th class = " center " > '.$this->l(' Actions ').' </ th >
</ tr > ' ;
$tokenOrders = Tools :: getAdminToken ( 'AdminOrders' . ( int )( Tab :: getIdFromClassName ( 'AdminOrders' )) . ( int )( $cookie -> id_employee ));
foreach ( $products AS $product )
echo '
< tr '.($irow++ % 2 ? ' class = " alt_row " ' : ' ').' style = " cursor: pointer " onclick = " document.location = \ '?tab=AdminOrders&id_order='. $product['id_order'] .'&vieworder&token='. $tokenOrders .' \ ' " >
< td > '.Tools::displayDate($product[' date_add '], (int)($cookie->id_lang), true).' </ td >
< td > '.$product[' product_name '].' </ td >
< td align = " right " > '.$product[' product_quantity '].' </ td >
< td align = " center " >< a href = " ?tab=AdminOrders&id_order='. $product['id_order'] .'&vieworder&token='. $tokenOrders .' " >< img src = " ../img/admin/details.gif " /></ a ></ td >
</ tr > ' ;
echo '
</ table > ' ;
}
echo ' < div class = " clear " >& nbsp ; </ div >
< h2 > '.$this->l(' Addresses ').' ( '.sizeof($addresses).' ) </ h2 > ' ;
if ( sizeof ( $addresses ))
{
echo '
< table cellspacing = " 0 " cellpadding = " 0 " class = " table " >
< tr >
< th > '.$this->l(' Company ').' </ th >
< th > '.$this->l(' Name ').' </ th >
< th > '.$this->l(' Address ').' </ th >
< th > '.$this->l(' Country ').' </ th >
< th > '.$this->l(' Phone number ( s ) ').' </ th >
< th > '.$this->l(' Actions ').' </ th >
</ tr > ' ;
$tokenAddresses = Tools :: getAdminToken ( 'AdminAddresses' . ( int )( Tab :: getIdFromClassName ( 'AdminAddresses' )) . ( int )( $cookie -> id_employee ));
foreach ( $addresses AS $address )
echo '
< tr '.($irow++ % 2 ? ' class = " alt_row " ' : ' ').' >
< td > '.($address[' company '] ? $address[' company '] : ' -- ').' </ td >
< td > '.$address[' firstname '].' '.$address[' lastname '].' </ td >
< td > '.$address[' address1 '].($address[' address2 '] ? ' '.$address[' address2 '] : ' ').' '.$address[' postcode '].' '.$address[' city '].' </ td >
< td > '.$address[' country '].' </ td >
< td > '.($address[' phone '] ? ($address[' phone '].($address[' phone_mobile '] ? ' < br /> '.$address[' phone_mobile '] : ' ')) : ($address[' phone_mobile '] ? ' < br /> '.$address[' phone_mobile '] : ' -- ')).' </ td >
< td align = " center " >
< a href = " ?tab=AdminAddresses&id_address='. $address['id_address'] .'&addaddress&token='. $tokenAddresses .' " >< img src = " ../img/admin/edit.gif " /></ a >
< a href = " ?tab=AdminAddresses&id_address='. $address['id_address'] .'&deleteaddress&token='. $tokenAddresses .' " >< img src = " ../img/admin/delete.gif " /></ a >
</ td >
</ tr > ' ;
echo '
</ table > ' ;
}
else
echo $customer -> firstname . ' ' . $customer -> lastname . ' ' . $this -> l ( 'has not registered any addresses yet' ) . '.' ;
echo ' < div class = " clear " >& nbsp ; </ div >
< h2 > '.$this->l(' Discounts ').' ( '.sizeof($discounts).' ) </ h2 > ' ;
if ( sizeof ( $discounts ))
{
echo '
< table cellspacing = " 0 " cellpadding = " 0 " class = " table " >
< tr >
< th > '.$this->l(' ID ').' </ th >
< th > '.$this->l(' Code ').' </ th >
< th > '.$this->l(' Type ').' </ th >
< th > '.$this->l(' Value ').' </ th >
< th > '.$this->l(' Qty available ').' </ th >
< th > '.$this->l(' Status ').' </ th >
< th > '.$this->l(' Actions ').' </ th >
</ tr > ' ;
$tokenDiscounts = Tools :: getAdminToken ( 'AdminDiscounts' . ( int )( Tab :: getIdFromClassName ( 'AdminDiscounts' )) . ( int )( $cookie -> id_employee ));
foreach ( $discounts AS $discount )
{
echo '
< tr '.($irow++ % 2 ? ' class = " alt_row " ' : ' ').' >
< td align = " center " > '.$discount[' id_discount '].' </ td >
< td > '.$discount[' name '].' </ td >
< td > '.$discount[' type '].' </ td >
< td align = " right " > '.$discount[' value '].' </ td >
< td align = " center " > '.$discount[' quantity_for_user '].' </ td >
< td align = " center " >< img src = " ../img/admin/'.( $discount['active'] ? 'enabled.gif' : 'disabled.gif').' " alt = " '. $this->l ('Status').' " title = " '. $this->l ('Status').' " /></ td >
< td align = " center " >
< a href = " ?tab=AdminDiscounts&id_discount='. $discount['id_discount'] .'&adddiscount&token='. $tokenDiscounts .' " >< img src = " ../img/admin/edit.gif " /></ a >
< a href = " ?tab=AdminDiscounts&id_discount='. $discount['id_discount'] .'&deletediscount&token='. $tokenDiscounts .' " >< img src = " ../img/admin/delete.gif " /></ a >
</ td >
</ tr > ' ;
}
echo '
</ table > ' ;
}
else
echo $customer -> firstname . ' ' . $customer -> lastname . ' ' . $this -> l ( 'has no discount vouchers' ) . '.' ;
echo '<div class="clear"> </div>' ;
2017-06-28 15:00:53 +02:00
2016-01-04 12:48:08 +01:00
echo ' < div style = " float:left " >
< h2 > '.$this->l(' Carts ').' ( '.sizeof($carts).' ) </ h2 > ' ;
if ( $carts AND sizeof ( $carts ))
{
echo '
< table cellspacing = " 0 " cellpadding = " 0 " class = " table " >
< tr >
< th class = " center " > '.$this->l(' ID ').' </ th >
< th class = " center " > '.$this->l(' Date ').' </ th >
< th class = " center " > '.$this->l(' Total ').' </ th >
< th class = " center " > '.$this->l(' Carrier ').' </ th >
< th class = " center " > '.$this->l(' Actions ').' </ th >
</ tr > ' ;
$tokenCarts = Tools :: getAdminToken ( 'AdminCarts' . ( int )( Tab :: getIdFromClassName ( 'AdminCarts' )) . ( int )( $cookie -> id_employee ));
foreach ( $carts AS $cart )
{
$cartI = new Cart (( int )( $cart [ 'id_cart' ]));
$summary = $cartI -> getSummaryDetails ();
$currency = new Currency (( int )( $cart [ 'id_currency' ]));
$carrier = new Carrier (( int )( $cart [ 'id_carrier' ]));
echo '
< tr '.($irow++ % 2 ? ' class = " alt_row " ' : ' ').' style = " cursor: pointer " onclick = " document.location = \ '?tab=AdminCarts&id_cart='. $cart['id_cart'] .'&viewcart&token='. $tokenCarts .' \ ' " >
< td class = " center " > '.sprintf(' % 06 d ', $cart[' id_cart ']).' </ td >
< td > '.Tools::displayDate($cart[' date_add '], (int)($cookie->id_lang), true).' </ td >
< td align = " right " > '.Tools::displayPrice($summary[' total_price '], $currency).' </ td >
< td > '.$carrier->name.' </ td >
< td align = " center " >< a href = " index.php?tab=AdminCarts&id_cart='. $cart['id_cart'] .'&viewcart&token='. $tokenCarts .' " >< img src = " ../img/admin/details.gif " /></ a ></ td >
</ tr > ' ;
}
echo '
</ table > ' ;
}
else
echo $this -> l ( 'No cart available' ) . '.' ;
echo '</div>' ;
2017-06-28 15:00:53 +02:00
2016-01-04 12:48:08 +01:00
$interested = Db :: getInstance () -> ExecuteS ( 'SELECT DISTINCT id_product FROM ' . _DB_PREFIX_ . 'cart_product cp INNER JOIN ' . _DB_PREFIX_ . 'cart c on c.id_cart = cp.id_cart WHERE c.id_customer = ' . ( int ) $customer -> id . ' AND cp . id_product NOT IN (
SELECT product_id FROM '._DB_PREFIX_.' orders o inner join '._DB_PREFIX_.' order_detail od ON o . id_order = od . id_order WHERE o . valid = 1 AND o . id_customer = '.(int)$customer->id.' ) ' );
if ( count ( $interested ))
{
echo ' < div style = " float:left;margin-left:20px " >
< h2 > '.$this->l(' Products ').' ( '.count($interested).' ) </ h2 >
< table cellspacing = " 0 " cellpadding = " 0 " class = " table " > ' ;
foreach ( $interested as $p )
{
$product = new Product (( int ) $p [ 'id_product' ], false , $cookie -> id_lang );
echo '
< tr '.($irow++ % 2 ? ' class = " alt_row " ' : ' ').' style = " cursor: pointer " onclick = " document.location = \ ''. $link->getProductLink ((int) $product->id , $product->link_rewrite , Category::getLinkRewrite( $product->id_category_default , (int)( $cookie->id_lang ))).' \ ' " >
< td > '.(int)$product->id.' </ td >
< td > '.Tools::htmlentitiesUTF8($product->name).' </ td >
< td align = " center " >< a href = " '. $link->getProductLink ((int) $product->id , $product->link_rewrite , Category::getLinkRewrite( $product->id_category_default , (int)( $cookie->id_lang ))).' " >< img src = " ../img/admin/details.gif " /></ a ></ td >
</ tr > ' ;
}
echo '</table></div>' ;
}
2017-06-28 15:00:53 +02:00
2016-01-04 12:48:08 +01:00
echo '<div class="clear"> </div>' ;
/* Last connections */
$connections = $customer -> getLastConnections ();
2017-06-28 15:00:53 +02:00
if ( sizeof ( $connections ))
2016-01-04 12:48:08 +01:00
{
echo '<h2>' . $this -> l ( 'Last connections' ) . ' </ h2 >
< table cellspacing = " 0 " cellpadding = " 0 " class = " table " >
< tr >
< th style = " width: 200px " > '.$this->l(' Date ').' </ th >
< th style = " width: 100px " > '.$this->l(' Pages viewed ').' </ th >
< th style = " width: 100px " > '.$this->l(' Total time ').' </ th >
< th style = " width: 100px " > '.$this->l(' Origin ').' </ th >
< th style = " width: 100px " > '.$this->l(' IP Address ').' </ th >
</ tr > ' ;
foreach ( $connections as $connection )
echo ' < tr >
< td > '.Tools::displayDate($connection[' date_add '], (int)($cookie->id_lang), true).' </ td >
< td > '.(int)($connection[' pages ']).' </ td >
< td > '.$connection[' time '].' </ td >
< td > '.($connection[' http_referer '] ? preg_replace(' /^ www ./ ', ' ', parse_url($connection[' http_referer '], PHP_URL_HOST)) : $this->l(' Direct link ')).' </ td >
< td > '.$connection[' ipaddress '].' </ td >
</ tr > ' ;
echo '</table><div class="clear"> </div>' ;
}
2017-06-28 15:00:53 +02:00
if ( sizeof ( $referrers ))
2016-01-04 12:48:08 +01:00
{
echo '<h2>' . $this -> l ( 'Referrers' ) . ' </ h2 >
< table cellspacing = " 0 " cellpadding = " 0 " class = " table " >
< tr >
< th style = " width: 200px " > '.$this->l(' Date ').' </ th >
< th style = " width: 200px " > '.$this->l(' Name ').' </ th >
</ tr > ' ;
foreach ( $referrers as $referrer )
echo ' < tr >
< td > '.Tools::displayDate($referrer[' date_add '], (int)($cookie->id_lang), true).' </ td >
< td > '.$referrer[' name '].' </ td >
</ tr > ' ;
echo '</table><div class="clear"> </div>' ;
}
echo '<a href="' . $currentIndex . '&token=' . $this -> token . '"><img src="../img/admin/arrow2.gif" /> ' . $this -> l ( 'Back to customer list' ) . '</a><br />' ;
}
public function displayForm ( $isMainTab = true )
{
global $currentIndex ;
parent :: displayForm ();
2017-06-28 15:00:53 +02:00
2016-01-04 12:48:08 +01:00
if ( ! ( $obj = $this -> loadObject ( true )))
return ;
2017-06-28 15:00:53 +02:00
2016-01-04 12:48:08 +01:00
$birthday = explode ( '-' , $this -> getFieldValue ( $obj , 'birthday' ));
$customer_groups = Tools :: getValue ( 'groupBox' , $obj -> getGroups ());
$groups = Group :: getGroups ( $this -> _defaultFormLanguage , true );
$sql = 'SELECT id_customer FROM `' . _DB_PREFIX_ . 'customer_credits` WHERE id_customer = ' . $obj -> id ;
if ( Db :: getInstance () -> getValue ( $sql )){
$obj -> use_credits = " 0 " ;
} else {
$obj -> use_credits = " 1 " ;
}
2017-06-28 15:00:53 +02:00
2016-01-04 12:48:08 +01:00
echo '
< form action = " '. $currentIndex .'&submitAdd'. $this->table .'=1&token='. $this->token .' " method = " post " autocomplete = " off " >
'.($obj->id ? ' < input type = " hidden " name = " id_'. $this->table .' " value = " '. $obj->id .' " /> ' : ' ').'
< fieldset >< legend >< img src = " ../img/admin/tab-customers.gif " /> '.$this->l(' Customer ').' </ legend >
< label > '.$this->l(' Gender : ').' </ label >
< div class = " margin-form " >
< input type = " radio " size = " 33 " name = " id_gender " id = " gender_1 " value = " 1 " '.($this->getFieldValue($obj, ' id_gender ') == 1 ? ' checked = " checked " ' : ' ').' />
< label class = " t " for = " gender_1 " > '.$this->l(' Male ').' </ label >
< input type = " radio " size = " 33 " name = " id_gender " id = " gender_2 " value = " 2 " '.($this->getFieldValue($obj, ' id_gender ') == 2 ? ' checked = " checked " ' : ' ').' />
< label class = " t " for = " gender_2 " > '.$this->l(' Female ').' </ label >
< input type = " radio " size = " 33 " name = " id_gender " id = " gender_3 " value = " 9 " '.(($this->getFieldValue($obj, ' id_gender ') == 9 OR !$this->getFieldValue($obj, ' id_gender ')) ? ' checked = " checked " ' : ' ').' />
< label class = " t " for = " gender_3 " > '.$this->l(' Unknown ').' </ label >
</ div >
< label > '.$this->l(' Last name : ').' </ label >
< div class = " margin-form " >
< input type = " text " size = " 33 " name = " lastname " value = " '.htmlentities( $this->getFieldValue ( $obj , 'lastname'), ENT_COMPAT, 'UTF-8').' " /> < sup >*</ sup >
< span class = " hint " name = " help_box " > '.$this->l(' Invalid characters : ').' 0 - 9 !<> ,; ? =+ () @ #"<22> {}_$%:<span class="hint-pointer"> </span></span>
</ div >
< label > '.$this->l(' First name : ').' </ label >
< div class = " margin-form " >
< input type = " text " size = " 33 " name = " firstname " value = " '.htmlentities( $this->getFieldValue ( $obj , 'firstname'), ENT_COMPAT, 'UTF-8').' " /> < sup >*</ sup >
< span class = " hint " name = " help_box " > '.$this->l(' Forbidden characters : ').' 0 - 9 !<> ,; ? =+ () @ #"<22> {}_$%:<span class="hint-pointer"> </span></span>
</ div >
< label > '.$this->l(' Password : ').' </ label >
< div class = " margin-form " >
< input type = " password " size = " 33 " name = " passwd " value = " " /> '.(!$obj->id ? ' < sup >*</ sup > ' : ' ').'
< p > '.($obj->id ? $this->l(' Leave blank if no change ') : $this->l(' 5 characters min . , only letters , numbers , or ').' - _ ').' </ p >
</ div >
< label > '.$this->l(' E - mail address : ').' </ label >
< div class = " margin-form " >
< input type = " text " size = " 33 " name = " email " value = " '.htmlentities( $this->getFieldValue ( $obj , 'email'), ENT_COMPAT, 'UTF-8').' " /> < sup >*</ sup >
</ div >
< label > '.$this->l(' Birthday : ').' </ label > ' ;
$sl_year = ( $this -> getFieldValue ( $obj , 'birthday' )) ? $birthday [ 0 ] : 0 ;
$years = Tools :: dateYears ();
$sl_month = ( $this -> getFieldValue ( $obj , 'birthday' )) ? $birthday [ 1 ] : 0 ;
$months = Tools :: dateMonths ();
$sl_day = ( $this -> getFieldValue ( $obj , 'birthday' )) ? $birthday [ 2 ] : 0 ;
$days = Tools :: dateDays ();
$tab_months = array (
$this -> l ( 'January' ),
$this -> l ( 'February' ),
$this -> l ( 'March' ),
$this -> l ( 'April' ),
$this -> l ( 'May' ),
$this -> l ( 'June' ),
$this -> l ( 'July' ),
$this -> l ( 'August' ),
$this -> l ( 'September' ),
$this -> l ( 'October' ),
$this -> l ( 'November' ),
$this -> l ( 'December' ));
echo '
< div class = " margin-form " >
< select name = " days " >
< option value = " " >-</ option > ' ;
foreach ( $days as $v )
echo '<option value="' . $v . '" ' . ( $sl_day == $v ? 'selected="selected"' : '' ) . '>' . $v . '</option>' ;
echo '
</ select >
< select name = " months " >
< option value = " " >-</ option > ' ;
foreach ( $months as $k => $v )
echo '<option value="' . $k . '" ' . ( $sl_month == $k ? 'selected="selected"' : '' ) . '>' . $this -> l ( $v ) . '</option>' ;
echo ' </ select >
< select name = " years " >
< option value = " " >-</ option > ' ;
foreach ( $years as $v )
echo '<option value="' . $v . '" ' . ( $sl_year == $v ? 'selected="selected"' : '' ) . '>' . $v . '</option>' ;
echo ' </ select >
</ div > ' ;
echo '<label>' . $this -> l ( 'Status:' ) . ' </ label >
< div class = " margin-form " >
< input type = " radio " name = " active " id = " active_on " value = " 1 " '.($this->getFieldValue($obj, ' active ') ? ' checked = " checked " ' : ' ').' />
< label class = " t " for = " active_on " >< img src = " ../img/admin/enabled.gif " alt = " '. $this->l ('Enabled').' " title = " '. $this->l ('Enabled').' " /></ label >
< input type = " radio " name = " active " id = " active_off " value = " 0 " '.(!$this->getFieldValue($obj, ' active ') ? ' checked = " checked " ' : ' ').' />
< label class = " t " for = " active_off " >< img src = " ../img/admin/disabled.gif " alt = " '. $this->l ('Disabled').' " title = " '. $this->l ('Disabled').' " /></ label >
< p > '.$this->l(' Allow or disallow this customer to log in ').' </ p >
</ div >
< label > '.$this->l(' Newsletter : ').' </ label >
< div class = " margin-form " >
< input type = " radio " name = " newsletter " id = " newsletter_on " value = " 1 " '.($this->getFieldValue($obj, ' newsletter ') ? ' checked = " checked " ' : ' ').' />
< label class = " t " for = " newsletter_on " >< img src = " ../img/admin/enabled.gif " alt = " '. $this->l ('Enabled').' " title = " '. $this->l ('Enabled').' " /></ label >
< input type = " radio " name = " newsletter " id = " newsletter_off " value = " 0 " '.(!$this->getFieldValue($obj, ' newsletter ') ? ' checked = " checked " ' : ' ').' />
< label class = " t " for = " newsletter_off " >< img src = " ../img/admin/disabled.gif " alt = " '. $this->l ('Disabled').' " title = " '. $this->l ('Disabled').' " /></ label >
< p > '.$this->l(' Customer will receive your newsletter via e - mail ').' </ p >
</ div >
< label > '.$this->l(' Opt - in : ').' </ label >
< div class = " margin-form " >
< input type = " radio " name = " optin " id = " optin_on " value = " 1 " '.($this->getFieldValue($obj, ' optin ') ? ' checked = " checked " ' : ' ').' />
< label class = " t " for = " optin_on " >< img src = " ../img/admin/enabled.gif " alt = " '. $this->l ('Enabled').' " title = " '. $this->l ('Enabled').' " /></ label >
< input type = " radio " name = " optin " id = " optin_off " value = " 0 " '.(!$this->getFieldValue($obj, ' optin ') ? ' checked = " checked " ' : ' ').' />
< label class = " t " for = " optin_off " >< img src = " ../img/admin/disabled.gif " alt = " '. $this->l ('Disabled').' " title = " '. $this->l ('Disabled').' " /></ label >
< p > '.$this->l(' Customer will receive your ads via e - mail ').' </ p >
2017-06-28 15:00:53 +02:00
</ div >
2016-01-04 12:48:08 +01:00
< label > '.$this->l(' Parrainage : ').' </ label >
< div class = " margin-form " >
< input type = " radio " name = " use_credits " id = " credits_on " value = " 1 " '.($this->getFieldValue($obj, ' use_credits ') ? ' checked = " checked " ' : ' ').' />
< label class = " t " for = " credits_on " >< img src = " ../img/admin/enabled.gif " alt = " '. $this->l ('Enabled').' " title = " '. $this->l ('Enabled').' " /></ label >
< input type = " radio " name = " use_credits " id = " credits_off " value = " 0 " '.(!$this->getFieldValue($obj, ' use_credits ') ? ' checked = " checked " ' : ' ').' />
< label class = " t " for = " credits_off " >< img src = " ../img/admin/disabled.gif " alt = " '. $this->l ('Disabled').' " title = " '. $this->l ('Disabled').' " /></ label >
< p > '.$this->l(' Allow or disallow this customer to use credits ').' </ p >
</ div >
< label > '.$this->l(' Default group : ').' </ label >
< div class = " margin-form " >
< select name = " id_default_group " onchange = " checkDefaultGroup(this.value); " > ' ;
foreach ( $groups as $group )
echo '<option value="' . ( int )( $group [ 'id_group' ]) . '"' . ( $group [ 'id_group' ] == $obj -> id_default_group ? ' selected="selected"' : '' ) . '>' . htmlentities ( $group [ 'name' ], ENT_NOQUOTES , 'utf-8' ) . '</option>' ;
echo '
</ select >
< p > '.$this->l(' Apply non - cumulative rules ( e . g . , price , display method , reduction ) ').' </ p >
</ div >
< label > '.$this->l(' Groups : ').' </ label >
< div class = " margin-form " > ' ;
if ( sizeof ( $groups ))
{
echo '
< table cellspacing = " 0 " cellpadding = " 0 " class = " table " style = " width: 29.5em; " >
< tr >
< th >< input type = " checkbox " name = " checkme " class = " noborder " onclick = " checkDelBoxes(this.form, \ 'groupBox[] \ ', this.checked) " /></ th >
< th > '.$this->l(' ID ').' </ th >
< th > '.$this->l(' Group name ').' </ th >
</ tr > ' ;
$irow = 0 ;
foreach ( $groups as $group )
{
echo '
< tr class = " '.( $irow ++ % 2 ? 'alt_row' : '').' " >
< td > '.' < input type = " checkbox " name = " groupBox[] " class = " groupBox " id = " groupBox_'. $group['id_group'] .' " value = " '. $group['id_group'] .' " '.(in_array($group[' id_group '], $customer_groups) ? ' checked = " checked " ' : ' ').' /></ td >
< td > '.$group[' id_group '].' </ td >
< td >< label for = " groupBox_'. $group['id_group'] .' " class = " t " > '.$group[' name '].' </ label ></ td >
</ tr > ' ;
}
echo '
</ table >
< p style = " padding:0px; margin:10px 0px 10px 0px; " > '.$this->l(' Check all the box ( es ) of groups of which the customer is to be a member ').' < sup > *</ sup ></ p >
' ;
} else
echo '<p>' . $this -> l ( 'No group created' ) . '</p>' ;
echo '
</ div >
< div class = " margin-form " >
< input type = " submit " value = " '. $this->l (' Save ').' " name = " submitAdd'. $this->table .' " class = " button " />
</ div >
< div class = " small " >< sup >*</ sup > '.$this->l(' Required field ').' </ div >
</ fieldset >
</ form > ' ;
}
public function getList ( $id_lang , $orderBy = NULL , $orderWay = NULL , $start = 0 , $limit = NULL )
{
global $cookie ;
return parent :: getList (( int )( $cookie -> id_lang ), ! Tools :: getValue ( $this -> table . 'Orderby' ) ? 'date_add' : NULL , ! Tools :: getValue ( $this -> table . 'Orderway' ) ? 'DESC' : NULL );
}
2017-06-28 15:00:53 +02:00
2016-01-04 12:48:08 +01:00
public function beforeDelete ( $object )
{
return $object -> isUsed ();
}
}