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

Revision 21502, 32.4 KB checked in by Seasoft, 12 years ago (diff)

#1641 (商品規格における木構造の廃止)

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