Jump to content
  • Checkout
  • Login
  • Get in touch

osCommerce

The e-commerce.

Combining INSERT customer & Purchase order


suzie

Recommended Posts

I'm having a problem combining the STEP ORDER (or manual customer insert) hack and the Purchase order 1_4_ 1 Module. It's only the /admin/customers.php file I'm having problems with. They work fine on their own, but once combined I get a PARSE error on line 183 of the customers.php file.

 

Here's the code of the Combined customers.php file which is giving me a parse error.

<?php

/*

  $Id: customers.php,v 1.82 2003/06/30 13:54:14 dgw_ Exp $

 

  osCommerce, Open Source E-Commerce Solutions

  http://www.oscommerce.com

 

  Copyright © 2003 osCommerce

 

  Released under the GNU General Public License

*/

 

  require('includes/application_top.php');

 

//#CHAVEIRO6# Step order/customer begin

////

// This function makes a new password from a plaintext password.

  function tep_encrypt_password($plain) {

    $password = '';

 

    for ($i=0; $i<10; $i++) {

      $password .= tep_rand();

    }

 

    $salt = substr(md5($password), 0, 2);

 

    $password = md5($salt . $plain) . ':' . $salt;

 

    return $password;

  }

//#CHAVEIRO6# Step order/customer end

 

  $action = (isset($HTTP_GET_VARS['action']) ? $HTTP_GET_VARS['action'] : '');

 

  $error = false;

  $processed = false;

 

  if (tep_not_null($action)) {

    switch ($action) {

      case 'update':

      case 'insert':

        $customers_id = tep_db_prepare_input($HTTP_GET_VARS['cID']);

        $customers_firstname = tep_db_prepare_input($HTTP_POST_VARS['customers_firstname']);

        $customers_lastname = tep_db_prepare_input($HTTP_POST_VARS['customers_lastname']);

        $customers_email_address = tep_db_prepare_input($HTTP_POST_VARS['customers_email_address']);

        $customers_telephone = tep_db_prepare_input($HTTP_POST_VARS['customers_telephone']);

        $customers_fax = tep_db_prepare_input($HTTP_POST_VARS['customers_fax']);

        $customers_newsletter = tep_db_prepare_input($HTTP_POST_VARS['customers_newsletter']);

// purchaseorders_1_4 start

    // Addition of customers_allow_purchase_order_entry to query.

        $customers_allow_purchase_order_entry = tep_db_prepare_input($HTTP_POST_VARS['customers_allow_purchase_order_entry']);

// purchaseorders_1_4 end

        $customers_gender = tep_db_prepare_input($HTTP_POST_VARS['customers_gender']);

        $customers_dob = tep_db_prepare_input($HTTP_POST_VARS['customers_dob']);

 

        $default_address_id = tep_db_prepare_input($HTTP_POST_VARS['default_address_id']);

        $entry_street_address = tep_db_prepare_input($HTTP_POST_VARS['entry_street_address']);

        $entry_suburb = tep_db_prepare_input($HTTP_POST_VARS['entry_suburb']);

        $entry_postcode = tep_db_prepare_input($HTTP_POST_VARS['entry_postcode']);

        $entry_city = tep_db_prepare_input($HTTP_POST_VARS['entry_city']);

        $entry_country_id = tep_db_prepare_input($HTTP_POST_VARS['entry_country_id']);

 

        $entry_company = tep_db_prepare_input($HTTP_POST_VARS['entry_company']);

        $entry_state = tep_db_prepare_input($HTTP_POST_VARS['entry_state']);

        if (isset($HTTP_POST_VARS['entry_zone_id'])) $entry_zone_id = tep_db_prepare_input($HTTP_POST_VARS['entry_zone_id']);

 

        if (strlen($customers_firstname) < ENTRY_FIRST_NAME_MIN_LENGTH) {

          $error = true;

          $entry_firstname_error = true;

        } else {

          $entry_firstname_error = false;

        }

 

        if (strlen($customers_lastname) < ENTRY_LAST_NAME_MIN_LENGTH) {

          $error = true;

          $entry_lastname_error = true;

        } else {

          $entry_lastname_error = false;

        }

 

        if (ACCOUNT_DOB == 'true') {

          if (checkdate(substr(tep_date_raw($customers_dob), 4, 2), substr(tep_date_raw($customers_dob), 6, 2), substr(tep_date_raw($customers_dob), 0, 4))) {

            $entry_date_of_birth_error = false;

          } else {

            $error = true;

            $entry_date_of_birth_error = true;

          }

        }

 

        if (strlen($customers_email_address) < ENTRY_EMAIL_ADDRESS_MIN_LENGTH) {

          $error = true;

          $entry_email_address_error = true;

        } else {

          $entry_email_address_error = false;

        }

 

        if (!tep_validate_email($customers_email_address)) {

          $error = true;

          $entry_email_address_check_error = true;

        } else {

          $entry_email_address_check_error = false;

        }

 

        if (strlen($entry_street_address) < ENTRY_STREET_ADDRESS_MIN_LENGTH) {

          $error = true;

          $entry_street_address_error = true;

        } else {

          $entry_street_address_error = false;

        }

 

        if (strlen($entry_postcode) < ENTRY_POSTCODE_MIN_LENGTH) {

          $error = true;

          $entry_post_code_error = true;

        } else {

          $entry_post_code_error = false;

        }

 

        if (strlen($entry_city) < ENTRY_CITY_MIN_LENGTH) {

          $error = true;

          $entry_city_error = true;

        } else {

          $entry_city_error = false;

        }

 

        if ($entry_country_id == false) {

          $error = true;

          $entry_country_error = true;

        } else {

          $entry_country_error = false;

        }

 

        if (ACCOUNT_STATE == 'true') {

          if ($entry_country_error == true) {

            $entry_state_error = true;

          } else {

            $zone_id = 0;

            $entry_state_error = false;

            $check_query = tep_db_query("select count(*) as total from " . TABLE_ZONES . " where zone_country_id = '" . (int)$entry_country_id . "'");

            $check_value = tep_db_fetch_array($check_query);

            $entry_state_has_zones = ($check_value['total'] > 0);

            if ($entry_state_has_zones == true) {

              $zone_query = tep_db_query("select zone_id from " . TABLE_ZONES . " where zone_country_id = '" . (int)$entry_country_id . "' and zone_name = '" . tep_db_input($entry_state) . "'");

              if (tep_db_num_rows($zone_query) == 1) {

                $zone_values = tep_db_fetch_array($zone_query);

                $entry_zone_id = $zone_values['zone_id'];

              } else {

                $error = true;

                $entry_state_error = true;

              }

            } else {

              if ($entry_state == false) {

                $error = true;

                $entry_state_error = true;

              }

            }

        }

      }

 

      if (strlen($customers_telephone) < ENTRY_TELEPHONE_MIN_LENGTH) {

        $error = true;

        $entry_telephone_error = true;

      } else {

        $entry_telephone_error = false;

      }

 

      $check_email = tep_db_query("select customers_email_address from " . TABLE_CUSTOMERS . " where customers_email_address = '" . tep_db_input($customers_email_address) . "' and customers_id != '" . (int)$customers_id . "'");

      if (tep_db_num_rows($check_email)) {

        $error = true;

        $entry_email_address_exists = true;

      } else {

        $entry_email_address_exists = false;

      }

 

      if ($error == false) {

 

        $sql_data_array = array('customers_firstname' => $customers_firstname,

                                'customers_lastname' => $customers_lastname,

                                'customers_email_address' => $customers_email_address,

                                'customers_telephone' => $customers_telephone,

                                'customers_fax' => $customers_fax,

        'customers_newsletter' => $customers_newsletter);

// purchaseorders_1_4 start

        'customers_allow_purchase_order_entry' => $customers_allow_purchase_order_entry);

// purchaseorders_1_4 end

 

  if (ACCOUNT_GENDER == 'true') $sql_data_array['customers_gender'] = $customers_gender;

        if (ACCOUNT_DOB == 'true') $sql_data_array['customers_dob'] = tep_date_raw($customers_dob);

 

//#CHAVEIRO6# Step order/customer begin

  if ($action == 'insert') {

    //      RAMDOMIZING SCRIPT BY PATRIC VEVERKA

    $t1 = date("mdy");

    srand ((float) microtime() * 10000000);

//    $input = array ("A", "a", "B", "b", "C", "c", "D", "d", "E", "e", "F", "f", "G", "g", "H", "h", "I", "i", "J", "j", "K", "k", "L", "l", "M", "m", "N", "n", "O", "o", "P", "p", "Q", "q", "R", "r", "S", "s", "T", "t", "U", "u", "V", "v", "W", "w", "X", "x", "Y", "y", "Z", "z");

    $input = array ("a","b","c","d","e","f","g","h","i","j","k","l","m","n","o","p","q","r","s","t","u","v","w","x","y","z");

    $rand_keys = array_rand ($input, 3);

    $l1 = $input[$rand_keys[0]];

    $r1 = rand(0,9);

    $l2 = $input[$rand_keys[1]];

    $l3 = $input[$rand_keys[2]];

    $r2 = rand(0,9);

    $password = "gt".$l1.$r1.$l2.$l3.$r2;

    //    End of Randomizing Script

    $sql_data_array['customers_password'] = tep_encrypt_password($password);

 

    tep_db_perform(TABLE_CUSTOMERS, $sql_data_array);

 

    $customer_id = tep_db_insert_id();

 

    $sql_data_array = array('customers_id' => $customer_id,

                              'entry_firstname' => $customers_firstname,

                              'entry_lastname' => $customers_lastname,

                              'entry_street_address' => $entry_street_address,

                              'entry_postcode' => $entry_postcode,

                              'entry_city' => $entry_city,

        'entry_gender' => $customers_gender,

                              'entry_country_id' => $entry_country_id);

  }

  else {

//#CHAVEIRO6# Step order/customer end

 

  tep_db_perform(TABLE_CUSTOMERS, $sql_data_array, 'update', "customers_id = '" . (int)$customers_id . "'");

 

        tep_db_query("update " . TABLE_CUSTOMERS_INFO . " set customers_info_date_account_last_modified = now() where customers_info_id = '" . (int)$customers_id . "'");

 

        if ($entry_zone_id > 0) $entry_state = '';

 

        $sql_data_array = array('entry_firstname' => $customers_firstname,

                                'entry_lastname' => $customers_lastname,

                                'entry_street_address' => $entry_street_address,

                                'entry_postcode' => $entry_postcode,

                                'entry_city' => $entry_city,

                                'entry_country_id' => $entry_country_id);

 

//#CHAVEIRO6# Step order/customer begin

  }

//#CHAVEIRO6# Step order/customer end

 

        if (ACCOUNT_COMPANY == 'true') $sql_data_array['entry_company'] = $entry_company;

        if (ACCOUNT_SUBURB == 'true') $sql_data_array['entry_suburb'] = $entry_suburb;

 

        if (ACCOUNT_STATE == 'true') {

          if ($entry_zone_id > 0) {

            $sql_data_array['entry_zone_id'] = $entry_zone_id;

            $sql_data_array['entry_state'] = '';

          } else {

            $sql_data_array['entry_zone_id'] = '0';

            $sql_data_array['entry_state'] = $entry_state;

          }

        }

 

//#CHAVEIRO6# Step order/customer begin

  if ($action == 'insert') {

        tep_db_perform(TABLE_ADDRESS_BOOK, $sql_data_array);

      $address_id = tep_db_insert_id();

      tep_db_query("update " . TABLE_CUSTOMERS . " set customers_default_address_id = '" . (int)$address_id . "' where customers_id = '" . (int)$customer_id . "'");

      tep_db_query("insert into " . TABLE_CUSTOMERS_INFO . " (customers_info_id, customers_info_number_of_logons, customers_info_date_account_created) values ('" . (int)$customer_id . "', '0', now())");

 

    // build the message content

    $name = $customers_firstname . " " . $customers_lastname;

    if (ACCOUNT_GENDER == 'true') {

      if ($HTTP_POST_VARS['customers_gender'] == 'm') {

        $email_text = sprintf(EMAIL_GREET_MR, $customers_lastname);

      } else {

        $email_text = sprintf(EMAIL_GREET_MS, $customers_lastname);

      }

    } else {

    $email_text = sprintf(EMAIL_GREET_NONE, $customers_firstname);

    }

   

    $email_text .= EMAIL_WELCOME . sprintf(EMAIL_PASS, $password) . EMAIL_TEXT . EMAIL_CONTACT . EMAIL_WARNING;

    tep_mail($name, $customers_email_address, EMAIL_SUBJECT, nl2br($email_text), STORE_OWNER, STORE_OWNER_EMAIL_ADDRESS);

 

    tep_redirect(tep_href_link(FILENAME_CUSTOMERS, tep_get_all_get_params(array('cID', 'action')) . 'cID=' . $customer_id)); 

  }

  else {

//#CHAVEIRO6# Step order/customer end

 

  tep_db_perform(TABLE_ADDRESS_BOOK, $sql_data_array, 'update', "customers_id = '" . (int)$customers_id . "' and address_book_id = '" . (int)$default_address_id . "'");

 

        tep_redirect(tep_href_link(FILENAME_CUSTOMERS, tep_get_all_get_params(array('cID', 'action')) . 'cID=' . $customers_id));

 

//#CHAVEIRO6# Step order/customer begin

  }

//#CHAVEIRO6# Step order/customer end

 

        } else if ($error == true) {

          $cInfo = new objectInfo($HTTP_POST_VARS);

          $processed = true;

        }

 

        break;

      case 'deleteconfirm':

        $customers_id = tep_db_prepare_input($HTTP_GET_VARS['cID']);

 

        if (isset($HTTP_POST_VARS['delete_reviews']) && ($HTTP_POST_VARS['delete_reviews'] == 'on')) {

          $reviews_query = tep_db_query("select reviews_id from " . TABLE_REVIEWS . " where customers_id = '" . (int)$customers_id . "'");

          while ($reviews = tep_db_fetch_array($reviews_query)) {

            tep_db_query("delete from " . TABLE_REVIEWS_DESCRIPTION . " where reviews_id = '" . (int)$reviews['reviews_id'] . "'");

          }

 

          tep_db_query("delete from " . TABLE_REVIEWS . " where customers_id = '" . (int)$customers_id . "'");

        } else {

          tep_db_query("update " . TABLE_REVIEWS . " set customers_id = null where customers_id = '" . (int)$customers_id . "'");

        }

 

        tep_db_query("delete from " . TABLE_ADDRESS_BOOK . " where customers_id = '" . (int)$customers_id . "'");

        tep_db_query("delete from " . TABLE_CUSTOMERS . " where customers_id = '" . (int)$customers_id . "'");

        tep_db_query("delete from " . TABLE_CUSTOMERS_INFO . " where customers_info_id = '" . (int)$customers_id . "'");

        tep_db_query("delete from " . TABLE_CUSTOMERS_BASKET . " where customers_id = '" . (int)$customers_id . "'");

        tep_db_query("delete from " . TABLE_CUSTOMERS_BASKET_ATTRIBUTES . " where customers_id = '" . (int)$customers_id . "'");

        tep_db_query("delete from " . TABLE_WHOS_ONLINE . " where customer_id = '" . (int)$customers_id . "'");

 

        tep_redirect(tep_href_link(FILENAME_CUSTOMERS, tep_get_all_get_params(array('cID', 'action'))));

        break;

 

//#CHAVEIRO6# Step order/customer begin

      case 'new':

    $customers_newsletter = 1;

    $entry_country_id = STORE_COUNTRY;

//#CHAVEIRO6# Step order/customer end

 

      default:

 

//#CHAVEIRO6# Step order/customer begin

  if ($action != 'new') {

//#CHAVEIRO6# Step order/customer end

 

// purchaseorders_1_4 start

    // Added c.customers_allow_purchase_order_entry to query.

        $customers_query = tep_db_query("select c.customers_id, c.customers_gender, c.customers_firstname, c.customers_lastname, c.customers_dob, c.customers_email_address, c.customers_allow_purchase_order_entry, a.entry_company, a.entry_street_address, a.entry_suburb, a.entry_postcode, a.entry_city, a.entry_state, a.entry_zone_id, a.entry_country_id, c.customers_telephone, c.customers_fax, c.customers_newsletter, c.customers_default_address_id from " . TABLE_CUSTOMERS . " c left join " . TABLE_ADDRESS_BOOK . " a on c.customers_default_address_id = a.address_book_id where a.customers_id = c.customers_id and c.customers_id = '" . (int)$HTTP_GET_VARS['cID'] . "'");

// purchaseorders_1_4 end

 

        $customers = tep_db_fetch_array($customers_query);

        $cInfo = new objectInfo($customers);

 

//#CHAVEIRO6# Step order/customer begin

  }

//#CHAVEIRO6# Step order/customer end

    }

  }

?>

<!doctype html public "-//W3C//DTD HTML 4.01 Transitional//EN">

<html <?php echo HTML_PARAMS; ?>>

<head>

<meta http-equiv="Content-Type" content="text/html; charset=<?php echo CHARSET; ?>">

<title><?php echo TITLE; ?></title>

<link rel="stylesheet" type="text/css" href="includes/stylesheet.css">

<script language="javascript" src="includes/general.js"></script>

<?php

  if ($action == 'edit' || $action == 'update'

//#CHAVEIRO6# Step order/customer begin

  || $action == 'new' || $action == 'insert'

//#CHAVEIRO6# Step order/customer end

) {

?>

<script language="javascript"><!--

 

function check_form() {

  var error = 0;

  var error_message = "<?php echo JS_ERROR; ?>";

 

  var customers_firstname = document.customers.customers_firstname.value;

  var customers_lastname = document.customers.customers_lastname.value;

<?php if (ACCOUNT_COMPANY == 'true') echo 'var entry_company = document.customers.entry_company.value;' . "\n"; ?>

<?php if (ACCOUNT_DOB == 'true') echo 'var customers_dob = document.customers.customers_dob.value;' . "\n"; ?>

  var customers_email_address = document.customers.customers_email_address.value;

  var entry_street_address = document.customers.entry_street_address.value;

  var entry_postcode = document.customers.entry_postcode.value;

  var entry_city = document.customers.entry_city.value;

  var customers_telephone = document.customers.customers_telephone.value;

 

<?php if (ACCOUNT_GENDER == 'true') { ?>

  if (document.customers.customers_gender[0].checked || document.customers.customers_gender[1].checked) {

  } else {

    error_message = error_message + "<?php echo JS_GENDER; ?>";

    error = 1;

  }

<?php } ?>

 

  if (customers_firstname == "" || customers_firstname.length < <?php echo ENTRY_FIRST_NAME_MIN_LENGTH; ?>) {

    error_message = error_message + "<?php echo JS_FIRST_NAME; ?>";

    error = 1;

  }

 

  if (customers_lastname == "" || customers_lastname.length < <?php echo ENTRY_LAST_NAME_MIN_LENGTH; ?>) {

    error_message = error_message + "<?php echo JS_LAST_NAME; ?>";

    error = 1;

  }

 

<?php if (ACCOUNT_DOB == 'true') { ?>

  if (customers_dob == "" || customers_dob.length < <?php echo ENTRY_DOB_MIN_LENGTH; ?>) {

    error_message = error_message + "<?php echo JS_DOB; ?>";

    error = 1;

  }

<?php } ?>

 

  if (customers_email_address == "" || customers_email_address.length < <?php echo ENTRY_EMAIL_ADDRESS_MIN_LENGTH; ?>) {

    error_message = error_message + "<?php echo JS_EMAIL_ADDRESS; ?>";

    error = 1;

  }

 

  if (entry_street_address == "" || entry_street_address.length < <?php echo ENTRY_STREET_ADDRESS_MIN_LENGTH; ?>) {

    error_message = error_message + "<?php echo JS_ADDRESS; ?>";

    error = 1;

  }

 

  if (entry_postcode == "" || entry_postcode.length < <?php echo ENTRY_POSTCODE_MIN_LENGTH; ?>) {

    error_message = error_message + "<?php echo JS_POST_CODE; ?>";

    error = 1;

  }

 

  if (entry_city == "" || entry_city.length < <?php echo ENTRY_CITY_MIN_LENGTH; ?>) {

    error_message = error_message + "<?php echo JS_CITY; ?>";

    error = 1;

  }

 

<?php

  if (ACCOUNT_STATE == 'true') {

?>

  if (document.customers.elements['entry_state'].type != "hidden") {

    if (document.customers.entry_state.value == '' || document.customers.entry_state.value.length < <?php echo ENTRY_STATE_MIN_LENGTH; ?> ) {

      error_message = error_message + "<?php echo JS_STATE; ?>";

      error = 1;

    }

  }

<?php

  }

?>

 

  if (document.customers.elements['entry_country_id'].type != "hidden") {

    if (document.customers.entry_country_id.value == 0) {

      error_message = error_message + "<?php echo JS_COUNTRY; ?>";

      error = 1;

    }

  }

 

  if (customers_telephone == "" || customers_telephone.length < <?php echo ENTRY_TELEPHONE_MIN_LENGTH; ?>) {

    error_message = error_message + "<?php echo JS_TELEPHONE; ?>";

    error = 1;

  }

 

  if (error == 1) {

    alert(error_message);

    return false;

  } else {

    return true;

  }

}

//--></script>

<?php

  }

?>

</head>

<body marginwidth="0" marginheight="0" topmargin="0" bottommargin="0" leftmargin="0" rightmargin="0" bgcolor="#FFFFFF" onload="SetFocus();">

<!-- header //-->

<?php require(DIR_WS_INCLUDES . 'header.php'); ?>

<!-- header_eof //-->

 

<!-- body //-->

<table border="0" width="100%" cellspacing="2" cellpadding="2">

  <tr>

    <td width="<?php echo BOX_WIDTH; ?>" valign="top"><table border="0" width="<?php echo BOX_WIDTH; ?>" cellspacing="1" cellpadding="1" class="columnLeft">

<!-- left_navigation //-->

<?php require(DIR_WS_INCLUDES . 'column_left.php'); ?>

<!-- left_navigation_eof //-->

    </table></td>

<!-- body_text //-->

    <td width="100%" valign="top"><table border="0" width="100%" cellspacing="0" cellpadding="2">

<?php

  if ($action == 'edit' || $action == 'update'

//#CHAVEIRO6# Step order/customer begin

  || $action == 'new' || $action == 'insert'

//#CHAVEIRO6# Step order/customer end

  ) {

    $newsletter_array = array(array('id' => '1', 'text' => ENTRY_NEWSLETTER_YES),

                              array('id' => '0', 'text' => ENTRY_NEWSLETTER_NO));

?>

      <tr>

        <td><table border="0" width="100%" cellspacing="0" cellpadding="0">

          <tr>

            <td class="pageHeading"><?php

//#CHAVEIRO6# Step order/customer begin

    if ($action == 'new' || $action == 'insert') {

    echo HEADING_TITLE_ADD; }

    else {

//#CHAVEIRO6# Step order/customer end

    echo HEADING_TITLE;

//#CHAVEIRO6# Step order/customer begin

  }

//#CHAVEIRO6# Step order/customer end

?></td>

            <td class="pageHeading" align="right"><?php echo tep_draw_separator('pixel_trans.gif', HEADING_IMAGE_WIDTH, HEADING_IMAGE_HEIGHT); ?></td>

          </tr>

        </table></td>

      </tr>

      <tr>

        <td><?php echo tep_draw_separator('pixel_trans.gif', '1', '10'); ?></td>

      </tr>

      <tr><?php echo tep_draw_form('customers', FILENAME_CUSTOMERS, tep_get_all_get_params(array('action')) .

//#CHAVEIRO6# Step order/customer begin

(($action == 'new' || $action == 'insert') ? 'action=insert' : 'action=update')

//#CHAVEIRO6# Step order/customer end

, 'post', 'onSubmit="return check_form();"') . tep_draw_hidden_field('default_address_id', $cInfo->customers_default_address_id); ?>

        <td class="formAreaTitle"><?php echo CATEGORY_PERSONAL; ?></td>

      </tr>

      <tr>

        <td class="formArea"><table border="0" cellspacing="2" cellpadding="2">

<?php

    if (ACCOUNT_GENDER == 'true') {

?>

          <tr>

            <td class="main"><?php echo ENTRY_GENDER; ?></td>

            <td class="main">

<?php

    if ($error == true) {

      if ($entry_gender_error == true) {

        echo tep_draw_radio_field('customers_gender', 'm', false, $cInfo->customers_gender) . '  ' . MALE . '  ' . tep_draw_radio_field('customers_gender', 'f', false, $cInfo->customers_gender) . '  ' . FEMALE . ' ' . ENTRY_GENDER_ERROR;

      } else {

        echo ($cInfo->customers_gender == 'm') ? tep_draw_radio_field('customers_gender', 'm', true, $cInfo->customers_gender) . '  ' . MALE :  tep_draw_radio_field('customers_gender', 'f', true, $cInfo->customers_gender) . '  ' . FEMALE;

        echo tep_draw_hidden_field('customers_gender');

      }

    } else {

      echo tep_draw_radio_field('customers_gender', 'm', false, $cInfo->customers_gender) . '  ' . MALE . '  ' . tep_draw_radio_field('customers_gender', 'f', false, $cInfo->customers_gender) . '  ' . FEMALE;

    }

?></td>

          </tr>

<?php

    }

?>

          <tr>

            <td class="main"><?php echo ENTRY_FIRST_NAME; ?></td>

            <td class="main">

<?php

  if ($error == true) {

    if ($entry_firstname_error == true) {

      echo tep_draw_input_field('customers_firstname', $cInfo->customers_firstname, 'maxlength="32"') . ' ' . ENTRY_FIRST_NAME_ERROR;

    } else {

      echo $cInfo->customers_firstname . tep_draw_hidden_field('customers_firstname');

    }

  } else {

    echo tep_draw_input_field('customers_firstname', $cInfo->customers_firstname, 'maxlength="32"', true);

  }

?></td>

          </tr>

          <tr>

            <td class="main"><?php echo ENTRY_LAST_NAME; ?></td>

            <td class="main">

<?php

  if ($error == true) {

    if ($entry_lastname_error == true) {

      echo tep_draw_input_field('customers_lastname', $cInfo->customers_lastname, 'maxlength="32"') . ' ' . ENTRY_LAST_NAME_ERROR;

    } else {

      echo $cInfo->customers_lastname . tep_draw_hidden_field('customers_lastname');

    }

  } else {

    echo tep_draw_input_field('customers_lastname', $cInfo->customers_lastname, 'maxlength="32"', true);

  }

?></td>

          </tr>

<?php

    if (ACCOUNT_DOB == 'true') {

?>

          <tr>

            <td class="main"><?php echo ENTRY_DATE_OF_BIRTH; ?></td>

            <td class="main">

 

<?php

    if ($error == true) {

      if ($entry_date_of_birth_error == true) {

        echo tep_draw_input_field('customers_dob', tep_date_short($cInfo->customers_dob), 'maxlength="10"') . ' ' . ENTRY_DATE_OF_BIRTH_ERROR ;

      } else {

        echo $cInfo->customers_dob . tep_draw_hidden_field('customers_dob');

      }

    } else {

      echo tep_draw_input_field('customers_dob', tep_date_short($cInfo->customers_dob), 'maxlength="10"', true) . ' ' . ENTRY_DATE_OF_BIRTH_ERROR;

    }

?></td>

          </tr>

<?php

    }

?>

          <tr>

            <td class="main"><?php echo ENTRY_EMAIL_ADDRESS; ?></td>

            <td class="main">

<?php

  if ($error == true) {

    if ($entry_email_address_error == true) {

      echo tep_draw_input_field('customers_email_address', $cInfo->customers_email_address, 'maxlength="96"') . ' ' . ENTRY_EMAIL_ADDRESS_ERROR;

    } elseif ($entry_email_address_check_error == true) {

      echo tep_draw_input_field('customers_email_address', $cInfo->customers_email_address, 'maxlength="96"') . ' ' . ENTRY_EMAIL_ADDRESS_CHECK_ERROR;

    } elseif ($entry_email_address_exists == true) {

      echo tep_draw_input_field('customers_email_address', $cInfo->customers_email_address, 'maxlength="96"') . ' ' . ENTRY_EMAIL_ADDRESS_ERROR_EXISTS;

    } else {

      echo $customers_email_address . tep_draw_hidden_field('customers_email_address');

    }

  } else {

    echo tep_draw_input_field('customers_email_address', $cInfo->customers_email_address, 'maxlength="96"', true);

  }

?></td>

        </table></td>

      </tr>

<?php

    if (ACCOUNT_COMPANY == 'true') {

?>

      <tr>

        <td><?php echo tep_draw_separator('pixel_trans.gif', '1', '10'); ?></td>

      </tr>

      <tr>

        <td class="formAreaTitle"><?php echo CATEGORY_COMPANY; ?></td>

      </tr>

      <tr>

        <td class="formArea"><table border="0" cellspacing="2" cellpadding="2">

          <tr>

            <td class="main"><?php echo ENTRY_COMPANY; ?></td>

            <td class="main">

<?php

    if ($error == true) {

      if ($entry_company_error == true) {

        echo tep_draw_input_field('entry_company', $cInfo->entry_company, 'maxlength="32"') . ' ' . ENTRY_COMPANY_ERROR;

      } else {

        echo $cInfo->entry_company . tep_draw_hidden_field('entry_company');

      }

    } else {

      echo tep_draw_input_field('entry_company', $cInfo->entry_company, 'maxlength="32"');

    }

?></td>

          </tr>

        </table></td>

      </tr>

<?php

    }

?>

      <tr>

        <td><?php echo tep_draw_separator('pixel_trans.gif', '1', '10'); ?></td>

      </tr>

      <tr>

        <td class="formAreaTitle"><?php echo CATEGORY_ADDRESS; ?></td>

      </tr>

      <tr>

        <td class="formArea"><table border="0" cellspacing="2" cellpadding="2">

          <tr>

            <td class="main"><?php echo ENTRY_STREET_ADDRESS; ?></td>

            <td class="main">

<?php

  if ($error == true) {

    if ($entry_street_address_error == true) {

      echo tep_draw_input_field('entry_street_address', $cInfo->entry_street_address, 'maxlength="64"') . ' ' . ENTRY_STREET_ADDRESS_ERROR;

    } else {

      echo $cInfo->entry_street_address . tep_draw_hidden_field('entry_street_address');

    }

  } else {

    echo tep_draw_input_field('entry_street_address', $cInfo->entry_street_address, 'maxlength="64"', true);

  }

?></td>

          </tr>

<?php

    if (ACCOUNT_SUBURB == 'true') {

?>

          <tr>

            <td class="main"><?php echo ENTRY_SUBURB; ?></td>

            <td class="main">

<?php

    if ($error == true) {

      if ($entry_suburb_error == true) {

        echo tep_draw_input_field('suburb', $cInfo->entry_suburb, 'maxlength="32"') . ' ' . ENTRY_SUBURB_ERROR;

      } else {

        echo $cInfo->entry_suburb . tep_draw_hidden_field('entry_suburb');

      }

    } else {

      echo tep_draw_input_field('entry_suburb', $cInfo->entry_suburb, 'maxlength="32"');

    }

?></td>

          </tr>

<?php

    }

?>

          <tr>

            <td class="main"><?php echo ENTRY_POST_CODE; ?></td>

            <td class="main">

<?php

  if ($error == true) {

    if ($entry_post_code_error == true) {

      echo tep_draw_input_field('entry_postcode', $cInfo->entry_postcode, 'maxlength="8"') . ' ' . ENTRY_POST_CODE_ERROR;

    } else {

      echo $cInfo->entry_postcode . tep_draw_hidden_field('entry_postcode');

    }

  } else {

    echo tep_draw_input_field('entry_postcode', $cInfo->entry_postcode, 'maxlength="8"', true);

  }

?></td>

          </tr>

          <tr>

            <td class="main"><?php echo ENTRY_CITY; ?></td>

            <td class="main">

<?php

  if ($error == true) {

    if ($entry_city_error == true) {

      echo tep_draw_input_field('entry_city', $cInfo->entry_city, 'maxlength="32"') . ' ' . ENTRY_CITY_ERROR;

    } else {

      echo $cInfo->entry_city . tep_draw_hidden_field('entry_city');

    }

  } else {

    echo tep_draw_input_field('entry_city', $cInfo->entry_city, 'maxlength="32"', true);

  }

?></td>

          </tr>

<?php

    if (ACCOUNT_STATE == 'true') {

?>

          <tr>

            <td class="main"><?php echo ENTRY_STATE; ?></td>

            <td class="main">

<?php

    $entry_state = tep_get_zone_name($cInfo->entry_country_id, $cInfo->entry_zone_id, $cInfo->entry_state);

    if ($error == true) {

      if ($entry_state_error == true) {

        if ($entry_state_has_zones == true) {

          $zones_array = array();

          $zones_query = tep_db_query("select zone_name from " . TABLE_ZONES . " where zone_country_id = '" . tep_db_input($cInfo->entry_country_id) . "' order by zone_name");

          while ($zones_values = tep_db_fetch_array($zones_query)) {

            $zones_array[] = array('id' => $zones_values['zone_name'], 'text' => $zones_values['zone_name']);

          }

          echo tep_draw_pull_down_menu('entry_state', $zones_array) . ' ' . ENTRY_STATE_ERROR;

        } else {

          echo tep_draw_input_field('entry_state', tep_get_zone_name($cInfo->entry_country_id, $cInfo->entry_zone_id, $cInfo->entry_state)) . ' ' . ENTRY_STATE_ERROR;

        }

      } else {

        echo $entry_state . tep_draw_hidden_field('entry_zone_id') . tep_draw_hidden_field('entry_state');

      }

    } else {

      echo tep_draw_input_field('entry_state', tep_get_zone_name($cInfo->entry_country_id, $cInfo->entry_zone_id, $cInfo->entry_state),"",true);

    }

 

?></td>

        </tr>

<?php

    }

?>

          <tr>

            <td class="main"><?php echo ENTRY_COUNTRY; ?></td>

            <td class="main">

<?php

  if ($error == true) {

    if ($entry_country_error == true) {

      echo tep_draw_pull_down_menu('entry_country_id', tep_get_countries(), $cInfo->entry_country_id) . ' ' . ENTRY_COUNTRY_ERROR;

    } else {

      echo tep_get_country_name($cInfo->entry_country_id) . tep_draw_hidden_field('entry_country_id');

    }

  } else {

    echo tep_draw_pull_down_menu('entry_country_id', tep_get_countries(), $cInfo->entry_country_id);

  }

?></td>

          </tr>

        </table></td>

      </tr>

      <tr>

        <td><?php echo tep_draw_separator('pixel_trans.gif', '1', '10'); ?></td>

      </tr>

      <tr>

        <td class="formAreaTitle"><?php echo CATEGORY_CONTACT; ?></td>

      </tr>

      <tr>

        <td class="formArea"><table border="0" cellspacing="2" cellpadding="2">

          <tr>

            <td class="main"><?php echo ENTRY_TELEPHONE_NUMBER; ?></td>

            <td class="main">

<?php

  if ($error == true) {

    if ($entry_telephone_error == true) {

      echo tep_draw_input_field('customers_telephone', $cInfo->customers_telephone, 'maxlength="32"') . ' ' . ENTRY_TELEPHONE_NUMBER_ERROR;

    } else {

      echo $cInfo->customers_telephone . tep_draw_hidden_field('customers_telephone');

    }

  } else {

    echo tep_draw_input_field('customers_telephone', $cInfo->customers_telephone, 'maxlength="32"', true);

  }

?></td>

          </tr>

          <tr>

            <td class="main"><?php echo ENTRY_FAX_NUMBER; ?></td>

            <td class="main">

<?php

  if ($processed == true) {

    echo $cInfo->customers_fax . tep_draw_hidden_field('customers_fax');

  } else {

    echo tep_draw_input_field('customers_fax', $cInfo->customers_fax, 'maxlength="32"');

  }

?></td>

          </tr>

        </table></td>

      </tr>

      <tr>

        <td><?php echo tep_draw_separator('pixel_trans.gif', '1', '10'); ?></td>

      </tr>

      <tr>

        <td class="formAreaTitle"><?php echo CATEGORY_OPTIONS; ?></td>

      </tr>

      <tr>

        <td class="formArea"><table border="0" cellspacing="2" cellpadding="2">

          <tr>

            <td class="main"><?php echo ENTRY_NEWSLETTER; ?></td>

            <td class="main">

<?php

  if ($processed == true) {

    if ($cInfo->customers_newsletter == '1') {

      echo ENTRY_NEWSLETTER_YES;

    } else {

      echo ENTRY_NEWSLETTER_NO;

    }

    echo tep_draw_hidden_field('customers_newsletter');

  } else {

    echo tep_draw_pull_down_menu('customers_newsletter', $newsletter_array, (($cInfo->customers_newsletter == '1') ? '1' : '0'));

  }

?></td>

          </tr>

          <!-- purchaseorders_1_4 start -->

<!-- Radio buttons to enable/disable customer's ability to enter their own purchase order value. -->

  <tr>

        <td class="main"><?php echo ENTRY_ALLOW_PURCHASE_ORDER_ENTRY; ?></td>

        <td class="main">

<?php

        if($processed == true)

    {

          if($cInfo->customers_allow_purchase_order_entry == 'true')

      {

            echo TEXT_YES;

          }

      else

      {

            echo TEXT_NO;

          } // if - else

          echo tep_draw_hidden_field('customers_allow_purchase_order_entry');

        }

    else

    {

          echo tep_draw_radio_field('customers_allow_purchase_order_entry', 'true', false, $cInfo->customers_allow_purchase_order_entry) . '  ' . TEXT_YES . '  ' . tep_draw_radio_field('customers_allow_purchase_order_entry', 'false', false, $cInfo->customers_allow_purchase_order_entry) . '  ' . TEXT_NO;

        } // if - else

?></td>

<!-- purchaseorders_1_4 end -->

</tr>

        </table></td>

      </tr>

      <tr>

        <td><?php echo tep_draw_separator('pixel_trans.gif', '1', '10'); ?></td>

      </tr>

      <tr>

        <td align="right" class="main">

 

<!--//#CHAVEIRO6# Step order/customer begin !-->

  <?php

  if($action == 'new' || $action == 'insert') { echo tep_image_submit('button_insert.gif', IMAGE_INSERT) . ' <a href="' . tep_href_link(FILENAME_CUSTOMERS, tep_get_all_get_params(array('action'))) .'">' . tep_image_button('button_cancel.gif', IMAGE_CANCEL) . '</a>'; }

  else { ?>

<!--//#CHAVEIRO6# Step order/customer end !-->

 

  <?php echo tep_image_submit('button_update.gif', IMAGE_UPDATE) . ' <a href="' . tep_href_link(FILENAME_CUSTOMERS, tep_get_all_get_params(array('action'))) .'">' . tep_image_button('button_cancel.gif', IMAGE_CANCEL) . '</a>'; ?>

 

<!--//#CHAVEIRO6# Step order/customer begin !-->

  <?php } ?>

<!--//#CHAVEIRO6# Step order/customer end !-->

 

  </td>

      </tr></form>

<?php

  } else {

?>

      <tr>

        <td><table border="0" width="100%" cellspacing="0" cellpadding="0">

          <tr><?php echo tep_draw_form('search', FILENAME_CUSTOMERS, '', 'get'); ?>

            <td class="pageHeading"><?php echo HEADING_TITLE; ?></td>

            <td class="pageHeading" align="right"><?php echo tep_draw_separator('pixel_trans.gif', 1, HEADING_IMAGE_HEIGHT); ?></td>

            <td class="smallText" align="right"><?php echo HEADING_TITLE_SEARCH . ' ' . tep_draw_input_field('search'); ?></td>

          </form></tr>

        </table></td>

      </tr>

      <tr>

        <td><table border="0" width="100%" cellspacing="0" cellpadding="0">

          <tr>

            <td valign="top"><table border="0" width="100%" cellspacing="0" cellpadding="2">

              <tr class="dataTableHeadingRow">

                <td class="dataTableHeadingContent"><?php echo TABLE_HEADING_LASTNAME; ?></td>

                <td class="dataTableHeadingContent"><?php echo TABLE_HEADING_FIRSTNAME; ?></td>

                <td class="dataTableHeadingContent" align="right"><?php echo TABLE_HEADING_ACCOUNT_CREATED; ?></td>

                <td class="dataTableHeadingContent" align="right"><?php echo TABLE_HEADING_ACTION; ?> </td>

              </tr>

<?php

    $search = '';

    if (isset($HTTP_GET_VARS['search']) && tep_not_null($HTTP_GET_VARS['search'])) {

      $keywords = tep_db_input(tep_db_prepare_input($HTTP_GET_VARS['search']));

      $search = "where c.customers_lastname like '%" . $keywords . "%' or c.customers_firstname like '%" . $keywords . "%' or c.customers_email_address like '%" . $keywords . "%'";

    }

    $customers_query_raw = "select c.customers_id, c.customers_lastname, c.customers_firstname, c.customers_email_address, a.entry_country_id from " . TABLE_CUSTOMERS . " c left join " . TABLE_ADDRESS_BOOK . " a on c.customers_id = a.customers_id and c.customers_default_address_id = a.address_book_id " . $search . " order by c.customers_lastname, c.customers_firstname";

    $customers_split = new splitPageResults($HTTP_GET_VARS['page'], MAX_DISPLAY_SEARCH_RESULTS, $customers_query_raw, $customers_query_numrows);

    $customers_query = tep_db_query($customers_query_raw);

    while ($customers = tep_db_fetch_array($customers_query)) {

      $info_query = tep_db_query("select customers_info_date_account_created as date_account_created, customers_info_date_account_last_modified as date_account_last_modified, customers_info_date_of_last_logon as date_last_logon, customers_info_number_of_logons as number_of_logons from " . TABLE_CUSTOMERS_INFO . " where customers_info_id = '" . $customers[&

Link to comment
Share on other sites

  • 3 months later...

Your problem lies on this line

 

$sql_data_array = array('customers_firstname' => $customers_firstname,

'customers_lastname' => $customers_lastname,

'customers_email_address' => $customers_email_address,

'customers_telephone' => $customers_telephone,

'customers_fax' => $customers_fax,

'customers_newsletter' => $customers_newsletter);// purchaseorders_1_4 start

'customers_allow_purchase_order_entry' => $customers_allow_purchase_order_entry);

// purchaseorders_1_4 end

 

you need to remove the ); from the first statement and replace it with a ,

 

There are a number of issues with the Purchase Order module 1.4.1, when used with osCommerce 2.2ms2.

 

First of all, if you are installing this module on a live site, it is vital that you follow the instructions in reverse order:

 

1) Make the database changes first, otherwise your site will fall over.

2) Then perform the page changes.

3) Then add the new pages and perform the install in the admin payment module control centre.

 

Secondly, you will need some coding experience to be able to do the page changes. Simply cutting and pasting is not enough. You need to be able to recognise constructs such as if-then-else as some of the changes span parts of these blocks. Some also amend array initialisers.

 

Thirdly, the instructions advise to optionally add a default to the database column. This is to allow the site to default to customers not being able to pay by this method until one approves them within the admin panel. Be warned, the default will only affect newcustomers! If you wish to prevent all your existing registered users from being able to pay by purchase order (until you approve them), you will also need to run a subsequent SQL update to set all those customers to false.

 

Fourthly, the module will not work with 2.2ms2 unless you finish writing the code for the po class. The before_process() method has not been coded which results in the PO number entered by the customer being lost between the order confirmation and order success pages.

 

After a lot of rewriting, we have completed a fully working integration of this module for a site we are building for one of our eCommerce clients.

 

If you need further guidance, please email me for details.

Link to comment
Share on other sites

Archived

This topic is now archived and is closed to further replies.

×
×
  • Create New...