source: branches/version-2_13_0/data/class/helper/SC_Helper_Maker.php @ 23126

Revision 23126, 4.9 KB checked in by m_uehara, 11 years ago (diff)

#2348 r23116 - r23125 をマージ

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