function _process($id = '') { global $osC_MessageStack, $osC_Database, $osC_Language, $osC_Customer, $entry_state_has_zones; $data = array(); if (ACCOUNT_GENDER >= 0) { if (isset($_POST['gender']) && ($_POST['gender'] == 'm' || $_POST['gender'] == 'f')) { $data['gender'] = $_POST['gender']; } else { $osC_MessageStack->add('address_book', $osC_Language->get('field_customer_gender_error')); } } if (isset($_POST['firstname']) && strlen(trim($_POST['firstname'])) >= ACCOUNT_FIRST_NAME) { $data['firstname'] = $_POST['firstname']; } else { $osC_MessageStack->add('address_book', sprintf($osC_Language->get('field_customer_first_name_error'), ACCOUNT_FIRST_NAME)); } if (isset($_POST['lastname']) && strlen(trim($_POST['lastname'])) >= ACCOUNT_LAST_NAME) { $data['lastname'] = $_POST['lastname']; } else { $osC_MessageStack->add('address_book', sprintf($osC_Language->get('field_customer_last_name_error'), ACCOUNT_LAST_NAME)); } if (ACCOUNT_COMPANY > -1) { if (isset($_POST['company']) && strlen(trim($_POST['company'])) >= ACCOUNT_COMPANY) { $data['company'] = $_POST['company']; } else { $osC_MessageStack->add('address_book', sprintf($osC_Language->get('field_customer_company_error'), ACCOUNT_COMPANY)); } } if (isset($_POST['street_address']) && strlen(trim($_POST['street_address'])) >= ACCOUNT_STREET_ADDRESS) { $data['street_address'] = $_POST['street_address']; } else { $osC_MessageStack->add('address_book', sprintf($osC_Language->get('field_customer_street_address_error'), ACCOUNT_STREET_ADDRESS)); } if (ACCOUNT_SUBURB >= 0) { if (isset($_POST['suburb']) && strlen(trim($_POST['suburb'])) >= ACCOUNT_SUBURB) { $data['suburb'] = $_POST['suburb']; } else { $osC_MessageStack->add('address_book', sprintf($osC_Language->get('field_customer_suburb_error'), ACCOUNT_SUBURB)); } } if (ACCOUNT_POST_CODE > -1) { if (isset($_POST['postcode']) && strlen(trim($_POST['postcode'])) >= ACCOUNT_POST_CODE) { $data['postcode'] = $_POST['postcode']; } else { $osC_MessageStack->add('address_book', sprintf($osC_Language->get('field_customer_post_code_error'), ACCOUNT_POST_CODE)); } } if (isset($_POST['city']) && strlen(trim($_POST['city'])) >= ACCOUNT_CITY) { $data['city'] = $_POST['city']; } else { $osC_MessageStack->add('address_book', sprintf($osC_Language->get('field_customer_city_error'), ACCOUNT_CITY)); } if (ACCOUNT_STATE >= 0) { $Qcheck = $osC_Database->query('select zone_id from :table_zones where zone_country_id = :zone_country_id limit 1'); $Qcheck->bindTable(':table_zones', TABLE_ZONES); $Qcheck->bindInt(':zone_country_id', $_POST['country']); $Qcheck->execute(); $entry_state_has_zones = $Qcheck->numberOfRows() > 0; if ($entry_state_has_zones === true) { $Qzone = $osC_Database->query('select zone_id from :table_zones where zone_country_id = :zone_country_id and zone_code like :zone_code'); $Qzone->bindTable(':table_zones', TABLE_ZONES); $Qzone->bindInt(':zone_country_id', $_POST['country']); $Qzone->bindValue(':zone_code', $_POST['state']); $Qzone->execute(); if ($Qzone->numberOfRows() === 1) { $data['zone_id'] = $Qzone->valueInt('zone_id'); } else { $Qzone = $osC_Database->query('select zone_id from :table_zones where zone_country_id = :zone_country_id and zone_name like :zone_name'); $Qzone->bindTable(':table_zones', TABLE_ZONES); $Qzone->bindInt(':zone_country_id', $_POST['country']); $Qzone->bindValue(':zone_name', $_POST['state'] . '%'); $Qzone->execute(); if ($Qzone->numberOfRows() === 1) { $data['zone_id'] = $Qzone->valueInt('zone_id'); } else { $osC_MessageStack->add('address_book', $osC_Language->get('field_customer_state_select_pull_down_error')); } } } else { if (strlen(trim($_POST['state'])) >= ACCOUNT_STATE) { $data['state'] = $_POST['state']; } else { $osC_MessageStack->add('address_book', sprintf($osC_Language->get('field_customer_state_error'), ACCOUNT_STATE)); } } } else { if (strlen(trim($_POST['state'])) >= ACCOUNT_STATE) { $data['state'] = $_POST['state']; } else { $osC_MessageStack->add('address_book', sprintf($osC_Language->get('field_customer_state_error'), ACCOUNT_STATE)); } } if (isset($_POST['country']) && is_numeric($_POST['country']) && $_POST['country'] >= 1) { $data['country'] = $_POST['country']; } else { $osC_MessageStack->add('address_book', $osC_Language->get('field_customer_country_error')); } if (ACCOUNT_TELEPHONE >= 0) { if (isset($_POST['telephone']) && strlen(trim($_POST['telephone'])) >= ACCOUNT_TELEPHONE) { $data['telephone'] = $_POST['telephone']; } else { $osC_MessageStack->add('address_book', sprintf($osC_Language->get('field_customer_telephone_number_error'), ACCOUNT_TELEPHONE)); } } if (ACCOUNT_FAX >= 0) { if (isset($_POST['fax']) && strlen(trim($_POST['fax'])) >= ACCOUNT_FAX) { $data['fax'] = $_POST['fax']; } else { $osC_MessageStack->add('address_book', sprintf($osC_Language->get('field_customer_fax_number_error'), ACCOUNT_FAX)); } } if ($osC_Customer->hasDefaultAddress() === false || isset($_POST['primary']) && $_POST['primary'] == 'on') { $data['primary'] = true; } if ($osC_MessageStack->size('address_book') === 0) { if (osC_AddressBook::saveEntry($data, $id)) { $osC_MessageStack->add('address_book', $osC_Language->get('success_address_book_entry_updated'), 'success'); } osc_redirect(osc_href_link(FILENAME_ACCOUNT, 'address_book', 'SSL')); } }