799 lines
32 KiB
Plaintext
799 lines
32 KiB
Plaintext
<?php
|
|
/*
|
|
* @version $Id: index.php 10381 2008-06-01 03:35:53Z $
|
|
* @package Carteasy
|
|
* @copyright Copyright (C) 2005 - 2011 Wlanium
|
|
* @license proprietary
|
|
* @author Thomas Bartelt
|
|
* Carteasy is a web shop system
|
|
*/
|
|
|
|
include_once('./core/country.class.php');
|
|
include_once('./core/customer.class.php');
|
|
include_once('./core/customeraddress.class.php');
|
|
include_once('./core/shoppingcart.class.php');
|
|
include_once('./core/payment_method.class.php');
|
|
include_once('./core/deliverer.class.php'); // should be called shipping methods
|
|
include_once('./core/order.class.php');
|
|
include_once('./core/cs_ticket.class.php');
|
|
|
|
|
|
include_once('./core/orderhelper.class.php');
|
|
include_once('./core/giftcertificatehelper.class.php');
|
|
|
|
class website_cashdesk {
|
|
|
|
private $base_object;
|
|
private $layout_object;
|
|
private $errors;
|
|
private $personal_data;
|
|
private $countries;
|
|
private $customer_data;
|
|
private $customer_addresses;
|
|
private $shipping_address;
|
|
private $billing_address;
|
|
private $shoppingcart_data;
|
|
private $shipping_area_id;
|
|
private $payment_methods;
|
|
private $payment_method_id;
|
|
private $shipping_methods;
|
|
private $shipping_method_id;
|
|
private $has_gift_certificate;
|
|
private $gift_certificate_code;
|
|
private $gift_certificate_is_valid;
|
|
private $gift_certificate;
|
|
private $gift_certificate_value;
|
|
private $order_number;
|
|
private $order_id;
|
|
|
|
function __construct($base_object, $layout_object) {
|
|
$this->base_object = $base_object;
|
|
$this->layout_object = $layout_object;
|
|
$this->errors = array();
|
|
}
|
|
|
|
// end __construct
|
|
|
|
public function run() {
|
|
if (isset($_GET['guest_order']) && $_GET['guest_order'] == 1) {
|
|
// guest order
|
|
$this->base_object->customer->customer_id = $this->base_object->config->shopConfiguration['guest_order_customer_id'];
|
|
$this->layout_object->assign('guest_order', 1);
|
|
}
|
|
$action = '';
|
|
|
|
if ($this->base_object->customer->customer_id) {
|
|
if (isset($_POST['cashdesk_action'])) {
|
|
$action = $_POST['cashdesk_action'];
|
|
} else if (isset($_POST['save_address'])) {
|
|
$action = 'save_address';
|
|
} else if (isset($_GET['token'])) {
|
|
$action = 'change_order';
|
|
$param = 'paypal';
|
|
}
|
|
|
|
$this->personal_data = $_POST;
|
|
|
|
if ($action == 'ready2fly') {
|
|
// MAKE ORDER
|
|
|
|
$this->setup_countries();
|
|
$this->setup_customer_data();
|
|
if (isset($_GET['guest_order']) && $_GET['guest_order'] == 1) {
|
|
$this->manage_guest_order_address();
|
|
} else {
|
|
$this->manage_address();
|
|
}
|
|
$this->manage_shoppingcart();
|
|
$this->manage_payment_method();
|
|
$this->manage_shipping_method();
|
|
$this->manage_gift_certificate();
|
|
$this->managa_conditions();
|
|
|
|
$this->before_saving_order();
|
|
|
|
|
|
if (count($this->errors) == 0) {
|
|
if (isset($_GET['guest_order']) && $_GET['guest_order'] == 1) {
|
|
$this->setup_customer_data();
|
|
// check customer already exists by email
|
|
$customer_id = 0;//$this->base_object->customer->check_email($_POST['billing']['email']);
|
|
|
|
if (!$customer_id) {
|
|
// create new customer for guest order
|
|
$customer_data = array (
|
|
'honorific' => $_POST['billing']['honorific'],
|
|
'company' => $_POST['billing']['company'],
|
|
'firstname' => $_POST['billing']['firstname'],
|
|
'surname' => $_POST['billing']['surname'],
|
|
'phone' => $_POST['billing']['phone'],
|
|
'group_id' => $this->base_object->config->shopConfiguration['guest_order_customer_group'],
|
|
'email' => $_POST['billing']['email']
|
|
);
|
|
$result = $this->base_object->customer->create($customer_data);
|
|
} else {
|
|
$result = $customer_id;
|
|
}
|
|
|
|
if ($result) {
|
|
$this->customer_data->id = $customer_id = $this->base_object->customer->customer_id = $result;
|
|
|
|
include_once './core/customeraddress.class.php';
|
|
$customer_address_object = new CustomerAddress($this->base_object);
|
|
$billing_address = array (
|
|
'honorific' => $_POST['billing']['honorific'],
|
|
'company' => $_POST['billing']['company'],
|
|
'firstname' => $_POST['billing']['firstname'],
|
|
'surname' => $_POST['billing']['surname'],
|
|
'street' => $_POST['billing']['street'],
|
|
'house_number' => $_POST['billing']['house_number'],
|
|
'city' => $_POST['billing']['city'],
|
|
'zip_code' => $_POST['billing']['zip_code'],
|
|
'country' => $_POST['billing']['country'],
|
|
'customer_id' => $customer_id
|
|
);
|
|
$res = $customer_address_object->create($billing_address);
|
|
$this->billing_address['address'] = $res;
|
|
$shipping_address = array (
|
|
'honorific' => $_POST['shipping']['honorific'],
|
|
'company' => $_POST['shipping']['company'],
|
|
'firstname' => $_POST['shipping']['firstname'],
|
|
'surname' => $_POST['shipping']['surname'],
|
|
'street' => $_POST['shipping']['street'],
|
|
'house_number' => $_POST['shipping']['house_number'],
|
|
'city' => $_POST['shipping']['city'],
|
|
'zip_code' => $_POST['shipping']['zip_code'],
|
|
'country' => $_POST['shipping']['country'],
|
|
'customer_id' => $customer_id
|
|
);
|
|
|
|
$res = $customer_address_object->create($shipping_address);
|
|
$this->shipping_address['address'] = $res;
|
|
|
|
}
|
|
}
|
|
|
|
if (isset($_POST['billing']['email'])) {
|
|
$data = array(
|
|
'id' => $this->base_object->customer->customer_id,
|
|
'email' => $_POST['billing']['email']
|
|
);
|
|
$this->base_object->customer->save($data);
|
|
}
|
|
|
|
$is_saved = $this->save_order();
|
|
|
|
if ($is_saved) {
|
|
return $this->after_saving_order();
|
|
}
|
|
}
|
|
} else if ($action == 'change_order') {
|
|
return $this->change_order($param);
|
|
} else if ($action == 'save_address') {
|
|
// SAVE ADDRESS
|
|
$this->setup_customer_data();
|
|
$this->save_address();
|
|
|
|
} else {
|
|
// SHOW ORDER
|
|
|
|
$this->setup_countries();
|
|
$this->setup_customer_data();
|
|
if (isset($_GET['guest_order']) && $_GET['guest_order'] == 1) {
|
|
$this->manage_guest_order_address();
|
|
} else {
|
|
$this->manage_address();
|
|
}
|
|
$this->manage_shoppingcart();
|
|
$this->manage_payment_method();
|
|
$this->manage_shipping_method();
|
|
$this->manage_gift_certificate();
|
|
$this->managa_conditions();
|
|
}
|
|
//echo var_dump($this->personal_data);
|
|
$this->manage_errors();
|
|
$this->manage_data_persistence();
|
|
|
|
// customer info
|
|
if (isset($_SESSION['customer_info']) && $_SESSION['customer_info']) {
|
|
$this->layout_object->assign('customer_info', $_SESSION['customer_info']);
|
|
}
|
|
|
|
if (!$this->base_object->config->shopConfiguration['menu_in_cashdesk']) {
|
|
$this->layout_object->assign('site_type', 'full_width');
|
|
}
|
|
|
|
return $this->layout_object->_fetch('content_cash_desk.tpl');
|
|
|
|
} else if ($_GET['token']) {
|
|
return $this->change_order('paypal');
|
|
} else {
|
|
// login
|
|
$_SESSION['easyshop']['shopAction'] = 'cash_desk_customer_registration';
|
|
|
|
$this->layout_object->assign('go_to_cash_desk', 1);
|
|
return $this->layout_object->_fetch('content_login.tpl');
|
|
}
|
|
}
|
|
|
|
// end run
|
|
|
|
private function setup_countries() {
|
|
$country_object = new Country($this->base_object);
|
|
|
|
$this->countries = $country_object->get_all();
|
|
|
|
$this->layout_object->assign('countries', $this->countries);
|
|
}
|
|
|
|
// end setup_countries
|
|
|
|
private function setup_customer_data() {
|
|
$customer_id = $this->base_object->customer->customer_id;
|
|
|
|
$customer_object = new Customer($this->base_object);
|
|
|
|
$this->customer_data = $customer_object->get_by_id($customer_id);
|
|
|
|
// customer data is assigned in manage_address to take care of potential missing default address data
|
|
|
|
$this->layout_object->assign('shoppingcartVATUsage', $this->base_object->customer_group->show_tax);
|
|
$this->layout_object->assign('show_tax', $this->base_object->customer_group->show_tax);
|
|
$this->layout_object->assign('customer_data', $this->customer_data);
|
|
}
|
|
|
|
// end setup_customer_data
|
|
|
|
private function manage_guest_order_address() {
|
|
$address_object = new CustomerAddress($this->base_object);
|
|
|
|
$address_object->set_customer_id($this->customer_data->id);
|
|
$this->customer_addresses = $address_object->get_all();
|
|
|
|
if (!isset($this->customer_addresses[$this->customer_data->default_address])) {
|
|
$new_default = current($this->customer_addresses);
|
|
$this->customer_data->default_address_country_id = $new_default->country;
|
|
$this->customer_data->default_address_countryname = $this->countries[$new_default->country]->name;
|
|
}
|
|
|
|
if (isset($_POST['shipping']) && $_POST['shipping']['address'] == -1) {
|
|
$this->shipping_address = $_POST['billing'];
|
|
$_POST['shipping'] = $_POST['billing'];
|
|
} else if (isset($_POST['shipping'])) {
|
|
if (!$this->shipping_address['country']) {
|
|
$_POST['shipping']['country'] = $this->customer_data->default_address_country_id;
|
|
$this->layout_object->assign('default_address_country_id', $this->customer_data->default_address_country_id);
|
|
}
|
|
$this->shipping_address = $_POST['shipping'];
|
|
} else {
|
|
$this->shipping_address['country'] = $this->customer_data->default_address_country_id;
|
|
}
|
|
|
|
$this->layout_object->assign('shipping_address', $this->shipping_address);
|
|
|
|
if (isset($_POST['billing'])) {
|
|
$this->billing_address = $_POST['billing'];
|
|
} else {
|
|
$this->billing_address['country'] = $this->customer_data->default_address_country_id;
|
|
}
|
|
|
|
$this->layout_object->assign('billing_address', $this->billing_address);
|
|
|
|
$this->layout_object->assign('customer', $this->customer_data);
|
|
$shipping_country_id = $this->shipping_address['country'];
|
|
|
|
$this->shipping_area_id = Country::getShippingAreaById($shipping_country_id, $this->customer_data->group_id);
|
|
|
|
$this->layout_object->assign('addresses', $this->customer_addresses);
|
|
} // end manage_address
|
|
|
|
private function manage_address() {
|
|
$address_object = new CustomerAddress($this->base_object);
|
|
|
|
$address_object->set_customer_id($this->customer_data->id);
|
|
$this->customer_addresses = $address_object->get_all();
|
|
|
|
|
|
// hack for missing default address
|
|
if (is_array($this->customer_addresses) && !isset($this->customer_addresses[$this->customer_data->default_address])) {
|
|
$new_default = current($this->customer_addresses);
|
|
|
|
$this->customer_data->default_address = $new_default->id;
|
|
$this->customer_data->default_address_company = $new_default->company;
|
|
$this->customer_data->default_address_honorific = $new_default->honorific;
|
|
$this->customer_data->default_address_firstname = $new_default->firstname;
|
|
$this->customer_data->default_address_surname = $new_default->surname;
|
|
$this->customer_data->default_address_street = $new_default->street;
|
|
$this->customer_data->default_address_house_number = $new_default->house_number;
|
|
$this->customer_data->default_address_zip_code = $new_default->zip_code;
|
|
$this->customer_data->default_address_city = $new_default->city;
|
|
$this->customer_data->default_address_country_id = $new_default->country;
|
|
$this->customer_data->default_address_countryname = $this->countries[$new_default->country]->name;
|
|
}
|
|
|
|
if ($_POST['shipping']['address'] == -1) {
|
|
$this->shipping_address = $_POST['billing'];
|
|
} else if (isset($_POST['shipping'])) {
|
|
$this->shipping_address = $_POST['shipping'];
|
|
} else {
|
|
$this->shipping_address['address'] = $this->customer_data->default_address;
|
|
$this->shipping_address['honorific'] = $this->customer_data->default_address_honorific;
|
|
$this->shipping_address['firstname'] = $this->customer_data->default_address_firstname;
|
|
$this->shipping_address['surname'] = $this->customer_data->default_address_surname;
|
|
$this->shipping_address['company'] = $this->customer_data->default_address_company;
|
|
$this->shipping_address['street'] = $this->customer_data->default_address_street;
|
|
$this->shipping_address['house_number'] = $this->customer_data->default_address_house_number;
|
|
$this->shipping_address['zip_code'] = $this->customer_data->default_address_zip_code;
|
|
$this->shipping_address['city'] = $this->customer_data->default_address_city;
|
|
$this->shipping_address['country'] = $this->customer_data->default_address_country_id;
|
|
}
|
|
|
|
if (isset($_POST['billing'])) {
|
|
$this->billing_address = $_POST['billing'];
|
|
} else {
|
|
$this->billing_address['address'] = $this->customer_data->default_address;
|
|
$this->billing_address['honorific'] = $this->customer_data->default_address_honorific;
|
|
$this->billing_address['firstname'] = $this->customer_data->default_address_firstname;
|
|
$this->billing_address['surname'] = $this->customer_data->default_address_surname;
|
|
$this->billing_address['company'] = $this->customer_data->default_address_company;
|
|
$this->billing_address['street'] = $this->customer_data->default_address_street;
|
|
$this->billing_address['house_number'] = $this->customer_data->default_address_house_number;
|
|
$this->billing_address['zip_code'] = $this->customer_data->default_address_zip_code;
|
|
$this->billing_address['city'] = $this->customer_data->default_address_city;
|
|
$this->billing_address['country'] = $this->customer_data->default_address_country_id;
|
|
}
|
|
$billing_country_id = $this->billing_address['country'];
|
|
|
|
$this->layout_object->assign('customer', $this->customer_data);
|
|
|
|
$shipping_country_id = $this->shipping_address['country'];
|
|
$this->shipping_area_id = Country::getShippingAreaById($shipping_country_id, $this->customer_data->group_id);
|
|
|
|
$this->layout_object->assign('addresses', $this->customer_addresses);
|
|
}
|
|
|
|
// end manage_address
|
|
|
|
private function manage_shoppingcart() {
|
|
$shoppingcart_object = new Shoppingcart($this->base_object);
|
|
$this->shoppingcart_data = $shoppingcart_object->get_data();
|
|
|
|
// can't show shoppingcart data here, gift certificates can change the data
|
|
}
|
|
|
|
// end manage_shoppingcart
|
|
|
|
private function manage_payment_method() {
|
|
$payment_method_object = new Payment_method($this->base_object);
|
|
|
|
$this->payment_methods = $payment_method_object->getMethodsForGroup($this->customer_data->group_id, $this->shoppingcart_data['price_sum_gross'], $this->shipping_area_id);
|
|
if (isset($_POST['payment_method']) && $_POST['payment_method'] > 0) {
|
|
$this->payment_method_id = $_POST['payment_method'];
|
|
} else {
|
|
//$this->personal_data['payment_method'] = $this->payment_method_id = current($this->payment_methods)->id;
|
|
foreach ($this->payment_methods as $pm) {
|
|
if ($pm->activeType > 0) {
|
|
$this->personal_data['payment_method'] = $this->payment_method_id = $pm->id;
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
|
|
$this->layout_object->assign('payment_methods', $this->payment_methods);
|
|
}
|
|
|
|
// end manage_payment_method
|
|
|
|
private function manage_shipping_method() {
|
|
$shipping_method_object = new Deliverer($this->base_object);
|
|
|
|
$shoppingcart_object = new Shoppingcart($this->base_object);
|
|
$this->shoppingcart_data = $shoppingcart_object->get_data();
|
|
|
|
$this->shipping_methods = $shipping_method_object->getAllActive(
|
|
$this->shipping_area_id, $this->shoppingcart_data['standard_shipping_items'], $this->shoppingcart_data['bulk_goods'], $this->shoppingcart_data['item_weight'], $this->shoppingcart_data['price_sum_gross']
|
|
);
|
|
|
|
if (isset($_POST['shipping_method']) && $_POST['shipping_method'] > 0) {
|
|
foreach ($this->shipping_methods as $sm) {
|
|
if ($sm->id == $_POST['shipping_method']) {
|
|
$this->shipping_method_id = $_POST['shipping_method'];
|
|
}
|
|
}
|
|
}
|
|
|
|
if (!$this->shipping_method_id) {
|
|
$methods = $this->shipping_methods;
|
|
$method = array_shift($methods);
|
|
$this->personal_data['shipping_method'] = $this->shipping_method_id = $method->id;
|
|
}
|
|
$this->layout_object->assign('deliverers', $this->shipping_methods);
|
|
}
|
|
|
|
// end manage_shipping_method
|
|
|
|
private function manage_gift_certificate() {
|
|
$this->shoppingcart_data['order_total'] = $this->shoppingcart_data['price_sum_gross'] + $this->payment_methods[$this->payment_method_id]->paymentAdd + $this->shipping_methods[$this->shipping_method_id]->price_add;
|
|
|
|
$this->shoppingcart_data['payment_method_vat'] = $this->payment_methods[$this->payment_method_id]->paymentAddVat;
|
|
$this->shoppingcart_data['shipping_method_vat'] = $this->shipping_methods[$this->shipping_method_id]->price_add_vat;
|
|
|
|
if (isset($_POST['giftcertificate']['gift_certificat_code']) && $_POST['giftcertificate']['gift_certificat_code'] != '') {
|
|
$this->has_gift_certificate = true;
|
|
|
|
$this->gift_certificate_code = $_POST['giftcertificate']['gift_certificat_code'];
|
|
$this->layout_object->assign('giftcode', $this->gift_certificate_code);
|
|
$this->gift_certificate_is_valid = GiftCertificateHelper::code_is_valide($this->customer_data->id, $this->gift_certificate_code, $this->shoppingcart_data['price_sum_gross']);
|
|
|
|
if ($this->gift_certificate_is_valid) {
|
|
$this->shoppingcart_data['gift_certificate_code'] = $this->gift_certificate_code;
|
|
$this->gift_certificate = GiftCertificateHelper::get_certificate_by_code($this->gift_certificate_code);
|
|
|
|
$this->gift_certificate_value = GiftCertificateHelper::get_certificate_value($this->gift_certificate_code, $this->shoppingcart_data['price_sum_gross'], $this->customer_data->group_id);
|
|
|
|
$this->layout_object->assign('giftcertificatevalue', $this->gift_certificate_value->with_vat);
|
|
$this->layout_object->assign('giftcertificatmessage', "Code akzeptiert.");
|
|
|
|
// calculate the part of the gift certificate for each tax rate
|
|
$part = $this->gift_certificate_value->with_vat / $this->shoppingcart_data['price_sum_gross'];
|
|
} else {
|
|
$this->gift_certificate_error = GiftCertificateHelper::get_error_text();
|
|
|
|
$this->layout_object->assign('gftcertificateerrormessage', $this->gift_certificate_error);
|
|
$this->layout_object->assign('giftcertificatmessage', 'Code wird nicht akzeptiert.');
|
|
}
|
|
} else {
|
|
$this->has_gift_certificate = false;
|
|
}
|
|
|
|
foreach ($this->shoppingcart_data['tax_values'] as $key => $value) {
|
|
$this->shoppingcart_data['tax_values'][$key]['gift']['percent'] = $percent = round(($value['gross'] / $this->shoppingcart_data['price_sum_gross'] * 100), 2);
|
|
$this->shoppingcart_data['tax_values'][$key]['gift']['gross'] = $new_gross = $this->shoppingcart_data['price_sum_gross'] / 100 * $percent;
|
|
$this->shoppingcart_data['tax_values'][$key]['gift']['net'] = $new_net = $new_gross / (100 + $key) * 100;
|
|
$this->shoppingcart_data['tax_values'][$key]['gift']['vat'] = $new_gross - $new_net;
|
|
if ($this->base_object->customer_group->show_tax) {
|
|
$this->shoppingcart_data['tax_values'][$key]['gift']['show'] = $new_gross;
|
|
} else {
|
|
$this->shoppingcart_data['tax_values'][$key]['gift']['show'] = $new_net;
|
|
}
|
|
}
|
|
|
|
// TODO: HACK, generalize this
|
|
if (isset($this->payment_methods[9])) {
|
|
if ((isset($this->base_object->config->shopConfiguration['klarna_eid']) &&
|
|
$this->base_object->config->shopConfiguration['klarna_eid'] != '') &&
|
|
(isset($this->base_object->config->shopConfiguration['klarna_secret']) &&
|
|
$this->base_object->config->shopConfiguration['klarna_secret'] != '')) {
|
|
include_once('./core/shop_klarna.class.php');
|
|
|
|
// klarna installments
|
|
$klarna_object = new Shop_klarna($this->base_object);
|
|
if ($this->has_gift_certificate && $this->gift_certificate_is_valid) {
|
|
$klarna_installments = $klarna_object->get_installments($this->shoppingcart_data['order_total'] - $this->gift_certificate_value->with_vat);
|
|
} else {
|
|
$klarna_installments = $klarna_object->get_installments($this->shoppingcart_data['order_total']);
|
|
}
|
|
$this->layout_object->assign('klarna_installments', $klarna_installments);
|
|
}
|
|
}
|
|
|
|
// since the gift certificate can change the cart data this must be done here
|
|
$this->layout_object->assign('shoppingcart', $this->shoppingcart_data);
|
|
}
|
|
|
|
// end manage_gift_certificate
|
|
|
|
private function managa_conditions() {
|
|
$site_content_object = new SiteContent($this->base_object);
|
|
|
|
$agb_data = array();
|
|
$agb_data['datenschutz'] = $site_content_object->get_textbox_data_by_id(55);
|
|
$agb_data['agbs'] = $site_content_object->get_textbox_data_by_id(56);
|
|
$agb_data['agbs_b2b'] = $site_content_object->get_textbox_data_by_id(10632);
|
|
$agb_data['widerruf'] = $site_content_object->get_textbox_data_by_id(60);
|
|
|
|
$this->layout_object->assign('agb_data', $agb_data);
|
|
}
|
|
|
|
// end manage_conditions
|
|
|
|
private function manage_errors() {
|
|
$this->layout_object->assign('error_message', $this->errors);
|
|
}
|
|
|
|
// end manage_errors
|
|
|
|
private function manage_data_persistence() {
|
|
// ugly hack for data persistence
|
|
$this->layout_object->assign('personal_data', $this->personal_data);
|
|
}
|
|
|
|
// end manage_data_persistence
|
|
|
|
private function save_address() {
|
|
$address = $_POST;
|
|
unset($address['save_address']);
|
|
$address_id = false;
|
|
if ($address['address'] != '') {
|
|
$address_id = $address['address'];
|
|
}
|
|
unset($address['address']);
|
|
$address['customer_id'] = $this->customer_data->id;
|
|
|
|
$customer_address_object = new CustomerAddress($this->base_object);
|
|
|
|
$ret = array();
|
|
if ($customer_address_object->validate($address)) {
|
|
if ($address_id) {
|
|
$customer_address_object->update($address, $address_id);
|
|
} else {
|
|
$address_id = $customer_address_object->create($address);
|
|
}
|
|
|
|
$ret['id'] = $address_id;
|
|
$ret['stat'] = 'OK';
|
|
} else {
|
|
$ret['stat'] = 'ERR';
|
|
$ret['data'] = $customer_address_object->get_validation_errors();
|
|
}
|
|
|
|
echo json_encode($ret);
|
|
exit();
|
|
}
|
|
|
|
// end save_address
|
|
|
|
private function before_saving_order() {
|
|
// check order
|
|
if (!isset($_GET['guest_order']) || $_GET['guest_order'] != 1) {
|
|
if (!is_numeric($_POST['billing']['address'])) {
|
|
$this->errors[] = 'Bitte wählen Sie eine Rechnungsadresse';
|
|
}
|
|
|
|
if (!is_numeric($_POST['shipping']['address'])) {
|
|
$this->errors[] = 'Bitte wählen Sie eine Lieferadresse';
|
|
}
|
|
}
|
|
|
|
if (!is_numeric($_POST['payment_method'])) {
|
|
$this->errors[] = 'Bitte wählen Sie eine Zahlungsart';
|
|
} else {
|
|
$payment_method_id = $_POST['payment_method'];
|
|
|
|
if ($this->payment_methods[$payment_method_id]->module != '') {
|
|
$path = $_SERVER['DOCUMENT_ROOT'].'/core/paymentmethods/';
|
|
$module_name = ucfirst($this->payment_methods[$payment_method_id]->module).'PaymentMethod';
|
|
$file_name = strtolower($module_name).'.class.php';
|
|
|
|
if (file_exists($path.$file_name)) {
|
|
include_once('./core/paymentmethods/'.$file_name);
|
|
|
|
$payment_method_module = new $module_name($this->base_object, $this->layout_object);
|
|
|
|
$payment_method_module->set_data($this->customer_data, $this->shipping_address, $this->billing_address, $this->shoppingcart_data, $this->shipping_methods[$this->shipping_method_id], $this->payment_methods[$this->payment_method_id]);
|
|
|
|
if ($this->has_gift_certificate && $this->gift_certificate_is_valid) {
|
|
$payment_method_module->set_gift_certificate($this->gift_certificate_value);
|
|
}
|
|
|
|
if ($this->payment_methods[$payment_method_id]->argument != '') {
|
|
$return = $payment_method_module->before_order($this->payment_methods[$payment_method_id]->argument);
|
|
} else {
|
|
$return = $payment_method_module->before_order();
|
|
}
|
|
|
|
if ($return) {
|
|
$this->errors[] = $return;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
if (!is_numeric($_POST['shipping_method'])) {
|
|
$this->errors[] = 'Bitte wählen Sie eine Versandart';
|
|
}
|
|
|
|
if (!is_numeric($_POST['agreements_accepted'])) {
|
|
$this->errors[] = 'Bitte akzeptieren Sie unsere Bedingungen';
|
|
}
|
|
}
|
|
|
|
// end before_saving_order
|
|
|
|
private function save_order() {
|
|
if ($this->has_gift_certificate && $this->gift_certificate_is_valid) {
|
|
$orderDataObject = OrderHelper::createOrderObject(array(
|
|
'customerId' => $this->customer_data->id,
|
|
'cartId' => session_id(),
|
|
'billingAddressId' => $this->billing_address['address'],
|
|
'shippingAddressId' => $this->shipping_address['address'],
|
|
'paymentMethodId' => $this->payment_method_id,
|
|
'shippingMethodId' => $this->shipping_method_id,
|
|
'giftCertificate' => $this->gift_certificate_code
|
|
), $this->base_object);
|
|
} else {
|
|
$orderDataObject = OrderHelper::createOrderObject(array(
|
|
'customerId' => $this->base_object->customer->customer_id,
|
|
'cartId' => session_id(),
|
|
'billingAddressId' => $this->billing_address['address'],
|
|
'shippingAddressId' => $this->shipping_address['address'],
|
|
'paymentMethodId' => $this->payment_method_id,
|
|
'shippingMethodId' => $this->shipping_method_id
|
|
), $this->base_object);
|
|
}
|
|
|
|
// TODO : HACK
|
|
// fix up paymemt method with ALL the data
|
|
$orderDataObject->payment->methodId = $this->payment_method_id;
|
|
$orderDataObject->payment->areaId = $this->shipping_area_id;
|
|
$orderDataObject->payment->priceGross = $this->payment_methods[$this->payment_method_id]->paymentAdd;
|
|
$orderDataObject->payment->priceNet = $this->payment_methods[$this->payment_method_id]->paymentAddNet;
|
|
$orderDataObject->payment->priceVat = $this->payment_methods[$this->payment_method_id]->paymentAddVat;
|
|
$orderDataObject->payment->vatRate = '19.00';
|
|
|
|
// TODO : HACK
|
|
// fix up shipping method with ALL the data
|
|
$orderDataObject->shipping->methodId = $this->shipping_method_id;
|
|
$orderDataObject->shipping->areaId = $this->shipping_area_id;
|
|
$orderDataObject->shipping->priceGross = $this->shipping_methods[$this->shipping_method_id]->price_add;
|
|
$orderDataObject->shipping->priceNet = $this->shipping_methods[$this->shipping_method_id]->price_add_net;
|
|
$orderDataObject->shipping->priceVat = $this->shipping_methods[$this->shipping_method_id]->price_add_vat;
|
|
$orderDataObject->shipping->vatRate = '19.00';
|
|
|
|
if (isset($_POST['customer_info']) && $_POST['customer_info'] != '') {
|
|
$orderDataObject->customer_info = $_POST['customer_info'];
|
|
}
|
|
|
|
if ($this->payment_methods[$this->payment_method_id]->module != '') {
|
|
$path = $_SERVER['DOCUMENT_ROOT'].'/core/paymentmethods/';
|
|
$module_name = ucfirst($this->payment_methods[$this->payment_method_id]->module).'PaymentMethod';
|
|
$file_name = strtolower($module_name).'.class.php';
|
|
|
|
if (file_exists($path.$file_name)) {
|
|
include_once('./core/paymentmethods/'.$file_name);
|
|
|
|
$payment_method_module = new $module_name($this->base_object, $this->layout_object);
|
|
|
|
$payment_method_module->set_data($this->customer_data, $this->shipping_address, $this->billing_address, $this->shoppingcart_data, $this->shipping_methods[$this->shipping_method_id], $this->payment_methods[$this->payment_method_id]);
|
|
|
|
if ($this->has_gift_certificate && $this->gift_certificate_is_valid) {
|
|
$payment_method_module->set_gift_certificate($this->gift_certificate_value);
|
|
}
|
|
|
|
|
|
if ($this->payment_methods[$this->payment_method_id]->argument != '') {
|
|
$return = $payment_method_module->during_order($this->payment_methods[$this->payment_method_id]->argument);
|
|
} else {
|
|
$return = $payment_method_module->during_order();
|
|
}
|
|
|
|
if ($return) {
|
|
foreach ($return as $key => $value) {
|
|
$orderDataObject->$key = $value;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
$order_object = new Order($this->base_object);
|
|
$this->order_id = $order_object->create($orderDataObject);
|
|
$this->order_number = OrderHelper::get_order_number($this->order_id);
|
|
|
|
unset($_SESSION['customer_info']);
|
|
|
|
if ($this->order_id) {
|
|
// send email
|
|
$ticket_object = new Cs_ticket($this->base_object);
|
|
$ticket_object->event(3, $this->customer_data->id, $this->order_id);
|
|
|
|
if ($this->order_number) {
|
|
return true;
|
|
}
|
|
}
|
|
|
|
return false;
|
|
}
|
|
|
|
// end save_order
|
|
|
|
private function after_saving_order() {
|
|
$this->layout_object->assign('order_number', $this->order_number);
|
|
$this->layout_object->assign('order_amount', $this->shoppingcart_data['order_total']);
|
|
|
|
// get trusted shop payment id
|
|
$trusted_shop_payment = 'OTHER';
|
|
if ($this->payment_method_id == 1) {
|
|
$trusted_shop_payment = 'PREPAYMENT';
|
|
} else if ($this->payment_method_id == 2) {
|
|
$trusted_shop_payment = 'CASH_ON_DELIVERY';
|
|
} else if ($this->payment_method_id == 3) {
|
|
$trusted_shop_payment = 'INVOICE';
|
|
} else if ($this->payment_method_id == 4) {
|
|
$trusted_shop_payment = 'PAYPAL';
|
|
} else if ($this->payment_method_id == 6) {
|
|
$trusted_shop_payment = 'DIRECT_DEBIT';
|
|
}
|
|
$this->layout_object->assign('trusted_shop_payment', $trusted_shop_payment);
|
|
|
|
$shoppingcart_object = new Shoppingcart($this->base_object);
|
|
$shoppingcart_object->clear(1);
|
|
|
|
if ($this->payment_methods[$this->payment_method_id]->module != '') {
|
|
$path = $_SERVER['DOCUMENT_ROOT'].'/core/paymentmethods/';
|
|
$module_name = ucfirst($this->payment_methods[$this->payment_method_id]->module).'PaymentMethod';
|
|
$file_name = strtolower($module_name).'.class.php';
|
|
|
|
if (file_exists($path.$file_name)) {
|
|
include_once('./core/paymentmethods/'.$file_name);
|
|
|
|
$payment_method_module = new $module_name($this->base_object, $this->layout_object);
|
|
|
|
$payment_method_module->set_data($this->customer_data, $this->shipping_address, $this->billing_address, $this->shoppingcart_data, $this->shipping_methods[$this->shipping_method_id], $this->payment_methods[$this->payment_method_id], $this->order_id);
|
|
|
|
if ($this->has_gift_certificate && $this->gift_certificate_is_valid) {
|
|
$payment_method_module->set_gift_certificate($this->gift_certificate_value);
|
|
}
|
|
|
|
return $payment_method_module->after_order($this->shoppingcart_data['order_total']);
|
|
}
|
|
}
|
|
|
|
return $this->layout_object->_fetch('content_cash_desk/completed.tpl');
|
|
}
|
|
|
|
// end after_saving_order
|
|
|
|
private function change_order($param) {
|
|
$path = $_SERVER['DOCUMENT_ROOT'].'/core/paymentmethods/';
|
|
$module_name = ucfirst($param).'PaymentMethod';
|
|
$file_name = strtolower($module_name).'.class.php';
|
|
|
|
if (file_exists($path.$file_name)) {
|
|
include_once('./core/paymentmethods/'.$file_name);
|
|
|
|
$payment_method_module = new $module_name($this->base_object, $this->layout_object);
|
|
|
|
return $payment_method_module->change_order();
|
|
}
|
|
}
|
|
|
|
// end change_order
|
|
|
|
private function manage_guest_payment_method() {
|
|
$payment_method_object = new Payment_method($this->base_object);
|
|
/* temp: */ $this->shipping_area_id = 1;
|
|
$this->payment_methods = $payment_method_object->getMethodsForGroup($this->base_object->config->shopConfiguration['guest_order_customer_group'], $this->shoppingcart_data['price_sum_gross'], $this->shipping_area_id);
|
|
if (isset($_POST['payment_method']) && $_POST['payment_method'] > 0) {
|
|
$this->payment_method_id = $_POST['payment_method'];
|
|
} else {
|
|
$this->personal_data['payment_method'] = $this->payment_method_id = current($this->payment_methods)->id;
|
|
}
|
|
|
|
$this->layout_object->assign('payment_methods', $this->payment_methods);
|
|
}
|
|
|
|
// end manage_payment_method
|
|
|
|
private function manage_guest_shipping_method() {
|
|
$shipping_method_object = new Deliverer($this->base_object);
|
|
|
|
$shoppingcart_object = new Shoppingcart($this->base_object);
|
|
$this->shoppingcart_data = $shoppingcart_object->get_data();
|
|
$this->shipping_methods = $shipping_method_object->getAllActive(
|
|
$this->shipping_area_id, $this->shoppingcart_data['standard_shipping_items'], $this->shoppingcart_data['bulk_goods'], $this->shoppingcart_data['item_weight']
|
|
);
|
|
|
|
if (isset($_POST['shipping_method']) && $_POST['shipping_method'] > 0) {
|
|
$this->shipping_method_id = $_POST['shipping_method'];
|
|
} else {
|
|
$this->personal_data['shipping_method'] = $this->shipping_method_id = current($this->shipping_methods)->id;
|
|
}
|
|
$this->layout_object->assign('deliverers', $this->shipping_methods);
|
|
}
|
|
|
|
// end manage_shipping_method
|
|
}
|
|
|
|
// end website_cashdesk
|
|
|
|
?> |