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

Revision 21810, 11.3 KB checked in by nanasess, 12 years ago (diff)

#1573 プライマリーキーが無いテーブルの改善

  • dtb_baseinfo, mtb_zip にはプライマリーキーとなるカラムを追加

#800 SQL標準に準拠する

  • rule -> rule_max
  • 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     *
138     * @return void
139     */
140    function destroy() {
141        parent::destroy();
142    }
143
144    // 基本情報用のカラムを取り出す。
145    function lfGetCol() {
146        $arrCol = array(
147            'company_name',
148            'company_kana',
149            'shop_name',
150            'shop_kana',
151            'shop_name_eng',
152            'zip01',
153            'zip02',
154            'pref',
155            'addr01',
156            'addr02',
157            'tel01',
158            'tel02',
159            'tel03',
160            'fax01',
161            'fax02',
162            'fax03',
163            'business_hour',
164            'email01',
165            'email02',
166            'email03',
167            'email04',
168            'tax',
169            'tax_rule',
170            'free_rule',
171            'good_traded',
172            'message',
173            'regular_holiday_ids',
174            'latitude',
175            'longitude',
176            'downloadable_days',
177            'downloadable_days_unlimited'
178        );
179        return $arrCol;
180    }
181
182    function lfUpdateData($array) {
183        $objQuery =& SC_Query_Ex::getSingletonInstance();
184        $arrCol = $this->lfGetCol();
185        foreach ($arrCol as $val) {
186            //配列の場合は、パイプ区切りの文字列に変換
187            if (is_array($array[$val])) {
188                $sqlval[$val] = implode('|', $array[$val]);
189            } else {
190                $sqlval[$val] = $array[$val];
191            }
192        }
193        $sqlval['update_date'] = 'CURRENT_TIMESTAMP';
194        // UPDATEの実行
195        $ret = $objQuery->update('dtb_baseinfo', $sqlval);
196
197        GC_Utils_Ex::gfPrintLog('dtb_baseinfo に UPDATE を実行しました。');
198    }
199
200    function lfInsertData($array) {
201        $objQuery =& SC_Query_Ex::getSingletonInstance();
202        $arrCol = $this->lfGetCol();
203        foreach ($arrCol as $val) {
204            $sqlval[$val] = $array[$val];
205        }
206        $sqlval['id'] = 1;
207        $sqlval['update_date'] = 'CURRENT_TIMESTAMP';
208        // INSERTの実行
209        $ret = $objQuery->insert('dtb_baseinfo', $sqlval);
210
211        GC_Utils_Ex::gfPrintLog('dtb_baseinfo に INSERT を実行しました。');
212    }
213
214    function lfInitParam(&$objFormParam, $post) {
215        $objFormParam->addParam('会社名', 'company_name', STEXT_LEN, 'KVa',  array('MAX_LENGTH_CHECK'));
216        $objFormParam->addParam('会社名(フリガナ)', 'company_kana', STEXT_LEN, 'KVC',  array('KANA_CHECK','MAX_LENGTH_CHECK'));
217
218        $objFormParam->addParam('店名', 'shop_name', STEXT_LEN, 'KVa', array('EXIST_CHECK','MAX_LENGTH_CHECK'));
219        $objFormParam->addParam('店名(フリガナ)', 'shop_kana',  STEXT_LEN, 'KVC', array('KANA_CHECK','MAX_LENGTH_CHECK'));
220        $objFormParam->addParam('店名(英語表記)', 'shop_name_eng',MTEXT_LEN, 'a', array('GRAPH_CHECK','MAX_LENGTH_CHECK'));
221        // 郵便番号チェック
222        $objFormParam->addParam('郵便番号1', 'zip01', ZIP01_LEN, 'n', array('EXIST_CHECK', 'NUM_CHECK','NUM_COUNT_CHECK'));
223        $objFormParam->addParam('郵便番号2', 'zip02', ZIP02_LEN, 'n', array('EXIST_CHECK', 'NUM_CHECK','NUM_COUNT_CHECK'));
224        // 所在地チェック
225        $objFormParam->addParam('都道府県', 'pref', '', 'n', array('EXIST_CHECK'));
226        $objFormParam->addParam('所在地1', 'addr01', MTEXT_LEN, 'KVa', array('EXIST_CHECK', 'MAX_LENGTH_CHECK'));
227        $objFormParam->addParam('所在地2', 'addr02', MTEXT_LEN, 'KVa', array('EXIST_CHECK', 'MAX_LENGTH_CHECK'));
228        // メールチェック
229        $objFormParam->addParam('商品注文受付メールアドレス', 'email01', null, 'a', array('EXIST_CHECK', 'EMAIL_CHECK', 'EMAIL_CHAR_CHECK'));
230        $objFormParam->addParam('問い合わせ受付メールアドレス', 'email02', null, 'a', array('EXIST_CHECK', 'EMAIL_CHECK', 'EMAIL_CHAR_CHECK'));
231        $objFormParam->addParam('メール送信元メールアドレス', 'email03', null, 'a', array('EXIST_CHECK', 'EMAIL_CHECK', 'EMAIL_CHAR_CHECK'));
232        $objFormParam->addParam('送信エラー受付メールアドレス', 'email04', null, 'a', array('EXIST_CHECK', 'EMAIL_CHECK', 'EMAIL_CHAR_CHECK'));
233
234        // 電話番号
235        $objFormParam->addParam('電話番号1', 'tel01', TEL_ITEM_LEN, 'n', array('NUM_CHECK', 'MAX_LENGTH_CHECK'));
236        $objFormParam->addParam('電話番号2', 'tel02', TEL_ITEM_LEN, 'n', array('NUM_CHECK', 'MAX_LENGTH_CHECK'));
237        $objFormParam->addParam('電話番号3', 'tel03', TEL_ITEM_LEN, 'n', array('NUM_CHECK', 'MAX_LENGTH_CHECK'));
238
239        // FAX番号
240        $objFormParam->addParam('FAX番号1', 'fax01', TEL_ITEM_LEN, 'n', array('NUM_CHECK', 'MAX_LENGTH_CHECK'));
241        $objFormParam->addParam('FAX番号2', 'fax02', TEL_ITEM_LEN, 'n', array('NUM_CHECK', 'MAX_LENGTH_CHECK'));
242        $objFormParam->addParam('FAX番号3', 'fax03', TEL_ITEM_LEN, 'n', array('NUM_CHECK', 'MAX_LENGTH_CHECK'));
243
244        // その他
245        $objFormParam->addParam('消費税率', 'tax', PERCENTAGE_LEN, 'n', array('EXIST_CHECK', 'NUM_CHECK', 'MAX_LENGTH_CHECK'));
246        $objFormParam->addParam('課税規則 ', 'tax_rule', PERCENTAGE_LEN, 'n', array('EXIST_CHECK', 'NUM_CHECK', 'MAX_LENGTH_CHECK'));
247        $objFormParam->addParam('送料無料条件', 'free_rule', PRICE_LEN, 'n', array('NUM_CHECK', 'MAX_LENGTH_CHECK'));
248        $objFormParam->addParam('店舗営業時間', 'business_hour', STEXT_LEN, 'KVa', array('MAX_LENGTH_CHECK'));
249
250        $objFormParam->addParam('取扱商品', 'good_traded', LLTEXT_LEN, '', array('MAX_LENGTH_CHECK'));
251        $objFormParam->addParam('メッセージ', 'message', LLTEXT_LEN, '', array('MAX_LENGTH_CHECK'));
252
253        if (!isset($post['downloadable_days_unlimited']) && $post['downloadable_days_unlimited'] != '1') {
254            $objFormParam->addParam('ダウンロード可能日数', 'downloadable_days', DOWNLOAD_DAYS_LEN, 'n', array('EXIST_CHECK', 'ZERO_CHECK', 'NUM_CHECK', 'MAX_LENGTH_CHECK'));
255        } else {
256            $objFormParam->addParam('ダウンロード無制限', 'downloadable_days_unlimited', array('EXIST_CHECK'));
257        }
258        $objFormParam->addParam('緯度', 'latitude', STEXT_LEN, '',  array('MAX_LENGTH_CHECK'));
259        $objFormParam->addParam('軽度', 'longitude', STEXT_LEN, '',  array('MAX_LENGTH_CHECK'));
260
261        $objFormParam->addParam('定休日', 'regular_holiday_ids', INT_LEN, 'n', array('MAX_LENGTH_CHECK'));
262    }
263
264    // 入力エラーチェック
265    function lfErrorCheck(&$objFormParam) {
266        $arrErr = $objFormParam->checkError();
267        $post = $objFormParam->getHashArray();
268
269        $objErr = new SC_CheckError_Ex($post);
270        $objErr->doFunc(array('郵便番号', 'zip01', 'zip02'), array('ALL_EXIST_CHECK'));
271
272        // 電話番号チェック
273        $objErr->doFunc(array('TEL', 'tel01', 'tel02', 'tel03'), array('TEL_CHECK'));
274        $objErr->doFunc(array('FAX', 'fax01', 'fax02', 'fax03'), array('TEL_CHECK'));
275
276        $objErr->doFunc(array('緯度', 'latitude', STEXT_LEN), array('NUM_POINT_CHECK', 'MAX_LENGTH_CHECK'));
277        $objErr->doFunc(array('経度', 'longitude', STEXT_LEN), array('NUM_POINT_CHECK', 'MAX_LENGTH_CHECK'));
278
279        return array_merge((array)$arrErr, (array)$objErr->arrErr);
280    }
281}
Note: See TracBrowser for help on using the repository browser.