* @copyright 2007-2015 PrestaShop SA * @license http://opensource.org/licenses/osl-3.0.php Open Software License (OSL 3.0) * International Registered Trademark & Property of PrestaShop SA */ /** * @since 1.5 */ class HTMLTemplateOrderSlipCore extends HTMLTemplateInvoice { public $order; public $order_slip; /** * @param OrderSlip $order_slip * @param $smarty * @throws PrestaShopException */ public function __construct(OrderSlip $order_slip, $smarty) { $this->order_slip = $order_slip; $this->order = new Order((int)$order_slip->id_order); $products = OrderSlip::getOrdersSlipProducts($this->order_slip->id, $this->order); $customized_datas = Product::getAllCustomizedDatas((int)$this->order->id_cart); Product::addCustomizationPrice($products, $customized_datas); $this->order->products = $products; $this->smarty = $smarty; // header informations $this->date = Tools::displayDate($this->order_slip->date_add); $prefix = Configuration::get('PS_CREDIT_SLIP_PREFIX', Context::getContext()->language->id); $this->title = sprintf(HTMLTemplateOrderSlip::l('%1$s%2$06d'), $prefix, (int)$this->order_slip->id); $this->shop = new Shop((int)$this->order->id_shop); } /** * Returns the template's HTML header * * @return string HTML header */ public function getHeader() { $this->assignCommonHeaderData(); $this->smarty->assign(array( 'header' => HTMLTemplateOrderSlip::l('Credit slip'), )); return $this->smarty->fetch($this->getTemplate('header')); } /** * Returns the template's HTML content * * @return string HTML content */ public function getContent() { $delivery_address = $invoice_address = new Address((int)$this->order->id_address_invoice); $formatted_invoice_address = AddressFormat::generateAddress($invoice_address, array(), '
', ' '); $formatted_delivery_address = ''; if ($this->order->id_address_delivery != $this->order->id_address_invoice) { $delivery_address = new Address((int)$this->order->id_address_delivery); $formatted_delivery_address = AddressFormat::generateAddress($delivery_address, array(), '
', ' '); } $customer = new Customer((int)$this->order->id_customer); $this->order->total_paid_tax_excl = $this->order->total_paid_tax_incl = $this->order->total_products = $this->order->total_products_wt = 0; if ($this->order_slip->amount > 0) { foreach ($this->order->products as &$product) { $product['total_price_tax_excl'] = $product['unit_price_tax_excl'] * $product['product_quantity']; $product['total_price_tax_incl'] = $product['unit_price_tax_incl'] * $product['product_quantity']; if ($this->order_slip->partial == 1) { $order_slip_detail = Db::getInstance()->getRow(' SELECT * FROM `'._DB_PREFIX_.'order_slip_detail` WHERE `id_order_slip` = '.(int)$this->order_slip->id.' AND `id_order_detail` = '.(int)$product['id_order_detail']); $product['total_price_tax_excl'] = $order_slip_detail['amount_tax_excl']; $product['total_price_tax_incl'] = $order_slip_detail['amount_tax_incl']; } $this->order->total_products += $product['total_price_tax_excl']; $this->order->total_products_wt += $product['total_price_tax_incl']; $this->order->total_paid_tax_excl = $this->order->total_products; $this->order->total_paid_tax_incl = $this->order->total_products_wt; } } else { $this->order->products = null; } unset($product); // remove reference if ($this->order_slip->shipping_cost == 0) { $this->order->total_shipping_tax_incl = $this->order->total_shipping_tax_excl = 0; } $tax = new Tax(); $tax->rate = $this->order->carrier_tax_rate; $tax_calculator = new TaxCalculator(array($tax)); $tax_excluded_display = Group::getPriceDisplayMethod((int)$customer->id_default_group); if (/*$this->order_slip->partial == 1 && */$this->order_slip->shipping_cost_amount > 0) { if ($tax_excluded_display) { $this->order->total_shipping_tax_incl = Tools::ps_round($tax_calculator->addTaxes($this->order_slip->shipping_cost_amount), 2); } else { $this->order->total_shipping_tax_incl = $this->order_slip->shipping_cost_amount; } } if ($tax_excluded_display) { $this->order->total_shipping_tax_excl = $this->order_slip->shipping_cost_amount; } else { $this->order->total_shipping_tax_excl = Tools::ps_round($tax_calculator->removeTaxes($this->order_slip->shipping_cost_amount), 2); } $this->order->total_paid_tax_incl += $this->order->total_shipping_tax_incl; $this->order->total_paid_tax_excl += $this->order->total_shipping_tax_excl; $total_cart_rule = 0; if ($this->order_slip->order_slip_type == 1 && is_array($cart_rules = $this->order->getCartRules($this->order_invoice->id))) { foreach ($cart_rules as $cart_rule) { if ($tax_excluded_display) { $total_cart_rule += $cart_rule['value_tax_excl']; } else { $total_cart_rule += $cart_rule['value']; } } } $this->smarty->assign(array( 'order' => $this->order, 'order_slip' => $this->order_slip, 'order_details' => $this->order->products, 'cart_rules' => $this->order_slip->order_slip_type == 1 ? $this->order->getCartRules($this->order_invoice->id) : false, 'amount_choosen' => $this->order_slip->order_slip_type == 2 ? true : false, 'delivery_address' => $formatted_delivery_address, 'invoice_address' => $formatted_invoice_address, 'addresses' => array('invoice' => $invoice_address, 'delivery' => $delivery_address), 'tax_excluded_display' => $tax_excluded_display, 'total_cart_rule' => $total_cart_rule )); $tpls = array( 'style_tab' => $this->smarty->fetch($this->getTemplate('invoice.style-tab')), 'addresses_tab' => $this->smarty->fetch($this->getTemplate('invoice.addresses-tab')), 'summary_tab' => $this->smarty->fetch($this->getTemplate('order-slip.summary-tab')), 'product_tab' => $this->smarty->fetch($this->getTemplate('order-slip.product-tab')), 'total_tab' => $this->smarty->fetch($this->getTemplate('order-slip.total-tab')), 'payment_tab' => $this->smarty->fetch($this->getTemplate('order-slip.payment-tab')), 'tax_tab' => $this->getTaxTabContent(), ); $this->smarty->assign($tpls); return $this->smarty->fetch($this->getTemplate('order-slip')); } /** * Returns the template filename when using bulk rendering * * @return string filename */ public function getBulkFilename() { return 'order-slips.pdf'; } /** * Returns the template filename * * @return string filename */ public function getFilename() { return 'order-slip-'.sprintf('%06d', $this->order_slip->id).'.pdf'; } /** * Returns the tax tab content * * @return String Tax tab html content */ public function getTaxTabContent() { $address = new Address((int)$this->order->{Configuration::get('PS_TAX_ADDRESS_TYPE')}); $tax_exempt = Configuration::get('VATNUMBER_MANAGEMENT') && !empty($address->vat_number) && $address->id_country != Configuration::get('VATNUMBER_COUNTRY'); $this->smarty->assign(array( 'tax_exempt' => $tax_exempt, 'product_tax_breakdown' => $this->getProductTaxesBreakdown(), 'shipping_tax_breakdown' => $this->getShippingTaxesBreakdown(), 'order' => $this->order, 'ecotax_tax_breakdown' => $this->order_slip->getEcoTaxTaxesBreakdown(), 'is_order_slip' => true, 'tax_breakdowns' => $this->getTaxBreakdown(), 'display_tax_bases_in_breakdowns' => false )); return $this->smarty->fetch($this->getTemplate('invoice.tax-tab')); } /** * Returns different tax breakdown elements * * @return Array Different tax breakdown elements */ protected function getTaxBreakdown() { $breakdowns = array( 'product_tax' => $this->getProductTaxesBreakdown(), 'shipping_tax' => $this->getShippingTaxesBreakdown(), 'ecotax_tax' => $this->order_slip->getEcoTaxTaxesBreakdown(), ); foreach ($breakdowns as $type => $bd) { if (empty($bd)) { unset($breakdowns[$type]); } } if (empty($breakdowns)) { $breakdowns = false; } if (isset($breakdowns['product_tax'])) { foreach ($breakdowns['product_tax'] as &$bd) { $bd['total_tax_excl'] = $bd['total_price_tax_excl']; } } if (isset($breakdowns['ecotax_tax'])) { foreach ($breakdowns['ecotax_tax'] as &$bd) { $bd['total_tax_excl'] = $bd['ecotax_tax_excl']; $bd['total_amount'] = $bd['ecotax_tax_incl'] - $bd['ecotax_tax_excl']; } } return $breakdowns; } public function getProductTaxesBreakdown() { // $breakdown will be an array with tax rates as keys and at least the columns: // - 'total_price_tax_excl' // - 'total_amount' $breakdown = array(); $details = $this->order->getProductTaxesDetails($this->order->products); foreach ($details as $row) { $rate = sprintf('%.3f', $row['tax_rate']); if (!isset($breakdown[$rate])) { $breakdown[$rate] = array( 'total_price_tax_excl' => 0, 'total_amount' => 0, 'id_tax' => $row['id_tax'], 'rate' =>$rate, ); } $breakdown[$rate]['total_price_tax_excl'] += $row['total_tax_base']; $breakdown[$rate]['total_amount'] += $row['total_amount']; } foreach ($breakdown as $rate => $data) { $breakdown[$rate]['total_price_tax_excl'] = Tools::ps_round($data['total_price_tax_excl'], _PS_PRICE_COMPUTE_PRECISION_, $this->order->round_mode); $breakdown[$rate]['total_amount'] = Tools::ps_round($data['total_amount'], _PS_PRICE_COMPUTE_PRECISION_, $this->order->round_mode); } ksort($breakdown); return $breakdown; } /** * Returns Shipping tax breakdown elements * * @return Array Shipping tax breakdown elements */ public function getShippingTaxesBreakdown() { $taxes_breakdown = array(); $tax = new Tax(); $tax->rate = $this->order->carrier_tax_rate; $tax_calculator = new TaxCalculator(array($tax)); $customer = new Customer((int)$this->order->id_customer); $tax_excluded_display = Group::getPriceDisplayMethod((int)$customer->id_default_group); if ($tax_excluded_display) { $total_tax_excl = $this->order_slip->shipping_cost_amount; $shipping_tax_amount = $tax_calculator->addTaxes($this->order_slip->shipping_cost_amount) - $total_tax_excl; } else { $total_tax_excl = $tax_calculator->removeTaxes($this->order_slip->shipping_cost_amount); $shipping_tax_amount = $this->order_slip->shipping_cost_amount - $total_tax_excl; } if ($shipping_tax_amount > 0) { $taxes_breakdown[] = array( 'rate' => $this->order->carrier_tax_rate, 'total_amount' => $shipping_tax_amount, 'total_tax_excl' => $total_tax_excl ); } return $taxes_breakdown; } }