source: temp/trunk/html/admin/total/index.php @ 7247

Revision 7247, 23.5 KB checked in by kakinaka, 20 years ago (diff)

* empty log message *

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
Line 
1<?php
2/*
3 * Copyright(c) 2000-2006 LOCKON CO.,LTD. All Rights Reserved.
4 *
5 * http://www.lockon.co.jp/
6 */
7require_once("../require.php");
8require_once("./index_sub.php");
9require_once("../batch/daily.php");
10
11require_once("./class/SC_GraphPie.php");
12require_once("./class/SC_GraphLine.php");
13require_once("./class/SC_GraphBar.php");
14
15class LC_Page {
16    var $arrResults;
17    var $keyname;
18    var $tpl_image;
19    var $arrTitle;
20    function LC_Page() {
21        $this->tpl_mainpage = 'total/index.tpl';
22        $this->tpl_subnavi = 'total/subnavi.tpl';
23        $this->tpl_graphsubtitle = 'total/subtitle.tpl';
24        $this->tpl_titleimage = '/img/title/title_sale.jpg';
25        $this->tpl_mainno = 'total';
26        global $arrWDAY;
27        $this->arrWDAY = $arrWDAY;
28        // ¥Ú¡¼¥¸¥¿¥¤¥È¥ë
29        $this->arrTitle[''] = "´ü´ÖÊ̽¸·×";
30        $this->arrTitle['term'] = "´ü´ÖÊ̽¸·×";
31        $this->arrTitle['products'] = "¾¦ÉÊÊ̽¸·×";
32        $this->arrTitle['age'] = "ǯÂåÊ̽¸·×";
33        $this->arrTitle['job'] = "¿¦¶ÈÊ̽¸·×";
34        $this->arrTitle['member'] = "²ñ°÷Ê̽¸·×";
35       
36        // ¥­¥ã¥Ã¥·¥å²óÈò¤Î¤¿¤á¤ËÆüÉÕ¤òÅϤ¹
37        $this->cashtime = time();
38    }
39}
40
41$objPage = new LC_Page();
42$objView = new SC_AdminView();
43$objSess = new SC_Session();
44// ǧ¾Ú²ÄÈݤÎȽÄê
45sfIsSuccess($objSess);
46
47// ÆþÎÏ´ü´Ö¤ò¥»¥Ã¥·¥ç¥ó¤Ëµ­Ï¿¤¹¤ë
48lfSaveDateSession();
49
50if($_GET['draw_image'] != ""){
51    define(DRAW_IMAGE , true);
52}else{
53    define(DRAW_IMAGE , false);
54}
55
56// ¥Ñ¥é¥á¡¼¥¿´ÉÍý¥¯¥é¥¹
57$objFormParam = new SC_FormParam();
58// ¥Ñ¥é¥á¡¼¥¿¾ðÊó¤Î½é´ü²½
59lfInitParam();
60$objFormParam->setParam($_POST);
61$objFormParam->setParam($_GET);
62
63// ¸¡º÷¥ï¡¼¥É¤Î°ú¤­·Ñ¤®
64foreach ($_POST as $key => $val) {
65    if (ereg("^search_", $key)) {
66        $objPage->arrHidden[$key] = $val;       
67    }
68}
69
70$mode = $objFormParam->getValue('mode');
71switch($mode) {
72case 'pdf':
73case 'csv':
74case 'search':
75    // ÆþÎÏÃͤÎÊÑ´¹
76    $objFormParam->convParam();
77    $objPage->arrErr = lfCheckError($arrRet);
78    $arrRet = $objFormParam->getHashArray();
79   
80    // ÆþÎÏ¥¨¥é¡¼¤Ê¤·
81    if (count($objPage->arrErr) == 0) {
82        foreach ($arrRet as $key => $val) {
83            if($val == "") {
84                continue;
85            }
86            switch ($key) {
87            case 'search_startyear':
88                $sdate = $objFormParam->getValue('search_startyear') . "/" . $objFormParam->getValue('search_startmonth') . "/" . $objFormParam->getValue('search_startday');
89                break;
90            case 'search_endyear':
91                $edate = $objFormParam->getValue('search_endyear') . "/" . $objFormParam->getValue('search_endmonth') . "/" . $objFormParam->getValue('search_endday');
92                break;
93            case 'search_startyear_m':
94                list($sdate, $edate) = sfTermMonth($objFormParam->getValue('search_startyear_m'), $objFormParam->getValue('search_startmonth_m'), CLOSE_DAY);
95                break;
96            default:
97                break;
98            }
99        }
100
101        if($_POST['type'] != "") {
102            $type = $_POST['type'];
103        }
104               
105        $page = $objFormParam->getValue('page');
106        switch($page) {
107        // ¾¦ÉÊÊ̽¸·×
108        case 'products':
109            if($type == "") {
110                $type = 'all';
111            }
112            $objPage->tpl_page_type = "total/page_products.tpl";
113            // ̤½¸·×¥Ç¡¼¥¿¤Î½¸·×¤ò¹Ô¤¦
114            lfRealTimeDailyTotal($sdate, $edate);
115            // ¸¡º÷·ë²Ì¤Î¼èÆÀ
116            $objPage = lfGetOrderProducts($type, $sdate, $edate, $objPage, true, $mode);
117            break;
118        // ¿¦¶ÈÊ̽¸·×
119        case 'job':
120            if($type == "") {
121                $type = 'all';
122            }
123            $objPage->tpl_page_type = "total/page_job.tpl";
124            // ̤½¸·×¥Ç¡¼¥¿¤Î½¸·×¤ò¹Ô¤¦
125            lfRealTimeDailyTotal($sdate, $edate);
126            // ¸¡º÷·ë²Ì¤Î¼èÆÀ
127            $objPage = lfGetOrderJob($type, $sdate, $edate, $objPage);
128            break;
129        // ²ñ°÷Ê̽¸·×
130        case 'member':
131            if($type == "") {
132                $type = 'all';
133            }
134            $objPage->tpl_page_type = "total/page_member.tpl";
135            // ̤½¸·×¥Ç¡¼¥¿¤Î½¸·×¤ò¹Ô¤¦
136            lfRealTimeDailyTotal($sdate, $edate);
137            // ¸¡º÷·ë²Ì¤Î¼èÆÀ
138            $objPage = lfGetOrderMember($type, $sdate, $edate, $objPage);
139            break;
140        // ǯÂåÊ̽¸·×
141        case 'age':
142            if($type == "") {
143                $type = 'all';
144            }
145           
146            $objPage->tpl_page_type = "total/page_age.tpl";
147            // ̤½¸·×¥Ç¡¼¥¿¤Î½¸·×¤ò¹Ô¤¦
148            lfRealTimeDailyTotal($sdate, $edate);
149            // ¸¡º÷·ë²Ì¤Î¼èÆÀ
150            $objPage = lfGetOrderAge($type, $sdate, $edate, $objPage);
151            break;
152        // ´ü´ÖÊ̽¸·×
153        default:
154            if($type == "") {
155                $type = 'day';
156            }
157            $objPage->tpl_page_type = "total/page_term.tpl";
158            // ̤½¸·×¥Ç¡¼¥¿¤Î½¸·×¤ò¹Ô¤¦
159            lfRealTimeDailyTotal($sdate, $edate);
160            // ¸¡º÷·ë²Ì¤Î¼èÆÀ
161            $objPage = lfGetOrderTerm($type, $sdate, $edate, $objPage);
162           
163            break;
164        }
165
166        if($mode == 'csv') {
167            // CSV½ÐÎÏ¥¿¥¤¥È¥ë¹Ô¤Î¼èÆÀ
168            list($arrTitleCol, $arrDataCol) = lfGetCSVColum($page, $objPage->keyname);
169            $head = sfGetCSVList($arrTitleCol);
170            $data = lfGetDataColCSV($objPage->arrResults, $arrDataCol);
171            // CSV¤òÁ÷¿®¤¹¤ë¡£
172            sfCSVDownload($head.$data, $page."_".$type);
173            exit;
174        }
175       
176        if($mode == 'pdf') {
177            // CSV½ÐÎÏ¥¿¥¤¥È¥ë¹Ô¤Î¼èÆÀ
178            list($arrTitleCol, $arrDataCol, $arrColSize, $arrAlign, $title) = lfGetPDFColum($page, $type, $objPage->keyname);
179            $head = sfGetPDFList($arrTitleCol);
180            $data = lfGetDataColPDF($objPage->arrResults, $arrDataCol, 40);
181            // PDF½ÐÎÏÍÑ
182            $graph_name = basename($objPage->tpl_image);
183            lfPDFDownload($graph_name, $head . $data, $arrColSize, $arrAlign, $sdate, $edate, $title, $page);
184            exit;
185        }   
186    }
187    break;
188default:
189    if(count($_GET) == 0) {
190        /*
191            ¥ê¥¢¥ë¥¿¥¤¥à½¸·×¤ËÀÚ¤êÂØ¤¨ by Nakagawa 2006/08/31
192            // 1¥ö·îʬ¤Î½¸·×
193            lfStartDailyTotal(31,0);
194        */
195    }
196    break;
197}
198
199// ÅÐÏ¿¡¦¹¹¿·Æü¸¡º÷ÍÑ
200$objDate = new SC_Date();
201$objDate->setStartYear(RELEASE_YEAR);
202$objDate->setEndYear(DATE("Y"));
203$objPage->arrYear = $objDate->getYear();
204$objPage->arrMonth = $objDate->getMonth();
205$objPage->arrDay = $objDate->getDay();
206// ÆþÎÏÃͤμèÆÀ
207$objPage->arrForm = $objFormParam->getFormParamList();
208
209$objPage->tpl_subtitle = $objPage->arrTitle[$objFormParam->getValue('page')];
210
211$objView->assignobj($objPage);
212$objView->display(MAIN_FRAME);
213
214//---------------------------------------------------------------------------------------------------------------------------
215/* PDF½ÐÎÏ */
216function lfPDFDownload($image, $table, $arrColSize, $arrAlign, $sdate, $edate, $title, $page = "") {
217   
218    $objPdf = new SC_Pdf();
219    $objPdf->setTableColor("CCCCCC", "F0F0F0", "D1DEFE");
220           
221    // ÅÚÂæ¤È¤Ê¤ëPDF¥Õ¥¡¥¤¥ë¤Î»ØÄê
222    $objPdf->setTemplate(PDF_DIR . "total.pdf");
223
224    $disp_sdate = sfDispDBDate($sdate, false);
225    $disp_edate = sfDispDBDate($edate, false);
226               
227    $arrText['title_block'] = $title;
228    $arrText['date_block'] = "$disp_sdate-$disp_edate";
229    $arrImage['graph_block'] = GRAPH_DIR . $image;
230   
231    // ʸËö¤Î\n¤òºï½ü¤¹¤ë
232    $table = ereg_replace("\n$", "", $table);
233    $arrRet = split("\n", $table);
234    $page_max = intval((count($arrRet) / 35) + 1);
235   
236    for($page = 1; $page <= $page_max; $page++) {
237        if($page > 1) {
238            // 2¥Ú¡¼¥¸°Ê¹ß
239            $start_no = 35 * ($page - 1) + 1;
240        } else {
241            // ³«»Ï¥Ú¡¼¥¸
242            $start_no = 1;         
243        }
244               
245        $arrText['page_block'] = $page . " / " . $page_max;
246        $objPdf->setTextBlock($arrText);
247        $objPdf->setImageBlock($arrImage);
248        // ¥Ö¥í¥Ã¥¯ÃÍ¤ÎÆþÎÏ
249        $objPdf->writeBlock();
250        // ºÇ½ª¥Ú¡¼¥¸¤Î¤ß¡¢¾¦ÉÊÊ̽¸·×¤Ï¹ç·×¤¬¤Ê¤¤¤Î¤ÇºÇ½ª¹Ô¤Î¿§¤òÊѹ¹¤·¤Ê¤¤¡£
251        if($page == $page_max && $page != 'products') {
252            $last_color_flg = true;
253        } else {
254            $last_color_flg = false;
255        }   
256        $objPdf->writeTableCenter($table, 500, $arrColSize, $arrAlign, 35, $start_no, $last_color_flg);
257        $objPdf->closePage();
258    }
259
260    // PDF¤Î½ÐÎÏ
261    $objPdf->output(); 
262}
263
264/* ¥»¥Ã¥·¥ç¥ó¤ËÆþÎÏ´ü´Ö¤òµ­Ï¿¤¹¤ë */
265function lfSaveDateSession() {
266    if($_POST['form'] == 1) {
267        $_SESSION['total']['startyear_m'] = $_POST['search_startyear_m'];
268        $_SESSION['total']['startmonth_m'] = $_POST['search_startmonth_m'];
269    }
270   
271    if($_POST['form'] == 2) {
272        $_SESSION['total']['startyear'] = $_POST['search_startyear'];
273        $_SESSION['total']['startmonth'] = $_POST['search_startmonth'];
274        $_SESSION['total']['startday'] = $_POST['search_startday'];
275        $_SESSION['total']['endyear'] = $_POST['search_endyear'];
276        $_SESSION['total']['endmonth'] = $_POST['search_endmonth'];
277        $_SESSION['total']['endday'] = $_POST['search_endday'];
278    }
279}
280
281/* ¥Ç¥Õ¥©¥ë¥ÈÃͤμèÆÀ */
282function lfGetDateDefault() {
283    $year = date("Y");
284    $month = date("m");
285    $day = date("d");
286   
287    $list = $_SESSION['total'];
288   
289    // ¥»¥Ã¥·¥ç¥ó¾ðÊó¤Ë³«»Ï·îÅÙ¤¬Êݸ¤µ¤ì¤Æ¤¤¤Ê¤¤¡£
290    if($_SESSION['total']['startyear_m'] == "") {
291        $list['startyear_m'] = $year;
292        $list['startmonth_m'] = $month;
293    }
294   
295    // ¥»¥Ã¥·¥ç¥ó¾ðÊó¤Ë³«»ÏÆüÉÕ¡¢½ªÎ»ÆüÉÕ¤¬Êݸ¤µ¤ì¤Æ¤¤¤Ê¤¤¡£
296    if($_SESSION['total']['startyear'] == "" && $_SESSION['total']['endyear'] == "") {
297        $list['startyear'] = $year;
298        $list['startmonth'] = $month;
299        $list['startday'] = $day;
300        $list['endyear'] = $year;
301        $list['endmonth'] = $month;
302        $list['endday'] = $day;
303    }
304   
305    return $list;   
306}
307
308/* ¥Ñ¥é¥á¡¼¥¿¾ðÊó¤Î½é´ü²½ */
309function lfInitParam() {
310    global $objFormParam;
311       
312    // ¥Ç¥Õ¥©¥ë¥ÈÃͤμèÆÀ
313    $arrList = lfGetDateDefault();
314   
315    // ·îÅÙ½¸·×
316    $objFormParam->addParam("·îÅÙ", "search_startyear_m", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"), $arrList['startyear_m']);
317    $objFormParam->addParam("·îÅÙ", "search_startmonth_m", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"), $arrList['startmonth_m']);
318    // ´ü´Ö½¸·×
319    $objFormParam->addParam("³«»ÏÆü", "search_startyear", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"), $arrList['startyear']);
320    $objFormParam->addParam("³«»ÏÆü", "search_startmonth", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"), $arrList['startmonth']);
321    $objFormParam->addParam("³«»ÏÆü", "search_startday", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"), $arrList['startday']);
322    $objFormParam->addParam("½ªÎ»Æü", "search_endyear", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"), $arrList['endyear']);
323    $objFormParam->addParam("½ªÎ»Æü", "search_endmonth", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"), $arrList['endmonth']);
324    $objFormParam->addParam("½ªÎ»Æü", "search_endday", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"), $arrList['endday']);
325   
326    // hidden¥Ç¡¼¥¿¤Î¼èÆÀÍÑ
327    $objFormParam->addParam("", "page");
328    $objFormParam->addParam("", "type");
329    $objFormParam->addParam("", "mode");
330
331}
332
333/* ÆþÎÏÆâÍÆ¤Î¥Á¥§¥Ã¥¯ */
334function lfCheckError() {
335    global $objFormParam;
336    // ÆþÎϥǡ¼¥¿¤òÅϤ¹¡£
337    $arrRet =  $objFormParam->getHashArray();
338    $objErr = new SC_CheckError($arrRet);
339    $objErr->arrErr = $objFormParam->checkError();
340   
341    // ÆÃ¼ì¹àÌÜ¥Á¥§¥Ã¥¯
342    if($_POST['form'] == 1) {
343        $objErr->doFunc(array("·îÅÙ", "search_startyear_m"), array("ONE_EXIST_CHECK"));
344    }
345   
346    if($_POST['form'] == 2) {
347        $objErr->doFunc(array("´ü´Ö", "search_startyear", "search_endyear"), array("ONE_EXIST_CHECK"));
348    }
349           
350    $objErr->doFunc(array("·îÅÙ", "search_startyear_m", "search_startmonth_m"), array("ALL_EXIST_CHECK"));
351    $objErr->doFunc(array("³«»ÏÆü", "search_startyear", "search_startmonth", "search_startday"), array("CHECK_DATE"));
352    $objErr->doFunc(array("½ªÎ»Æü", "search_endyear", "search_endmonth", "search_endday"), array("CHECK_DATE"));
353    $objErr->doFunc(array("³«»ÏÆü", "½ªÎ»Æü", "search_startyear", "search_startmonth", "search_startday", "search_endyear", "search_endmonth", "search_endday"), array("CHECK_SET_TERM"));
354    return $objErr->arrErr;
355}
356
357/* ÀÞ¤ìÀþ¥°¥é¥Õ¤ÎºîÀ® */
358function lfGetGraphLine($arrResults, $keyname, $type, $xtitle, $ytitle, $sdate, $edate) {
359   
360    $ret_path = "";
361   
362    // ·ë²Ì¤¬0¹Ô°Ê¾å¤¢¤ë¾ì¹ç¤Î¤ß¥°¥é¥Õ¤òÀ¸À®¤¹¤ë¡£
363    if(count($arrResults) > 0) {
364       
365        // ¥°¥é¥Õ¤ÎÀ¸À®
366        $arrList = sfArrKeyValue($arrResults, $keyname, "total");
367
368        // °ì»þ¥Õ¥¡¥¤¥ë̾¤Î¼èÆÀ
369        $pngname = lfGetGraphPng($type);
370       
371        $path = GRAPH_DIR . $pngname;
372       
373        // ¥é¥Ù¥ëɽ¼¨¥¤¥ó¥¿¡¼¥Ð¥ë¤òµá¤á¤ë
374        $interval = intval(count($arrList) / 20);
375        if($interval < 1) {
376            $interval = 1;
377        }
378        $objGraphPie = new SC_GraphPie();
379        $objGraphLine = new SC_GraphLine();
380       
381        // ÃͤΥ»¥Ã¥È
382        $objGraphLine->setData($arrList);
383        $objGraphLine->setXLabel(array_keys($arrList));
384       
385        // ¥é¥Ù¥ë²óž(ÆüËܸìÉÔ²Ä)
386        if($keyname == "key_day"){
387            $objGraphLine->setXLabelAngle(45);
388        }
389
390        // ¥¿¥¤¥È¥ë¥»¥Ã¥È
391        $objGraphLine->setXTitle($xtitle);
392        $objGraphLine->setYTitle($ytitle);
393       
394        // ¥á¥¤¥ó¥¿¥¤¥È¥ëºîÀ®
395        list($sy, $sm, $sd) = split("[/ ]" , $sdate);
396        list($ey, $em, $ed) = split("[/ ]" , $edate);
397        $start_date = $sy . "ǯ" . $sm . "·î" . $sd . "Æü";
398        $end_date = $ey . "ǯ" . $em . "·î" . $ed . "Æü";
399        $objGraphLine->drawTitle("½¸·×´ü´Ö¡§" . $start_date . " - " . $end_date);
400       
401        // ¥°¥é¥ÕÉÁ²è
402        $objGraphLine->drawGraph();
403        $objGraphLine->outputGraph(false, $path);
404
405        // ¥Õ¥¡¥¤¥ë¥Ñ¥¹¤òÊÖ¤¹
406        $ret_path = GRAPH_URL . $pngname;
407    }
408    return $ret_path;
409}
410
411// ±ß¥°¥é¥Õ¤ÎºîÀ®
412function lfGetGraphPie($arrResults, $keyname, $type, $title = "", $sdate = "", $edate = "") {
413   
414    $ret_path = "";
415   
416    // ·ë²Ì¤¬0¹Ô°Ê¾å¤¢¤ë¾ì¹ç¤Î¤ß¥°¥é¥Õ¤òÀ¸À®¤¹¤ë¡£
417    if(count($arrResults) > 0) {
418        // ¥°¥é¥Õ¤ÎÀ¸À®
419        $arrList = sfArrKeyValue($arrResults, $keyname, "total", GRAPH_PIE_MAX, GRAPH_LABEL_MAX);
420       
421        // °ì»þ¥Õ¥¡¥¤¥ë̾¤Î¼èÆÀ
422        $pngname = lfGetGraphPng($type);
423        $path = GRAPH_DIR . $pngname;
424       
425        $objGraphPie = new SC_GraphPie();
426       
427        /* ¥Ç¥Ð¥Ã¥°É½¼¨ÍÑ by naka
428        foreach($arrList as $key => $val) {
429            $objGraphPie->debugPrint("key:$key val:$val");
430        }
431        */
432       
433        // ¥Ç¡¼¥¿¤ò¥»¥Ã¥È¤¹¤ë
434        $objGraphPie->setData($arrList);
435        // ËÞÎã¤ò¥»¥Ã¥È¤¹¤ë
436        $objGraphPie->setLegend(array_keys($arrList));
437                               
438        // ¥á¥¤¥ó¥¿¥¤¥È¥ëºîÀ®
439        list($sy, $sm, $sd) = split("[/ ]" , $sdate);
440        list($ey, $em, $ed) = split("[/ ]" , $edate);
441        $start_date = $sy . "ǯ" . $sm . "·î" . $sd . "Æü";
442        $end_date = $ey . "ǯ" . $em . "·î" . $ed . "Æü";
443        $objGraphPie->drawTitle("½¸·×´ü´Ö¡§" . $start_date . " - " . $end_date);
444               
445        // ±ß¥°¥é¥ÕÉÁ²è
446        $objGraphPie->drawGraph();
447       
448        // ¥°¥é¥Õ¤Î½ÐÎÏ
449        $objGraphPie->outputGraph(false, $path);
450
451        // ¥Õ¥¡¥¤¥ë¥Ñ¥¹¤òÊÖ¤¹
452        $ret_path = GRAPH_URL . $pngname;
453    }
454    return $ret_path;
455}
456
457// ËÀ¥°¥é¥Õ¤ÎºîÀ®
458function lfGetGraphBar($arrResults, $keyname, $type, $xtitle, $ytitle, $sdate, $edate) {
459    $ret_path = "";
460   
461    // ·ë²Ì¤¬0¹Ô°Ê¾å¤¢¤ë¾ì¹ç¤Î¤ß¥°¥é¥Õ¤òÀ¸À®¤¹¤ë¡£
462    if(count($arrResults) > 0) {
463        // ¥°¥é¥Õ¤ÎÀ¸À®
464        $arrList = sfArrKeyValue($arrResults, $keyname, "total", GRAPH_PIE_MAX, GRAPH_LABEL_MAX);
465       
466        // °ì»þ¥Õ¥¡¥¤¥ë̾¤Î¼èÆÀ
467        $pngname = lfGetGraphPng($type);
468        $path = GRAPH_DIR . $pngname;
469       
470        $objGraphBar = new SC_GraphBar();
471       
472        foreach(array_keys($arrList) as $val) {
473            $arrKey[] = ereg_replace("¡Á", "-", $val);
474        }
475       
476        // ¥°¥é¥ÕÉÁ²è
477        $objGraphBar->setXLabel($arrKey);
478        $objGraphBar->setXTitle($xtitle);
479        $objGraphBar->setYTitle($ytitle);
480        $objGraphBar->setData($arrList);
481       
482        // ¥á¥¤¥ó¥¿¥¤¥È¥ëºîÀ®
483        $arrKey = array_keys($arrList);
484        list($sy, $sm, $sd) = split("[/ ]" , $sdate);
485        list($ey, $em, $ed) = split("[/ ]" , $edate);
486        $start_date = $sy . "ǯ" . $sm . "·î" . $sd . "Æü";
487        $end_date = $ey . "ǯ" . $em . "·î" . $ed . "Æü";
488        $objGraphBar->drawTitle("½¸·×´ü´Ö¡§" . $start_date . " - " . $end_date);
489       
490        $objGraphBar->drawGraph();
491       
492        if(DRAW_IMAGE){
493            $objGraphBar->outputGraph();
494            exit();
495        }else{
496            $objGraphBar->outputGraph(false,$path);
497        }
498       
499        // ¥Õ¥¡¥¤¥ë¥Ñ¥¹¤òÊÖ¤¹
500        $ret_path = GRAPH_URL . $pngname;
501    }
502    return $ret_path;
503}
504
505// ¥°¥é¥ÕÍѤÎPNG¥Õ¥¡¥¤¥ë̾
506function lfGetGraphPng($keyname) {
507    if($_POST['search_startyear_m'] != "") {
508        $pngname = sprintf("%s_%02d%02d.png", $keyname, substr($_POST['search_startyear_m'],2), $_POST['search_startmonth_m']);
509    } else {
510        $pngname = sprintf("%s_%02d%02d%02d_%02d%02d%02d.png", $keyname, substr($_POST['search_startyear'], 2), $_POST['search_startmonth'], $_POST['search_startday'], substr($_POST['search_endyear'],2), $_POST['search_endmonth'], $_POST['search_endday']);
511    }
512    return $pngname;
513}
514
515// ²ñ°÷¡¢Èó²ñ°÷½¸·×¤ÎWHEREʬ¤ÎºîÀ®
516function lfGetWhereMember($col_date, $sdate, $edate, $type, $col_member = "customer_id") {
517    // ¼èÆÀÆüÉդλØÄê
518    if($sdate != "") {
519        if ($where != "") {
520            $where.= " AND ";
521        }           
522        $where.= " $col_date >= '". $sdate ."'";
523    }
524       
525    if($edate != "") {
526        if ($where != "") {
527            $where.= " AND ";
528        }
529        $edate = date("Y/m/d",strtotime("1 day" ,strtotime($edate)));   
530        $where.= " $col_date < date('" . $edate ."')";
531    }
532   
533    // ²ñ°÷¡¢Èó²ñ°÷¤ÎȽÄê
534    switch($type) {
535    // Á´ÂÎ
536    case 'all':
537        break;
538    case 'member':
539        if ($where != "") {
540            $where.= " AND ";
541        }
542        $where.= " $col_member <> 0";
543        break;
544    case 'nonmember':
545        if ($where != "") {
546            $where.= " AND ";
547        }
548        $where.= " $col_member = 0";
549        break;
550    default:
551        break;
552    }
553   
554    return array($where, $arrval);
555}
556
557/** ²ñ°÷Ê̽¸·× **/
558function lfGetOrderMember($type, $sdate, $edate, $objPage, $graph = true) {
559    global $arrSex;
560       
561    list($where, $arrval) = lfGetWhereMember('create_date', $sdate, $edate, $type);
562   
563    // ²ñ°÷½¸·×¤Î¼èÆÀ
564    $col = "COUNT(*) AS order_count, SUM(total) AS total, (AVG(total)) AS total_average, order_sex";
565    $from = "dtb_order";
566    $objQuery = new SC_Query();
567    $objQuery->setGroupBy("order_sex");
568   
569    $tmp_where = $where . " AND customer_id <> 0 AND del_flg = 0 ";
570    $arrRet = $objQuery->select($col, $from, $tmp_where, $arrval);
571   
572    // ²ñ°÷¹ØÆþ¤Ç¤¢¤ë¤³¤È¤òµ­Ï¿¤¹¤ë¡£
573    $max = count($arrRet);
574    for($i = 0; $i < $max; $i++) {
575        $arrRet[$i]['member_name'] = '²ñ°÷'.$arrSex[$arrRet[$i]['order_sex']];
576    }
577    $objPage->arrResults = $arrRet;
578   
579    // Èó²ñ°÷½¸·×¤Î¼èÆÀ
580    $tmp_where = $where . " AND customer_id = 0 AND del_flg = 0 ";
581    $arrRet = $objQuery->select($col, $from, $tmp_where, $arrval);
582    // Èó²ñ°÷¹ØÆþ¤Ç¤¢¤ë¤³¤È¤òµ­Ï¿¤¹¤ë¡£
583    $max = count($arrRet);
584    for($i = 0; $i < $max; $i++) {
585        $arrRet[$i]['member_name'] = 'Èó²ñ°÷'.$arrSex[$arrRet[$i]['order_sex']];
586    }
587   
588    $objPage->arrResults = array_merge($objPage->arrResults, $arrRet);
589   
590    // ±ß¥°¥é¥Õ¤ÎÀ¸À®
591    if($graph) {   
592        $image_key = "member";
593        $objPage->tpl_image = lfGetGraphPie($objPage->arrResults, "member_name", $image_key, "(Çä¾åÈæÎ¨)", $sdate, $edate);
594    }
595   
596    return $objPage;
597}
598
599/** ¾¦ÉÊÊ̽¸·× **/
600function lfGetOrderProducts($type, $sdate, $edate, $objPage, $graph = true, $mode = "") {
601    list($where, $arrval) = lfGetWhereMember('create_date', $sdate, $edate, $type);
602   
603    $sql = "SELECT T1.product_id, T1.product_code, T2.name, T1.products_count, T1.order_count, T1.price, T1.total ";
604    $sql.= "FROM ( ";
605    $sql.= "SELECT product_id, product_code, price, ";
606    $sql.= "COUNT(*) AS order_count, ";
607    $sql.= "SUM(quantity) AS products_count, ";
608    $sql.= "(price * sum(quantity)) AS total ";
609    $sql.= "FROM dtb_order_detail WHERE order_id IN (SELECT order_id FROM dtb_order WHERE $where ) ";
610    $sql.= "GROUP BY product_id, product_code, price ";
611    $sql.= ") ";
612    $sql.= "AS T1 LEFT JOIN dtb_products AS T2 USING (product_id) WHERE T2.name IS NOT NULL AND status = 1 ORDER BY T1.total DESC ";
613   
614    if($mode != "csv") {
615        $sql.= "LIMIT " . PRODUCTS_TOTAL_MAX;
616    }
617   
618    $objQuery = new SC_Query();
619    $objPage->arrResults = $objQuery->getall($sql, $arrval);
620   
621    // ±ß¥°¥é¥Õ¤ÎÀ¸À®
622    if($graph) {
623        $image_key = "products_" . $type;
624        $objPage->tpl_image = lfGetGraphPie($objPage->arrResults, "name", $image_key, "(Çä¾åÈæÎ¨)", $sdate, $edate);
625    }
626   
627    return $objPage;
628}
629
630/** ¿¦¶ÈÊ̽¸·× **/
631function lfGetOrderJob($type, $sdate, $edate, $objPage, $graph = true) {
632    global $arrJob;
633       
634    list($where, $arrval) = lfGetWhereMember('T2.create_date', $sdate, $edate, $type);
635   
636    $sql = "SELECT job, count(*) AS order_count, SUM(total) AS total, (AVG(total)) AS total_average ";
637    $sql.= "FROM dtb_customer AS T1 LEFT JOIN dtb_order AS T2 USING ( customer_id ) WHERE $where AND T2.del_flg = 0 ";
638    $sql.= "GROUP BY job ORDER BY total DESC";
639   
640    $objQuery = new SC_Query();
641    $objPage->arrResults = $objQuery->getall($sql, $arrval);
642           
643    $max = count($objPage->arrResults);
644    for($i = 0; $i < $max; $i++) {
645        $job_key = $objPage->arrResults[$i]['job'];
646        if($job_key != "") {
647            $objPage->arrResults[$i]['job_name'] = $arrJob[$job_key];
648        } else {
649            $objPage->arrResults[$i]['job_name'] = "̤²óÅú";
650        }
651    }
652   
653    // ±ß¥°¥é¥Õ¤ÎÀ¸À®   
654    if($graph) {
655        $image_key = "job_" . $type;
656        $objPage->tpl_image = lfGetGraphPie($objPage->arrResults, "job_name", $image_key, "(Çä¾åÈæÎ¨)", $sdate, $edate);
657    }
658   
659    return $objPage;
660}
661
662/** ǯÂåÊ̽¸·× **/
663function lfGetOrderAge($type, $sdate, $edate, $objPage, $graph = true) {
664
665    list($where, $arrval) = lfGetWhereMember('order_date', $sdate, $edate, $type, "member");
666   
667    $sql = "SELECT SUM(order_count) AS order_count, SUM(total) AS total, start_age, end_age ";
668    $sql.= "FROM dtb_bat_order_daily_age WHERE $where ";
669    $sql.= "GROUP BY start_age, end_age ORDER BY start_age, end_age";
670
671    $objQuery = new SC_Query();
672    $objPage->arrResults = $objQuery->getall($sql, $arrval);
673   
674    $max = count($objPage->arrResults);
675    for($i = 0; $i < $max; $i++) {
676        if($objPage->arrResults[$i]['order_count'] > 0) {
677            $objPage->arrResults[$i]['total_average'] = intval($objPage->arrResults[$i]['total'] / $objPage->arrResults[$i]['order_count']);
678        }   
679        $start_age = $objPage->arrResults[$i]['start_age'];
680        $end_age = $objPage->arrResults[$i]['end_age'];
681        if($start_age != "" || $end_age != "") {
682            if($end_age != 999) {
683                $objPage->arrResults[$i]['age_name'] = $start_age . "¡Á" . $end_age . "ºÐ";
684            } else {
685                $objPage->arrResults[$i]['age_name'] = $start_age . "ºÐ¡Á";
686            }
687        } else {
688            $objPage->arrResults[$i]['age_name'] = "̤²óÅú";
689        }
690    }
691   
692    // ËÀ¥°¥é¥Õ¤ÎÀ¸À®
693    if($graph) {
694        $image_key = "age_" . $type;
695        $xtitle = "(ǯÎð)";
696        $ytitle = "(Çä¾å¹ç·×)";
697        $objPage->tpl_image = lfGetGraphBar($objPage->arrResults, "age_name", $image_key, $xtitle, $ytitle, $sdate, $edate);
698    }
699   
700    return $objPage;
701}
702
703/** ´ü´ÖÊ̽¸·× **/
704function lfGetOrderTerm($type, $sdate, $edate, $objPage, $graph = true) {
705       
706        $tmp_col = "sum(total_order) as total_order, sum(men) as men, sum(women) as women,";
707        $tmp_col.= "sum(men_member) as men_member, sum(men_nonmember) as men_nonmember,";
708        $tmp_col.= "sum(women_member) as women_member, sum(women_nonmember) as women_nonmember,";
709        $tmp_col.= "sum(total) as total, (avg(total_average)) as total_average";
710        $objQuery = new SC_Query();
711       
712        switch($type) {
713        // ·îÊÌ
714        case 'month':
715            $col = $tmp_col . ",key_month";
716            $objQuery->setgroupby("key_month");
717            $objQuery->setOrder("key_month");
718            $objPage->keyname = "key_month";
719            $objPage->tpl_tail = "·î";
720            $from = "dtb_bat_order_daily";
721            $xtitle = "(·îÊÌ)";
722            $ytitle = "(Çä¾å¹ç·×)";
723            break;
724        // ǯÊÌ
725        case 'year':
726            $col = $tmp_col . ",key_year";
727            $objQuery->setgroupby("key_year");
728            $objQuery->setOrder("key_year");
729            $objPage->keyname = "key_year";
730            $objPage->tpl_tail = "ǯ";
731            $from = "dtb_bat_order_daily";
732            $xtitle = "(ǯÊÌ)";
733            $ytitle = "(Çä¾å¹ç·×)";
734            break;
735        // ÍËÆüÊÌ
736        case 'wday':
737            $col = $tmp_col . ",key_wday, wday";
738            $objQuery->setgroupby("key_wday, wday");
739            $objQuery->setOrder("wday");
740            $objPage->keyname = "key_wday";
741            $objPage->tpl_tail = "ÍËÆü";
742            $from = "dtb_bat_order_daily";
743            $xtitle = "(ÍËÆüÊÌ)";
744            $ytitle = "(Çä¾å¹ç·×)";
745            break;
746        // »þ´ÖÊÌ
747        case 'hour':
748            $col = $tmp_col . ",hour";
749            $objQuery->setgroupby("hour");
750            $objQuery->setOrder("hour");
751            $objPage->keyname = "hour";
752            $objPage->tpl_tail = "»þ";
753            $from = "dtb_bat_order_daily_hour";
754            $xtitle = "(»þ´ÖÊÌ)";
755            $ytitle = "(Çä¾å¹ç·×)";
756            break;
757        default:
758            $col = "*";
759            $objQuery->setOrder("key_day");
760            $objPage->keyname = "key_day";
761            $from = "dtb_bat_order_daily";
762            $xtitle = "(ÆüÊÌ)";
763            $ytitle = "(Çä¾å¹ç·×)";
764            break;
765        }
766       
767
768    // ¼èÆÀÆüÉդλØÄê
769        if($sdate != "") {
770            if ($where != "") {
771                $where.= " AND ";
772            }           
773            $where.= " order_date >= '". $sdate ."'";
774        }
775       
776        if($edate != "") {
777            if ($where != "") {
778                $where.= " AND ";
779            }
780            $edate_next = date("Y/m/d",strtotime("1 day" ,strtotime($edate)));
781            $where.= " order_date < date('" . $edate_next ."')";
782        }
783       
784        // ¸¡º÷·ë²Ì¤Î¼èÆÀ
785        $objPage->arrResults = $objQuery->select($col, $from, $where, $arrval);
786       
787        // ÀÞ¤ìÀþ¥°¥é¥Õ¤ÎÀ¸À®   
788        if($graph) {
789            $image_key = "term_" . $type;
790            $objPage->tpl_image = lfGetGraphLine($objPage->arrResults, $objPage->keyname, $image_key, $xtitle, $ytitle, $sdate, $edate);
791        }
792       
793        // ¸¡º÷·ë²Ì¤¬0¤Ç¤Ê¤¤¾ì¹ç
794        if(count($objPage->arrResults) > 0) {
795            // ºÇ½ª½¸·×¹Ô¼èÆÀ¤¹¤ë
796            $col = $tmp_col;
797            $objQuery = new SC_Query();
798            $arrRet = $objQuery->select($col, $from, $where, $arrval);
799            $arrRet[0][$objPage->keyname] = "¹ç·×";
800            $objPage->arrResults[] = $arrRet[0];
801        }
802
803        // Ê¿¶ÑÃͤη׻»
804        $max = count($objPage->arrResults);
805        for($i = 0; $i < $max; $i++) {
806            if($objPage->arrResults[$i]['total_order'] > 0) {
807                $objPage->arrResults[$i]['total_average'] = intval($objPage->arrResults[$i]['total'] / $objPage->arrResults[$i]['total_order']);
808            }
809        }
810       
811        return $objPage;
812}
813
814?>
Note: See TracBrowser for help on using the repository browser.