* @copyright 2007-2011 PrestaShop SA * @version Release: $Revision: 6844 $ * @license http://opensource.org/licenses/osl-3.0.php Open Software License (OSL 3.0) * International Registered Trademark & Property of PrestaShop SA */ define('_PS_ADMIN_DIR_', getcwd()); include(_PS_ADMIN_DIR_.'/../config/config.inc.php'); if (!Context::getContext()->employee->id) Tools::redirectAdmin('index.php?controller=AdminLogin'); $functionArray = array( 'pdf' => 'generateInvoicePDF', 'id_order_slip' => 'generateOrderSlipPDF', 'id_delivery' => 'generateDeliverySlipPDF', 'delivery' => 'generateDeliverySlipPDF', 'invoices' => 'generateInvoicesPDF', 'invoices2' => 'generateInvoicesPDF2', 'slips' => 'generateOrderSlipsPDF', 'deliveryslips' => 'generateDeliverySlipsPDF', 'id_supply_order' => 'generateSupplyOrderFormPDF' ); foreach ($functionArray as $var => $function) if (isset($_GET[$var])) { call_user_func($function); die; } function generateSupplyOrderFormPDF() { if (!isset($_GET['id_supply_order'])) die (Tools::displayError('Missing supply order ID')); $id_supply_order = (int)$_GET['id_supply_order']; $supply_order = new SupplyOrder($id_supply_order); if (!Validate::isLoadedObject($supply_order)) die(Tools::displayError('Cannot find this supply order in the database')); generatePDF($supply_order, PDF::TEMPLATE_SUPPLY_ORDER_FORM); } function generateInvoicePDF() { if (Tools::isSubmit('id_order')) generateInvoicePDFByIdOrder(Tools::getValue('id_order')); elseif (Tools::isSubmit('id_order_invoice')) generateInvoicePDFByIdOrderInvoice(Tools::getValue('id_order_invoice')); else die (Tools::displayError('Missing order ID or invoice order ID')); exit; } function generateInvoicePDFByIdOrder($id_order) { $order = new Order($id_order); if (!Validate::isLoadedObject($order)) die(Tools::displayError('Cannot find order in database')); $order_invoice_list = $order->getInvoicesCollection(); Hook::exec('actionPDFInvoiceRender', array('order_invoice_list' => $order_invoice_list)); generatePDF($order_invoice_list, PDF::TEMPLATE_INVOICE); } function generateInvoicePDFByIdOrderInvoice($id_order_invoice) { $order_invoice = new OrderInvoice($id_order_invoice); if (!Validate::isLoadedObject($order_invoice)) die(Tools::displayError('Cannot find order invoice in database')); Hook::exec('actionPDFInvoiceRender', array('order_invoice_list' => array($order_invoice))); generatePDF($order_invoice, PDF::TEMPLATE_INVOICE); } function generateOrderSlipPDF() { $orderSlip = new OrderSlip((int)($_GET['id_order_slip'])); $order = new Order((int)($orderSlip->id_order)); if (!Validate::isLoadedObject($order)) die(Tools::displayError('Cannot find order in database')); $order->products = OrderSlip::getOrdersSlipProducts($orderSlip->id, $order); $tmp = NULL; generatePDF($orderSlip, PDF::TEMPLATE_ORDER_SLIP); } function generateDeliverySlipPDF() { if (Tools::isSubmit('id_order')) generateDeliverySlipPDFByIdOrder(Tools::getValue('id_order')); elseif (Tools::isSubmit('id_order_invoice')) generateDeliverySlipPDFByIdOrderInvoice(Tools::getValue('id_order_invoice')); elseif (Tools::isSubmit('id_delivery')) { $order = Order::getByDelivery(Tools::getValue('id_delivery')); generateDeliverySlipPDFByIdOrder($order->id); } else die (Tools::displayError('Missing order ID or invoice order ID')); exit; } function generateDeliverySlipPDFByIdOrder($id_order) { $order = new Order($id_order); if (!Validate::isLoadedObject($order)) throw new PrestaShopException('Can\'t load Order object'); $order_invoice_collection = $order->getInvoicesCollection(); generatePDF($order_invoice_collection, PDF::TEMPLATE_DELIVERY_SLIP); } function generateDeliverySlipPDFByIdOrderInvoice($id_order_invoice) { $order_invoice = new OrderInvoice($id_order_invoice); if (!Validate::isLoadedObject($order_invoice)) throw new PrestaShopException('Can\'t load Order Invoice object'); generatePDF($order_invoice, PDF::TEMPLATE_DELIVERY_SLIP); } function generateInvoicesPDF() { $order_invoice_collection = OrderInvoice::getByDateInterval($_GET['date_from'], $_GET['date_to']); if (!sizeof($order_invoice_collection)) die(Tools::displayError('No invoices found')); generatePDF($order_invoice_collection, PDF::TEMPLATE_INVOICE); } function generateInvoicesPDF2() { $order_invoice_collection = array(); foreach (explode('-', Tools::getValue('id_order_state')) as $id_order_state) if (is_array($order_invoices = OrderInvoice::getByStatus($id_order_state))) $order_invoice_collection = array_merge($order_invoices, $order_invoice_collection); if (!sizeof($order_invoice_collection)) die(Tools::displayError('No invoices found')); generatePDF($order_invoice_collection, PDF::TEMPLATE_INVOICE); } function generateOrderSlipsPDF() { $id_order_slips_list = OrderSlip::getSlipsIdByDate($_GET['date_from'], $_GET['date_to']); if (!count($id_order_slips_list)) die (Tools::displayError('No order slips found')); $order_slips = array(); foreach ($id_order_slips_list as $id_order_slips) $order_slips[] = new OrderSlip((int)$id_order_slips); generatePDF($order_slips, PDF::TEMPLATE_ORDER_SLIP); } function generateDeliverySlipsPDF() { $order_invoice_collection = OrderInvoice::getByDeliveryDateInterval(Tools::getValue('date_from'), Tools::getValue('date_to')); if (!sizeof($order_invoice_collection)) die(Tools::displayError('No invoices found')); generatePDF($order_invoice_collection, PDF::TEMPLATE_DELIVERY_SLIP); } function generatePDF($object, $template) { global $smarty; $pdf = new PDF($object, $template, $smarty); $pdf->render(); }