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

Revision 4979, 23.2 KB checked in by kakinaka, 20 years ago (diff)

blank

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