* @copyright 2007-2011 PrestaShop SA * @version Release: $Revision: 8160 $ * @license http://opensource.org/licenses/osl-3.0.php Open Software License (OSL 3.0) * International Registered Trademark & Property of PrestaShop SA */ ControllerFactory::includeController('ParentOrderController'); class OrderOpcControllerCore extends ParentOrderController { public $php_self = 'order-opc.php'; public $isLogged; public function preProcess() { parent::preProcess(); if ($this->nbProducts) self::$smarty->assign('virtual_cart', false); $this->isLogged = (bool)((int)(self::$cookie->id_customer) AND Customer::customerIdExistsStatic((int)(self::$cookie->id_customer))); if (self::$cart->nbProducts()) { if (Tools::isSubmit('ajax')) { if (Tools::isSubmit('method')) { switch (Tools::getValue('method')) { case 'updateMessage': if (Tools::isSubmit('message')) { $txtMessage = urldecode(Tools::getValue('message')); $this->_updateMessage($txtMessage); if (sizeof($this->errors)) die('{"hasError" : true, "errors" : ["'.implode('\',\'', $this->errors).'"]}'); die(true); } break; case 'updateCarrierAndGetPayments': if (Tools::isSubmit('id_carrier') AND Tools::isSubmit('recyclable') AND Tools::isSubmit('gift') AND Tools::isSubmit('gift_message')) { if ($this->_processCarrier()) { $return = array( 'summary' => self::$cart->getSummaryDetails(), 'HOOK_TOP_PAYMENT' => Module::hookExec('paymentTop'), 'HOOK_PAYMENT' => $this->_getPaymentMethods() ); die(Tools::jsonEncode($return)); } else $this->errors[] = Tools::displayError('Error occurred updating cart.'); if (sizeof($this->errors)) die('{"hasError" : true, "errors" : ["'.implode('\',\'', $this->errors).'"]}'); exit; } break; case 'updateTOSStatusAndGetPayments': if (Tools::isSubmit('checked')) { self::$cookie->checkedTOS = (int)(Tools::getValue('checked')); die(Tools::jsonEncode(array( 'HOOK_TOP_PAYMENT' => Module::hookExec('paymentTop'), 'HOOK_PAYMENT' => $this->_getPaymentMethods() ))); } break; case 'getCarrierList': die(Tools::jsonEncode($this->_getCarrierList())); break; case 'editCustomer': if (!$this->isLogged) exit; $customer = new Customer((int)self::$cookie->id_customer); if (Tools::getValue('years')) $customer->birthday = (int)Tools::getValue('years').'-'.(int)Tools::getValue('months').'-'.(int)Tools::getValue('days'); $_POST['lastname'] = $_POST['customer_lastname']; $_POST['firstname'] = $_POST['customer_firstname']; $this->errors = $customer->validateControler(); $customer->newsletter = (int)Tools::isSubmit('newsletter'); $customer->optin = (int)Tools::isSubmit('optin'); $return = array( 'hasError' => !empty($this->errors), 'errors' => $this->errors, 'id_customer' => (int)self::$cookie->id_customer, 'token' => Tools::getToken(false) ); if (!sizeof($this->errors)) $return['isSaved'] = (bool)$customer->update(); else $return['isSaved'] = false; die(Tools::jsonEncode($return)); break; case 'getAddressBlockAndCarriersAndPayments': if (self::$cookie->isLogged()) { // check if customer have addresses if (!Customer::getAddressesTotalById((int)(self::$cookie->id_customer))) die(Tools::jsonEncode(array('no_address' => 1))); if (file_exists(_PS_MODULE_DIR_.'blockuserinfo/blockuserinfo.php')) { include_once(_PS_MODULE_DIR_.'blockuserinfo/blockuserinfo.php'); $blockUserInfo = new BlockUserInfo(); } self::$smarty->assign('isVirtualCart', self::$cart->isVirtualCart()); $this->_processAddressFormat(); $this->_assignAddress(); // Wrapping fees $wrapping_fees = (float)(Configuration::get('PS_GIFT_WRAPPING_PRICE')); $wrapping_fees_tax = new Tax((int)(Configuration::get('PS_GIFT_WRAPPING_TAX'))); $wrapping_fees_tax_inc = $wrapping_fees * (1 + (((float)($wrapping_fees_tax->rate) / 100))); $return = array( 'summary' => self::$cart->getSummaryDetails(), 'order_opc_adress' => self::$smarty->fetch(_PS_THEME_DIR_.'order-address.tpl'), 'block_user_info' => (isset($blockUserInfo) ? $blockUserInfo->hookTop(array()) : ''), 'carrier_list' => $this->_getCarrierList(), 'HOOK_TOP_PAYMENT' => Module::hookExec('paymentTop'), 'HOOK_PAYMENT' => $this->_getPaymentMethods(), 'no_address' => 0, 'gift_price' => Tools::displayPrice(Tools::convertPrice(Product::getTaxCalculationMethod() == 1 ? $wrapping_fees : $wrapping_fees_tax_inc, new Currency((int)(self::$cookie->id_currency)))) ); die(Tools::jsonEncode($return)); } die(Tools::displayError()); break; case 'makeFreeOrder': /* Bypass payment step if total is 0 */ if (($id_order = $this->_checkFreeOrder()) AND $id_order) { $email = self::$cookie->email; if (self::$cookie->is_guest) self::$cookie->logout(); // If guest we clear the cookie for security reason die('freeorder:'.$id_order.':'.$email); } exit; break; case 'updateAddressesSelected': if (self::$cookie->isLogged(true)) { $id_address_delivery = (int)(Tools::getValue('id_address_delivery')); $id_address_invoice = (int)(Tools::getValue('id_address_invoice')); $address_delivery = new Address((int)(Tools::getValue('id_address_delivery'))); $address_invoice = ((int)(Tools::getValue('id_address_delivery')) == (int)(Tools::getValue('id_address_invoice')) ? $address_delivery : new Address((int)(Tools::getValue('id_address_invoice')))); if ($address_delivery->id_customer != self::$cookie->id_customer || $address_invoice->id_customer != self::$cookie->id_customer) $this->errors[] = Tools::displayError('This address is not yours.'); elseif (!Address::isCountryActiveById((int)(Tools::getValue('id_address_delivery')))) $this->errors[] = Tools::displayError('This address is not in a valid area.'); elseif (!Validate::isLoadedObject($address_delivery) OR !Validate::isLoadedObject($address_invoice) OR $address_invoice->deleted OR $address_delivery->deleted) $this->errors[] = Tools::displayError('This address is invalid.'); else { self::$cart->id_address_delivery = (int)(Tools::getValue('id_address_delivery')); self::$cart->id_address_invoice = Tools::isSubmit('same') ? self::$cart->id_address_delivery : (int)(Tools::getValue('id_address_invoice')); if (!self::$cart->update()) $this->errors[] = Tools::displayError('An error occurred while updating your cart.'); if (!sizeof($this->errors)) { if (self::$cookie->id_customer) { $customer = new Customer((int)(self::$cookie->id_customer)); $groups = $customer->getGroups(); } else $groups = array(1); $result = $this->_getCarrierList(); // Wrapping fees $wrapping_fees = (float)(Configuration::get('PS_GIFT_WRAPPING_PRICE')); $wrapping_fees_tax = new Tax((int)(Configuration::get('PS_GIFT_WRAPPING_TAX'))); $wrapping_fees_tax_inc = $wrapping_fees * (1 + (((float)($wrapping_fees_tax->rate) / 100))); $result = array_merge($result, array( 'summary' => self::$cart->getSummaryDetails(), 'HOOK_TOP_PAYMENT' => Module::hookExec('paymentTop'), 'HOOK_PAYMENT' => $this->_getPaymentMethods(), 'gift_price' => Tools::displayPrice(Tools::convertPrice(Product::getTaxCalculationMethod() == 1 ? $wrapping_fees : $wrapping_fees_tax_inc, new Currency((int)(self::$cookie->id_currency)))) )); die(Tools::jsonEncode($result)); } } if (sizeof($this->errors)) die('{"hasError" : true, "errors" : ["'.implode('\',\'', $this->errors).'"]}'); } die(Tools::displayError()); break; default: exit; } } exit; } } elseif (Tools::isSubmit('ajax')) exit; } public function setMedia() { parent::setMedia(); // Adding CSS style sheet Tools::addCSS(_THEME_CSS_DIR_.'order-opc.css'); // Adding JS files Tools::addJS(_THEME_JS_DIR_.'order-opc.js'); Tools::addJs(_PS_JS_DIR_.'jquery/jquery.scrollTo-1.4.2-min.js'); Tools::addJS(_THEME_JS_DIR_.'tools/statesManagement.js'); } public function process() { // SHOPPING CART $this->_assignSummaryInformations(); // WRAPPING AND TOS $this->_assignWrappingAndTOS(); $selectedCountry = (int)(Configuration::get('PS_COUNTRY_DEFAULT')); if (Configuration::get('PS_RESTRICT_DELIVERED_COUNTRIES')) $countries = Carrier::getDeliveredCountries((int)self::$cookie->id_lang, true, true); else $countries = Country::getCountries((int)self::$cookie->id_lang, true); self::$smarty->assign(array( 'isLogged' => $this->isLogged, 'isGuest' => isset(self::$cookie->is_guest) ? self::$cookie->is_guest : 0, 'countries' => $countries, 'sl_country' => isset($selectedCountry) ? $selectedCountry : 0, 'PS_GUEST_CHECKOUT_ENABLED' => Configuration::get('PS_GUEST_CHECKOUT_ENABLED'), 'errorCarrier' => Tools::displayError('You must choose a carrier before', false), 'errorTOS' => Tools::displayError('You must accept terms of service before', false), 'isPaymentStep' => (bool)(isset($_GET['isPaymentStep']) AND $_GET['isPaymentStep']) )); /* Call a hook to display more information on form */ self::$smarty->assign(array( 'HOOK_CREATE_ACCOUNT_FORM' => Module::hookExec('createAccountForm'), 'HOOK_CREATE_ACCOUNT_TOP' => Module::hookExec('createAccountTop') )); $years = Tools::dateYears(); $months = Tools::dateMonths(); $days = Tools::dateDays(); self::$smarty->assign(array( 'years' => $years, 'months' => $months, 'days' => $days, )); /* Load guest informations */ if ($this->isLogged AND self::$cookie->is_guest) self::$smarty->assign('guestInformations', $this->_getGuestInformations()); if ($this->isLogged) $this->_assignAddress(); // ADDRESS // CARRIER $this->_assignCarrier(); // PAYMENT $this->_assignPayment(); Tools::safePostVars(); if ($blocknewsletter = Module::getInstanceByName('blocknewsletter')) self::$smarty->assign('newsletter', (int)$blocknewsletter->active); else self::$smarty->assign('newsletter', 0); } public function displayHeader() { if (Tools::getValue('ajax') != 'true') parent::displayHeader(); } public function displayContent() { parent::displayContent(); $this->_processAddressFormat(); self::$smarty->display(_PS_THEME_DIR_.'order-opc.tpl'); } public function displayFooter() { if (Tools::getValue('ajax') != 'true') parent::displayFooter(); } protected function _getGuestInformations() { $customer = new Customer((int)(self::$cookie->id_customer)); $address_delivery = new Address((int)self::$cart->id_address_delivery); if ($customer->birthday) $birthday = explode('-', $customer->birthday); else $birthday = array('0', '0', '0'); return array( 'id_customer' => (int)(self::$cookie->id_customer), 'email' => Tools::htmlentitiesUTF8($customer->email), 'customer_lastname' => Tools::htmlentitiesUTF8($customer->lastname), 'customer_firstname' => Tools::htmlentitiesUTF8($customer->firstname), 'newsletter' => (int)$customer->newsletter, 'optin' => (int)$customer->optin, 'id_address_delivery' => (int)self::$cart->id_address_delivery, 'company' => Tools::htmlentitiesUTF8($address_delivery->company), 'lastname' => Tools::htmlentitiesUTF8($address_delivery->lastname), 'firstname' => Tools::htmlentitiesUTF8($address_delivery->firstname), 'vat_number' => Tools::htmlentitiesUTF8($address_delivery->vat_number), 'dni' => Tools::htmlentitiesUTF8($address_delivery->dni), 'address1' => Tools::htmlentitiesUTF8($address_delivery->address1), 'postcode' => Tools::htmlentitiesUTF8($address_delivery->postcode), 'city' => Tools::htmlentitiesUTF8($address_delivery->city), 'phone' => Tools::htmlentitiesUTF8($address_delivery->phone), 'phone_mobile' => Tools::htmlentitiesUTF8($address_delivery->phone_mobile), 'id_country' => (int)($address_delivery->id_country), 'id_state' => (int)($address_delivery->id_state), 'id_gender' => (int)$customer->id_gender, 'sl_year' => $birthday[0], 'sl_month' => $birthday[1], 'sl_day' => $birthday[2] ); } protected function _assignCarrier() { if (!$this->isLogged) { $carriers = Carrier::getCarriersForOrder(Country::getIdZone((int)Configuration::get('PS_COUNTRY_DEFAULT'))); self::$smarty->assign(array( 'checked' => $this->_setDefaultCarrierSelection($carriers), 'carriers' => $carriers, 'default_carrier' => (int)(Configuration::get('PS_CARRIER_DEFAULT')), 'HOOK_EXTRACARRIER' => NULL, 'HOOK_BEFORECARRIER' => Module::hookExec('beforeCarrier', array('carriers' => $carriers)) )); } else parent::_assignCarrier(); } protected function _assignPayment() { self::$smarty->assign(array( 'HOOK_TOP_PAYMENT' => ($this->isLogged ? Module::hookExec('paymentTop') : ''), 'HOOK_PAYMENT' => $this->_getPaymentMethods() )); } protected function _getPaymentMethods() { if (!$this->isLogged) return '

'.Tools::displayError('Please sign in to see payment methods').'

'; if (self::$cart->OrderExists()) return '

'.Tools::displayError('Error: this order is already validated').'

'; if (!self::$cart->id_customer OR !Customer::customerIdExistsStatic(self::$cart->id_customer) OR Customer::isBanned(self::$cart->id_customer)) return '

'.Tools::displayError('Error: no customer').'

'; $address_delivery = new Address(self::$cart->id_address_delivery); $address_invoice = (self::$cart->id_address_delivery == self::$cart->id_address_invoice ? $address_delivery : new Address(self::$cart->id_address_invoice)); if (!self::$cart->id_address_delivery OR !self::$cart->id_address_invoice OR !Validate::isLoadedObject($address_delivery) OR !Validate::isLoadedObject($address_invoice) OR $address_invoice->deleted OR $address_delivery->deleted) return '

'.Tools::displayError('Error: please choose an address').'

'; if (!self::$cart->id_carrier AND !self::$cart->isVirtualCart()) return '

'.Tools::displayError('Error: please choose a carrier').'

'; elseif (self::$cart->id_carrier != 0) { $carrier = new Carrier((int)(self::$cart->id_carrier)); if (!Validate::isLoadedObject($carrier) OR $carrier->deleted OR !$carrier->active) return '

'.Tools::displayError('Error: the carrier is invalid').'

'; } if (!self::$cart->id_currency) return '

'.Tools::displayError('Error: no currency has been selected').'

'; if (!self::$cookie->checkedTOS AND Configuration::get('PS_CONDITIONS')) return '

'.Tools::displayError('Please accept Terms of Service').'

'; /* If some products have disappear */ if (!self::$cart->checkQuantities()) return '

'.Tools::displayError('An item in your cart is no longer available, you cannot proceed with your order.').'

'; /* Check minimal amount */ $currency = Currency::getCurrency((int)self::$cart->id_currency); $minimalPurchase = Tools::convertPrice((float)Configuration::get('PS_PURCHASE_MINIMUM'), $currency); if (self::$cart->getOrderTotal(false, Cart::ONLY_PRODUCTS) < $minimalPurchase) return '

'.Tools::displayError('A minimum purchase total of').' '.Tools::displayPrice($minimalPurchase, $currency). ' '.Tools::displayError('is required in order to validate your order.').'

'; /* Bypass payment step if total is 0 */ if (self::$cart->getOrderTotal() <= 0) return '

'; $return = Module::hookExecPayment(); if (!$return) return '

'.Tools::displayError('No payment method is available').'

'; return $return; } protected function _getCarrierList() { $address_delivery = new Address(self::$cart->id_address_delivery); if (self::$cookie->id_customer) { $customer = new Customer((int)(self::$cookie->id_customer)); $groups = $customer->getGroups(); } else $groups = array(1); if (!Address::isCountryActiveById((int)(self::$cart->id_address_delivery))) $this->errors[] = Tools::displayError('This address is not in a valid area.'); elseif (!Validate::isLoadedObject($address_delivery) OR $address_delivery->deleted) $this->errors[] = Tools::displayError('This address is invalid.'); else { $carriers = Carrier::getCarriersForOrder((int)Address::getZoneById((int)($address_delivery->id)), $groups); $result = array( 'checked' => $this->_setDefaultCarrierSelection($carriers), 'carriers' => $carriers, 'HOOK_BEFORECARRIER' => Module::hookExec('beforeCarrier', array('carriers' => $carriers)), 'HOOK_EXTRACARRIER' => Module::hookExec('extraCarrier', array('address' => $address_delivery)) ); return $result; } if (sizeof($this->errors)) return array( 'hasError' => true, 'errors' => $this->errors ); } protected function _processAddressFormat() { $selectedCountry = (int)(Configuration::get('PS_COUNTRY_DEFAULT')); $address_delivery = new Address((int)self::$cart->id_address_delivery); $address_invoice = new Address((int)self::$cart->id_address_invoice); $inv_adr_fields = AddressFormat::getOrderedAddressFields((int)$address_delivery->id_country, false, true); $dlv_adr_fields = AddressFormat::getOrderedAddressFields((int)$address_invoice->id_country, false, true); $inv_all_fields = array(); $dlv_all_fields = 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); self::$smarty->assign($adr_type.'_adr_fields', ${$adr_type.'_adr_fields'}); self::$smarty->assign($adr_type.'_all_fields', ${$adr_type.'_all_fields'}); } } }