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

Revision 22408, 34.0 KB checked in by kim, 11 years ago (diff)

#2060 メッセージIDの振り直し SC_Fpdf_001-002(002とPARAM_LABEL_QUANTITY、LC_Page_Admin_Total_024を統合)
#2060 メッセージIDの振り直し SC_Fpdf003とLC_Page_Admin_Total_025、PARAM_LABEL_PRICEを統合
#2060 メッセージIDの振り直し SC_Fpdf004-006(006とPARAM_LABEL_DELIV_FEEを統合)
#2060 メッセージIDの振り直し SC_Fpdf007とPARAM_LABEL_CHARGE統合、SC_CartSession_001を修正時の間違いを訂正

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