source: branches/version-2_12-multilang/data/class/pages/admin/total/LC_Page_Admin_Total.php @ 22096

Revision 22096, 34.8 KB checked in by h_yoshimoto, 10 years ago (diff)

#1955 r22089r22095 間のコミットをmerge

  • Property svn:eol-style set to LF
  • Property svn:keywords set to Id
  • Property svn:mime-type set to text/x-httpd-php; charset=UTF-8
Line 
1<?php
2/*
3 * This file is part of EC-CUBE
4 *
5 * Copyright(c) 2000-2012 LOCKON CO.,LTD. All Rights Reserved.
6 *
7 * http://www.lockon.co.jp/
8 *
9 * This program is free software; you can redistribute it and/or
10 * modify it under the terms of the GNU General Public License
11 * as published by the Free Software Foundation; either version 2
12 * of the License, or (at your option) any later version.
13 *
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17 * GNU General Public License for more details.
18 *
19 * You should have received a copy of the GNU General Public License
20 * along with this program; if not, write to the Free Software
21 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
22 */
23// {{{ requires
24require_once CLASS_EX_REALDIR . 'page_extends/admin/LC_Page_Admin_Ex.php';
25
26/**
27 * 売上集計 のページクラス.
28 *
29 * @package Page
30 * @author LOCKON CO.,LTD.
31 * @version $Id$
32 */
33class LC_Page_Admin_Total extends LC_Page_Admin_Ex {
34
35    // }}}
36    // {{{ functions
37
38    /**
39     * Page を初期化する.
40     *
41     * @return void
42     */
43    function init() {
44        parent::init();
45        // GDライブラリのインストール判定
46        $this->install_GD = function_exists('gd_info') ? true : false;
47        $this->tpl_mainpage         = 'total/index.tpl';
48        $this->tpl_graphsubtitle    = 'total/subtitle.tpl';
49        $this->tpl_titleimage       = ROOT_URLPATH.'img/title/title_sale.jpg';
50        $this->tpl_maintitle = $this->tpl_maintitle = SC_I18n_Ex::t('TPL_MAINTITLE_010');
51        $this->tpl_mainno           = 'total';
52
53        $masterData                 = new SC_DB_MasterData_Ex();
54        $this->arrWDAY              = $masterData->getMasterData('mtb_wday');
55        $this->arrSex               = $masterData->getMasterData('mtb_sex');
56        $this->arrJob               = $masterData->getMasterData('mtb_job');
57
58        // 登録・更新日検索用
59        $objDate                    = new SC_Date_Ex();
60        $objDate->setStartYear(RELEASE_YEAR);
61        $objDate->setEndYear(DATE('Y'));
62        $this->arrYear              = $objDate->getYear();
63        $this->arrMonth             = $objDate->getMonth();
64        $this->arrDay               = $objDate->getDay();
65
66        // ページタイトル todo あとでなおす
67        $this->arrTitle['']         = SC_I18n_Ex::t('LC_Page_Admin_Total_001');
68        $this->arrTitle['term']     = SC_I18n_Ex::t('LC_Page_Admin_Total_002');
69        $this->arrTitle['products'] = SC_I18n_Ex::t('LC_Page_Admin_Total_003');
70        $this->arrTitle['age']      = SC_I18n_Ex::t('LC_Page_Admin_Total_004');
71        $this->arrTitle['job']      = SC_I18n_Ex::t('LC_Page_Admin_Total_005');
72        $this->arrTitle['member']   = SC_I18n_Ex::t('LC_Page_Admin_Total_006');
73
74        // 月度集計のkey名
75        $this->arrSearchForm1       = array('search_startyear_m', 'search_startmonth_m');
76
77        // 期間別集計のkey名
78        $this->arrSearchForm2 = array(
79            'search_startyear',
80            'search_startmonth',
81            'search_startday',
82            'search_endyear',
83            'search_endmonth',
84            'search_endday',
85        );
86    }
87
88    /**
89     * Page のプロセス.
90     *
91     * @return void
92     */
93    function process() {
94        $this->action();
95        $this->sendResponse();
96    }
97
98    /**
99     * Page のアクション.
100     *
101     * @return void
102     */
103    function action() {
104
105        if (isset($_GET['draw_image']) && $_GET['draw_image'] != '') {
106            define('DRAW_IMAGE' , true);
107        } else {
108            define('DRAW_IMAGE' , false);
109        }
110
111        // パラメーター管理クラス
112        $objFormParam = new SC_FormParam_Ex();
113        // パラメーター情報の初期化
114        $this->lfInitParam($objFormParam);
115        $objFormParam->setParam($_POST);
116        $objFormParam->setParam($_GET);
117
118        // 検索ワードの引き継ぎ
119        $this->arrHidden = $objFormParam->getSearchArray();
120
121        switch ($this->getMode()) {
122            case 'csv':
123            case 'search':
124
125                $this->arrErr = $this->lfCheckError($objFormParam);
126                if (empty($this->arrErr)) {
127
128                    // 日付
129                    list($sdate, $edate) = $this->lfSetStartEndDate($objFormParam);
130
131                    // ページ
132                    $page = ($objFormParam->getValue('page')) ? $objFormParam->getValue('page') : 'term';
133
134                    // 集計種類
135                    $type = ($objFormParam->getValue('type')) ? $objFormParam->getValue('type'): 'all';
136
137                    $this->tpl_page_type = 'total/page_'. $page .'.tpl';
138                    list($this->arrResults, $this->tpl_image) = call_user_func_array(array($this, 'lfGetOrder'.$page),
139                                                                                     array($type, $sdate, $edate));
140                    if ($this->getMode() == 'csv') {
141                        // CSV出力タイトル行の取得
142                        list($arrTitleCol, $arrDataCol) = $this->lfGetCSVColum($page);
143                        $head = SC_Utils_Ex::sfGetCSVList($arrTitleCol);
144                        $data = $this->lfGetDataColCSV($this->arrResults, $arrDataCol);
145
146                        // CSVを送信する。
147                        list($fime_name, $data) = SC_Utils_Ex::sfGetCSVData($head.$data);
148
149                        $this->sendResponseCSV($fime_name, $data);
150                        SC_Response_Ex::actionExit();
151                    }
152                }
153                break;
154            default:
155                break;
156        }
157
158        // 画面宣しても日付が保存される
159        $_SESSION           = $this->lfSaveDateSession($_SESSION, $this->arrHidden);
160        $objFormParam->setParam($_SESSION['total']);
161        // 入力値の取得
162        $this->arrForm      = $objFormParam->getFormParamList();
163        $this->tpl_subtitle = $this->arrTitle[$objFormParam->getValue('page')];
164
165    }
166
167    /**
168     * デストラクタ.
169     *
170     * @return void
171     */
172    function destroy() {
173        parent::destroy();
174    }
175
176    /* デフォルト値の取得 */
177    function lfGetDateDefault() {
178        $year = date('Y');
179        $month = date('m');
180        $day = date('d');
181
182        $list = isset($_SESSION['total']) ? $_SESSION['total'] : '';
183
184        // セッション情報に開始月度が保存されていない。
185        if (empty($_SESSION['total']['startyear_m'])) {
186            $list['startyear_m'] = $year;
187            $list['startmonth_m'] = $month;
188        }
189
190        // セッション情報に開始日付、終了日付が保存されていない。
191        if (empty($_SESSION['total']['startyear']) && empty($_SESSION['total']['endyear'])) {
192            $list['startyear'] = $year;
193            $list['startmonth'] = $month;
194            $list['startday'] = $day;
195            $list['endyear'] = $year;
196            $list['endmonth'] = $month;
197            $list['endday'] = $day;
198        }
199
200        return $list;
201    }
202
203    /* パラメーター情報の初期化 */
204    function lfInitParam(&$objFormParam) {
205        // デフォルト値の取得
206        $arrList = $this->lfGetDateDefault();
207
208        // 月度集計
209        $objFormParam->addParam(SC_I18n_Ex::t('PARAM_LABEL_MONTHLY'), 'search_startyear_m', INT_LEN, 'n', array('MAX_LENGTH_CHECK', 'NUM_CHECK'), $arrList['startyear_m']);
210        $objFormParam->addParam(SC_I18n_Ex::t('PARAM_LABEL_MONTHLY'), 'search_startmonth_m', INT_LEN, 'n', array('MAX_LENGTH_CHECK', 'NUM_CHECK'), $arrList['startmonth_m']);
211        // 期間集計
212        $objFormParam->addParam(SC_I18n_Ex::t('PARAM_LABEL_START_DAY'), 'search_startyear', INT_LEN, 'n', array('MAX_LENGTH_CHECK', 'NUM_CHECK'), $arrList['startyear']);
213        $objFormParam->addParam(SC_I18n_Ex::t('PARAM_LABEL_START_DAY'), 'search_startmonth', INT_LEN, 'n', array('MAX_LENGTH_CHECK', 'NUM_CHECK'), $arrList['startmonth']);
214        $objFormParam->addParam(SC_I18n_Ex::t('PARAM_LABEL_START_DAY'), 'search_startday', INT_LEN, 'n', array('MAX_LENGTH_CHECK', 'NUM_CHECK'), $arrList['startday']);
215        $objFormParam->addParam(SC_I18n_Ex::t('PARAM_LABEL_END_DAY'), 'search_endyear', INT_LEN, 'n', array('MAX_LENGTH_CHECK', 'NUM_CHECK'), $arrList['endyear']);
216        $objFormParam->addParam(SC_I18n_Ex::t('PARAM_LABEL_END_DAY'), 'search_endmonth', INT_LEN, 'n', array('MAX_LENGTH_CHECK', 'NUM_CHECK'), $arrList['endmonth']);
217        $objFormParam->addParam(SC_I18n_Ex::t('PARAM_LABEL_END_DAY'), 'search_endday', INT_LEN, 'n', array('MAX_LENGTH_CHECK', 'NUM_CHECK'), $arrList['endday']);
218
219        // hiddenデータの取得用
220        $objFormParam->addParam('', 'page');
221        $objFormParam->addParam('', 'type');
222        $objFormParam->addParam('', 'mode');
223        $objFormParam->addParam('', 'form');
224    }
225
226    /* 入力内容のチェック */
227    function lfCheckError(&$objFormParam) {
228
229        $objFormParam->convParam();
230        $objErr         = new SC_CheckError_Ex();
231        $objErr->arrErr = $objFormParam->checkError();
232
233        // 特殊項目チェック
234        if ($objFormParam->getValue('form') == 1) {
235            $objErr->doFunc(array(SC_I18n_Ex::t('PARAM_LABEL_MONTHLY'), 'search_startyear_m'), array('ONE_EXIST_CHECK'));
236        }
237
238        if ($objFormParam->getValue('form') == 2) {
239            $objErr->doFunc(array(SC_I18n_Ex::t('PARAM_LABEL_PERIOD'), 'search_startyear', 'search_startmonth', 'search_startday', 'search_endyear', 'search_endmonth', 'search_endday'), array('FULL_EXIST_CHECK'));
240        }
241        $objErr->doFunc(array(SC_I18n_Ex::t('PARAM_LABEL_MONTHLY'), 'search_startyear_m', 'search_startmonth_m'), array('ALL_EXIST_CHECK'));
242        $objErr->doFunc(array(SC_I18n_Ex::t('PARAM_LABEL_START_DAY'), 'search_startyear', 'search_startmonth', 'search_startday'), array('CHECK_DATE'));
243        $objErr->doFunc(array(SC_I18n_Ex::t('PARAM_LABEL_END_DAY'), 'search_endyear', 'search_endmonth', 'search_endday'), array('CHECK_DATE'));
244        $objErr->doFunc(array(SC_I18n_Ex::t('PARAM_LABEL_START_DAY'), SC_I18n_Ex::t('PARAM_LABEL_END_DAY'), 'search_startyear', 'search_startmonth', 'search_startday', 'search_endyear', 'search_endmonth', 'search_endday'), array('CHECK_SET_TERM'));
245        return $objErr->arrErr;
246    }
247
248    /* サブナビを移動しても日付が残るようにセッションに入力期間を記録する */
249    function lfSaveDateSession($session, $arrForm) {
250
251        // session の初期化をする
252        if (!isset($session['total'])) {
253            $session['total'] = $this->lfGetDateInit();
254        }
255
256        if (!empty($arrForm)) {
257            $session['total'] = array_merge($session['total'], $arrForm);
258        }
259
260        return $session;
261    }
262
263    /* 日付の初期値 */
264    function lfGetDateInit() {
265        $search_startyear_m     = $search_startyear  = $search_endyear  = date('Y');
266        $search_startmonth_m    = $search_startmonth = $search_endmonth = date('m');
267        $search_startday        = $search_endday     = date('d');
268
269        return compact($this->arrSearchForm1, $this->arrSearchForm2);
270    }
271
272    /* フォームで入力された日付を適切な形にする */
273    function lfSetStartEndDate(&$objFormParam) {
274
275        $arrRet = $objFormParam->getHashArray();
276        $out_flg = 0;
277
278        foreach ($arrRet as $key => $val) {
279            if ($val == '') {
280                continue;
281            }
282            switch ($key) {
283                case 'search_startyear':
284                    $sdate = $objFormParam->getValue('search_startyear') . '/' . $objFormParam->getValue('search_startmonth') . '/' . $objFormParam->getValue('search_startday');
285                    break;
286                case 'search_endyear':
287                    $edate = $objFormParam->getValue('search_endyear') . '/' . $objFormParam->getValue('search_endmonth') . '/' . $objFormParam->getValue('search_endday');
288                    break;
289                case 'search_startyear_m':
290                    list($sdate, $edate) = SC_Utils_Ex::sfTermMonth($objFormParam->getValue('search_startyear_m'),
291                                                                    $objFormParam->getValue('search_startmonth_m'),
292                                                                    CLOSE_DAY);
293                    $out_flg = 1;
294                    break;
295                default:
296                    break;
297            }
298            // 月度集計の場合に、集計期間が本日日付で上書きされてしまうのを回避するため
299            if (($objFormParam->getValue('form') == 1) && ($out_flg == 1)) {
300                break;
301            }
302        }
303
304        return array($sdate, $edate);
305    }
306
307    /* 折れ線グラフの作成 */
308    function lfGetGraphLine($arrResults, $keyname, $type, $xtitle, $ytitle, $sdate, $edate, $xincline) {
309
310        $ret_path = '';
311
312        // 結果が0行以上ある場合のみグラフを生成する。
313        if (count($arrResults) > 0 && $this->install_GD) {
314
315            // グラフの生成
316            $arrList = SC_Utils_Ex::sfArrKeyValue($arrResults, $keyname, 'total');
317
318            // 一時ファイル名の取得
319            $pngname = $this->lfGetGraphPng($type);
320
321            $path = GRAPH_REALDIR . $pngname;
322
323            // ラベル表示インターバルを求める
324            $interval = intval(count($arrList) / 20);
325            if ($interval < 1) {
326                $interval = 1;
327            }
328            $objGraphLine = new SC_Graph_Line();
329
330            // 値のセット
331            $objGraphLine->setData($arrList);
332            $objGraphLine->setXLabel(array_keys($arrList));
333
334            // ラベル回転(日本語不可)
335            if ($xincline == true) {
336                $objGraphLine->setXLabelAngle(45);
337            }
338
339            // タイトルセット
340            $objGraphLine->setXTitle($xtitle);
341            $objGraphLine->setYTitle($ytitle);
342
343            // メインタイトル作成
344            list($sy, $sm, $sd) = preg_split('|[/ ]|' , $sdate);
345            list($ey, $em, $ed) = preg_split('|[/ ]|' , $edate);
346            $start_date = SC_I18n_Ex::t('LC_Page_Admin_Total_007', array('T_FIELD1' => $sy, 'T_FIELD2' => $sm, 'T_FIELD3' => $sd));
347            $end_date = SC_I18n_Ex::t('LC_Page_Admin_Total_007', array('T_FIELD1' => $ey, 'T_FIELD2' => $em, 'T_FIELD3' => $ed));
348            $objGraphLine->drawTitle(SC_I18n_Ex::t('LC_Page_Admin_Total_008', array('T_FIELD1' => $start_date, 'T_FIELD2' => $end_date)));
349
350            // グラフ描画
351            $objGraphLine->drawGraph();
352
353            // グラフの出力
354            if (DRAW_IMAGE) {
355                $objGraphLine->outputGraph();
356                SC_Response_Ex::actionExit();
357            }
358
359            // ファイルパスを返す
360            $ret_path = GRAPH_URLPATH . $pngname;
361        }
362        return $ret_path;
363    }
364
365    // 円グラフの作成
366    function lfGetGraphPie($arrResults, $keyname, $type, $title = '', $sdate = '', $edate = '') {
367
368        $ret_path = '';
369        // 結果が0行以上ある場合のみグラフを生成する。
370        if (count($arrResults) > 0 && $this->install_GD) {
371            // グラフの生成
372            $arrList = SC_Utils_Ex::sfArrKeyValue($arrResults, $keyname,
373                                                  'total', GRAPH_PIE_MAX,
374                                                  GRAPH_LABEL_MAX);
375
376            // 一時ファイル名の取得
377            $pngname = $this->lfGetGraphPng($type);
378            $path = GRAPH_REALDIR . $pngname;
379
380            $objGraphPie = new SC_Graph_Pie();
381
382            // データをセットする
383            $objGraphPie->setData($arrList);
384            // 凡例をセットする
385            $objGraphPie->setLegend(array_keys($arrList));
386
387            // メインタイトル作成
388            list($sy, $sm, $sd) = preg_split('|[/ ]|' , $sdate);
389            list($ey, $em, $ed) = preg_split('|[/ ]|' , $edate);
390            $start_date = SC_I18n_Ex::t('LC_Page_Admin_Total_007', array('T_FIELD1' => $sy, 'T_FIELD2' => $sm, 'T_FIELD3' => $sd));
391            $end_date = SC_I18n_Ex::t('LC_Page_Admin_Total_007', array('T_FIELD1' => $ey, 'T_FIELD2' => $em, 'T_FIELD3' => $ed));
392           
393            $objGraphPie->drawTitle(SC_I18n_Ex::t('LC_Page_Admin_Total_008', array('T_FIELD1' => $start_date, 'T_FIELD2' => $end_date)));
394
395            // 円グラフ描画
396            $objGraphPie->drawGraph();
397
398            // グラフの出力
399            if (DRAW_IMAGE) {
400                $objGraphPie->outputGraph();
401                SC_Response_Ex::actionExit();
402            }
403
404            // ファイルパスを返す
405            $ret_path = GRAPH_URLPATH . $pngname;
406        }
407        return $ret_path;
408    }
409
410    // 棒グラフの作成
411    function lfGetGraphBar($arrResults, $keyname, $type, $xtitle, $ytitle, $sdate, $edate) {
412        $ret_path = '';
413
414        // 結果が0行以上ある場合のみグラフを生成する。
415        if (count($arrResults) > 0 && $this->install_GD) {
416            // グラフの生成
417            $arrList = SC_Utils_Ex::sfArrKeyValue($arrResults, $keyname, 'total', GRAPH_PIE_MAX, GRAPH_LABEL_MAX);
418
419            // 一時ファイル名の取得
420            $pngname = $this->lfGetGraphPng($type);
421            $path = GRAPH_REALDIR . $pngname;
422
423            $objGraphBar = new SC_Graph_Bar();
424
425            foreach ($arrList as $key => $value) {
426                $arrKey[] = mb_ereg_replace('~', '-', $key);
427            }
428
429            // グラフ描画
430            $objGraphBar->setXLabel($arrKey);
431            $objGraphBar->setXTitle($xtitle);
432            $objGraphBar->setYTitle($ytitle);
433            $objGraphBar->setData($arrList);
434
435            // メインタイトル作成
436            $arrKey = array_keys($arrList);
437            list($sy, $sm, $sd) = preg_split('|[/ ]|' , $sdate);
438            list($ey, $em, $ed) = preg_split('|[/ ]|' , $edate);
439            $start_date = SC_I18n_Ex::t('LC_Page_Admin_Total_007', array('T_FIELD1' => $sy, 'T_FIELD2' => $sm, 'T_FIELD3' => $sd));
440            $end_date = SC_I18n_Ex::t('LC_Page_Admin_Total_007', array('T_FIELD1' => $ey, 'T_FIELD2' => $em, 'T_FIELD3' => $ed));
441            $objGraphBar->drawTitle(SC_I18n_Ex::t('LC_Page_Admin_Total_008', array('T_FIELD1' => $start_date, 'T_FIELD2' => $end_date)));
442
443            $objGraphBar->drawGraph();
444
445            if (DRAW_IMAGE) {
446                $objGraphBar->outputGraph();
447                SC_Response_Ex::actionExit();
448            }
449
450            // ファイルパスを返す
451            $ret_path = GRAPH_URLPATH . $pngname;
452        }
453        return $ret_path;
454    }
455
456    // グラフ用のPNGファイル名
457    function lfGetGraphPng($keyname) {
458
459        if ($_POST['search_startyear_m'] != '') {
460            $pngname = sprintf('%s_%02d%02d.png', $keyname, substr($_POST['search_startyear_m'],2), $_POST['search_startmonth_m']);
461        } else {
462            $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']);
463        }
464        return $pngname;
465    }
466
467    // 会員、非会員集計のWHERE分の作成
468    function lfGetWhereMember($col_date, $sdate, $edate, $type, $col_member = 'customer_id') {
469        $where = '';
470        // 取得日付の指定
471        if ($sdate != '') {
472            if ($where != '') {
473                $where.= ' AND ';
474            }
475            $where.= " $col_date >= '". $sdate ."'";
476        }
477
478        if ($edate != '') {
479            if ($where != '') {
480                $where.= ' AND ';
481            }
482            $edate = date('Y/m/d',strtotime('1 day' ,strtotime($edate)));
483            $where.= " $col_date < date('" . $edate ."')";
484        }
485
486        // 会員、非会員の判定
487        switch ($type) {
488            // 全体
489            case 'all':
490                break;
491            case 'member':
492                if ($where != '') {
493                    $where.= ' AND ';
494                }
495                $where.= " $col_member <> 0";
496                break;
497            case 'nonmember':
498                if ($where != '') {
499                    $where.= ' AND ';
500                }
501                $where.= " $col_member = 0";
502                break;
503            default:
504                break;
505        }
506
507        return array($where, array());
508    }
509
510    /** 会員別集計 **/
511    function lfGetOrderMember($type, $sdate, $edate) {
512        $objQuery = SC_Query_Ex::getSingletonInstance();
513
514        list($where, $arrWhereVal) = $this->lfGetWhereMember('create_date', $sdate, $edate, $type);
515        $where .= ' AND del_flg = 0 AND status <> ?';
516        $arrWhereVal[] = ORDER_CANCEL;
517
518        // 会員集計の取得
519        $col = <<< __EOS__
520            COUNT(order_id) AS order_count,
521            SUM(total) AS total,
522            AVG(total) AS total_average,
523            CASE
524                WHEN customer_id <> 0 THEN 1
525                ELSE 0
526            END AS member,
527            order_sex
528__EOS__;
529
530        $from       = 'dtb_order';
531
532        $objQuery->setGroupBy('member, order_sex');
533
534        $arrTotalResults = $objQuery->select($col, $from, $where, $arrWhereVal);
535
536        foreach ($arrTotalResults as $key => $value) {
537            $arrResult =& $arrTotalResults[$key];
538            $member_key = $arrResult['order_sex'];
539            if ($member_key != '') {
540                $arrResult['member_name'] = (($arrResult['member']) ? SC_I18n_Ex::t('LC_Page_Admin_Total_009') : SC_I18n_Ex::t('LC_Page_Admin_Total_010')) . $this->arrSex[$member_key];
541            } else {
542                $arrResult['member_name'] = SC_I18n_Ex::t('LC_Page_Admin_Total_011');
543            }
544        }
545
546        $tpl_image = $this->lfGetGraphPie($arrTotalResults, 'member_name', 'member', SC_I18n_Ex::t('LC_Page_Admin_Total_039'), $sdate, $edate);
547
548        return array($arrTotalResults, $tpl_image);
549    }
550
551    /** 商品別集計 **/
552    function lfGetOrderProducts($type, $sdate, $edate) {
553        $objQuery = SC_Query_Ex::getSingletonInstance();
554
555        list($where, $arrWhereVal) = $this->lfGetWhereMember('create_date', $sdate, $edate, $type);
556
557        $where .= ' AND dtb_order.del_flg = 0 AND dtb_order.status <> ?';
558        $arrWhereVal[] = ORDER_CANCEL;
559
560        $col = <<< __EOS__
561                product_id,
562                product_code,
563                product_name,
564                SUM(quantity) AS products_count,
565                COUNT(dtb_order_detail.order_id) AS order_count,
566                price,
567                (price * SUM(quantity)) AS total
568__EOS__;
569
570        $from = 'dtb_order_detail JOIN dtb_order ON dtb_order_detail.order_id = dtb_order.order_id';
571
572        /*
573        if ($mode != 'csv') {
574            $sql.= 'LIMIT ' . PRODUCTS_TOTAL_MAX;
575        }*/
576
577        // 要index
578        $objQuery->setGroupBy('product_id, product_name, product_code, price');
579        //$objQuery->setGroupBy('product_id');
580        $objQuery->setOrder('total DESC');
581        $arrTotalResults = $objQuery->select($col, $from, $where, $arrWhereVal);
582
583        $tpl_image  = $this->lfGetGraphPie($arrTotalResults, 'product_name', 'products_' . $type, SC_I18n_Ex::t('LC_Page_Admin_Total_039'), $sdate, $edate);
584
585        return array($arrTotalResults, $tpl_image);
586    }
587
588    /** 職業別集計 **/
589    function lfGetOrderJob($type, $sdate, $edate) {
590        $objQuery = SC_Query_Ex::getSingletonInstance();
591        list($where, $arrWhereVal) = $this->lfGetWhereMember('dtb_order.create_date', $sdate, $edate, $type);
592
593        $col = <<< __EOS__
594            job,
595            COUNT(order_id) AS order_count,
596            SUM(total) AS total,
597            AVG(total) AS total_average
598__EOS__;
599
600        $from   = 'dtb_order JOIN dtb_customer ON dtb_order.customer_id = dtb_customer.customer_id';
601
602        $where .= ' AND dtb_order.del_flg = 0 AND dtb_order.status <> ?';
603        $arrWhereVal[] = ORDER_CANCEL;
604
605        $objQuery->setGroupBy('job');
606        $objQuery->setOrder('total DESC');
607        $arrTotalResults = $objQuery->select($col, $from, $where, $arrWhereVal);
608
609        foreach ($arrTotalResults as $key => $value) {
610            $arrResult =& $arrTotalResults[$key];
611            $job_key = $arrResult['job'];
612            if ($job_key != '') {
613                $arrResult['job_name'] = $this->arrJob[$job_key];
614            } else {
615                $arrResult['job_name'] = SC_I18n_Ex::t('LC_Page_Admin_Total_011');
616            }
617
618        }
619        $tpl_image     = $this->lfGetGraphPie($arrTotalResults, 'job_name', 'job_' . $type, SC_I18n_Ex::t('LC_Page_Admin_Total_039'), $sdate, $edate);
620
621        return array($arrTotalResults, $tpl_image);
622    }
623
624    /** 年代別集計 **/
625    function lfGetOrderAge($type, $sdate, $edate) {
626
627        $objQuery = SC_Query_Ex::getSingletonInstance();
628
629        list($where, $arrWhereVal) = $this->lfGetWhereMember('create_date', $sdate, $edate, $type);
630
631        $dbFactory = SC_DB_DBFactory_Ex::getInstance();
632        $col = $dbFactory->getOrderTotalAgeColSql() . ' AS age';
633        $col .= ',COUNT(order_id) AS order_count';
634        $col .= ',SUM(total) AS total';
635        $col .= ',AVG(total) AS total_average';
636
637        $from   = 'dtb_order';
638
639        $where .= ' AND del_flg = 0 AND status <> ?';
640        $arrWhereVal[] = ORDER_CANCEL;
641
642        $objQuery->setGroupBy('age');
643        $objQuery->setOrder('age DESC');
644        $arrTotalResults = $objQuery->select($col, $from, $where, $arrWhereVal);
645
646        foreach ($arrTotalResults as $key => $value) {
647            $arrResult =& $arrTotalResults[$key];
648            $age_key = $arrResult['age'];
649            if ($age_key != '') {
650                $arrResult['age_name'] = SC_I18n_Ex::t('LC_Page_Admin_Total_012', array('T_FIELD' => $arrResult['age']));
651            } else {
652                $arrResult['age_name'] = SC_I18n_Ex::t('LC_Page_Admin_Total_011');
653            }
654
655        }
656        $tpl_image = $this->lfGetGraphBar($arrTotalResults, 'age_name', 'age_' . $type, SC_I18n_Ex::t('LC_Page_Admin_Total_013'), SC_I18n_Ex::t('LC_Page_Admin_Total_014'), $sdate, $edate);
657
658        return array($arrTotalResults, $tpl_image);
659    }
660
661    /** 期間別集計 **/
662    // todo あいだの日付埋める
663    function lfGetOrderTerm($type, $sdate, $edate) {
664        $objQuery   = SC_Query_Ex::getSingletonInstance();
665
666        list($where, $arrWhereVal) = $this->lfGetWhereMember('create_date', $sdate, $edate);
667        $where .= ' AND del_flg = 0 AND status <> ?';
668        $arrWhereVal[] = ORDER_CANCEL;
669
670        switch ($type) {
671            case 'month':
672                $xtitle = SC_I18n_Ex::t('LC_Page_Admin_Total_015');
673                $ytitle = SC_I18n_Ex::t('LC_Page_Admin_Total_014');
674                $format = '%m';
675                break;
676            case 'year':
677                $xtitle = SC_I18n_Ex::t('LC_Page_Admin_Total_016');
678                $ytitle = SC_I18n_Ex::t('LC_Page_Admin_Total_014');
679                $format = '%Y';
680                break;
681            case 'wday':
682                $xtitle = SC_I18n_Ex::t('LC_Page_Admin_Total_017');
683                $ytitle = SC_I18n_Ex::t('LC_Page_Admin_Total_014');
684                $format = '%a';
685                break;
686            case 'hour':
687                $xtitle = SC_I18n_Ex::t('LC_Page_Admin_Total_018');
688                $ytitle = SC_I18n_Ex::t('LC_Page_Admin_Total_014');
689                $format = '%H';
690                break;
691            default:
692                $xtitle = SC_I18n_Ex::t('LC_Page_Admin_Total_019');
693                $ytitle = SC_I18n_Ex::t('LC_Page_Admin_Total_014');
694                $format = '%Y-%m-%d';
695                $xincline = true;
696                break;
697        }
698
699        $dbFactory = SC_DB_DBFactory_Ex::getInstance();
700        // todo postgres
701        $col = $dbFactory->getOrderTotalDaysWhereSql($type);
702
703        $objQuery->setGroupBy('str_date');
704        $objQuery->setOrder('str_date');
705        // 検索結果の取得
706        $arrTotalResults = $objQuery->select($col, 'dtb_order', $where, $arrWhereVal);
707
708        $arrTotalResults = $this->lfAddBlankLine($arrTotalResults, $type, $sdate, $edate);
709        // todo GDない場合の処理
710        $tpl_image       = $this->lfGetGraphLine($arrTotalResults, 'str_date', 'term_' . $type, $xtitle, $ytitle, $sdate, $edate, $xincline);
711        $arrTotalResults = $this->lfAddTotalLine($arrTotalResults);
712
713        return array($arrTotalResults, $tpl_image);
714    }
715
716    /*
717     * 期間中の日付を埋める
718     */
719    function lfAddBlankLine($arrResults, $type, $st, $ed) {
720
721        $arrDateList = $this->lfDateTimeArray($type, $st, $ed);
722
723        foreach ($arrResults as $arrResult) {
724            $strdate                = $arrResult['str_date'];
725            $arrDateResults[$strdate] = $arrResult;
726        }
727
728        foreach ($arrDateList as $date) {
729
730            if (array_key_exists($date, $arrDateResults)) {
731
732                $arrRet[] = $arrDateResults[$date];
733
734            } else {
735                $arrRet[]['str_date'] = $date;
736            }
737        }
738        return $arrRet;
739    }
740
741    /*
742     * 日付の配列を作成する
743     *
744     */
745    function lfDateTimeArray($type, $st, $ed) {
746        switch ($type) {
747            case 'month':
748                $format        = 'm';
749                break;
750            case 'year':
751                $format        = 'Y';
752                break;
753            case 'wday':
754                $format        = 'D';
755                break;
756            case 'hour':
757                $format        = 'H';
758                break;
759            default:
760                $format        = 'Y-m-d';
761                break;
762        }
763
764        if ($type == 'hour') {
765            $arrDateList = array('00','01','02','03','04','05','06','07','08','09','10','11','12','13','14','15','16','17','18','19','20','21','22','23');
766
767        } else {
768            $arrDateList = array();
769            $tmp    = strtotime($st);
770            $nAday  = 60*60*24;
771            $edx    = strtotime($ed);
772            while ($tmp <= $edx) {
773                $sDate = date($format, $tmp);
774                if (!in_array($sDate, $arrDateList)) {
775                    $arrDateList[] = $sDate;
776                }
777                $tmp += $nAday;
778            }
779        }
780        return $arrDateList;
781    }
782
783    /*
784     * 合計を付与する
785     */
786    function lfAddTotalLine($arrResults) {
787        // 検索結果が0でない場合
788        if (count($arrResults) > 0) {
789
790            // 合計の計算
791            foreach ($arrResults as $arrResult) {
792                foreach ($arrResult as $key => $value) {
793                    $arrTotal[$key] += $arrResult[$key];
794                }
795            }
796            // 平均値の計算
797            $arrTotal['total_average'] = $arrTotal['total'] / $arrTotal['total_order'];
798            $arrResults[] = $arrTotal;
799        }
800
801        return $arrResults;
802    }
803
804    // 必要なカラムのみ抽出する(CSVデータで取得する)
805    function lfGetDataColCSV($arrData, $arrDataCol) {
806        $max = count($arrData);
807        $csv_data = '';
808        for ($i = 0; $i < $max; $i++) {
809            foreach ($arrDataCol as $val) {
810                $arrRet[$i][$val] = $arrData[$i][$val];
811            }
812            // 期間別集計の合計行の「期間」項目に不要な値が表示されてしまわない様、'合計'と表示する
813            if (($i === $max -1) && isset($arrRet[$i]['str_date'])) {
814                $arrRet[$i]['str_date'] = SC_I18n_Ex::t('LC_Page_Admin_Total_020');
815            }
816            $csv_data.= SC_Utils_Ex::sfGetCSVList($arrRet[$i]);
817        }
818        return $csv_data;
819    }
820
821    function lfGetCSVColum($page) {
822        switch ($page) {
823            // 商品別集計
824            case 'products':
825                $arrTitleCol = array(
826                    SC_I18n_Ex::t('LC_Page_Admin_Total_021'),
827                    SC_I18n_Ex::t('LC_Page_Admin_Total_022'),
828                    SC_I18n_Ex::t('LC_Page_Admin_Total_023'),
829                    SC_I18n_Ex::t('LC_Page_Admin_Total_024'),
830                    SC_I18n_Ex::t('LC_Page_Admin_Total_025'),
831                    SC_I18n_Ex::t('LC_Page_Admin_Total_026'),
832                );
833                $arrDataCol = array(
834                    'product_code',
835                    'product_name',
836                    'order_count',
837                    'products_count',
838                    'price',
839                    'total',
840                );
841                break;
842            // 職業別集計
843            case 'job':
844                $arrTitleCol = array(
845                    SC_I18n_Ex::t('LC_Page_Admin_Total_027'),
846                    SC_I18n_Ex::t('LC_Page_Admin_Total_023'),
847                    SC_I18n_Ex::t('LC_Page_Admin_Total_028'),
848                    SC_I18n_Ex::t('LC_Page_Admin_Total_029'),
849                );
850                $arrDataCol = array(
851                    'job_name',
852                    'order_count',
853                    'total',
854                    'total_average',
855                );
856                break;
857            // 会員別集計
858            case 'member':
859                $arrTitleCol = array(
860                    SC_I18n_Ex::t('LC_Page_Admin_Total_030'),
861                    SC_I18n_Ex::t('LC_Page_Admin_Total_023'),
862                    SC_I18n_Ex::t('LC_Page_Admin_Total_028'),
863                    SC_I18n_Ex::t('LC_Page_Admin_Total_029'),
864                );
865                $arrDataCol = array(
866                    'member_name',
867                    'order_count',
868                    'total',
869                    'total_average',
870                );
871                break;
872            // 年代別集計
873            case 'age':
874                $arrTitleCol = array(
875                    SC_I18n_Ex::t('LC_Page_Admin_Total_031'),
876                    SC_I18n_Ex::t('LC_Page_Admin_Total_023'),
877                    SC_I18n_Ex::t('LC_Page_Admin_Total_028'),
878                    SC_I18n_Ex::t('LC_Page_Admin_Total_029'),
879                );
880                $arrDataCol = array(
881                    'age_name',
882                    'order_count',
883                    'total',
884                    'total_average',
885                );
886                break;
887            // 期間別集計
888            default:
889                $arrTitleCol = array(
890                    SC_I18n_Ex::t('LC_Page_Admin_Total_032'),
891                    SC_I18n_Ex::t('LC_Page_Admin_Total_023'),
892                    SC_I18n_Ex::t('LC_Page_Admin_Total_033'),
893                    SC_I18n_Ex::t('LC_Page_Admin_Total_034'),
894                    SC_I18n_Ex::t('LC_Page_Admin_Total_035'),
895                    SC_I18n_Ex::t('LC_Page_Admin_Total_036'),
896                    SC_I18n_Ex::t('LC_Page_Admin_Total_037'),
897                    SC_I18n_Ex::t('LC_Page_Admin_Total_038'),
898                    SC_I18n_Ex::t('LC_Page_Admin_Total_028'),
899                    SC_I18n_Ex::t('LC_Page_Admin_Total_029'),
900                );
901                $arrDataCol = array(
902                    'str_date',
903                    'total_order',
904                    'men',
905                    'women',
906                    'men_member',
907                    'men_nonmember',
908                    'women_member',
909                    'women_nonmember',
910                    'total',
911                    'total_average',
912                );
913                break;
914        }
915
916        return array($arrTitleCol, $arrDataCol);
917    }
918}
Note: See TracBrowser for help on using the repository browser.