source: branches/beta/html/admin/total/index.php @ 14676

Revision 14676, 24.1 KB checked in by adati, 17 years ago (diff)

1.4.0a-betaのマージ

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