source: branches/version-2_13-dev/data/class/helper/SC_Helper_Maker.php @ 22735

Revision 22735, 4.9 KB checked in by h_yoshimoto, 11 years ago (diff)

#2193 ユニットテストチームのコミットをマージ(from camp/camp-2_13-tests)

Line 
1<?php
2/*
3 * This file is part of EC-CUBE
4 *
5 * Copyright(c) 2000-2013 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/**
25 * メーカーを管理するヘルパークラス.
26 *
27 * @package Helper
28 * @author pineray
29 * @version $Id:$
30 */
31class SC_Helper_Maker
32{
33    /**
34     * メーカーの情報を取得.
35     *
36     * @param integer $maker_id メーカーID
37     * @param boolean $has_deleted 削除されたメーカーも含む場合 true; 初期値 false
38     * @return array
39     */
40    public function getMaker($maker_id, $has_deleted = false)
41    {
42        $objQuery =& SC_Query_Ex::getSingletonInstance();
43        $where = 'maker_id = ?';
44        if (!$has_deleted) {
45            $where .= ' AND del_flg = 0';
46        }
47        $arrRet = $objQuery->select('*', 'dtb_maker', $where, array($maker_id));
48        return $arrRet[0];
49    }
50
51    /**
52     * 名前からメーカーの情報を取得.
53     *
54     * @param integer $name メーカー名
55     * @param boolean $has_deleted 削除されたメーカーも含む場合 true; 初期値 false
56     * @return array
57     */
58    public function getByName($name, $has_deleted = false)
59    {
60        $objQuery =& SC_Query_Ex::getSingletonInstance();
61        $where = 'name = ?';
62        if (!$has_deleted) {
63            $where .= ' AND del_flg = 0';
64        }
65        $arrRet = $objQuery->select('*', 'dtb_maker', $where, array($name));
66        return $arrRet[0];
67    }
68
69    /**
70     * メーカー一覧の取得.
71     *
72     * @param boolean $has_deleted 削除されたメーカーも含む場合 true; 初期値 false
73     * @return array
74     */
75    public function getList($has_deleted = false)
76    {
77        $objQuery =& SC_Query_Ex::getSingletonInstance();
78        $col = 'maker_id, name';
79        $where = '';
80        if (!$has_deleted) {
81            $where .= 'del_flg = 0';
82        }
83        $table = 'dtb_maker';
84        $objQuery->setOrder('rank DESC');
85        $arrRet = $objQuery->select($col, $table, $where);
86        return $arrRet;
87    }
88
89    /**
90     * メーカーの登録.
91     *
92     * @param array $sqlval
93     * @return multiple 登録成功:メーカーID, 失敗:FALSE
94     */
95    public function saveMaker($sqlval)
96    {
97        $objQuery =& SC_Query_Ex::getSingletonInstance();
98
99        $maker_id = $sqlval['maker_id'];
100        $sqlval['update_date'] = 'CURRENT_TIMESTAMP';
101        // 新規登録
102        if ($maker_id == '') {
103            // INSERTの実行
104            $sqlval['rank'] = $objQuery->max('rank', 'dtb_maker') + 1;
105            $sqlval['create_date'] = 'CURRENT_TIMESTAMP';
106            $sqlval['maker_id'] = $objQuery->nextVal('dtb_maker_maker_id');
107            $ret = $objQuery->insert('dtb_maker', $sqlval);
108        // 既存編集
109        } else {
110            unset($sqlval['creator_id']);
111            unset($sqlval['create_date']);
112            $where = 'maker_id = ?';
113            $ret = $objQuery->update('dtb_maker', $sqlval, $where, array($maker_id));
114        }
115        return ($ret) ? $sqlval['maker_id'] : FALSE;
116    }
117
118    /**
119     * メーカーの削除.
120     *
121     * @param integer $maker_id メーカーID
122     * @return void
123     */
124    public function delete($maker_id)
125    {
126        $objDb = new SC_Helper_DB_Ex();
127        // ランク付きレコードの削除
128        $objDb->sfDeleteRankRecord('dtb_maker', 'maker_id', $maker_id, '', true);
129    }
130
131    /**
132     * メーカーの表示順をひとつ上げる.
133     *
134     * @param integer $maker_id メーカーID
135     * @return void
136     */
137    public function rankUp($maker_id)
138    {
139        $objDb = new SC_Helper_DB_Ex();
140        $objDb->sfRankUp('dtb_maker', 'maker_id', $maker_id);
141    }
142
143    /**
144     * メーカーの表示順をひとつ下げる.
145     *
146     * @param integer $maker_id メーカーID
147     * @return void
148     */
149    public function rankDown($maker_id)
150    {
151        $objDb = new SC_Helper_DB_Ex();
152        $objDb->sfRankDown('dtb_maker', 'maker_id', $maker_id);
153    }
154
155    /**
156     * メーカーIDをキー, 名前を値とする配列を取得.
157     *
158     * @return array
159     */
160    public static function getIDValueList()
161    {
162        return SC_Helper_DB_Ex::sfGetIDValueList('dtb_maker', 'maker_id', 'name');
163    }
164}
Note: See TracBrowser for help on using the repository browser.