source: branches/version-2/data/class/pages/admin/contents/LC_Page_Admin_Contents_Campaign.php @ 17653

Revision 17653, 18.8 KB checked in by takegami, 15 years ago (diff)

#366修正

  • 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                exit;
99            }
100
101            break;
102            // 編集押下時
103        case 'update':
104            // キャンペーン情報を取得
105            $this->arrForm = $this->lfGetCampaign($campaign_id, &$objQuery);
106            $this->is_update = true;
107            break;
108            // 削除押下時
109        case 'delete':
110            // 削除
111            $this->lfDeleteCampaign($campaign_id, &$objQuery);
112            // キャンペーンTOPへリダイレクト
113            $this->sendRedirect($this->getLocation(URL_CAMPAIGN_TOP));
114            exit;
115            break;
116            // CSV出力
117        case 'csv':
118            // オプションの指定
119            $option = "ORDER BY create_date DESC";
120
121            // CSV出力タイトル行の作成
122            $arrCsvOutput = SC_Utils_Ex::sfSwapArray($objCSV->sfgetCsvOutput(4, " WHERE csv_id = 4 AND status = 1"));
123
124            if (count($arrCsvOutput) <= 0) break;
125
126            $arrCsvOutputCols = $arrCsvOutput['col'];
127            $arrCsvOutputTitle = $arrCsvOutput['disp_name'];
128            $head = SC_Utils_Ex::sfGetCSVList($arrCsvOutputTitle);
129            $data = $objCSV->lfGetCSV("dtb_campaign_order", "campaign_id = ?", $option, array($campaign_id), $arrCsvOutputCols);
130
131            // CSVを送信する。
132            SC_Utils_Ex::sfCSVDownload($head.$data);
133            exit;
134            break;
135        default:
136            break;
137        }
138
139        // キャンペーン一覧取得
140        $this->arrCampaign = $this->lfGetCampaignList($objQuery);
141        $this->campaign_id = $campaign_id;
142
143        // キャンペーン期間用
144        $objDate = new SC_Date();
145        $this->arrYear = $objDate->getYear();
146        $this->arrMonth = $objDate->getMonth();
147        $this->arrDay = $objDate->getDay();
148        $this->arrHour = $objDate->getHour();
149        $this->arrMinutes = $objDate->getMinutes();
150
151        //---- ページ表示
152        $objView->assignobj($this);
153        $objView->display(MAIN_FRAME);
154    }
155
156    /**
157     * デストラクタ.
158     *
159     * @return void
160     */
161    function destroy() {
162        parent::destroy();
163    }
164
165    /**
166     * 入力情報の初期化
167     */
168    function lfInitParam(&$objFormParam) {
169
170        $objFormParam->addParam("キャンペーン名", "campaign_name", MTEXT_LEN, "KVa", array("EXIST_CHECK","SPTAB_CHECK","MAX_LENGTH_CHECK"));
171
172        $objFormParam->addParam("開始日時", "start_year", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
173        $objFormParam->addParam("開始日時", "start_month", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
174        $objFormParam->addParam("開始日時", "start_day", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
175        $objFormParam->addParam("開始日時", "start_hour", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
176        $objFormParam->addParam("開始日時", "start_minute", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
177
178        $objFormParam->addParam("停止日時", "end_year", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
179        $objFormParam->addParam("停止日時", "end_month", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
180        $objFormParam->addParam("停止日時", "end_day", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
181        $objFormParam->addParam("停止日時", "end_hour", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
182        $objFormParam->addParam("停止日時", "end_minute", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
183
184        $objFormParam->addParam("ディレクトリ名", "directory_name", MTEXT_LEN, "KVa", array("EXIST_CHECK","ALNUM_CHECK","SPTAB_CHECK","MAX_LENGTH_CHECK"));
185        $objFormParam->addParam("申込数制御", "limit_count", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
186        $objFormParam->addParam("重複申込制御", "orverlapping_flg", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
187        $objFormParam->addParam("カートに商品を入れる", "cart_flg", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
188        $objFormParam->addParam("送料無料設定", "deliv_free_flg", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
189
190    }
191
192    /*
193     * 関数名:lfErrorCheck()
194     * 引数1 :キャンペーンID
195     * 説明 :エラーチェック
196     * 戻り値:エラー文字格納配列
197     */
198    function lfErrorCheck($campaign_id = "", &$objQuery, &$objFormParam) {
199
200        $arrList = $objFormParam->getHashArray();
201        $objErr = new SC_CheckError($arrList);
202        $objErr->arrErr = $objFormParam->checkError();
203
204        $objErr->doFunc(array("開始日時", "start_year", "start_month", "start_day", "start_hour", "start_minute", "0"), array("CHECK_DATE2"));
205        $objErr->doFunc(array("停止日時", "end_year", "end_month", "end_day", "end_hour", "end_minute", "0"), array("CHECK_DATE2"));
206        $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"));
207
208        if (!is_writable(CAMPAIGN_TEMPLATE_PATH)) {
209            $objErr->arrErr['campaign_template_path'] = "※" . CAMPAIGN_TEMPLATE_PATH . " へ書き込み権限を与えてください。 <br/>";
210        }
211        if (!is_writable(CAMPAIGN_PATH)) {
212            $objErr->arrErr['campaign_path'] = "※" . CAMPAIGN_PATH . " へ書き込み権限を与えてください。<br/>";
213        }
214
215        if(count($objErr->arrErr) <= 0) {
216
217            // 編集時用に元のディレクトリ名を取得する。
218            if($campaign_id != "") {
219                $directory_name = $objQuery->get("dtb_campaign", "directory_name", "campaign_id = ?", array($campaign_id));
220            } else {
221                $directory_name = "";
222            }
223
224            // 同名のフォルダが存在する場合はエラー
225            if(file_exists(CAMPAIGN_TEMPLATE_PATH.$arrList['directory_name']) && $directory_name != $arrList['directory_name']) {
226                $objErr->arrErr['directory_name'] = "※ 同名のディレクトリがすでに存在します。<br/>";
227            }
228            $ret = $objQuery->get("dtb_campaign", "directory_name", "directory_name = ? AND del_flg = 0", array($arrList['directory_name']));
229            // DBにすでに登録されていないかチェック
230            if($ret != "" && $directory_name != $arrList['directory_name']) {
231                $objErr->arrErr['directory_name'] = "※ すでに登録されているディレクトリ名です。<br/>";
232            }
233        }
234
235        return $objErr->arrErr;
236    }
237
238    /*
239     * 関数名:lfRegistCampaign()
240     * 引数1 :キャンペーンID(アップデート時に指定)
241     * 説明 :キャンペーン登録/更新
242     * 戻り値:無し
243     */
244    function lfRegistCampaign($campaign_id = "", &$objQuery, &$objFormParam) {
245
246        $objSiteInfo = new SC_SiteInfo();
247        $arrInfo = $objSiteInfo->data;
248        $arrList = $objFormParam->getHashArray();
249
250        // 開始日時・終了日時整形
251        $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";
252        $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";
253
254        // ポイントレートは設定されていなければ0を挿入
255        if($arrInfo['point_rate'] == "") $arrInfo['point_rate'] = "0";
256        // フラグは設定されていなければ0を挿入
257        if(!$arrList['limit_count']) $arrList['limit_count'] = "0";
258        if(!$arrList['orverlapping_flg']) $arrList['orverlapping_flg'] = "0";
259        if(!$arrList['cart_flg']) $arrList['cart_flg'] = "0";
260        if(!$arrList['deliv_free_flg']) $arrList['deliv_free_flg'] = "0";
261
262        $sqlval['campaign_name'] = $arrList['campaign_name'];
263        $sqlval['campaign_point_rate'] = $arrInfo['point_rate'];
264        $sqlval['start_date'] = $start_date;
265        $sqlval['end_date'] = $end_date;
266        $sqlval['directory_name'] = $arrList['directory_name'];
267        $sqlval['limit_count'] = $arrList['limit_count'];
268        $sqlval['orverlapping_flg'] = $arrList['orverlapping_flg'];
269        $sqlval['cart_flg'] = $arrList['cart_flg'];
270        $sqlval['deliv_free_flg'] = $arrList['deliv_free_flg'];
271        $sqlval['update_date'] = "now()";
272
273        // キャンペーンIDで指定されている場合はupdate
274        if($campaign_id != "") {
275
276            // 元のディレクトリ名を取得名
277            $directory_name = $objQuery->get("dtb_campaign", "directory_name", "campaign_id = ?", array($campaign_id));
278            // ファイル名を変更
279            @rename(CAMPAIGN_TEMPLATE_PATH . $directory_name , CAMPAIGN_TEMPLATE_PATH . $arrList['directory_name']);
280            @rename(CAMPAIGN_PATH . $directory_name , CAMPAIGN_PATH . $arrList['directory_name']);
281
282            // update
283            $objQuery->update("dtb_campaign", $sqlval, "campaign_id = ?", array($campaign_id));
284
285        } else {
286
287            // キャンペーンページディレクトリ作成
288            $this->lfCreateTemplate(CAMPAIGN_TEMPLATE_PATH, $arrList['directory_name'], $objFormParam);
289
290            $sqlval['create_date'] = "now()";
291            // insert
292            $objQuery->insert("dtb_campaign", $sqlval);
293        }
294    }
295
296    /*
297     * 関数名:lfGetCampaignList()
298     * 説明 :キャンペーン一覧を取得
299     * 戻り値:キャンペーン一覧配列
300     */
301    function lfGetCampaignList(&$objQuery) {
302
303        $col = "campaign_id,campaign_name,directory_name,total_count";
304        $objQuery->setorder("update_date DESC");
305        $arrRet = $objQuery->select($col, "dtb_campaign", "del_flg = 0");
306
307        return $arrRet;
308    }
309
310    /*
311     * 関数名:lfGetCampaign()
312     * 引数1 :キャンペーンID
313     * 説明 :キャンペーン情報取得
314     * 戻り値:キャンペーン情報配列
315     */
316    function lfGetCampaign($campaign_id, &$objQuery) {
317
318        $col = "campaign_id,campaign_name,start_date,end_date,directory_name,limit_count,orverlapping_flg,cart_flg,deliv_free_flg";
319        $arrRet = $objQuery->select($col, "dtb_campaign", "campaign_id = ?", array($campaign_id));
320
321        // 開始日時・停止日時を分解
322        $start_date = (date("Y/m/d/H/i/s" , strtotime($arrRet[0]['start_date'])));
323        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);
324        $end_date = (date("Y/m/d/H/i/s" , strtotime($arrRet[0]['end_date'])));
325        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);
326
327        return $arrRet[0];
328    }
329
330    /*
331     * 関数名:lfDeleteCampaign()
332     * 引数1 :キャンペーンID
333     * 説明 :キャンペーン削除
334     * 戻り値:無し
335     */
336    function lfDeleteCampaign($campaign_id, &$objQuery) {
337        $objFileManager = new SC_Helper_FileManager_Ex();
338
339        // ディレクトリ名を取得名
340        $directory_name = $objQuery->get("dtb_campaign", "directory_name", "campaign_id = ?", array($campaign_id));
341        // ファイルを削除
342        $objFileManager->sfDeleteDir(CAMPAIGN_TEMPLATE_PATH . $directory_name);
343        $objFileManager->sfDeleteDir(CAMPAIGN_PATH . $directory_name);
344
345        $sqlval['del_flg'] = 1;
346        $sqlval['update_date'] = "now()";
347        // delete
348        $objQuery->update("dtb_campaign", $sqlval, "campaign_id = ?", array($campaign_id));
349    }
350
351    /*
352     * 関数名:lfCreateTemplate()
353     * 引数1 :ディレクトリパス
354     * 引数2 :作成ファイル名
355     * 説明 :キャンペーンの初期テンプレート作成
356     * 戻り値:無し
357     */
358    function lfCreateTemplate($dir, $file, &$objFormParam) {
359
360        $objFileManager = new SC_Helper_FileManager_Ex();
361        $arrRet = $objFormParam->getHashArray();
362
363
364        // 作成ファイルディレクトリ
365        $create_dir = $dir . $file;
366        $create_active_dir = $create_dir . "/" . CAMPAIGN_TEMPLATE_ACTIVE;
367        $create_end_dir = $create_dir . "/" . CAMPAIGN_TEMPLATE_END;
368        // デフォルトファイルディレクトリ
369        $default_dir = TEMPLATE_DIR . CAMPAIGN_TEMPLATE_DIR;
370        $default_active_dir = $default_dir . "/" . CAMPAIGN_TEMPLATE_ACTIVE;
371        $default_end_dir = $default_dir . "/" . CAMPAIGN_TEMPLATE_END;
372
373        $ret = $objFileManager->sfCreateFile($create_dir, 0755);
374        $ret = $objFileManager->sfCreateFile($create_active_dir, 0755);
375        $ret = $objFileManager->sfCreateFile($create_end_dir, 0755);
376
377        // キャンペーン実行PHPをコピー
378        $ret = $objFileManager->sfCreateFile(CAMPAIGN_PATH . $file);
379        copy(HTML_PATH . CAMPAIGN_TEMPLATE_DIR . "index.php", CAMPAIGN_PATH . $file . "/index.php");
380        copy(HTML_PATH . CAMPAIGN_TEMPLATE_DIR . "application.php", CAMPAIGN_PATH . $file . "/application.php");
381        copy(HTML_PATH . CAMPAIGN_TEMPLATE_DIR . "complete.php", CAMPAIGN_PATH . $file . "/complete.php");
382        copy(HTML_PATH . CAMPAIGN_TEMPLATE_DIR . "entry.php", CAMPAIGN_PATH . $file . "/entry.php");
383
384        // デフォルトテンプレート作成(キャンペーン中)
385        $header = $this->lfGetFileContents($default_active_dir."header.tpl");
386        SC_Utils_Ex::sfWriteFile($header, $create_active_dir."header.tpl", "w");
387        $contents = $this->lfGetFileContents($default_active_dir."contents.tpl");
388        if(!$arrRet['cart_flg']) {
389            $contents .= "\n" . '<!--{*ログインフォーム*}-->' . "\n";
390            $contents .= $this->lfGetFileContents(CAMPAIGN_BLOC_PATH . "login.tpl");
391            $contents .= '<!--{*会員登録フォーム*}-->'."\n";
392            $contents .= $this->lfGetFileContents(CAMPAIGN_BLOC_PATH . "entry.tpl");
393        }
394        SC_Utils_Ex::sfWriteFile($contents, $create_active_dir."contents.tpl", "w");
395        $footer = $this->lfGetFileContents($default_active_dir."footer.tpl");
396        SC_Utils_Ex::sfWriteFile($footer, $create_active_dir."footer.tpl", "w");
397
398        // サイトフレーム作成
399        $site_frame  = $header."\n";
400        $site_frame .= '<script type="text/javascript" src="<!--{$TPL_DIR}-->js/navi.js"></script>'."\n";
401        $site_frame .= '<script type="text/javascript" src="<!--{$TPL_DIR}-->js/site.js"></script>'."\n";
402        $site_frame .= '<!--{include file=$tpl_mainpage}-->'."\n";
403        $site_frame .= $footer."\n";
404        SC_Utils_Ex::sfWriteFile($site_frame, $create_active_dir."site_frame.tpl", "w");
405
406        /* デフォルトテンプレート作成(キャンペーン終了) */
407        $header = $this->lfGetFileContents($default_end_dir."header.tpl");
408        SC_Utils_Ex::sfWriteFile($header, $create_end_dir."header.tpl", "w");
409        $contents = $this->lfGetFileContents($default_end_dir."contents.tpl");
410        SC_Utils_Ex::sfWriteFile($contents, $create_end_dir."contents.tpl", "w");
411        $footer = $this->lfGetFileContents($default_end_dir."footer.tpl");
412        SC_Utils_Ex::sfWriteFile($footer, $create_end_dir."footer.tpl", "w");
413    }
414
415    /*
416     * 関数名:lfGetFileContents()
417     * 引数1 :ファイルパス
418     * 説明 :ファイル読込
419     * 戻り値:無し
420     */
421    function lfGetFileContents($read_file) {
422
423        if(file_exists($read_file)) {
424            $contents = file_get_contents($read_file);
425        } else {
426            $contents = "";
427        }
428
429        return $contents;
430    }
431}
432?>
Note: See TracBrowser for help on using the repository browser.