Completed
Branch BUG-10381-asset-loading (189bf4)
by
unknown
13:54
created
admin_pages/registration_form/Registration_Form_Admin_Page.core.php 2 patches
Indentation   +633 added lines, -633 removed lines patch added patch discarded remove patch
@@ -1,6 +1,6 @@  discard block
 block discarded – undo
1 1
 <?php
2 2
 if (! defined('EVENT_ESPRESSO_VERSION')) {
3
-    exit('NO direct script access allowed');
3
+	exit('NO direct script access allowed');
4 4
 }
5 5
 
6 6
 /**
@@ -28,589 +28,589 @@  discard block
 block discarded – undo
28 28
 class Registration_Form_Admin_Page extends EE_Admin_Page
29 29
 {
30 30
 
31
-    /**
32
-     * _question
33
-     * holds the specific question object for the question details screen
34
-     *
35
-     * @var EE_Question $_question
36
-     */
37
-    protected $_question;
38
-
39
-    /**
40
-     * _question_group
41
-     * holds the specific question group object for the question group details screen
42
-     *
43
-     * @var EE_Question_Group $_question_group
44
-     */
45
-    protected $_question_group;
46
-
47
-    /**
48
-     *_question_model EEM_Question model instance (for queries)
49
-     *
50
-     * @var EEM_Question $_question_model ;
51
-     */
52
-    protected $_question_model;
53
-
54
-    /**
55
-     * _question_group_model EEM_Question_group instance (for queries)
56
-     *
57
-     * @var EEM_Question_Group $_question_group_model
58
-     */
59
-    protected $_question_group_model;
60
-
61
-
62
-    /**
63
-     * @Constructor
64
-     * @param bool $routing indicate whether we want to just load the object and handle routing or just load the object.
65
-     * @access public
66
-     */
67
-    public function __construct($routing = true)
68
-    {
69
-        require_once(EE_MODELS . 'EEM_Question.model.php');
70
-        require_once(EE_MODELS . 'EEM_Question_Group.model.php');
71
-        $this->_question_model       = EEM_Question::instance();
72
-        $this->_question_group_model = EEM_Question_Group::instance();
73
-        parent::__construct($routing);
74
-    }
75
-
76
-
77
-    protected function _init_page_props()
78
-    {
79
-        $this->page_slug        = REGISTRATION_FORM_PG_SLUG;
80
-        $this->page_label       = esc_html__('Registration Form', 'event_espresso');
81
-        $this->_admin_base_url  = REGISTRATION_FORM_ADMIN_URL;
82
-        $this->_admin_base_path = REGISTRATION_FORM_ADMIN;
83
-    }
84
-
85
-
86
-    protected function _ajax_hooks()
87
-    {
88
-    }
89
-
90
-
91
-    protected function _define_page_props()
92
-    {
93
-        $this->_admin_page_title = esc_html__('Registration Form', 'event_espresso');
94
-        $this->_labels           = array(
95
-            'buttons' => array(
96
-                'edit_question' => esc_html__('Edit Question', 'event_espresso'),
97
-            ),
98
-        );
99
-    }
100
-
101
-
102
-    /**
103
-     *_set_page_routes
104
-     */
105
-    protected function _set_page_routes()
106
-    {
107
-        $qst_id             = ! empty($this->_req_data['QST_ID']) ? $this->_req_data['QST_ID'] : 0;
108
-        $this->_page_routes = array(
109
-            'default' => array(
110
-                'func'       => '_questions_overview_list_table',
111
-                'capability' => 'ee_read_questions',
112
-            ),
113
-
114
-            'edit_question' => array(
115
-                'func'       => '_edit_question',
116
-                'capability' => 'ee_edit_question',
117
-                'obj_id'     => $qst_id,
118
-                'args'       => array('edit'),
119
-            ),
120
-
121
-            'question_groups' => array(
122
-                'func'       => '_questions_groups_preview',
123
-                'capability' => 'ee_read_question_groups',
124
-            ),
125
-
126
-            'update_question' => array(
127
-                'func'       => '_insert_or_update_question',
128
-                'args'       => array('new_question' => false),
129
-                'capability' => 'ee_edit_question',
130
-                'obj_id'     => $qst_id,
131
-                'noheader'   => true,
132
-            ),
133
-        );
134
-    }
135
-
136
-
137
-    protected function _set_page_config()
138
-    {
139
-        $this->_page_config = array(
140
-            'default' => array(
141
-                'nav'           => array(
142
-                    'label' => esc_html__('Questions', 'event_espresso'),
143
-                    'order' => 10,
144
-                ),
145
-                'list_table'    => 'Registration_Form_Questions_Admin_List_Table',
146
-                'metaboxes'     => $this->_default_espresso_metaboxes,
147
-                'help_tabs'     => array(
148
-                    'registration_form_questions_overview_help_tab'                           => array(
149
-                        'title'    => esc_html__('Questions Overview', 'event_espresso'),
150
-                        'filename' => 'registration_form_questions_overview',
151
-                    ),
152
-                    'registration_form_questions_overview_table_column_headings_help_tab'     => array(
153
-                        'title'    => esc_html__('Questions Overview Table Column Headings', 'event_espresso'),
154
-                        'filename' => 'registration_form_questions_overview_table_column_headings',
155
-                    ),
156
-                    'registration_form_questions_overview_views_bulk_actions_search_help_tab' => array(
157
-                        'title'    => esc_html__('Question Overview Views & Bulk Actions & Search', 'event_espresso'),
158
-                        'filename' => 'registration_form_questions_overview_views_bulk_actions_search',
159
-                    ),
160
-                ),
161
-                'help_tour'     => array('Registration_Form_Questions_Overview_Help_Tour'),
162
-                'require_nonce' => false,
163
-                'qtips'         => array(
164
-                    'EE_Registration_Form_Tips',
165
-                )/**/
166
-            ),
167
-
168
-            'question_groups' => array(
169
-                'nav'           => array(
170
-                    'label' => esc_html__('Question Groups', 'event_espresso'),
171
-                    'order' => 20,
172
-                ),
173
-                'metaboxes'     => $this->_default_espresso_metaboxes,
174
-                'help_tabs'     => array(
175
-                    'registration_form_question_groups_help_tab' => array(
176
-                        'title'    => esc_html__('Question Groups', 'event_espresso'),
177
-                        'filename' => 'registration_form_question_groups',
178
-                    ),
179
-                ),
180
-                'help_tour'     => array('Registration_Form_Question_Groups_Help_Tour'),
181
-                'require_nonce' => false,
182
-            ),
183
-
184
-            'edit_question' => array(
185
-                'nav'           => array(
186
-                    'label'      => esc_html__('Edit Question', 'event_espresso'),
187
-                    'order'      => 15,
188
-                    'persistent' => false,
189
-                    'url'        => isset($this->_req_data['question_id']) ? add_query_arg(array('question_id' => $this->_req_data['question_id']),
190
-                        $this->_current_page_view_url) : $this->_admin_base_url,
191
-                ),
192
-                'metaboxes'     => array_merge($this->_default_espresso_metaboxes, array('_publish_post_box')),
193
-                'help_tabs'     => array(
194
-                    'registration_form_edit_question_group_help_tab' => array(
195
-                        'title'    => esc_html__('Edit Question', 'event_espresso'),
196
-                        'filename' => 'registration_form_edit_question',
197
-                    ),
198
-                ),
199
-                'help_tour'     => array('Registration_Form_Edit_Question_Help_Tour'),
200
-                'require_nonce' => false,
201
-            ),
202
-        );
203
-    }
204
-
205
-
206
-    protected function _add_screen_options()
207
-    {
208
-        //todo
209
-    }
210
-
211
-    protected function _add_screen_options_default()
212
-    {
213
-        $page_title              = $this->_admin_page_title;
214
-        $this->_admin_page_title = esc_html__('Questions', 'event_espresso');
215
-        $this->_per_page_screen_option();
216
-        $this->_admin_page_title = $page_title;
217
-    }
218
-
219
-    protected function _add_screen_options_question_groups()
220
-    {
221
-        $page_title              = $this->_admin_page_title;
222
-        $this->_admin_page_title = esc_html__('Question Groups', 'event_espresso');
223
-        $this->_per_page_screen_option();
224
-        $this->_admin_page_title = $page_title;
225
-    }
226
-
227
-    //none of the below group are currently used for Event Categories
228
-    protected function _add_feature_pointers()
229
-    {
230
-    }
231
-
232
-    public function load_scripts_styles()
233
-    {
234
-        wp_register_style('espresso_registration',
235
-            REGISTRATION_FORM_ASSETS_URL . 'espresso_registration_form_admin.css', array(), EVENT_ESPRESSO_VERSION);
236
-        wp_enqueue_style('espresso_registration');
237
-    }
238
-
239
-    public function admin_init()
240
-    {
241
-    }
242
-
243
-    public function admin_notices()
244
-    {
245
-    }
246
-
247
-    public function admin_footer_scripts()
248
-    {
249
-    }
250
-
251
-
252
-    public function load_scripts_styles_default()
253
-    {
254
-    }
255
-
256
-
257
-    public function load_scripts_styles_add_question()
258
-    {
259
-        $this->load_scripts_styles_forms();
260
-        wp_register_script('espresso_registration_form_single',
261
-            REGISTRATION_FORM_ASSETS_URL . 'espresso_registration_form_admin.js', array('jquery-ui-sortable'),
262
-            EVENT_ESPRESSO_VERSION, true);
263
-        wp_enqueue_script('espresso_registration_form_single');
264
-    }
265
-
266
-    public function load_scripts_styles_edit_question()
267
-    {
268
-        $this->load_scripts_styles_forms();
269
-        wp_register_script('espresso_registration_form_single',
270
-            REGISTRATION_FORM_ASSETS_URL . 'espresso_registration_form_admin.js', array('jquery-ui-sortable'),
271
-            EVENT_ESPRESSO_VERSION, true);
272
-        wp_enqueue_script('espresso_registration_form_single');
273
-    }
274
-
275
-
276
-    public function recaptcha_info_help_tab()
277
-    {
278
-        $template = REGISTRATION_FORM_TEMPLATE_PATH . 'recaptcha_info_help_tab.template.php';
279
-        EEH_Template::display_template($template, array());
280
-    }
281
-
282
-
283
-    public function load_scripts_styles_forms()
284
-    {
285
-        //styles
286
-        wp_enqueue_style('espresso-ui-theme');
287
-        //scripts
288
-        wp_enqueue_script('ee_admin_js');
289
-    }
290
-
291
-
292
-    protected function _set_list_table_views_default()
293
-    {
294
-        $this->_views = array(
295
-            'all' => array(
296
-                'slug'  => 'all',
297
-                'label' => esc_html__('View All Questions', 'event_espresso'),
298
-                'count' => 0,
31
+	/**
32
+	 * _question
33
+	 * holds the specific question object for the question details screen
34
+	 *
35
+	 * @var EE_Question $_question
36
+	 */
37
+	protected $_question;
38
+
39
+	/**
40
+	 * _question_group
41
+	 * holds the specific question group object for the question group details screen
42
+	 *
43
+	 * @var EE_Question_Group $_question_group
44
+	 */
45
+	protected $_question_group;
46
+
47
+	/**
48
+	 *_question_model EEM_Question model instance (for queries)
49
+	 *
50
+	 * @var EEM_Question $_question_model ;
51
+	 */
52
+	protected $_question_model;
53
+
54
+	/**
55
+	 * _question_group_model EEM_Question_group instance (for queries)
56
+	 *
57
+	 * @var EEM_Question_Group $_question_group_model
58
+	 */
59
+	protected $_question_group_model;
60
+
61
+
62
+	/**
63
+	 * @Constructor
64
+	 * @param bool $routing indicate whether we want to just load the object and handle routing or just load the object.
65
+	 * @access public
66
+	 */
67
+	public function __construct($routing = true)
68
+	{
69
+		require_once(EE_MODELS . 'EEM_Question.model.php');
70
+		require_once(EE_MODELS . 'EEM_Question_Group.model.php');
71
+		$this->_question_model       = EEM_Question::instance();
72
+		$this->_question_group_model = EEM_Question_Group::instance();
73
+		parent::__construct($routing);
74
+	}
75
+
76
+
77
+	protected function _init_page_props()
78
+	{
79
+		$this->page_slug        = REGISTRATION_FORM_PG_SLUG;
80
+		$this->page_label       = esc_html__('Registration Form', 'event_espresso');
81
+		$this->_admin_base_url  = REGISTRATION_FORM_ADMIN_URL;
82
+		$this->_admin_base_path = REGISTRATION_FORM_ADMIN;
83
+	}
84
+
85
+
86
+	protected function _ajax_hooks()
87
+	{
88
+	}
89
+
90
+
91
+	protected function _define_page_props()
92
+	{
93
+		$this->_admin_page_title = esc_html__('Registration Form', 'event_espresso');
94
+		$this->_labels           = array(
95
+			'buttons' => array(
96
+				'edit_question' => esc_html__('Edit Question', 'event_espresso'),
97
+			),
98
+		);
99
+	}
100
+
101
+
102
+	/**
103
+	 *_set_page_routes
104
+	 */
105
+	protected function _set_page_routes()
106
+	{
107
+		$qst_id             = ! empty($this->_req_data['QST_ID']) ? $this->_req_data['QST_ID'] : 0;
108
+		$this->_page_routes = array(
109
+			'default' => array(
110
+				'func'       => '_questions_overview_list_table',
111
+				'capability' => 'ee_read_questions',
112
+			),
113
+
114
+			'edit_question' => array(
115
+				'func'       => '_edit_question',
116
+				'capability' => 'ee_edit_question',
117
+				'obj_id'     => $qst_id,
118
+				'args'       => array('edit'),
119
+			),
120
+
121
+			'question_groups' => array(
122
+				'func'       => '_questions_groups_preview',
123
+				'capability' => 'ee_read_question_groups',
124
+			),
125
+
126
+			'update_question' => array(
127
+				'func'       => '_insert_or_update_question',
128
+				'args'       => array('new_question' => false),
129
+				'capability' => 'ee_edit_question',
130
+				'obj_id'     => $qst_id,
131
+				'noheader'   => true,
132
+			),
133
+		);
134
+	}
135
+
136
+
137
+	protected function _set_page_config()
138
+	{
139
+		$this->_page_config = array(
140
+			'default' => array(
141
+				'nav'           => array(
142
+					'label' => esc_html__('Questions', 'event_espresso'),
143
+					'order' => 10,
144
+				),
145
+				'list_table'    => 'Registration_Form_Questions_Admin_List_Table',
146
+				'metaboxes'     => $this->_default_espresso_metaboxes,
147
+				'help_tabs'     => array(
148
+					'registration_form_questions_overview_help_tab'                           => array(
149
+						'title'    => esc_html__('Questions Overview', 'event_espresso'),
150
+						'filename' => 'registration_form_questions_overview',
151
+					),
152
+					'registration_form_questions_overview_table_column_headings_help_tab'     => array(
153
+						'title'    => esc_html__('Questions Overview Table Column Headings', 'event_espresso'),
154
+						'filename' => 'registration_form_questions_overview_table_column_headings',
155
+					),
156
+					'registration_form_questions_overview_views_bulk_actions_search_help_tab' => array(
157
+						'title'    => esc_html__('Question Overview Views & Bulk Actions & Search', 'event_espresso'),
158
+						'filename' => 'registration_form_questions_overview_views_bulk_actions_search',
159
+					),
160
+				),
161
+				'help_tour'     => array('Registration_Form_Questions_Overview_Help_Tour'),
162
+				'require_nonce' => false,
163
+				'qtips'         => array(
164
+					'EE_Registration_Form_Tips',
165
+				)/**/
166
+			),
167
+
168
+			'question_groups' => array(
169
+				'nav'           => array(
170
+					'label' => esc_html__('Question Groups', 'event_espresso'),
171
+					'order' => 20,
172
+				),
173
+				'metaboxes'     => $this->_default_espresso_metaboxes,
174
+				'help_tabs'     => array(
175
+					'registration_form_question_groups_help_tab' => array(
176
+						'title'    => esc_html__('Question Groups', 'event_espresso'),
177
+						'filename' => 'registration_form_question_groups',
178
+					),
179
+				),
180
+				'help_tour'     => array('Registration_Form_Question_Groups_Help_Tour'),
181
+				'require_nonce' => false,
182
+			),
183
+
184
+			'edit_question' => array(
185
+				'nav'           => array(
186
+					'label'      => esc_html__('Edit Question', 'event_espresso'),
187
+					'order'      => 15,
188
+					'persistent' => false,
189
+					'url'        => isset($this->_req_data['question_id']) ? add_query_arg(array('question_id' => $this->_req_data['question_id']),
190
+						$this->_current_page_view_url) : $this->_admin_base_url,
191
+				),
192
+				'metaboxes'     => array_merge($this->_default_espresso_metaboxes, array('_publish_post_box')),
193
+				'help_tabs'     => array(
194
+					'registration_form_edit_question_group_help_tab' => array(
195
+						'title'    => esc_html__('Edit Question', 'event_espresso'),
196
+						'filename' => 'registration_form_edit_question',
197
+					),
198
+				),
199
+				'help_tour'     => array('Registration_Form_Edit_Question_Help_Tour'),
200
+				'require_nonce' => false,
201
+			),
202
+		);
203
+	}
204
+
205
+
206
+	protected function _add_screen_options()
207
+	{
208
+		//todo
209
+	}
210
+
211
+	protected function _add_screen_options_default()
212
+	{
213
+		$page_title              = $this->_admin_page_title;
214
+		$this->_admin_page_title = esc_html__('Questions', 'event_espresso');
215
+		$this->_per_page_screen_option();
216
+		$this->_admin_page_title = $page_title;
217
+	}
218
+
219
+	protected function _add_screen_options_question_groups()
220
+	{
221
+		$page_title              = $this->_admin_page_title;
222
+		$this->_admin_page_title = esc_html__('Question Groups', 'event_espresso');
223
+		$this->_per_page_screen_option();
224
+		$this->_admin_page_title = $page_title;
225
+	}
226
+
227
+	//none of the below group are currently used for Event Categories
228
+	protected function _add_feature_pointers()
229
+	{
230
+	}
231
+
232
+	public function load_scripts_styles()
233
+	{
234
+		wp_register_style('espresso_registration',
235
+			REGISTRATION_FORM_ASSETS_URL . 'espresso_registration_form_admin.css', array(), EVENT_ESPRESSO_VERSION);
236
+		wp_enqueue_style('espresso_registration');
237
+	}
238
+
239
+	public function admin_init()
240
+	{
241
+	}
242
+
243
+	public function admin_notices()
244
+	{
245
+	}
246
+
247
+	public function admin_footer_scripts()
248
+	{
249
+	}
250
+
251
+
252
+	public function load_scripts_styles_default()
253
+	{
254
+	}
255
+
256
+
257
+	public function load_scripts_styles_add_question()
258
+	{
259
+		$this->load_scripts_styles_forms();
260
+		wp_register_script('espresso_registration_form_single',
261
+			REGISTRATION_FORM_ASSETS_URL . 'espresso_registration_form_admin.js', array('jquery-ui-sortable'),
262
+			EVENT_ESPRESSO_VERSION, true);
263
+		wp_enqueue_script('espresso_registration_form_single');
264
+	}
265
+
266
+	public function load_scripts_styles_edit_question()
267
+	{
268
+		$this->load_scripts_styles_forms();
269
+		wp_register_script('espresso_registration_form_single',
270
+			REGISTRATION_FORM_ASSETS_URL . 'espresso_registration_form_admin.js', array('jquery-ui-sortable'),
271
+			EVENT_ESPRESSO_VERSION, true);
272
+		wp_enqueue_script('espresso_registration_form_single');
273
+	}
274
+
275
+
276
+	public function recaptcha_info_help_tab()
277
+	{
278
+		$template = REGISTRATION_FORM_TEMPLATE_PATH . 'recaptcha_info_help_tab.template.php';
279
+		EEH_Template::display_template($template, array());
280
+	}
281
+
282
+
283
+	public function load_scripts_styles_forms()
284
+	{
285
+		//styles
286
+		wp_enqueue_style('espresso-ui-theme');
287
+		//scripts
288
+		wp_enqueue_script('ee_admin_js');
289
+	}
290
+
291
+
292
+	protected function _set_list_table_views_default()
293
+	{
294
+		$this->_views = array(
295
+			'all' => array(
296
+				'slug'  => 'all',
297
+				'label' => esc_html__('View All Questions', 'event_espresso'),
298
+				'count' => 0,
299 299
 //				'bulk_action' => array(
300 300
 //					'trash_questions' => esc_html__('Trash', 'event_espresso'),
301 301
 //					)
302
-            ),
303
-        );
304
-
305
-        if (EE_Registry::instance()->CAP->current_user_can('ee_delete_questions',
306
-            'espresso_registration_form_trash_questions')
307
-        ) {
308
-            $this->_views['trash'] = array(
309
-                'slug'  => 'trash',
310
-                'label' => esc_html__('Trash', 'event_espresso'),
311
-                'count' => 0,
302
+			),
303
+		);
304
+
305
+		if (EE_Registry::instance()->CAP->current_user_can('ee_delete_questions',
306
+			'espresso_registration_form_trash_questions')
307
+		) {
308
+			$this->_views['trash'] = array(
309
+				'slug'  => 'trash',
310
+				'label' => esc_html__('Trash', 'event_espresso'),
311
+				'count' => 0,
312 312
 //				'bulk_action' => array(
313 313
 //					'delete_questions' => esc_html__('Delete Permanently', 'event_espresso'),
314 314
 //					'restore_questions' => esc_html__('Restore', 'event_espresso'),
315
-            );
316
-        }
317
-    }
318
-
319
-    /**
320
-     * This just previews the question groups tab that comes in caffeinated.
321
-     *
322
-     * @return string html
323
-     */
324
-    protected function _questions_groups_preview()
325
-    {
326
-        $this->_admin_page_title              = esc_html__('Question Groups (Preview)', 'event_espresso');
327
-        $this->_template_args['preview_img']  = '<img src="' . REGISTRATION_FORM_ASSETS_URL . 'caf_reg_form_preview.jpg" alt="' . esc_attr__('Preview Question Groups Overview List Table screenshot',
328
-                'event_espresso') . '" />';
329
-        $this->_template_args['preview_text'] = '<strong>' . esc_html__('Question Groups is a feature that is only available in the premium version of Event Espresso 4 which is available with a support license purchase on EventEspresso.com. With the Question Groups feature you are able to create new question groups, edit existing question groups, and create and edit new questions and add them to question groups.',
330
-                'event_espresso') . '</strong>';
331
-        $this->display_admin_caf_preview_page('question_groups_tab');
332
-    }
333
-
334
-
335
-    /**
336
-     * Extracts the question field's values from the POST request to update or insert them
337
-     *
338
-     * @param \EEM_Base $model
339
-     * @return array where each key is the name of a model's field/db column, and each value is its value.
340
-     */
341
-    protected function _set_column_values_for(EEM_Base $model)
342
-    {
343
-        do_action('AHEE_log', __FILE__, __FUNCTION__, '');
344
-        $set_column_values = array();
345
-
346
-        //some initial checks for proper values.
347
-        //if QST_admin_only, then no matter what QST_required is we disable.
348
-        if (! empty($this->_req_data['QST_admin_only'])) {
349
-            $this->_req_data['QST_required'] = 0;
350
-        }
351
-        foreach ($model->field_settings() as $fieldName => $settings) {
352
-            // basically if QSG_identifier is empty or not set
353
-            if ($fieldName === 'QSG_identifier' && (isset($this->_req_data['QSG_identifier']) && empty($this->_req_data['QSG_identifier']))) {
354
-                $QSG_name                      = isset($this->_req_data['QSG_name']) ? $this->_req_data['QSG_name'] : '';
355
-                $set_column_values[$fieldName] = sanitize_title($QSG_name) . '-' . uniqid('', true);
315
+			);
316
+		}
317
+	}
318
+
319
+	/**
320
+	 * This just previews the question groups tab that comes in caffeinated.
321
+	 *
322
+	 * @return string html
323
+	 */
324
+	protected function _questions_groups_preview()
325
+	{
326
+		$this->_admin_page_title              = esc_html__('Question Groups (Preview)', 'event_espresso');
327
+		$this->_template_args['preview_img']  = '<img src="' . REGISTRATION_FORM_ASSETS_URL . 'caf_reg_form_preview.jpg" alt="' . esc_attr__('Preview Question Groups Overview List Table screenshot',
328
+				'event_espresso') . '" />';
329
+		$this->_template_args['preview_text'] = '<strong>' . esc_html__('Question Groups is a feature that is only available in the premium version of Event Espresso 4 which is available with a support license purchase on EventEspresso.com. With the Question Groups feature you are able to create new question groups, edit existing question groups, and create and edit new questions and add them to question groups.',
330
+				'event_espresso') . '</strong>';
331
+		$this->display_admin_caf_preview_page('question_groups_tab');
332
+	}
333
+
334
+
335
+	/**
336
+	 * Extracts the question field's values from the POST request to update or insert them
337
+	 *
338
+	 * @param \EEM_Base $model
339
+	 * @return array where each key is the name of a model's field/db column, and each value is its value.
340
+	 */
341
+	protected function _set_column_values_for(EEM_Base $model)
342
+	{
343
+		do_action('AHEE_log', __FILE__, __FUNCTION__, '');
344
+		$set_column_values = array();
345
+
346
+		//some initial checks for proper values.
347
+		//if QST_admin_only, then no matter what QST_required is we disable.
348
+		if (! empty($this->_req_data['QST_admin_only'])) {
349
+			$this->_req_data['QST_required'] = 0;
350
+		}
351
+		foreach ($model->field_settings() as $fieldName => $settings) {
352
+			// basically if QSG_identifier is empty or not set
353
+			if ($fieldName === 'QSG_identifier' && (isset($this->_req_data['QSG_identifier']) && empty($this->_req_data['QSG_identifier']))) {
354
+				$QSG_name                      = isset($this->_req_data['QSG_name']) ? $this->_req_data['QSG_name'] : '';
355
+				$set_column_values[$fieldName] = sanitize_title($QSG_name) . '-' . uniqid('', true);
356 356
 //				dd($set_column_values);
357
-            } //if the admin label is blank, use a slug version of the question text
358
-            else if ($fieldName === 'QST_admin_label' && (isset($this->_req_data['QST_admin_label']) && empty($this->_req_data['QST_admin_label']))) {
359
-                $QST_text                      = isset($this->_req_data['QST_display_text']) ? $this->_req_data['QST_display_text'] : '';
360
-                $set_column_values[$fieldName] = sanitize_title(wp_trim_words($QST_text, 10));
361
-            } else if ($fieldName === 'QST_admin_only' && (! isset($this->_req_data['QST_admin_only']))) {
362
-                $set_column_values[$fieldName] = 0;
363
-            } else if ($fieldName === 'QST_max') {
364
-                $qst_system = EEM_Question::instance()->get_var(
365
-                    array(
366
-                        array(
367
-                            'QST_ID' => isset($this->_req_data['QST_ID']) ? $this->_req_data['QST_ID'] : 0,
368
-                        ),
369
-                    ),
370
-                    'QST_system');
371
-                $max_max    = EEM_Question::instance()->absolute_max_for_system_question($qst_system);
372
-                if (empty($this->_req_data['QST_max']) ||
373
-                    $this->_req_data['QST_max'] > $max_max
374
-                ) {
375
-                    $set_column_values[$fieldName] = $max_max;
376
-                }
377
-            }
378
-
379
-
380
-            //only add a property to the array if it's not null (otherwise the model should just use the default value)
381
-            if (
382
-                ! isset($set_column_values[$fieldName]) &&
383
-                isset($this->_req_data[$fieldName])
384
-            ) {
385
-                $set_column_values[$fieldName] = $this->_req_data[$fieldName];
386
-            }
387
-
388
-        }
389
-        return $set_column_values;//validation fo this data to be performed by the model before insertion.
390
-    }
391
-
392
-
393
-    /**
394
-     *_questions_overview_list_table
395
-     */
396
-    protected function _questions_overview_list_table()
397
-    {
398
-        $this->_search_btn_label = esc_html__('Questions', 'event_espresso');
399
-        $this->display_admin_list_table_page_with_sidebar();
400
-    }
401
-
402
-
403
-    /**
404
-     * _edit_question
405
-     */
406
-    protected function _edit_question()
407
-    {
408
-        do_action('AHEE_log', __FILE__, __FUNCTION__, '');
409
-        $ID = isset($this->_req_data['QST_ID']) && ! empty($this->_req_data['QST_ID']) ? absint($this->_req_data['QST_ID']) : false;
410
-
411
-        switch ($this->_req_action) {
412
-            case 'add_question' :
413
-                $this->_admin_page_title = esc_html__('Add Question', 'event_espresso');
414
-                break;
415
-            case 'edit_question' :
416
-                $this->_admin_page_title = esc_html__('Edit Question', 'event_espresso');
417
-                break;
418
-            default :
419
-                $this->_admin_page_title = ucwords(str_replace('_', ' ', $this->_req_action));
420
-        }
421
-
422
-        // add PRC_ID to title if editing
423
-        $this->_admin_page_title = $ID ? $this->_admin_page_title . ' # ' . $ID : $this->_admin_page_title;
424
-        if ($ID) {
425
-            $question                 = $this->_question_model->get_one_by_ID($ID);
426
-            $additional_hidden_fields = array('QST_ID' => array('type' => 'hidden', 'value' => $ID));
427
-            $this->_set_add_edit_form_tags('update_question', $additional_hidden_fields);
428
-        } else {
429
-            $question = EE_Question::new_instance();
430
-            $question->set_order_to_latest();
431
-            $this->_set_add_edit_form_tags('insert_question');
432
-        }
433
-        $question_types                                     = $question->has_answers()
434
-            ? $this->_question_model->question_types_in_same_category($question->type())
435
-            : $this->_question_model->allowed_question_types();
436
-        $this->_template_args['QST_ID']                     = $ID;
437
-        $this->_template_args['question']                   = $question;
438
-        $this->_template_args['question_types']             = $question_types;
439
-        $this->_template_args['max_max']                    = EEM_Question::instance()->absolute_max_for_system_question(
440
-            $question->system_ID()
441
-        );
442
-        $this->_template_args['question_type_descriptions'] = $this->_get_question_type_descriptions();
443
-        $this->_set_publish_post_box_vars('id', $ID);
444
-        $this->_template_args['admin_page_content'] = EEH_Template::display_template(
445
-            REGISTRATION_FORM_TEMPLATE_PATH . 'questions_main_meta_box.template.php',
446
-            $this->_template_args, true
447
-        );
448
-
449
-        // the details template wrapper
450
-        $this->display_admin_page_with_sidebar();
451
-    }
452
-
453
-
454
-    /**
455
-     * @return string
456
-     */
457
-    protected function _get_question_type_descriptions()
458
-    {
459
-        EE_Registry::instance()->load_helper('HTML');
460
-        $descriptions               = '';
461
-        $question_type_descriptions = EEM_Question::instance()->question_descriptions();
462
-        foreach ($question_type_descriptions as $type => $question_type_description) {
463
-            if ($type == 'HTML_TEXTAREA') {
464
-                $html = new EE_Simple_HTML_Validation_Strategy();
465
-                $question_type_description .= sprintf(
466
-                    esc_html__('%1$s(allowed tags: %2$s)', 'event_espresso'),
467
-                    '<br/>',
468
-                    $html->get_list_of_allowed_tags()
469
-                );
470
-            }
471
-            $descriptions .= EEH_HTML::p(
472
-                $question_type_description,
473
-                'question_type_description-' . $type,
474
-                'question_type_description description',
475
-                'display:none;'
476
-            );
477
-        }
478
-        return $descriptions;
479
-    }
480
-
481
-
482
-    /**
483
-     * @param bool|true $new_question
484
-     * @throws \EE_Error
485
-     */
486
-    protected function _insert_or_update_question($new_question = true)
487
-    {
488
-        do_action('AHEE_log', __FILE__, __FUNCTION__, '');
489
-        $set_column_values = $this->_set_column_values_for($this->_question_model);
490
-        if ($new_question) {
491
-            $ID          = $this->_question_model->insert($set_column_values);
492
-            $success     = $ID ? true : false;
493
-            $action_desc = 'added';
494
-        } else {
495
-            $ID     = absint($this->_req_data['QST_ID']);
496
-            $pk     = $this->_question_model->primary_key_name();
497
-            $wheres = array($pk => $ID);
498
-            unset($set_column_values[$pk]);
499
-            $success     = $this->_question_model->update($set_column_values, array($wheres));
500
-            $action_desc = 'updated';
501
-        }
502
-
503
-        if ($ID) {
504
-            //save the related options
505
-            //trash removed options, save old ones
506
-            //get list of all options
507
-            /** @type EE_Question $question */
508
-            $question = $this->_question_model->get_one_by_ID($ID);
509
-            $options  = $question->options();
510
-            if (! empty($options)) {
511
-                foreach ($options as $option_ID => $option) {
512
-                    $option_req_index = $this->_get_option_req_data_index($option_ID);
513
-                    if ($option_req_index !== false) {
514
-                        $option->save($this->_req_data['question_options'][$option_req_index]);
515
-                    } else {
516
-                        //not found, remove it
517
-                        $option->delete();
518
-                    }
519
-                }
520
-            }
521
-            //save new related options
522
-            foreach ($this->_req_data['question_options'] as $index => $option_req_data) {
523
-                //skip $index that is from our sample
524
-                if ( $index === 'xxcountxx' ) {
525
-                    continue;
526
-                }
527
-                //note we allow saving blank options.
528
-                if (empty($option_req_data['QSO_ID'])
529
-                ) {//no ID! save it!
530
-                    $new_option = EE_Question_Option::new_instance(array(
531
-                        'QSO_value' => $option_req_data['QSO_value'],
532
-                        'QSO_desc'  => $option_req_data['QSO_desc'],
533
-                        'QSO_order' => $option_req_data['QSO_order'],
534
-                        'QST_ID'    => $question->ID(),
535
-                    ));
536
-                    $new_option->save();
537
-                }
538
-            }
539
-        }
540
-        $query_args = array('action' => 'edit_question', 'QST_ID' => $ID);
541
-        if ($success !== false) {
542
-            $msg = $new_question ? sprintf(esc_html__('The %s has been created', 'event_espresso'),
543
-                $this->_question_model->item_name()) : sprintf(esc_html__('The %s has been updated', 'event_espresso'),
544
-                $this->_question_model->item_name());
545
-            EE_Error::add_success($msg);
546
-        }
547
-
548
-        $this->_redirect_after_action(false, '', $action_desc, $query_args, true);
549
-    }
550
-
551
-
552
-    /**
553
-     * Upon saving a question, there should be an array of 'question_options'. This array is index numerically, but not
554
-     * by ID
555
-     * (this is done because new question options don't have an ID, but we may want to add multiple simultaneously).
556
-     * So, this function gets the index in that request data array called question_options. Returns FALSE if not found.
557
-     *
558
-     * @param int $ID of the question option to find
559
-     * @return int index in question_options array if successful, FALSE if unsuccessful
560
-     */
561
-    protected function _get_option_req_data_index($ID)
562
-    {
563
-        $req_data_for_question_options = $this->_req_data['question_options'];
564
-        foreach ($req_data_for_question_options as $num => $option_data) {
565
-            if (array_key_exists('QSO_ID', $option_data) && (int)$option_data['QSO_ID'] === $ID) {
566
-                return $num;
567
-            }
568
-        }
569
-        return false;
570
-    }
571
-
572
-
573
-
574
-
575
-    /***********/
576
-    /* QUERIES */
577
-    /**
578
-     * For internal use in getting all the query parameters
579
-     * (because it's pretty well the same between question, question groups,
580
-     * and for both when searching for trashed and untrashed ones)
581
-     *
582
-     * @param EEM_Base $model either EEM_Question or EEM_Question_Group
583
-     * @param int      $per_page
584
-     * @param int      $current_page
585
-     * @return array lik EEM_Base::get_all's $query_params parameter
586
-     */
587
-    protected function get_query_params($model, $per_page = 10, $current_page = 10)
588
-    {
589
-        $query_params             = array();
590
-        $offset                   = ($current_page - 1) * $per_page;
591
-        $query_params['limit']    = array($offset, $per_page);
592
-        $order                    = (isset($this->_req_data['order']) && ! empty($this->_req_data['order'])) ? $this->_req_data['order'] : 'ASC';
593
-        $orderby_field            = $model instanceof EEM_Question ? 'QST_ID' : 'QSG_order';
594
-        $field_to_order_by        = empty($this->_req_data['orderby']) ? $orderby_field : $this->_req_data['orderby'];
595
-        $query_params['order_by'] = array($field_to_order_by => $order);
596
-        $search_string            = array_key_exists('s', $this->_req_data) ? $this->_req_data['s'] : null;
597
-        if (! empty($search_string)) {
598
-            if ($model instanceof EEM_Question_Group) {
599
-                $query_params[0] = array(
600
-                    'OR' => array(
601
-                        'QSG_name' => array('LIKE', "%$search_string%"),
602
-                        'QSG_desc' => array('LIKE', "%$search_string%"),
603
-                    ),
604
-                );
605
-            } else {
606
-                $query_params[0] = array(
607
-                    'QST_display_text' => array('LIKE', "%$search_string%"),
608
-                );
609
-            }
610
-        }
611
-
612
-        //capability checks (just leaving this commented out for reference because it illustrates some complicated query params that could be useful when fully implemented)
613
-        /*if ( $model instanceof EEM_Question_Group ) {
357
+			} //if the admin label is blank, use a slug version of the question text
358
+			else if ($fieldName === 'QST_admin_label' && (isset($this->_req_data['QST_admin_label']) && empty($this->_req_data['QST_admin_label']))) {
359
+				$QST_text                      = isset($this->_req_data['QST_display_text']) ? $this->_req_data['QST_display_text'] : '';
360
+				$set_column_values[$fieldName] = sanitize_title(wp_trim_words($QST_text, 10));
361
+			} else if ($fieldName === 'QST_admin_only' && (! isset($this->_req_data['QST_admin_only']))) {
362
+				$set_column_values[$fieldName] = 0;
363
+			} else if ($fieldName === 'QST_max') {
364
+				$qst_system = EEM_Question::instance()->get_var(
365
+					array(
366
+						array(
367
+							'QST_ID' => isset($this->_req_data['QST_ID']) ? $this->_req_data['QST_ID'] : 0,
368
+						),
369
+					),
370
+					'QST_system');
371
+				$max_max    = EEM_Question::instance()->absolute_max_for_system_question($qst_system);
372
+				if (empty($this->_req_data['QST_max']) ||
373
+					$this->_req_data['QST_max'] > $max_max
374
+				) {
375
+					$set_column_values[$fieldName] = $max_max;
376
+				}
377
+			}
378
+
379
+
380
+			//only add a property to the array if it's not null (otherwise the model should just use the default value)
381
+			if (
382
+				! isset($set_column_values[$fieldName]) &&
383
+				isset($this->_req_data[$fieldName])
384
+			) {
385
+				$set_column_values[$fieldName] = $this->_req_data[$fieldName];
386
+			}
387
+
388
+		}
389
+		return $set_column_values;//validation fo this data to be performed by the model before insertion.
390
+	}
391
+
392
+
393
+	/**
394
+	 *_questions_overview_list_table
395
+	 */
396
+	protected function _questions_overview_list_table()
397
+	{
398
+		$this->_search_btn_label = esc_html__('Questions', 'event_espresso');
399
+		$this->display_admin_list_table_page_with_sidebar();
400
+	}
401
+
402
+
403
+	/**
404
+	 * _edit_question
405
+	 */
406
+	protected function _edit_question()
407
+	{
408
+		do_action('AHEE_log', __FILE__, __FUNCTION__, '');
409
+		$ID = isset($this->_req_data['QST_ID']) && ! empty($this->_req_data['QST_ID']) ? absint($this->_req_data['QST_ID']) : false;
410
+
411
+		switch ($this->_req_action) {
412
+			case 'add_question' :
413
+				$this->_admin_page_title = esc_html__('Add Question', 'event_espresso');
414
+				break;
415
+			case 'edit_question' :
416
+				$this->_admin_page_title = esc_html__('Edit Question', 'event_espresso');
417
+				break;
418
+			default :
419
+				$this->_admin_page_title = ucwords(str_replace('_', ' ', $this->_req_action));
420
+		}
421
+
422
+		// add PRC_ID to title if editing
423
+		$this->_admin_page_title = $ID ? $this->_admin_page_title . ' # ' . $ID : $this->_admin_page_title;
424
+		if ($ID) {
425
+			$question                 = $this->_question_model->get_one_by_ID($ID);
426
+			$additional_hidden_fields = array('QST_ID' => array('type' => 'hidden', 'value' => $ID));
427
+			$this->_set_add_edit_form_tags('update_question', $additional_hidden_fields);
428
+		} else {
429
+			$question = EE_Question::new_instance();
430
+			$question->set_order_to_latest();
431
+			$this->_set_add_edit_form_tags('insert_question');
432
+		}
433
+		$question_types                                     = $question->has_answers()
434
+			? $this->_question_model->question_types_in_same_category($question->type())
435
+			: $this->_question_model->allowed_question_types();
436
+		$this->_template_args['QST_ID']                     = $ID;
437
+		$this->_template_args['question']                   = $question;
438
+		$this->_template_args['question_types']             = $question_types;
439
+		$this->_template_args['max_max']                    = EEM_Question::instance()->absolute_max_for_system_question(
440
+			$question->system_ID()
441
+		);
442
+		$this->_template_args['question_type_descriptions'] = $this->_get_question_type_descriptions();
443
+		$this->_set_publish_post_box_vars('id', $ID);
444
+		$this->_template_args['admin_page_content'] = EEH_Template::display_template(
445
+			REGISTRATION_FORM_TEMPLATE_PATH . 'questions_main_meta_box.template.php',
446
+			$this->_template_args, true
447
+		);
448
+
449
+		// the details template wrapper
450
+		$this->display_admin_page_with_sidebar();
451
+	}
452
+
453
+
454
+	/**
455
+	 * @return string
456
+	 */
457
+	protected function _get_question_type_descriptions()
458
+	{
459
+		EE_Registry::instance()->load_helper('HTML');
460
+		$descriptions               = '';
461
+		$question_type_descriptions = EEM_Question::instance()->question_descriptions();
462
+		foreach ($question_type_descriptions as $type => $question_type_description) {
463
+			if ($type == 'HTML_TEXTAREA') {
464
+				$html = new EE_Simple_HTML_Validation_Strategy();
465
+				$question_type_description .= sprintf(
466
+					esc_html__('%1$s(allowed tags: %2$s)', 'event_espresso'),
467
+					'<br/>',
468
+					$html->get_list_of_allowed_tags()
469
+				);
470
+			}
471
+			$descriptions .= EEH_HTML::p(
472
+				$question_type_description,
473
+				'question_type_description-' . $type,
474
+				'question_type_description description',
475
+				'display:none;'
476
+			);
477
+		}
478
+		return $descriptions;
479
+	}
480
+
481
+
482
+	/**
483
+	 * @param bool|true $new_question
484
+	 * @throws \EE_Error
485
+	 */
486
+	protected function _insert_or_update_question($new_question = true)
487
+	{
488
+		do_action('AHEE_log', __FILE__, __FUNCTION__, '');
489
+		$set_column_values = $this->_set_column_values_for($this->_question_model);
490
+		if ($new_question) {
491
+			$ID          = $this->_question_model->insert($set_column_values);
492
+			$success     = $ID ? true : false;
493
+			$action_desc = 'added';
494
+		} else {
495
+			$ID     = absint($this->_req_data['QST_ID']);
496
+			$pk     = $this->_question_model->primary_key_name();
497
+			$wheres = array($pk => $ID);
498
+			unset($set_column_values[$pk]);
499
+			$success     = $this->_question_model->update($set_column_values, array($wheres));
500
+			$action_desc = 'updated';
501
+		}
502
+
503
+		if ($ID) {
504
+			//save the related options
505
+			//trash removed options, save old ones
506
+			//get list of all options
507
+			/** @type EE_Question $question */
508
+			$question = $this->_question_model->get_one_by_ID($ID);
509
+			$options  = $question->options();
510
+			if (! empty($options)) {
511
+				foreach ($options as $option_ID => $option) {
512
+					$option_req_index = $this->_get_option_req_data_index($option_ID);
513
+					if ($option_req_index !== false) {
514
+						$option->save($this->_req_data['question_options'][$option_req_index]);
515
+					} else {
516
+						//not found, remove it
517
+						$option->delete();
518
+					}
519
+				}
520
+			}
521
+			//save new related options
522
+			foreach ($this->_req_data['question_options'] as $index => $option_req_data) {
523
+				//skip $index that is from our sample
524
+				if ( $index === 'xxcountxx' ) {
525
+					continue;
526
+				}
527
+				//note we allow saving blank options.
528
+				if (empty($option_req_data['QSO_ID'])
529
+				) {//no ID! save it!
530
+					$new_option = EE_Question_Option::new_instance(array(
531
+						'QSO_value' => $option_req_data['QSO_value'],
532
+						'QSO_desc'  => $option_req_data['QSO_desc'],
533
+						'QSO_order' => $option_req_data['QSO_order'],
534
+						'QST_ID'    => $question->ID(),
535
+					));
536
+					$new_option->save();
537
+				}
538
+			}
539
+		}
540
+		$query_args = array('action' => 'edit_question', 'QST_ID' => $ID);
541
+		if ($success !== false) {
542
+			$msg = $new_question ? sprintf(esc_html__('The %s has been created', 'event_espresso'),
543
+				$this->_question_model->item_name()) : sprintf(esc_html__('The %s has been updated', 'event_espresso'),
544
+				$this->_question_model->item_name());
545
+			EE_Error::add_success($msg);
546
+		}
547
+
548
+		$this->_redirect_after_action(false, '', $action_desc, $query_args, true);
549
+	}
550
+
551
+
552
+	/**
553
+	 * Upon saving a question, there should be an array of 'question_options'. This array is index numerically, but not
554
+	 * by ID
555
+	 * (this is done because new question options don't have an ID, but we may want to add multiple simultaneously).
556
+	 * So, this function gets the index in that request data array called question_options. Returns FALSE if not found.
557
+	 *
558
+	 * @param int $ID of the question option to find
559
+	 * @return int index in question_options array if successful, FALSE if unsuccessful
560
+	 */
561
+	protected function _get_option_req_data_index($ID)
562
+	{
563
+		$req_data_for_question_options = $this->_req_data['question_options'];
564
+		foreach ($req_data_for_question_options as $num => $option_data) {
565
+			if (array_key_exists('QSO_ID', $option_data) && (int)$option_data['QSO_ID'] === $ID) {
566
+				return $num;
567
+			}
568
+		}
569
+		return false;
570
+	}
571
+
572
+
573
+
574
+
575
+	/***********/
576
+	/* QUERIES */
577
+	/**
578
+	 * For internal use in getting all the query parameters
579
+	 * (because it's pretty well the same between question, question groups,
580
+	 * and for both when searching for trashed and untrashed ones)
581
+	 *
582
+	 * @param EEM_Base $model either EEM_Question or EEM_Question_Group
583
+	 * @param int      $per_page
584
+	 * @param int      $current_page
585
+	 * @return array lik EEM_Base::get_all's $query_params parameter
586
+	 */
587
+	protected function get_query_params($model, $per_page = 10, $current_page = 10)
588
+	{
589
+		$query_params             = array();
590
+		$offset                   = ($current_page - 1) * $per_page;
591
+		$query_params['limit']    = array($offset, $per_page);
592
+		$order                    = (isset($this->_req_data['order']) && ! empty($this->_req_data['order'])) ? $this->_req_data['order'] : 'ASC';
593
+		$orderby_field            = $model instanceof EEM_Question ? 'QST_ID' : 'QSG_order';
594
+		$field_to_order_by        = empty($this->_req_data['orderby']) ? $orderby_field : $this->_req_data['orderby'];
595
+		$query_params['order_by'] = array($field_to_order_by => $order);
596
+		$search_string            = array_key_exists('s', $this->_req_data) ? $this->_req_data['s'] : null;
597
+		if (! empty($search_string)) {
598
+			if ($model instanceof EEM_Question_Group) {
599
+				$query_params[0] = array(
600
+					'OR' => array(
601
+						'QSG_name' => array('LIKE', "%$search_string%"),
602
+						'QSG_desc' => array('LIKE', "%$search_string%"),
603
+					),
604
+				);
605
+			} else {
606
+				$query_params[0] = array(
607
+					'QST_display_text' => array('LIKE', "%$search_string%"),
608
+				);
609
+			}
610
+		}
611
+
612
+		//capability checks (just leaving this commented out for reference because it illustrates some complicated query params that could be useful when fully implemented)
613
+		/*if ( $model instanceof EEM_Question_Group ) {
614 614
             if ( ! EE_Registry::instance()->CAP->current_user_can( 'edit_others_question_groups', 'espresso_registration_form_edit_question_group' ) ) {
615 615
                 $query_params[0] = array(
616 616
                     'AND' => array(
@@ -640,62 +640,62 @@  discard block
 block discarded – undo
640 640
             }
641 641
         }/**/
642 642
 
643
-        return $query_params;
644
-
645
-    }
646
-
647
-
648
-    /**
649
-     * @param int        $per_page
650
-     * @param int        $current_page
651
-     * @param bool|false $count
652
-     * @return \EE_Soft_Delete_Base_Class[]|int
653
-     */
654
-    public function get_questions($per_page = 10, $current_page = 1, $count = false)
655
-    {
656
-        $QST          = EEM_Question::instance();
657
-        $query_params = $this->get_query_params($QST, $per_page, $current_page);
658
-        if ($count) {
659
-            $where   = isset($query_params[0]) ? array($query_params[0]) : array();
660
-            $results = $QST->count($where);
661
-        } else {
662
-            $results = $QST->get_all($query_params);
663
-        }
664
-        return $results;
665
-
666
-    }
667
-
668
-
669
-    /**
670
-     * @param            $per_page
671
-     * @param int        $current_page
672
-     * @param bool|false $count
673
-     * @return \EE_Soft_Delete_Base_Class[]|int
674
-     */
675
-    public function get_trashed_questions($per_page, $current_page = 1, $count = false)
676
-    {
677
-        $query_params = $this->get_query_params(EEM_Question::instance(), $per_page, $current_page);
678
-        $where        = isset($query_params[0]) ? array($query_params[0]) : array();
679
-        $questions    = $count ? EEM_Question::instance()->count_deleted($where) : EEM_Question::instance()->get_all_deleted($query_params);
680
-        return $questions;
681
-    }
682
-
683
-
684
-    /**
685
-     * @param            $per_page
686
-     * @param int        $current_page
687
-     * @param bool|false $count
688
-     * @return \EE_Soft_Delete_Base_Class[]
689
-     */
690
-    public function get_question_groups($per_page, $current_page = 1, $count = false)
691
-    {
692
-        /** @type EEM_Question_Group $questionGroupModel */
693
-        $questionGroupModel = EEM_Question_Group::instance();
694
-        //note: this a subclass of EEM_Soft_Delete_Base, so this is actually only getting non-trashed items
695
-        return $questionGroupModel->get_all(
696
-            $this->get_query_params($questionGroupModel, $per_page, $current_page)
697
-        );
698
-    }
643
+		return $query_params;
644
+
645
+	}
646
+
647
+
648
+	/**
649
+	 * @param int        $per_page
650
+	 * @param int        $current_page
651
+	 * @param bool|false $count
652
+	 * @return \EE_Soft_Delete_Base_Class[]|int
653
+	 */
654
+	public function get_questions($per_page = 10, $current_page = 1, $count = false)
655
+	{
656
+		$QST          = EEM_Question::instance();
657
+		$query_params = $this->get_query_params($QST, $per_page, $current_page);
658
+		if ($count) {
659
+			$where   = isset($query_params[0]) ? array($query_params[0]) : array();
660
+			$results = $QST->count($where);
661
+		} else {
662
+			$results = $QST->get_all($query_params);
663
+		}
664
+		return $results;
665
+
666
+	}
667
+
668
+
669
+	/**
670
+	 * @param            $per_page
671
+	 * @param int        $current_page
672
+	 * @param bool|false $count
673
+	 * @return \EE_Soft_Delete_Base_Class[]|int
674
+	 */
675
+	public function get_trashed_questions($per_page, $current_page = 1, $count = false)
676
+	{
677
+		$query_params = $this->get_query_params(EEM_Question::instance(), $per_page, $current_page);
678
+		$where        = isset($query_params[0]) ? array($query_params[0]) : array();
679
+		$questions    = $count ? EEM_Question::instance()->count_deleted($where) : EEM_Question::instance()->get_all_deleted($query_params);
680
+		return $questions;
681
+	}
682
+
683
+
684
+	/**
685
+	 * @param            $per_page
686
+	 * @param int        $current_page
687
+	 * @param bool|false $count
688
+	 * @return \EE_Soft_Delete_Base_Class[]
689
+	 */
690
+	public function get_question_groups($per_page, $current_page = 1, $count = false)
691
+	{
692
+		/** @type EEM_Question_Group $questionGroupModel */
693
+		$questionGroupModel = EEM_Question_Group::instance();
694
+		//note: this a subclass of EEM_Soft_Delete_Base, so this is actually only getting non-trashed items
695
+		return $questionGroupModel->get_all(
696
+			$this->get_query_params($questionGroupModel, $per_page, $current_page)
697
+		);
698
+	}
699 699
 
700 700
 
701 701
 } //ends Registration_Form_Admin_Page class
Please login to merge, or discard this patch.
Spacing   +23 added lines, -23 removed lines patch added patch discarded remove patch
@@ -1,5 +1,5 @@  discard block
 block discarded – undo
1 1
 <?php
2
-if (! defined('EVENT_ESPRESSO_VERSION')) {
2
+if ( ! defined('EVENT_ESPRESSO_VERSION')) {
3 3
     exit('NO direct script access allowed');
4 4
 }
5 5
 
@@ -66,8 +66,8 @@  discard block
 block discarded – undo
66 66
      */
67 67
     public function __construct($routing = true)
68 68
     {
69
-        require_once(EE_MODELS . 'EEM_Question.model.php');
70
-        require_once(EE_MODELS . 'EEM_Question_Group.model.php');
69
+        require_once(EE_MODELS.'EEM_Question.model.php');
70
+        require_once(EE_MODELS.'EEM_Question_Group.model.php');
71 71
         $this->_question_model       = EEM_Question::instance();
72 72
         $this->_question_group_model = EEM_Question_Group::instance();
73 73
         parent::__construct($routing);
@@ -232,7 +232,7 @@  discard block
 block discarded – undo
232 232
     public function load_scripts_styles()
233 233
     {
234 234
         wp_register_style('espresso_registration',
235
-            REGISTRATION_FORM_ASSETS_URL . 'espresso_registration_form_admin.css', array(), EVENT_ESPRESSO_VERSION);
235
+            REGISTRATION_FORM_ASSETS_URL.'espresso_registration_form_admin.css', array(), EVENT_ESPRESSO_VERSION);
236 236
         wp_enqueue_style('espresso_registration');
237 237
     }
238 238
 
@@ -258,7 +258,7 @@  discard block
 block discarded – undo
258 258
     {
259 259
         $this->load_scripts_styles_forms();
260 260
         wp_register_script('espresso_registration_form_single',
261
-            REGISTRATION_FORM_ASSETS_URL . 'espresso_registration_form_admin.js', array('jquery-ui-sortable'),
261
+            REGISTRATION_FORM_ASSETS_URL.'espresso_registration_form_admin.js', array('jquery-ui-sortable'),
262 262
             EVENT_ESPRESSO_VERSION, true);
263 263
         wp_enqueue_script('espresso_registration_form_single');
264 264
     }
@@ -267,7 +267,7 @@  discard block
 block discarded – undo
267 267
     {
268 268
         $this->load_scripts_styles_forms();
269 269
         wp_register_script('espresso_registration_form_single',
270
-            REGISTRATION_FORM_ASSETS_URL . 'espresso_registration_form_admin.js', array('jquery-ui-sortable'),
270
+            REGISTRATION_FORM_ASSETS_URL.'espresso_registration_form_admin.js', array('jquery-ui-sortable'),
271 271
             EVENT_ESPRESSO_VERSION, true);
272 272
         wp_enqueue_script('espresso_registration_form_single');
273 273
     }
@@ -275,7 +275,7 @@  discard block
 block discarded – undo
275 275
 
276 276
     public function recaptcha_info_help_tab()
277 277
     {
278
-        $template = REGISTRATION_FORM_TEMPLATE_PATH . 'recaptcha_info_help_tab.template.php';
278
+        $template = REGISTRATION_FORM_TEMPLATE_PATH.'recaptcha_info_help_tab.template.php';
279 279
         EEH_Template::display_template($template, array());
280 280
     }
281 281
 
@@ -324,10 +324,10 @@  discard block
 block discarded – undo
324 324
     protected function _questions_groups_preview()
325 325
     {
326 326
         $this->_admin_page_title              = esc_html__('Question Groups (Preview)', 'event_espresso');
327
-        $this->_template_args['preview_img']  = '<img src="' . REGISTRATION_FORM_ASSETS_URL . 'caf_reg_form_preview.jpg" alt="' . esc_attr__('Preview Question Groups Overview List Table screenshot',
328
-                'event_espresso') . '" />';
329
-        $this->_template_args['preview_text'] = '<strong>' . esc_html__('Question Groups is a feature that is only available in the premium version of Event Espresso 4 which is available with a support license purchase on EventEspresso.com. With the Question Groups feature you are able to create new question groups, edit existing question groups, and create and edit new questions and add them to question groups.',
330
-                'event_espresso') . '</strong>';
327
+        $this->_template_args['preview_img']  = '<img src="'.REGISTRATION_FORM_ASSETS_URL.'caf_reg_form_preview.jpg" alt="'.esc_attr__('Preview Question Groups Overview List Table screenshot',
328
+                'event_espresso').'" />';
329
+        $this->_template_args['preview_text'] = '<strong>'.esc_html__('Question Groups is a feature that is only available in the premium version of Event Espresso 4 which is available with a support license purchase on EventEspresso.com. With the Question Groups feature you are able to create new question groups, edit existing question groups, and create and edit new questions and add them to question groups.',
330
+                'event_espresso').'</strong>';
331 331
         $this->display_admin_caf_preview_page('question_groups_tab');
332 332
     }
333 333
 
@@ -345,20 +345,20 @@  discard block
 block discarded – undo
345 345
 
346 346
         //some initial checks for proper values.
347 347
         //if QST_admin_only, then no matter what QST_required is we disable.
348
-        if (! empty($this->_req_data['QST_admin_only'])) {
348
+        if ( ! empty($this->_req_data['QST_admin_only'])) {
349 349
             $this->_req_data['QST_required'] = 0;
350 350
         }
351 351
         foreach ($model->field_settings() as $fieldName => $settings) {
352 352
             // basically if QSG_identifier is empty or not set
353 353
             if ($fieldName === 'QSG_identifier' && (isset($this->_req_data['QSG_identifier']) && empty($this->_req_data['QSG_identifier']))) {
354 354
                 $QSG_name                      = isset($this->_req_data['QSG_name']) ? $this->_req_data['QSG_name'] : '';
355
-                $set_column_values[$fieldName] = sanitize_title($QSG_name) . '-' . uniqid('', true);
355
+                $set_column_values[$fieldName] = sanitize_title($QSG_name).'-'.uniqid('', true);
356 356
 //				dd($set_column_values);
357 357
             } //if the admin label is blank, use a slug version of the question text
358 358
             else if ($fieldName === 'QST_admin_label' && (isset($this->_req_data['QST_admin_label']) && empty($this->_req_data['QST_admin_label']))) {
359 359
                 $QST_text                      = isset($this->_req_data['QST_display_text']) ? $this->_req_data['QST_display_text'] : '';
360 360
                 $set_column_values[$fieldName] = sanitize_title(wp_trim_words($QST_text, 10));
361
-            } else if ($fieldName === 'QST_admin_only' && (! isset($this->_req_data['QST_admin_only']))) {
361
+            } else if ($fieldName === 'QST_admin_only' && ( ! isset($this->_req_data['QST_admin_only']))) {
362 362
                 $set_column_values[$fieldName] = 0;
363 363
             } else if ($fieldName === 'QST_max') {
364 364
                 $qst_system = EEM_Question::instance()->get_var(
@@ -368,7 +368,7 @@  discard block
 block discarded – undo
368 368
                         ),
369 369
                     ),
370 370
                     'QST_system');
371
-                $max_max    = EEM_Question::instance()->absolute_max_for_system_question($qst_system);
371
+                $max_max = EEM_Question::instance()->absolute_max_for_system_question($qst_system);
372 372
                 if (empty($this->_req_data['QST_max']) ||
373 373
                     $this->_req_data['QST_max'] > $max_max
374 374
                 ) {
@@ -386,7 +386,7 @@  discard block
 block discarded – undo
386 386
             }
387 387
 
388 388
         }
389
-        return $set_column_values;//validation fo this data to be performed by the model before insertion.
389
+        return $set_column_values; //validation fo this data to be performed by the model before insertion.
390 390
     }
391 391
 
392 392
 
@@ -420,7 +420,7 @@  discard block
 block discarded – undo
420 420
         }
421 421
 
422 422
         // add PRC_ID to title if editing
423
-        $this->_admin_page_title = $ID ? $this->_admin_page_title . ' # ' . $ID : $this->_admin_page_title;
423
+        $this->_admin_page_title = $ID ? $this->_admin_page_title.' # '.$ID : $this->_admin_page_title;
424 424
         if ($ID) {
425 425
             $question                 = $this->_question_model->get_one_by_ID($ID);
426 426
             $additional_hidden_fields = array('QST_ID' => array('type' => 'hidden', 'value' => $ID));
@@ -442,7 +442,7 @@  discard block
 block discarded – undo
442 442
         $this->_template_args['question_type_descriptions'] = $this->_get_question_type_descriptions();
443 443
         $this->_set_publish_post_box_vars('id', $ID);
444 444
         $this->_template_args['admin_page_content'] = EEH_Template::display_template(
445
-            REGISTRATION_FORM_TEMPLATE_PATH . 'questions_main_meta_box.template.php',
445
+            REGISTRATION_FORM_TEMPLATE_PATH.'questions_main_meta_box.template.php',
446 446
             $this->_template_args, true
447 447
         );
448 448
 
@@ -470,7 +470,7 @@  discard block
 block discarded – undo
470 470
             }
471 471
             $descriptions .= EEH_HTML::p(
472 472
                 $question_type_description,
473
-                'question_type_description-' . $type,
473
+                'question_type_description-'.$type,
474 474
                 'question_type_description description',
475 475
                 'display:none;'
476 476
             );
@@ -507,7 +507,7 @@  discard block
 block discarded – undo
507 507
             /** @type EE_Question $question */
508 508
             $question = $this->_question_model->get_one_by_ID($ID);
509 509
             $options  = $question->options();
510
-            if (! empty($options)) {
510
+            if ( ! empty($options)) {
511 511
                 foreach ($options as $option_ID => $option) {
512 512
                     $option_req_index = $this->_get_option_req_data_index($option_ID);
513 513
                     if ($option_req_index !== false) {
@@ -521,7 +521,7 @@  discard block
 block discarded – undo
521 521
             //save new related options
522 522
             foreach ($this->_req_data['question_options'] as $index => $option_req_data) {
523 523
                 //skip $index that is from our sample
524
-                if ( $index === 'xxcountxx' ) {
524
+                if ($index === 'xxcountxx') {
525 525
                     continue;
526 526
                 }
527 527
                 //note we allow saving blank options.
@@ -562,7 +562,7 @@  discard block
 block discarded – undo
562 562
     {
563 563
         $req_data_for_question_options = $this->_req_data['question_options'];
564 564
         foreach ($req_data_for_question_options as $num => $option_data) {
565
-            if (array_key_exists('QSO_ID', $option_data) && (int)$option_data['QSO_ID'] === $ID) {
565
+            if (array_key_exists('QSO_ID', $option_data) && (int) $option_data['QSO_ID'] === $ID) {
566 566
                 return $num;
567 567
             }
568 568
         }
@@ -594,7 +594,7 @@  discard block
 block discarded – undo
594 594
         $field_to_order_by        = empty($this->_req_data['orderby']) ? $orderby_field : $this->_req_data['orderby'];
595 595
         $query_params['order_by'] = array($field_to_order_by => $order);
596 596
         $search_string            = array_key_exists('s', $this->_req_data) ? $this->_req_data['s'] : null;
597
-        if (! empty($search_string)) {
597
+        if ( ! empty($search_string)) {
598 598
             if ($model instanceof EEM_Question_Group) {
599 599
                 $query_params[0] = array(
600 600
                     'OR' => array(
Please login to merge, or discard this patch.
admin_pages/registrations/Registrations_Admin_Page.core.php 2 patches
Indentation   +2947 added lines, -2947 removed lines patch added patch discarded remove patch
@@ -1,5 +1,5 @@  discard block
 block discarded – undo
1 1
 <?php if ( ! defined('EVENT_ESPRESSO_VERSION')) {
2
-    exit('No direct script access allowed');
2
+	exit('No direct script access allowed');
3 3
 }
4 4
 
5 5
 
@@ -23,1831 +23,1831 @@  discard block
 block discarded – undo
23 23
 class Registrations_Admin_Page extends EE_Admin_Page_CPT
24 24
 {
25 25
 
26
-    /**
27
-     * @var EE_Registration
28
-     */
29
-    private $_registration;
30
-
31
-    /**
32
-     * @var EE_Event
33
-     */
34
-    private $_reg_event;
35
-
36
-    /**
37
-     * @var EE_Session
38
-     */
39
-    private $_session;
40
-
41
-    private static $_reg_status;
42
-
43
-    /**
44
-     * Form for displaying the custom questions for this registration.
45
-     * This gets used a few times throughout the request so its best to cache it
46
-     *
47
-     * @var EE_Registration_Custom_Questions_Form
48
-     */
49
-    protected $_reg_custom_questions_form = null;
50
-
51
-
52
-    /**
53
-     *        constructor
54
-     *
55
-     * @Constructor
56
-     * @access public
57
-     * @param bool $routing
58
-     * @return Registrations_Admin_Page
59
-     */
60
-    public function __construct($routing = true)
61
-    {
62
-        parent::__construct($routing);
63
-        add_action('wp_loaded', array($this, 'wp_loaded'));
64
-    }
65
-
66
-
67
-    public function wp_loaded()
68
-    {
69
-        // when adding a new registration...
70
-        if (isset($this->_req_data['action']) && $this->_req_data['action'] === 'new_registration') {
71
-            EE_System::do_not_cache();
72
-            if ( ! isset($this->_req_data['processing_registration'])
73
-                 || absint($this->_req_data['processing_registration']) !== 1
74
-            ) {
75
-                // and it's NOT the attendee information reg step
76
-                // force cookie expiration by setting time to last week
77
-                setcookie('ee_registration_added', 0, time() - WEEK_IN_SECONDS, '/');
78
-                // and update the global
79
-                $_COOKIE['ee_registration_added'] = 0;
80
-            }
81
-        }
82
-    }
83
-
84
-
85
-    protected function _init_page_props()
86
-    {
87
-        $this->page_slug        = REG_PG_SLUG;
88
-        $this->_admin_base_url  = REG_ADMIN_URL;
89
-        $this->_admin_base_path = REG_ADMIN;
90
-        $this->page_label       = __('Registrations', 'event_espresso');
91
-        $this->_cpt_routes      = array(
92
-            'add_new_attendee' => 'espresso_attendees',
93
-            'edit_attendee'    => 'espresso_attendees',
94
-            'insert_attendee'  => 'espresso_attendees',
95
-            'update_attendee'  => 'espresso_attendees',
96
-        );
97
-        $this->_cpt_model_names = array(
98
-            'add_new_attendee' => 'EEM_Attendee',
99
-            'edit_attendee'    => 'EEM_Attendee',
100
-        );
101
-        $this->_cpt_edit_routes = array(
102
-            'espresso_attendees' => 'edit_attendee',
103
-        );
104
-        $this->_pagenow_map     = array(
105
-            'add_new_attendee' => 'post-new.php',
106
-            'edit_attendee'    => 'post.php',
107
-            'trash'            => 'post.php',
108
-        );
109
-        add_action('edit_form_after_title', array($this, 'after_title_form_fields'), 10);
110
-        //add filters so that the comment urls don't take users to a confusing 404 page
111
-        add_filter('get_comment_link', array($this, 'clear_comment_link'), 10, 3);
112
-    }
113
-
114
-
115
-    public function clear_comment_link($link, $comment, $args)
116
-    {
117
-        //gotta make sure this only happens on this route
118
-        $post_type = get_post_type($comment->comment_post_ID);
119
-        if ($post_type === 'espresso_attendees') {
120
-            return '#commentsdiv';
121
-        }
122
-        return $link;
123
-    }
124
-
125
-
126
-    protected function _ajax_hooks()
127
-    {
128
-        //todo: all hooks for registrations ajax goes in here
129
-        add_action('wp_ajax_toggle_checkin_status', array($this, 'toggle_checkin_status'));
130
-    }
131
-
132
-
133
-    protected function _define_page_props()
134
-    {
135
-        $this->_admin_page_title = $this->page_label;
136
-        $this->_labels           = array(
137
-            'buttons'                      => array(
138
-                'add-registrant'      => __('Add New Registration', 'event_espresso'),
139
-                'add-attendee'        => __('Add Contact', 'event_espresso'),
140
-                'edit'                => __('Edit Contact', 'event_espresso'),
141
-                'report'              => __("Event Registrations CSV Report", "event_espresso"),
142
-                'report_all'          => __('All Registrations CSV Report', 'event_espresso'),
143
-                'report_filtered'     => __('Filtered CSV Report', 'event_espresso'),
144
-                'contact_list_report' => __('Contact List Report', 'event_espresso'),
145
-                'contact_list_export' => __("Export Data", "event_espresso"),
146
-            ),
147
-            'publishbox'                   => array(
148
-                'add_new_attendee' => __("Add Contact Record", 'event_espresso'),
149
-                'edit_attendee'    => __("Update Contact Record", 'event_espresso'),
150
-            ),
151
-            'hide_add_button_on_cpt_route' => array(
152
-                'edit_attendee' => true,
153
-            ),
154
-        );
155
-    }
156
-
157
-
158
-    /**
159
-     *        grab url requests and route them
160
-     *
161
-     * @access private
162
-     * @return void
163
-     */
164
-    public function _set_page_routes()
165
-    {
166
-        $this->_get_registration_status_array();
167
-        $reg_id             = ! empty($this->_req_data['_REG_ID']) && ! is_array($this->_req_data['_REG_ID'])
168
-            ? $this->_req_data['_REG_ID'] : 0;
169
-        $att_id             = ! empty($this->_req_data['ATT_ID']) && ! is_array($this->_req_data['ATT_ID'])
170
-            ? $this->_req_data['ATT_ID'] : 0;
171
-        $att_id             = ! empty($this->_req_data['post']) && ! is_array($this->_req_data['post']) ? $this->_req_data['post']
172
-            : $att_id;
173
-        $this->_page_routes = array(
174
-            'default'                            => array(
175
-                'func'       => '_registrations_overview_list_table',
176
-                'capability' => 'ee_read_registrations',
177
-            ),
178
-            'view_registration'                  => array(
179
-                'func'       => '_registration_details',
180
-                'capability' => 'ee_read_registration',
181
-                'obj_id'     => $reg_id,
182
-            ),
183
-            'edit_registration'                  => array(
184
-                'func'               => '_update_attendee_registration_form',
185
-                'noheader'           => true,
186
-                'headers_sent_route' => 'view_registration',
187
-                'capability'         => 'ee_edit_registration',
188
-                'obj_id'             => $reg_id,
189
-                '_REG_ID'            => $reg_id,
190
-            ),
191
-            'trash_registrations'                => array(
192
-                'func'       => '_trash_or_restore_registrations',
193
-                'args'       => array('trash' => true),
194
-                'noheader'   => true,
195
-                'capability' => 'ee_delete_registrations',
196
-            ),
197
-            'restore_registrations'              => array(
198
-                'func'       => '_trash_or_restore_registrations',
199
-                'args'       => array('trash' => false),
200
-                'noheader'   => true,
201
-                'capability' => 'ee_delete_registrations',
202
-            ),
203
-            'delete_registrations'               => array(
204
-                'func'       => '_delete_registrations',
205
-                'noheader'   => true,
206
-                'capability' => 'ee_delete_registrations',
207
-            ),
208
-            'new_registration'                   => array(
209
-                'func'       => 'new_registration',
210
-                'capability' => 'ee_edit_registrations',
211
-            ),
212
-            'process_reg_step'                   => array(
213
-                'func'       => 'process_reg_step',
214
-                'noheader'   => true,
215
-                'capability' => 'ee_edit_registrations',
216
-            ),
217
-            'redirect_to_txn'                    => array(
218
-                'func'       => 'redirect_to_txn',
219
-                'noheader'   => true,
220
-                'capability' => 'ee_edit_registrations',
221
-            ),
222
-            'change_reg_status'                  => array(
223
-                'func'       => '_change_reg_status',
224
-                'noheader'   => true,
225
-                'capability' => 'ee_edit_registration',
226
-                'obj_id'     => $reg_id,
227
-            ),
228
-            'approve_registration'               => array(
229
-                'func'       => 'approve_registration',
230
-                'noheader'   => true,
231
-                'capability' => 'ee_edit_registration',
232
-                'obj_id'     => $reg_id,
233
-            ),
234
-            'approve_and_notify_registration'    => array(
235
-                'func'       => 'approve_registration',
236
-                'noheader'   => true,
237
-                'args'       => array(true),
238
-                'capability' => 'ee_edit_registration',
239
-                'obj_id'     => $reg_id,
240
-            ),
241
-            'decline_registration'               => array(
242
-                'func'       => 'decline_registration',
243
-                'noheader'   => true,
244
-                'capability' => 'ee_edit_registration',
245
-                'obj_id'     => $reg_id,
246
-            ),
247
-            'decline_and_notify_registration'    => array(
248
-                'func'       => 'decline_registration',
249
-                'noheader'   => true,
250
-                'args'       => array(true),
251
-                'capability' => 'ee_edit_registration',
252
-                'obj_id'     => $reg_id,
253
-            ),
254
-            'pending_registration'               => array(
255
-                'func'       => 'pending_registration',
256
-                'noheader'   => true,
257
-                'capability' => 'ee_edit_registration',
258
-                'obj_id'     => $reg_id,
259
-            ),
260
-            'pending_and_notify_registration'    => array(
261
-                'func'       => 'pending_registration',
262
-                'noheader'   => true,
263
-                'args'       => array(true),
264
-                'capability' => 'ee_edit_registration',
265
-                'obj_id'     => $reg_id,
266
-            ),
267
-            'no_approve_registration'            => array(
268
-                'func'       => 'not_approve_registration',
269
-                'noheader'   => true,
270
-                'capability' => 'ee_edit_registration',
271
-                'obj_id'     => $reg_id,
272
-            ),
273
-            'no_approve_and_notify_registration' => array(
274
-                'func'       => 'not_approve_registration',
275
-                'noheader'   => true,
276
-                'args'       => array(true),
277
-                'capability' => 'ee_edit_registration',
278
-                'obj_id'     => $reg_id,
279
-            ),
280
-            'cancel_registration'                => array(
281
-                'func'       => 'cancel_registration',
282
-                'noheader'   => true,
283
-                'capability' => 'ee_edit_registration',
284
-                'obj_id'     => $reg_id,
285
-            ),
286
-            'cancel_and_notify_registration'     => array(
287
-                'func'       => 'cancel_registration',
288
-                'noheader'   => true,
289
-                'args'       => array(true),
290
-                'capability' => 'ee_edit_registration',
291
-                'obj_id'     => $reg_id,
292
-            ),
293
-            'contact_list'                       => array(
294
-                'func'       => '_attendee_contact_list_table',
295
-                'capability' => 'ee_read_contacts',
296
-            ),
297
-            'add_new_attendee'                   => array(
298
-                'func' => '_create_new_cpt_item',
299
-                'args' => array(
300
-                    'new_attendee' => true,
301
-                    'capability'   => 'ee_edit_contacts',
302
-                ),
303
-            ),
304
-            'edit_attendee'                      => array(
305
-                'func'       => '_edit_cpt_item',
306
-                'capability' => 'ee_edit_contacts',
307
-                'obj_id'     => $att_id,
308
-            ),
309
-            'duplicate_attendee'                 => array(
310
-                'func'       => '_duplicate_attendee',
311
-                'noheader'   => true,
312
-                'capability' => 'ee_edit_contacts',
313
-                'obj_id'     => $att_id,
314
-            ),
315
-            'insert_attendee'                    => array(
316
-                'func'       => '_insert_or_update_attendee',
317
-                'args'       => array(
318
-                    'new_attendee' => true,
319
-                ),
320
-                'noheader'   => true,
321
-                'capability' => 'ee_edit_contacts',
322
-            ),
323
-            'update_attendee'                    => array(
324
-                'func'       => '_insert_or_update_attendee',
325
-                'args'       => array(
326
-                    'new_attendee' => false,
327
-                ),
328
-                'noheader'   => true,
329
-                'capability' => 'ee_edit_contacts',
330
-                'obj_id'     => $att_id,
331
-            ),
332
-            'trash_attendees'                    => array(
333
-                'func'       => '_trash_or_restore_attendees',
334
-                'args'       => array(
335
-                    'trash' => true,
336
-                ),
337
-                'noheader'   => true,
338
-                'capability' => 'ee_delete_contacts',
339
-                'obj_id'     => $att_id,
340
-            ),
341
-            'restore_attendees'                  => array(
342
-                'func'       => '_trash_or_restore_attendees',
343
-                'args'       => array(
344
-                    'trash' => false,
345
-                ),
346
-                'noheader'   => true,
347
-                'capability' => 'ee_delete_contacts',
348
-                'obj_id'     => $att_id,
349
-            ),
350
-            'resend_registration'                => array(
351
-                'func'       => '_resend_registration',
352
-                'noheader'   => true,
353
-                'capability' => 'ee_send_message',
354
-            ),
355
-            'registrations_report'               => array(
356
-                'func'       => '_registrations_report',
357
-                'noheader'   => true,
358
-                'capability' => 'ee_read_registrations',
359
-            ),
360
-            'contact_list_export'                => array(
361
-                'func'       => '_contact_list_export',
362
-                'noheader'   => true,
363
-                'capability' => 'export',
364
-            ),
365
-            'contact_list_report'                => array(
366
-                'func'       => '_contact_list_report',
367
-                'noheader'   => true,
368
-                'capability' => 'ee_read_contacts',
369
-            ),
370
-        );
371
-    }
372
-
373
-
374
-    protected function _set_page_config()
375
-    {
376
-        $this->_page_config = array(
377
-            'default'           => array(
378
-                'nav'           => array(
379
-                    'label' => __('Overview', 'event_espresso'),
380
-                    'order' => 5,
381
-                ),
382
-                'help_tabs'     => array(
383
-                    'registrations_overview_help_tab'                       => array(
384
-                        'title'    => __('Registrations Overview', 'event_espresso'),
385
-                        'filename' => 'registrations_overview',
386
-                    ),
387
-                    'registrations_overview_table_column_headings_help_tab' => array(
388
-                        'title'    => __('Registrations Table Column Headings', 'event_espresso'),
389
-                        'filename' => 'registrations_overview_table_column_headings',
390
-                    ),
391
-                    'registrations_overview_filters_help_tab'               => array(
392
-                        'title'    => __('Registration Filters', 'event_espresso'),
393
-                        'filename' => 'registrations_overview_filters',
394
-                    ),
395
-                    'registrations_overview_views_help_tab'                 => array(
396
-                        'title'    => __('Registration Views', 'event_espresso'),
397
-                        'filename' => 'registrations_overview_views',
398
-                    ),
399
-                    'registrations_regoverview_other_help_tab'              => array(
400
-                        'title'    => __('Registrations Other', 'event_espresso'),
401
-                        'filename' => 'registrations_overview_other',
402
-                    ),
403
-                ),
404
-                'help_tour'     => array('Registration_Overview_Help_Tour'),
405
-                'qtips'         => array('Registration_List_Table_Tips'),
406
-                'list_table'    => 'EE_Registrations_List_Table',
407
-                'require_nonce' => false,
408
-            ),
409
-            'view_registration' => array(
410
-                'nav'           => array(
411
-                    'label'      => __('REG Details', 'event_espresso'),
412
-                    'order'      => 15,
413
-                    'url'        => isset($this->_req_data['_REG_ID'])
414
-                        ? add_query_arg(array('_REG_ID' => $this->_req_data['_REG_ID']), $this->_current_page_view_url)
415
-                        : $this->_admin_base_url,
416
-                    'persistent' => false,
417
-                ),
418
-                'help_tabs'     => array(
419
-                    'registrations_details_help_tab'                    => array(
420
-                        'title'    => __('Registration Details', 'event_espresso'),
421
-                        'filename' => 'registrations_details',
422
-                    ),
423
-                    'registrations_details_table_help_tab'              => array(
424
-                        'title'    => __('Registration Details Table', 'event_espresso'),
425
-                        'filename' => 'registrations_details_table',
426
-                    ),
427
-                    'registrations_details_form_answers_help_tab'       => array(
428
-                        'title'    => __('Registration Form Answers', 'event_espresso'),
429
-                        'filename' => 'registrations_details_form_answers',
430
-                    ),
431
-                    'registrations_details_registrant_details_help_tab' => array(
432
-                        'title'    => __('Contact Details', 'event_espresso'),
433
-                        'filename' => 'registrations_details_registrant_details',
434
-                    ),
435
-                ),
436
-                'help_tour'     => array('Registration_Details_Help_Tour'),
437
-                'metaboxes'     => array_merge($this->_default_espresso_metaboxes,
438
-                    array('_registration_details_metaboxes')),
439
-                'require_nonce' => false,
440
-            ),
441
-            'new_registration'  => array(
442
-                'nav'           => array(
443
-                    'label'      => __('Add New Registration', 'event_espresso'),
444
-                    'url'        => '#',
445
-                    'order'      => 15,
446
-                    'persistent' => false,
447
-                ),
448
-                'metaboxes'     => $this->_default_espresso_metaboxes,
449
-                'labels'        => array(
450
-                    'publishbox' => __('Save Registration', 'event_espresso'),
451
-                ),
452
-                'require_nonce' => false,
453
-            ),
454
-            'add_new_attendee'  => array(
455
-                'nav'           => array(
456
-                    'label'      => __('Add Contact', 'event_espresso'),
457
-                    'order'      => 15,
458
-                    'persistent' => false,
459
-                ),
460
-                'metaboxes'     => array_merge($this->_default_espresso_metaboxes,
461
-                    array('_publish_post_box', 'attendee_editor_metaboxes')),
462
-                'require_nonce' => false,
463
-            ),
464
-            'edit_attendee'     => array(
465
-                'nav'           => array(
466
-                    'label'      => __('Edit Contact', 'event_espresso'),
467
-                    'order'      => 15,
468
-                    'persistent' => false,
469
-                    'url'        => isset($this->_req_data['ATT_ID'])
470
-                        ? add_query_arg(array('ATT_ID' => $this->_req_data['ATT_ID']), $this->_current_page_view_url)
471
-                        : $this->_admin_base_url,
472
-                ),
473
-                'metaboxes'     => array('attendee_editor_metaboxes'),
474
-                'require_nonce' => false,
475
-            ),
476
-            'contact_list'      => array(
477
-                'nav'           => array(
478
-                    'label' => __('Contact List', 'event_espresso'),
479
-                    'order' => 20,
480
-                ),
481
-                'list_table'    => 'EE_Attendee_Contact_List_Table',
482
-                'help_tabs'     => array(
483
-                    'registrations_contact_list_help_tab'                       => array(
484
-                        'title'    => __('Registrations Contact List', 'event_espresso'),
485
-                        'filename' => 'registrations_contact_list',
486
-                    ),
487
-                    'registrations_contact-list_table_column_headings_help_tab' => array(
488
-                        'title'    => __('Contact List Table Column Headings', 'event_espresso'),
489
-                        'filename' => 'registrations_contact_list_table_column_headings',
490
-                    ),
491
-                    'registrations_contact_list_views_help_tab'                 => array(
492
-                        'title'    => __('Contact List Views', 'event_espresso'),
493
-                        'filename' => 'registrations_contact_list_views',
494
-                    ),
495
-                    'registrations_contact_list_other_help_tab'                 => array(
496
-                        'title'    => __('Contact List Other', 'event_espresso'),
497
-                        'filename' => 'registrations_contact_list_other',
498
-                    ),
499
-                ),
500
-                'help_tour'     => array('Contact_List_Help_Tour'),
501
-                'metaboxes'     => array(),
502
-                'require_nonce' => false,
503
-            ),
504
-            //override default cpt routes
505
-            'create_new'        => '',
506
-            'edit'              => '',
507
-        );
508
-    }
509
-
510
-
511
-    /**
512
-     * The below methods aren't used by this class currently
513
-     */
514
-    protected function _add_screen_options()
515
-    {
516
-    }
517
-
518
-
519
-    protected function _add_feature_pointers()
520
-    {
521
-    }
522
-
523
-
524
-    public function admin_init()
525
-    {
526
-        EE_Registry::$i18n_js_strings['update_att_qstns'] = __('click "Update Registration Questions" to save your changes',
527
-            'event_espresso');
528
-    }
529
-
530
-
531
-    public function admin_notices()
532
-    {
533
-    }
534
-
535
-
536
-    public function admin_footer_scripts()
537
-    {
538
-    }
539
-
540
-
541
-    /**
542
-     *        get list of registration statuses
543
-     *
544
-     * @access private
545
-     * @return void
546
-     */
547
-    private function _get_registration_status_array()
548
-    {
549
-        self::$_reg_status = EEM_Registration::reg_status_array(array(), true);
550
-    }
551
-
552
-
553
-    protected function _add_screen_options_default()
554
-    {
555
-        $this->_per_page_screen_option();
556
-    }
557
-
558
-
559
-    protected function _add_screen_options_contact_list()
560
-    {
561
-        $page_title              = $this->_admin_page_title;
562
-        $this->_admin_page_title = __("Contacts", 'event_espresso');
563
-        $this->_per_page_screen_option();
564
-        $this->_admin_page_title = $page_title;
565
-    }
566
-
567
-
568
-    public function load_scripts_styles()
569
-    {
570
-        //style
571
-        //wp_register_style('espresso_attendees', ATT_ASSETS_URL . 'espresso_attendees_admin.css', array(), EVENT_ESPRESSO_VERSION );
572
-        wp_register_style('espresso_reg', REG_ASSETS_URL . 'espresso_registrations_admin.css', array('ee-admin-css'),
573
-            EVENT_ESPRESSO_VERSION);
574
-        wp_enqueue_style('espresso_reg');
575
-        //script
576
-        wp_register_script('espresso_reg', REG_ASSETS_URL . 'espresso_registrations_admin.js',
577
-            array('jquery-ui-datepicker', 'jquery-ui-draggable', 'ee_admin_js'), EVENT_ESPRESSO_VERSION, true);
578
-        wp_enqueue_script('espresso_reg');
579
-    }
580
-
581
-
582
-    public function load_scripts_styles_edit_attendee()
583
-    {
584
-        //stuff to only show up on our attendee edit details page.
585
-        $attendee_details_translations = array(
586
-            'att_publish_text' => sprintf(__('Created on: <b>%1$s</b>', 'event_espresso'),
587
-                $this->_cpt_model_obj->get_datetime('ATT_created')),
588
-        );
589
-        wp_localize_script('espresso_reg', 'ATTENDEE_DETAILS', $attendee_details_translations);
590
-        wp_enqueue_script('jquery-validate');
591
-    }
592
-
593
-
594
-    public function load_scripts_styles_view_registration()
595
-    {
596
-        //styles
597
-        wp_enqueue_style('espresso-ui-theme');
598
-        //scripts
599
-        $this->_get_reg_custom_questions_form($this->_registration->ID());
600
-        $this->_reg_custom_questions_form->wp_enqueue_scripts(true);
601
-    }
602
-
603
-
604
-    public function load_scripts_styles_contact_list()
605
-    {
606
-        wp_deregister_style('espresso_reg');
607
-        wp_register_style('espresso_att', REG_ASSETS_URL . 'espresso_attendees_admin.css', array('ee-admin-css'),
608
-            EVENT_ESPRESSO_VERSION);
609
-        wp_enqueue_style('espresso_att');
610
-    }
611
-
612
-
613
-    public function load_scripts_styles_new_registration()
614
-    {
615
-        wp_register_script('ee-spco-for-admin', REG_ASSETS_URL . 'spco_for_admin.js', array('underscore', 'jquery'),
616
-            EVENT_ESPRESSO_VERSION, true);
617
-        wp_enqueue_script('ee-spco-for-admin');
618
-        add_filter('FHEE__EED_Ticket_Selector__load_tckt_slctr_assets', '__return_true');
619
-        EE_Form_Section_Proper::wp_enqueue_scripts();
620
-        EED_Ticket_Selector::load_tckt_slctr_assets();
621
-        EE_Datepicker_Input::enqueue_styles_and_scripts();
622
-    }
623
-
624
-
625
-    public function AHEE__EE_Admin_Page__route_admin_request_resend_registration()
626
-    {
627
-        add_filter('FHEE_load_EE_messages', '__return_true');
628
-    }
629
-
630
-
631
-    public function AHEE__EE_Admin_Page__route_admin_request_approve_registration()
632
-    {
633
-        add_filter('FHEE_load_EE_messages', '__return_true');
634
-    }
635
-
636
-
637
-    protected function _set_list_table_views_default()
638
-    {
639
-        //for notification related bulk actions we need to make sure only active messengers have an option.
640
-        EED_Messages::set_autoloaders();
641
-        /** @type EE_Message_Resource_Manager $message_resource_manager */
642
-        $message_resource_manager = EE_Registry::instance()->load_lib('Message_Resource_Manager');
643
-        $active_mts               = $message_resource_manager->list_of_active_message_types();
644
-        //key= bulk_action_slug, value= message type.
645
-        $match_array = array(
646
-            'approve_registration'    => 'registration',
647
-            'decline_registration'    => 'declined_registration',
648
-            'pending_registration'    => 'pending_approval',
649
-            'no_approve_registration' => 'not_approved_registration',
650
-            'cancel_registration'     => 'cancelled_registration',
651
-        );
652
-        /** setup reg status bulk actions **/
653
-        $def_reg_status_actions['approve_registration'] = __('Approve Registrations', 'event_espresso');
654
-        if (in_array($match_array['approve_registration'], $active_mts)
655
-            && EE_Registry::instance()->CAP->current_user_can('ee_send_message', 'batch_send_messages')
656
-        ) {
657
-            $def_reg_status_actions['approve_and_notify_registration'] = __('Approve and Notify Registrations',
658
-                'event_espresso');
659
-        }
660
-        $def_reg_status_actions['decline_registration'] = __('Decline Registrations', 'event_espresso');
661
-        if (in_array($match_array['decline_registration'], $active_mts)
662
-            && EE_Registry::instance()->CAP->current_user_can('ee_send_message', 'batch_send_messages')
663
-        ) {
664
-            $def_reg_status_actions['decline_and_notify_registration'] = __('Decline and Notify Registrations',
665
-                'event_espresso');
666
-        }
667
-        $def_reg_status_actions['pending_registration'] = __('Set Registrations to Pending Payment', 'event_espresso');
668
-        if (in_array($match_array['pending_registration'], $active_mts)
669
-            && EE_Registry::instance()->CAP->current_user_can('ee_send_message', 'batch_send_messages')
670
-        ) {
671
-            $def_reg_status_actions['pending_and_notify_registration'] = __('Set Registrations to Pending Payment and Notify',
672
-                'event_espresso');
673
-        }
674
-        $def_reg_status_actions['no_approve_registration'] = __('Set Registrations to Not Approved', 'event_espresso');
675
-        if (in_array($match_array['no_approve_registration'], $active_mts)
676
-            && EE_Registry::instance()->CAP->current_user_can('ee_send_message', 'batch_send_messages')
677
-        ) {
678
-            $def_reg_status_actions['no_approve_and_notify_registration'] = __('Set Registrations to Not Approved and Notify',
679
-                'event_espresso');
680
-        }
681
-        $def_reg_status_actions['cancel_registration'] = __('Cancel Registrations', 'event_espresso');
682
-        if (in_array($match_array['cancel_registration'], $active_mts)
683
-            && EE_Registry::instance()->CAP->current_user_can('ee_send_message', 'batch_send_messages')
684
-        ) {
685
-            $def_reg_status_actions['cancel_and_notify_registration'] = __('Cancel Registrations and Notify',
686
-                'event_espresso');
687
-        }
688
-        $this->_views = array(
689
-            'all'   => array(
690
-                'slug'        => 'all',
691
-                'label'       => __('View All Registrations', 'event_espresso'),
692
-                'count'       => 0,
693
-                'bulk_action' => array_merge($def_reg_status_actions, array(
694
-                    'trash_registrations' => __('Trash Registrations', 'event_espresso'),
695
-                )),
696
-            ),
697
-            'month' => array(
698
-                'slug'        => 'month',
699
-                'label'       => __('This Month', 'event_espresso'),
700
-                'count'       => 0,
701
-                'bulk_action' => array_merge($def_reg_status_actions, array(
702
-                    'trash_registrations' => __('Trash Registrations', 'event_espresso'),
703
-                )),
704
-            ),
705
-            'today' => array(
706
-                'slug'        => 'today',
707
-                'label'       => sprintf(__('Today - %s', 'event_espresso'), date('M d, Y', current_time('timestamp'))),
708
-                'count'       => 0,
709
-                'bulk_action' => array_merge($def_reg_status_actions, array(
710
-                    'trash_registrations' => __('Trash Registrations', 'event_espresso'),
711
-                )),
712
-            ),
713
-        );
714
-        if (EE_Registry::instance()->CAP->current_user_can('ee_delete_registrations',
715
-            'espresso_registrations_delete_registration')
716
-        ) {
717
-            $this->_views['incomplete'] = array(
718
-                'slug'        => 'incomplete',
719
-                'label'       => __('Incomplete', 'event_espresso'),
720
-                'count'       => 0,
721
-                'bulk_action' => array(
722
-                    'trash_registrations' => __('Trash Registrations', 'event_espresso'),
723
-                ),
724
-            );
725
-            $this->_views['trash']      = array(
726
-                'slug'        => 'trash',
727
-                'label'       => __('Trash', 'event_espresso'),
728
-                'count'       => 0,
729
-                'bulk_action' => array(
730
-                    'restore_registrations' => __('Restore Registrations', 'event_espresso'),
731
-                    'delete_registrations'  => __('Delete Registrations Permanently', 'event_espresso'),
732
-                ),
733
-            );
734
-        }
735
-    }
736
-
737
-
738
-    protected function _set_list_table_views_contact_list()
739
-    {
740
-        $this->_views = array(
741
-            'in_use' => array(
742
-                'slug'        => 'in_use',
743
-                'label'       => __('In Use', 'event_espresso'),
744
-                'count'       => 0,
745
-                'bulk_action' => array(
746
-                    'trash_attendees' => __('Move to Trash', 'event_espresso'),
747
-                ),
748
-            ),
749
-        );
750
-        if (EE_Registry::instance()->CAP->current_user_can('ee_delete_contacts',
751
-            'espresso_registrations_trash_attendees')
752
-        ) {
753
-            $this->_views['trash'] = array(
754
-                'slug'        => 'trash',
755
-                'label'       => __('Trash', 'event_espresso'),
756
-                'count'       => 0,
757
-                'bulk_action' => array(
758
-                    'restore_attendees' => __('Restore from Trash', 'event_espresso'),
759
-                ),
760
-            );
761
-        }
762
-    }
763
-
764
-
765
-    protected function _registration_legend_items()
766
-    {
767
-        $fc_items = array(
768
-            'star-icon'        => array(
769
-                'class' => 'dashicons dashicons-star-filled lt-blue-icon ee-icon-size-8',
770
-                'desc'  => __('This is the Primary Registrant', 'event_espresso'),
771
-            ),
772
-            'view_details'     => array(
773
-                'class' => 'dashicons dashicons-clipboard',
774
-                'desc'  => __('View Registration Details', 'event_espresso'),
775
-            ),
776
-            'edit_attendee'    => array(
777
-                'class' => 'ee-icon ee-icon-user-edit ee-icon-size-16',
778
-                'desc'  => __('Edit Contact Details', 'event_espresso'),
779
-            ),
780
-            'view_transaction' => array(
781
-                'class' => 'dashicons dashicons-cart',
782
-                'desc'  => __('View Transaction Details', 'event_espresso'),
783
-            ),
784
-            'view_invoice'     => array(
785
-                'class' => 'dashicons dashicons-media-spreadsheet',
786
-                'desc'  => __('View Transaction Invoice', 'event_espresso'),
787
-            ),
788
-        );
789
-        if (EE_Registry::instance()->CAP->current_user_can('ee_send_message',
790
-            'espresso_registrations_resend_registration')
791
-        ) {
792
-            $fc_items['resend_registration'] = array(
793
-                'class' => 'dashicons dashicons-email-alt',
794
-                'desc'  => __('Resend Registration Details', 'event_espresso'),
795
-            );
796
-        } else {
797
-            $fc_items['blank'] = array('class' => 'blank', 'desc' => '');
798
-        }
799
-        if (EE_Registry::instance()->CAP->current_user_can('ee_read_global_messages', 'view_filtered_messages')) {
800
-            $related_for_icon = EEH_MSG_Template::get_message_action_icon('see_notifications_for');
801
-            if (isset($related_for_icon['css_class']) && isset($related_for_icon['label'])) {
802
-                $fc_items['view_related_messages'] = array(
803
-                    'class' => $related_for_icon['css_class'],
804
-                    'desc'  => $related_for_icon['label'],
805
-                );
806
-            }
807
-        }
808
-        $sc_items = array(
809
-            'approved_status'   => array(
810
-                'class' => 'ee-status-legend ee-status-legend-' . EEM_Registration::status_id_approved,
811
-                'desc'  => EEH_Template::pretty_status(EEM_Registration::status_id_approved, false, 'sentence'),
812
-            ),
813
-            'pending_status'    => array(
814
-                'class' => 'ee-status-legend ee-status-legend-' . EEM_Registration::status_id_pending_payment,
815
-                'desc'  => EEH_Template::pretty_status(EEM_Registration::status_id_pending_payment, false, 'sentence'),
816
-            ),
817
-            'wait_list'         => array(
818
-                'class' => 'ee-status-legend ee-status-legend-' . EEM_Registration::status_id_wait_list,
819
-                'desc'  => EEH_Template::pretty_status(EEM_Registration::status_id_wait_list, false, 'sentence'),
820
-            ),
821
-            'incomplete_status' => array(
822
-                'class' => 'ee-status-legend ee-status-legend-' . EEM_Registration::status_id_incomplete,
823
-                'desc'  => EEH_Template::pretty_status(EEM_Registration::status_id_incomplete, false, 'sentence'),
824
-            ),
825
-            'not_approved'      => array(
826
-                'class' => 'ee-status-legend ee-status-legend-' . EEM_Registration::status_id_not_approved,
827
-                'desc'  => EEH_Template::pretty_status(EEM_Registration::status_id_not_approved, false, 'sentence'),
828
-            ),
829
-            'declined_status'   => array(
830
-                'class' => 'ee-status-legend ee-status-legend-' . EEM_Registration::status_id_declined,
831
-                'desc'  => EEH_Template::pretty_status(EEM_Registration::status_id_declined, false, 'sentence'),
832
-            ),
833
-            'cancelled_status'  => array(
834
-                'class' => 'ee-status-legend ee-status-legend-' . EEM_Registration::status_id_cancelled,
835
-                'desc'  => EEH_Template::pretty_status(EEM_Registration::status_id_cancelled, false, 'sentence'),
836
-            ),
837
-        );
838
-        return array_merge($fc_items, $sc_items);
839
-    }
840
-
841
-
842
-
843
-    /***************************************        REGISTRATION OVERVIEW        **************************************/
844
-    /**
845
-     * @throws \EE_Error
846
-     */
847
-    protected function _registrations_overview_list_table()
848
-    {
849
-        $this->_template_args['admin_page_header'] = '';
850
-        $EVT_ID                                    = ! empty($this->_req_data['event_id']) ? absint($this->_req_data['event_id']) : 0;
851
-        if ($EVT_ID) {
852
-            if (EE_Registry::instance()->CAP->current_user_can('ee_edit_registrations',
853
-                'espresso_registrations_new_registration', $EVT_ID)
854
-            ) {
855
-                $this->_admin_page_title .= ' ' . $this->get_action_link_or_button('new_registration', 'add-registrant',
856
-                        array('event_id' => $EVT_ID), 'add-new-h2');
857
-            }
858
-            $event = EEM_Event::instance()->get_one_by_ID($EVT_ID);
859
-            if ($event instanceof EE_Event) {
860
-                $this->_template_args['admin_page_header'] = sprintf(__('%s Viewing registrations for the event: %s%s',
861
-                    'event_espresso'), '<h3 style="line-height:1.5em;">',
862
-                    '<br /><a href="' . EE_Admin_Page::add_query_args_and_nonce(array(
863
-                        'action' => 'edit',
864
-                        'post'   => $event->ID(),
865
-                    ), EVENTS_ADMIN_URL) . '">&nbsp;' . $event->get('EVT_name') . '&nbsp;</a>&nbsp;', '</h3>');
866
-            }
867
-            $DTT_ID   = ! empty($this->_req_data['datetime_id']) ? absint($this->_req_data['datetime_id']) : 0;
868
-            $datetime = EEM_Datetime::instance()->get_one_by_ID($DTT_ID);
869
-            if ($datetime instanceof EE_Datetime && $this->_template_args['admin_page_header'] !== '') {
870
-                $this->_template_args['admin_page_header'] = substr($this->_template_args['admin_page_header'], 0, -5);
871
-                $this->_template_args['admin_page_header'] .= ' &nbsp;<span class="drk-grey-text">';
872
-                $this->_template_args['admin_page_header'] .= '<span class="dashicons dashicons-calendar"></span>';
873
-                $this->_template_args['admin_page_header'] .= $datetime->name();
874
-                $this->_template_args['admin_page_header'] .= ' ( ' . $datetime->start_date() . ' )';
875
-                $this->_template_args['admin_page_header'] .= '</span></h3>';
876
-            }
877
-        }
878
-        $this->_template_args['after_list_table'] = $this->_display_legend($this->_registration_legend_items());
879
-        $this->display_admin_list_table_page_with_no_sidebar();
880
-    }
881
-
882
-
883
-    /**
884
-     * This sets the _registration property for the registration details screen
885
-     *
886
-     * @access private
887
-     * @return bool
888
-     */
889
-    private function _set_registration_object()
890
-    {
891
-        //get out if we've already set the object
892
-        if (is_object($this->_registration)) {
893
-            return true;
894
-        }
895
-        $REG    = EEM_Registration::instance();
896
-        $REG_ID = ( ! empty($this->_req_data['_REG_ID'])) ? absint($this->_req_data['_REG_ID']) : false;
897
-        if ($this->_registration = $REG->get_one_by_ID($REG_ID)) {
898
-            return true;
899
-        } else {
900
-            $error_msg = sprintf(__('An error occurred and the details for Registration ID #%s could not be retrieved.',
901
-                'event_espresso'), $REG_ID);
902
-            EE_Error::add_error($error_msg, __FILE__, __FUNCTION__, __LINE__);
903
-            $this->_registration = null;
904
-            return false;
905
-        }
906
-    }
907
-
908
-
909
-    /**
910
-     * Used to retrieve registrations for the list table.
911
-     *
912
-     * @param int    $per_page
913
-     * @param bool   $count
914
-     * @param bool   $this_month
915
-     * @param bool   $today
916
-     * @return \EE_Registration[]|int
917
-     */
918
-    public function get_registrations(
919
-        $per_page = 10,
920
-        $count = false,
921
-        $this_month = false,
922
-        $today = false
923
-    ) {
924
-        if( $this_month ) {
925
-            $this->_req_data['status'] = 'month';
926
-        }
927
-        if( $today ) {
928
-            $this->_req_data['status'] = 'today';
929
-        }
930
-        $query_params = $this->_get_registration_query_parameters($this->_req_data, $per_page, $count);
931
-        return $count
932
-            ? EEM_Registration::instance()->count($query_params)
933
-            /** @type EE_Registration[] */
934
-            : EEM_Registration::instance()->get_all($query_params);
935
-    }
936
-
937
-
938
-
939
-    /**
940
-     * Retrieves the query parameters to be used by the Registration model for getting registrations.
941
-     * Note: this listens to values on the request for some of the query parameters.
942
-     *
943
-     * @param array $request
944
-     * @param int    $per_page
945
-     * @param bool   $count
946
-     * @return array
947
-     */
948
-    protected function _get_registration_query_parameters(
949
-        $request = array(),
950
-        $per_page = 10,
951
-        $count = false
952
-    ) {
953
-
954
-        $query_params = array(
955
-            0                          => $this->_get_where_conditions_for_registrations_query(
956
-                $request
957
-            ),
958
-            'caps'                     => EEM_Registration::caps_read_admin,
959
-            'default_where_conditions' => 'this_model_only',
960
-        );
961
-        if ( ! $count) {
962
-            $query_params = array_merge(
963
-                $query_params,
964
-                $this->_get_orderby_for_registrations_query(),
965
-                $this->_get_limit($per_page)
966
-            );
967
-        }
968
-
969
-        return $query_params;
970
-    }
971
-
972
-
973
-    /**
974
-     * This will add EVT_ID to the provided $where array for EE model query parameters.
975
-     *
976
-     * @param array $request usually the same as $this->_req_data but not necessarily
977
-     * @return array
978
-     */
979
-    protected function _add_event_id_to_where_conditions(array $request)
980
-    {
981
-        $where = array();
982
-        if ( ! empty($request['event_id'])) {
983
-            $where['EVT_ID'] = absint($request['event_id']);
984
-        }
985
-        return $where;
986
-    }
987
-
988
-
989
-    /**
990
-     * Adds category ID if it exists in the request to the where conditions for the registrations query.
991
-     *
992
-     * @param array $request usually the same as $this->_req_data but not necessarily
993
-     * @return array
994
-     */
995
-    protected function _add_category_id_to_where_conditions(array $request)
996
-    {
997
-        $where = array();
998
-        if ( ! empty($request['EVT_CAT']) && (int)$request['EVT_CAT'] !== -1) {
999
-            $where['Event.Term_Taxonomy.term_id'] = absint($request['EVT_CAT']);
1000
-        }
1001
-        return $where;
1002
-    }
1003
-
1004
-
1005
-    /**
1006
-     * Adds the datetime ID if it exists in the request to the where conditions for the registrations query.
1007
-     *
1008
-     * @param array $request usually the same as $this->_req_data but not necessarily
1009
-     * @return array
1010
-     */
1011
-    protected function _add_datetime_id_to_where_conditions(array $request)
1012
-    {
1013
-        $where = array();
1014
-        if ( ! empty($request['datetime_id'])) {
1015
-            $where['Ticket.Datetime.DTT_ID'] = absint($request['datetime_id']);
1016
-        }
1017
-        if( ! empty($request['DTT_ID'])){
1018
-            $where['Ticket.Datetime.DTT_ID'] = absint($request['DTT_ID']);
1019
-        }
1020
-        return $where;
1021
-    }
1022
-
1023
-
1024
-    /**
1025
-     * Adds the correct registration status to the where conditions for the registrations query.
1026
-     *
1027
-     * @param array $request usually the same as $this->_req_data but not necessarily
1028
-     * @return array
1029
-     */
1030
-    protected function _add_registration_status_to_where_conditions(array $request)
1031
-    {
1032
-        $where = array();
1033
-        $view  = EEH_Array::is_set( $request, 'status', '' );
1034
-        $registration_status = ! empty($request['_reg_status'])
1035
-            ? sanitize_text_field($request['_reg_status'])
1036
-            : '';
1037
-
1038
-        /*
26
+	/**
27
+	 * @var EE_Registration
28
+	 */
29
+	private $_registration;
30
+
31
+	/**
32
+	 * @var EE_Event
33
+	 */
34
+	private $_reg_event;
35
+
36
+	/**
37
+	 * @var EE_Session
38
+	 */
39
+	private $_session;
40
+
41
+	private static $_reg_status;
42
+
43
+	/**
44
+	 * Form for displaying the custom questions for this registration.
45
+	 * This gets used a few times throughout the request so its best to cache it
46
+	 *
47
+	 * @var EE_Registration_Custom_Questions_Form
48
+	 */
49
+	protected $_reg_custom_questions_form = null;
50
+
51
+
52
+	/**
53
+	 *        constructor
54
+	 *
55
+	 * @Constructor
56
+	 * @access public
57
+	 * @param bool $routing
58
+	 * @return Registrations_Admin_Page
59
+	 */
60
+	public function __construct($routing = true)
61
+	{
62
+		parent::__construct($routing);
63
+		add_action('wp_loaded', array($this, 'wp_loaded'));
64
+	}
65
+
66
+
67
+	public function wp_loaded()
68
+	{
69
+		// when adding a new registration...
70
+		if (isset($this->_req_data['action']) && $this->_req_data['action'] === 'new_registration') {
71
+			EE_System::do_not_cache();
72
+			if ( ! isset($this->_req_data['processing_registration'])
73
+				 || absint($this->_req_data['processing_registration']) !== 1
74
+			) {
75
+				// and it's NOT the attendee information reg step
76
+				// force cookie expiration by setting time to last week
77
+				setcookie('ee_registration_added', 0, time() - WEEK_IN_SECONDS, '/');
78
+				// and update the global
79
+				$_COOKIE['ee_registration_added'] = 0;
80
+			}
81
+		}
82
+	}
83
+
84
+
85
+	protected function _init_page_props()
86
+	{
87
+		$this->page_slug        = REG_PG_SLUG;
88
+		$this->_admin_base_url  = REG_ADMIN_URL;
89
+		$this->_admin_base_path = REG_ADMIN;
90
+		$this->page_label       = __('Registrations', 'event_espresso');
91
+		$this->_cpt_routes      = array(
92
+			'add_new_attendee' => 'espresso_attendees',
93
+			'edit_attendee'    => 'espresso_attendees',
94
+			'insert_attendee'  => 'espresso_attendees',
95
+			'update_attendee'  => 'espresso_attendees',
96
+		);
97
+		$this->_cpt_model_names = array(
98
+			'add_new_attendee' => 'EEM_Attendee',
99
+			'edit_attendee'    => 'EEM_Attendee',
100
+		);
101
+		$this->_cpt_edit_routes = array(
102
+			'espresso_attendees' => 'edit_attendee',
103
+		);
104
+		$this->_pagenow_map     = array(
105
+			'add_new_attendee' => 'post-new.php',
106
+			'edit_attendee'    => 'post.php',
107
+			'trash'            => 'post.php',
108
+		);
109
+		add_action('edit_form_after_title', array($this, 'after_title_form_fields'), 10);
110
+		//add filters so that the comment urls don't take users to a confusing 404 page
111
+		add_filter('get_comment_link', array($this, 'clear_comment_link'), 10, 3);
112
+	}
113
+
114
+
115
+	public function clear_comment_link($link, $comment, $args)
116
+	{
117
+		//gotta make sure this only happens on this route
118
+		$post_type = get_post_type($comment->comment_post_ID);
119
+		if ($post_type === 'espresso_attendees') {
120
+			return '#commentsdiv';
121
+		}
122
+		return $link;
123
+	}
124
+
125
+
126
+	protected function _ajax_hooks()
127
+	{
128
+		//todo: all hooks for registrations ajax goes in here
129
+		add_action('wp_ajax_toggle_checkin_status', array($this, 'toggle_checkin_status'));
130
+	}
131
+
132
+
133
+	protected function _define_page_props()
134
+	{
135
+		$this->_admin_page_title = $this->page_label;
136
+		$this->_labels           = array(
137
+			'buttons'                      => array(
138
+				'add-registrant'      => __('Add New Registration', 'event_espresso'),
139
+				'add-attendee'        => __('Add Contact', 'event_espresso'),
140
+				'edit'                => __('Edit Contact', 'event_espresso'),
141
+				'report'              => __("Event Registrations CSV Report", "event_espresso"),
142
+				'report_all'          => __('All Registrations CSV Report', 'event_espresso'),
143
+				'report_filtered'     => __('Filtered CSV Report', 'event_espresso'),
144
+				'contact_list_report' => __('Contact List Report', 'event_espresso'),
145
+				'contact_list_export' => __("Export Data", "event_espresso"),
146
+			),
147
+			'publishbox'                   => array(
148
+				'add_new_attendee' => __("Add Contact Record", 'event_espresso'),
149
+				'edit_attendee'    => __("Update Contact Record", 'event_espresso'),
150
+			),
151
+			'hide_add_button_on_cpt_route' => array(
152
+				'edit_attendee' => true,
153
+			),
154
+		);
155
+	}
156
+
157
+
158
+	/**
159
+	 *        grab url requests and route them
160
+	 *
161
+	 * @access private
162
+	 * @return void
163
+	 */
164
+	public function _set_page_routes()
165
+	{
166
+		$this->_get_registration_status_array();
167
+		$reg_id             = ! empty($this->_req_data['_REG_ID']) && ! is_array($this->_req_data['_REG_ID'])
168
+			? $this->_req_data['_REG_ID'] : 0;
169
+		$att_id             = ! empty($this->_req_data['ATT_ID']) && ! is_array($this->_req_data['ATT_ID'])
170
+			? $this->_req_data['ATT_ID'] : 0;
171
+		$att_id             = ! empty($this->_req_data['post']) && ! is_array($this->_req_data['post']) ? $this->_req_data['post']
172
+			: $att_id;
173
+		$this->_page_routes = array(
174
+			'default'                            => array(
175
+				'func'       => '_registrations_overview_list_table',
176
+				'capability' => 'ee_read_registrations',
177
+			),
178
+			'view_registration'                  => array(
179
+				'func'       => '_registration_details',
180
+				'capability' => 'ee_read_registration',
181
+				'obj_id'     => $reg_id,
182
+			),
183
+			'edit_registration'                  => array(
184
+				'func'               => '_update_attendee_registration_form',
185
+				'noheader'           => true,
186
+				'headers_sent_route' => 'view_registration',
187
+				'capability'         => 'ee_edit_registration',
188
+				'obj_id'             => $reg_id,
189
+				'_REG_ID'            => $reg_id,
190
+			),
191
+			'trash_registrations'                => array(
192
+				'func'       => '_trash_or_restore_registrations',
193
+				'args'       => array('trash' => true),
194
+				'noheader'   => true,
195
+				'capability' => 'ee_delete_registrations',
196
+			),
197
+			'restore_registrations'              => array(
198
+				'func'       => '_trash_or_restore_registrations',
199
+				'args'       => array('trash' => false),
200
+				'noheader'   => true,
201
+				'capability' => 'ee_delete_registrations',
202
+			),
203
+			'delete_registrations'               => array(
204
+				'func'       => '_delete_registrations',
205
+				'noheader'   => true,
206
+				'capability' => 'ee_delete_registrations',
207
+			),
208
+			'new_registration'                   => array(
209
+				'func'       => 'new_registration',
210
+				'capability' => 'ee_edit_registrations',
211
+			),
212
+			'process_reg_step'                   => array(
213
+				'func'       => 'process_reg_step',
214
+				'noheader'   => true,
215
+				'capability' => 'ee_edit_registrations',
216
+			),
217
+			'redirect_to_txn'                    => array(
218
+				'func'       => 'redirect_to_txn',
219
+				'noheader'   => true,
220
+				'capability' => 'ee_edit_registrations',
221
+			),
222
+			'change_reg_status'                  => array(
223
+				'func'       => '_change_reg_status',
224
+				'noheader'   => true,
225
+				'capability' => 'ee_edit_registration',
226
+				'obj_id'     => $reg_id,
227
+			),
228
+			'approve_registration'               => array(
229
+				'func'       => 'approve_registration',
230
+				'noheader'   => true,
231
+				'capability' => 'ee_edit_registration',
232
+				'obj_id'     => $reg_id,
233
+			),
234
+			'approve_and_notify_registration'    => array(
235
+				'func'       => 'approve_registration',
236
+				'noheader'   => true,
237
+				'args'       => array(true),
238
+				'capability' => 'ee_edit_registration',
239
+				'obj_id'     => $reg_id,
240
+			),
241
+			'decline_registration'               => array(
242
+				'func'       => 'decline_registration',
243
+				'noheader'   => true,
244
+				'capability' => 'ee_edit_registration',
245
+				'obj_id'     => $reg_id,
246
+			),
247
+			'decline_and_notify_registration'    => array(
248
+				'func'       => 'decline_registration',
249
+				'noheader'   => true,
250
+				'args'       => array(true),
251
+				'capability' => 'ee_edit_registration',
252
+				'obj_id'     => $reg_id,
253
+			),
254
+			'pending_registration'               => array(
255
+				'func'       => 'pending_registration',
256
+				'noheader'   => true,
257
+				'capability' => 'ee_edit_registration',
258
+				'obj_id'     => $reg_id,
259
+			),
260
+			'pending_and_notify_registration'    => array(
261
+				'func'       => 'pending_registration',
262
+				'noheader'   => true,
263
+				'args'       => array(true),
264
+				'capability' => 'ee_edit_registration',
265
+				'obj_id'     => $reg_id,
266
+			),
267
+			'no_approve_registration'            => array(
268
+				'func'       => 'not_approve_registration',
269
+				'noheader'   => true,
270
+				'capability' => 'ee_edit_registration',
271
+				'obj_id'     => $reg_id,
272
+			),
273
+			'no_approve_and_notify_registration' => array(
274
+				'func'       => 'not_approve_registration',
275
+				'noheader'   => true,
276
+				'args'       => array(true),
277
+				'capability' => 'ee_edit_registration',
278
+				'obj_id'     => $reg_id,
279
+			),
280
+			'cancel_registration'                => array(
281
+				'func'       => 'cancel_registration',
282
+				'noheader'   => true,
283
+				'capability' => 'ee_edit_registration',
284
+				'obj_id'     => $reg_id,
285
+			),
286
+			'cancel_and_notify_registration'     => array(
287
+				'func'       => 'cancel_registration',
288
+				'noheader'   => true,
289
+				'args'       => array(true),
290
+				'capability' => 'ee_edit_registration',
291
+				'obj_id'     => $reg_id,
292
+			),
293
+			'contact_list'                       => array(
294
+				'func'       => '_attendee_contact_list_table',
295
+				'capability' => 'ee_read_contacts',
296
+			),
297
+			'add_new_attendee'                   => array(
298
+				'func' => '_create_new_cpt_item',
299
+				'args' => array(
300
+					'new_attendee' => true,
301
+					'capability'   => 'ee_edit_contacts',
302
+				),
303
+			),
304
+			'edit_attendee'                      => array(
305
+				'func'       => '_edit_cpt_item',
306
+				'capability' => 'ee_edit_contacts',
307
+				'obj_id'     => $att_id,
308
+			),
309
+			'duplicate_attendee'                 => array(
310
+				'func'       => '_duplicate_attendee',
311
+				'noheader'   => true,
312
+				'capability' => 'ee_edit_contacts',
313
+				'obj_id'     => $att_id,
314
+			),
315
+			'insert_attendee'                    => array(
316
+				'func'       => '_insert_or_update_attendee',
317
+				'args'       => array(
318
+					'new_attendee' => true,
319
+				),
320
+				'noheader'   => true,
321
+				'capability' => 'ee_edit_contacts',
322
+			),
323
+			'update_attendee'                    => array(
324
+				'func'       => '_insert_or_update_attendee',
325
+				'args'       => array(
326
+					'new_attendee' => false,
327
+				),
328
+				'noheader'   => true,
329
+				'capability' => 'ee_edit_contacts',
330
+				'obj_id'     => $att_id,
331
+			),
332
+			'trash_attendees'                    => array(
333
+				'func'       => '_trash_or_restore_attendees',
334
+				'args'       => array(
335
+					'trash' => true,
336
+				),
337
+				'noheader'   => true,
338
+				'capability' => 'ee_delete_contacts',
339
+				'obj_id'     => $att_id,
340
+			),
341
+			'restore_attendees'                  => array(
342
+				'func'       => '_trash_or_restore_attendees',
343
+				'args'       => array(
344
+					'trash' => false,
345
+				),
346
+				'noheader'   => true,
347
+				'capability' => 'ee_delete_contacts',
348
+				'obj_id'     => $att_id,
349
+			),
350
+			'resend_registration'                => array(
351
+				'func'       => '_resend_registration',
352
+				'noheader'   => true,
353
+				'capability' => 'ee_send_message',
354
+			),
355
+			'registrations_report'               => array(
356
+				'func'       => '_registrations_report',
357
+				'noheader'   => true,
358
+				'capability' => 'ee_read_registrations',
359
+			),
360
+			'contact_list_export'                => array(
361
+				'func'       => '_contact_list_export',
362
+				'noheader'   => true,
363
+				'capability' => 'export',
364
+			),
365
+			'contact_list_report'                => array(
366
+				'func'       => '_contact_list_report',
367
+				'noheader'   => true,
368
+				'capability' => 'ee_read_contacts',
369
+			),
370
+		);
371
+	}
372
+
373
+
374
+	protected function _set_page_config()
375
+	{
376
+		$this->_page_config = array(
377
+			'default'           => array(
378
+				'nav'           => array(
379
+					'label' => __('Overview', 'event_espresso'),
380
+					'order' => 5,
381
+				),
382
+				'help_tabs'     => array(
383
+					'registrations_overview_help_tab'                       => array(
384
+						'title'    => __('Registrations Overview', 'event_espresso'),
385
+						'filename' => 'registrations_overview',
386
+					),
387
+					'registrations_overview_table_column_headings_help_tab' => array(
388
+						'title'    => __('Registrations Table Column Headings', 'event_espresso'),
389
+						'filename' => 'registrations_overview_table_column_headings',
390
+					),
391
+					'registrations_overview_filters_help_tab'               => array(
392
+						'title'    => __('Registration Filters', 'event_espresso'),
393
+						'filename' => 'registrations_overview_filters',
394
+					),
395
+					'registrations_overview_views_help_tab'                 => array(
396
+						'title'    => __('Registration Views', 'event_espresso'),
397
+						'filename' => 'registrations_overview_views',
398
+					),
399
+					'registrations_regoverview_other_help_tab'              => array(
400
+						'title'    => __('Registrations Other', 'event_espresso'),
401
+						'filename' => 'registrations_overview_other',
402
+					),
403
+				),
404
+				'help_tour'     => array('Registration_Overview_Help_Tour'),
405
+				'qtips'         => array('Registration_List_Table_Tips'),
406
+				'list_table'    => 'EE_Registrations_List_Table',
407
+				'require_nonce' => false,
408
+			),
409
+			'view_registration' => array(
410
+				'nav'           => array(
411
+					'label'      => __('REG Details', 'event_espresso'),
412
+					'order'      => 15,
413
+					'url'        => isset($this->_req_data['_REG_ID'])
414
+						? add_query_arg(array('_REG_ID' => $this->_req_data['_REG_ID']), $this->_current_page_view_url)
415
+						: $this->_admin_base_url,
416
+					'persistent' => false,
417
+				),
418
+				'help_tabs'     => array(
419
+					'registrations_details_help_tab'                    => array(
420
+						'title'    => __('Registration Details', 'event_espresso'),
421
+						'filename' => 'registrations_details',
422
+					),
423
+					'registrations_details_table_help_tab'              => array(
424
+						'title'    => __('Registration Details Table', 'event_espresso'),
425
+						'filename' => 'registrations_details_table',
426
+					),
427
+					'registrations_details_form_answers_help_tab'       => array(
428
+						'title'    => __('Registration Form Answers', 'event_espresso'),
429
+						'filename' => 'registrations_details_form_answers',
430
+					),
431
+					'registrations_details_registrant_details_help_tab' => array(
432
+						'title'    => __('Contact Details', 'event_espresso'),
433
+						'filename' => 'registrations_details_registrant_details',
434
+					),
435
+				),
436
+				'help_tour'     => array('Registration_Details_Help_Tour'),
437
+				'metaboxes'     => array_merge($this->_default_espresso_metaboxes,
438
+					array('_registration_details_metaboxes')),
439
+				'require_nonce' => false,
440
+			),
441
+			'new_registration'  => array(
442
+				'nav'           => array(
443
+					'label'      => __('Add New Registration', 'event_espresso'),
444
+					'url'        => '#',
445
+					'order'      => 15,
446
+					'persistent' => false,
447
+				),
448
+				'metaboxes'     => $this->_default_espresso_metaboxes,
449
+				'labels'        => array(
450
+					'publishbox' => __('Save Registration', 'event_espresso'),
451
+				),
452
+				'require_nonce' => false,
453
+			),
454
+			'add_new_attendee'  => array(
455
+				'nav'           => array(
456
+					'label'      => __('Add Contact', 'event_espresso'),
457
+					'order'      => 15,
458
+					'persistent' => false,
459
+				),
460
+				'metaboxes'     => array_merge($this->_default_espresso_metaboxes,
461
+					array('_publish_post_box', 'attendee_editor_metaboxes')),
462
+				'require_nonce' => false,
463
+			),
464
+			'edit_attendee'     => array(
465
+				'nav'           => array(
466
+					'label'      => __('Edit Contact', 'event_espresso'),
467
+					'order'      => 15,
468
+					'persistent' => false,
469
+					'url'        => isset($this->_req_data['ATT_ID'])
470
+						? add_query_arg(array('ATT_ID' => $this->_req_data['ATT_ID']), $this->_current_page_view_url)
471
+						: $this->_admin_base_url,
472
+				),
473
+				'metaboxes'     => array('attendee_editor_metaboxes'),
474
+				'require_nonce' => false,
475
+			),
476
+			'contact_list'      => array(
477
+				'nav'           => array(
478
+					'label' => __('Contact List', 'event_espresso'),
479
+					'order' => 20,
480
+				),
481
+				'list_table'    => 'EE_Attendee_Contact_List_Table',
482
+				'help_tabs'     => array(
483
+					'registrations_contact_list_help_tab'                       => array(
484
+						'title'    => __('Registrations Contact List', 'event_espresso'),
485
+						'filename' => 'registrations_contact_list',
486
+					),
487
+					'registrations_contact-list_table_column_headings_help_tab' => array(
488
+						'title'    => __('Contact List Table Column Headings', 'event_espresso'),
489
+						'filename' => 'registrations_contact_list_table_column_headings',
490
+					),
491
+					'registrations_contact_list_views_help_tab'                 => array(
492
+						'title'    => __('Contact List Views', 'event_espresso'),
493
+						'filename' => 'registrations_contact_list_views',
494
+					),
495
+					'registrations_contact_list_other_help_tab'                 => array(
496
+						'title'    => __('Contact List Other', 'event_espresso'),
497
+						'filename' => 'registrations_contact_list_other',
498
+					),
499
+				),
500
+				'help_tour'     => array('Contact_List_Help_Tour'),
501
+				'metaboxes'     => array(),
502
+				'require_nonce' => false,
503
+			),
504
+			//override default cpt routes
505
+			'create_new'        => '',
506
+			'edit'              => '',
507
+		);
508
+	}
509
+
510
+
511
+	/**
512
+	 * The below methods aren't used by this class currently
513
+	 */
514
+	protected function _add_screen_options()
515
+	{
516
+	}
517
+
518
+
519
+	protected function _add_feature_pointers()
520
+	{
521
+	}
522
+
523
+
524
+	public function admin_init()
525
+	{
526
+		EE_Registry::$i18n_js_strings['update_att_qstns'] = __('click "Update Registration Questions" to save your changes',
527
+			'event_espresso');
528
+	}
529
+
530
+
531
+	public function admin_notices()
532
+	{
533
+	}
534
+
535
+
536
+	public function admin_footer_scripts()
537
+	{
538
+	}
539
+
540
+
541
+	/**
542
+	 *        get list of registration statuses
543
+	 *
544
+	 * @access private
545
+	 * @return void
546
+	 */
547
+	private function _get_registration_status_array()
548
+	{
549
+		self::$_reg_status = EEM_Registration::reg_status_array(array(), true);
550
+	}
551
+
552
+
553
+	protected function _add_screen_options_default()
554
+	{
555
+		$this->_per_page_screen_option();
556
+	}
557
+
558
+
559
+	protected function _add_screen_options_contact_list()
560
+	{
561
+		$page_title              = $this->_admin_page_title;
562
+		$this->_admin_page_title = __("Contacts", 'event_espresso');
563
+		$this->_per_page_screen_option();
564
+		$this->_admin_page_title = $page_title;
565
+	}
566
+
567
+
568
+	public function load_scripts_styles()
569
+	{
570
+		//style
571
+		//wp_register_style('espresso_attendees', ATT_ASSETS_URL . 'espresso_attendees_admin.css', array(), EVENT_ESPRESSO_VERSION );
572
+		wp_register_style('espresso_reg', REG_ASSETS_URL . 'espresso_registrations_admin.css', array('ee-admin-css'),
573
+			EVENT_ESPRESSO_VERSION);
574
+		wp_enqueue_style('espresso_reg');
575
+		//script
576
+		wp_register_script('espresso_reg', REG_ASSETS_URL . 'espresso_registrations_admin.js',
577
+			array('jquery-ui-datepicker', 'jquery-ui-draggable', 'ee_admin_js'), EVENT_ESPRESSO_VERSION, true);
578
+		wp_enqueue_script('espresso_reg');
579
+	}
580
+
581
+
582
+	public function load_scripts_styles_edit_attendee()
583
+	{
584
+		//stuff to only show up on our attendee edit details page.
585
+		$attendee_details_translations = array(
586
+			'att_publish_text' => sprintf(__('Created on: <b>%1$s</b>', 'event_espresso'),
587
+				$this->_cpt_model_obj->get_datetime('ATT_created')),
588
+		);
589
+		wp_localize_script('espresso_reg', 'ATTENDEE_DETAILS', $attendee_details_translations);
590
+		wp_enqueue_script('jquery-validate');
591
+	}
592
+
593
+
594
+	public function load_scripts_styles_view_registration()
595
+	{
596
+		//styles
597
+		wp_enqueue_style('espresso-ui-theme');
598
+		//scripts
599
+		$this->_get_reg_custom_questions_form($this->_registration->ID());
600
+		$this->_reg_custom_questions_form->wp_enqueue_scripts(true);
601
+	}
602
+
603
+
604
+	public function load_scripts_styles_contact_list()
605
+	{
606
+		wp_deregister_style('espresso_reg');
607
+		wp_register_style('espresso_att', REG_ASSETS_URL . 'espresso_attendees_admin.css', array('ee-admin-css'),
608
+			EVENT_ESPRESSO_VERSION);
609
+		wp_enqueue_style('espresso_att');
610
+	}
611
+
612
+
613
+	public function load_scripts_styles_new_registration()
614
+	{
615
+		wp_register_script('ee-spco-for-admin', REG_ASSETS_URL . 'spco_for_admin.js', array('underscore', 'jquery'),
616
+			EVENT_ESPRESSO_VERSION, true);
617
+		wp_enqueue_script('ee-spco-for-admin');
618
+		add_filter('FHEE__EED_Ticket_Selector__load_tckt_slctr_assets', '__return_true');
619
+		EE_Form_Section_Proper::wp_enqueue_scripts();
620
+		EED_Ticket_Selector::load_tckt_slctr_assets();
621
+		EE_Datepicker_Input::enqueue_styles_and_scripts();
622
+	}
623
+
624
+
625
+	public function AHEE__EE_Admin_Page__route_admin_request_resend_registration()
626
+	{
627
+		add_filter('FHEE_load_EE_messages', '__return_true');
628
+	}
629
+
630
+
631
+	public function AHEE__EE_Admin_Page__route_admin_request_approve_registration()
632
+	{
633
+		add_filter('FHEE_load_EE_messages', '__return_true');
634
+	}
635
+
636
+
637
+	protected function _set_list_table_views_default()
638
+	{
639
+		//for notification related bulk actions we need to make sure only active messengers have an option.
640
+		EED_Messages::set_autoloaders();
641
+		/** @type EE_Message_Resource_Manager $message_resource_manager */
642
+		$message_resource_manager = EE_Registry::instance()->load_lib('Message_Resource_Manager');
643
+		$active_mts               = $message_resource_manager->list_of_active_message_types();
644
+		//key= bulk_action_slug, value= message type.
645
+		$match_array = array(
646
+			'approve_registration'    => 'registration',
647
+			'decline_registration'    => 'declined_registration',
648
+			'pending_registration'    => 'pending_approval',
649
+			'no_approve_registration' => 'not_approved_registration',
650
+			'cancel_registration'     => 'cancelled_registration',
651
+		);
652
+		/** setup reg status bulk actions **/
653
+		$def_reg_status_actions['approve_registration'] = __('Approve Registrations', 'event_espresso');
654
+		if (in_array($match_array['approve_registration'], $active_mts)
655
+			&& EE_Registry::instance()->CAP->current_user_can('ee_send_message', 'batch_send_messages')
656
+		) {
657
+			$def_reg_status_actions['approve_and_notify_registration'] = __('Approve and Notify Registrations',
658
+				'event_espresso');
659
+		}
660
+		$def_reg_status_actions['decline_registration'] = __('Decline Registrations', 'event_espresso');
661
+		if (in_array($match_array['decline_registration'], $active_mts)
662
+			&& EE_Registry::instance()->CAP->current_user_can('ee_send_message', 'batch_send_messages')
663
+		) {
664
+			$def_reg_status_actions['decline_and_notify_registration'] = __('Decline and Notify Registrations',
665
+				'event_espresso');
666
+		}
667
+		$def_reg_status_actions['pending_registration'] = __('Set Registrations to Pending Payment', 'event_espresso');
668
+		if (in_array($match_array['pending_registration'], $active_mts)
669
+			&& EE_Registry::instance()->CAP->current_user_can('ee_send_message', 'batch_send_messages')
670
+		) {
671
+			$def_reg_status_actions['pending_and_notify_registration'] = __('Set Registrations to Pending Payment and Notify',
672
+				'event_espresso');
673
+		}
674
+		$def_reg_status_actions['no_approve_registration'] = __('Set Registrations to Not Approved', 'event_espresso');
675
+		if (in_array($match_array['no_approve_registration'], $active_mts)
676
+			&& EE_Registry::instance()->CAP->current_user_can('ee_send_message', 'batch_send_messages')
677
+		) {
678
+			$def_reg_status_actions['no_approve_and_notify_registration'] = __('Set Registrations to Not Approved and Notify',
679
+				'event_espresso');
680
+		}
681
+		$def_reg_status_actions['cancel_registration'] = __('Cancel Registrations', 'event_espresso');
682
+		if (in_array($match_array['cancel_registration'], $active_mts)
683
+			&& EE_Registry::instance()->CAP->current_user_can('ee_send_message', 'batch_send_messages')
684
+		) {
685
+			$def_reg_status_actions['cancel_and_notify_registration'] = __('Cancel Registrations and Notify',
686
+				'event_espresso');
687
+		}
688
+		$this->_views = array(
689
+			'all'   => array(
690
+				'slug'        => 'all',
691
+				'label'       => __('View All Registrations', 'event_espresso'),
692
+				'count'       => 0,
693
+				'bulk_action' => array_merge($def_reg_status_actions, array(
694
+					'trash_registrations' => __('Trash Registrations', 'event_espresso'),
695
+				)),
696
+			),
697
+			'month' => array(
698
+				'slug'        => 'month',
699
+				'label'       => __('This Month', 'event_espresso'),
700
+				'count'       => 0,
701
+				'bulk_action' => array_merge($def_reg_status_actions, array(
702
+					'trash_registrations' => __('Trash Registrations', 'event_espresso'),
703
+				)),
704
+			),
705
+			'today' => array(
706
+				'slug'        => 'today',
707
+				'label'       => sprintf(__('Today - %s', 'event_espresso'), date('M d, Y', current_time('timestamp'))),
708
+				'count'       => 0,
709
+				'bulk_action' => array_merge($def_reg_status_actions, array(
710
+					'trash_registrations' => __('Trash Registrations', 'event_espresso'),
711
+				)),
712
+			),
713
+		);
714
+		if (EE_Registry::instance()->CAP->current_user_can('ee_delete_registrations',
715
+			'espresso_registrations_delete_registration')
716
+		) {
717
+			$this->_views['incomplete'] = array(
718
+				'slug'        => 'incomplete',
719
+				'label'       => __('Incomplete', 'event_espresso'),
720
+				'count'       => 0,
721
+				'bulk_action' => array(
722
+					'trash_registrations' => __('Trash Registrations', 'event_espresso'),
723
+				),
724
+			);
725
+			$this->_views['trash']      = array(
726
+				'slug'        => 'trash',
727
+				'label'       => __('Trash', 'event_espresso'),
728
+				'count'       => 0,
729
+				'bulk_action' => array(
730
+					'restore_registrations' => __('Restore Registrations', 'event_espresso'),
731
+					'delete_registrations'  => __('Delete Registrations Permanently', 'event_espresso'),
732
+				),
733
+			);
734
+		}
735
+	}
736
+
737
+
738
+	protected function _set_list_table_views_contact_list()
739
+	{
740
+		$this->_views = array(
741
+			'in_use' => array(
742
+				'slug'        => 'in_use',
743
+				'label'       => __('In Use', 'event_espresso'),
744
+				'count'       => 0,
745
+				'bulk_action' => array(
746
+					'trash_attendees' => __('Move to Trash', 'event_espresso'),
747
+				),
748
+			),
749
+		);
750
+		if (EE_Registry::instance()->CAP->current_user_can('ee_delete_contacts',
751
+			'espresso_registrations_trash_attendees')
752
+		) {
753
+			$this->_views['trash'] = array(
754
+				'slug'        => 'trash',
755
+				'label'       => __('Trash', 'event_espresso'),
756
+				'count'       => 0,
757
+				'bulk_action' => array(
758
+					'restore_attendees' => __('Restore from Trash', 'event_espresso'),
759
+				),
760
+			);
761
+		}
762
+	}
763
+
764
+
765
+	protected function _registration_legend_items()
766
+	{
767
+		$fc_items = array(
768
+			'star-icon'        => array(
769
+				'class' => 'dashicons dashicons-star-filled lt-blue-icon ee-icon-size-8',
770
+				'desc'  => __('This is the Primary Registrant', 'event_espresso'),
771
+			),
772
+			'view_details'     => array(
773
+				'class' => 'dashicons dashicons-clipboard',
774
+				'desc'  => __('View Registration Details', 'event_espresso'),
775
+			),
776
+			'edit_attendee'    => array(
777
+				'class' => 'ee-icon ee-icon-user-edit ee-icon-size-16',
778
+				'desc'  => __('Edit Contact Details', 'event_espresso'),
779
+			),
780
+			'view_transaction' => array(
781
+				'class' => 'dashicons dashicons-cart',
782
+				'desc'  => __('View Transaction Details', 'event_espresso'),
783
+			),
784
+			'view_invoice'     => array(
785
+				'class' => 'dashicons dashicons-media-spreadsheet',
786
+				'desc'  => __('View Transaction Invoice', 'event_espresso'),
787
+			),
788
+		);
789
+		if (EE_Registry::instance()->CAP->current_user_can('ee_send_message',
790
+			'espresso_registrations_resend_registration')
791
+		) {
792
+			$fc_items['resend_registration'] = array(
793
+				'class' => 'dashicons dashicons-email-alt',
794
+				'desc'  => __('Resend Registration Details', 'event_espresso'),
795
+			);
796
+		} else {
797
+			$fc_items['blank'] = array('class' => 'blank', 'desc' => '');
798
+		}
799
+		if (EE_Registry::instance()->CAP->current_user_can('ee_read_global_messages', 'view_filtered_messages')) {
800
+			$related_for_icon = EEH_MSG_Template::get_message_action_icon('see_notifications_for');
801
+			if (isset($related_for_icon['css_class']) && isset($related_for_icon['label'])) {
802
+				$fc_items['view_related_messages'] = array(
803
+					'class' => $related_for_icon['css_class'],
804
+					'desc'  => $related_for_icon['label'],
805
+				);
806
+			}
807
+		}
808
+		$sc_items = array(
809
+			'approved_status'   => array(
810
+				'class' => 'ee-status-legend ee-status-legend-' . EEM_Registration::status_id_approved,
811
+				'desc'  => EEH_Template::pretty_status(EEM_Registration::status_id_approved, false, 'sentence'),
812
+			),
813
+			'pending_status'    => array(
814
+				'class' => 'ee-status-legend ee-status-legend-' . EEM_Registration::status_id_pending_payment,
815
+				'desc'  => EEH_Template::pretty_status(EEM_Registration::status_id_pending_payment, false, 'sentence'),
816
+			),
817
+			'wait_list'         => array(
818
+				'class' => 'ee-status-legend ee-status-legend-' . EEM_Registration::status_id_wait_list,
819
+				'desc'  => EEH_Template::pretty_status(EEM_Registration::status_id_wait_list, false, 'sentence'),
820
+			),
821
+			'incomplete_status' => array(
822
+				'class' => 'ee-status-legend ee-status-legend-' . EEM_Registration::status_id_incomplete,
823
+				'desc'  => EEH_Template::pretty_status(EEM_Registration::status_id_incomplete, false, 'sentence'),
824
+			),
825
+			'not_approved'      => array(
826
+				'class' => 'ee-status-legend ee-status-legend-' . EEM_Registration::status_id_not_approved,
827
+				'desc'  => EEH_Template::pretty_status(EEM_Registration::status_id_not_approved, false, 'sentence'),
828
+			),
829
+			'declined_status'   => array(
830
+				'class' => 'ee-status-legend ee-status-legend-' . EEM_Registration::status_id_declined,
831
+				'desc'  => EEH_Template::pretty_status(EEM_Registration::status_id_declined, false, 'sentence'),
832
+			),
833
+			'cancelled_status'  => array(
834
+				'class' => 'ee-status-legend ee-status-legend-' . EEM_Registration::status_id_cancelled,
835
+				'desc'  => EEH_Template::pretty_status(EEM_Registration::status_id_cancelled, false, 'sentence'),
836
+			),
837
+		);
838
+		return array_merge($fc_items, $sc_items);
839
+	}
840
+
841
+
842
+
843
+	/***************************************        REGISTRATION OVERVIEW        **************************************/
844
+	/**
845
+	 * @throws \EE_Error
846
+	 */
847
+	protected function _registrations_overview_list_table()
848
+	{
849
+		$this->_template_args['admin_page_header'] = '';
850
+		$EVT_ID                                    = ! empty($this->_req_data['event_id']) ? absint($this->_req_data['event_id']) : 0;
851
+		if ($EVT_ID) {
852
+			if (EE_Registry::instance()->CAP->current_user_can('ee_edit_registrations',
853
+				'espresso_registrations_new_registration', $EVT_ID)
854
+			) {
855
+				$this->_admin_page_title .= ' ' . $this->get_action_link_or_button('new_registration', 'add-registrant',
856
+						array('event_id' => $EVT_ID), 'add-new-h2');
857
+			}
858
+			$event = EEM_Event::instance()->get_one_by_ID($EVT_ID);
859
+			if ($event instanceof EE_Event) {
860
+				$this->_template_args['admin_page_header'] = sprintf(__('%s Viewing registrations for the event: %s%s',
861
+					'event_espresso'), '<h3 style="line-height:1.5em;">',
862
+					'<br /><a href="' . EE_Admin_Page::add_query_args_and_nonce(array(
863
+						'action' => 'edit',
864
+						'post'   => $event->ID(),
865
+					), EVENTS_ADMIN_URL) . '">&nbsp;' . $event->get('EVT_name') . '&nbsp;</a>&nbsp;', '</h3>');
866
+			}
867
+			$DTT_ID   = ! empty($this->_req_data['datetime_id']) ? absint($this->_req_data['datetime_id']) : 0;
868
+			$datetime = EEM_Datetime::instance()->get_one_by_ID($DTT_ID);
869
+			if ($datetime instanceof EE_Datetime && $this->_template_args['admin_page_header'] !== '') {
870
+				$this->_template_args['admin_page_header'] = substr($this->_template_args['admin_page_header'], 0, -5);
871
+				$this->_template_args['admin_page_header'] .= ' &nbsp;<span class="drk-grey-text">';
872
+				$this->_template_args['admin_page_header'] .= '<span class="dashicons dashicons-calendar"></span>';
873
+				$this->_template_args['admin_page_header'] .= $datetime->name();
874
+				$this->_template_args['admin_page_header'] .= ' ( ' . $datetime->start_date() . ' )';
875
+				$this->_template_args['admin_page_header'] .= '</span></h3>';
876
+			}
877
+		}
878
+		$this->_template_args['after_list_table'] = $this->_display_legend($this->_registration_legend_items());
879
+		$this->display_admin_list_table_page_with_no_sidebar();
880
+	}
881
+
882
+
883
+	/**
884
+	 * This sets the _registration property for the registration details screen
885
+	 *
886
+	 * @access private
887
+	 * @return bool
888
+	 */
889
+	private function _set_registration_object()
890
+	{
891
+		//get out if we've already set the object
892
+		if (is_object($this->_registration)) {
893
+			return true;
894
+		}
895
+		$REG    = EEM_Registration::instance();
896
+		$REG_ID = ( ! empty($this->_req_data['_REG_ID'])) ? absint($this->_req_data['_REG_ID']) : false;
897
+		if ($this->_registration = $REG->get_one_by_ID($REG_ID)) {
898
+			return true;
899
+		} else {
900
+			$error_msg = sprintf(__('An error occurred and the details for Registration ID #%s could not be retrieved.',
901
+				'event_espresso'), $REG_ID);
902
+			EE_Error::add_error($error_msg, __FILE__, __FUNCTION__, __LINE__);
903
+			$this->_registration = null;
904
+			return false;
905
+		}
906
+	}
907
+
908
+
909
+	/**
910
+	 * Used to retrieve registrations for the list table.
911
+	 *
912
+	 * @param int    $per_page
913
+	 * @param bool   $count
914
+	 * @param bool   $this_month
915
+	 * @param bool   $today
916
+	 * @return \EE_Registration[]|int
917
+	 */
918
+	public function get_registrations(
919
+		$per_page = 10,
920
+		$count = false,
921
+		$this_month = false,
922
+		$today = false
923
+	) {
924
+		if( $this_month ) {
925
+			$this->_req_data['status'] = 'month';
926
+		}
927
+		if( $today ) {
928
+			$this->_req_data['status'] = 'today';
929
+		}
930
+		$query_params = $this->_get_registration_query_parameters($this->_req_data, $per_page, $count);
931
+		return $count
932
+			? EEM_Registration::instance()->count($query_params)
933
+			/** @type EE_Registration[] */
934
+			: EEM_Registration::instance()->get_all($query_params);
935
+	}
936
+
937
+
938
+
939
+	/**
940
+	 * Retrieves the query parameters to be used by the Registration model for getting registrations.
941
+	 * Note: this listens to values on the request for some of the query parameters.
942
+	 *
943
+	 * @param array $request
944
+	 * @param int    $per_page
945
+	 * @param bool   $count
946
+	 * @return array
947
+	 */
948
+	protected function _get_registration_query_parameters(
949
+		$request = array(),
950
+		$per_page = 10,
951
+		$count = false
952
+	) {
953
+
954
+		$query_params = array(
955
+			0                          => $this->_get_where_conditions_for_registrations_query(
956
+				$request
957
+			),
958
+			'caps'                     => EEM_Registration::caps_read_admin,
959
+			'default_where_conditions' => 'this_model_only',
960
+		);
961
+		if ( ! $count) {
962
+			$query_params = array_merge(
963
+				$query_params,
964
+				$this->_get_orderby_for_registrations_query(),
965
+				$this->_get_limit($per_page)
966
+			);
967
+		}
968
+
969
+		return $query_params;
970
+	}
971
+
972
+
973
+	/**
974
+	 * This will add EVT_ID to the provided $where array for EE model query parameters.
975
+	 *
976
+	 * @param array $request usually the same as $this->_req_data but not necessarily
977
+	 * @return array
978
+	 */
979
+	protected function _add_event_id_to_where_conditions(array $request)
980
+	{
981
+		$where = array();
982
+		if ( ! empty($request['event_id'])) {
983
+			$where['EVT_ID'] = absint($request['event_id']);
984
+		}
985
+		return $where;
986
+	}
987
+
988
+
989
+	/**
990
+	 * Adds category ID if it exists in the request to the where conditions for the registrations query.
991
+	 *
992
+	 * @param array $request usually the same as $this->_req_data but not necessarily
993
+	 * @return array
994
+	 */
995
+	protected function _add_category_id_to_where_conditions(array $request)
996
+	{
997
+		$where = array();
998
+		if ( ! empty($request['EVT_CAT']) && (int)$request['EVT_CAT'] !== -1) {
999
+			$where['Event.Term_Taxonomy.term_id'] = absint($request['EVT_CAT']);
1000
+		}
1001
+		return $where;
1002
+	}
1003
+
1004
+
1005
+	/**
1006
+	 * Adds the datetime ID if it exists in the request to the where conditions for the registrations query.
1007
+	 *
1008
+	 * @param array $request usually the same as $this->_req_data but not necessarily
1009
+	 * @return array
1010
+	 */
1011
+	protected function _add_datetime_id_to_where_conditions(array $request)
1012
+	{
1013
+		$where = array();
1014
+		if ( ! empty($request['datetime_id'])) {
1015
+			$where['Ticket.Datetime.DTT_ID'] = absint($request['datetime_id']);
1016
+		}
1017
+		if( ! empty($request['DTT_ID'])){
1018
+			$where['Ticket.Datetime.DTT_ID'] = absint($request['DTT_ID']);
1019
+		}
1020
+		return $where;
1021
+	}
1022
+
1023
+
1024
+	/**
1025
+	 * Adds the correct registration status to the where conditions for the registrations query.
1026
+	 *
1027
+	 * @param array $request usually the same as $this->_req_data but not necessarily
1028
+	 * @return array
1029
+	 */
1030
+	protected function _add_registration_status_to_where_conditions(array $request)
1031
+	{
1032
+		$where = array();
1033
+		$view  = EEH_Array::is_set( $request, 'status', '' );
1034
+		$registration_status = ! empty($request['_reg_status'])
1035
+			? sanitize_text_field($request['_reg_status'])
1036
+			: '';
1037
+
1038
+		/*
1039 1039
          * If filtering by registration status, then we show registrations matching that status.
1040 1040
          * If not filtering by specified status, then we show all registrations excluding incomplete registrations UNLESS
1041 1041
          * viewing trashed registrations.
1042 1042
          */
1043
-        if ( ! empty($registration_status)) {
1044
-            $where['STS_ID'] = $registration_status;
1045
-        } else {
1046
-            //make sure we exclude incomplete registrations, but only if not trashed.
1047
-            if ($view === 'trash') {
1048
-                $where['REG_deleted'] = true;
1049
-            } else if ($view === 'incomplete') {
1050
-                $where['STS_ID'] = EEM_Registration::status_id_incomplete;
1051
-            } else {
1052
-                $where['STS_ID'] = array('!=', EEM_Registration::status_id_incomplete);
1053
-            }
1054
-        }
1055
-        return $where;
1056
-    }
1057
-
1058
-
1059
-    /**
1060
-     * Adds any provided date restraints to the where conditions for the registrations query.
1061
-     *
1062
-     * @param array $request usually the same as $this->_req_data but not necessarily
1063
-     * @return array
1064
-     */
1065
-    protected function _add_date_to_where_conditions(array $request)
1066
-    {
1067
-        $where = array();
1068
-        $view  = EEH_Array::is_set( $request, 'status', '' );
1069
-        $month_range             = ! empty($request['month_range'])
1070
-            ? sanitize_text_field($request['month_range'])
1071
-            : '';
1072
-        $retrieve_for_today      = $view === 'today';
1073
-        $retrieve_for_this_month = $view === 'month';
1074
-
1075
-        if ($retrieve_for_today) {
1076
-            $now               = date('Y-m-d', current_time('timestamp'));
1077
-            $where['REG_date'] = array(
1078
-                'BETWEEN',
1079
-                array(
1080
-                    EEM_Registration::instance()->convert_datetime_for_query(
1081
-                        'REG_date',
1082
-                        $now . ' 00:00:00',
1083
-                        'Y-m-d H:i:s'
1084
-                    ),
1085
-                    EEM_Registration::instance()->convert_datetime_for_query(
1086
-                        'REG_date',
1087
-                        $now . ' 23:59:59',
1088
-                        'Y-m-d H:i:s'
1089
-                    ),
1090
-                ),
1091
-            );
1092
-        } elseif ($retrieve_for_this_month) {
1093
-            $current_year_and_month = date('Y-m', current_time('timestamp'));
1094
-            $days_this_month        = date('t', current_time('timestamp'));
1095
-            $where['REG_date']      = array(
1096
-                'BETWEEN',
1097
-                array(
1098
-                    EEM_Registration::instance()->convert_datetime_for_query(
1099
-                        'REG_date',
1100
-                        $current_year_and_month . '-01 00:00:00',
1101
-                        'Y-m-d H:i:s'
1102
-                    ),
1103
-                    EEM_Registration::instance()->convert_datetime_for_query(
1104
-                        'REG_date',
1105
-                        $current_year_and_month . '-' . $days_this_month . ' 23:59:59',
1106
-                        'Y-m-d H:i:s'
1107
-                    ),
1108
-                ),
1109
-            );
1110
-        } elseif ($month_range) {
1111
-            $pieces          = explode(' ', $month_range, 3);
1112
-            $month_requested = ! empty($pieces[0])
1113
-                ? date('m', \EEH_DTT_Helper::first_of_month_timestamp($pieces[0]))
1114
-                : '';
1115
-            $year_requested  = ! empty($pieces[1])
1116
-                ? $pieces[1]
1117
-                : '';
1118
-            //if there is not a month or year then we can't go further
1119
-            if ($month_requested && $year_requested) {
1120
-                $days_in_month     = date('t', strtotime($year_requested . '-' . $month_requested . '-' . '01'));
1121
-                $where['REG_date'] = array(
1122
-                    'BETWEEN',
1123
-                    array(
1124
-                        EEM_Registration::instance()->convert_datetime_for_query(
1125
-                            'REG_date',
1126
-                            $year_requested . '-' . $month_requested . '-01 00:00:00',
1127
-                            'Y-m-d H:i:s'
1128
-                        ),
1129
-                        EEM_Registration::instance()->convert_datetime_for_query(
1130
-                            'REG_date',
1131
-                            $year_requested . '-' . $month_requested . '-' . $days_in_month . ' 23:59:59',
1132
-                            'Y-m-d H:i:s'
1133
-                        ),
1134
-                    ),
1135
-                );
1136
-            }
1137
-        }
1138
-        return $where;
1139
-    }
1140
-
1141
-
1142
-    /**
1143
-     * Adds any provided search restraints to the where conditions for the registrations query
1144
-     *
1145
-     * @param array $request usually the same as $this->_req_data but not necessarily
1146
-     * @return array
1147
-     */
1148
-    protected function _add_search_to_where_conditions(array $request)
1149
-    {
1150
-        $where = array();
1151
-        if ( ! empty($request['s'])) {
1152
-            $search_string = '%' . sanitize_text_field($request['s']) . '%';
1153
-            $where['OR'] = array(
1154
-                'Event.EVT_name'                          => array('LIKE', $search_string),
1155
-                'Event.EVT_desc'                          => array('LIKE', $search_string),
1156
-                'Event.EVT_short_desc'                    => array('LIKE', $search_string),
1157
-                'Attendee.ATT_full_name'                  => array('LIKE', $search_string),
1158
-                'Attendee.ATT_fname'                      => array('LIKE', $search_string),
1159
-                'Attendee.ATT_lname'                      => array('LIKE', $search_string),
1160
-                'Attendee.ATT_short_bio'                  => array('LIKE', $search_string),
1161
-                'Attendee.ATT_email'                      => array('LIKE', $search_string),
1162
-                'Attendee.ATT_address'                    => array('LIKE', $search_string),
1163
-                'Attendee.ATT_address2'                   => array('LIKE', $search_string),
1164
-                'Attendee.ATT_city'                       => array('LIKE', $search_string),
1165
-                'REG_final_price'                         => array('LIKE', $search_string),
1166
-                'REG_code'                                => array('LIKE', $search_string),
1167
-                'REG_count'                               => array('LIKE', $search_string),
1168
-                'REG_group_size'                          => array('LIKE', $search_string),
1169
-                'Ticket.TKT_name'                         => array('LIKE', $search_string),
1170
-                'Ticket.TKT_description'                  => array('LIKE', $search_string),
1171
-                'Transaction.Payment.PAY_txn_id_chq_nmbr' => array('LIKE', $search_string),
1172
-            );
1173
-        }
1174
-        return $where;
1175
-    }
1176
-
1177
-
1178
-    /**
1179
-     * Sets up the where conditions for the registrations query.
1180
-     *
1181
-     * @param array $request
1182
-     * @return array
1183
-     */
1184
-    protected function _get_where_conditions_for_registrations_query($request)
1185
-    {
1186
-        return array_merge(
1187
-            $this->_add_event_id_to_where_conditions($request),
1188
-            $this->_add_category_id_to_where_conditions($request),
1189
-            $this->_add_datetime_id_to_where_conditions($request),
1190
-            $this->_add_registration_status_to_where_conditions($request),
1191
-            $this->_add_date_to_where_conditions($request),
1192
-            $this->_add_search_to_where_conditions($request)
1193
-        );
1194
-    }
1195
-
1196
-
1197
-    /**
1198
-     * Sets up the orderby for the registrations query.
1199
-     *
1200
-     * @return array
1201
-     */
1202
-    protected function _get_orderby_for_registrations_query()
1203
-    {
1204
-        $orderby_field = ! empty($this->_req_data['orderby'])
1205
-            ? sanitize_text_field($this->_req_data['orderby'])
1206
-            : '';
1207
-        switch ($orderby_field) {
1208
-            case '_REG_ID':
1209
-                $orderby_field = 'REG_ID';
1210
-                break;
1211
-            case '_Reg_status':
1212
-                $orderby_field = 'STS_ID';
1213
-                break;
1214
-            case 'ATT_fname':
1215
-                //just for spite, we're going to order it by their LAST name, NOT their first name. Now who's the boss?
1216
-                //jk, we don't want to break existing links, and customers preferred ordering by last name
1217
-                //besides, from the UI, its ambiguous as to whether we will order by first or last name
1218
-                $orderby_field = 'Attendee.ATT_lname';
1219
-                break;
1220
-            case 'event_name':
1221
-                $orderby_field = 'Event.EVT_name';
1222
-                break;
1223
-            case 'DTT_EVT_start':
1224
-                $orderby_field = 'Event.Datetime.DTT_EVT_start';
1225
-                break;
1226
-            default: //'REG_date'
1227
-                $orderby_field = 'REG_date';
1228
-        }
1229
-
1230
-        //order
1231
-        $order = ! empty($this->_req_data['order'])
1232
-            ? sanitize_text_field($this->_req_data['order'])
1233
-            : 'DESC';
1234
-        return array('order_by' => array($orderby_field => $order));
1235
-    }
1236
-
1237
-
1238
-    /**
1239
-     * Sets up the limit for the registrations query.
1240
-     *
1241
-     * @param $per_page
1242
-     * @return array
1243
-     */
1244
-    protected function _get_limit($per_page)
1245
-    {
1246
-        $current_page = ! empty($this->_req_data['paged'])
1247
-            ? absint($this->_req_data['paged'])
1248
-            : 1;
1249
-        $per_page     = ! empty($this->_req_data['perpage'])
1250
-            ? $this->_req_data['perpage']
1251
-            : $per_page;
1252
-
1253
-        //-1 means return all results so get out if that's set.
1254
-        if ((int)$per_page === -1) {
1255
-            return array();
1256
-        }
1257
-        $per_page = absint($per_page);
1258
-        $offset   = ($current_page - 1) * $per_page;
1259
-        return array('limit' => array($offset, $per_page));
1260
-    }
1261
-
1262
-
1263
-    public function get_registration_status_array()
1264
-    {
1265
-        return self::$_reg_status;
1266
-    }
1267
-
1268
-
1269
-
1270
-
1271
-    /***************************************        REGISTRATION DETAILS        ***************************************/
1272
-    /**
1273
-     *        generates HTML for the View Registration Details Admin page
1274
-     *
1275
-     * @access protected
1276
-     * @return void
1277
-     */
1278
-    protected function _registration_details()
1279
-    {
1280
-        $this->_template_args = array();
1281
-        $this->_set_registration_object();
1282
-        if (is_object($this->_registration)) {
1283
-            $transaction                                   = $this->_registration->transaction() ? $this->_registration->transaction()
1284
-                : EE_Transaction::new_instance();
1285
-            $this->_session                                = $transaction->session_data();
1286
-            $event_id                                      = $this->_registration->event_ID();
1287
-            $this->_template_args['reg_nmbr']['value']     = $this->_registration->ID();
1288
-            $this->_template_args['reg_nmbr']['label']     = __('Registration Number', 'event_espresso');
1289
-            $this->_template_args['reg_datetime']['value'] = $this->_registration->get_i18n_datetime('REG_date');
1290
-            $this->_template_args['reg_datetime']['label'] = __('Date', 'event_espresso');
1291
-            $this->_template_args['grand_total']           = $transaction->total();
1292
-            $this->_template_args['currency_sign']         = EE_Registry::instance()->CFG->currency->sign;
1293
-            // link back to overview
1294
-            $this->_template_args['reg_overview_url']            = REG_ADMIN_URL;
1295
-            $this->_template_args['registration']                = $this->_registration;
1296
-            $this->_template_args['filtered_registrations_link'] = EE_Admin_Page::add_query_args_and_nonce(array(
1297
-                'action'   => 'default',
1298
-                'event_id' => $event_id,
1299
-            ), REG_ADMIN_URL);
1300
-            $this->_template_args['filtered_transactions_link']  = EE_Admin_Page::add_query_args_and_nonce(array(
1301
-                'action' => 'default',
1302
-                'EVT_ID' => $event_id,
1303
-                'page'   => 'espresso_transactions',
1304
-            ), admin_url('admin.php'));
1305
-            $this->_template_args['event_link']                  = EE_Admin_Page::add_query_args_and_nonce(array(
1306
-                'page'   => 'espresso_events',
1307
-                'action' => 'edit',
1308
-                'post'   => $event_id,
1309
-            ), admin_url('admin.php'));
1310
-            //next and previous links
1311
-            $next_reg                                      = $this->_registration->next(null, array(), 'REG_ID');
1312
-            $this->_template_args['next_registration']     = $next_reg
1313
-                ? $this->_next_link(EE_Admin_Page::add_query_args_and_nonce(array(
1314
-                    'action'  => 'view_registration',
1315
-                    '_REG_ID' => $next_reg['REG_ID'],
1316
-                ), REG_ADMIN_URL), 'dashicons dashicons-arrow-right ee-icon-size-22') : '';
1317
-            $previous_reg                                  = $this->_registration->previous(null, array(), 'REG_ID');
1318
-            $this->_template_args['previous_registration'] = $previous_reg
1319
-                ? $this->_previous_link(EE_Admin_Page::add_query_args_and_nonce(array(
1320
-                    'action'  => 'view_registration',
1321
-                    '_REG_ID' => $previous_reg['REG_ID'],
1322
-                ), REG_ADMIN_URL), 'dashicons dashicons-arrow-left ee-icon-size-22') : '';
1323
-            // grab header
1324
-            $template_path                             = REG_TEMPLATE_PATH . 'reg_admin_details_header.template.php';
1325
-            $this->_template_args['REG_ID']            = $this->_registration->ID();
1326
-            $this->_template_args['admin_page_header'] = EEH_Template::display_template($template_path,
1327
-                $this->_template_args, true);
1328
-        } else {
1329
-            $this->_template_args['admin_page_header'] = $this->display_espresso_notices();
1330
-        }
1331
-        // the details template wrapper
1332
-        $this->display_admin_page_with_sidebar();
1333
-    }
1334
-
1335
-
1336
-    protected function _registration_details_metaboxes()
1337
-    {
1338
-        do_action('AHEE__Registrations_Admin_Page___registration_details_metabox__start', $this);
1339
-        $this->_set_registration_object();
1340
-        $attendee = $this->_registration instanceof EE_Registration ? $this->_registration->attendee() : null;
1341
-        add_meta_box('edit-reg-status-mbox', __('Registration Status', 'event_espresso'),
1342
-            array($this, 'set_reg_status_buttons_metabox'), $this->wp_page_slug, 'normal', 'high');
1343
-        add_meta_box('edit-reg-details-mbox', __('Registration Details', 'event_espresso'),
1344
-            array($this, '_reg_details_meta_box'), $this->wp_page_slug, 'normal', 'high');
1345
-        if ($attendee instanceof EE_Attendee
1346
-            && EE_Registry::instance()->CAP->current_user_can('ee_edit_registration', 'edit-reg-questions-mbox')
1347
-        ) {
1348
-            add_meta_box('edit-reg-questions-mbox', __('Registration Form Answers', 'event_espresso'),
1349
-                array($this, '_reg_questions_meta_box'), $this->wp_page_slug, 'normal', 'high');
1350
-        }
1351
-        add_meta_box('edit-reg-registrant-mbox', __('Contact Details', 'event_espresso'),
1352
-            array($this, '_reg_registrant_side_meta_box'), $this->wp_page_slug, 'side', 'high');
1353
-        if ($this->_registration->group_size() > 1) {
1354
-            add_meta_box('edit-reg-attendees-mbox', __('Other Registrations in this Transaction', 'event_espresso'),
1355
-                array($this, '_reg_attendees_meta_box'), $this->wp_page_slug, 'normal', 'high');
1356
-        }
1357
-    }
1358
-
1359
-
1360
-    /**
1361
-     * set_reg_status_buttons_metabox
1362
-     *
1363
-     * @access protected
1364
-     * @return string
1365
-     * @throws \EE_Error
1366
-     */
1367
-    public function set_reg_status_buttons_metabox()
1368
-    {
1369
-        $this->_set_registration_object();
1370
-        $change_reg_status_form = $this->_generate_reg_status_change_form();
1371
-        echo $change_reg_status_form->form_open(self::add_query_args_and_nonce(array(
1372
-            'action' => 'change_reg_status',
1373
-        ), REG_ADMIN_URL));
1374
-        echo $change_reg_status_form->get_html();
1375
-        echo $change_reg_status_form->form_close();
1376
-    }
1377
-
1378
-
1379
-    /**
1380
-     * @return EE_Form_Section_Proper
1381
-     */
1382
-    protected function _generate_reg_status_change_form()
1383
-    {
1384
-        return new EE_Form_Section_Proper(array(
1385
-            'name'            => 'reg_status_change_form',
1386
-            'html_id'         => 'reg-status-change-form',
1387
-            'layout_strategy' => new EE_Admin_Two_Column_Layout(),
1388
-            'subsections'     => array(
1389
-                'return'             => new EE_Hidden_Input(array(
1390
-                    'name'    => 'return',
1391
-                    'default' => 'view_registration',
1392
-                )),
1393
-                'REG_ID'             => new EE_Hidden_Input(array(
1394
-                    'name'    => 'REG_ID',
1395
-                    'default' => $this->_registration->ID(),
1396
-                )),
1397
-                'current_status'     => new EE_Form_Section_HTML(EEH_HTML::tr(EEH_HTML::th(EEH_HTML::label(EEH_HTML::strong(__('Current Registration Status',
1398
-                        'event_espresso')))) . EEH_HTML::td(EEH_HTML::strong($this->_registration->pretty_status(),
1399
-                        '', 'status-' . $this->_registration->status_ID(),
1400
-                        'line-height: 1em; font-size: 1.5em; font-weight: bold;')))),
1401
-                'reg_status'         => new EE_Select_Input($this->_get_reg_statuses(), array(
1402
-                    'html_label_text' => __('Change Registration Status to', 'event_espresso'),
1403
-                    'default'         => $this->_registration->status_ID(),
1404
-                )),
1405
-                'send_notifications' => new EE_Yes_No_Input(array(
1406
-                    'html_label_text' => __('Send Related Messages', 'event_espresso'),
1407
-                    'default'         => false,
1408
-                    'html_help_text'  => __('If set to "Yes", then the related messages will be sent to the registrant.',
1409
-                        'event_espresso'),
1410
-                )),
1411
-                'submit'             => new EE_Submit_Input(array(
1412
-                    'html_class'      => 'button-primary',
1413
-                    'html_label_text' => '&nbsp;',
1414
-                    'default'         => __('Update Registration Status', 'event_espresso'),
1415
-                )),
1416
-            ),
1417
-        ));
1418
-    }
1419
-
1420
-
1421
-
1422
-    /**
1423
-     * Returns an array of all the buttons for the various statuses and switch status actions
1424
-     *
1425
-     * @return array
1426
-     */
1427
-    protected function _get_reg_statuses()
1428
-    {
1429
-        $reg_status_array = EEM_Registration::instance()->reg_status_array();
1430
-        unset ($reg_status_array[EEM_Registration::status_id_incomplete]);
1431
-        // get current reg status
1432
-        $current_status = $this->_registration->status_ID();
1433
-        // is registration for free event? This will determine whether to display the pending payment option
1434
-        if ($current_status != EEM_Registration::status_id_pending_payment
1435
-            && $this->_registration->transaction()
1436
-                                   ->is_free()
1437
-        ) {
1438
-            unset($reg_status_array[EEM_Registration::status_id_pending_payment]);
1439
-        }
1440
-        return EEM_Status::instance()->localized_status($reg_status_array, false, 'sentence');
1441
-    }
1442
-
1443
-
1444
-    /**
1445
-     * This method is used when using _REG_ID from request which may or may not be an array of reg_ids.
1446
-     *
1447
-     * @param bool $status REG status given for changing registrations to.
1448
-     * @param bool $notify Whether to send messages notifications or not.
1449
-     * @return array  (array with reg_id(s) updated and whether update was successful.
1450
-     */
1451
-    protected function _set_registration_status_from_request($status = false, $notify = false)
1452
-    {
1453
-        if (isset($this->_req_data['reg_status_change_form'])) {
1454
-            $REG_IDs = isset($this->_req_data['reg_status_change_form']['REG_ID'])
1455
-                ? (array)$this->_req_data['reg_status_change_form']['REG_ID'] : array();
1456
-        } else {
1457
-            $REG_IDs = isset($this->_req_data['_REG_ID']) ? (array)$this->_req_data['_REG_ID'] : array();
1458
-        }
1459
-        $success = $this->_set_registration_status($REG_IDs, $status);
1460
-        //notify?
1461
-        if ($success
1462
-            && $notify
1463
-            && EE_Registry::instance()->CAP->current_user_can('ee_send_message',
1464
-                'espresso_registrations_resend_registration')
1465
-        ) {
1466
-            $this->_process_resend_registration();
1467
-        }
1468
-        return $success;
1469
-    }
1470
-
1471
-
1472
-    /**
1473
-     * Set the registration status for the given reg_id (which may or may not be an array, it gets typecast to an
1474
-     * array). Note, this method does NOT take care of possible notifications.  That is required by calling code.
1475
-     *
1476
-     * @param array $REG_IDs
1477
-     * @param bool  $status
1478
-     * @return array (an array with 'success' key representing whether status change was successful, and 'REG_ID' as
1479
-     *               the array of updated registrations).
1480
-     */
1481
-    protected function _set_registration_status($REG_IDs = array(), $status = false)
1482
-    {
1483
-        $success = false;
1484
-        // typecast $REG_IDs
1485
-        $REG_IDs = (array)$REG_IDs;
1486
-        if ( ! empty($REG_IDs)) {
1487
-            $success = true;
1488
-            // set default status if none is passed
1489
-            $status = $status ? $status : EEM_Registration::status_id_pending_payment;
1490
-            // sanitize $REG_IDs
1491
-            $REG_IDs = array_filter($REG_IDs, 'absint');
1492
-            //loop through REG_ID's and change status
1493
-            foreach ($REG_IDs as $REG_ID) {
1494
-                $registration = EEM_Registration::instance()->get_one_by_ID($REG_ID);
1495
-                if ($registration instanceof EE_Registration) {
1496
-                    $registration->set_status($status);
1497
-                    $result = $registration->save();
1498
-                    // verifying explicit fails because update *may* just return 0 for 0 rows affected
1499
-                    $success = $result !== false ? $success : false;
1500
-                }
1501
-            }
1502
-        }
1503
-        //reset _req_data['_REG_ID'] for any potential future messages notifications
1504
-        $this->_req_data['_REG_ID'] = $REG_IDs;
1505
-        //return $success and processed registrations
1506
-        return array('REG_ID' => $REG_IDs, 'success' => $success);
1507
-    }
1508
-
1509
-
1510
-    /**
1511
-     * Common logic for setting up success message and redirecting to appropriate route
1512
-     *
1513
-     * @param  string $STS_ID status id for the registration changed to
1514
-     * @param   bool  $notify indicates whether the _set_registration_status_from_request does notifications or not.
1515
-     * @return void
1516
-     */
1517
-    protected function _reg_status_change_return($STS_ID, $notify = false)
1518
-    {
1519
-        $result  = ! empty($STS_ID) ? $this->_set_registration_status_from_request($STS_ID, $notify)
1520
-            : array('success' => false);
1521
-        $success = isset($result['success']) && $result['success'];
1522
-        //setup success message
1523
-        if ($success) {
1524
-            if (is_array($result['REG_ID']) && count($result['REG_ID']) === 1) {
1525
-                $msg = sprintf(__('Registration status has been set to %s', 'event_espresso'),
1526
-                    EEH_Template::pretty_status($STS_ID, false, 'lower'));
1527
-            } else {
1528
-                $msg = sprintf(__('Registrations have been set to %s.', 'event_espresso'),
1529
-                    EEH_Template::pretty_status($STS_ID, false, 'lower'));
1530
-            }
1531
-            EE_Error::add_success($msg);
1532
-        } else {
1533
-            EE_Error::add_error(__('Something went wrong, and the status was not changed', 'event_espresso'), __FILE__,
1534
-                __LINE__, __FUNCTION__);
1535
-        }
1536
-        if (isset($this->_req_data['return']) && $this->_req_data['return'] == 'view_registration') {
1537
-            $route = array('action' => 'view_registration', '_REG_ID' => reset($result['REG_ID']));
1538
-        } else {
1539
-            $route = array('action' => 'default');
1540
-        }
1541
-        //unset nonces
1542
-        foreach ($this->_req_data as $ref => $value) {
1543
-            if (strpos($ref, 'nonce') !== false) {
1544
-                unset($this->_req_data[$ref]);
1545
-                continue;
1546
-            }
1547
-            $value                 = is_array($value) ? array_map('urlencode', $value) : urlencode($value);
1548
-            $this->_req_data[$ref] = $value;
1549
-        }
1550
-        //merge request vars so that the reloaded list table contains any existing filter query params
1551
-        $route = array_merge($this->_req_data, $route);
1552
-        $this->_redirect_after_action($success, '', '', $route, true);
1553
-    }
1554
-
1555
-
1556
-    /**
1557
-     * incoming reg status change from reg details page.
1558
-     *
1559
-     * @return void
1560
-     */
1561
-    protected function _change_reg_status()
1562
-    {
1563
-        $this->_req_data['return'] = 'view_registration';
1564
-        //set notify based on whether the send notifications toggle is set or not
1565
-        $notify = ! empty($this->_req_data['reg_status_change_form']['send_notifications']);
1566
-        //$notify = ! empty( $this->_req_data['txn_reg_status_change']['send_notifications'] );
1567
-        $this->_req_data['reg_status_change_form']['reg_status'] = isset($this->_req_data['reg_status_change_form']['reg_status'])
1568
-            ? $this->_req_data['reg_status_change_form']['reg_status'] : '';
1569
-        switch ($this->_req_data['reg_status_change_form']['reg_status']) {
1570
-            case EEM_Registration::status_id_approved :
1571
-            case EEH_Template::pretty_status(EEM_Registration::status_id_approved, false, 'sentence') :
1572
-                $this->approve_registration($notify);
1573
-                break;
1574
-            case EEM_Registration::status_id_pending_payment :
1575
-            case EEH_Template::pretty_status(EEM_Registration::status_id_pending_payment, false, 'sentence') :
1576
-                $this->pending_registration($notify);
1577
-                break;
1578
-            case EEM_Registration::status_id_not_approved :
1579
-            case EEH_Template::pretty_status(EEM_Registration::status_id_not_approved, false, 'sentence') :
1580
-                $this->not_approve_registration($notify);
1581
-                break;
1582
-            case EEM_Registration::status_id_declined :
1583
-            case EEH_Template::pretty_status(EEM_Registration::status_id_declined, false, 'sentence') :
1584
-                $this->decline_registration($notify);
1585
-                break;
1586
-            case EEM_Registration::status_id_cancelled :
1587
-            case EEH_Template::pretty_status(EEM_Registration::status_id_cancelled, false, 'sentence') :
1588
-                $this->cancel_registration($notify);
1589
-                break;
1590
-            case EEM_Registration::status_id_wait_list :
1591
-            case EEH_Template::pretty_status(EEM_Registration::status_id_wait_list, false, 'sentence') :
1592
-                $this->waitlist_registration($notify);
1593
-                break;
1594
-            case EEM_Registration::status_id_incomplete :
1595
-            default :
1596
-                $result['success'] = false;
1597
-                unset($this->_req_data['return']);
1598
-                $this->_reg_status_change_return('', false);
1599
-                break;
1600
-        }
1601
-    }
1602
-
1603
-
1604
-    /**
1605
-     * approve_registration
1606
-     *
1607
-     * @access protected
1608
-     * @param bool $notify whether or not to notify the registrant about their approval.
1609
-     * @return void
1610
-     */
1611
-    protected function approve_registration($notify = false)
1612
-    {
1613
-        $this->_reg_status_change_return(EEM_Registration::status_id_approved, $notify);
1614
-    }
1615
-
1616
-
1617
-    /**
1618
-     *        decline_registration
1619
-     *
1620
-     * @access protected
1621
-     * @param bool $notify whether or not to notify the registrant about their status change.
1622
-     * @return void
1623
-     */
1624
-    protected function decline_registration($notify = false)
1625
-    {
1626
-        $this->_reg_status_change_return(EEM_Registration::status_id_declined, $notify);
1627
-    }
1628
-
1629
-
1630
-    /**
1631
-     *        cancel_registration
1632
-     *
1633
-     * @access protected
1634
-     * @param bool $notify whether or not to notify the registrant about their status change.
1635
-     * @return void
1636
-     */
1637
-    protected function cancel_registration($notify = false)
1638
-    {
1639
-        $this->_reg_status_change_return(EEM_Registration::status_id_cancelled, $notify);
1640
-    }
1641
-
1642
-
1643
-    /**
1644
-     *        not_approve_registration
1645
-     *
1646
-     * @access protected
1647
-     * @param bool $notify whether or not to notify the registrant about their status change.
1648
-     * @return void
1649
-     */
1650
-    protected function not_approve_registration($notify = false)
1651
-    {
1652
-        $this->_reg_status_change_return(EEM_Registration::status_id_not_approved, $notify);
1653
-    }
1654
-
1655
-
1656
-    /**
1657
-     *        decline_registration
1658
-     *
1659
-     * @access protected
1660
-     * @param bool $notify whether or not to notify the registrant about their status change.
1661
-     * @return void
1662
-     */
1663
-    protected function pending_registration($notify = false)
1664
-    {
1665
-        $this->_reg_status_change_return(EEM_Registration::status_id_pending_payment, $notify);
1666
-    }
1667
-
1668
-
1669
-    /**
1670
-     * waitlist_registration
1671
-     *
1672
-     * @access protected
1673
-     * @param bool $notify whether or not to notify the registrant about their status change.
1674
-     * @return void
1675
-     */
1676
-    protected function waitlist_registration($notify = false)
1677
-    {
1678
-        $this->_reg_status_change_return(EEM_Registration::status_id_wait_list, $notify);
1679
-    }
1680
-
1681
-
1682
-    /**
1683
-     *        generates HTML for the Registration main meta box
1684
-     *
1685
-     * @access public
1686
-     * @return void
1687
-     */
1688
-    public function _reg_details_meta_box()
1689
-    {
1690
-        EEH_Autoloader::register_line_item_display_autoloaders();
1691
-        EEH_Autoloader::register_line_item_filter_autoloaders();
1692
-        EE_Registry::instance()->load_helper('Line_Item');
1693
-        $transaction    = $this->_registration->transaction() ? $this->_registration->transaction()
1694
-            : EE_Transaction::new_instance();
1695
-        $this->_session = $transaction->session_data();
1696
-        $filters        = new EE_Line_Item_Filter_Collection();
1697
-        //$filters->add( new EE_Non_Zero_Line_Item_Filter() );
1698
-        $filters->add(new EE_Single_Registration_Line_Item_Filter($this->_registration));
1699
-        $line_item_filter_processor              = new EE_Line_Item_Filter_Processor($filters,
1700
-            $transaction->total_line_item());
1701
-        $filtered_line_item_tree                 = $line_item_filter_processor->process();
1702
-        $line_item_display                       = new EE_Line_Item_Display('reg_admin_table',
1703
-            'EE_Admin_Table_Registration_Line_Item_Display_Strategy');
1704
-        $this->_template_args['line_item_table'] = $line_item_display->display_line_item($filtered_line_item_tree,
1705
-            array('EE_Registration' => $this->_registration));
1706
-        $attendee                                = $this->_registration->attendee();
1707
-        if (EE_Registry::instance()->CAP->current_user_can('ee_read_transaction',
1708
-            'espresso_transactions_view_transaction')
1709
-        ) {
1710
-            $this->_template_args['view_transaction_button'] = EEH_Template::get_button_or_link(EE_Admin_Page::add_query_args_and_nonce(array(
1711
-                'action' => 'view_transaction',
1712
-                'TXN_ID' => $transaction->ID(),
1713
-            ), TXN_ADMIN_URL), esc_html__(' View Transaction'), 'button secondary-button right',
1714
-                'dashicons dashicons-cart');
1715
-        } else {
1716
-            $this->_template_args['view_transaction_button'] = '';
1717
-        }
1718
-        if ($attendee instanceof EE_Attendee
1719
-            && EE_Registry::instance()->CAP->current_user_can('ee_send_message',
1720
-                'espresso_registrations_resend_registration')
1721
-        ) {
1722
-            $this->_template_args['resend_registration_button'] = EEH_Template::get_button_or_link(EE_Admin_Page::add_query_args_and_nonce(array(
1723
-                'action'      => 'resend_registration',
1724
-                '_REG_ID'     => $this->_registration->ID(),
1725
-                'redirect_to' => 'view_registration',
1726
-            ), REG_ADMIN_URL), esc_html__(' Resend Registration'), 'button secondary-button right',
1727
-                'dashicons dashicons-email-alt');
1728
-        } else {
1729
-            $this->_template_args['resend_registration_button'] = '';
1730
-        }
1731
-        $this->_template_args['currency_sign'] = EE_Registry::instance()->CFG->currency->sign;
1732
-        $payment                               = $transaction->get_first_related('Payment');
1733
-        $payment                               = ! $payment instanceof EE_Payment ? EE_Payment::new_instance() : $payment;
1734
-        $payment_method                        = $payment->get_first_related('Payment_Method');
1735
-        $payment_method                        = ! $payment_method instanceof EE_Payment_Method ? EE_Payment_Method::new_instance()
1736
-            : $payment_method;
1737
-        $reg_details                           = array(
1738
-            'payment_method'       => $payment_method->name(),
1739
-            'response_msg'         => $payment->gateway_response(),
1740
-            'registration_id'      => $this->_registration->get('REG_code'),
1741
-            'registration_session' => $this->_registration->session_ID(),
1742
-            'ip_address'           => isset($this->_session['ip_address']) ? $this->_session['ip_address'] : '',
1743
-            'user_agent'           => isset($this->_session['user_agent']) ? $this->_session['user_agent'] : '',
1744
-        );
1745
-        if (isset($reg_details['registration_id'])) {
1746
-            $this->_template_args['reg_details']['registration_id']['value'] = $reg_details['registration_id'];
1747
-            $this->_template_args['reg_details']['registration_id']['label'] = __('Registration ID', 'event_espresso');
1748
-            $this->_template_args['reg_details']['registration_id']['class'] = 'regular-text';
1749
-        }
1750
-        if (isset($reg_details['payment_method'])) {
1751
-            $this->_template_args['reg_details']['payment_method']['value'] = $reg_details['payment_method'];
1752
-            $this->_template_args['reg_details']['payment_method']['label'] = __('Most Recent Payment Method',
1753
-                'event_espresso');
1754
-            $this->_template_args['reg_details']['payment_method']['class'] = 'regular-text';
1755
-            $this->_template_args['reg_details']['response_msg']['value']   = $reg_details['response_msg'];
1756
-            $this->_template_args['reg_details']['response_msg']['label']   = __('Payment method response',
1757
-                'event_espresso');
1758
-            $this->_template_args['reg_details']['response_msg']['class']   = 'regular-text';
1759
-        }
1760
-        $this->_template_args['reg_details']['registration_session']['value'] = $reg_details['registration_session'];
1761
-        $this->_template_args['reg_details']['registration_session']['label'] = __('Registration Session',
1762
-            'event_espresso');
1763
-        $this->_template_args['reg_details']['registration_session']['class'] = 'regular-text';
1764
-        $this->_template_args['reg_details']['ip_address']['value']           = $reg_details['ip_address'];
1765
-        $this->_template_args['reg_details']['ip_address']['label']           = __('Registration placed from IP',
1766
-            'event_espresso');
1767
-        $this->_template_args['reg_details']['ip_address']['class']           = 'regular-text';
1768
-        $this->_template_args['reg_details']['user_agent']['value']           = $reg_details['user_agent'];
1769
-        $this->_template_args['reg_details']['user_agent']['label']           = __('Registrant User Agent',
1770
-            'event_espresso');
1771
-        $this->_template_args['reg_details']['user_agent']['class']           = 'large-text';
1772
-        $this->_template_args['event_link']                                   = EE_Admin_Page::add_query_args_and_nonce(array(
1773
-            'action'   => 'default',
1774
-            'event_id' => $this->_registration->event_ID(),
1775
-        ), REG_ADMIN_URL);
1776
-        $this->_template_args['REG_ID']                                       = $this->_registration->ID();
1777
-        $this->_template_args['event_id']                                     = $this->_registration->event_ID();
1778
-        $template_path                                                        = REG_TEMPLATE_PATH . 'reg_admin_details_main_meta_box_reg_details.template.php';
1779
-        echo EEH_Template::display_template($template_path, $this->_template_args, true);
1780
-    }
1781
-
1782
-
1783
-    /**
1784
-     * generates HTML for the Registration Questions meta box.
1785
-     * If pre-4.8.32.rc.000 hooks are used, uses old methods (with its filters),
1786
-     * otherwise uses new forms system
1787
-     *
1788
-     * @access public
1789
-     * @return void
1790
-     */
1791
-    public function _reg_questions_meta_box()
1792
-    {
1793
-        //allow someone to override this method entirely
1794
-        if (apply_filters('FHEE__Registrations_Admin_Page___reg_questions_meta_box__do_default', true, $this,
1795
-            $this->_registration)) {
1796
-            $form                                              = $this->_get_reg_custom_questions_form($this->_registration->ID());
1797
-            $this->_template_args['att_questions']             = count($form->subforms()) > 0 ? $form->get_html_and_js() : '';
1798
-            $this->_template_args['reg_questions_form_action'] = 'edit_registration';
1799
-            $this->_template_args['REG_ID']                    = $this->_registration->ID();
1800
-            $template_path                                     = REG_TEMPLATE_PATH . 'reg_admin_details_main_meta_box_reg_questions.template.php';
1801
-            echo EEH_Template::display_template($template_path, $this->_template_args, true);
1802
-        }
1803
-    }
1804
-
1805
-
1806
-    /**
1807
-     * form_before_question_group
1808
-     *
1809
-     * @deprecated    as of 4.8.32.rc.000
1810
-     * @access        public
1811
-     * @param        string $output
1812
-     * @return        string
1813
-     */
1814
-    public function form_before_question_group($output)
1815
-    {
1816
-        EE_Error::doing_it_wrong(__CLASS__ . '::' . __FUNCTION__,
1817
-            __('This method would have been protected but was used on a filter callback'
1818
-               . 'so needed to be public. Please discontinue usage as it will be removed soon.', 'event_espresso'),
1819
-            '4.8.32.rc.000');
1820
-        return '
1043
+		if ( ! empty($registration_status)) {
1044
+			$where['STS_ID'] = $registration_status;
1045
+		} else {
1046
+			//make sure we exclude incomplete registrations, but only if not trashed.
1047
+			if ($view === 'trash') {
1048
+				$where['REG_deleted'] = true;
1049
+			} else if ($view === 'incomplete') {
1050
+				$where['STS_ID'] = EEM_Registration::status_id_incomplete;
1051
+			} else {
1052
+				$where['STS_ID'] = array('!=', EEM_Registration::status_id_incomplete);
1053
+			}
1054
+		}
1055
+		return $where;
1056
+	}
1057
+
1058
+
1059
+	/**
1060
+	 * Adds any provided date restraints to the where conditions for the registrations query.
1061
+	 *
1062
+	 * @param array $request usually the same as $this->_req_data but not necessarily
1063
+	 * @return array
1064
+	 */
1065
+	protected function _add_date_to_where_conditions(array $request)
1066
+	{
1067
+		$where = array();
1068
+		$view  = EEH_Array::is_set( $request, 'status', '' );
1069
+		$month_range             = ! empty($request['month_range'])
1070
+			? sanitize_text_field($request['month_range'])
1071
+			: '';
1072
+		$retrieve_for_today      = $view === 'today';
1073
+		$retrieve_for_this_month = $view === 'month';
1074
+
1075
+		if ($retrieve_for_today) {
1076
+			$now               = date('Y-m-d', current_time('timestamp'));
1077
+			$where['REG_date'] = array(
1078
+				'BETWEEN',
1079
+				array(
1080
+					EEM_Registration::instance()->convert_datetime_for_query(
1081
+						'REG_date',
1082
+						$now . ' 00:00:00',
1083
+						'Y-m-d H:i:s'
1084
+					),
1085
+					EEM_Registration::instance()->convert_datetime_for_query(
1086
+						'REG_date',
1087
+						$now . ' 23:59:59',
1088
+						'Y-m-d H:i:s'
1089
+					),
1090
+				),
1091
+			);
1092
+		} elseif ($retrieve_for_this_month) {
1093
+			$current_year_and_month = date('Y-m', current_time('timestamp'));
1094
+			$days_this_month        = date('t', current_time('timestamp'));
1095
+			$where['REG_date']      = array(
1096
+				'BETWEEN',
1097
+				array(
1098
+					EEM_Registration::instance()->convert_datetime_for_query(
1099
+						'REG_date',
1100
+						$current_year_and_month . '-01 00:00:00',
1101
+						'Y-m-d H:i:s'
1102
+					),
1103
+					EEM_Registration::instance()->convert_datetime_for_query(
1104
+						'REG_date',
1105
+						$current_year_and_month . '-' . $days_this_month . ' 23:59:59',
1106
+						'Y-m-d H:i:s'
1107
+					),
1108
+				),
1109
+			);
1110
+		} elseif ($month_range) {
1111
+			$pieces          = explode(' ', $month_range, 3);
1112
+			$month_requested = ! empty($pieces[0])
1113
+				? date('m', \EEH_DTT_Helper::first_of_month_timestamp($pieces[0]))
1114
+				: '';
1115
+			$year_requested  = ! empty($pieces[1])
1116
+				? $pieces[1]
1117
+				: '';
1118
+			//if there is not a month or year then we can't go further
1119
+			if ($month_requested && $year_requested) {
1120
+				$days_in_month     = date('t', strtotime($year_requested . '-' . $month_requested . '-' . '01'));
1121
+				$where['REG_date'] = array(
1122
+					'BETWEEN',
1123
+					array(
1124
+						EEM_Registration::instance()->convert_datetime_for_query(
1125
+							'REG_date',
1126
+							$year_requested . '-' . $month_requested . '-01 00:00:00',
1127
+							'Y-m-d H:i:s'
1128
+						),
1129
+						EEM_Registration::instance()->convert_datetime_for_query(
1130
+							'REG_date',
1131
+							$year_requested . '-' . $month_requested . '-' . $days_in_month . ' 23:59:59',
1132
+							'Y-m-d H:i:s'
1133
+						),
1134
+					),
1135
+				);
1136
+			}
1137
+		}
1138
+		return $where;
1139
+	}
1140
+
1141
+
1142
+	/**
1143
+	 * Adds any provided search restraints to the where conditions for the registrations query
1144
+	 *
1145
+	 * @param array $request usually the same as $this->_req_data but not necessarily
1146
+	 * @return array
1147
+	 */
1148
+	protected function _add_search_to_where_conditions(array $request)
1149
+	{
1150
+		$where = array();
1151
+		if ( ! empty($request['s'])) {
1152
+			$search_string = '%' . sanitize_text_field($request['s']) . '%';
1153
+			$where['OR'] = array(
1154
+				'Event.EVT_name'                          => array('LIKE', $search_string),
1155
+				'Event.EVT_desc'                          => array('LIKE', $search_string),
1156
+				'Event.EVT_short_desc'                    => array('LIKE', $search_string),
1157
+				'Attendee.ATT_full_name'                  => array('LIKE', $search_string),
1158
+				'Attendee.ATT_fname'                      => array('LIKE', $search_string),
1159
+				'Attendee.ATT_lname'                      => array('LIKE', $search_string),
1160
+				'Attendee.ATT_short_bio'                  => array('LIKE', $search_string),
1161
+				'Attendee.ATT_email'                      => array('LIKE', $search_string),
1162
+				'Attendee.ATT_address'                    => array('LIKE', $search_string),
1163
+				'Attendee.ATT_address2'                   => array('LIKE', $search_string),
1164
+				'Attendee.ATT_city'                       => array('LIKE', $search_string),
1165
+				'REG_final_price'                         => array('LIKE', $search_string),
1166
+				'REG_code'                                => array('LIKE', $search_string),
1167
+				'REG_count'                               => array('LIKE', $search_string),
1168
+				'REG_group_size'                          => array('LIKE', $search_string),
1169
+				'Ticket.TKT_name'                         => array('LIKE', $search_string),
1170
+				'Ticket.TKT_description'                  => array('LIKE', $search_string),
1171
+				'Transaction.Payment.PAY_txn_id_chq_nmbr' => array('LIKE', $search_string),
1172
+			);
1173
+		}
1174
+		return $where;
1175
+	}
1176
+
1177
+
1178
+	/**
1179
+	 * Sets up the where conditions for the registrations query.
1180
+	 *
1181
+	 * @param array $request
1182
+	 * @return array
1183
+	 */
1184
+	protected function _get_where_conditions_for_registrations_query($request)
1185
+	{
1186
+		return array_merge(
1187
+			$this->_add_event_id_to_where_conditions($request),
1188
+			$this->_add_category_id_to_where_conditions($request),
1189
+			$this->_add_datetime_id_to_where_conditions($request),
1190
+			$this->_add_registration_status_to_where_conditions($request),
1191
+			$this->_add_date_to_where_conditions($request),
1192
+			$this->_add_search_to_where_conditions($request)
1193
+		);
1194
+	}
1195
+
1196
+
1197
+	/**
1198
+	 * Sets up the orderby for the registrations query.
1199
+	 *
1200
+	 * @return array
1201
+	 */
1202
+	protected function _get_orderby_for_registrations_query()
1203
+	{
1204
+		$orderby_field = ! empty($this->_req_data['orderby'])
1205
+			? sanitize_text_field($this->_req_data['orderby'])
1206
+			: '';
1207
+		switch ($orderby_field) {
1208
+			case '_REG_ID':
1209
+				$orderby_field = 'REG_ID';
1210
+				break;
1211
+			case '_Reg_status':
1212
+				$orderby_field = 'STS_ID';
1213
+				break;
1214
+			case 'ATT_fname':
1215
+				//just for spite, we're going to order it by their LAST name, NOT their first name. Now who's the boss?
1216
+				//jk, we don't want to break existing links, and customers preferred ordering by last name
1217
+				//besides, from the UI, its ambiguous as to whether we will order by first or last name
1218
+				$orderby_field = 'Attendee.ATT_lname';
1219
+				break;
1220
+			case 'event_name':
1221
+				$orderby_field = 'Event.EVT_name';
1222
+				break;
1223
+			case 'DTT_EVT_start':
1224
+				$orderby_field = 'Event.Datetime.DTT_EVT_start';
1225
+				break;
1226
+			default: //'REG_date'
1227
+				$orderby_field = 'REG_date';
1228
+		}
1229
+
1230
+		//order
1231
+		$order = ! empty($this->_req_data['order'])
1232
+			? sanitize_text_field($this->_req_data['order'])
1233
+			: 'DESC';
1234
+		return array('order_by' => array($orderby_field => $order));
1235
+	}
1236
+
1237
+
1238
+	/**
1239
+	 * Sets up the limit for the registrations query.
1240
+	 *
1241
+	 * @param $per_page
1242
+	 * @return array
1243
+	 */
1244
+	protected function _get_limit($per_page)
1245
+	{
1246
+		$current_page = ! empty($this->_req_data['paged'])
1247
+			? absint($this->_req_data['paged'])
1248
+			: 1;
1249
+		$per_page     = ! empty($this->_req_data['perpage'])
1250
+			? $this->_req_data['perpage']
1251
+			: $per_page;
1252
+
1253
+		//-1 means return all results so get out if that's set.
1254
+		if ((int)$per_page === -1) {
1255
+			return array();
1256
+		}
1257
+		$per_page = absint($per_page);
1258
+		$offset   = ($current_page - 1) * $per_page;
1259
+		return array('limit' => array($offset, $per_page));
1260
+	}
1261
+
1262
+
1263
+	public function get_registration_status_array()
1264
+	{
1265
+		return self::$_reg_status;
1266
+	}
1267
+
1268
+
1269
+
1270
+
1271
+	/***************************************        REGISTRATION DETAILS        ***************************************/
1272
+	/**
1273
+	 *        generates HTML for the View Registration Details Admin page
1274
+	 *
1275
+	 * @access protected
1276
+	 * @return void
1277
+	 */
1278
+	protected function _registration_details()
1279
+	{
1280
+		$this->_template_args = array();
1281
+		$this->_set_registration_object();
1282
+		if (is_object($this->_registration)) {
1283
+			$transaction                                   = $this->_registration->transaction() ? $this->_registration->transaction()
1284
+				: EE_Transaction::new_instance();
1285
+			$this->_session                                = $transaction->session_data();
1286
+			$event_id                                      = $this->_registration->event_ID();
1287
+			$this->_template_args['reg_nmbr']['value']     = $this->_registration->ID();
1288
+			$this->_template_args['reg_nmbr']['label']     = __('Registration Number', 'event_espresso');
1289
+			$this->_template_args['reg_datetime']['value'] = $this->_registration->get_i18n_datetime('REG_date');
1290
+			$this->_template_args['reg_datetime']['label'] = __('Date', 'event_espresso');
1291
+			$this->_template_args['grand_total']           = $transaction->total();
1292
+			$this->_template_args['currency_sign']         = EE_Registry::instance()->CFG->currency->sign;
1293
+			// link back to overview
1294
+			$this->_template_args['reg_overview_url']            = REG_ADMIN_URL;
1295
+			$this->_template_args['registration']                = $this->_registration;
1296
+			$this->_template_args['filtered_registrations_link'] = EE_Admin_Page::add_query_args_and_nonce(array(
1297
+				'action'   => 'default',
1298
+				'event_id' => $event_id,
1299
+			), REG_ADMIN_URL);
1300
+			$this->_template_args['filtered_transactions_link']  = EE_Admin_Page::add_query_args_and_nonce(array(
1301
+				'action' => 'default',
1302
+				'EVT_ID' => $event_id,
1303
+				'page'   => 'espresso_transactions',
1304
+			), admin_url('admin.php'));
1305
+			$this->_template_args['event_link']                  = EE_Admin_Page::add_query_args_and_nonce(array(
1306
+				'page'   => 'espresso_events',
1307
+				'action' => 'edit',
1308
+				'post'   => $event_id,
1309
+			), admin_url('admin.php'));
1310
+			//next and previous links
1311
+			$next_reg                                      = $this->_registration->next(null, array(), 'REG_ID');
1312
+			$this->_template_args['next_registration']     = $next_reg
1313
+				? $this->_next_link(EE_Admin_Page::add_query_args_and_nonce(array(
1314
+					'action'  => 'view_registration',
1315
+					'_REG_ID' => $next_reg['REG_ID'],
1316
+				), REG_ADMIN_URL), 'dashicons dashicons-arrow-right ee-icon-size-22') : '';
1317
+			$previous_reg                                  = $this->_registration->previous(null, array(), 'REG_ID');
1318
+			$this->_template_args['previous_registration'] = $previous_reg
1319
+				? $this->_previous_link(EE_Admin_Page::add_query_args_and_nonce(array(
1320
+					'action'  => 'view_registration',
1321
+					'_REG_ID' => $previous_reg['REG_ID'],
1322
+				), REG_ADMIN_URL), 'dashicons dashicons-arrow-left ee-icon-size-22') : '';
1323
+			// grab header
1324
+			$template_path                             = REG_TEMPLATE_PATH . 'reg_admin_details_header.template.php';
1325
+			$this->_template_args['REG_ID']            = $this->_registration->ID();
1326
+			$this->_template_args['admin_page_header'] = EEH_Template::display_template($template_path,
1327
+				$this->_template_args, true);
1328
+		} else {
1329
+			$this->_template_args['admin_page_header'] = $this->display_espresso_notices();
1330
+		}
1331
+		// the details template wrapper
1332
+		$this->display_admin_page_with_sidebar();
1333
+	}
1334
+
1335
+
1336
+	protected function _registration_details_metaboxes()
1337
+	{
1338
+		do_action('AHEE__Registrations_Admin_Page___registration_details_metabox__start', $this);
1339
+		$this->_set_registration_object();
1340
+		$attendee = $this->_registration instanceof EE_Registration ? $this->_registration->attendee() : null;
1341
+		add_meta_box('edit-reg-status-mbox', __('Registration Status', 'event_espresso'),
1342
+			array($this, 'set_reg_status_buttons_metabox'), $this->wp_page_slug, 'normal', 'high');
1343
+		add_meta_box('edit-reg-details-mbox', __('Registration Details', 'event_espresso'),
1344
+			array($this, '_reg_details_meta_box'), $this->wp_page_slug, 'normal', 'high');
1345
+		if ($attendee instanceof EE_Attendee
1346
+			&& EE_Registry::instance()->CAP->current_user_can('ee_edit_registration', 'edit-reg-questions-mbox')
1347
+		) {
1348
+			add_meta_box('edit-reg-questions-mbox', __('Registration Form Answers', 'event_espresso'),
1349
+				array($this, '_reg_questions_meta_box'), $this->wp_page_slug, 'normal', 'high');
1350
+		}
1351
+		add_meta_box('edit-reg-registrant-mbox', __('Contact Details', 'event_espresso'),
1352
+			array($this, '_reg_registrant_side_meta_box'), $this->wp_page_slug, 'side', 'high');
1353
+		if ($this->_registration->group_size() > 1) {
1354
+			add_meta_box('edit-reg-attendees-mbox', __('Other Registrations in this Transaction', 'event_espresso'),
1355
+				array($this, '_reg_attendees_meta_box'), $this->wp_page_slug, 'normal', 'high');
1356
+		}
1357
+	}
1358
+
1359
+
1360
+	/**
1361
+	 * set_reg_status_buttons_metabox
1362
+	 *
1363
+	 * @access protected
1364
+	 * @return string
1365
+	 * @throws \EE_Error
1366
+	 */
1367
+	public function set_reg_status_buttons_metabox()
1368
+	{
1369
+		$this->_set_registration_object();
1370
+		$change_reg_status_form = $this->_generate_reg_status_change_form();
1371
+		echo $change_reg_status_form->form_open(self::add_query_args_and_nonce(array(
1372
+			'action' => 'change_reg_status',
1373
+		), REG_ADMIN_URL));
1374
+		echo $change_reg_status_form->get_html();
1375
+		echo $change_reg_status_form->form_close();
1376
+	}
1377
+
1378
+
1379
+	/**
1380
+	 * @return EE_Form_Section_Proper
1381
+	 */
1382
+	protected function _generate_reg_status_change_form()
1383
+	{
1384
+		return new EE_Form_Section_Proper(array(
1385
+			'name'            => 'reg_status_change_form',
1386
+			'html_id'         => 'reg-status-change-form',
1387
+			'layout_strategy' => new EE_Admin_Two_Column_Layout(),
1388
+			'subsections'     => array(
1389
+				'return'             => new EE_Hidden_Input(array(
1390
+					'name'    => 'return',
1391
+					'default' => 'view_registration',
1392
+				)),
1393
+				'REG_ID'             => new EE_Hidden_Input(array(
1394
+					'name'    => 'REG_ID',
1395
+					'default' => $this->_registration->ID(),
1396
+				)),
1397
+				'current_status'     => new EE_Form_Section_HTML(EEH_HTML::tr(EEH_HTML::th(EEH_HTML::label(EEH_HTML::strong(__('Current Registration Status',
1398
+						'event_espresso')))) . EEH_HTML::td(EEH_HTML::strong($this->_registration->pretty_status(),
1399
+						'', 'status-' . $this->_registration->status_ID(),
1400
+						'line-height: 1em; font-size: 1.5em; font-weight: bold;')))),
1401
+				'reg_status'         => new EE_Select_Input($this->_get_reg_statuses(), array(
1402
+					'html_label_text' => __('Change Registration Status to', 'event_espresso'),
1403
+					'default'         => $this->_registration->status_ID(),
1404
+				)),
1405
+				'send_notifications' => new EE_Yes_No_Input(array(
1406
+					'html_label_text' => __('Send Related Messages', 'event_espresso'),
1407
+					'default'         => false,
1408
+					'html_help_text'  => __('If set to "Yes", then the related messages will be sent to the registrant.',
1409
+						'event_espresso'),
1410
+				)),
1411
+				'submit'             => new EE_Submit_Input(array(
1412
+					'html_class'      => 'button-primary',
1413
+					'html_label_text' => '&nbsp;',
1414
+					'default'         => __('Update Registration Status', 'event_espresso'),
1415
+				)),
1416
+			),
1417
+		));
1418
+	}
1419
+
1420
+
1421
+
1422
+	/**
1423
+	 * Returns an array of all the buttons for the various statuses and switch status actions
1424
+	 *
1425
+	 * @return array
1426
+	 */
1427
+	protected function _get_reg_statuses()
1428
+	{
1429
+		$reg_status_array = EEM_Registration::instance()->reg_status_array();
1430
+		unset ($reg_status_array[EEM_Registration::status_id_incomplete]);
1431
+		// get current reg status
1432
+		$current_status = $this->_registration->status_ID();
1433
+		// is registration for free event? This will determine whether to display the pending payment option
1434
+		if ($current_status != EEM_Registration::status_id_pending_payment
1435
+			&& $this->_registration->transaction()
1436
+								   ->is_free()
1437
+		) {
1438
+			unset($reg_status_array[EEM_Registration::status_id_pending_payment]);
1439
+		}
1440
+		return EEM_Status::instance()->localized_status($reg_status_array, false, 'sentence');
1441
+	}
1442
+
1443
+
1444
+	/**
1445
+	 * This method is used when using _REG_ID from request which may or may not be an array of reg_ids.
1446
+	 *
1447
+	 * @param bool $status REG status given for changing registrations to.
1448
+	 * @param bool $notify Whether to send messages notifications or not.
1449
+	 * @return array  (array with reg_id(s) updated and whether update was successful.
1450
+	 */
1451
+	protected function _set_registration_status_from_request($status = false, $notify = false)
1452
+	{
1453
+		if (isset($this->_req_data['reg_status_change_form'])) {
1454
+			$REG_IDs = isset($this->_req_data['reg_status_change_form']['REG_ID'])
1455
+				? (array)$this->_req_data['reg_status_change_form']['REG_ID'] : array();
1456
+		} else {
1457
+			$REG_IDs = isset($this->_req_data['_REG_ID']) ? (array)$this->_req_data['_REG_ID'] : array();
1458
+		}
1459
+		$success = $this->_set_registration_status($REG_IDs, $status);
1460
+		//notify?
1461
+		if ($success
1462
+			&& $notify
1463
+			&& EE_Registry::instance()->CAP->current_user_can('ee_send_message',
1464
+				'espresso_registrations_resend_registration')
1465
+		) {
1466
+			$this->_process_resend_registration();
1467
+		}
1468
+		return $success;
1469
+	}
1470
+
1471
+
1472
+	/**
1473
+	 * Set the registration status for the given reg_id (which may or may not be an array, it gets typecast to an
1474
+	 * array). Note, this method does NOT take care of possible notifications.  That is required by calling code.
1475
+	 *
1476
+	 * @param array $REG_IDs
1477
+	 * @param bool  $status
1478
+	 * @return array (an array with 'success' key representing whether status change was successful, and 'REG_ID' as
1479
+	 *               the array of updated registrations).
1480
+	 */
1481
+	protected function _set_registration_status($REG_IDs = array(), $status = false)
1482
+	{
1483
+		$success = false;
1484
+		// typecast $REG_IDs
1485
+		$REG_IDs = (array)$REG_IDs;
1486
+		if ( ! empty($REG_IDs)) {
1487
+			$success = true;
1488
+			// set default status if none is passed
1489
+			$status = $status ? $status : EEM_Registration::status_id_pending_payment;
1490
+			// sanitize $REG_IDs
1491
+			$REG_IDs = array_filter($REG_IDs, 'absint');
1492
+			//loop through REG_ID's and change status
1493
+			foreach ($REG_IDs as $REG_ID) {
1494
+				$registration = EEM_Registration::instance()->get_one_by_ID($REG_ID);
1495
+				if ($registration instanceof EE_Registration) {
1496
+					$registration->set_status($status);
1497
+					$result = $registration->save();
1498
+					// verifying explicit fails because update *may* just return 0 for 0 rows affected
1499
+					$success = $result !== false ? $success : false;
1500
+				}
1501
+			}
1502
+		}
1503
+		//reset _req_data['_REG_ID'] for any potential future messages notifications
1504
+		$this->_req_data['_REG_ID'] = $REG_IDs;
1505
+		//return $success and processed registrations
1506
+		return array('REG_ID' => $REG_IDs, 'success' => $success);
1507
+	}
1508
+
1509
+
1510
+	/**
1511
+	 * Common logic for setting up success message and redirecting to appropriate route
1512
+	 *
1513
+	 * @param  string $STS_ID status id for the registration changed to
1514
+	 * @param   bool  $notify indicates whether the _set_registration_status_from_request does notifications or not.
1515
+	 * @return void
1516
+	 */
1517
+	protected function _reg_status_change_return($STS_ID, $notify = false)
1518
+	{
1519
+		$result  = ! empty($STS_ID) ? $this->_set_registration_status_from_request($STS_ID, $notify)
1520
+			: array('success' => false);
1521
+		$success = isset($result['success']) && $result['success'];
1522
+		//setup success message
1523
+		if ($success) {
1524
+			if (is_array($result['REG_ID']) && count($result['REG_ID']) === 1) {
1525
+				$msg = sprintf(__('Registration status has been set to %s', 'event_espresso'),
1526
+					EEH_Template::pretty_status($STS_ID, false, 'lower'));
1527
+			} else {
1528
+				$msg = sprintf(__('Registrations have been set to %s.', 'event_espresso'),
1529
+					EEH_Template::pretty_status($STS_ID, false, 'lower'));
1530
+			}
1531
+			EE_Error::add_success($msg);
1532
+		} else {
1533
+			EE_Error::add_error(__('Something went wrong, and the status was not changed', 'event_espresso'), __FILE__,
1534
+				__LINE__, __FUNCTION__);
1535
+		}
1536
+		if (isset($this->_req_data['return']) && $this->_req_data['return'] == 'view_registration') {
1537
+			$route = array('action' => 'view_registration', '_REG_ID' => reset($result['REG_ID']));
1538
+		} else {
1539
+			$route = array('action' => 'default');
1540
+		}
1541
+		//unset nonces
1542
+		foreach ($this->_req_data as $ref => $value) {
1543
+			if (strpos($ref, 'nonce') !== false) {
1544
+				unset($this->_req_data[$ref]);
1545
+				continue;
1546
+			}
1547
+			$value                 = is_array($value) ? array_map('urlencode', $value) : urlencode($value);
1548
+			$this->_req_data[$ref] = $value;
1549
+		}
1550
+		//merge request vars so that the reloaded list table contains any existing filter query params
1551
+		$route = array_merge($this->_req_data, $route);
1552
+		$this->_redirect_after_action($success, '', '', $route, true);
1553
+	}
1554
+
1555
+
1556
+	/**
1557
+	 * incoming reg status change from reg details page.
1558
+	 *
1559
+	 * @return void
1560
+	 */
1561
+	protected function _change_reg_status()
1562
+	{
1563
+		$this->_req_data['return'] = 'view_registration';
1564
+		//set notify based on whether the send notifications toggle is set or not
1565
+		$notify = ! empty($this->_req_data['reg_status_change_form']['send_notifications']);
1566
+		//$notify = ! empty( $this->_req_data['txn_reg_status_change']['send_notifications'] );
1567
+		$this->_req_data['reg_status_change_form']['reg_status'] = isset($this->_req_data['reg_status_change_form']['reg_status'])
1568
+			? $this->_req_data['reg_status_change_form']['reg_status'] : '';
1569
+		switch ($this->_req_data['reg_status_change_form']['reg_status']) {
1570
+			case EEM_Registration::status_id_approved :
1571
+			case EEH_Template::pretty_status(EEM_Registration::status_id_approved, false, 'sentence') :
1572
+				$this->approve_registration($notify);
1573
+				break;
1574
+			case EEM_Registration::status_id_pending_payment :
1575
+			case EEH_Template::pretty_status(EEM_Registration::status_id_pending_payment, false, 'sentence') :
1576
+				$this->pending_registration($notify);
1577
+				break;
1578
+			case EEM_Registration::status_id_not_approved :
1579
+			case EEH_Template::pretty_status(EEM_Registration::status_id_not_approved, false, 'sentence') :
1580
+				$this->not_approve_registration($notify);
1581
+				break;
1582
+			case EEM_Registration::status_id_declined :
1583
+			case EEH_Template::pretty_status(EEM_Registration::status_id_declined, false, 'sentence') :
1584
+				$this->decline_registration($notify);
1585
+				break;
1586
+			case EEM_Registration::status_id_cancelled :
1587
+			case EEH_Template::pretty_status(EEM_Registration::status_id_cancelled, false, 'sentence') :
1588
+				$this->cancel_registration($notify);
1589
+				break;
1590
+			case EEM_Registration::status_id_wait_list :
1591
+			case EEH_Template::pretty_status(EEM_Registration::status_id_wait_list, false, 'sentence') :
1592
+				$this->waitlist_registration($notify);
1593
+				break;
1594
+			case EEM_Registration::status_id_incomplete :
1595
+			default :
1596
+				$result['success'] = false;
1597
+				unset($this->_req_data['return']);
1598
+				$this->_reg_status_change_return('', false);
1599
+				break;
1600
+		}
1601
+	}
1602
+
1603
+
1604
+	/**
1605
+	 * approve_registration
1606
+	 *
1607
+	 * @access protected
1608
+	 * @param bool $notify whether or not to notify the registrant about their approval.
1609
+	 * @return void
1610
+	 */
1611
+	protected function approve_registration($notify = false)
1612
+	{
1613
+		$this->_reg_status_change_return(EEM_Registration::status_id_approved, $notify);
1614
+	}
1615
+
1616
+
1617
+	/**
1618
+	 *        decline_registration
1619
+	 *
1620
+	 * @access protected
1621
+	 * @param bool $notify whether or not to notify the registrant about their status change.
1622
+	 * @return void
1623
+	 */
1624
+	protected function decline_registration($notify = false)
1625
+	{
1626
+		$this->_reg_status_change_return(EEM_Registration::status_id_declined, $notify);
1627
+	}
1628
+
1629
+
1630
+	/**
1631
+	 *        cancel_registration
1632
+	 *
1633
+	 * @access protected
1634
+	 * @param bool $notify whether or not to notify the registrant about their status change.
1635
+	 * @return void
1636
+	 */
1637
+	protected function cancel_registration($notify = false)
1638
+	{
1639
+		$this->_reg_status_change_return(EEM_Registration::status_id_cancelled, $notify);
1640
+	}
1641
+
1642
+
1643
+	/**
1644
+	 *        not_approve_registration
1645
+	 *
1646
+	 * @access protected
1647
+	 * @param bool $notify whether or not to notify the registrant about their status change.
1648
+	 * @return void
1649
+	 */
1650
+	protected function not_approve_registration($notify = false)
1651
+	{
1652
+		$this->_reg_status_change_return(EEM_Registration::status_id_not_approved, $notify);
1653
+	}
1654
+
1655
+
1656
+	/**
1657
+	 *        decline_registration
1658
+	 *
1659
+	 * @access protected
1660
+	 * @param bool $notify whether or not to notify the registrant about their status change.
1661
+	 * @return void
1662
+	 */
1663
+	protected function pending_registration($notify = false)
1664
+	{
1665
+		$this->_reg_status_change_return(EEM_Registration::status_id_pending_payment, $notify);
1666
+	}
1667
+
1668
+
1669
+	/**
1670
+	 * waitlist_registration
1671
+	 *
1672
+	 * @access protected
1673
+	 * @param bool $notify whether or not to notify the registrant about their status change.
1674
+	 * @return void
1675
+	 */
1676
+	protected function waitlist_registration($notify = false)
1677
+	{
1678
+		$this->_reg_status_change_return(EEM_Registration::status_id_wait_list, $notify);
1679
+	}
1680
+
1681
+
1682
+	/**
1683
+	 *        generates HTML for the Registration main meta box
1684
+	 *
1685
+	 * @access public
1686
+	 * @return void
1687
+	 */
1688
+	public function _reg_details_meta_box()
1689
+	{
1690
+		EEH_Autoloader::register_line_item_display_autoloaders();
1691
+		EEH_Autoloader::register_line_item_filter_autoloaders();
1692
+		EE_Registry::instance()->load_helper('Line_Item');
1693
+		$transaction    = $this->_registration->transaction() ? $this->_registration->transaction()
1694
+			: EE_Transaction::new_instance();
1695
+		$this->_session = $transaction->session_data();
1696
+		$filters        = new EE_Line_Item_Filter_Collection();
1697
+		//$filters->add( new EE_Non_Zero_Line_Item_Filter() );
1698
+		$filters->add(new EE_Single_Registration_Line_Item_Filter($this->_registration));
1699
+		$line_item_filter_processor              = new EE_Line_Item_Filter_Processor($filters,
1700
+			$transaction->total_line_item());
1701
+		$filtered_line_item_tree                 = $line_item_filter_processor->process();
1702
+		$line_item_display                       = new EE_Line_Item_Display('reg_admin_table',
1703
+			'EE_Admin_Table_Registration_Line_Item_Display_Strategy');
1704
+		$this->_template_args['line_item_table'] = $line_item_display->display_line_item($filtered_line_item_tree,
1705
+			array('EE_Registration' => $this->_registration));
1706
+		$attendee                                = $this->_registration->attendee();
1707
+		if (EE_Registry::instance()->CAP->current_user_can('ee_read_transaction',
1708
+			'espresso_transactions_view_transaction')
1709
+		) {
1710
+			$this->_template_args['view_transaction_button'] = EEH_Template::get_button_or_link(EE_Admin_Page::add_query_args_and_nonce(array(
1711
+				'action' => 'view_transaction',
1712
+				'TXN_ID' => $transaction->ID(),
1713
+			), TXN_ADMIN_URL), esc_html__(' View Transaction'), 'button secondary-button right',
1714
+				'dashicons dashicons-cart');
1715
+		} else {
1716
+			$this->_template_args['view_transaction_button'] = '';
1717
+		}
1718
+		if ($attendee instanceof EE_Attendee
1719
+			&& EE_Registry::instance()->CAP->current_user_can('ee_send_message',
1720
+				'espresso_registrations_resend_registration')
1721
+		) {
1722
+			$this->_template_args['resend_registration_button'] = EEH_Template::get_button_or_link(EE_Admin_Page::add_query_args_and_nonce(array(
1723
+				'action'      => 'resend_registration',
1724
+				'_REG_ID'     => $this->_registration->ID(),
1725
+				'redirect_to' => 'view_registration',
1726
+			), REG_ADMIN_URL), esc_html__(' Resend Registration'), 'button secondary-button right',
1727
+				'dashicons dashicons-email-alt');
1728
+		} else {
1729
+			$this->_template_args['resend_registration_button'] = '';
1730
+		}
1731
+		$this->_template_args['currency_sign'] = EE_Registry::instance()->CFG->currency->sign;
1732
+		$payment                               = $transaction->get_first_related('Payment');
1733
+		$payment                               = ! $payment instanceof EE_Payment ? EE_Payment::new_instance() : $payment;
1734
+		$payment_method                        = $payment->get_first_related('Payment_Method');
1735
+		$payment_method                        = ! $payment_method instanceof EE_Payment_Method ? EE_Payment_Method::new_instance()
1736
+			: $payment_method;
1737
+		$reg_details                           = array(
1738
+			'payment_method'       => $payment_method->name(),
1739
+			'response_msg'         => $payment->gateway_response(),
1740
+			'registration_id'      => $this->_registration->get('REG_code'),
1741
+			'registration_session' => $this->_registration->session_ID(),
1742
+			'ip_address'           => isset($this->_session['ip_address']) ? $this->_session['ip_address'] : '',
1743
+			'user_agent'           => isset($this->_session['user_agent']) ? $this->_session['user_agent'] : '',
1744
+		);
1745
+		if (isset($reg_details['registration_id'])) {
1746
+			$this->_template_args['reg_details']['registration_id']['value'] = $reg_details['registration_id'];
1747
+			$this->_template_args['reg_details']['registration_id']['label'] = __('Registration ID', 'event_espresso');
1748
+			$this->_template_args['reg_details']['registration_id']['class'] = 'regular-text';
1749
+		}
1750
+		if (isset($reg_details['payment_method'])) {
1751
+			$this->_template_args['reg_details']['payment_method']['value'] = $reg_details['payment_method'];
1752
+			$this->_template_args['reg_details']['payment_method']['label'] = __('Most Recent Payment Method',
1753
+				'event_espresso');
1754
+			$this->_template_args['reg_details']['payment_method']['class'] = 'regular-text';
1755
+			$this->_template_args['reg_details']['response_msg']['value']   = $reg_details['response_msg'];
1756
+			$this->_template_args['reg_details']['response_msg']['label']   = __('Payment method response',
1757
+				'event_espresso');
1758
+			$this->_template_args['reg_details']['response_msg']['class']   = 'regular-text';
1759
+		}
1760
+		$this->_template_args['reg_details']['registration_session']['value'] = $reg_details['registration_session'];
1761
+		$this->_template_args['reg_details']['registration_session']['label'] = __('Registration Session',
1762
+			'event_espresso');
1763
+		$this->_template_args['reg_details']['registration_session']['class'] = 'regular-text';
1764
+		$this->_template_args['reg_details']['ip_address']['value']           = $reg_details['ip_address'];
1765
+		$this->_template_args['reg_details']['ip_address']['label']           = __('Registration placed from IP',
1766
+			'event_espresso');
1767
+		$this->_template_args['reg_details']['ip_address']['class']           = 'regular-text';
1768
+		$this->_template_args['reg_details']['user_agent']['value']           = $reg_details['user_agent'];
1769
+		$this->_template_args['reg_details']['user_agent']['label']           = __('Registrant User Agent',
1770
+			'event_espresso');
1771
+		$this->_template_args['reg_details']['user_agent']['class']           = 'large-text';
1772
+		$this->_template_args['event_link']                                   = EE_Admin_Page::add_query_args_and_nonce(array(
1773
+			'action'   => 'default',
1774
+			'event_id' => $this->_registration->event_ID(),
1775
+		), REG_ADMIN_URL);
1776
+		$this->_template_args['REG_ID']                                       = $this->_registration->ID();
1777
+		$this->_template_args['event_id']                                     = $this->_registration->event_ID();
1778
+		$template_path                                                        = REG_TEMPLATE_PATH . 'reg_admin_details_main_meta_box_reg_details.template.php';
1779
+		echo EEH_Template::display_template($template_path, $this->_template_args, true);
1780
+	}
1781
+
1782
+
1783
+	/**
1784
+	 * generates HTML for the Registration Questions meta box.
1785
+	 * If pre-4.8.32.rc.000 hooks are used, uses old methods (with its filters),
1786
+	 * otherwise uses new forms system
1787
+	 *
1788
+	 * @access public
1789
+	 * @return void
1790
+	 */
1791
+	public function _reg_questions_meta_box()
1792
+	{
1793
+		//allow someone to override this method entirely
1794
+		if (apply_filters('FHEE__Registrations_Admin_Page___reg_questions_meta_box__do_default', true, $this,
1795
+			$this->_registration)) {
1796
+			$form                                              = $this->_get_reg_custom_questions_form($this->_registration->ID());
1797
+			$this->_template_args['att_questions']             = count($form->subforms()) > 0 ? $form->get_html_and_js() : '';
1798
+			$this->_template_args['reg_questions_form_action'] = 'edit_registration';
1799
+			$this->_template_args['REG_ID']                    = $this->_registration->ID();
1800
+			$template_path                                     = REG_TEMPLATE_PATH . 'reg_admin_details_main_meta_box_reg_questions.template.php';
1801
+			echo EEH_Template::display_template($template_path, $this->_template_args, true);
1802
+		}
1803
+	}
1804
+
1805
+
1806
+	/**
1807
+	 * form_before_question_group
1808
+	 *
1809
+	 * @deprecated    as of 4.8.32.rc.000
1810
+	 * @access        public
1811
+	 * @param        string $output
1812
+	 * @return        string
1813
+	 */
1814
+	public function form_before_question_group($output)
1815
+	{
1816
+		EE_Error::doing_it_wrong(__CLASS__ . '::' . __FUNCTION__,
1817
+			__('This method would have been protected but was used on a filter callback'
1818
+			   . 'so needed to be public. Please discontinue usage as it will be removed soon.', 'event_espresso'),
1819
+			'4.8.32.rc.000');
1820
+		return '
1821 1821
 	<table class="form-table ee-width-100">
1822 1822
 		<tbody>
1823 1823
 			';
1824
-    }
1825
-
1826
-
1827
-    /**
1828
-     * form_after_question_group
1829
-     *
1830
-     * @deprecated    as of 4.8.32.rc.000
1831
-     * @access        public
1832
-     * @param        string $output
1833
-     * @return        string
1834
-     */
1835
-    public function form_after_question_group($output)
1836
-    {
1837
-        EE_Error::doing_it_wrong(__CLASS__ . '::' . __FUNCTION__,
1838
-            __('This method would have been protected but was used on a filter callback'
1839
-               . 'so needed to be public. Please discontinue usage as it will be removed soon.', 'event_espresso'),
1840
-            '4.8.32.rc.000');
1841
-        return '
1824
+	}
1825
+
1826
+
1827
+	/**
1828
+	 * form_after_question_group
1829
+	 *
1830
+	 * @deprecated    as of 4.8.32.rc.000
1831
+	 * @access        public
1832
+	 * @param        string $output
1833
+	 * @return        string
1834
+	 */
1835
+	public function form_after_question_group($output)
1836
+	{
1837
+		EE_Error::doing_it_wrong(__CLASS__ . '::' . __FUNCTION__,
1838
+			__('This method would have been protected but was used on a filter callback'
1839
+			   . 'so needed to be public. Please discontinue usage as it will be removed soon.', 'event_espresso'),
1840
+			'4.8.32.rc.000');
1841
+		return '
1842 1842
 			<tr class="hide-if-no-js">
1843 1843
 				<th> </th>
1844 1844
 				<td class="reg-admin-edit-attendee-question-td">
1845 1845
 					<a class="reg-admin-edit-attendee-question-lnk" href="#" title="'
1846
-               . esc_attr__('click to edit question', 'event_espresso')
1847
-               . '">
1846
+			   . esc_attr__('click to edit question', 'event_espresso')
1847
+			   . '">
1848 1848
 						<span class="reg-admin-edit-question-group-spn lt-grey-txt">'
1849
-               . __('edit the above question group', 'event_espresso')
1850
-               . '</span>
1849
+			   . __('edit the above question group', 'event_espresso')
1850
+			   . '</span>
1851 1851
 						<div class="dashicons dashicons-edit"></div>
1852 1852
 					</a>
1853 1853
 				</td>
@@ -1855,495 +1855,495 @@  discard block
 block discarded – undo
1855 1855
 		</tbody>
1856 1856
 	</table>
1857 1857
 ';
1858
-    }
1859
-
1860
-
1861
-    /**
1862
-     * form_form_field_label_wrap
1863
-     *
1864
-     * @deprecated    as of 4.8.32.rc.000
1865
-     * @access        public
1866
-     * @param        string $label
1867
-     * @return        string
1868
-     */
1869
-    public function form_form_field_label_wrap($label)
1870
-    {
1871
-        EE_Error::doing_it_wrong(__CLASS__ . '::' . __FUNCTION__,
1872
-            __('This method would have been protected but was used on a filter callback'
1873
-               . 'so needed to be public. Please discontinue usage as it will be removed soon.', 'event_espresso'),
1874
-            '4.8.32.rc.000');
1875
-        return '
1858
+	}
1859
+
1860
+
1861
+	/**
1862
+	 * form_form_field_label_wrap
1863
+	 *
1864
+	 * @deprecated    as of 4.8.32.rc.000
1865
+	 * @access        public
1866
+	 * @param        string $label
1867
+	 * @return        string
1868
+	 */
1869
+	public function form_form_field_label_wrap($label)
1870
+	{
1871
+		EE_Error::doing_it_wrong(__CLASS__ . '::' . __FUNCTION__,
1872
+			__('This method would have been protected but was used on a filter callback'
1873
+			   . 'so needed to be public. Please discontinue usage as it will be removed soon.', 'event_espresso'),
1874
+			'4.8.32.rc.000');
1875
+		return '
1876 1876
 			<tr>
1877 1877
 				<th>
1878 1878
 					' . $label . '
1879 1879
 				</th>';
1880
-    }
1881
-
1882
-
1883
-    /**
1884
-     * form_form_field_input__wrap
1885
-     *
1886
-     * @deprecated    as of 4.8.32.rc.000
1887
-     * @access        public
1888
-     * @param        string $input
1889
-     * @return        string
1890
-     */
1891
-    public function form_form_field_input__wrap($input)
1892
-    {
1893
-        EE_Error::doing_it_wrong(__CLASS__ . '::' . __FUNCTION__,
1894
-            __('This method would have been protected but was used on a filter callback'
1895
-               . 'so needed to be public. Please discontinue usage as it will be removed soon.', 'event_espresso'),
1896
-            '4.8.32.rc.000');
1897
-        return '
1880
+	}
1881
+
1882
+
1883
+	/**
1884
+	 * form_form_field_input__wrap
1885
+	 *
1886
+	 * @deprecated    as of 4.8.32.rc.000
1887
+	 * @access        public
1888
+	 * @param        string $input
1889
+	 * @return        string
1890
+	 */
1891
+	public function form_form_field_input__wrap($input)
1892
+	{
1893
+		EE_Error::doing_it_wrong(__CLASS__ . '::' . __FUNCTION__,
1894
+			__('This method would have been protected but was used on a filter callback'
1895
+			   . 'so needed to be public. Please discontinue usage as it will be removed soon.', 'event_espresso'),
1896
+			'4.8.32.rc.000');
1897
+		return '
1898 1898
 				<td class="reg-admin-attendee-questions-input-td disabled-input">
1899 1899
 					' . $input . '
1900 1900
 				</td>
1901 1901
 			</tr>';
1902
-    }
1903
-
1904
-
1905
-    /**
1906
-     * Updates the registration's custom questions according to the form info, if the form is submitted.
1907
-     * If it's not a post, the "view_registrations" route will be called next on the SAME request
1908
-     * to display the page
1909
-     *
1910
-     * @access protected
1911
-     * @return void
1912
-     */
1913
-    protected function _update_attendee_registration_form()
1914
-    {
1915
-        do_action('AHEE__Registrations_Admin_Page___update_attendee_registration_form__start', $this);
1916
-        if ($_SERVER['REQUEST_METHOD'] == 'POST') {
1917
-            $REG_ID  = isset($this->_req_data['_REG_ID']) ? absint($this->_req_data['_REG_ID']) : false;
1918
-            $success = $this->_save_reg_custom_questions_form($REG_ID);
1919
-            if ($success) {
1920
-                $what  = __('Registration Form', 'event_espresso');
1921
-                $route = $REG_ID ? array('action' => 'view_registration', '_REG_ID' => $REG_ID)
1922
-                    : array('action' => 'default');
1923
-                $this->_redirect_after_action($success, $what, __('updated', 'event_espresso'), $route);
1924
-            }
1925
-        }
1926
-    }
1927
-
1928
-
1929
-    /**
1930
-     * Gets the form for saving registrations custom questions (if done
1931
-     * previously retrieves the cached form object, which may have validation errors in it)
1932
-     *
1933
-     * @param int $REG_ID
1934
-     * @return EE_Registration_Custom_Questions_Form
1935
-     */
1936
-    protected function _get_reg_custom_questions_form($REG_ID)
1937
-    {
1938
-        if ( ! $this->_reg_custom_questions_form) {
1939
-            require_once(REG_ADMIN . 'form_sections' . DS . 'EE_Registration_Custom_Questions_Form.form.php');
1940
-            $this->_reg_custom_questions_form = new EE_Registration_Custom_Questions_Form(
1941
-                EEM_Registration::instance()->get_one_by_ID($REG_ID)
1942
-            );
1943
-            $this->_reg_custom_questions_form->_construct_finalize(null, null);
1944
-        }
1945
-        return $this->_reg_custom_questions_form;
1946
-    }
1947
-
1948
-
1949
-    /**
1950
-     * Saves
1951
-     *
1952
-     * @access private
1953
-     * @param bool $REG_ID
1954
-     * @return bool
1955
-     */
1956
-    private function _save_reg_custom_questions_form($REG_ID = false)
1957
-    {
1958
-        if ( ! $REG_ID) {
1959
-            EE_Error::add_error(__('An error occurred. No registration ID was received.', 'event_espresso'), __FILE__,
1960
-                __FUNCTION__, __LINE__);
1961
-        }
1962
-        $form = $this->_get_reg_custom_questions_form($REG_ID);
1963
-        $form->receive_form_submission($this->_req_data);
1964
-        $success = false;
1965
-        if ($form->is_valid()) {
1966
-            foreach ($form->subforms() as $question_group_id => $question_group_form) {
1967
-                foreach ($question_group_form->inputs() as $question_id => $input) {
1968
-                    $where_conditions    = array(
1969
-                        'QST_ID' => $question_id,
1970
-                        'REG_ID' => $REG_ID,
1971
-                    );
1972
-                    $possibly_new_values = array(
1973
-                        'ANS_value' => $input->normalized_value(),
1974
-                    );
1975
-                    $answer              = EEM_Answer::instance()->get_one(array($where_conditions));
1976
-                    if ($answer instanceof EE_Answer) {
1977
-                        $success = $answer->save($possibly_new_values);
1978
-                    } else {
1979
-                        //insert it then
1980
-                        $cols_n_vals = array_merge($where_conditions, $possibly_new_values);
1981
-                        $answer      = EE_Answer::new_instance($cols_n_vals);
1982
-                        $success     = $answer->save();
1983
-                    }
1984
-                }
1985
-            }
1986
-        } else {
1987
-            EE_Error::add_error($form->get_validation_error_string(), __FILE__, __FUNCTION__, __LINE__);
1988
-        }
1989
-        return $success;
1990
-    }
1991
-
1992
-
1993
-    /**
1994
-     *        generates HTML for the Registration main meta box
1995
-     *
1996
-     * @access public
1997
-     * @return void
1998
-     */
1999
-    public function _reg_attendees_meta_box()
2000
-    {
2001
-        $REG = EEM_Registration::instance();
2002
-        //get all other registrations on this transaction, and cache
2003
-        //the attendees for them so we don't have to run another query using force_join
2004
-        $registrations                           = $REG->get_all(array(
2005
-            array(
2006
-                'TXN_ID' => $this->_registration->transaction_ID(),
2007
-                'REG_ID' => array('!=', $this->_registration->ID()),
2008
-            ),
2009
-            'force_join' => array('Attendee'),
2010
-        ));
2011
-        $this->_template_args['attendees']       = array();
2012
-        $this->_template_args['attendee_notice'] = '';
2013
-        if (empty($registrations)
2014
-            || (is_array($registrations)
2015
-                && ! EEH_Array::get_one_item_from_array($registrations))
2016
-        ) {
2017
-            EE_Error::add_error(__('There are no records attached to this registration. Something may have gone wrong with the registration',
2018
-                'event_espresso'), __FILE__, __FUNCTION__, __LINE__);
2019
-            $this->_template_args['attendee_notice'] = EE_Error::get_notices();
2020
-        } else {
2021
-            $att_nmbr = 1;
2022
-            foreach ($registrations as $registration) {
2023
-                /* @var $registration EE_Registration */
2024
-                $attendee                                                    = $registration->attendee()
2025
-                    ? $registration->attendee()
2026
-                    : EEM_Attendee::instance()
2027
-                                  ->create_default_object();
2028
-                $this->_template_args['attendees'][$att_nmbr]['STS_ID']      = $registration->status_ID();
2029
-                $this->_template_args['attendees'][$att_nmbr]['fname']       = $attendee->fname();//( isset( $registration->ATT_fname ) & ! empty( $registration->ATT_fname ) ) ? $registration->ATT_fname : '';
2030
-                $this->_template_args['attendees'][$att_nmbr]['lname']       = $attendee->lname();//( isset( $registration->ATT_lname ) & ! empty( $registration->ATT_lname ) ) ? $registration->ATT_lname : '';
2031
-                $this->_template_args['attendees'][$att_nmbr]['email']       = $attendee->email();//( isset( $registration->ATT_email ) & ! empty( $registration->ATT_email ) ) ? $registration->ATT_email : '';
2032
-                $this->_template_args['attendees'][$att_nmbr]['final_price'] = $registration->final_price();//( isset( $registration->REG_final_price ) & ! empty( $registration->REG_final_price ) ) ? $registration->REG_final_price : '';
2033
-                $this->_template_args['attendees'][$att_nmbr]['address']     = implode(', ',
2034
-                    $attendee->full_address_as_array());
2035
-                $this->_template_args['attendees'][$att_nmbr]['att_link']    = self::add_query_args_and_nonce(array(
2036
-                    'action' => 'edit_attendee',
2037
-                    'post'   => $attendee->ID(),
2038
-                ), REG_ADMIN_URL);
2039
-                $this->_template_args['attendees'][$att_nmbr]['event_name']  = $registration->event_obj()->name();
2040
-                $att_nmbr++;
2041
-            }
2042
-            //EEH_Debug_Tools::printr( $attendees, '$attendees  <br /><span style="font-size:10px;font-weight:normal;">( file: '. __FILE__ . ' - line no: ' . __LINE__ . ' )</span>', 'auto' );
2043
-            $this->_template_args['currency_sign'] = EE_Registry::instance()->CFG->currency->sign;
2044
-            //			$this->_template_args['registration_form_url'] = add_query_arg( array( 'action' => 'edit_registration', 'process' => 'attendees'  ), REG_ADMIN_URL );
2045
-        }
2046
-        $template_path = REG_TEMPLATE_PATH . 'reg_admin_details_main_meta_box_attendees.template.php';
2047
-        echo EEH_Template::display_template($template_path, $this->_template_args, true);
2048
-    }
2049
-
2050
-
2051
-    /**
2052
-     *        generates HTML for the Edit Registration side meta box
2053
-     *
2054
-     * @access public
2055
-     * @return void
2056
-     */
2057
-    public function _reg_registrant_side_meta_box()
2058
-    {
2059
-        /*@var $attendee EE_Attendee */
2060
-        $att_check = $this->_registration->attendee();
2061
-        $attendee  = $att_check instanceof EE_Attendee ? $att_check : EEM_Attendee::instance()->create_default_object();
2062
-        //now let's determine if this is not the primary registration.  If it isn't then we set the primary_registration object for reference BUT ONLY if the Attendee object loaded is not the same as the primary registration object (that way we know if we need to show create button or not)
2063
-        if ( ! $this->_registration->is_primary_registrant()) {
2064
-            $primary_registration = $this->_registration->get_primary_registration();
2065
-            $primary_attendee     = $primary_registration instanceof EE_Registration ? $primary_registration->attendee()
2066
-                : null;
2067
-            if ( ! $primary_attendee instanceof EE_Attendee || $attendee->ID() !== $primary_attendee->ID()) {
2068
-                //in here?  This means the displayed registration is not the primary registrant but ALREADY HAS its own custom attendee object so let's not worry about the primary reg.
2069
-                $primary_registration = null;
2070
-            }
2071
-        } else {
2072
-            $primary_registration = null;
2073
-        }
2074
-        $this->_template_args['ATT_ID']            = $attendee->ID();
2075
-        $this->_template_args['fname']             = $attendee->fname();//$this->_registration->ATT_fname;
2076
-        $this->_template_args['lname']             = $attendee->lname();//$this->_registration->ATT_lname;
2077
-        $this->_template_args['email']             = $attendee->email();//$this->_registration->ATT_email;
2078
-        $this->_template_args['phone']             = $attendee->phone();
2079
-        $this->_template_args['formatted_address'] = EEH_Address::format($attendee);
2080
-        //edit link
2081
-        $this->_template_args['att_edit_link']  = EE_Admin_Page::add_query_args_and_nonce(array(
2082
-            'action' => 'edit_attendee',
2083
-            'post'   => $attendee->ID(),
2084
-        ), REG_ADMIN_URL);
2085
-        $this->_template_args['att_edit_label'] = __('View/Edit Contact', 'event_espresso');
2086
-        //create link
2087
-        $this->_template_args['create_link']  = $primary_registration instanceof EE_Registration
2088
-            ? EE_Admin_Page::add_query_args_and_nonce(array(
2089
-                'action'  => 'duplicate_attendee',
2090
-                '_REG_ID' => $this->_registration->ID(),
2091
-            ), REG_ADMIN_URL) : '';
2092
-        $this->_template_args['create_label'] = __('Create Contact', 'event_espresso');
2093
-        $this->_template_args['att_check']    = $att_check;
2094
-        $template_path                        = REG_TEMPLATE_PATH . 'reg_admin_details_side_meta_box_registrant.template.php';
2095
-        echo EEH_Template::display_template($template_path, $this->_template_args, true);
2096
-    }
2097
-
2098
-
2099
-    /**
2100
-     * trash or restore registrations
2101
-     *
2102
-     * @param  boolean $trash whether to archive or restore
2103
-     * @access protected
2104
-     * @return void
2105
-     */
2106
-    protected function _trash_or_restore_registrations($trash = true)
2107
-    {
2108
-        $REGM    = EEM_Registration::instance();
2109
-        $success = 1;
2110
-        $error   = 0;
2111
-        $tickets = array();
2112
-        $dtts    = array();
2113
-        //if empty _REG_ID then get out because there's nothing to do
2114
-        if (empty($this->_req_data['_REG_ID'])) {
2115
-            $msg = $trash
2116
-                ? __('In order to trash registrations you must select which ones you wish to trash by clicking the checkboxes.',
2117
-                    'event_espresso')
2118
-                : __('In order to restore registrations you must select which ones you wish to restore by clicking the checkboxes.',
2119
-                    'event_espresso');
2120
-            EE_Error::add_error($msg, __FILE__, __LINE__, __FUNCTION__);
2121
-            $this->_redirect_after_action(false, '', '', array(), true);
2122
-        }
2123
-        //Checkboxes
2124
-        if ( ! empty($this->_req_data['_REG_ID']) && is_array($this->_req_data['_REG_ID'])) {
2125
-            // if array has more than one element than success message should be plural
2126
-            $success = count($this->_req_data['_REG_ID']) > 1 ? 2 : 1;
2127
-            // cycle thru checkboxes
2128
-            while (list($ind, $REG_ID) = each($this->_req_data['_REG_ID'])) {
2129
-                /** @var EE_Registration $REG */
2130
-                $REG           = $REGM->get_one_by_ID($REG_ID);
2131
-                $payment_count = $REG->get_first_related('Transaction')->count_related('Payment');
2132
-                if ($payment_count > 0) {
2133
-                    $name    = $REG->attendee() instanceof EE_Attendee ? $REG->attendee()->full_name()
2134
-                        : __('Unknown Attendee', 'event_espresso');
2135
-                    $error   = 1;
2136
-                    $success = 0;
2137
-                    EE_Error::add_error(sprintf(__('The registration for %s could not be trashed because it has payments attached to the related transaction.  If you wish to trash this registration you must first delete the payments on the related transaction.',
2138
-                        'event_espresso'), $name), __FILE__, __FUNCTION__, __LINE__);
2139
-                    continue; //can't trash this registration because it has payments.
2140
-                }
2141
-                $ticket                 = $REG->get_first_related('Ticket');
2142
-                $tickets[$ticket->ID()] = $ticket;
2143
-                $dtt                    = $ticket->get_many_related('Datetime');
2144
-                $dtts                   = array_merge($dtts, $dtt);
2145
-                $updated                = $trash ? $REG->delete() : $REG->restore();
2146
-                if ( ! $updated) {
2147
-                    $success = 0;
2148
-                } else {
2149
-                    $success = 2;
2150
-                }/**/
2151
-            }
2152
-        } else {
2153
-            // grab single id and delete
2154
-            $REG_ID                 = absint($this->_req_data['_REG_ID']);
2155
-            $REG                    = $REGM->get_one_by_ID($REG_ID);
2156
-            $ticket                 = $REG->get_first_related('Ticket');
2157
-            $tickets[$ticket->ID()] = $ticket;
2158
-            $dtts                   = $ticket->get_many_related('Datetime');
2159
-            $updated                = $trash ? $REG->delete() : $REG->restore();
2160
-            if ( ! $updated) {
2161
-                $success = 0;
2162
-            }
2163
-        }
2164
-        //now let's update counts
2165
-        EEM_Ticket::instance()->update_tickets_sold($tickets);
2166
-        EEM_Datetime::instance()->update_sold($dtts);
2167
-        $what           = $success > 1 ? __('Registrations', 'event_espresso') : __('Registration', 'event_espresso');
2168
-        $action_desc    = $trash ? __('moved to the trash', 'event_espresso') : __('restored', 'event_espresso');
2169
-        $overwrite_msgs = $error ? true : false;
2170
-        $this->_redirect_after_action($success, $what, $action_desc, array('action' => 'default'), $overwrite_msgs);
2171
-    }
2172
-
2173
-
2174
-    /**
2175
-     * This is used to permanently delete registrations.  Note, this will handle not only deleting permanently the
2176
-     * registration but also.
2177
-     * 1. Removing relations to EE_Attendee
2178
-     * 2. Deleting permanently the related transaction, but ONLY if all related registrations to the transaction are
2179
-     * ALSO trashed.
2180
-     * 3. Deleting permanently any related Line items but only if the above conditions are met.
2181
-     * 4. Removing relationships between all tickets and the related registrations
2182
-     * 5. Deleting permanently any related Answers (and the answers for other related registrations that were deleted.)
2183
-     * 6. Deleting permanently any related Checkins.
2184
-     *
2185
-     * @return void
2186
-     */
2187
-    protected function _delete_registrations()
2188
-    {
2189
-        $REG_MDL = EEM_Registration::instance();
2190
-        $success = 1;
2191
-        //Checkboxes
2192
-        if ( ! empty($this->_req_data['_REG_ID']) && is_array($this->_req_data['_REG_ID'])) {
2193
-            // if array has more than one element than success message should be plural
2194
-            $success = count($this->_req_data['_REG_ID']) > 1 ? 2 : 1;
2195
-            // cycle thru checkboxes
2196
-            while (list($ind, $REG_ID) = each($this->_req_data['_REG_ID'])) {
2197
-                $REG = $REG_MDL->get_one_by_ID($REG_ID);
2198
-                if ( ! $REG instanceof EE_Registration) {
2199
-                    continue;
2200
-                }
2201
-                $deleted = $this->_delete_registration($REG);
2202
-                if ( ! $deleted) {
2203
-                    $success = 0;
2204
-                }
2205
-            }
2206
-        } else {
2207
-            // grab single id and delete
2208
-            $REG_ID  = $this->_req_data['_REG_ID'];
2209
-            $REG     = $REG_MDL->get_one_by_ID($REG_ID);
2210
-            $deleted = $this->_delete_registration($REG);
2211
-            if ( ! $deleted) {
2212
-                $success = 0;
2213
-            }
2214
-        }
2215
-        $what        = $success > 1 ? __('Registrations', 'event_espresso') : __('Registration', 'event_espresso');
2216
-        $action_desc = __('permanently deleted.', 'event_espresso');
2217
-        $this->_redirect_after_action($success, $what, $action_desc, array('action' => 'default'), true);
2218
-    }
2219
-
2220
-
2221
-    /**
2222
-     * handles the permanent deletion of a registration.  See comments with _delete_registrations() for details on what
2223
-     * models get affected.
2224
-     *
2225
-     * @param  EE_Registration $REG registration to be deleted permenantly
2226
-     * @return boolean              true = successful deletion, false = fail.
2227
-     */
2228
-    protected function _delete_registration(EE_Registration $REG)
2229
-    {
2230
-        //first we start with the transaction... ultimately, we WILL not delete permanently if there are any related registrations on the transaction that are NOT trashed.
2231
-        $TXN         = $REG->get_first_related('Transaction');
2232
-        $REGS        = $TXN->get_many_related('Registration');
2233
-        $all_trashed = true;
2234
-        foreach ($REGS as $registration) {
2235
-            if ( ! $registration->get('REG_deleted')) {
2236
-                $all_trashed = false;
2237
-            }
2238
-        }
2239
-        if ( ! $all_trashed) {
2240
-            EE_Error::add_error(__('Unable to permanently delete this registration. Before this registration can be permanently deleted, all registrations made in the same transaction must be trashed as well.  These registrations will be permanently deleted in the same action.',
2241
-                'event_espresso'), __FILE__, __FUNCTION__, __LINE__);
2242
-            return false;
2243
-        }
2244
-        //k made it here so that means we can delete all the related transactions and their answers (but let's do them separately from THIS one).
2245
-        foreach ($REGS as $registration) {
2246
-            //delete related answers
2247
-            $registration->delete_related_permanently('Answer');
2248
-            //remove relationship to EE_Attendee (but we ALWAYS leave the contact record intact)
2249
-            $attendee = $registration->get_first_related('Attendee');
2250
-            if ($attendee instanceof EE_Attendee) {
2251
-                $registration->_remove_relation_to($attendee, 'Attendee');
2252
-            }
2253
-            //now remove relationships to tickets on this registration.
2254
-            $registration->_remove_relations('Ticket');
2255
-            //now delete permanently the checkins related to this registration.
2256
-            $registration->delete_related_permanently('Checkin');
2257
-            if ($registration->ID() === $REG->ID()) {
2258
-                continue;
2259
-            } //we don't want to delete permanently the existing registration just yet.
2260
-            //remove relation to transaction for these registrations if NOT the existing registrations
2261
-            $registration->_remove_relations('Transaction');
2262
-            //delete permanently any related messages.
2263
-            $registration->delete_related_permanently('Message');
2264
-            //now delete this registration permanently
2265
-            $registration->delete_permanently();
2266
-        }
2267
-        //now all related registrations on the transaction are handled.  So let's just handle this registration itself (the transaction and line items should be all that's left).
2268
-        //delete the line items related to the transaction for this registration.
2269
-        $TXN->delete_related_permanently('Line_Item');
2270
-        //we need to remove all the relationships on the transaction
2271
-        $TXN->delete_related_permanently('Payment');
2272
-        $TXN->delete_related_permanently('Extra_Meta');
2273
-        $TXN->delete_related_permanently('Message');
2274
-        //now we can delete this REG permanently (and the transaction of course)
2275
-        $REG->delete_related_permanently('Transaction');
2276
-        return $REG->delete_permanently();
2277
-    }
2278
-
2279
-
2280
-    /**
2281
-     *    generates HTML for the Register New Attendee Admin page
2282
-     *
2283
-     * @access private
2284
-     * @throws \EE_Error
2285
-     * @return void
2286
-     */
2287
-    public function new_registration()
2288
-    {
2289
-        if ( ! $this->_set_reg_event()) {
2290
-            throw new EE_Error(__('Unable to continue with registering because there is no Event ID in the request',
2291
-                'event_espresso'));
2292
-        }
2293
-        EE_Registry::instance()->REQ->set_espresso_page(true);
2294
-        // gotta start with a clean slate if we're not coming here via ajax
2295
-        if ( ! defined('DOING_AJAX')
2296
-             && ( ! isset($this->_req_data['processing_registration']) || isset($this->_req_data['step_error']))
2297
-        ) {
2298
-            EE_Registry::instance()->SSN->clear_session(__CLASS__, __FUNCTION__);
2299
-        }
2300
-        $this->_template_args['event_name'] = '';
2301
-        // event name
2302
-        if ($this->_reg_event) {
2303
-            $this->_template_args['event_name'] = $this->_reg_event->name();
2304
-            $edit_event_url                     = self::add_query_args_and_nonce(array(
2305
-                'action' => 'edit',
2306
-                'post'   => $this->_reg_event->ID(),
2307
-            ), EVENTS_ADMIN_URL);
2308
-            $edit_event_lnk                     = '<a href="'
2309
-                                                  . $edit_event_url
2310
-                                                  . '" title="'
2311
-                                                  . esc_attr__('Edit ', 'event_espresso')
2312
-                                                  . $this->_reg_event->name()
2313
-                                                  . '">'
2314
-                                                  . __('Edit Event', 'event_espresso')
2315
-                                                  . '</a>';
2316
-            $this->_template_args['event_name'] .= ' <span class="admin-page-header-edit-lnk not-bold">'
2317
-                                                   . $edit_event_lnk
2318
-                                                   . '</span>';
2319
-        }
2320
-        $this->_template_args['step_content'] = $this->_get_registration_step_content();
2321
-        if (defined('DOING_AJAX')) {
2322
-            $this->_return_json();
2323
-        }
2324
-        // grab header
2325
-        $template_path                              = REG_TEMPLATE_PATH . 'reg_admin_register_new_attendee.template.php';
2326
-        $this->_template_args['admin_page_content'] = EEH_Template::display_template($template_path,
2327
-            $this->_template_args, true);
2328
-        //$this->_set_publish_post_box_vars( NULL, FALSE, FALSE, NULL, FALSE );
2329
-        // the details template wrapper
2330
-        $this->display_admin_page_with_sidebar();
2331
-    }
2332
-
2333
-
2334
-    /**
2335
-     * This returns the content for a registration step
2336
-     *
2337
-     * @access protected
2338
-     * @return string html
2339
-     */
2340
-    protected function _get_registration_step_content()
2341
-    {
2342
-        if (isset($_COOKIE['ee_registration_added']) && $_COOKIE['ee_registration_added']) {
2343
-            $warning_msg = sprintf(__('%2$sWARNING!!!%3$s%1$sPlease do not use the back button to return to this page for the purpose of adding another registration.%1$sThis can result in lost and/or corrupted data.%1$sIf you wish to add another registration, then please click the%1$s%7$s"Add Another New Registration to Event"%8$s button%1$son the Transaction details page, after you are redirected.%1$s%1$s%4$s redirecting in %5$s seconds %6$s',
2344
-                'event_espresso'), '<br />', '<h3 class="important-notice">', '</h3>', '<div class="float-right">',
2345
-                '<span id="redirect_timer" class="important-notice">30</span>', '</div>', '<b>', '</b>');
2346
-            return '
1902
+	}
1903
+
1904
+
1905
+	/**
1906
+	 * Updates the registration's custom questions according to the form info, if the form is submitted.
1907
+	 * If it's not a post, the "view_registrations" route will be called next on the SAME request
1908
+	 * to display the page
1909
+	 *
1910
+	 * @access protected
1911
+	 * @return void
1912
+	 */
1913
+	protected function _update_attendee_registration_form()
1914
+	{
1915
+		do_action('AHEE__Registrations_Admin_Page___update_attendee_registration_form__start', $this);
1916
+		if ($_SERVER['REQUEST_METHOD'] == 'POST') {
1917
+			$REG_ID  = isset($this->_req_data['_REG_ID']) ? absint($this->_req_data['_REG_ID']) : false;
1918
+			$success = $this->_save_reg_custom_questions_form($REG_ID);
1919
+			if ($success) {
1920
+				$what  = __('Registration Form', 'event_espresso');
1921
+				$route = $REG_ID ? array('action' => 'view_registration', '_REG_ID' => $REG_ID)
1922
+					: array('action' => 'default');
1923
+				$this->_redirect_after_action($success, $what, __('updated', 'event_espresso'), $route);
1924
+			}
1925
+		}
1926
+	}
1927
+
1928
+
1929
+	/**
1930
+	 * Gets the form for saving registrations custom questions (if done
1931
+	 * previously retrieves the cached form object, which may have validation errors in it)
1932
+	 *
1933
+	 * @param int $REG_ID
1934
+	 * @return EE_Registration_Custom_Questions_Form
1935
+	 */
1936
+	protected function _get_reg_custom_questions_form($REG_ID)
1937
+	{
1938
+		if ( ! $this->_reg_custom_questions_form) {
1939
+			require_once(REG_ADMIN . 'form_sections' . DS . 'EE_Registration_Custom_Questions_Form.form.php');
1940
+			$this->_reg_custom_questions_form = new EE_Registration_Custom_Questions_Form(
1941
+				EEM_Registration::instance()->get_one_by_ID($REG_ID)
1942
+			);
1943
+			$this->_reg_custom_questions_form->_construct_finalize(null, null);
1944
+		}
1945
+		return $this->_reg_custom_questions_form;
1946
+	}
1947
+
1948
+
1949
+	/**
1950
+	 * Saves
1951
+	 *
1952
+	 * @access private
1953
+	 * @param bool $REG_ID
1954
+	 * @return bool
1955
+	 */
1956
+	private function _save_reg_custom_questions_form($REG_ID = false)
1957
+	{
1958
+		if ( ! $REG_ID) {
1959
+			EE_Error::add_error(__('An error occurred. No registration ID was received.', 'event_espresso'), __FILE__,
1960
+				__FUNCTION__, __LINE__);
1961
+		}
1962
+		$form = $this->_get_reg_custom_questions_form($REG_ID);
1963
+		$form->receive_form_submission($this->_req_data);
1964
+		$success = false;
1965
+		if ($form->is_valid()) {
1966
+			foreach ($form->subforms() as $question_group_id => $question_group_form) {
1967
+				foreach ($question_group_form->inputs() as $question_id => $input) {
1968
+					$where_conditions    = array(
1969
+						'QST_ID' => $question_id,
1970
+						'REG_ID' => $REG_ID,
1971
+					);
1972
+					$possibly_new_values = array(
1973
+						'ANS_value' => $input->normalized_value(),
1974
+					);
1975
+					$answer              = EEM_Answer::instance()->get_one(array($where_conditions));
1976
+					if ($answer instanceof EE_Answer) {
1977
+						$success = $answer->save($possibly_new_values);
1978
+					} else {
1979
+						//insert it then
1980
+						$cols_n_vals = array_merge($where_conditions, $possibly_new_values);
1981
+						$answer      = EE_Answer::new_instance($cols_n_vals);
1982
+						$success     = $answer->save();
1983
+					}
1984
+				}
1985
+			}
1986
+		} else {
1987
+			EE_Error::add_error($form->get_validation_error_string(), __FILE__, __FUNCTION__, __LINE__);
1988
+		}
1989
+		return $success;
1990
+	}
1991
+
1992
+
1993
+	/**
1994
+	 *        generates HTML for the Registration main meta box
1995
+	 *
1996
+	 * @access public
1997
+	 * @return void
1998
+	 */
1999
+	public function _reg_attendees_meta_box()
2000
+	{
2001
+		$REG = EEM_Registration::instance();
2002
+		//get all other registrations on this transaction, and cache
2003
+		//the attendees for them so we don't have to run another query using force_join
2004
+		$registrations                           = $REG->get_all(array(
2005
+			array(
2006
+				'TXN_ID' => $this->_registration->transaction_ID(),
2007
+				'REG_ID' => array('!=', $this->_registration->ID()),
2008
+			),
2009
+			'force_join' => array('Attendee'),
2010
+		));
2011
+		$this->_template_args['attendees']       = array();
2012
+		$this->_template_args['attendee_notice'] = '';
2013
+		if (empty($registrations)
2014
+			|| (is_array($registrations)
2015
+				&& ! EEH_Array::get_one_item_from_array($registrations))
2016
+		) {
2017
+			EE_Error::add_error(__('There are no records attached to this registration. Something may have gone wrong with the registration',
2018
+				'event_espresso'), __FILE__, __FUNCTION__, __LINE__);
2019
+			$this->_template_args['attendee_notice'] = EE_Error::get_notices();
2020
+		} else {
2021
+			$att_nmbr = 1;
2022
+			foreach ($registrations as $registration) {
2023
+				/* @var $registration EE_Registration */
2024
+				$attendee                                                    = $registration->attendee()
2025
+					? $registration->attendee()
2026
+					: EEM_Attendee::instance()
2027
+								  ->create_default_object();
2028
+				$this->_template_args['attendees'][$att_nmbr]['STS_ID']      = $registration->status_ID();
2029
+				$this->_template_args['attendees'][$att_nmbr]['fname']       = $attendee->fname();//( isset( $registration->ATT_fname ) & ! empty( $registration->ATT_fname ) ) ? $registration->ATT_fname : '';
2030
+				$this->_template_args['attendees'][$att_nmbr]['lname']       = $attendee->lname();//( isset( $registration->ATT_lname ) & ! empty( $registration->ATT_lname ) ) ? $registration->ATT_lname : '';
2031
+				$this->_template_args['attendees'][$att_nmbr]['email']       = $attendee->email();//( isset( $registration->ATT_email ) & ! empty( $registration->ATT_email ) ) ? $registration->ATT_email : '';
2032
+				$this->_template_args['attendees'][$att_nmbr]['final_price'] = $registration->final_price();//( isset( $registration->REG_final_price ) & ! empty( $registration->REG_final_price ) ) ? $registration->REG_final_price : '';
2033
+				$this->_template_args['attendees'][$att_nmbr]['address']     = implode(', ',
2034
+					$attendee->full_address_as_array());
2035
+				$this->_template_args['attendees'][$att_nmbr]['att_link']    = self::add_query_args_and_nonce(array(
2036
+					'action' => 'edit_attendee',
2037
+					'post'   => $attendee->ID(),
2038
+				), REG_ADMIN_URL);
2039
+				$this->_template_args['attendees'][$att_nmbr]['event_name']  = $registration->event_obj()->name();
2040
+				$att_nmbr++;
2041
+			}
2042
+			//EEH_Debug_Tools::printr( $attendees, '$attendees  <br /><span style="font-size:10px;font-weight:normal;">( file: '. __FILE__ . ' - line no: ' . __LINE__ . ' )</span>', 'auto' );
2043
+			$this->_template_args['currency_sign'] = EE_Registry::instance()->CFG->currency->sign;
2044
+			//			$this->_template_args['registration_form_url'] = add_query_arg( array( 'action' => 'edit_registration', 'process' => 'attendees'  ), REG_ADMIN_URL );
2045
+		}
2046
+		$template_path = REG_TEMPLATE_PATH . 'reg_admin_details_main_meta_box_attendees.template.php';
2047
+		echo EEH_Template::display_template($template_path, $this->_template_args, true);
2048
+	}
2049
+
2050
+
2051
+	/**
2052
+	 *        generates HTML for the Edit Registration side meta box
2053
+	 *
2054
+	 * @access public
2055
+	 * @return void
2056
+	 */
2057
+	public function _reg_registrant_side_meta_box()
2058
+	{
2059
+		/*@var $attendee EE_Attendee */
2060
+		$att_check = $this->_registration->attendee();
2061
+		$attendee  = $att_check instanceof EE_Attendee ? $att_check : EEM_Attendee::instance()->create_default_object();
2062
+		//now let's determine if this is not the primary registration.  If it isn't then we set the primary_registration object for reference BUT ONLY if the Attendee object loaded is not the same as the primary registration object (that way we know if we need to show create button or not)
2063
+		if ( ! $this->_registration->is_primary_registrant()) {
2064
+			$primary_registration = $this->_registration->get_primary_registration();
2065
+			$primary_attendee     = $primary_registration instanceof EE_Registration ? $primary_registration->attendee()
2066
+				: null;
2067
+			if ( ! $primary_attendee instanceof EE_Attendee || $attendee->ID() !== $primary_attendee->ID()) {
2068
+				//in here?  This means the displayed registration is not the primary registrant but ALREADY HAS its own custom attendee object so let's not worry about the primary reg.
2069
+				$primary_registration = null;
2070
+			}
2071
+		} else {
2072
+			$primary_registration = null;
2073
+		}
2074
+		$this->_template_args['ATT_ID']            = $attendee->ID();
2075
+		$this->_template_args['fname']             = $attendee->fname();//$this->_registration->ATT_fname;
2076
+		$this->_template_args['lname']             = $attendee->lname();//$this->_registration->ATT_lname;
2077
+		$this->_template_args['email']             = $attendee->email();//$this->_registration->ATT_email;
2078
+		$this->_template_args['phone']             = $attendee->phone();
2079
+		$this->_template_args['formatted_address'] = EEH_Address::format($attendee);
2080
+		//edit link
2081
+		$this->_template_args['att_edit_link']  = EE_Admin_Page::add_query_args_and_nonce(array(
2082
+			'action' => 'edit_attendee',
2083
+			'post'   => $attendee->ID(),
2084
+		), REG_ADMIN_URL);
2085
+		$this->_template_args['att_edit_label'] = __('View/Edit Contact', 'event_espresso');
2086
+		//create link
2087
+		$this->_template_args['create_link']  = $primary_registration instanceof EE_Registration
2088
+			? EE_Admin_Page::add_query_args_and_nonce(array(
2089
+				'action'  => 'duplicate_attendee',
2090
+				'_REG_ID' => $this->_registration->ID(),
2091
+			), REG_ADMIN_URL) : '';
2092
+		$this->_template_args['create_label'] = __('Create Contact', 'event_espresso');
2093
+		$this->_template_args['att_check']    = $att_check;
2094
+		$template_path                        = REG_TEMPLATE_PATH . 'reg_admin_details_side_meta_box_registrant.template.php';
2095
+		echo EEH_Template::display_template($template_path, $this->_template_args, true);
2096
+	}
2097
+
2098
+
2099
+	/**
2100
+	 * trash or restore registrations
2101
+	 *
2102
+	 * @param  boolean $trash whether to archive or restore
2103
+	 * @access protected
2104
+	 * @return void
2105
+	 */
2106
+	protected function _trash_or_restore_registrations($trash = true)
2107
+	{
2108
+		$REGM    = EEM_Registration::instance();
2109
+		$success = 1;
2110
+		$error   = 0;
2111
+		$tickets = array();
2112
+		$dtts    = array();
2113
+		//if empty _REG_ID then get out because there's nothing to do
2114
+		if (empty($this->_req_data['_REG_ID'])) {
2115
+			$msg = $trash
2116
+				? __('In order to trash registrations you must select which ones you wish to trash by clicking the checkboxes.',
2117
+					'event_espresso')
2118
+				: __('In order to restore registrations you must select which ones you wish to restore by clicking the checkboxes.',
2119
+					'event_espresso');
2120
+			EE_Error::add_error($msg, __FILE__, __LINE__, __FUNCTION__);
2121
+			$this->_redirect_after_action(false, '', '', array(), true);
2122
+		}
2123
+		//Checkboxes
2124
+		if ( ! empty($this->_req_data['_REG_ID']) && is_array($this->_req_data['_REG_ID'])) {
2125
+			// if array has more than one element than success message should be plural
2126
+			$success = count($this->_req_data['_REG_ID']) > 1 ? 2 : 1;
2127
+			// cycle thru checkboxes
2128
+			while (list($ind, $REG_ID) = each($this->_req_data['_REG_ID'])) {
2129
+				/** @var EE_Registration $REG */
2130
+				$REG           = $REGM->get_one_by_ID($REG_ID);
2131
+				$payment_count = $REG->get_first_related('Transaction')->count_related('Payment');
2132
+				if ($payment_count > 0) {
2133
+					$name    = $REG->attendee() instanceof EE_Attendee ? $REG->attendee()->full_name()
2134
+						: __('Unknown Attendee', 'event_espresso');
2135
+					$error   = 1;
2136
+					$success = 0;
2137
+					EE_Error::add_error(sprintf(__('The registration for %s could not be trashed because it has payments attached to the related transaction.  If you wish to trash this registration you must first delete the payments on the related transaction.',
2138
+						'event_espresso'), $name), __FILE__, __FUNCTION__, __LINE__);
2139
+					continue; //can't trash this registration because it has payments.
2140
+				}
2141
+				$ticket                 = $REG->get_first_related('Ticket');
2142
+				$tickets[$ticket->ID()] = $ticket;
2143
+				$dtt                    = $ticket->get_many_related('Datetime');
2144
+				$dtts                   = array_merge($dtts, $dtt);
2145
+				$updated                = $trash ? $REG->delete() : $REG->restore();
2146
+				if ( ! $updated) {
2147
+					$success = 0;
2148
+				} else {
2149
+					$success = 2;
2150
+				}/**/
2151
+			}
2152
+		} else {
2153
+			// grab single id and delete
2154
+			$REG_ID                 = absint($this->_req_data['_REG_ID']);
2155
+			$REG                    = $REGM->get_one_by_ID($REG_ID);
2156
+			$ticket                 = $REG->get_first_related('Ticket');
2157
+			$tickets[$ticket->ID()] = $ticket;
2158
+			$dtts                   = $ticket->get_many_related('Datetime');
2159
+			$updated                = $trash ? $REG->delete() : $REG->restore();
2160
+			if ( ! $updated) {
2161
+				$success = 0;
2162
+			}
2163
+		}
2164
+		//now let's update counts
2165
+		EEM_Ticket::instance()->update_tickets_sold($tickets);
2166
+		EEM_Datetime::instance()->update_sold($dtts);
2167
+		$what           = $success > 1 ? __('Registrations', 'event_espresso') : __('Registration', 'event_espresso');
2168
+		$action_desc    = $trash ? __('moved to the trash', 'event_espresso') : __('restored', 'event_espresso');
2169
+		$overwrite_msgs = $error ? true : false;
2170
+		$this->_redirect_after_action($success, $what, $action_desc, array('action' => 'default'), $overwrite_msgs);
2171
+	}
2172
+
2173
+
2174
+	/**
2175
+	 * This is used to permanently delete registrations.  Note, this will handle not only deleting permanently the
2176
+	 * registration but also.
2177
+	 * 1. Removing relations to EE_Attendee
2178
+	 * 2. Deleting permanently the related transaction, but ONLY if all related registrations to the transaction are
2179
+	 * ALSO trashed.
2180
+	 * 3. Deleting permanently any related Line items but only if the above conditions are met.
2181
+	 * 4. Removing relationships between all tickets and the related registrations
2182
+	 * 5. Deleting permanently any related Answers (and the answers for other related registrations that were deleted.)
2183
+	 * 6. Deleting permanently any related Checkins.
2184
+	 *
2185
+	 * @return void
2186
+	 */
2187
+	protected function _delete_registrations()
2188
+	{
2189
+		$REG_MDL = EEM_Registration::instance();
2190
+		$success = 1;
2191
+		//Checkboxes
2192
+		if ( ! empty($this->_req_data['_REG_ID']) && is_array($this->_req_data['_REG_ID'])) {
2193
+			// if array has more than one element than success message should be plural
2194
+			$success = count($this->_req_data['_REG_ID']) > 1 ? 2 : 1;
2195
+			// cycle thru checkboxes
2196
+			while (list($ind, $REG_ID) = each($this->_req_data['_REG_ID'])) {
2197
+				$REG = $REG_MDL->get_one_by_ID($REG_ID);
2198
+				if ( ! $REG instanceof EE_Registration) {
2199
+					continue;
2200
+				}
2201
+				$deleted = $this->_delete_registration($REG);
2202
+				if ( ! $deleted) {
2203
+					$success = 0;
2204
+				}
2205
+			}
2206
+		} else {
2207
+			// grab single id and delete
2208
+			$REG_ID  = $this->_req_data['_REG_ID'];
2209
+			$REG     = $REG_MDL->get_one_by_ID($REG_ID);
2210
+			$deleted = $this->_delete_registration($REG);
2211
+			if ( ! $deleted) {
2212
+				$success = 0;
2213
+			}
2214
+		}
2215
+		$what        = $success > 1 ? __('Registrations', 'event_espresso') : __('Registration', 'event_espresso');
2216
+		$action_desc = __('permanently deleted.', 'event_espresso');
2217
+		$this->_redirect_after_action($success, $what, $action_desc, array('action' => 'default'), true);
2218
+	}
2219
+
2220
+
2221
+	/**
2222
+	 * handles the permanent deletion of a registration.  See comments with _delete_registrations() for details on what
2223
+	 * models get affected.
2224
+	 *
2225
+	 * @param  EE_Registration $REG registration to be deleted permenantly
2226
+	 * @return boolean              true = successful deletion, false = fail.
2227
+	 */
2228
+	protected function _delete_registration(EE_Registration $REG)
2229
+	{
2230
+		//first we start with the transaction... ultimately, we WILL not delete permanently if there are any related registrations on the transaction that are NOT trashed.
2231
+		$TXN         = $REG->get_first_related('Transaction');
2232
+		$REGS        = $TXN->get_many_related('Registration');
2233
+		$all_trashed = true;
2234
+		foreach ($REGS as $registration) {
2235
+			if ( ! $registration->get('REG_deleted')) {
2236
+				$all_trashed = false;
2237
+			}
2238
+		}
2239
+		if ( ! $all_trashed) {
2240
+			EE_Error::add_error(__('Unable to permanently delete this registration. Before this registration can be permanently deleted, all registrations made in the same transaction must be trashed as well.  These registrations will be permanently deleted in the same action.',
2241
+				'event_espresso'), __FILE__, __FUNCTION__, __LINE__);
2242
+			return false;
2243
+		}
2244
+		//k made it here so that means we can delete all the related transactions and their answers (but let's do them separately from THIS one).
2245
+		foreach ($REGS as $registration) {
2246
+			//delete related answers
2247
+			$registration->delete_related_permanently('Answer');
2248
+			//remove relationship to EE_Attendee (but we ALWAYS leave the contact record intact)
2249
+			$attendee = $registration->get_first_related('Attendee');
2250
+			if ($attendee instanceof EE_Attendee) {
2251
+				$registration->_remove_relation_to($attendee, 'Attendee');
2252
+			}
2253
+			//now remove relationships to tickets on this registration.
2254
+			$registration->_remove_relations('Ticket');
2255
+			//now delete permanently the checkins related to this registration.
2256
+			$registration->delete_related_permanently('Checkin');
2257
+			if ($registration->ID() === $REG->ID()) {
2258
+				continue;
2259
+			} //we don't want to delete permanently the existing registration just yet.
2260
+			//remove relation to transaction for these registrations if NOT the existing registrations
2261
+			$registration->_remove_relations('Transaction');
2262
+			//delete permanently any related messages.
2263
+			$registration->delete_related_permanently('Message');
2264
+			//now delete this registration permanently
2265
+			$registration->delete_permanently();
2266
+		}
2267
+		//now all related registrations on the transaction are handled.  So let's just handle this registration itself (the transaction and line items should be all that's left).
2268
+		//delete the line items related to the transaction for this registration.
2269
+		$TXN->delete_related_permanently('Line_Item');
2270
+		//we need to remove all the relationships on the transaction
2271
+		$TXN->delete_related_permanently('Payment');
2272
+		$TXN->delete_related_permanently('Extra_Meta');
2273
+		$TXN->delete_related_permanently('Message');
2274
+		//now we can delete this REG permanently (and the transaction of course)
2275
+		$REG->delete_related_permanently('Transaction');
2276
+		return $REG->delete_permanently();
2277
+	}
2278
+
2279
+
2280
+	/**
2281
+	 *    generates HTML for the Register New Attendee Admin page
2282
+	 *
2283
+	 * @access private
2284
+	 * @throws \EE_Error
2285
+	 * @return void
2286
+	 */
2287
+	public function new_registration()
2288
+	{
2289
+		if ( ! $this->_set_reg_event()) {
2290
+			throw new EE_Error(__('Unable to continue with registering because there is no Event ID in the request',
2291
+				'event_espresso'));
2292
+		}
2293
+		EE_Registry::instance()->REQ->set_espresso_page(true);
2294
+		// gotta start with a clean slate if we're not coming here via ajax
2295
+		if ( ! defined('DOING_AJAX')
2296
+			 && ( ! isset($this->_req_data['processing_registration']) || isset($this->_req_data['step_error']))
2297
+		) {
2298
+			EE_Registry::instance()->SSN->clear_session(__CLASS__, __FUNCTION__);
2299
+		}
2300
+		$this->_template_args['event_name'] = '';
2301
+		// event name
2302
+		if ($this->_reg_event) {
2303
+			$this->_template_args['event_name'] = $this->_reg_event->name();
2304
+			$edit_event_url                     = self::add_query_args_and_nonce(array(
2305
+				'action' => 'edit',
2306
+				'post'   => $this->_reg_event->ID(),
2307
+			), EVENTS_ADMIN_URL);
2308
+			$edit_event_lnk                     = '<a href="'
2309
+												  . $edit_event_url
2310
+												  . '" title="'
2311
+												  . esc_attr__('Edit ', 'event_espresso')
2312
+												  . $this->_reg_event->name()
2313
+												  . '">'
2314
+												  . __('Edit Event', 'event_espresso')
2315
+												  . '</a>';
2316
+			$this->_template_args['event_name'] .= ' <span class="admin-page-header-edit-lnk not-bold">'
2317
+												   . $edit_event_lnk
2318
+												   . '</span>';
2319
+		}
2320
+		$this->_template_args['step_content'] = $this->_get_registration_step_content();
2321
+		if (defined('DOING_AJAX')) {
2322
+			$this->_return_json();
2323
+		}
2324
+		// grab header
2325
+		$template_path                              = REG_TEMPLATE_PATH . 'reg_admin_register_new_attendee.template.php';
2326
+		$this->_template_args['admin_page_content'] = EEH_Template::display_template($template_path,
2327
+			$this->_template_args, true);
2328
+		//$this->_set_publish_post_box_vars( NULL, FALSE, FALSE, NULL, FALSE );
2329
+		// the details template wrapper
2330
+		$this->display_admin_page_with_sidebar();
2331
+	}
2332
+
2333
+
2334
+	/**
2335
+	 * This returns the content for a registration step
2336
+	 *
2337
+	 * @access protected
2338
+	 * @return string html
2339
+	 */
2340
+	protected function _get_registration_step_content()
2341
+	{
2342
+		if (isset($_COOKIE['ee_registration_added']) && $_COOKIE['ee_registration_added']) {
2343
+			$warning_msg = sprintf(__('%2$sWARNING!!!%3$s%1$sPlease do not use the back button to return to this page for the purpose of adding another registration.%1$sThis can result in lost and/or corrupted data.%1$sIf you wish to add another registration, then please click the%1$s%7$s"Add Another New Registration to Event"%8$s button%1$son the Transaction details page, after you are redirected.%1$s%1$s%4$s redirecting in %5$s seconds %6$s',
2344
+				'event_espresso'), '<br />', '<h3 class="important-notice">', '</h3>', '<div class="float-right">',
2345
+				'<span id="redirect_timer" class="important-notice">30</span>', '</div>', '<b>', '</b>');
2346
+			return '
2347 2347
 	<div id="ee-add-reg-back-button-dv"><p>' . $warning_msg . '</p></div>
2348 2348
 	<script >
2349 2349
 		// WHOAH !!! it appears that someone is using the back button from the Transaction admin page
@@ -2356,658 +2356,658 @@  discard block
 block discarded – undo
2356 2356
 	        }
2357 2357
 	    }, 800 );
2358 2358
 	</script >';
2359
-        }
2360
-        $template_args = array(
2361
-            'title'                    => '',
2362
-            'content'                  => '',
2363
-            'step_button_text'         => '',
2364
-            'show_notification_toggle' => false,
2365
-        );
2366
-        //to indicate we're processing a new registration
2367
-        $hidden_fields = array(
2368
-            'processing_registration' => array(
2369
-                'type'  => 'hidden',
2370
-                'value' => 0,
2371
-            ),
2372
-            'event_id'                => array(
2373
-                'type'  => 'hidden',
2374
-                'value' => $this->_reg_event->ID(),
2375
-            ),
2376
-        );
2377
-        //if the cart is empty then we know we're at step one so we'll display ticket selector
2378
-        $cart = EE_Registry::instance()->SSN->cart();
2379
-        $step = ! $cart instanceof EE_Cart ? 'ticket' : 'questions';
2380
-        switch ($step) {
2381
-            case 'ticket' :
2382
-                $hidden_fields['processing_registration']['value'] = 1;
2383
-                $template_args['title']                            = __('Step One: Select the Ticket for this registration',
2384
-                    'event_espresso');
2385
-                $template_args['content']                          = EED_Ticket_Selector::instance()->display_ticket_selector($this->_reg_event);
2386
-                $template_args['step_button_text']                 = __('Add Tickets and Continue to Registrant Details',
2387
-                    'event_espresso');
2388
-                $template_args['show_notification_toggle']         = false;
2389
-                break;
2390
-            case 'questions' :
2391
-                $hidden_fields['processing_registration']['value'] = 2;
2392
-                $template_args['title']                            = __('Step Two: Add Registrant Details for this Registration',
2393
-                    'event_espresso');
2394
-                //in theory we should be able to run EED_SPCO at this point because the cart should have been setup properly by the first process_reg_step run.
2395
-                $template_args['content']                  = EED_Single_Page_Checkout::registration_checkout_for_admin();
2396
-                $template_args['step_button_text']         = __('Save Registration and Continue to Details',
2397
-                    'event_espresso');
2398
-                $template_args['show_notification_toggle'] = true;
2399
-                break;
2400
-        }
2401
-        $this->_set_add_edit_form_tags('process_reg_step',
2402
-            $hidden_fields); //we come back to the process_registration_step route.
2403
-        return EEH_Template::display_template(REG_TEMPLATE_PATH
2404
-                                              . 'reg_admin_register_new_attendee_step_content.template.php',
2405
-            $template_args, true);
2406
-    }
2407
-
2408
-
2409
-    /**
2410
-     *        set_reg_event
2411
-     *
2412
-     * @access private
2413
-     * @return boolean
2414
-     */
2415
-    private function _set_reg_event()
2416
-    {
2417
-        if (is_object($this->_reg_event)) {
2418
-            return true;
2419
-        }
2420
-        $EVT_ID = ( ! empty($this->_req_data['event_id'])) ? absint($this->_req_data['event_id']) : false;
2421
-        if ( ! $EVT_ID) {
2422
-            return false;
2423
-        }
2424
-        $this->_reg_event = EEM_Event::instance()->get_one_by_ID($EVT_ID);
2425
-        return true;
2426
-    }
2427
-
2428
-
2429
-    /**
2430
-     * process_reg_step
2431
-     *
2432
-     * @access        public
2433
-     * @return        string
2434
-     * @throws \RuntimeException
2435
-     * @throws \EE_Error
2436
-     */
2437
-    public function process_reg_step()
2438
-    {
2439
-        EE_System::do_not_cache();
2440
-        $this->_set_reg_event();
2441
-        EE_Registry::instance()->REQ->set_espresso_page(true);
2442
-        EE_Registry::instance()->REQ->set('uts', time());
2443
-        //what step are we on?
2444
-        $cart = EE_Registry::instance()->SSN->cart();
2445
-        $step = ! $cart instanceof EE_Cart ? 'ticket' : 'questions';
2446
-        //if doing ajax then we need to verify the nonce
2447
-        if (defined('DOING_AJAX')) {
2448
-            $nonce = isset($this->_req_data[$this->_req_nonce])
2449
-                ? sanitize_text_field($this->_req_data[$this->_req_nonce]) : '';
2450
-            $this->_verify_nonce($nonce, $this->_req_nonce);
2451
-        }
2452
-        switch ($step) {
2453
-            case 'ticket' :
2454
-                //process ticket selection
2455
-                $success = EED_Ticket_Selector::instance()->process_ticket_selections();
2456
-                if ($success) {
2457
-                    EE_Error::add_success(esc_html__('Tickets Selected. Now complete the registration.',
2458
-                        'event_espresso'));
2459
-                } else {
2460
-                    $query_args['step_error'] = $this->_req_data['step_error'] = true;
2461
-                }
2462
-                if (defined('DOING_AJAX')) {
2463
-                    $this->new_registration(); //display next step
2464
-                } else {
2465
-                    $query_args = array(
2466
-                        'action'                  => 'new_registration',
2467
-                        'processing_registration' => 1,
2468
-                        'event_id'                => $this->_reg_event->ID(),
2469
-                        'uts'                     => time(),
2470
-                    );
2471
-                    $this->_redirect_after_action(false, '', '', $query_args, true);
2472
-                }
2473
-                break;
2474
-            case 'questions' :
2475
-                if ( ! isset($this->_req_data['txn_reg_status_change'], $this->_req_data['txn_reg_status_change']['send_notifications'])) {
2476
-                    add_filter('FHEE__EED_Messages___maybe_registration__deliver_notifications', '__return_false', 15);
2477
-                }
2478
-                //process registration
2479
-                $transaction = EED_Single_Page_Checkout::instance()->process_registration_from_admin();
2480
-                if ($cart instanceof EE_Cart) {
2481
-                    $grand_total = $cart->get_cart_grand_total();
2482
-                    if ($grand_total instanceof EE_Line_Item) {
2483
-                        $grand_total->save_this_and_descendants_to_txn();
2484
-                    }
2485
-                }
2486
-                if ( ! $transaction instanceof EE_Transaction) {
2487
-                    $query_args = array(
2488
-                        'action'                  => 'new_registration',
2489
-                        'processing_registration' => 2,
2490
-                        'event_id'                => $this->_reg_event->ID(),
2491
-                        'uts'                     => time(),
2492
-                    );
2493
-                    if (defined('DOING_AJAX')) {
2494
-                        //display registration form again because there are errors (maybe validation?)
2495
-                        $this->new_registration();
2496
-                        return;
2497
-                    } else {
2498
-                        $this->_redirect_after_action(false, '', '', $query_args, true);
2499
-                        return;
2500
-                    }
2501
-                }
2502
-                // maybe update status, and make sure to save transaction if not done already
2503
-                if ( ! $transaction->update_status_based_on_total_paid()) {
2504
-                    $transaction->save();
2505
-                }
2506
-                EE_Registry::instance()->SSN->clear_session(__CLASS__, __FUNCTION__);
2507
-                $this->_req_data = array();
2508
-                $query_args      = array(
2509
-                    'action'        => 'redirect_to_txn',
2510
-                    'TXN_ID'        => $transaction->ID(),
2511
-                    'EVT_ID'        => $this->_reg_event->ID(),
2512
-                    'event_name'    => urlencode($this->_reg_event->name()),
2513
-                    'redirect_from' => 'new_registration',
2514
-                );
2515
-                $this->_redirect_after_action(false, '', '', $query_args, true);
2516
-                break;
2517
-        }
2518
-        //what are you looking here for?  Should be nothing to do at this point.
2519
-    }
2520
-
2521
-
2522
-    /**
2523
-     * redirect_to_txn
2524
-     *
2525
-     * @access public
2526
-     * @return void
2527
-     */
2528
-    public function redirect_to_txn()
2529
-    {
2530
-        EE_System::do_not_cache();
2531
-        EE_Registry::instance()->SSN->clear_session(__CLASS__, __FUNCTION__);
2532
-        $query_args = array(
2533
-            'action' => 'view_transaction',
2534
-            'TXN_ID' => isset($this->_req_data['TXN_ID']) ? absint($this->_req_data['TXN_ID']) : 0,
2535
-            'page'   => 'espresso_transactions',
2536
-        );
2537
-        if (isset($this->_req_data['EVT_ID'], $this->_req_data['redirect_from'])) {
2538
-            $query_args['EVT_ID']        = $this->_req_data['EVT_ID'];
2539
-            $query_args['event_name']    = urlencode($this->_req_data['event_name']);
2540
-            $query_args['redirect_from'] = $this->_req_data['redirect_from'];
2541
-        }
2542
-        EE_Error::add_success(__('Registration Created.  Please review the transaction and add any payments as necessary',
2543
-            'event_espresso'));
2544
-        $this->_redirect_after_action(false, '', '', $query_args, true);
2545
-    }
2546
-
2547
-
2548
-    /**
2549
-     *        generates HTML for the Attendee Contact List
2550
-     *
2551
-     * @access protected
2552
-     * @return void
2553
-     */
2554
-    protected function _attendee_contact_list_table()
2555
-    {
2556
-        do_action('AHEE_log', __FILE__, __FUNCTION__, '');
2557
-        $this->_search_btn_label = __('Contacts', 'event_espresso');
2558
-        $this->display_admin_list_table_page_with_no_sidebar();
2559
-    }
2560
-
2561
-
2562
-    /**
2563
-     *        get_attendees
2564
-     *
2565
-     * @param bool $count whether to return count or data.
2566
-     * @access public
2567
-     * @return array
2568
-     */
2569
-    public function get_attendees($per_page, $count = false, $trash = false)
2570
-    {
2571
-        do_action('AHEE_log', __FILE__, __FUNCTION__, '');
2572
-        require_once(REG_ADMIN . 'EE_Attendee_Contact_List_Table.class.php');
2573
-        $ATT_MDL                    = EEM_Attendee::instance();
2574
-        $this->_req_data['orderby'] = ! empty($this->_req_data['orderby']) ? $this->_req_data['orderby'] : '';
2575
-        switch ($this->_req_data['orderby']) {
2576
-            case 'ATT_ID':
2577
-                $orderby = 'ATT_ID';
2578
-                break;
2579
-            case 'ATT_fname':
2580
-                $orderby = 'ATT_fname';
2581
-                break;
2582
-            case 'ATT_email':
2583
-                $orderby = 'ATT_email';
2584
-                break;
2585
-            case 'ATT_city':
2586
-                $orderby = 'ATT_city';
2587
-                break;
2588
-            case 'STA_ID':
2589
-                $orderby = 'STA_ID';
2590
-                break;
2591
-            case 'CNT_ID':
2592
-                $orderby = 'CNT_ID';
2593
-                break;
2594
-            default:
2595
-                $orderby = 'ATT_lname';
2596
-        }
2597
-        $sort         = (isset($this->_req_data['order']) && ! empty($this->_req_data['order'])) ? $this->_req_data['order']
2598
-            : 'ASC';
2599
-        $current_page = isset($this->_req_data['paged']) && ! empty($this->_req_data['paged'])
2600
-            ? $this->_req_data['paged'] : 1;
2601
-        $per_page     = isset($per_page) && ! empty($per_page) ? $per_page : 10;
2602
-        $per_page     = isset($this->_req_data['perpage']) && ! empty($this->_req_data['perpage'])
2603
-            ? $this->_req_data['perpage'] : $per_page;
2604
-        $_where       = array();
2605
-        if ( ! empty($this->_req_data['s'])) {
2606
-            $sstr         = '%' . $this->_req_data['s'] . '%';
2607
-            $_where['OR'] = array(
2608
-                'Registration.Event.EVT_name'       => array('LIKE', $sstr),
2609
-                'Registration.Event.EVT_desc'       => array('LIKE', $sstr),
2610
-                'Registration.Event.EVT_short_desc' => array('LIKE', $sstr),
2611
-                'ATT_fname'                         => array('LIKE', $sstr),
2612
-                'ATT_lname'                         => array('LIKE', $sstr),
2613
-                'ATT_short_bio'                     => array('LIKE', $sstr),
2614
-                'ATT_email'                         => array('LIKE', $sstr),
2615
-                'ATT_address'                       => array('LIKE', $sstr),
2616
-                'ATT_address2'                      => array('LIKE', $sstr),
2617
-                'ATT_city'                          => array('LIKE', $sstr),
2618
-                'Country.CNT_name'                  => array('LIKE', $sstr),
2619
-                'State.STA_name'                    => array('LIKE', $sstr),
2620
-                'ATT_phone'                         => array('LIKE', $sstr),
2621
-                'Registration.REG_final_price'      => array('LIKE', $sstr),
2622
-                'Registration.REG_code'             => array('LIKE', $sstr),
2623
-                'Registration.REG_count'            => array('LIKE', $sstr),
2624
-                'Registration.REG_group_size'       => array('LIKE', $sstr),
2625
-            );
2626
-        }
2627
-        $offset = ($current_page - 1) * $per_page;
2628
-        $limit  = $count ? null : array($offset, $per_page);
2629
-        if ($trash) {
2630
-            $_where['status'] = array('!=', 'publish');
2631
-            $all_attendees    = $count
2632
-                ? $ATT_MDL->count(array(
2633
-                    $_where,
2634
-                    'order_by' => array($orderby => $sort),
2635
-                    'limit'    => $limit,
2636
-                ), 'ATT_ID', true)
2637
-                : $ATT_MDL->get_all(array(
2638
-                    $_where,
2639
-                    'order_by' => array($orderby => $sort),
2640
-                    'limit'    => $limit,
2641
-                ));
2642
-        } else {
2643
-            $_where['status'] = array('IN', array('publish'));
2644
-            $all_attendees    = $count
2645
-                ? $ATT_MDL->count(array(
2646
-                    $_where,
2647
-                    'order_by' => array($orderby => $sort),
2648
-                    'limit'    => $limit,
2649
-                ), 'ATT_ID', true)
2650
-                : $ATT_MDL->get_all(array(
2651
-                    $_where,
2652
-                    'order_by' => array($orderby => $sort),
2653
-                    'limit'    => $limit,
2654
-                ));
2655
-        }
2656
-        return $all_attendees;
2657
-    }
2658
-
2659
-
2660
-    /**
2661
-     * This is just taking care of resending the registration confirmation
2662
-     *
2663
-     * @access protected
2664
-     * @return void
2665
-     */
2666
-    protected function _resend_registration()
2667
-    {
2668
-        $this->_process_resend_registration();
2669
-        $query_args = isset($this->_req_data['redirect_to'])
2670
-            ? array('action' => $this->_req_data['redirect_to'], '_REG_ID' => $this->_req_data['_REG_ID'])
2671
-            : array(
2672
-                'action' => 'default',
2673
-            );
2674
-        $this->_redirect_after_action(false, '', '', $query_args, true);
2675
-    }
2676
-
2677
-    /**
2678
-     * Creates a registration report, but accepts the name of a method to use for preparing the query parameters
2679
-     * to use when selecting registrations
2680
-     * @param string $method_name_for_getting_query_params the name of the method (on this class) to use for preparing
2681
-     *                                                     the query parameters from the request
2682
-     * @return void ends the request with a redirect or download
2683
-     */
2684
-    public function _registrations_report_base( $method_name_for_getting_query_params )
2685
-    {
2686
-        if ( ! defined('EE_USE_OLD_CSV_REPORT_CLASS')) {
2687
-            wp_redirect(EE_Admin_Page::add_query_args_and_nonce(array(
2688
-                'page'        => 'espresso_batch',
2689
-                'batch'       => 'file',
2690
-                'EVT_ID'      => isset($this->_req_data['EVT_ID']) ? $this->_req_data['EVT_ID'] : null,
2691
-                'filters'     => urlencode(
2692
-                    serialize(
2693
-                        call_user_func(
2694
-                            array( $this, $method_name_for_getting_query_params ),
2695
-                            EEH_Array::is_set(
2696
-                                $this->_req_data,
2697
-                                'filters',
2698
-                                array()
2699
-                            )
2700
-                        )
2701
-                    )
2702
-                ),
2703
-                'use_filters' => EEH_Array::is_set($this->_req_data, 'use_filters', false),
2704
-                'job_handler' => urlencode('EventEspressoBatchRequest\JobHandlers\RegistrationsReport'),
2705
-                'return_url'  => urlencode($this->_req_data['return_url']),
2706
-            )));
2707
-        } else {
2708
-            $new_request_args = array(
2709
-                'export' => 'report',
2710
-                'action' => 'registrations_report_for_event',
2711
-                'EVT_ID' => isset($this->_req_data['EVT_ID']) ? $this->_req_data['EVT_ID'] : null,
2712
-            );
2713
-            $this->_req_data = array_merge($this->_req_data, $new_request_args);
2714
-            if (is_readable(EE_CLASSES . 'EE_Export.class.php')) {
2715
-                require_once(EE_CLASSES . 'EE_Export.class.php');
2716
-                $EE_Export = EE_Export::instance($this->_req_data);
2717
-                $EE_Export->export();
2718
-            }
2719
-        }
2720
-    }
2721
-
2722
-
2723
-
2724
-    /**
2725
-     * Creates a registration report using only query parameters in the request
2726
-     * @return void
2727
-     */
2728
-    public function _registrations_report()
2729
-    {
2730
-        $this->_registrations_report_base( '_get_registration_query_parameters' );
2731
-    }
2732
-
2733
-
2734
-    public function _contact_list_export()
2735
-    {
2736
-        if (is_readable(EE_CLASSES . 'EE_Export.class.php')) {
2737
-            require_once(EE_CLASSES . 'EE_Export.class.php');
2738
-            $EE_Export = EE_Export::instance($this->_req_data);
2739
-            $EE_Export->export_attendees();
2740
-        }
2741
-    }
2742
-
2743
-
2744
-    public function _contact_list_report()
2745
-    {
2746
-        if ( ! defined('EE_USE_OLD_CSV_REPORT_CLASS')) {
2747
-            wp_redirect(EE_Admin_Page::add_query_args_and_nonce(array(
2748
-                'page'        => 'espresso_batch',
2749
-                'batch'       => 'file',
2750
-                'job_handler' => urlencode('EventEspressoBatchRequest\JobHandlers\AttendeesReport'),
2751
-                'return_url'  => urlencode($this->_req_data['return_url']),
2752
-            )));
2753
-        } else {
2754
-            if (is_readable(EE_CLASSES . 'EE_Export.class.php')) {
2755
-                require_once(EE_CLASSES . 'EE_Export.class.php');
2756
-                $EE_Export = EE_Export::instance($this->_req_data);
2757
-                $EE_Export->report_attendees();
2758
-            }
2759
-        }
2760
-    }
2761
-
2762
-
2763
-
2764
-
2765
-
2766
-    /***************************************        ATTENDEE DETAILS        ***************************************/
2767
-    /**
2768
-     * This duplicates the attendee object for the given incoming registration id and attendee_id.
2769
-     *
2770
-     * @return void
2771
-     */
2772
-    protected function _duplicate_attendee()
2773
-    {
2774
-        $action = ! empty($this->_req_data['return']) ? $this->_req_data['return'] : 'default';
2775
-        //verify we have necessary info
2776
-        if (empty($this->_req_data['_REG_ID'])) {
2777
-            EE_Error::add_error(__('Unable to create the contact for the registration because the required parameters are not present (_REG_ID )',
2778
-                'event_espresso'), __FILE__, __LINE__, __FUNCTION__);
2779
-            $query_args = array('action' => $action);
2780
-            $this->_redirect_after_action('', '', '', $query_args, true);
2781
-        }
2782
-        //okay necessary deets present... let's dupe the incoming attendee and attach to incoming registration.
2783
-        $registration = EEM_Registration::instance()->get_one_by_ID($this->_req_data['_REG_ID']);
2784
-        $attendee     = $registration->attendee();
2785
-        //remove relation of existing attendee on registration
2786
-        $registration->_remove_relation_to($attendee, 'Attendee');
2787
-        //new attendee
2788
-        $new_attendee = clone $attendee;
2789
-        $new_attendee->set('ATT_ID', 0);
2790
-        $new_attendee->save();
2791
-        //add new attendee to reg
2792
-        $registration->_add_relation_to($new_attendee, 'Attendee');
2793
-        EE_Error::add_success(__('New Contact record created.  Now make any edits you wish to make for this contact.',
2794
-            'event_espresso'));
2795
-        //redirect to edit page for attendee
2796
-        $query_args = array('post' => $new_attendee->ID(), 'action' => 'edit_attendee');
2797
-        $this->_redirect_after_action('', '', '', $query_args, true);
2798
-    }
2799
-
2800
-
2801
-    //related to cpt routes
2802
-    protected function _insert_update_cpt_item($post_id, $post)
2803
-    {
2804
-        $success  = true;
2805
-        $attendee = EEM_Attendee::instance()->get_one_by_ID($post_id);
2806
-        //for attendee updates
2807
-        if ($post->post_type = 'espresso_attendees' && ! empty($attendee)) {
2808
-            //note we should only be UPDATING attendees at this point.
2809
-            $updated_fields = array(
2810
-                'ATT_fname'     => $this->_req_data['ATT_fname'],
2811
-                'ATT_lname'     => $this->_req_data['ATT_lname'],
2812
-                'ATT_full_name' => $this->_req_data['ATT_fname'] . ' ' . $this->_req_data['ATT_lname'],
2813
-                'ATT_address'   => isset($this->_req_data['ATT_address']) ? $this->_req_data['ATT_address'] : '',
2814
-                'ATT_address2'  => isset($this->_req_data['ATT_address2']) ? $this->_req_data['ATT_address2'] : '',
2815
-                'ATT_city'      => isset($this->_req_data['ATT_city']) ? $this->_req_data['ATT_city'] : '',
2816
-                'STA_ID'        => isset($this->_req_data['STA_ID']) ? $this->_req_data['STA_ID'] : '',
2817
-                'CNT_ISO'       => isset($this->_req_data['CNT_ISO']) ? $this->_req_data['CNT_ISO'] : '',
2818
-                'ATT_zip'       => isset($this->_req_data['ATT_zip']) ? $this->_req_data['ATT_zip'] : '',
2819
-                'ATT_email'     => isset($this->_req_data['ATT_email']) ? $this->_req_data['ATT_email'] : '',
2820
-                'ATT_phone'     => isset($this->_req_data['ATT_phone']) ? $this->_req_data['ATT_phone'] : '',
2821
-            );
2822
-            foreach ($updated_fields as $field => $value) {
2823
-                $attendee->set($field, $value);
2824
-            }
2825
-            $success                   = $attendee->save();
2826
-            $attendee_update_callbacks = apply_filters('FHEE__Registrations_Admin_Page__insert_update_cpt_item__attendee_update',
2827
-                array());
2828
-            foreach ($attendee_update_callbacks as $a_callback) {
2829
-                if (false === call_user_func_array($a_callback, array($attendee, $this->_req_data))) {
2830
-                    throw new EE_Error(sprintf(__('The %s callback given for the "FHEE__Registrations_Admin_Page__insert_update_cpt_item__attendee_update" filter is not a valid callback.  Please check the spelling.',
2831
-                        'event_espresso'), $a_callback));
2832
-                }
2833
-            }
2834
-        }
2835
-        if ($success === false) {
2836
-            EE_Error::add_error(__('Something went wrong with updating the meta table data for the registration.',
2837
-                'event_espresso'), __FILE__, __FUNCTION__, __LINE__);
2838
-        }
2839
-    }
2840
-
2841
-
2842
-    public function trash_cpt_item($post_id)
2843
-    {
2844
-    }
2845
-
2846
-
2847
-    public function delete_cpt_item($post_id)
2848
-    {
2849
-    }
2850
-
2851
-
2852
-    public function restore_cpt_item($post_id)
2853
-    {
2854
-    }
2855
-
2856
-
2857
-    protected function _restore_cpt_item($post_id, $revision_id)
2858
-    {
2859
-    }
2860
-
2861
-
2862
-    public function attendee_editor_metaboxes()
2863
-    {
2864
-        $this->verify_cpt_object();
2865
-        remove_meta_box('postexcerpt', __('Excerpt'), 'post_excerpt_meta_box', $this->_cpt_routes[$this->_req_action],
2866
-            'normal', 'core');
2867
-        remove_meta_box('commentstatusdiv', $this->_cpt_routes[$this->_req_action], 'normal', 'core');
2868
-        if (post_type_supports('espresso_attendees', 'excerpt')) {
2869
-            add_meta_box('postexcerpt', __('Short Biography', 'event_espresso'), 'post_excerpt_meta_box',
2870
-                $this->_cpt_routes[$this->_req_action], 'normal');
2871
-        }
2872
-        if (post_type_supports('espresso_attendees', 'comments')) {
2873
-            add_meta_box('commentsdiv', __('Notes on the Contact', 'event_espresso'), 'post_comment_meta_box',
2874
-                $this->_cpt_routes[$this->_req_action], 'normal', 'core');
2875
-        }
2876
-        add_meta_box('attendee_contact_info', __('Contact Info', 'event_espresso'),
2877
-            array($this, 'attendee_contact_info'), $this->_cpt_routes[$this->_req_action], 'side', 'core');
2878
-        add_meta_box('attendee_details_address', __('Address Details', 'event_espresso'),
2879
-            array($this, 'attendee_address_details'), $this->_cpt_routes[$this->_req_action], 'normal', 'core');
2880
-        add_meta_box('attendee_registrations', __('Registrations for this Contact', 'event_espresso'),
2881
-            array($this, 'attendee_registrations_meta_box'), $this->_cpt_routes[$this->_req_action], 'normal', 'high');
2882
-    }
2883
-
2884
-
2885
-    /**
2886
-     * Metabox for attendee contact info
2887
-     *
2888
-     * @param  WP_Post $post wp post object
2889
-     * @return string        attendee contact info ( and form )
2890
-     */
2891
-    public function attendee_contact_info($post)
2892
-    {
2893
-        //get attendee object ( should already have it )
2894
-        $this->_template_args['attendee'] = $this->_cpt_model_obj;
2895
-        $template                         = REG_TEMPLATE_PATH . 'attendee_contact_info_metabox_content.template.php';
2896
-        EEH_Template::display_template($template, $this->_template_args);
2897
-    }
2898
-
2899
-
2900
-    /**
2901
-     * Metabox for attendee details
2902
-     *
2903
-     * @param  WP_Post $post wp post object
2904
-     * @return string        attendee address details (and form)
2905
-     */
2906
-    public function attendee_address_details($post)
2907
-    {
2908
-        //get attendee object (should already have it)
2909
-        $this->_template_args['attendee']     = $this->_cpt_model_obj;
2910
-        $this->_template_args['state_html']   = EEH_Form_Fields::generate_form_input(new EE_Question_Form_Input(EE_Question::new_instance(array(
2911
-            'QST_ID'           => 0,
2912
-            'QST_display_text' => __('State/Province', 'event_espresso'),
2913
-            'QST_system'       => 'admin-state',
2914
-        )), EE_Answer::new_instance(array(
2915
-            'ANS_ID'    => 0,
2916
-            'ANS_value' => $this->_cpt_model_obj->state_ID(),
2917
-        )), array(
2918
-            'input_id'       => 'STA_ID',
2919
-            'input_name'     => 'STA_ID',
2920
-            'input_prefix'   => '',
2921
-            'append_qstn_id' => false,
2922
-        )));
2923
-        $this->_template_args['country_html'] = EEH_Form_Fields::generate_form_input(new EE_Question_Form_Input(EE_Question::new_instance(array(
2924
-            'QST_ID'           => 0,
2925
-            'QST_display_text' => __('Country', 'event_espresso'),
2926
-            'QST_system'       => 'admin-country',
2927
-        )), EE_Answer::new_instance(array(
2928
-            'ANS_ID'    => 0,
2929
-            'ANS_value' => $this->_cpt_model_obj->country_ID(),
2930
-        )), array(
2931
-            'input_id'       => 'CNT_ISO',
2932
-            'input_name'     => 'CNT_ISO',
2933
-            'input_prefix'   => '',
2934
-            'append_qstn_id' => false,
2935
-        )));
2936
-        $template                             = REG_TEMPLATE_PATH . 'attendee_address_details_metabox_content.template.php';
2937
-        EEH_Template::display_template($template, $this->_template_args);
2938
-    }
2939
-
2940
-
2941
-    /**
2942
-     *        _attendee_details
2943
-     *
2944
-     * @access protected
2945
-     * @return void
2946
-     */
2947
-    public function attendee_registrations_meta_box($post)
2948
-    {
2949
-        $this->_template_args['attendee']      = $this->_cpt_model_obj;
2950
-        $this->_template_args['registrations'] = $this->_cpt_model_obj->get_many_related('Registration');
2951
-        $template                              = REG_TEMPLATE_PATH . 'attendee_registrations_main_meta_box.template.php';
2952
-        EEH_Template::display_template($template, $this->_template_args);
2953
-    }
2954
-
2955
-
2956
-    /**
2957
-     * add in the form fields for the attendee edit
2958
-     *
2959
-     * @param  WP_Post $post wp post object
2960
-     * @return string        html for new form.
2961
-     */
2962
-    public function after_title_form_fields($post)
2963
-    {
2964
-        if ($post->post_type == 'espresso_attendees') {
2965
-            $template                  = REG_TEMPLATE_PATH . 'attendee_details_after_title_form_fields.template.php';
2966
-            $template_args['attendee'] = $this->_cpt_model_obj;
2967
-            EEH_Template::display_template($template, $template_args);
2968
-        }
2969
-    }
2970
-
2971
-
2972
-    /**
2973
-     *        _trash_or_restore_attendee
2974
-     *
2975
-     * @param boolean $trash - whether to move item to trash (TRUE) or restore it (FALSE)
2976
-     * @access protected
2977
-     * @return void
2978
-     */
2979
-    protected function _trash_or_restore_attendees($trash = true)
2980
-    {
2981
-        do_action('AHEE_log', __FILE__, __FUNCTION__, '');
2982
-        $ATT_MDL = EEM_Attendee::instance();
2983
-        $success = 1;
2984
-        //Checkboxes
2985
-        if ( ! empty($this->_req_data['checkbox']) && is_array($this->_req_data['checkbox'])) {
2986
-            // if array has more than one element than success message should be plural
2987
-            $success = count($this->_req_data['checkbox']) > 1 ? 2 : 1;
2988
-            // cycle thru checkboxes
2989
-            while (list($ATT_ID, $value) = each($this->_req_data['checkbox'])) {
2990
-                $updated = $trash ? $ATT_MDL->update_by_ID(array('status' => 'trash'), $ATT_ID)
2991
-                    : $ATT_MDL->update_by_ID(array('status' => 'publish'), $ATT_ID);
2992
-                if ( ! $updated) {
2993
-                    $success = 0;
2994
-                }
2995
-            }
2996
-        } else {
2997
-            // grab single id and delete
2998
-            $ATT_ID = absint($this->_req_data['ATT_ID']);
2999
-            //get attendee
3000
-            $att     = $ATT_MDL->get_one_by_ID($ATT_ID);
3001
-            $updated = $trash ? $att->set_status('trash') : $att->set_status('publish');
3002
-            $updated = $att->save();
3003
-            if ( ! $updated) {
3004
-                $success = 0;
3005
-            }
3006
-        }
3007
-        $what        = $success > 1 ? __('Contacts', 'event_espresso') : __('Contact', 'event_espresso');
3008
-        $action_desc = $trash ? __('moved to the trash', 'event_espresso') : __('restored', 'event_espresso');
3009
-        $this->_redirect_after_action($success, $what, $action_desc, array('action' => 'contact_list'));
3010
-    }
2359
+		}
2360
+		$template_args = array(
2361
+			'title'                    => '',
2362
+			'content'                  => '',
2363
+			'step_button_text'         => '',
2364
+			'show_notification_toggle' => false,
2365
+		);
2366
+		//to indicate we're processing a new registration
2367
+		$hidden_fields = array(
2368
+			'processing_registration' => array(
2369
+				'type'  => 'hidden',
2370
+				'value' => 0,
2371
+			),
2372
+			'event_id'                => array(
2373
+				'type'  => 'hidden',
2374
+				'value' => $this->_reg_event->ID(),
2375
+			),
2376
+		);
2377
+		//if the cart is empty then we know we're at step one so we'll display ticket selector
2378
+		$cart = EE_Registry::instance()->SSN->cart();
2379
+		$step = ! $cart instanceof EE_Cart ? 'ticket' : 'questions';
2380
+		switch ($step) {
2381
+			case 'ticket' :
2382
+				$hidden_fields['processing_registration']['value'] = 1;
2383
+				$template_args['title']                            = __('Step One: Select the Ticket for this registration',
2384
+					'event_espresso');
2385
+				$template_args['content']                          = EED_Ticket_Selector::instance()->display_ticket_selector($this->_reg_event);
2386
+				$template_args['step_button_text']                 = __('Add Tickets and Continue to Registrant Details',
2387
+					'event_espresso');
2388
+				$template_args['show_notification_toggle']         = false;
2389
+				break;
2390
+			case 'questions' :
2391
+				$hidden_fields['processing_registration']['value'] = 2;
2392
+				$template_args['title']                            = __('Step Two: Add Registrant Details for this Registration',
2393
+					'event_espresso');
2394
+				//in theory we should be able to run EED_SPCO at this point because the cart should have been setup properly by the first process_reg_step run.
2395
+				$template_args['content']                  = EED_Single_Page_Checkout::registration_checkout_for_admin();
2396
+				$template_args['step_button_text']         = __('Save Registration and Continue to Details',
2397
+					'event_espresso');
2398
+				$template_args['show_notification_toggle'] = true;
2399
+				break;
2400
+		}
2401
+		$this->_set_add_edit_form_tags('process_reg_step',
2402
+			$hidden_fields); //we come back to the process_registration_step route.
2403
+		return EEH_Template::display_template(REG_TEMPLATE_PATH
2404
+											  . 'reg_admin_register_new_attendee_step_content.template.php',
2405
+			$template_args, true);
2406
+	}
2407
+
2408
+
2409
+	/**
2410
+	 *        set_reg_event
2411
+	 *
2412
+	 * @access private
2413
+	 * @return boolean
2414
+	 */
2415
+	private function _set_reg_event()
2416
+	{
2417
+		if (is_object($this->_reg_event)) {
2418
+			return true;
2419
+		}
2420
+		$EVT_ID = ( ! empty($this->_req_data['event_id'])) ? absint($this->_req_data['event_id']) : false;
2421
+		if ( ! $EVT_ID) {
2422
+			return false;
2423
+		}
2424
+		$this->_reg_event = EEM_Event::instance()->get_one_by_ID($EVT_ID);
2425
+		return true;
2426
+	}
2427
+
2428
+
2429
+	/**
2430
+	 * process_reg_step
2431
+	 *
2432
+	 * @access        public
2433
+	 * @return        string
2434
+	 * @throws \RuntimeException
2435
+	 * @throws \EE_Error
2436
+	 */
2437
+	public function process_reg_step()
2438
+	{
2439
+		EE_System::do_not_cache();
2440
+		$this->_set_reg_event();
2441
+		EE_Registry::instance()->REQ->set_espresso_page(true);
2442
+		EE_Registry::instance()->REQ->set('uts', time());
2443
+		//what step are we on?
2444
+		$cart = EE_Registry::instance()->SSN->cart();
2445
+		$step = ! $cart instanceof EE_Cart ? 'ticket' : 'questions';
2446
+		//if doing ajax then we need to verify the nonce
2447
+		if (defined('DOING_AJAX')) {
2448
+			$nonce = isset($this->_req_data[$this->_req_nonce])
2449
+				? sanitize_text_field($this->_req_data[$this->_req_nonce]) : '';
2450
+			$this->_verify_nonce($nonce, $this->_req_nonce);
2451
+		}
2452
+		switch ($step) {
2453
+			case 'ticket' :
2454
+				//process ticket selection
2455
+				$success = EED_Ticket_Selector::instance()->process_ticket_selections();
2456
+				if ($success) {
2457
+					EE_Error::add_success(esc_html__('Tickets Selected. Now complete the registration.',
2458
+						'event_espresso'));
2459
+				} else {
2460
+					$query_args['step_error'] = $this->_req_data['step_error'] = true;
2461
+				}
2462
+				if (defined('DOING_AJAX')) {
2463
+					$this->new_registration(); //display next step
2464
+				} else {
2465
+					$query_args = array(
2466
+						'action'                  => 'new_registration',
2467
+						'processing_registration' => 1,
2468
+						'event_id'                => $this->_reg_event->ID(),
2469
+						'uts'                     => time(),
2470
+					);
2471
+					$this->_redirect_after_action(false, '', '', $query_args, true);
2472
+				}
2473
+				break;
2474
+			case 'questions' :
2475
+				if ( ! isset($this->_req_data['txn_reg_status_change'], $this->_req_data['txn_reg_status_change']['send_notifications'])) {
2476
+					add_filter('FHEE__EED_Messages___maybe_registration__deliver_notifications', '__return_false', 15);
2477
+				}
2478
+				//process registration
2479
+				$transaction = EED_Single_Page_Checkout::instance()->process_registration_from_admin();
2480
+				if ($cart instanceof EE_Cart) {
2481
+					$grand_total = $cart->get_cart_grand_total();
2482
+					if ($grand_total instanceof EE_Line_Item) {
2483
+						$grand_total->save_this_and_descendants_to_txn();
2484
+					}
2485
+				}
2486
+				if ( ! $transaction instanceof EE_Transaction) {
2487
+					$query_args = array(
2488
+						'action'                  => 'new_registration',
2489
+						'processing_registration' => 2,
2490
+						'event_id'                => $this->_reg_event->ID(),
2491
+						'uts'                     => time(),
2492
+					);
2493
+					if (defined('DOING_AJAX')) {
2494
+						//display registration form again because there are errors (maybe validation?)
2495
+						$this->new_registration();
2496
+						return;
2497
+					} else {
2498
+						$this->_redirect_after_action(false, '', '', $query_args, true);
2499
+						return;
2500
+					}
2501
+				}
2502
+				// maybe update status, and make sure to save transaction if not done already
2503
+				if ( ! $transaction->update_status_based_on_total_paid()) {
2504
+					$transaction->save();
2505
+				}
2506
+				EE_Registry::instance()->SSN->clear_session(__CLASS__, __FUNCTION__);
2507
+				$this->_req_data = array();
2508
+				$query_args      = array(
2509
+					'action'        => 'redirect_to_txn',
2510
+					'TXN_ID'        => $transaction->ID(),
2511
+					'EVT_ID'        => $this->_reg_event->ID(),
2512
+					'event_name'    => urlencode($this->_reg_event->name()),
2513
+					'redirect_from' => 'new_registration',
2514
+				);
2515
+				$this->_redirect_after_action(false, '', '', $query_args, true);
2516
+				break;
2517
+		}
2518
+		//what are you looking here for?  Should be nothing to do at this point.
2519
+	}
2520
+
2521
+
2522
+	/**
2523
+	 * redirect_to_txn
2524
+	 *
2525
+	 * @access public
2526
+	 * @return void
2527
+	 */
2528
+	public function redirect_to_txn()
2529
+	{
2530
+		EE_System::do_not_cache();
2531
+		EE_Registry::instance()->SSN->clear_session(__CLASS__, __FUNCTION__);
2532
+		$query_args = array(
2533
+			'action' => 'view_transaction',
2534
+			'TXN_ID' => isset($this->_req_data['TXN_ID']) ? absint($this->_req_data['TXN_ID']) : 0,
2535
+			'page'   => 'espresso_transactions',
2536
+		);
2537
+		if (isset($this->_req_data['EVT_ID'], $this->_req_data['redirect_from'])) {
2538
+			$query_args['EVT_ID']        = $this->_req_data['EVT_ID'];
2539
+			$query_args['event_name']    = urlencode($this->_req_data['event_name']);
2540
+			$query_args['redirect_from'] = $this->_req_data['redirect_from'];
2541
+		}
2542
+		EE_Error::add_success(__('Registration Created.  Please review the transaction and add any payments as necessary',
2543
+			'event_espresso'));
2544
+		$this->_redirect_after_action(false, '', '', $query_args, true);
2545
+	}
2546
+
2547
+
2548
+	/**
2549
+	 *        generates HTML for the Attendee Contact List
2550
+	 *
2551
+	 * @access protected
2552
+	 * @return void
2553
+	 */
2554
+	protected function _attendee_contact_list_table()
2555
+	{
2556
+		do_action('AHEE_log', __FILE__, __FUNCTION__, '');
2557
+		$this->_search_btn_label = __('Contacts', 'event_espresso');
2558
+		$this->display_admin_list_table_page_with_no_sidebar();
2559
+	}
2560
+
2561
+
2562
+	/**
2563
+	 *        get_attendees
2564
+	 *
2565
+	 * @param bool $count whether to return count or data.
2566
+	 * @access public
2567
+	 * @return array
2568
+	 */
2569
+	public function get_attendees($per_page, $count = false, $trash = false)
2570
+	{
2571
+		do_action('AHEE_log', __FILE__, __FUNCTION__, '');
2572
+		require_once(REG_ADMIN . 'EE_Attendee_Contact_List_Table.class.php');
2573
+		$ATT_MDL                    = EEM_Attendee::instance();
2574
+		$this->_req_data['orderby'] = ! empty($this->_req_data['orderby']) ? $this->_req_data['orderby'] : '';
2575
+		switch ($this->_req_data['orderby']) {
2576
+			case 'ATT_ID':
2577
+				$orderby = 'ATT_ID';
2578
+				break;
2579
+			case 'ATT_fname':
2580
+				$orderby = 'ATT_fname';
2581
+				break;
2582
+			case 'ATT_email':
2583
+				$orderby = 'ATT_email';
2584
+				break;
2585
+			case 'ATT_city':
2586
+				$orderby = 'ATT_city';
2587
+				break;
2588
+			case 'STA_ID':
2589
+				$orderby = 'STA_ID';
2590
+				break;
2591
+			case 'CNT_ID':
2592
+				$orderby = 'CNT_ID';
2593
+				break;
2594
+			default:
2595
+				$orderby = 'ATT_lname';
2596
+		}
2597
+		$sort         = (isset($this->_req_data['order']) && ! empty($this->_req_data['order'])) ? $this->_req_data['order']
2598
+			: 'ASC';
2599
+		$current_page = isset($this->_req_data['paged']) && ! empty($this->_req_data['paged'])
2600
+			? $this->_req_data['paged'] : 1;
2601
+		$per_page     = isset($per_page) && ! empty($per_page) ? $per_page : 10;
2602
+		$per_page     = isset($this->_req_data['perpage']) && ! empty($this->_req_data['perpage'])
2603
+			? $this->_req_data['perpage'] : $per_page;
2604
+		$_where       = array();
2605
+		if ( ! empty($this->_req_data['s'])) {
2606
+			$sstr         = '%' . $this->_req_data['s'] . '%';
2607
+			$_where['OR'] = array(
2608
+				'Registration.Event.EVT_name'       => array('LIKE', $sstr),
2609
+				'Registration.Event.EVT_desc'       => array('LIKE', $sstr),
2610
+				'Registration.Event.EVT_short_desc' => array('LIKE', $sstr),
2611
+				'ATT_fname'                         => array('LIKE', $sstr),
2612
+				'ATT_lname'                         => array('LIKE', $sstr),
2613
+				'ATT_short_bio'                     => array('LIKE', $sstr),
2614
+				'ATT_email'                         => array('LIKE', $sstr),
2615
+				'ATT_address'                       => array('LIKE', $sstr),
2616
+				'ATT_address2'                      => array('LIKE', $sstr),
2617
+				'ATT_city'                          => array('LIKE', $sstr),
2618
+				'Country.CNT_name'                  => array('LIKE', $sstr),
2619
+				'State.STA_name'                    => array('LIKE', $sstr),
2620
+				'ATT_phone'                         => array('LIKE', $sstr),
2621
+				'Registration.REG_final_price'      => array('LIKE', $sstr),
2622
+				'Registration.REG_code'             => array('LIKE', $sstr),
2623
+				'Registration.REG_count'            => array('LIKE', $sstr),
2624
+				'Registration.REG_group_size'       => array('LIKE', $sstr),
2625
+			);
2626
+		}
2627
+		$offset = ($current_page - 1) * $per_page;
2628
+		$limit  = $count ? null : array($offset, $per_page);
2629
+		if ($trash) {
2630
+			$_where['status'] = array('!=', 'publish');
2631
+			$all_attendees    = $count
2632
+				? $ATT_MDL->count(array(
2633
+					$_where,
2634
+					'order_by' => array($orderby => $sort),
2635
+					'limit'    => $limit,
2636
+				), 'ATT_ID', true)
2637
+				: $ATT_MDL->get_all(array(
2638
+					$_where,
2639
+					'order_by' => array($orderby => $sort),
2640
+					'limit'    => $limit,
2641
+				));
2642
+		} else {
2643
+			$_where['status'] = array('IN', array('publish'));
2644
+			$all_attendees    = $count
2645
+				? $ATT_MDL->count(array(
2646
+					$_where,
2647
+					'order_by' => array($orderby => $sort),
2648
+					'limit'    => $limit,
2649
+				), 'ATT_ID', true)
2650
+				: $ATT_MDL->get_all(array(
2651
+					$_where,
2652
+					'order_by' => array($orderby => $sort),
2653
+					'limit'    => $limit,
2654
+				));
2655
+		}
2656
+		return $all_attendees;
2657
+	}
2658
+
2659
+
2660
+	/**
2661
+	 * This is just taking care of resending the registration confirmation
2662
+	 *
2663
+	 * @access protected
2664
+	 * @return void
2665
+	 */
2666
+	protected function _resend_registration()
2667
+	{
2668
+		$this->_process_resend_registration();
2669
+		$query_args = isset($this->_req_data['redirect_to'])
2670
+			? array('action' => $this->_req_data['redirect_to'], '_REG_ID' => $this->_req_data['_REG_ID'])
2671
+			: array(
2672
+				'action' => 'default',
2673
+			);
2674
+		$this->_redirect_after_action(false, '', '', $query_args, true);
2675
+	}
2676
+
2677
+	/**
2678
+	 * Creates a registration report, but accepts the name of a method to use for preparing the query parameters
2679
+	 * to use when selecting registrations
2680
+	 * @param string $method_name_for_getting_query_params the name of the method (on this class) to use for preparing
2681
+	 *                                                     the query parameters from the request
2682
+	 * @return void ends the request with a redirect or download
2683
+	 */
2684
+	public function _registrations_report_base( $method_name_for_getting_query_params )
2685
+	{
2686
+		if ( ! defined('EE_USE_OLD_CSV_REPORT_CLASS')) {
2687
+			wp_redirect(EE_Admin_Page::add_query_args_and_nonce(array(
2688
+				'page'        => 'espresso_batch',
2689
+				'batch'       => 'file',
2690
+				'EVT_ID'      => isset($this->_req_data['EVT_ID']) ? $this->_req_data['EVT_ID'] : null,
2691
+				'filters'     => urlencode(
2692
+					serialize(
2693
+						call_user_func(
2694
+							array( $this, $method_name_for_getting_query_params ),
2695
+							EEH_Array::is_set(
2696
+								$this->_req_data,
2697
+								'filters',
2698
+								array()
2699
+							)
2700
+						)
2701
+					)
2702
+				),
2703
+				'use_filters' => EEH_Array::is_set($this->_req_data, 'use_filters', false),
2704
+				'job_handler' => urlencode('EventEspressoBatchRequest\JobHandlers\RegistrationsReport'),
2705
+				'return_url'  => urlencode($this->_req_data['return_url']),
2706
+			)));
2707
+		} else {
2708
+			$new_request_args = array(
2709
+				'export' => 'report',
2710
+				'action' => 'registrations_report_for_event',
2711
+				'EVT_ID' => isset($this->_req_data['EVT_ID']) ? $this->_req_data['EVT_ID'] : null,
2712
+			);
2713
+			$this->_req_data = array_merge($this->_req_data, $new_request_args);
2714
+			if (is_readable(EE_CLASSES . 'EE_Export.class.php')) {
2715
+				require_once(EE_CLASSES . 'EE_Export.class.php');
2716
+				$EE_Export = EE_Export::instance($this->_req_data);
2717
+				$EE_Export->export();
2718
+			}
2719
+		}
2720
+	}
2721
+
2722
+
2723
+
2724
+	/**
2725
+	 * Creates a registration report using only query parameters in the request
2726
+	 * @return void
2727
+	 */
2728
+	public function _registrations_report()
2729
+	{
2730
+		$this->_registrations_report_base( '_get_registration_query_parameters' );
2731
+	}
2732
+
2733
+
2734
+	public function _contact_list_export()
2735
+	{
2736
+		if (is_readable(EE_CLASSES . 'EE_Export.class.php')) {
2737
+			require_once(EE_CLASSES . 'EE_Export.class.php');
2738
+			$EE_Export = EE_Export::instance($this->_req_data);
2739
+			$EE_Export->export_attendees();
2740
+		}
2741
+	}
2742
+
2743
+
2744
+	public function _contact_list_report()
2745
+	{
2746
+		if ( ! defined('EE_USE_OLD_CSV_REPORT_CLASS')) {
2747
+			wp_redirect(EE_Admin_Page::add_query_args_and_nonce(array(
2748
+				'page'        => 'espresso_batch',
2749
+				'batch'       => 'file',
2750
+				'job_handler' => urlencode('EventEspressoBatchRequest\JobHandlers\AttendeesReport'),
2751
+				'return_url'  => urlencode($this->_req_data['return_url']),
2752
+			)));
2753
+		} else {
2754
+			if (is_readable(EE_CLASSES . 'EE_Export.class.php')) {
2755
+				require_once(EE_CLASSES . 'EE_Export.class.php');
2756
+				$EE_Export = EE_Export::instance($this->_req_data);
2757
+				$EE_Export->report_attendees();
2758
+			}
2759
+		}
2760
+	}
2761
+
2762
+
2763
+
2764
+
2765
+
2766
+	/***************************************        ATTENDEE DETAILS        ***************************************/
2767
+	/**
2768
+	 * This duplicates the attendee object for the given incoming registration id and attendee_id.
2769
+	 *
2770
+	 * @return void
2771
+	 */
2772
+	protected function _duplicate_attendee()
2773
+	{
2774
+		$action = ! empty($this->_req_data['return']) ? $this->_req_data['return'] : 'default';
2775
+		//verify we have necessary info
2776
+		if (empty($this->_req_data['_REG_ID'])) {
2777
+			EE_Error::add_error(__('Unable to create the contact for the registration because the required parameters are not present (_REG_ID )',
2778
+				'event_espresso'), __FILE__, __LINE__, __FUNCTION__);
2779
+			$query_args = array('action' => $action);
2780
+			$this->_redirect_after_action('', '', '', $query_args, true);
2781
+		}
2782
+		//okay necessary deets present... let's dupe the incoming attendee and attach to incoming registration.
2783
+		$registration = EEM_Registration::instance()->get_one_by_ID($this->_req_data['_REG_ID']);
2784
+		$attendee     = $registration->attendee();
2785
+		//remove relation of existing attendee on registration
2786
+		$registration->_remove_relation_to($attendee, 'Attendee');
2787
+		//new attendee
2788
+		$new_attendee = clone $attendee;
2789
+		$new_attendee->set('ATT_ID', 0);
2790
+		$new_attendee->save();
2791
+		//add new attendee to reg
2792
+		$registration->_add_relation_to($new_attendee, 'Attendee');
2793
+		EE_Error::add_success(__('New Contact record created.  Now make any edits you wish to make for this contact.',
2794
+			'event_espresso'));
2795
+		//redirect to edit page for attendee
2796
+		$query_args = array('post' => $new_attendee->ID(), 'action' => 'edit_attendee');
2797
+		$this->_redirect_after_action('', '', '', $query_args, true);
2798
+	}
2799
+
2800
+
2801
+	//related to cpt routes
2802
+	protected function _insert_update_cpt_item($post_id, $post)
2803
+	{
2804
+		$success  = true;
2805
+		$attendee = EEM_Attendee::instance()->get_one_by_ID($post_id);
2806
+		//for attendee updates
2807
+		if ($post->post_type = 'espresso_attendees' && ! empty($attendee)) {
2808
+			//note we should only be UPDATING attendees at this point.
2809
+			$updated_fields = array(
2810
+				'ATT_fname'     => $this->_req_data['ATT_fname'],
2811
+				'ATT_lname'     => $this->_req_data['ATT_lname'],
2812
+				'ATT_full_name' => $this->_req_data['ATT_fname'] . ' ' . $this->_req_data['ATT_lname'],
2813
+				'ATT_address'   => isset($this->_req_data['ATT_address']) ? $this->_req_data['ATT_address'] : '',
2814
+				'ATT_address2'  => isset($this->_req_data['ATT_address2']) ? $this->_req_data['ATT_address2'] : '',
2815
+				'ATT_city'      => isset($this->_req_data['ATT_city']) ? $this->_req_data['ATT_city'] : '',
2816
+				'STA_ID'        => isset($this->_req_data['STA_ID']) ? $this->_req_data['STA_ID'] : '',
2817
+				'CNT_ISO'       => isset($this->_req_data['CNT_ISO']) ? $this->_req_data['CNT_ISO'] : '',
2818
+				'ATT_zip'       => isset($this->_req_data['ATT_zip']) ? $this->_req_data['ATT_zip'] : '',
2819
+				'ATT_email'     => isset($this->_req_data['ATT_email']) ? $this->_req_data['ATT_email'] : '',
2820
+				'ATT_phone'     => isset($this->_req_data['ATT_phone']) ? $this->_req_data['ATT_phone'] : '',
2821
+			);
2822
+			foreach ($updated_fields as $field => $value) {
2823
+				$attendee->set($field, $value);
2824
+			}
2825
+			$success                   = $attendee->save();
2826
+			$attendee_update_callbacks = apply_filters('FHEE__Registrations_Admin_Page__insert_update_cpt_item__attendee_update',
2827
+				array());
2828
+			foreach ($attendee_update_callbacks as $a_callback) {
2829
+				if (false === call_user_func_array($a_callback, array($attendee, $this->_req_data))) {
2830
+					throw new EE_Error(sprintf(__('The %s callback given for the "FHEE__Registrations_Admin_Page__insert_update_cpt_item__attendee_update" filter is not a valid callback.  Please check the spelling.',
2831
+						'event_espresso'), $a_callback));
2832
+				}
2833
+			}
2834
+		}
2835
+		if ($success === false) {
2836
+			EE_Error::add_error(__('Something went wrong with updating the meta table data for the registration.',
2837
+				'event_espresso'), __FILE__, __FUNCTION__, __LINE__);
2838
+		}
2839
+	}
2840
+
2841
+
2842
+	public function trash_cpt_item($post_id)
2843
+	{
2844
+	}
2845
+
2846
+
2847
+	public function delete_cpt_item($post_id)
2848
+	{
2849
+	}
2850
+
2851
+
2852
+	public function restore_cpt_item($post_id)
2853
+	{
2854
+	}
2855
+
2856
+
2857
+	protected function _restore_cpt_item($post_id, $revision_id)
2858
+	{
2859
+	}
2860
+
2861
+
2862
+	public function attendee_editor_metaboxes()
2863
+	{
2864
+		$this->verify_cpt_object();
2865
+		remove_meta_box('postexcerpt', __('Excerpt'), 'post_excerpt_meta_box', $this->_cpt_routes[$this->_req_action],
2866
+			'normal', 'core');
2867
+		remove_meta_box('commentstatusdiv', $this->_cpt_routes[$this->_req_action], 'normal', 'core');
2868
+		if (post_type_supports('espresso_attendees', 'excerpt')) {
2869
+			add_meta_box('postexcerpt', __('Short Biography', 'event_espresso'), 'post_excerpt_meta_box',
2870
+				$this->_cpt_routes[$this->_req_action], 'normal');
2871
+		}
2872
+		if (post_type_supports('espresso_attendees', 'comments')) {
2873
+			add_meta_box('commentsdiv', __('Notes on the Contact', 'event_espresso'), 'post_comment_meta_box',
2874
+				$this->_cpt_routes[$this->_req_action], 'normal', 'core');
2875
+		}
2876
+		add_meta_box('attendee_contact_info', __('Contact Info', 'event_espresso'),
2877
+			array($this, 'attendee_contact_info'), $this->_cpt_routes[$this->_req_action], 'side', 'core');
2878
+		add_meta_box('attendee_details_address', __('Address Details', 'event_espresso'),
2879
+			array($this, 'attendee_address_details'), $this->_cpt_routes[$this->_req_action], 'normal', 'core');
2880
+		add_meta_box('attendee_registrations', __('Registrations for this Contact', 'event_espresso'),
2881
+			array($this, 'attendee_registrations_meta_box'), $this->_cpt_routes[$this->_req_action], 'normal', 'high');
2882
+	}
2883
+
2884
+
2885
+	/**
2886
+	 * Metabox for attendee contact info
2887
+	 *
2888
+	 * @param  WP_Post $post wp post object
2889
+	 * @return string        attendee contact info ( and form )
2890
+	 */
2891
+	public function attendee_contact_info($post)
2892
+	{
2893
+		//get attendee object ( should already have it )
2894
+		$this->_template_args['attendee'] = $this->_cpt_model_obj;
2895
+		$template                         = REG_TEMPLATE_PATH . 'attendee_contact_info_metabox_content.template.php';
2896
+		EEH_Template::display_template($template, $this->_template_args);
2897
+	}
2898
+
2899
+
2900
+	/**
2901
+	 * Metabox for attendee details
2902
+	 *
2903
+	 * @param  WP_Post $post wp post object
2904
+	 * @return string        attendee address details (and form)
2905
+	 */
2906
+	public function attendee_address_details($post)
2907
+	{
2908
+		//get attendee object (should already have it)
2909
+		$this->_template_args['attendee']     = $this->_cpt_model_obj;
2910
+		$this->_template_args['state_html']   = EEH_Form_Fields::generate_form_input(new EE_Question_Form_Input(EE_Question::new_instance(array(
2911
+			'QST_ID'           => 0,
2912
+			'QST_display_text' => __('State/Province', 'event_espresso'),
2913
+			'QST_system'       => 'admin-state',
2914
+		)), EE_Answer::new_instance(array(
2915
+			'ANS_ID'    => 0,
2916
+			'ANS_value' => $this->_cpt_model_obj->state_ID(),
2917
+		)), array(
2918
+			'input_id'       => 'STA_ID',
2919
+			'input_name'     => 'STA_ID',
2920
+			'input_prefix'   => '',
2921
+			'append_qstn_id' => false,
2922
+		)));
2923
+		$this->_template_args['country_html'] = EEH_Form_Fields::generate_form_input(new EE_Question_Form_Input(EE_Question::new_instance(array(
2924
+			'QST_ID'           => 0,
2925
+			'QST_display_text' => __('Country', 'event_espresso'),
2926
+			'QST_system'       => 'admin-country',
2927
+		)), EE_Answer::new_instance(array(
2928
+			'ANS_ID'    => 0,
2929
+			'ANS_value' => $this->_cpt_model_obj->country_ID(),
2930
+		)), array(
2931
+			'input_id'       => 'CNT_ISO',
2932
+			'input_name'     => 'CNT_ISO',
2933
+			'input_prefix'   => '',
2934
+			'append_qstn_id' => false,
2935
+		)));
2936
+		$template                             = REG_TEMPLATE_PATH . 'attendee_address_details_metabox_content.template.php';
2937
+		EEH_Template::display_template($template, $this->_template_args);
2938
+	}
2939
+
2940
+
2941
+	/**
2942
+	 *        _attendee_details
2943
+	 *
2944
+	 * @access protected
2945
+	 * @return void
2946
+	 */
2947
+	public function attendee_registrations_meta_box($post)
2948
+	{
2949
+		$this->_template_args['attendee']      = $this->_cpt_model_obj;
2950
+		$this->_template_args['registrations'] = $this->_cpt_model_obj->get_many_related('Registration');
2951
+		$template                              = REG_TEMPLATE_PATH . 'attendee_registrations_main_meta_box.template.php';
2952
+		EEH_Template::display_template($template, $this->_template_args);
2953
+	}
2954
+
2955
+
2956
+	/**
2957
+	 * add in the form fields for the attendee edit
2958
+	 *
2959
+	 * @param  WP_Post $post wp post object
2960
+	 * @return string        html for new form.
2961
+	 */
2962
+	public function after_title_form_fields($post)
2963
+	{
2964
+		if ($post->post_type == 'espresso_attendees') {
2965
+			$template                  = REG_TEMPLATE_PATH . 'attendee_details_after_title_form_fields.template.php';
2966
+			$template_args['attendee'] = $this->_cpt_model_obj;
2967
+			EEH_Template::display_template($template, $template_args);
2968
+		}
2969
+	}
2970
+
2971
+
2972
+	/**
2973
+	 *        _trash_or_restore_attendee
2974
+	 *
2975
+	 * @param boolean $trash - whether to move item to trash (TRUE) or restore it (FALSE)
2976
+	 * @access protected
2977
+	 * @return void
2978
+	 */
2979
+	protected function _trash_or_restore_attendees($trash = true)
2980
+	{
2981
+		do_action('AHEE_log', __FILE__, __FUNCTION__, '');
2982
+		$ATT_MDL = EEM_Attendee::instance();
2983
+		$success = 1;
2984
+		//Checkboxes
2985
+		if ( ! empty($this->_req_data['checkbox']) && is_array($this->_req_data['checkbox'])) {
2986
+			// if array has more than one element than success message should be plural
2987
+			$success = count($this->_req_data['checkbox']) > 1 ? 2 : 1;
2988
+			// cycle thru checkboxes
2989
+			while (list($ATT_ID, $value) = each($this->_req_data['checkbox'])) {
2990
+				$updated = $trash ? $ATT_MDL->update_by_ID(array('status' => 'trash'), $ATT_ID)
2991
+					: $ATT_MDL->update_by_ID(array('status' => 'publish'), $ATT_ID);
2992
+				if ( ! $updated) {
2993
+					$success = 0;
2994
+				}
2995
+			}
2996
+		} else {
2997
+			// grab single id and delete
2998
+			$ATT_ID = absint($this->_req_data['ATT_ID']);
2999
+			//get attendee
3000
+			$att     = $ATT_MDL->get_one_by_ID($ATT_ID);
3001
+			$updated = $trash ? $att->set_status('trash') : $att->set_status('publish');
3002
+			$updated = $att->save();
3003
+			if ( ! $updated) {
3004
+				$success = 0;
3005
+			}
3006
+		}
3007
+		$what        = $success > 1 ? __('Contacts', 'event_espresso') : __('Contact', 'event_espresso');
3008
+		$action_desc = $trash ? __('moved to the trash', 'event_espresso') : __('restored', 'event_espresso');
3009
+		$this->_redirect_after_action($success, $what, $action_desc, array('action' => 'contact_list'));
3010
+	}
3011 3011
 
3012 3012
 }
3013 3013
 
Please login to merge, or discard this patch.
Spacing   +82 added lines, -82 removed lines patch added patch discarded remove patch
@@ -569,11 +569,11 @@  discard block
 block discarded – undo
569 569
     {
570 570
         //style
571 571
         //wp_register_style('espresso_attendees', ATT_ASSETS_URL . 'espresso_attendees_admin.css', array(), EVENT_ESPRESSO_VERSION );
572
-        wp_register_style('espresso_reg', REG_ASSETS_URL . 'espresso_registrations_admin.css', array('ee-admin-css'),
572
+        wp_register_style('espresso_reg', REG_ASSETS_URL.'espresso_registrations_admin.css', array('ee-admin-css'),
573 573
             EVENT_ESPRESSO_VERSION);
574 574
         wp_enqueue_style('espresso_reg');
575 575
         //script
576
-        wp_register_script('espresso_reg', REG_ASSETS_URL . 'espresso_registrations_admin.js',
576
+        wp_register_script('espresso_reg', REG_ASSETS_URL.'espresso_registrations_admin.js',
577 577
             array('jquery-ui-datepicker', 'jquery-ui-draggable', 'ee_admin_js'), EVENT_ESPRESSO_VERSION, true);
578 578
         wp_enqueue_script('espresso_reg');
579 579
     }
@@ -604,7 +604,7 @@  discard block
 block discarded – undo
604 604
     public function load_scripts_styles_contact_list()
605 605
     {
606 606
         wp_deregister_style('espresso_reg');
607
-        wp_register_style('espresso_att', REG_ASSETS_URL . 'espresso_attendees_admin.css', array('ee-admin-css'),
607
+        wp_register_style('espresso_att', REG_ASSETS_URL.'espresso_attendees_admin.css', array('ee-admin-css'),
608 608
             EVENT_ESPRESSO_VERSION);
609 609
         wp_enqueue_style('espresso_att');
610 610
     }
@@ -612,7 +612,7 @@  discard block
 block discarded – undo
612 612
 
613 613
     public function load_scripts_styles_new_registration()
614 614
     {
615
-        wp_register_script('ee-spco-for-admin', REG_ASSETS_URL . 'spco_for_admin.js', array('underscore', 'jquery'),
615
+        wp_register_script('ee-spco-for-admin', REG_ASSETS_URL.'spco_for_admin.js', array('underscore', 'jquery'),
616 616
             EVENT_ESPRESSO_VERSION, true);
617 617
         wp_enqueue_script('ee-spco-for-admin');
618 618
         add_filter('FHEE__EED_Ticket_Selector__load_tckt_slctr_assets', '__return_true');
@@ -722,7 +722,7 @@  discard block
 block discarded – undo
722 722
                     'trash_registrations' => __('Trash Registrations', 'event_espresso'),
723 723
                 ),
724 724
             );
725
-            $this->_views['trash']      = array(
725
+            $this->_views['trash'] = array(
726 726
                 'slug'        => 'trash',
727 727
                 'label'       => __('Trash', 'event_espresso'),
728 728
                 'count'       => 0,
@@ -807,31 +807,31 @@  discard block
 block discarded – undo
807 807
         }
808 808
         $sc_items = array(
809 809
             'approved_status'   => array(
810
-                'class' => 'ee-status-legend ee-status-legend-' . EEM_Registration::status_id_approved,
810
+                'class' => 'ee-status-legend ee-status-legend-'.EEM_Registration::status_id_approved,
811 811
                 'desc'  => EEH_Template::pretty_status(EEM_Registration::status_id_approved, false, 'sentence'),
812 812
             ),
813 813
             'pending_status'    => array(
814
-                'class' => 'ee-status-legend ee-status-legend-' . EEM_Registration::status_id_pending_payment,
814
+                'class' => 'ee-status-legend ee-status-legend-'.EEM_Registration::status_id_pending_payment,
815 815
                 'desc'  => EEH_Template::pretty_status(EEM_Registration::status_id_pending_payment, false, 'sentence'),
816 816
             ),
817 817
             'wait_list'         => array(
818
-                'class' => 'ee-status-legend ee-status-legend-' . EEM_Registration::status_id_wait_list,
818
+                'class' => 'ee-status-legend ee-status-legend-'.EEM_Registration::status_id_wait_list,
819 819
                 'desc'  => EEH_Template::pretty_status(EEM_Registration::status_id_wait_list, false, 'sentence'),
820 820
             ),
821 821
             'incomplete_status' => array(
822
-                'class' => 'ee-status-legend ee-status-legend-' . EEM_Registration::status_id_incomplete,
822
+                'class' => 'ee-status-legend ee-status-legend-'.EEM_Registration::status_id_incomplete,
823 823
                 'desc'  => EEH_Template::pretty_status(EEM_Registration::status_id_incomplete, false, 'sentence'),
824 824
             ),
825 825
             'not_approved'      => array(
826
-                'class' => 'ee-status-legend ee-status-legend-' . EEM_Registration::status_id_not_approved,
826
+                'class' => 'ee-status-legend ee-status-legend-'.EEM_Registration::status_id_not_approved,
827 827
                 'desc'  => EEH_Template::pretty_status(EEM_Registration::status_id_not_approved, false, 'sentence'),
828 828
             ),
829 829
             'declined_status'   => array(
830
-                'class' => 'ee-status-legend ee-status-legend-' . EEM_Registration::status_id_declined,
830
+                'class' => 'ee-status-legend ee-status-legend-'.EEM_Registration::status_id_declined,
831 831
                 'desc'  => EEH_Template::pretty_status(EEM_Registration::status_id_declined, false, 'sentence'),
832 832
             ),
833 833
             'cancelled_status'  => array(
834
-                'class' => 'ee-status-legend ee-status-legend-' . EEM_Registration::status_id_cancelled,
834
+                'class' => 'ee-status-legend ee-status-legend-'.EEM_Registration::status_id_cancelled,
835 835
                 'desc'  => EEH_Template::pretty_status(EEM_Registration::status_id_cancelled, false, 'sentence'),
836 836
             ),
837 837
         );
@@ -852,17 +852,17 @@  discard block
 block discarded – undo
852 852
             if (EE_Registry::instance()->CAP->current_user_can('ee_edit_registrations',
853 853
                 'espresso_registrations_new_registration', $EVT_ID)
854 854
             ) {
855
-                $this->_admin_page_title .= ' ' . $this->get_action_link_or_button('new_registration', 'add-registrant',
855
+                $this->_admin_page_title .= ' '.$this->get_action_link_or_button('new_registration', 'add-registrant',
856 856
                         array('event_id' => $EVT_ID), 'add-new-h2');
857 857
             }
858 858
             $event = EEM_Event::instance()->get_one_by_ID($EVT_ID);
859 859
             if ($event instanceof EE_Event) {
860 860
                 $this->_template_args['admin_page_header'] = sprintf(__('%s Viewing registrations for the event: %s%s',
861 861
                     'event_espresso'), '<h3 style="line-height:1.5em;">',
862
-                    '<br /><a href="' . EE_Admin_Page::add_query_args_and_nonce(array(
862
+                    '<br /><a href="'.EE_Admin_Page::add_query_args_and_nonce(array(
863 863
                         'action' => 'edit',
864 864
                         'post'   => $event->ID(),
865
-                    ), EVENTS_ADMIN_URL) . '">&nbsp;' . $event->get('EVT_name') . '&nbsp;</a>&nbsp;', '</h3>');
865
+                    ), EVENTS_ADMIN_URL).'">&nbsp;'.$event->get('EVT_name').'&nbsp;</a>&nbsp;', '</h3>');
866 866
             }
867 867
             $DTT_ID   = ! empty($this->_req_data['datetime_id']) ? absint($this->_req_data['datetime_id']) : 0;
868 868
             $datetime = EEM_Datetime::instance()->get_one_by_ID($DTT_ID);
@@ -871,7 +871,7 @@  discard block
 block discarded – undo
871 871
                 $this->_template_args['admin_page_header'] .= ' &nbsp;<span class="drk-grey-text">';
872 872
                 $this->_template_args['admin_page_header'] .= '<span class="dashicons dashicons-calendar"></span>';
873 873
                 $this->_template_args['admin_page_header'] .= $datetime->name();
874
-                $this->_template_args['admin_page_header'] .= ' ( ' . $datetime->start_date() . ' )';
874
+                $this->_template_args['admin_page_header'] .= ' ( '.$datetime->start_date().' )';
875 875
                 $this->_template_args['admin_page_header'] .= '</span></h3>';
876 876
             }
877 877
         }
@@ -921,10 +921,10 @@  discard block
 block discarded – undo
921 921
         $this_month = false,
922 922
         $today = false
923 923
     ) {
924
-        if( $this_month ) {
924
+        if ($this_month) {
925 925
             $this->_req_data['status'] = 'month';
926 926
         }
927
-        if( $today ) {
927
+        if ($today) {
928 928
             $this->_req_data['status'] = 'today';
929 929
         }
930 930
         $query_params = $this->_get_registration_query_parameters($this->_req_data, $per_page, $count);
@@ -995,7 +995,7 @@  discard block
 block discarded – undo
995 995
     protected function _add_category_id_to_where_conditions(array $request)
996 996
     {
997 997
         $where = array();
998
-        if ( ! empty($request['EVT_CAT']) && (int)$request['EVT_CAT'] !== -1) {
998
+        if ( ! empty($request['EVT_CAT']) && (int) $request['EVT_CAT'] !== -1) {
999 999
             $where['Event.Term_Taxonomy.term_id'] = absint($request['EVT_CAT']);
1000 1000
         }
1001 1001
         return $where;
@@ -1014,7 +1014,7 @@  discard block
 block discarded – undo
1014 1014
         if ( ! empty($request['datetime_id'])) {
1015 1015
             $where['Ticket.Datetime.DTT_ID'] = absint($request['datetime_id']);
1016 1016
         }
1017
-        if( ! empty($request['DTT_ID'])){
1017
+        if ( ! empty($request['DTT_ID'])) {
1018 1018
             $where['Ticket.Datetime.DTT_ID'] = absint($request['DTT_ID']);
1019 1019
         }
1020 1020
         return $where;
@@ -1030,7 +1030,7 @@  discard block
 block discarded – undo
1030 1030
     protected function _add_registration_status_to_where_conditions(array $request)
1031 1031
     {
1032 1032
         $where = array();
1033
-        $view  = EEH_Array::is_set( $request, 'status', '' );
1033
+        $view  = EEH_Array::is_set($request, 'status', '');
1034 1034
         $registration_status = ! empty($request['_reg_status'])
1035 1035
             ? sanitize_text_field($request['_reg_status'])
1036 1036
             : '';
@@ -1065,7 +1065,7 @@  discard block
 block discarded – undo
1065 1065
     protected function _add_date_to_where_conditions(array $request)
1066 1066
     {
1067 1067
         $where = array();
1068
-        $view  = EEH_Array::is_set( $request, 'status', '' );
1068
+        $view  = EEH_Array::is_set($request, 'status', '');
1069 1069
         $month_range             = ! empty($request['month_range'])
1070 1070
             ? sanitize_text_field($request['month_range'])
1071 1071
             : '';
@@ -1079,12 +1079,12 @@  discard block
 block discarded – undo
1079 1079
                 array(
1080 1080
                     EEM_Registration::instance()->convert_datetime_for_query(
1081 1081
                         'REG_date',
1082
-                        $now . ' 00:00:00',
1082
+                        $now.' 00:00:00',
1083 1083
                         'Y-m-d H:i:s'
1084 1084
                     ),
1085 1085
                     EEM_Registration::instance()->convert_datetime_for_query(
1086 1086
                         'REG_date',
1087
-                        $now . ' 23:59:59',
1087
+                        $now.' 23:59:59',
1088 1088
                         'Y-m-d H:i:s'
1089 1089
                     ),
1090 1090
                 ),
@@ -1097,12 +1097,12 @@  discard block
 block discarded – undo
1097 1097
                 array(
1098 1098
                     EEM_Registration::instance()->convert_datetime_for_query(
1099 1099
                         'REG_date',
1100
-                        $current_year_and_month . '-01 00:00:00',
1100
+                        $current_year_and_month.'-01 00:00:00',
1101 1101
                         'Y-m-d H:i:s'
1102 1102
                     ),
1103 1103
                     EEM_Registration::instance()->convert_datetime_for_query(
1104 1104
                         'REG_date',
1105
-                        $current_year_and_month . '-' . $days_this_month . ' 23:59:59',
1105
+                        $current_year_and_month.'-'.$days_this_month.' 23:59:59',
1106 1106
                         'Y-m-d H:i:s'
1107 1107
                     ),
1108 1108
                 ),
@@ -1117,18 +1117,18 @@  discard block
 block discarded – undo
1117 1117
                 : '';
1118 1118
             //if there is not a month or year then we can't go further
1119 1119
             if ($month_requested && $year_requested) {
1120
-                $days_in_month     = date('t', strtotime($year_requested . '-' . $month_requested . '-' . '01'));
1120
+                $days_in_month     = date('t', strtotime($year_requested.'-'.$month_requested.'-'.'01'));
1121 1121
                 $where['REG_date'] = array(
1122 1122
                     'BETWEEN',
1123 1123
                     array(
1124 1124
                         EEM_Registration::instance()->convert_datetime_for_query(
1125 1125
                             'REG_date',
1126
-                            $year_requested . '-' . $month_requested . '-01 00:00:00',
1126
+                            $year_requested.'-'.$month_requested.'-01 00:00:00',
1127 1127
                             'Y-m-d H:i:s'
1128 1128
                         ),
1129 1129
                         EEM_Registration::instance()->convert_datetime_for_query(
1130 1130
                             'REG_date',
1131
-                            $year_requested . '-' . $month_requested . '-' . $days_in_month . ' 23:59:59',
1131
+                            $year_requested.'-'.$month_requested.'-'.$days_in_month.' 23:59:59',
1132 1132
                             'Y-m-d H:i:s'
1133 1133
                         ),
1134 1134
                     ),
@@ -1149,7 +1149,7 @@  discard block
 block discarded – undo
1149 1149
     {
1150 1150
         $where = array();
1151 1151
         if ( ! empty($request['s'])) {
1152
-            $search_string = '%' . sanitize_text_field($request['s']) . '%';
1152
+            $search_string = '%'.sanitize_text_field($request['s']).'%';
1153 1153
             $where['OR'] = array(
1154 1154
                 'Event.EVT_name'                          => array('LIKE', $search_string),
1155 1155
                 'Event.EVT_desc'                          => array('LIKE', $search_string),
@@ -1251,7 +1251,7 @@  discard block
 block discarded – undo
1251 1251
             : $per_page;
1252 1252
 
1253 1253
         //-1 means return all results so get out if that's set.
1254
-        if ((int)$per_page === -1) {
1254
+        if ((int) $per_page === -1) {
1255 1255
             return array();
1256 1256
         }
1257 1257
         $per_page = absint($per_page);
@@ -1297,12 +1297,12 @@  discard block
 block discarded – undo
1297 1297
                 'action'   => 'default',
1298 1298
                 'event_id' => $event_id,
1299 1299
             ), REG_ADMIN_URL);
1300
-            $this->_template_args['filtered_transactions_link']  = EE_Admin_Page::add_query_args_and_nonce(array(
1300
+            $this->_template_args['filtered_transactions_link'] = EE_Admin_Page::add_query_args_and_nonce(array(
1301 1301
                 'action' => 'default',
1302 1302
                 'EVT_ID' => $event_id,
1303 1303
                 'page'   => 'espresso_transactions',
1304 1304
             ), admin_url('admin.php'));
1305
-            $this->_template_args['event_link']                  = EE_Admin_Page::add_query_args_and_nonce(array(
1305
+            $this->_template_args['event_link'] = EE_Admin_Page::add_query_args_and_nonce(array(
1306 1306
                 'page'   => 'espresso_events',
1307 1307
                 'action' => 'edit',
1308 1308
                 'post'   => $event_id,
@@ -1321,7 +1321,7 @@  discard block
 block discarded – undo
1321 1321
                     '_REG_ID' => $previous_reg['REG_ID'],
1322 1322
                 ), REG_ADMIN_URL), 'dashicons dashicons-arrow-left ee-icon-size-22') : '';
1323 1323
             // grab header
1324
-            $template_path                             = REG_TEMPLATE_PATH . 'reg_admin_details_header.template.php';
1324
+            $template_path                             = REG_TEMPLATE_PATH.'reg_admin_details_header.template.php';
1325 1325
             $this->_template_args['REG_ID']            = $this->_registration->ID();
1326 1326
             $this->_template_args['admin_page_header'] = EEH_Template::display_template($template_path,
1327 1327
                 $this->_template_args, true);
@@ -1395,8 +1395,8 @@  discard block
 block discarded – undo
1395 1395
                     'default' => $this->_registration->ID(),
1396 1396
                 )),
1397 1397
                 'current_status'     => new EE_Form_Section_HTML(EEH_HTML::tr(EEH_HTML::th(EEH_HTML::label(EEH_HTML::strong(__('Current Registration Status',
1398
-                        'event_espresso')))) . EEH_HTML::td(EEH_HTML::strong($this->_registration->pretty_status(),
1399
-                        '', 'status-' . $this->_registration->status_ID(),
1398
+                        'event_espresso')))).EEH_HTML::td(EEH_HTML::strong($this->_registration->pretty_status(),
1399
+                        '', 'status-'.$this->_registration->status_ID(),
1400 1400
                         'line-height: 1em; font-size: 1.5em; font-weight: bold;')))),
1401 1401
                 'reg_status'         => new EE_Select_Input($this->_get_reg_statuses(), array(
1402 1402
                     'html_label_text' => __('Change Registration Status to', 'event_espresso'),
@@ -1452,9 +1452,9 @@  discard block
 block discarded – undo
1452 1452
     {
1453 1453
         if (isset($this->_req_data['reg_status_change_form'])) {
1454 1454
             $REG_IDs = isset($this->_req_data['reg_status_change_form']['REG_ID'])
1455
-                ? (array)$this->_req_data['reg_status_change_form']['REG_ID'] : array();
1455
+                ? (array) $this->_req_data['reg_status_change_form']['REG_ID'] : array();
1456 1456
         } else {
1457
-            $REG_IDs = isset($this->_req_data['_REG_ID']) ? (array)$this->_req_data['_REG_ID'] : array();
1457
+            $REG_IDs = isset($this->_req_data['_REG_ID']) ? (array) $this->_req_data['_REG_ID'] : array();
1458 1458
         }
1459 1459
         $success = $this->_set_registration_status($REG_IDs, $status);
1460 1460
         //notify?
@@ -1482,7 +1482,7 @@  discard block
 block discarded – undo
1482 1482
     {
1483 1483
         $success = false;
1484 1484
         // typecast $REG_IDs
1485
-        $REG_IDs = (array)$REG_IDs;
1485
+        $REG_IDs = (array) $REG_IDs;
1486 1486
         if ( ! empty($REG_IDs)) {
1487 1487
             $success = true;
1488 1488
             // set default status if none is passed
@@ -1775,7 +1775,7 @@  discard block
 block discarded – undo
1775 1775
         ), REG_ADMIN_URL);
1776 1776
         $this->_template_args['REG_ID']                                       = $this->_registration->ID();
1777 1777
         $this->_template_args['event_id']                                     = $this->_registration->event_ID();
1778
-        $template_path                                                        = REG_TEMPLATE_PATH . 'reg_admin_details_main_meta_box_reg_details.template.php';
1778
+        $template_path                                                        = REG_TEMPLATE_PATH.'reg_admin_details_main_meta_box_reg_details.template.php';
1779 1779
         echo EEH_Template::display_template($template_path, $this->_template_args, true);
1780 1780
     }
1781 1781
 
@@ -1797,7 +1797,7 @@  discard block
 block discarded – undo
1797 1797
             $this->_template_args['att_questions']             = count($form->subforms()) > 0 ? $form->get_html_and_js() : '';
1798 1798
             $this->_template_args['reg_questions_form_action'] = 'edit_registration';
1799 1799
             $this->_template_args['REG_ID']                    = $this->_registration->ID();
1800
-            $template_path                                     = REG_TEMPLATE_PATH . 'reg_admin_details_main_meta_box_reg_questions.template.php';
1800
+            $template_path                                     = REG_TEMPLATE_PATH.'reg_admin_details_main_meta_box_reg_questions.template.php';
1801 1801
             echo EEH_Template::display_template($template_path, $this->_template_args, true);
1802 1802
         }
1803 1803
     }
@@ -1813,7 +1813,7 @@  discard block
 block discarded – undo
1813 1813
      */
1814 1814
     public function form_before_question_group($output)
1815 1815
     {
1816
-        EE_Error::doing_it_wrong(__CLASS__ . '::' . __FUNCTION__,
1816
+        EE_Error::doing_it_wrong(__CLASS__.'::'.__FUNCTION__,
1817 1817
             __('This method would have been protected but was used on a filter callback'
1818 1818
                . 'so needed to be public. Please discontinue usage as it will be removed soon.', 'event_espresso'),
1819 1819
             '4.8.32.rc.000');
@@ -1834,7 +1834,7 @@  discard block
 block discarded – undo
1834 1834
      */
1835 1835
     public function form_after_question_group($output)
1836 1836
     {
1837
-        EE_Error::doing_it_wrong(__CLASS__ . '::' . __FUNCTION__,
1837
+        EE_Error::doing_it_wrong(__CLASS__.'::'.__FUNCTION__,
1838 1838
             __('This method would have been protected but was used on a filter callback'
1839 1839
                . 'so needed to be public. Please discontinue usage as it will be removed soon.', 'event_espresso'),
1840 1840
             '4.8.32.rc.000');
@@ -1868,14 +1868,14 @@  discard block
 block discarded – undo
1868 1868
      */
1869 1869
     public function form_form_field_label_wrap($label)
1870 1870
     {
1871
-        EE_Error::doing_it_wrong(__CLASS__ . '::' . __FUNCTION__,
1871
+        EE_Error::doing_it_wrong(__CLASS__.'::'.__FUNCTION__,
1872 1872
             __('This method would have been protected but was used on a filter callback'
1873 1873
                . 'so needed to be public. Please discontinue usage as it will be removed soon.', 'event_espresso'),
1874 1874
             '4.8.32.rc.000');
1875 1875
         return '
1876 1876
 			<tr>
1877 1877
 				<th>
1878
-					' . $label . '
1878
+					' . $label.'
1879 1879
 				</th>';
1880 1880
     }
1881 1881
 
@@ -1890,13 +1890,13 @@  discard block
 block discarded – undo
1890 1890
      */
1891 1891
     public function form_form_field_input__wrap($input)
1892 1892
     {
1893
-        EE_Error::doing_it_wrong(__CLASS__ . '::' . __FUNCTION__,
1893
+        EE_Error::doing_it_wrong(__CLASS__.'::'.__FUNCTION__,
1894 1894
             __('This method would have been protected but was used on a filter callback'
1895 1895
                . 'so needed to be public. Please discontinue usage as it will be removed soon.', 'event_espresso'),
1896 1896
             '4.8.32.rc.000');
1897 1897
         return '
1898 1898
 				<td class="reg-admin-attendee-questions-input-td disabled-input">
1899
-					' . $input . '
1899
+					' . $input.'
1900 1900
 				</td>
1901 1901
 			</tr>';
1902 1902
     }
@@ -1936,7 +1936,7 @@  discard block
 block discarded – undo
1936 1936
     protected function _get_reg_custom_questions_form($REG_ID)
1937 1937
     {
1938 1938
         if ( ! $this->_reg_custom_questions_form) {
1939
-            require_once(REG_ADMIN . 'form_sections' . DS . 'EE_Registration_Custom_Questions_Form.form.php');
1939
+            require_once(REG_ADMIN.'form_sections'.DS.'EE_Registration_Custom_Questions_Form.form.php');
1940 1940
             $this->_reg_custom_questions_form = new EE_Registration_Custom_Questions_Form(
1941 1941
                 EEM_Registration::instance()->get_one_by_ID($REG_ID)
1942 1942
             );
@@ -1965,7 +1965,7 @@  discard block
 block discarded – undo
1965 1965
         if ($form->is_valid()) {
1966 1966
             foreach ($form->subforms() as $question_group_id => $question_group_form) {
1967 1967
                 foreach ($question_group_form->inputs() as $question_id => $input) {
1968
-                    $where_conditions    = array(
1968
+                    $where_conditions = array(
1969 1969
                         'QST_ID' => $question_id,
1970 1970
                         'REG_ID' => $REG_ID,
1971 1971
                     );
@@ -2001,7 +2001,7 @@  discard block
 block discarded – undo
2001 2001
         $REG = EEM_Registration::instance();
2002 2002
         //get all other registrations on this transaction, and cache
2003 2003
         //the attendees for them so we don't have to run another query using force_join
2004
-        $registrations                           = $REG->get_all(array(
2004
+        $registrations = $REG->get_all(array(
2005 2005
             array(
2006 2006
                 'TXN_ID' => $this->_registration->transaction_ID(),
2007 2007
                 'REG_ID' => array('!=', $this->_registration->ID()),
@@ -2021,29 +2021,29 @@  discard block
 block discarded – undo
2021 2021
             $att_nmbr = 1;
2022 2022
             foreach ($registrations as $registration) {
2023 2023
                 /* @var $registration EE_Registration */
2024
-                $attendee                                                    = $registration->attendee()
2024
+                $attendee = $registration->attendee()
2025 2025
                     ? $registration->attendee()
2026 2026
                     : EEM_Attendee::instance()
2027 2027
                                   ->create_default_object();
2028 2028
                 $this->_template_args['attendees'][$att_nmbr]['STS_ID']      = $registration->status_ID();
2029
-                $this->_template_args['attendees'][$att_nmbr]['fname']       = $attendee->fname();//( isset( $registration->ATT_fname ) & ! empty( $registration->ATT_fname ) ) ? $registration->ATT_fname : '';
2030
-                $this->_template_args['attendees'][$att_nmbr]['lname']       = $attendee->lname();//( isset( $registration->ATT_lname ) & ! empty( $registration->ATT_lname ) ) ? $registration->ATT_lname : '';
2031
-                $this->_template_args['attendees'][$att_nmbr]['email']       = $attendee->email();//( isset( $registration->ATT_email ) & ! empty( $registration->ATT_email ) ) ? $registration->ATT_email : '';
2032
-                $this->_template_args['attendees'][$att_nmbr]['final_price'] = $registration->final_price();//( isset( $registration->REG_final_price ) & ! empty( $registration->REG_final_price ) ) ? $registration->REG_final_price : '';
2029
+                $this->_template_args['attendees'][$att_nmbr]['fname']       = $attendee->fname(); //( isset( $registration->ATT_fname ) & ! empty( $registration->ATT_fname ) ) ? $registration->ATT_fname : '';
2030
+                $this->_template_args['attendees'][$att_nmbr]['lname']       = $attendee->lname(); //( isset( $registration->ATT_lname ) & ! empty( $registration->ATT_lname ) ) ? $registration->ATT_lname : '';
2031
+                $this->_template_args['attendees'][$att_nmbr]['email']       = $attendee->email(); //( isset( $registration->ATT_email ) & ! empty( $registration->ATT_email ) ) ? $registration->ATT_email : '';
2032
+                $this->_template_args['attendees'][$att_nmbr]['final_price'] = $registration->final_price(); //( isset( $registration->REG_final_price ) & ! empty( $registration->REG_final_price ) ) ? $registration->REG_final_price : '';
2033 2033
                 $this->_template_args['attendees'][$att_nmbr]['address']     = implode(', ',
2034 2034
                     $attendee->full_address_as_array());
2035 2035
                 $this->_template_args['attendees'][$att_nmbr]['att_link']    = self::add_query_args_and_nonce(array(
2036 2036
                     'action' => 'edit_attendee',
2037 2037
                     'post'   => $attendee->ID(),
2038 2038
                 ), REG_ADMIN_URL);
2039
-                $this->_template_args['attendees'][$att_nmbr]['event_name']  = $registration->event_obj()->name();
2039
+                $this->_template_args['attendees'][$att_nmbr]['event_name'] = $registration->event_obj()->name();
2040 2040
                 $att_nmbr++;
2041 2041
             }
2042 2042
             //EEH_Debug_Tools::printr( $attendees, '$attendees  <br /><span style="font-size:10px;font-weight:normal;">( file: '. __FILE__ . ' - line no: ' . __LINE__ . ' )</span>', 'auto' );
2043 2043
             $this->_template_args['currency_sign'] = EE_Registry::instance()->CFG->currency->sign;
2044 2044
             //			$this->_template_args['registration_form_url'] = add_query_arg( array( 'action' => 'edit_registration', 'process' => 'attendees'  ), REG_ADMIN_URL );
2045 2045
         }
2046
-        $template_path = REG_TEMPLATE_PATH . 'reg_admin_details_main_meta_box_attendees.template.php';
2046
+        $template_path = REG_TEMPLATE_PATH.'reg_admin_details_main_meta_box_attendees.template.php';
2047 2047
         echo EEH_Template::display_template($template_path, $this->_template_args, true);
2048 2048
     }
2049 2049
 
@@ -2072,26 +2072,26 @@  discard block
 block discarded – undo
2072 2072
             $primary_registration = null;
2073 2073
         }
2074 2074
         $this->_template_args['ATT_ID']            = $attendee->ID();
2075
-        $this->_template_args['fname']             = $attendee->fname();//$this->_registration->ATT_fname;
2076
-        $this->_template_args['lname']             = $attendee->lname();//$this->_registration->ATT_lname;
2077
-        $this->_template_args['email']             = $attendee->email();//$this->_registration->ATT_email;
2075
+        $this->_template_args['fname']             = $attendee->fname(); //$this->_registration->ATT_fname;
2076
+        $this->_template_args['lname']             = $attendee->lname(); //$this->_registration->ATT_lname;
2077
+        $this->_template_args['email']             = $attendee->email(); //$this->_registration->ATT_email;
2078 2078
         $this->_template_args['phone']             = $attendee->phone();
2079 2079
         $this->_template_args['formatted_address'] = EEH_Address::format($attendee);
2080 2080
         //edit link
2081
-        $this->_template_args['att_edit_link']  = EE_Admin_Page::add_query_args_and_nonce(array(
2081
+        $this->_template_args['att_edit_link'] = EE_Admin_Page::add_query_args_and_nonce(array(
2082 2082
             'action' => 'edit_attendee',
2083 2083
             'post'   => $attendee->ID(),
2084 2084
         ), REG_ADMIN_URL);
2085 2085
         $this->_template_args['att_edit_label'] = __('View/Edit Contact', 'event_espresso');
2086 2086
         //create link
2087
-        $this->_template_args['create_link']  = $primary_registration instanceof EE_Registration
2087
+        $this->_template_args['create_link'] = $primary_registration instanceof EE_Registration
2088 2088
             ? EE_Admin_Page::add_query_args_and_nonce(array(
2089 2089
                 'action'  => 'duplicate_attendee',
2090 2090
                 '_REG_ID' => $this->_registration->ID(),
2091 2091
             ), REG_ADMIN_URL) : '';
2092 2092
         $this->_template_args['create_label'] = __('Create Contact', 'event_espresso');
2093 2093
         $this->_template_args['att_check']    = $att_check;
2094
-        $template_path                        = REG_TEMPLATE_PATH . 'reg_admin_details_side_meta_box_registrant.template.php';
2094
+        $template_path                        = REG_TEMPLATE_PATH.'reg_admin_details_side_meta_box_registrant.template.php';
2095 2095
         echo EEH_Template::display_template($template_path, $this->_template_args, true);
2096 2096
     }
2097 2097
 
@@ -2305,7 +2305,7 @@  discard block
 block discarded – undo
2305 2305
                 'action' => 'edit',
2306 2306
                 'post'   => $this->_reg_event->ID(),
2307 2307
             ), EVENTS_ADMIN_URL);
2308
-            $edit_event_lnk                     = '<a href="'
2308
+            $edit_event_lnk = '<a href="'
2309 2309
                                                   . $edit_event_url
2310 2310
                                                   . '" title="'
2311 2311
                                                   . esc_attr__('Edit ', 'event_espresso')
@@ -2322,7 +2322,7 @@  discard block
 block discarded – undo
2322 2322
             $this->_return_json();
2323 2323
         }
2324 2324
         // grab header
2325
-        $template_path                              = REG_TEMPLATE_PATH . 'reg_admin_register_new_attendee.template.php';
2325
+        $template_path                              = REG_TEMPLATE_PATH.'reg_admin_register_new_attendee.template.php';
2326 2326
         $this->_template_args['admin_page_content'] = EEH_Template::display_template($template_path,
2327 2327
             $this->_template_args, true);
2328 2328
         //$this->_set_publish_post_box_vars( NULL, FALSE, FALSE, NULL, FALSE );
@@ -2344,7 +2344,7 @@  discard block
 block discarded – undo
2344 2344
                 'event_espresso'), '<br />', '<h3 class="important-notice">', '</h3>', '<div class="float-right">',
2345 2345
                 '<span id="redirect_timer" class="important-notice">30</span>', '</div>', '<b>', '</b>');
2346 2346
             return '
2347
-	<div id="ee-add-reg-back-button-dv"><p>' . $warning_msg . '</p></div>
2347
+	<div id="ee-add-reg-back-button-dv"><p>' . $warning_msg.'</p></div>
2348 2348
 	<script >
2349 2349
 		// WHOAH !!! it appears that someone is using the back button from the Transaction admin page
2350 2350
 		// after just adding a new registration... we gotta try to put a stop to that !!!
@@ -2569,7 +2569,7 @@  discard block
 block discarded – undo
2569 2569
     public function get_attendees($per_page, $count = false, $trash = false)
2570 2570
     {
2571 2571
         do_action('AHEE_log', __FILE__, __FUNCTION__, '');
2572
-        require_once(REG_ADMIN . 'EE_Attendee_Contact_List_Table.class.php');
2572
+        require_once(REG_ADMIN.'EE_Attendee_Contact_List_Table.class.php');
2573 2573
         $ATT_MDL                    = EEM_Attendee::instance();
2574 2574
         $this->_req_data['orderby'] = ! empty($this->_req_data['orderby']) ? $this->_req_data['orderby'] : '';
2575 2575
         switch ($this->_req_data['orderby']) {
@@ -2603,7 +2603,7 @@  discard block
 block discarded – undo
2603 2603
             ? $this->_req_data['perpage'] : $per_page;
2604 2604
         $_where       = array();
2605 2605
         if ( ! empty($this->_req_data['s'])) {
2606
-            $sstr         = '%' . $this->_req_data['s'] . '%';
2606
+            $sstr         = '%'.$this->_req_data['s'].'%';
2607 2607
             $_where['OR'] = array(
2608 2608
                 'Registration.Event.EVT_name'       => array('LIKE', $sstr),
2609 2609
                 'Registration.Event.EVT_desc'       => array('LIKE', $sstr),
@@ -2681,7 +2681,7 @@  discard block
 block discarded – undo
2681 2681
      *                                                     the query parameters from the request
2682 2682
      * @return void ends the request with a redirect or download
2683 2683
      */
2684
-    public function _registrations_report_base( $method_name_for_getting_query_params )
2684
+    public function _registrations_report_base($method_name_for_getting_query_params)
2685 2685
     {
2686 2686
         if ( ! defined('EE_USE_OLD_CSV_REPORT_CLASS')) {
2687 2687
             wp_redirect(EE_Admin_Page::add_query_args_and_nonce(array(
@@ -2691,7 +2691,7 @@  discard block
 block discarded – undo
2691 2691
                 'filters'     => urlencode(
2692 2692
                     serialize(
2693 2693
                         call_user_func(
2694
-                            array( $this, $method_name_for_getting_query_params ),
2694
+                            array($this, $method_name_for_getting_query_params),
2695 2695
                             EEH_Array::is_set(
2696 2696
                                 $this->_req_data,
2697 2697
                                 'filters',
@@ -2711,8 +2711,8 @@  discard block
 block discarded – undo
2711 2711
                 'EVT_ID' => isset($this->_req_data['EVT_ID']) ? $this->_req_data['EVT_ID'] : null,
2712 2712
             );
2713 2713
             $this->_req_data = array_merge($this->_req_data, $new_request_args);
2714
-            if (is_readable(EE_CLASSES . 'EE_Export.class.php')) {
2715
-                require_once(EE_CLASSES . 'EE_Export.class.php');
2714
+            if (is_readable(EE_CLASSES.'EE_Export.class.php')) {
2715
+                require_once(EE_CLASSES.'EE_Export.class.php');
2716 2716
                 $EE_Export = EE_Export::instance($this->_req_data);
2717 2717
                 $EE_Export->export();
2718 2718
             }
@@ -2727,14 +2727,14 @@  discard block
 block discarded – undo
2727 2727
      */
2728 2728
     public function _registrations_report()
2729 2729
     {
2730
-        $this->_registrations_report_base( '_get_registration_query_parameters' );
2730
+        $this->_registrations_report_base('_get_registration_query_parameters');
2731 2731
     }
2732 2732
 
2733 2733
 
2734 2734
     public function _contact_list_export()
2735 2735
     {
2736
-        if (is_readable(EE_CLASSES . 'EE_Export.class.php')) {
2737
-            require_once(EE_CLASSES . 'EE_Export.class.php');
2736
+        if (is_readable(EE_CLASSES.'EE_Export.class.php')) {
2737
+            require_once(EE_CLASSES.'EE_Export.class.php');
2738 2738
             $EE_Export = EE_Export::instance($this->_req_data);
2739 2739
             $EE_Export->export_attendees();
2740 2740
         }
@@ -2751,8 +2751,8 @@  discard block
 block discarded – undo
2751 2751
                 'return_url'  => urlencode($this->_req_data['return_url']),
2752 2752
             )));
2753 2753
         } else {
2754
-            if (is_readable(EE_CLASSES . 'EE_Export.class.php')) {
2755
-                require_once(EE_CLASSES . 'EE_Export.class.php');
2754
+            if (is_readable(EE_CLASSES.'EE_Export.class.php')) {
2755
+                require_once(EE_CLASSES.'EE_Export.class.php');
2756 2756
                 $EE_Export = EE_Export::instance($this->_req_data);
2757 2757
                 $EE_Export->report_attendees();
2758 2758
             }
@@ -2809,7 +2809,7 @@  discard block
 block discarded – undo
2809 2809
             $updated_fields = array(
2810 2810
                 'ATT_fname'     => $this->_req_data['ATT_fname'],
2811 2811
                 'ATT_lname'     => $this->_req_data['ATT_lname'],
2812
-                'ATT_full_name' => $this->_req_data['ATT_fname'] . ' ' . $this->_req_data['ATT_lname'],
2812
+                'ATT_full_name' => $this->_req_data['ATT_fname'].' '.$this->_req_data['ATT_lname'],
2813 2813
                 'ATT_address'   => isset($this->_req_data['ATT_address']) ? $this->_req_data['ATT_address'] : '',
2814 2814
                 'ATT_address2'  => isset($this->_req_data['ATT_address2']) ? $this->_req_data['ATT_address2'] : '',
2815 2815
                 'ATT_city'      => isset($this->_req_data['ATT_city']) ? $this->_req_data['ATT_city'] : '',
@@ -2892,7 +2892,7 @@  discard block
 block discarded – undo
2892 2892
     {
2893 2893
         //get attendee object ( should already have it )
2894 2894
         $this->_template_args['attendee'] = $this->_cpt_model_obj;
2895
-        $template                         = REG_TEMPLATE_PATH . 'attendee_contact_info_metabox_content.template.php';
2895
+        $template                         = REG_TEMPLATE_PATH.'attendee_contact_info_metabox_content.template.php';
2896 2896
         EEH_Template::display_template($template, $this->_template_args);
2897 2897
     }
2898 2898
 
@@ -2933,7 +2933,7 @@  discard block
 block discarded – undo
2933 2933
             'input_prefix'   => '',
2934 2934
             'append_qstn_id' => false,
2935 2935
         )));
2936
-        $template                             = REG_TEMPLATE_PATH . 'attendee_address_details_metabox_content.template.php';
2936
+        $template = REG_TEMPLATE_PATH.'attendee_address_details_metabox_content.template.php';
2937 2937
         EEH_Template::display_template($template, $this->_template_args);
2938 2938
     }
2939 2939
 
@@ -2948,7 +2948,7 @@  discard block
 block discarded – undo
2948 2948
     {
2949 2949
         $this->_template_args['attendee']      = $this->_cpt_model_obj;
2950 2950
         $this->_template_args['registrations'] = $this->_cpt_model_obj->get_many_related('Registration');
2951
-        $template                              = REG_TEMPLATE_PATH . 'attendee_registrations_main_meta_box.template.php';
2951
+        $template                              = REG_TEMPLATE_PATH.'attendee_registrations_main_meta_box.template.php';
2952 2952
         EEH_Template::display_template($template, $this->_template_args);
2953 2953
     }
2954 2954
 
@@ -2962,7 +2962,7 @@  discard block
 block discarded – undo
2962 2962
     public function after_title_form_fields($post)
2963 2963
     {
2964 2964
         if ($post->post_type == 'espresso_attendees') {
2965
-            $template                  = REG_TEMPLATE_PATH . 'attendee_details_after_title_form_fields.template.php';
2965
+            $template                  = REG_TEMPLATE_PATH.'attendee_details_after_title_form_fields.template.php';
2966 2966
             $template_args['attendee'] = $this->_cpt_model_obj;
2967 2967
             EEH_Template::display_template($template, $template_args);
2968 2968
         }
Please login to merge, or discard this patch.
core/libraries/plugin_api/EE_Register_Message_Type.lib.php 2 patches
Indentation   +426 added lines, -426 removed lines patch added patch discarded remove patch
@@ -7,7 +7,7 @@  discard block
 block discarded – undo
7 7
  * @since           4.3.0
8 8
  */
9 9
 if (! defined('EVENT_ESPRESSO_VERSION')) {
10
-    exit('No direct script access allowed');
10
+	exit('No direct script access allowed');
11 11
 }
12 12
 
13 13
 /**
@@ -22,455 +22,455 @@  discard block
 block discarded – undo
22 22
 {
23 23
 
24 24
 
25
-    /**
26
-     * Holds values for registered message types
27
-     *
28
-     * @var array
29
-     */
30
-    protected static $_ee_message_type_registry = array();
25
+	/**
26
+	 * Holds values for registered message types
27
+	 *
28
+	 * @var array
29
+	 */
30
+	protected static $_ee_message_type_registry = array();
31 31
 
32 32
 
33
-    /**
34
-     * Method for registering new message types in the EE_messages system.
35
-     * Note:  All message types must have the following files in order to work:
36
-     * Template files for default templates getting setup.
37
-     * See /core/libraries/messages/defaults/default/ for examples
38
-     * (note that template files match a specific naming schema).
39
-     * These templates will need to be registered with the default template pack.
40
-     * - EE_Messages_Validator extended class(es).  See /core/libraries/messages/validators/email/
41
-     *      for examples.  Note for any new message types, there will need to be a validator for each
42
-     *      messenger combo this message type can activate with.
43
-     * - And of course the main EE_{Message_Type_Name}_message_type class that defines the new
44
-     *      message type and its properties.
45
-     *
46
-     * @since    4.3.0
47
-     * @param string $mt_name       Whatever is defined for the $name property of
48
-     *                              the message type you are registering (eg.
49
-     *                              declined_registration). Required.
50
-     * @param  array $setup_args    An array of arguments provided for registering the message type.
51
-     *                              @see inline docs in the register method for what can be passed in as arguments.
52
-     * @throws \EE_Error
53
-     *                              }
54
-     */
55
-    public static function register($mt_name = null, $setup_args = array())
56
-    {
57
-        //required fields MUST be present, so let's make sure they are.
58
-        if (
59
-            ! isset($mt_name)
60
-            || ! is_array($setup_args)
61
-            || empty($setup_args['mtfilename']) || empty($setup_args['autoloadpaths'])
62
-        ) {
63
-            throw new EE_Error(
64
-                __('In order to register a message type with EE_Register_Message_Type::register, you must include a unique name for the message type, plus an array containing the following keys: "mtfilename", "autoloadpaths"',
65
-                    'event_espresso')
66
-            );
67
-        }
33
+	/**
34
+	 * Method for registering new message types in the EE_messages system.
35
+	 * Note:  All message types must have the following files in order to work:
36
+	 * Template files for default templates getting setup.
37
+	 * See /core/libraries/messages/defaults/default/ for examples
38
+	 * (note that template files match a specific naming schema).
39
+	 * These templates will need to be registered with the default template pack.
40
+	 * - EE_Messages_Validator extended class(es).  See /core/libraries/messages/validators/email/
41
+	 *      for examples.  Note for any new message types, there will need to be a validator for each
42
+	 *      messenger combo this message type can activate with.
43
+	 * - And of course the main EE_{Message_Type_Name}_message_type class that defines the new
44
+	 *      message type and its properties.
45
+	 *
46
+	 * @since    4.3.0
47
+	 * @param string $mt_name       Whatever is defined for the $name property of
48
+	 *                              the message type you are registering (eg.
49
+	 *                              declined_registration). Required.
50
+	 * @param  array $setup_args    An array of arguments provided for registering the message type.
51
+	 *                              @see inline docs in the register method for what can be passed in as arguments.
52
+	 * @throws \EE_Error
53
+	 *                              }
54
+	 */
55
+	public static function register($mt_name = null, $setup_args = array())
56
+	{
57
+		//required fields MUST be present, so let's make sure they are.
58
+		if (
59
+			! isset($mt_name)
60
+			|| ! is_array($setup_args)
61
+			|| empty($setup_args['mtfilename']) || empty($setup_args['autoloadpaths'])
62
+		) {
63
+			throw new EE_Error(
64
+				__('In order to register a message type with EE_Register_Message_Type::register, you must include a unique name for the message type, plus an array containing the following keys: "mtfilename", "autoloadpaths"',
65
+					'event_espresso')
66
+			);
67
+		}
68 68
 
69
-        //make sure we don't register twice
70
-        if (isset(self::$_ee_message_type_registry[$mt_name])) {
71
-            return;
72
-        }
69
+		//make sure we don't register twice
70
+		if (isset(self::$_ee_message_type_registry[$mt_name])) {
71
+			return;
72
+		}
73 73
 
74
-        //make sure this was called in the right place!
75
-        if (
76
-            ! did_action('EE_Brewing_Regular___messages_caf')
77
-            || did_action('AHEE__EE_System__perform_activations_upgrades_and_migrations')
78
-        ) {
79
-            EE_Error::doing_it_wrong(
80
-                __METHOD__,
81
-                sprintf(
82
-                    __('A message type named "%s" has been attempted to be registered with the EE Messages System.  It may or may not work because it should be only called on the "EE_Brewing_Regular___messages_caf" hook.',
83
-                        'event_espresso'),
84
-                    $mt_name
85
-                ),
86
-                '4.3.0'
87
-            );
88
-        }
89
-        //setup $__ee_message_type_registry array from incoming values.
90
-        self::$_ee_message_type_registry[$mt_name] = array(
91
-            /**
92
-             * The file name for the message type being registered.
93
-             * Required.
94
-             * @type string
95
-             */
96
-            'mtfilename'                  => (string)$setup_args['mtfilename'],
97
-            /**
98
-             * Autoload paths for classes used by the message type.
99
-             * Required.
100
-             * @type array
101
-             */
102
-            'autoloadpaths'               => (array)$setup_args['autoloadpaths'],
103
-            /**
104
-             * Messengers that the message type should be able to activate with.
105
-             * Use messenger slugs.
106
-             * @type array
107
-             */
108
-            'messengers_to_activate_with' => ! empty($setup_args['messengers_to_activate_with'])
109
-                ? (array)$setup_args['messengers_to_activate_with']
110
-                : array(),
111
-            /**
112
-             * Messengers that the message type should validate with.
113
-             * Use messenger slugs.
114
-             * @type array
115
-             */
116
-            'messengers_to_validate_with' => ! empty($setup_args['messengers_to_validate_with'])
117
-                ? (array)$setup_args['messengers_to_validate_with']
118
-                : array(),
119
-            /**
120
-             * Whether to force activate this message type the first time it is registered.
121
-             * @type bool   False means its not activated by default and left up to the end user to activate.
122
-             */
123
-            'force_activation'            => ! empty($setup_args['force_activation'])
124
-                ? (bool)$setup_args['force_activation']
125
-                : false,
126
-            /**
127
-             * What messengers this message type supports the default template pack for.
128
-             * Note: If you do not set this (or any of the following template pack/variation related arguments) to true,
129
-             * then it is expected that the message type being registered is doing its own custom default template
130
-             * pack/variation registration.
131
-             *
132
-             * If this is set and has values, then it is expected that the following arguments are also set in the incoming options
133
-             * $setup_arguments array as well:
134
-             * - 'base_path_for_default_templates'
135
-             *
136
-             * @type array   Expect an array of messengers this supports default template packs for.
137
-             */
138
-            'messengers_supporting_default_template_pack_with' => isset($setup_args['messengers_supporting_default_template_pack_with'])
139
-                ? (array)$setup_args['messengers_supporting_default_template_pack_with']
140
-                : array(),
141
-            /**
142
-             * The base path where the default templates for this message type can be found.
143
-             * @type string
144
-             */
145
-            'base_path_for_default_templates' => isset($setup_args['base_path_for_default_templates'])
146
-                ? $setup_args['base_path_for_default_templates']
147
-                : '',
148
-            /**
149
-             * The base path where the default variations for this message type can be found.
150
-             * @type string
151
-             */
152
-            'base_path_for_default_variation' => isset($setup_args['base_path_for_default_variation'])
153
-                ? $setup_args['base_path_for_default_variation']
154
-                : '',
155
-            /**
156
-             * The base url for the default variations for this message type.
157
-             * @type string
158
-             */
159
-            'base_url_for_default_variation' => isset($setup_args['base_url_for_default_variation'])
160
-                ? $setup_args['base_url_for_default_variation']
161
-                : ''
162
-        );
163
-        //add filters but only if they haven't already been set (these filters only need to be registered ONCE because
164
-        //the callback handles all registered message types.
165
-        if ( false === has_filter(
166
-            'FHEE__EED_Messages___set_messages_paths___MSG_PATHS',
167
-            array('EE_Register_Message_Type', 'register_msgs_autoload_paths')
168
-        )) {
169
-            add_filter(
170
-                'FHEE__EED_Messages___set_messages_paths___MSG_PATHS',
171
-                array('EE_Register_Message_Type', 'register_msgs_autoload_paths'),
172
-                10
173
-            );
174
-            add_filter(
175
-                'FHEE__EE_messages__get_installed__messagetype_files',
176
-                array('EE_Register_Message_Type', 'register_messagetype_files'),
177
-                10,
178
-                1
179
-            );
180
-            add_filter(
181
-                'FHEE__EE_messenger__get_default_message_types__default_types',
182
-                array('EE_Register_Message_Type', 'register_messengers_to_activate_mt_with'),
183
-                10,
184
-                2
185
-            );
186
-            add_filter(
187
-                'FHEE__EE_messenger__get_valid_message_types__valid_types',
188
-                array('EE_Register_Message_Type', 'register_messengers_to_validate_mt_with'),
189
-                10,
190
-                2
191
-            );
192
-            //actions
193
-            add_action(
194
-                'AHEE__EE_Addon__initialize_default_data__begin',
195
-                array('EE_Register_Message_Type', 'set_defaults')
196
-            );
74
+		//make sure this was called in the right place!
75
+		if (
76
+			! did_action('EE_Brewing_Regular___messages_caf')
77
+			|| did_action('AHEE__EE_System__perform_activations_upgrades_and_migrations')
78
+		) {
79
+			EE_Error::doing_it_wrong(
80
+				__METHOD__,
81
+				sprintf(
82
+					__('A message type named "%s" has been attempted to be registered with the EE Messages System.  It may or may not work because it should be only called on the "EE_Brewing_Regular___messages_caf" hook.',
83
+						'event_espresso'),
84
+					$mt_name
85
+				),
86
+				'4.3.0'
87
+			);
88
+		}
89
+		//setup $__ee_message_type_registry array from incoming values.
90
+		self::$_ee_message_type_registry[$mt_name] = array(
91
+			/**
92
+			 * The file name for the message type being registered.
93
+			 * Required.
94
+			 * @type string
95
+			 */
96
+			'mtfilename'                  => (string)$setup_args['mtfilename'],
97
+			/**
98
+			 * Autoload paths for classes used by the message type.
99
+			 * Required.
100
+			 * @type array
101
+			 */
102
+			'autoloadpaths'               => (array)$setup_args['autoloadpaths'],
103
+			/**
104
+			 * Messengers that the message type should be able to activate with.
105
+			 * Use messenger slugs.
106
+			 * @type array
107
+			 */
108
+			'messengers_to_activate_with' => ! empty($setup_args['messengers_to_activate_with'])
109
+				? (array)$setup_args['messengers_to_activate_with']
110
+				: array(),
111
+			/**
112
+			 * Messengers that the message type should validate with.
113
+			 * Use messenger slugs.
114
+			 * @type array
115
+			 */
116
+			'messengers_to_validate_with' => ! empty($setup_args['messengers_to_validate_with'])
117
+				? (array)$setup_args['messengers_to_validate_with']
118
+				: array(),
119
+			/**
120
+			 * Whether to force activate this message type the first time it is registered.
121
+			 * @type bool   False means its not activated by default and left up to the end user to activate.
122
+			 */
123
+			'force_activation'            => ! empty($setup_args['force_activation'])
124
+				? (bool)$setup_args['force_activation']
125
+				: false,
126
+			/**
127
+			 * What messengers this message type supports the default template pack for.
128
+			 * Note: If you do not set this (or any of the following template pack/variation related arguments) to true,
129
+			 * then it is expected that the message type being registered is doing its own custom default template
130
+			 * pack/variation registration.
131
+			 *
132
+			 * If this is set and has values, then it is expected that the following arguments are also set in the incoming options
133
+			 * $setup_arguments array as well:
134
+			 * - 'base_path_for_default_templates'
135
+			 *
136
+			 * @type array   Expect an array of messengers this supports default template packs for.
137
+			 */
138
+			'messengers_supporting_default_template_pack_with' => isset($setup_args['messengers_supporting_default_template_pack_with'])
139
+				? (array)$setup_args['messengers_supporting_default_template_pack_with']
140
+				: array(),
141
+			/**
142
+			 * The base path where the default templates for this message type can be found.
143
+			 * @type string
144
+			 */
145
+			'base_path_for_default_templates' => isset($setup_args['base_path_for_default_templates'])
146
+				? $setup_args['base_path_for_default_templates']
147
+				: '',
148
+			/**
149
+			 * The base path where the default variations for this message type can be found.
150
+			 * @type string
151
+			 */
152
+			'base_path_for_default_variation' => isset($setup_args['base_path_for_default_variation'])
153
+				? $setup_args['base_path_for_default_variation']
154
+				: '',
155
+			/**
156
+			 * The base url for the default variations for this message type.
157
+			 * @type string
158
+			 */
159
+			'base_url_for_default_variation' => isset($setup_args['base_url_for_default_variation'])
160
+				? $setup_args['base_url_for_default_variation']
161
+				: ''
162
+		);
163
+		//add filters but only if they haven't already been set (these filters only need to be registered ONCE because
164
+		//the callback handles all registered message types.
165
+		if ( false === has_filter(
166
+			'FHEE__EED_Messages___set_messages_paths___MSG_PATHS',
167
+			array('EE_Register_Message_Type', 'register_msgs_autoload_paths')
168
+		)) {
169
+			add_filter(
170
+				'FHEE__EED_Messages___set_messages_paths___MSG_PATHS',
171
+				array('EE_Register_Message_Type', 'register_msgs_autoload_paths'),
172
+				10
173
+			);
174
+			add_filter(
175
+				'FHEE__EE_messages__get_installed__messagetype_files',
176
+				array('EE_Register_Message_Type', 'register_messagetype_files'),
177
+				10,
178
+				1
179
+			);
180
+			add_filter(
181
+				'FHEE__EE_messenger__get_default_message_types__default_types',
182
+				array('EE_Register_Message_Type', 'register_messengers_to_activate_mt_with'),
183
+				10,
184
+				2
185
+			);
186
+			add_filter(
187
+				'FHEE__EE_messenger__get_valid_message_types__valid_types',
188
+				array('EE_Register_Message_Type', 'register_messengers_to_validate_mt_with'),
189
+				10,
190
+				2
191
+			);
192
+			//actions
193
+			add_action(
194
+				'AHEE__EE_Addon__initialize_default_data__begin',
195
+				array('EE_Register_Message_Type', 'set_defaults')
196
+			);
197 197
 
198
-            //default template packs and variations related
199
-            add_filter(
200
-                'FHEE__EE_Messages_Template_Pack_Default__get_supports',
201
-                array('EE_Register_Message_Type', 'register_default_template_pack_supports')
202
-            );
203
-            add_filter(
204
-                'FHEE__EE_Template_Pack___get_specific_template__filtered_base_path',
205
-                array('EE_Register_Message_Type', 'register_base_template_path'),
206
-                10,
207
-                6
208
-            );
209
-            add_filter(
210
-                'FHEE__EE_Messages_Template_Pack__get_variation__base_path_or_url',
211
-                array('EE_Register_Message_Type', 'register_variation_base_path_or_url'),
212
-                10,
213
-                8
214
-            );
215
-            add_filter(
216
-                'FHEE__EE_Messages_Template_Pack__get_variation__base_path',
217
-                array('EE_Register_Message_Type', 'register_variation_base_path_or_url'),
218
-                10,
219
-                8
220
-            );
221
-        }
222
-    }
198
+			//default template packs and variations related
199
+			add_filter(
200
+				'FHEE__EE_Messages_Template_Pack_Default__get_supports',
201
+				array('EE_Register_Message_Type', 'register_default_template_pack_supports')
202
+			);
203
+			add_filter(
204
+				'FHEE__EE_Template_Pack___get_specific_template__filtered_base_path',
205
+				array('EE_Register_Message_Type', 'register_base_template_path'),
206
+				10,
207
+				6
208
+			);
209
+			add_filter(
210
+				'FHEE__EE_Messages_Template_Pack__get_variation__base_path_or_url',
211
+				array('EE_Register_Message_Type', 'register_variation_base_path_or_url'),
212
+				10,
213
+				8
214
+			);
215
+			add_filter(
216
+				'FHEE__EE_Messages_Template_Pack__get_variation__base_path',
217
+				array('EE_Register_Message_Type', 'register_variation_base_path_or_url'),
218
+				10,
219
+				8
220
+			);
221
+		}
222
+	}
223 223
 
224 224
 
225
-    /**
226
-     * This just ensures that when an addon registers a message type that on initial activation/reactivation the
227
-     * defaults the addon sets are taken care of.
228
-     */
229
-    public static function set_defaults()
230
-    {
231
-        /** @type EE_Message_Resource_Manager $message_resource_manager */
232
-        $message_resource_manager = EE_Registry::instance()->load_lib('Message_Resource_Manager');
225
+	/**
226
+	 * This just ensures that when an addon registers a message type that on initial activation/reactivation the
227
+	 * defaults the addon sets are taken care of.
228
+	 */
229
+	public static function set_defaults()
230
+	{
231
+		/** @type EE_Message_Resource_Manager $message_resource_manager */
232
+		$message_resource_manager = EE_Registry::instance()->load_lib('Message_Resource_Manager');
233 233
 
234
-        //for any message types with force activation, let's ensure they are activated
235
-        foreach (self::$_ee_message_type_registry as $message_type_name => $settings) {
236
-            if ($settings['force_activation']) {
237
-                foreach ($settings['messengers_to_activate_with'] as $messenger) {
238
-                    //DO not force activation if this message type has already been activated in the system
239
-                    if (! $message_resource_manager->has_message_type_been_activated_for_messenger($message_type_name,
240
-                        $messenger)
241
-                    ) {
242
-                        $message_resource_manager->ensure_message_type_is_active($message_type_name, $messenger);
243
-                    }
244
-                }
245
-            }
246
-        }
247
-    }
234
+		//for any message types with force activation, let's ensure they are activated
235
+		foreach (self::$_ee_message_type_registry as $message_type_name => $settings) {
236
+			if ($settings['force_activation']) {
237
+				foreach ($settings['messengers_to_activate_with'] as $messenger) {
238
+					//DO not force activation if this message type has already been activated in the system
239
+					if (! $message_resource_manager->has_message_type_been_activated_for_messenger($message_type_name,
240
+						$messenger)
241
+					) {
242
+						$message_resource_manager->ensure_message_type_is_active($message_type_name, $messenger);
243
+					}
244
+				}
245
+			}
246
+		}
247
+	}
248 248
 
249 249
 
250
-    /**
251
-     * This deregisters a message type that was previously registered with a specific message_type_name.
252
-     *
253
-     * @since    4.3.0
254
-     * @param string $message_type_name the name for the message type that was previously registered
255
-     * @return void
256
-     */
257
-    public static function deregister($message_type_name = null)
258
-    {
259
-        if (! empty(self::$_ee_message_type_registry[$message_type_name])) {
260
-            //let's make sure that we remove any place this message type was made active
261
-            /** @var EE_Message_Resource_Manager $Message_Resource_Manager */
262
-            $Message_Resource_Manager = EE_Registry::instance()->load_lib('Message_Resource_Manager');
263
-            $Message_Resource_Manager->deactivate_message_type($message_type_name);
264
-            unset(self::$_ee_message_type_registry[$message_type_name]);
265
-        }
266
-    }
250
+	/**
251
+	 * This deregisters a message type that was previously registered with a specific message_type_name.
252
+	 *
253
+	 * @since    4.3.0
254
+	 * @param string $message_type_name the name for the message type that was previously registered
255
+	 * @return void
256
+	 */
257
+	public static function deregister($message_type_name = null)
258
+	{
259
+		if (! empty(self::$_ee_message_type_registry[$message_type_name])) {
260
+			//let's make sure that we remove any place this message type was made active
261
+			/** @var EE_Message_Resource_Manager $Message_Resource_Manager */
262
+			$Message_Resource_Manager = EE_Registry::instance()->load_lib('Message_Resource_Manager');
263
+			$Message_Resource_Manager->deactivate_message_type($message_type_name);
264
+			unset(self::$_ee_message_type_registry[$message_type_name]);
265
+		}
266
+	}
267 267
 
268 268
 
269
-    /**
270
-     * callback for FHEE__EE_messages__get_installed__messagetype_files filter.
271
-     *
272
-     * @since   4.3.0
273
-     * @param  array $messagetype_files The current array of message type file names
274
-     * @return  array                                 Array of message type file names
275
-     */
276
-    public static function register_messagetype_files($messagetype_files)
277
-    {
278
-        if (empty(self::$_ee_message_type_registry)) {
279
-            return $messagetype_files;
280
-        }
281
-        foreach (self::$_ee_message_type_registry as $mt_reg) {
282
-            if (empty($mt_reg['mtfilename'])) {
283
-                continue;
284
-            }
285
-            $messagetype_files[] = $mt_reg['mtfilename'];
286
-        }
287
-        return $messagetype_files;
288
-    }
269
+	/**
270
+	 * callback for FHEE__EE_messages__get_installed__messagetype_files filter.
271
+	 *
272
+	 * @since   4.3.0
273
+	 * @param  array $messagetype_files The current array of message type file names
274
+	 * @return  array                                 Array of message type file names
275
+	 */
276
+	public static function register_messagetype_files($messagetype_files)
277
+	{
278
+		if (empty(self::$_ee_message_type_registry)) {
279
+			return $messagetype_files;
280
+		}
281
+		foreach (self::$_ee_message_type_registry as $mt_reg) {
282
+			if (empty($mt_reg['mtfilename'])) {
283
+				continue;
284
+			}
285
+			$messagetype_files[] = $mt_reg['mtfilename'];
286
+		}
287
+		return $messagetype_files;
288
+	}
289 289
 
290 290
 
291
-    /**
292
-     * callback for FHEE__EED_Messages___set_messages_paths___MSG_PATHS filter.
293
-     *
294
-     * @since    4.3.0
295
-     * @param array $paths array of paths to be checked by EE_messages autoloader.
296
-     * @return array
297
-     */
298
-    public static function register_msgs_autoload_paths($paths)
299
-    {
300
-        if (! empty(self::$_ee_message_type_registry)) {
301
-            foreach (self::$_ee_message_type_registry as $mt_reg) {
302
-                if (empty($mt_reg['autoloadpaths'])) {
303
-                    continue;
304
-                }
305
-                $paths = array_merge($paths, $mt_reg['autoloadpaths']);
306
-            }
307
-        }
308
-        return $paths;
309
-    }
291
+	/**
292
+	 * callback for FHEE__EED_Messages___set_messages_paths___MSG_PATHS filter.
293
+	 *
294
+	 * @since    4.3.0
295
+	 * @param array $paths array of paths to be checked by EE_messages autoloader.
296
+	 * @return array
297
+	 */
298
+	public static function register_msgs_autoload_paths($paths)
299
+	{
300
+		if (! empty(self::$_ee_message_type_registry)) {
301
+			foreach (self::$_ee_message_type_registry as $mt_reg) {
302
+				if (empty($mt_reg['autoloadpaths'])) {
303
+					continue;
304
+				}
305
+				$paths = array_merge($paths, $mt_reg['autoloadpaths']);
306
+			}
307
+		}
308
+		return $paths;
309
+	}
310 310
 
311 311
 
312
-    /**
313
-     * callback for FHEE__EE_messenger__get_default_message_types__default_types filter.
314
-     *
315
-     * @since  4.3.0
316
-     * @param  array        $default_types  array of message types activated with messenger (
317
-     *                                      corresponds to the $name property of message type)
318
-     * @param  EE_messenger $messenger      The EE_messenger the filter is called from.
319
-     * @return array
320
-     */
321
-    public static function register_messengers_to_activate_mt_with($default_types, EE_messenger $messenger)
322
-    {
323
-        if (empty(self::$_ee_message_type_registry)) {
324
-            return $default_types;
325
-        }
326
-        foreach (self::$_ee_message_type_registry as $message_type_name => $mt_reg) {
327
-            if (empty($mt_reg['messengers_to_activate_with']) || empty($mt_reg['mtfilename'])) {
328
-                continue;
329
-            }
330
-            // loop through each of the messengers and if it matches the loaded class
331
-            // then we add this message type to the
332
-            foreach ($mt_reg['messengers_to_activate_with'] as $msgr) {
333
-                if ($messenger->name == $msgr) {
334
-                    $default_types[] = $message_type_name;
335
-                }
336
-            }
337
-        }
312
+	/**
313
+	 * callback for FHEE__EE_messenger__get_default_message_types__default_types filter.
314
+	 *
315
+	 * @since  4.3.0
316
+	 * @param  array        $default_types  array of message types activated with messenger (
317
+	 *                                      corresponds to the $name property of message type)
318
+	 * @param  EE_messenger $messenger      The EE_messenger the filter is called from.
319
+	 * @return array
320
+	 */
321
+	public static function register_messengers_to_activate_mt_with($default_types, EE_messenger $messenger)
322
+	{
323
+		if (empty(self::$_ee_message_type_registry)) {
324
+			return $default_types;
325
+		}
326
+		foreach (self::$_ee_message_type_registry as $message_type_name => $mt_reg) {
327
+			if (empty($mt_reg['messengers_to_activate_with']) || empty($mt_reg['mtfilename'])) {
328
+				continue;
329
+			}
330
+			// loop through each of the messengers and if it matches the loaded class
331
+			// then we add this message type to the
332
+			foreach ($mt_reg['messengers_to_activate_with'] as $msgr) {
333
+				if ($messenger->name == $msgr) {
334
+					$default_types[] = $message_type_name;
335
+				}
336
+			}
337
+		}
338 338
 
339
-        return $default_types;
340
-    }
339
+		return $default_types;
340
+	}
341 341
 
342 342
 
343
-    /**
344
-     * callback for FHEE__EE_messenger__get_valid_message_types__default_types filter.
345
-     *
346
-     * @since   4.3.0
347
-     * @param  array        $valid_types    array of message types valid with messenger (
348
-     *                                      corresponds to the $name property of message type)
349
-     * @param  EE_messenger $messenger      The EE_messenger the filter is called from.
350
-     * @return  array
351
-     */
352
-    public static function register_messengers_to_validate_mt_with($valid_types, EE_messenger $messenger)
353
-    {
354
-        if (empty(self::$_ee_message_type_registry)) {
355
-            return $valid_types;
356
-        }
357
-        foreach (self::$_ee_message_type_registry as $message_type_name => $mt_reg) {
358
-            if (empty($mt_reg['messengers_to_validate_with']) || empty($mt_reg['mtfilename'])) {
359
-                continue;
360
-            }
361
-            // loop through each of the messengers and if it matches the loaded class
362
-            // then we add this message type to the
363
-            foreach ($mt_reg['messengers_to_validate_with'] as $msgr) {
364
-                if ($messenger->name == $msgr) {
365
-                    $valid_types[] = $message_type_name;
366
-                }
367
-            }
368
-        }
343
+	/**
344
+	 * callback for FHEE__EE_messenger__get_valid_message_types__default_types filter.
345
+	 *
346
+	 * @since   4.3.0
347
+	 * @param  array        $valid_types    array of message types valid with messenger (
348
+	 *                                      corresponds to the $name property of message type)
349
+	 * @param  EE_messenger $messenger      The EE_messenger the filter is called from.
350
+	 * @return  array
351
+	 */
352
+	public static function register_messengers_to_validate_mt_with($valid_types, EE_messenger $messenger)
353
+	{
354
+		if (empty(self::$_ee_message_type_registry)) {
355
+			return $valid_types;
356
+		}
357
+		foreach (self::$_ee_message_type_registry as $message_type_name => $mt_reg) {
358
+			if (empty($mt_reg['messengers_to_validate_with']) || empty($mt_reg['mtfilename'])) {
359
+				continue;
360
+			}
361
+			// loop through each of the messengers and if it matches the loaded class
362
+			// then we add this message type to the
363
+			foreach ($mt_reg['messengers_to_validate_with'] as $msgr) {
364
+				if ($messenger->name == $msgr) {
365
+					$valid_types[] = $message_type_name;
366
+				}
367
+			}
368
+		}
369 369
 
370
-        return $valid_types;
371
-    }
370
+		return $valid_types;
371
+	}
372 372
 
373 373
 
374
-    /**
375
-     * Callback for `FHEE__EE_Messages_Template_Pack_Default__get_supports` filter to register this message type as
376
-     * supporting the default template pack
377
-     *
378
-     * @param array $supports
379
-     *
380
-     * @return array
381
-     */
382
-    public static function register_default_template_pack_supports($supports)
383
-    {
384
-        foreach (self::$_ee_message_type_registry as $message_type_name => $mt_reg) {
385
-            if (empty($mt_reg['messengers_supporting_default_template_pack_with'])) {
386
-                continue;
387
-            }
388
-            foreach ($mt_reg['messengers_supporting_default_template_pack_with'] as $messenger_slug) {
389
-                $supports[$messenger_slug][] = $message_type_name;
390
-            }
391
-        }
392
-        return $supports;
393
-    }
374
+	/**
375
+	 * Callback for `FHEE__EE_Messages_Template_Pack_Default__get_supports` filter to register this message type as
376
+	 * supporting the default template pack
377
+	 *
378
+	 * @param array $supports
379
+	 *
380
+	 * @return array
381
+	 */
382
+	public static function register_default_template_pack_supports($supports)
383
+	{
384
+		foreach (self::$_ee_message_type_registry as $message_type_name => $mt_reg) {
385
+			if (empty($mt_reg['messengers_supporting_default_template_pack_with'])) {
386
+				continue;
387
+			}
388
+			foreach ($mt_reg['messengers_supporting_default_template_pack_with'] as $messenger_slug) {
389
+				$supports[$messenger_slug][] = $message_type_name;
390
+			}
391
+		}
392
+		return $supports;
393
+	}
394 394
 
395 395
 
396
-    /**
397
-     * Callback for FHEE__EE_Template_Pack___get_specific_template__filtered_base_path
398
-     *
399
-     * @param string $base_path The original base path for message templates
400
-     * @param EE_messenger $messenger
401
-     * @param EE_message_type $message_type
402
-     * @param string $field  The field requesting a template
403
-     * @param string $context  The context requesting a template
404
-     * @param EE_Messages_Template_Pack $template_pack
405
-     *
406
-     * @return string
407
-     */
408
-    public static function register_base_template_path(
409
-        $base_path,
410
-        $messenger,
411
-        $message_type,
412
-        $field,
413
-        $context,
414
-        $template_pack
415
-    ) {
416
-        if (! $template_pack instanceof EE_Messages_Template_Pack_Default
417
-            || ! $message_type instanceof EE_message_type
418
-        ) {
419
-            return $base_path;
420
-        }
421
-        foreach (self::$_ee_message_type_registry as $message_type_name => $mt_reg) {
422
-            if ($message_type->name === $message_type_name
423
-                && ! empty($mt_reg['base_path_for_default_templates'])
424
-            ) {
425
-                return $mt_reg['base_path_for_default_templates'];
426
-            }
427
-        }
428
-        return $base_path;
429
-    }
396
+	/**
397
+	 * Callback for FHEE__EE_Template_Pack___get_specific_template__filtered_base_path
398
+	 *
399
+	 * @param string $base_path The original base path for message templates
400
+	 * @param EE_messenger $messenger
401
+	 * @param EE_message_type $message_type
402
+	 * @param string $field  The field requesting a template
403
+	 * @param string $context  The context requesting a template
404
+	 * @param EE_Messages_Template_Pack $template_pack
405
+	 *
406
+	 * @return string
407
+	 */
408
+	public static function register_base_template_path(
409
+		$base_path,
410
+		$messenger,
411
+		$message_type,
412
+		$field,
413
+		$context,
414
+		$template_pack
415
+	) {
416
+		if (! $template_pack instanceof EE_Messages_Template_Pack_Default
417
+			|| ! $message_type instanceof EE_message_type
418
+		) {
419
+			return $base_path;
420
+		}
421
+		foreach (self::$_ee_message_type_registry as $message_type_name => $mt_reg) {
422
+			if ($message_type->name === $message_type_name
423
+				&& ! empty($mt_reg['base_path_for_default_templates'])
424
+			) {
425
+				return $mt_reg['base_path_for_default_templates'];
426
+			}
427
+		}
428
+		return $base_path;
429
+	}
430 430
 
431 431
 
432
-    /**
433
-     * Callback for FHEE__EE_Messages_Template_Pack__get_variation__base_path and
434
-     * FHEE__EE_Messages_Template_Pack__get_variation__base_path_or_url hooks
435
-     *
436
-     * @param string $base_path_or_url       The original incoming base url or path
437
-     * @param string $messenger_slug      The slug of the messenger the template is being generated for.
438
-     * @param string $message_type_slug The slug of the message type the template is being generated for.
439
-     * @param string $type             The "type" of css being requested.
440
-     * @param string $variation      The variation being requested.
441
-     * @param string $file_extension What file extension is expected for the variation file.
442
-     * @param bool $url whether a url or path is being requested.
443
-     * @param EE_Messages_Template_Pack $template_pack
444
-     *
445
-     * @return string
446
-     */
447
-    public static function register_variation_base_path_or_url(
448
-        $base_path_or_url,
449
-        $messenger_slug,
450
-        $message_type_slug,
451
-        $type,
452
-        $variation,
453
-        $url,
454
-        $file_extension,
455
-        $template_pack
456
-    ) {
457
-        if (! $template_pack instanceof EE_Messages_Template_Pack_Default) {
458
-            return $base_path_or_url;
459
-        }
460
-        foreach (self::$_ee_message_type_registry as $message_type_name => $mt_reg) {
461
-            if ($message_type_name === $message_type_slug
462
-            ) {
463
-                if ($url
464
-                    && ! empty($mt_reg['base_url_for_default_variation'])
465
-                ) {
466
-                    return $mt_reg['base_url_for_default_variation'];
467
-                } elseif (! $url
468
-                    && ! empty($mt_reg['base_path_for_default_variation'])
469
-                ) {
470
-                    return $mt_reg['base_path_for_default_variation'];
471
-                }
472
-            }
473
-        }
474
-        return $base_path_or_url;
475
-    }
432
+	/**
433
+	 * Callback for FHEE__EE_Messages_Template_Pack__get_variation__base_path and
434
+	 * FHEE__EE_Messages_Template_Pack__get_variation__base_path_or_url hooks
435
+	 *
436
+	 * @param string $base_path_or_url       The original incoming base url or path
437
+	 * @param string $messenger_slug      The slug of the messenger the template is being generated for.
438
+	 * @param string $message_type_slug The slug of the message type the template is being generated for.
439
+	 * @param string $type             The "type" of css being requested.
440
+	 * @param string $variation      The variation being requested.
441
+	 * @param string $file_extension What file extension is expected for the variation file.
442
+	 * @param bool $url whether a url or path is being requested.
443
+	 * @param EE_Messages_Template_Pack $template_pack
444
+	 *
445
+	 * @return string
446
+	 */
447
+	public static function register_variation_base_path_or_url(
448
+		$base_path_or_url,
449
+		$messenger_slug,
450
+		$message_type_slug,
451
+		$type,
452
+		$variation,
453
+		$url,
454
+		$file_extension,
455
+		$template_pack
456
+	) {
457
+		if (! $template_pack instanceof EE_Messages_Template_Pack_Default) {
458
+			return $base_path_or_url;
459
+		}
460
+		foreach (self::$_ee_message_type_registry as $message_type_name => $mt_reg) {
461
+			if ($message_type_name === $message_type_slug
462
+			) {
463
+				if ($url
464
+					&& ! empty($mt_reg['base_url_for_default_variation'])
465
+				) {
466
+					return $mt_reg['base_url_for_default_variation'];
467
+				} elseif (! $url
468
+					&& ! empty($mt_reg['base_path_for_default_variation'])
469
+				) {
470
+					return $mt_reg['base_path_for_default_variation'];
471
+				}
472
+			}
473
+		}
474
+		return $base_path_or_url;
475
+	}
476 476
 }
Please login to merge, or discard this patch.
Spacing   +14 added lines, -14 removed lines patch added patch discarded remove patch
@@ -6,7 +6,7 @@  discard block
 block discarded – undo
6 6
  * @subpackage      plugin api, messages
7 7
  * @since           4.3.0
8 8
  */
9
-if (! defined('EVENT_ESPRESSO_VERSION')) {
9
+if ( ! defined('EVENT_ESPRESSO_VERSION')) {
10 10
     exit('No direct script access allowed');
11 11
 }
12 12
 
@@ -93,20 +93,20 @@  discard block
 block discarded – undo
93 93
              * Required.
94 94
              * @type string
95 95
              */
96
-            'mtfilename'                  => (string)$setup_args['mtfilename'],
96
+            'mtfilename'                  => (string) $setup_args['mtfilename'],
97 97
             /**
98 98
              * Autoload paths for classes used by the message type.
99 99
              * Required.
100 100
              * @type array
101 101
              */
102
-            'autoloadpaths'               => (array)$setup_args['autoloadpaths'],
102
+            'autoloadpaths'               => (array) $setup_args['autoloadpaths'],
103 103
             /**
104 104
              * Messengers that the message type should be able to activate with.
105 105
              * Use messenger slugs.
106 106
              * @type array
107 107
              */
108 108
             'messengers_to_activate_with' => ! empty($setup_args['messengers_to_activate_with'])
109
-                ? (array)$setup_args['messengers_to_activate_with']
109
+                ? (array) $setup_args['messengers_to_activate_with']
110 110
                 : array(),
111 111
             /**
112 112
              * Messengers that the message type should validate with.
@@ -114,14 +114,14 @@  discard block
 block discarded – undo
114 114
              * @type array
115 115
              */
116 116
             'messengers_to_validate_with' => ! empty($setup_args['messengers_to_validate_with'])
117
-                ? (array)$setup_args['messengers_to_validate_with']
117
+                ? (array) $setup_args['messengers_to_validate_with']
118 118
                 : array(),
119 119
             /**
120 120
              * Whether to force activate this message type the first time it is registered.
121 121
              * @type bool   False means its not activated by default and left up to the end user to activate.
122 122
              */
123 123
             'force_activation'            => ! empty($setup_args['force_activation'])
124
-                ? (bool)$setup_args['force_activation']
124
+                ? (bool) $setup_args['force_activation']
125 125
                 : false,
126 126
             /**
127 127
              * What messengers this message type supports the default template pack for.
@@ -136,7 +136,7 @@  discard block
 block discarded – undo
136 136
              * @type array   Expect an array of messengers this supports default template packs for.
137 137
              */
138 138
             'messengers_supporting_default_template_pack_with' => isset($setup_args['messengers_supporting_default_template_pack_with'])
139
-                ? (array)$setup_args['messengers_supporting_default_template_pack_with']
139
+                ? (array) $setup_args['messengers_supporting_default_template_pack_with']
140 140
                 : array(),
141 141
             /**
142 142
              * The base path where the default templates for this message type can be found.
@@ -162,7 +162,7 @@  discard block
 block discarded – undo
162 162
         );
163 163
         //add filters but only if they haven't already been set (these filters only need to be registered ONCE because
164 164
         //the callback handles all registered message types.
165
-        if ( false === has_filter(
165
+        if (false === has_filter(
166 166
             'FHEE__EED_Messages___set_messages_paths___MSG_PATHS',
167 167
             array('EE_Register_Message_Type', 'register_msgs_autoload_paths')
168 168
         )) {
@@ -236,7 +236,7 @@  discard block
 block discarded – undo
236 236
             if ($settings['force_activation']) {
237 237
                 foreach ($settings['messengers_to_activate_with'] as $messenger) {
238 238
                     //DO not force activation if this message type has already been activated in the system
239
-                    if (! $message_resource_manager->has_message_type_been_activated_for_messenger($message_type_name,
239
+                    if ( ! $message_resource_manager->has_message_type_been_activated_for_messenger($message_type_name,
240 240
                         $messenger)
241 241
                     ) {
242 242
                         $message_resource_manager->ensure_message_type_is_active($message_type_name, $messenger);
@@ -256,7 +256,7 @@  discard block
 block discarded – undo
256 256
      */
257 257
     public static function deregister($message_type_name = null)
258 258
     {
259
-        if (! empty(self::$_ee_message_type_registry[$message_type_name])) {
259
+        if ( ! empty(self::$_ee_message_type_registry[$message_type_name])) {
260 260
             //let's make sure that we remove any place this message type was made active
261 261
             /** @var EE_Message_Resource_Manager $Message_Resource_Manager */
262 262
             $Message_Resource_Manager = EE_Registry::instance()->load_lib('Message_Resource_Manager');
@@ -297,7 +297,7 @@  discard block
 block discarded – undo
297 297
      */
298 298
     public static function register_msgs_autoload_paths($paths)
299 299
     {
300
-        if (! empty(self::$_ee_message_type_registry)) {
300
+        if ( ! empty(self::$_ee_message_type_registry)) {
301 301
             foreach (self::$_ee_message_type_registry as $mt_reg) {
302 302
                 if (empty($mt_reg['autoloadpaths'])) {
303 303
                     continue;
@@ -413,7 +413,7 @@  discard block
 block discarded – undo
413 413
         $context,
414 414
         $template_pack
415 415
     ) {
416
-        if (! $template_pack instanceof EE_Messages_Template_Pack_Default
416
+        if ( ! $template_pack instanceof EE_Messages_Template_Pack_Default
417 417
             || ! $message_type instanceof EE_message_type
418 418
         ) {
419 419
             return $base_path;
@@ -454,7 +454,7 @@  discard block
 block discarded – undo
454 454
         $file_extension,
455 455
         $template_pack
456 456
     ) {
457
-        if (! $template_pack instanceof EE_Messages_Template_Pack_Default) {
457
+        if ( ! $template_pack instanceof EE_Messages_Template_Pack_Default) {
458 458
             return $base_path_or_url;
459 459
         }
460 460
         foreach (self::$_ee_message_type_registry as $message_type_name => $mt_reg) {
@@ -464,7 +464,7 @@  discard block
 block discarded – undo
464 464
                     && ! empty($mt_reg['base_url_for_default_variation'])
465 465
                 ) {
466 466
                     return $mt_reg['base_url_for_default_variation'];
467
-                } elseif (! $url
467
+                } elseif ( ! $url
468 468
                     && ! empty($mt_reg['base_path_for_default_variation'])
469 469
                 ) {
470 470
                     return $mt_reg['base_path_for_default_variation'];
Please login to merge, or discard this patch.
core/EE_Maintenance_Mode.core.php 1 patch
Spacing   +35 added lines, -35 removed lines patch added patch discarded remove patch
@@ -73,7 +73,7 @@  discard block
 block discarded – undo
73 73
 	 */
74 74
 	public static function instance() {
75 75
 		// check if class object is instantiated
76
-		if ( self::$_instance === NULL  or ! is_object( self::$_instance ) or ! ( self::$_instance instanceof EE_Maintenance_Mode )) {
76
+		if (self::$_instance === NULL or ! is_object(self::$_instance) or ! (self::$_instance instanceof EE_Maintenance_Mode)) {
77 77
 			self::$_instance = new self();
78 78
 		}
79 79
 		return self::$_instance;
@@ -83,7 +83,7 @@  discard block
 block discarded – undo
83 83
 	 * Resets maintenance mode (mostly just re-checks whether or not we should be in maintenance mode)
84 84
 	 * @return EE_Maintenance_Mode
85 85
 	 */
86
-	public static function reset(){
86
+	public static function reset() {
87 87
 		self::instance()->set_maintenance_mode_if_db_old();
88 88
 		return self::instance();
89 89
 	}
@@ -98,11 +98,11 @@  discard block
 block discarded – undo
98 98
 	 */
99 99
 	private function __construct() {
100 100
 		// if M-Mode level 2 is engaged, we still need basic assets loaded
101
-		add_action( 'wp_enqueue_scripts', array( $this, 'load_assets_required_for_m_mode' ));
101
+		add_action('wp_enqueue_scripts', array($this, 'load_assets_required_for_m_mode'));
102 102
 		// shut 'er down down for maintenance ?
103
-		add_filter( 'the_content', array( $this, 'the_content' ), 2 );
103
+		add_filter('the_content', array($this, 'the_content'), 2);
104 104
 		// add powered by EE msg
105
-		add_action( 'shutdown', array( $this, 'display_maintenance_mode_notice' ), 10 );
105
+		add_action('shutdown', array($this, 'display_maintenance_mode_notice'), 10);
106 106
 	}
107 107
 
108 108
 
@@ -112,8 +112,8 @@  discard block
 block discarded – undo
112 112
 	 * retrieves the maintenance mode option value from the db
113 113
 	 * @return int
114 114
 	 */
115
-	public function real_level(){
116
-		return get_option( self::option_name_maintenance_mode, EE_Maintenance_Mode::level_0_not_in_maintenance );
115
+	public function real_level() {
116
+		return get_option(self::option_name_maintenance_mode, EE_Maintenance_Mode::level_0_not_in_maintenance);
117 117
 	}
118 118
 
119 119
 	/**
@@ -121,7 +121,7 @@  discard block
 block discarded – undo
121 121
 	 * thinks their tables are present and up-to-date).
122 122
 	 * @return boolean
123 123
 	 */
124
-	public function models_can_query(){
124
+	public function models_can_query() {
125 125
 		return $this->real_level() != EE_Maintenance_Mode::level_2_complete_maintenance;
126 126
 	}
127 127
 
@@ -134,14 +134,14 @@  discard block
 block discarded – undo
134 134
 	 * EE_Maintenance_Mode::level_2_complete_maintenance => frontend and backend maintenance mode
135 135
 	 * @return int
136 136
 	 */
137
-	public function level(){
137
+	public function level() {
138 138
 		$real_maintenance_mode_level = $this->real_level();
139 139
 		//if this is an admin request, we'll be honest... except if it's ajax, because that might be from the frontend
140
-		if( ( ! is_admin() || (defined('DOING_AJAX') && DOING_AJAX)) && //only on frontend or ajax requests
140
+		if (( ! is_admin() || (defined('DOING_AJAX') && DOING_AJAX)) && //only on frontend or ajax requests
141 141
 			current_user_can('administrator') && //when the user is an admin
142
-			$real_maintenance_mode_level == EE_Maintenance_Mode::level_1_frontend_only_maintenance){//and we're in level 1
142
+			$real_maintenance_mode_level == EE_Maintenance_Mode::level_1_frontend_only_maintenance) {//and we're in level 1
143 143
 			$maintenance_mode_level = EE_Maintenance_Mode::level_0_not_in_maintenance;
144
-		}else{
144
+		} else {
145 145
 			$maintenance_mode_level = $real_maintenance_mode_level;
146 146
 		}
147 147
 		return $maintenance_mode_level;
@@ -151,17 +151,17 @@  discard block
 block discarded – undo
151 151
 	 * Determines if we need to put EE in maintenance mode because the database needs updating
152 152
 	 * @return boolean true if DB is old and maintenance mode was triggered; false otherwise
153 153
 	 */
154
-	public function set_maintenance_mode_if_db_old(){
155
-		EE_Registry::instance()->load_core( 'Data_Migration_Manager' );
156
-		if( EE_Data_Migration_Manager::instance()->check_for_applicable_data_migration_scripts()){
154
+	public function set_maintenance_mode_if_db_old() {
155
+		EE_Registry::instance()->load_core('Data_Migration_Manager');
156
+		if (EE_Data_Migration_Manager::instance()->check_for_applicable_data_migration_scripts()) {
157 157
 			update_option(self::option_name_maintenance_mode, self::level_2_complete_maintenance);
158 158
 			return true;
159
-		}elseif( $this->level() == self::level_2_complete_maintenance ){
159
+		}elseif ($this->level() == self::level_2_complete_maintenance) {
160 160
 			//we also want to handle the opposite: if the site is mm2, but there aren't any migrations to run
161 161
 			//then we shouldn't be in mm2. (Maybe an addon got deactivated?)
162
-			update_option( self::option_name_maintenance_mode, self::level_0_not_in_maintenance );
162
+			update_option(self::option_name_maintenance_mode, self::level_0_not_in_maintenance);
163 163
 			return false;
164
-		}else{
164
+		} else {
165 165
 			return false;
166 166
 		}
167 167
 	}
@@ -171,8 +171,8 @@  discard block
 block discarded – undo
171 171
 	 * @param int $level
172 172
 	 * @return void
173 173
 	 */
174
-	public function set_maintenance_level($level){
175
-		do_action( 'AHEE__EE_Maintenance_Mode__set_maintenance_level', $level );
174
+	public function set_maintenance_level($level) {
175
+		do_action('AHEE__EE_Maintenance_Mode__set_maintenance_level', $level);
176 176
 		update_option(self::option_name_maintenance_mode, intval($level));
177 177
 	}
178 178
 
@@ -199,11 +199,11 @@  discard block
 block discarded – undo
199 199
 	 *  @return 	string
200 200
 	 */
201 201
 	public function load_assets_required_for_m_mode() {
202
-		if ( $this->real_level() == EE_Maintenance_Mode::level_2_complete_maintenance && ! wp_script_is( 'espresso_core', 'enqueued' )) {
203
-			wp_register_style( 'espresso_default', EE_GLOBAL_ASSETS_URL . 'css/espresso_default.css', array( 'dashicons' ), EVENT_ESPRESSO_VERSION );
202
+		if ($this->real_level() == EE_Maintenance_Mode::level_2_complete_maintenance && ! wp_script_is('espresso_core', 'enqueued')) {
203
+			wp_register_style('espresso_default', EE_GLOBAL_ASSETS_URL.'css/espresso_default.css', array('dashicons'), EVENT_ESPRESSO_VERSION);
204 204
 			wp_enqueue_style('espresso_default');
205
-			wp_register_script( 'espresso_core', EE_GLOBAL_ASSETS_URL . 'scripts/espresso_core.js', array('jquery'), EVENT_ESPRESSO_VERSION, TRUE );
206
-			wp_enqueue_script( 'espresso_core' );
205
+			wp_register_script('espresso_core', EE_GLOBAL_ASSETS_URL.'scripts/espresso_core.js', array('jquery'), EVENT_ESPRESSO_VERSION, TRUE);
206
+			wp_enqueue_script('espresso_core');
207 207
 		}
208 208
 	}
209 209
 
@@ -221,7 +221,7 @@  discard block
 block discarded – undo
221 221
 	 */
222 222
 	public static function template_include() {
223 223
 		// shut 'er down down for maintenance ? then don't use any of our templates for our endpoints
224
-		return get_template_directory() . '/index.php';
224
+		return get_template_directory().'/index.php';
225 225
 	}
226 226
 
227 227
 
@@ -235,12 +235,12 @@  discard block
 block discarded – undo
235 235
 	 * @param    string $the_content
236 236
 	 * @return    string
237 237
 	 */
238
-	public function the_content( $the_content ) {
238
+	public function the_content($the_content) {
239 239
 		// check if M-mode is engaged and for EE shortcode
240
-		if ( $this->level() && strpos( $the_content, '[ESPRESSO_' ) !== false ) {
240
+		if ($this->level() && strpos($the_content, '[ESPRESSO_') !== false) {
241 241
 			// this can eventually be moved to a template, or edited via admin. But for now...
242 242
 			$the_content = sprintf(
243
-				__( '%sMaintenance Mode%sEvent Registration has been temporarily closed while system maintenance is being performed. We\'re sorry for any inconveniences this may have caused. Please try back again later.%s', 'event_espresso' ),
243
+				__('%sMaintenance Mode%sEvent Registration has been temporarily closed while system maintenance is being performed. We\'re sorry for any inconveniences this may have caused. Please try back again later.%s', 'event_espresso'),
244 244
 				'<h3>',
245 245
 				'</h3><p>',
246 246
 				'</p>'
@@ -264,16 +264,16 @@  discard block
 block discarded – undo
264 264
 		// check if M-mode is engaged and for EE shortcode
265 265
 		if (
266 266
 			$this->real_level() &&
267
-			current_user_can( 'administrator' ) &&
267
+			current_user_can('administrator') &&
268 268
 			! is_admin() &&
269
-			! ( defined( 'DOING_AJAX' ) && DOING_AJAX )
269
+			! (defined('DOING_AJAX') && DOING_AJAX)
270 270
 			&& EE_Registry::instance()->REQ->is_espresso_page()
271 271
 		) {
272 272
 			printf(
273
-				__( '%sclose%sEvent Registration is currently disabled because Event Espresso has been placed into Maintenance Mode. To change Maintenance Mode settings, click here %sEE Maintenance Mode Admin Page%s', 'event_espresso' ),
273
+				__('%sclose%sEvent Registration is currently disabled because Event Espresso has been placed into Maintenance Mode. To change Maintenance Mode settings, click here %sEE Maintenance Mode Admin Page%s', 'event_espresso'),
274 274
 				'<div id="ee-m-mode-admin-notice-dv" class="ee-really-important-notice-dv"><a class="close-espresso-notice" title="',
275 275
 				'"><span class="dashicons dashicons-no"></span></a><p>',
276
-				' &raquo; <a href="' . add_query_arg( array( 'page' => 'espresso_maintenance_settings' ), admin_url( 'admin.php' )) . '">',
276
+				' &raquo; <a href="'.add_query_arg(array('page' => 'espresso_maintenance_settings'), admin_url('admin.php')).'">',
277 277
 				'</a></p></div>'
278 278
 			);
279 279
 		}
@@ -291,9 +291,9 @@  discard block
 block discarded – undo
291 291
 	 *		@ return void
292 292
 	 */
293 293
 	final function __destruct() {}
294
-	final function __call($a,$b) {}
294
+	final function __call($a, $b) {}
295 295
 	final function __get($a) {}
296
-	final function __set($a,$b) {}
296
+	final function __set($a, $b) {}
297 297
 	final function __isset($a) {}
298 298
 	final function __unset($a) {}
299 299
 	final function __sleep() {
@@ -304,7 +304,7 @@  discard block
 block discarded – undo
304 304
 	final function __invoke() {}
305 305
 	final static function __set_state() {}
306 306
 	final function __clone() {}
307
-	final static function __callStatic($a,$b) {}
307
+	final static function __callStatic($a, $b) {}
308 308
 
309 309
 }
310 310
 // End of file EE_Maintenance_Mode.core.php
Please login to merge, or discard this patch.
core/EE_Registry.core.php 1 patch
Indentation   +1336 added lines, -1336 removed lines patch added patch discarded remove patch
@@ -16,1372 +16,1372 @@
 block discarded – undo
16 16
 class EE_Registry
17 17
 {
18 18
 
19
-    /**
20
-     *    EE_Registry Object
21
-     *
22
-     * @var EE_Registry $_instance
23
-     * @access    private
24
-     */
25
-    private static $_instance = null;
26
-
27
-    /**
28
-     * @var EE_Dependency_Map $_dependency_map
29
-     * @access    protected
30
-     */
31
-    protected $_dependency_map = null;
32
-
33
-    /**
34
-     * @var array $_class_abbreviations
35
-     * @access    protected
36
-     */
37
-    protected $_class_abbreviations = array();
38
-
39
-    /**
40
-     * @access public
41
-     * @var \EventEspresso\core\services\commands\CommandBusInterface $BUS
42
-     */
43
-    public $BUS;
44
-
45
-    /**
46
-     *    EE_Cart Object
47
-     *
48
-     * @access    public
49
-     * @var    EE_Cart $CART
50
-     */
51
-    public $CART = null;
52
-
53
-    /**
54
-     *    EE_Config Object
55
-     *
56
-     * @access    public
57
-     * @var    EE_Config $CFG
58
-     */
59
-    public $CFG = null;
60
-
61
-    /**
62
-     * EE_Network_Config Object
63
-     *
64
-     * @access public
65
-     * @var EE_Network_Config $NET_CFG
66
-     */
67
-    public $NET_CFG = null;
68
-
69
-    /**
70
-     *    StdClass object for storing library classes in
71
-     *
72
-     * @public LIB
73
-     * @var StdClass $LIB
74
-     */
75
-    public $LIB = null;
76
-
77
-    /**
78
-     *    EE_Request_Handler Object
79
-     *
80
-     * @access    public
81
-     * @var    EE_Request_Handler $REQ
82
-     */
83
-    public $REQ = null;
84
-
85
-    /**
86
-     *    EE_Session Object
87
-     *
88
-     * @access    public
89
-     * @var    EE_Session $SSN
90
-     */
91
-    public $SSN = null;
92
-
93
-    /**
94
-     * holds the ee capabilities object.
95
-     *
96
-     * @since 4.5.0
97
-     * @var EE_Capabilities
98
-     */
99
-    public $CAP = null;
100
-
101
-    /**
102
-     * holds the EE_Message_Resource_Manager object.
103
-     *
104
-     * @since 4.9.0
105
-     * @var EE_Message_Resource_Manager
106
-     */
107
-    public $MRM = null;
108
-
109
-
110
-    /**
111
-     * Holds the Assets Registry instance
112
-     * @var Registry
113
-     */
114
-    public $AssetsRegistry = null;
115
-
116
-    /**
117
-     *    $addons - StdClass object for holding addons which have registered themselves to work with EE core
118
-     *
119
-     * @access    public
120
-     * @var    EE_Addon[]
121
-     */
122
-    public $addons = null;
123
-
124
-    /**
125
-     *    $models
126
-     * @access    public
127
-     * @var    EEM_Base[] $models keys are 'short names' (eg Event), values are class names (eg 'EEM_Event')
128
-     */
129
-    public $models = array();
130
-
131
-    /**
132
-     *    $modules
133
-     * @access    public
134
-     * @var    EED_Module[] $modules
135
-     */
136
-    public $modules = null;
137
-
138
-    /**
139
-     *    $shortcodes
140
-     * @access    public
141
-     * @var    EES_Shortcode[] $shortcodes
142
-     */
143
-    public $shortcodes = null;
144
-
145
-    /**
146
-     *    $widgets
147
-     * @access    public
148
-     * @var    WP_Widget[] $widgets
149
-     */
150
-    public $widgets = null;
151
-
152
-    /**
153
-     * $non_abstract_db_models
154
-     * @access public
155
-     * @var array this is an array of all implemented model names (i.e. not the parent abstract models, or models
156
-     * which don't actually fetch items from the DB in the normal way (ie, are not children of EEM_Base)).
157
-     * Keys are model "short names" (eg "Event") as used in model relations, and values are
158
-     * classnames (eg "EEM_Event")
159
-     */
160
-    public $non_abstract_db_models = array();
161
-
162
-
163
-    /**
164
-     *    $i18n_js_strings - internationalization for JS strings
165
-     *    usage:   EE_Registry::i18n_js_strings['string_key'] = __( 'string to translate.', 'event_espresso' );
166
-     *    in js file:  var translatedString = eei18n.string_key;
167
-     *
168
-     * @access    public
169
-     * @var    array
170
-     */
171
-    public static $i18n_js_strings = array();
172
-
173
-
174
-    /**
175
-     *    $main_file - path to espresso.php
176
-     *
177
-     * @access    public
178
-     * @var    array
179
-     */
180
-    public $main_file;
181
-
182
-    /**
183
-     * array of ReflectionClass objects where the key is the class name
184
-     *
185
-     * @access    public
186
-     * @var ReflectionClass[]
187
-     */
188
-    public $_reflectors;
189
-
190
-    /**
191
-     * boolean flag to indicate whether or not to load/save dependencies from/to the cache
192
-     *
193
-     * @access    protected
194
-     * @var boolean $_cache_on
195
-     */
196
-    protected $_cache_on = true;
197
-
198
-
199
-
200
-    /**
201
-     * @singleton method used to instantiate class object
202
-     * @access    public
203
-     * @param  \EE_Dependency_Map $dependency_map
204
-     * @return \EE_Registry instance
205
-     */
206
-    public static function instance(\EE_Dependency_Map $dependency_map = null)
207
-    {
208
-        // check if class object is instantiated
209
-        if ( ! self::$_instance instanceof EE_Registry) {
210
-            self::$_instance = new EE_Registry($dependency_map);
211
-        }
212
-        return self::$_instance;
213
-    }
214
-
215
-
216
-
217
-    /**
218
-     *protected constructor to prevent direct creation
219
-     *
220
-     * @Constructor
221
-     * @access protected
222
-     * @param  \EE_Dependency_Map $dependency_map
223
-     * @return \EE_Registry
224
-     */
225
-    protected function __construct(\EE_Dependency_Map $dependency_map)
226
-    {
227
-        $this->_dependency_map = $dependency_map;
228
-        add_action('EE_Load_Espresso_Core__handle_request__initialize_core_loading', array($this, 'initialize'));
229
-    }
230
-
231
-
232
-
233
-    /**
234
-     * initialize
235
-     */
236
-    public function initialize()
237
-    {
238
-        $this->_class_abbreviations = apply_filters(
239
-            'FHEE__EE_Registry____construct___class_abbreviations',
240
-            array(
241
-                'EE_Config'                                       => 'CFG',
242
-                'EE_Session'                                      => 'SSN',
243
-                'EE_Capabilities'                                 => 'CAP',
244
-                'EE_Cart'                                         => 'CART',
245
-                'EE_Network_Config'                               => 'NET_CFG',
246
-                'EE_Request_Handler'                              => 'REQ',
247
-                'EE_Message_Resource_Manager'                     => 'MRM',
248
-                'EventEspresso\core\services\commands\CommandBus' => 'BUS',
249
-            )
250
-        );
251
-        // class library
252
-        $this->LIB = new stdClass();
253
-        $this->addons = new stdClass();
254
-        $this->modules = new stdClass();
255
-        $this->shortcodes = new stdClass();
256
-        $this->widgets = new stdClass();
257
-        $this->load_core('Base', array(), true);
258
-        // add our request and response objects to the cache
259
-        $request_loader = $this->_dependency_map->class_loader('EE_Request');
260
-        $this->_set_cached_class(
261
-            $request_loader(),
262
-            'EE_Request'
263
-        );
264
-        $response_loader = $this->_dependency_map->class_loader('EE_Response');
265
-        $this->_set_cached_class(
266
-            $response_loader(),
267
-            'EE_Response'
268
-        );
269
-        add_action('AHEE__EE_System__set_hooks_for_core', array($this, 'init'));
270
-    }
271
-
272
-
273
-
274
-    /**
275
-     *    init
276
-     *
277
-     * @access    public
278
-     * @return    void
279
-     */
280
-    public function init()
281
-    {
282
-        $this->AssetsRegistry = new Registry();
283
-        // Get current page protocol
284
-        $protocol = isset($_SERVER['HTTPS']) ? 'https://' : 'http://';
285
-        // Output admin-ajax.php URL with same protocol as current page
286
-        self::$i18n_js_strings['ajax_url'] = admin_url('admin-ajax.php', $protocol);
287
-        self::$i18n_js_strings['wp_debug'] = defined('WP_DEBUG') ? WP_DEBUG : false;
288
-    }
289
-
290
-
291
-
292
-    /**
293
-     * localize_i18n_js_strings
294
-     *
295
-     * @return string
296
-     */
297
-    public static function localize_i18n_js_strings()
298
-    {
299
-        $i18n_js_strings = (array)EE_Registry::$i18n_js_strings;
300
-        foreach ($i18n_js_strings as $key => $value) {
301
-            if (is_scalar($value)) {
302
-                $i18n_js_strings[$key] = html_entity_decode((string)$value, ENT_QUOTES, 'UTF-8');
303
-            }
304
-        }
305
-        return "/* <![CDATA[ */ var eei18n = " . wp_json_encode($i18n_js_strings) . '; /* ]]> */';
306
-    }
307
-
308
-
309
-
310
-    /**
311
-     * @param mixed string | EED_Module $module
312
-     */
313
-    public function add_module($module)
314
-    {
315
-        if ($module instanceof EED_Module) {
316
-            $module_class = get_class($module);
317
-            $this->modules->{$module_class} = $module;
318
-        } else {
319
-            if ( ! class_exists('EE_Module_Request_Router')) {
320
-                $this->load_core('Module_Request_Router');
321
-            }
322
-            $this->modules->{$module} = EE_Module_Request_Router::module_factory($module);
323
-        }
324
-    }
325
-
326
-
327
-
328
-    /**
329
-     * @param string $module_name
330
-     * @return mixed EED_Module | NULL
331
-     */
332
-    public function get_module($module_name = '')
333
-    {
334
-        return isset($this->modules->{$module_name}) ? $this->modules->{$module_name} : null;
335
-    }
336
-
337
-
338
-
339
-    /**
340
-     *    loads core classes - must be singletons
341
-     *
342
-     * @access    public
343
-     * @param string $class_name - simple class name ie: session
344
-     * @param mixed  $arguments
345
-     * @param bool   $load_only
346
-     * @return mixed
347
-     */
348
-    public function load_core($class_name, $arguments = array(), $load_only = false)
349
-    {
350
-        $core_paths = apply_filters(
351
-            'FHEE__EE_Registry__load_core__core_paths',
352
-            array(
353
-                EE_CORE,
354
-                EE_ADMIN,
355
-                EE_CPTS,
356
-                EE_CORE . 'data_migration_scripts' . DS,
357
-                EE_CORE . 'request_stack' . DS,
358
-                EE_CORE . 'middleware' . DS,
359
-            )
360
-        );
361
-        // retrieve instantiated class
362
-        return $this->_load($core_paths, 'EE_', $class_name, 'core', $arguments, false, true, $load_only);
363
-    }
364
-
365
-
366
-
367
-    /**
368
-     *    loads service classes
369
-     *
370
-     * @access    public
371
-     * @param string $class_name - simple class name ie: session
372
-     * @param mixed  $arguments
373
-     * @param bool   $load_only
374
-     * @return mixed
375
-     */
376
-    public function load_service($class_name, $arguments = array(), $load_only = false)
377
-    {
378
-        $service_paths = apply_filters(
379
-            'FHEE__EE_Registry__load_service__service_paths',
380
-            array(
381
-                EE_CORE . 'services' . DS,
382
-            )
383
-        );
384
-        // retrieve instantiated class
385
-        return $this->_load($service_paths, 'EE_', $class_name, 'class', $arguments, false, true, $load_only);
386
-    }
387
-
388
-
389
-
390
-    /**
391
-     *    loads data_migration_scripts
392
-     *
393
-     * @access    public
394
-     * @param string $class_name - class name for the DMS ie: EE_DMS_Core_4_2_0
395
-     * @param mixed  $arguments
396
-     * @return EE_Data_Migration_Script_Base|mixed
397
-     */
398
-    public function load_dms($class_name, $arguments = array())
399
-    {
400
-        // retrieve instantiated class
401
-        return $this->_load(EE_Data_Migration_Manager::instance()->get_data_migration_script_folders(), 'EE_DMS_', $class_name, 'dms', $arguments, false, false, false);
402
-    }
403
-
404
-
405
-
406
-    /**
407
-     *    loads object creating classes - must be singletons
408
-     *
409
-     * @param string $class_name - simple class name ie: attendee
410
-     * @param mixed  $arguments  - an array of arguments to pass to the class
411
-     * @param bool   $from_db    - some classes are instantiated from the db and thus call a different method to instantiate
412
-     * @param bool   $cache      if you don't want the class to be stored in the internal cache (non-persistent) then set this to FALSE (ie. when instantiating model objects from client in a loop)
413
-     * @param bool   $load_only  whether or not to just load the file and NOT instantiate, or load AND instantiate (default)
414
-     * @return EE_Base_Class | bool
415
-     */
416
-    public function load_class($class_name, $arguments = array(), $from_db = false, $cache = true, $load_only = false)
417
-    {
418
-        $paths = apply_filters('FHEE__EE_Registry__load_class__paths', array(
419
-            EE_CORE,
420
-            EE_CLASSES,
421
-            EE_BUSINESS,
422
-        ));
423
-        // retrieve instantiated class
424
-        return $this->_load($paths, 'EE_', $class_name, 'class', $arguments, $from_db, $cache, $load_only);
425
-    }
426
-
427
-
428
-
429
-    /**
430
-     *    loads helper classes - must be singletons
431
-     *
432
-     * @param string $class_name - simple class name ie: price
433
-     * @param mixed  $arguments
434
-     * @param bool   $load_only
435
-     * @return EEH_Base | bool
436
-     */
437
-    public function load_helper($class_name, $arguments = array(), $load_only = true)
438
-    {
439
-        // todo: add doing_it_wrong() in a few versions after all addons have had calls to this method removed
440
-        $helper_paths = apply_filters('FHEE__EE_Registry__load_helper__helper_paths', array(EE_HELPERS));
441
-        // retrieve instantiated class
442
-        return $this->_load($helper_paths, 'EEH_', $class_name, 'helper', $arguments, false, true, $load_only);
443
-    }
444
-
445
-
446
-
447
-    /**
448
-     *    loads core classes - must be singletons
449
-     *
450
-     * @access    public
451
-     * @param string $class_name - simple class name ie: session
452
-     * @param mixed  $arguments
453
-     * @param bool   $load_only
454
-     * @param bool   $cache      whether to cache the object or not.
455
-     * @return mixed
456
-     */
457
-    public function load_lib($class_name, $arguments = array(), $load_only = false, $cache = true)
458
-    {
459
-        $paths = array(
460
-            EE_LIBRARIES,
461
-            EE_LIBRARIES . 'messages' . DS,
462
-            EE_LIBRARIES . 'shortcodes' . DS,
463
-            EE_LIBRARIES . 'qtips' . DS,
464
-            EE_LIBRARIES . 'payment_methods' . DS,
465
-        );
466
-        // retrieve instantiated class
467
-        return $this->_load($paths, 'EE_', $class_name, 'lib', $arguments, false, $cache, $load_only);
468
-    }
469
-
470
-
471
-
472
-    /**
473
-     *    loads model classes - must be singletons
474
-     *
475
-     * @param string $class_name - simple class name ie: price
476
-     * @param mixed  $arguments
477
-     * @param bool   $load_only
478
-     * @return EEM_Base | bool
479
-     */
480
-    public function load_model($class_name, $arguments = array(), $load_only = false)
481
-    {
482
-        $paths = apply_filters('FHEE__EE_Registry__load_model__paths', array(
483
-            EE_MODELS,
484
-            EE_CORE,
485
-        ));
486
-        // retrieve instantiated class
487
-        return $this->_load($paths, 'EEM_', $class_name, 'model', $arguments, false, true, $load_only);
488
-    }
489
-
490
-
491
-
492
-    /**
493
-     *    loads model classes - must be singletons
494
-     *
495
-     * @param string $class_name - simple class name ie: price
496
-     * @param mixed  $arguments
497
-     * @param bool   $load_only
498
-     * @return mixed | bool
499
-     */
500
-    public function load_model_class($class_name, $arguments = array(), $load_only = true)
501
-    {
502
-        $paths = array(
503
-            EE_MODELS . 'fields' . DS,
504
-            EE_MODELS . 'helpers' . DS,
505
-            EE_MODELS . 'relations' . DS,
506
-            EE_MODELS . 'strategies' . DS,
507
-        );
508
-        // retrieve instantiated class
509
-        return $this->_load($paths, 'EE_', $class_name, '', $arguments, false, true, $load_only);
510
-    }
511
-
512
-
513
-
514
-    /**
515
-     * Determines if $model_name is the name of an actual EE model.
516
-     *
517
-     * @param string $model_name like Event, Attendee, Question_Group_Question, etc.
518
-     * @return boolean
519
-     */
520
-    public function is_model_name($model_name)
521
-    {
522
-        return isset($this->models[$model_name]) ? true : false;
523
-    }
524
-
525
-
526
-
527
-    /**
528
-     *    generic class loader
529
-     *
530
-     * @param string $path_to_file - directory path to file location, not including filename
531
-     * @param string $file_name    - file name  ie:  my_file.php, including extension
532
-     * @param string $type         - file type - core? class? helper? model?
533
-     * @param mixed  $arguments
534
-     * @param bool   $load_only
535
-     * @return mixed
536
-     */
537
-    public function load_file($path_to_file, $file_name, $type = '', $arguments = array(), $load_only = true)
538
-    {
539
-        // retrieve instantiated class
540
-        return $this->_load($path_to_file, '', $file_name, $type, $arguments, false, true, $load_only);
541
-    }
542
-
543
-
544
-
545
-    /**
546
-     *    load_addon
547
-     *
548
-     * @param string $path_to_file - directory path to file location, not including filename
549
-     * @param string $class_name   - full class name  ie:  My_Class
550
-     * @param string $type         - file type - core? class? helper? model?
551
-     * @param mixed  $arguments
552
-     * @param bool   $load_only
553
-     * @return EE_Addon
554
-     */
555
-    public function load_addon($path_to_file, $class_name, $type = 'class', $arguments = array(), $load_only = false)
556
-    {
557
-        // retrieve instantiated class
558
-        return $this->_load($path_to_file, 'addon', $class_name, $type, $arguments, false, true, $load_only);
559
-    }
560
-
561
-
562
-
563
-    /**
564
-     * instantiates, caches, and automatically resolves dependencies
565
-     * for classes that use a Fully Qualified Class Name.
566
-     * if the class is not capable of being loaded using PSR-4 autoloading,
567
-     * then you need to use one of the existing load_*() methods
568
-     * which can resolve the classname and filepath from the passed arguments
569
-     *
570
-     * @param bool|string $class_name   Fully Qualified Class Name
571
-     * @param array       $arguments    an argument, or array of arguments to pass to the class upon instantiation
572
-     * @param bool        $cache        whether to cache the instantiated object for reuse
573
-     * @param bool        $from_db      some classes are instantiated from the db
574
-     *                                  and thus call a different method to instantiate
575
-     * @param bool        $load_only    if true, will only load the file, but will NOT instantiate an object
576
-     * @param bool|string $addon        if true, will cache the object in the EE_Registry->$addons array
577
-     * @return mixed                    null = failure to load or instantiate class object.
578
-     *                                  object = class loaded and instantiated successfully.
579
-     *                                  bool = fail or success when $load_only is true
580
-     */
581
-    public function create(
582
-        $class_name = false,
583
-        $arguments = array(),
584
-        $cache = false,
585
-        $from_db = false,
586
-        $load_only = false,
587
-        $addon = false
588
-    ) {
589
-        $class_name = $this->_dependency_map->get_alias($class_name);
590
-        if ( ! class_exists($class_name)) {
591
-            // maybe the class is registered with a preceding \
592
-            $class_name = strpos($class_name, '\\') !== 0 ? '\\' . $class_name : $class_name;
593
-            // still doesn't exist ?
594
-            if ( ! class_exists($class_name)) {
595
-                return null;
596
-            }
597
-        }
598
-        // if we're only loading the class and it already exists, then let's just return true immediately
599
-        if ($load_only) {
600
-            return true;
601
-        }
602
-        $addon = $addon ? 'addon' : '';
603
-        // $this->_cache_on is toggled during the recursive loading that can occur with dependency injection
604
-        // $cache is controlled by individual calls to separate Registry loader methods like load_class()
605
-        // $load_only is also controlled by individual calls to separate Registry loader methods like load_file()
606
-        if ($this->_cache_on && $cache && ! $load_only) {
607
-            // return object if it's already cached
608
-            $cached_class = $this->_get_cached_class($class_name, $addon);
609
-            if ($cached_class !== null) {
610
-                return $cached_class;
611
-            }
612
-        }
613
-        // instantiate the requested object
614
-        $class_obj = $this->_create_object($class_name, $arguments, $addon, $from_db);
615
-        if ($this->_cache_on && $cache) {
616
-            // save it for later... kinda like gum  { : $
617
-            $this->_set_cached_class($class_obj, $class_name, $addon, $from_db);
618
-        }
619
-        $this->_cache_on = true;
620
-        return $class_obj;
621
-    }
622
-
623
-
624
-
625
-    /**
626
-     * instantiates, caches, and injects dependencies for classes
627
-     *
628
-     * @param array       $file_paths   an array of paths to folders to look in
629
-     * @param string      $class_prefix EE  or EEM or... ???
630
-     * @param bool|string $class_name   $class name
631
-     * @param string      $type         file type - core? class? helper? model?
632
-     * @param mixed       $arguments    an argument or array of arguments to pass to the class upon instantiation
633
-     * @param bool        $from_db      some classes are instantiated from the db
634
-     *                                  and thus call a different method to instantiate
635
-     * @param bool        $cache        whether to cache the instantiated object for reuse
636
-     * @param bool        $load_only    if true, will only load the file, but will NOT instantiate an object
637
-     * @return null|object|bool         null = failure to load or instantiate class object.
638
-     *                                  object = class loaded and instantiated successfully.
639
-     *                                  bool = fail or success when $load_only is true
640
-     */
641
-    protected function _load(
642
-        $file_paths = array(),
643
-        $class_prefix = 'EE_',
644
-        $class_name = false,
645
-        $type = 'class',
646
-        $arguments = array(),
647
-        $from_db = false,
648
-        $cache = true,
649
-        $load_only = false
650
-    ) {
651
-        // strip php file extension
652
-        $class_name = str_replace('.php', '', trim($class_name));
653
-        // does the class have a prefix ?
654
-        if ( ! empty($class_prefix) && $class_prefix != 'addon') {
655
-            // make sure $class_prefix is uppercase
656
-            $class_prefix = strtoupper(trim($class_prefix));
657
-            // add class prefix ONCE!!!
658
-            $class_name = $class_prefix . str_replace($class_prefix, '', $class_name);
659
-        }
660
-        $class_name = $this->_dependency_map->get_alias($class_name);
661
-        $class_exists = class_exists($class_name);
662
-        // if we're only loading the class and it already exists, then let's just return true immediately
663
-        if ($load_only && $class_exists) {
664
-            return true;
665
-        }
666
-        // $this->_cache_on is toggled during the recursive loading that can occur with dependency injection
667
-        // $cache is controlled by individual calls to separate Registry loader methods like load_class()
668
-        // $load_only is also controlled by individual calls to separate Registry loader methods like load_file()
669
-        if ($this->_cache_on && $cache && ! $load_only) {
670
-            // return object if it's already cached
671
-            $cached_class = $this->_get_cached_class($class_name, $class_prefix);
672
-            if ($cached_class !== null) {
673
-                return $cached_class;
674
-            }
675
-        }
676
-        // if the class doesn't already exist.. then we need to try and find the file and load it
677
-        if ( ! $class_exists) {
678
-            // get full path to file
679
-            $path = $this->_resolve_path($class_name, $type, $file_paths);
680
-            // load the file
681
-            $loaded = $this->_require_file($path, $class_name, $type, $file_paths);
682
-            // if loading failed, or we are only loading a file but NOT instantiating an object
683
-            if ( ! $loaded || $load_only) {
684
-                // return boolean if only loading, or null if an object was expected
685
-                return $load_only ? $loaded : null;
686
-            }
687
-        }
688
-        // instantiate the requested object
689
-        $class_obj = $this->_create_object($class_name, $arguments, $type, $from_db);
690
-        if ($this->_cache_on && $cache) {
691
-            // save it for later... kinda like gum  { : $
692
-            $this->_set_cached_class($class_obj, $class_name, $class_prefix, $from_db);
693
-        }
694
-        $this->_cache_on = true;
695
-        return $class_obj;
696
-    }
697
-
698
-
699
-
700
-    /**
701
-     * _get_cached_class
702
-     * attempts to find a cached version of the requested class
703
-     * by looking in the following places:
704
-     *        $this->{$class_abbreviation}            ie:    $this->CART
705
-     *        $this->{$class_name}                        ie:    $this->Some_Class
706
-     *        $this->LIB->{$class_name}                ie:    $this->LIB->Some_Class
707
-     *        $this->addon->{$class_name}    ie:    $this->addon->Some_Addon_Class
708
-     *
709
-     * @access protected
710
-     * @param string $class_name
711
-     * @param string $class_prefix
712
-     * @return mixed
713
-     */
714
-    protected function _get_cached_class($class_name, $class_prefix = '')
715
-    {
716
-        if (isset($this->_class_abbreviations[$class_name])) {
717
-            $class_abbreviation = $this->_class_abbreviations[$class_name];
718
-        } else {
719
-            // have to specify something, but not anything that will conflict
720
-            $class_abbreviation = 'FANCY_BATMAN_PANTS';
721
-        }
722
-        // check if class has already been loaded, and return it if it has been
723
-        if (isset($this->{$class_abbreviation}) && ! is_null($this->{$class_abbreviation})) {
724
-            return $this->{$class_abbreviation};
725
-        } else if (isset ($this->{$class_name})) {
726
-            return $this->{$class_name};
727
-        } else if (isset ($this->LIB->{$class_name})) {
728
-            return $this->LIB->{$class_name};
729
-        } else if ($class_prefix == 'addon' && isset ($this->addons->{$class_name})) {
730
-            return $this->addons->{$class_name};
731
-        }
732
-        return null;
733
-    }
734
-
735
-
736
-
737
-    /**
738
-     * _resolve_path
739
-     * attempts to find a full valid filepath for the requested class.
740
-     * loops thru each of the base paths in the $file_paths array and appends : "{classname} . {file type} . php"
741
-     * then returns that path if the target file has been found and is readable
742
-     *
743
-     * @access protected
744
-     * @param string $class_name
745
-     * @param string $type
746
-     * @param array  $file_paths
747
-     * @return string | bool
748
-     */
749
-    protected function _resolve_path($class_name, $type = '', $file_paths = array())
750
-    {
751
-        // make sure $file_paths is an array
752
-        $file_paths = is_array($file_paths) ? $file_paths : array($file_paths);
753
-        // cycle thru paths
754
-        foreach ($file_paths as $key => $file_path) {
755
-            // convert all separators to proper DS, if no filepath, then use EE_CLASSES
756
-            $file_path = $file_path ? str_replace(array('/', '\\'), DS, $file_path) : EE_CLASSES;
757
-            // prep file type
758
-            $type = ! empty($type) ? trim($type, '.') . '.' : '';
759
-            // build full file path
760
-            $file_paths[$key] = rtrim($file_path, DS) . DS . $class_name . '.' . $type . 'php';
761
-            //does the file exist and can be read ?
762
-            if (is_readable($file_paths[$key])) {
763
-                return $file_paths[$key];
764
-            }
765
-        }
766
-        return false;
767
-    }
768
-
769
-
770
-
771
-    /**
772
-     * _require_file
773
-     * basically just performs a require_once()
774
-     * but with some error handling
775
-     *
776
-     * @access protected
777
-     * @param  string $path
778
-     * @param  string $class_name
779
-     * @param  string $type
780
-     * @param  array  $file_paths
781
-     * @return boolean
782
-     * @throws \EE_Error
783
-     */
784
-    protected function _require_file($path, $class_name, $type = '', $file_paths = array())
785
-    {
786
-        // don't give up! you gotta...
787
-        try {
788
-            //does the file exist and can it be read ?
789
-            if ( ! $path) {
790
-                // so sorry, can't find the file
791
-                throw new EE_Error (
792
-                    sprintf(
793
-                        __('The %1$s file %2$s could not be located or is not readable due to file permissions. Please ensure that the following filepath(s) are correct: %3$s', 'event_espresso'),
794
-                        trim($type, '.'),
795
-                        $class_name,
796
-                        '<br />' . implode(',<br />', $file_paths)
797
-                    )
798
-                );
799
-            }
800
-            // get the file
801
-            require_once($path);
802
-            // if the class isn't already declared somewhere
803
-            if (class_exists($class_name, false) === false) {
804
-                // so sorry, not a class
805
-                throw new EE_Error(
806
-                    sprintf(
807
-                        __('The %s file %s does not appear to contain the %s Class.', 'event_espresso'),
808
-                        $type,
809
-                        $path,
810
-                        $class_name
811
-                    )
812
-                );
813
-            }
814
-        } catch (EE_Error $e) {
815
-            $e->get_error();
816
-            return false;
817
-        }
818
-        return true;
819
-    }
820
-
821
-
822
-
823
-    /**
824
-     * _create_object
825
-     * Attempts to instantiate the requested class via any of the
826
-     * commonly used instantiation methods employed throughout EE.
827
-     * The priority for instantiation is as follows:
828
-     *        - abstract classes or any class flagged as "load only" (no instantiation occurs)
829
-     *        - model objects via their 'new_instance_from_db' method
830
-     *        - model objects via their 'new_instance' method
831
-     *        - "singleton" classes" via their 'instance' method
832
-     *    - standard instantiable classes via their __constructor
833
-     * Prior to instantiation, if the classname exists in the dependency_map,
834
-     * then the constructor for the requested class will be examined to determine
835
-     * if any dependencies exist, and if they can be injected.
836
-     * If so, then those classes will be added to the array of arguments passed to the constructor
837
-     *
838
-     * @access protected
839
-     * @param string $class_name
840
-     * @param array  $arguments
841
-     * @param string $type
842
-     * @param bool   $from_db
843
-     * @return null | object
844
-     * @throws \EE_Error
845
-     */
846
-    protected function _create_object($class_name, $arguments = array(), $type = '', $from_db = false)
847
-    {
848
-        $class_obj = null;
849
-        $instantiation_mode = '0) none';
850
-        // don't give up! you gotta...
851
-        try {
852
-            // create reflection
853
-            $reflector = $this->get_ReflectionClass($class_name);
854
-            // make sure arguments are an array
855
-            $arguments = is_array($arguments) ? $arguments : array($arguments);
856
-            // and if arguments array is numerically and sequentially indexed, then we want it to remain as is,
857
-            // else wrap it in an additional array so that it doesn't get split into multiple parameters
858
-            $arguments = $this->_array_is_numerically_and_sequentially_indexed($arguments)
859
-                ? $arguments
860
-                : array($arguments);
861
-            // attempt to inject dependencies ?
862
-            if ($this->_dependency_map->has($class_name)) {
863
-                $arguments = $this->_resolve_dependencies($reflector, $class_name, $arguments);
864
-            }
865
-            // instantiate the class if possible
866
-            if ($reflector->isAbstract()) {
867
-                // nothing to instantiate, loading file was enough
868
-                // does not throw an exception so $instantiation_mode is unused
869
-                // $instantiation_mode = "1) no constructor abstract class";
870
-                $class_obj = true;
871
-            } else if ($reflector->getConstructor() === null && $reflector->isInstantiable() && empty($arguments)) {
872
-                // no constructor = static methods only... nothing to instantiate, loading file was enough
873
-                $instantiation_mode = "2) no constructor but instantiable";
874
-                $class_obj = $reflector->newInstance();
875
-            } else if ($from_db && method_exists($class_name, 'new_instance_from_db')) {
876
-                $instantiation_mode = "3) new_instance_from_db()";
877
-                $class_obj = call_user_func_array(array($class_name, 'new_instance_from_db'), $arguments);
878
-            } else if (method_exists($class_name, 'new_instance')) {
879
-                $instantiation_mode = "4) new_instance()";
880
-                $class_obj = call_user_func_array(array($class_name, 'new_instance'), $arguments);
881
-            } else if (method_exists($class_name, 'instance')) {
882
-                $instantiation_mode = "5) instance()";
883
-                $class_obj = call_user_func_array(array($class_name, 'instance'), $arguments);
884
-            } else if ($reflector->isInstantiable()) {
885
-                $instantiation_mode = "6) constructor";
886
-                $class_obj = $reflector->newInstanceArgs($arguments);
887
-            } else {
888
-                // heh ? something's not right !
889
-                throw new EE_Error(
890
-                    sprintf(
891
-                        __('The %s file %s could not be instantiated.', 'event_espresso'),
892
-                        $type,
893
-                        $class_name
894
-                    )
895
-                );
896
-            }
897
-        } catch (Exception $e) {
898
-            if ( ! $e instanceof EE_Error) {
899
-                $e = new EE_Error(
900
-                    sprintf(
901
-                        __('The following error occurred while attempting to instantiate "%1$s": %2$s %3$s %2$s instantiation mode : %4$s', 'event_espresso'),
902
-                        $class_name,
903
-                        '<br />',
904
-                        $e->getMessage(),
905
-                        $instantiation_mode
906
-                    )
907
-                );
908
-            }
909
-            $e->get_error();
910
-        }
911
-        return $class_obj;
912
-    }
913
-
914
-
915
-
916
-    /**
917
-     * @see http://stackoverflow.com/questions/173400/how-to-check-if-php-array-is-associative-or-sequential
918
-     * @param array $array
919
-     * @return bool
920
-     */
921
-    protected function _array_is_numerically_and_sequentially_indexed(array $array)
922
-    {
923
-        return ! empty($array) ? array_keys($array) === range(0, count($array) - 1) : true;
924
-    }
925
-
926
-
927
-
928
-    /**
929
-     * getReflectionClass
930
-     * checks if a ReflectionClass object has already been generated for a class
931
-     * and returns that instead of creating a new one
932
-     *
933
-     * @access public
934
-     * @param string $class_name
935
-     * @return ReflectionClass
936
-     */
937
-    public function get_ReflectionClass($class_name)
938
-    {
939
-        if (
940
-            ! isset($this->_reflectors[$class_name])
941
-            || ! $this->_reflectors[$class_name] instanceof ReflectionClass
942
-        ) {
943
-            $this->_reflectors[$class_name] = new ReflectionClass($class_name);
944
-        }
945
-        return $this->_reflectors[$class_name];
946
-    }
947
-
948
-
949
-
950
-    /**
951
-     * _resolve_dependencies
952
-     * examines the constructor for the requested class to determine
953
-     * if any dependencies exist, and if they can be injected.
954
-     * If so, then those classes will be added to the array of arguments passed to the constructor
955
-     * PLZ NOTE: this is achieved by type hinting the constructor params
956
-     * For example:
957
-     *        if attempting to load a class "Foo" with the following constructor:
958
-     *        __construct( Bar $bar_class, Fighter $grohl_class )
959
-     *        then $bar_class and $grohl_class will be added to the $arguments array,
960
-     *        but only IF they are NOT already present in the incoming arguments array,
961
-     *        and the correct classes can be loaded
962
-     *
963
-     * @access protected
964
-     * @param ReflectionClass $reflector
965
-     * @param string          $class_name
966
-     * @param array           $arguments
967
-     * @return array
968
-     * @throws \ReflectionException
969
-     */
970
-    protected function _resolve_dependencies(ReflectionClass $reflector, $class_name, $arguments = array())
971
-    {
972
-        // let's examine the constructor
973
-        $constructor = $reflector->getConstructor();
974
-        // whu? huh? nothing?
975
-        if ( ! $constructor) {
976
-            return $arguments;
977
-        }
978
-        // get constructor parameters
979
-        $params = $constructor->getParameters();
980
-        // and the keys for the incoming arguments array so that we can compare existing arguments with what is expected
981
-        $argument_keys = array_keys($arguments);
982
-        // now loop thru all of the constructors expected parameters
983
-        foreach ($params as $index => $param) {
984
-            // is this a dependency for a specific class ?
985
-            $param_class = $param->getClass() ? $param->getClass()->name : null;
986
-            if (
987
-                // param is not even a class
988
-                empty($param_class)
989
-                // and something already exists in the incoming arguments for this param
990
-                && isset($argument_keys[$index], $arguments[$argument_keys[$index]])
991
-            ) {
992
-                // so let's skip this argument and move on to the next
993
-                continue;
994
-            } else if (
995
-                // parameter is type hinted as a class, exists as an incoming argument, AND it's the correct class
996
-                ! empty($param_class)
997
-                && isset($argument_keys[$index], $arguments[$argument_keys[$index]])
998
-                && $arguments[$argument_keys[$index]] instanceof $param_class
999
-            ) {
1000
-                // skip this argument and move on to the next
1001
-                continue;
1002
-            } else if (
1003
-                // parameter is type hinted as a class, and should be injected
1004
-                ! empty($param_class)
1005
-                && $this->_dependency_map->has_dependency_for_class($class_name, $param_class)
1006
-            ) {
1007
-                $arguments = $this->_resolve_dependency($class_name, $param_class, $arguments, $index);
1008
-            } else {
1009
-                try {
1010
-                    $arguments[$index] = $param->getDefaultValue();
1011
-                } catch (ReflectionException $e) {
1012
-                    throw new ReflectionException(
1013
-                        sprintf(
1014
-                            __('%1$s for parameter "$%2$s"', 'event_espresso'),
1015
-                            $e->getMessage(),
1016
-                            $param->getName()
1017
-                        )
1018
-                    );
1019
-                }
1020
-            }
1021
-        }
1022
-        return $arguments;
1023
-    }
1024
-
1025
-
1026
-
1027
-    /**
1028
-     * @access protected
1029
-     * @param string $class_name
1030
-     * @param string $param_class
1031
-     * @param array  $arguments
1032
-     * @param mixed  $index
1033
-     * @return array
1034
-     */
1035
-    protected function _resolve_dependency($class_name, $param_class, $arguments, $index)
1036
-    {
1037
-        $dependency = null;
1038
-        // should dependency be loaded from cache ?
1039
-        $cache_on = $this->_dependency_map->loading_strategy_for_class_dependency($class_name, $param_class)
1040
-                    !== EE_Dependency_Map::load_new_object
1041
-            ? true
1042
-            : false;
1043
-        // we might have a dependency...
1044
-        // let's MAYBE try and find it in our cache if that's what's been requested
1045
-        $cached_class = $cache_on ? $this->_get_cached_class($param_class) : null;
1046
-        // and grab it if it exists
1047
-        if ($cached_class instanceof $param_class) {
1048
-            $dependency = $cached_class;
1049
-        } else if ($param_class != $class_name) {
1050
-            // obtain the loader method from the dependency map
1051
-            $loader = $this->_dependency_map->class_loader($param_class);
1052
-            // is loader a custom closure ?
1053
-            if ($loader instanceof Closure) {
1054
-                $dependency = $loader();
1055
-            } else {
1056
-                // set the cache on property for the recursive loading call
1057
-                $this->_cache_on = $cache_on;
1058
-                // if not, then let's try and load it via the registry
1059
-                if (method_exists($this, $loader)) {
1060
-                    $dependency = $this->{$loader}($param_class);
1061
-                } else {
1062
-                    $dependency = $this->create($param_class, array(), $cache_on);
1063
-                }
1064
-            }
1065
-        }
1066
-        // did we successfully find the correct dependency ?
1067
-        if ($dependency instanceof $param_class) {
1068
-            // then let's inject it into the incoming array of arguments at the correct location
1069
-            if (isset($argument_keys[$index])) {
1070
-                $arguments[$argument_keys[$index]] = $dependency;
1071
-            } else {
1072
-                $arguments[$index] = $dependency;
1073
-            }
1074
-        }
1075
-        return $arguments;
1076
-    }
1077
-
1078
-
1079
-
1080
-    /**
1081
-     * _set_cached_class
1082
-     * attempts to cache the instantiated class locally
1083
-     * in one of the following places, in the following order:
1084
-     *        $this->{class_abbreviation}   ie:    $this->CART
1085
-     *        $this->{$class_name}          ie:    $this->Some_Class
1086
-     *        $this->addon->{$$class_name}    ie:    $this->addon->Some_Addon_Class
1087
-     *        $this->LIB->{$class_name}     ie:    $this->LIB->Some_Class
1088
-     *
1089
-     * @access protected
1090
-     * @param object $class_obj
1091
-     * @param string $class_name
1092
-     * @param string $class_prefix
1093
-     * @param bool   $from_db
1094
-     * @return void
1095
-     */
1096
-    protected function _set_cached_class($class_obj, $class_name, $class_prefix = '', $from_db = false)
1097
-    {
1098
-        if (empty($class_obj)) {
1099
-            return;
1100
-        }
1101
-        // return newly instantiated class
1102
-        if (isset($this->_class_abbreviations[$class_name])) {
1103
-            $class_abbreviation = $this->_class_abbreviations[$class_name];
1104
-            $this->{$class_abbreviation} = $class_obj;
1105
-        } else if (property_exists($this, $class_name)) {
1106
-            $this->{$class_name} = $class_obj;
1107
-        } else if ($class_prefix == 'addon') {
1108
-            $this->addons->{$class_name} = $class_obj;
1109
-        } else if ( ! $from_db) {
1110
-            $this->LIB->{$class_name} = $class_obj;
1111
-        }
1112
-    }
1113
-
1114
-
1115
-
1116
-    /**
1117
-     * call any loader that's been registered in the EE_Dependency_Map::$_class_loaders array
1118
-     *
1119
-     * @param string $classname PLEASE NOTE: the class name needs to match what's registered
1120
-     *                          in the EE_Dependency_Map::$_class_loaders array,
1121
-     *                          including the class prefix, ie: "EE_", "EEM_", "EEH_", etc
1122
-     * @param array  $arguments
1123
-     * @return object
1124
-     */
1125
-    public static function factory($classname, $arguments = array())
1126
-    {
1127
-        $loader = self::instance()->_dependency_map->class_loader($classname);
1128
-        if ($loader instanceof Closure) {
1129
-            return $loader($arguments);
1130
-        } else if (method_exists(EE_Registry::instance(), $loader)) {
1131
-            return EE_Registry::instance()->{$loader}($classname, $arguments);
1132
-        }
1133
-        return null;
1134
-    }
1135
-
1136
-
1137
-
1138
-    /**
1139
-     * Gets the addon by its name/slug (not classname. For that, just
1140
-     * use the classname as the property name on EE_Config::instance()->addons)
1141
-     *
1142
-     * @param string $name
1143
-     * @return EE_Addon
1144
-     */
1145
-    public function get_addon_by_name($name)
1146
-    {
1147
-        foreach ($this->addons as $addon) {
1148
-            if ($addon->name() == $name) {
1149
-                return $addon;
1150
-            }
1151
-        }
1152
-        return null;
1153
-    }
1154
-
1155
-
1156
-
1157
-    /**
1158
-     * Gets an array of all the registered addons, where the keys are their names. (ie, what each returns for their name() function) They're already available on EE_Config::instance()->addons as properties, where each property's name is
1159
-     * the addon's classname. So if you just want to get the addon by classname, use EE_Config::instance()->addons->{classname}
1160
-     *
1161
-     * @return EE_Addon[] where the KEYS are the addon's name()
1162
-     */
1163
-    public function get_addons_by_name()
1164
-    {
1165
-        $addons = array();
1166
-        foreach ($this->addons as $addon) {
1167
-            $addons[$addon->name()] = $addon;
1168
-        }
1169
-        return $addons;
1170
-    }
1171
-
1172
-
1173
-
1174
-    /**
1175
-     * Resets the specified model's instance AND makes sure EE_Registry doesn't keep
1176
-     * a stale copy of it around
1177
-     *
1178
-     * @param string $model_name
1179
-     * @return \EEM_Base
1180
-     * @throws \EE_Error
1181
-     */
1182
-    public function reset_model($model_name)
1183
-    {
1184
-        $model_class_name = strpos($model_name, 'EEM_') !== 0 ? "EEM_{$model_name}" : $model_name;
1185
-        if ( ! isset($this->LIB->{$model_class_name}) || ! $this->LIB->{$model_class_name} instanceof EEM_Base) {
1186
-            return null;
1187
-        }
1188
-        //get that model reset it and make sure we nuke the old reference to it
1189
-        if ($this->LIB->{$model_class_name} instanceof $model_class_name && is_callable(array($model_class_name, 'reset'))) {
1190
-            $this->LIB->{$model_class_name} = $this->LIB->{$model_class_name}->reset();
1191
-        } else {
1192
-            throw new EE_Error(sprintf(__('Model %s does not have a method "reset"', 'event_espresso'), $model_name));
1193
-        }
1194
-        return $this->LIB->{$model_class_name};
1195
-    }
1196
-
1197
-
1198
-
1199
-    /**
1200
-     * Resets the registry.
1201
-     * The criteria for what gets reset is based on what can be shared between sites on the same request when switch_to_blog
1202
-     * is used in a multisite install.  Here is a list of things that are NOT reset.
1203
-     * - $_dependency_map
1204
-     * - $_class_abbreviations
1205
-     * - $NET_CFG (EE_Network_Config): The config is shared network wide so no need to reset.
1206
-     * - $REQ:  Still on the same request so no need to change.
1207
-     * - $CAP: There is no site specific state in the EE_Capability class.
1208
-     * - $SSN: Although ideally, the session should not be shared between site switches, we can't reset it because only one Session
1209
-     *         can be active in a single request.  Resetting could resolve in "headers already sent" errors.
1210
-     * - $addons:  In multisite, the state of the addons is something controlled via hooks etc in a normal request.  So
1211
-     *             for now, we won't reset the addons because it could break calls to an add-ons class/methods in the
1212
-     *             switch or on the restore.
1213
-     * - $modules
1214
-     * - $shortcodes
1215
-     * - $widgets
1216
-     *
1217
-     * @param boolean $hard             whether to reset data in the database too, or just refresh
1218
-     *                                  the Registry to its state at the beginning of the request
1219
-     * @param boolean $reinstantiate    whether to create new instances of EE_Registry's singletons too,
1220
-     *                                  or just reset without re-instantiating (handy to set to FALSE if you're not sure if you CAN
1221
-     *                                  currently reinstantiate the singletons at the moment)
1222
-     * @param   bool  $reset_models     Defaults to true.  When false, then the models are not reset.  This is so client
1223
-     *                                  code instead can just change the model context to a different blog id if necessary
1224
-     * @return EE_Registry
1225
-     */
1226
-    public static function reset($hard = false, $reinstantiate = true, $reset_models = true)
1227
-    {
1228
-        $instance = self::instance();
1229
-        EEH_Activation::reset();
1230
-        //properties that get reset
1231
-        $instance->_cache_on = true;
1232
-        $instance->CFG = EE_Config::reset($hard, $reinstantiate);
1233
-        $instance->CART = null;
1234
-        $instance->MRM = null;
1235
-        $instance->AssetsRegistry = new Registry();
1236
-        //messages reset
1237
-        EED_Messages::reset();
1238
-        if ($reset_models) {
1239
-            foreach (array_keys($instance->non_abstract_db_models) as $model_name) {
1240
-                $instance->reset_model($model_name);
1241
-            }
1242
-        }
1243
-        $instance->LIB = new stdClass();
1244
-        return $instance;
1245
-    }
1246
-
1247
-
1248
-
1249
-    /**
1250
-     * @override magic methods
1251
-     * @return void
1252
-     */
1253
-    final function __destruct()
1254
-    {
1255
-    }
1256
-
1257
-
1258
-
1259
-    /**
1260
-     * @param $a
1261
-     * @param $b
1262
-     */
1263
-    final function __call($a, $b)
1264
-    {
1265
-    }
1266
-
1267
-
1268
-
1269
-    /**
1270
-     * @param $a
1271
-     */
1272
-    final function __get($a)
1273
-    {
1274
-    }
1275
-
1276
-
1277
-
1278
-    /**
1279
-     * @param $a
1280
-     * @param $b
1281
-     */
1282
-    final function __set($a, $b)
1283
-    {
1284
-    }
1285
-
1286
-
1287
-
1288
-    /**
1289
-     * @param $a
1290
-     */
1291
-    final function __isset($a)
1292
-    {
1293
-    }
19
+	/**
20
+	 *    EE_Registry Object
21
+	 *
22
+	 * @var EE_Registry $_instance
23
+	 * @access    private
24
+	 */
25
+	private static $_instance = null;
26
+
27
+	/**
28
+	 * @var EE_Dependency_Map $_dependency_map
29
+	 * @access    protected
30
+	 */
31
+	protected $_dependency_map = null;
32
+
33
+	/**
34
+	 * @var array $_class_abbreviations
35
+	 * @access    protected
36
+	 */
37
+	protected $_class_abbreviations = array();
38
+
39
+	/**
40
+	 * @access public
41
+	 * @var \EventEspresso\core\services\commands\CommandBusInterface $BUS
42
+	 */
43
+	public $BUS;
44
+
45
+	/**
46
+	 *    EE_Cart Object
47
+	 *
48
+	 * @access    public
49
+	 * @var    EE_Cart $CART
50
+	 */
51
+	public $CART = null;
52
+
53
+	/**
54
+	 *    EE_Config Object
55
+	 *
56
+	 * @access    public
57
+	 * @var    EE_Config $CFG
58
+	 */
59
+	public $CFG = null;
60
+
61
+	/**
62
+	 * EE_Network_Config Object
63
+	 *
64
+	 * @access public
65
+	 * @var EE_Network_Config $NET_CFG
66
+	 */
67
+	public $NET_CFG = null;
68
+
69
+	/**
70
+	 *    StdClass object for storing library classes in
71
+	 *
72
+	 * @public LIB
73
+	 * @var StdClass $LIB
74
+	 */
75
+	public $LIB = null;
76
+
77
+	/**
78
+	 *    EE_Request_Handler Object
79
+	 *
80
+	 * @access    public
81
+	 * @var    EE_Request_Handler $REQ
82
+	 */
83
+	public $REQ = null;
84
+
85
+	/**
86
+	 *    EE_Session Object
87
+	 *
88
+	 * @access    public
89
+	 * @var    EE_Session $SSN
90
+	 */
91
+	public $SSN = null;
92
+
93
+	/**
94
+	 * holds the ee capabilities object.
95
+	 *
96
+	 * @since 4.5.0
97
+	 * @var EE_Capabilities
98
+	 */
99
+	public $CAP = null;
100
+
101
+	/**
102
+	 * holds the EE_Message_Resource_Manager object.
103
+	 *
104
+	 * @since 4.9.0
105
+	 * @var EE_Message_Resource_Manager
106
+	 */
107
+	public $MRM = null;
108
+
109
+
110
+	/**
111
+	 * Holds the Assets Registry instance
112
+	 * @var Registry
113
+	 */
114
+	public $AssetsRegistry = null;
115
+
116
+	/**
117
+	 *    $addons - StdClass object for holding addons which have registered themselves to work with EE core
118
+	 *
119
+	 * @access    public
120
+	 * @var    EE_Addon[]
121
+	 */
122
+	public $addons = null;
123
+
124
+	/**
125
+	 *    $models
126
+	 * @access    public
127
+	 * @var    EEM_Base[] $models keys are 'short names' (eg Event), values are class names (eg 'EEM_Event')
128
+	 */
129
+	public $models = array();
130
+
131
+	/**
132
+	 *    $modules
133
+	 * @access    public
134
+	 * @var    EED_Module[] $modules
135
+	 */
136
+	public $modules = null;
137
+
138
+	/**
139
+	 *    $shortcodes
140
+	 * @access    public
141
+	 * @var    EES_Shortcode[] $shortcodes
142
+	 */
143
+	public $shortcodes = null;
144
+
145
+	/**
146
+	 *    $widgets
147
+	 * @access    public
148
+	 * @var    WP_Widget[] $widgets
149
+	 */
150
+	public $widgets = null;
151
+
152
+	/**
153
+	 * $non_abstract_db_models
154
+	 * @access public
155
+	 * @var array this is an array of all implemented model names (i.e. not the parent abstract models, or models
156
+	 * which don't actually fetch items from the DB in the normal way (ie, are not children of EEM_Base)).
157
+	 * Keys are model "short names" (eg "Event") as used in model relations, and values are
158
+	 * classnames (eg "EEM_Event")
159
+	 */
160
+	public $non_abstract_db_models = array();
161
+
162
+
163
+	/**
164
+	 *    $i18n_js_strings - internationalization for JS strings
165
+	 *    usage:   EE_Registry::i18n_js_strings['string_key'] = __( 'string to translate.', 'event_espresso' );
166
+	 *    in js file:  var translatedString = eei18n.string_key;
167
+	 *
168
+	 * @access    public
169
+	 * @var    array
170
+	 */
171
+	public static $i18n_js_strings = array();
172
+
173
+
174
+	/**
175
+	 *    $main_file - path to espresso.php
176
+	 *
177
+	 * @access    public
178
+	 * @var    array
179
+	 */
180
+	public $main_file;
181
+
182
+	/**
183
+	 * array of ReflectionClass objects where the key is the class name
184
+	 *
185
+	 * @access    public
186
+	 * @var ReflectionClass[]
187
+	 */
188
+	public $_reflectors;
189
+
190
+	/**
191
+	 * boolean flag to indicate whether or not to load/save dependencies from/to the cache
192
+	 *
193
+	 * @access    protected
194
+	 * @var boolean $_cache_on
195
+	 */
196
+	protected $_cache_on = true;
197
+
198
+
199
+
200
+	/**
201
+	 * @singleton method used to instantiate class object
202
+	 * @access    public
203
+	 * @param  \EE_Dependency_Map $dependency_map
204
+	 * @return \EE_Registry instance
205
+	 */
206
+	public static function instance(\EE_Dependency_Map $dependency_map = null)
207
+	{
208
+		// check if class object is instantiated
209
+		if ( ! self::$_instance instanceof EE_Registry) {
210
+			self::$_instance = new EE_Registry($dependency_map);
211
+		}
212
+		return self::$_instance;
213
+	}
214
+
215
+
216
+
217
+	/**
218
+	 *protected constructor to prevent direct creation
219
+	 *
220
+	 * @Constructor
221
+	 * @access protected
222
+	 * @param  \EE_Dependency_Map $dependency_map
223
+	 * @return \EE_Registry
224
+	 */
225
+	protected function __construct(\EE_Dependency_Map $dependency_map)
226
+	{
227
+		$this->_dependency_map = $dependency_map;
228
+		add_action('EE_Load_Espresso_Core__handle_request__initialize_core_loading', array($this, 'initialize'));
229
+	}
230
+
231
+
232
+
233
+	/**
234
+	 * initialize
235
+	 */
236
+	public function initialize()
237
+	{
238
+		$this->_class_abbreviations = apply_filters(
239
+			'FHEE__EE_Registry____construct___class_abbreviations',
240
+			array(
241
+				'EE_Config'                                       => 'CFG',
242
+				'EE_Session'                                      => 'SSN',
243
+				'EE_Capabilities'                                 => 'CAP',
244
+				'EE_Cart'                                         => 'CART',
245
+				'EE_Network_Config'                               => 'NET_CFG',
246
+				'EE_Request_Handler'                              => 'REQ',
247
+				'EE_Message_Resource_Manager'                     => 'MRM',
248
+				'EventEspresso\core\services\commands\CommandBus' => 'BUS',
249
+			)
250
+		);
251
+		// class library
252
+		$this->LIB = new stdClass();
253
+		$this->addons = new stdClass();
254
+		$this->modules = new stdClass();
255
+		$this->shortcodes = new stdClass();
256
+		$this->widgets = new stdClass();
257
+		$this->load_core('Base', array(), true);
258
+		// add our request and response objects to the cache
259
+		$request_loader = $this->_dependency_map->class_loader('EE_Request');
260
+		$this->_set_cached_class(
261
+			$request_loader(),
262
+			'EE_Request'
263
+		);
264
+		$response_loader = $this->_dependency_map->class_loader('EE_Response');
265
+		$this->_set_cached_class(
266
+			$response_loader(),
267
+			'EE_Response'
268
+		);
269
+		add_action('AHEE__EE_System__set_hooks_for_core', array($this, 'init'));
270
+	}
271
+
272
+
273
+
274
+	/**
275
+	 *    init
276
+	 *
277
+	 * @access    public
278
+	 * @return    void
279
+	 */
280
+	public function init()
281
+	{
282
+		$this->AssetsRegistry = new Registry();
283
+		// Get current page protocol
284
+		$protocol = isset($_SERVER['HTTPS']) ? 'https://' : 'http://';
285
+		// Output admin-ajax.php URL with same protocol as current page
286
+		self::$i18n_js_strings['ajax_url'] = admin_url('admin-ajax.php', $protocol);
287
+		self::$i18n_js_strings['wp_debug'] = defined('WP_DEBUG') ? WP_DEBUG : false;
288
+	}
289
+
290
+
291
+
292
+	/**
293
+	 * localize_i18n_js_strings
294
+	 *
295
+	 * @return string
296
+	 */
297
+	public static function localize_i18n_js_strings()
298
+	{
299
+		$i18n_js_strings = (array)EE_Registry::$i18n_js_strings;
300
+		foreach ($i18n_js_strings as $key => $value) {
301
+			if (is_scalar($value)) {
302
+				$i18n_js_strings[$key] = html_entity_decode((string)$value, ENT_QUOTES, 'UTF-8');
303
+			}
304
+		}
305
+		return "/* <![CDATA[ */ var eei18n = " . wp_json_encode($i18n_js_strings) . '; /* ]]> */';
306
+	}
307
+
308
+
309
+
310
+	/**
311
+	 * @param mixed string | EED_Module $module
312
+	 */
313
+	public function add_module($module)
314
+	{
315
+		if ($module instanceof EED_Module) {
316
+			$module_class = get_class($module);
317
+			$this->modules->{$module_class} = $module;
318
+		} else {
319
+			if ( ! class_exists('EE_Module_Request_Router')) {
320
+				$this->load_core('Module_Request_Router');
321
+			}
322
+			$this->modules->{$module} = EE_Module_Request_Router::module_factory($module);
323
+		}
324
+	}
325
+
326
+
327
+
328
+	/**
329
+	 * @param string $module_name
330
+	 * @return mixed EED_Module | NULL
331
+	 */
332
+	public function get_module($module_name = '')
333
+	{
334
+		return isset($this->modules->{$module_name}) ? $this->modules->{$module_name} : null;
335
+	}
336
+
337
+
338
+
339
+	/**
340
+	 *    loads core classes - must be singletons
341
+	 *
342
+	 * @access    public
343
+	 * @param string $class_name - simple class name ie: session
344
+	 * @param mixed  $arguments
345
+	 * @param bool   $load_only
346
+	 * @return mixed
347
+	 */
348
+	public function load_core($class_name, $arguments = array(), $load_only = false)
349
+	{
350
+		$core_paths = apply_filters(
351
+			'FHEE__EE_Registry__load_core__core_paths',
352
+			array(
353
+				EE_CORE,
354
+				EE_ADMIN,
355
+				EE_CPTS,
356
+				EE_CORE . 'data_migration_scripts' . DS,
357
+				EE_CORE . 'request_stack' . DS,
358
+				EE_CORE . 'middleware' . DS,
359
+			)
360
+		);
361
+		// retrieve instantiated class
362
+		return $this->_load($core_paths, 'EE_', $class_name, 'core', $arguments, false, true, $load_only);
363
+	}
364
+
365
+
366
+
367
+	/**
368
+	 *    loads service classes
369
+	 *
370
+	 * @access    public
371
+	 * @param string $class_name - simple class name ie: session
372
+	 * @param mixed  $arguments
373
+	 * @param bool   $load_only
374
+	 * @return mixed
375
+	 */
376
+	public function load_service($class_name, $arguments = array(), $load_only = false)
377
+	{
378
+		$service_paths = apply_filters(
379
+			'FHEE__EE_Registry__load_service__service_paths',
380
+			array(
381
+				EE_CORE . 'services' . DS,
382
+			)
383
+		);
384
+		// retrieve instantiated class
385
+		return $this->_load($service_paths, 'EE_', $class_name, 'class', $arguments, false, true, $load_only);
386
+	}
387
+
388
+
389
+
390
+	/**
391
+	 *    loads data_migration_scripts
392
+	 *
393
+	 * @access    public
394
+	 * @param string $class_name - class name for the DMS ie: EE_DMS_Core_4_2_0
395
+	 * @param mixed  $arguments
396
+	 * @return EE_Data_Migration_Script_Base|mixed
397
+	 */
398
+	public function load_dms($class_name, $arguments = array())
399
+	{
400
+		// retrieve instantiated class
401
+		return $this->_load(EE_Data_Migration_Manager::instance()->get_data_migration_script_folders(), 'EE_DMS_', $class_name, 'dms', $arguments, false, false, false);
402
+	}
403
+
404
+
405
+
406
+	/**
407
+	 *    loads object creating classes - must be singletons
408
+	 *
409
+	 * @param string $class_name - simple class name ie: attendee
410
+	 * @param mixed  $arguments  - an array of arguments to pass to the class
411
+	 * @param bool   $from_db    - some classes are instantiated from the db and thus call a different method to instantiate
412
+	 * @param bool   $cache      if you don't want the class to be stored in the internal cache (non-persistent) then set this to FALSE (ie. when instantiating model objects from client in a loop)
413
+	 * @param bool   $load_only  whether or not to just load the file and NOT instantiate, or load AND instantiate (default)
414
+	 * @return EE_Base_Class | bool
415
+	 */
416
+	public function load_class($class_name, $arguments = array(), $from_db = false, $cache = true, $load_only = false)
417
+	{
418
+		$paths = apply_filters('FHEE__EE_Registry__load_class__paths', array(
419
+			EE_CORE,
420
+			EE_CLASSES,
421
+			EE_BUSINESS,
422
+		));
423
+		// retrieve instantiated class
424
+		return $this->_load($paths, 'EE_', $class_name, 'class', $arguments, $from_db, $cache, $load_only);
425
+	}
426
+
427
+
428
+
429
+	/**
430
+	 *    loads helper classes - must be singletons
431
+	 *
432
+	 * @param string $class_name - simple class name ie: price
433
+	 * @param mixed  $arguments
434
+	 * @param bool   $load_only
435
+	 * @return EEH_Base | bool
436
+	 */
437
+	public function load_helper($class_name, $arguments = array(), $load_only = true)
438
+	{
439
+		// todo: add doing_it_wrong() in a few versions after all addons have had calls to this method removed
440
+		$helper_paths = apply_filters('FHEE__EE_Registry__load_helper__helper_paths', array(EE_HELPERS));
441
+		// retrieve instantiated class
442
+		return $this->_load($helper_paths, 'EEH_', $class_name, 'helper', $arguments, false, true, $load_only);
443
+	}
444
+
445
+
446
+
447
+	/**
448
+	 *    loads core classes - must be singletons
449
+	 *
450
+	 * @access    public
451
+	 * @param string $class_name - simple class name ie: session
452
+	 * @param mixed  $arguments
453
+	 * @param bool   $load_only
454
+	 * @param bool   $cache      whether to cache the object or not.
455
+	 * @return mixed
456
+	 */
457
+	public function load_lib($class_name, $arguments = array(), $load_only = false, $cache = true)
458
+	{
459
+		$paths = array(
460
+			EE_LIBRARIES,
461
+			EE_LIBRARIES . 'messages' . DS,
462
+			EE_LIBRARIES . 'shortcodes' . DS,
463
+			EE_LIBRARIES . 'qtips' . DS,
464
+			EE_LIBRARIES . 'payment_methods' . DS,
465
+		);
466
+		// retrieve instantiated class
467
+		return $this->_load($paths, 'EE_', $class_name, 'lib', $arguments, false, $cache, $load_only);
468
+	}
469
+
470
+
471
+
472
+	/**
473
+	 *    loads model classes - must be singletons
474
+	 *
475
+	 * @param string $class_name - simple class name ie: price
476
+	 * @param mixed  $arguments
477
+	 * @param bool   $load_only
478
+	 * @return EEM_Base | bool
479
+	 */
480
+	public function load_model($class_name, $arguments = array(), $load_only = false)
481
+	{
482
+		$paths = apply_filters('FHEE__EE_Registry__load_model__paths', array(
483
+			EE_MODELS,
484
+			EE_CORE,
485
+		));
486
+		// retrieve instantiated class
487
+		return $this->_load($paths, 'EEM_', $class_name, 'model', $arguments, false, true, $load_only);
488
+	}
489
+
490
+
491
+
492
+	/**
493
+	 *    loads model classes - must be singletons
494
+	 *
495
+	 * @param string $class_name - simple class name ie: price
496
+	 * @param mixed  $arguments
497
+	 * @param bool   $load_only
498
+	 * @return mixed | bool
499
+	 */
500
+	public function load_model_class($class_name, $arguments = array(), $load_only = true)
501
+	{
502
+		$paths = array(
503
+			EE_MODELS . 'fields' . DS,
504
+			EE_MODELS . 'helpers' . DS,
505
+			EE_MODELS . 'relations' . DS,
506
+			EE_MODELS . 'strategies' . DS,
507
+		);
508
+		// retrieve instantiated class
509
+		return $this->_load($paths, 'EE_', $class_name, '', $arguments, false, true, $load_only);
510
+	}
511
+
512
+
513
+
514
+	/**
515
+	 * Determines if $model_name is the name of an actual EE model.
516
+	 *
517
+	 * @param string $model_name like Event, Attendee, Question_Group_Question, etc.
518
+	 * @return boolean
519
+	 */
520
+	public function is_model_name($model_name)
521
+	{
522
+		return isset($this->models[$model_name]) ? true : false;
523
+	}
524
+
525
+
526
+
527
+	/**
528
+	 *    generic class loader
529
+	 *
530
+	 * @param string $path_to_file - directory path to file location, not including filename
531
+	 * @param string $file_name    - file name  ie:  my_file.php, including extension
532
+	 * @param string $type         - file type - core? class? helper? model?
533
+	 * @param mixed  $arguments
534
+	 * @param bool   $load_only
535
+	 * @return mixed
536
+	 */
537
+	public function load_file($path_to_file, $file_name, $type = '', $arguments = array(), $load_only = true)
538
+	{
539
+		// retrieve instantiated class
540
+		return $this->_load($path_to_file, '', $file_name, $type, $arguments, false, true, $load_only);
541
+	}
542
+
543
+
544
+
545
+	/**
546
+	 *    load_addon
547
+	 *
548
+	 * @param string $path_to_file - directory path to file location, not including filename
549
+	 * @param string $class_name   - full class name  ie:  My_Class
550
+	 * @param string $type         - file type - core? class? helper? model?
551
+	 * @param mixed  $arguments
552
+	 * @param bool   $load_only
553
+	 * @return EE_Addon
554
+	 */
555
+	public function load_addon($path_to_file, $class_name, $type = 'class', $arguments = array(), $load_only = false)
556
+	{
557
+		// retrieve instantiated class
558
+		return $this->_load($path_to_file, 'addon', $class_name, $type, $arguments, false, true, $load_only);
559
+	}
560
+
561
+
562
+
563
+	/**
564
+	 * instantiates, caches, and automatically resolves dependencies
565
+	 * for classes that use a Fully Qualified Class Name.
566
+	 * if the class is not capable of being loaded using PSR-4 autoloading,
567
+	 * then you need to use one of the existing load_*() methods
568
+	 * which can resolve the classname and filepath from the passed arguments
569
+	 *
570
+	 * @param bool|string $class_name   Fully Qualified Class Name
571
+	 * @param array       $arguments    an argument, or array of arguments to pass to the class upon instantiation
572
+	 * @param bool        $cache        whether to cache the instantiated object for reuse
573
+	 * @param bool        $from_db      some classes are instantiated from the db
574
+	 *                                  and thus call a different method to instantiate
575
+	 * @param bool        $load_only    if true, will only load the file, but will NOT instantiate an object
576
+	 * @param bool|string $addon        if true, will cache the object in the EE_Registry->$addons array
577
+	 * @return mixed                    null = failure to load or instantiate class object.
578
+	 *                                  object = class loaded and instantiated successfully.
579
+	 *                                  bool = fail or success when $load_only is true
580
+	 */
581
+	public function create(
582
+		$class_name = false,
583
+		$arguments = array(),
584
+		$cache = false,
585
+		$from_db = false,
586
+		$load_only = false,
587
+		$addon = false
588
+	) {
589
+		$class_name = $this->_dependency_map->get_alias($class_name);
590
+		if ( ! class_exists($class_name)) {
591
+			// maybe the class is registered with a preceding \
592
+			$class_name = strpos($class_name, '\\') !== 0 ? '\\' . $class_name : $class_name;
593
+			// still doesn't exist ?
594
+			if ( ! class_exists($class_name)) {
595
+				return null;
596
+			}
597
+		}
598
+		// if we're only loading the class and it already exists, then let's just return true immediately
599
+		if ($load_only) {
600
+			return true;
601
+		}
602
+		$addon = $addon ? 'addon' : '';
603
+		// $this->_cache_on is toggled during the recursive loading that can occur with dependency injection
604
+		// $cache is controlled by individual calls to separate Registry loader methods like load_class()
605
+		// $load_only is also controlled by individual calls to separate Registry loader methods like load_file()
606
+		if ($this->_cache_on && $cache && ! $load_only) {
607
+			// return object if it's already cached
608
+			$cached_class = $this->_get_cached_class($class_name, $addon);
609
+			if ($cached_class !== null) {
610
+				return $cached_class;
611
+			}
612
+		}
613
+		// instantiate the requested object
614
+		$class_obj = $this->_create_object($class_name, $arguments, $addon, $from_db);
615
+		if ($this->_cache_on && $cache) {
616
+			// save it for later... kinda like gum  { : $
617
+			$this->_set_cached_class($class_obj, $class_name, $addon, $from_db);
618
+		}
619
+		$this->_cache_on = true;
620
+		return $class_obj;
621
+	}
622
+
623
+
624
+
625
+	/**
626
+	 * instantiates, caches, and injects dependencies for classes
627
+	 *
628
+	 * @param array       $file_paths   an array of paths to folders to look in
629
+	 * @param string      $class_prefix EE  or EEM or... ???
630
+	 * @param bool|string $class_name   $class name
631
+	 * @param string      $type         file type - core? class? helper? model?
632
+	 * @param mixed       $arguments    an argument or array of arguments to pass to the class upon instantiation
633
+	 * @param bool        $from_db      some classes are instantiated from the db
634
+	 *                                  and thus call a different method to instantiate
635
+	 * @param bool        $cache        whether to cache the instantiated object for reuse
636
+	 * @param bool        $load_only    if true, will only load the file, but will NOT instantiate an object
637
+	 * @return null|object|bool         null = failure to load or instantiate class object.
638
+	 *                                  object = class loaded and instantiated successfully.
639
+	 *                                  bool = fail or success when $load_only is true
640
+	 */
641
+	protected function _load(
642
+		$file_paths = array(),
643
+		$class_prefix = 'EE_',
644
+		$class_name = false,
645
+		$type = 'class',
646
+		$arguments = array(),
647
+		$from_db = false,
648
+		$cache = true,
649
+		$load_only = false
650
+	) {
651
+		// strip php file extension
652
+		$class_name = str_replace('.php', '', trim($class_name));
653
+		// does the class have a prefix ?
654
+		if ( ! empty($class_prefix) && $class_prefix != 'addon') {
655
+			// make sure $class_prefix is uppercase
656
+			$class_prefix = strtoupper(trim($class_prefix));
657
+			// add class prefix ONCE!!!
658
+			$class_name = $class_prefix . str_replace($class_prefix, '', $class_name);
659
+		}
660
+		$class_name = $this->_dependency_map->get_alias($class_name);
661
+		$class_exists = class_exists($class_name);
662
+		// if we're only loading the class and it already exists, then let's just return true immediately
663
+		if ($load_only && $class_exists) {
664
+			return true;
665
+		}
666
+		// $this->_cache_on is toggled during the recursive loading that can occur with dependency injection
667
+		// $cache is controlled by individual calls to separate Registry loader methods like load_class()
668
+		// $load_only is also controlled by individual calls to separate Registry loader methods like load_file()
669
+		if ($this->_cache_on && $cache && ! $load_only) {
670
+			// return object if it's already cached
671
+			$cached_class = $this->_get_cached_class($class_name, $class_prefix);
672
+			if ($cached_class !== null) {
673
+				return $cached_class;
674
+			}
675
+		}
676
+		// if the class doesn't already exist.. then we need to try and find the file and load it
677
+		if ( ! $class_exists) {
678
+			// get full path to file
679
+			$path = $this->_resolve_path($class_name, $type, $file_paths);
680
+			// load the file
681
+			$loaded = $this->_require_file($path, $class_name, $type, $file_paths);
682
+			// if loading failed, or we are only loading a file but NOT instantiating an object
683
+			if ( ! $loaded || $load_only) {
684
+				// return boolean if only loading, or null if an object was expected
685
+				return $load_only ? $loaded : null;
686
+			}
687
+		}
688
+		// instantiate the requested object
689
+		$class_obj = $this->_create_object($class_name, $arguments, $type, $from_db);
690
+		if ($this->_cache_on && $cache) {
691
+			// save it for later... kinda like gum  { : $
692
+			$this->_set_cached_class($class_obj, $class_name, $class_prefix, $from_db);
693
+		}
694
+		$this->_cache_on = true;
695
+		return $class_obj;
696
+	}
697
+
698
+
699
+
700
+	/**
701
+	 * _get_cached_class
702
+	 * attempts to find a cached version of the requested class
703
+	 * by looking in the following places:
704
+	 *        $this->{$class_abbreviation}            ie:    $this->CART
705
+	 *        $this->{$class_name}                        ie:    $this->Some_Class
706
+	 *        $this->LIB->{$class_name}                ie:    $this->LIB->Some_Class
707
+	 *        $this->addon->{$class_name}    ie:    $this->addon->Some_Addon_Class
708
+	 *
709
+	 * @access protected
710
+	 * @param string $class_name
711
+	 * @param string $class_prefix
712
+	 * @return mixed
713
+	 */
714
+	protected function _get_cached_class($class_name, $class_prefix = '')
715
+	{
716
+		if (isset($this->_class_abbreviations[$class_name])) {
717
+			$class_abbreviation = $this->_class_abbreviations[$class_name];
718
+		} else {
719
+			// have to specify something, but not anything that will conflict
720
+			$class_abbreviation = 'FANCY_BATMAN_PANTS';
721
+		}
722
+		// check if class has already been loaded, and return it if it has been
723
+		if (isset($this->{$class_abbreviation}) && ! is_null($this->{$class_abbreviation})) {
724
+			return $this->{$class_abbreviation};
725
+		} else if (isset ($this->{$class_name})) {
726
+			return $this->{$class_name};
727
+		} else if (isset ($this->LIB->{$class_name})) {
728
+			return $this->LIB->{$class_name};
729
+		} else if ($class_prefix == 'addon' && isset ($this->addons->{$class_name})) {
730
+			return $this->addons->{$class_name};
731
+		}
732
+		return null;
733
+	}
734
+
735
+
736
+
737
+	/**
738
+	 * _resolve_path
739
+	 * attempts to find a full valid filepath for the requested class.
740
+	 * loops thru each of the base paths in the $file_paths array and appends : "{classname} . {file type} . php"
741
+	 * then returns that path if the target file has been found and is readable
742
+	 *
743
+	 * @access protected
744
+	 * @param string $class_name
745
+	 * @param string $type
746
+	 * @param array  $file_paths
747
+	 * @return string | bool
748
+	 */
749
+	protected function _resolve_path($class_name, $type = '', $file_paths = array())
750
+	{
751
+		// make sure $file_paths is an array
752
+		$file_paths = is_array($file_paths) ? $file_paths : array($file_paths);
753
+		// cycle thru paths
754
+		foreach ($file_paths as $key => $file_path) {
755
+			// convert all separators to proper DS, if no filepath, then use EE_CLASSES
756
+			$file_path = $file_path ? str_replace(array('/', '\\'), DS, $file_path) : EE_CLASSES;
757
+			// prep file type
758
+			$type = ! empty($type) ? trim($type, '.') . '.' : '';
759
+			// build full file path
760
+			$file_paths[$key] = rtrim($file_path, DS) . DS . $class_name . '.' . $type . 'php';
761
+			//does the file exist and can be read ?
762
+			if (is_readable($file_paths[$key])) {
763
+				return $file_paths[$key];
764
+			}
765
+		}
766
+		return false;
767
+	}
768
+
769
+
770
+
771
+	/**
772
+	 * _require_file
773
+	 * basically just performs a require_once()
774
+	 * but with some error handling
775
+	 *
776
+	 * @access protected
777
+	 * @param  string $path
778
+	 * @param  string $class_name
779
+	 * @param  string $type
780
+	 * @param  array  $file_paths
781
+	 * @return boolean
782
+	 * @throws \EE_Error
783
+	 */
784
+	protected function _require_file($path, $class_name, $type = '', $file_paths = array())
785
+	{
786
+		// don't give up! you gotta...
787
+		try {
788
+			//does the file exist and can it be read ?
789
+			if ( ! $path) {
790
+				// so sorry, can't find the file
791
+				throw new EE_Error (
792
+					sprintf(
793
+						__('The %1$s file %2$s could not be located or is not readable due to file permissions. Please ensure that the following filepath(s) are correct: %3$s', 'event_espresso'),
794
+						trim($type, '.'),
795
+						$class_name,
796
+						'<br />' . implode(',<br />', $file_paths)
797
+					)
798
+				);
799
+			}
800
+			// get the file
801
+			require_once($path);
802
+			// if the class isn't already declared somewhere
803
+			if (class_exists($class_name, false) === false) {
804
+				// so sorry, not a class
805
+				throw new EE_Error(
806
+					sprintf(
807
+						__('The %s file %s does not appear to contain the %s Class.', 'event_espresso'),
808
+						$type,
809
+						$path,
810
+						$class_name
811
+					)
812
+				);
813
+			}
814
+		} catch (EE_Error $e) {
815
+			$e->get_error();
816
+			return false;
817
+		}
818
+		return true;
819
+	}
820
+
821
+
822
+
823
+	/**
824
+	 * _create_object
825
+	 * Attempts to instantiate the requested class via any of the
826
+	 * commonly used instantiation methods employed throughout EE.
827
+	 * The priority for instantiation is as follows:
828
+	 *        - abstract classes or any class flagged as "load only" (no instantiation occurs)
829
+	 *        - model objects via their 'new_instance_from_db' method
830
+	 *        - model objects via their 'new_instance' method
831
+	 *        - "singleton" classes" via their 'instance' method
832
+	 *    - standard instantiable classes via their __constructor
833
+	 * Prior to instantiation, if the classname exists in the dependency_map,
834
+	 * then the constructor for the requested class will be examined to determine
835
+	 * if any dependencies exist, and if they can be injected.
836
+	 * If so, then those classes will be added to the array of arguments passed to the constructor
837
+	 *
838
+	 * @access protected
839
+	 * @param string $class_name
840
+	 * @param array  $arguments
841
+	 * @param string $type
842
+	 * @param bool   $from_db
843
+	 * @return null | object
844
+	 * @throws \EE_Error
845
+	 */
846
+	protected function _create_object($class_name, $arguments = array(), $type = '', $from_db = false)
847
+	{
848
+		$class_obj = null;
849
+		$instantiation_mode = '0) none';
850
+		// don't give up! you gotta...
851
+		try {
852
+			// create reflection
853
+			$reflector = $this->get_ReflectionClass($class_name);
854
+			// make sure arguments are an array
855
+			$arguments = is_array($arguments) ? $arguments : array($arguments);
856
+			// and if arguments array is numerically and sequentially indexed, then we want it to remain as is,
857
+			// else wrap it in an additional array so that it doesn't get split into multiple parameters
858
+			$arguments = $this->_array_is_numerically_and_sequentially_indexed($arguments)
859
+				? $arguments
860
+				: array($arguments);
861
+			// attempt to inject dependencies ?
862
+			if ($this->_dependency_map->has($class_name)) {
863
+				$arguments = $this->_resolve_dependencies($reflector, $class_name, $arguments);
864
+			}
865
+			// instantiate the class if possible
866
+			if ($reflector->isAbstract()) {
867
+				// nothing to instantiate, loading file was enough
868
+				// does not throw an exception so $instantiation_mode is unused
869
+				// $instantiation_mode = "1) no constructor abstract class";
870
+				$class_obj = true;
871
+			} else if ($reflector->getConstructor() === null && $reflector->isInstantiable() && empty($arguments)) {
872
+				// no constructor = static methods only... nothing to instantiate, loading file was enough
873
+				$instantiation_mode = "2) no constructor but instantiable";
874
+				$class_obj = $reflector->newInstance();
875
+			} else if ($from_db && method_exists($class_name, 'new_instance_from_db')) {
876
+				$instantiation_mode = "3) new_instance_from_db()";
877
+				$class_obj = call_user_func_array(array($class_name, 'new_instance_from_db'), $arguments);
878
+			} else if (method_exists($class_name, 'new_instance')) {
879
+				$instantiation_mode = "4) new_instance()";
880
+				$class_obj = call_user_func_array(array($class_name, 'new_instance'), $arguments);
881
+			} else if (method_exists($class_name, 'instance')) {
882
+				$instantiation_mode = "5) instance()";
883
+				$class_obj = call_user_func_array(array($class_name, 'instance'), $arguments);
884
+			} else if ($reflector->isInstantiable()) {
885
+				$instantiation_mode = "6) constructor";
886
+				$class_obj = $reflector->newInstanceArgs($arguments);
887
+			} else {
888
+				// heh ? something's not right !
889
+				throw new EE_Error(
890
+					sprintf(
891
+						__('The %s file %s could not be instantiated.', 'event_espresso'),
892
+						$type,
893
+						$class_name
894
+					)
895
+				);
896
+			}
897
+		} catch (Exception $e) {
898
+			if ( ! $e instanceof EE_Error) {
899
+				$e = new EE_Error(
900
+					sprintf(
901
+						__('The following error occurred while attempting to instantiate "%1$s": %2$s %3$s %2$s instantiation mode : %4$s', 'event_espresso'),
902
+						$class_name,
903
+						'<br />',
904
+						$e->getMessage(),
905
+						$instantiation_mode
906
+					)
907
+				);
908
+			}
909
+			$e->get_error();
910
+		}
911
+		return $class_obj;
912
+	}
913
+
914
+
915
+
916
+	/**
917
+	 * @see http://stackoverflow.com/questions/173400/how-to-check-if-php-array-is-associative-or-sequential
918
+	 * @param array $array
919
+	 * @return bool
920
+	 */
921
+	protected function _array_is_numerically_and_sequentially_indexed(array $array)
922
+	{
923
+		return ! empty($array) ? array_keys($array) === range(0, count($array) - 1) : true;
924
+	}
925
+
926
+
927
+
928
+	/**
929
+	 * getReflectionClass
930
+	 * checks if a ReflectionClass object has already been generated for a class
931
+	 * and returns that instead of creating a new one
932
+	 *
933
+	 * @access public
934
+	 * @param string $class_name
935
+	 * @return ReflectionClass
936
+	 */
937
+	public function get_ReflectionClass($class_name)
938
+	{
939
+		if (
940
+			! isset($this->_reflectors[$class_name])
941
+			|| ! $this->_reflectors[$class_name] instanceof ReflectionClass
942
+		) {
943
+			$this->_reflectors[$class_name] = new ReflectionClass($class_name);
944
+		}
945
+		return $this->_reflectors[$class_name];
946
+	}
947
+
948
+
949
+
950
+	/**
951
+	 * _resolve_dependencies
952
+	 * examines the constructor for the requested class to determine
953
+	 * if any dependencies exist, and if they can be injected.
954
+	 * If so, then those classes will be added to the array of arguments passed to the constructor
955
+	 * PLZ NOTE: this is achieved by type hinting the constructor params
956
+	 * For example:
957
+	 *        if attempting to load a class "Foo" with the following constructor:
958
+	 *        __construct( Bar $bar_class, Fighter $grohl_class )
959
+	 *        then $bar_class and $grohl_class will be added to the $arguments array,
960
+	 *        but only IF they are NOT already present in the incoming arguments array,
961
+	 *        and the correct classes can be loaded
962
+	 *
963
+	 * @access protected
964
+	 * @param ReflectionClass $reflector
965
+	 * @param string          $class_name
966
+	 * @param array           $arguments
967
+	 * @return array
968
+	 * @throws \ReflectionException
969
+	 */
970
+	protected function _resolve_dependencies(ReflectionClass $reflector, $class_name, $arguments = array())
971
+	{
972
+		// let's examine the constructor
973
+		$constructor = $reflector->getConstructor();
974
+		// whu? huh? nothing?
975
+		if ( ! $constructor) {
976
+			return $arguments;
977
+		}
978
+		// get constructor parameters
979
+		$params = $constructor->getParameters();
980
+		// and the keys for the incoming arguments array so that we can compare existing arguments with what is expected
981
+		$argument_keys = array_keys($arguments);
982
+		// now loop thru all of the constructors expected parameters
983
+		foreach ($params as $index => $param) {
984
+			// is this a dependency for a specific class ?
985
+			$param_class = $param->getClass() ? $param->getClass()->name : null;
986
+			if (
987
+				// param is not even a class
988
+				empty($param_class)
989
+				// and something already exists in the incoming arguments for this param
990
+				&& isset($argument_keys[$index], $arguments[$argument_keys[$index]])
991
+			) {
992
+				// so let's skip this argument and move on to the next
993
+				continue;
994
+			} else if (
995
+				// parameter is type hinted as a class, exists as an incoming argument, AND it's the correct class
996
+				! empty($param_class)
997
+				&& isset($argument_keys[$index], $arguments[$argument_keys[$index]])
998
+				&& $arguments[$argument_keys[$index]] instanceof $param_class
999
+			) {
1000
+				// skip this argument and move on to the next
1001
+				continue;
1002
+			} else if (
1003
+				// parameter is type hinted as a class, and should be injected
1004
+				! empty($param_class)
1005
+				&& $this->_dependency_map->has_dependency_for_class($class_name, $param_class)
1006
+			) {
1007
+				$arguments = $this->_resolve_dependency($class_name, $param_class, $arguments, $index);
1008
+			} else {
1009
+				try {
1010
+					$arguments[$index] = $param->getDefaultValue();
1011
+				} catch (ReflectionException $e) {
1012
+					throw new ReflectionException(
1013
+						sprintf(
1014
+							__('%1$s for parameter "$%2$s"', 'event_espresso'),
1015
+							$e->getMessage(),
1016
+							$param->getName()
1017
+						)
1018
+					);
1019
+				}
1020
+			}
1021
+		}
1022
+		return $arguments;
1023
+	}
1024
+
1025
+
1026
+
1027
+	/**
1028
+	 * @access protected
1029
+	 * @param string $class_name
1030
+	 * @param string $param_class
1031
+	 * @param array  $arguments
1032
+	 * @param mixed  $index
1033
+	 * @return array
1034
+	 */
1035
+	protected function _resolve_dependency($class_name, $param_class, $arguments, $index)
1036
+	{
1037
+		$dependency = null;
1038
+		// should dependency be loaded from cache ?
1039
+		$cache_on = $this->_dependency_map->loading_strategy_for_class_dependency($class_name, $param_class)
1040
+					!== EE_Dependency_Map::load_new_object
1041
+			? true
1042
+			: false;
1043
+		// we might have a dependency...
1044
+		// let's MAYBE try and find it in our cache if that's what's been requested
1045
+		$cached_class = $cache_on ? $this->_get_cached_class($param_class) : null;
1046
+		// and grab it if it exists
1047
+		if ($cached_class instanceof $param_class) {
1048
+			$dependency = $cached_class;
1049
+		} else if ($param_class != $class_name) {
1050
+			// obtain the loader method from the dependency map
1051
+			$loader = $this->_dependency_map->class_loader($param_class);
1052
+			// is loader a custom closure ?
1053
+			if ($loader instanceof Closure) {
1054
+				$dependency = $loader();
1055
+			} else {
1056
+				// set the cache on property for the recursive loading call
1057
+				$this->_cache_on = $cache_on;
1058
+				// if not, then let's try and load it via the registry
1059
+				if (method_exists($this, $loader)) {
1060
+					$dependency = $this->{$loader}($param_class);
1061
+				} else {
1062
+					$dependency = $this->create($param_class, array(), $cache_on);
1063
+				}
1064
+			}
1065
+		}
1066
+		// did we successfully find the correct dependency ?
1067
+		if ($dependency instanceof $param_class) {
1068
+			// then let's inject it into the incoming array of arguments at the correct location
1069
+			if (isset($argument_keys[$index])) {
1070
+				$arguments[$argument_keys[$index]] = $dependency;
1071
+			} else {
1072
+				$arguments[$index] = $dependency;
1073
+			}
1074
+		}
1075
+		return $arguments;
1076
+	}
1077
+
1078
+
1079
+
1080
+	/**
1081
+	 * _set_cached_class
1082
+	 * attempts to cache the instantiated class locally
1083
+	 * in one of the following places, in the following order:
1084
+	 *        $this->{class_abbreviation}   ie:    $this->CART
1085
+	 *        $this->{$class_name}          ie:    $this->Some_Class
1086
+	 *        $this->addon->{$$class_name}    ie:    $this->addon->Some_Addon_Class
1087
+	 *        $this->LIB->{$class_name}     ie:    $this->LIB->Some_Class
1088
+	 *
1089
+	 * @access protected
1090
+	 * @param object $class_obj
1091
+	 * @param string $class_name
1092
+	 * @param string $class_prefix
1093
+	 * @param bool   $from_db
1094
+	 * @return void
1095
+	 */
1096
+	protected function _set_cached_class($class_obj, $class_name, $class_prefix = '', $from_db = false)
1097
+	{
1098
+		if (empty($class_obj)) {
1099
+			return;
1100
+		}
1101
+		// return newly instantiated class
1102
+		if (isset($this->_class_abbreviations[$class_name])) {
1103
+			$class_abbreviation = $this->_class_abbreviations[$class_name];
1104
+			$this->{$class_abbreviation} = $class_obj;
1105
+		} else if (property_exists($this, $class_name)) {
1106
+			$this->{$class_name} = $class_obj;
1107
+		} else if ($class_prefix == 'addon') {
1108
+			$this->addons->{$class_name} = $class_obj;
1109
+		} else if ( ! $from_db) {
1110
+			$this->LIB->{$class_name} = $class_obj;
1111
+		}
1112
+	}
1113
+
1114
+
1115
+
1116
+	/**
1117
+	 * call any loader that's been registered in the EE_Dependency_Map::$_class_loaders array
1118
+	 *
1119
+	 * @param string $classname PLEASE NOTE: the class name needs to match what's registered
1120
+	 *                          in the EE_Dependency_Map::$_class_loaders array,
1121
+	 *                          including the class prefix, ie: "EE_", "EEM_", "EEH_", etc
1122
+	 * @param array  $arguments
1123
+	 * @return object
1124
+	 */
1125
+	public static function factory($classname, $arguments = array())
1126
+	{
1127
+		$loader = self::instance()->_dependency_map->class_loader($classname);
1128
+		if ($loader instanceof Closure) {
1129
+			return $loader($arguments);
1130
+		} else if (method_exists(EE_Registry::instance(), $loader)) {
1131
+			return EE_Registry::instance()->{$loader}($classname, $arguments);
1132
+		}
1133
+		return null;
1134
+	}
1135
+
1136
+
1137
+
1138
+	/**
1139
+	 * Gets the addon by its name/slug (not classname. For that, just
1140
+	 * use the classname as the property name on EE_Config::instance()->addons)
1141
+	 *
1142
+	 * @param string $name
1143
+	 * @return EE_Addon
1144
+	 */
1145
+	public function get_addon_by_name($name)
1146
+	{
1147
+		foreach ($this->addons as $addon) {
1148
+			if ($addon->name() == $name) {
1149
+				return $addon;
1150
+			}
1151
+		}
1152
+		return null;
1153
+	}
1154
+
1155
+
1156
+
1157
+	/**
1158
+	 * Gets an array of all the registered addons, where the keys are their names. (ie, what each returns for their name() function) They're already available on EE_Config::instance()->addons as properties, where each property's name is
1159
+	 * the addon's classname. So if you just want to get the addon by classname, use EE_Config::instance()->addons->{classname}
1160
+	 *
1161
+	 * @return EE_Addon[] where the KEYS are the addon's name()
1162
+	 */
1163
+	public function get_addons_by_name()
1164
+	{
1165
+		$addons = array();
1166
+		foreach ($this->addons as $addon) {
1167
+			$addons[$addon->name()] = $addon;
1168
+		}
1169
+		return $addons;
1170
+	}
1171
+
1172
+
1173
+
1174
+	/**
1175
+	 * Resets the specified model's instance AND makes sure EE_Registry doesn't keep
1176
+	 * a stale copy of it around
1177
+	 *
1178
+	 * @param string $model_name
1179
+	 * @return \EEM_Base
1180
+	 * @throws \EE_Error
1181
+	 */
1182
+	public function reset_model($model_name)
1183
+	{
1184
+		$model_class_name = strpos($model_name, 'EEM_') !== 0 ? "EEM_{$model_name}" : $model_name;
1185
+		if ( ! isset($this->LIB->{$model_class_name}) || ! $this->LIB->{$model_class_name} instanceof EEM_Base) {
1186
+			return null;
1187
+		}
1188
+		//get that model reset it and make sure we nuke the old reference to it
1189
+		if ($this->LIB->{$model_class_name} instanceof $model_class_name && is_callable(array($model_class_name, 'reset'))) {
1190
+			$this->LIB->{$model_class_name} = $this->LIB->{$model_class_name}->reset();
1191
+		} else {
1192
+			throw new EE_Error(sprintf(__('Model %s does not have a method "reset"', 'event_espresso'), $model_name));
1193
+		}
1194
+		return $this->LIB->{$model_class_name};
1195
+	}
1196
+
1197
+
1198
+
1199
+	/**
1200
+	 * Resets the registry.
1201
+	 * The criteria for what gets reset is based on what can be shared between sites on the same request when switch_to_blog
1202
+	 * is used in a multisite install.  Here is a list of things that are NOT reset.
1203
+	 * - $_dependency_map
1204
+	 * - $_class_abbreviations
1205
+	 * - $NET_CFG (EE_Network_Config): The config is shared network wide so no need to reset.
1206
+	 * - $REQ:  Still on the same request so no need to change.
1207
+	 * - $CAP: There is no site specific state in the EE_Capability class.
1208
+	 * - $SSN: Although ideally, the session should not be shared between site switches, we can't reset it because only one Session
1209
+	 *         can be active in a single request.  Resetting could resolve in "headers already sent" errors.
1210
+	 * - $addons:  In multisite, the state of the addons is something controlled via hooks etc in a normal request.  So
1211
+	 *             for now, we won't reset the addons because it could break calls to an add-ons class/methods in the
1212
+	 *             switch or on the restore.
1213
+	 * - $modules
1214
+	 * - $shortcodes
1215
+	 * - $widgets
1216
+	 *
1217
+	 * @param boolean $hard             whether to reset data in the database too, or just refresh
1218
+	 *                                  the Registry to its state at the beginning of the request
1219
+	 * @param boolean $reinstantiate    whether to create new instances of EE_Registry's singletons too,
1220
+	 *                                  or just reset without re-instantiating (handy to set to FALSE if you're not sure if you CAN
1221
+	 *                                  currently reinstantiate the singletons at the moment)
1222
+	 * @param   bool  $reset_models     Defaults to true.  When false, then the models are not reset.  This is so client
1223
+	 *                                  code instead can just change the model context to a different blog id if necessary
1224
+	 * @return EE_Registry
1225
+	 */
1226
+	public static function reset($hard = false, $reinstantiate = true, $reset_models = true)
1227
+	{
1228
+		$instance = self::instance();
1229
+		EEH_Activation::reset();
1230
+		//properties that get reset
1231
+		$instance->_cache_on = true;
1232
+		$instance->CFG = EE_Config::reset($hard, $reinstantiate);
1233
+		$instance->CART = null;
1234
+		$instance->MRM = null;
1235
+		$instance->AssetsRegistry = new Registry();
1236
+		//messages reset
1237
+		EED_Messages::reset();
1238
+		if ($reset_models) {
1239
+			foreach (array_keys($instance->non_abstract_db_models) as $model_name) {
1240
+				$instance->reset_model($model_name);
1241
+			}
1242
+		}
1243
+		$instance->LIB = new stdClass();
1244
+		return $instance;
1245
+	}
1246
+
1247
+
1248
+
1249
+	/**
1250
+	 * @override magic methods
1251
+	 * @return void
1252
+	 */
1253
+	final function __destruct()
1254
+	{
1255
+	}
1256
+
1257
+
1258
+
1259
+	/**
1260
+	 * @param $a
1261
+	 * @param $b
1262
+	 */
1263
+	final function __call($a, $b)
1264
+	{
1265
+	}
1266
+
1267
+
1268
+
1269
+	/**
1270
+	 * @param $a
1271
+	 */
1272
+	final function __get($a)
1273
+	{
1274
+	}
1275
+
1276
+
1277
+
1278
+	/**
1279
+	 * @param $a
1280
+	 * @param $b
1281
+	 */
1282
+	final function __set($a, $b)
1283
+	{
1284
+	}
1285
+
1286
+
1287
+
1288
+	/**
1289
+	 * @param $a
1290
+	 */
1291
+	final function __isset($a)
1292
+	{
1293
+	}
1294 1294
 
1295 1295
 
1296 1296
 
1297
-    /**
1298
-     * @param $a
1299
-     */
1300
-    final function __unset($a)
1301
-    {
1302
-    }
1297
+	/**
1298
+	 * @param $a
1299
+	 */
1300
+	final function __unset($a)
1301
+	{
1302
+	}
1303 1303
 
1304 1304
 
1305 1305
 
1306
-    /**
1307
-     * @return array
1308
-     */
1309
-    final function __sleep()
1310
-    {
1311
-        return array();
1312
-    }
1306
+	/**
1307
+	 * @return array
1308
+	 */
1309
+	final function __sleep()
1310
+	{
1311
+		return array();
1312
+	}
1313 1313
 
1314 1314
 
1315 1315
 
1316
-    final function __wakeup()
1317
-    {
1318
-    }
1316
+	final function __wakeup()
1317
+	{
1318
+	}
1319 1319
 
1320 1320
 
1321 1321
 
1322
-    /**
1323
-     * @return string
1324
-     */
1325
-    final function __toString()
1326
-    {
1327
-        return '';
1328
-    }
1322
+	/**
1323
+	 * @return string
1324
+	 */
1325
+	final function __toString()
1326
+	{
1327
+		return '';
1328
+	}
1329 1329
 
1330 1330
 
1331 1331
 
1332
-    final function __invoke()
1333
-    {
1334
-    }
1332
+	final function __invoke()
1333
+	{
1334
+	}
1335 1335
 
1336 1336
 
1337 1337
 
1338
-    final static function __set_state()
1339
-    {
1340
-    }
1338
+	final static function __set_state()
1339
+	{
1340
+	}
1341 1341
 
1342 1342
 
1343 1343
 
1344
-    final function __clone()
1345
-    {
1346
-    }
1344
+	final function __clone()
1345
+	{
1346
+	}
1347 1347
 
1348 1348
 
1349 1349
 
1350
-    /**
1351
-     * @param $a
1352
-     * @param $b
1353
-     */
1354
-    final static function __callStatic($a, $b)
1355
-    {
1356
-    }
1350
+	/**
1351
+	 * @param $a
1352
+	 * @param $b
1353
+	 */
1354
+	final static function __callStatic($a, $b)
1355
+	{
1356
+	}
1357 1357
 
1358 1358
 
1359 1359
 
1360
-    /**
1361
-     * Gets all the custom post type models defined
1362
-     *
1363
-     * @return array keys are model "short names" (Eg "Event") and keys are classnames (eg "EEM_Event")
1364
-     */
1365
-    public function cpt_models()
1366
-    {
1367
-        $cpt_models = array();
1368
-        foreach ($this->non_abstract_db_models as $short_name => $classname) {
1369
-            if (is_subclass_of($classname, 'EEM_CPT_Base')) {
1370
-                $cpt_models[$short_name] = $classname;
1371
-            }
1372
-        }
1373
-        return $cpt_models;
1374
-    }
1360
+	/**
1361
+	 * Gets all the custom post type models defined
1362
+	 *
1363
+	 * @return array keys are model "short names" (Eg "Event") and keys are classnames (eg "EEM_Event")
1364
+	 */
1365
+	public function cpt_models()
1366
+	{
1367
+		$cpt_models = array();
1368
+		foreach ($this->non_abstract_db_models as $short_name => $classname) {
1369
+			if (is_subclass_of($classname, 'EEM_CPT_Base')) {
1370
+				$cpt_models[$short_name] = $classname;
1371
+			}
1372
+		}
1373
+		return $cpt_models;
1374
+	}
1375 1375
 
1376 1376
 
1377 1377
 
1378
-    /**
1379
-     * @return \EE_Config
1380
-     */
1381
-    public static function CFG()
1382
-    {
1383
-        return self::instance()->CFG;
1384
-    }
1378
+	/**
1379
+	 * @return \EE_Config
1380
+	 */
1381
+	public static function CFG()
1382
+	{
1383
+		return self::instance()->CFG;
1384
+	}
1385 1385
 
1386 1386
 
1387 1387
 }
Please login to merge, or discard this patch.
core/EE_Data_Mapper.core.php 1 patch
Indentation   +5 added lines, -5 removed lines patch added patch discarded remove patch
@@ -28,9 +28,9 @@  discard block
 block discarded – undo
28 28
 
29 29
 
30 30
    /**
31
-     * instance of the EE_Data_Mapper Object
32
-     * @private _instance
33
-     */
31
+    * instance of the EE_Data_Mapper Object
32
+    * @private _instance
33
+    */
34 34
 	private static $_instance = NULL;
35 35
 
36 36
 
@@ -82,8 +82,8 @@  discard block
 block discarded – undo
82 82
 	}
83 83
 	final function __wakeup() {}
84 84
 	final function __toString() {
85
-	    return '';
86
-    }
85
+		return '';
86
+	}
87 87
 	final function __invoke() {}
88 88
 	final static function __set_state() {}
89 89
 	final function __clone() {}
Please login to merge, or discard this patch.
core/services/shortcodes/EspressoShortcode.php 2 patches
Indentation   +167 added lines, -167 removed lines patch added patch discarded remove patch
@@ -18,173 +18,173 @@
 block discarded – undo
18 18
 abstract class EspressoShortcode implements ShortcodeInterface
19 19
 {
20 20
 
21
-    /**
22
-     * transient prefix
23
-     *
24
-     * @type string
25
-     */
26
-    const CACHE_TRANSIENT_PREFIX = 'ee_sc_';
27
-
28
-
29
-
30
-    /**
31
-     * enqueues scripts then processes the shortcode
32
-     *
33
-     * @param array $attributes
34
-     * @return string
35
-     * @throws \EE_Error
36
-     */
37
-    final public function processShortcodeCallback($attributes = array())
38
-    {
39
-        if ($this instanceof EnqueueAssetsInterface) {
40
-            if (is_admin()) {
41
-                $this->enqueueAdminScripts();
42
-            } else {
43
-                $this->enqueueScripts();
44
-            }
45
-        }
46
-        return $this->shortcodeContent(
47
-            $this->sanitizeAttributes((array)$attributes)
48
-        );
49
-    }
50
-
51
-
52
-
53
-    /**
54
-     * If shortcode caching is enabled for the shortcode,
55
-     * and cached results exist, then that will be returned
56
-     * else new content will be generated.
57
-     * If caching is enabled, then the new content will be cached for later.
58
-     *
59
-     * @param array $attributes
60
-     * @return mixed|string
61
-     * @throws \EE_Error
62
-     */
63
-    private function shortcodeContent(array $attributes)
64
-    {
65
-        $content = '';
66
-        $cache_id = '';
67
-        // how long should we cache this shortcode's content for? 0 means no caching.
68
-        $cache_expiration = absint(
69
-            apply_filters(
70
-                'FHEE__EventEspresso_core_services_shortcodes_EspressoShortcode__shortcodeContent__cache_expiration',
71
-                $this->cacheExpiration(),
72
-                $this->getTag(),
73
-                $this
74
-            )
75
-        );
76
-        // is caching enabled for this shortcode ?
77
-        if ($cache_expiration) {
78
-            $cache_id = $this->shortcodeCacheID($attributes);
79
-            $content = get_transient($cache_id);
80
-        }
81
-        // any existing content ?
82
-        if (empty($content)) {
83
-            // nope! let's generate some new stuff
84
-            $content = $this->processShortcode($attributes);
85
-            // save the new content if caching is enabled
86
-            if ($cache_expiration) {
87
-                set_transient($cache_id, $content, $cache_expiration);
88
-            }
89
-        }
90
-        return $content;
91
-    }
92
-
93
-
94
-
95
-    /**
96
-     * @param array $attributes
97
-     * @return string
98
-     * @throws \EE_Error
99
-     */
100
-    private function shortcodeCacheID(array $attributes)
101
-    {
102
-        // try to get EE_Event any way we can
103
-        $event = \EEH_Event_View::get_event();
104
-        // then get some kind of ID
105
-        if ($event instanceof \EE_Event) {
106
-            $ID = $event->ID();
107
-        } else {
108
-            global $post;
109
-            $ID = $post->ID;
110
-        }
111
-        return EspressoShortcode::CACHE_TRANSIENT_PREFIX . $ID . md5(wp_json_encode($attributes));
112
-    }
113
-
114
-
115
-
116
-    /**
117
-     * array for defining custom attribute sanitization callbacks,
118
-     * where keys match keys in your attributes array,
119
-     * and values represent the sanitization function you wish to be applied to that attribute.
120
-     * So for example, if you had an integer attribute named "event_id"
121
-     * that you wanted to be sanitized using absint(),
122
-     * then you would return the following:
123
-     *      array('event_id' => 'absint')
124
-     * Entering 'skip_sanitization' for the callback value
125
-     * means that no sanitization will be applied
126
-     * on the assumption that the attribute
127
-     * will be sanitized at some point... right?
128
-     * You wouldn't pass around unsanitized attributes would you?
129
-     * That would be very Tom Foolery of you!!!
130
-     *
131
-     * @return array
132
-     */
133
-    protected function customAttributeSanitizationMap()
134
-    {
135
-        return array();
136
-    }
137
-
138
-
139
-
140
-    /**
141
-     * Performs basic sanitization on shortcode attributes
142
-     * Since incoming attributes from the shortcode usage in the WP editor will all be strings,
143
-     * most attributes will by default be sanitized using the sanitize_text_field() function.
144
-     * This can be overridden using the customAttributeSanitizationMap() method (see above),
145
-     * all other attributes would be sanitized using the defaults in the switch statement below
146
-     *
147
-     * @param array $attributes
148
-     * @return array
149
-     */
150
-    private function sanitizeAttributes(array $attributes)
151
-    {
152
-        $custom_sanitization = $this->customAttributeSanitizationMap();
153
-        foreach ($attributes as $key => $value) {
154
-            // is a custom sanitization callback specified ?
155
-            if (isset($custom_sanitization[$key])) {
156
-                $callback = $custom_sanitization[$key];
157
-                if ($callback === 'skip_sanitization') {
158
-                    $attributes[$key] = $value;
159
-                    continue;
160
-                } else if (function_exists($callback)) {
161
-                    $attributes[$key] = $callback($value);
162
-                    continue;
163
-                }
164
-            }
165
-            switch (true) {
166
-                case $value === null :
167
-                case is_int($value) :
168
-                case is_float($value) :
169
-                    // typical booleans
170
-                case in_array($value, array(true, 'true', '1', 'on', 'yes', false, 'false', '0', 'off', 'no'), true) :
171
-                    $attributes[$key] = $value;
172
-                    break;
173
-                case is_string($value) :
174
-                    $attributes[$key] = sanitize_text_field($value);
175
-                    break;
176
-                case is_array($value) :
177
-                    $attributes[$key] = $this->sanitizeAttributes($value);
178
-                    break;
179
-                default :
180
-                    // only remaining data types are Object and Resource
181
-                    // which are not allowed as shortcode attributes
182
-                    $attributes[$key] = null;
183
-                    break;
184
-            }
185
-        }
186
-        return $attributes;
187
-    }
21
+	/**
22
+	 * transient prefix
23
+	 *
24
+	 * @type string
25
+	 */
26
+	const CACHE_TRANSIENT_PREFIX = 'ee_sc_';
27
+
28
+
29
+
30
+	/**
31
+	 * enqueues scripts then processes the shortcode
32
+	 *
33
+	 * @param array $attributes
34
+	 * @return string
35
+	 * @throws \EE_Error
36
+	 */
37
+	final public function processShortcodeCallback($attributes = array())
38
+	{
39
+		if ($this instanceof EnqueueAssetsInterface) {
40
+			if (is_admin()) {
41
+				$this->enqueueAdminScripts();
42
+			} else {
43
+				$this->enqueueScripts();
44
+			}
45
+		}
46
+		return $this->shortcodeContent(
47
+			$this->sanitizeAttributes((array)$attributes)
48
+		);
49
+	}
50
+
51
+
52
+
53
+	/**
54
+	 * If shortcode caching is enabled for the shortcode,
55
+	 * and cached results exist, then that will be returned
56
+	 * else new content will be generated.
57
+	 * If caching is enabled, then the new content will be cached for later.
58
+	 *
59
+	 * @param array $attributes
60
+	 * @return mixed|string
61
+	 * @throws \EE_Error
62
+	 */
63
+	private function shortcodeContent(array $attributes)
64
+	{
65
+		$content = '';
66
+		$cache_id = '';
67
+		// how long should we cache this shortcode's content for? 0 means no caching.
68
+		$cache_expiration = absint(
69
+			apply_filters(
70
+				'FHEE__EventEspresso_core_services_shortcodes_EspressoShortcode__shortcodeContent__cache_expiration',
71
+				$this->cacheExpiration(),
72
+				$this->getTag(),
73
+				$this
74
+			)
75
+		);
76
+		// is caching enabled for this shortcode ?
77
+		if ($cache_expiration) {
78
+			$cache_id = $this->shortcodeCacheID($attributes);
79
+			$content = get_transient($cache_id);
80
+		}
81
+		// any existing content ?
82
+		if (empty($content)) {
83
+			// nope! let's generate some new stuff
84
+			$content = $this->processShortcode($attributes);
85
+			// save the new content if caching is enabled
86
+			if ($cache_expiration) {
87
+				set_transient($cache_id, $content, $cache_expiration);
88
+			}
89
+		}
90
+		return $content;
91
+	}
92
+
93
+
94
+
95
+	/**
96
+	 * @param array $attributes
97
+	 * @return string
98
+	 * @throws \EE_Error
99
+	 */
100
+	private function shortcodeCacheID(array $attributes)
101
+	{
102
+		// try to get EE_Event any way we can
103
+		$event = \EEH_Event_View::get_event();
104
+		// then get some kind of ID
105
+		if ($event instanceof \EE_Event) {
106
+			$ID = $event->ID();
107
+		} else {
108
+			global $post;
109
+			$ID = $post->ID;
110
+		}
111
+		return EspressoShortcode::CACHE_TRANSIENT_PREFIX . $ID . md5(wp_json_encode($attributes));
112
+	}
113
+
114
+
115
+
116
+	/**
117
+	 * array for defining custom attribute sanitization callbacks,
118
+	 * where keys match keys in your attributes array,
119
+	 * and values represent the sanitization function you wish to be applied to that attribute.
120
+	 * So for example, if you had an integer attribute named "event_id"
121
+	 * that you wanted to be sanitized using absint(),
122
+	 * then you would return the following:
123
+	 *      array('event_id' => 'absint')
124
+	 * Entering 'skip_sanitization' for the callback value
125
+	 * means that no sanitization will be applied
126
+	 * on the assumption that the attribute
127
+	 * will be sanitized at some point... right?
128
+	 * You wouldn't pass around unsanitized attributes would you?
129
+	 * That would be very Tom Foolery of you!!!
130
+	 *
131
+	 * @return array
132
+	 */
133
+	protected function customAttributeSanitizationMap()
134
+	{
135
+		return array();
136
+	}
137
+
138
+
139
+
140
+	/**
141
+	 * Performs basic sanitization on shortcode attributes
142
+	 * Since incoming attributes from the shortcode usage in the WP editor will all be strings,
143
+	 * most attributes will by default be sanitized using the sanitize_text_field() function.
144
+	 * This can be overridden using the customAttributeSanitizationMap() method (see above),
145
+	 * all other attributes would be sanitized using the defaults in the switch statement below
146
+	 *
147
+	 * @param array $attributes
148
+	 * @return array
149
+	 */
150
+	private function sanitizeAttributes(array $attributes)
151
+	{
152
+		$custom_sanitization = $this->customAttributeSanitizationMap();
153
+		foreach ($attributes as $key => $value) {
154
+			// is a custom sanitization callback specified ?
155
+			if (isset($custom_sanitization[$key])) {
156
+				$callback = $custom_sanitization[$key];
157
+				if ($callback === 'skip_sanitization') {
158
+					$attributes[$key] = $value;
159
+					continue;
160
+				} else if (function_exists($callback)) {
161
+					$attributes[$key] = $callback($value);
162
+					continue;
163
+				}
164
+			}
165
+			switch (true) {
166
+				case $value === null :
167
+				case is_int($value) :
168
+				case is_float($value) :
169
+					// typical booleans
170
+				case in_array($value, array(true, 'true', '1', 'on', 'yes', false, 'false', '0', 'off', 'no'), true) :
171
+					$attributes[$key] = $value;
172
+					break;
173
+				case is_string($value) :
174
+					$attributes[$key] = sanitize_text_field($value);
175
+					break;
176
+				case is_array($value) :
177
+					$attributes[$key] = $this->sanitizeAttributes($value);
178
+					break;
179
+				default :
180
+					// only remaining data types are Object and Resource
181
+					// which are not allowed as shortcode attributes
182
+					$attributes[$key] = null;
183
+					break;
184
+			}
185
+		}
186
+		return $attributes;
187
+	}
188 188
 
189 189
 
190 190
 
Please login to merge, or discard this patch.
Spacing   +2 added lines, -2 removed lines patch added patch discarded remove patch
@@ -44,7 +44,7 @@  discard block
 block discarded – undo
44 44
             }
45 45
         }
46 46
         return $this->shortcodeContent(
47
-            $this->sanitizeAttributes((array)$attributes)
47
+            $this->sanitizeAttributes((array) $attributes)
48 48
         );
49 49
     }
50 50
 
@@ -108,7 +108,7 @@  discard block
 block discarded – undo
108 108
             global $post;
109 109
             $ID = $post->ID;
110 110
         }
111
-        return EspressoShortcode::CACHE_TRANSIENT_PREFIX . $ID . md5(wp_json_encode($attributes));
111
+        return EspressoShortcode::CACHE_TRANSIENT_PREFIX.$ID.md5(wp_json_encode($attributes));
112 112
     }
113 113
 
114 114
 
Please login to merge, or discard this patch.
core/EES_Shortcode.shortcode.php 2 patches
Indentation   +68 added lines, -68 removed lines patch added patch discarded remove patch
@@ -20,17 +20,17 @@  discard block
 block discarded – undo
20 20
 
21 21
 
22 22
 
23
-    /**
24
-     * class constructor - should ONLY be instantiated by EE_Front_Controller
25
-     */
26
-    final public function __construct()
27
-    {
28
-        $shortcode = LegacyShortcodesManager::generateShortcodeTagFromClassName(get_class($this));
29
-        // assign shortcode to the preferred callback, which overwrites the "fallback shortcode processor" assigned earlier
30
-        add_shortcode($shortcode, array($this, 'process_shortcode'));
31
-        // make sure system knows this is an EE page
32
-        EE_Registry::instance()->REQ->set_espresso_page(true);
33
-    }
23
+	/**
24
+	 * class constructor - should ONLY be instantiated by EE_Front_Controller
25
+	 */
26
+	final public function __construct()
27
+	{
28
+		$shortcode = LegacyShortcodesManager::generateShortcodeTagFromClassName(get_class($this));
29
+		// assign shortcode to the preferred callback, which overwrites the "fallback shortcode processor" assigned earlier
30
+		add_shortcode($shortcode, array($this, 'process_shortcode'));
31
+		// make sure system knows this is an EE page
32
+		EE_Registry::instance()->REQ->set_espresso_page(true);
33
+	}
34 34
 
35 35
 
36 36
 
@@ -77,11 +77,11 @@  discard block
 block discarded – undo
77 77
 		}
78 78
 		$shortcode = str_replace( 'EES_', '', strtoupper( $shortcode_class ));
79 79
 		$shortcode_obj = isset( EE_Registry::instance()->shortcodes->{$shortcode} )
80
-            ? EE_Registry::instance()->shortcodes->{$shortcode}
81
-            : null;
80
+			? EE_Registry::instance()->shortcodes->{$shortcode}
81
+			: null;
82 82
 		return $shortcode_obj instanceof $shortcode_class || $shortcode_class === 'self'
83
-            ? $shortcode_obj
84
-            : new $shortcode_class();
83
+			? $shortcode_obj
84
+			: new $shortcode_class();
85 85
 	}
86 86
 
87 87
 
@@ -135,59 +135,59 @@  discard block
 block discarded – undo
135 135
 
136 136
 
137 137
 
138
-    /**
139
-     * Performs basic sanitization on shortcode attributes
140
-     * Since incoming attributes from the shortcode usage in the WP editor will all be strings,
141
-     * most attributes will by default be sanitized using the sanitize_text_field() function.
142
-     * This can be overridden by supplying an array for the $custom_sanitization param,
143
-     * where keys match keys in your attributes array,
144
-     * and values represent the sanitization function you wish to be applied to that attribute.
145
-     * So for example, if you had an integer attribute named "event_id"
146
-     * that you wanted to be sanitized using absint(),
147
-     * then you would pass the following for your $custom_sanitization array:
148
-     *      array('event_id' => 'absint')
149
-     * all other attributes would be sanitized using the defaults in the switch statement below
150
-     *
151
-     * @param array $attributes
152
-     * @param array $custom_sanitization
153
-     * @return array
154
-     */
155
-    public static function sanitize_attributes(array $attributes, $custom_sanitization = array())
156
-    {
157
-        foreach ($attributes as $key => $value) {
158
-            // is a custom sanitization callback specified ?
159
-            if ( isset($custom_sanitization[$key])) {
160
-                $callback = $custom_sanitization[$key];
161
-                if ($callback === 'skip_sanitization') {
162
-                    $attributes[$key] = $value;
163
-                    continue;
164
-                } else if (function_exists($callback)){
165
-                    $attributes[$key] = $callback($value);
166
-                    continue;
167
-                }
168
-            }
169
-            switch (true) {
170
-                case $value === null :
171
-                case is_int($value) :
172
-                case is_float($value) :
173
-                    // typical booleans
174
-                case in_array($value, array(true, 'true', '1', 'on', 'yes', false, 'false', '0', 'off', 'no'), true) :
175
-                    $attributes[$key] = $value;
176
-                    break;
177
-                case is_string($value) :
178
-                    $attributes[$key] = sanitize_text_field($value);
179
-                    break;
180
-                case is_array($value) :
181
-                    $attributes[$key] = \EES_Shortcode::sanitize_attributes($value);
182
-                    break;
183
-                default :
184
-                    // only remaining data types are Object and Resource
185
-                    // which are not allowed as shortcode attributes
186
-                    $attributes[$key] = null;
187
-                    break;
188
-            }
189
-        }
190
-        return $attributes;
138
+	/**
139
+	 * Performs basic sanitization on shortcode attributes
140
+	 * Since incoming attributes from the shortcode usage in the WP editor will all be strings,
141
+	 * most attributes will by default be sanitized using the sanitize_text_field() function.
142
+	 * This can be overridden by supplying an array for the $custom_sanitization param,
143
+	 * where keys match keys in your attributes array,
144
+	 * and values represent the sanitization function you wish to be applied to that attribute.
145
+	 * So for example, if you had an integer attribute named "event_id"
146
+	 * that you wanted to be sanitized using absint(),
147
+	 * then you would pass the following for your $custom_sanitization array:
148
+	 *      array('event_id' => 'absint')
149
+	 * all other attributes would be sanitized using the defaults in the switch statement below
150
+	 *
151
+	 * @param array $attributes
152
+	 * @param array $custom_sanitization
153
+	 * @return array
154
+	 */
155
+	public static function sanitize_attributes(array $attributes, $custom_sanitization = array())
156
+	{
157
+		foreach ($attributes as $key => $value) {
158
+			// is a custom sanitization callback specified ?
159
+			if ( isset($custom_sanitization[$key])) {
160
+				$callback = $custom_sanitization[$key];
161
+				if ($callback === 'skip_sanitization') {
162
+					$attributes[$key] = $value;
163
+					continue;
164
+				} else if (function_exists($callback)){
165
+					$attributes[$key] = $callback($value);
166
+					continue;
167
+				}
168
+			}
169
+			switch (true) {
170
+				case $value === null :
171
+				case is_int($value) :
172
+				case is_float($value) :
173
+					// typical booleans
174
+				case in_array($value, array(true, 'true', '1', 'on', 'yes', false, 'false', '0', 'off', 'no'), true) :
175
+					$attributes[$key] = $value;
176
+					break;
177
+				case is_string($value) :
178
+					$attributes[$key] = sanitize_text_field($value);
179
+					break;
180
+				case is_array($value) :
181
+					$attributes[$key] = \EES_Shortcode::sanitize_attributes($value);
182
+					break;
183
+				default :
184
+					// only remaining data types are Object and Resource
185
+					// which are not allowed as shortcode attributes
186
+					$attributes[$key] = null;
187
+					break;
188
+			}
189
+		}
190
+		return $attributes;
191 191
 	}
192 192
 
193 193
 
Please login to merge, or discard this patch.
Spacing   +18 added lines, -18 removed lines patch added patch discarded remove patch
@@ -47,7 +47,7 @@  discard block
 block discarded – undo
47 47
 	 * @param WP $WP
48 48
 	 * @return    void
49 49
 	 */
50
-	public abstract function run( WP $WP );
50
+	public abstract function run(WP $WP);
51 51
 
52 52
 
53 53
 
@@ -59,7 +59,7 @@  discard block
 block discarded – undo
59 59
 	 *  @param		array 	$attributes
60 60
 	 *  @return 	mixed
61 61
 	 */
62
-	public abstract function process_shortcode( $attributes = array() );
62
+	public abstract function process_shortcode($attributes = array());
63 63
 
64 64
 
65 65
 
@@ -70,13 +70,13 @@  discard block
 block discarded – undo
70 70
 	 * @param 	string $shortcode_class
71 71
 	 * @return 	\EES_Shortcode
72 72
 	 */
73
-	final public static function instance( $shortcode_class = null ) {
74
-		$shortcode_class = ! empty( $shortcode_class ) ? $shortcode_class : get_called_class();
75
-		if ( $shortcode_class === 'EES_Shortcode' || empty( $shortcode_class )) {
73
+	final public static function instance($shortcode_class = null) {
74
+		$shortcode_class = ! empty($shortcode_class) ? $shortcode_class : get_called_class();
75
+		if ($shortcode_class === 'EES_Shortcode' || empty($shortcode_class)) {
76 76
 			return null;
77 77
 		}
78
-		$shortcode = str_replace( 'EES_', '', strtoupper( $shortcode_class ));
79
-		$shortcode_obj = isset( EE_Registry::instance()->shortcodes->{$shortcode} )
78
+		$shortcode = str_replace('EES_', '', strtoupper($shortcode_class));
79
+		$shortcode_obj = isset(EE_Registry::instance()->shortcodes->{$shortcode} )
80 80
             ? EE_Registry::instance()->shortcodes->{$shortcode}
81 81
             : null;
82 82
 		return $shortcode_obj instanceof $shortcode_class || $shortcode_class === 'self'
@@ -95,23 +95,23 @@  discard block
 block discarded – undo
95 95
 	 * @param 	$attributes
96 96
 	 * @return 	mixed
97 97
 	 */
98
-	final public static function fallback_shortcode_processor( $attributes ) {
99
-		if ( EE_Maintenance_Mode::disable_frontend_for_maintenance() ) {
98
+	final public static function fallback_shortcode_processor($attributes) {
99
+		if (EE_Maintenance_Mode::disable_frontend_for_maintenance()) {
100 100
 			return null;
101 101
 		}
102 102
 		// what shortcode was actually parsed ?
103 103
 		$shortcode_class = get_called_class();
104 104
 		// notify rest of system that fallback processor was triggered
105
-		add_filter( 'FHEE__fallback_shortcode_processor__' . $shortcode_class, '__return_true' );
105
+		add_filter('FHEE__fallback_shortcode_processor__'.$shortcode_class, '__return_true');
106 106
 		// get instance of actual shortcode
107
-		$shortcode_obj = self::instance( $shortcode_class );
107
+		$shortcode_obj = self::instance($shortcode_class);
108 108
 		// verify class
109
-		if ( $shortcode_obj instanceof EES_Shortcode ) {
109
+		if ($shortcode_obj instanceof EES_Shortcode) {
110 110
 			global $wp;
111
-			$shortcode_obj->run( $wp );
111
+			$shortcode_obj->run($wp);
112 112
 			// set attributes and run the shortcode
113
-			$shortcode_obj->_attributes = (array)$attributes;
114
-			return $shortcode_obj->process_shortcode( $shortcode_obj->_attributes );
113
+			$shortcode_obj->_attributes = (array) $attributes;
114
+			return $shortcode_obj->process_shortcode($shortcode_obj->_attributes);
115 115
 		} else {
116 116
 			return null;
117 117
 		}
@@ -127,7 +127,7 @@  discard block
 block discarded – undo
127 127
 	 * @param 	$attributes
128 128
 	 * @return 	string
129 129
 	 */
130
-	final public static function invalid_shortcode_processor( $attributes ) {
130
+	final public static function invalid_shortcode_processor($attributes) {
131 131
 		return '';
132 132
 	}
133 133
 
@@ -156,12 +156,12 @@  discard block
 block discarded – undo
156 156
     {
157 157
         foreach ($attributes as $key => $value) {
158 158
             // is a custom sanitization callback specified ?
159
-            if ( isset($custom_sanitization[$key])) {
159
+            if (isset($custom_sanitization[$key])) {
160 160
                 $callback = $custom_sanitization[$key];
161 161
                 if ($callback === 'skip_sanitization') {
162 162
                     $attributes[$key] = $value;
163 163
                     continue;
164
-                } else if (function_exists($callback)){
164
+                } else if (function_exists($callback)) {
165 165
                     $attributes[$key] = $callback($value);
166 166
                     continue;
167 167
                 }
Please login to merge, or discard this patch.
core/EE_System.core.php 1 patch
Indentation   +1431 added lines, -1431 removed lines patch added patch discarded remove patch
@@ -2,7 +2,7 @@  discard block
 block discarded – undo
2 2
 use EventEspresso\core\services\shortcodes\ShortcodesManager;
3 3
 
4 4
 if ( ! defined('EVENT_ESPRESSO_VERSION')) {
5
-    exit('No direct script access allowed');
5
+	exit('No direct script access allowed');
6 6
 }
7 7
 
8 8
 
@@ -19,1436 +19,1436 @@  discard block
 block discarded – undo
19 19
 {
20 20
 
21 21
 
22
-    /**
23
-     * indicates this is a 'normal' request. Ie, not activation, nor upgrade, nor activation.
24
-     * So examples of this would be a normal GET request on the frontend or backend, or a POST, etc
25
-     */
26
-    const req_type_normal = 0;
27
-
28
-    /**
29
-     * Indicates this is a brand new installation of EE so we should install
30
-     * tables and default data etc
31
-     */
32
-    const req_type_new_activation = 1;
33
-
34
-    /**
35
-     * we've detected that EE has been reactivated (or EE was activated during maintenance mode,
36
-     * and we just exited maintenance mode). We MUST check the database is setup properly
37
-     * and that default data is setup too
38
-     */
39
-    const req_type_reactivation = 2;
40
-
41
-    /**
42
-     * indicates that EE has been upgraded since its previous request.
43
-     * We may have data migration scripts to call and will want to trigger maintenance mode
44
-     */
45
-    const req_type_upgrade = 3;
46
-
47
-    /**
48
-     * TODO  will detect that EE has been DOWNGRADED. We probably don't want to run in this case...
49
-     */
50
-    const req_type_downgrade = 4;
51
-
52
-    /**
53
-     * @deprecated since version 4.6.0.dev.006
54
-     * Now whenever a new_activation is detected the request type is still just
55
-     * new_activation (same for reactivation, upgrade, downgrade etc), but if we'r ein maintenance mode
56
-     * EE_System::initialize_db_if_no_migrations_required and EE_Addon::initialize_db_if_no_migrations_required
57
-     * will instead enqueue that EE plugin's db initialization for when we're taken out of maintenance mode.
58
-     * (Specifically, when the migration manager indicates migrations are finished
59
-     * EE_Data_Migration_Manager::initialize_db_for_enqueued_ee_plugins() will be called)
60
-     */
61
-    const req_type_activation_but_not_installed = 5;
62
-
63
-    /**
64
-     * option prefix for recording the activation history (like core's "espresso_db_update") of addons
65
-     */
66
-    const addon_activation_history_option_prefix = 'ee_addon_activation_history_';
67
-
68
-
69
-    /**
70
-     *    instance of the EE_System object
71
-     *
72
-     * @var    $_instance
73
-     * @access    private
74
-     */
75
-    private static $_instance = null;
76
-
77
-    /**
78
-     * @type  EE_Registry $Registry
79
-     * @access    protected
80
-     */
81
-    protected $registry;
82
-
83
-    /**
84
-     * Stores which type of request this is, options being one of the constants on EE_System starting with req_type_*.
85
-     * It can be a brand-new activation, a reactivation, an upgrade, a downgrade, or a normal request.
86
-     *
87
-     * @var int
88
-     */
89
-    private $_req_type;
90
-
91
-    /**
92
-     * Whether or not there was a non-micro version change in EE core version during this request
93
-     *
94
-     * @var boolean
95
-     */
96
-    private $_major_version_change = false;
97
-
98
-
99
-
100
-    /**
101
-     * @singleton method used to instantiate class object
102
-     * @access    public
103
-     * @param  \EE_Registry $Registry
104
-     * @return \EE_System
105
-     */
106
-    public static function instance(EE_Registry $Registry = null)
107
-    {
108
-        // check if class object is instantiated
109
-        if ( ! self::$_instance instanceof EE_System) {
110
-            self::$_instance = new self($Registry);
111
-        }
112
-        return self::$_instance;
113
-    }
114
-
115
-
116
-
117
-    /**
118
-     * resets the instance and returns it
119
-     *
120
-     * @return EE_System
121
-     */
122
-    public static function reset()
123
-    {
124
-        self::$_instance->_req_type = null;
125
-        //make sure none of the old hooks are left hanging around
126
-        remove_all_actions('AHEE__EE_System__perform_activations_upgrades_and_migrations');
127
-        //we need to reset the migration manager in order for it to detect DMSs properly
128
-        EE_Data_Migration_Manager::reset();
129
-        self::instance()->detect_activations_or_upgrades();
130
-        self::instance()->perform_activations_upgrades_and_migrations();
131
-        return self::instance();
132
-    }
133
-
134
-
135
-
136
-    /**
137
-     *    sets hooks for running rest of system
138
-     *    provides "AHEE__EE_System__construct__complete" hook for EE Addons to use as their starting point
139
-     *    starting EE Addons from any other point may lead to problems
140
-     *
141
-     * @access private
142
-     * @param  \EE_Registry $Registry
143
-     */
144
-    private function __construct(EE_Registry $Registry)
145
-    {
146
-        $this->registry = $Registry;
147
-        do_action('AHEE__EE_System__construct__begin', $this);
148
-        // allow addons to load first so that they can register autoloaders, set hooks for running DMS's, etc
149
-        add_action('AHEE__EE_Bootstrap__load_espresso_addons', array($this, 'load_espresso_addons'));
150
-        // when an ee addon is activated, we want to call the core hook(s) again
151
-        // because the newly-activated addon didn't get a chance to run at all
152
-        add_action('activate_plugin', array($this, 'load_espresso_addons'), 1);
153
-        // detect whether install or upgrade
154
-        add_action('AHEE__EE_Bootstrap__detect_activations_or_upgrades', array($this, 'detect_activations_or_upgrades'),
155
-            3);
156
-        // load EE_Config, EE_Textdomain, etc
157
-        add_action('AHEE__EE_Bootstrap__load_core_configuration', array($this, 'load_core_configuration'), 5);
158
-        // load EE_Config, EE_Textdomain, etc
159
-        add_action('AHEE__EE_Bootstrap__register_shortcodes_modules_and_widgets',
160
-            array($this, 'register_shortcodes_modules_and_widgets'), 7);
161
-        // you wanna get going? I wanna get going... let's get going!
162
-        add_action('AHEE__EE_Bootstrap__brew_espresso', array($this, 'brew_espresso'), 9);
163
-        //other housekeeping
164
-        //exclude EE critical pages from wp_list_pages
165
-        add_filter('wp_list_pages_excludes', array($this, 'remove_pages_from_wp_list_pages'), 10);
166
-        // ALL EE Addons should use the following hook point to attach their initial setup too
167
-        // it's extremely important for EE Addons to register any class autoloaders so that they can be available when the EE_Config loads
168
-        do_action('AHEE__EE_System__construct__complete', $this);
169
-    }
170
-
171
-
172
-
173
-    /**
174
-     * load_espresso_addons
175
-     * allow addons to load first so that they can set hooks for running DMS's, etc
176
-     * this is hooked into both:
177
-     *    'AHEE__EE_Bootstrap__load_core_configuration'
178
-     *        which runs during the WP 'plugins_loaded' action at priority 5
179
-     *    and the WP 'activate_plugin' hookpoint
180
-     *
181
-     * @access public
182
-     * @return void
183
-     */
184
-    public function load_espresso_addons()
185
-    {
186
-        // set autoloaders for all of the classes implementing EEI_Plugin_API
187
-        // which provide helpers for EE plugin authors to more easily register certain components with EE.
188
-        EEH_Autoloader::instance()->register_autoloaders_for_each_file_in_folder(EE_LIBRARIES . 'plugin_api');
189
-        //load and setup EE_Capabilities
190
-        $this->registry->load_core('Capabilities');
191
-        //caps need to be initialized on every request so that capability maps are set.
192
-        //@see https://events.codebasehq.com/projects/event-espresso/tickets/8674
193
-        $this->registry->CAP->init_caps();
194
-        do_action('AHEE__EE_System__load_espresso_addons');
195
-        //if the WP API basic auth plugin isn't already loaded, load it now.
196
-        //We want it for mobile apps. Just include the entire plugin
197
-        //also, don't load the basic auth when a plugin is getting activated, because
198
-        //it could be the basic auth plugin, and it doesn't check if its methods are already defined
199
-        //and causes a fatal error
200
-        if ( ! function_exists('json_basic_auth_handler')
201
-             && ! function_exists('json_basic_auth_error')
202
-             && ! (
203
-                isset($_GET['action'])
204
-                && in_array($_GET['action'], array('activate', 'activate-selected'))
205
-            )
206
-             && ! (
207
-                isset($_GET['activate'])
208
-                && $_GET['activate'] === 'true'
209
-            )
210
-        ) {
211
-            include_once EE_THIRD_PARTY . 'wp-api-basic-auth' . DS . 'basic-auth.php';
212
-        }
213
-        do_action('AHEE__EE_System__load_espresso_addons__complete');
214
-    }
215
-
216
-
217
-
218
-    /**
219
-     * detect_activations_or_upgrades
220
-     * Checks for activation or upgrade of core first;
221
-     * then also checks if any registered addons have been activated or upgraded
222
-     * This is hooked into 'AHEE__EE_Bootstrap__detect_activations_or_upgrades'
223
-     * which runs during the WP 'plugins_loaded' action at priority 3
224
-     *
225
-     * @access public
226
-     * @return void
227
-     */
228
-    public function detect_activations_or_upgrades()
229
-    {
230
-        //first off: let's make sure to handle core
231
-        $this->detect_if_activation_or_upgrade();
232
-        foreach ($this->registry->addons as $addon) {
233
-            //detect teh request type for that addon
234
-            $addon->detect_activation_or_upgrade();
235
-        }
236
-    }
237
-
238
-
239
-
240
-    /**
241
-     * detect_if_activation_or_upgrade
242
-     * Takes care of detecting whether this is a brand new install or code upgrade,
243
-     * and either setting up the DB or setting up maintenance mode etc.
244
-     *
245
-     * @access public
246
-     * @return void
247
-     */
248
-    public function detect_if_activation_or_upgrade()
249
-    {
250
-        do_action('AHEE__EE_System___detect_if_activation_or_upgrade__begin');
251
-        // load M-Mode class
252
-        $this->registry->load_core('Maintenance_Mode');
253
-        // check if db has been updated, or if its a brand-new installation
254
-        $espresso_db_update = $this->fix_espresso_db_upgrade_option();
255
-        $request_type = $this->detect_req_type($espresso_db_update);
256
-        //EEH_Debug_Tools::printr( $request_type, '$request_type', __FILE__, __LINE__ );
257
-        switch ($request_type) {
258
-            case EE_System::req_type_new_activation:
259
-                do_action('AHEE__EE_System__detect_if_activation_or_upgrade__new_activation');
260
-                $this->_handle_core_version_change($espresso_db_update);
261
-                break;
262
-            case EE_System::req_type_reactivation:
263
-                do_action('AHEE__EE_System__detect_if_activation_or_upgrade__reactivation');
264
-                $this->_handle_core_version_change($espresso_db_update);
265
-                break;
266
-            case EE_System::req_type_upgrade:
267
-                do_action('AHEE__EE_System__detect_if_activation_or_upgrade__upgrade');
268
-                //migrations may be required now that we've upgraded
269
-                EE_Maintenance_Mode::instance()->set_maintenance_mode_if_db_old();
270
-                $this->_handle_core_version_change($espresso_db_update);
271
-                //				echo "done upgrade";die;
272
-                break;
273
-            case EE_System::req_type_downgrade:
274
-                do_action('AHEE__EE_System__detect_if_activation_or_upgrade__downgrade');
275
-                //its possible migrations are no longer required
276
-                EE_Maintenance_Mode::instance()->set_maintenance_mode_if_db_old();
277
-                $this->_handle_core_version_change($espresso_db_update);
278
-                break;
279
-            case EE_System::req_type_normal:
280
-            default:
281
-                //				$this->_maybe_redirect_to_ee_about();
282
-                break;
283
-        }
284
-        do_action('AHEE__EE_System__detect_if_activation_or_upgrade__complete');
285
-    }
286
-
287
-
288
-
289
-    /**
290
-     * Updates the list of installed versions and sets hooks for
291
-     * initializing the database later during the request
292
-     *
293
-     * @param array $espresso_db_update
294
-     */
295
-    protected function _handle_core_version_change($espresso_db_update)
296
-    {
297
-        $this->update_list_of_installed_versions($espresso_db_update);
298
-        //get ready to verify the DB is ok (provided we aren't in maintenance mode, of course)
299
-        add_action('AHEE__EE_System__perform_activations_upgrades_and_migrations',
300
-            array($this, 'initialize_db_if_no_migrations_required'));
301
-    }
302
-
303
-
304
-
305
-    /**
306
-     * standardizes the wp option 'espresso_db_upgrade' which actually stores
307
-     * information about what versions of EE have been installed and activated,
308
-     * NOT necessarily the state of the database
309
-     *
310
-     * @param null $espresso_db_update
311
-     * @internal param array $espresso_db_update_value the value of the WordPress option. If not supplied, fetches it
312
-     *           from the options table
313
-     * @return array the correct value of 'espresso_db_upgrade', after saving it, if it needed correction
314
-     */
315
-    private function fix_espresso_db_upgrade_option($espresso_db_update = null)
316
-    {
317
-        do_action('FHEE__EE_System__manage_fix_espresso_db_upgrade_option__begin', $espresso_db_update);
318
-        if ( ! $espresso_db_update) {
319
-            $espresso_db_update = get_option('espresso_db_update');
320
-        }
321
-        // check that option is an array
322
-        if ( ! is_array($espresso_db_update)) {
323
-            // if option is FALSE, then it never existed
324
-            if ($espresso_db_update === false) {
325
-                // make $espresso_db_update an array and save option with autoload OFF
326
-                $espresso_db_update = array();
327
-                add_option('espresso_db_update', $espresso_db_update, '', 'no');
328
-            } else {
329
-                // option is NOT FALSE but also is NOT an array, so make it an array and save it
330
-                $espresso_db_update = array($espresso_db_update => array());
331
-                update_option('espresso_db_update', $espresso_db_update);
332
-            }
333
-        } else {
334
-            $corrected_db_update = array();
335
-            //if IS an array, but is it an array where KEYS are version numbers, and values are arrays?
336
-            foreach ($espresso_db_update as $should_be_version_string => $should_be_array) {
337
-                if (is_int($should_be_version_string) && ! is_array($should_be_array)) {
338
-                    //the key is an int, and the value IS NOT an array
339
-                    //so it must be numerically-indexed, where values are versions installed...
340
-                    //fix it!
341
-                    $version_string = $should_be_array;
342
-                    $corrected_db_update[$version_string] = array('unknown-date');
343
-                } else {
344
-                    //ok it checks out
345
-                    $corrected_db_update[$should_be_version_string] = $should_be_array;
346
-                }
347
-            }
348
-            $espresso_db_update = $corrected_db_update;
349
-            update_option('espresso_db_update', $espresso_db_update);
350
-        }
351
-        do_action('FHEE__EE_System__manage_fix_espresso_db_upgrade_option__complete', $espresso_db_update);
352
-        return $espresso_db_update;
353
-    }
354
-
355
-
356
-
357
-    /**
358
-     * Does the traditional work of setting up the plugin's database and adding default data.
359
-     * If migration script/process did not exist, this is what would happen on every activation/reactivation/upgrade.
360
-     * NOTE: if we're in maintenance mode (which would be the case if we detect there are data
361
-     * migration scripts that need to be run and a version change happens), enqueues core for database initialization,
362
-     * so that it will be done when migrations are finished
363
-     *
364
-     * @param boolean $initialize_addons_too if true, we double-check addons' database tables etc too;
365
-     * @param boolean $verify_schema         if true will re-check the database tables have the correct schema.
366
-     *                                       This is a resource-intensive job
367
-     *                                       so we prefer to only do it when necessary
368
-     * @return void
369
-     */
370
-    public function initialize_db_if_no_migrations_required($initialize_addons_too = false, $verify_schema = true)
371
-    {
372
-        $request_type = $this->detect_req_type();
373
-        //only initialize system if we're not in maintenance mode.
374
-        if (EE_Maintenance_Mode::instance()->level() != EE_Maintenance_Mode::level_2_complete_maintenance) {
375
-            update_option('ee_flush_rewrite_rules', true);
376
-            if ($verify_schema) {
377
-                EEH_Activation::initialize_db_and_folders();
378
-            }
379
-            EEH_Activation::initialize_db_content();
380
-            EEH_Activation::system_initialization();
381
-            if ($initialize_addons_too) {
382
-                $this->initialize_addons();
383
-            }
384
-        } else {
385
-            EE_Data_Migration_Manager::instance()->enqueue_db_initialization_for('Core');
386
-        }
387
-        if ($request_type === EE_System::req_type_new_activation
388
-            || $request_type === EE_System::req_type_reactivation
389
-            || (
390
-                $request_type === EE_System::req_type_upgrade
391
-                && $this->is_major_version_change()
392
-            )
393
-        ) {
394
-            add_action('AHEE__EE_System__initialize_last', array($this, 'redirect_to_about_ee'), 9);
395
-        }
396
-    }
397
-
398
-
399
-
400
-    /**
401
-     * Initializes the db for all registered addons
402
-     */
403
-    public function initialize_addons()
404
-    {
405
-        //foreach registered addon, make sure its db is up-to-date too
406
-        foreach ($this->registry->addons as $addon) {
407
-            $addon->initialize_db_if_no_migrations_required();
408
-        }
409
-    }
410
-
411
-
412
-
413
-    /**
414
-     * Adds the current code version to the saved wp option which stores a list of all ee versions ever installed.
415
-     *
416
-     * @param    array  $version_history
417
-     * @param    string $current_version_to_add version to be added to the version history
418
-     * @return    boolean success as to whether or not this option was changed
419
-     */
420
-    public function update_list_of_installed_versions($version_history = null, $current_version_to_add = null)
421
-    {
422
-        if ( ! $version_history) {
423
-            $version_history = $this->fix_espresso_db_upgrade_option($version_history);
424
-        }
425
-        if ($current_version_to_add == null) {
426
-            $current_version_to_add = espresso_version();
427
-        }
428
-        $version_history[$current_version_to_add][] = date('Y-m-d H:i:s', time());
429
-        // re-save
430
-        return update_option('espresso_db_update', $version_history);
431
-    }
432
-
433
-
434
-
435
-    /**
436
-     * Detects if the current version indicated in the has existed in the list of
437
-     * previously-installed versions of EE (espresso_db_update). Does NOT modify it (ie, no side-effect)
438
-     *
439
-     * @param array $espresso_db_update array from the wp option stored under the name 'espresso_db_update'.
440
-     *                                  If not supplied, fetches it from the options table.
441
-     *                                  Also, caches its result so later parts of the code can also know whether
442
-     *                                  there's been an update or not. This way we can add the current version to
443
-     *                                  espresso_db_update, but still know if this is a new install or not
444
-     * @return int one of the constants on EE_System::req_type_
445
-     */
446
-    public function detect_req_type($espresso_db_update = null)
447
-    {
448
-        if ($this->_req_type === null) {
449
-            $espresso_db_update = ! empty($espresso_db_update) ? $espresso_db_update
450
-                : $this->fix_espresso_db_upgrade_option();
451
-            $this->_req_type = $this->detect_req_type_given_activation_history($espresso_db_update,
452
-                'ee_espresso_activation', espresso_version());
453
-            $this->_major_version_change = $this->_detect_major_version_change($espresso_db_update);
454
-        }
455
-        return $this->_req_type;
456
-    }
457
-
458
-
459
-
460
-    /**
461
-     * Returns whether or not there was a non-micro version change (ie, change in either
462
-     * the first or second number in the version. Eg 4.9.0.rc.001 to 4.10.0.rc.000,
463
-     * but not 4.9.0.rc.0001 to 4.9.1.rc.0001
464
-     *
465
-     * @param $activation_history
466
-     * @return bool
467
-     */
468
-    protected function _detect_major_version_change($activation_history)
469
-    {
470
-        $previous_version = EE_System::_get_most_recently_active_version_from_activation_history($activation_history);
471
-        $previous_version_parts = explode('.', $previous_version);
472
-        $current_version_parts = explode('.', espresso_version());
473
-        return isset($previous_version_parts[0], $previous_version_parts[1], $current_version_parts[0], $current_version_parts[1])
474
-               && ($previous_version_parts[0] !== $current_version_parts[0]
475
-                   || $previous_version_parts[1] !== $current_version_parts[1]
476
-               );
477
-    }
478
-
479
-
480
-
481
-    /**
482
-     * Returns true if either the major or minor version of EE changed during this request.
483
-     * Eg 4.9.0.rc.001 to 4.10.0.rc.000, but not 4.9.0.rc.0001 to 4.9.1.rc.0001
484
-     *
485
-     * @return bool
486
-     */
487
-    public function is_major_version_change()
488
-    {
489
-        return $this->_major_version_change;
490
-    }
491
-
492
-
493
-
494
-    /**
495
-     * Determines the request type for any ee addon, given three piece of info: the current array of activation
496
-     * histories (for core that' 'espresso_db_update' wp option); the name of the wordpress option which is temporarily
497
-     * set upon activation of the plugin (for core it's 'ee_espresso_activation'); and the version that this plugin was
498
-     * just activated to (for core that will always be espresso_version())
499
-     *
500
-     * @param array  $activation_history_for_addon     the option's value which stores the activation history for this
501
-     *                                                 ee plugin. for core that's 'espresso_db_update'
502
-     * @param string $activation_indicator_option_name the name of the wordpress option that is temporarily set to
503
-     *                                                 indicate that this plugin was just activated
504
-     * @param string $version_to_upgrade_to            the version that was just upgraded to (for core that will be
505
-     *                                                 espresso_version())
506
-     * @return int one of the constants on EE_System::req_type_*
507
-     */
508
-    public static function detect_req_type_given_activation_history(
509
-        $activation_history_for_addon,
510
-        $activation_indicator_option_name,
511
-        $version_to_upgrade_to
512
-    ) {
513
-        $version_is_higher = self::_new_version_is_higher($activation_history_for_addon, $version_to_upgrade_to);
514
-        if ($activation_history_for_addon) {
515
-            //it exists, so this isn't a completely new install
516
-            //check if this version already in that list of previously installed versions
517
-            if ( ! isset($activation_history_for_addon[$version_to_upgrade_to])) {
518
-                //it a version we haven't seen before
519
-                if ($version_is_higher === 1) {
520
-                    $req_type = EE_System::req_type_upgrade;
521
-                } else {
522
-                    $req_type = EE_System::req_type_downgrade;
523
-                }
524
-                delete_option($activation_indicator_option_name);
525
-            } else {
526
-                // its not an update. maybe a reactivation?
527
-                if (get_option($activation_indicator_option_name, false)) {
528
-                    if ($version_is_higher === -1) {
529
-                        $req_type = EE_System::req_type_downgrade;
530
-                    } elseif ($version_is_higher === 0) {
531
-                        //we've seen this version before, but it's an activation. must be a reactivation
532
-                        $req_type = EE_System::req_type_reactivation;
533
-                    } else {//$version_is_higher === 1
534
-                        $req_type = EE_System::req_type_upgrade;
535
-                    }
536
-                    delete_option($activation_indicator_option_name);
537
-                } else {
538
-                    //we've seen this version before and the activation indicate doesn't show it was just activated
539
-                    if ($version_is_higher === -1) {
540
-                        $req_type = EE_System::req_type_downgrade;
541
-                    } elseif ($version_is_higher === 0) {
542
-                        //we've seen this version before and it's not an activation. its normal request
543
-                        $req_type = EE_System::req_type_normal;
544
-                    } else {//$version_is_higher === 1
545
-                        $req_type = EE_System::req_type_upgrade;
546
-                    }
547
-                }
548
-            }
549
-        } else {
550
-            //brand new install
551
-            $req_type = EE_System::req_type_new_activation;
552
-            delete_option($activation_indicator_option_name);
553
-        }
554
-        return $req_type;
555
-    }
556
-
557
-
558
-
559
-    /**
560
-     * Detects if the $version_to_upgrade_to is higher than the most recent version in
561
-     * the $activation_history_for_addon
562
-     *
563
-     * @param array  $activation_history_for_addon (keys are versions, values are arrays of times activated,
564
-     *                                             sometimes containing 'unknown-date'
565
-     * @param string $version_to_upgrade_to        (current version)
566
-     * @return int results of version_compare( $version_to_upgrade_to, $most_recently_active_version ).
567
-     *                                             ie, -1 if $version_to_upgrade_to is LOWER (downgrade);
568
-     *                                             0 if $version_to_upgrade_to MATCHES (reactivation or normal request);
569
-     *                                             1 if $version_to_upgrade_to is HIGHER (upgrade) ;
570
-     */
571
-    protected static function _new_version_is_higher($activation_history_for_addon, $version_to_upgrade_to)
572
-    {
573
-        //find the most recently-activated version
574
-        $most_recently_active_version = EE_System::_get_most_recently_active_version_from_activation_history($activation_history_for_addon);
575
-        return version_compare($version_to_upgrade_to, $most_recently_active_version);
576
-    }
577
-
578
-
579
-
580
-    /**
581
-     * Gets the most recently active version listed in the activation history,
582
-     * and if none are found (ie, it's a brand new install) returns '0.0.0.dev.000'.
583
-     *
584
-     * @param array $activation_history  (keys are versions, values are arrays of times activated,
585
-     *                                   sometimes containing 'unknown-date'
586
-     * @return string
587
-     */
588
-    protected static function _get_most_recently_active_version_from_activation_history($activation_history)
589
-    {
590
-        $most_recently_active_version_activation = '1970-01-01 00:00:00';
591
-        $most_recently_active_version = '0.0.0.dev.000';
592
-        if (is_array($activation_history)) {
593
-            foreach ($activation_history as $version => $times_activated) {
594
-                //check there is a record of when this version was activated. Otherwise,
595
-                //mark it as unknown
596
-                if ( ! $times_activated) {
597
-                    $times_activated = array('unknown-date');
598
-                }
599
-                if (is_string($times_activated)) {
600
-                    $times_activated = array($times_activated);
601
-                }
602
-                foreach ($times_activated as $an_activation) {
603
-                    if ($an_activation != 'unknown-date' && $an_activation > $most_recently_active_version_activation) {
604
-                        $most_recently_active_version = $version;
605
-                        $most_recently_active_version_activation = $an_activation == 'unknown-date'
606
-                            ? '1970-01-01 00:00:00' : $an_activation;
607
-                    }
608
-                }
609
-            }
610
-        }
611
-        return $most_recently_active_version;
612
-    }
613
-
614
-
615
-
616
-    /**
617
-     * This redirects to the about EE page after activation
618
-     *
619
-     * @return void
620
-     */
621
-    public function redirect_to_about_ee()
622
-    {
623
-        $notices = EE_Error::get_notices(false);
624
-        //if current user is an admin and it's not an ajax or rest request
625
-        if (
626
-            ! (defined('DOING_AJAX') && DOING_AJAX)
627
-            && ! (defined('REST_REQUEST') && REST_REQUEST)
628
-            && ! isset($notices['errors'])
629
-            && apply_filters(
630
-                'FHEE__EE_System__redirect_to_about_ee__do_redirect',
631
-                $this->registry->CAP->current_user_can('manage_options', 'espresso_about_default')
632
-            )
633
-        ) {
634
-            $query_params = array('page' => 'espresso_about');
635
-            if (EE_System::instance()->detect_req_type() == EE_System::req_type_new_activation) {
636
-                $query_params['new_activation'] = true;
637
-            }
638
-            if (EE_System::instance()->detect_req_type() == EE_System::req_type_reactivation) {
639
-                $query_params['reactivation'] = true;
640
-            }
641
-            $url = add_query_arg($query_params, admin_url('admin.php'));
642
-            wp_safe_redirect($url);
643
-            exit();
644
-        }
645
-    }
646
-
647
-
648
-
649
-    /**
650
-     * load_core_configuration
651
-     * this is hooked into 'AHEE__EE_Bootstrap__load_core_configuration'
652
-     * which runs during the WP 'plugins_loaded' action at priority 5
653
-     *
654
-     * @return void
655
-     */
656
-    public function load_core_configuration()
657
-    {
658
-        do_action('AHEE__EE_System__load_core_configuration__begin', $this);
659
-        $this->registry->load_core('EE_Load_Textdomain');
660
-        //load textdomain
661
-        EE_Load_Textdomain::load_textdomain();
662
-        // load and setup EE_Config and EE_Network_Config
663
-        $this->registry->load_core('Config');
664
-        $this->registry->load_core('Network_Config');
665
-        // setup autoloaders
666
-        // enable logging?
667
-        if ($this->registry->CFG->admin->use_full_logging) {
668
-            $this->registry->load_core('Log');
669
-        }
670
-        // check for activation errors
671
-        $activation_errors = get_option('ee_plugin_activation_errors', false);
672
-        if ($activation_errors) {
673
-            EE_Error::add_error($activation_errors, __FILE__, __FUNCTION__, __LINE__);
674
-            update_option('ee_plugin_activation_errors', false);
675
-        }
676
-        // get model names
677
-        $this->_parse_model_names();
678
-        //load caf stuff a chance to play during the activation process too.
679
-        $this->_maybe_brew_regular();
680
-        do_action('AHEE__EE_System__load_core_configuration__complete', $this);
681
-    }
682
-
683
-
684
-
685
-    /**
686
-     * cycles through all of the models/*.model.php files, and assembles an array of model names
687
-     *
688
-     * @return void
689
-     */
690
-    private function _parse_model_names()
691
-    {
692
-        //get all the files in the EE_MODELS folder that end in .model.php
693
-        $models = glob(EE_MODELS . '*.model.php');
694
-        $model_names = array();
695
-        $non_abstract_db_models = array();
696
-        foreach ($models as $model) {
697
-            // get model classname
698
-            $classname = EEH_File::get_classname_from_filepath_with_standard_filename($model);
699
-            $short_name = str_replace('EEM_', '', $classname);
700
-            $reflectionClass = new ReflectionClass($classname);
701
-            if ($reflectionClass->isSubclassOf('EEM_Base') && ! $reflectionClass->isAbstract()) {
702
-                $non_abstract_db_models[$short_name] = $classname;
703
-            }
704
-            $model_names[$short_name] = $classname;
705
-        }
706
-        $this->registry->models = apply_filters('FHEE__EE_System__parse_model_names', $model_names);
707
-        $this->registry->non_abstract_db_models = apply_filters('FHEE__EE_System__parse_implemented_model_names',
708
-            $non_abstract_db_models);
709
-    }
710
-
711
-
712
-
713
-    /**
714
-     * The purpose of this method is to simply check for a file named "caffeinated/brewing_regular.php" for any hooks
715
-     * that need to be setup before our EE_System launches.
716
-     *
717
-     * @return void
718
-     */
719
-    private function _maybe_brew_regular()
720
-    {
721
-        if (( ! defined('EE_DECAF') || EE_DECAF !== true) && is_readable(EE_CAFF_PATH . 'brewing_regular.php')) {
722
-            require_once EE_CAFF_PATH . 'brewing_regular.php';
723
-        }
724
-    }
725
-
726
-
727
-
728
-    /**
729
-     * register_shortcodes_modules_and_widgets
730
-     * generate lists of shortcodes and modules, then verify paths and classes
731
-     * This is hooked into 'AHEE__EE_Bootstrap__register_shortcodes_modules_and_widgets'
732
-     * which runs during the WP 'plugins_loaded' action at priority 7
733
-     *
734
-     * @access public
735
-     * @return void
736
-     */
737
-    public function register_shortcodes_modules_and_widgets()
738
-    {
739
-        // load, register, and add shortcodes the new way
740
-        new ShortcodesManager(
741
-            // and the old way, but we'll put it under control of the new system
742
-            EE_Config::getLegacyShortcodesManager()
743
-        );
744
-        do_action('AHEE__EE_System__register_shortcodes_modules_and_widgets');
745
-        // check for addons using old hookpoint
746
-        if (has_action('AHEE__EE_System__register_shortcodes_modules_and_addons')) {
747
-            $this->_incompatible_addon_error();
748
-        }
749
-    }
750
-
751
-
752
-
753
-    /**
754
-     * _incompatible_addon_error
755
-     *
756
-     * @access public
757
-     * @return void
758
-     */
759
-    private function _incompatible_addon_error()
760
-    {
761
-        // get array of classes hooking into here
762
-        $class_names = EEH_Class_Tools::get_class_names_for_all_callbacks_on_hook('AHEE__EE_System__register_shortcodes_modules_and_addons');
763
-        if ( ! empty($class_names)) {
764
-            $msg = __('The following plugins, addons, or modules appear to be incompatible with this version of Event Espresso and were automatically deactivated to avoid fatal errors:',
765
-                'event_espresso');
766
-            $msg .= '<ul>';
767
-            foreach ($class_names as $class_name) {
768
-                $msg .= '<li><b>Event Espresso - ' . str_replace(array('EE_', 'EEM_', 'EED_', 'EES_', 'EEW_'), '',
769
-                        $class_name) . '</b></li>';
770
-            }
771
-            $msg .= '</ul>';
772
-            $msg .= __('Compatibility issues can be avoided and/or resolved by keeping addons and plugins updated to the latest version.',
773
-                'event_espresso');
774
-            // save list of incompatible addons to wp-options for later use
775
-            add_option('ee_incompatible_addons', $class_names, '', 'no');
776
-            if (is_admin()) {
777
-                EE_Error::add_error($msg, __FILE__, __FUNCTION__, __LINE__);
778
-            }
779
-        }
780
-    }
781
-
782
-
783
-
784
-    /**
785
-     * brew_espresso
786
-     * begins the process of setting hooks for initializing EE in the correct order
787
-     * This is happening on the 'AHEE__EE_Bootstrap__brew_espresso' hookpoint
788
-     * which runs during the WP 'plugins_loaded' action at priority 9
789
-     *
790
-     * @return void
791
-     */
792
-    public function brew_espresso()
793
-    {
794
-        do_action('AHEE__EE_System__brew_espresso__begin', $this);
795
-        // load some final core systems
796
-        add_action('init', array($this, 'set_hooks_for_core'), 1);
797
-        add_action('init', array($this, 'perform_activations_upgrades_and_migrations'), 3);
798
-        add_action('init', array($this, 'load_CPTs_and_session'), 5);
799
-        add_action('init', array($this, 'load_controllers'), 7);
800
-        add_action('init', array($this, 'core_loaded_and_ready'), 9);
801
-        add_action('init', array($this, 'initialize'), 10);
802
-        add_action('init', array($this, 'initialize_last'), 100);
803
-        add_action('wp_enqueue_scripts', array($this, 'wp_enqueue_scripts'), 100);
804
-        add_action('admin_enqueue_scripts', array($this, 'wp_enqueue_scripts'), 100);
805
-        add_action('admin_bar_menu', array($this, 'espresso_toolbar_items'), 100);
806
-        if (is_admin() && apply_filters('FHEE__EE_System__brew_espresso__load_pue', true)) {
807
-            // pew pew pew
808
-            $this->registry->load_core('PUE');
809
-            do_action('AHEE__EE_System__brew_espresso__after_pue_init');
810
-        }
811
-        do_action('AHEE__EE_System__brew_espresso__complete', $this);
812
-    }
813
-
814
-
815
-
816
-    /**
817
-     *    set_hooks_for_core
818
-     *
819
-     * @access public
820
-     * @return    void
821
-     */
822
-    public function set_hooks_for_core()
823
-    {
824
-        $this->_deactivate_incompatible_addons();
825
-        do_action('AHEE__EE_System__set_hooks_for_core');
826
-    }
827
-
828
-
829
-
830
-    /**
831
-     * Using the information gathered in EE_System::_incompatible_addon_error,
832
-     * deactivates any addons considered incompatible with the current version of EE
833
-     */
834
-    private function _deactivate_incompatible_addons()
835
-    {
836
-        $incompatible_addons = get_option('ee_incompatible_addons', array());
837
-        if ( ! empty($incompatible_addons)) {
838
-            $active_plugins = get_option('active_plugins', array());
839
-            foreach ($active_plugins as $active_plugin) {
840
-                foreach ($incompatible_addons as $incompatible_addon) {
841
-                    if (strpos($active_plugin, $incompatible_addon) !== false) {
842
-                        unset($_GET['activate']);
843
-                        espresso_deactivate_plugin($active_plugin);
844
-                    }
845
-                }
846
-            }
847
-        }
848
-    }
849
-
850
-
851
-
852
-    /**
853
-     *    perform_activations_upgrades_and_migrations
854
-     *
855
-     * @access public
856
-     * @return    void
857
-     */
858
-    public function perform_activations_upgrades_and_migrations()
859
-    {
860
-        //first check if we had previously attempted to setup EE's directories but failed
861
-        if (EEH_Activation::upload_directories_incomplete()) {
862
-            EEH_Activation::create_upload_directories();
863
-        }
864
-        do_action('AHEE__EE_System__perform_activations_upgrades_and_migrations');
865
-    }
866
-
867
-
868
-
869
-    /**
870
-     *    load_CPTs_and_session
871
-     *
872
-     * @access public
873
-     * @return    void
874
-     */
875
-    public function load_CPTs_and_session()
876
-    {
877
-        do_action('AHEE__EE_System__load_CPTs_and_session__start');
878
-        // register Custom Post Types
879
-        $this->registry->load_core('Register_CPTs');
880
-        do_action('AHEE__EE_System__load_CPTs_and_session__complete');
881
-    }
882
-
883
-
884
-
885
-    /**
886
-     * load_controllers
887
-     * this is the best place to load any additional controllers that needs access to EE core.
888
-     * it is expected that all basic core EE systems, that are not dependant on the current request are loaded at this
889
-     * time
890
-     *
891
-     * @access public
892
-     * @return void
893
-     */
894
-    public function load_controllers()
895
-    {
896
-        do_action('AHEE__EE_System__load_controllers__start');
897
-        // let's get it started
898
-        if ( ! is_admin() && ! EE_Maintenance_Mode::instance()->level()) {
899
-            do_action('AHEE__EE_System__load_controllers__load_front_controllers');
900
-            $this->registry->load_core('Front_Controller', array(), false);
901
-        } else if ( ! EE_FRONT_AJAX) {
902
-            do_action('AHEE__EE_System__load_controllers__load_admin_controllers');
903
-            EE_Registry::instance()->load_core('Admin');
904
-        }
905
-        do_action('AHEE__EE_System__load_controllers__complete');
906
-    }
907
-
908
-
909
-
910
-    /**
911
-     * core_loaded_and_ready
912
-     * all of the basic EE core should be loaded at this point and available regardless of M-Mode
913
-     *
914
-     * @access public
915
-     * @return void
916
-     */
917
-    public function core_loaded_and_ready()
918
-    {
919
-        do_action('AHEE__EE_System__core_loaded_and_ready');
920
-        // load_espresso_template_tags
921
-        if (is_readable(EE_PUBLIC . 'template_tags.php')) {
922
-            require_once(EE_PUBLIC . 'template_tags.php');
923
-        }
924
-        do_action('AHEE__EE_System__set_hooks_for_shortcodes_modules_and_addons');
925
-        $this->registry->load_core('Session');
926
-    }
927
-
928
-
929
-
930
-    /**
931
-     * initialize
932
-     * this is the best place to begin initializing client code
933
-     *
934
-     * @access public
935
-     * @return void
936
-     */
937
-    public function initialize()
938
-    {
939
-        do_action('AHEE__EE_System__initialize');
940
-    }
941
-
942
-
943
-
944
-    /**
945
-     * initialize_last
946
-     * this is run really late during the WP init hookpoint, and ensures that mostly everything else that needs to
947
-     * initialize has done so
948
-     *
949
-     * @access public
950
-     * @return void
951
-     */
952
-    public function initialize_last()
953
-    {
954
-        do_action('AHEE__EE_System__initialize_last');
955
-    }
956
-
957
-
958
-
959
-    /**
960
-     * set_hooks_for_shortcodes_modules_and_addons
961
-     * this is the best place for other systems to set callbacks for hooking into other parts of EE
962
-     * this happens at the very beginning of the wp_loaded hookpoint
963
-     *
964
-     * @access public
965
-     * @return void
966
-     */
967
-    public function set_hooks_for_shortcodes_modules_and_addons()
968
-    {
969
-        //		do_action( 'AHEE__EE_System__set_hooks_for_shortcodes_modules_and_addons' );
970
-    }
971
-
972
-
973
-
974
-    /**
975
-     * do_not_cache
976
-     * sets no cache headers and defines no cache constants for WP plugins
977
-     *
978
-     * @access public
979
-     * @return void
980
-     */
981
-    public static function do_not_cache()
982
-    {
983
-        // set no cache constants
984
-        if ( ! defined('DONOTCACHEPAGE')) {
985
-            define('DONOTCACHEPAGE', true);
986
-        }
987
-        if ( ! defined('DONOTCACHCEOBJECT')) {
988
-            define('DONOTCACHCEOBJECT', true);
989
-        }
990
-        if ( ! defined('DONOTCACHEDB')) {
991
-            define('DONOTCACHEDB', true);
992
-        }
993
-        // add no cache headers
994
-        add_action('send_headers', array('EE_System', 'nocache_headers'), 10);
995
-        // plus a little extra for nginx and Google Chrome
996
-        add_filter('nocache_headers', array('EE_System', 'extra_nocache_headers'), 10, 1);
997
-        // prevent browsers from prefetching of the rel='next' link, because it may contain content that interferes with the registration process
998
-        remove_action('wp_head', 'adjacent_posts_rel_link_wp_head');
999
-    }
1000
-
1001
-
1002
-
1003
-    /**
1004
-     *    extra_nocache_headers
1005
-     *
1006
-     * @access    public
1007
-     * @param $headers
1008
-     * @return    array
1009
-     */
1010
-    public static function extra_nocache_headers($headers)
1011
-    {
1012
-        // for NGINX
1013
-        $headers['X-Accel-Expires'] = 0;
1014
-        // plus extra for Google Chrome since it doesn't seem to respect "no-cache", but WILL respect "no-store"
1015
-        $headers['Cache-Control'] = 'no-store, no-cache, must-revalidate, max-age=0';
1016
-        return $headers;
1017
-    }
1018
-
1019
-
1020
-
1021
-    /**
1022
-     *    nocache_headers
1023
-     *
1024
-     * @access    public
1025
-     * @return    void
1026
-     */
1027
-    public static function nocache_headers()
1028
-    {
1029
-        nocache_headers();
1030
-    }
1031
-
1032
-
1033
-
1034
-    /**
1035
-     *    espresso_toolbar_items
1036
-     *
1037
-     * @access public
1038
-     * @param  WP_Admin_Bar $admin_bar
1039
-     * @return void
1040
-     */
1041
-    public function espresso_toolbar_items(WP_Admin_Bar $admin_bar)
1042
-    {
1043
-        // if in full M-Mode, or its an AJAX request, or user is NOT an admin
1044
-        if (EE_Maintenance_Mode::instance()->level() == EE_Maintenance_Mode::level_2_complete_maintenance
1045
-            || defined('DOING_AJAX')
1046
-            || ! $this->registry->CAP->current_user_can('ee_read_ee', 'ee_admin_bar_menu_top_level')
1047
-        ) {
1048
-            return;
1049
-        }
1050
-        do_action('AHEE_log', __FILE__, __FUNCTION__, '');
1051
-        $menu_class = 'espresso_menu_item_class';
1052
-        //we don't use the constants EVENTS_ADMIN_URL or REG_ADMIN_URL
1053
-        //because they're only defined in each of their respective constructors
1054
-        //and this might be a frontend request, in which case they aren't available
1055
-        $events_admin_url = admin_url("admin.php?page=espresso_events");
1056
-        $reg_admin_url = admin_url("admin.php?page=espresso_registrations");
1057
-        $extensions_admin_url = admin_url("admin.php?page=espresso_packages");
1058
-        //Top Level
1059
-        $admin_bar->add_menu(array(
1060
-            'id'    => 'espresso-toolbar',
1061
-            'title' => '<span class="ee-icon ee-icon-ee-cup-thick ee-icon-size-20"></span><span class="ab-label">'
1062
-                       . _x('Event Espresso', 'admin bar menu group label', 'event_espresso')
1063
-                       . '</span>',
1064
-            'href'  => $events_admin_url,
1065
-            'meta'  => array(
1066
-                'title' => __('Event Espresso', 'event_espresso'),
1067
-                'class' => $menu_class . 'first',
1068
-            ),
1069
-        ));
1070
-        //Events
1071
-        if ($this->registry->CAP->current_user_can('ee_read_events', 'ee_admin_bar_menu_espresso-toolbar-events')) {
1072
-            $admin_bar->add_menu(array(
1073
-                'id'     => 'espresso-toolbar-events',
1074
-                'parent' => 'espresso-toolbar',
1075
-                'title'  => __('Events', 'event_espresso'),
1076
-                'href'   => $events_admin_url,
1077
-                'meta'   => array(
1078
-                    'title'  => __('Events', 'event_espresso'),
1079
-                    'target' => '',
1080
-                    'class'  => $menu_class,
1081
-                ),
1082
-            ));
1083
-        }
1084
-        if ($this->registry->CAP->current_user_can('ee_edit_events', 'ee_admin_bar_menu_espresso-toolbar-events-new')) {
1085
-            //Events Add New
1086
-            $admin_bar->add_menu(array(
1087
-                'id'     => 'espresso-toolbar-events-new',
1088
-                'parent' => 'espresso-toolbar-events',
1089
-                'title'  => __('Add New', 'event_espresso'),
1090
-                'href'   => EEH_URL::add_query_args_and_nonce(array('action' => 'create_new'), $events_admin_url),
1091
-                'meta'   => array(
1092
-                    'title'  => __('Add New', 'event_espresso'),
1093
-                    'target' => '',
1094
-                    'class'  => $menu_class,
1095
-                ),
1096
-            ));
1097
-        }
1098
-        if (is_single() && (get_post_type() == 'espresso_events')) {
1099
-            //Current post
1100
-            global $post;
1101
-            if ($this->registry->CAP->current_user_can('ee_edit_event',
1102
-                'ee_admin_bar_menu_espresso-toolbar-events-edit', $post->ID)
1103
-            ) {
1104
-                //Events Edit Current Event
1105
-                $admin_bar->add_menu(array(
1106
-                    'id'     => 'espresso-toolbar-events-edit',
1107
-                    'parent' => 'espresso-toolbar-events',
1108
-                    'title'  => __('Edit Event', 'event_espresso'),
1109
-                    'href'   => EEH_URL::add_query_args_and_nonce(array('action' => 'edit', 'post' => $post->ID),
1110
-                        $events_admin_url),
1111
-                    'meta'   => array(
1112
-                        'title'  => __('Edit Event', 'event_espresso'),
1113
-                        'target' => '',
1114
-                        'class'  => $menu_class,
1115
-                    ),
1116
-                ));
1117
-            }
1118
-        }
1119
-        //Events View
1120
-        if ($this->registry->CAP->current_user_can('ee_read_events',
1121
-            'ee_admin_bar_menu_espresso-toolbar-events-view')
1122
-        ) {
1123
-            $admin_bar->add_menu(array(
1124
-                'id'     => 'espresso-toolbar-events-view',
1125
-                'parent' => 'espresso-toolbar-events',
1126
-                'title'  => __('View', 'event_espresso'),
1127
-                'href'   => $events_admin_url,
1128
-                'meta'   => array(
1129
-                    'title'  => __('View', 'event_espresso'),
1130
-                    'target' => '',
1131
-                    'class'  => $menu_class,
1132
-                ),
1133
-            ));
1134
-        }
1135
-        if ($this->registry->CAP->current_user_can('ee_read_events', 'ee_admin_bar_menu_espresso-toolbar-events-all')) {
1136
-            //Events View All
1137
-            $admin_bar->add_menu(array(
1138
-                'id'     => 'espresso-toolbar-events-all',
1139
-                'parent' => 'espresso-toolbar-events-view',
1140
-                'title'  => __('All', 'event_espresso'),
1141
-                'href'   => $events_admin_url,
1142
-                'meta'   => array(
1143
-                    'title'  => __('All', 'event_espresso'),
1144
-                    'target' => '',
1145
-                    'class'  => $menu_class,
1146
-                ),
1147
-            ));
1148
-        }
1149
-        if ($this->registry->CAP->current_user_can('ee_read_events',
1150
-            'ee_admin_bar_menu_espresso-toolbar-events-today')
1151
-        ) {
1152
-            //Events View Today
1153
-            $admin_bar->add_menu(array(
1154
-                'id'     => 'espresso-toolbar-events-today',
1155
-                'parent' => 'espresso-toolbar-events-view',
1156
-                'title'  => __('Today', 'event_espresso'),
1157
-                'href'   => EEH_URL::add_query_args_and_nonce(array('action' => 'default', 'status' => 'today'),
1158
-                    $events_admin_url),
1159
-                'meta'   => array(
1160
-                    'title'  => __('Today', 'event_espresso'),
1161
-                    'target' => '',
1162
-                    'class'  => $menu_class,
1163
-                ),
1164
-            ));
1165
-        }
1166
-        if ($this->registry->CAP->current_user_can('ee_read_events',
1167
-            'ee_admin_bar_menu_espresso-toolbar-events-month')
1168
-        ) {
1169
-            //Events View This Month
1170
-            $admin_bar->add_menu(array(
1171
-                'id'     => 'espresso-toolbar-events-month',
1172
-                'parent' => 'espresso-toolbar-events-view',
1173
-                'title'  => __('This Month', 'event_espresso'),
1174
-                'href'   => EEH_URL::add_query_args_and_nonce(array('action' => 'default', 'status' => 'month'),
1175
-                    $events_admin_url),
1176
-                'meta'   => array(
1177
-                    'title'  => __('This Month', 'event_espresso'),
1178
-                    'target' => '',
1179
-                    'class'  => $menu_class,
1180
-                ),
1181
-            ));
1182
-        }
1183
-        //Registration Overview
1184
-        if ($this->registry->CAP->current_user_can('ee_read_registrations',
1185
-            'ee_admin_bar_menu_espresso-toolbar-registrations')
1186
-        ) {
1187
-            $admin_bar->add_menu(array(
1188
-                'id'     => 'espresso-toolbar-registrations',
1189
-                'parent' => 'espresso-toolbar',
1190
-                'title'  => __('Registrations', 'event_espresso'),
1191
-                'href'   => $reg_admin_url,
1192
-                'meta'   => array(
1193
-                    'title'  => __('Registrations', 'event_espresso'),
1194
-                    'target' => '',
1195
-                    'class'  => $menu_class,
1196
-                ),
1197
-            ));
1198
-        }
1199
-        //Registration Overview Today
1200
-        if ($this->registry->CAP->current_user_can('ee_read_registrations',
1201
-            'ee_admin_bar_menu_espresso-toolbar-registrations-today')
1202
-        ) {
1203
-            $admin_bar->add_menu(array(
1204
-                'id'     => 'espresso-toolbar-registrations-today',
1205
-                'parent' => 'espresso-toolbar-registrations',
1206
-                'title'  => __('Today', 'event_espresso'),
1207
-                'href'   => EEH_URL::add_query_args_and_nonce(array('action' => 'default', 'status' => 'today'),
1208
-                    $reg_admin_url),
1209
-                'meta'   => array(
1210
-                    'title'  => __('Today', 'event_espresso'),
1211
-                    'target' => '',
1212
-                    'class'  => $menu_class,
1213
-                ),
1214
-            ));
1215
-        }
1216
-        //Registration Overview Today Completed
1217
-        if ($this->registry->CAP->current_user_can('ee_read_registrations',
1218
-            'ee_admin_bar_menu_espresso-toolbar-registrations-today-approved')
1219
-        ) {
1220
-            $admin_bar->add_menu(array(
1221
-                'id'     => 'espresso-toolbar-registrations-today-approved',
1222
-                'parent' => 'espresso-toolbar-registrations-today',
1223
-                'title'  => __('Approved', 'event_espresso'),
1224
-                'href'   => EEH_URL::add_query_args_and_nonce(array(
1225
-                    'action'      => 'default',
1226
-                    'status'      => 'today',
1227
-                    '_reg_status' => EEM_Registration::status_id_approved,
1228
-                ), $reg_admin_url),
1229
-                'meta'   => array(
1230
-                    'title'  => __('Approved', 'event_espresso'),
1231
-                    'target' => '',
1232
-                    'class'  => $menu_class,
1233
-                ),
1234
-            ));
1235
-        }
1236
-        //Registration Overview Today Pending\
1237
-        if ($this->registry->CAP->current_user_can('ee_read_registrations',
1238
-            'ee_admin_bar_menu_espresso-toolbar-registrations-today-pending')
1239
-        ) {
1240
-            $admin_bar->add_menu(array(
1241
-                'id'     => 'espresso-toolbar-registrations-today-pending',
1242
-                'parent' => 'espresso-toolbar-registrations-today',
1243
-                'title'  => __('Pending', 'event_espresso'),
1244
-                'href'   => EEH_URL::add_query_args_and_nonce(array(
1245
-                    'action'     => 'default',
1246
-                    'status'     => 'today',
1247
-                    'reg_status' => EEM_Registration::status_id_pending_payment,
1248
-                ), $reg_admin_url),
1249
-                'meta'   => array(
1250
-                    'title'  => __('Pending Payment', 'event_espresso'),
1251
-                    'target' => '',
1252
-                    'class'  => $menu_class,
1253
-                ),
1254
-            ));
1255
-        }
1256
-        //Registration Overview Today Incomplete
1257
-        if ($this->registry->CAP->current_user_can('ee_read_registrations',
1258
-            'ee_admin_bar_menu_espresso-toolbar-registrations-today-not-approved')
1259
-        ) {
1260
-            $admin_bar->add_menu(array(
1261
-                'id'     => 'espresso-toolbar-registrations-today-not-approved',
1262
-                'parent' => 'espresso-toolbar-registrations-today',
1263
-                'title'  => __('Not Approved', 'event_espresso'),
1264
-                'href'   => EEH_URL::add_query_args_and_nonce(array(
1265
-                    'action'      => 'default',
1266
-                    'status'      => 'today',
1267
-                    '_reg_status' => EEM_Registration::status_id_not_approved,
1268
-                ), $reg_admin_url),
1269
-                'meta'   => array(
1270
-                    'title'  => __('Not Approved', 'event_espresso'),
1271
-                    'target' => '',
1272
-                    'class'  => $menu_class,
1273
-                ),
1274
-            ));
1275
-        }
1276
-        //Registration Overview Today Incomplete
1277
-        if ($this->registry->CAP->current_user_can('ee_read_registrations',
1278
-            'ee_admin_bar_menu_espresso-toolbar-registrations-today-cancelled')
1279
-        ) {
1280
-            $admin_bar->add_menu(array(
1281
-                'id'     => 'espresso-toolbar-registrations-today-cancelled',
1282
-                'parent' => 'espresso-toolbar-registrations-today',
1283
-                'title'  => __('Cancelled', 'event_espresso'),
1284
-                'href'   => EEH_URL::add_query_args_and_nonce(array(
1285
-                    'action'      => 'default',
1286
-                    'status'      => 'today',
1287
-                    '_reg_status' => EEM_Registration::status_id_cancelled,
1288
-                ), $reg_admin_url),
1289
-                'meta'   => array(
1290
-                    'title'  => __('Cancelled', 'event_espresso'),
1291
-                    'target' => '',
1292
-                    'class'  => $menu_class,
1293
-                ),
1294
-            ));
1295
-        }
1296
-        //Registration Overview This Month
1297
-        if ($this->registry->CAP->current_user_can('ee_read_registrations',
1298
-            'ee_admin_bar_menu_espresso-toolbar-registrations-month')
1299
-        ) {
1300
-            $admin_bar->add_menu(array(
1301
-                'id'     => 'espresso-toolbar-registrations-month',
1302
-                'parent' => 'espresso-toolbar-registrations',
1303
-                'title'  => __('This Month', 'event_espresso'),
1304
-                'href'   => EEH_URL::add_query_args_and_nonce(array('action' => 'default', 'status' => 'month'),
1305
-                    $reg_admin_url),
1306
-                'meta'   => array(
1307
-                    'title'  => __('This Month', 'event_espresso'),
1308
-                    'target' => '',
1309
-                    'class'  => $menu_class,
1310
-                ),
1311
-            ));
1312
-        }
1313
-        //Registration Overview This Month Approved
1314
-        if ($this->registry->CAP->current_user_can('ee_read_registrations',
1315
-            'ee_admin_bar_menu_espresso-toolbar-registrations-month-approved')
1316
-        ) {
1317
-            $admin_bar->add_menu(array(
1318
-                'id'     => 'espresso-toolbar-registrations-month-approved',
1319
-                'parent' => 'espresso-toolbar-registrations-month',
1320
-                'title'  => __('Approved', 'event_espresso'),
1321
-                'href'   => EEH_URL::add_query_args_and_nonce(array(
1322
-                    'action'      => 'default',
1323
-                    'status'      => 'month',
1324
-                    '_reg_status' => EEM_Registration::status_id_approved,
1325
-                ), $reg_admin_url),
1326
-                'meta'   => array(
1327
-                    'title'  => __('Approved', 'event_espresso'),
1328
-                    'target' => '',
1329
-                    'class'  => $menu_class,
1330
-                ),
1331
-            ));
1332
-        }
1333
-        //Registration Overview This Month Pending
1334
-        if ($this->registry->CAP->current_user_can('ee_read_registrations',
1335
-            'ee_admin_bar_menu_espresso-toolbar-registrations-month-pending')
1336
-        ) {
1337
-            $admin_bar->add_menu(array(
1338
-                'id'     => 'espresso-toolbar-registrations-month-pending',
1339
-                'parent' => 'espresso-toolbar-registrations-month',
1340
-                'title'  => __('Pending', 'event_espresso'),
1341
-                'href'   => EEH_URL::add_query_args_and_nonce(array(
1342
-                    'action'      => 'default',
1343
-                    'status'      => 'month',
1344
-                    '_reg_status' => EEM_Registration::status_id_pending_payment,
1345
-                ), $reg_admin_url),
1346
-                'meta'   => array(
1347
-                    'title'  => __('Pending', 'event_espresso'),
1348
-                    'target' => '',
1349
-                    'class'  => $menu_class,
1350
-                ),
1351
-            ));
1352
-        }
1353
-        //Registration Overview This Month Not Approved
1354
-        if ($this->registry->CAP->current_user_can('ee_read_registrations',
1355
-            'ee_admin_bar_menu_espresso-toolbar-registrations-month-not-approved')
1356
-        ) {
1357
-            $admin_bar->add_menu(array(
1358
-                'id'     => 'espresso-toolbar-registrations-month-not-approved',
1359
-                'parent' => 'espresso-toolbar-registrations-month',
1360
-                'title'  => __('Not Approved', 'event_espresso'),
1361
-                'href'   => EEH_URL::add_query_args_and_nonce(array(
1362
-                    'action'      => 'default',
1363
-                    'status'      => 'month',
1364
-                    '_reg_status' => EEM_Registration::status_id_not_approved,
1365
-                ), $reg_admin_url),
1366
-                'meta'   => array(
1367
-                    'title'  => __('Not Approved', 'event_espresso'),
1368
-                    'target' => '',
1369
-                    'class'  => $menu_class,
1370
-                ),
1371
-            ));
1372
-        }
1373
-        //Registration Overview This Month Cancelled
1374
-        if ($this->registry->CAP->current_user_can('ee_read_registrations',
1375
-            'ee_admin_bar_menu_espresso-toolbar-registrations-month-cancelled')
1376
-        ) {
1377
-            $admin_bar->add_menu(array(
1378
-                'id'     => 'espresso-toolbar-registrations-month-cancelled',
1379
-                'parent' => 'espresso-toolbar-registrations-month',
1380
-                'title'  => __('Cancelled', 'event_espresso'),
1381
-                'href'   => EEH_URL::add_query_args_and_nonce(array(
1382
-                    'action'      => 'default',
1383
-                    'status'      => 'month',
1384
-                    '_reg_status' => EEM_Registration::status_id_cancelled,
1385
-                ), $reg_admin_url),
1386
-                'meta'   => array(
1387
-                    'title'  => __('Cancelled', 'event_espresso'),
1388
-                    'target' => '',
1389
-                    'class'  => $menu_class,
1390
-                ),
1391
-            ));
1392
-        }
1393
-        //Extensions & Services
1394
-        if ($this->registry->CAP->current_user_can('ee_read_ee',
1395
-            'ee_admin_bar_menu_espresso-toolbar-extensions-and-services')
1396
-        ) {
1397
-            $admin_bar->add_menu(array(
1398
-                'id'     => 'espresso-toolbar-extensions-and-services',
1399
-                'parent' => 'espresso-toolbar',
1400
-                'title'  => __('Extensions & Services', 'event_espresso'),
1401
-                'href'   => $extensions_admin_url,
1402
-                'meta'   => array(
1403
-                    'title'  => __('Extensions & Services', 'event_espresso'),
1404
-                    'target' => '',
1405
-                    'class'  => $menu_class,
1406
-                ),
1407
-            ));
1408
-        }
1409
-    }
1410
-
1411
-
1412
-
1413
-    /**
1414
-     * simply hooks into "wp_list_pages_exclude" filter (for wp_list_pages method) and makes sure EE critical pages are
1415
-     * never returned with the function.
1416
-     *
1417
-     * @param  array $exclude_array any existing pages being excluded are in this array.
1418
-     * @return array
1419
-     */
1420
-    public function remove_pages_from_wp_list_pages($exclude_array)
1421
-    {
1422
-        return array_merge($exclude_array, $this->registry->CFG->core->get_critical_pages_array());
1423
-    }
1424
-
1425
-
1426
-
1427
-
1428
-
1429
-
1430
-    /***********************************************        WP_ENQUEUE_SCRIPTS HOOK         ***********************************************/
1431
-    /**
1432
-     *    wp_enqueue_scripts
1433
-     *
1434
-     * @access    public
1435
-     * @return    void
1436
-     */
1437
-    public function wp_enqueue_scripts()
1438
-    {
1439
-        // unlike other systems, EE_System_scripts loading is turned ON by default, but prior to the init hook, can be turned off via: add_filter( 'FHEE_load_EE_System_scripts', '__return_false' );
1440
-        if (apply_filters('FHEE_load_EE_System_scripts', true)) {
1441
-            // jquery_validate loading is turned OFF by default, but prior to the wp_enqueue_scripts hook, can be turned back on again via:  add_filter( 'FHEE_load_jquery_validate', '__return_true' );
1442
-            if (apply_filters('FHEE_load_jquery_validate', false)) {
1443
-                // register jQuery Validate and additional methods
1444
-                wp_register_script('jquery-validate', EE_GLOBAL_ASSETS_URL . 'scripts/jquery.validate.min.js',
1445
-                    array('jquery'), '1.15.0', true);
1446
-                wp_register_script('jquery-validate-extra-methods',
1447
-                    EE_GLOBAL_ASSETS_URL . 'scripts/jquery.validate.additional-methods.min.js',
1448
-                    array('jquery', 'jquery-validate'), '1.15.0', true);
1449
-            }
1450
-        }
1451
-    }
22
+	/**
23
+	 * indicates this is a 'normal' request. Ie, not activation, nor upgrade, nor activation.
24
+	 * So examples of this would be a normal GET request on the frontend or backend, or a POST, etc
25
+	 */
26
+	const req_type_normal = 0;
27
+
28
+	/**
29
+	 * Indicates this is a brand new installation of EE so we should install
30
+	 * tables and default data etc
31
+	 */
32
+	const req_type_new_activation = 1;
33
+
34
+	/**
35
+	 * we've detected that EE has been reactivated (or EE was activated during maintenance mode,
36
+	 * and we just exited maintenance mode). We MUST check the database is setup properly
37
+	 * and that default data is setup too
38
+	 */
39
+	const req_type_reactivation = 2;
40
+
41
+	/**
42
+	 * indicates that EE has been upgraded since its previous request.
43
+	 * We may have data migration scripts to call and will want to trigger maintenance mode
44
+	 */
45
+	const req_type_upgrade = 3;
46
+
47
+	/**
48
+	 * TODO  will detect that EE has been DOWNGRADED. We probably don't want to run in this case...
49
+	 */
50
+	const req_type_downgrade = 4;
51
+
52
+	/**
53
+	 * @deprecated since version 4.6.0.dev.006
54
+	 * Now whenever a new_activation is detected the request type is still just
55
+	 * new_activation (same for reactivation, upgrade, downgrade etc), but if we'r ein maintenance mode
56
+	 * EE_System::initialize_db_if_no_migrations_required and EE_Addon::initialize_db_if_no_migrations_required
57
+	 * will instead enqueue that EE plugin's db initialization for when we're taken out of maintenance mode.
58
+	 * (Specifically, when the migration manager indicates migrations are finished
59
+	 * EE_Data_Migration_Manager::initialize_db_for_enqueued_ee_plugins() will be called)
60
+	 */
61
+	const req_type_activation_but_not_installed = 5;
62
+
63
+	/**
64
+	 * option prefix for recording the activation history (like core's "espresso_db_update") of addons
65
+	 */
66
+	const addon_activation_history_option_prefix = 'ee_addon_activation_history_';
67
+
68
+
69
+	/**
70
+	 *    instance of the EE_System object
71
+	 *
72
+	 * @var    $_instance
73
+	 * @access    private
74
+	 */
75
+	private static $_instance = null;
76
+
77
+	/**
78
+	 * @type  EE_Registry $Registry
79
+	 * @access    protected
80
+	 */
81
+	protected $registry;
82
+
83
+	/**
84
+	 * Stores which type of request this is, options being one of the constants on EE_System starting with req_type_*.
85
+	 * It can be a brand-new activation, a reactivation, an upgrade, a downgrade, or a normal request.
86
+	 *
87
+	 * @var int
88
+	 */
89
+	private $_req_type;
90
+
91
+	/**
92
+	 * Whether or not there was a non-micro version change in EE core version during this request
93
+	 *
94
+	 * @var boolean
95
+	 */
96
+	private $_major_version_change = false;
97
+
98
+
99
+
100
+	/**
101
+	 * @singleton method used to instantiate class object
102
+	 * @access    public
103
+	 * @param  \EE_Registry $Registry
104
+	 * @return \EE_System
105
+	 */
106
+	public static function instance(EE_Registry $Registry = null)
107
+	{
108
+		// check if class object is instantiated
109
+		if ( ! self::$_instance instanceof EE_System) {
110
+			self::$_instance = new self($Registry);
111
+		}
112
+		return self::$_instance;
113
+	}
114
+
115
+
116
+
117
+	/**
118
+	 * resets the instance and returns it
119
+	 *
120
+	 * @return EE_System
121
+	 */
122
+	public static function reset()
123
+	{
124
+		self::$_instance->_req_type = null;
125
+		//make sure none of the old hooks are left hanging around
126
+		remove_all_actions('AHEE__EE_System__perform_activations_upgrades_and_migrations');
127
+		//we need to reset the migration manager in order for it to detect DMSs properly
128
+		EE_Data_Migration_Manager::reset();
129
+		self::instance()->detect_activations_or_upgrades();
130
+		self::instance()->perform_activations_upgrades_and_migrations();
131
+		return self::instance();
132
+	}
133
+
134
+
135
+
136
+	/**
137
+	 *    sets hooks for running rest of system
138
+	 *    provides "AHEE__EE_System__construct__complete" hook for EE Addons to use as their starting point
139
+	 *    starting EE Addons from any other point may lead to problems
140
+	 *
141
+	 * @access private
142
+	 * @param  \EE_Registry $Registry
143
+	 */
144
+	private function __construct(EE_Registry $Registry)
145
+	{
146
+		$this->registry = $Registry;
147
+		do_action('AHEE__EE_System__construct__begin', $this);
148
+		// allow addons to load first so that they can register autoloaders, set hooks for running DMS's, etc
149
+		add_action('AHEE__EE_Bootstrap__load_espresso_addons', array($this, 'load_espresso_addons'));
150
+		// when an ee addon is activated, we want to call the core hook(s) again
151
+		// because the newly-activated addon didn't get a chance to run at all
152
+		add_action('activate_plugin', array($this, 'load_espresso_addons'), 1);
153
+		// detect whether install or upgrade
154
+		add_action('AHEE__EE_Bootstrap__detect_activations_or_upgrades', array($this, 'detect_activations_or_upgrades'),
155
+			3);
156
+		// load EE_Config, EE_Textdomain, etc
157
+		add_action('AHEE__EE_Bootstrap__load_core_configuration', array($this, 'load_core_configuration'), 5);
158
+		// load EE_Config, EE_Textdomain, etc
159
+		add_action('AHEE__EE_Bootstrap__register_shortcodes_modules_and_widgets',
160
+			array($this, 'register_shortcodes_modules_and_widgets'), 7);
161
+		// you wanna get going? I wanna get going... let's get going!
162
+		add_action('AHEE__EE_Bootstrap__brew_espresso', array($this, 'brew_espresso'), 9);
163
+		//other housekeeping
164
+		//exclude EE critical pages from wp_list_pages
165
+		add_filter('wp_list_pages_excludes', array($this, 'remove_pages_from_wp_list_pages'), 10);
166
+		// ALL EE Addons should use the following hook point to attach their initial setup too
167
+		// it's extremely important for EE Addons to register any class autoloaders so that they can be available when the EE_Config loads
168
+		do_action('AHEE__EE_System__construct__complete', $this);
169
+	}
170
+
171
+
172
+
173
+	/**
174
+	 * load_espresso_addons
175
+	 * allow addons to load first so that they can set hooks for running DMS's, etc
176
+	 * this is hooked into both:
177
+	 *    'AHEE__EE_Bootstrap__load_core_configuration'
178
+	 *        which runs during the WP 'plugins_loaded' action at priority 5
179
+	 *    and the WP 'activate_plugin' hookpoint
180
+	 *
181
+	 * @access public
182
+	 * @return void
183
+	 */
184
+	public function load_espresso_addons()
185
+	{
186
+		// set autoloaders for all of the classes implementing EEI_Plugin_API
187
+		// which provide helpers for EE plugin authors to more easily register certain components with EE.
188
+		EEH_Autoloader::instance()->register_autoloaders_for_each_file_in_folder(EE_LIBRARIES . 'plugin_api');
189
+		//load and setup EE_Capabilities
190
+		$this->registry->load_core('Capabilities');
191
+		//caps need to be initialized on every request so that capability maps are set.
192
+		//@see https://events.codebasehq.com/projects/event-espresso/tickets/8674
193
+		$this->registry->CAP->init_caps();
194
+		do_action('AHEE__EE_System__load_espresso_addons');
195
+		//if the WP API basic auth plugin isn't already loaded, load it now.
196
+		//We want it for mobile apps. Just include the entire plugin
197
+		//also, don't load the basic auth when a plugin is getting activated, because
198
+		//it could be the basic auth plugin, and it doesn't check if its methods are already defined
199
+		//and causes a fatal error
200
+		if ( ! function_exists('json_basic_auth_handler')
201
+			 && ! function_exists('json_basic_auth_error')
202
+			 && ! (
203
+				isset($_GET['action'])
204
+				&& in_array($_GET['action'], array('activate', 'activate-selected'))
205
+			)
206
+			 && ! (
207
+				isset($_GET['activate'])
208
+				&& $_GET['activate'] === 'true'
209
+			)
210
+		) {
211
+			include_once EE_THIRD_PARTY . 'wp-api-basic-auth' . DS . 'basic-auth.php';
212
+		}
213
+		do_action('AHEE__EE_System__load_espresso_addons__complete');
214
+	}
215
+
216
+
217
+
218
+	/**
219
+	 * detect_activations_or_upgrades
220
+	 * Checks for activation or upgrade of core first;
221
+	 * then also checks if any registered addons have been activated or upgraded
222
+	 * This is hooked into 'AHEE__EE_Bootstrap__detect_activations_or_upgrades'
223
+	 * which runs during the WP 'plugins_loaded' action at priority 3
224
+	 *
225
+	 * @access public
226
+	 * @return void
227
+	 */
228
+	public function detect_activations_or_upgrades()
229
+	{
230
+		//first off: let's make sure to handle core
231
+		$this->detect_if_activation_or_upgrade();
232
+		foreach ($this->registry->addons as $addon) {
233
+			//detect teh request type for that addon
234
+			$addon->detect_activation_or_upgrade();
235
+		}
236
+	}
237
+
238
+
239
+
240
+	/**
241
+	 * detect_if_activation_or_upgrade
242
+	 * Takes care of detecting whether this is a brand new install or code upgrade,
243
+	 * and either setting up the DB or setting up maintenance mode etc.
244
+	 *
245
+	 * @access public
246
+	 * @return void
247
+	 */
248
+	public function detect_if_activation_or_upgrade()
249
+	{
250
+		do_action('AHEE__EE_System___detect_if_activation_or_upgrade__begin');
251
+		// load M-Mode class
252
+		$this->registry->load_core('Maintenance_Mode');
253
+		// check if db has been updated, or if its a brand-new installation
254
+		$espresso_db_update = $this->fix_espresso_db_upgrade_option();
255
+		$request_type = $this->detect_req_type($espresso_db_update);
256
+		//EEH_Debug_Tools::printr( $request_type, '$request_type', __FILE__, __LINE__ );
257
+		switch ($request_type) {
258
+			case EE_System::req_type_new_activation:
259
+				do_action('AHEE__EE_System__detect_if_activation_or_upgrade__new_activation');
260
+				$this->_handle_core_version_change($espresso_db_update);
261
+				break;
262
+			case EE_System::req_type_reactivation:
263
+				do_action('AHEE__EE_System__detect_if_activation_or_upgrade__reactivation');
264
+				$this->_handle_core_version_change($espresso_db_update);
265
+				break;
266
+			case EE_System::req_type_upgrade:
267
+				do_action('AHEE__EE_System__detect_if_activation_or_upgrade__upgrade');
268
+				//migrations may be required now that we've upgraded
269
+				EE_Maintenance_Mode::instance()->set_maintenance_mode_if_db_old();
270
+				$this->_handle_core_version_change($espresso_db_update);
271
+				//				echo "done upgrade";die;
272
+				break;
273
+			case EE_System::req_type_downgrade:
274
+				do_action('AHEE__EE_System__detect_if_activation_or_upgrade__downgrade');
275
+				//its possible migrations are no longer required
276
+				EE_Maintenance_Mode::instance()->set_maintenance_mode_if_db_old();
277
+				$this->_handle_core_version_change($espresso_db_update);
278
+				break;
279
+			case EE_System::req_type_normal:
280
+			default:
281
+				//				$this->_maybe_redirect_to_ee_about();
282
+				break;
283
+		}
284
+		do_action('AHEE__EE_System__detect_if_activation_or_upgrade__complete');
285
+	}
286
+
287
+
288
+
289
+	/**
290
+	 * Updates the list of installed versions and sets hooks for
291
+	 * initializing the database later during the request
292
+	 *
293
+	 * @param array $espresso_db_update
294
+	 */
295
+	protected function _handle_core_version_change($espresso_db_update)
296
+	{
297
+		$this->update_list_of_installed_versions($espresso_db_update);
298
+		//get ready to verify the DB is ok (provided we aren't in maintenance mode, of course)
299
+		add_action('AHEE__EE_System__perform_activations_upgrades_and_migrations',
300
+			array($this, 'initialize_db_if_no_migrations_required'));
301
+	}
302
+
303
+
304
+
305
+	/**
306
+	 * standardizes the wp option 'espresso_db_upgrade' which actually stores
307
+	 * information about what versions of EE have been installed and activated,
308
+	 * NOT necessarily the state of the database
309
+	 *
310
+	 * @param null $espresso_db_update
311
+	 * @internal param array $espresso_db_update_value the value of the WordPress option. If not supplied, fetches it
312
+	 *           from the options table
313
+	 * @return array the correct value of 'espresso_db_upgrade', after saving it, if it needed correction
314
+	 */
315
+	private function fix_espresso_db_upgrade_option($espresso_db_update = null)
316
+	{
317
+		do_action('FHEE__EE_System__manage_fix_espresso_db_upgrade_option__begin', $espresso_db_update);
318
+		if ( ! $espresso_db_update) {
319
+			$espresso_db_update = get_option('espresso_db_update');
320
+		}
321
+		// check that option is an array
322
+		if ( ! is_array($espresso_db_update)) {
323
+			// if option is FALSE, then it never existed
324
+			if ($espresso_db_update === false) {
325
+				// make $espresso_db_update an array and save option with autoload OFF
326
+				$espresso_db_update = array();
327
+				add_option('espresso_db_update', $espresso_db_update, '', 'no');
328
+			} else {
329
+				// option is NOT FALSE but also is NOT an array, so make it an array and save it
330
+				$espresso_db_update = array($espresso_db_update => array());
331
+				update_option('espresso_db_update', $espresso_db_update);
332
+			}
333
+		} else {
334
+			$corrected_db_update = array();
335
+			//if IS an array, but is it an array where KEYS are version numbers, and values are arrays?
336
+			foreach ($espresso_db_update as $should_be_version_string => $should_be_array) {
337
+				if (is_int($should_be_version_string) && ! is_array($should_be_array)) {
338
+					//the key is an int, and the value IS NOT an array
339
+					//so it must be numerically-indexed, where values are versions installed...
340
+					//fix it!
341
+					$version_string = $should_be_array;
342
+					$corrected_db_update[$version_string] = array('unknown-date');
343
+				} else {
344
+					//ok it checks out
345
+					$corrected_db_update[$should_be_version_string] = $should_be_array;
346
+				}
347
+			}
348
+			$espresso_db_update = $corrected_db_update;
349
+			update_option('espresso_db_update', $espresso_db_update);
350
+		}
351
+		do_action('FHEE__EE_System__manage_fix_espresso_db_upgrade_option__complete', $espresso_db_update);
352
+		return $espresso_db_update;
353
+	}
354
+
355
+
356
+
357
+	/**
358
+	 * Does the traditional work of setting up the plugin's database and adding default data.
359
+	 * If migration script/process did not exist, this is what would happen on every activation/reactivation/upgrade.
360
+	 * NOTE: if we're in maintenance mode (which would be the case if we detect there are data
361
+	 * migration scripts that need to be run and a version change happens), enqueues core for database initialization,
362
+	 * so that it will be done when migrations are finished
363
+	 *
364
+	 * @param boolean $initialize_addons_too if true, we double-check addons' database tables etc too;
365
+	 * @param boolean $verify_schema         if true will re-check the database tables have the correct schema.
366
+	 *                                       This is a resource-intensive job
367
+	 *                                       so we prefer to only do it when necessary
368
+	 * @return void
369
+	 */
370
+	public function initialize_db_if_no_migrations_required($initialize_addons_too = false, $verify_schema = true)
371
+	{
372
+		$request_type = $this->detect_req_type();
373
+		//only initialize system if we're not in maintenance mode.
374
+		if (EE_Maintenance_Mode::instance()->level() != EE_Maintenance_Mode::level_2_complete_maintenance) {
375
+			update_option('ee_flush_rewrite_rules', true);
376
+			if ($verify_schema) {
377
+				EEH_Activation::initialize_db_and_folders();
378
+			}
379
+			EEH_Activation::initialize_db_content();
380
+			EEH_Activation::system_initialization();
381
+			if ($initialize_addons_too) {
382
+				$this->initialize_addons();
383
+			}
384
+		} else {
385
+			EE_Data_Migration_Manager::instance()->enqueue_db_initialization_for('Core');
386
+		}
387
+		if ($request_type === EE_System::req_type_new_activation
388
+			|| $request_type === EE_System::req_type_reactivation
389
+			|| (
390
+				$request_type === EE_System::req_type_upgrade
391
+				&& $this->is_major_version_change()
392
+			)
393
+		) {
394
+			add_action('AHEE__EE_System__initialize_last', array($this, 'redirect_to_about_ee'), 9);
395
+		}
396
+	}
397
+
398
+
399
+
400
+	/**
401
+	 * Initializes the db for all registered addons
402
+	 */
403
+	public function initialize_addons()
404
+	{
405
+		//foreach registered addon, make sure its db is up-to-date too
406
+		foreach ($this->registry->addons as $addon) {
407
+			$addon->initialize_db_if_no_migrations_required();
408
+		}
409
+	}
410
+
411
+
412
+
413
+	/**
414
+	 * Adds the current code version to the saved wp option which stores a list of all ee versions ever installed.
415
+	 *
416
+	 * @param    array  $version_history
417
+	 * @param    string $current_version_to_add version to be added to the version history
418
+	 * @return    boolean success as to whether or not this option was changed
419
+	 */
420
+	public function update_list_of_installed_versions($version_history = null, $current_version_to_add = null)
421
+	{
422
+		if ( ! $version_history) {
423
+			$version_history = $this->fix_espresso_db_upgrade_option($version_history);
424
+		}
425
+		if ($current_version_to_add == null) {
426
+			$current_version_to_add = espresso_version();
427
+		}
428
+		$version_history[$current_version_to_add][] = date('Y-m-d H:i:s', time());
429
+		// re-save
430
+		return update_option('espresso_db_update', $version_history);
431
+	}
432
+
433
+
434
+
435
+	/**
436
+	 * Detects if the current version indicated in the has existed in the list of
437
+	 * previously-installed versions of EE (espresso_db_update). Does NOT modify it (ie, no side-effect)
438
+	 *
439
+	 * @param array $espresso_db_update array from the wp option stored under the name 'espresso_db_update'.
440
+	 *                                  If not supplied, fetches it from the options table.
441
+	 *                                  Also, caches its result so later parts of the code can also know whether
442
+	 *                                  there's been an update or not. This way we can add the current version to
443
+	 *                                  espresso_db_update, but still know if this is a new install or not
444
+	 * @return int one of the constants on EE_System::req_type_
445
+	 */
446
+	public function detect_req_type($espresso_db_update = null)
447
+	{
448
+		if ($this->_req_type === null) {
449
+			$espresso_db_update = ! empty($espresso_db_update) ? $espresso_db_update
450
+				: $this->fix_espresso_db_upgrade_option();
451
+			$this->_req_type = $this->detect_req_type_given_activation_history($espresso_db_update,
452
+				'ee_espresso_activation', espresso_version());
453
+			$this->_major_version_change = $this->_detect_major_version_change($espresso_db_update);
454
+		}
455
+		return $this->_req_type;
456
+	}
457
+
458
+
459
+
460
+	/**
461
+	 * Returns whether or not there was a non-micro version change (ie, change in either
462
+	 * the first or second number in the version. Eg 4.9.0.rc.001 to 4.10.0.rc.000,
463
+	 * but not 4.9.0.rc.0001 to 4.9.1.rc.0001
464
+	 *
465
+	 * @param $activation_history
466
+	 * @return bool
467
+	 */
468
+	protected function _detect_major_version_change($activation_history)
469
+	{
470
+		$previous_version = EE_System::_get_most_recently_active_version_from_activation_history($activation_history);
471
+		$previous_version_parts = explode('.', $previous_version);
472
+		$current_version_parts = explode('.', espresso_version());
473
+		return isset($previous_version_parts[0], $previous_version_parts[1], $current_version_parts[0], $current_version_parts[1])
474
+			   && ($previous_version_parts[0] !== $current_version_parts[0]
475
+				   || $previous_version_parts[1] !== $current_version_parts[1]
476
+			   );
477
+	}
478
+
479
+
480
+
481
+	/**
482
+	 * Returns true if either the major or minor version of EE changed during this request.
483
+	 * Eg 4.9.0.rc.001 to 4.10.0.rc.000, but not 4.9.0.rc.0001 to 4.9.1.rc.0001
484
+	 *
485
+	 * @return bool
486
+	 */
487
+	public function is_major_version_change()
488
+	{
489
+		return $this->_major_version_change;
490
+	}
491
+
492
+
493
+
494
+	/**
495
+	 * Determines the request type for any ee addon, given three piece of info: the current array of activation
496
+	 * histories (for core that' 'espresso_db_update' wp option); the name of the wordpress option which is temporarily
497
+	 * set upon activation of the plugin (for core it's 'ee_espresso_activation'); and the version that this plugin was
498
+	 * just activated to (for core that will always be espresso_version())
499
+	 *
500
+	 * @param array  $activation_history_for_addon     the option's value which stores the activation history for this
501
+	 *                                                 ee plugin. for core that's 'espresso_db_update'
502
+	 * @param string $activation_indicator_option_name the name of the wordpress option that is temporarily set to
503
+	 *                                                 indicate that this plugin was just activated
504
+	 * @param string $version_to_upgrade_to            the version that was just upgraded to (for core that will be
505
+	 *                                                 espresso_version())
506
+	 * @return int one of the constants on EE_System::req_type_*
507
+	 */
508
+	public static function detect_req_type_given_activation_history(
509
+		$activation_history_for_addon,
510
+		$activation_indicator_option_name,
511
+		$version_to_upgrade_to
512
+	) {
513
+		$version_is_higher = self::_new_version_is_higher($activation_history_for_addon, $version_to_upgrade_to);
514
+		if ($activation_history_for_addon) {
515
+			//it exists, so this isn't a completely new install
516
+			//check if this version already in that list of previously installed versions
517
+			if ( ! isset($activation_history_for_addon[$version_to_upgrade_to])) {
518
+				//it a version we haven't seen before
519
+				if ($version_is_higher === 1) {
520
+					$req_type = EE_System::req_type_upgrade;
521
+				} else {
522
+					$req_type = EE_System::req_type_downgrade;
523
+				}
524
+				delete_option($activation_indicator_option_name);
525
+			} else {
526
+				// its not an update. maybe a reactivation?
527
+				if (get_option($activation_indicator_option_name, false)) {
528
+					if ($version_is_higher === -1) {
529
+						$req_type = EE_System::req_type_downgrade;
530
+					} elseif ($version_is_higher === 0) {
531
+						//we've seen this version before, but it's an activation. must be a reactivation
532
+						$req_type = EE_System::req_type_reactivation;
533
+					} else {//$version_is_higher === 1
534
+						$req_type = EE_System::req_type_upgrade;
535
+					}
536
+					delete_option($activation_indicator_option_name);
537
+				} else {
538
+					//we've seen this version before and the activation indicate doesn't show it was just activated
539
+					if ($version_is_higher === -1) {
540
+						$req_type = EE_System::req_type_downgrade;
541
+					} elseif ($version_is_higher === 0) {
542
+						//we've seen this version before and it's not an activation. its normal request
543
+						$req_type = EE_System::req_type_normal;
544
+					} else {//$version_is_higher === 1
545
+						$req_type = EE_System::req_type_upgrade;
546
+					}
547
+				}
548
+			}
549
+		} else {
550
+			//brand new install
551
+			$req_type = EE_System::req_type_new_activation;
552
+			delete_option($activation_indicator_option_name);
553
+		}
554
+		return $req_type;
555
+	}
556
+
557
+
558
+
559
+	/**
560
+	 * Detects if the $version_to_upgrade_to is higher than the most recent version in
561
+	 * the $activation_history_for_addon
562
+	 *
563
+	 * @param array  $activation_history_for_addon (keys are versions, values are arrays of times activated,
564
+	 *                                             sometimes containing 'unknown-date'
565
+	 * @param string $version_to_upgrade_to        (current version)
566
+	 * @return int results of version_compare( $version_to_upgrade_to, $most_recently_active_version ).
567
+	 *                                             ie, -1 if $version_to_upgrade_to is LOWER (downgrade);
568
+	 *                                             0 if $version_to_upgrade_to MATCHES (reactivation or normal request);
569
+	 *                                             1 if $version_to_upgrade_to is HIGHER (upgrade) ;
570
+	 */
571
+	protected static function _new_version_is_higher($activation_history_for_addon, $version_to_upgrade_to)
572
+	{
573
+		//find the most recently-activated version
574
+		$most_recently_active_version = EE_System::_get_most_recently_active_version_from_activation_history($activation_history_for_addon);
575
+		return version_compare($version_to_upgrade_to, $most_recently_active_version);
576
+	}
577
+
578
+
579
+
580
+	/**
581
+	 * Gets the most recently active version listed in the activation history,
582
+	 * and if none are found (ie, it's a brand new install) returns '0.0.0.dev.000'.
583
+	 *
584
+	 * @param array $activation_history  (keys are versions, values are arrays of times activated,
585
+	 *                                   sometimes containing 'unknown-date'
586
+	 * @return string
587
+	 */
588
+	protected static function _get_most_recently_active_version_from_activation_history($activation_history)
589
+	{
590
+		$most_recently_active_version_activation = '1970-01-01 00:00:00';
591
+		$most_recently_active_version = '0.0.0.dev.000';
592
+		if (is_array($activation_history)) {
593
+			foreach ($activation_history as $version => $times_activated) {
594
+				//check there is a record of when this version was activated. Otherwise,
595
+				//mark it as unknown
596
+				if ( ! $times_activated) {
597
+					$times_activated = array('unknown-date');
598
+				}
599
+				if (is_string($times_activated)) {
600
+					$times_activated = array($times_activated);
601
+				}
602
+				foreach ($times_activated as $an_activation) {
603
+					if ($an_activation != 'unknown-date' && $an_activation > $most_recently_active_version_activation) {
604
+						$most_recently_active_version = $version;
605
+						$most_recently_active_version_activation = $an_activation == 'unknown-date'
606
+							? '1970-01-01 00:00:00' : $an_activation;
607
+					}
608
+				}
609
+			}
610
+		}
611
+		return $most_recently_active_version;
612
+	}
613
+
614
+
615
+
616
+	/**
617
+	 * This redirects to the about EE page after activation
618
+	 *
619
+	 * @return void
620
+	 */
621
+	public function redirect_to_about_ee()
622
+	{
623
+		$notices = EE_Error::get_notices(false);
624
+		//if current user is an admin and it's not an ajax or rest request
625
+		if (
626
+			! (defined('DOING_AJAX') && DOING_AJAX)
627
+			&& ! (defined('REST_REQUEST') && REST_REQUEST)
628
+			&& ! isset($notices['errors'])
629
+			&& apply_filters(
630
+				'FHEE__EE_System__redirect_to_about_ee__do_redirect',
631
+				$this->registry->CAP->current_user_can('manage_options', 'espresso_about_default')
632
+			)
633
+		) {
634
+			$query_params = array('page' => 'espresso_about');
635
+			if (EE_System::instance()->detect_req_type() == EE_System::req_type_new_activation) {
636
+				$query_params['new_activation'] = true;
637
+			}
638
+			if (EE_System::instance()->detect_req_type() == EE_System::req_type_reactivation) {
639
+				$query_params['reactivation'] = true;
640
+			}
641
+			$url = add_query_arg($query_params, admin_url('admin.php'));
642
+			wp_safe_redirect($url);
643
+			exit();
644
+		}
645
+	}
646
+
647
+
648
+
649
+	/**
650
+	 * load_core_configuration
651
+	 * this is hooked into 'AHEE__EE_Bootstrap__load_core_configuration'
652
+	 * which runs during the WP 'plugins_loaded' action at priority 5
653
+	 *
654
+	 * @return void
655
+	 */
656
+	public function load_core_configuration()
657
+	{
658
+		do_action('AHEE__EE_System__load_core_configuration__begin', $this);
659
+		$this->registry->load_core('EE_Load_Textdomain');
660
+		//load textdomain
661
+		EE_Load_Textdomain::load_textdomain();
662
+		// load and setup EE_Config and EE_Network_Config
663
+		$this->registry->load_core('Config');
664
+		$this->registry->load_core('Network_Config');
665
+		// setup autoloaders
666
+		// enable logging?
667
+		if ($this->registry->CFG->admin->use_full_logging) {
668
+			$this->registry->load_core('Log');
669
+		}
670
+		// check for activation errors
671
+		$activation_errors = get_option('ee_plugin_activation_errors', false);
672
+		if ($activation_errors) {
673
+			EE_Error::add_error($activation_errors, __FILE__, __FUNCTION__, __LINE__);
674
+			update_option('ee_plugin_activation_errors', false);
675
+		}
676
+		// get model names
677
+		$this->_parse_model_names();
678
+		//load caf stuff a chance to play during the activation process too.
679
+		$this->_maybe_brew_regular();
680
+		do_action('AHEE__EE_System__load_core_configuration__complete', $this);
681
+	}
682
+
683
+
684
+
685
+	/**
686
+	 * cycles through all of the models/*.model.php files, and assembles an array of model names
687
+	 *
688
+	 * @return void
689
+	 */
690
+	private function _parse_model_names()
691
+	{
692
+		//get all the files in the EE_MODELS folder that end in .model.php
693
+		$models = glob(EE_MODELS . '*.model.php');
694
+		$model_names = array();
695
+		$non_abstract_db_models = array();
696
+		foreach ($models as $model) {
697
+			// get model classname
698
+			$classname = EEH_File::get_classname_from_filepath_with_standard_filename($model);
699
+			$short_name = str_replace('EEM_', '', $classname);
700
+			$reflectionClass = new ReflectionClass($classname);
701
+			if ($reflectionClass->isSubclassOf('EEM_Base') && ! $reflectionClass->isAbstract()) {
702
+				$non_abstract_db_models[$short_name] = $classname;
703
+			}
704
+			$model_names[$short_name] = $classname;
705
+		}
706
+		$this->registry->models = apply_filters('FHEE__EE_System__parse_model_names', $model_names);
707
+		$this->registry->non_abstract_db_models = apply_filters('FHEE__EE_System__parse_implemented_model_names',
708
+			$non_abstract_db_models);
709
+	}
710
+
711
+
712
+
713
+	/**
714
+	 * The purpose of this method is to simply check for a file named "caffeinated/brewing_regular.php" for any hooks
715
+	 * that need to be setup before our EE_System launches.
716
+	 *
717
+	 * @return void
718
+	 */
719
+	private function _maybe_brew_regular()
720
+	{
721
+		if (( ! defined('EE_DECAF') || EE_DECAF !== true) && is_readable(EE_CAFF_PATH . 'brewing_regular.php')) {
722
+			require_once EE_CAFF_PATH . 'brewing_regular.php';
723
+		}
724
+	}
725
+
726
+
727
+
728
+	/**
729
+	 * register_shortcodes_modules_and_widgets
730
+	 * generate lists of shortcodes and modules, then verify paths and classes
731
+	 * This is hooked into 'AHEE__EE_Bootstrap__register_shortcodes_modules_and_widgets'
732
+	 * which runs during the WP 'plugins_loaded' action at priority 7
733
+	 *
734
+	 * @access public
735
+	 * @return void
736
+	 */
737
+	public function register_shortcodes_modules_and_widgets()
738
+	{
739
+		// load, register, and add shortcodes the new way
740
+		new ShortcodesManager(
741
+			// and the old way, but we'll put it under control of the new system
742
+			EE_Config::getLegacyShortcodesManager()
743
+		);
744
+		do_action('AHEE__EE_System__register_shortcodes_modules_and_widgets');
745
+		// check for addons using old hookpoint
746
+		if (has_action('AHEE__EE_System__register_shortcodes_modules_and_addons')) {
747
+			$this->_incompatible_addon_error();
748
+		}
749
+	}
750
+
751
+
752
+
753
+	/**
754
+	 * _incompatible_addon_error
755
+	 *
756
+	 * @access public
757
+	 * @return void
758
+	 */
759
+	private function _incompatible_addon_error()
760
+	{
761
+		// get array of classes hooking into here
762
+		$class_names = EEH_Class_Tools::get_class_names_for_all_callbacks_on_hook('AHEE__EE_System__register_shortcodes_modules_and_addons');
763
+		if ( ! empty($class_names)) {
764
+			$msg = __('The following plugins, addons, or modules appear to be incompatible with this version of Event Espresso and were automatically deactivated to avoid fatal errors:',
765
+				'event_espresso');
766
+			$msg .= '<ul>';
767
+			foreach ($class_names as $class_name) {
768
+				$msg .= '<li><b>Event Espresso - ' . str_replace(array('EE_', 'EEM_', 'EED_', 'EES_', 'EEW_'), '',
769
+						$class_name) . '</b></li>';
770
+			}
771
+			$msg .= '</ul>';
772
+			$msg .= __('Compatibility issues can be avoided and/or resolved by keeping addons and plugins updated to the latest version.',
773
+				'event_espresso');
774
+			// save list of incompatible addons to wp-options for later use
775
+			add_option('ee_incompatible_addons', $class_names, '', 'no');
776
+			if (is_admin()) {
777
+				EE_Error::add_error($msg, __FILE__, __FUNCTION__, __LINE__);
778
+			}
779
+		}
780
+	}
781
+
782
+
783
+
784
+	/**
785
+	 * brew_espresso
786
+	 * begins the process of setting hooks for initializing EE in the correct order
787
+	 * This is happening on the 'AHEE__EE_Bootstrap__brew_espresso' hookpoint
788
+	 * which runs during the WP 'plugins_loaded' action at priority 9
789
+	 *
790
+	 * @return void
791
+	 */
792
+	public function brew_espresso()
793
+	{
794
+		do_action('AHEE__EE_System__brew_espresso__begin', $this);
795
+		// load some final core systems
796
+		add_action('init', array($this, 'set_hooks_for_core'), 1);
797
+		add_action('init', array($this, 'perform_activations_upgrades_and_migrations'), 3);
798
+		add_action('init', array($this, 'load_CPTs_and_session'), 5);
799
+		add_action('init', array($this, 'load_controllers'), 7);
800
+		add_action('init', array($this, 'core_loaded_and_ready'), 9);
801
+		add_action('init', array($this, 'initialize'), 10);
802
+		add_action('init', array($this, 'initialize_last'), 100);
803
+		add_action('wp_enqueue_scripts', array($this, 'wp_enqueue_scripts'), 100);
804
+		add_action('admin_enqueue_scripts', array($this, 'wp_enqueue_scripts'), 100);
805
+		add_action('admin_bar_menu', array($this, 'espresso_toolbar_items'), 100);
806
+		if (is_admin() && apply_filters('FHEE__EE_System__brew_espresso__load_pue', true)) {
807
+			// pew pew pew
808
+			$this->registry->load_core('PUE');
809
+			do_action('AHEE__EE_System__brew_espresso__after_pue_init');
810
+		}
811
+		do_action('AHEE__EE_System__brew_espresso__complete', $this);
812
+	}
813
+
814
+
815
+
816
+	/**
817
+	 *    set_hooks_for_core
818
+	 *
819
+	 * @access public
820
+	 * @return    void
821
+	 */
822
+	public function set_hooks_for_core()
823
+	{
824
+		$this->_deactivate_incompatible_addons();
825
+		do_action('AHEE__EE_System__set_hooks_for_core');
826
+	}
827
+
828
+
829
+
830
+	/**
831
+	 * Using the information gathered in EE_System::_incompatible_addon_error,
832
+	 * deactivates any addons considered incompatible with the current version of EE
833
+	 */
834
+	private function _deactivate_incompatible_addons()
835
+	{
836
+		$incompatible_addons = get_option('ee_incompatible_addons', array());
837
+		if ( ! empty($incompatible_addons)) {
838
+			$active_plugins = get_option('active_plugins', array());
839
+			foreach ($active_plugins as $active_plugin) {
840
+				foreach ($incompatible_addons as $incompatible_addon) {
841
+					if (strpos($active_plugin, $incompatible_addon) !== false) {
842
+						unset($_GET['activate']);
843
+						espresso_deactivate_plugin($active_plugin);
844
+					}
845
+				}
846
+			}
847
+		}
848
+	}
849
+
850
+
851
+
852
+	/**
853
+	 *    perform_activations_upgrades_and_migrations
854
+	 *
855
+	 * @access public
856
+	 * @return    void
857
+	 */
858
+	public function perform_activations_upgrades_and_migrations()
859
+	{
860
+		//first check if we had previously attempted to setup EE's directories but failed
861
+		if (EEH_Activation::upload_directories_incomplete()) {
862
+			EEH_Activation::create_upload_directories();
863
+		}
864
+		do_action('AHEE__EE_System__perform_activations_upgrades_and_migrations');
865
+	}
866
+
867
+
868
+
869
+	/**
870
+	 *    load_CPTs_and_session
871
+	 *
872
+	 * @access public
873
+	 * @return    void
874
+	 */
875
+	public function load_CPTs_and_session()
876
+	{
877
+		do_action('AHEE__EE_System__load_CPTs_and_session__start');
878
+		// register Custom Post Types
879
+		$this->registry->load_core('Register_CPTs');
880
+		do_action('AHEE__EE_System__load_CPTs_and_session__complete');
881
+	}
882
+
883
+
884
+
885
+	/**
886
+	 * load_controllers
887
+	 * this is the best place to load any additional controllers that needs access to EE core.
888
+	 * it is expected that all basic core EE systems, that are not dependant on the current request are loaded at this
889
+	 * time
890
+	 *
891
+	 * @access public
892
+	 * @return void
893
+	 */
894
+	public function load_controllers()
895
+	{
896
+		do_action('AHEE__EE_System__load_controllers__start');
897
+		// let's get it started
898
+		if ( ! is_admin() && ! EE_Maintenance_Mode::instance()->level()) {
899
+			do_action('AHEE__EE_System__load_controllers__load_front_controllers');
900
+			$this->registry->load_core('Front_Controller', array(), false);
901
+		} else if ( ! EE_FRONT_AJAX) {
902
+			do_action('AHEE__EE_System__load_controllers__load_admin_controllers');
903
+			EE_Registry::instance()->load_core('Admin');
904
+		}
905
+		do_action('AHEE__EE_System__load_controllers__complete');
906
+	}
907
+
908
+
909
+
910
+	/**
911
+	 * core_loaded_and_ready
912
+	 * all of the basic EE core should be loaded at this point and available regardless of M-Mode
913
+	 *
914
+	 * @access public
915
+	 * @return void
916
+	 */
917
+	public function core_loaded_and_ready()
918
+	{
919
+		do_action('AHEE__EE_System__core_loaded_and_ready');
920
+		// load_espresso_template_tags
921
+		if (is_readable(EE_PUBLIC . 'template_tags.php')) {
922
+			require_once(EE_PUBLIC . 'template_tags.php');
923
+		}
924
+		do_action('AHEE__EE_System__set_hooks_for_shortcodes_modules_and_addons');
925
+		$this->registry->load_core('Session');
926
+	}
927
+
928
+
929
+
930
+	/**
931
+	 * initialize
932
+	 * this is the best place to begin initializing client code
933
+	 *
934
+	 * @access public
935
+	 * @return void
936
+	 */
937
+	public function initialize()
938
+	{
939
+		do_action('AHEE__EE_System__initialize');
940
+	}
941
+
942
+
943
+
944
+	/**
945
+	 * initialize_last
946
+	 * this is run really late during the WP init hookpoint, and ensures that mostly everything else that needs to
947
+	 * initialize has done so
948
+	 *
949
+	 * @access public
950
+	 * @return void
951
+	 */
952
+	public function initialize_last()
953
+	{
954
+		do_action('AHEE__EE_System__initialize_last');
955
+	}
956
+
957
+
958
+
959
+	/**
960
+	 * set_hooks_for_shortcodes_modules_and_addons
961
+	 * this is the best place for other systems to set callbacks for hooking into other parts of EE
962
+	 * this happens at the very beginning of the wp_loaded hookpoint
963
+	 *
964
+	 * @access public
965
+	 * @return void
966
+	 */
967
+	public function set_hooks_for_shortcodes_modules_and_addons()
968
+	{
969
+		//		do_action( 'AHEE__EE_System__set_hooks_for_shortcodes_modules_and_addons' );
970
+	}
971
+
972
+
973
+
974
+	/**
975
+	 * do_not_cache
976
+	 * sets no cache headers and defines no cache constants for WP plugins
977
+	 *
978
+	 * @access public
979
+	 * @return void
980
+	 */
981
+	public static function do_not_cache()
982
+	{
983
+		// set no cache constants
984
+		if ( ! defined('DONOTCACHEPAGE')) {
985
+			define('DONOTCACHEPAGE', true);
986
+		}
987
+		if ( ! defined('DONOTCACHCEOBJECT')) {
988
+			define('DONOTCACHCEOBJECT', true);
989
+		}
990
+		if ( ! defined('DONOTCACHEDB')) {
991
+			define('DONOTCACHEDB', true);
992
+		}
993
+		// add no cache headers
994
+		add_action('send_headers', array('EE_System', 'nocache_headers'), 10);
995
+		// plus a little extra for nginx and Google Chrome
996
+		add_filter('nocache_headers', array('EE_System', 'extra_nocache_headers'), 10, 1);
997
+		// prevent browsers from prefetching of the rel='next' link, because it may contain content that interferes with the registration process
998
+		remove_action('wp_head', 'adjacent_posts_rel_link_wp_head');
999
+	}
1000
+
1001
+
1002
+
1003
+	/**
1004
+	 *    extra_nocache_headers
1005
+	 *
1006
+	 * @access    public
1007
+	 * @param $headers
1008
+	 * @return    array
1009
+	 */
1010
+	public static function extra_nocache_headers($headers)
1011
+	{
1012
+		// for NGINX
1013
+		$headers['X-Accel-Expires'] = 0;
1014
+		// plus extra for Google Chrome since it doesn't seem to respect "no-cache", but WILL respect "no-store"
1015
+		$headers['Cache-Control'] = 'no-store, no-cache, must-revalidate, max-age=0';
1016
+		return $headers;
1017
+	}
1018
+
1019
+
1020
+
1021
+	/**
1022
+	 *    nocache_headers
1023
+	 *
1024
+	 * @access    public
1025
+	 * @return    void
1026
+	 */
1027
+	public static function nocache_headers()
1028
+	{
1029
+		nocache_headers();
1030
+	}
1031
+
1032
+
1033
+
1034
+	/**
1035
+	 *    espresso_toolbar_items
1036
+	 *
1037
+	 * @access public
1038
+	 * @param  WP_Admin_Bar $admin_bar
1039
+	 * @return void
1040
+	 */
1041
+	public function espresso_toolbar_items(WP_Admin_Bar $admin_bar)
1042
+	{
1043
+		// if in full M-Mode, or its an AJAX request, or user is NOT an admin
1044
+		if (EE_Maintenance_Mode::instance()->level() == EE_Maintenance_Mode::level_2_complete_maintenance
1045
+			|| defined('DOING_AJAX')
1046
+			|| ! $this->registry->CAP->current_user_can('ee_read_ee', 'ee_admin_bar_menu_top_level')
1047
+		) {
1048
+			return;
1049
+		}
1050
+		do_action('AHEE_log', __FILE__, __FUNCTION__, '');
1051
+		$menu_class = 'espresso_menu_item_class';
1052
+		//we don't use the constants EVENTS_ADMIN_URL or REG_ADMIN_URL
1053
+		//because they're only defined in each of their respective constructors
1054
+		//and this might be a frontend request, in which case they aren't available
1055
+		$events_admin_url = admin_url("admin.php?page=espresso_events");
1056
+		$reg_admin_url = admin_url("admin.php?page=espresso_registrations");
1057
+		$extensions_admin_url = admin_url("admin.php?page=espresso_packages");
1058
+		//Top Level
1059
+		$admin_bar->add_menu(array(
1060
+			'id'    => 'espresso-toolbar',
1061
+			'title' => '<span class="ee-icon ee-icon-ee-cup-thick ee-icon-size-20"></span><span class="ab-label">'
1062
+					   . _x('Event Espresso', 'admin bar menu group label', 'event_espresso')
1063
+					   . '</span>',
1064
+			'href'  => $events_admin_url,
1065
+			'meta'  => array(
1066
+				'title' => __('Event Espresso', 'event_espresso'),
1067
+				'class' => $menu_class . 'first',
1068
+			),
1069
+		));
1070
+		//Events
1071
+		if ($this->registry->CAP->current_user_can('ee_read_events', 'ee_admin_bar_menu_espresso-toolbar-events')) {
1072
+			$admin_bar->add_menu(array(
1073
+				'id'     => 'espresso-toolbar-events',
1074
+				'parent' => 'espresso-toolbar',
1075
+				'title'  => __('Events', 'event_espresso'),
1076
+				'href'   => $events_admin_url,
1077
+				'meta'   => array(
1078
+					'title'  => __('Events', 'event_espresso'),
1079
+					'target' => '',
1080
+					'class'  => $menu_class,
1081
+				),
1082
+			));
1083
+		}
1084
+		if ($this->registry->CAP->current_user_can('ee_edit_events', 'ee_admin_bar_menu_espresso-toolbar-events-new')) {
1085
+			//Events Add New
1086
+			$admin_bar->add_menu(array(
1087
+				'id'     => 'espresso-toolbar-events-new',
1088
+				'parent' => 'espresso-toolbar-events',
1089
+				'title'  => __('Add New', 'event_espresso'),
1090
+				'href'   => EEH_URL::add_query_args_and_nonce(array('action' => 'create_new'), $events_admin_url),
1091
+				'meta'   => array(
1092
+					'title'  => __('Add New', 'event_espresso'),
1093
+					'target' => '',
1094
+					'class'  => $menu_class,
1095
+				),
1096
+			));
1097
+		}
1098
+		if (is_single() && (get_post_type() == 'espresso_events')) {
1099
+			//Current post
1100
+			global $post;
1101
+			if ($this->registry->CAP->current_user_can('ee_edit_event',
1102
+				'ee_admin_bar_menu_espresso-toolbar-events-edit', $post->ID)
1103
+			) {
1104
+				//Events Edit Current Event
1105
+				$admin_bar->add_menu(array(
1106
+					'id'     => 'espresso-toolbar-events-edit',
1107
+					'parent' => 'espresso-toolbar-events',
1108
+					'title'  => __('Edit Event', 'event_espresso'),
1109
+					'href'   => EEH_URL::add_query_args_and_nonce(array('action' => 'edit', 'post' => $post->ID),
1110
+						$events_admin_url),
1111
+					'meta'   => array(
1112
+						'title'  => __('Edit Event', 'event_espresso'),
1113
+						'target' => '',
1114
+						'class'  => $menu_class,
1115
+					),
1116
+				));
1117
+			}
1118
+		}
1119
+		//Events View
1120
+		if ($this->registry->CAP->current_user_can('ee_read_events',
1121
+			'ee_admin_bar_menu_espresso-toolbar-events-view')
1122
+		) {
1123
+			$admin_bar->add_menu(array(
1124
+				'id'     => 'espresso-toolbar-events-view',
1125
+				'parent' => 'espresso-toolbar-events',
1126
+				'title'  => __('View', 'event_espresso'),
1127
+				'href'   => $events_admin_url,
1128
+				'meta'   => array(
1129
+					'title'  => __('View', 'event_espresso'),
1130
+					'target' => '',
1131
+					'class'  => $menu_class,
1132
+				),
1133
+			));
1134
+		}
1135
+		if ($this->registry->CAP->current_user_can('ee_read_events', 'ee_admin_bar_menu_espresso-toolbar-events-all')) {
1136
+			//Events View All
1137
+			$admin_bar->add_menu(array(
1138
+				'id'     => 'espresso-toolbar-events-all',
1139
+				'parent' => 'espresso-toolbar-events-view',
1140
+				'title'  => __('All', 'event_espresso'),
1141
+				'href'   => $events_admin_url,
1142
+				'meta'   => array(
1143
+					'title'  => __('All', 'event_espresso'),
1144
+					'target' => '',
1145
+					'class'  => $menu_class,
1146
+				),
1147
+			));
1148
+		}
1149
+		if ($this->registry->CAP->current_user_can('ee_read_events',
1150
+			'ee_admin_bar_menu_espresso-toolbar-events-today')
1151
+		) {
1152
+			//Events View Today
1153
+			$admin_bar->add_menu(array(
1154
+				'id'     => 'espresso-toolbar-events-today',
1155
+				'parent' => 'espresso-toolbar-events-view',
1156
+				'title'  => __('Today', 'event_espresso'),
1157
+				'href'   => EEH_URL::add_query_args_and_nonce(array('action' => 'default', 'status' => 'today'),
1158
+					$events_admin_url),
1159
+				'meta'   => array(
1160
+					'title'  => __('Today', 'event_espresso'),
1161
+					'target' => '',
1162
+					'class'  => $menu_class,
1163
+				),
1164
+			));
1165
+		}
1166
+		if ($this->registry->CAP->current_user_can('ee_read_events',
1167
+			'ee_admin_bar_menu_espresso-toolbar-events-month')
1168
+		) {
1169
+			//Events View This Month
1170
+			$admin_bar->add_menu(array(
1171
+				'id'     => 'espresso-toolbar-events-month',
1172
+				'parent' => 'espresso-toolbar-events-view',
1173
+				'title'  => __('This Month', 'event_espresso'),
1174
+				'href'   => EEH_URL::add_query_args_and_nonce(array('action' => 'default', 'status' => 'month'),
1175
+					$events_admin_url),
1176
+				'meta'   => array(
1177
+					'title'  => __('This Month', 'event_espresso'),
1178
+					'target' => '',
1179
+					'class'  => $menu_class,
1180
+				),
1181
+			));
1182
+		}
1183
+		//Registration Overview
1184
+		if ($this->registry->CAP->current_user_can('ee_read_registrations',
1185
+			'ee_admin_bar_menu_espresso-toolbar-registrations')
1186
+		) {
1187
+			$admin_bar->add_menu(array(
1188
+				'id'     => 'espresso-toolbar-registrations',
1189
+				'parent' => 'espresso-toolbar',
1190
+				'title'  => __('Registrations', 'event_espresso'),
1191
+				'href'   => $reg_admin_url,
1192
+				'meta'   => array(
1193
+					'title'  => __('Registrations', 'event_espresso'),
1194
+					'target' => '',
1195
+					'class'  => $menu_class,
1196
+				),
1197
+			));
1198
+		}
1199
+		//Registration Overview Today
1200
+		if ($this->registry->CAP->current_user_can('ee_read_registrations',
1201
+			'ee_admin_bar_menu_espresso-toolbar-registrations-today')
1202
+		) {
1203
+			$admin_bar->add_menu(array(
1204
+				'id'     => 'espresso-toolbar-registrations-today',
1205
+				'parent' => 'espresso-toolbar-registrations',
1206
+				'title'  => __('Today', 'event_espresso'),
1207
+				'href'   => EEH_URL::add_query_args_and_nonce(array('action' => 'default', 'status' => 'today'),
1208
+					$reg_admin_url),
1209
+				'meta'   => array(
1210
+					'title'  => __('Today', 'event_espresso'),
1211
+					'target' => '',
1212
+					'class'  => $menu_class,
1213
+				),
1214
+			));
1215
+		}
1216
+		//Registration Overview Today Completed
1217
+		if ($this->registry->CAP->current_user_can('ee_read_registrations',
1218
+			'ee_admin_bar_menu_espresso-toolbar-registrations-today-approved')
1219
+		) {
1220
+			$admin_bar->add_menu(array(
1221
+				'id'     => 'espresso-toolbar-registrations-today-approved',
1222
+				'parent' => 'espresso-toolbar-registrations-today',
1223
+				'title'  => __('Approved', 'event_espresso'),
1224
+				'href'   => EEH_URL::add_query_args_and_nonce(array(
1225
+					'action'      => 'default',
1226
+					'status'      => 'today',
1227
+					'_reg_status' => EEM_Registration::status_id_approved,
1228
+				), $reg_admin_url),
1229
+				'meta'   => array(
1230
+					'title'  => __('Approved', 'event_espresso'),
1231
+					'target' => '',
1232
+					'class'  => $menu_class,
1233
+				),
1234
+			));
1235
+		}
1236
+		//Registration Overview Today Pending\
1237
+		if ($this->registry->CAP->current_user_can('ee_read_registrations',
1238
+			'ee_admin_bar_menu_espresso-toolbar-registrations-today-pending')
1239
+		) {
1240
+			$admin_bar->add_menu(array(
1241
+				'id'     => 'espresso-toolbar-registrations-today-pending',
1242
+				'parent' => 'espresso-toolbar-registrations-today',
1243
+				'title'  => __('Pending', 'event_espresso'),
1244
+				'href'   => EEH_URL::add_query_args_and_nonce(array(
1245
+					'action'     => 'default',
1246
+					'status'     => 'today',
1247
+					'reg_status' => EEM_Registration::status_id_pending_payment,
1248
+				), $reg_admin_url),
1249
+				'meta'   => array(
1250
+					'title'  => __('Pending Payment', 'event_espresso'),
1251
+					'target' => '',
1252
+					'class'  => $menu_class,
1253
+				),
1254
+			));
1255
+		}
1256
+		//Registration Overview Today Incomplete
1257
+		if ($this->registry->CAP->current_user_can('ee_read_registrations',
1258
+			'ee_admin_bar_menu_espresso-toolbar-registrations-today-not-approved')
1259
+		) {
1260
+			$admin_bar->add_menu(array(
1261
+				'id'     => 'espresso-toolbar-registrations-today-not-approved',
1262
+				'parent' => 'espresso-toolbar-registrations-today',
1263
+				'title'  => __('Not Approved', 'event_espresso'),
1264
+				'href'   => EEH_URL::add_query_args_and_nonce(array(
1265
+					'action'      => 'default',
1266
+					'status'      => 'today',
1267
+					'_reg_status' => EEM_Registration::status_id_not_approved,
1268
+				), $reg_admin_url),
1269
+				'meta'   => array(
1270
+					'title'  => __('Not Approved', 'event_espresso'),
1271
+					'target' => '',
1272
+					'class'  => $menu_class,
1273
+				),
1274
+			));
1275
+		}
1276
+		//Registration Overview Today Incomplete
1277
+		if ($this->registry->CAP->current_user_can('ee_read_registrations',
1278
+			'ee_admin_bar_menu_espresso-toolbar-registrations-today-cancelled')
1279
+		) {
1280
+			$admin_bar->add_menu(array(
1281
+				'id'     => 'espresso-toolbar-registrations-today-cancelled',
1282
+				'parent' => 'espresso-toolbar-registrations-today',
1283
+				'title'  => __('Cancelled', 'event_espresso'),
1284
+				'href'   => EEH_URL::add_query_args_and_nonce(array(
1285
+					'action'      => 'default',
1286
+					'status'      => 'today',
1287
+					'_reg_status' => EEM_Registration::status_id_cancelled,
1288
+				), $reg_admin_url),
1289
+				'meta'   => array(
1290
+					'title'  => __('Cancelled', 'event_espresso'),
1291
+					'target' => '',
1292
+					'class'  => $menu_class,
1293
+				),
1294
+			));
1295
+		}
1296
+		//Registration Overview This Month
1297
+		if ($this->registry->CAP->current_user_can('ee_read_registrations',
1298
+			'ee_admin_bar_menu_espresso-toolbar-registrations-month')
1299
+		) {
1300
+			$admin_bar->add_menu(array(
1301
+				'id'     => 'espresso-toolbar-registrations-month',
1302
+				'parent' => 'espresso-toolbar-registrations',
1303
+				'title'  => __('This Month', 'event_espresso'),
1304
+				'href'   => EEH_URL::add_query_args_and_nonce(array('action' => 'default', 'status' => 'month'),
1305
+					$reg_admin_url),
1306
+				'meta'   => array(
1307
+					'title'  => __('This Month', 'event_espresso'),
1308
+					'target' => '',
1309
+					'class'  => $menu_class,
1310
+				),
1311
+			));
1312
+		}
1313
+		//Registration Overview This Month Approved
1314
+		if ($this->registry->CAP->current_user_can('ee_read_registrations',
1315
+			'ee_admin_bar_menu_espresso-toolbar-registrations-month-approved')
1316
+		) {
1317
+			$admin_bar->add_menu(array(
1318
+				'id'     => 'espresso-toolbar-registrations-month-approved',
1319
+				'parent' => 'espresso-toolbar-registrations-month',
1320
+				'title'  => __('Approved', 'event_espresso'),
1321
+				'href'   => EEH_URL::add_query_args_and_nonce(array(
1322
+					'action'      => 'default',
1323
+					'status'      => 'month',
1324
+					'_reg_status' => EEM_Registration::status_id_approved,
1325
+				), $reg_admin_url),
1326
+				'meta'   => array(
1327
+					'title'  => __('Approved', 'event_espresso'),
1328
+					'target' => '',
1329
+					'class'  => $menu_class,
1330
+				),
1331
+			));
1332
+		}
1333
+		//Registration Overview This Month Pending
1334
+		if ($this->registry->CAP->current_user_can('ee_read_registrations',
1335
+			'ee_admin_bar_menu_espresso-toolbar-registrations-month-pending')
1336
+		) {
1337
+			$admin_bar->add_menu(array(
1338
+				'id'     => 'espresso-toolbar-registrations-month-pending',
1339
+				'parent' => 'espresso-toolbar-registrations-month',
1340
+				'title'  => __('Pending', 'event_espresso'),
1341
+				'href'   => EEH_URL::add_query_args_and_nonce(array(
1342
+					'action'      => 'default',
1343
+					'status'      => 'month',
1344
+					'_reg_status' => EEM_Registration::status_id_pending_payment,
1345
+				), $reg_admin_url),
1346
+				'meta'   => array(
1347
+					'title'  => __('Pending', 'event_espresso'),
1348
+					'target' => '',
1349
+					'class'  => $menu_class,
1350
+				),
1351
+			));
1352
+		}
1353
+		//Registration Overview This Month Not Approved
1354
+		if ($this->registry->CAP->current_user_can('ee_read_registrations',
1355
+			'ee_admin_bar_menu_espresso-toolbar-registrations-month-not-approved')
1356
+		) {
1357
+			$admin_bar->add_menu(array(
1358
+				'id'     => 'espresso-toolbar-registrations-month-not-approved',
1359
+				'parent' => 'espresso-toolbar-registrations-month',
1360
+				'title'  => __('Not Approved', 'event_espresso'),
1361
+				'href'   => EEH_URL::add_query_args_and_nonce(array(
1362
+					'action'      => 'default',
1363
+					'status'      => 'month',
1364
+					'_reg_status' => EEM_Registration::status_id_not_approved,
1365
+				), $reg_admin_url),
1366
+				'meta'   => array(
1367
+					'title'  => __('Not Approved', 'event_espresso'),
1368
+					'target' => '',
1369
+					'class'  => $menu_class,
1370
+				),
1371
+			));
1372
+		}
1373
+		//Registration Overview This Month Cancelled
1374
+		if ($this->registry->CAP->current_user_can('ee_read_registrations',
1375
+			'ee_admin_bar_menu_espresso-toolbar-registrations-month-cancelled')
1376
+		) {
1377
+			$admin_bar->add_menu(array(
1378
+				'id'     => 'espresso-toolbar-registrations-month-cancelled',
1379
+				'parent' => 'espresso-toolbar-registrations-month',
1380
+				'title'  => __('Cancelled', 'event_espresso'),
1381
+				'href'   => EEH_URL::add_query_args_and_nonce(array(
1382
+					'action'      => 'default',
1383
+					'status'      => 'month',
1384
+					'_reg_status' => EEM_Registration::status_id_cancelled,
1385
+				), $reg_admin_url),
1386
+				'meta'   => array(
1387
+					'title'  => __('Cancelled', 'event_espresso'),
1388
+					'target' => '',
1389
+					'class'  => $menu_class,
1390
+				),
1391
+			));
1392
+		}
1393
+		//Extensions & Services
1394
+		if ($this->registry->CAP->current_user_can('ee_read_ee',
1395
+			'ee_admin_bar_menu_espresso-toolbar-extensions-and-services')
1396
+		) {
1397
+			$admin_bar->add_menu(array(
1398
+				'id'     => 'espresso-toolbar-extensions-and-services',
1399
+				'parent' => 'espresso-toolbar',
1400
+				'title'  => __('Extensions & Services', 'event_espresso'),
1401
+				'href'   => $extensions_admin_url,
1402
+				'meta'   => array(
1403
+					'title'  => __('Extensions & Services', 'event_espresso'),
1404
+					'target' => '',
1405
+					'class'  => $menu_class,
1406
+				),
1407
+			));
1408
+		}
1409
+	}
1410
+
1411
+
1412
+
1413
+	/**
1414
+	 * simply hooks into "wp_list_pages_exclude" filter (for wp_list_pages method) and makes sure EE critical pages are
1415
+	 * never returned with the function.
1416
+	 *
1417
+	 * @param  array $exclude_array any existing pages being excluded are in this array.
1418
+	 * @return array
1419
+	 */
1420
+	public function remove_pages_from_wp_list_pages($exclude_array)
1421
+	{
1422
+		return array_merge($exclude_array, $this->registry->CFG->core->get_critical_pages_array());
1423
+	}
1424
+
1425
+
1426
+
1427
+
1428
+
1429
+
1430
+	/***********************************************        WP_ENQUEUE_SCRIPTS HOOK         ***********************************************/
1431
+	/**
1432
+	 *    wp_enqueue_scripts
1433
+	 *
1434
+	 * @access    public
1435
+	 * @return    void
1436
+	 */
1437
+	public function wp_enqueue_scripts()
1438
+	{
1439
+		// unlike other systems, EE_System_scripts loading is turned ON by default, but prior to the init hook, can be turned off via: add_filter( 'FHEE_load_EE_System_scripts', '__return_false' );
1440
+		if (apply_filters('FHEE_load_EE_System_scripts', true)) {
1441
+			// jquery_validate loading is turned OFF by default, but prior to the wp_enqueue_scripts hook, can be turned back on again via:  add_filter( 'FHEE_load_jquery_validate', '__return_true' );
1442
+			if (apply_filters('FHEE_load_jquery_validate', false)) {
1443
+				// register jQuery Validate and additional methods
1444
+				wp_register_script('jquery-validate', EE_GLOBAL_ASSETS_URL . 'scripts/jquery.validate.min.js',
1445
+					array('jquery'), '1.15.0', true);
1446
+				wp_register_script('jquery-validate-extra-methods',
1447
+					EE_GLOBAL_ASSETS_URL . 'scripts/jquery.validate.additional-methods.min.js',
1448
+					array('jquery', 'jquery-validate'), '1.15.0', true);
1449
+			}
1450
+		}
1451
+	}
1452 1452
 
1453 1453
 
1454 1454
 
Please login to merge, or discard this patch.