source: branches/version-2_12-dev/data/class/pages/admin/basis/LC_Page_Admin_Basis.php @ 21442

Revision 21442, 11.1 KB checked in by Seasoft, 12 years ago (diff)

#1613 (ソース整形・ソースコメントの改善)

  • Zend Framework PHP 標準コーディング規約への準拠を高めた
  • 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-2011 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_EX_REALDIR . 'page_extends/admin/LC_Page_Admin_Ex.php';
26
27/**
28 * 店舗基本情報 のページクラス.
29 *
30 * @package Page
31 * @author LOCKON CO.,LTD.
32 * @version $Id$
33 */
34class LC_Page_Admin_Basis extends LC_Page_Admin_Ex {
35
36    // }}}
37    // {{{ functions
38
39    /**
40     * Page を初期化する.
41     *
42     * @return void
43     */
44    function init() {
45        parent::init();
46        $this->tpl_mainpage = 'basis/index.tpl';
47        $this->tpl_subno = 'index';
48        $this->tpl_mainno = 'basis';
49        $masterData = new SC_DB_MasterData_Ex();
50        $this->arrPref = $masterData->getMasterData('mtb_pref');
51        $this->arrTAXRULE = $masterData->getMasterData("mtb_taxrule");
52        $this->tpl_maintitle = '基本情報管理';
53        $this->tpl_subtitle = 'SHOPマスター';
54
55        //定休日用配列
56        $this->arrRegularHoliday[0] = '日';
57        $this->arrRegularHoliday[1] = '月';
58        $this->arrRegularHoliday[2] = '火';
59        $this->arrRegularHoliday[3] = '水';
60        $this->arrRegularHoliday[4] = '木';
61        $this->arrRegularHoliday[5] = '金';
62        $this->arrRegularHoliday[6] = '土';
63    }
64
65    /**
66     * Page のプロセス.
67     *
68     * @return void
69     */
70    function process() {
71        $this->action();
72        $this->sendResponse();
73    }
74
75    /**
76     * Page のアクション.
77     *
78     * @return void
79     */
80    function action() {
81
82        $objDb = new SC_Helper_DB_Ex();
83
84        if ($objDb->sfGetBasisExists()) {
85            $this->tpl_mode = 'update';
86        } else {
87            $this->tpl_mode = 'insert';
88        }
89
90        if (!empty($_POST)) {
91
92            $objFormParam = new SC_FormParam_Ex();
93            $this->lfInitParam($objFormParam, $_POST);
94            $objFormParam->setParam($_POST);
95            $objFormParam->convParam();
96
97            $this->arrErr = $this->lfErrorCheck($objFormParam);
98            $post = $objFormParam->getHashArray();
99
100            $this->arrForm = $post;
101
102            if (count($this->arrErr) == 0) {
103                switch ($this->getMode()) {
104                    // 既存編集
105                    case 'update':
106                        $this->lfUpdateData($this->arrForm);
107                        break;
108                    // 新規作成
109                    case 'insert':
110                        $this->lfInsertData($this->arrForm);
111                        break;
112                    default:
113                        break;
114                }
115                $this->tpl_onload = "fnCheckLimit('downloadable_days', 'downloadable_days_unlimited', '" . DISABLED_RGB . "'); window.alert('SHOPマスターの登録が完了しました。');";
116            }
117            if (empty($this->arrForm['regular_holiday_ids'])) {
118                $this->arrSel = array();
119            } else {
120                $this->arrSel = $this->arrForm['regular_holiday_ids'];
121            }
122        } else {
123            $arrCol = $this->lfGetCol();
124            $col    = SC_Utils_Ex::sfGetCommaList($arrCol);
125            $arrRet = $objDb->sfGetBasisData(true, $col);
126            $this->arrForm = $arrRet;
127
128            $regular_holiday_ids = explode('|', $this->arrForm['regular_holiday_ids']);
129            $this->arrForm['regular_holiday_ids'] = $regular_holiday_ids;
130            $this->tpl_onload = "fnCheckLimit('downloadable_days', 'downloadable_days_unlimited', '" . DISABLED_RGB . "');";
131        }
132    }
133
134    /**
135     * デストラクタ.
136     *
137     * @return void
138     */
139    function destroy() {
140        parent::destroy();
141    }
142
143    // 基本情報用のカラムを取り出す。
144    function lfGetCol() {
145        $arrCol = array(
146            "company_name",
147            "company_kana",
148            "shop_name",
149            "shop_kana",
150            "shop_name_eng",
151            "zip01",
152            "zip02",
153            'pref',
154            "addr01",
155            "addr02",
156            "tel01",
157            "tel02",
158            "tel03",
159            "fax01",
160            "fax02",
161            "fax03",
162            "business_hour",
163            "email01",
164            "email02",
165            "email03",
166            "email04",
167            'tax',
168            "tax_rule",
169            "free_rule",
170            "good_traded",
171            'message',
172            "regular_holiday_ids",
173            'latitude',
174            'longitude',
175            "downloadable_days",
176            "downloadable_days_unlimited"
177        );
178        return $arrCol;
179    }
180
181    function lfUpdateData($array) {
182        $objQuery =& SC_Query_Ex::getSingletonInstance();
183        $arrCol = $this->lfGetCol();
184        foreach ($arrCol as $val) {
185            //配列の場合は、パイプ区切りの文字列に変換
186            if (is_array($array[$val])) {
187                $sqlval[$val] = implode("|", $array[$val]);
188            } else {
189                $sqlval[$val] = $array[$val];
190            }
191        }
192        $sqlval['update_date'] = 'CURRENT_TIMESTAMP';
193        // UPDATEの実行
194        $ret = $objQuery->update("dtb_baseinfo", $sqlval);
195
196        $this->log("update done.");
197    }
198
199    function lfInsertData($array) {
200        $objQuery =& SC_Query_Ex::getSingletonInstance();
201        $arrCol = $this->lfGetCol();
202        foreach ($arrCol as $val) {
203            $sqlval[$val] = $array[$val];
204        }
205        $sqlval['update_date'] = 'CURRENT_TIMESTAMP';
206        // INSERTの実行
207        $ret = $objQuery->insert("dtb_baseinfo", $sqlval);
208
209        $this->log("insert done.");
210    }
211
212    function lfInitParam(&$objFormParam, $post) {
213        $objFormParam->addParam('会社名', 'company_name', STEXT_LEN, 'KVa',  array("MAX_LENGTH_CHECK"));
214        $objFormParam->addParam('会社名(フリガナ)', 'company_kana', STEXT_LEN, 'KVC',  array("KANA_CHECK","MAX_LENGTH_CHECK"));
215
216        $objFormParam->addParam("店名", "shop_name", STEXT_LEN, 'KVa', array("EXIST_CHECK","MAX_LENGTH_CHECK"));
217        $objFormParam->addParam("店名(フリガナ)", "shop_kana",  STEXT_LEN, 'KVC', array("KANA_CHECK","MAX_LENGTH_CHECK"));
218        $objFormParam->addParam("店名(英語表記)", "shop_name_eng",MTEXT_LEN, 'a', array("GRAPH_CHECK","MAX_LENGTH_CHECK"));
219        // 郵便番号チェック
220        $objFormParam->addParam("郵便番号1", "zip01", ZIP01_LEN, 'n', array("EXIST_CHECK", "NUM_CHECK","NUM_COUNT_CHECK"));
221        $objFormParam->addParam("郵便番号2", "zip02", ZIP02_LEN, 'n', array("EXIST_CHECK", "NUM_CHECK","NUM_COUNT_CHECK"));
222        // 住所チェック
223        $objFormParam->addParam("都道府県", 'pref', '', 'n', array("EXIST_CHECK"));
224        $objFormParam->addParam("住所1", "addr01", MTEXT_LEN, 'KVa', array("EXIST_CHECK", "MAX_LENGTH_CHECK"));
225        $objFormParam->addParam("住所2", "addr02", MTEXT_LEN, 'KVa', array("EXIST_CHECK", "MAX_LENGTH_CHECK"));
226        // メールチェック
227        $objFormParam->addParam('商品注文受付メールアドレス', "email01", null, 'a', array("EXIST_CHECK", "EMAIL_CHECK", "EMAIL_CHAR_CHECK"));
228        $objFormParam->addParam('問い合わせ受付メールアドレス', "email02", null, 'a', array("EXIST_CHECK", "EMAIL_CHECK", "EMAIL_CHAR_CHECK"));
229        $objFormParam->addParam('メール送信元メールアドレス', "email03", null, 'a', array("EXIST_CHECK", "EMAIL_CHECK", "EMAIL_CHAR_CHECK"));
230        $objFormParam->addParam('送信エラー受付メールアドレス', "email04", null, 'a', array("EXIST_CHECK", "EMAIL_CHECK", "EMAIL_CHAR_CHECK"));
231
232        // 電話番号
233        $objFormParam->addParam("電話番号1", "tel01", TEL_ITEM_LEN, 'n', array("NUM_CHECK", "MAX_LENGTH_CHECK"));
234        $objFormParam->addParam("電話番号2", "tel02", TEL_ITEM_LEN, 'n', array("NUM_CHECK", "MAX_LENGTH_CHECK"));
235        $objFormParam->addParam("電話番号3", "tel03", TEL_ITEM_LEN, 'n', array("NUM_CHECK", "MAX_LENGTH_CHECK"));
236
237        // FAX番号
238        $objFormParam->addParam("FAX番号1", "fax01", TEL_ITEM_LEN, 'n', array("NUM_CHECK", "MAX_LENGTH_CHECK"));
239        $objFormParam->addParam("FAX番号2", "fax02", TEL_ITEM_LEN, 'n', array("NUM_CHECK", "MAX_LENGTH_CHECK"));
240        $objFormParam->addParam("FAX番号3", "fax03", TEL_ITEM_LEN, 'n', array("NUM_CHECK", "MAX_LENGTH_CHECK"));
241
242        // その他
243        $objFormParam->addParam("消費税率", 'tax', PERCENTAGE_LEN, 'n', array("EXIST_CHECK", "NUM_CHECK", "MAX_LENGTH_CHECK"));
244        $objFormParam->addParam("課税規則 ", "tax_rule", PERCENTAGE_LEN, 'n', array("EXIST_CHECK", "NUM_CHECK", "MAX_LENGTH_CHECK"));
245        $objFormParam->addParam("送料無料条件", "free_rule", PRICE_LEN, 'n', array("NUM_CHECK", "MAX_LENGTH_CHECK"));
246        $objFormParam->addParam("店舗営業時間", "business_hour", STEXT_LEN, 'KVa', array("MAX_LENGTH_CHECK"));
247
248        $objFormParam->addParam("取扱商品", "good_traded", LLTEXT_LEN, '', array("MAX_LENGTH_CHECK"));
249        $objFormParam->addParam("メッセージ", 'message', LLTEXT_LEN, '', array("MAX_LENGTH_CHECK"));
250
251        if (!isset($post['downloadable_days_unlimited']) && $post['downloadable_days_unlimited'] != "1") {
252            $objFormParam->addParam("ダウンロード可能日数", "downloadable_days", DOWNLOAD_DAYS_LEN, 'n', array("EXIST_CHECK", "ZERO_CHECK", "NUM_CHECK", "MAX_LENGTH_CHECK"));
253        } else {
254            $objFormParam->addParam("ダウンロード無制限", "downloadable_days_unlimited", array("EXIST_CHECK"));
255        }
256        $objFormParam->addParam('緯度', 'latitude', STEXT_LEN, '',  array("MAX_LENGTH_CHECK"));
257        $objFormParam->addParam('軽度', 'longitude', STEXT_LEN, '',  array("MAX_LENGTH_CHECK"));
258
259        $objFormParam->addParam("定休日", "regular_holiday_ids", INT_LEN, 'n', array("MAX_LENGTH_CHECK"));
260    }
261
262    // 入力エラーチェック
263    function lfErrorCheck(&$objFormParam) {
264        $arrErr = $objFormParam->checkError();
265        $post = $objFormParam->getHashArray();
266
267        $objErr = new SC_CheckError_Ex($post);
268        $objErr->doFunc(array("郵便番号", "zip01", "zip02"), array("ALL_EXIST_CHECK"));
269
270        // 電話番号チェック
271        $objErr->doFunc(array('TEL', "tel01", "tel02", "tel03"), array("TEL_CHECK"));
272        $objErr->doFunc(array('FAX', "fax01", "fax02", "fax03"), array("TEL_CHECK"));
273
274        $objErr->doFunc(array("緯度", 'latitude', STEXT_LEN), array("NUM_POINT_CHECK", "MAX_LENGTH_CHECK"));
275        $objErr->doFunc(array("経度", 'longitude', STEXT_LEN), array("NUM_POINT_CHECK", "MAX_LENGTH_CHECK"));
276
277        return  array_merge((array)$arrErr, (array)$objErr->arrErr);
278    }
279}
Note: See TracBrowser for help on using the repository browser.