[phpBB Debug] PHP Warning: in file [ROOT]/includes/crs/crs_misc_functions.php on line 37: mime_content_type(): Empty filename or path
[phpBB Debug] PHP Warning: in file [ROOT]/includes/crs/crs_misc_functions.php on line 37: mime_content_type(): Empty filename or path
Zen Cart 源代码 stats_products_purchased.php

Zen Cart 源代码 stats_products_purchased.php




下载文件

文件名: stats_products_purchased.php
文件类型: PHP文件
文件大小: 14.16 KiB
MD5: bbadcb6969567bef2695fe53f6f0d377

stats_products_purchased.php - 关闭高亮
  1. <?php
  2. /**
  3.  * @package admin
  4.  * @copyright Copyright 2003-2011 Zen Cart Development Team
  5.  * @copyright Portions Copyright 2003 osCommerce
  6.  * @license http://www.zen-cart.com/license/2_0.txt GNU Public License V2.0
  7.  * @version $Id: stats_products_purchased.php 18698 2011-05-04 14:50:06Z wilt $
  8.  */
  9.  
  10.   require('includes/application_top.php');
  11.  
  12.   $products_filter = (isset($_GET['products_filter']) ? $_GET['products_filter'] : $products_filter);
  13.   $products_filter = str_replace(' ', ',', $products_filter);
  14.   $products_filter = str_replace(',,', ',', $products_filter);
  15.   $products_filter_name_model = (isset($_GET['products_filter_name_model']) ? $_GET['products_filter_name_model'] : $products_filter_name_model);
  16. ?>
  17. <!doctype html public "-//W3C//DTD HTML 4.01 Transitional//EN">
  18. <html <?php echo HTML_PARAMS; ?>>
  19. <head>
  20. <meta http-equiv="Content-Type" content="text/html; charset=<?php echo CHARSET; ?>">
  21. <title><?php echo TITLE; ?></title>
  22. <link rel="stylesheet" type="text/css" href="includes/stylesheet.css">
  23. <link rel="stylesheet" type="text/css" media="print" href="includes/stylesheet_print.css">
  24. <link rel="stylesheet" type="text/css" href="includes/cssjsmenuhover.css" media="all" id="hoverJS">
  25. <script language="javascript" src="includes/menu.js"></script>
  26. <script language="javascript" src="includes/general.js"></script>
  27. <script type="text/javascript">
  28.   <!--
  29.   function init()
  30.   {
  31.     cssjsmenu('navbar');
  32.     if (document.getElementById)
  33.     {
  34.       var kill = document.getElementById('hoverJS');
  35.       kill.disabled = true;
  36.     }
  37.   }
  38.   // -->
  39. </script>
  40. </head>
  41. <body onload="init()">
  42. <!-- header //-->
  43. <div class="header-area">
  44. <?php require(DIR_WS_INCLUDES . 'header.php'); ?>
  45. </div>
  46. <!-- header_eof //-->
  47.  
  48. <!-- body //-->
  49. <table border="0" width="100%" cellspacing="2" cellpadding="2">
  50.   <tr>
  51. <!-- body_text //-->
  52.     <td width="100%" valign="top"><table border="0" width="100%" cellspacing="0" cellpadding="2">
  53.       <tr>
  54.         <td><table border="0" width="100%" cellspacing="0" cellpadding="0">
  55.           <tr>
  56.             <td class="pageHeading"><?php echo HEADING_TITLE; ?></td>
  57.             <td class="pageHeading" align="right"><?php echo zen_draw_separator('pixel_trans.gif', 1, HEADING_IMAGE_HEIGHT); ?></td>
  58.             <td class="smallText" align="right">
  59. <?php
  60. // show reset search
  61.     echo zen_draw_form('search', FILENAME_STATS_PRODUCTS_PURCHASED, '', 'get', '', true);
  62.     echo HEADING_TITLE_SEARCH_DETAIL_REPORTS . ' ' . zen_draw_input_field('products_filter') . zen_hide_session_id();
  63.     if (isset($products_filter) && zen_not_null($products_filter)) {
  64.       $products_filter = preg_replace('/[^0-9,]/', '', $products_filter);
  65.       $products_filter = zen_db_input(zen_db_prepare_input($products_filter));
  66.       echo '<br/ >' . TEXT_INFO_SEARCH_DETAIL_FILTER . $products_filter;
  67.     }
  68.     if (isset($products_filter) && zen_not_null($products_filter)) {
  69.       echo '<br/ >' . '<a href="' . zen_href_link(FILENAME_STATS_PRODUCTS_PURCHASED, '', 'NONSSL') . '">' . zen_image_button('button_reset.gif', IMAGE_RESET) . '</a>&nbsp;&nbsp;';
  70.     }
  71.     echo '</form>';
  72.  
  73. // show reset search
  74.     echo zen_draw_form('search', FILENAME_STATS_PRODUCTS_PURCHASED, '', 'get', '', true);
  75.     echo '<br/ >' . HEADING_TITLE_SEARCH_DETAIL_REPORTS_NAME_MODEL . ' ' . zen_draw_input_field('products_filter_name_model') . zen_hide_session_id();
  76.     if (isset($products_filter_name_model) && zen_not_null($products_filter_name_model)) {
  77.       $products_filter_name_model = zen_db_input(zen_db_prepare_input($products_filter_name_model));
  78.       echo '<br/ >' . TEXT_INFO_SEARCH_DETAIL_FILTER . zen_db_prepare_input($products_filter_name_model);
  79.     }
  80.     if (isset($products_filter_name_model) && zen_not_null($products_filter_name_model)) {
  81.       echo '<br/ >' . '<a href="' . zen_href_link(FILENAME_STATS_PRODUCTS_PURCHASED, '', 'NONSSL') . '">' . zen_image_button('button_reset.gif', IMAGE_RESET) . '</a>&nbsp;&nbsp;';
  82.     }
  83.     echo '</form>';
  84. ?>
  85.             </td>
  86.           </tr>
  87.         </table></td>
  88.       </tr>
  89. <?php
  90. if ($products_filter > 0 or $products_filter_name_model != '') {
  91.   if ($products_filter > 0) {
  92.     // by products_id
  93.     $chk_orders_products_query = "SELECT o.customers_id, op.orders_id, op.products_id, op.products_quantity, op.products_name, op.products_model,
  94.                                  o.customers_name, o.customers_company, o.customers_email_address, o.date_purchased
  95.                                  FROM " . TABLE_ORDERS . " o, " . TABLE_ORDERS_PRODUCTS . " op
  96.                                  WHERE op.products_id in (" . $products_filter . ")
  97.                                  and op.orders_id = o.orders_id
  98.                                  ORDER by op.products_id, o.date_purchased DESC";
  99.   } else {
  100.     // by products name or model
  101.     $chk_orders_products_query = "SELECT o.customers_id, op.orders_id, op.products_id, op.products_quantity, op.products_name, op.products_model,
  102.                                  o.customers_name, o.customers_company, o.customers_email_address, o.date_purchased
  103.                                  FROM " . TABLE_ORDERS . " o, " . TABLE_ORDERS_PRODUCTS . " op
  104.                                  WHERE ((op.products_model LIKE '%" . $products_filter_name_model . "%')
  105.                                  or (op.products_name LIKE '%" . $products_filter_name_model . "%'))
  106.                                  and op.orders_id = o.orders_id
  107.                                  ORDER by op.products_id, o.date_purchased DESC";
  108. }
  109.   $chk_orders_products_query_numrows='';
  110.   $chk_orders_products_split = new splitPageResults($_GET['page'], MAX_DISPLAY_SEARCH_RESULTS_REPORTS, $chk_orders_products_query, $chk_orders_products_query_numrows);
  111.  
  112.   $rows = 0;
  113.   $chk_orders_products = $db->Execute($chk_orders_products_query);
  114. ?>
  115.       <tr>
  116.         <td><table border="0" width="100%" cellspacing="0" cellpadding="0">
  117.           <tr>
  118.             <td valign="top"><table border="0" width="100%" cellspacing="0" cellpadding="2">
  119.               <tr class="dataTableHeadingRow">
  120.                 <td class="dataTableHeadingContent"><?php echo TABLE_HEADING_CUSTOMERS_ID; ?></td>
  121.                 <td class="dataTableHeadingContent"><?php echo TABLE_HEADING_ORDERS_ID; ?></td>
  122.                 <td class="dataTableHeadingContent"><?php echo TABLE_HEADING_ORDERS_DATE_PURCHASED; ?></td>
  123.                 <td class="dataTableHeadingContent"><?php echo TABLE_HEADING_CUSTOMERS_INFO; ?></td>
  124.                 <td class="dataTableHeadingContent" align="center"><?php echo TABLE_HEADING_PRODUCTS_QUANTITY; ?>&nbsp;</td>
  125.                 <td class="dataTableHeadingContent" align="center"><?php echo TABLE_HEADING_PRODUCTS_NAME; ?>&nbsp;</td>
  126.                 <td class="dataTableHeadingContent" align="center"><?php echo TABLE_HEADING_PRODUCTS_MODEL; ?>&nbsp;</td>
  127.               </tr>
  128.  
  129. <?php
  130.   if ($chk_orders_products->EOF) {
  131. ?>
  132.               <tr class="dataTableRowSelectedBot">
  133.                 <td colspan="7" class="dataTableContent" align="center"><?php echo NONE; ?></td>
  134.               </tr>
  135. <?php } ?>
  136. <?php
  137.   while (!$chk_orders_products->EOF) {
  138.     $rows++;
  139.  
  140.     if (strlen($rows) < 2) {
  141.       $rows = '0' . $rows;
  142.     }
  143.     if ($products_filter != '') {
  144.     // products_id
  145.       $cPath = zen_get_product_path($products_filter);
  146.     } else {
  147.     // products_name or products_model
  148.       $cPath = zen_get_product_path($chk_orders_products->fields['products_id']);
  149.     }
  150. ?>
  151.               <tr class="dataTableRow">
  152.                 <td class="dataTableContent"><?php echo '<a href="' . zen_href_link(FILENAME_CUSTOMERS, zen_get_all_get_params(array('cID', 'action', 'page', 'products_filter')) . 'cID=' . $chk_orders_products->fields['customers_id'] . '&action=edit', 'NONSSL') . '">' . $chk_orders_products->fields['customers_id'] . '</a>'; ?></td>
  153.                 <td class="dataTableContent"><?php echo '<a href="' . zen_href_link(FILENAME_ORDERS, zen_get_all_get_params(array('oID', 'action', 'page', 'products_filter')) . 'oID=' . $chk_orders_products->fields['orders_id'] . '&action=edit', 'NONSSL') . '">' . $chk_orders_products->fields['orders_id'] . '</a>'; ?></td>
  154.                 <td class="dataTableContent"><?php echo zen_date_short($chk_orders_products->fields['date_purchased']); ?></td>
  155.                 <td class="dataTableContent"><?php echo $chk_orders_products->fields['customers_name'] . ($chk_orders_products->fields['customers_company'] !='' ? '<br />' . $chk_orders_products->fields['customers_company'] : '') . '<br />' . $chk_orders_products->fields['customers_email_address']; ?></td>
  156.                 <td class="dataTableContent" align="center"><?php echo $chk_orders_products->fields['products_quantity']; ?>&nbsp;</td>
  157.                 <td class="dataTableContent" align="center"><?php echo '<a href="' . zen_href_link(FILENAME_CATEGORIES, 'cPath=' . $cPath . '&pID=' . $products_filter) . '">' . $chk_orders_products->fields['products_name'] . '</a>'; ?>&nbsp;</td>
  158.                 <td class="dataTableContent" align="center"><?php echo $chk_orders_products->fields['products_model']; ?>&nbsp;</td>
  159.  
  160.               </tr>
  161. <?php
  162.     $chk_orders_products->MoveNext();
  163.   }
  164. ?>
  165.             </table></td>
  166.           </tr>
  167.           <tr>
  168.             <td colspan="3"><table border="0" width="100%" cellspacing="0" cellpadding="2">
  169.               <tr>
  170.                 <td class="smallText" valign="top"><?php echo $chk_orders_products_split->display_count($chk_orders_products_query_numrows, MAX_DISPLAY_SEARCH_RESULTS_REPORTS, $_GET['page'], TEXT_DISPLAY_NUMBER_OF_PRODUCTS); ?></td>
  171.                 <td class="smallText" align="right"><?php echo $chk_orders_products_split->display_links($chk_orders_products_query_numrows, MAX_DISPLAY_SEARCH_RESULTS_REPORTS, MAX_DISPLAY_PAGE_LINKS, $_GET['page'], zen_get_all_get_params(array('page', 'x', 'y'))); ?>&nbsp;</td>
  172.               </tr>
  173.             </table></td>
  174.           </tr>
  175.  
  176. <?php
  177. } else {
  178. // all products by name and quantity display
  179. ?>
  180.       <tr>
  181.         <td><table border="0" width="100%" cellspacing="0" cellpadding="0">
  182.           <tr>
  183.             <td valign="top"><table border="0" width="100%" cellspacing="0" cellpadding="2">
  184.               <tr class="dataTableHeadingRow">
  185.                 <td class="dataTableHeadingContent"><?php echo TABLE_HEADING_NUMBER; ?></td>
  186.                 <td class="dataTableHeadingContent"><?php echo TABLE_HEADING_PRODUCTS; ?></td>
  187.                 <td class="dataTableHeadingContent" align="center"><?php echo TABLE_HEADING_PURCHASED; ?>&nbsp;</td>
  188.               </tr>
  189. <?php
  190.   if (isset($_GET['page']) && ($_GET['page'] > 1)) $rows = $_GET['page'] * MAX_DISPLAY_SEARCH_RESULTS_REPORTS - MAX_DISPLAY_SEARCH_RESULTS_REPORTS;
  191. // The following OLD query only considers the "products_ordered" value from the products table.
  192. // Thus this older query is somewhat deprecated
  193.   $products_query_raw = "select p.products_id, p.products_ordered, pd.products_name from " . TABLE_PRODUCTS . " p, " . TABLE_PRODUCTS_DESCRIPTION . " pd where pd.products_id = p.products_id and pd.language_id = '" . $_SESSION['languages_id']. "' and p.products_ordered > 0 group by pd.products_id order by p.products_ordered DESC, pd.products_name";
  194.  
  195. // The new query uses real order info from the orders_products table, and is theoretically more accurate.
  196. // To use this newer query, remove the "1" from the following line ($products_query_raw1 becomes $products_query_raw )
  197.     $products_query_raw1 =
  198.       "select sum(op.products_quantity) as products_ordered, pd.products_name, op.products_id
  199.      from ".TABLE_ORDERS_PRODUCTS." op
  200.      left join " . TABLE_PRODUCTS_DESCRIPTION . " pd
  201.        on (pd.products_id = op.products_id )
  202.      where pd.language_id = '" . $_SESSION['languages_id']. "'
  203.      group by pd.products_id
  204.      order by products_ordered DESC, products_name";
  205.  
  206.   $products_query_numrows='';
  207.   $products_split = new splitPageResults($_GET['page'], MAX_DISPLAY_SEARCH_RESULTS_REPORTS, $products_query_raw, $products_query_numrows);
  208.  
  209.   $rows = 0;
  210.   $products = $db->Execute($products_query_raw);
  211.   while (!$products->EOF) {
  212.     $rows++;
  213.  
  214.     if (strlen($rows) < 2) {
  215.       $rows = '0' . $rows;
  216.     }
  217.     $cPath = zen_get_product_path($products->fields['products_id']);
  218. ?>
  219.               <tr class="dataTableRow" onmouseover="rowOverEffect(this)" onmouseout="rowOutEffect(this)" onclick="document.location.href='<?php echo zen_href_link(FILENAME_CATEGORIES, 'cPath=' . $cPath . '&pID=' . $products->fields['products_id'] . '&page='); ?>'">
  220.                 <td class="dataTableContent" align="right"><?php echo '<a href="' . zen_href_link(FILENAME_STATS_PRODUCTS_PURCHASED, zen_get_all_get_params(array('oID', 'action', 'page', 'products_filter')) . 'products_filter=' . $products->fields['products_id']) . '">' . $products->fields['products_id'] . '</a>'; ?>&nbsp;&nbsp;</td>
  221.                 <td class="dataTableContent"><?php echo '<a href="' . zen_href_link(FILENAME_CATEGORIES, 'cPath=' . $cPath . '&pID=' . $products->fields['products_id'] . '&page=') . '">' . $products->fields['products_name'] . '</a>'; ?></td>
  222.                 <td class="dataTableContent" align="center"><?php echo $products->fields['products_ordered']; ?>&nbsp;</td>
  223.               </tr>
  224. <?php
  225.     $products->MoveNext();
  226.   }
  227. ?>
  228.             </table></td>
  229.           </tr>
  230.           <tr>
  231.             <td colspan="3"><table border="0" width="100%" cellspacing="0" cellpadding="2">
  232.               <tr>
  233.                 <td class="smallText" valign="top"><?php echo $products_split->display_count($products_query_numrows, MAX_DISPLAY_SEARCH_RESULTS_REPORTS, $_GET['page'], TEXT_DISPLAY_NUMBER_OF_PRODUCTS); ?></td>
  234.                 <td class="smallText" align="right"><?php echo $products_split->display_links($products_query_numrows, MAX_DISPLAY_SEARCH_RESULTS_REPORTS, MAX_DISPLAY_PAGE_LINKS, $_GET['page']); ?>&nbsp;</td>
  235.               </tr>
  236.             </table></td>
  237.           </tr>
  238. <?php
  239. } // $products_filter > 0
  240. ?>
  241.         </table></td>
  242.       </tr>
  243.     </table></td>
  244. <!-- body_text_eof //-->
  245.   </tr>
  246. </table>
  247. <!-- body_eof //-->
  248.  
  249. <!-- footer //-->
  250. <div class="footer-area">
  251. <?php require(DIR_WS_INCLUDES . 'footer.php'); ?>
  252. </div>
  253. <!-- footer_eof //-->
  254. </body>
  255. </html>
  256. <?php require(DIR_WS_INCLUDES . 'application_bottom.php'); ?>