5 * @copyright CiviCRM LLC https://civicrm.org/licensing
7 * Generated from xml/schema/CRM/Core/MessageTemplate.xml
8 * DO NOT EDIT. Generated by CRM_Core_CodeGen
9 * (GenCodeChecksum:6a15fab577959d8cea4613098356e03d)
13 * Database access object for the MessageTemplate entity.
15 class CRM_Core_DAO_MessageTemplate
extends CRM_Core_DAO
{
16 const EXT
= 'civicrm';
17 const TABLE_ADDED
= '1.6';
20 * Static instance to hold the table name.
24 public static $_tableName = 'civicrm_msg_template';
27 * Should CiviCRM log any modifications to this table in the civicrm_log table.
31 public static $_log = FALSE;
41 * Descriptive title of message
48 * Subject for email message.
55 * Text formatted message
62 * HTML formatted message
74 * a pseudo-FK to civicrm_option_value
83 public $workflow_name;
86 * is this the default message template for the workflow referenced by workflow_id?
93 * is this the reserved message template which we ship for the workflow referenced by workflow_id?
100 * Is this message template used for sms?
107 * a pseudo-FK to civicrm_option_value containing PDF Page Format.
111 public $pdf_format_id;
116 public function __construct() {
117 $this->__table
= 'civicrm_msg_template';
118 parent
::__construct();
122 * Returns localized title of this entity.
124 * @param bool $plural
125 * Whether to return the plural version of the title.
127 public static function getEntityTitle($plural = FALSE) {
128 return $plural ?
ts('Message Templates') : ts('Message Template');
132 * Returns all the column names of this table
136 public static function &fields() {
137 if (!isset(Civi
::$statics[__CLASS__
]['fields'])) {
138 Civi
::$statics[__CLASS__
]['fields'] = [
141 'type' => CRM_Utils_Type
::T_INT
,
142 'title' => ts('Message Template ID'),
143 'description' => ts('Message Template ID'),
145 'where' => 'civicrm_msg_template.id',
146 'table_name' => 'civicrm_msg_template',
147 'entity' => 'MessageTemplate',
148 'bao' => 'CRM_Core_BAO_MessageTemplate',
156 'name' => 'msg_title',
157 'type' => CRM_Utils_Type
::T_STRING
,
158 'title' => ts('Message Template Title'),
159 'description' => ts('Descriptive title of message'),
161 'size' => CRM_Utils_Type
::HUGE
,
162 'where' => 'civicrm_msg_template.msg_title',
163 'table_name' => 'civicrm_msg_template',
164 'entity' => 'MessageTemplate',
165 'bao' => 'CRM_Core_BAO_MessageTemplate',
170 'name' => 'msg_subject',
171 'type' => CRM_Utils_Type
::T_TEXT
,
172 'title' => ts('Message Template Subject'),
173 'description' => ts('Subject for email message.'),
174 'where' => 'civicrm_msg_template.msg_subject',
175 'table_name' => 'civicrm_msg_template',
176 'entity' => 'MessageTemplate',
177 'bao' => 'CRM_Core_BAO_MessageTemplate',
182 'name' => 'msg_text',
183 'type' => CRM_Utils_Type
::T_LONGTEXT
,
184 'title' => ts('Message Template Text'),
185 'description' => ts('Text formatted message'),
186 'where' => 'civicrm_msg_template.msg_text',
187 'table_name' => 'civicrm_msg_template',
188 'entity' => 'MessageTemplate',
189 'bao' => 'CRM_Core_BAO_MessageTemplate',
192 'type' => 'TextArea',
197 'name' => 'msg_html',
198 'type' => CRM_Utils_Type
::T_LONGTEXT
,
199 'title' => ts('Message Template HTML'),
200 'description' => ts('HTML formatted message'),
201 'where' => 'civicrm_msg_template.msg_html',
202 'table_name' => 'civicrm_msg_template',
203 'entity' => 'MessageTemplate',
204 'bao' => 'CRM_Core_BAO_MessageTemplate',
207 'type' => 'RichTextEditor',
212 'name' => 'is_active',
213 'type' => CRM_Utils_Type
::T_BOOLEAN
,
214 'title' => ts('Is Active'),
215 'where' => 'civicrm_msg_template.is_active',
217 'table_name' => 'civicrm_msg_template',
218 'entity' => 'MessageTemplate',
219 'bao' => 'CRM_Core_BAO_MessageTemplate',
224 'name' => 'workflow_id',
225 'type' => CRM_Utils_Type
::T_INT
,
226 'title' => ts('Deprecated field for Message Template Workflow.'),
227 'description' => ts('a pseudo-FK to civicrm_option_value'),
228 'where' => 'civicrm_msg_template.workflow_id',
229 'table_name' => 'civicrm_msg_template',
230 'entity' => 'MessageTemplate',
231 'bao' => 'CRM_Core_BAO_MessageTemplate',
236 'name' => 'workflow_name',
237 'type' => CRM_Utils_Type
::T_STRING
,
238 'title' => ts('Message Template Workflow Name'),
240 'size' => CRM_Utils_Type
::HUGE
,
241 'where' => 'civicrm_msg_template.workflow_name',
242 'table_name' => 'civicrm_msg_template',
243 'entity' => 'MessageTemplate',
244 'bao' => 'CRM_Core_BAO_MessageTemplate',
249 'name' => 'is_default',
250 'type' => CRM_Utils_Type
::T_BOOLEAN
,
251 'title' => ts('Message Template Is Default?'),
252 'description' => ts('is this the default message template for the workflow referenced by workflow_id?'),
253 'where' => 'civicrm_msg_template.is_default',
255 'table_name' => 'civicrm_msg_template',
256 'entity' => 'MessageTemplate',
257 'bao' => 'CRM_Core_BAO_MessageTemplate',
262 'name' => 'is_reserved',
263 'type' => CRM_Utils_Type
::T_BOOLEAN
,
264 'title' => ts('Message Template Is Reserved?'),
265 'description' => ts('is this the reserved message template which we ship for the workflow referenced by workflow_id?'),
266 'where' => 'civicrm_msg_template.is_reserved',
267 'table_name' => 'civicrm_msg_template',
268 'entity' => 'MessageTemplate',
269 'bao' => 'CRM_Core_BAO_MessageTemplate',
275 'type' => CRM_Utils_Type
::T_BOOLEAN
,
276 'title' => ts('Message Template is used for SMS?'),
277 'description' => ts('Is this message template used for sms?'),
278 'where' => 'civicrm_msg_template.is_sms',
280 'table_name' => 'civicrm_msg_template',
281 'entity' => 'MessageTemplate',
282 'bao' => 'CRM_Core_BAO_MessageTemplate',
287 'name' => 'pdf_format_id',
288 'type' => CRM_Utils_Type
::T_INT
,
289 'title' => ts('Message Template Format'),
290 'description' => ts('a pseudo-FK to civicrm_option_value containing PDF Page Format.'),
291 'where' => 'civicrm_msg_template.pdf_format_id',
292 'table_name' => 'civicrm_msg_template',
293 'entity' => 'MessageTemplate',
294 'bao' => 'CRM_Core_BAO_MessageTemplate',
296 'pseudoconstant' => [
297 'optionGroupName' => 'pdf_format',
299 'optionEditPath' => 'civicrm/admin/options/pdf_format',
304 CRM_Core_DAO_AllCoreTables
::invoke(__CLASS__
, 'fields_callback', Civi
::$statics[__CLASS__
]['fields']);
306 return Civi
::$statics[__CLASS__
]['fields'];
310 * Return a mapping from field-name to the corresponding key (as used in fields()).
313 * Array(string $name => string $uniqueName).
315 public static function &fieldKeys() {
316 if (!isset(Civi
::$statics[__CLASS__
]['fieldKeys'])) {
317 Civi
::$statics[__CLASS__
]['fieldKeys'] = array_flip(CRM_Utils_Array
::collect('name', self
::fields()));
319 return Civi
::$statics[__CLASS__
]['fieldKeys'];
323 * Returns the names of this table
327 public static function getTableName() {
328 return self
::$_tableName;
332 * Returns if this table needs to be logged
336 public function getLog() {
341 * Returns the list of fields that can be imported
343 * @param bool $prefix
347 public static function &import($prefix = FALSE) {
348 $r = CRM_Core_DAO_AllCoreTables
::getImports(__CLASS__
, 'msg_template', $prefix, []);
353 * Returns the list of fields that can be exported
355 * @param bool $prefix
359 public static function &export($prefix = FALSE) {
360 $r = CRM_Core_DAO_AllCoreTables
::getExports(__CLASS__
, 'msg_template', $prefix, []);
365 * Returns the list of indices
367 * @param bool $localize
371 public static function indices($localize = TRUE) {
373 return ($localize && !empty($indices)) ? CRM_Core_DAO_AllCoreTables
::multilingualize(__CLASS__
, $indices) : $indices;