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

Revision 18820, 11.3 KB checked in by nanasess, 14 years ago (diff)

#781(規格のデータベースを木構造に)

  • 規格の無い商品が品切れになってしまう不具合修正
  • 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; 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_PATH . "pages/LC_Page.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 {
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", array("pref_id", "pref_name", "rank"));
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        $objView = new SC_AdminView();
72        $objSess = new SC_Session();
73        $objQuery = new SC_Query();
74
75        // 認証可否の判定
76        SC_Utils_Ex::sfIsSuccess($objSess);
77
78        $cnt = $objQuery->count("dtb_baseinfo");
79
80        if ($cnt > 0) {
81            $this->tpl_mode = "update";
82        } else {
83            $this->tpl_mode = "insert";
84        }
85
86        if(isset($_POST['mode']) && !empty($_POST["mode"])) {
87            // POSTデータの引き継ぎ
88            $this->arrForm = $_POST;
89
90            // 入力データの変換
91            $this->arrForm = $this->lfConvertParam($this->arrForm);
92            $this->arrForm['regular_holiday_ids'] = $_POST['regular_holiday_ids'];  // 定休日情報を付加
93            // 入力データのエラーチェック
94            $this->arrErr = $this->lfErrorCheck($this->arrForm);
95
96            if(count($this->arrErr) == 0) {
97                switch($_POST['mode']) {
98                case 'update':
99                    $this->lfUpdateData($this->arrForm);    // 既存編集
100                    break;
101                case 'insert':
102                    $this->lfInsertData($this->arrForm);    // 新規作成
103                    break;
104                default:
105                    break;
106                }
107                $this->tpl_onload = "fnCheckLimit('downloadable_days', 'downloadable_days_unlimited', '" . DISABLED_RGB . "'); window.alert('SHOPマスタの登録が完了しました。');";
108            }
109            if( empty($this->arrForm['regular_holiday_ids']) ) {
110                $this->arrSel = array();
111            } else {
112                $this->arrSel = $this->arrForm['regular_holiday_ids'];
113            }
114        } else {
115            $arrCol = $this->lfGetCol();
116            $col    = SC_Utils_Ex::sfGetCommaList($arrCol);
117            $arrRet = $objQuery->select($col, "dtb_baseinfo");
118            $this->arrForm = $arrRet[0];
119
120            $regular_holiday_ids = explode('|', $this->arrForm['regular_holiday_ids']);
121            $this->arrForm['regular_holiday_ids'] = $regular_holiday_ids;
122            $this->tpl_onload = "fnCheckLimit('downloadable_days', 'downloadable_days_unlimited', '" . DISABLED_RGB . "');";
123        }
124
125        $objView->assignobj($this);
126        $objView->display(MAIN_FRAME);
127    }
128
129    /**
130     * デストラクタ.
131     *
132     * @return void
133     */
134    function destroy() {
135        parent::destroy();
136    }
137
138    // 基本情報用のカラムを取り出す。
139    function lfGetCol() {
140        $arrCol = array(
141            "company_name",
142            "company_kana",
143            "shop_name",
144            "shop_kana",
145            "shop_name_eng",
146            "zip01",
147            "zip02",
148            "pref",
149            "addr01",
150            "addr02",
151            "tel01",
152            "tel02",
153            "tel03",
154            "fax01",
155            "fax02",
156            "fax03",
157            "business_hour",
158            "email01",
159            "email02",
160            "email03",
161            "email04",
162            "tax",
163            "tax_rule",
164            "free_rule",
165            "good_traded",
166            "message",
167            "regular_holiday_ids",
168            "latitude",
169            "longitude",
170            "downloadable_days",
171            "downloadable_days_unlimited"
172        );
173        return $arrCol;
174    }
175
176    function lfUpdateData($array) {
177        $objQuery = new SC_Query();
178        $arrCol = $this->lfGetCol();
179        foreach($arrCol as $val) {
180            //配列の場合は、パイプ区切りの文字列に変換
181            if(is_array($array[$val])) {
182                $sqlval[$val] = implode("|", $array[$val]);
183            } else {
184                $sqlval[$val] = $array[$val];
185            }
186        }
187        $sqlval['update_date'] = 'Now()';
188        // UPDATEの実行
189        $ret = $objQuery->update("dtb_baseinfo", $sqlval);
190    }
191
192    function lfInsertData($array) {
193        $objQuery = new SC_Query();
194        $arrCol = $this->lfGetCol();
195        foreach($arrCol as $val) {
196            $sqlval[$val] = $array[$val];
197        }
198        $sqlval['update_date'] = 'Now()';
199        // INSERTの実行
200        $ret = $objQuery->insert("dtb_baseinfo", $sqlval);
201    }
202
203    /* 取得文字列の変換 */
204    function lfConvertParam($array) {
205        /*
206         *  文字列の変換
207         *  K :  「半角(ハンカク)片仮名」を「全角片仮名」に変換
208         *  C :  「全角ひら仮名」を「全角かた仮名」に変換
209         *  V :  濁点付きの文字を一文字に変換。"K","H"と共に使用します
210         *  n :  「全角」数字を「半角(ハンカク)」に変換
211         *  a :  全角英数字を半角英数字に変換する
212         */
213        // 人物基本情報
214
215        // スポット商品
216        $arrConvList['company_name'] = "KVa";
217        $arrConvList['company_kana'] = "KVC";
218        $arrConvList['shop_name'] = "KVa";
219        $arrConvList['shop_kana'] = "KVC";
220        $arrConvList['shop_name_eng'] = "a";
221        $arrConvList['addr01'] = "KVa";
222        $arrConvList['addr02'] = "KVa";
223        $arrConvList['zip01'] = "n";
224        $arrConvList['zip02'] = "n";
225        $arrConvList['tel01'] = "n";
226        $arrConvList['tel02'] = "n";
227        $arrConvList['tel03'] = "n";
228        $arrConvList['fax01'] = "n";
229        $arrConvList['fax02'] = "n";
230        $arrConvList['fax03'] = "n";
231        $arrConvList['email01'] = "a";
232        $arrConvList['email02'] = "a";
233        $arrConvList['email03'] = "a";
234        $arrConvList['email04'] = "a";
235        $arrConvList['tax'] = "n";
236        $arrConvList['free_rule'] = "n";
237        $arrConvList['business_hour'] = "KVa";
238        $arrConvList['good_traded'] = "";
239        $arrConvList['message'] = "";
240        $arrConvList['downloadable_days'] = "n";
241        $arrConvList['downloadable_days_unlimited'] = "n";
242
243        return SC_Utils_Ex::mbConvertKanaWithArray($array, $arrConvList);
244    }
245
246    // 入力エラーチェック
247    function lfErrorCheck($array) {
248        $objErr = new SC_CheckError($array);
249
250        $objErr->doFunc(array("会社名", "company_name", STEXT_LEN), array("MAX_LENGTH_CHECK"));
251        $objErr->doFunc(array("会社名(カナ)", "company_kana", STEXT_LEN), array("KANA_CHECK","MAX_LENGTH_CHECK"));
252        $objErr->doFunc(array("店名", "shop_name", STEXT_LEN), array("EXIST_CHECK","MAX_LENGTH_CHECK"));
253        $objErr->doFunc(array("店名(カナ)", "shop_kana", STEXT_LEN), array("KANA_CHECK","MAX_LENGTH_CHECK"));
254        $objErr->doFunc(array("店名(英語表記)", "shop_name_eng", MTEXT_LEN), array("EXIST_CHECK","GRAPH_CHECK","MAX_LENGTH_CHECK"));
255        // 郵便番号チェック
256        $objErr->doFunc(array("郵便番号1","zip01",ZIP01_LEN ) ,array("EXIST_CHECK", "NUM_CHECK","NUM_COUNT_CHECK"));
257        $objErr->doFunc(array("郵便番号2","zip02",ZIP02_LEN ) ,array("EXIST_CHECK", "NUM_CHECK","NUM_COUNT_CHECK"));
258        $objErr->doFunc(array("郵便番号", "zip01", "zip02"), array("ALL_EXIST_CHECK"));
259        // 住所チェック
260        $objErr->doFunc(array("都道府県", "pref"), array("EXIST_CHECK"));
261        $objErr->doFunc(array("住所1", "addr01", MTEXT_LEN), array("EXIST_CHECK", "MAX_LENGTH_CHECK"));
262        $objErr->doFunc(array("住所2", "addr02", MTEXT_LEN), array("EXIST_CHECK", "MAX_LENGTH_CHECK"));
263        // メールチェック
264        $objErr->doFunc(array('商品注文受付メールアドレス', "email01", STEXT_LEN) ,array("EXIST_CHECK", "EMAIL_CHECK", "EMAIL_CHAR_CHECK", "MAX_LENGTH_CHECK"));
265        $objErr->doFunc(array('問い合わせ受付メールアドレス', "email02", STEXT_LEN) ,array("EXIST_CHECK", "EMAIL_CHECK", "EMAIL_CHAR_CHECK", "MAX_LENGTH_CHECK"));
266        $objErr->doFunc(array('メール送信元メールアドレス', "email03", STEXT_LEN) ,array("EXIST_CHECK", "EMAIL_CHECK", "EMAIL_CHAR_CHECK", "MAX_LENGTH_CHECK"));
267        $objErr->doFunc(array('送信エラー受付メールアドレス', "email04", STEXT_LEN) ,array("EXIST_CHECK", "EMAIL_CHECK", "EMAIL_CHAR_CHECK","MAX_LENGTH_CHECK"));
268        // 電話番号チェック
269        $objErr->doFunc(array("TEL", "tel01", "tel02", "tel03"), array("TEL_CHECK"));
270        $objErr->doFunc(array("FAX", "fax01", "fax02", "fax03"), array("TEL_CHECK"));
271        // その他
272        $objErr->doFunc(array("消費税率", "tax", PERCENTAGE_LEN), array("EXIST_CHECK", "NUM_CHECK", "MAX_LENGTH_CHECK"));
273        $objErr->doFunc(array("送料無料条件", "free_rule", PRICE_LEN), array("NUM_CHECK", "MAX_LENGTH_CHECK"));
274        $objErr->doFunc(array("店舗営業時間", "business_hour", STEXT_LEN), array("MAX_LENGTH_CHECK"));
275
276        $objErr->doFunc(array("取扱商品", "good_traded", LLTEXT_LEN), array("MAX_LENGTH_CHECK"));
277        $objErr->doFunc(array("メッセージ", "message", LLTEXT_LEN), array("MAX_LENGTH_CHECK"));
278        if(!isset($array['downloadable_days_unlimited']) && $array['downloadable_days_unlimited'] != "1") {
279            $objErr->doFunc(array("ダウンロード可能日数", "downloadable_days", DOWNLOAD_DAYS_LEN), array("EXIST_CHECK", "ZERO_CHECK", "NUM_CHECK", "MAX_LENGTH_CHECK"));
280        }
281        $objErr->doFunc(array("緯度", "latitude", STEXT_LEN), array("NUM_POINT_CHECK", "MAX_LENGTH_CHECK"));
282        $objErr->doFunc(array("経度", "longitude", STEXT_LEN), array("NUM_POINT_CHECK", "MAX_LENGTH_CHECK"));
283        return $objErr->arrErr;
284    }
285}
286?>
Note: See TracBrowser for help on using the repository browser.