Merge pull request #12177 from eileenmcnaughton/test_monish
[civicrm-core.git] / CRM / Contribute / DAO / Premium.php
CommitLineData
e501603b 1<?php
c3fc2621 2
e501603b
TO
3/**
4 * @package CRM
8c9251b3 5 * @copyright CiviCRM LLC (c) 2004-2018
e501603b
TO
6 *
7 * Generated from xml/schema/CRM/Contribute/Premium.xml
8 * DO NOT EDIT. Generated by CRM_Core_CodeGen
6a7e5e5d 9 * (GenCodeChecksum:86a5118380bd35cee851da735f699ac2)
e501603b 10 */
c3fc2621 11
f41f0342 12/**
c3fc2621 13 * Database access object for the Premium entity.
f41f0342 14 */
e501603b 15class CRM_Contribute_DAO_Premium extends CRM_Core_DAO {
c3fc2621 16
e501603b 17 /**
f41f0342 18 * Static instance to hold the table name.
e501603b
TO
19 *
20 * @var string
21 */
22 static $_tableName = 'civicrm_premiums';
c3fc2621 23
e501603b 24 /**
f41f0342 25 * Should CiviCRM log any modifications to this table in the civicrm_log table.
e501603b 26 *
c3fc2621 27 * @var bool
e501603b 28 */
c3fc2621
CW
29 static $_log = TRUE;
30
e501603b 31 /**
e501603b
TO
32 * @var int unsigned
33 */
34 public $id;
c3fc2621 35
e501603b
TO
36 /**
37 * Joins these premium settings to another object. Always civicrm_contribution_page for now.
38 *
39 * @var string
40 */
41 public $entity_table;
c3fc2621 42
e501603b 43 /**
e501603b
TO
44 * @var int unsigned
45 */
46 public $entity_id;
c3fc2621 47
e501603b
TO
48 /**
49 * Is the Premiums feature enabled for this page?
50 *
51 * @var boolean
52 */
53 public $premiums_active;
c3fc2621 54
e501603b
TO
55 /**
56 * Title for Premiums section.
57 *
58 * @var string
59 */
60 public $premiums_intro_title;
c3fc2621 61
e501603b
TO
62 /**
63 * Displayed in <div> at top of Premiums section of page. Text and HTML allowed.
64 *
65 * @var text
66 */
67 public $premiums_intro_text;
c3fc2621 68
e501603b
TO
69 /**
70 * This email address is included in receipts if it is populated and a premium has been selected.
71 *
72 * @var string
73 */
74 public $premiums_contact_email;
c3fc2621 75
e501603b
TO
76 /**
77 * This phone number is included in receipts if it is populated and a premium has been selected.
78 *
79 * @var string
80 */
81 public $premiums_contact_phone;
c3fc2621 82
e501603b
TO
83 /**
84 * Boolean. Should we automatically display minimum contribution amount text after the premium descriptions.
85 *
86 * @var boolean
87 */
88 public $premiums_display_min_contribution;
c3fc2621 89
e501603b
TO
90 /**
91 * Label displayed for No Thank-you option in premiums block (e.g. No thank you)
92 *
93 * @var string
94 */
95 public $premiums_nothankyou_label;
c3fc2621 96
e501603b 97 /**
e501603b
TO
98 * @var int unsigned
99 */
100 public $premiums_nothankyou_position;
c3fc2621 101
e501603b 102 /**
f41f0342 103 * Class constructor.
e501603b 104 */
c3fc2621 105 public function __construct() {
e501603b
TO
106 $this->__table = 'civicrm_premiums';
107 parent::__construct();
108 }
c3fc2621 109
e501603b 110 /**
f41f0342 111 * Returns foreign keys and entity references.
e501603b
TO
112 *
113 * @return array
114 * [CRM_Core_Reference_Interface]
115 */
c3fc2621 116 public static function getReferenceColumns() {
346aaaba
TO
117 if (!isset(Civi::$statics[__CLASS__]['links'])) {
118 Civi::$statics[__CLASS__]['links'] = static ::createReferenceColumns(__CLASS__);
c3fc2621 119 Civi::$statics[__CLASS__]['links'][] = new CRM_Core_Reference_Dynamic(self::getTableName(), 'entity_id', NULL, 'id', 'entity_table');
346aaaba 120 CRM_Core_DAO_AllCoreTables::invoke(__CLASS__, 'links_callback', Civi::$statics[__CLASS__]['links']);
e501603b 121 }
346aaaba 122 return Civi::$statics[__CLASS__]['links'];
e501603b 123 }
c3fc2621 124
e501603b
TO
125 /**
126 * Returns all the column names of this table
127 *
128 * @return array
129 */
c3fc2621 130 public static function &fields() {
346aaaba 131 if (!isset(Civi::$statics[__CLASS__]['fields'])) {
c3fc2621
CW
132 Civi::$statics[__CLASS__]['fields'] = [
133 'id' => [
e501603b
TO
134 'name' => 'id',
135 'type' => CRM_Utils_Type::T_INT,
c3fc2621
CW
136 'title' => ts('Premium ID'),
137 'required' => TRUE,
522a26c9 138 'table_name' => 'civicrm_premiums',
139 'entity' => 'Premium',
140 'bao' => 'CRM_Contribute_BAO_Premium',
6a7e5e5d 141 'localizable' => 0,
c3fc2621
CW
142 ],
143 'entity_table' => [
e501603b
TO
144 'name' => 'entity_table',
145 'type' => CRM_Utils_Type::T_STRING,
c3fc2621 146 'title' => ts('Premium Entity'),
e501603b 147 'description' => 'Joins these premium settings to another object. Always civicrm_contribution_page for now.',
c3fc2621 148 'required' => TRUE,
e501603b
TO
149 'maxlength' => 64,
150 'size' => CRM_Utils_Type::BIG,
522a26c9 151 'table_name' => 'civicrm_premiums',
152 'entity' => 'Premium',
153 'bao' => 'CRM_Contribute_BAO_Premium',
6a7e5e5d 154 'localizable' => 0,
c3fc2621
CW
155 ],
156 'entity_id' => [
e501603b
TO
157 'name' => 'entity_id',
158 'type' => CRM_Utils_Type::T_INT,
c3fc2621
CW
159 'title' => ts('Premium entity ID'),
160 'required' => TRUE,
522a26c9 161 'table_name' => 'civicrm_premiums',
162 'entity' => 'Premium',
163 'bao' => 'CRM_Contribute_BAO_Premium',
6a7e5e5d 164 'localizable' => 0,
c3fc2621
CW
165 ],
166 'premiums_active' => [
e501603b
TO
167 'name' => 'premiums_active',
168 'type' => CRM_Utils_Type::T_BOOLEAN,
c3fc2621 169 'title' => ts('Is Premium Active?'),
e501603b 170 'description' => 'Is the Premiums feature enabled for this page?',
c3fc2621 171 'required' => TRUE,
522a26c9 172 'table_name' => 'civicrm_premiums',
173 'entity' => 'Premium',
174 'bao' => 'CRM_Contribute_BAO_Premium',
6a7e5e5d 175 'localizable' => 0,
c3fc2621
CW
176 ],
177 'premiums_intro_title' => [
e501603b
TO
178 'name' => 'premiums_intro_title',
179 'type' => CRM_Utils_Type::T_STRING,
c3fc2621 180 'title' => ts('Title for Premiums section'),
e501603b
TO
181 'description' => 'Title for Premiums section.',
182 'maxlength' => 255,
183 'size' => CRM_Utils_Type::HUGE,
522a26c9 184 'table_name' => 'civicrm_premiums',
185 'entity' => 'Premium',
186 'bao' => 'CRM_Contribute_BAO_Premium',
6a7e5e5d 187 'localizable' => 1,
c3fc2621
CW
188 ],
189 'premiums_intro_text' => [
e501603b
TO
190 'name' => 'premiums_intro_text',
191 'type' => CRM_Utils_Type::T_TEXT,
c3fc2621 192 'title' => ts('Premium Introductory Text'),
e501603b 193 'description' => 'Displayed in <div> at top of Premiums section of page. Text and HTML allowed.',
522a26c9 194 'table_name' => 'civicrm_premiums',
195 'entity' => 'Premium',
196 'bao' => 'CRM_Contribute_BAO_Premium',
6a7e5e5d 197 'localizable' => 1,
c3fc2621
CW
198 ],
199 'premiums_contact_email' => [
e501603b
TO
200 'name' => 'premiums_contact_email',
201 'type' => CRM_Utils_Type::T_STRING,
c3fc2621 202 'title' => ts('Premium Contact Email'),
e501603b
TO
203 'description' => 'This email address is included in receipts if it is populated and a premium has been selected.',
204 'maxlength' => 100,
205 'size' => CRM_Utils_Type::HUGE,
522a26c9 206 'table_name' => 'civicrm_premiums',
207 'entity' => 'Premium',
208 'bao' => 'CRM_Contribute_BAO_Premium',
6a7e5e5d 209 'localizable' => 0,
c3fc2621
CW
210 ],
211 'premiums_contact_phone' => [
e501603b
TO
212 'name' => 'premiums_contact_phone',
213 'type' => CRM_Utils_Type::T_STRING,
c3fc2621 214 'title' => ts('Premiums Contact Phone'),
e501603b
TO
215 'description' => 'This phone number is included in receipts if it is populated and a premium has been selected.',
216 'maxlength' => 50,
217 'size' => CRM_Utils_Type::BIG,
522a26c9 218 'table_name' => 'civicrm_premiums',
219 'entity' => 'Premium',
220 'bao' => 'CRM_Contribute_BAO_Premium',
6a7e5e5d 221 'localizable' => 0,
c3fc2621
CW
222 ],
223 'premiums_display_min_contribution' => [
e501603b
TO
224 'name' => 'premiums_display_min_contribution',
225 'type' => CRM_Utils_Type::T_BOOLEAN,
c3fc2621 226 'title' => ts('Display Minimum Contribution?'),
e501603b 227 'description' => 'Boolean. Should we automatically display minimum contribution amount text after the premium descriptions.',
c3fc2621 228 'required' => TRUE,
522a26c9 229 'table_name' => 'civicrm_premiums',
230 'entity' => 'Premium',
231 'bao' => 'CRM_Contribute_BAO_Premium',
6a7e5e5d 232 'localizable' => 0,
c3fc2621
CW
233 ],
234 'premiums_nothankyou_label' => [
e501603b
TO
235 'name' => 'premiums_nothankyou_label',
236 'type' => CRM_Utils_Type::T_STRING,
c3fc2621 237 'title' => ts('No Thank-you Text'),
e501603b
TO
238 'description' => 'Label displayed for No Thank-you option in premiums block (e.g. No thank you)',
239 'maxlength' => 255,
240 'size' => CRM_Utils_Type::HUGE,
522a26c9 241 'table_name' => 'civicrm_premiums',
242 'entity' => 'Premium',
243 'bao' => 'CRM_Contribute_BAO_Premium',
6a7e5e5d 244 'localizable' => 1,
c3fc2621
CW
245 ],
246 'premiums_nothankyou_position' => [
e501603b
TO
247 'name' => 'premiums_nothankyou_position',
248 'type' => CRM_Utils_Type::T_INT,
c3fc2621 249 'title' => ts('No Thank-you Position'),
e501603b 250 'default' => '1',
522a26c9 251 'table_name' => 'civicrm_premiums',
252 'entity' => 'Premium',
253 'bao' => 'CRM_Contribute_BAO_Premium',
6a7e5e5d 254 'localizable' => 0,
c3fc2621
CW
255 ],
256 ];
346aaaba 257 CRM_Core_DAO_AllCoreTables::invoke(__CLASS__, 'fields_callback', Civi::$statics[__CLASS__]['fields']);
e501603b 258 }
346aaaba 259 return Civi::$statics[__CLASS__]['fields'];
e501603b 260 }
c3fc2621 261
e501603b 262 /**
bd8e0b14 263 * Return a mapping from field-name to the corresponding key (as used in fields()).
e501603b
TO
264 *
265 * @return array
bd8e0b14 266 * Array(string $name => string $uniqueName).
e501603b 267 */
c3fc2621 268 public static function &fieldKeys() {
bd8e0b14
TO
269 if (!isset(Civi::$statics[__CLASS__]['fieldKeys'])) {
270 Civi::$statics[__CLASS__]['fieldKeys'] = array_flip(CRM_Utils_Array::collect('name', self::fields()));
e501603b 271 }
bd8e0b14 272 return Civi::$statics[__CLASS__]['fieldKeys'];
e501603b 273 }
c3fc2621 274
e501603b
TO
275 /**
276 * Returns the names of this table
277 *
278 * @return string
279 */
c3fc2621 280 public static function getTableName() {
e501603b
TO
281 return CRM_Core_DAO::getLocaleTableName(self::$_tableName);
282 }
c3fc2621 283
e501603b
TO
284 /**
285 * Returns if this table needs to be logged
286 *
c3fc2621 287 * @return bool
e501603b 288 */
c3fc2621 289 public function getLog() {
e501603b
TO
290 return self::$_log;
291 }
c3fc2621 292
e501603b
TO
293 /**
294 * Returns the list of fields that can be imported
295 *
296 * @param bool $prefix
297 *
298 * @return array
299 */
c3fc2621
CW
300 public static function &import($prefix = FALSE) {
301 $r = CRM_Core_DAO_AllCoreTables::getImports(__CLASS__, 'premiums', $prefix, []);
60808919 302 return $r;
e501603b 303 }
c3fc2621 304
e501603b
TO
305 /**
306 * Returns the list of fields that can be exported
307 *
308 * @param bool $prefix
309 *
310 * @return array
311 */
c3fc2621
CW
312 public static function &export($prefix = FALSE) {
313 $r = CRM_Core_DAO_AllCoreTables::getExports(__CLASS__, 'premiums', $prefix, []);
60808919 314 return $r;
e501603b 315 }
c3fc2621 316
e7a6b91a
AS
317 /**
318 * Returns the list of indices
c3fc2621
CW
319 *
320 * @param bool $localize
321 *
322 * @return array
e7a6b91a
AS
323 */
324 public static function indices($localize = TRUE) {
c3fc2621 325 $indices = [];
e7a6b91a
AS
326 return ($localize && !empty($indices)) ? CRM_Core_DAO_AllCoreTables::multilingualize(__CLASS__, $indices) : $indices;
327 }
c3fc2621 328
e501603b 329}