source: branches/version-2_12-dev/data/class/pages/admin/products/LC_Page_Admin_Products_ProductClass.php @ 21743

Revision 21743, 32.1 KB checked in by AMUAMU, 12 years ago (diff)

#1754 (exit;を個別の処理でしない) #1692 (プラグイン機能) 各ファイルでフックポイントの呼出を書かないで、自動的にフックポイントを呼び出すように修正。

  • 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_Products_ProductClass 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 = 'products/product_class.tpl';
47        $this->tpl_mainno = 'products';
48        $this->tpl_subno = 'product';
49        $this->tpl_maintitle = '商品管理';
50        $this->tpl_subtitle = '商品登録(商品規格)';
51        $masterData = new SC_DB_MasterData_Ex();
52        $this->arrProductType = $masterData->getMasterData('mtb_product_type');
53        // 規格プルダウンのリスト
54        $this->arrClass = $this->getAllClass();
55    }
56
57    /**
58     * Page のプロセス.
59     *
60     * @return void
61     */
62    function process() {
63        $this->action();
64        $this->sendResponse();
65    }
66
67    /**
68     * Page のアクション.
69     *
70     * @return void
71     */
72    function action() {
73
74        // 商品マスターの検索条件パラメーターを初期化
75        $objFormParam = new SC_FormParam_Ex();
76        $this->initParam($objFormParam);
77
78        $objFormParam->setParam($_POST);
79        $objFormParam->convParam();
80
81        $this->arrSearchHidden = $objFormParam->getSearchArray();
82
83        switch ($this->getMode()) {
84
85            // 編集実行
86            case 'edit':
87                $this->arrErr = $this->lfCheckProductsClass($objFormParam);
88
89                // エラーの無い場合は確認画面を表示
90                if (SC_Utils_Ex::isBlank($this->arrErr)) {
91                    $this->tpl_mainpage = 'products/product_class_confirm.tpl';
92                    $this->doDisp($objFormParam);
93                    $this->fillCheckboxesValue('stock_unlimited', $_POST['total']);
94                    $objFormParam->setParam($_POST);
95                    $objFormParam->convParam();
96                }
97                // エラーが発生した場合
98                else {
99                    $objFormParam->setParam($_POST);
100                    $objFormParam->convParam();
101                }
102                break;
103
104            // 削除
105            case 'delete':
106                $this->doDelete($objFormParam->getValue('product_id'));
107                $objFormParam->setValue('class_id1', '');
108                $objFormParam->setValue('class_id2', '');
109                $this->doDisp($objFormParam);
110                break;
111
112            // 初期表示
113            case 'pre_edit':
114                $this->doPreEdit($objFormParam);
115                break;
116
117            // 「表示する」ボタン押下時
118            case 'disp':
119                $this->arrErr = $this->lfCheckSelectClass();
120                if (SC_Utils_Ex::isBlank($this->arrErr)) {
121                    $this->doDisp($objFormParam);
122                    $this->initDispParam($objFormParam);
123                }
124                break;
125
126            // ダウンロード商品ファイルアップロード
127            case 'file_upload':
128                $this->doFileUpload($objFormParam);
129                break;
130
131            // ダウンロードファイルの削除
132            case 'file_delete':
133                $this->doFileDelete($objFormParam);
134                break;
135
136            // 確認画面からの戻り
137            case 'confirm_return':
138                $this->doPreEdit($objFormParam);
139                $objFormParam->setParam($_POST);
140                $objFormParam->convParam();
141                break;
142
143            case 'complete':
144                $this->tpl_mainpage = 'products/product_class_complete.tpl';
145                $this->doUploadComplete($objFormParam);
146                $this->registerProductClass($objFormParam->getHashArray(),
147                                            $objFormParam->getValue('product_id'),
148                                            $objFormParam->getValue('total'));
149                break;
150
151            default:
152                break;
153        }
154
155        // 登録対象の商品名を取得
156        $objFormParam->setValue('product_name',
157                $this->getProductName($objFormParam->getValue('product_id')));
158        $this->arrForm = $objFormParam->getFormParamList();
159
160    }
161
162    /**
163     * デストラクタ.
164     *
165     * @return void
166     */
167    function destroy() {
168        parent::destroy();
169    }
170
171    /**
172     * パラメーター初期化
173     *
174     * @param SC_FormParam $objFormParam SC_FormParam インスタンス
175     * @return void
176     */
177    function initParam(&$objFormParam) {
178        // 商品マスター検索パラメーター引き継ぎ
179        $objFormParam->addParam('商品ID', 'product_id', INT_LEN, 'n', array('NUM_CHECK', 'MAX_LENGTH_CHECK'));
180        $objFormParam->addParam('カテゴリID', 'category_id', STEXT_LEN, 'n', array('SPTAB_CHECK', 'MAX_LENGTH_CHECK'));
181        $objFormParam->addParam('ページ送り番号','search_pageno', INT_LEN, 'n', array('MAX_LENGTH_CHECK', 'NUM_CHECK'));
182        $objFormParam->addParam('表示件数', 'search_page_max', INT_LEN, 'n', array('MAX_LENGTH_CHECK', 'NUM_CHECK'));
183        $objFormParam->addParam('商品ID', 'search_product_id', INT_LEN, 'n', array('NUM_CHECK', 'MAX_LENGTH_CHECK'));
184        $objFormParam->addParam('商品コード', 'search_product_code', STEXT_LEN, 'KVna', array('SPTAB_CHECK', 'MAX_LENGTH_CHECK'));
185        $objFormParam->addParam('商品名', 'search_name', STEXT_LEN, 'KVa', array('SPTAB_CHECK', 'MAX_LENGTH_CHECK'));
186        $objFormParam->addParam('カテゴリ', 'search_category_id', STEXT_LEN, 'n', array('SPTAB_CHECK', 'MAX_LENGTH_CHECK'));
187        $objFormParam->addParam('種別', 'search_status', INT_LEN, 'n', array('MAX_LENGTH_CHECK'));
188        $objFormParam->addParam('開始年', 'search_startyear', INT_LEN, 'n', array('MAX_LENGTH_CHECK', 'NUM_CHECK'));
189        $objFormParam->addParam('開始月', 'search_startmonth', INT_LEN, 'n', array('MAX_LENGTH_CHECK', 'NUM_CHECK'));
190        $objFormParam->addParam('開始日', 'search_startday', INT_LEN, 'n', array('MAX_LENGTH_CHECK', 'NUM_CHECK'));
191        $objFormParam->addParam('終了年', 'search_endyear', INT_LEN, 'n', array('MAX_LENGTH_CHECK', 'NUM_CHECK'));
192        $objFormParam->addParam('終了月', 'search_endmonth', INT_LEN, 'n', array('MAX_LENGTH_CHECK', 'NUM_CHECK'));
193        $objFormParam->addParam('終了日', 'search_endday', INT_LEN, 'n', array('MAX_LENGTH_CHECK', 'NUM_CHECK'));
194        $objFormParam->addParam('商品ステータス', 'search_product_statuses', INT_LEN, 'n', array('MAX_LENGTH_CHECK'));
195
196        // 規格プルダウン
197        $objFormParam->addParam('規格1', 'class_id1', INT_LEN, 'n', array('MAX_LENGTH_CHECK', 'NUM_CHECK'));
198        $objFormParam->addParam('規格2', 'class_id2', INT_LEN, 'n', array('MAX_LENGTH_CHECK', 'NUM_CHECK'));
199
200        // 商品規格
201        $objFormParam->addParam('商品規格数', 'total', INT_LEN, 'n', array('MAX_LENGTH_CHECK', 'NUM_CHECK'));
202        $objFormParam->addParam('商品名', 'product_name', STEXT_LEN, 'KVa', array('MAX_LENGTH_CHECK'));
203        $objFormParam->addParam('商品コード', 'product_code', STEXT_LEN, 'KVa', array('MAX_LENGTH_CHECK'));
204        $objFormParam->addParam('規格ID1', 'classcategory_id1', INT_LEN, 'n', array('MAX_LENGTH_CHECK', 'NUM_CHECK'));
205        $objFormParam->addParam('規格ID2', 'classcategory_id2', INT_LEN, 'n', array('MAX_LENGTH_CHECK', 'NUM_CHECK'));
206        $objFormParam->addParam('規格名1', 'classcategory_name1', STEXT_LEN, 'KVa', array('MAX_LENGTH_CHECK'));
207        $objFormParam->addParam('規格名2', 'classcategory_name2', STEXT_LEN, 'KVa', array('MAX_LENGTH_CHECK'));
208        $objFormParam->addParam('商品規格ID', 'product_class_id', INT_LEN, 'n', array('MAX_LENGTH_CHECK', 'NUM_CHECK'));
209        $objFormParam->addParam('在庫数', 'stock', AMOUNT_LEN, 'n', array('NUM_CHECK', 'MAX_LENGTH_CHECK'));
210        $objFormParam->addParam('在庫数', 'stock_unlimited', INT_LEN, 'n', array('MAX_LENGTH_CHECK', 'NUM_CHECK'));
211        $objFormParam->addParam(NORMAL_PRICE_TITLE, 'price01', PRICE_LEN, 'n', array('NUM_CHECK', 'MAX_LENGTH_CHECK'));
212        $objFormParam->addParam(SALE_PRICE_TITLE, 'price02', PRICE_LEN, 'n', array('NUM_CHECK', 'MAX_LENGTH_CHECK'));
213        $objFormParam->addParam('商品種別', 'product_type_id', INT_LEN, 'n', array('MAX_LENGTH_CHECK', 'NUM_CHECK'));
214        $objFormParam->addParam('削除フラグ', 'del_flg', INT_LEN, 'n', array('MAX_LENGTH_CHECK', 'NUM_CHECK'));
215        $objFormParam->addParam('ダウンロード販売用ファイル名', 'down_filename', STEXT_LEN, 'KVa', array('MAX_LENGTH_CHECK'));
216        $objFormParam->addParam('ダウンロード販売用ファイル名', 'down_realfilename', STEXT_LEN, 'KVa', array('MAX_LENGTH_CHECK'));
217        $objFormParam->addParam('チェックボックス', 'check', INT_LEN, 'n', array('MAX_LENGTH_CHECK', 'NUM_CHECK'));
218        $objFormParam->addParam('ファイルアップロード用キー', 'upload_index', STEXT_LEN, 'KVa', array('MAX_LENGTH_CHECK'));
219    }
220
221    /**
222     * 規格の登録または更新を行う.
223     *
224     * @param array $arrList 入力フォームの内容
225     * @param integer $product_id 登録を行う商品ID
226     */
227    function registerProductClass($arrList, $product_id, $total) {
228        $objQuery =& SC_Query_Ex::getSingletonInstance();
229        $objDb = new SC_Helper_DB_Ex();
230
231        $objQuery->begin();
232
233        $arrProductsClass = $objQuery->select('*', 'dtb_products_class', 'product_id = ?', array($product_id));
234        $arrExists = array();
235        foreach ($arrProductsClass as $val) {
236            $arrExists[$val['product_class_id']] = $val;
237        }
238
239        // デフォルト値として設定する値を取得しておく
240        $arrDefault = $this->getProductsClass($product_id);
241
242        $objQuery->delete('dtb_products_class', 'product_id = ? AND (classcategory_id1 <> 0 OR classcategory_id2 <> 0)', array($product_id));
243
244        for ($i = 0; $i < $total; $i++) {
245            $del_flg = SC_Utils_Ex::isBlank($arrList['check'][$i]) ? 1 : 0;
246            $stock_unlimited = SC_Utils_Ex::isBlank($arrList['stock_unlimited'][$i]) ? 0 : $arrList['stock_unlimited'][$i];
247            $price02 = SC_Utils_Ex::isBlank($arrList['price02'][$i]) ? 0 : $arrList['price02'][$i];
248            // dtb_products_class 登録/更新用
249            $registerKeys = array(
250                'classcategory_id1', 'classcategory_id2',
251                'product_code', 'stock', 'price01', 'product_type_id',
252                'down_filename', 'down_realfilename',
253            );
254
255            $arrPC = array();
256            foreach ($registerKeys as $key) {
257                $arrPC[$key] = $arrList[$key][$i];
258            }
259            $arrPC['product_id'] = $product_id;
260            $arrPC['sale_limit'] = $arrDefault['sale_limit'];
261            $arrPC['deliv_fee'] = $arrDefault['deliv_fee'];
262            $arrPC['point_rate'] = $arrDefault['point_rate'];
263            $arrPC['stock_unlimited'] = $stock_unlimited;
264            $arrPC['price02'] = $price02;
265
266            // 該当関数が無いため, セッションの値を直接代入
267            $arrPC['creator_id'] = $_SESSION['member_id'];
268            $arrPC['update_date'] = 'CURRENT_TIMESTAMP';
269            $arrPC['del_flg'] = $del_flg;
270
271            $arrPC['create_date'] = 'CURRENT_TIMESTAMP';
272            // 更新の場合は, product_class_id を使い回す
273            if (!SC_Utils_Ex::isBlank($arrList['product_class_id'][$i])) {
274                $arrPC['product_class_id'] = $arrList['product_class_id'][$i];
275            } else {
276                $arrPC['product_class_id'] = $objQuery->nextVal('dtb_products_class_product_class_id');
277            }
278
279            /*
280             * チェックを入れない商品は product_type_id が NULL になるので, 0 を入れる
281             */
282            $arrPC['product_type_id'] = SC_Utils_Ex::isBlank($arrPC['product_type_id']) ? 0 : $arrPC['product_type_id'];
283
284            $objQuery->insert('dtb_products_class', $arrPC);
285        }
286
287        // 規格無し用の商品規格を非表示に
288        $arrBlank['del_flg'] = 1;
289        $arrBlank['update_date'] = 'CURRENT_TIMESTAMP';
290        $objQuery->update('dtb_products_class', $arrBlank,
291                          'product_id = ? AND classcategory_id1 = 0 AND classcategory_id2 = 0',
292                          array($product_id));
293
294        // 件数カウントバッチ実行
295        $objDb->sfCountCategory($objQuery);
296        $objQuery->commit();
297    }
298
299    /**
300     * 規格選択エラーチェックを行う
301     *
302     * ※SC_FormParamで対応していないエラーチェックのため, SC_CheckErrorを使用している.
303     *
304     * @return array エラーの配列
305     */
306    function lfCheckSelectClass() {
307        $objErr = new SC_CheckError_Ex();
308        $objErr->doFunc(array('規格1', 'class_id1'), array('EXIST_CHECK'));
309        $objErr->doFunc(array('規格', 'class_id1', 'select_class_id2'), array('TOP_EXIST_CHECK'));
310        $objErr->doFunc(array('規格1', '規格2', 'class_id1', 'class_id2'), array('DIFFERENT_CHECK'));
311        return $objErr->arrErr;
312    }
313
314    /**
315     * 商品規格エラーチェック.
316     *
317     * @param SC_FormParam $objFormParam SC_FormParam インスタンス
318     * @return array エラー結果の配列
319     */
320    function lfCheckProductsClass(&$objFormParam) {
321        $arrValues = $objFormParam->getHashArray();
322        $arrErr = $objFormParam->checkError();
323        $total = $objFormParam->getValue('total');
324
325        if (SC_Utils_Ex::isBlank($arrValues['check'])) {
326            $arrErr['check_empty'] = '※ 規格が選択されていません。<br />';
327        }
328
329        for ($i = 0; $i < $total; $i++) {
330
331            /*
332             * チェックボックスの入っている項目のみ, 必須チェックを行う.
333             * エラーを配列で返す必要があるため, SC_CheckError を使用しない.
334             */
335            if (!SC_Utils_Ex::isBlank($arrValues['check'][$i])) {
336
337                /*
338                 * 販売価格の必須チェック
339                 */
340                if (SC_Utils_Ex::isBlank($arrValues['price02'][$i])) {
341                    $arrErr['price02'][$i] = '※ ' . SALE_PRICE_TITLE . 'が入力されていません。<br />';
342                }
343                /*
344                 * 在庫数の必須チェック
345                 */
346                if ((SC_Utils_Ex::isBlank($arrValues['stock_unlimited'][$i]) || $arrValues['stock_unlimited'][$i] != 1)
347                    && SC_Utils_Ex::isBlank($arrValues['stock'][$i])
348                ) {
349                    $arrErr['stock'][$i] = '※ 在庫数が入力されていません。<br />';
350                }
351                /*
352                 * 商品種別の必須チェック
353                 */
354                if (SC_Utils_Ex::isBlank($arrValues['product_type_id'][$i])) {
355                    $arrErr['product_type_id'][$i] = '※ 商品種別は、いずれかを選択してください。<br />';
356                }
357                /*
358                 * ダウンロード商品の必須チェック
359                 */
360                if ($arrValues['product_type_id'][$i] == PRODUCT_TYPE_DOWNLOAD) {
361                    if (SC_Utils_Ex::isBlank($arrValues['down_filename'][$i])) {
362                        $arrErr['down_filename'][$i] = '※ ダウンロード商品の場合はダウンロードファイル名を入力してください。<br />';
363                    }
364                    if (SC_Utils_Ex::isBlank($arrValues['down_realfilename'][$i])) {
365                        $arrErr['down_realfilename'][$i] = '※ ダウンロード商品の場合はダウンロード商品用ファイルをアップロードしてください。<br />';
366                    }
367                }
368                /*
369                 * 通常商品チェック
370                 */
371                else if ($arrValues['product_type_id'][$i] == PRODUCT_TYPE_NORMAL) {
372                    if (!SC_Utils_Ex::isBlank($arrValues['down_filename'][$i])) {
373                        $arrErr['down_filename'][$i] = '※ 通常商品の場合はダウンロードファイル名を設定できません。<br />';
374                    }
375                    if (!SC_Utils_Ex::isBlank($arrValues['down_realfilename'][$i])) {
376                        $arrErr['down_realfilename'][$i] = '※ 実商品の場合はダウンロード商品用ファイルをアップロードできません。<br />ファイルを取り消してください。<br />';
377                    }
378                }
379            }
380        }
381        return $arrErr;
382    }
383
384    /**
385     * 規格の組み合わせ一覧を表示する.
386     *
387     * 規格1, 規格2における規格分類のすべての組み合わせを取得し,
388     * 該当商品の商品規格の内容を取得後, フォームに設定する.
389     *
390     * @param SC_FormParam $objFormParam SC_FormParam インスタンス
391     * @return void
392     */
393    function doDisp(&$objFormParam) {
394        $product_id = $objFormParam->getValue('product_id');
395        $class_id1 = $objFormParam->getValue('class_id1');
396        $class_id2 = $objFormParam->getValue('class_id2');
397
398        // すべての組み合わせを取得し, フォームに設定
399        $arrClassCat = $this->getAllClassCategory($class_id1, $class_id2);
400        $total = count($arrClassCat);
401        $objFormParam->setValue('total', $total);
402        $objFormParam->setParam(SC_Utils_Ex::sfSwapArray($arrClassCat));
403
404        // class_id1, class_id2 を, 入力値で上書き
405        $objFormParam->setValue('class_id1', $class_id1);
406        $objFormParam->setValue('class_id2', $class_id2);
407
408        // 商品情報を取得し, フォームに設定
409        $arrProductsClass = $this->getProductsClass($product_id);
410
411        foreach ($arrProductsClass as $key => $val) {
412            // 組み合わせ数分の値の配列を生成する
413            $arrValues = array();
414            for ($i = 0; $i < $total; $i++) {
415                $arrValues[] = $val;
416            }
417            $objFormParam->setValue($key, $arrValues);
418        }
419        // 商品種別を 1 に初期化
420        $objFormParam->setValue('product_type_id', array_pad(array(), $total, 1));
421    }
422
423    /**
424     * 「表示する」ボタンをクリックされたときのパラメーター初期化処理
425     *
426     * @param SC_FormParam $objFormParam SC_FormParam インスタンス
427     * @return void
428     */
429    function initDispParam(&$objFormParam) {
430        // 登録チェックボックス初期化(すべてチェックを外す)
431        $objFormParam->setValue('check', '');
432
433        // 規格2が選択されていない場合、規格2名称初期化
434        $class_id2 = $objFormParam->getValue('class_id2');
435        if (SC_Utils_Ex::isBlank($class_id2) == true) {
436            $objFormParam->setValue('classcategory_name2', '');
437        }
438    }
439
440    /**
441     * 規格編集画面を表示する
442     *
443     * @param integer $product_id 商品ID
444     * @param bool $existsValue
445     * @param bool $usepostValue
446     */
447    function doPreEdit(&$objFormParam) {
448        $product_id = $objFormParam->getValue('product_id');
449        $objProduct = new SC_Product_Ex();
450        $existsProductsClass = $objProduct->getProductsClassFullByProductId($product_id);
451
452        // 規格のデフォルト値(すべての組み合わせ)を取得し, フォームに反映
453        $class_id1 = $existsProductsClass[0]['class_id1'];
454        $class_id2 = $existsProductsClass[0]['class_id2'];
455        $objFormParam->setValue('class_id1', $class_id1);
456        $objFormParam->setValue('class_id2', $class_id2);
457        $this->doDisp($objFormParam);
458
459        /*
460         * 登録済みのデータで, フォームの値を上書きする.
461         *
462         * 登録済みデータと, フォームの値は, 配列の形式が違うため,
463         * 同じ形式の配列を生成し, マージしてフォームの値を上書きする
464         */
465        $arrKeys = array('classcategory_id1', 'classcategory_id2','product_code',
466            'classcategory_name1', 'classcategory_name2', 'stock',
467            'stock_unlimited', 'price01', 'price02',
468            'product_type_id', 'down_filename', 'down_realfilename', 'upload_index',
469        );
470        $arrFormValues = $objFormParam->getSwapArray($arrKeys);
471        // フォームの規格1, 規格2をキーにした配列を生成
472        $arrClassCatKey = array();
473        foreach ($arrFormValues as $formValue) {
474            $arrClassCatKey[$formValue['classcategory_id1']][$formValue['classcategory_id2']] = $formValue;
475        }
476        // 登録済みデータをマージ
477        foreach ($existsProductsClass as $existsValue) {
478            $arrClassCatKey[$existsValue['classcategory_id1']][$existsValue['classcategory_id2']] = $existsValue;
479        }
480
481        // 規格のデフォルト値に del_flg をつけてマージ後の1次元配列を生成
482        $arrMergeProductsClass = array();
483        foreach ($arrClassCatKey as $arrC1) {
484            foreach ($arrC1 as $arrValues) {
485                $arrValues['del_flg'] = (string) $arrValues['del_flg'];
486                if (SC_Utils_Ex::isBlank($arrValues['del_flg'])
487                    || $arrValues['del_flg'] === '1') {
488                    $arrValues['del_flg'] = '1';
489                } else {
490                    $arrValues['del_flg'] = '0';
491                }
492                $arrMergeProductsClass[] = $arrValues;
493            }
494        }
495
496        // 登録済みのデータで上書き
497        $objFormParam->setParam(SC_Utils_Ex::sfSwapArray($arrMergeProductsClass));
498
499        // $arrMergeProductsClass で product_id が配列になってしまうため数値で上書き
500        $objFormParam->setValue('product_id', $product_id);
501
502        // check を設定
503        $arrChecks = array();
504        $index = 0;
505        foreach ($objFormParam->getValue('del_flg') as $key => $val) {
506            if ($val === '0') {
507                $arrChecks[$index] = 1;
508            }
509            $index++;
510        }
511        $objFormParam->setValue('check', $arrChecks);
512
513        // class_id1, class_id2 を取得値で上書き
514        $objFormParam->setValue('class_id1', $class_id1);
515        $objFormParam->setValue('class_id2', $class_id2);
516    }
517
518    /**
519     * 規格の削除を実行する
520     *
521     * @param $product_id
522     * @return void
523     */
524    function doDelete($product_id) {
525        $objQuery =& SC_Query_Ex::getSingletonInstance();
526
527        $objQuery->begin();
528
529        // 商品規格なしデータの復元
530        $where = 'product_id = ? AND classcategory_id1 = 0 AND classcategory_id2 = 0';
531        $objQuery->update('dtb_products_class', array('del_flg' => 0), $where, array($product_id));
532
533        // 商品規格データの削除
534        $where = 'product_id = ? AND (classcategory_id1 <> 0 OR classcategory_id2 <> 0)';
535        $objQuery->delete('dtb_products_class', $where, array($product_id));
536
537        $objQuery->commit();
538
539        // 在庫無し商品の非表示対応
540        if (NOSTOCK_HIDDEN) {
541            // 件数カウントバッチ実行
542            $objDb = new SC_Helper_DB_Ex();
543            $objDb->sfCountCategory($objQuery);
544        }
545    }
546
547    /**
548     * ファイルアップロードを行う.
549     *
550     * 以下のチェックを行い, ファイルを一時領域へアップロードする.
551     * 1. ファイルサイズチェック
552     * 2. 拡張子チェック
553     *
554     * TODO
555     * SC_CheckError クラスや, SC_UploadFile クラスが多次元配列に対応して
556     * いないため, 独自のロジックを使用している.
557     *
558     * @param SC_FormParam $objFormParam SC_FormParam インスタンス
559     * @return void
560     */
561    function doFileUpload(&$objFormParam) {
562        $index   = $objFormParam->getValue('upload_index');
563        $arrDownRealFiles = $objFormParam->getValue('down_realfilename');
564
565        if ($_FILES['down_realfilename']['size'][$index] <= 0) {
566            $this->arrErr['down_realfilename'][$index] = '※ ファイルがアップロードされていません';
567        } else if ($_FILES['down_realfilename']['size'][$index] > DOWN_SIZE *  1024) {
568            $size = DOWN_SIZE;
569            $byte = 'KB';
570            if ($size >= 1000) {
571                $size = $size / 1000;
572                $byte = 'MB';
573            }
574            $this->arrErr['down_realfilename'][$index] = '※ ダウンロード販売用ファイル名のファイルサイズは' . $size . $byte . '以下のものを使用してください。<br />';
575        } else {
576            // SC_CheckError::FILE_EXT_CHECK とのソース互換を強めるための配列
577            $value = array(
578                0 => 'ダウンロード販売用ファイル名',
579                1 => 'down_realfilename',
580                2 => explode(',', DOWNLOAD_EXTENSION),
581            );
582            // ▼SC_CheckError::FILE_EXT_CHECK から移植
583            $match = false;
584            if (strlen($_FILES[$value[1]]['name'][$index]) >= 1) {
585                $filename = $_FILES[$value[1]]['name'][$index];
586
587                foreach ($value[2] as $check_ext) {
588                    $match = preg_match('/' . preg_quote('.' . $check_ext) . '$/i', $filename) >= 1;
589                    if ($match === true) {
590                        break 1;
591                    }
592                }
593            }
594
595            if ($match === false) {
596                $str_ext = implode('・', $value[2]);
597                $this->arrErr[$value[1]][$index] = '※ ' . $value[0] . 'で許可されている形式は、' . $str_ext . 'です。<br />';
598            // ▲SC_CheckError::FILE_EXT_CHECK から移植
599            } else {
600                $uniqname = date('mdHi') . '_' . uniqid('').'.';
601                $temp_file = preg_replace("/^.*\./", $uniqname, $_FILES['down_realfilename']['name'][$index]);
602
603                if (move_uploaded_file($_FILES['down_realfilename']['tmp_name'][$index], DOWN_TEMP_REALDIR . $temp_file)) {
604                    $arrDownRealFiles[$index] = $temp_file;
605                    $objFormParam->setValue('down_realfilename', $arrDownRealFiles);
606                    GC_Utils_Ex::gfPrintLog($_FILES['down_realfilename']['name'][$index] .' -> '. realpath(DOWN_TEMP_REALDIR . $temp_file));
607                } else {
608                    $objErr->arrErr[$keyname] = '※ ファイルのアップロードに失敗しました。<br />';
609                    GC_Utils_Ex::gfPrintLog('File Upload Error!: ' . $_FILES['down_realfilename']['name'][$index] . ' -> ' . DOWN_TEMP_REALDIR . $temp_file);
610                }
611            }
612        }
613    }
614
615    /**
616     * アップロードしたファイルを削除する.
617     *
618     * TODO 一時ファイルの削除
619     *
620     * @param SC_FormParam $objFormParam SC_FormParam インスタンス
621     * @return void
622     */
623    function doFileDelete(&$objFormParam) {
624        $objImage = new SC_Image_Ex(DOWN_TEMP_REALDIR);
625        $arrRealFileName = $objFormParam->getValue('down_realfilename');
626        $index = $objFormParam->getValue('upload_index');
627        $objImage->deleteImage($arrRealFileName[$index], DOWN_SAVE_REALDIR);
628        $arrRealFileName[$index] = '';
629        $objFormParam->setValue('down_realfilename', $arrRealFileName);
630    }
631
632    /**
633     * アップロードした一時ファイルを保存する.
634     *
635     * @param SC_FormParam $objFormParam SC_FormParam インスタンス
636     * @return void
637     */
638    function doUploadComplete(&$objFormParam) {
639        $objImage = new SC_Image_Ex(DOWN_TEMP_REALDIR);
640        $arrRealFileName = $objFormParam->getValue('down_realfilename');
641        foreach ($arrRealFileName as $real_file_name) {
642            $objImage->moveTempImage($real_file_name, DOWN_SAVE_REALDIR);
643        }
644    }
645
646    /**
647     * 規格ID1, 規格ID2の規格分類すべてを取得する.
648     *
649     * @param integer $class_id1 規格ID1
650     * @param integer $class_id2 規格ID2
651     * @return array 規格と規格分類の配列
652     */
653    function getAllClassCategory($class_id1, $class_id2 = null) {
654        $objQuery =& SC_Query_Ex::getSingletonInstance();
655
656        $col = <<< __EOF__
657            T1.class_id AS class_id1,
658            T1.classcategory_id AS classcategory_id1,
659            T1.name AS classcategory_name1,
660            T1.rank AS rank1
661__EOF__;
662        $table = '';
663        $arrParams = array();
664        if (SC_Utils_Ex::isBlank($class_id2)) {
665            $col .= ',0 AS classcategory_id2';
666            $table = 'dtb_classcategory T1 ';
667            $objQuery->setWhere('T1.class_id = ?');
668            $objQuery->setOrder('T1.rank DESC');
669            $arrParams = array($class_id1);
670        } else {
671            $col .= <<< __EOF__
672                ,
673                T2.class_id AS class_id2,
674                T2.classcategory_id AS classcategory_id2,
675                T2.name AS classcategory_name2,
676                T2.rank AS rank2
677__EOF__;
678            $table = 'dtb_classcategory AS T1, dtb_classcategory AS T2';
679            $objQuery->setWhere('T1.class_id = ? AND T2.class_id = ?');
680            $objQuery->setOrder('T1.rank DESC, T2.rank DESC');
681            $arrParams = array($class_id1, $class_id2);
682        }
683        return $objQuery->select($col, $table, '', $arrParams);
684    }
685
686    /**
687     * 商品名を取得する.
688     *
689     * @access private
690     * @param integer $product_id 商品ID
691     * @return string 商品名の文字列
692     */
693    function getProductName($product_id) {
694        $objQuery =& SC_Query_Ex::getSingletonInstance();
695        return $objQuery->get('name', 'dtb_products', 'product_id = ?', array($product_id));
696    }
697
698    /**
699     * 規格分類の登録された, すべての規格を取得する.
700     *
701     * @access private
702     * @return array 規格分類の登録された, すべての規格
703     */
704    function getAllClass() {
705        $arrClass = SC_Helper_DB_Ex::sfGetIDValueList('dtb_class', 'class_id', 'name');
706
707        // 規格分類が登録されていない規格は表示しないようにする。
708        $arrClassCatCount = SC_Utils_Ex::sfGetClassCatCount();
709
710        $results = array();
711        if (!SC_Utils_Ex::isBlank($arrClass)) {
712            foreach ($arrClass as $key => $val) {
713                if ($arrClassCatCount[$key] > 0) {
714                    $results[$key] = $arrClass[$key];
715                }
716            }
717        }
718        return $results;
719    }
720
721    /**
722     * 商品IDをキーにして, 商品規格の初期値を取得する.
723     *
724     * 商品IDをキーにし, デフォルトに設定されている商品規格を取得する.
725     *
726     * @param integer $product_id 商品ID
727     * @return array 商品規格の配列
728     */
729    function getProductsClass($product_id) {
730        $objQuery =& SC_Query_Ex::getSingletonInstance();
731        $col = 'product_code, price01, price02, stock, stock_unlimited, sale_limit, deliv_fee, point_rate';
732        $where = 'product_id = ? AND classcategory_id1 = 0 AND classcategory_id2 = 0';
733        return $objQuery->getRow($col, 'dtb_products_class', $where, array($product_id));
734    }
735
736    /**
737     * チェックボックスの値を埋める.
738     *
739     * チェックボックスが, すべて空で submit されると, $_POST の値が全く渡らない
740     * ため, SC_FormParam::getValue() で取得できない.
741     * これを防ぐため, $_POST[$key] を直接操作し, 指定の長さで空白の配列を作成する
742     *
743     * @param string $key $_POST のキー
744     * @param integer $size 作成する配列のサイズ
745     * @return void
746     */
747    function fillCheckboxesValue($key, $size) {
748        if (empty($_POST[$key])) {
749            $_POST[$key] = array_pad(array(), $size, '');
750        }
751    }
752}
Note: See TracBrowser for help on using the repository browser.