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

Revision 20503, 11.0 KB checked in by shutta, 13 years ago (diff)

SC_CheckErrorクラスのclass_extends対応

  • 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-2010 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_subnavi = 'basis/subnavi.tpl';
48        $this->tpl_subno = 'index';
49        $this->tpl_mainno = 'basis';
50        $masterData = new SC_DB_MasterData_Ex();
51        $this->arrPref = $masterData->getMasterData('mtb_pref');
52        $this->arrTAXRULE = $masterData->getMasterData("mtb_taxrule");
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        $cnt = $objDb->sfGetBasisCount();
85        if ($cnt > 0) {
86            $this->tpl_mode = "update";
87        } else {
88            $this->tpl_mode = "insert";
89        }
90
91        if(!empty($_POST)) {
92
93            $objFormParam = new SC_FormParam_Ex();
94            $this->lfInitParam($objFormParam, $_POST);
95            $objFormParam->setParam($_POST);
96            $objFormParam->convParam();
97
98            $this->arrErr = $this->lfErrorCheck($objFormParam);
99            $post = $objFormParam->getHashArray();
100
101            $this->arrForm = $post;
102
103            if(count($this->arrErr) == 0) {
104                switch($this->getMode()) {
105                case 'update':
106                    $this->lfUpdateData($this->arrForm);    // 既存編集
107                    break;
108                case 'insert':
109                    $this->lfInsertData($this->arrForm);    // 新規作成
110                    break;
111                default:
112                    break;
113                }
114                $this->tpl_onload = "fnCheckLimit('downloadable_days', 'downloadable_days_unlimited', '" . DISABLED_RGB . "'); window.alert('SHOPマスタの登録が完了しました。');";
115            }
116            if( empty($this->arrForm['regular_holiday_ids']) ) {
117                $this->arrSel = array();
118            } else {
119                $this->arrSel = $this->arrForm['regular_holiday_ids'];
120            }
121        } else {
122            $arrCol = $this->lfGetCol();
123            $col    = SC_Utils_Ex::sfGetCommaList($arrCol);
124            $arrRet = $objDb->sfGetBasisData(true, $col);
125            $this->arrForm = $arrRet;
126
127            $regular_holiday_ids = explode('|', $this->arrForm['regular_holiday_ids']);
128            $this->arrForm['regular_holiday_ids'] = $regular_holiday_ids;
129            $this->tpl_onload = "fnCheckLimit('downloadable_days', 'downloadable_days_unlimited', '" . DISABLED_RGB . "');";
130        }
131    }
132
133    /**
134     * デストラクタ.
135     *
136     * @return void
137     */
138    function destroy() {
139        parent::destroy();
140    }
141
142    // 基本情報用のカラムを取り出す。
143    function lfGetCol() {
144        $arrCol = array(
145            "company_name",
146            "company_kana",
147            "shop_name",
148            "shop_kana",
149            "shop_name_eng",
150            "zip01",
151            "zip02",
152            "pref",
153            "addr01",
154            "addr02",
155            "tel01",
156            "tel02",
157            "tel03",
158            "fax01",
159            "fax02",
160            "fax03",
161            "business_hour",
162            "email01",
163            "email02",
164            "email03",
165            "email04",
166            "tax",
167            "tax_rule",
168            "free_rule",
169            "good_traded",
170            "message",
171            "regular_holiday_ids",
172            "latitude",
173            "longitude",
174            "downloadable_days",
175            "downloadable_days_unlimited"
176        );
177        return $arrCol;
178    }
179
180    function lfUpdateData($array) {
181        $objQuery =& SC_Query::getSingletonInstance();
182        $arrCol = $this->lfGetCol();
183        foreach($arrCol as $val) {
184            //配列の場合は、パイプ区切りの文字列に変換
185            if(is_array($array[$val])) {
186                $sqlval[$val] = implode("|", $array[$val]);
187            } else {
188                $sqlval[$val] = $array[$val];
189            }
190        }
191        $sqlval['update_date'] = 'Now()';
192        // UPDATEの実行
193        $ret = $objQuery->update("dtb_baseinfo", $sqlval);
194    }
195
196    function lfInsertData($array) {
197        $objQuery =& SC_Query::getSingletonInstance();
198        $arrCol = $this->lfGetCol();
199        foreach($arrCol as $val) {
200            $sqlval[$val] = $array[$val];
201        }
202        $sqlval['update_date'] = 'Now()';
203        // INSERTの実行
204        $ret = $objQuery->insert("dtb_baseinfo", $sqlval);
205    }
206
207    function lfInitParam(&$objFormParam, $post) {
208        $objFormParam->addParam('会社名', 'company_name', STEXT_LEN, 'KVa',  array("MAX_LENGTH_CHECK"));
209        $objFormParam->addParam('会社名(カナ)', 'company_kana', STEXT_LEN, 'KVC',  array("KANA_CHECK","MAX_LENGTH_CHECK"));
210
211        $objFormParam->addParam("店名", "shop_name", STEXT_LEN, 'KVa', array("EXIST_CHECK","MAX_LENGTH_CHECK"));
212        $objFormParam->addParam("店名(カナ)", "shop_kana",  STEXT_LEN, 'KVC', array("KANA_CHECK","MAX_LENGTH_CHECK"));
213        $objFormParam->addParam("店名(英語表記)", "shop_name_eng",MTEXT_LEN, 'a', array("GRAPH_CHECK","MAX_LENGTH_CHECK"));
214        // 郵便番号チェック
215        $objFormParam->addParam("郵便番号1", "zip01", ZIP01_LEN, 'n', array("EXIST_CHECK", "NUM_CHECK","NUM_COUNT_CHECK"));
216        $objFormParam->addParam("郵便番号2", "zip02", ZIP02_LEN, 'n', array("EXIST_CHECK", "NUM_CHECK","NUM_COUNT_CHECK"));
217        // 住所チェック
218        $objFormParam->addParam("都道府県", "pref", array("EXIST_CHECK"));
219        $objFormParam->addParam("住所1", "addr01", MTEXT_LEN, 'KVa', array("EXIST_CHECK", "MAX_LENGTH_CHECK"));
220        $objFormParam->addParam("住所2", "addr02", MTEXT_LEN, 'KVa', array("EXIST_CHECK", "MAX_LENGTH_CHECK"));
221        // メールチェック
222        $objFormParam->addParam('商品注文受付メールアドレス', "email01", STEXT_LEN, 'a', array("EXIST_CHECK", "EMAIL_CHECK", "EMAIL_CHAR_CHECK", "MAX_LENGTH_CHECK"));
223        $objFormParam->addParam('問い合わせ受付メールアドレス', "email02", STEXT_LEN, 'a', array("EXIST_CHECK", "EMAIL_CHECK", "EMAIL_CHAR_CHECK", "MAX_LENGTH_CHECK"));
224        $objFormParam->addParam('メール送信元メールアドレス', "email03", STEXT_LEN, 'a', array("EXIST_CHECK", "EMAIL_CHECK", "EMAIL_CHAR_CHECK", "MAX_LENGTH_CHECK"));
225        $objFormParam->addParam('送信エラー受付メールアドレス', "email04", STEXT_LEN, 'a', array("EXIST_CHECK", "EMAIL_CHECK", "EMAIL_CHAR_CHECK","MAX_LENGTH_CHECK"));
226
227        // 電話番号
228        $objFormParam->addParam("電話番号1", "tel01", TEL_ITEM_LEN, 'n', array("NUM_CHECK", "MAX_LENGTH_CHECK"));
229        $objFormParam->addParam("電話番号2", "tel02", TEL_ITEM_LEN, 'n', array("NUM_CHECK", "MAX_LENGTH_CHECK"));
230        $objFormParam->addParam("電話番号3", "tel03", TEL_ITEM_LEN, 'n', array("NUM_CHECK", "MAX_LENGTH_CHECK"));
231
232        // FAX番号
233        $objFormParam->addParam("FAX番号1", "fax01", TEL_ITEM_LEN, 'n', array("NUM_CHECK", "MAX_LENGTH_CHECK"));
234        $objFormParam->addParam("FAX番号2", "fax02", TEL_ITEM_LEN, 'n', array("NUM_CHECK", "MAX_LENGTH_CHECK"));
235        $objFormParam->addParam("FAX番号3", "fax03", TEL_ITEM_LEN, 'n', array("NUM_CHECK", "MAX_LENGTH_CHECK"));
236
237        // その他
238        $objFormParam->addParam("消費税率", "tax", PERCENTAGE_LEN, 'n', array("EXIST_CHECK", "NUM_CHECK", "MAX_LENGTH_CHECK"));
239        $objFormParam->addParam("課税規則 ", "tax_rule", PERCENTAGE_LEN, 'n', array("EXIST_CHECK", "NUM_CHECK", "MAX_LENGTH_CHECK"));
240        $objFormParam->addParam("送料無料条件", "free_rule", PRICE_LEN, 'n', array("NUM_CHECK", "MAX_LENGTH_CHECK"));
241        $objFormParam->addParam("店舗営業時間", "business_hour", STEXT_LEN, 'KVa', array("MAX_LENGTH_CHECK"));
242
243        $objFormParam->addParam("取扱商品", "good_traded", LLTEXT_LEN, '', array("MAX_LENGTH_CHECK"));
244        $objFormParam->addParam("メッセージ", "message", LLTEXT_LEN, '', array("MAX_LENGTH_CHECK"));
245
246        if(!isset($post['downloadable_days_unlimited']) && $post['downloadable_days_unlimited'] != "1") {
247            $objFormParam->addParam("ダウンロード可能日数", "downloadable_days", DOWNLOAD_DAYS_LEN, 'n', array("EXIST_CHECK", "ZERO_CHECK", "NUM_CHECK", "MAX_LENGTH_CHECK"));
248        } else {
249            $objFormParam->addParam("ダウンロード無制限", "downloadable_days_unlimited", array("EXIST_CHECK"));
250        }
251        $objFormParam->addParam('緯度', 'latitude', STEXT_LEN, '',  array("MAX_LENGTH_CHECK"));
252        $objFormParam->addParam('軽度', 'longitude', STEXT_LEN, '',  array("MAX_LENGTH_CHECK"));
253
254        $objFormParam->addParam("定休日", "regular_holiday_ids", INT_LEN, "n", array("MAX_LENGTH_CHECK"));
255    }
256
257    // 入力エラーチェック
258    function lfErrorCheck(&$objFormParam) {
259        $arrErr = $objFormParam->checkError();
260        $post = $objFormParam->getHashArray();
261
262        $objErr = new SC_CheckError_Ex($post);
263        $objErr->doFunc(array("郵便番号", "zip01", "zip02"), array("ALL_EXIST_CHECK"));
264
265        // 電話番号チェック
266        $objErr->doFunc(array("TEL", "tel01", "tel02", "tel03"), array("TEL_CHECK"));
267        $objErr->doFunc(array("FAX", "fax01", "fax02", "fax03"), array("TEL_CHECK"));
268
269        $objErr->doFunc(array("緯度", "latitude", STEXT_LEN), array("NUM_POINT_CHECK", "MAX_LENGTH_CHECK"));
270        $objErr->doFunc(array("経度", "longitude", STEXT_LEN), array("NUM_POINT_CHECK", "MAX_LENGTH_CHECK"));
271
272        return  array_merge((array)$arrErr, (array)$objErr->arrErr);
273    }
274}
275?>
Note: See TracBrowser for help on using the repository browser.