Completed
Push — develop ( 3861a6...5ec043 )
by Daniel
06:44
created

field::set_field_explain()   A

Complexity

Conditions 3
Paths 2

Size

Total Lines 10
Code Lines 5

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
dl 0
loc 10
rs 9.4285
c 0
b 0
f 0
cc 3
eloc 5
nc 2
nop 2
1
<?php
2
/**
3
 *
4
 * @package sitemaker
5
 * @copyright (c) 2016 Daniel A. (blitze)
6
 * @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2
7
 *
8
 */
9
10
namespace blitze\content\model\entity;
11
12
use blitze\sitemaker\model\base_entity;
13
14
/**
15
 * @method integer get_field_id()
16
 * @method object set_content_id($content_id)
17
 * @method integer get_content_id()
18
 * @method object set_field_name($field_name)
19
 * @method integer get_field_name()
20
 * @method integer get_field_label()
21
 * @method object set_field_type($field_type)
22
 * @method string get_field_type()
23
 * @method object set_field_mod_only($mod_only)
24
 * @method boolean get_field_mod_only()
25
 * @method object set_field_required($required_field)
26
 * @method boolean get_field_required()
27
 * @method object set_field_summary_show($summary_show)
28
 * @method boolean get_field_summary_show()
29
 * @method object set_field_detail_show($detail_show)
30
 * @method boolean get_field_detail_show()
31
 * @method object set_field_summary_ldisp($summary_ldisp)
32
 * @method boolean get_field_summary_ldisp()
33
 * @method object set_field_detail_ldisp($detail_ldisp)
34
 * @method boolean get_field_detail_ldisp()
35
 * @method object set_exp_uid($uid)
36
 * @method string get_exp_uid()
37
 * @method object set_exp_bitfield($bitfield)
38
 * @method string get_exp_bitfield()
39
 * @method object set_exp_options($options)
40
 * @method integer get_exp_options()
41
 * @method object set_field_order($order)
42
 * @method string get_field_order()
43
 */
44
final class field extends base_entity
45
{
46
	/** @var integer */
47
	protected $field_id;
48
49
	/** @var integer */
50
	protected $content_id;
51
52
	/** @var string */
53
	protected $field_name;
54
55
	/** @var string */
56
	protected $field_label;
57
58
	/** @var string */
59
	protected $field_explain = '';
60
61
	/** @var string */
62
	protected $field_type;
63
64
	/** @var string */
65
	protected $field_settings = '';
66
67
	/** @var boolean */
68
	protected $field_mod_only = false;
69
70
	/** @var boolean */
71
	protected $field_required = false;
72
73
	/** @var boolean */
74
	protected $field_summary_show = false;
75
76
	/** @var boolean */
77
	protected $field_detail_show = false;
78
79
	/** @var boolean */
80
	protected $field_summary_ldisp = false;
81
82
	/** @var boolean */
83
	protected $field_detail_ldisp = false;
84
85
	/** @var string */
86
	protected $field_exp_uid = '';
87
88
	/** @var string */
89
	protected $field_exp_bitfield = '';
90
91
	/** @var integer */
92
	protected $field_exp_options = 7;
93
94
	/** @var integer */
95
	protected $field_order = 0;
96
97
	/** @var array */
98
	protected $required_fields = array('content_id', 'field_name', 'field_label', 'field_type');
99
100
	/** @var array */
101
	protected $db_fields = array(
102
		'content_id',
103
		'field_name',
104
		'field_label',
105
		'field_explain',
106
		'field_type',
107
		'field_settings',
108
		'field_mod_only',
109
		'field_required',
110
		'field_summary_show',
111
		'field_detail_show',
112
		'field_summary_ldisp',
113
		'field_detail_ldisp',
114
		'field_exp_uid',
115
		'field_exp_bitfield',
116
		'field_exp_options',
117
		'field_order',
118
	);
119
120
	/**
121
	 * Set field ID
122
	 * @param int $field_id
123
	 * @return $this
124
	 */
125
	public function set_field_id($field_id)
126
	{
127
		if (!$this->field_id)
128
		{
129
			$this->field_id = (int) $field_id;
130
		}
131
		return $this;
132
	}
133
134
	/**
135
	 * Set field label
136
	 * @param string $label
137
	 * @return $this
138
	 */
139
	public function set_field_label($label)
140
	{
141
		$this->field_label = utf8_ucfirst(trim($label));
142
		return $this;
143
	}
144
145
	/**
146
	 * @param string $explain
147
	 * @param string $mode
148
	 * @return $this
149
	 */
150
	public function set_field_explain($explain, $mode = '')
151
	{
152
		$this->field_explain = $explain;
153
154
		if ($this->field_explain && $mode === 'storage')
155
		{
156
			generate_text_for_storage($this->field_explain, $this->field_exp_uid, $this->field_exp_bitfield, $this->field_exp_options, true, true, true);
157
		}
158
		return $this;
159
	}
160
161
	/**
162
	 * @param string $mode
163
	 * @return string|array
164
	 */
165
	public function get_field_explain($mode = 'display')
166
	{
167
		if ($mode === 'edit')
168
		{
169
			return generate_text_for_edit($this->field_explain, $this->field_exp_uid, $this->field_exp_options);
170
		}
171
		else
172
		{
173
			$parse_flags = ($this->field_exp_bitfield ? OPTION_FLAG_BBCODE : 0) | OPTION_FLAG_SMILIES;
174
			return generate_text_for_display($this->field_explain, $this->field_exp_uid, $this->field_exp_bitfield, $parse_flags);
175
		}
176
	}
177
178
	/**
179
	 * Set field settings
180
	 * @param array|string $settings
181
	 * @return $this
182
	 */
183
	public function set_field_settings($settings)
184
	{
185
		if (!is_array($settings))
186
		{
187
			$this->field_settings = $settings;
188
		}
189
		else if (sizeof($settings))
190
		{
191
			$this->field_settings = json_encode($settings);
192
		}
193
		return $this;
194
	}
195
196
	/**
197
	 * Get field settings
198
	 * @return array
199
	 */
200
	public function get_field_settings()
201
	{
202
		return ($this->field_settings) ? json_decode($this->field_settings, true) : array();
203
	}
204
}
205