source: branches/feature-module-update/data/class/pages/admin/contents/LC_Page_Admin_Contents_Campaign.php @ 16582

Revision 16582, 18.4 KB checked in by nanasess, 17 years ago (diff)

ライセンス表記変更

  • Property svn:eol-style set to LF
  • Property svn:keywords set to Id Revision Date
  • Property svn:mime-type set to text/x-httpd-php
Line 
1<?php
2/*
3 * This file is part of EC-CUBE
4 *
5 * Copyright(c) 2000-2007 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
24// {{{ requires
25require_once(CLASS_PATH . "pages/LC_Page.php");
26require_once(CLASS_EX_PATH . "helper_extends/SC_Helper_CSV_Ex.php");
27require_once(CLASS_EX_PATH . "helper_extends/SC_Helper_FileManager_Ex.php");
28
29/**
30 * キャンペーン管理 のページクラス.
31 *
32 * @package Page
33 * @author LOCKON CO.,LTD.
34 * @version $Id$
35 */
36class LC_Page_Admin_Contents_Campaign extends LC_Page {
37
38    // }}}
39    // {{{ functions
40
41    /**
42     * Page を初期化する.
43     *
44     * @return void
45     */
46    function init() {
47        parent::init();
48        $this->tpl_mainpage = 'contents/campaign.tpl';
49        $this->tpl_subnavi = 'contents/subnavi.tpl';
50        $this->tpl_subno = "campaign";
51        $this->tpl_mainno = 'contents';
52        $this->tpl_subtitle = 'キャンペーン管理';
53        // カートに商品が入っているにチェックが入っているかチェック
54        $this->tpl_onload = "fnIsCartOn();";
55    }
56
57    /**
58     * Page のプロセス.
59     *
60     * @return void
61     */
62    function process() {
63        //---- 認証可否の判定
64        $objSess = new SC_Session();
65        SC_Utils_Ex::sfIsSuccess($objSess);
66
67        $objView = new SC_AdminView();
68        $objQuery = new SC_Query();
69        $objFormParam = new SC_FormParam();
70        $objCSV = new SC_Helper_CSV_Ex();
71
72        // パラメータ情報の初期化
73        $this->lfInitParam($objFormParam);
74        // フォームの値をセット
75        $objFormParam->setParam($_POST);
76
77        // 編集処理の場合は状態を保持
78        $this->is_update = isset($_POST['is_update']) ? $_POST['is_update'] : "";
79
80        // フォームの値をテンプレートへ渡す
81        $this->arrForm = $objFormParam->getHashArray();
82        $campaign_id = isset($_POST['campaign_id']) ? $_POST['campaign_id'] : "";
83
84        if (!isset($_POST['mode'])) $_POST['mode'] = "";
85
86        switch($_POST['mode']) {
87            // 新規登録/編集登録
88        case 'regist':
89            // エラーチェック
90            $this->arrErr = $this->lfErrorCheck($campaign_id, $objQuery, $objFormParam);
91
92            if(count($this->arrErr) <= 0) {
93                // 登録
94                $this->lfRegistCampaign($campaign_id, $objQuery, $objFormParam);
95
96                // キャンペーンTOPへリダイレクト
97                $this->sendRedirect($this->getLocation(URL_CAMPAIGN_TOP));
98            }
99
100            break;
101            // 編集押下時
102        case 'update':
103            // キャンペーン情報を取得
104            $this->arrForm = $this->lfGetCampaign($campaign_id, &$objQuery);
105            $this->is_update = true;
106            break;
107            // 削除押下時
108        case 'delete':
109            // 削除
110            $this->lfDeleteCampaign($campaign_id, &$objQuery);
111            // キャンペーンTOPへリダイレクト
112            $this->sendRedirect($this->getLocation(URL_CAMPAIGN_TOP));
113            break;
114            // CSV出力
115        case 'csv':
116            // オプションの指定
117            $option = "ORDER BY create_date DESC";
118
119            // CSV出力タイトル行の作成
120            $arrCsvOutput = SC_Utils_Ex::sfSwapArray($objCSV->sfgetCsvOutput(4, " WHERE csv_id = 4 AND status = 1"));
121
122            if (count($arrCsvOutput) <= 0) break;
123
124            $arrCsvOutputCols = $arrCsvOutput['col'];
125            $arrCsvOutputTitle = $arrCsvOutput['disp_name'];
126            $head = SC_Utils_Ex::sfGetCSVList($arrCsvOutputTitle);
127            $data = $objCSV->lfGetCSV("dtb_campaign_order", "campaign_id = ?", $option, array($campaign_id), $arrCsvOutputCols);
128
129            // CSVを送信する。
130            SC_Utils_Ex::sfCSVDownload($head.$data);
131            exit;
132            break;
133        default:
134            break;
135        }
136
137        // キャンペーン一覧取得
138        $this->arrCampaign = $this->lfGetCampaignList($objQuery);
139        $this->campaign_id = $campaign_id;
140
141        // キャンペーン期間用
142        $objDate = new SC_Date();
143        $this->arrYear = $objDate->getYear();
144        $this->arrMonth = $objDate->getMonth();
145        $this->arrDay = $objDate->getDay();
146        $this->arrHour = $objDate->getHour();
147        $this->arrMinutes = $objDate->getMinutes();
148
149        //---- ページ表示
150        $objView->assignobj($this);
151        $objView->display(MAIN_FRAME);
152    }
153
154    /**
155     * デストラクタ.
156     *
157     * @return void
158     */
159    function destroy() {
160        parent::destroy();
161    }
162
163    /**
164     * 入力情報の初期化
165     */
166    function lfInitParam(&$objFormParam) {
167
168        $objFormParam->addParam("キャンペーン名", "campaign_name", MTEXT_LEN, "KVa", array("EXIST_CHECK","SPTAB_CHECK","MAX_LENGTH_CHECK"));
169
170        $objFormParam->addParam("開始日時", "start_year", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
171        $objFormParam->addParam("開始日時", "start_month", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
172        $objFormParam->addParam("開始日時", "start_day", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
173        $objFormParam->addParam("開始日時", "start_hour", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
174        $objFormParam->addParam("開始日時", "start_minute", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
175
176        $objFormParam->addParam("停止日時", "end_year", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
177        $objFormParam->addParam("停止日時", "end_month", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
178        $objFormParam->addParam("停止日時", "end_day", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
179        $objFormParam->addParam("停止日時", "end_hour", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
180        $objFormParam->addParam("停止日時", "end_minute", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
181
182        $objFormParam->addParam("ディレクトリ名", "directory_name", MTEXT_LEN, "KVa", array("EXIST_CHECK","ALNUM_CHECK","SPTAB_CHECK","MAX_LENGTH_CHECK"));
183        $objFormParam->addParam("申込数制御", "limit_count", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
184        $objFormParam->addParam("重複申込制御", "orverlapping_flg", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
185        $objFormParam->addParam("カートに商品を入れる", "cart_flg", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
186        $objFormParam->addParam("送料無料設定", "deliv_free_flg", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
187
188    }
189
190    /*
191     * 関数名:lfErrorCheck()
192     * 引数1 :キャンペーンID
193     * 説明 :エラーチェック
194     * 戻り値:エラー文字格納配列
195     */
196    function lfErrorCheck($campaign_id = "", &$objQuery, &$objFormParam) {
197
198        $arrList = $objFormParam->getHashArray();
199        $objErr = new SC_CheckError($arrList);
200        $objErr->arrErr = $objFormParam->checkError();
201
202        $objErr->doFunc(array("開始日時", "start_year", "start_month", "start_day", "start_hour", "start_minute", "0"), array("CHECK_DATE2"));
203        $objErr->doFunc(array("停止日時", "end_year", "end_month", "end_day", "end_hour", "end_minute", "0"), array("CHECK_DATE2"));
204        $objErr->doFunc(array("開始日時", "停止日時", "start_year", "start_month", "start_day", "start_hour", "start_minute", "00", "end_year", "end_month", "end_day", "end_hour", "end_minute", "59"), array("CHECK_SET_TERM2"));
205
206        if(count($objErr->arrErr) <= 0) {
207
208            // 編集時用に元のディレクトリ名を取得する。
209            if($campaign_id != "") {
210                $directory_name = $objQuery->get("dtb_campaign", "directory_name", "campaign_id = ?", array($campaign_id));
211            } else {
212                $directory_name = "";
213            }
214
215            // 同名のフォルダが存在する場合はエラー
216            if(file_exists(CAMPAIGN_TEMPLATE_PATH.$arrList['directory_name']) && $directory_name != $arrList['directory_name']) {
217                $objErr->arrErr['directory_name'] = "※ 同名のディレクトリがすでに存在します。<br/>";
218            }
219            $ret = $objQuery->get("dtb_campaign", "directory_name", "directory_name = ? AND del_flg = 0", array($arrList['directory_name']));
220            // DBにすでに登録されていないかチェック
221            if($ret != "" && $directory_name != $arrList['directory_name']) {
222                $objErr->arrErr['directory_name'] = "※ すでに登録されているディレクトリ名です。<br/>";
223            }
224        }
225
226        return $objErr->arrErr;
227    }
228
229    /*
230     * 関数名:lfRegistCampaign()
231     * 引数1 :キャンペーンID(アップデート時に指定)
232     * 説明 :キャンペーン登録/更新
233     * 戻り値:無し
234     */
235    function lfRegistCampaign($campaign_id = "", &$objQuery, &$objFormParam) {
236
237        $objSiteInfo = new SC_SiteInfo();
238        $arrInfo = $objSiteInfo->data;
239        $arrList = $objFormParam->getHashArray();
240
241        // 開始日時・終了日時整形
242        $start_date = $arrList['start_year']."-".sprintf("%02d", $arrList['start_month'])."-".sprintf("%02d", $arrList['start_day'])." ".sprintf("%02d", $arrList['start_hour']).":".sprintf("%02d", $arrList['start_minute']).":00";
243        $end_date = $arrList['end_year']."-".sprintf("%02d", $arrList['end_month'])."-".sprintf("%02d", $arrList['end_day'])." ".sprintf("%02d", $arrList['end_hour']).":".sprintf("%02d", $arrList['end_minute']).":00";
244
245        // ポイントレートは設定されていなければ0を挿入
246        if($arrInfo['point_rate'] == "") $arrInfo['point_rate'] = "0";
247        // フラグは設定されていなければ0を挿入
248        if(!$arrList['limit_count']) $arrList['limit_count'] = "0";
249        if(!$arrList['orverlapping_flg']) $arrList['orverlapping_flg'] = "0";
250        if(!$arrList['cart_flg']) $arrList['cart_flg'] = "0";
251        if(!$arrList['deliv_free_flg']) $arrList['deliv_free_flg'] = "0";
252
253        $sqlval['campaign_name'] = $arrList['campaign_name'];
254        $sqlval['campaign_point_rate'] = $arrInfo['point_rate'];
255        $sqlval['start_date'] = $start_date;
256        $sqlval['end_date'] = $end_date;
257        $sqlval['directory_name'] = $arrList['directory_name'];
258        $sqlval['limit_count'] = $arrList['limit_count'];
259        $sqlval['orverlapping_flg'] = $arrList['orverlapping_flg'];
260        $sqlval['cart_flg'] = $arrList['cart_flg'];
261        $sqlval['deliv_free_flg'] = $arrList['deliv_free_flg'];
262        $sqlval['update_date'] = "now()";
263
264        // キャンペーンIDで指定されている場合はupdate
265        if($campaign_id != "") {
266
267            // 元のディレクトリ名を取得名
268            $directory_name = $objQuery->get("dtb_campaign", "directory_name", "campaign_id = ?", array($campaign_id));
269            // ファイル名を変更
270            @rename(CAMPAIGN_TEMPLATE_PATH . $directory_name , CAMPAIGN_TEMPLATE_PATH . $arrList['directory_name']);
271            @rename(CAMPAIGN_PATH . $directory_name , CAMPAIGN_PATH . $arrList['directory_name']);
272
273            // update
274            $objQuery->update("dtb_campaign", $sqlval, "campaign_id = ?", array($campaign_id));
275
276        } else {
277
278            // キャンペーンページディレクトリ作成
279            $this->lfCreateTemplate(CAMPAIGN_TEMPLATE_PATH, $arrList['directory_name'], $objFormParam);
280
281            $sqlval['create_date'] = "now()";
282            // insert
283            $objQuery->insert("dtb_campaign", $sqlval);
284        }
285    }
286
287    /*
288     * 関数名:lfGetCampaignList()
289     * 説明 :キャンペーン一覧を取得
290     * 戻り値:キャンペーン一覧配列
291     */
292    function lfGetCampaignList(&$objQuery) {
293
294        $col = "campaign_id,campaign_name,directory_name,total_count";
295        $objQuery->setorder("update_date DESC");
296        $arrRet = $objQuery->select($col, "dtb_campaign", "del_flg = 0");
297
298        return $arrRet;
299    }
300
301    /*
302     * 関数名:lfGetCampaign()
303     * 引数1 :キャンペーンID
304     * 説明 :キャンペーン情報取得
305     * 戻り値:キャンペーン情報配列
306     */
307    function lfGetCampaign($campaign_id, &$objQuery) {
308
309        $col = "campaign_id,campaign_name,start_date,end_date,directory_name,limit_count,orverlapping_flg,cart_flg,deliv_free_flg";
310        $arrRet = $objQuery->select($col, "dtb_campaign", "campaign_id = ?", array($campaign_id));
311
312        // 開始日時・停止日時を分解
313        $start_date = (date("Y/m/d/H/i/s" , strtotime($arrRet[0]['start_date'])));
314        list($arrRet[0]['start_year'],$arrRet[0]['start_month'],$arrRet[0]['start_day'],$arrRet[0]['start_hour'], $arrRet[0]['start_minute'], $arrRet[0]['start_second']) = split("/", $start_date);
315        $end_date = (date("Y/m/d/H/i/s" , strtotime($arrRet[0]['end_date'])));
316        list($arrRet[0]['end_year'],$arrRet[0]['end_month'],$arrRet[0]['end_day'],$arrRet[0]['end_hour'], $arrRet[0]['end_minute'], $arrRet[0]['end_second']) = split("/", $end_date);
317
318        return $arrRet[0];
319    }
320
321    /*
322     * 関数名:lfDeleteCampaign()
323     * 引数1 :キャンペーンID
324     * 説明 :キャンペーン削除
325     * 戻り値:無し
326     */
327    function lfDeleteCampaign($campaign_id, &$objQuery) {
328        $objFileManager = new SC_Helper_FileManager_Ex();
329
330        // ディレクトリ名を取得名
331        $directory_name = $objQuery->get("dtb_campaign", "directory_name", "campaign_id = ?", array($campaign_id));
332        // ファイルを削除
333        $objFileManager->sfDeleteDir(CAMPAIGN_TEMPLATE_PATH . $directory_name);
334        $objFileManager->sfDeleteDir(CAMPAIGN_PATH . $directory_name);
335
336        $sqlval['del_flg'] = 1;
337        $sqlval['update_date'] = "now()";
338        // delete
339        $objQuery->update("dtb_campaign", $sqlval, "campaign_id = ?", array($campaign_id));
340    }
341
342    /*
343     * 関数名:lfCreateTemplate()
344     * 引数1 :ディレクトリパス
345     * 引数2 :作成ファイル名
346     * 説明 :キャンペーンの初期テンプレート作成
347     * 戻り値:無し
348     */
349    function lfCreateTemplate($dir, $file, &$objFormParam) {
350
351        $objFileManager = new SC_Helper_FileManager_Ex();
352        $arrRet = $objFormParam->getHashArray();
353
354
355        // 作成ファイルディレクトリ
356        $create_dir = $dir . $file;
357        $create_active_dir = $create_dir . "/" . CAMPAIGN_TEMPLATE_ACTIVE;
358        $create_end_dir = $create_dir . "/" . CAMPAIGN_TEMPLATE_END;
359        // デフォルトファイルディレクトリ
360        $default_dir = TEMPLATE_DIR . CAMPAIGN_TEMPLATE_DIR;
361        $default_active_dir = $default_dir . "/" . CAMPAIGN_TEMPLATE_ACTIVE;
362        $default_end_dir = $default_dir . "/" . CAMPAIGN_TEMPLATE_END;
363
364        $ret = $objFileManager->sfCreateFile($create_dir, 0755);
365        $ret = $objFileManager->sfCreateFile($create_active_dir, 0755);
366        $ret = $objFileManager->sfCreateFile($create_end_dir, 0755);
367
368        // キャンペーン実行PHPをコピー
369        $ret = $objFileManager->sfCreateFile(CAMPAIGN_PATH . $file);
370        copy(HTML_PATH . CAMPAIGN_TEMPLATE_DIR . "index.php", CAMPAIGN_PATH . $file . "/index.php");
371        copy(HTML_PATH . CAMPAIGN_TEMPLATE_DIR . "application.php", CAMPAIGN_PATH . $file . "/application.php");
372        copy(HTML_PATH . CAMPAIGN_TEMPLATE_DIR . "complete.php", CAMPAIGN_PATH . $file . "/complete.php");
373        copy(HTML_PATH . CAMPAIGN_TEMPLATE_DIR . "entry.php", CAMPAIGN_PATH . $file . "/entry.php");
374
375        // デフォルトテンプレート作成(キャンペーン中)
376        $header = $this->lfGetFileContents($default_active_dir."header.tpl");
377        SC_Utils_Ex::sfWriteFile($header, $create_active_dir."header.tpl", "w");
378        $contents = $this->lfGetFileContents($default_active_dir."contents.tpl");
379        if(!$arrRet['cart_flg']) {
380            $contents .= "\n" . '<!--{*ログインフォーム*}-->' . "\n";
381            $contents .= $this->lfGetFileContents(CAMPAIGN_BLOC_PATH . "login.tpl");
382            $contents .= '<!--{*会員登録フォーム*}-->'."\n";
383            $contents .= $this->lfGetFileContents(CAMPAIGN_BLOC_PATH . "entry.tpl");
384        }
385        SC_Utils_Ex::sfWriteFile($contents, $create_active_dir."contents.tpl", "w");
386        $footer = $this->lfGetFileContents($default_active_dir."footer.tpl");
387        SC_Utils_Ex::sfWriteFile($footer, $create_active_dir."footer.tpl", "w");
388
389        // サイトフレーム作成
390        $site_frame  = $header."\n";
391        $site_frame .= '<script type="text/javascript" src="<!--{$TPL_DIR}-->js/navi.js"></script>'."\n";
392        $site_frame .= '<script type="text/javascript" src="<!--{$TPL_DIR}-->js/site.js"></script>'."\n";
393        $site_frame .= '<!--{include file=$tpl_mainpage}-->'."\n";
394        $site_frame .= $footer."\n";
395        SC_Utils_Ex::sfWriteFile($site_frame, $create_active_dir."site_frame.tpl", "w");
396
397        /* デフォルトテンプレート作成(キャンペーン終了) */
398        $header = $this->lfGetFileContents($default_end_dir."header.tpl");
399        SC_Utils_Ex::sfWriteFile($header, $create_end_dir."header.tpl", "w");
400        $contents = $this->lfGetFileContents($default_end_dir."contents.tpl");
401        SC_Utils_Ex::sfWriteFile($contents, $create_end_dir."contents.tpl", "w");
402        $footer = $this->lfGetFileContents($default_end_dir."footer.tpl");
403        SC_Utils_Ex::sfWriteFile($footer, $create_end_dir."footer.tpl", "w");
404    }
405
406    /*
407     * 関数名:lfGetFileContents()
408     * 引数1 :ファイルパス
409     * 説明 :ファイル読込
410     * 戻り値:無し
411     */
412    function lfGetFileContents($read_file) {
413
414        if(file_exists($read_file)) {
415            $contents = file_get_contents($read_file);
416        } else {
417            $contents = "";
418        }
419
420        return $contents;
421    }
422}
423?>
Note: See TracBrowser for help on using the repository browser.