569 lines
23 KiB
PHP
Executable File
569 lines
23 KiB
PHP
Executable File
<?php
|
||
/*
|
||
* 2007-2011 PrestaShop
|
||
*
|
||
* 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: 9188 $
|
||
* @license http://opensource.org/licenses/osl-3.0.php Open Software License (OSL 3.0)
|
||
* International Registered Trademark & Property of PrestaShop SA
|
||
*/
|
||
include_once(PS_ADMIN_DIR.'/../classes/AdminTab.php');
|
||
if (Configuration::get('VATNUMBER_MANAGEMENT') AND file_exists(_PS_MODULE_DIR_.'vatnumber/vatnumber.php'))
|
||
include_once(_PS_MODULE_DIR_.'vatnumber/vatnumber.php');
|
||
|
||
class AdminAddresses extends AdminTab
|
||
{
|
||
/** @var array countries list */
|
||
private $countriesArray = array();
|
||
|
||
public function __construct()
|
||
{
|
||
global $cookie;
|
||
|
||
$this->table = 'address';
|
||
$this->className = 'Address';
|
||
$this->lang = false;
|
||
$this->edit = true;
|
||
$this->delete = true;
|
||
$this->requiredDatabase = true;
|
||
$this->addressType = 'customer';
|
||
|
||
if (!Tools::getValue('realedit'))
|
||
$this->deleted = true;
|
||
$this->_select = 'cl.`name` as country';
|
||
$this->_join = 'LEFT JOIN `'._DB_PREFIX_.'country_lang` cl ON
|
||
(cl.`id_country` = a.`id_country` AND cl.`id_lang` = '.(int)($cookie->id_lang).')';
|
||
|
||
$countries = Country::getCountries((int)($cookie->id_lang));
|
||
foreach ($countries AS $country)
|
||
$this->countriesArray[$country['id_country']] = $country['name'];
|
||
|
||
$this->fieldsDisplay = array(
|
||
'id_address' => array('title' => $this->l('ID'), 'align' => 'center', 'width' => 25),
|
||
'firstname' => array('title' => $this->l('First name'), 'width' => 80, 'filter_key' => 'a!firstname'),
|
||
'lastname' => array('title' => $this->l('Last name'), 'width' => 100, 'filter_key' => 'a!lastname'),
|
||
'address1' => array('title' => $this->l('Address'), 'width' => 200),
|
||
'postcode' => array('title' => $this->l('Postcode/ Zip Code'), 'align' => 'right', 'width' => 50),
|
||
'city' => array('title' => $this->l('City'), 'width' => 150),
|
||
'country' => array('title' => $this->l('Country'), 'width' => 100, 'type' => 'select', 'select' => $this->countriesArray, 'filter_key' => 'cl!id_country'));
|
||
|
||
parent::__construct();
|
||
}
|
||
|
||
public function postProcess()
|
||
{
|
||
if (isset($_POST['submitAdd'.$this->table]))
|
||
{
|
||
// Transform e-mail in id_customer for parent processing
|
||
if ($this->addressType == 'customer')
|
||
{
|
||
if (Validate::isEmail(Tools::getValue('email')))
|
||
{
|
||
$customer = new Customer();
|
||
$customer->getByEmail(Tools::getValue('email'));
|
||
if (Validate::isLoadedObject($customer))
|
||
$_POST['id_customer'] = $customer->id;
|
||
else
|
||
$this->_errors[] = Tools::displayError('This e-mail address is not registered.');
|
||
}
|
||
elseif ($id_customer = Tools::getValue('id_customer'))
|
||
{
|
||
$customer = new Customer((int)$id_customer);
|
||
if (Validate::isLoadedObject($customer))
|
||
$_POST['id_customer'] = $customer->id;
|
||
else
|
||
$this->_errors[] = Tools::displayError('Unknown customer');
|
||
}
|
||
else
|
||
$this->_errors[] = Tools::displayError('Unknown customer');
|
||
if (Country::isNeedDniByCountryId(Tools::getValue('id_country')) AND !Tools::getValue('dni'))
|
||
$this->_errors[] = Tools::displayError('Identification number is incorrect or has already been used.');
|
||
}
|
||
|
||
// Check manufacturer selected
|
||
if ($this->addressType == 'manufacturer')
|
||
{
|
||
$manufacturer = new Manufacturer((int)(Tools::getValue('id_manufacturer')));
|
||
if (!Validate::isLoadedObject($manufacturer))
|
||
$this->_errors[] = Tools::displayError('Manufacturer selected is not valid.');
|
||
}
|
||
|
||
/* If the selected country does not contain states */
|
||
$id_state = (int)(Tools::getValue('id_state'));
|
||
if ($id_country = Tools::getValue('id_country') AND $country = new Country((int)($id_country)) AND !(int)($country->contains_states) AND $id_state)
|
||
$this->_errors[] = Tools::displayError('You have selected a state for a country that does not contain states.');
|
||
|
||
/* If the selected country contains states, then a state have to be selected */
|
||
if ((int)($country->contains_states) AND !$id_state)
|
||
$this->_errors[] = Tools::displayError('An address located in a country containing states must have a state selected.');
|
||
|
||
/* Check zip code */
|
||
if ($country->need_zip_code)
|
||
{
|
||
$zip_code_format = $country->zip_code_format;
|
||
if (($postcode = Tools::getValue('postcode')) AND $zip_code_format)
|
||
{
|
||
$zip_regexp = '/^'.$zip_code_format.'$/ui';
|
||
$zip_regexp = str_replace(' ', '( |)', $zip_regexp);
|
||
$zip_regexp = str_replace('-', '(-|)', $zip_regexp);
|
||
$zip_regexp = str_replace('N', '[0-9]', $zip_regexp);
|
||
$zip_regexp = str_replace('L', '[a-zA-Z]', $zip_regexp);
|
||
$zip_regexp = str_replace('C', $country->iso_code, $zip_regexp);
|
||
if (!preg_match($zip_regexp, $postcode))
|
||
$this->_errors[] = Tools::displayError('Your zip/postal code is incorrect.').'<br />'.Tools::displayError('Must be typed as follows:').' '.str_replace('C', $country->iso_code, str_replace('N', '0', str_replace('L', 'A', $zip_code_format)));
|
||
}
|
||
elseif ($zip_code_format)
|
||
$this->_errors[] = Tools::displayError('Postcode required.');
|
||
elseif ($postcode AND !preg_match('/^[0-9a-zA-Z -]{4,9}$/ui', $postcode))
|
||
$this->_errors[] = Tools::displayError('Your zip/postal code is incorrect.');
|
||
}
|
||
|
||
/**
|
||
* If this address come from order's edition and is the same as the other one
|
||
* (invoice or delivery one)
|
||
* we delete its id_address to force the creation of a new one
|
||
*/
|
||
if ((int)(Tools::getValue('id_order'))) {
|
||
$this->_redirect = false;
|
||
if (isset($_POST['address_type'])) {
|
||
$_POST['id_address'] = '';
|
||
}
|
||
}
|
||
}
|
||
|
||
if (!sizeof($this->_errors)) {
|
||
parent::postProcess();
|
||
}
|
||
|
||
/* Reassignation of the order's new (invoice or delivery) address */
|
||
$address_type = ((int)(Tools::getValue('address_type')) == 2 ? 'invoice' : ((int)(Tools::getValue('address_type')) == 1 ? 'delivery' : ''));
|
||
if (isset($_POST['submitAdd'.$this->table]) AND ($id_order = (int)(Tools::getValue('id_order'))) AND !sizeof($this->_errors) AND !empty($address_type))
|
||
{
|
||
if (!Db::getInstance()->Execute('UPDATE '._DB_PREFIX_.'orders SET `id_address_'.$address_type.'` = '.Db::getInstance()->Insert_ID().' WHERE `id_order` = '.$id_order)) {
|
||
$this->_errors[] = Tools::displayError('An error occurred while linking this address to its order.');
|
||
}
|
||
else {
|
||
Tools::redirectAdmin(Tools::getValue('back').'&conf=4');
|
||
}
|
||
}
|
||
}
|
||
|
||
protected function afterAdd($object)
|
||
{
|
||
$this->afterUpdate($object);
|
||
}
|
||
|
||
protected function afterUpdate($object)
|
||
{
|
||
if (isset($_POST['submitAdd'.$this->table]) &&
|
||
($id_order = (int)(Tools::getValue('id_order'))) && !sizeof($this->_errors)) {
|
||
|
||
$address_type = ((int)(Tools::getValue('address_type')) == 2 ? 'invoice' : ((int)(Tools::getValue('address_type')) == 1 ? 'delivery' : ''));
|
||
if ($address_type == 'invoice') {
|
||
return;
|
||
}
|
||
|
||
// If socol AND delivery to DOM AND address change, update ps_socolissimo_delivery_info
|
||
$cart = Cart::getCartByOrderId($id_order);
|
||
if ((int)$cart->id_carrier == (int)Configuration::get('ANT_CARRIER_DOM')) {
|
||
$socol = Db::getInstance()->getRow('
|
||
SELECT * FROM `'._DB_PREFIX_.'socolissimo_delivery_info`
|
||
WHERE `id_cart` = '.(int)$cart->id.'
|
||
AND `cecountry` IN ("FR","BE","ES") AND `delivery_mode`="DOM"
|
||
AND (`pradress1`!="" OR `pradress2`!="" OR `pradress3`!="" OR `pradress4`!="")
|
||
');
|
||
if ($socol) {
|
||
// Get address
|
||
$delivery = new Address($object->id);
|
||
// Update So Colissimo Address - for printing label
|
||
Db::getInstance()->Execute('UPDATE `'._DB_PREFIX_.'socolissimo_delivery_info` SET
|
||
prname = "'.$delivery->lastname.'",
|
||
prfirstname = "'.$delivery->firstname.'",
|
||
cecompanyname = "'.$delivery->company.'",
|
||
cename = "'.$delivery->lastname.'",
|
||
cefirstname = "'.$delivery->firstname.'",
|
||
prcompladress = "",
|
||
pradress1 = "",
|
||
pradress2 = "",
|
||
pradress3 = "'.$delivery->address1.'",
|
||
pradress4 = "'.$delivery->address2.'",
|
||
przipcode = "'.$delivery->postcode.'",
|
||
prtown = "'.$delivery->city.'",
|
||
cephonenumber = "'.($delivery->phone_mobile ?
|
||
$delivery->phone_mobile : ($delivery->phone ? $delivery->phone : '')).'"
|
||
WHERE id_cart = '.(int)$cart->id
|
||
);
|
||
}
|
||
}
|
||
}
|
||
|
||
return true;
|
||
}
|
||
|
||
public function getList($id_lang, $orderBy = NULL, $orderWay = NULL, $start = 0, $limit = NULL)
|
||
{
|
||
parent::getList($id_lang, $orderBy, $orderWay, $start, $limit);
|
||
|
||
global $cookie;
|
||
|
||
/* Manage default params values */
|
||
if (empty($limit))
|
||
$limit = ((!isset($cookie->{$this->table.'_pagination'})) ? $this->_pagination[0] : $limit = $cookie->{$this->table.'_pagination'});
|
||
|
||
if (!Validate::isTableOrIdentifier($this->table))
|
||
die('filter is corrupted');
|
||
if (empty($orderBy))
|
||
$orderBy = Tools::getValue($this->table.'Orderby', 'id_'.$this->table);
|
||
if (empty($orderWay))
|
||
$orderWay = Tools::getValue($this->table.'Orderway', 'ASC');
|
||
$limit = (int)(Tools::getValue('pagination', $limit));
|
||
$cookie->{$this->table.'_pagination'} = $limit;
|
||
|
||
/* Check params validity */
|
||
if (!Validate::isOrderBy($orderBy) OR !Validate::isOrderWay($orderWay)
|
||
OR !is_numeric($start) OR !is_numeric($limit)
|
||
OR !Validate::isUnsignedId($id_lang))
|
||
die(Tools::displayError('get list params is not valid'));
|
||
|
||
/* Determine offset from current page */
|
||
if ((isset($_POST['submitFilter'.$this->table]) OR
|
||
isset($_POST['submitFilter'.$this->table.'_x']) OR
|
||
isset($_POST['submitFilter'.$this->table.'_y'])) AND
|
||
!empty($_POST['submitFilter'.$this->table]) AND
|
||
is_numeric($_POST['submitFilter'.$this->table]))
|
||
$start = (int)($_POST['submitFilter'.$this->table] - 1) * $limit;
|
||
|
||
/* Cache */
|
||
$this->_lang = (int)($id_lang);
|
||
$this->_orderBy = $orderBy;
|
||
$this->_orderWay = Tools::strtoupper($orderWay);
|
||
|
||
/* SQL table : orders, but class name is Order */
|
||
$sqlTable = $this->table == 'order' ? 'orders' : $this->table;
|
||
|
||
/* Query in order to get results number */
|
||
$queryTotal = Db::getInstance()->getRow('
|
||
SELECT COUNT(a.`id_'.$this->table.'`) AS total
|
||
FROM `'._DB_PREFIX_.$sqlTable.'` a
|
||
'.($this->lang ? 'LEFT JOIN `'._DB_PREFIX_.$this->table.'_lang` b ON (b.`id_'.$this->table.'` = a.`id_'.$this->table.'` AND b.`id_lang` = '.(int)($id_lang).')' : '').'
|
||
'.(isset($this->_join) ? $this->_join.' ' : '').'
|
||
WHERE 1 '.(isset($this->_where) ? $this->_where.' ' : '').(($this->deleted OR $this->table == 'currency') ? 'AND a.`deleted` = 0 ' : '').$this->_filter.'
|
||
'.(isset($this->_group) ? $this->_group.' ' : '').'
|
||
'.(isset($this->addressType) ? 'AND a.id_'.strval($this->addressType).' != 0' : ''));
|
||
$this->_listTotal = (int)($queryTotal['total']);
|
||
|
||
/* Query in order to get results with all fields */
|
||
$this->_list = Db::getInstance()->ExecuteS('
|
||
SELECT a.*'.($this->lang ? ', b.*' : '').(isset($this->_select) ? ', '.$this->_select.' ' : '').'
|
||
FROM `'._DB_PREFIX_.$sqlTable.'` a
|
||
'.($this->lang ? 'LEFT JOIN `'._DB_PREFIX_.$this->table.'_lang` b ON (b.`id_'.$this->table.'` = a.`id_'.$this->table.'` AND b.`id_lang` = '.(int)($id_lang).')' : '').'
|
||
'.(isset($this->_join) ? $this->_join.' ' : '').'
|
||
WHERE 1 '.(isset($this->_where) ? $this->_where.' ' : '').(($this->deleted OR $this->table == 'currency') ? 'AND a.`deleted` = 0 ' : '').$this->_filter.'
|
||
'.(isset($this->_group) ? $this->_group.' ' : '').'
|
||
'.(isset($this->addressType) ? 'AND a.id_'.strval($this->addressType).' != 0' : '').'
|
||
ORDER BY '.(($orderBy == 'id_'.$this->table) ? 'a.' : '').'`'.bqSQL($orderBy).'` '.bqSQL($orderWay).'
|
||
LIMIT '.(int)($start).','.(int)($limit));
|
||
}
|
||
|
||
public function displayForm($isMainTab = true)
|
||
{
|
||
global $currentIndex, $cookie;
|
||
parent::displayForm();
|
||
|
||
if (!($obj = $this->loadObject(true)))
|
||
return;
|
||
|
||
echo '
|
||
<form action="'.$currentIndex.'&submitAdd'.$this->table.'=1&token='.$this->token.'" method="post">
|
||
'.((int)($obj->id) ? '<input type="hidden" name="id_'.$this->table.'" value="'.(int)($obj->id).'" />' : '').'
|
||
'.(($id_order = (int)(Tools::getValue('id_order'))) ? '<input type="hidden" name="id_order" value="'.(int)($id_order).'" />' : '').'
|
||
'.(($address_type = (int)(Tools::getValue('address_type'))) ? '<input type="hidden" name="address_type" value="'.(int)($address_type).'" />' : '').'
|
||
'.(Tools::getValue('realedit') ? '<input type="hidden" name="realedit" value="1" />' : '').'
|
||
<fieldset>
|
||
<legend><img src="../img/admin/contact.gif" alt="" />'.$this->l('Addresses').'</legend>';
|
||
switch ($this->addressType)
|
||
{
|
||
case 'manufacturer':
|
||
echo '<label>'.$this->l('Choose manufacturer').'</label>
|
||
<div class="margin-form">';
|
||
$manufacturers = Manufacturer::getManufacturers();
|
||
echo '<select name="id_manufacturer">';
|
||
if (!sizeof($manufacturers))
|
||
echo '<option value="0">'.$this->l('No manufacturer available').' </option>';
|
||
foreach ($manufacturers as $manufacturer)
|
||
echo '<option value="'.(int)($manufacturer['id_manufacturer']).'"'.($this->getFieldValue($obj, 'id_manufacturer') == $manufacturer['id_manufacturer'] ? ' selected="selected"' : '').'>'.$manufacturer['name'].' </option>';
|
||
echo '</select>';
|
||
echo '</div>';
|
||
echo '<input type="hidden" name="alias" value="manufacturer">';
|
||
break;
|
||
case 'customer':
|
||
default:
|
||
if ($obj->id)
|
||
{
|
||
$customer = new Customer($obj->id_customer);
|
||
$tokenCustomer = Tools::getAdminToken('AdminCustomers'.(int)(Tab::getIdFromClassName('AdminCustomers')).(int)($cookie->id_employee));
|
||
echo '
|
||
<label>'.$this->l('Customer').'</label>
|
||
<div class="margin-form"><a style="display: block; padding-top: 4px;" href="?tab=AdminCustomers&id_customer='.$customer->id.'&viewcustomer&token='.$tokenCustomer.'">'.$customer->lastname.' '.$customer->firstname.' ('.$customer->email.')</a></div>
|
||
<input type="hidden" name="id_customer" value="'.$customer->id.'" />
|
||
<input type="hidden" name="email" value="'.$customer->email.'" />';
|
||
}
|
||
else
|
||
{
|
||
echo
|
||
'<label>'.$this->l('Customer e-mail').'</label>
|
||
<div class="margin-form">
|
||
<input type="text" size="33" name="email" value="'.htmlentities(Tools::getValue('email'), ENT_COMPAT, 'UTF-8').'" style="text-transform: lowercase;" /> <sup>*</sup>
|
||
</div>';
|
||
}
|
||
echo '
|
||
<label for="dni">'.$this->l('Identification Number').'</label>
|
||
<div class="margin-form">
|
||
<input type="text" name="dni" id="dni" value="'.htmlentities($this->getFieldValue($obj, 'dni'), ENT_COMPAT, 'UTF-8').'" />
|
||
<p>'.$this->l('DNI / NIF / NIE').'</p>
|
||
</div>';
|
||
|
||
echo '<label>'.$this->l('Alias').'</label>
|
||
<div class="margin-form">
|
||
<input type="text" size="33" name="alias" value="'.htmlentities($this->getFieldValue($obj, 'alias'), ENT_COMPAT, 'UTF-8').'" /> <sup>*</sup>
|
||
<span class="hint" name="help_box">'.$this->l('Invalid characters:').' <>;=#{}<span class="hint-pointer"> </span></span>
|
||
</div>';
|
||
break;
|
||
}
|
||
|
||
$addresses_fields = $this->processAddressFormat();
|
||
$addresses_fields = $addresses_fields["dlv_all_fields"]; // we use delivery address
|
||
|
||
|
||
|
||
foreach($addresses_fields as $addr_field_item)
|
||
{
|
||
if ($addr_field_item == 'company')
|
||
{
|
||
if ($this->addressType != 'manufacturer')
|
||
{
|
||
echo '<label>'.$this->l('Company').'</label>
|
||
<div class="margin-form">
|
||
<input type="text" size="33" name="company" value="'.htmlentities($this->getFieldValue($obj, 'company'), ENT_COMPAT, 'UTF-8').'" />
|
||
<span class="hint" name="help_box">'.$this->l('Invalid characters:').' <>;=#{}<span class="hint-pointer"> </span></span>
|
||
</div>';
|
||
|
||
if ((Configuration::get('VATNUMBER_MANAGEMENT') AND file_exists(_PS_MODULE_DIR_.'vatnumber/vatnumber.php')) && VatNumber::isApplicable(Configuration::get('PS_COUNTRY_DEFAULT')))
|
||
echo '<div id="vat_area" style="display: visible">';
|
||
elseif (Configuration::get('VATNUMBER_MANAGEMENT'))
|
||
echo '<div id="vat_area" style="display: hidden">';
|
||
else
|
||
echo'<div style="display: none;">';
|
||
|
||
echo '<label>'.$this->l('VAT number').'</label>
|
||
<div class="margin-form">
|
||
<input type="text" size="33" name="vat_number" value="'.htmlentities($this->getFieldValue($obj, 'vat_number'), ENT_COMPAT, 'UTF-8').'" />
|
||
</div>
|
||
</div>';
|
||
}
|
||
}
|
||
elseif ($addr_field_item == 'lastname')
|
||
{
|
||
echo '
|
||
<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>';
|
||
}
|
||
elseif ($addr_field_item == 'firstname')
|
||
{
|
||
|
||
echo '
|
||
<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('Invalid characters:').' 0-9!<>,;?=+()@#"<22>{}_$%:<span class="hint-pointer"> </span></span>
|
||
</div>';
|
||
}
|
||
elseif ($addr_field_item == 'address1')
|
||
{
|
||
|
||
echo '
|
||
<label>'.$this->l('Address').'</label>
|
||
<div class="margin-form">
|
||
<input type="text" size="33" name="address1" value="'.htmlentities($this->getFieldValue($obj, 'address1'), ENT_COMPAT, 'UTF-8').'" /> <sup>*</sup>
|
||
</div>';
|
||
}
|
||
elseif ($addr_field_item == 'address2')
|
||
{
|
||
|
||
echo '
|
||
<label>'.$this->l('Address').' (2)</label>
|
||
<div class="margin-form">
|
||
<input type="text" size="33" name="address2" value="'.htmlentities($this->getFieldValue($obj, 'address2'), ENT_COMPAT, 'UTF-8').'" />
|
||
</div>';
|
||
}
|
||
elseif ($addr_field_item == 'postcode')
|
||
{
|
||
|
||
echo '
|
||
<label>'.$this->l('Postcode/ Zip Code').'</label>
|
||
<div class="margin-form">
|
||
<input type="text" size="33" name="postcode" value="'.htmlentities($this->getFieldValue($obj, 'postcode'), ENT_COMPAT, 'UTF-8').'" />
|
||
</div>';
|
||
}
|
||
elseif ($addr_field_item == 'city')
|
||
{
|
||
|
||
echo '
|
||
<label>'.$this->l('City').'</label>
|
||
<div class="margin-form">
|
||
<input type="text" size="33" name="city" value="'.htmlentities($this->getFieldValue($obj, 'city'), ENT_COMPAT, 'UTF-8').'" style="text-transform: uppercase;" /> <sup>*</sup>
|
||
</div>';
|
||
}
|
||
elseif ($addr_field_item == 'country' || $addr_field_item == 'Country:name')
|
||
{
|
||
|
||
echo '
|
||
<label>'.$this->l('Country').'</label>
|
||
<div class="margin-form">
|
||
<select name="id_country" id="id_country" />';
|
||
$selectedCountry = $this->getFieldValue($obj, 'id_country');
|
||
foreach ($this->countriesArray AS $id_country => $name)
|
||
echo ' <option value="'.$id_country.'"'.((!$selectedCountry AND Configuration::get('PS_COUNTRY_DEFAULT') == $id_country) ? ' selected="selected"' : ($selectedCountry == $id_country ? ' selected="selected"' : '')).'>'.$name.'</option>';
|
||
echo ' </select> <sup>*</sup>
|
||
</div>';
|
||
|
||
|
||
echo '
|
||
<div id="contains_states" '.(!Country::containsStates((int)$selectedCountry) ? 'style="display:none;"' : '').'>
|
||
<label>'.$this->l('State').'</label>
|
||
<div class="margin-form">
|
||
<select name="id_state" id="id_state">
|
||
</select>
|
||
<sup>*</sup>
|
||
</div>
|
||
</div>';
|
||
|
||
|
||
$id_country_ajax = (int)$this->getFieldValue($obj, 'id_country');
|
||
|
||
echo '
|
||
<script type="text/javascript">
|
||
$(document).ready(function(){
|
||
ajaxStates ();
|
||
$(\'#id_country\').change(function() {
|
||
ajaxStates ();
|
||
});
|
||
function ajaxStates ()
|
||
{
|
||
$.ajax({
|
||
url: "ajax.php",
|
||
cache: false,
|
||
data: "ajaxStates=1&id_country="+$(\'#id_country\').val()+"&id_state="+$(\'#id_state\').val(),
|
||
success: function(html)
|
||
{
|
||
if (html == \'false\')
|
||
{
|
||
$("#contains_states").fadeOut();
|
||
$(\'#id_state option[value=0]\').attr("selected", "selected");
|
||
}
|
||
else
|
||
{
|
||
$("#id_state").html(html);
|
||
$("#contains_states").fadeIn();
|
||
$(\'#id_state option[value='.(int)$obj->id_state.']\').attr("selected", "selected");
|
||
}
|
||
}
|
||
}); ';
|
||
if (file_exists(_PS_MODULE_DIR_.'vatnumber/ajax.php'))
|
||
echo ' $.ajax({
|
||
type: "GET",
|
||
url: "'._MODULE_DIR_.'vatnumber/ajax.php?id_country="+$(\'#id_country\').val(),
|
||
success: function(isApplicable)
|
||
{
|
||
if (isApplicable == 1)
|
||
$(\'#vat_area\').show();
|
||
else
|
||
$(\'#vat_area\').hide();
|
||
}
|
||
});';
|
||
echo ' }; }); </script>';
|
||
}
|
||
|
||
} // End foreach
|
||
echo '
|
||
<label>'.$this->l('Home phone').'</label>
|
||
<div class="margin-form">
|
||
<input type="text" size="33" name="phone" value="'.htmlentities($this->getFieldValue($obj, 'phone'), ENT_COMPAT, 'UTF-8').'" />
|
||
</div>';
|
||
|
||
echo '
|
||
<label>'.$this->l('Mobile phone').'</label>
|
||
<div class="margin-form">
|
||
<input type="text" size="33" name="phone_mobile" value="'.htmlentities($this->getFieldValue($obj, 'phone_mobile'), ENT_COMPAT, 'UTF-8').'" />
|
||
</div>';
|
||
|
||
|
||
echo '
|
||
<label>'.$this->l('Other').'</label>
|
||
<div class="margin-form">
|
||
<textarea name="other" cols="36" rows="4">'.htmlentities($this->getFieldValue($obj, 'other'), ENT_COMPAT, 'UTF-8').'</textarea>
|
||
<span class="hint" name="help_box">'.$this->l('Forbidden characters:').' <>;=#{}<span class="hint-pointer"> </span></span>
|
||
</div>';
|
||
|
||
echo '
|
||
<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>';
|
||
echo '
|
||
</form>';
|
||
}
|
||
|
||
protected function processAddressFormat()
|
||
{
|
||
$tmp_addr = new Address((int)Tools::getValue("id_address"));
|
||
|
||
$selectedCountry = ($tmp_addr && $tmp_addr->id_country) ? $tmp_addr->id_country :
|
||
(int)(Configuration::get('PS_COUNTRY_DEFAULT'));
|
||
|
||
$inv_adr_fields = AddressFormat::getOrderedAddressFields($selectedCountry, false, true);
|
||
$dlv_adr_fields = AddressFormat::getOrderedAddressFields($selectedCountry, false, true);
|
||
|
||
$inv_all_fields = array();
|
||
$dlv_all_fields = array();
|
||
|
||
$out = array();
|
||
|
||
foreach (array('inv','dlv') as $adr_type)
|
||
{
|
||
foreach (${$adr_type.'_adr_fields'} as $fields_line)
|
||
foreach(explode(' ',$fields_line) as $field_item)
|
||
${$adr_type.'_all_fields'}[] = trim($field_item);
|
||
|
||
|
||
$out[$adr_type.'_adr_fields'] = ${$adr_type.'_adr_fields'};
|
||
$out[$adr_type.'_all_fields'] = ${$adr_type.'_all_fields'};
|
||
}
|
||
|
||
return $out;
|
||
}
|
||
}
|
||
|
||
|