[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.09 KiB
MD5: 1f6cd278e6d230e406dc2e9cb43be564

stats_products_purchased.php - 关闭高亮
  1. <?php
  2. /**
  3.  * @package admin
  4.  * @copyright Copyright 2003-2009 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 17534 2010-09-08 19:50:34Z 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 = zen_db_input(zen_db_prepare_input($products_filter));
  65.       echo '<br/ >' . TEXT_INFO_SEARCH_DETAIL_FILTER . $products_filter;
  66.     }
  67.     if (isset($products_filter) && zen_not_null($products_filter)) {
  68.       echo '<br/ >' . '<a href="' . zen_href_link(FILENAME_STATS_PRODUCTS_PURCHASED, '', 'NONSSL') . '">' . zen_image_button('button_reset.gif', IMAGE_RESET) . '</a>&nbsp;&nbsp;';
  69.     }
  70.     echo '</form>';
  71.  
  72. // show reset search
  73.     echo zen_draw_form('search', FILENAME_STATS_PRODUCTS_PURCHASED, '', 'get', '', true);
  74.     echo '<br/ >' . HEADING_TITLE_SEARCH_DETAIL_REPORTS_NAME_MODEL . ' ' . zen_draw_input_field('products_filter_name_model') . zen_hide_session_id();
  75.     if (isset($products_filter_name_model) && zen_not_null($products_filter_name_model)) {
  76.       $products_filter_name_model = zen_db_input(zen_db_prepare_input($products_filter_name_model));
  77.       echo '<br/ >' . TEXT_INFO_SEARCH_DETAIL_FILTER . zen_db_prepare_input($products_filter_name_model);
  78.     }
  79.     if (isset($products_filter_name_model) && zen_not_null($products_filter_name_model)) {
  80.       echo '<br/ >' . '<a href="' . zen_href_link(FILENAME_STATS_PRODUCTS_PURCHASED, '', 'NONSSL') . '">' . zen_image_button('button_reset.gif', IMAGE_RESET) . '</a>&nbsp;&nbsp;';
  81.     }
  82.     echo '</form>';
  83. ?>
  84.             </td>
  85.           </tr>
  86.         </table></td>
  87.       </tr>
  88. <?php
  89. if ($products_filter > 0 or $products_filter_name_model != '') {
  90.   if ($products_filter > 0) {
  91.     // by products_id
  92.     $chk_orders_products_query = "SELECT o.customers_id, op.orders_id, op.products_id, op.products_quantity, op.products_name, op.products_model,
  93.                                  o.customers_name, o.customers_company, o.customers_email_address, o.date_purchased
  94.                                  FROM " . TABLE_ORDERS . " o, " . TABLE_ORDERS_PRODUCTS . " op
  95.                                  WHERE op.products_id in (" . $products_filter . ")
  96.                                  and op.orders_id = o.orders_id
  97.                                  ORDER by op.products_id, o.date_purchased DESC";
  98.   } else {
  99.     // by products name or model
  100.     $chk_orders_products_query = "SELECT o.customers_id, op.orders_id, op.products_id, op.products_quantity, op.products_name, op.products_model,
  101.                                  o.customers_name, o.customers_company, o.customers_email_address, o.date_purchased
  102.                                  FROM " . TABLE_ORDERS . " o, " . TABLE_ORDERS_PRODUCTS . " op
  103.                                  WHERE ((op.products_model LIKE '%" . $products_filter_name_model . "%')
  104.                                  or (op.products_name LIKE '%" . $products_filter_name_model . "%'))
  105.                                  and op.orders_id = o.orders_id
  106.                                  ORDER by op.products_id, o.date_purchased DESC";
  107. }
  108.   $chk_orders_products_query_numrows='';
  109.   $chk_orders_products_split = new splitPageResults($_GET['page'], MAX_DISPLAY_SEARCH_RESULTS_REPORTS, $chk_orders_products_query, $chk_orders_products_query_numrows);
  110.  
  111.   $rows = 0;
  112.   $chk_orders_products = $db->Execute($chk_orders_products_query);
  113. ?>
  114.       <tr>
  115.         <td><table border="0" width="100%" cellspacing="0" cellpadding="0">
  116.           <tr>
  117.             <td valign="top"><table border="0" width="100%" cellspacing="0" cellpadding="2">
  118.               <tr class="dataTableHeadingRow">
  119.                 <td class="dataTableHeadingContent"><?php echo TABLE_HEADING_CUSTOMERS_ID; ?></td>
  120.                 <td class="dataTableHeadingContent"><?php echo TABLE_HEADING_ORDERS_ID; ?></td>
  121.                 <td class="dataTableHeadingContent"><?php echo TABLE_HEADING_ORDERS_DATE_PURCHASED; ?></td>
  122.                 <td class="dataTableHeadingContent"><?php echo TABLE_HEADING_CUSTOMERS_INFO; ?></td>
  123.                 <td class="dataTableHeadingContent" align="center"><?php echo TABLE_HEADING_PRODUCTS_QUANTITY; ?>&nbsp;</td>
  124.                 <td class="dataTableHeadingContent" align="center"><?php echo TABLE_HEADING_PRODUCTS_NAME; ?>&nbsp;</td>
  125.                 <td class="dataTableHeadingContent" align="center"><?php echo TABLE_HEADING_PRODUCTS_MODEL; ?>&nbsp;</td>
  126.               </tr>
  127.  
  128. <?php
  129.   if ($chk_orders_products->EOF) {
  130. ?>
  131.               <tr class="dataTableRowSelectedBot">
  132.                 <td colspan="7" class="dataTableContent" align="center"><?php echo NONE; ?></td>
  133.               </tr>
  134. <?php } ?>
  135. <?php
  136.   while (!$chk_orders_products->EOF) {
  137.     $rows++;
  138.  
  139.     if (strlen($rows) < 2) {
  140.       $rows = '0' . $rows;
  141.     }
  142.     if ($products_filter != '') {
  143.     // products_id
  144.       $cPath = zen_get_product_path($products_filter);
  145.     } else {
  146.     // products_name or products_model
  147.       $cPath = zen_get_product_path($chk_orders_products->fields['products_id']);
  148.     }
  149. ?>
  150.               <tr class="dataTableRow">
  151.                 <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>
  152.                 <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>
  153.                 <td class="dataTableContent"><?php echo zen_date_short($chk_orders_products->fields['date_purchased']); ?></td>
  154.                 <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>
  155.                 <td class="dataTableContent" align="center"><?php echo $chk_orders_products->fields['products_quantity']; ?>&nbsp;</td>
  156.                 <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>
  157.                 <td class="dataTableContent" align="center"><?php echo $chk_orders_products->fields['products_model']; ?>&nbsp;</td>
  158.  
  159.               </tr>
  160. <?php
  161.     $chk_orders_products->MoveNext();
  162.   }
  163. ?>
  164.             </table></td>
  165.           </tr>
  166.           <tr>
  167.             <td colspan="3"><table border="0" width="100%" cellspacing="0" cellpadding="2">
  168.               <tr>
  169.                 <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>
  170.                 <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>
  171.               </tr>
  172.             </table></td>
  173.           </tr>
  174.  
  175. <?php
  176. } else {
  177. // all products by name and quantity display
  178. ?>
  179.       <tr>
  180.         <td><table border="0" width="100%" cellspacing="0" cellpadding="0">
  181.           <tr>
  182.             <td valign="top"><table border="0" width="100%" cellspacing="0" cellpadding="2">
  183.               <tr class="dataTableHeadingRow">
  184.                 <td class="dataTableHeadingContent"><?php echo TABLE_HEADING_NUMBER; ?></td>
  185.                 <td class="dataTableHeadingContent"><?php echo TABLE_HEADING_PRODUCTS; ?></td>
  186.                 <td class="dataTableHeadingContent" align="center"><?php echo TABLE_HEADING_PURCHASED; ?>&nbsp;</td>
  187.               </tr>
  188. <?php
  189.   if (isset($_GET['page']) && ($_GET['page'] > 1)) $rows = $_GET['page'] * MAX_DISPLAY_SEARCH_RESULTS_REPORTS - MAX_DISPLAY_SEARCH_RESULTS_REPORTS;
  190. // The following OLD query only considers the "products_ordered" value from the products table.
  191. // Thus this older query is somewhat deprecated
  192.   $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";
  193.  
  194. // The new query uses real order info from the orders_products table, and is theoretically more accurate.
  195. // To use this newer query, remove the "1" from the following line ($products_query_raw1 becomes $products_query_raw )
  196.     $products_query_raw1 =
  197.       "select sum(op.products_quantity) as products_ordered, pd.products_name, op.products_id
  198.      from ".TABLE_ORDERS_PRODUCTS." op
  199.      left join " . TABLE_PRODUCTS_DESCRIPTION . " pd
  200.        on (pd.products_id = op.products_id )
  201.      where pd.language_id = '" . $_SESSION['languages_id']. "'
  202.      group by pd.products_id
  203.      order by products_ordered DESC, products_name";
  204.  
  205.   $products_query_numrows='';
  206.   $products_split = new splitPageResults($_GET['page'], MAX_DISPLAY_SEARCH_RESULTS_REPORTS, $products_query_raw, $products_query_numrows);
  207.  
  208.   $rows = 0;
  209.   $products = $db->Execute($products_query_raw);
  210.   while (!$products->EOF) {
  211.     $rows++;
  212.  
  213.     if (strlen($rows) < 2) {
  214.       $rows = '0' . $rows;
  215.     }
  216.     $cPath = zen_get_product_path($products->fields['products_id']);
  217. ?>
  218.               <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='); ?>'">
  219.                 <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>
  220.                 <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>
  221.                 <td class="dataTableContent" align="center"><?php echo $products->fields['products_ordered']; ?>&nbsp;</td>
  222.               </tr>
  223. <?php
  224.     $products->MoveNext();
  225.   }
  226. ?>
  227.             </table></td>
  228.           </tr>
  229.           <tr>
  230.             <td colspan="3"><table border="0" width="100%" cellspacing="0" cellpadding="2">
  231.               <tr>
  232.                 <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>
  233.                 <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>
  234.               </tr>
  235.             </table></td>
  236.           </tr>
  237. <?php
  238. } // $products_filter > 0
  239. ?>
  240.         </table></td>
  241.       </tr>
  242.     </table></td>
  243. <!-- body_text_eof //-->
  244.   </tr>
  245. </table>
  246. <!-- body_eof //-->
  247.  
  248. <!-- footer //-->
  249. <div class="footer-area">
  250. <?php require(DIR_WS_INCLUDES . 'footer.php'); ?>
  251. </div>
  252. <!-- footer_eof //-->
  253. </body>
  254. </html>
  255. <?php require(DIR_WS_INCLUDES . 'application_bottom.php'); ?>


cron