[phpBB Debug] PHP Warning: in file [ROOT]/includes/crs/crs_misc_functions.php on line 37: mime_content_type(): Empty filename or path
[phpBB Debug] PHP Warning: in file [ROOT]/includes/crs/crs_misc_functions.php on line 37: mime_content_type(): Empty filename or path
Zen Cart 源代码 checkout_new_address.php

Zen Cart 源代码 checkout_new_address.php




下载文件

文件名: checkout_new_address.php
文件类型: PHP文件
文件大小: 10.9 KiB
MD5: 5b87ad4a576fd1b8540ab0a6450b7f4c

checkout_new_address.php - 关闭高亮
  1. <?php
  2. /**
  3.  * checkout_new_address.php
  4.  *
  5.  * @package modules
  6.  * @copyright Copyright 2003-2007 Zen Cart Development Team
  7.  * @copyright Portions Copyright 2003 osCommerce
  8.  * @license http://www.zen-cart.com/license/2_0.txt GNU Public License V2.0
  9.  * @version $Id: checkout_new_address.php 6772 2007-08-21 12:33:29Z drbyte $
  10.  */
  11. // This should be first line of the script:
  12. $zco_notifier->notify('NOTIFY_MODULE_START_CHECKOUT_NEW_ADDRESS');
  13.  
  14. if (!defined('IS_ADMIN_FLAG')) {
  15.   die('Illegal Access');
  16. }
  17. /**
  18.  * Set some defaults
  19.  */
  20.   $process = false;
  21.   $zone_name = '';
  22.   $entry_state_has_zones = '';
  23.   $error_state_input = false;
  24.   $state = '';
  25.   $zone_id = 0;
  26.   $error = false;
  27.  
  28. if (isset($_POST['action']) && ($_POST['action'] == 'submit')) {
  29.   // process a new address
  30.   if (zen_not_null($_POST['firstname']) && zen_not_null($_POST['lastname']) && zen_not_null($_POST['street_address'])) {
  31.     $process = true;
  32.     if (ACCOUNT_GENDER == 'true') $gender = zen_db_prepare_input($_POST['gender']);
  33.     if (ACCOUNT_COMPANY == 'true') $company = zen_db_prepare_input($_POST['company']);
  34.     $firstname = zen_db_prepare_input($_POST['firstname']);
  35.     $lastname = zen_db_prepare_input($_POST['lastname']);
  36.     $street_address = zen_db_prepare_input($_POST['street_address']);
  37.     if (ACCOUNT_SUBURB == 'true') $suburb = zen_db_prepare_input($_POST['suburb']);
  38.     $postcode = zen_db_prepare_input($_POST['postcode']);
  39.     $city = zen_db_prepare_input($_POST['city']);
  40.     if (ACCOUNT_STATE == 'true') {
  41.       $state = zen_db_prepare_input($_POST['state']);
  42.       if (isset($_POST['zone_id'])) {
  43.         $zone_id = zen_db_prepare_input($_POST['zone_id']);
  44.       } else {
  45.         $zone_id = false;
  46.       }
  47.     }
  48.     $country = zen_db_prepare_input($_POST['zone_country_id']);
  49. //echo ' I SEE: country=' . $country . '&nbsp;&nbsp;&nbsp;state=' . $state . '&nbsp;&nbsp;&nbsp;zone_id=' . $zone_id;
  50.     if (ACCOUNT_GENDER == 'true') {
  51.       if ( ($gender != 'm') && ($gender != 'f') ) {
  52.         $error = true;
  53.         $messageStack->add('checkout_address', ENTRY_GENDER_ERROR);
  54.       }
  55.     }
  56.  
  57.     if (strlen($firstname) < ENTRY_FIRST_NAME_MIN_LENGTH) {
  58.       $error = true;
  59.       $messageStack->add('checkout_address', ENTRY_FIRST_NAME_ERROR);
  60.     }
  61.  
  62.     if (strlen($lastname) < ENTRY_LAST_NAME_MIN_LENGTH) {
  63.       $error = true;
  64.       $messageStack->add('checkout_address', ENTRY_LAST_NAME_ERROR);
  65.     }
  66.  
  67.     if (strlen($street_address) < ENTRY_STREET_ADDRESS_MIN_LENGTH) {
  68.       $error = true;
  69.       $messageStack->add('checkout_address', ENTRY_STREET_ADDRESS_ERROR);
  70.     }
  71.  
  72.     if (strlen($city) < ENTRY_CITY_MIN_LENGTH) {
  73.       $error = true;
  74.       $messageStack->add('checkout_address', ENTRY_CITY_ERROR);
  75.     }
  76.  
  77.     if (ACCOUNT_STATE == 'true') {
  78.       $check_query = "SELECT count(*) AS total
  79.                      FROM " . TABLE_ZONES . "
  80.                      WHERE zone_country_id = :zoneCountryID";
  81.       $check_query = $db->bindVars($check_query, ':zoneCountryID', $country, 'integer');
  82.       $check = $db->Execute($check_query);
  83.       $entry_state_has_zones = ($check->fields['total'] > 0);
  84.       if ($entry_state_has_zones == true) {
  85.       $zone_query = "SELECT distinct zone_id, zone_name, zone_code
  86.                       FROM " . TABLE_ZONES . "
  87.                       WHERE zone_country_id = :zoneCountryID
  88.                       AND " .
  89.                      ((trim($state) != '' && $zone_id == 0) ? "(upper(zone_name) like ':zoneState%' OR upper(zone_code) like '%:zoneState%') OR " : "") .
  90.                       "zone_id = :zoneID
  91.                       ORDER BY zone_code ASC, zone_name";
  92.  
  93.         $zone_query = $db->bindVars($zone_query, ':zoneCountryID', $country, 'integer');
  94. // BOM by zen-cart.cn
  95.         $zone_query = $db->bindVars($zone_query, ':zoneState', GBcase($state,"upper"), 'noquotestring');
  96. // EOM by zen-cart.cn
  97.         $zone_query = $db->bindVars($zone_query, ':zoneID', $zone_id, 'integer');
  98.         $zone = $db->Execute($zone_query);
  99.  
  100.       //look for an exact match on zone ISO code
  101.       $found_exact_iso_match = ($zone->RecordCount() == 1);
  102.       if ($zone->RecordCount() > 1) {
  103.         while (!$zone->EOF && !$found_exact_iso_match) {
  104.           if (strtoupper($zone->fields['zone_code']) == strtoupper($state) ) {
  105.             $found_exact_iso_match = true;
  106.             continue;
  107.           }
  108.           $zone->MoveNext();
  109.         }
  110.       }
  111.  
  112.       if ($found_exact_iso_match) {
  113.         $zone_id = $zone->fields['zone_id'];
  114.         $zone_name = $zone->fields['zone_name'];
  115.       } else {
  116.         $error = true;
  117.         $error_state_input = true;
  118.         $messageStack->add('checkout_address', ENTRY_STATE_ERROR_SELECT);
  119.       }
  120.     } else {
  121.       if (strlen($state) < ENTRY_STATE_MIN_LENGTH) {
  122.         $error = true;
  123.         $error_state_input = true;
  124.         $messageStack->add('checkout_address', ENTRY_STATE_ERROR);
  125.       }
  126.     }
  127.   }
  128.  
  129.     if (strlen($postcode) < ENTRY_POSTCODE_MIN_LENGTH) {
  130.       $error = true;
  131.       $messageStack->add('checkout_address', ENTRY_POST_CODE_ERROR);
  132.     }
  133.  
  134.     if ( (is_numeric($country) == false) || ($country < 1) ) {
  135.       $error = true;
  136.       $messageStack->add('checkout_address', ENTRY_COUNTRY_ERROR);
  137.     }
  138.  
  139.     if ($error == false) {
  140.       $sql_data_array = array(array('fieldName'=>'customers_id', 'value'=>$_SESSION['customer_id'], 'type'=>'integer'),
  141.                               array('fieldName'=>'entry_firstname', 'value'=>$firstname, 'type'=>'string'),
  142.                               array('fieldName'=>'entry_lastname','value'=>$lastname, 'type'=>'string'),
  143.                               array('fieldName'=>'entry_street_address','value'=>$street_address, 'type'=>'string'),
  144.                               array('fieldName'=>'entry_postcode', 'value'=>$postcode, 'type'=>'string'),
  145.                               array('fieldName'=>'entry_city', 'value'=>$city, 'type'=>'string'),
  146.                               array('fieldName'=>'entry_country_id', 'value'=>$country, 'type'=>'integer')
  147.       );
  148.  
  149.       if (ACCOUNT_GENDER == 'true') $sql_data_array[] = array('fieldName'=>'entry_gender', 'value'=>$gender, 'type'=>'enum:m|f');
  150.       if (ACCOUNT_COMPANY == 'true') $sql_data_array[] = array('fieldName'=>'entry_company', 'value'=>$company, 'type'=>'string');
  151.       if (ACCOUNT_SUBURB == 'true') $sql_data_array[] = array('fieldName'=>'entry_suburb', 'value'=>$suburb, 'type'=>'string');
  152.       if (ACCOUNT_STATE == 'true') {
  153.         if ($zone_id > 0) {
  154.           $sql_data_array[] = array('fieldName'=>'entry_zone_id', 'value'=>$zone_id, 'type'=>'integer');
  155.           $sql_data_array[] = array('fieldName'=>'entry_state', 'value'=>'', 'type'=>'string');
  156.         } else {
  157.           $sql_data_array[] = array('fieldName'=>'entry_zone_id', 'value'=>0, 'type'=>'integer');
  158.           $sql_data_array[] = array('fieldName'=>'entry_state', 'value'=>$state, 'type'=>'string');
  159.         }
  160.       }
  161.       $db->perform(TABLE_ADDRESS_BOOK, $sql_data_array);
  162.       $zco_notifier->notify('NOTIFY_MODULE_CHECKOUT_ADDED_ADDRESS_BOOK_RECORD', array_merge(array('address_id' => $db->Insert_ID() ), $sql_data_array));
  163.       switch($addressType) {
  164.         case 'billto':
  165.         $_SESSION['billto'] = $db->Insert_ID();
  166.         $_SESSION['payment'] = '';
  167.         zen_redirect(zen_href_link(FILENAME_CHECKOUT_PAYMENT, '', 'SSL'));
  168.         break;
  169.         case 'shipto':
  170.         $_SESSION['sendto'] = $db->Insert_ID();
  171.         $_SESSION['shipping'] = '';
  172.         zen_redirect(zen_href_link(FILENAME_CHECKOUT_SHIPPING, '', 'SSL'));
  173.         break;
  174.       }
  175.     }
  176.   } elseif (isset($_POST['address'])) {
  177.     switch($addressType) {
  178.       case 'billto':
  179.       $reset_payment = false;
  180.       if ($_SESSION['billto']) {
  181.         if ($_SESSION['billto'] != $_POST['address']) {
  182.           if ($_SESSION['payment']) {
  183.             $reset_payment = true;
  184.           }
  185.         }
  186.       }
  187.       $_SESSION['billto'] = $_POST['address'];
  188.  
  189.       $check_address_query = "SELECT count(*) AS total
  190.                              FROM " . TABLE_ADDRESS_BOOK . "
  191.                              WHERE customers_id = :customersID
  192.                              AND address_book_id = :addressBookID";
  193.  
  194.       $check_address_query = $db->bindVars($check_address_query, ':customersID', $_SESSION['customer_id'], 'integer');
  195.       $check_address_query = $db->bindVars($check_address_query, ':addressBookID', $_SESSION['billto'], 'integer');
  196.       $check_address = $db->Execute($check_address_query);
  197.  
  198.       if ($check_address->fields['total'] == '1') {
  199.         if ($reset_payment == true) $_SESSION['payment'] = '';
  200.         zen_redirect(zen_href_link(FILENAME_CHECKOUT_PAYMENT, '', 'SSL'));
  201.       } else {
  202.         $_SESSION['billto'] = '';
  203.       }
  204.       // no addresses to select from - customer decided to keep the current assigned address
  205.       break;
  206.       case 'shipto':
  207.       $reset_shipping = false;
  208.       if ($_SESSION['sendto']) {
  209.         if ($_SESSION['sendto'] != $_POST['address']) {
  210.           if ($_SESSION['shipping']) {
  211.             $reset_shipping = true;
  212.           }
  213.         }
  214.       }
  215.      $_SESSION['sendto'] = $_POST['address'];
  216.       $check_address_query = "SELECT count(*) AS total
  217.                              FROM " . TABLE_ADDRESS_BOOK . "
  218.                              WHERE customers_id = :customersID
  219.                              AND address_book_id = :addressBookID";
  220.  
  221.       $check_address_query = $db->bindVars($check_address_query, ':customersID', $_SESSION['customer_id'], 'integer');
  222.       $check_address_query = $db->bindVars($check_address_query, ':addressBookID', $_SESSION['sendto'], 'integer');
  223.       $check_address = $db->Execute($check_address_query);
  224.       if ($check_address->fields['total'] == '1') {
  225.         if ($reset_shipping == true) $_SESSION['shipping'] = '';
  226.         zen_redirect(zen_href_link(FILENAME_CHECKOUT_SHIPPING, '', 'SSL'));
  227.       } else {
  228.         $_SESSION['sendto'] = '';
  229.       }
  230.       break;
  231.     }
  232.   } else {
  233.     switch($addressType) {
  234.       case 'billto':
  235.       $_SESSION['billto'] = $_SESSION['customer_default_address_id'];
  236.       zen_redirect(zen_href_link(FILENAME_CHECKOUT_PAYMENT, '', 'SSL'));
  237.       break;
  238.       case 'shipto':
  239.       $_SESSION['sendto'] = $_SESSION['customer_default_address_id'];
  240.       zen_redirect(zen_href_link(FILENAME_CHECKOUT_SHIPPING, '', 'SSL'));
  241.       break;
  242.     }
  243.   }
  244. }
  245.  
  246.  
  247. /*
  248.  * Set flags for template use:
  249.  */
  250.   $selected_country = (isset($_POST['zone_country_id']) && $_POST['zone_country_id'] != '') ? $country : SHOW_CREATE_ACCOUNT_DEFAULT_COUNTRY;
  251.   $flag_show_pulldown_states = ((($process == true || $entry_state_has_zones == true) && $zone_name == '') || ACCOUNT_STATE_DRAW_INITIAL_DROPDOWN == 'true' || $error_state_input) ? true : false;
  252.   $state = ($flag_show_pulldown_states) ? $state : $zone_name;
  253.   $state_field_label = ($flag_show_pulldown_states) ? '' : ENTRY_STATE;
  254.  
  255. // This should be last line of the script:
  256. $zco_notifier->notify('NOTIFY_MODULE_END_CHECKOUT_NEW_ADDRESS');
  257. ?>