ExecuteS(' SELECT `id_sale`, `id_category` FROM `'._DB_PREFIX_.'privatesale` WHERE `date_end` >= DATE_FORMAT("'.$now.'" - INTERVAL 7 DAY, \'%Y-%m-%d 00:00:00\') AND `date_end` < DATE_FORMAT("'.$now.'", \'%Y-%m-%d 00:00:00\') ORDER BY `date_end` '); //echo "
";var_dump($sales);echo "
";die(); foreach($sales as $row) { //echo $row['id_sale']." - ".$row['id_category']."\n"; $id_category = (int) $row['id_category']; $category = new Category($id_category, $id_lang); $sale = new Sale((int)$row['id_sale']); $products = $category->getProductsStats($id_lang , "1", "1000000000000000000", "reference",NULL , FALSE, FALSE , FALSE ); $arrayProduct = array(); foreach($products as $product) $array_product[$product['id_product']] = $arrayProduct[$product['id_product']] = new Product($product['id_product']); $order_states = explode(',', Configuration::get('PS_IT_OF_ORDER_STATES')); $lines = MakeStats::getOrdersByIdsProduct(array_keys($arrayProduct), $order_states); // for stats $lines_tmp = $lines; $lines = MakeStats::getArrayLines($lines); $stats = new SaleStats($sale, $category); $stats->loadData(); $total_sale_product = array(); $total_sale_ht = 0; foreach ($lines_tmp as $key => $order_line) { $id_product = $order_line['product_id']; $id_product_attribute = $order_line['product_attribute_id']; $current_product = $array_product[$id_product]; if($id_product_attribute != 0) { $combination = new Combination($id_product_attribute); if($combination->wholesale_price == 0) { $wholesale_price = $current_product->wholesale_price; } else { $wholesale_price = $combination->wholesale_price; } } else { $wholesale_price = $current_product->wholesale_price; } $quantity_to_cmd = $order_line['product_quantity'] - $order_line['product_quantity_reinjected']; $total_sale_ht += $quantity_to_cmd * $wholesale_price; if (!is_array($total_sale_product[(int)$id_product]) ){ $total_sale_product[(int)$id_product] = array(); $total_sale_product[(int)$id_product]['total_ht'] = 0; $total_sale_product[(int)$id_product]['quantiy'] = 0; $total_sale_product[(int)$id_product]['name'] = $current_product->name[2]; } $total_sale_product[(int)$id_product]['total_ht'] += ($wholesale_price * $quantity_to_cmd); $total_sale_product[(int)$id_product]['quantiy'] += $quantity_to_cmd; } $stats->addToStats('total_bdc_ht', $total_sale_ht); $bestsales = MakeStats::orderMultiArray($total_sale_product, 'total_ht'); $bestsales_extract = array_slice($bestsales, 0, 3); $i = 1; foreach ($bestsales_extract as $key => $bestsalesProduct) { $stats->addToStats('bestsale_'.$i.'_product', $bestsalesProduct['name']); $stats->addToStats('bestsale_'.$i.'_quantity', $bestsalesProduct['quantiy']); $stats->addToStats('bestsale_'.$i.'_ca', $bestsalesProduct['total_ht']); $i++; } $stats->loadDataForSubCategory(); $csv_row = array( $row['id_sale'], $stats->data_stats['name'], $stats->data_stats['date_start'], $stats->data_stats['date_end'], $stats->data_stats['duration'], $stats->data_stats['nb_ref'], $stats->data_stats['nb_quantity_start'], $stats->data_stats['nb_order_simple'], $stats->data_stats['nb_order_multi'], $stats->data_stats['nb_order_total'], $stats->data_stats['taux_multi'], $stats->data_stats['quantity_sale'], $stats->data_stats['percent_sale'], $stats->data_stats['percent_out_of_stock'], Tools::displayPrice($stats->data_stats['ca_ttc']), Tools::displayPrice($stats->data_stats['total_bdc_ht']), $stats->data_stats['marge'], (isset($stats->data_stats['bestsale_1_product'])?$stats->data_stats['bestsale_1_product']:''), (isset($stats->data_stats['bestsale_1_quantity'])?$stats->data_stats['bestsale_1_quantity']:''), (isset($stats->data_stats['bestsale_1_ca'])?Tools::displayPrice($stats->data_stats['bestsale_1_ca']):0), (isset($stats->data_stats['bestsale_2_product'])?$stats->data_stats['bestsale_2_product']:''), (isset($stats->data_stats['bestsale_2_quantity'])?$stats->data_stats['bestsale_2_quantity']:''), (isset($stats->data_stats['bestsale_2_ca'])?Tools::displayPrice($stats->data_stats['bestsale_2_ca']):0), (isset($stats->data_stats['bestsale_3_product'])?$stats->data_stats['bestsale_3_product']:''), (isset($stats->data_stats['bestsale_3_quantity'])?$stats->data_stats['bestsale_3_quantity']:''), (isset($stats->data_stats['bestsale_3_ca'])?Tools::displayPrice($stats->data_stats['bestsale_3_ca']):0), ); foreach ($stats->data_subcategories as $key => $subcategories) { foreach ($subcategories as $key_2 => $subcategory) { if ($key_2 == 'total_amount_wholesale_price') { $csv_row[] = Tools::displayPrice($subcategory); } else { $csv_row[]= $subcategory; } $i++; } } fwrite($f, implode(';', $csv_row)."\n"); } fclose($f); exit;